mirror of
https://review.coreboot.org/flashrom.git
synced 2025-04-26 22:52:34 +02:00
Support for the 39sf020
Corresponding to coreboot v1 svn r544.
This commit is contained in:
parent
3193a90719
commit
213ee71ff4
@ -48,7 +48,7 @@ struct flashchip flashchips[] = {
|
|||||||
{"SST28SF040A", SST_ID, SST_28SF040, NULL, 512, 256,
|
{"SST28SF040A", SST_ID, SST_28SF040, NULL, 512, 256,
|
||||||
probe_28sf040, erase_28sf040, write_28sf040},
|
probe_28sf040, erase_28sf040, write_28sf040},
|
||||||
{"SST39SF020A", SST_ID, SST_39SF020, NULL, 256, 4096,
|
{"SST39SF020A", SST_ID, SST_39SF020, NULL, 256, 4096,
|
||||||
probe_jedec, erase_jedec, write_39sf020},
|
probe_39sf020, erase_39sf020, write_39sf020},
|
||||||
{"W29C020C", WINBOND_ID, W_29C020C, NULL, 256, 128,
|
{"W29C020C", WINBOND_ID, W_29C020C, NULL, 256, 128,
|
||||||
probe_jedec, erase_jedec, write_jedec},
|
probe_jedec, erase_jedec, write_jedec},
|
||||||
{NULL,}
|
{NULL,}
|
||||||
|
47
sst39sf020.c
47
sst39sf020.c
@ -72,13 +72,19 @@ static __inline__ erase_sector_39sf020 (volatile char * bios, unsigned long addr
|
|||||||
toggle_ready_jedec(bios);
|
toggle_ready_jedec(bios);
|
||||||
}
|
}
|
||||||
|
|
||||||
static __inline__ write_sector_39sf020(volatile char * bios, unsigned char * src,
|
static __inline__ write_sector_39sf020(volatile char * bios,
|
||||||
volatile unsigned char * dst, unsigned int page_size)
|
unsigned char * src,
|
||||||
|
volatile unsigned char * dst,
|
||||||
|
unsigned int page_size)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
volatile char *Temp;
|
volatile char *Temp;
|
||||||
|
|
||||||
for (i = 0; i < page_size; i++) {
|
for (i = 0; i < page_size; i++) {
|
||||||
|
if (*dst != 0xff) {
|
||||||
|
printf("FATAL: dst %p not erased (val 0x%x\n", dst, *dst);
|
||||||
|
return;
|
||||||
|
}
|
||||||
/* transfer data from source to destination */
|
/* transfer data from source to destination */
|
||||||
if (*src == 0xFF) {
|
if (*src == 0xFF) {
|
||||||
dst++, src++;
|
dst++, src++;
|
||||||
@ -91,8 +97,11 @@ static __inline__ write_sector_39sf020(volatile char * bios, unsigned char * src
|
|||||||
*Temp = 0x55;
|
*Temp = 0x55;
|
||||||
Temp = bios + 0x5555;
|
Temp = bios + 0x5555;
|
||||||
*Temp = 0xA0;
|
*Temp = 0xA0;
|
||||||
*dst++ = *src++;
|
*dst = *src;
|
||||||
toggle_ready_jedec(bios);
|
toggle_ready_jedec(bios);
|
||||||
|
if (*dst != *src) printf("BAD! dst 0x%x val 0x%x src 0x%x\n",
|
||||||
|
dst, *dst, *src);
|
||||||
|
dst++, src++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,15 +136,29 @@ int probe_39sf020 (struct flashchip * flash)
|
|||||||
|
|
||||||
int erase_39sf020 (struct flashchip * flash)
|
int erase_39sf020 (struct flashchip * flash)
|
||||||
{
|
{
|
||||||
volatile char * bios = flash->virt_addr;
|
volatile unsigned char * bios = flash->virt_addr;
|
||||||
|
volatile unsigned char *Temp;
|
||||||
unprotect_39sf020 (bios);
|
/* Issue the Sector Erase command to 39SF020 */
|
||||||
*bios = CHIP_ERASE;
|
printf(__FUNCTION__ " bios is %p\n", bios);
|
||||||
*bios = CHIP_ERASE;
|
Temp = bios + 0x5555; /* set up address to be C000:5555h */
|
||||||
protect_39sf020 (bios);
|
*Temp = 0xAA; /* write data 0xAA to the address */
|
||||||
|
|
||||||
myusec_delay(10);
|
myusec_delay(10);
|
||||||
toggle_ready_jedec(bios);
|
Temp = bios + 0x2AAA; /* set up address to be C000:2AAAh */
|
||||||
|
*Temp = 0x55; /* write data 0x55 to the address */
|
||||||
|
myusec_delay(10);
|
||||||
|
Temp = bios + 0x5555; /* set up address to be C000:5555h */
|
||||||
|
*Temp = 0x80; /* write data 0x80 to the address */
|
||||||
|
myusec_delay(10);
|
||||||
|
Temp = bios + 0x5555; /* set up address to be C000:5555h */
|
||||||
|
*Temp = 0xAA; /* write data 0xAA to the address */
|
||||||
|
myusec_delay(10);
|
||||||
|
Temp = bios + 0x2AAA; /* set up address to be C000:2AAAh */
|
||||||
|
*Temp = 0x55; /* write data 0x55 to the address */
|
||||||
|
myusec_delay(10);
|
||||||
|
Temp = bios + 0x5555; /* set up address to be C000:5555h */
|
||||||
|
*Temp = 0x10; /* write data 0x55 to the address */
|
||||||
|
|
||||||
|
myusec_delay(20000);
|
||||||
}
|
}
|
||||||
|
|
||||||
int write_39sf020 (struct flashchip * flash, char * buf)
|
int write_39sf020 (struct flashchip * flash, char * buf)
|
||||||
@ -145,7 +168,7 @@ int write_39sf020 (struct flashchip * flash, char * buf)
|
|||||||
volatile char * bios = flash->virt_addr;
|
volatile char * bios = flash->virt_addr;
|
||||||
|
|
||||||
// unprotect_39sf020 (bios);
|
// unprotect_39sf020 (bios);
|
||||||
|
erase_39sf020(flash);
|
||||||
printf ("Programming Page: ");
|
printf ("Programming Page: ");
|
||||||
for (i = 0; i < total_size/page_size; i++) {
|
for (i = 0; i < total_size/page_size; i++) {
|
||||||
/* erase the page before programming */
|
/* erase the page before programming */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user