sdio_func.h 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. /*
  2. * include/linux/mmc/sdio_func.h
  3. *
  4. * Copyright 2007-2008 Pierre Ossman
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or (at
  9. * your option) any later version.
  10. */
  11. #ifndef LINUX_MMC_SDIO_FUNC_H
  12. #define LINUX_MMC_SDIO_FUNC_H
  13. #include <linux/device.h>
  14. #include <linux/mod_devicetable.h>
  15. #include <linux/mmc/pm.h>
  16. struct mmc_card;
  17. struct sdio_func;
  18. typedef void (sdio_irq_handler_t)(struct sdio_func *);
  19. /*
  20. * SDIO function CIS tuple (unknown to the core)
  21. */
  22. struct sdio_func_tuple {
  23. struct sdio_func_tuple *next;
  24. unsigned char code;
  25. unsigned char size;
  26. unsigned char data[0];
  27. };
  28. /*
  29. * SDIO function devices
  30. */
  31. struct sdio_func {
  32. struct mmc_card *card; /* the card this device belongs to */
  33. struct device dev; /* the device */
  34. sdio_irq_handler_t *irq_handler; /* IRQ callback */
  35. unsigned int num; /* function number */
  36. unsigned char class; /* standard interface class */
  37. unsigned short vendor; /* vendor id */
  38. unsigned short device; /* device id */
  39. unsigned max_blksize; /* maximum block size */
  40. unsigned cur_blksize; /* current block size */
  41. unsigned enable_timeout; /* max enable timeout in msec */
  42. unsigned int state; /* function state */
  43. #define SDIO_STATE_PRESENT (1<<0) /* present in sysfs */
  44. u8 *tmpbuf; /* DMA:able scratch buffer */
  45. unsigned num_info; /* number of info strings */
  46. const char **info; /* info strings */
  47. struct sdio_func_tuple *tuples;
  48. };
  49. #define sdio_func_present(f) ((f)->state & SDIO_STATE_PRESENT)
  50. #define sdio_func_set_present(f) ((f)->state |= SDIO_STATE_PRESENT)
  51. #define sdio_func_id(f) (dev_name(&(f)->dev))
  52. #define sdio_get_drvdata(f) dev_get_drvdata(&(f)->dev)
  53. #define sdio_set_drvdata(f,d) dev_set_drvdata(&(f)->dev, d)
  54. #define dev_to_sdio_func(d) container_of(d, struct sdio_func, dev)
  55. /*
  56. * SDIO function device driver
  57. */
  58. struct sdio_driver {
  59. char *name;
  60. const struct sdio_device_id *id_table;
  61. int (*probe)(struct sdio_func *, const struct sdio_device_id *);
  62. void (*remove)(struct sdio_func *);
  63. struct device_driver drv;
  64. };
  65. /**
  66. * SDIO_DEVICE - macro used to describe a specific SDIO device
  67. * @vend: the 16 bit manufacturer code
  68. * @dev: the 16 bit function id
  69. *
  70. * This macro is used to create a struct sdio_device_id that matches a
  71. * specific device. The class field will be set to SDIO_ANY_ID.
  72. */
  73. #define SDIO_DEVICE(vend,dev) \
  74. .class = SDIO_ANY_ID, \
  75. .vendor = (vend), .device = (dev)
  76. /**
  77. * SDIO_DEVICE_CLASS - macro used to describe a specific SDIO device class
  78. * @dev_class: the 8 bit standard interface code
  79. *
  80. * This macro is used to create a struct sdio_device_id that matches a
  81. * specific standard SDIO function type. The vendor and device fields will
  82. * be set to SDIO_ANY_ID.
  83. */
  84. #define SDIO_DEVICE_CLASS(dev_class) \
  85. .class = (dev_class), \
  86. .vendor = SDIO_ANY_ID, .device = SDIO_ANY_ID
  87. extern int sdio_register_driver(struct sdio_driver *);
  88. extern void sdio_unregister_driver(struct sdio_driver *);
  89. /*
  90. * SDIO I/O operations
  91. */
  92. extern void sdio_claim_host(struct sdio_func *func);
  93. extern void sdio_release_host(struct sdio_func *func);
  94. extern int sdio_enable_func(struct sdio_func *func);
  95. extern int sdio_disable_func(struct sdio_func *func);
  96. extern int sdio_set_block_size(struct sdio_func *func, unsigned blksz);
  97. extern int sdio_claim_irq(struct sdio_func *func, sdio_irq_handler_t *handler);
  98. extern int sdio_release_irq(struct sdio_func *func);
  99. extern unsigned int sdio_align_size(struct sdio_func *func, unsigned int sz);
  100. extern u8 sdio_readb(struct sdio_func *func, unsigned int addr, int *err_ret);
  101. extern u16 sdio_readw(struct sdio_func *func, unsigned int addr, int *err_ret);
  102. extern u32 sdio_readl(struct sdio_func *func, unsigned int addr, int *err_ret);
  103. extern int sdio_memcpy_fromio(struct sdio_func *func, void *dst,
  104. unsigned int addr, int count);
  105. extern int sdio_readsb(struct sdio_func *func, void *dst,
  106. unsigned int addr, int count);
  107. extern void sdio_writeb(struct sdio_func *func, u8 b,
  108. unsigned int addr, int *err_ret);
  109. extern void sdio_writew(struct sdio_func *func, u16 b,
  110. unsigned int addr, int *err_ret);
  111. extern void sdio_writel(struct sdio_func *func, u32 b,
  112. unsigned int addr, int *err_ret);
  113. extern u8 sdio_writeb_readb(struct sdio_func *func, u8 write_byte,
  114. unsigned int addr, int *err_ret);
  115. extern int sdio_memcpy_toio(struct sdio_func *func, unsigned int addr,
  116. void *src, int count);
  117. extern int sdio_writesb(struct sdio_func *func, unsigned int addr,
  118. void *src, int count);
  119. extern unsigned char sdio_f0_readb(struct sdio_func *func,
  120. unsigned int addr, int *err_ret);
  121. extern void sdio_f0_writeb(struct sdio_func *func, unsigned char b,
  122. unsigned int addr, int *err_ret);
  123. extern mmc_pm_flag_t sdio_get_host_pm_caps(struct sdio_func *func);
  124. extern int sdio_set_host_pm_flags(struct sdio_func *func, mmc_pm_flag_t flags);
  125. #endif /* LINUX_MMC_SDIO_FUNC_H */