whci.c 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. /*
  2. * WHCI UWB Multi-interface Controller enumerator.
  3. *
  4. * Copyright (C) 2007 Cambridge Silicon Radio Ltd.
  5. *
  6. * This file is released under the GNU GPL v2.
  7. */
  8. #include <linux/delay.h>
  9. #include <linux/kernel.h>
  10. #include <linux/module.h>
  11. #include <linux/pci.h>
  12. #include <linux/dma-mapping.h>
  13. #include <linux/slab.h>
  14. #include <linux/uwb/whci.h>
  15. #include <linux/uwb/umc.h>
  16. struct whci_card {
  17. struct pci_dev *pci;
  18. void __iomem *uwbbase;
  19. u8 n_caps;
  20. struct umc_dev *devs[0];
  21. };
  22. /* Fix faulty HW :( */
  23. static
  24. u64 whci_capdata_quirks(struct whci_card *card, u64 capdata)
  25. {
  26. u64 capdata_orig = capdata;
  27. struct pci_dev *pci_dev = card->pci;
  28. if (pci_dev->vendor == PCI_VENDOR_ID_INTEL
  29. && (pci_dev->device == 0x0c3b || pci_dev->device == 0004)
  30. && pci_dev->class == 0x0d1010) {
  31. switch (UWBCAPDATA_TO_CAP_ID(capdata)) {
  32. /* WLP capability has 0x100 bytes of aperture */
  33. case 0x80:
  34. capdata |= 0x40 << 8; break;
  35. /* WUSB capability has 0x80 bytes of aperture
  36. * and ID is 1 */
  37. case 0x02:
  38. capdata &= ~0xffff;
  39. capdata |= 0x2001;
  40. break;
  41. }
  42. }
  43. if (capdata_orig != capdata)
  44. dev_warn(&pci_dev->dev,
  45. "PCI v%04x d%04x c%06x#%02x: "
  46. "corrected capdata from %016Lx to %016Lx\n",
  47. pci_dev->vendor, pci_dev->device, pci_dev->class,
  48. (unsigned)UWBCAPDATA_TO_CAP_ID(capdata),
  49. (unsigned long long)capdata_orig,
  50. (unsigned long long)capdata);
  51. return capdata;
  52. }
  53. /**
  54. * whci_wait_for - wait for a WHCI register to be set
  55. *
  56. * Polls (for at most @max_ms ms) until '*@reg & @mask == @result'.
  57. */
  58. int whci_wait_for(struct device *dev, u32 __iomem *reg, u32 mask, u32 result,
  59. unsigned long max_ms, const char *tag)
  60. {
  61. unsigned t = 0;
  62. u32 val;
  63. for (;;) {
  64. val = le_readl(reg);
  65. if ((val & mask) == result)
  66. break;
  67. if (t >= max_ms) {
  68. dev_err(dev, "%s timed out\n", tag);
  69. return -ETIMEDOUT;
  70. }
  71. msleep(10);
  72. t += 10;
  73. }
  74. return 0;
  75. }
  76. EXPORT_SYMBOL_GPL(whci_wait_for);
  77. /*
  78. * NOTE: the capinfo and capdata registers are slightly different
  79. * (size and cap-id fields). So for cap #0, we need to fill
  80. * in. Size comes from the size of the register block
  81. * (statically calculated); cap_id comes from nowhere, we use
  82. * zero, that is reserved, for the radio controller, because
  83. * none was defined at the spec level.
  84. */
  85. static int whci_add_cap(struct whci_card *card, int n)
  86. {
  87. struct umc_dev *umc;
  88. u64 capdata;
  89. int bar, err;
  90. umc = umc_device_create(&card->pci->dev, n);
  91. if (umc == NULL)
  92. return -ENOMEM;
  93. capdata = le_readq(card->uwbbase + UWBCAPDATA(n));
  94. bar = UWBCAPDATA_TO_BAR(capdata) << 1;
  95. capdata = whci_capdata_quirks(card, capdata);
  96. /* Capability 0 is the radio controller. It's size is 32
  97. * bytes (WHCI0.95[2.3, T2-9]). */
  98. umc->version = UWBCAPDATA_TO_VERSION(capdata);
  99. umc->cap_id = n == 0 ? 0 : UWBCAPDATA_TO_CAP_ID(capdata);
  100. umc->bar = bar;
  101. umc->resource.start = pci_resource_start(card->pci, bar)
  102. + UWBCAPDATA_TO_OFFSET(capdata);
  103. umc->resource.end = umc->resource.start
  104. + (n == 0 ? 0x20 : UWBCAPDATA_TO_SIZE(capdata)) - 1;
  105. umc->resource.name = dev_name(&umc->dev);
  106. umc->resource.flags = card->pci->resource[bar].flags;
  107. umc->resource.parent = &card->pci->resource[bar];
  108. umc->irq = card->pci->irq;
  109. err = umc_device_register(umc);
  110. if (err < 0)
  111. goto error;
  112. card->devs[n] = umc;
  113. return 0;
  114. error:
  115. kfree(umc);
  116. return err;
  117. }
  118. static void whci_del_cap(struct whci_card *card, int n)
  119. {
  120. struct umc_dev *umc = card->devs[n];
  121. if (umc != NULL)
  122. umc_device_unregister(umc);
  123. }
  124. static int whci_n_caps(struct pci_dev *pci)
  125. {
  126. void __iomem *uwbbase;
  127. u64 capinfo;
  128. uwbbase = pci_iomap(pci, 0, 8);
  129. if (!uwbbase)
  130. return -ENOMEM;
  131. capinfo = le_readq(uwbbase + UWBCAPINFO);
  132. pci_iounmap(pci, uwbbase);
  133. return UWBCAPINFO_TO_N_CAPS(capinfo);
  134. }
  135. static int whci_probe(struct pci_dev *pci, const struct pci_device_id *id)
  136. {
  137. struct whci_card *card;
  138. int err, n_caps, n;
  139. err = pci_enable_device(pci);
  140. if (err < 0)
  141. goto error;
  142. pci_enable_msi(pci);
  143. pci_set_master(pci);
  144. err = -ENXIO;
  145. if (!pci_set_dma_mask(pci, DMA_BIT_MASK(64)))
  146. pci_set_consistent_dma_mask(pci, DMA_BIT_MASK(64));
  147. else if (!pci_set_dma_mask(pci, DMA_BIT_MASK(32)))
  148. pci_set_consistent_dma_mask(pci, DMA_BIT_MASK(32));
  149. else
  150. goto error_dma;
  151. err = n_caps = whci_n_caps(pci);
  152. if (n_caps < 0)
  153. goto error_ncaps;
  154. err = -ENOMEM;
  155. card = kzalloc(sizeof(struct whci_card)
  156. + sizeof(struct whci_dev *) * (n_caps + 1),
  157. GFP_KERNEL);
  158. if (card == NULL)
  159. goto error_kzalloc;
  160. card->pci = pci;
  161. card->n_caps = n_caps;
  162. err = -EBUSY;
  163. if (!request_mem_region(pci_resource_start(pci, 0),
  164. UWBCAPDATA_SIZE(card->n_caps),
  165. "whci (capability data)"))
  166. goto error_request_memregion;
  167. err = -ENOMEM;
  168. card->uwbbase = pci_iomap(pci, 0, UWBCAPDATA_SIZE(card->n_caps));
  169. if (!card->uwbbase)
  170. goto error_iomap;
  171. /* Add each capability. */
  172. for (n = 0; n <= card->n_caps; n++) {
  173. err = whci_add_cap(card, n);
  174. if (err < 0 && n == 0) {
  175. dev_err(&pci->dev, "cannot bind UWB radio controller:"
  176. " %d\n", err);
  177. goto error_bind;
  178. }
  179. if (err < 0)
  180. dev_warn(&pci->dev, "warning: cannot bind capability "
  181. "#%u: %d\n", n, err);
  182. }
  183. pci_set_drvdata(pci, card);
  184. return 0;
  185. error_bind:
  186. pci_iounmap(pci, card->uwbbase);
  187. error_iomap:
  188. release_mem_region(pci_resource_start(pci, 0), UWBCAPDATA_SIZE(card->n_caps));
  189. error_request_memregion:
  190. kfree(card);
  191. error_kzalloc:
  192. error_ncaps:
  193. error_dma:
  194. pci_disable_msi(pci);
  195. pci_disable_device(pci);
  196. error:
  197. return err;
  198. }
  199. static void whci_remove(struct pci_dev *pci)
  200. {
  201. struct whci_card *card = pci_get_drvdata(pci);
  202. int n;
  203. pci_set_drvdata(pci, NULL);
  204. /* Unregister each capability in reverse (so the master device
  205. * is unregistered last). */
  206. for (n = card->n_caps; n >= 0 ; n--)
  207. whci_del_cap(card, n);
  208. pci_iounmap(pci, card->uwbbase);
  209. release_mem_region(pci_resource_start(pci, 0), UWBCAPDATA_SIZE(card->n_caps));
  210. kfree(card);
  211. pci_disable_msi(pci);
  212. pci_disable_device(pci);
  213. }
  214. static struct pci_device_id whci_id_table[] = {
  215. { PCI_DEVICE_CLASS(PCI_CLASS_WIRELESS_WHCI, ~0) },
  216. { 0 },
  217. };
  218. MODULE_DEVICE_TABLE(pci, whci_id_table);
  219. static struct pci_driver whci_driver = {
  220. .name = "whci",
  221. .id_table = whci_id_table,
  222. .probe = whci_probe,
  223. .remove = whci_remove,
  224. };
  225. static int __init whci_init(void)
  226. {
  227. return pci_register_driver(&whci_driver);
  228. }
  229. static void __exit whci_exit(void)
  230. {
  231. pci_unregister_driver(&whci_driver);
  232. }
  233. module_init(whci_init);
  234. module_exit(whci_exit);
  235. MODULE_DESCRIPTION("WHCI UWB Multi-interface Controller enumerator");
  236. MODULE_AUTHOR("Cambridge Silicon Radio Ltd.");
  237. MODULE_LICENSE("GPL");