Hello, I wrote:
Signed-off-by: Swaminathan S <swami.iyer@xxxxxx>
Does fix MUSB for me in the linux-davinci tree. Linus' tree crashes
this way:
<6>usbcore: registered new interface driver usbfs
<6>usbcore: registered new interface driver hub
<6>usbcore: registered new device driver usb
<6>pcf857x 1-0038: gpios 104..111 on a pcf8574
<6>pcf857x 1-0039: gpios 112..119 on a pcf8574
<6>pcf857x 1-003a: gpios 120..127 on a pcf8574
<7>Switched to high resolution mode on CPU 0
<6>musb_hdrc: version 6.0, pio, host, debug=0
<1>Unable to handle kernel NULL pointer dereference at virtual address
0000002c
<1>pgd = c0004000
<1>[0000002c] *pgd=00000000
Internal error: Oops: 5 [#1] PREEMPT
<d>Modules linked in:
CPU: 0 Not tainted (2.6.31-rc8-00015-gadda766-dirty #9)
PC is at gpio_set_value_cansleep+0x20/0x40
LR is at davinci_source_power+0x4c/0x7c
pc : [<c0149c60>] lr : [<c01941c4>] psr: 20000013
sp : cf823e18 ip : 00000090 fp : 00000000
r10: c02e6ca0 r9 : c02e6c78 r8 : c02f7f58
r7 : 00147900 r6 : fec64000 r5 : cf8488d8 r4 : 00000000
r3 : 00000000 r2 : 00000001 r1 : 00000001 r0 : 000006c0
Flags: nzCv IRQs on FIQs on Mode SVC_32 ISA ARM Segment kernel
Control: 0005317f Table: 80004000 DAC: 00000017
Process swapper (pid: 1, stack limit = 0xcf822270)
Stack: (0xcf823e18 to 0xcf824000)
3e00: fec64000
c01941c4
3e20: cf8488d8 c00191a0 c02f8d8c c02e6d50 cf8488d8 00000000 00000000
c001883c
3e40: cf822000 00000000 cf856320 00000002 cf822000 c0314a5c c02e6c98
0000000c
3e60: fec64000 00000000 000000d0 cf806850 00000000 c013d528 cf823ecc
cf802780
3e80: 00000000 c02289f0 00000000 00000000 00000000 c00d3b68 00000000
cf823eb0
3ea0: cf823eb4 c00d33b8 cf8616c0 cf865a50 cf823ee0 c00d37cc cf865a50
00000000
3ec0: cf865a50 cf823ee0 cf8616c0 00000001 00000001 00000000 00000000
c00d48c4
3ee0: cf8616c0 00000000 00000000 c02e6ca0 c02e6cd4 c02f8d8c c02f8d8c
c02f7f58
3f00: 00000001 00000000 00000000 c0178154 c02f8d8c c0177258 00000000
c02e6ca0
3f20: c02e6cd4 c02f8d8c c02f8d8c c0177370 00000000 cf823f40 c0177310
c017672c
3f40: cf8045b8 cf8633f0 c02f8d8c c001e910 c02f8d8c cf894b40 00000000
c0176cdc
3f60: c023c1a8 00000000 00000000 c001e910 c02f8d8c 00000000 00000000
c02fe8a0
3f80: c001847c c0177740 00000000 c001e910 c02f8d70 00000000 00000000
c02fe8a0
3fa0: c001847c c0178388 c001e910 c001eac4 00000000 c0025314 00000000
00000000
3fc0: 00000000 000000a8 c001e910 c001eac4 00000000 00000000 00000000
00000000
3fe0: 00000000 c0008890 00000000 00000000 00000000 c002680c ffffffff
ffffffff
[<c0149c60>] (gpio_set_value_cansleep+0x20/0x40) from [<c01941c4>]
(davinci_source_power+0x4c/0x7c)
[<c01941c4>] (davinci_source_power+0x4c/0x7c) from [<c00191a0>]
(musb_platform_init+0x7c/0x154)
[<c00191a0>] (musb_platform_init+0x7c/0x154) from [<c001883c>]
(musb_probe+0x208/0xaf0)
[<c001883c>] (musb_probe+0x208/0xaf0) from [<c0178154>]
(platform_drv_probe+0x1c/0x24)
[<c0178154>] (platform_drv_probe+0x1c/0x24) from [<c0177258>]
(driver_probe_device+0xac/0x164)
[<c0177258>] (driver_probe_device+0xac/0x164) from [<c0177370>]
(__driver_attach+0x60/0x84)
[<c0177370>] (__driver_attach+0x60/0x84) from [<c017672c>]
(bus_for_each_dev+0x4c/0x80)
[<c017672c>] (bus_for_each_dev+0x4c/0x80) from [<c0176cdc>]
(bus_add_driver+0x9c/0x220)
[<c0176cdc>] (bus_add_driver+0x9c/0x220) from [<c0177740>]
(driver_register+0xac/0x13c)
[<c0177740>] (driver_register+0xac/0x13c) from [<c0178388>]
(platform_driver_probe+0x10/0x8c)
[<c0178388>] (platform_driver_probe+0x10/0x8c) from [<c0025314>]
(do_one_initcall+0x54/0x194)
[<c0025314>] (do_one_initcall+0x54/0x194) from [<c0008890>]
(kernel_init+0x94/0x10c)
[<c0008890>] (kernel_init+0x94/0x10c) from [<c002680c>]
(kernel_thread_exit+0x0/0x8)
Code: e59f3024 e1a02001 e7903003 e24dd004 (e593102c)
<4>---[ end trace 1b75b31a2719ed1c ]---
<0>Kernel panic - not syncing: Attempted to kill init!
[<c002a5f8>] (unwind_backtrace+0x0/0xdc) from [<c00391ac>]
(panic+0x4c/0x11c)
[<c00391ac>] (panic+0x4c/0x11c) from [<c003bf84>] (do_exit+0x5c/0x620)
[<c003bf84>] (do_exit+0x5c/0x620) from [<c00294bc>] (die+0x158/0x178)
[<c00294bc>] (die+0x158/0x178) from [<c002b58c>]
(__do_kernel_fault+0x68/0x80)
[<c002b58c>] (__do_kernel_fault+0x68/0x80) from [<c002b7c0>]
(do_page_fault+0x21c/0x23c)
[<c002b7c0>] (do_page_fault+0x21c/0x23c) from [<c0025258>]
(do_DataAbort+0x34/0x98)
[<c0025258>] (do_DataAbort+0x34/0x98) from [<c00259cc>]
(__dabt_svc+0x4c/0x60)
Exception stack(0xcf823dd0 to 0xcf823e18)
3dc0: 000006c0 00000001 00000001
00000000
3de0: 00000000 cf8488d8 fec64000 00147900 c02f7f58 c02e6c78 c02e6ca0
00000000
3e00: 00000090 cf823e18 c01941c4 c0149c60 20000013 ffffffff
[<c00259cc>] (__dabt_svc+0x4c/0x60) from [<c0149c60>]
(gpio_set_value_cansleep+0x20/0x40)
[<c0149c60>] (gpio_set_value_cansleep+0x20/0x40) from [<c01941c4>]
(davinci_source_power+0x4c/0x7c)
[<c01941c4>] (davinci_source_power+0x4c/0x7c) from [<c00191a0>]
(musb_platform_init+0x7c/0x154)
[<c00191a0>] (musb_platform_init+0x7c/0x154) from [<c001883c>]
(musb_probe+0x208/0xaf0)
[<c001883c>] (musb_probe+0x208/0xaf0) from [<c0178154>]
(platform_drv_probe+0x1c/0x24)
[<c0178154>] (platform_drv_probe+0x1c/0x24) from [<c0177258>]
(driver_probe_device+0xac/0x164)
[<c0177258>] (driver_probe_device+0xac/0x164) from [<c0177370>]
(__driver_attach+0x60/0x84)
[<c0177370>] (__driver_attach+0x60/0x84) from [<c017672c>]
(bus_for_each_dev+0x4c/0x80)
[<c017672c>] (bus_for_each_dev+0x4c/0x80) from [<c0176cdc>]
(bus_add_driver+0x9c/0x220)
[<c0176cdc>] (bus_add_driver+0x9c/0x220) from [<c0177740>]
(driver_register+0xac/0x13c)
[<c0177740>] (driver_register+0xac/0x13c) from [<c0178388>]
(platform_driver_probe+0x10/0x8c)
[<c0178388>] (platform_driver_probe+0x10/0x8c) from [<c0025314>]
(do_one_initcall+0x54/0x194)
[<c0025314>] (do_one_initcall+0x54/0x194) from [<c0008890>]
(kernel_init+0x94/0x10c)
[<c0008890>] (kernel_init+0x94/0x10c) from [<c002680c>]
(kernel_thread_exit+0x0/0x8)
diff --git a/drivers/usb/musb/davinci.c b/drivers/usb/musb/davinci.c
index e16ff60..6691381 100644
--- a/drivers/usb/musb/davinci.c
+++ b/drivers/usb/musb/davinci.c
@@ -42,7 +42,7 @@
#include "musb_core.h"
#ifdef CONFIG_MACH_DAVINCI_EVM
-#define GPIO_nVBUS_DRV 144
+#define GPIO_nVBUS_DRV 160
Note that the last GPIO for PCF8574 expander is 127 in the trace
above. So, does this really apply to the mainline tree? It seems that
even 144 doesn't...
120 works though... so updating to 144 and 160 are a bit to soonish.
Don't apply this patch yet please. Looks like we need to revet back to 120
instead...
#endif
#include "davinci.h"
WBR, Sergei
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html