diff options
author | David Brownell <david-b@pacbell.net> | 2007-07-21 14:43:35 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2007-07-30 16:27:47 -0400 |
commit | 1060bce7b74c8914999a067803ec659949ff682e (patch) | |
tree | 9ad9ebfab596164fc0fc6acd87ebf52a3532f541 /drivers/usb/gadget | |
parent | 4f47bb567368f732989058e26dc282f7fe931dab (diff) |
USB: more pxa2xx_udc dead code removal
Remove some more dead code from the pxa2xx_udc driver: support
for a no-longer-undocumented hardware "test mode". Newer chips
made this the default, evidently as the best workaround for deep
silicon bugs. The interest was that this seemed to be the only
way to kick in the (documented!) double buffering capability.
Signed-off-by: David Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/gadget')
-rw-r--r-- | drivers/usb/gadget/pxa2xx_udc.c | 30 |
1 files changed, 0 insertions, 30 deletions
diff --git a/drivers/usb/gadget/pxa2xx_udc.c b/drivers/usb/gadget/pxa2xx_udc.c index 63b9521c1322..72b4ebbf132d 100644 --- a/drivers/usb/gadget/pxa2xx_udc.c +++ b/drivers/usb/gadget/pxa2xx_udc.c | |||
@@ -93,8 +93,6 @@ static const char driver_name [] = "pxa2xx_udc"; | |||
93 | static const char ep0name [] = "ep0"; | 93 | static const char ep0name [] = "ep0"; |
94 | 94 | ||
95 | 95 | ||
96 | // #define DISABLE_TEST_MODE | ||
97 | |||
98 | #ifdef CONFIG_ARCH_IXP4XX | 96 | #ifdef CONFIG_ARCH_IXP4XX |
99 | 97 | ||
100 | /* cpu-specific register addresses are compiled in to this code */ | 98 | /* cpu-specific register addresses are compiled in to this code */ |
@@ -113,17 +111,6 @@ static const char ep0name [] = "ep0"; | |||
113 | #define SIZE_STR "" | 111 | #define SIZE_STR "" |
114 | #endif | 112 | #endif |
115 | 113 | ||
116 | #ifdef DISABLE_TEST_MODE | ||
117 | /* (mode == 0) == no undocumented chip tweaks | ||
118 | * (mode & 1) == double buffer bulk IN | ||
119 | * (mode & 2) == double buffer bulk OUT | ||
120 | * ... so mode = 3 (or 7, 15, etc) does it for both | ||
121 | */ | ||
122 | static ushort fifo_mode = 0; | ||
123 | module_param(fifo_mode, ushort, 0); | ||
124 | MODULE_PARM_DESC (fifo_mode, "pxa2xx udc fifo mode"); | ||
125 | #endif | ||
126 | |||
127 | /* --------------------------------------------------------------------------- | 114 | /* --------------------------------------------------------------------------- |
128 | * endpoint related parts of the api to the usb controller hardware, | 115 | * endpoint related parts of the api to the usb controller hardware, |
129 | * used by gadget driver; and the inner talker-to-hardware core. | 116 | * used by gadget driver; and the inner talker-to-hardware core. |
@@ -1252,23 +1239,6 @@ static void udc_enable (struct pxa2xx_udc *dev) | |||
1252 | UDC_RES2 = 0x00; | 1239 | UDC_RES2 = 0x00; |
1253 | } | 1240 | } |
1254 | 1241 | ||
1255 | #ifdef DISABLE_TEST_MODE | ||
1256 | /* "test mode" seems to have become the default in later chip | ||
1257 | * revs, preventing double buffering (and invalidating docs). | ||
1258 | * this EXPERIMENT enables it for bulk endpoints by tweaking | ||
1259 | * undefined/reserved register bits (that other drivers clear). | ||
1260 | * Belcarra code comments noted this usage. | ||
1261 | */ | ||
1262 | if (fifo_mode & 1) { /* IN endpoints */ | ||
1263 | UDC_RES1 |= USIR0_IR1|USIR0_IR6; | ||
1264 | UDC_RES2 |= USIR1_IR11; | ||
1265 | } | ||
1266 | if (fifo_mode & 2) { /* OUT endpoints */ | ||
1267 | UDC_RES1 |= USIR0_IR2|USIR0_IR7; | ||
1268 | UDC_RES2 |= USIR1_IR12; | ||
1269 | } | ||
1270 | #endif | ||
1271 | |||
1272 | /* enable suspend/resume and reset irqs */ | 1242 | /* enable suspend/resume and reset irqs */ |
1273 | udc_clear_mask_UDCCR(UDCCR_SRM | UDCCR_REM); | 1243 | udc_clear_mask_UDCCR(UDCCR_SRM | UDCCR_REM); |
1274 | 1244 | ||