2 * mx29f002.c: driver for MXIC MX29F002 flash models
5 * Copyright 2000 Silicon Integrated System Corporation
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 * MX29F002/002N data sheet
34 int probe_29f002(struct flashchip *flash)
36 volatile uint8_t *bios = flash->virt_addr;
39 *(bios + 0x5555) = 0xAA;
40 *(bios + 0x2AAA) = 0x55;
41 *(bios + 0x5555) = 0x90;
43 id1 = *(volatile uint8_t *) bios;
44 id2 = *(volatile uint8_t *) (bios + 0x01);
50 printf_debug("%s: id1 0x%x, id2 0x%x\n", __FUNCTION__, id1, id2);
51 if (id1 == flash->manufacture_id && id2 == flash->model_id)
57 int erase_29f002(struct flashchip *flash)
59 volatile uint8_t *bios = flash->virt_addr;
61 *(bios + 0x555) = 0xF0;
62 *(bios + 0x555) = 0xAA;
63 *(bios + 0x2AA) = 0x55;
64 *(bios + 0x555) = 0x80;
65 *(bios + 0x555) = 0xAA;
66 *(bios + 0x2AA) = 0x55;
67 *(bios + 0x555) = 0x10;
70 toggle_ready_jedec(bios);
72 // while ((*bios & 0x40) != 0x40)
76 toggle_ready_jedec(bios);
77 *(bios + 0x0ffff) = 0x30;
78 *(bios + 0x1ffff) = 0x30;
79 *(bios + 0x2ffff) = 0x30;
80 *(bios + 0x37fff) = 0x30;
81 *(bios + 0x39fff) = 0x30;
82 *(bios + 0x3bfff) = 0x30;
88 int write_29f002(struct flashchip *flash, uint8_t *buf)
91 int total_size = flash->total_size * 1024;
92 volatile uint8_t *bios = flash->virt_addr;
93 volatile uint8_t *dst = bios;
100 printf("Programming Page: ");
101 for (i = 0; i < total_size; i++) {
102 /* write to the sector */
103 if ((i & 0xfff) == 0)
104 printf("address: 0x%08lx", (unsigned long) i);
105 *(bios + 0x5555) = 0xAA;
106 *(bios + 0x2AAA) = 0x55;
107 *(bios + 0x5555) = 0xA0;
110 /* wait for Toggle bit ready */
111 toggle_ready_jedec(dst);
113 if ((i & 0xfff) == 0)
114 printf("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");