/* * CF IDE addon card code * * Enter bugs at http://blackfin.uclinux.org/ * * Copyright (c) 2005-2009 Analog Devices Inc. * * Licensed under the GPL-2 or later. */ #include #include #include void cf_outb(unsigned char val, volatile unsigned char *addr) { /* "ETHERNET" means the expansion memory banks */ swap_to(ETHERNET); *addr = val; SSYNC(); swap_to(FLASH); } unsigned char cf_inb(volatile unsigned char *addr) { unsigned char c; swap_to(ETHERNET); c = *addr; SSYNC(); swap_to(FLASH); return c; } void cf_insw(unsigned short *sect_buf, unsigned short *addr, int words) { int i; swap_to(ETHERNET); for (i = 0; i < words; i++) { *(sect_buf + i) = *addr; SSYNC(); } swap_to(FLASH); } void cf_outsw(unsigned short *addr, unsigned short *sect_buf, int words) { int i; swap_to(ETHERNET); for (i = 0; i < words; i++) { *addr = *(sect_buf + i); SSYNC(); } swap_to(FLASH); } /* Definitions used in Compact Flash Boot support */ #define FIO_EDGE_CF_BITS 0x0000 #define FIO_POLAR_CF_BITS 0x0000 #define FIO_EDGE_BITS 0x1E0 #define FIO_POLAR_BITS 0x160 /* Compact flash status bits in status register */ #define CF_STAT_BITS 0x00000060 void cf_ide_init(void) { int i, cf_stat; /* Check whether CF card is inserted */ bfin_write_FIO_EDGE(FIO_EDGE_CF_BITS); bfin_write_FIO_POLAR(FIO_POLAR_CF_BITS); for (i = 0; i < 0x300; i++) asm volatile("nop;"); cf_stat = bfin_read_FIO_FLAG_S() & CF_STAT_BITS; bfin_write_FIO_EDGE(FIO_EDGE_BITS); bfin_write_FIO_POLAR(FIO_POLAR_BITS); if (!cf_stat) { for (i = 0; i < 0x3000; i++) asm volatile("nop;"); ide_init(); } }