blob: e5af5459ce81a231446c6088b6b911b2a1763526 [file] [log] [blame]
Roman Kononov41c47672006-10-07 00:21:13 +00001/* sst49lf040.c: driver for SST49LF040 flash models.
David Hendricks3770a112004-03-17 21:47:30 +00002 *
3 *
4 * Copyright 2000 Silicon Integrated System Corporation
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 *
20 *
21 * Reference:
Stefan Reinauer7ed78c82007-05-24 09:26:39 +000022 * 4 Megabit (512K x 8) SuperFlash EEPROM, SST49lF040 data sheet
David Hendricks3770a112004-03-17 21:47:30 +000023 *
Stefan Reinauer7ed78c82007-05-24 09:26:39 +000024 * TODO: Consilidated to standard JEDEC code.
Ollie Lhocf29de82004-03-18 19:40:07 +000025 *
David Hendricks3770a112004-03-17 21:47:30 +000026 */
Uwe Hermannffec5f32007-08-23 16:08:21 +000027
David Hendricks3770a112004-03-17 21:47:30 +000028#include <stdio.h>
29#include "flash.h"
David Hendricks3770a112004-03-17 21:47:30 +000030
Ollie Lhoa1439cf2005-01-11 02:48:22 +000031int erase_49lf040(struct flashchip *flash)
32{
Uwe Hermann0b7afe62007-04-01 19:44:21 +000033 int i;
34 int total_size = flash->total_size * 1024;
35 int page_size = flash->page_size;
Stefan Reinauerce532972007-05-23 17:20:56 +000036 volatile uint8_t *bios = flash->virtual_memory;
Ollie Lhoa1439cf2005-01-11 02:48:22 +000037
Uwe Hermann0b7afe62007-04-01 19:44:21 +000038 for (i = 0; i < total_size / page_size; i++) {
Ollie Lhoa1439cf2005-01-11 02:48:22 +000039 /* Chip erase only works in parallel programming mode
40 * for the 49lf040. Use sector-erase instead */
41 erase_sector_jedec(bios, i * page_size);
Uwe Hermann0b7afe62007-04-01 19:44:21 +000042 }
Uwe Hermannffec5f32007-08-23 16:08:21 +000043
Ollie Lhoa1439cf2005-01-11 02:48:22 +000044 return 0;
45}
46
Ollie Lho184a4042005-11-26 21:55:36 +000047int write_49lf040(struct flashchip *flash, uint8_t *buf)
David Hendricks3770a112004-03-17 21:47:30 +000048{
49 int i;
Ollie Lho8b8897a2004-03-27 00:18:15 +000050 int total_size = flash->total_size * 1024;
51 int page_size = flash->page_size;
Stefan Reinauerce532972007-05-23 17:20:56 +000052 volatile uint8_t *bios = flash->virtual_memory;
David Hendricks3770a112004-03-17 21:47:30 +000053
Ollie Lho761bf1b2004-03-20 16:46:10 +000054 printf("Programming Page: ");
55 for (i = 0; i < total_size / page_size; i++) {
Ollie Lho73eca802004-03-19 22:10:07 +000056 /* erase the page before programming
Ollie Lhoa1439cf2005-01-11 02:48:22 +000057 * Chip erase only works in parallel programming mode
58 * for the 49lf040. Use sector-erase instead */
Ollie Lho73eca802004-03-19 22:10:07 +000059 erase_sector_jedec(bios, i * page_size);
David Hendricks3770a112004-03-17 21:47:30 +000060
61 /* write to the sector */
Roman Kononov41c47672006-10-07 00:21:13 +000062 printf("%04d at address: 0x%08x ", i, i * page_size);
Uwe Hermann0b7afe62007-04-01 19:44:21 +000063
Ollie Lho761bf1b2004-03-20 16:46:10 +000064 write_sector_jedec(bios, buf + i * page_size,
65 bios + i * page_size, page_size);
Roman Kononov41c47672006-10-07 00:21:13 +000066
67 printf("\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b\b");
Ollie Lho761bf1b2004-03-20 16:46:10 +000068 fflush(stdout);
David Hendricks3770a112004-03-17 21:47:30 +000069 }
70 printf("\n");
71
Uwe Hermannffec5f32007-08-23 16:08:21 +000072 return 0;
David Hendricks3770a112004-03-17 21:47:30 +000073}