imx21-hcd.c 48 KB

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