ISAPNP: handle independent options following dependent ones
[deliverable/linux.git] / drivers / pnp / base.h
CommitLineData
1da177e4
LT
1extern spinlock_t pnp_lock;
2void *pnp_alloc(long size);
62cfb298
BH
3
4int pnp_register_protocol(struct pnp_protocol *protocol);
5void pnp_unregister_protocol(struct pnp_protocol *protocol);
6
25eb8461
BH
7#define PNP_EISA_ID_MASK 0x7fffffff
8void pnp_eisa_id_to_string(u32 id, char *str);
bda1e4e5 9struct pnp_dev *pnp_alloc_dev(struct pnp_protocol *, int id, char *pnpid);
6bf2aab2 10struct pnp_card *pnp_alloc_card(struct pnp_protocol *, int id, char *pnpid);
62cfb298
BH
11
12int pnp_add_device(struct pnp_dev *dev);
772defc6 13struct pnp_id *pnp_add_id(struct pnp_dev *dev, char *id);
1da177e4 14int pnp_interface_attach_device(struct pnp_dev *dev);
62cfb298
BH
15
16int pnp_add_card(struct pnp_card *card);
17struct pnp_id *pnp_add_card_id(struct pnp_card *card, char *id);
18void pnp_remove_card(struct pnp_card *card);
19int pnp_add_card_device(struct pnp_card *card, struct pnp_dev *dev);
20void pnp_remove_card_device(struct pnp_dev *dev);
21
a1802c42 22struct pnp_port {
169aaffe
BH
23 resource_size_t min; /* min base number */
24 resource_size_t max; /* max base number */
25 resource_size_t align; /* align boundary */
26 resource_size_t size; /* size of range */
a1802c42
BH
27 unsigned char flags; /* port flags */
28 unsigned char pad; /* pad */
29 struct pnp_port *next; /* next port */
30};
31
32#define PNP_IRQ_NR 256
7aefff51
BH
33typedef struct { DECLARE_BITMAP(bits, PNP_IRQ_NR); } pnp_irq_mask_t;
34
a1802c42 35struct pnp_irq {
7aefff51 36 pnp_irq_mask_t map; /* bitmap for IRQ lines */
a1802c42
BH
37 unsigned char flags; /* IRQ flags */
38 unsigned char pad; /* pad */
39 struct pnp_irq *next; /* next IRQ */
40};
41
42struct pnp_dma {
43 unsigned char map; /* bitmask for DMA channels */
44 unsigned char flags; /* DMA flags */
45 struct pnp_dma *next; /* next port */
46};
47
48struct pnp_mem {
169aaffe
BH
49 resource_size_t min; /* min base number */
50 resource_size_t max; /* max base number */
51 resource_size_t align; /* align boundary */
52 resource_size_t size; /* size of range */
a1802c42
BH
53 unsigned char flags; /* memory flags */
54 unsigned char pad; /* pad */
55 struct pnp_mem *next; /* next memory resource */
56};
57
58#define PNP_RES_PRIORITY_PREFERRED 0
59#define PNP_RES_PRIORITY_ACCEPTABLE 1
60#define PNP_RES_PRIORITY_FUNCTIONAL 2
61#define PNP_RES_PRIORITY_INVALID 65535
62
63struct pnp_option {
64 unsigned short priority; /* priority */
65 struct pnp_port *port; /* first port */
66 struct pnp_irq *irq; /* first IRQ */
67 struct pnp_dma *dma; /* first DMA */
68 struct pnp_mem *mem; /* first memory resource */
69 struct pnp_option *next; /* used to chain dependent resources */
70};
71
bc033c9b 72struct pnp_option *pnp_build_option(int priority);
62cfb298
BH
73struct pnp_option *pnp_register_independent_option(struct pnp_dev *dev);
74struct pnp_option *pnp_register_dependent_option(struct pnp_dev *dev,
75 int priority);
76int pnp_register_irq_resource(struct pnp_dev *dev, struct pnp_option *option,
c227536b 77 pnp_irq_mask_t *map, unsigned char flags);
62cfb298 78int pnp_register_dma_resource(struct pnp_dev *dev, struct pnp_option *option,
c227536b 79 unsigned char map, unsigned char flags);
62cfb298 80int pnp_register_port_resource(struct pnp_dev *dev, struct pnp_option *option,
c227536b
BH
81 resource_size_t min, resource_size_t max,
82 resource_size_t align, resource_size_t size,
83 unsigned char flags);
62cfb298 84int pnp_register_mem_resource(struct pnp_dev *dev, struct pnp_option *option,
c227536b
BH
85 resource_size_t min, resource_size_t max,
86 resource_size_t align, resource_size_t size,
87 unsigned char flags);
62cfb298
BH
88void pnp_init_resources(struct pnp_dev *dev);
89
1da177e4
LT
90void pnp_fixup_device(struct pnp_dev *dev);
91void pnp_free_option(struct pnp_option *option);
92int __pnp_add_device(struct pnp_dev *dev);
93void __pnp_remove_device(struct pnp_dev *dev);
94
f5d94ff0
BH
95int pnp_check_port(struct pnp_dev *dev, struct resource *res);
96int pnp_check_mem(struct pnp_dev *dev, struct resource *res);
97int pnp_check_irq(struct pnp_dev *dev, struct resource *res);
98int pnp_check_dma(struct pnp_dev *dev, struct resource *res);
81b5c75f 99
9fdee4e0 100char *pnp_resource_type_name(struct resource *res);
81b5c75f 101void dbg_pnp_show_resources(struct pnp_dev *dev, char *desc);
d948a8da 102
aee3ad81 103void pnp_free_resources(struct pnp_dev *dev);
940e98db 104int pnp_resource_type(struct resource *res);
02d83b5d 105
784f01d5 106struct pnp_resource {
aee3ad81 107 struct list_head list;
784f01d5
BH
108 struct resource res;
109};
110
aee3ad81 111void pnp_free_resource(struct pnp_resource *pnp_res);
dbddd038
BH
112
113struct pnp_resource *pnp_add_irq_resource(struct pnp_dev *dev, int irq,
114 int flags);
dc16f5f2
BH
115struct pnp_resource *pnp_add_dma_resource(struct pnp_dev *dev, int dma,
116 int flags);
cc8c2e30
BH
117struct pnp_resource *pnp_add_io_resource(struct pnp_dev *dev,
118 resource_size_t start,
119 resource_size_t end, int flags);
d6180f36
BH
120struct pnp_resource *pnp_add_mem_resource(struct pnp_dev *dev,
121 resource_size_t start,
122 resource_size_t end, int flags);
This page took 0.360111 seconds and 5 git commands to generate.