imx21-hcd.c 44 KB

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