| /* | |
| * This file is part of the flashrom project. | |
| * | |
| * Copyright (C) 2000 Silicon Integrated System Corporation | |
| * Copyright (C) 2004 Tyan Corp | |
| * Copyright (C) 2005-2008 coresystems GmbH <stepan@openbios.org> | |
| * Copyright (C) 2006-2009 Carl-Daniel Hailfinger | |
| * Copyright (C) 2009 Sean Nelson <audiohacked@gmail.com> | |
| * | |
| * This program is free software; you can redistribute it and/or modify | |
| * it under the terms of the GNU General Public License as published by | |
| * the Free Software Foundation; either version 2 of the License, or | |
| * (at your option) any later version. | |
| * | |
| * This program is distributed in the hope that it will be useful, | |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| * GNU General Public License for more details. | |
| */ | |
| { | |
| .vendor = "Zetta Device", | |
| .name = "ZD25D20", | |
| .bustype = BUS_SPI, | |
| .manufacture_id = ZETTA_ID, | |
| .model_id = ZETTA_ZD25D20, | |
| .total_size = 256, | |
| .page_size = 256, | |
| .feature_bits = FEATURE_WRSR_WREN, | |
| .tested = TEST_UNTESTED, | |
| .probe = PROBE_SPI_RDID, | |
| .probe_timing = TIMING_ZERO, | |
| .block_erasers = | |
| { | |
| { | |
| .eraseblocks = { {4 * 1024, 64} }, | |
| .block_erase = SPI_BLOCK_ERASE_20, | |
| }, { | |
| .eraseblocks = { {32 * 1024, 8} }, | |
| .block_erase = SPI_BLOCK_ERASE_52, | |
| }, { | |
| .eraseblocks = { {64 * 1024, 4} }, | |
| .block_erase = SPI_BLOCK_ERASE_D8, | |
| }, { | |
| .eraseblocks = { {256 * 1024, 1} }, | |
| .block_erase = SPI_BLOCK_ERASE_60, | |
| }, { | |
| .eraseblocks = { {256 * 1024, 1} }, | |
| .block_erase = SPI_BLOCK_ERASE_C7, | |
| } | |
| }, | |
| .printlock = SPI_PRETTYPRINT_STATUS_REGISTER_PLAIN, /* TODO: improve */ | |
| .unlock = SPI_DISABLE_BLOCKPROTECT, | |
| .write = SPI_CHIP_WRITE256, | |
| .read = SPI_CHIP_READ, | |
| .voltage = {2700, 3600}, | |
| }, | |
| { | |
| .vendor = "Zetta Device", | |
| .name = "ZD25D40", | |
| .bustype = BUS_SPI, | |
| .manufacture_id = ZETTA_ID, | |
| .model_id = ZETTA_ZD25D40, | |
| .total_size = 512, | |
| .page_size = 256, | |
| .feature_bits = FEATURE_WRSR_WREN, | |
| .tested = TEST_UNTESTED, | |
| .probe = PROBE_SPI_RDID, | |
| .probe_timing = TIMING_ZERO, | |
| .block_erasers = | |
| { | |
| { | |
| .eraseblocks = { {4 * 1024, 128} }, | |
| .block_erase = SPI_BLOCK_ERASE_20, | |
| }, { | |
| .eraseblocks = { {32 * 1024, 16} }, | |
| .block_erase = SPI_BLOCK_ERASE_52, | |
| }, { | |
| .eraseblocks = { {64 * 1024, 8} }, | |
| .block_erase = SPI_BLOCK_ERASE_D8, | |
| }, { | |
| .eraseblocks = { {512 * 1024, 1} }, | |
| .block_erase = SPI_BLOCK_ERASE_60, | |
| }, { | |
| .eraseblocks = { {512 * 1024, 1} }, | |
| .block_erase = SPI_BLOCK_ERASE_C7, | |
| } | |
| }, | |
| .printlock = SPI_PRETTYPRINT_STATUS_REGISTER_PLAIN, /* TODO: improve */ | |
| .unlock = SPI_DISABLE_BLOCKPROTECT, | |
| .write = SPI_CHIP_WRITE256, | |
| .read = SPI_CHIP_READ, | |
| .voltage = {2700, 3600}, | |
| }, | |
| { | |
| .vendor = "Zetta Device", | |
| .name = "ZD25LQ128", | |
| .bustype = BUS_SPI, | |
| .manufacture_id = ZETTA_ID, | |
| .model_id = ZETTA_ZD25LQ128_REMS, | |
| .total_size = 16384, | |
| .page_size = 256, | |
| .feature_bits = FEATURE_WRSR_WREN, | |
| .tested = TEST_OK_PREW, | |
| .probe = PROBE_SPI_REMS, | |
| .probe_timing = TIMING_ZERO, | |
| .block_erasers = | |
| { | |
| { | |
| .eraseblocks = { {4 * 1024, 4096} }, | |
| .block_erase = SPI_BLOCK_ERASE_20, | |
| }, { | |
| .eraseblocks = { {32 * 1024, 512} }, | |
| .block_erase = SPI_BLOCK_ERASE_52, | |
| }, { | |
| .eraseblocks = { {64 * 1024, 256} }, | |
| .block_erase = SPI_BLOCK_ERASE_D8, | |
| }, { | |
| .eraseblocks = { {16 * 1024 * 1024, 1} }, | |
| .block_erase = SPI_BLOCK_ERASE_60, | |
| }, { | |
| .eraseblocks = { {16 * 1024 * 1024, 1} }, | |
| .block_erase = SPI_BLOCK_ERASE_C7, | |
| } | |
| }, | |
| .printlock = SPI_PRETTYPRINT_STATUS_REGISTER_PLAIN, /* TODO: improve */ | |
| .unlock = SPI_DISABLE_BLOCKPROTECT, | |
| .write = SPI_CHIP_WRITE256, | |
| .read = SPI_CHIP_READ, | |
| .voltage = {1650, 1950}, | |
| }, |