blob: 3126e45820087ecf8c07ead194bd5aedaa2e2724 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001extern spinlock_t pnp_lock;
2void *pnp_alloc(long size);
Bjorn Helgaas62cfb292008-04-28 16:34:40 -06003
4int pnp_register_protocol(struct pnp_protocol *protocol);
5void pnp_unregister_protocol(struct pnp_protocol *protocol);
6
Bjorn Helgaas25eb8462008-04-28 16:33:53 -06007#define PNP_EISA_ID_MASK 0x7fffffff
8void pnp_eisa_id_to_string(u32 id, char *str);
Bjorn Helgaasbda1e4e2008-04-28 16:33:54 -06009struct pnp_dev *pnp_alloc_dev(struct pnp_protocol *, int id, char *pnpid);
Bjorn Helgaas6bf2aab2008-04-28 16:33:58 -060010struct pnp_card *pnp_alloc_card(struct pnp_protocol *, int id, char *pnpid);
Bjorn Helgaas62cfb292008-04-28 16:34:40 -060011
12int pnp_add_device(struct pnp_dev *dev);
Bjorn Helgaas772defc2008-04-28 16:33:52 -060013struct pnp_id *pnp_add_id(struct pnp_dev *dev, char *id);
Linus Torvalds1da177e2005-04-16 15:20:36 -070014int pnp_interface_attach_device(struct pnp_dev *dev);
Bjorn Helgaas62cfb292008-04-28 16:34:40 -060015
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
Bjorn Helgaasa1802c42008-06-27 16:57:04 -060022struct pnp_port {
23 unsigned short min; /* min base number */
24 unsigned short max; /* max base number */
25 unsigned char align; /* align boundary */
26 unsigned char size; /* size of range */
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
33struct pnp_irq {
34 DECLARE_BITMAP(map, PNP_IRQ_NR); /* bitmask for IRQ lines */
35 unsigned char flags; /* IRQ flags */
36 unsigned char pad; /* pad */
37 struct pnp_irq *next; /* next IRQ */
38};
39
40struct pnp_dma {
41 unsigned char map; /* bitmask for DMA channels */
42 unsigned char flags; /* DMA flags */
43 struct pnp_dma *next; /* next port */
44};
45
46struct pnp_mem {
47 unsigned int min; /* min base number */
48 unsigned int max; /* max base number */
49 unsigned int align; /* align boundary */
50 unsigned int size; /* size of range */
51 unsigned char flags; /* memory flags */
52 unsigned char pad; /* pad */
53 struct pnp_mem *next; /* next memory resource */
54};
55
56#define PNP_RES_PRIORITY_PREFERRED 0
57#define PNP_RES_PRIORITY_ACCEPTABLE 1
58#define PNP_RES_PRIORITY_FUNCTIONAL 2
59#define PNP_RES_PRIORITY_INVALID 65535
60
61struct pnp_option {
62 unsigned short priority; /* priority */
63 struct pnp_port *port; /* first port */
64 struct pnp_irq *irq; /* first IRQ */
65 struct pnp_dma *dma; /* first DMA */
66 struct pnp_mem *mem; /* first memory resource */
67 struct pnp_option *next; /* used to chain dependent resources */
68};
69
Rene Hermanbc033c92008-05-14 16:05:34 -070070struct pnp_option *pnp_build_option(int priority);
Bjorn Helgaas62cfb292008-04-28 16:34:40 -060071struct pnp_option *pnp_register_independent_option(struct pnp_dev *dev);
72struct pnp_option *pnp_register_dependent_option(struct pnp_dev *dev,
73 int priority);
74int pnp_register_irq_resource(struct pnp_dev *dev, struct pnp_option *option,
75 struct pnp_irq *data);
76int pnp_register_dma_resource(struct pnp_dev *dev, struct pnp_option *option,
77 struct pnp_dma *data);
78int pnp_register_port_resource(struct pnp_dev *dev, struct pnp_option *option,
79 struct pnp_port *data);
80int pnp_register_mem_resource(struct pnp_dev *dev, struct pnp_option *option,
81 struct pnp_mem *data);
82void pnp_init_resources(struct pnp_dev *dev);
83
Linus Torvalds1da177e2005-04-16 15:20:36 -070084void pnp_fixup_device(struct pnp_dev *dev);
85void pnp_free_option(struct pnp_option *option);
86int __pnp_add_device(struct pnp_dev *dev);
87void __pnp_remove_device(struct pnp_dev *dev);
88
Bjorn Helgaasf5d94ff2008-04-28 16:34:22 -060089int pnp_check_port(struct pnp_dev *dev, struct resource *res);
90int pnp_check_mem(struct pnp_dev *dev, struct resource *res);
91int pnp_check_irq(struct pnp_dev *dev, struct resource *res);
92int pnp_check_dma(struct pnp_dev *dev, struct resource *res);
Bjorn Helgaas81b5c752008-04-28 16:34:08 -060093
Bjorn Helgaas9fdee4e2008-06-27 16:56:55 -060094char *pnp_resource_type_name(struct resource *res);
Bjorn Helgaas81b5c752008-04-28 16:34:08 -060095void dbg_pnp_show_resources(struct pnp_dev *dev, char *desc);
Bjorn Helgaasd948a8d2008-04-28 16:34:13 -060096
Bjorn Helgaasaee3ad82008-06-27 16:56:57 -060097void pnp_free_resources(struct pnp_dev *dev);
Bjorn Helgaas940e98d2008-06-27 16:56:54 -060098int pnp_resource_type(struct resource *res);
Bjorn Helgaas02d83b52008-04-28 16:34:28 -060099
Bjorn Helgaas784f01d2008-04-28 16:34:30 -0600100struct pnp_resource {
Bjorn Helgaasaee3ad82008-06-27 16:56:57 -0600101 struct list_head list;
Bjorn Helgaas784f01d2008-04-28 16:34:30 -0600102 struct resource res;
103};
104
Bjorn Helgaasaee3ad82008-06-27 16:56:57 -0600105void pnp_free_resource(struct pnp_resource *pnp_res);
Bjorn Helgaasdbddd032008-04-28 16:34:34 -0600106
107struct pnp_resource *pnp_add_irq_resource(struct pnp_dev *dev, int irq,
108 int flags);
Bjorn Helgaasdc16f5f2008-04-28 16:34:35 -0600109struct pnp_resource *pnp_add_dma_resource(struct pnp_dev *dev, int dma,
110 int flags);
Bjorn Helgaascc8c2e32008-04-28 16:34:36 -0600111struct pnp_resource *pnp_add_io_resource(struct pnp_dev *dev,
112 resource_size_t start,
113 resource_size_t end, int flags);
Bjorn Helgaasd6180f32008-04-28 16:34:37 -0600114struct pnp_resource *pnp_add_mem_resource(struct pnp_dev *dev,
115 resource_size_t start,
116 resource_size_t end, int flags);