From 8c078f34ffc8b20282263a31d8a7e0c8294a848f Mon Sep 17 00:00:00 2001 From: Dave Chapman Date: Sat, 10 Oct 2009 15:26:38 +0000 Subject: Nano2G - reboot into disk mode when USB is inserted. git-svn-id: svn://svn.rockbox.org/rockbox/trunk@23070 a1c6a512-1295-4272-9138-f99709370657 --- firmware/target/arm/s5l8700/usb-s5l8700.c | 31 ++++++++++++++++++++----------- 1 file changed, 20 insertions(+), 11 deletions(-) (limited to 'firmware/target') diff --git a/firmware/target/arm/s5l8700/usb-s5l8700.c b/firmware/target/arm/s5l8700/usb-s5l8700.c index 6ad4dcea95..c0bf7a951b 100644 --- a/firmware/target/arm/s5l8700/usb-s5l8700.c +++ b/firmware/target/arm/s5l8700/usb-s5l8700.c @@ -20,6 +20,9 @@ ****************************************************************************/ #include "config.h" #include "usb.h" +#include "cpu.h" +#include "system.h" +#include "string.h" void usb_init_device(void) { @@ -27,21 +30,27 @@ void usb_init_device(void) void usb_enable(bool on) { - (void)on; -} - -void usb_attach(void) -{ + /* This device specific code will eventually give way to proper USB + handling, which should be the same for all S5L870x targets. */ + if (on) + { +#ifdef IPOD_ARCH + /* For iPod, we can only do one thing with USB mode atm - reboot + into the flash-based disk-mode. This does not return. */ -} + memcpy((void *)0x0002bf00, "diskmodehotstuff\1\0\0\0", 20); -static bool usb_pin_state(void) -{ - return false; + system_reboot(); /* Reboot */ +#endif + } } -/* detect host or charger (INSERTED or EXTRACTED) */ int usb_detect(void) { - return usb_pin_state() ? USB_INSERTED : USB_EXTRACTED; +#if defined(IPOD_NANO2G) + if ((PDAT14 & 0x8) == 0x0) + return USB_INSERTED; +#endif + + return USB_EXTRACTED; } -- cgit v1.2.3