Add the rt linux 4.1.3-rt3 as base
[kvmfornfv.git] / kernel / include / uapi / linux / zorro.h
1 /*
2  *  linux/zorro.h -- Amiga AutoConfig (Zorro) Bus Definitions
3  *
4  *  Copyright (C) 1995--2003 Geert Uytterhoeven
5  *
6  *  This file is subject to the terms and conditions of the GNU General Public
7  *  License.  See the file COPYING in the main directory of this archive
8  *  for more details.
9  */
10
11 #ifndef _UAPI_LINUX_ZORRO_H
12 #define _UAPI_LINUX_ZORRO_H
13
14 #include <linux/types.h>
15
16
17     /*
18      *  Each Zorro board has a 32-bit ID of the form
19      *
20      *      mmmmmmmmmmmmmmmmppppppppeeeeeeee
21      *
22      *  with
23      *
24      *      mmmmmmmmmmmmmmmm    16-bit Manufacturer ID (assigned by CBM (sigh))
25      *      pppppppp            8-bit Product ID (assigned by manufacturer)
26      *      eeeeeeee            8-bit Extended Product ID (currently only used
27      *                          for some GVP boards)
28      */
29
30
31 #define ZORRO_MANUF(id)         ((id) >> 16)
32 #define ZORRO_PROD(id)          (((id) >> 8) & 0xff)
33 #define ZORRO_EPC(id)           ((id) & 0xff)
34
35 #define ZORRO_ID(manuf, prod, epc) \
36         ((ZORRO_MANUF_##manuf << 16) | ((prod) << 8) | (epc))
37
38 typedef __u32 zorro_id;
39
40
41 /* Include the ID list */
42 #include <linux/zorro_ids.h>
43
44
45     /*
46      *  GVP identifies most of its products through the 'extended product code'
47      *  (epc). The epc has to be ANDed with the GVP_PRODMASK before the
48      *  identification.
49      */
50
51 #define GVP_PRODMASK            (0xf8)
52 #define GVP_SCSICLKMASK         (0x01)
53
54 enum GVP_flags {
55         GVP_IO                  = 0x01,
56         GVP_ACCEL               = 0x02,
57         GVP_SCSI                = 0x04,
58         GVP_24BITDMA            = 0x08,
59         GVP_25BITDMA            = 0x10,
60         GVP_NOBANK              = 0x20,
61         GVP_14MHZ               = 0x40,
62 };
63
64
65 struct Node {
66         __be32 ln_Succ;         /* Pointer to next (successor) */
67         __be32 ln_Pred;         /* Pointer to previous (predecessor) */
68         __u8   ln_Type;
69         __s8   ln_Pri;          /* Priority, for sorting */
70         __be32 ln_Name;         /* ID string, null terminated */
71 } __packed;
72
73 struct ExpansionRom {
74         /* -First 16 bytes of the expansion ROM */
75         __u8   er_Type;         /* Board type, size and flags */
76         __u8   er_Product;      /* Product number, assigned by manufacturer */
77         __u8   er_Flags;                /* Flags */
78         __u8   er_Reserved03;   /* Must be zero ($ff inverted) */
79         __be16 er_Manufacturer; /* Unique ID, ASSIGNED BY COMMODORE-AMIGA! */
80         __be32 er_SerialNumber; /* Available for use by manufacturer */
81         __be16 er_InitDiagVec;  /* Offset to optional "DiagArea" structure */
82         __u8   er_Reserved0c;
83         __u8   er_Reserved0d;
84         __u8   er_Reserved0e;
85         __u8   er_Reserved0f;
86 } __packed;
87
88 /* er_Type board type bits */
89 #define ERT_TYPEMASK    0xc0
90 #define ERT_ZORROII     0xc0
91 #define ERT_ZORROIII    0x80
92
93 /* other bits defined in er_Type */
94 #define ERTB_MEMLIST    5               /* Link RAM into free memory list */
95 #define ERTF_MEMLIST    (1<<5)
96
97 struct ConfigDev {
98         struct Node     cd_Node;
99         __u8            cd_Flags;       /* (read/write) */
100         __u8            cd_Pad;         /* reserved */
101         struct ExpansionRom cd_Rom;     /* copy of board's expansion ROM */
102         __be32          cd_BoardAddr;   /* where in memory the board was placed */
103         __be32          cd_BoardSize;   /* size of board in bytes */
104         __be16          cd_SlotAddr;    /* which slot number (PRIVATE) */
105         __be16          cd_SlotSize;    /* number of slots (PRIVATE) */
106         __be32          cd_Driver;      /* pointer to node of driver */
107         __be32          cd_NextCD;      /* linked list of drivers to config */
108         __be32          cd_Unused[4];   /* for whatever the driver wants */
109 } __packed;
110
111 #define ZORRO_NUM_AUTO          16
112
113 #endif /* _UAPI_LINUX_ZORRO_H */