imx21-hcd.c 44 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789
  1. /*
  2. * USB Host Controller Driver for IMX21
  3. *
  4. * Copyright (C) 2006 Loping Dog Embedded Systems
  5. * Copyright (C) 2009 Martin Fuzzey
  6. * Originally written by Jay Monkman <jtm@lopingdog.com>
  7. * Ported to 2.6.30, debugged and enhanced by Martin Fuzzey
  8. *
  9. * This program is free software; you can redistribute it and/or modify it
  10. * under the terms of the GNU General Public License as published by the
  11. * Free Software Foundation; either version 2 of the License, or (at your
  12. * option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful, but
  15. * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
  16. * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
  17. * for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this program; if not, write to the Free Software Foundation,
  21. * Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
  22. */
  23. /*
  24. * The i.MX21 USB hardware contains
  25. * * 32 transfer descriptors (called ETDs)
  26. * * 4Kb of Data memory
  27. *
  28. * The data memory is shared between the host and fuction controlers
  29. * (but this driver only supports the host controler)
  30. *
  31. * So setting up a transfer involves:
  32. * * Allocating a ETD
  33. * * Fill in ETD with appropriate information
  34. * * Allocating data memory (and putting the offset in the ETD)
  35. * * Activate the ETD
  36. * * Get interrupt when done.
  37. *
  38. * An ETD is assigned to each active endpoint.
  39. *
  40. * Low resource (ETD and Data memory) situations are handled differently for
  41. * isochronous and non insosynchronous transactions :
  42. *
  43. * Non ISOC transfers are queued if either ETDs or Data memory are unavailable
  44. *
  45. * ISOC transfers use 2 ETDs per endpoint to achieve double buffering.
  46. * They allocate both ETDs and Data memory during URB submission
  47. * (and fail if unavailable).
  48. */
  49. #include <linux/clk.h>
  50. #include <linux/io.h>
  51. #include <linux/kernel.h>
  52. #include <linux/list.h>
  53. #include <linux/platform_device.h>
  54. #include <linux/usb.h>
  55. #include "../core/hcd.h"
  56. #include "imx21-hcd.h"
  57. #ifdef DEBUG
  58. #define DEBUG_LOG_FRAME(imx21, etd, event) \
  59. (etd)->event##_frame = readl((imx21)->regs + USBH_FRMNUB)
  60. #else
  61. #define DEBUG_LOG_FRAME(imx21, etd, event) do { } while (0)
  62. #endif
  63. static const char hcd_name[] = "imx21-hcd";
  64. static inline struct imx21 *hcd_to_imx21(struct usb_hcd *hcd)
  65. {
  66. return (struct imx21 *)hcd->hcd_priv;
  67. }
  68. /* =========================================== */
  69. /* Hardware access helpers */
  70. /* =========================================== */
  71. static inline void set_register_bits(struct imx21 *imx21, u32 offset, u32 mask)
  72. {
  73. void __iomem *reg = imx21->regs + offset;
  74. writel(readl(reg) | mask, reg);
  75. }
  76. static inline void clear_register_bits(struct imx21 *imx21,
  77. u32 offset, u32 mask)
  78. {
  79. void __iomem *reg = imx21->regs + offset;
  80. writel(readl(reg) & ~mask, reg);
  81. }
  82. static inline void clear_toggle_bit(struct imx21 *imx21, u32 offset, u32 mask)
  83. {
  84. void __iomem *reg = imx21->regs + offset;
  85. if (readl(reg) & mask)
  86. writel(mask, reg);
  87. }
  88. static inline void set_toggle_bit(struct imx21 *imx21, u32 offset, u32 mask)
  89. {
  90. void __iomem *reg = imx21->regs + offset;
  91. if (!(readl(reg) & mask))
  92. writel(mask, reg);
  93. }
  94. static void etd_writel(struct imx21 *imx21, int etd_num, int dword, u32 value)
  95. {
  96. writel(value, imx21->regs + USB_ETD_DWORD(etd_num, dword));
  97. }
  98. static u32 etd_readl(struct imx21 *imx21, int etd_num, int dword)
  99. {
  100. return readl(imx21->regs + USB_ETD_DWORD(etd_num, dword));
  101. }
  102. static inline int wrap_frame(int counter)
  103. {
  104. return counter & 0xFFFF;
  105. }
  106. static inline int frame_after(int frame, int after)
  107. {
  108. /* handle wrapping like jiffies time_afer */
  109. return (s16)((s16)after - (s16)frame) < 0;
  110. }
  111. static int imx21_hc_get_frame(struct usb_hcd *hcd)
  112. {
  113. struct imx21 *imx21 = hcd_to_imx21(hcd);
  114. return wrap_frame(readl(imx21->regs + USBH_FRMNUB));
  115. }
  116. #include "imx21-dbg.c"
  117. /* =========================================== */
  118. /* ETD management */
  119. /* =========================================== */
  120. static int alloc_etd(struct imx21 *imx21)
  121. {
  122. int i;
  123. struct etd_priv *etd = imx21->etd;
  124. for (i = 0; i < USB_NUM_ETD; i++, etd++) {
  125. if (etd->alloc == 0) {
  126. memset(etd, 0, sizeof(imx21->etd[0]));
  127. etd->alloc = 1;
  128. debug_etd_allocated(imx21);
  129. return i;
  130. }
  131. }
  132. return -1;
  133. }
  134. static void disactivate_etd(struct imx21 *imx21, int num)
  135. {
  136. int etd_mask = (1 << num);
  137. struct etd_priv *etd = &imx21->etd[num];
  138. writel(etd_mask, imx21->regs + USBH_ETDENCLR);
  139. clear_register_bits(imx21, USBH_ETDDONEEN, etd_mask);
  140. writel(etd_mask, imx21->regs + USB_ETDDMACHANLCLR);
  141. clear_toggle_bit(imx21, USBH_ETDDONESTAT, etd_mask);
  142. etd->active_count = 0;
  143. DEBUG_LOG_FRAME(imx21, etd, disactivated);
  144. }
  145. static void reset_etd(struct imx21 *imx21, int num)
  146. {
  147. struct etd_priv *etd = imx21->etd + num;
  148. int i;
  149. disactivate_etd(imx21, num);
  150. for (i = 0; i < 4; i++)
  151. etd_writel(imx21, num, i, 0);
  152. etd->urb = NULL;
  153. etd->ep = NULL;
  154. etd->td = NULL;;
  155. }
  156. static void free_etd(struct imx21 *imx21, int num)
  157. {
  158. if (num < 0)
  159. return;
  160. if (num >= USB_NUM_ETD) {
  161. dev_err(imx21->dev, "BAD etd=%d!\n", num);
  162. return;
  163. }
  164. if (imx21->etd[num].alloc == 0) {
  165. dev_err(imx21->dev, "ETD %d already free!\n", num);
  166. return;
  167. }
  168. debug_etd_freed(imx21);
  169. reset_etd(imx21, num);
  170. memset(&imx21->etd[num], 0, sizeof(imx21->etd[0]));
  171. }
  172. static void setup_etd_dword0(struct imx21 *imx21,
  173. int etd_num, struct urb *urb, u8 dir, u16 maxpacket)
  174. {
  175. etd_writel(imx21, etd_num, 0,
  176. ((u32) usb_pipedevice(urb->pipe)) << DW0_ADDRESS |
  177. ((u32) usb_pipeendpoint(urb->pipe) << DW0_ENDPNT) |
  178. ((u32) dir << DW0_DIRECT) |
  179. ((u32) ((urb->dev->speed == USB_SPEED_LOW) ?
  180. 1 : 0) << DW0_SPEED) |
  181. ((u32) fmt_urb_to_etd[usb_pipetype(urb->pipe)] << DW0_FORMAT) |
  182. ((u32) maxpacket << DW0_MAXPKTSIZ));
  183. }
  184. static void activate_etd(struct imx21 *imx21,
  185. int etd_num, dma_addr_t dma, u8 dir)
  186. {
  187. u32 etd_mask = 1 << etd_num;
  188. struct etd_priv *etd = &imx21->etd[etd_num];
  189. clear_toggle_bit(imx21, USBH_ETDDONESTAT, etd_mask);
  190. set_register_bits(imx21, USBH_ETDDONEEN, etd_mask);
  191. clear_toggle_bit(imx21, USBH_XFILLSTAT, etd_mask);
  192. clear_toggle_bit(imx21, USBH_YFILLSTAT, etd_mask);
  193. if (dma) {
  194. set_register_bits(imx21, USB_ETDDMACHANLCLR, etd_mask);
  195. clear_toggle_bit(imx21, USBH_XBUFSTAT, etd_mask);
  196. clear_toggle_bit(imx21, USBH_YBUFSTAT, etd_mask);
  197. writel(dma, imx21->regs + USB_ETDSMSA(etd_num));
  198. set_register_bits(imx21, USB_ETDDMAEN, etd_mask);
  199. } else {
  200. if (dir != TD_DIR_IN) {
  201. /* need to set for ZLP */
  202. set_toggle_bit(imx21, USBH_XFILLSTAT, etd_mask);
  203. set_toggle_bit(imx21, USBH_YFILLSTAT, etd_mask);
  204. }
  205. }
  206. DEBUG_LOG_FRAME(imx21, etd, activated);
  207. #ifdef DEBUG
  208. if (!etd->active_count) {
  209. int i;
  210. etd->activated_frame = readl(imx21->regs + USBH_FRMNUB);
  211. etd->disactivated_frame = -1;
  212. etd->last_int_frame = -1;
  213. etd->last_req_frame = -1;
  214. for (i = 0; i < 4; i++)
  215. etd->submitted_dwords[i] = etd_readl(imx21, etd_num, i);
  216. }
  217. #endif
  218. etd->active_count = 1;
  219. writel(etd_mask, imx21->regs + USBH_ETDENSET);
  220. }
  221. /* =========================================== */
  222. /* Data memory management */
  223. /* =========================================== */
  224. static int alloc_dmem(struct imx21 *imx21, unsigned int size,
  225. struct usb_host_endpoint *ep)
  226. {
  227. unsigned int offset = 0;
  228. struct imx21_dmem_area *area;
  229. struct imx21_dmem_area *tmp;
  230. size += (~size + 1) & 0x3; /* Round to 4 byte multiple */
  231. if (size > DMEM_SIZE) {
  232. dev_err(imx21->dev, "size=%d > DMEM_SIZE(%d)\n",
  233. size, DMEM_SIZE);
  234. return -EINVAL;
  235. }
  236. list_for_each_entry(tmp, &imx21->dmem_list, list) {
  237. if ((size + offset) < offset)
  238. goto fail;
  239. if ((size + offset) <= tmp->offset)
  240. break;
  241. offset = tmp->size + tmp->offset;
  242. if ((offset + size) > DMEM_SIZE)
  243. goto fail;
  244. }
  245. area = kmalloc(sizeof(struct imx21_dmem_area), GFP_ATOMIC);
  246. if (area == NULL)
  247. return -ENOMEM;
  248. area->ep = ep;
  249. area->offset = offset;
  250. area->size = size;
  251. list_add_tail(&area->list, &tmp->list);
  252. debug_dmem_allocated(imx21, size);
  253. return offset;
  254. fail:
  255. return -ENOMEM;
  256. }
  257. /* Memory now available for a queued ETD - activate it */
  258. static void activate_queued_etd(struct imx21 *imx21,
  259. struct etd_priv *etd, u32 dmem_offset)
  260. {
  261. struct urb_priv *urb_priv = etd->urb->hcpriv;
  262. int etd_num = etd - &imx21->etd[0];
  263. u32 maxpacket = etd_readl(imx21, etd_num, 1) >> DW1_YBUFSRTAD;
  264. u8 dir = (etd_readl(imx21, etd_num, 2) >> DW2_DIRPID) & 0x03;
  265. dev_dbg(imx21->dev, "activating queued ETD %d now DMEM available\n",
  266. etd_num);
  267. etd_writel(imx21, etd_num, 1,
  268. ((dmem_offset + maxpacket) << DW1_YBUFSRTAD) | dmem_offset);
  269. urb_priv->active = 1;
  270. activate_etd(imx21, etd_num, etd->dma_handle, dir);
  271. }
  272. static void free_dmem(struct imx21 *imx21, int offset)
  273. {
  274. struct imx21_dmem_area *area;
  275. struct etd_priv *etd, *tmp;
  276. int found = 0;
  277. list_for_each_entry(area, &imx21->dmem_list, list) {
  278. if (area->offset == offset) {
  279. debug_dmem_freed(imx21, area->size);
  280. list_del(&area->list);
  281. kfree(area);
  282. found = 1;
  283. break;
  284. }
  285. }
  286. if (!found) {
  287. dev_err(imx21->dev,
  288. "Trying to free unallocated DMEM %d\n", offset);
  289. return;
  290. }
  291. /* Try again to allocate memory for anything we've queued */
  292. list_for_each_entry_safe(etd, tmp, &imx21->queue_for_dmem, queue) {
  293. offset = alloc_dmem(imx21, etd->dmem_size, etd->ep);
  294. if (offset >= 0) {
  295. list_del(&etd->queue);
  296. activate_queued_etd(imx21, etd, (u32)offset);
  297. }
  298. }
  299. }
  300. static void free_epdmem(struct imx21 *imx21, struct usb_host_endpoint *ep)
  301. {
  302. struct imx21_dmem_area *area, *tmp;
  303. list_for_each_entry_safe(area, tmp, &imx21->dmem_list, list) {
  304. if (area->ep == ep) {
  305. dev_err(imx21->dev,
  306. "Active DMEM %d for disabled ep=%p\n",
  307. area->offset, ep);
  308. list_del(&area->list);
  309. kfree(area);
  310. }
  311. }
  312. }
  313. /* =========================================== */
  314. /* End handling */
  315. /* =========================================== */
  316. static void schedule_nonisoc_etd(struct imx21 *imx21, struct urb *urb);
  317. /* Endpoint now idle - release it's ETD(s) or asssign to queued request */
  318. static void ep_idle(struct imx21 *imx21, struct ep_priv *ep_priv)
  319. {
  320. int etd_num;
  321. int i;
  322. for (i = 0; i < NUM_ISO_ETDS; i++) {
  323. etd_num = ep_priv->etd[i];
  324. if (etd_num < 0)
  325. continue;
  326. ep_priv->etd[i] = -1;
  327. if (list_empty(&imx21->queue_for_etd)) {
  328. free_etd(imx21, etd_num);
  329. continue;
  330. }
  331. dev_dbg(imx21->dev,
  332. "assigning idle etd %d for queued request\n", etd_num);
  333. ep_priv = list_first_entry(&imx21->queue_for_etd,
  334. struct ep_priv, queue);
  335. list_del(&ep_priv->queue);
  336. reset_etd(imx21, etd_num);
  337. ep_priv->waiting_etd = 0;
  338. ep_priv->etd[i] = etd_num;
  339. if (list_empty(&ep_priv->ep->urb_list)) {
  340. dev_err(imx21->dev, "No urb for queued ep!\n");
  341. continue;
  342. }
  343. schedule_nonisoc_etd(imx21, list_first_entry(
  344. &ep_priv->ep->urb_list, struct urb, urb_list));
  345. }
  346. }
  347. static void urb_done(struct usb_hcd *hcd, struct urb *urb, int status)
  348. __releases(imx21->lock)
  349. __acquires(imx21->lock)
  350. {
  351. struct imx21 *imx21 = hcd_to_imx21(hcd);
  352. struct ep_priv *ep_priv = urb->ep->hcpriv;
  353. struct urb_priv *urb_priv = urb->hcpriv;
  354. debug_urb_completed(imx21, urb, status);
  355. dev_vdbg(imx21->dev, "urb %p done %d\n", urb, status);
  356. kfree(urb_priv->isoc_td);
  357. kfree(urb->hcpriv);
  358. urb->hcpriv = NULL;
  359. usb_hcd_unlink_urb_from_ep(hcd, urb);
  360. spin_unlock(&imx21->lock);
  361. usb_hcd_giveback_urb(hcd, urb, status);
  362. spin_lock(&imx21->lock);
  363. if (list_empty(&ep_priv->ep->urb_list))
  364. ep_idle(imx21, ep_priv);
  365. }
  366. /* =========================================== */
  367. /* ISOC Handling ... */
  368. /* =========================================== */
  369. static void schedule_isoc_etds(struct usb_hcd *hcd,
  370. struct usb_host_endpoint *ep)
  371. {
  372. struct imx21 *imx21 = hcd_to_imx21(hcd);
  373. struct ep_priv *ep_priv = ep->hcpriv;
  374. struct etd_priv *etd;
  375. struct urb_priv *urb_priv;
  376. struct td *td;
  377. int etd_num;
  378. int i;
  379. int cur_frame;
  380. u8 dir;
  381. for (i = 0; i < NUM_ISO_ETDS; i++) {
  382. too_late:
  383. if (list_empty(&ep_priv->td_list))
  384. break;
  385. etd_num = ep_priv->etd[i];
  386. if (etd_num < 0)
  387. break;
  388. etd = &imx21->etd[etd_num];
  389. if (etd->urb)
  390. continue;
  391. td = list_entry(ep_priv->td_list.next, struct td, list);
  392. list_del(&td->list);
  393. urb_priv = td->urb->hcpriv;
  394. cur_frame = imx21_hc_get_frame(hcd);
  395. if (frame_after(cur_frame, td->frame)) {
  396. dev_dbg(imx21->dev, "isoc too late frame %d > %d\n",
  397. cur_frame, td->frame);
  398. urb_priv->isoc_status = -EXDEV;
  399. td->urb->iso_frame_desc[
  400. td->isoc_index].actual_length = 0;
  401. td->urb->iso_frame_desc[td->isoc_index].status = -EXDEV;
  402. if (--urb_priv->isoc_remaining == 0)
  403. urb_done(hcd, td->urb, urb_priv->isoc_status);
  404. goto too_late;
  405. }
  406. urb_priv->active = 1;
  407. etd->td = td;
  408. etd->ep = td->ep;
  409. etd->urb = td->urb;
  410. etd->len = td->len;
  411. debug_isoc_submitted(imx21, cur_frame, td);
  412. dir = usb_pipeout(td->urb->pipe) ? TD_DIR_OUT : TD_DIR_IN;
  413. setup_etd_dword0(imx21, etd_num, td->urb, dir, etd->dmem_size);
  414. etd_writel(imx21, etd_num, 1, etd->dmem_offset);
  415. etd_writel(imx21, etd_num, 2,
  416. (TD_NOTACCESSED << DW2_COMPCODE) |
  417. ((td->frame & 0xFFFF) << DW2_STARTFRM));
  418. etd_writel(imx21, etd_num, 3,
  419. (TD_NOTACCESSED << DW3_COMPCODE0) |
  420. (td->len << DW3_PKTLEN0));
  421. activate_etd(imx21, etd_num, td->data, dir);
  422. }
  423. }
  424. static void isoc_etd_done(struct usb_hcd *hcd, struct urb *urb, int etd_num)
  425. {
  426. struct imx21 *imx21 = hcd_to_imx21(hcd);
  427. int etd_mask = 1 << etd_num;
  428. struct urb_priv *urb_priv = urb->hcpriv;
  429. struct etd_priv *etd = imx21->etd + etd_num;
  430. struct td *td = etd->td;
  431. struct usb_host_endpoint *ep = etd->ep;
  432. int isoc_index = td->isoc_index;
  433. unsigned int pipe = urb->pipe;
  434. int dir_in = usb_pipein(pipe);
  435. int cc;
  436. int bytes_xfrd;
  437. disactivate_etd(imx21, etd_num);
  438. cc = (etd_readl(imx21, etd_num, 3) >> DW3_COMPCODE0) & 0xf;
  439. bytes_xfrd = etd_readl(imx21, etd_num, 3) & 0x3ff;
  440. /* Input doesn't always fill the buffer, don't generate an error
  441. * when this happens.
  442. */
  443. if (dir_in && (cc == TD_DATAUNDERRUN))
  444. cc = TD_CC_NOERROR;
  445. if (cc == TD_NOTACCESSED)
  446. bytes_xfrd = 0;
  447. debug_isoc_completed(imx21,
  448. imx21_hc_get_frame(hcd), td, cc, bytes_xfrd);
  449. if (cc) {
  450. urb_priv->isoc_status = -EXDEV;
  451. dev_dbg(imx21->dev,
  452. "bad iso cc=0x%X frame=%d sched frame=%d "
  453. "cnt=%d len=%d urb=%p etd=%d index=%d\n",
  454. cc, imx21_hc_get_frame(hcd), td->frame,
  455. bytes_xfrd, td->len, urb, etd_num, isoc_index);
  456. }
  457. if (dir_in)
  458. clear_toggle_bit(imx21, USBH_XFILLSTAT, etd_mask);
  459. urb->actual_length += bytes_xfrd;
  460. urb->iso_frame_desc[isoc_index].actual_length = bytes_xfrd;
  461. urb->iso_frame_desc[isoc_index].status = cc_to_error[cc];
  462. etd->td = NULL;
  463. etd->urb = NULL;
  464. etd->ep = NULL;
  465. if (--urb_priv->isoc_remaining == 0)
  466. urb_done(hcd, urb, urb_priv->isoc_status);
  467. schedule_isoc_etds(hcd, ep);
  468. }
  469. static struct ep_priv *alloc_isoc_ep(
  470. struct imx21 *imx21, struct usb_host_endpoint *ep)
  471. {
  472. struct ep_priv *ep_priv;
  473. int i;
  474. ep_priv = kzalloc(sizeof(struct ep_priv), GFP_ATOMIC);
  475. if (ep_priv == NULL)
  476. return NULL;
  477. /* Allocate the ETDs */
  478. for (i = 0; i < NUM_ISO_ETDS; i++) {
  479. ep_priv->etd[i] = alloc_etd(imx21);
  480. if (ep_priv->etd[i] < 0) {
  481. int j;
  482. dev_err(imx21->dev, "isoc: Couldn't allocate etd\n");
  483. for (j = 0; j < i; j++)
  484. free_etd(imx21, ep_priv->etd[j]);
  485. goto alloc_etd_failed;
  486. }
  487. imx21->etd[ep_priv->etd[i]].ep = ep;
  488. }
  489. INIT_LIST_HEAD(&ep_priv->td_list);
  490. ep_priv->ep = ep;
  491. ep->hcpriv = ep_priv;
  492. return ep_priv;
  493. alloc_etd_failed:
  494. kfree(ep_priv);
  495. return NULL;
  496. }
  497. static int imx21_hc_urb_enqueue_isoc(struct usb_hcd *hcd,
  498. struct usb_host_endpoint *ep,
  499. struct urb *urb, gfp_t mem_flags)
  500. {
  501. struct imx21 *imx21 = hcd_to_imx21(hcd);
  502. struct urb_priv *urb_priv;
  503. unsigned long flags;
  504. struct ep_priv *ep_priv;
  505. struct td *td = NULL;
  506. int i;
  507. int ret;
  508. int cur_frame;
  509. u16 maxpacket;
  510. urb_priv = kzalloc(sizeof(struct urb_priv), mem_flags);
  511. if (urb_priv == NULL)
  512. return -ENOMEM;
  513. urb_priv->isoc_td = kzalloc(
  514. sizeof(struct td) * urb->number_of_packets, mem_flags);
  515. if (urb_priv->isoc_td == NULL) {
  516. ret = -ENOMEM;
  517. goto alloc_td_failed;
  518. }
  519. spin_lock_irqsave(&imx21->lock, flags);
  520. if (ep->hcpriv == NULL) {
  521. ep_priv = alloc_isoc_ep(imx21, ep);
  522. if (ep_priv == NULL) {
  523. ret = -ENOMEM;
  524. goto alloc_ep_failed;
  525. }
  526. } else {
  527. ep_priv = ep->hcpriv;
  528. }
  529. ret = usb_hcd_link_urb_to_ep(hcd, urb);
  530. if (ret)
  531. goto link_failed;
  532. urb->status = -EINPROGRESS;
  533. urb->actual_length = 0;
  534. urb->error_count = 0;
  535. urb->hcpriv = urb_priv;
  536. urb_priv->ep = ep;
  537. /* allocate data memory for largest packets if not already done */
  538. maxpacket = usb_maxpacket(urb->dev, urb->pipe, usb_pipeout(urb->pipe));
  539. for (i = 0; i < NUM_ISO_ETDS; i++) {
  540. struct etd_priv *etd = &imx21->etd[ep_priv->etd[i]];
  541. if (etd->dmem_size > 0 && etd->dmem_size < maxpacket) {
  542. /* not sure if this can really occur.... */
  543. dev_err(imx21->dev, "increasing isoc buffer %d->%d\n",
  544. etd->dmem_size, maxpacket);
  545. ret = -EMSGSIZE;
  546. goto alloc_dmem_failed;
  547. }
  548. if (etd->dmem_size == 0) {
  549. etd->dmem_offset = alloc_dmem(imx21, maxpacket, ep);
  550. if (etd->dmem_offset < 0) {
  551. dev_dbg(imx21->dev, "failed alloc isoc dmem\n");
  552. ret = -EAGAIN;
  553. goto alloc_dmem_failed;
  554. }
  555. etd->dmem_size = maxpacket;
  556. }
  557. }
  558. /* calculate frame */
  559. cur_frame = imx21_hc_get_frame(hcd);
  560. if (urb->transfer_flags & URB_ISO_ASAP) {
  561. if (list_empty(&ep_priv->td_list))
  562. urb->start_frame = cur_frame + 5;
  563. else
  564. urb->start_frame = list_entry(
  565. ep_priv->td_list.prev,
  566. struct td, list)->frame + urb->interval;
  567. }
  568. urb->start_frame = wrap_frame(urb->start_frame);
  569. if (frame_after(cur_frame, urb->start_frame)) {
  570. dev_dbg(imx21->dev,
  571. "enqueue: adjusting iso start %d (cur=%d) asap=%d\n",
  572. urb->start_frame, cur_frame,
  573. (urb->transfer_flags & URB_ISO_ASAP) != 0);
  574. urb->start_frame = wrap_frame(cur_frame + 1);
  575. }
  576. /* set up transfers */
  577. td = urb_priv->isoc_td;
  578. for (i = 0; i < urb->number_of_packets; i++, td++) {
  579. td->ep = ep;
  580. td->urb = urb;
  581. td->len = urb->iso_frame_desc[i].length;
  582. td->isoc_index = i;
  583. td->frame = wrap_frame(urb->start_frame + urb->interval * i);
  584. td->data = urb->transfer_dma + urb->iso_frame_desc[i].offset;
  585. list_add_tail(&td->list, &ep_priv->td_list);
  586. }
  587. urb_priv->isoc_remaining = urb->number_of_packets;
  588. dev_vdbg(imx21->dev, "setup %d packets for iso frame %d->%d\n",
  589. urb->number_of_packets, urb->start_frame, td->frame);
  590. debug_urb_submitted(imx21, urb);
  591. schedule_isoc_etds(hcd, ep);
  592. spin_unlock_irqrestore(&imx21->lock, flags);
  593. return 0;
  594. alloc_dmem_failed:
  595. usb_hcd_unlink_urb_from_ep(hcd, urb);
  596. link_failed:
  597. alloc_ep_failed:
  598. spin_unlock_irqrestore(&imx21->lock, flags);
  599. kfree(urb_priv->isoc_td);
  600. alloc_td_failed:
  601. kfree(urb_priv);
  602. return ret;
  603. }
  604. static void dequeue_isoc_urb(struct imx21 *imx21,
  605. struct urb *urb, struct ep_priv *ep_priv)
  606. {
  607. struct urb_priv *urb_priv = urb->hcpriv;
  608. struct td *td, *tmp;
  609. int i;
  610. if (urb_priv->active) {
  611. for (i = 0; i < NUM_ISO_ETDS; i++) {
  612. int etd_num = ep_priv->etd[i];
  613. if (etd_num != -1 && imx21->etd[etd_num].urb == urb) {
  614. struct etd_priv *etd = imx21->etd + etd_num;
  615. reset_etd(imx21, etd_num);
  616. if (etd->dmem_size)
  617. free_dmem(imx21, etd->dmem_offset);
  618. etd->dmem_size = 0;
  619. }
  620. }
  621. }
  622. list_for_each_entry_safe(td, tmp, &ep_priv->td_list, list) {
  623. if (td->urb == urb) {
  624. dev_vdbg(imx21->dev, "removing td %p\n", td);
  625. list_del(&td->list);
  626. }
  627. }
  628. }
  629. /* =========================================== */
  630. /* NON ISOC Handling ... */
  631. /* =========================================== */
  632. static void schedule_nonisoc_etd(struct imx21 *imx21, struct urb *urb)
  633. {
  634. unsigned int pipe = urb->pipe;
  635. struct urb_priv *urb_priv = urb->hcpriv;
  636. struct ep_priv *ep_priv = urb_priv->ep->hcpriv;
  637. int state = urb_priv->state;
  638. int etd_num = ep_priv->etd[0];
  639. struct etd_priv *etd;
  640. int dmem_offset;
  641. u32 count;
  642. u16 etd_buf_size;
  643. u16 maxpacket;
  644. u8 dir;
  645. u8 bufround;
  646. u8 datatoggle;
  647. u8 interval = 0;
  648. u8 relpolpos = 0;
  649. if (etd_num < 0) {
  650. dev_err(imx21->dev, "No valid ETD\n");
  651. return;
  652. }
  653. if (readl(imx21->regs + USBH_ETDENSET) & (1 << etd_num))
  654. dev_err(imx21->dev, "submitting to active ETD %d\n", etd_num);
  655. etd = &imx21->etd[etd_num];
  656. maxpacket = usb_maxpacket(urb->dev, pipe, usb_pipeout(pipe));
  657. if (!maxpacket)
  658. maxpacket = 8;
  659. if (usb_pipecontrol(pipe) && (state != US_CTRL_DATA)) {
  660. if (state == US_CTRL_SETUP) {
  661. dir = TD_DIR_SETUP;
  662. etd->dma_handle = urb->setup_dma;
  663. bufround = 0;
  664. count = 8;
  665. datatoggle = TD_TOGGLE_DATA0;
  666. } else { /* US_CTRL_ACK */
  667. dir = usb_pipeout(pipe) ? TD_DIR_IN : TD_DIR_OUT;
  668. etd->dma_handle = urb->transfer_dma;
  669. bufround = 0;
  670. count = 0;
  671. datatoggle = TD_TOGGLE_DATA1;
  672. }
  673. } else {
  674. dir = usb_pipeout(pipe) ? TD_DIR_OUT : TD_DIR_IN;
  675. bufround = (dir == TD_DIR_IN) ? 1 : 0;
  676. etd->dma_handle = urb->transfer_dma;
  677. if (usb_pipebulk(pipe) && (state == US_BULK0))
  678. count = 0;
  679. else
  680. count = urb->transfer_buffer_length;
  681. if (usb_pipecontrol(pipe)) {
  682. datatoggle = TD_TOGGLE_DATA1;
  683. } else {
  684. if (usb_gettoggle(
  685. urb->dev,
  686. usb_pipeendpoint(urb->pipe),
  687. usb_pipeout(urb->pipe)))
  688. datatoggle = TD_TOGGLE_DATA1;
  689. else
  690. datatoggle = TD_TOGGLE_DATA0;
  691. }
  692. }
  693. etd->urb = urb;
  694. etd->ep = urb_priv->ep;
  695. etd->len = count;
  696. if (usb_pipeint(pipe)) {
  697. interval = urb->interval;
  698. relpolpos = (readl(imx21->regs + USBH_FRMNUB) + 1) & 0xff;
  699. }
  700. /* Write ETD to device memory */
  701. setup_etd_dword0(imx21, etd_num, urb, dir, maxpacket);
  702. etd_writel(imx21, etd_num, 2,
  703. (u32) interval << DW2_POLINTERV |
  704. ((u32) relpolpos << DW2_RELPOLPOS) |
  705. ((u32) dir << DW2_DIRPID) |
  706. ((u32) bufround << DW2_BUFROUND) |
  707. ((u32) datatoggle << DW2_DATATOG) |
  708. ((u32) TD_NOTACCESSED << DW2_COMPCODE));
  709. /* DMA will always transfer buffer size even if TOBYCNT in DWORD3
  710. is smaller. Make sure we don't overrun the buffer!
  711. */
  712. if (count && count < maxpacket)
  713. etd_buf_size = count;
  714. else
  715. etd_buf_size = maxpacket;
  716. etd_writel(imx21, etd_num, 3,
  717. ((u32) (etd_buf_size - 1) << DW3_BUFSIZE) | (u32) count);
  718. if (!count)
  719. etd->dma_handle = 0;
  720. /* allocate x and y buffer space at once */
  721. etd->dmem_size = (count > maxpacket) ? maxpacket * 2 : maxpacket;
  722. dmem_offset = alloc_dmem(imx21, etd->dmem_size, urb_priv->ep);
  723. if (dmem_offset < 0) {
  724. /* Setup everything we can in HW and update when we get DMEM */
  725. etd_writel(imx21, etd_num, 1, (u32)maxpacket << 16);
  726. dev_dbg(imx21->dev, "Queuing etd %d for DMEM\n", etd_num);
  727. debug_urb_queued_for_dmem(imx21, urb);
  728. list_add_tail(&etd->queue, &imx21->queue_for_dmem);
  729. return;
  730. }
  731. etd_writel(imx21, etd_num, 1,
  732. (((u32) dmem_offset + (u32) maxpacket) << DW1_YBUFSRTAD) |
  733. (u32) dmem_offset);
  734. urb_priv->active = 1;
  735. /* enable the ETD to kick off transfer */
  736. dev_vdbg(imx21->dev, "Activating etd %d for %d bytes %s\n",
  737. etd_num, count, dir != TD_DIR_IN ? "out" : "in");
  738. activate_etd(imx21, etd_num, etd->dma_handle, dir);
  739. }
  740. static void nonisoc_etd_done(struct usb_hcd *hcd, struct urb *urb, int etd_num)
  741. {
  742. struct imx21 *imx21 = hcd_to_imx21(hcd);
  743. struct etd_priv *etd = &imx21->etd[etd_num];
  744. u32 etd_mask = 1 << etd_num;
  745. struct urb_priv *urb_priv = urb->hcpriv;
  746. int dir;
  747. u16 xbufaddr;
  748. int cc;
  749. u32 bytes_xfrd;
  750. int etd_done;
  751. disactivate_etd(imx21, etd_num);
  752. dir = (etd_readl(imx21, etd_num, 0) >> DW0_DIRECT) & 0x3;
  753. xbufaddr = etd_readl(imx21, etd_num, 1) & 0xffff;
  754. cc = (etd_readl(imx21, etd_num, 2) >> DW2_COMPCODE) & 0xf;
  755. bytes_xfrd = etd->len - (etd_readl(imx21, etd_num, 3) & 0x1fffff);
  756. /* save toggle carry */
  757. usb_settoggle(urb->dev, usb_pipeendpoint(urb->pipe),
  758. usb_pipeout(urb->pipe),
  759. (etd_readl(imx21, etd_num, 0) >> DW0_TOGCRY) & 0x1);
  760. if (dir == TD_DIR_IN) {
  761. clear_toggle_bit(imx21, USBH_XFILLSTAT, etd_mask);
  762. clear_toggle_bit(imx21, USBH_YFILLSTAT, etd_mask);
  763. }
  764. free_dmem(imx21, xbufaddr);
  765. urb->error_count = 0;
  766. if (!(urb->transfer_flags & URB_SHORT_NOT_OK)
  767. && (cc == TD_DATAUNDERRUN))
  768. cc = TD_CC_NOERROR;
  769. if (cc != 0)
  770. dev_vdbg(imx21->dev, "cc is 0x%x\n", cc);
  771. etd_done = (cc_to_error[cc] != 0); /* stop if error */
  772. switch (usb_pipetype(urb->pipe)) {
  773. case PIPE_CONTROL:
  774. switch (urb_priv->state) {
  775. case US_CTRL_SETUP:
  776. if (urb->transfer_buffer_length > 0)
  777. urb_priv->state = US_CTRL_DATA;
  778. else
  779. urb_priv->state = US_CTRL_ACK;
  780. break;
  781. case US_CTRL_DATA:
  782. urb->actual_length += bytes_xfrd;
  783. urb_priv->state = US_CTRL_ACK;
  784. break;
  785. case US_CTRL_ACK:
  786. etd_done = 1;
  787. break;
  788. default:
  789. dev_err(imx21->dev,
  790. "Invalid pipe state %d\n", urb_priv->state);
  791. etd_done = 1;
  792. break;
  793. }
  794. break;
  795. case PIPE_BULK:
  796. urb->actual_length += bytes_xfrd;
  797. if ((urb_priv->state == US_BULK)
  798. && (urb->transfer_flags & URB_ZERO_PACKET)
  799. && urb->transfer_buffer_length > 0
  800. && ((urb->transfer_buffer_length %
  801. usb_maxpacket(urb->dev, urb->pipe,
  802. usb_pipeout(urb->pipe))) == 0)) {
  803. /* need a 0-packet */
  804. urb_priv->state = US_BULK0;
  805. } else {
  806. etd_done = 1;
  807. }
  808. break;
  809. case PIPE_INTERRUPT:
  810. urb->actual_length += bytes_xfrd;
  811. etd_done = 1;
  812. break;
  813. }
  814. if (!etd_done) {
  815. dev_vdbg(imx21->dev, "next state=%d\n", urb_priv->state);
  816. schedule_nonisoc_etd(imx21, urb);
  817. } else {
  818. struct usb_host_endpoint *ep = urb->ep;
  819. urb_done(hcd, urb, cc_to_error[cc]);
  820. etd->urb = NULL;
  821. if (!list_empty(&ep->urb_list)) {
  822. urb = list_first_entry(&ep->urb_list,
  823. struct urb, urb_list);
  824. dev_vdbg(imx21->dev, "next URB %p\n", urb);
  825. schedule_nonisoc_etd(imx21, urb);
  826. }
  827. }
  828. }
  829. static struct ep_priv *alloc_ep(void)
  830. {
  831. int i;
  832. struct ep_priv *ep_priv;
  833. ep_priv = kzalloc(sizeof(struct ep_priv), GFP_ATOMIC);
  834. if (!ep_priv)
  835. return NULL;
  836. for (i = 0; i < NUM_ISO_ETDS; ++i)
  837. ep_priv->etd[i] = -1;
  838. return ep_priv;
  839. }
  840. static int imx21_hc_urb_enqueue(struct usb_hcd *hcd,
  841. struct urb *urb, gfp_t mem_flags)
  842. {
  843. struct imx21 *imx21 = hcd_to_imx21(hcd);
  844. struct usb_host_endpoint *ep = urb->ep;
  845. struct urb_priv *urb_priv;
  846. struct ep_priv *ep_priv;
  847. struct etd_priv *etd;
  848. int ret;
  849. unsigned long flags;
  850. int new_ep = 0;
  851. dev_vdbg(imx21->dev,
  852. "enqueue urb=%p ep=%p len=%d "
  853. "buffer=%p dma=%08X setupBuf=%p setupDma=%08X\n",
  854. urb, ep,
  855. urb->transfer_buffer_length,
  856. urb->transfer_buffer, urb->transfer_dma,
  857. urb->setup_packet, urb->setup_dma);
  858. if (usb_pipeisoc(urb->pipe))
  859. return imx21_hc_urb_enqueue_isoc(hcd, ep, urb, mem_flags);
  860. urb_priv = kzalloc(sizeof(struct urb_priv), mem_flags);
  861. if (!urb_priv)
  862. return -ENOMEM;
  863. spin_lock_irqsave(&imx21->lock, flags);
  864. ep_priv = ep->hcpriv;
  865. if (ep_priv == NULL) {
  866. ep_priv = alloc_ep();
  867. if (!ep_priv) {
  868. ret = -ENOMEM;
  869. goto failed_alloc_ep;
  870. }
  871. ep->hcpriv = ep_priv;
  872. ep_priv->ep = ep;
  873. new_ep = 1;
  874. }
  875. ret = usb_hcd_link_urb_to_ep(hcd, urb);
  876. if (ret)
  877. goto failed_link;
  878. urb->status = -EINPROGRESS;
  879. urb->actual_length = 0;
  880. urb->error_count = 0;
  881. urb->hcpriv = urb_priv;
  882. urb_priv->ep = ep;
  883. switch (usb_pipetype(urb->pipe)) {
  884. case PIPE_CONTROL:
  885. urb_priv->state = US_CTRL_SETUP;
  886. break;
  887. case PIPE_BULK:
  888. urb_priv->state = US_BULK;
  889. break;
  890. }
  891. debug_urb_submitted(imx21, urb);
  892. if (ep_priv->etd[0] < 0) {
  893. if (ep_priv->waiting_etd) {
  894. dev_dbg(imx21->dev,
  895. "no ETD available already queued %p\n",
  896. ep_priv);
  897. debug_urb_queued_for_etd(imx21, urb);
  898. goto out;
  899. }
  900. ep_priv->etd[0] = alloc_etd(imx21);
  901. if (ep_priv->etd[0] < 0) {
  902. dev_dbg(imx21->dev,
  903. "no ETD available queueing %p\n", ep_priv);
  904. debug_urb_queued_for_etd(imx21, urb);
  905. list_add_tail(&ep_priv->queue, &imx21->queue_for_etd);
  906. ep_priv->waiting_etd = 1;
  907. goto out;
  908. }
  909. }
  910. /* Schedule if no URB already active for this endpoint */
  911. etd = &imx21->etd[ep_priv->etd[0]];
  912. if (etd->urb == NULL) {
  913. DEBUG_LOG_FRAME(imx21, etd, last_req);
  914. schedule_nonisoc_etd(imx21, urb);
  915. }
  916. out:
  917. spin_unlock_irqrestore(&imx21->lock, flags);
  918. return 0;
  919. failed_link:
  920. failed_alloc_ep:
  921. spin_unlock_irqrestore(&imx21->lock, flags);
  922. kfree(urb_priv);
  923. return ret;
  924. }
  925. static int imx21_hc_urb_dequeue(struct usb_hcd *hcd, struct urb *urb,
  926. int status)
  927. {
  928. struct imx21 *imx21 = hcd_to_imx21(hcd);
  929. unsigned long flags;
  930. struct usb_host_endpoint *ep;
  931. struct ep_priv *ep_priv;
  932. struct urb_priv *urb_priv = urb->hcpriv;
  933. int ret = -EINVAL;
  934. dev_vdbg(imx21->dev, "dequeue urb=%p iso=%d status=%d\n",
  935. urb, usb_pipeisoc(urb->pipe), status);
  936. spin_lock_irqsave(&imx21->lock, flags);
  937. ret = usb_hcd_check_unlink_urb(hcd, urb, status);
  938. if (ret)
  939. goto fail;
  940. ep = urb_priv->ep;
  941. ep_priv = ep->hcpriv;
  942. debug_urb_unlinked(imx21, urb);
  943. if (usb_pipeisoc(urb->pipe)) {
  944. dequeue_isoc_urb(imx21, urb, ep_priv);
  945. schedule_isoc_etds(hcd, ep);
  946. } else if (urb_priv->active) {
  947. int etd_num = ep_priv->etd[0];
  948. if (etd_num != -1) {
  949. disactivate_etd(imx21, etd_num);
  950. free_dmem(imx21, etd_readl(imx21, etd_num, 1) & 0xffff);
  951. imx21->etd[etd_num].urb = NULL;
  952. }
  953. }
  954. urb_done(hcd, urb, status);
  955. spin_unlock_irqrestore(&imx21->lock, flags);
  956. return 0;
  957. fail:
  958. spin_unlock_irqrestore(&imx21->lock, flags);
  959. return ret;
  960. }
  961. /* =========================================== */
  962. /* Interrupt dispatch */
  963. /* =========================================== */
  964. static void process_etds(struct usb_hcd *hcd, struct imx21 *imx21, int sof)
  965. {
  966. int etd_num;
  967. int enable_sof_int = 0;
  968. unsigned long flags;
  969. spin_lock_irqsave(&imx21->lock, flags);
  970. for (etd_num = 0; etd_num < USB_NUM_ETD; etd_num++) {
  971. u32 etd_mask = 1 << etd_num;
  972. u32 enabled = readl(imx21->regs + USBH_ETDENSET) & etd_mask;
  973. u32 done = readl(imx21->regs + USBH_ETDDONESTAT) & etd_mask;
  974. struct etd_priv *etd = &imx21->etd[etd_num];
  975. if (done) {
  976. DEBUG_LOG_FRAME(imx21, etd, last_int);
  977. } else {
  978. /*
  979. * Kludge warning!
  980. *
  981. * When multiple transfers are using the bus we sometimes get into a state
  982. * where the transfer has completed (the CC field of the ETD is != 0x0F),
  983. * the ETD has self disabled but the ETDDONESTAT flag is not set
  984. * (and hence no interrupt occurs).
  985. * This causes the transfer in question to hang.
  986. * The kludge below checks for this condition at each SOF and processes any
  987. * blocked ETDs (after an arbitary 10 frame wait)
  988. *
  989. * With a single active transfer the usbtest test suite will run for days
  990. * without the kludge.
  991. * With other bus activity (eg mass storage) even just test1 will hang without
  992. * the kludge.
  993. */
  994. u32 dword0;
  995. int cc;
  996. if (etd->active_count && !enabled) /* suspicious... */
  997. enable_sof_int = 1;
  998. if (!sof || enabled || !etd->active_count)
  999. continue;
  1000. cc = etd_readl(imx21, etd_num, 2) >> DW2_COMPCODE;
  1001. if (cc == TD_NOTACCESSED)
  1002. continue;
  1003. if (++etd->active_count < 10)
  1004. continue;
  1005. dword0 = etd_readl(imx21, etd_num, 0);
  1006. dev_dbg(imx21->dev,
  1007. "unblock ETD %d dev=0x%X ep=0x%X cc=0x%02X!\n",
  1008. etd_num, dword0 & 0x7F,
  1009. (dword0 >> DW0_ENDPNT) & 0x0F,
  1010. cc);
  1011. #ifdef DEBUG
  1012. dev_dbg(imx21->dev,
  1013. "frame: act=%d disact=%d"
  1014. " int=%d req=%d cur=%d\n",
  1015. etd->activated_frame,
  1016. etd->disactivated_frame,
  1017. etd->last_int_frame,
  1018. etd->last_req_frame,
  1019. readl(imx21->regs + USBH_FRMNUB));
  1020. imx21->debug_unblocks++;
  1021. #endif
  1022. etd->active_count = 0;
  1023. /* End of kludge */
  1024. }
  1025. if (etd->ep == NULL || etd->urb == NULL) {
  1026. dev_dbg(imx21->dev,
  1027. "Interrupt for unexpected etd %d"
  1028. " ep=%p urb=%p\n",
  1029. etd_num, etd->ep, etd->urb);
  1030. disactivate_etd(imx21, etd_num);
  1031. continue;
  1032. }
  1033. if (usb_pipeisoc(etd->urb->pipe))
  1034. isoc_etd_done(hcd, etd->urb, etd_num);
  1035. else
  1036. nonisoc_etd_done(hcd, etd->urb, etd_num);
  1037. }
  1038. /* only enable SOF interrupt if it may be needed for the kludge */
  1039. if (enable_sof_int)
  1040. set_register_bits(imx21, USBH_SYSIEN, USBH_SYSIEN_SOFINT);
  1041. else
  1042. clear_register_bits(imx21, USBH_SYSIEN, USBH_SYSIEN_SOFINT);
  1043. spin_unlock_irqrestore(&imx21->lock, flags);
  1044. }
  1045. static irqreturn_t imx21_irq(struct usb_hcd *hcd)
  1046. {
  1047. struct imx21 *imx21 = hcd_to_imx21(hcd);
  1048. u32 ints = readl(imx21->regs + USBH_SYSISR);
  1049. if (ints & USBH_SYSIEN_HERRINT)
  1050. dev_dbg(imx21->dev, "Scheduling error\n");
  1051. if (ints & USBH_SYSIEN_SORINT)
  1052. dev_dbg(imx21->dev, "Scheduling overrun\n");
  1053. if (ints & (USBH_SYSISR_DONEINT | USBH_SYSISR_SOFINT))
  1054. process_etds(hcd, imx21, ints & USBH_SYSISR_SOFINT);
  1055. writel(ints, imx21->regs + USBH_SYSISR);
  1056. return IRQ_HANDLED;
  1057. }
  1058. static void imx21_hc_endpoint_disable(struct usb_hcd *hcd,
  1059. struct usb_host_endpoint *ep)
  1060. {
  1061. struct imx21 *imx21 = hcd_to_imx21(hcd);
  1062. unsigned long flags;
  1063. struct ep_priv *ep_priv;
  1064. int i;
  1065. if (ep == NULL)
  1066. return;
  1067. spin_lock_irqsave(&imx21->lock, flags);
  1068. ep_priv = ep->hcpriv;
  1069. dev_vdbg(imx21->dev, "disable ep=%p, ep->hcpriv=%p\n", ep, ep_priv);
  1070. if (!list_empty(&ep->urb_list))
  1071. dev_dbg(imx21->dev, "ep's URB list is not empty\n");
  1072. if (ep_priv != NULL) {
  1073. for (i = 0; i < NUM_ISO_ETDS; i++) {
  1074. if (ep_priv->etd[i] > -1)
  1075. dev_dbg(imx21->dev, "free etd %d for disable\n",
  1076. ep_priv->etd[i]);
  1077. free_etd(imx21, ep_priv->etd[i]);
  1078. }
  1079. kfree(ep_priv);
  1080. ep->hcpriv = NULL;
  1081. }
  1082. for (i = 0; i < USB_NUM_ETD; i++) {
  1083. if (imx21->etd[i].alloc && imx21->etd[i].ep == ep) {
  1084. dev_err(imx21->dev,
  1085. "Active etd %d for disabled ep=%p!\n", i, ep);
  1086. free_etd(imx21, i);
  1087. }
  1088. }
  1089. free_epdmem(imx21, ep);
  1090. spin_unlock_irqrestore(&imx21->lock, flags);
  1091. }
  1092. /* =========================================== */
  1093. /* Hub handling */
  1094. /* =========================================== */
  1095. static int get_hub_descriptor(struct usb_hcd *hcd,
  1096. struct usb_hub_descriptor *desc)
  1097. {
  1098. struct imx21 *imx21 = hcd_to_imx21(hcd);
  1099. desc->bDescriptorType = 0x29; /* HUB descriptor */
  1100. desc->bHubContrCurrent = 0;
  1101. desc->bNbrPorts = readl(imx21->regs + USBH_ROOTHUBA)
  1102. & USBH_ROOTHUBA_NDNSTMPRT_MASK;
  1103. desc->bDescLength = 9;
  1104. desc->bPwrOn2PwrGood = 0;
  1105. desc->wHubCharacteristics = (__force __u16) cpu_to_le16(
  1106. 0x0002 | /* No power switching */
  1107. 0x0010 | /* No over current protection */
  1108. 0);
  1109. desc->bitmap[0] = 1 << 1;
  1110. desc->bitmap[1] = ~0;
  1111. return 0;
  1112. }
  1113. static int imx21_hc_hub_status_data(struct usb_hcd *hcd, char *buf)
  1114. {
  1115. struct imx21 *imx21 = hcd_to_imx21(hcd);
  1116. int ports;
  1117. int changed = 0;
  1118. int i;
  1119. unsigned long flags;
  1120. spin_lock_irqsave(&imx21->lock, flags);
  1121. ports = readl(imx21->regs + USBH_ROOTHUBA)
  1122. & USBH_ROOTHUBA_NDNSTMPRT_MASK;
  1123. if (ports > 7) {
  1124. ports = 7;
  1125. dev_err(imx21->dev, "ports %d > 7\n", ports);
  1126. }
  1127. for (i = 0; i < ports; i++) {
  1128. if (readl(imx21->regs + USBH_PORTSTAT(i)) &
  1129. (USBH_PORTSTAT_CONNECTSC |
  1130. USBH_PORTSTAT_PRTENBLSC |
  1131. USBH_PORTSTAT_PRTSTATSC |
  1132. USBH_PORTSTAT_OVRCURIC |
  1133. USBH_PORTSTAT_PRTRSTSC)) {
  1134. changed = 1;
  1135. buf[0] |= 1 << (i + 1);
  1136. }
  1137. }
  1138. spin_unlock_irqrestore(&imx21->lock, flags);
  1139. if (changed)
  1140. dev_info(imx21->dev, "Hub status changed\n");
  1141. return changed;
  1142. }
  1143. static int imx21_hc_hub_control(struct usb_hcd *hcd,
  1144. u16 typeReq,
  1145. u16 wValue, u16 wIndex, char *buf, u16 wLength)
  1146. {
  1147. struct imx21 *imx21 = hcd_to_imx21(hcd);
  1148. int rc = 0;
  1149. u32 status_write = 0;
  1150. switch (typeReq) {
  1151. case ClearHubFeature:
  1152. dev_dbg(imx21->dev, "ClearHubFeature\n");
  1153. switch (wValue) {
  1154. case C_HUB_OVER_CURRENT:
  1155. dev_dbg(imx21->dev, " OVER_CURRENT\n");
  1156. break;
  1157. case C_HUB_LOCAL_POWER:
  1158. dev_dbg(imx21->dev, " LOCAL_POWER\n");
  1159. break;
  1160. default:
  1161. dev_dbg(imx21->dev, " unknown\n");
  1162. rc = -EINVAL;
  1163. break;
  1164. }
  1165. break;
  1166. case ClearPortFeature:
  1167. dev_dbg(imx21->dev, "ClearPortFeature\n");
  1168. switch (wValue) {
  1169. case USB_PORT_FEAT_ENABLE:
  1170. dev_dbg(imx21->dev, " ENABLE\n");
  1171. status_write = USBH_PORTSTAT_CURCONST;
  1172. break;
  1173. case USB_PORT_FEAT_SUSPEND:
  1174. dev_dbg(imx21->dev, " SUSPEND\n");
  1175. status_write = USBH_PORTSTAT_PRTOVRCURI;
  1176. break;
  1177. case USB_PORT_FEAT_POWER:
  1178. dev_dbg(imx21->dev, " POWER\n");
  1179. status_write = USBH_PORTSTAT_LSDEVCON;
  1180. break;
  1181. case USB_PORT_FEAT_C_ENABLE:
  1182. dev_dbg(imx21->dev, " C_ENABLE\n");
  1183. status_write = USBH_PORTSTAT_PRTENBLSC;
  1184. break;
  1185. case USB_PORT_FEAT_C_SUSPEND:
  1186. dev_dbg(imx21->dev, " C_SUSPEND\n");
  1187. status_write = USBH_PORTSTAT_PRTSTATSC;
  1188. break;
  1189. case USB_PORT_FEAT_C_CONNECTION:
  1190. dev_dbg(imx21->dev, " C_CONNECTION\n");
  1191. status_write = USBH_PORTSTAT_CONNECTSC;
  1192. break;
  1193. case USB_PORT_FEAT_C_OVER_CURRENT:
  1194. dev_dbg(imx21->dev, " C_OVER_CURRENT\n");
  1195. status_write = USBH_PORTSTAT_OVRCURIC;
  1196. break;
  1197. case USB_PORT_FEAT_C_RESET:
  1198. dev_dbg(imx21->dev, " C_RESET\n");
  1199. status_write = USBH_PORTSTAT_PRTRSTSC;
  1200. break;
  1201. default:
  1202. dev_dbg(imx21->dev, " unknown\n");
  1203. rc = -EINVAL;
  1204. break;
  1205. }
  1206. break;
  1207. case GetHubDescriptor:
  1208. dev_dbg(imx21->dev, "GetHubDescriptor\n");
  1209. rc = get_hub_descriptor(hcd, (void *)buf);
  1210. break;
  1211. case GetHubStatus:
  1212. dev_dbg(imx21->dev, " GetHubStatus\n");
  1213. *(__le32 *) buf = 0;
  1214. break;
  1215. case GetPortStatus:
  1216. dev_dbg(imx21->dev, "GetPortStatus: port: %d, 0x%x\n",
  1217. wIndex, USBH_PORTSTAT(wIndex - 1));
  1218. *(__le32 *) buf = readl(imx21->regs +
  1219. USBH_PORTSTAT(wIndex - 1));
  1220. break;
  1221. case SetHubFeature:
  1222. dev_dbg(imx21->dev, "SetHubFeature\n");
  1223. switch (wValue) {
  1224. case C_HUB_OVER_CURRENT:
  1225. dev_dbg(imx21->dev, " OVER_CURRENT\n");
  1226. break;
  1227. case C_HUB_LOCAL_POWER:
  1228. dev_dbg(imx21->dev, " LOCAL_POWER\n");
  1229. break;
  1230. default:
  1231. dev_dbg(imx21->dev, " unknown\n");
  1232. rc = -EINVAL;
  1233. break;
  1234. }
  1235. break;
  1236. case SetPortFeature:
  1237. dev_dbg(imx21->dev, "SetPortFeature\n");
  1238. switch (wValue) {
  1239. case USB_PORT_FEAT_SUSPEND:
  1240. dev_dbg(imx21->dev, " SUSPEND\n");
  1241. status_write = USBH_PORTSTAT_PRTSUSPST;
  1242. break;
  1243. case USB_PORT_FEAT_POWER:
  1244. dev_dbg(imx21->dev, " POWER\n");
  1245. status_write = USBH_PORTSTAT_PRTPWRST;
  1246. break;
  1247. case USB_PORT_FEAT_RESET:
  1248. dev_dbg(imx21->dev, " RESET\n");
  1249. status_write = USBH_PORTSTAT_PRTRSTST;
  1250. break;
  1251. default:
  1252. dev_dbg(imx21->dev, " unknown\n");
  1253. rc = -EINVAL;
  1254. break;
  1255. }
  1256. break;
  1257. default:
  1258. dev_dbg(imx21->dev, " unknown\n");
  1259. rc = -EINVAL;
  1260. break;
  1261. }
  1262. if (status_write)
  1263. writel(status_write, imx21->regs + USBH_PORTSTAT(wIndex - 1));
  1264. return rc;
  1265. }
  1266. /* =========================================== */
  1267. /* Host controller management */
  1268. /* =========================================== */
  1269. static int imx21_hc_reset(struct usb_hcd *hcd)
  1270. {
  1271. struct imx21 *imx21 = hcd_to_imx21(hcd);
  1272. unsigned long timeout;
  1273. unsigned long flags;
  1274. spin_lock_irqsave(&imx21->lock, flags);
  1275. /* Reset the Host controler modules */
  1276. writel(USBOTG_RST_RSTCTRL | USBOTG_RST_RSTRH |
  1277. USBOTG_RST_RSTHSIE | USBOTG_RST_RSTHC,
  1278. imx21->regs + USBOTG_RST_CTRL);
  1279. /* Wait for reset to finish */
  1280. timeout = jiffies + HZ;
  1281. while (readl(imx21->regs + USBOTG_RST_CTRL) != 0) {
  1282. if (time_after(jiffies, timeout)) {
  1283. spin_unlock_irqrestore(&imx21->lock, flags);
  1284. dev_err(imx21->dev, "timeout waiting for reset\n");
  1285. return -ETIMEDOUT;
  1286. }
  1287. spin_unlock_irq(&imx21->lock);
  1288. schedule_timeout(1);
  1289. spin_lock_irq(&imx21->lock);
  1290. }
  1291. spin_unlock_irqrestore(&imx21->lock, flags);
  1292. return 0;
  1293. }
  1294. static int __devinit imx21_hc_start(struct usb_hcd *hcd)
  1295. {
  1296. struct imx21 *imx21 = hcd_to_imx21(hcd);
  1297. unsigned long flags;
  1298. int i, j;
  1299. u32 hw_mode = USBOTG_HWMODE_CRECFG_HOST;
  1300. u32 usb_control = 0;
  1301. hw_mode |= ((imx21->pdata->host_xcvr << USBOTG_HWMODE_HOSTXCVR_SHIFT) &
  1302. USBOTG_HWMODE_HOSTXCVR_MASK);
  1303. hw_mode |= ((imx21->pdata->otg_xcvr << USBOTG_HWMODE_OTGXCVR_SHIFT) &
  1304. USBOTG_HWMODE_OTGXCVR_MASK);
  1305. if (imx21->pdata->host1_txenoe)
  1306. usb_control |= USBCTRL_HOST1_TXEN_OE;
  1307. if (!imx21->pdata->host1_xcverless)
  1308. usb_control |= USBCTRL_HOST1_BYP_TLL;
  1309. if (imx21->pdata->otg_ext_xcvr)
  1310. usb_control |= USBCTRL_OTC_RCV_RXDP;
  1311. spin_lock_irqsave(&imx21->lock, flags);
  1312. writel((USBOTG_CLK_CTRL_HST | USBOTG_CLK_CTRL_MAIN),
  1313. imx21->regs + USBOTG_CLK_CTRL);
  1314. writel(hw_mode, imx21->regs + USBOTG_HWMODE);
  1315. writel(usb_control, imx21->regs + USBCTRL);
  1316. writel(USB_MISCCONTROL_SKPRTRY | USB_MISCCONTROL_ARBMODE,
  1317. imx21->regs + USB_MISCCONTROL);
  1318. /* Clear the ETDs */
  1319. for (i = 0; i < USB_NUM_ETD; i++)
  1320. for (j = 0; j < 4; j++)
  1321. etd_writel(imx21, i, j, 0);
  1322. /* Take the HC out of reset */
  1323. writel(USBH_HOST_CTRL_HCUSBSTE_OPERATIONAL | USBH_HOST_CTRL_CTLBLKSR_1,
  1324. imx21->regs + USBH_HOST_CTRL);
  1325. /* Enable ports */
  1326. if (imx21->pdata->enable_otg_host)
  1327. writel(USBH_PORTSTAT_PRTPWRST | USBH_PORTSTAT_PRTENABST,
  1328. imx21->regs + USBH_PORTSTAT(0));
  1329. if (imx21->pdata->enable_host1)
  1330. writel(USBH_PORTSTAT_PRTPWRST | USBH_PORTSTAT_PRTENABST,
  1331. imx21->regs + USBH_PORTSTAT(1));
  1332. if (imx21->pdata->enable_host2)
  1333. writel(USBH_PORTSTAT_PRTPWRST | USBH_PORTSTAT_PRTENABST,
  1334. imx21->regs + USBH_PORTSTAT(2));
  1335. hcd->state = HC_STATE_RUNNING;
  1336. /* Enable host controller interrupts */
  1337. set_register_bits(imx21, USBH_SYSIEN,
  1338. USBH_SYSIEN_HERRINT |
  1339. USBH_SYSIEN_DONEINT | USBH_SYSIEN_SORINT);
  1340. set_register_bits(imx21, USBOTG_CINT_STEN, USBOTG_HCINT);
  1341. spin_unlock_irqrestore(&imx21->lock, flags);
  1342. return 0;
  1343. }
  1344. static void imx21_hc_stop(struct usb_hcd *hcd)
  1345. {
  1346. struct imx21 *imx21 = hcd_to_imx21(hcd);
  1347. unsigned long flags;
  1348. spin_lock_irqsave(&imx21->lock, flags);
  1349. writel(0, imx21->regs + USBH_SYSIEN);
  1350. clear_register_bits(imx21, USBOTG_CINT_STEN, USBOTG_HCINT);
  1351. clear_register_bits(imx21, USBOTG_CLK_CTRL_HST | USBOTG_CLK_CTRL_MAIN,
  1352. USBOTG_CLK_CTRL);
  1353. spin_unlock_irqrestore(&imx21->lock, flags);
  1354. }
  1355. /* =========================================== */
  1356. /* Driver glue */
  1357. /* =========================================== */
  1358. static struct hc_driver imx21_hc_driver = {
  1359. .description = hcd_name,
  1360. .product_desc = "IMX21 USB Host Controller",
  1361. .hcd_priv_size = sizeof(struct imx21),
  1362. .flags = HCD_USB11,
  1363. .irq = imx21_irq,
  1364. .reset = imx21_hc_reset,
  1365. .start = imx21_hc_start,
  1366. .stop = imx21_hc_stop,
  1367. /* I/O requests */
  1368. .urb_enqueue = imx21_hc_urb_enqueue,
  1369. .urb_dequeue = imx21_hc_urb_dequeue,
  1370. .endpoint_disable = imx21_hc_endpoint_disable,
  1371. /* scheduling support */
  1372. .get_frame_number = imx21_hc_get_frame,
  1373. /* Root hub support */
  1374. .hub_status_data = imx21_hc_hub_status_data,
  1375. .hub_control = imx21_hc_hub_control,
  1376. };
  1377. static struct mx21_usbh_platform_data default_pdata = {
  1378. .host_xcvr = MX21_USBXCVR_TXDIF_RXDIF,
  1379. .otg_xcvr = MX21_USBXCVR_TXDIF_RXDIF,
  1380. .enable_host1 = 1,
  1381. .enable_host2 = 1,
  1382. .enable_otg_host = 1,
  1383. };
  1384. static int imx21_remove(struct platform_device *pdev)
  1385. {
  1386. struct usb_hcd *hcd = platform_get_drvdata(pdev);
  1387. struct imx21 *imx21 = hcd_to_imx21(hcd);
  1388. struct resource *res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  1389. remove_debug_files(imx21);
  1390. usb_remove_hcd(hcd);
  1391. if (res != NULL) {
  1392. clk_disable(imx21->clk);
  1393. clk_put(imx21->clk);
  1394. iounmap(imx21->regs);
  1395. release_mem_region(res->start, resource_size(res));
  1396. }
  1397. kfree(hcd);
  1398. return 0;
  1399. }
  1400. static int imx21_probe(struct platform_device *pdev)
  1401. {
  1402. struct usb_hcd *hcd;
  1403. struct imx21 *imx21;
  1404. struct resource *res;
  1405. int ret;
  1406. int irq;
  1407. printk(KERN_INFO "%s\n", imx21_hc_driver.product_desc);
  1408. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  1409. if (!res)
  1410. return -ENODEV;
  1411. irq = platform_get_irq(pdev, 0);
  1412. if (irq < 0)
  1413. return -ENXIO;
  1414. hcd = usb_create_hcd(&imx21_hc_driver,
  1415. &pdev->dev, dev_name(&pdev->dev));
  1416. if (hcd == NULL) {
  1417. dev_err(&pdev->dev, "Cannot create hcd (%s)\n",
  1418. dev_name(&pdev->dev));
  1419. return -ENOMEM;
  1420. }
  1421. imx21 = hcd_to_imx21(hcd);
  1422. imx21->dev = &pdev->dev;
  1423. imx21->pdata = pdev->dev.platform_data;
  1424. if (!imx21->pdata)
  1425. imx21->pdata = &default_pdata;
  1426. spin_lock_init(&imx21->lock);
  1427. INIT_LIST_HEAD(&imx21->dmem_list);
  1428. INIT_LIST_HEAD(&imx21->queue_for_etd);
  1429. INIT_LIST_HEAD(&imx21->queue_for_dmem);
  1430. create_debug_files(imx21);
  1431. res = request_mem_region(res->start, resource_size(res), hcd_name);
  1432. if (!res) {
  1433. ret = -EBUSY;
  1434. goto failed_request_mem;
  1435. }
  1436. imx21->regs = ioremap(res->start, resource_size(res));
  1437. if (imx21->regs == NULL) {
  1438. dev_err(imx21->dev, "Cannot map registers\n");
  1439. ret = -ENOMEM;
  1440. goto failed_ioremap;
  1441. }
  1442. /* Enable clocks source */
  1443. imx21->clk = clk_get(imx21->dev, NULL);
  1444. if (IS_ERR(imx21->clk)) {
  1445. dev_err(imx21->dev, "no clock found\n");
  1446. ret = PTR_ERR(imx21->clk);
  1447. goto failed_clock_get;
  1448. }
  1449. ret = clk_set_rate(imx21->clk, clk_round_rate(imx21->clk, 48000000));
  1450. if (ret)
  1451. goto failed_clock_set;
  1452. ret = clk_enable(imx21->clk);
  1453. if (ret)
  1454. goto failed_clock_enable;
  1455. dev_info(imx21->dev, "Hardware HC revision: 0x%02X\n",
  1456. (readl(imx21->regs + USBOTG_HWMODE) >> 16) & 0xFF);
  1457. ret = usb_add_hcd(hcd, irq, IRQF_DISABLED);
  1458. if (ret != 0) {
  1459. dev_err(imx21->dev, "usb_add_hcd() returned %d\n", ret);
  1460. goto failed_add_hcd;
  1461. }
  1462. return 0;
  1463. failed_add_hcd:
  1464. clk_disable(imx21->clk);
  1465. failed_clock_enable:
  1466. failed_clock_set:
  1467. clk_put(imx21->clk);
  1468. failed_clock_get:
  1469. iounmap(imx21->regs);
  1470. failed_ioremap:
  1471. release_mem_region(res->start, res->end - res->start);
  1472. failed_request_mem:
  1473. remove_debug_files(imx21);
  1474. usb_put_hcd(hcd);
  1475. return ret;
  1476. }
  1477. static struct platform_driver imx21_hcd_driver = {
  1478. .driver = {
  1479. .name = (char *)hcd_name,
  1480. },
  1481. .probe = imx21_probe,
  1482. .remove = imx21_remove,
  1483. .suspend = NULL,
  1484. .resume = NULL,
  1485. };
  1486. static int __init imx21_hcd_init(void)
  1487. {
  1488. return platform_driver_register(&imx21_hcd_driver);
  1489. }
  1490. static void __exit imx21_hcd_cleanup(void)
  1491. {
  1492. platform_driver_unregister(&imx21_hcd_driver);
  1493. }
  1494. module_init(imx21_hcd_init);
  1495. module_exit(imx21_hcd_cleanup);
  1496. MODULE_DESCRIPTION("i.MX21 USB Host controller");
  1497. MODULE_AUTHOR("Martin Fuzzey");
  1498. MODULE_LICENSE("GPL");
  1499. MODULE_ALIAS("platform:imx21-hcd");