base.h 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. /*
  2. * Copyright (C) 2008 Hewlett-Packard Development Company, L.P.
  3. * Bjorn Helgaas <bjorn.helgaas@hp.com>
  4. */
  5. extern spinlock_t pnp_lock;
  6. extern struct device_attribute pnp_interface_attrs[];
  7. void *pnp_alloc(long size);
  8. int pnp_register_protocol(struct pnp_protocol *protocol);
  9. void pnp_unregister_protocol(struct pnp_protocol *protocol);
  10. #define PNP_EISA_ID_MASK 0x7fffffff
  11. void pnp_eisa_id_to_string(u32 id, char *str);
  12. struct pnp_dev *pnp_alloc_dev(struct pnp_protocol *, int id, char *pnpid);
  13. struct pnp_card *pnp_alloc_card(struct pnp_protocol *, int id, char *pnpid);
  14. int pnp_add_device(struct pnp_dev *dev);
  15. struct pnp_id *pnp_add_id(struct pnp_dev *dev, char *id);
  16. int pnp_add_card(struct pnp_card *card);
  17. void pnp_remove_card(struct pnp_card *card);
  18. int pnp_add_card_device(struct pnp_card *card, struct pnp_dev *dev);
  19. void pnp_remove_card_device(struct pnp_dev *dev);
  20. struct pnp_port {
  21. resource_size_t min; /* min base number */
  22. resource_size_t max; /* max base number */
  23. resource_size_t align; /* align boundary */
  24. resource_size_t size; /* size of range */
  25. unsigned char flags; /* port flags */
  26. };
  27. #define PNP_IRQ_NR 256
  28. typedef struct { DECLARE_BITMAP(bits, PNP_IRQ_NR); } pnp_irq_mask_t;
  29. struct pnp_irq {
  30. pnp_irq_mask_t map; /* bitmap for IRQ lines */
  31. unsigned char flags; /* IRQ flags */
  32. };
  33. struct pnp_dma {
  34. unsigned char map; /* bitmask for DMA channels */
  35. unsigned char flags; /* DMA flags */
  36. };
  37. struct pnp_mem {
  38. resource_size_t min; /* min base number */
  39. resource_size_t max; /* max base number */
  40. resource_size_t align; /* align boundary */
  41. resource_size_t size; /* size of range */
  42. unsigned char flags; /* memory flags */
  43. };
  44. #define PNP_OPTION_DEPENDENT 0x80000000
  45. #define PNP_OPTION_SET_MASK 0xffff
  46. #define PNP_OPTION_SET_SHIFT 12
  47. #define PNP_OPTION_PRIORITY_MASK 0xfff
  48. #define PNP_OPTION_PRIORITY_SHIFT 0
  49. #define PNP_RES_PRIORITY_PREFERRED 0
  50. #define PNP_RES_PRIORITY_ACCEPTABLE 1
  51. #define PNP_RES_PRIORITY_FUNCTIONAL 2
  52. #define PNP_RES_PRIORITY_INVALID PNP_OPTION_PRIORITY_MASK
  53. struct pnp_option {
  54. struct list_head list;
  55. unsigned int flags; /* independent/dependent, set, priority */
  56. unsigned long type; /* IORESOURCE_{IO,MEM,IRQ,DMA} */
  57. union {
  58. struct pnp_port port;
  59. struct pnp_irq irq;
  60. struct pnp_dma dma;
  61. struct pnp_mem mem;
  62. } u;
  63. };
  64. int pnp_register_irq_resource(struct pnp_dev *dev, unsigned int option_flags,
  65. pnp_irq_mask_t *map, unsigned char flags);
  66. int pnp_register_dma_resource(struct pnp_dev *dev, unsigned int option_flags,
  67. unsigned char map, unsigned char flags);
  68. int pnp_register_port_resource(struct pnp_dev *dev, unsigned int option_flags,
  69. resource_size_t min, resource_size_t max,
  70. resource_size_t align, resource_size_t size,
  71. unsigned char flags);
  72. int pnp_register_mem_resource(struct pnp_dev *dev, unsigned int option_flags,
  73. resource_size_t min, resource_size_t max,
  74. resource_size_t align, resource_size_t size,
  75. unsigned char flags);
  76. static inline int pnp_option_is_dependent(struct pnp_option *option)
  77. {
  78. return option->flags & PNP_OPTION_DEPENDENT ? 1 : 0;
  79. }
  80. static inline unsigned int pnp_option_set(struct pnp_option *option)
  81. {
  82. return (option->flags >> PNP_OPTION_SET_SHIFT) & PNP_OPTION_SET_MASK;
  83. }
  84. static inline unsigned int pnp_option_priority(struct pnp_option *option)
  85. {
  86. return (option->flags >> PNP_OPTION_PRIORITY_SHIFT) &
  87. PNP_OPTION_PRIORITY_MASK;
  88. }
  89. static inline unsigned int pnp_new_dependent_set(struct pnp_dev *dev,
  90. int priority)
  91. {
  92. unsigned int flags;
  93. if (priority > PNP_RES_PRIORITY_FUNCTIONAL) {
  94. dev_warn(&dev->dev, "invalid dependent option priority %d "
  95. "clipped to %d", priority,
  96. PNP_RES_PRIORITY_INVALID);
  97. priority = PNP_RES_PRIORITY_INVALID;
  98. }
  99. flags = PNP_OPTION_DEPENDENT |
  100. ((dev->num_dependent_sets & PNP_OPTION_SET_MASK) <<
  101. PNP_OPTION_SET_SHIFT) |
  102. ((priority & PNP_OPTION_PRIORITY_MASK) <<
  103. PNP_OPTION_PRIORITY_SHIFT);
  104. dev->num_dependent_sets++;
  105. return flags;
  106. }
  107. char *pnp_option_priority_name(struct pnp_option *option);
  108. void dbg_pnp_show_option(struct pnp_dev *dev, struct pnp_option *option);
  109. void pnp_init_resources(struct pnp_dev *dev);
  110. void pnp_fixup_device(struct pnp_dev *dev);
  111. void pnp_free_options(struct pnp_dev *dev);
  112. int __pnp_add_device(struct pnp_dev *dev);
  113. void __pnp_remove_device(struct pnp_dev *dev);
  114. int pnp_check_port(struct pnp_dev *dev, struct resource *res);
  115. int pnp_check_mem(struct pnp_dev *dev, struct resource *res);
  116. int pnp_check_irq(struct pnp_dev *dev, struct resource *res);
  117. int pnp_check_dma(struct pnp_dev *dev, struct resource *res);
  118. char *pnp_resource_type_name(struct resource *res);
  119. void dbg_pnp_show_resources(struct pnp_dev *dev, char *desc);
  120. void pnp_free_resources(struct pnp_dev *dev);
  121. unsigned long pnp_resource_type(struct resource *res);
  122. struct pnp_resource {
  123. struct list_head list;
  124. struct resource res;
  125. };
  126. void pnp_free_resource(struct pnp_resource *pnp_res);
  127. struct pnp_resource *pnp_add_irq_resource(struct pnp_dev *dev, int irq,
  128. int flags);
  129. struct pnp_resource *pnp_add_dma_resource(struct pnp_dev *dev, int dma,
  130. int flags);
  131. struct pnp_resource *pnp_add_io_resource(struct pnp_dev *dev,
  132. resource_size_t start,
  133. resource_size_t end, int flags);
  134. struct pnp_resource *pnp_add_mem_resource(struct pnp_dev *dev,
  135. resource_size_t start,
  136. resource_size_t end, int flags);
  137. extern int pnp_debug;
  138. #if defined(CONFIG_PNP_DEBUG_MESSAGES)
  139. #define pnp_dbg(dev, format, arg...) \
  140. ({ if (pnp_debug) dev_printk(KERN_DEBUG, dev, format, ## arg); 0; })
  141. #else
  142. #define pnp_dbg(dev, format, arg...) \
  143. ({ if (0) dev_printk(KERN_DEBUG, dev, format, ## arg); 0; })
  144. #endif