#include #ifdef DFII_BASE #include #include #include #include #include #include "sdram.h" static void cdelay(int i) { while(i > 0) { #if defined (__lm32__) __asm__ volatile("nop"); #elif defined (__or1k__) __asm__ volatile("l.nop"); #else #error Unsupported architecture #endif i--; } } void sdrsw(void) { dfii_control_write(DFII_CONTROL_CKE); printf("SDRAM now under software control\n"); } void sdrhw(void) { dfii_control_write(DFII_CONTROL_SEL|DFII_CONTROL_CKE); printf("SDRAM now under hardware control\n"); } void sdrrow(char *_row) { char *c; unsigned int row; if(*_row == 0) { dfii_pi0_address_write(0x0000); dfii_pi0_baddress_write(0); command_p0(DFII_COMMAND_RAS|DFII_COMMAND_WE|DFII_COMMAND_CS); cdelay(15); printf("Precharged\n"); } else { row = strtoul(_row, &c, 0); if(*c != 0) { printf("incorrect row\n"); return; } dfii_pi0_address_write(row); dfii_pi0_baddress_write(0); command_p0(DFII_COMMAND_RAS|DFII_COMMAND_CS); cdelay(15); printf("Activated row %d\n", row); } } void sdrrd(char *startaddr) { char *c; unsigned int addr; int i; if(*startaddr == 0) { printf("sdrrd
\n"); return; } addr = strtoul(startaddr, &c, 0); if(*c != 0) { printf("incorrect address\n"); return; } dfii_pird_address_write(addr); dfii_pird_baddress_write(0); command_prd(DFII_COMMAND_CAS|DFII_COMMAND_CS|DFII_COMMAND_RDDATA); cdelay(15); // FIXME for(i=0;i<8;i++) printf("%02x", MMPTR(0xe0001038+4*i)); for(i=0;i<8;i++) printf("%02x", MMPTR(0xe000108c+4*i)); printf("\n"); } void sdrwr(char *startaddr) { char *c; unsigned int addr; int i; if(*startaddr == 0) { printf("sdrrd
\n"); return; } addr = strtoul(startaddr, &c, 0); if(*c != 0) { printf("incorrect address\n"); return; } // FIXME for(i=0;i<8;i++) { MMPTR(0xe0001018+4*i) = i; MMPTR(0xe000106c+4*i) = 0xf0 + i; } dfii_piwr_address_write(addr); dfii_piwr_baddress_write(0); command_pwr(DFII_COMMAND_CAS|DFII_COMMAND_WE|DFII_COMMAND_CS|DFII_COMMAND_WRDATA); } #define TEST_SIZE (4*1024*1024) int memtest_silent(void) { volatile unsigned int *array = (unsigned int *)SDRAM_BASE; int i; unsigned int prv; unsigned int error_cnt; prv = 0; for(i=0;i