1/*
2 * ocp_ids.h
3 *
4 * OCP device ids based on the ideas from PCI
5 *
6 * The numbers below are almost completely arbitrary, and in fact
7 * strings might work better.  -- paulus
8 *
9 * This program is free software; you can redistribute  it and/or modify it
10 * under  the terms of  the GNU General  Public License as published by the
11 * Free Software Foundation;  either version 2 of the  License, or (at your
12 * option) any later version.
13 */
14
15
16/* Vendor IDs 0x0001 - 0xFFFF copied from pci_ids.h */
17
18#define	OCP_VENDOR_INVALID	0x0000
19#define	OCP_VENDOR_ARM		0x0004
20#define OCP_VENDOR_FREESCALE	0x1057
21#define OCP_VENDOR_IBM		0x1014
22#define OCP_VENDOR_MOTOROLA	OCP_VENDOR_FREESCALE
23#define	OCP_VENDOR_XILINX	0x10ee
24#define	OCP_VENDOR_UNKNOWN	0xFFFF
25
26/* device identification */
27
28/* define type */
29#define OCP_FUNC_INVALID	0x0000
30
31/* system 0x0001 - 0x001F */
32
33/* Timers 0x0020 - 0x002F */
34
35/* Serial 0x0030 - 0x006F*/
36#define OCP_FUNC_16550		0x0031
37#define OCP_FUNC_IIC		0x0032
38#define OCP_FUNC_USB		0x0033
39#define OCP_FUNC_PSC_UART	0x0034
40
41/* Memory devices 0x0090 - 0x009F */
42#define OCP_FUNC_MAL		0x0090
43#define OCP_FUNC_DMA		0x0091
44
45/* Display 0x00A0 - 0x00AF */
46
47/* Sound 0x00B0 - 0x00BF */
48
49/* Mass Storage 0x00C0 - 0xxCF */
50#define OCP_FUNC_IDE		0x00C0
51
52/* Misc 0x00D0 - 0x00DF*/
53#define OCP_FUNC_GPIO		0x00D0
54#define OCP_FUNC_ZMII		0x00D1
55#define OCP_FUNC_PERFMON	0x00D2	/* Performance Monitor */
56#define OCP_FUNC_RGMII		0x00D3
57#define OCP_FUNC_TAH		0x00D4
58#define OCP_FUNC_SEC2		0x00D5	/* Crypto/Security 2.0 */
59
60/* Network 0x0200 - 0x02FF */
61#define OCP_FUNC_EMAC		0x0200
62#define OCP_FUNC_GFAR		0x0201	/* TSEC & FEC */
63
64/* Bridge devices 0xE00 - 0xEFF */
65#define OCP_FUNC_OPB		0x0E00
66
67#define OCP_FUNC_UNKNOWN	0xFFFF
68