blob: 424b0ed4ff76fdc97b21395e434a4db742d95255 [file] [log] [blame]
Nikolay Petukhov4784c472008-05-17 01:08:58 +00001/*
2 * This file is part of the flashrom project.
3 *
4 * Copyright (C) 2004 Tyan Corporation
5 * Copyright (C) 2007 Nikolay Petukhov <nikolay.petukhov@gmail.com>
6 * Copyright (C) 2007 Reinder E.N. de Haan <lb_reha@mveas.com>
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
21 */
22
Nikolay Petukhov4784c472008-05-17 01:08:58 +000023#include "flash.h"
24
Carl-Daniel Hailfinger5820f422009-05-16 21:22:56 +000025void write_lockbits_49fl00x(chipaddr bios, int size,
Uwe Hermann394131e2008-10-18 21:14:13 +000026 unsigned char bits, int block_size)
Nikolay Petukhov4784c472008-05-17 01:08:58 +000027{
28 int i, left = size;
29
30 for (i = 0; left >= block_size; i++, left -= block_size) {
Nikolay Petukhov4784c472008-05-17 01:08:58 +000031 /* pm49fl002 */
Uwe Hermann394131e2008-10-18 21:14:13 +000032 if (block_size == 16384 && i % 2)
Nikolay Petukhov4784c472008-05-17 01:08:58 +000033 continue;
34
Carl-Daniel Hailfinger0472f3d2009-03-06 22:26:00 +000035 chip_writeb(bits, bios + (i * block_size) + 2);
Nikolay Petukhov4784c472008-05-17 01:08:58 +000036 }
37}
38
39int probe_49fl00x(struct flashchip *flash)
40{
41 int ret = probe_jedec(flash);
Uwe Hermann394131e2008-10-18 21:14:13 +000042
Nikolay Petukhov4784c472008-05-17 01:08:58 +000043 if (ret == 1)
44 map_flash_registers(flash);
45
46 return ret;
47}
48
49int erase_49fl00x(struct flashchip *flash)
50{
51 int i;
52 int total_size = flash->total_size * 1024;
53 int page_size = flash->page_size;
Nikolay Petukhov4784c472008-05-17 01:08:58 +000054
55 /* unprotected */
Uwe Hermann394131e2008-10-18 21:14:13 +000056 write_lockbits_49fl00x(flash->virtual_registers,
57 total_size, 0, page_size);
Nikolay Petukhov4784c472008-05-17 01:08:58 +000058
Uwe Hermann394131e2008-10-18 21:14:13 +000059 /*
60 * erase_chip_jedec() will not work... Datasheet says
61 * "Chip erase is available in A/A Mux Mode only".
62 */
Nikolay Petukhov4784c472008-05-17 01:08:58 +000063 printf("Erasing page: ");
64 for (i = 0; i < total_size / page_size; i++) {
Nikolay Petukhov4784c472008-05-17 01:08:58 +000065 /* erase the page */
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +000066 if (erase_block_jedec(flash, i * page_size, page_size)) {
67 fprintf(stderr, "ERASE FAILED!\n");
68 return -1;
69 }
Nikolay Petukhov4784c472008-05-17 01:08:58 +000070 printf("%04d at address: 0x%08x", i, i * page_size);
71 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");
72 fflush(stdout);
73 }
74 printf("\n");
75
76 /* protected */
Uwe Hermann394131e2008-10-18 21:14:13 +000077 write_lockbits_49fl00x(flash->virtual_registers,
78 total_size, 1, page_size);
Nikolay Petukhov4784c472008-05-17 01:08:58 +000079
80 return 0;
81}
82
83int write_49fl00x(struct flashchip *flash, uint8_t *buf)
84{
85 int i;
86 int total_size = flash->total_size * 1024;
87 int page_size = flash->page_size;
Carl-Daniel Hailfinger5820f422009-05-16 21:22:56 +000088 chipaddr bios = flash->virtual_memory;
Nikolay Petukhov4784c472008-05-17 01:08:58 +000089
90 /* unprotected */
Uwe Hermann394131e2008-10-18 21:14:13 +000091 write_lockbits_49fl00x(flash->virtual_registers, total_size, 0,
92 page_size);
Nikolay Petukhov4784c472008-05-17 01:08:58 +000093
94 printf("Programming page: ");
95 for (i = 0; i < total_size / page_size; i++) {
Nikolay Petukhov4784c472008-05-17 01:08:58 +000096 /* erase the page before programming */
Carl-Daniel Hailfinger30f7cb22009-06-15 17:23:36 +000097 if (erase_block_jedec(flash, i * page_size, page_size)) {
98 fprintf(stderr, "ERASE FAILED!\n");
99 return -1;
100 }
Nikolay Petukhov4784c472008-05-17 01:08:58 +0000101
102 /* write to the sector */
103 printf("%04d at address: 0x%08x", i, i * page_size);
Sean Nelsonc57a9202010-01-04 17:15:23 +0000104 write_sector_jedec_common(flash, buf + i * page_size,
105 bios + i * page_size, page_size, 0xffff);
Nikolay Petukhov4784c472008-05-17 01:08:58 +0000106 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");
107 fflush(stdout);
108 }
109 printf("\n");
Uwe Hermann394131e2008-10-18 21:14:13 +0000110
Nikolay Petukhov4784c472008-05-17 01:08:58 +0000111 /* protected */
Uwe Hermann394131e2008-10-18 21:14:13 +0000112 write_lockbits_49fl00x(flash->virtual_registers, total_size, 1,
113 page_size);
Nikolay Petukhov4784c472008-05-17 01:08:58 +0000114
115 return 0;
116}