123cd1385SRemy Bohmer /* 223cd1385SRemy Bohmer * USB device controllers have lots of quirks. Use these macros in 323cd1385SRemy Bohmer * gadget drivers or other code that needs to deal with them, and which 423cd1385SRemy Bohmer * autoconfigures instead of using early binding to the hardware. 523cd1385SRemy Bohmer * 623cd1385SRemy Bohmer * This SHOULD eventually work like the ARM mach_is_*() stuff, driven by 723cd1385SRemy Bohmer * some config file that gets updated as new hardware is supported. 823cd1385SRemy Bohmer * (And avoiding all runtime comparisons in typical one-choice configs!) 923cd1385SRemy Bohmer * 1023cd1385SRemy Bohmer * NOTE: some of these controller drivers may not be available yet. 1123cd1385SRemy Bohmer * Some are available on 2.4 kernels; several are available, but not 1223cd1385SRemy Bohmer * yet pushed in the 2.6 mainline tree. 1323cd1385SRemy Bohmer * 1423cd1385SRemy Bohmer * Ported to U-boot by: Thomas Smits <ts.smits@gmail.com> and 1523cd1385SRemy Bohmer * Remy Bohmer <linux@bohmer.net> 1623cd1385SRemy Bohmer */ 1723cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_NET2280 186142e0aeSVitaly Kuzmichev #define gadget_is_net2280(g) (!strcmp("net2280", (g)->name)) 1923cd1385SRemy Bohmer #else 2023cd1385SRemy Bohmer #define gadget_is_net2280(g) 0 2123cd1385SRemy Bohmer #endif 2223cd1385SRemy Bohmer 2323cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_AMD5536UDC 246142e0aeSVitaly Kuzmichev #define gadget_is_amd5536udc(g) (!strcmp("amd5536udc", (g)->name)) 2523cd1385SRemy Bohmer #else 2623cd1385SRemy Bohmer #define gadget_is_amd5536udc(g) 0 2723cd1385SRemy Bohmer #endif 2823cd1385SRemy Bohmer 2923cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_DUMMY_HCD 306142e0aeSVitaly Kuzmichev #define gadget_is_dummy(g) (!strcmp("dummy_udc", (g)->name)) 3123cd1385SRemy Bohmer #else 3223cd1385SRemy Bohmer #define gadget_is_dummy(g) 0 3323cd1385SRemy Bohmer #endif 3423cd1385SRemy Bohmer 3523cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_PXA2XX 366142e0aeSVitaly Kuzmichev #define gadget_is_pxa(g) (!strcmp("pxa2xx_udc", (g)->name)) 3723cd1385SRemy Bohmer #else 3823cd1385SRemy Bohmer #define gadget_is_pxa(g) 0 3923cd1385SRemy Bohmer #endif 4023cd1385SRemy Bohmer 4123cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_GOKU 426142e0aeSVitaly Kuzmichev #define gadget_is_goku(g) (!strcmp("goku_udc", (g)->name)) 4323cd1385SRemy Bohmer #else 4423cd1385SRemy Bohmer #define gadget_is_goku(g) 0 4523cd1385SRemy Bohmer #endif 4623cd1385SRemy Bohmer 4723cd1385SRemy Bohmer /* SH3 UDC -- not yet ported 2.4 --> 2.6 */ 4823cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_SUPERH 496142e0aeSVitaly Kuzmichev #define gadget_is_sh(g) (!strcmp("sh_udc", (g)->name)) 5023cd1385SRemy Bohmer #else 5123cd1385SRemy Bohmer #define gadget_is_sh(g) 0 5223cd1385SRemy Bohmer #endif 5323cd1385SRemy Bohmer 5423cd1385SRemy Bohmer /* not yet stable on 2.6 (would help "original Zaurus") */ 5523cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_SA1100 566142e0aeSVitaly Kuzmichev #define gadget_is_sa1100(g) (!strcmp("sa1100_udc", (g)->name)) 5723cd1385SRemy Bohmer #else 5823cd1385SRemy Bohmer #define gadget_is_sa1100(g) 0 5923cd1385SRemy Bohmer #endif 6023cd1385SRemy Bohmer 6123cd1385SRemy Bohmer /* handhelds.org tree (?) */ 6223cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_MQ11XX 636142e0aeSVitaly Kuzmichev #define gadget_is_mq11xx(g) (!strcmp("mq11xx_udc", (g)->name)) 6423cd1385SRemy Bohmer #else 6523cd1385SRemy Bohmer #define gadget_is_mq11xx(g) 0 6623cd1385SRemy Bohmer #endif 6723cd1385SRemy Bohmer 6823cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_OMAP 696142e0aeSVitaly Kuzmichev #define gadget_is_omap(g) (!strcmp("omap_udc", (g)->name)) 7023cd1385SRemy Bohmer #else 7123cd1385SRemy Bohmer #define gadget_is_omap(g) 0 7223cd1385SRemy Bohmer #endif 7323cd1385SRemy Bohmer 7423cd1385SRemy Bohmer /* not yet ported 2.4 --> 2.6 */ 7523cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_N9604 766142e0aeSVitaly Kuzmichev #define gadget_is_n9604(g) (!strcmp("n9604_udc", (g)->name)) 7723cd1385SRemy Bohmer #else 7823cd1385SRemy Bohmer #define gadget_is_n9604(g) 0 7923cd1385SRemy Bohmer #endif 8023cd1385SRemy Bohmer 8123cd1385SRemy Bohmer /* various unstable versions available */ 8223cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_PXA27X 836142e0aeSVitaly Kuzmichev #define gadget_is_pxa27x(g) (!strcmp("pxa27x_udc", (g)->name)) 8423cd1385SRemy Bohmer #else 8523cd1385SRemy Bohmer #define gadget_is_pxa27x(g) 0 8623cd1385SRemy Bohmer #endif 8723cd1385SRemy Bohmer 8823cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_ATMEL_USBA 896142e0aeSVitaly Kuzmichev #define gadget_is_atmel_usba(g) (!strcmp("atmel_usba_udc", (g)->name)) 9023cd1385SRemy Bohmer #else 9123cd1385SRemy Bohmer #define gadget_is_atmel_usba(g) 0 9223cd1385SRemy Bohmer #endif 9323cd1385SRemy Bohmer 9423cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_S3C2410 956142e0aeSVitaly Kuzmichev #define gadget_is_s3c2410(g) (!strcmp("s3c2410_udc", (g)->name)) 9623cd1385SRemy Bohmer #else 9723cd1385SRemy Bohmer #define gadget_is_s3c2410(g) 0 9823cd1385SRemy Bohmer #endif 9923cd1385SRemy Bohmer 10023cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_AT91 1016142e0aeSVitaly Kuzmichev #define gadget_is_at91(g) (!strcmp("at91_udc", (g)->name)) 10223cd1385SRemy Bohmer #else 10323cd1385SRemy Bohmer #define gadget_is_at91(g) 0 10423cd1385SRemy Bohmer #endif 10523cd1385SRemy Bohmer 10623cd1385SRemy Bohmer /* status unclear */ 10723cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_IMX 1086142e0aeSVitaly Kuzmichev #define gadget_is_imx(g) (!strcmp("imx_udc", (g)->name)) 10923cd1385SRemy Bohmer #else 11023cd1385SRemy Bohmer #define gadget_is_imx(g) 0 11123cd1385SRemy Bohmer #endif 11223cd1385SRemy Bohmer 11323cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_FSL_USB2 1146142e0aeSVitaly Kuzmichev #define gadget_is_fsl_usb2(g) (!strcmp("fsl-usb2-udc", (g)->name)) 11523cd1385SRemy Bohmer #else 11623cd1385SRemy Bohmer #define gadget_is_fsl_usb2(g) 0 11723cd1385SRemy Bohmer #endif 11823cd1385SRemy Bohmer 11923cd1385SRemy Bohmer /* Mentor high speed function controller */ 12023cd1385SRemy Bohmer /* from Montavista kernel (?) */ 12123cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_MUSBHSFC 1226142e0aeSVitaly Kuzmichev #define gadget_is_musbhsfc(g) (!strcmp("musbhsfc_udc", (g)->name)) 12323cd1385SRemy Bohmer #else 12423cd1385SRemy Bohmer #define gadget_is_musbhsfc(g) 0 12523cd1385SRemy Bohmer #endif 12623cd1385SRemy Bohmer 12723cd1385SRemy Bohmer /* Mentor high speed "dual role" controller, in peripheral role */ 12823cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_MUSB_HDRC 1296142e0aeSVitaly Kuzmichev #define gadget_is_musbhdrc(g) (!strcmp("musb_hdrc", (g)->name)) 13023cd1385SRemy Bohmer #else 13123cd1385SRemy Bohmer #define gadget_is_musbhdrc(g) 0 13223cd1385SRemy Bohmer #endif 13323cd1385SRemy Bohmer 13423cd1385SRemy Bohmer /* from Montavista kernel (?) */ 13523cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_MPC8272 1366142e0aeSVitaly Kuzmichev #define gadget_is_mpc8272(g) (!strcmp("mpc8272_udc", (g)->name)) 13723cd1385SRemy Bohmer #else 13823cd1385SRemy Bohmer #define gadget_is_mpc8272(g) 0 13923cd1385SRemy Bohmer #endif 14023cd1385SRemy Bohmer 14123cd1385SRemy Bohmer #ifdef CONFIG_USB_GADGET_M66592 1426142e0aeSVitaly Kuzmichev #define gadget_is_m66592(g) (!strcmp("m66592_udc", (g)->name)) 14323cd1385SRemy Bohmer #else 14423cd1385SRemy Bohmer #define gadget_is_m66592(g) 0 14523cd1385SRemy Bohmer #endif 14623cd1385SRemy Bohmer 14726cc5129SLei Wen #ifdef CONFIG_USB_GADGET_MV 14826cc5129SLei Wen #define gadget_is_mv(g) (!strcmp("mv_udc", (g)->name)) 14926cc5129SLei Wen #else 15026cc5129SLei Wen #define gadget_is_mv(g) 0 15126cc5129SLei Wen #endif 15223cd1385SRemy Bohmer 1536142e0aeSVitaly Kuzmichev /* 1546142e0aeSVitaly Kuzmichev * CONFIG_USB_GADGET_SX2 1556142e0aeSVitaly Kuzmichev * CONFIG_USB_GADGET_AU1X00 1566142e0aeSVitaly Kuzmichev * ... 1576142e0aeSVitaly Kuzmichev */ 15823cd1385SRemy Bohmer 15923cd1385SRemy Bohmer /** 16023cd1385SRemy Bohmer * usb_gadget_controller_number - support bcdDevice id convention 16123cd1385SRemy Bohmer * @gadget: the controller being driven 16223cd1385SRemy Bohmer * 16323cd1385SRemy Bohmer * Return a 2-digit BCD value associated with the peripheral controller, 16423cd1385SRemy Bohmer * suitable for use as part of a bcdDevice value, or a negative error code. 16523cd1385SRemy Bohmer * 16623cd1385SRemy Bohmer * NOTE: this convention is purely optional, and has no meaning in terms of 16723cd1385SRemy Bohmer * any USB specification. If you want to use a different convention in your 16823cd1385SRemy Bohmer * gadget driver firmware -- maybe a more formal revision ID -- feel free. 16923cd1385SRemy Bohmer * 17023cd1385SRemy Bohmer * Hosts see these bcdDevice numbers, and are allowed (but not encouraged!) 17123cd1385SRemy Bohmer * to change their behavior accordingly. For example it might help avoiding 17223cd1385SRemy Bohmer * some chip bug. 17323cd1385SRemy Bohmer */ 17423cd1385SRemy Bohmer static inline int usb_gadget_controller_number(struct usb_gadget *gadget) 17523cd1385SRemy Bohmer { 17623cd1385SRemy Bohmer if (gadget_is_net2280(gadget)) 17723cd1385SRemy Bohmer return 0x01; 17823cd1385SRemy Bohmer else if (gadget_is_dummy(gadget)) 17923cd1385SRemy Bohmer return 0x02; 18023cd1385SRemy Bohmer else if (gadget_is_pxa(gadget)) 18123cd1385SRemy Bohmer return 0x03; 18223cd1385SRemy Bohmer else if (gadget_is_sh(gadget)) 18323cd1385SRemy Bohmer return 0x04; 18423cd1385SRemy Bohmer else if (gadget_is_sa1100(gadget)) 18523cd1385SRemy Bohmer return 0x05; 18623cd1385SRemy Bohmer else if (gadget_is_goku(gadget)) 18723cd1385SRemy Bohmer return 0x06; 18823cd1385SRemy Bohmer else if (gadget_is_mq11xx(gadget)) 18923cd1385SRemy Bohmer return 0x07; 19023cd1385SRemy Bohmer else if (gadget_is_omap(gadget)) 19123cd1385SRemy Bohmer return 0x08; 19223cd1385SRemy Bohmer else if (gadget_is_n9604(gadget)) 193*b9f4bc34SAlbert ARIBAUD return 0x09; 19423cd1385SRemy Bohmer else if (gadget_is_pxa27x(gadget)) 195*b9f4bc34SAlbert ARIBAUD return 0x10; 19623cd1385SRemy Bohmer else if (gadget_is_s3c2410(gadget)) 197*b9f4bc34SAlbert ARIBAUD return 0x11; 19823cd1385SRemy Bohmer else if (gadget_is_at91(gadget)) 199*b9f4bc34SAlbert ARIBAUD return 0x12; 20023cd1385SRemy Bohmer else if (gadget_is_imx(gadget)) 201*b9f4bc34SAlbert ARIBAUD return 0x13; 20223cd1385SRemy Bohmer else if (gadget_is_musbhsfc(gadget)) 203*b9f4bc34SAlbert ARIBAUD return 0x14; 20423cd1385SRemy Bohmer else if (gadget_is_musbhdrc(gadget)) 205*b9f4bc34SAlbert ARIBAUD return 0x15; 20623cd1385SRemy Bohmer else if (gadget_is_mpc8272(gadget)) 207*b9f4bc34SAlbert ARIBAUD return 0x16; 20823cd1385SRemy Bohmer else if (gadget_is_atmel_usba(gadget)) 209*b9f4bc34SAlbert ARIBAUD return 0x17; 21023cd1385SRemy Bohmer else if (gadget_is_fsl_usb2(gadget)) 211*b9f4bc34SAlbert ARIBAUD return 0x18; 21223cd1385SRemy Bohmer else if (gadget_is_amd5536udc(gadget)) 213*b9f4bc34SAlbert ARIBAUD return 0x19; 21423cd1385SRemy Bohmer else if (gadget_is_m66592(gadget)) 215*b9f4bc34SAlbert ARIBAUD return 0x20; 21626cc5129SLei Wen else if (gadget_is_mv(gadget)) 217*b9f4bc34SAlbert ARIBAUD return 0x21; 21823cd1385SRemy Bohmer return -ENOENT; 21923cd1385SRemy Bohmer } 220