Sansa AMS SD driver: cleanup defines and comments

Remove useless E200V2 || FUZE || C200V2 : all those models have
MULTIDRIVE and/or HOTSWAP defined and have no specific difference.

Correct some comments

Remove HAVE_MULTIDRIVE within HAVE_HOTSWAP since HOTSWAP imply MULTIDRIVE

Change HOTSWAP to MULTIDRIVE where needed

Use NUM_DRIVES in sd_num_drives()

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@23180 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Rafaël Carré 2009-10-15 07:16:38 +00:00
parent afe08ed8b2
commit 5303ab101b

View file

@ -132,7 +132,6 @@ static unsigned char *uncached_buffer = UNCACHED_ADDR(&aligned_buffer[0]);
static inline void mci_delay(void) { int i = 0xffff; while(i--) ; } static inline void mci_delay(void) { int i = 0xffff; while(i--) ; }
#ifdef HAVE_HOTSWAP #ifdef HAVE_HOTSWAP
#if defined(SANSA_E200V2) || defined(SANSA_FUZE) || defined(SANSA_C200V2)
static int sd1_oneshot_callback(struct timeout *tmo) static int sd1_oneshot_callback(struct timeout *tmo)
{ {
(void)tmo; (void)tmo;
@ -152,11 +151,10 @@ static int sd1_oneshot_callback(struct timeout *tmo)
void INT_GPIOA(void) void INT_GPIOA(void)
{ {
static struct timeout sd1_oneshot; static struct timeout sd1_oneshot;
/* reset irq */ /* acknowledge interrupt */
GPIOA_IC = (1<<2); GPIOA_IC = (1<<2);
timeout_register(&sd1_oneshot, sd1_oneshot_callback, (3*HZ/10), 0); timeout_register(&sd1_oneshot, sd1_oneshot_callback, (3*HZ/10), 0);
} }
#endif /* defined(SANSA_E200V2) || defined(SANSA_FUZE) || defined(SANSA_C200V2) */
#endif /* HAVE_HOTSWAP */ #endif /* HAVE_HOTSWAP */
void INT_NAND(void) void INT_NAND(void)
@ -448,7 +446,6 @@ static void init_pl180_controller(const int drive)
VIC_INT_ENABLE |= VIC_INT_ENABLE |=
(drive == INTERNAL_AS3525) ? INTERRUPT_NAND : INTERRUPT_MCI0; (drive == INTERNAL_AS3525) ? INTERRUPT_NAND : INTERRUPT_MCI0;
#if defined(SANSA_E200V2) || defined(SANSA_FUZE) || defined(SANSA_C200V2)
/* setup isr for microsd monitoring */ /* setup isr for microsd monitoring */
VIC_INT_ENABLE |= (INTERRUPT_GPIOA); VIC_INT_ENABLE |= (INTERRUPT_GPIOA);
/* clear previous irq */ /* clear previous irq */
@ -458,8 +455,6 @@ static void init_pl180_controller(const int drive)
/* detect both raising and falling edges */ /* detect both raising and falling edges */
GPIOA_IBE |= (1<<2); GPIOA_IBE |= (1<<2);
#endif
#else #else
VIC_INT_ENABLE |= INTERRUPT_NAND; VIC_INT_ENABLE |= INTERRUPT_NAND;
#endif #endif
@ -519,27 +514,14 @@ int sd_init(void)
#ifdef HAVE_HOTSWAP #ifdef HAVE_HOTSWAP
bool sd_removable(IF_MD_NONVOID(int drive)) bool sd_removable(IF_MD_NONVOID(int drive))
{ {
#ifndef HAVE_MULTIDRIVE
const int drive=0;
#endif
return (drive==1); return (drive==1);
} }
bool sd_present(IF_MD_NONVOID(int drive)) bool sd_present(IF_MD_NONVOID(int drive))
{ {
#ifndef HAVE_MULTIDRIVE return (drive == 0) ? true : card_detect_target();
const int drive=0;
#endif
if(drive==0)
{
return true;
}
else
{
return card_detect_target();
}
} }
#endif #endif /* HAVE_HOTSWAP */
static int sd_wait_for_state(const int drive, unsigned int state) static int sd_wait_for_state(const int drive, unsigned int state)
{ {
@ -825,7 +807,7 @@ long sd_last_disk_activity(void)
void sd_enable(bool on) void sd_enable(bool on)
{ {
/* buttonlight AMSes need a bit of special handling for the buttonlight here, /* buttonlight AMSes need a bit of special handling for the buttonlight here
* due to the dual mapping of GPIOD and XPD */ * due to the dual mapping of GPIOD and XPD */
#if defined(HAVE_BUTTON_LIGHT) && defined(HAVE_MULTIDRIVE) #if defined(HAVE_BUTTON_LIGHT) && defined(HAVE_MULTIDRIVE)
extern int buttonlight_is_on; extern int buttonlight_is_on;
@ -843,8 +825,8 @@ void sd_enable(bool on)
GPIOD_DIR &= ~(1<<7); GPIOD_DIR &= ~(1<<7);
else else
_buttonlight_off(); _buttonlight_off();
#endif #endif /* HAVE_BUTTON_LIGHT */
#endif #endif /* HAVE_MULTIDRIVE */
CGU_IDE |= (1<<7) /* AHB interface enable */ | CGU_IDE |= (1<<7) /* AHB interface enable */ |
(1<<6) /* interface enable */; (1<<6) /* interface enable */;
sd_enabled = true; sd_enabled = true;
@ -857,9 +839,9 @@ void sd_enable(bool on)
CCU_IO &= ~(1<<2); CCU_IO &= ~(1<<2);
if (buttonlight_is_on) if (buttonlight_is_on)
_buttonlight_on(); _buttonlight_on();
#endif #endif /* HAVE_BUTTON_LIGHT */
CGU_PERI &= ~CGU_MCI_CLOCK_ENABLE; CGU_PERI &= ~CGU_MCI_CLOCK_ENABLE;
#endif #endif /* HAVE_MULTIDRIVE */
CGU_IDE &= ~((1<<7)|(1<<6)); CGU_IDE &= ~((1<<7)|(1<<6));
sd_enabled = false; sd_enabled = false;
} }
@ -872,8 +854,7 @@ tCardInfo *card_get_info_target(int card_no)
bool card_detect_target(void) bool card_detect_target(void)
{ {
#if defined(HAVE_HOTSWAP) && \ #if defined(HAVE_MULTIDRIVE)
(defined(SANSA_E200V2) || defined(SANSA_FUZE) || defined(SANSA_C200V2))
return !(GPIOA_PIN(2)); return !(GPIOA_PIN(2));
#else #else
return false; return false;
@ -883,36 +864,21 @@ bool card_detect_target(void)
#ifdef HAVE_HOTSWAP #ifdef HAVE_HOTSWAP
void card_enable_monitoring_target(bool on) void card_enable_monitoring_target(bool on)
{ {
if (on) if (on) /* enable interrupt */
{
/* add e200v2/c200v2 here */
#if defined(SANSA_E200V2) || defined(SANSA_FUZE) || defined(SANSA_C200V2)
/* enable isr*/
GPIOA_IE |= (1<<2); GPIOA_IE |= (1<<2);
#endif else /* disable interrupt */
}
else
{
#if defined(SANSA_E200V2) || defined(SANSA_FUZE) || defined(SANSA_C200V2)
/* edisable isr*/
GPIOA_IE &= ~(1<<2); GPIOA_IE &= ~(1<<2);
#endif
}
} }
#endif #endif /* HAVE_HOTSWAP */
#endif /* BOOTLOADER */ #endif /* !BOOTLOADER */
#ifdef CONFIG_STORAGE_MULTI #ifdef CONFIG_STORAGE_MULTI
int sd_num_drives(int first_drive) int sd_num_drives(int first_drive)
{ {
/* We don't care which logical drive number(s) we have been assigned */ /* We don't care which logical drive number(s) we have been assigned */
(void)first_drive; (void)first_drive;
#ifdef HAVE_MULTIDRIVE return NUM_DRIVES;
return 2;
#else
return 1;
#endif
} }
#endif #endif /* CONFIG_STORAGE_MULTI */