summaryrefslogtreecommitdiff
path: root/util/flash_and_burn/w49f002u.c
diff options
context:
space:
mode:
authorLi-Ta Lo <ollie@lanl.gov>2004-03-17 23:03:37 +0000
committerLi-Ta Lo <ollie@lanl.gov>2004-03-17 23:03:37 +0000
commit698f23db22cc71da488eb9bec001fda60cbf0b35 (patch)
treed21543d81b88cf048246688d96e337e031f4498a /util/flash_and_burn/w49f002u.c
parente74ff463c488acdc300a9486b4f1b749e841a30d (diff)
removed spd_dump.c, it has nothing to do with flashing flash parts.
use standard product ID exit method for w49f002u move udelay stuff into its own file git-svn-id: svn://svn.coreboot.org/coreboot/trunk@1433 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
Diffstat (limited to 'util/flash_and_burn/w49f002u.c')
-rw-r--r--util/flash_and_burn/w49f002u.c80
1 files changed, 33 insertions, 47 deletions
diff --git a/util/flash_and_burn/w49f002u.c b/util/flash_and_burn/w49f002u.c
index b7c57eb256..4d5d16b653 100644
--- a/util/flash_and_burn/w49f002u.c
+++ b/util/flash_and_burn/w49f002u.c
@@ -22,7 +22,7 @@
* Reference:
* W49F002U data sheet
*
- * $Id
+ * $Id$
*/
#include <stdio.h>
@@ -35,14 +35,16 @@ int probe_49f002 (struct flashchip * flash)
volatile char * bios = flash->virt_addr;
unsigned char id1, id2;
- *(bios + 0x5555) = 0xAA;
- *(bios + 0x2AAA) = 0x55;
- *(bios + 0x5555) = 0x90;
+ *(volatile char *) (bios + 0x5555) = 0xAA;
+ *(volatile char *) (bios + 0x2AAA) = 0x55;
+ *(volatile char *) (bios + 0x5555) = 0x90;
id1 = *(volatile unsigned char *) bios;
id2 = *(volatile unsigned char *) (bios + 0x01);
-
- *bios = 0xF0;
+
+ *(volatile char *) (bios + 0x5555) = 0xAA;
+ *(volatile char *) (bios + 0x2AAA) = 0x55;
+ *(volatile char *) (bios + 0x5555) = 0xF0;
myusec_delay(10);
@@ -68,52 +70,36 @@ int erase_49f002 (struct flashchip * flash)
myusec_delay(100);
toggle_ready_jedec(bios);
- // while ((*bios & 0x40) != 0x40)
- //;
-
-#if 0
- toggle_ready_jedec(bios);
- *(bios + 0x0ffff) = 0x30;
- *(bios + 0x1ffff) = 0x30;
- *(bios + 0x2ffff) = 0x30;
- *(bios + 0x37fff) = 0x30;
- *(bios + 0x39fff) = 0x30;
- *(bios + 0x3bfff) = 0x30;
-#endif
-
return(0);
}
int write_49f002 (struct flashchip * flash, unsigned char * buf)
{
- int i;
- int total_size = flash->total_size * 1024;
- volatile char * bios = flash->virt_addr;
- volatile char * dst = bios;
-
- *bios = 0xF0;
- myusec_delay(10);
- erase_49f002(flash);
- //*bios = 0xF0;
-#if 1
- printf ("Programming Page: ");
- for (i = 0; i < total_size; i++) {
- /* write to the sector */
- if ((i & 0xfff) == 0)
- printf ("address: 0x%08lx", (unsigned long)i);
- *(bios + 0x5555) = 0xAA;
- *(bios + 0x2AAA) = 0x55;
- *(bios + 0x5555) = 0xA0;
- *dst++ = *buf++;
-
- /* wait for Toggle bit ready */
- toggle_ready_jedec(dst);
+ int i;
+ int total_size = flash->total_size * 1024;
+ volatile char * bios = flash->virt_addr;
+ volatile char * dst = bios;
- if ((i & 0xfff) == 0)
- printf ("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
- }
-#endif
- printf("\n");
+ myusec_delay(10);
+ erase_49f002(flash);
+
+ printf ("Programming Page: ");
+ for (i = 0; i < total_size; i++) {
+ /* write to the sector */
+ if ((i & 0xfff) == 0)
+ printf ("address: 0x%08lx", (unsigned long)i);
+ *(bios + 0x5555) = 0xAA;
+ *(bios + 0x2AAA) = 0x55;
+ *(bios + 0x5555) = 0xA0;
+ *dst++ = *buf++;
+
+ /* wait for Toggle bit ready */
+ toggle_ready_jedec(dst);
+
+ if ((i & 0xfff) == 0)
+ printf ("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
+ }
+ printf("\n");
- return(0);
+ return(0);
}