ioport.h
上传用户:szlgq88
上传日期:2009-04-28
资源大小:48287k
文件大小:5k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /*
  2.  * ioport.h Definitions of routines for detecting, reserving and
  3.  * allocating system resources.
  4.  *
  5.  * Authors: Linus Torvalds
  6.  */
  7. #ifndef _LINUX_IOPORT_H
  8. #define _LINUX_IOPORT_H
  9. #include <linux/compiler.h>
  10. /*
  11.  * Resources are tree-like, allowing
  12.  * nesting etc..
  13.  */
  14. struct resource {
  15. const char *name;
  16. unsigned long start, end;
  17. unsigned long flags;
  18. struct resource *parent, *sibling, *child;
  19. };
  20. struct resource_list {
  21. struct resource_list *next;
  22. struct resource *res;
  23. struct pci_dev *dev;
  24. };
  25. /*
  26.  * IO resources have these defined flags.
  27.  */
  28. #define IORESOURCE_BITS 0x000000ff /* Bus-specific bits */
  29. #define IORESOURCE_IO 0x00000100 /* Resource type */
  30. #define IORESOURCE_MEM 0x00000200
  31. #define IORESOURCE_IRQ 0x00000400
  32. #define IORESOURCE_DMA 0x00000800
  33. #define IORESOURCE_PREFETCH 0x00001000 /* No side effects */
  34. #define IORESOURCE_READONLY 0x00002000
  35. #define IORESOURCE_CACHEABLE 0x00004000
  36. #define IORESOURCE_RANGELENGTH 0x00008000
  37. #define IORESOURCE_SHADOWABLE 0x00010000
  38. #define IORESOURCE_BUS_HAS_VGA 0x00080000
  39. #define IORESOURCE_DISABLED 0x10000000
  40. #define IORESOURCE_UNSET 0x20000000
  41. #define IORESOURCE_AUTO 0x40000000
  42. #define IORESOURCE_BUSY 0x80000000 /* Driver has marked this resource busy */
  43. /* ISA PnP IRQ specific bits (IORESOURCE_BITS) */
  44. #define IORESOURCE_IRQ_HIGHEDGE (1<<0)
  45. #define IORESOURCE_IRQ_LOWEDGE (1<<1)
  46. #define IORESOURCE_IRQ_HIGHLEVEL (1<<2)
  47. #define IORESOURCE_IRQ_LOWLEVEL (1<<3)
  48. /* ISA PnP DMA specific bits (IORESOURCE_BITS) */
  49. #define IORESOURCE_DMA_TYPE_MASK (3<<0)
  50. #define IORESOURCE_DMA_8BIT (0<<0)
  51. #define IORESOURCE_DMA_8AND16BIT (1<<0)
  52. #define IORESOURCE_DMA_16BIT (2<<0)
  53. #define IORESOURCE_DMA_MASTER (1<<2)
  54. #define IORESOURCE_DMA_BYTE (1<<3)
  55. #define IORESOURCE_DMA_WORD (1<<4)
  56. #define IORESOURCE_DMA_SPEED_MASK (3<<6)
  57. #define IORESOURCE_DMA_COMPATIBLE (0<<6)
  58. #define IORESOURCE_DMA_TYPEA (1<<6)
  59. #define IORESOURCE_DMA_TYPEB (2<<6)
  60. #define IORESOURCE_DMA_TYPEF (3<<6)
  61. /* ISA PnP memory I/O specific bits (IORESOURCE_BITS) */
  62. #define IORESOURCE_MEM_WRITEABLE (1<<0) /* dup: IORESOURCE_READONLY */
  63. #define IORESOURCE_MEM_CACHEABLE (1<<1) /* dup: IORESOURCE_CACHEABLE */
  64. #define IORESOURCE_MEM_RANGELENGTH (1<<2) /* dup: IORESOURCE_RANGELENGTH */
  65. #define IORESOURCE_MEM_TYPE_MASK (3<<3)
  66. #define IORESOURCE_MEM_8BIT (0<<3)
  67. #define IORESOURCE_MEM_16BIT (1<<3)
  68. #define IORESOURCE_MEM_8AND16BIT (2<<3)
  69. #define IORESOURCE_MEM_32BIT (3<<3)
  70. #define IORESOURCE_MEM_SHADOWABLE (1<<5) /* dup: IORESOURCE_SHADOWABLE */
  71. #define IORESOURCE_MEM_EXPANSIONROM (1<<6)
  72. /* PCI ROM control bits (IORESOURCE_BITS) */
  73. #define IORESOURCE_ROM_ENABLE (1<<0) /* ROM is enabled, same as PCI_ROM_ADDRESS_ENABLE */
  74. #define IORESOURCE_ROM_SHADOW (1<<1) /* ROM is copy at C000:0 */
  75. #define IORESOURCE_ROM_COPY (1<<2) /* ROM is alloc'd copy, resource field overlaid */
  76. /* PC/ISA/whatever - the normal PC address spaces: IO and memory */
  77. extern struct resource ioport_resource;
  78. extern struct resource iomem_resource;
  79. extern int request_resource(struct resource *root, struct resource *new);
  80. extern struct resource * ____request_resource(struct resource *root, struct resource *new);
  81. extern int release_resource(struct resource *new);
  82. extern int insert_resource(struct resource *parent, struct resource *new);
  83. extern int allocate_resource(struct resource *root, struct resource *new,
  84.      unsigned long size,
  85.      unsigned long min, unsigned long max,
  86.      unsigned long align,
  87.      void (*alignf)(void *, struct resource *,
  88.     unsigned long, unsigned long),
  89.      void *alignf_data);
  90. int adjust_resource(struct resource *res, unsigned long start,
  91.     unsigned long size);
  92. /* Convenience shorthand with allocation */
  93. #define request_region(start,n,name) __request_region(&ioport_resource, (start), (n), (name))
  94. #define request_mem_region(start,n,name) __request_region(&iomem_resource, (start), (n), (name))
  95. #define rename_region(region, newname) do { (region)->name = (newname); } while (0)
  96. extern struct resource * __request_region(struct resource *, unsigned long start, unsigned long n, const char *name);
  97. /* Compatibility cruft */
  98. #define release_region(start,n) __release_region(&ioport_resource, (start), (n))
  99. #define check_mem_region(start,n) __check_region(&iomem_resource, (start), (n))
  100. #define release_mem_region(start,n) __release_region(&iomem_resource, (start), (n))
  101. extern int __check_region(struct resource *, unsigned long, unsigned long);
  102. extern void __release_region(struct resource *, unsigned long, unsigned long);
  103. static inline int __deprecated check_region(unsigned long s, unsigned long n)
  104. {
  105. return __check_region(&ioport_resource, s, n);
  106. }
  107. #endif /* _LINUX_IOPORT_H */