#ifndef CYGONCE_DEVS_FLASH_AMD_AM29XXXXX_PARTS_INL #define CYGONCE_DEVS_FLASH_AMD_AM29XXXXX_PARTS_INL //========================================================================== // // am29xxxxx_parts.inl // // AMD AM29xxxxx part descriptors // //========================================================================== //####ECOSGPLCOPYRIGHTBEGIN#### // ------------------------------------------- // This file is part of eCos, the Embedded Configurable Operating System. // Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc. // Copyright (C) 2002 Gary Thomas // // eCos 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 or (at your option) any later version. // // eCos 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. // // You should have received a copy of the GNU General Public License along // with eCos; if not, write to the Free Software Foundation, Inc., // 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. // // As a special exception, if other files instantiate templates or use macros // or inline functions from this file, or you compile this file and link it // with other works to produce a work based on this file, this file does not // by itself cause the resulting work to be covered by the GNU General Public // License. However the source code for this file must still be made available // in accordance with section (3) of the GNU General Public License. // // This exception does not invalidate any other reasons why a work based on // this file might be covered by the GNU General Public License. // // Alternative licenses for eCos may be arranged by contacting Red Hat, Inc. // at http://sources.redhat.com/ecos/ecos-license/ // ------------------------------------------- //####ECOSGPLCOPYRIGHTEND#### //========================================================================== //#####DESCRIPTIONBEGIN#### // // Author(s): jskov // Contributors: jskov, Koichi Nagashima // Date: 2001-06-08 // Purpose: // Description: AMD AM29xxxxx part descriptors // Usage: Should be included from the flash_am29xxxxx.inl file only. // // FIXME: Add configury for selecting bottom/top bootblocks //####DESCRIPTIONEND#### // //========================================================================== // // Note: 'bootblocks' are a set of blocks which are treated by // the driver as a single larger block. This simplifies the driver // so as to only have to deal with single size blocks (even though // the physical device may differ). The data structure is laid out as: //
// // // ... // //
// // // ... // // _LAST_BOOTBLOCK // // Finally, when specifying a device with bootblocks, the total number // of blocks should reflect this collapse, i.e. if the device has 15 // full size blocks and 8 blocks which are 1/8 each, then the total // should be 16 blocks. // #define _LAST_BOOTBLOCK (-1) #if CYGNUM_FLASH_WIDTH == 8 #ifdef CYGHWR_DEVS_FLASH_AMD_AM29F002T { // AM29F002T device_id : FLASHWORD(0xb0), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 4, device_size: 0x40000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x40000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x030000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29F010 { // AM29F010 device_id : FLASHWORD(0x20), block_size : 0x4000 * CYGNUM_FLASH_INTERLEAVE, block_count: 8, device_size: 0x20000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x20000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : false, banked : false }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29F040B { // AM29F040B device_id : FLASHWORD(0xa4), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 8, device_size: 0x80000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x80000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : false, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV160 { // MBM29LV160-T | AM29LV160-T device_id : FLASHWORD(0xc4), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 32, device_size: 0x200000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x200000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x1f0000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // MBM29LV160-B | AM29LV160-B device_id : FLASHWORD(0x49), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 32, device_size: 0x200000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x200000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV200 { // AM29LV200-T device_id : FLASHWORD(0x3b), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 4, device_size: 0x40000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x40000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x030000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29LV200-B device_id : FLASHWORD(0xbf), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 4, device_size: 0x40000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x40000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV320D { // AM29LV320DT device_id : FLASHWORD(0xF6), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x3f0000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29LV320D device_id : FLASHWORD(0xF9), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29DL322D { // AM29DL322D-T device_id : FLASHWORD(0x55), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x3f0000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x380000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, { // AM29DL322D-B device_id : FLASHWORD(0x56), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x80000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29DL323D { // AM29DL323D-T device_id : FLASHWORD(0x50), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x3f0000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x300000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, { // AM29DL323D-B device_id : FLASHWORD(0x53), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x100000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29DL324D { // AM29DL324D-T device_id : FLASHWORD(0x5c), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x3f0000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x200000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, { // AM29DL324D-B device_id : FLASHWORD(0x5f), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x200000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29DL640D { // AM29DL640D long_device_id: true, device_id : FLASHWORD(0x7e), device_id2 : FLASHWORD(0x02), device_id3 : FLASHWORD(0x01), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 128, device_size: 0x0800000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x8000000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x7F0000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x0700000 * CYGNUM_FLASH_INTERLEAVE, 0x0400000 * CYGNUM_FLASH_INTERLEAVE, 0x0100000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29F800 { // AM29F800-T device_id : FLASHWORD(0xd6), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0xf0000 * CYGNUM_FLASH_INTERLEAVE, 0x08000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x04000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29F800-B device_id : FLASHWORD(0x58), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV800 { // AM29LV800-T device_id : FLASHWORD(0xda), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0xf0000 * CYGNUM_FLASH_INTERLEAVE, 0x08000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x04000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29LV800-B device_id : FLASHWORD(0x5b), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_TC58FVB800 { // Toshiba TC58FVB800 (compatible with AM29LV800-B except for IDs.) device_id : FLASHWORD(0xCE), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV081B { // AM29LV081B device_id : FLASHWORD(0x38), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : false, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV017D { // AM29LV017D device_id : FLASHWORD(0xC8), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 32, device_size: 0x200000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x200000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : false, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV033C { // AM29LV033C device_id : FLASHWORD(0xA3), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : false, // Although this device is not a true banked device, we // treat the device as having two banks to get the // Sector Protect Verify to work for the upper half of // the device. Reference Note 9 for Table 9 in the // AMD data sheet. banked : true, banks : { 0x200000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV065D { // AM29LV065D device_id : FLASHWORD(0x93), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 128, device_size: 0x800000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x800000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : false, banked : false, bufsiz : 1 }, #endif #else // 16 bit devices #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV128 { // AM29LV128 long_device_id: true, device_id : FLASHWORD(0x227e), device_id2 : FLASHWORD(0x2212), device_id3 : FLASHWORD(0x2200), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 256, device_size: 0x1000000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x1000000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : false, banked : false, bufsiz : 16 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV160 { // MBM29LV160-T | AM29LV160-T device_id : FLASHWORD(0x22c4), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 32, device_size: 0x200000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x200000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x1f0000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // MBM29LV160-B | AM29LV160-B device_id : FLASHWORD(0x2249), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 32, device_size: 0x200000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x200000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29PL160 { // AM29PL160-T device_id : FLASHWORD(0x2227), block_size : 0x00040000 * CYGNUM_FLASH_INTERLEAVE, block_count: 8, device_size: 0x00200000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x00200000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x1c0000 * CYGNUM_FLASH_INTERLEAVE, 0x038000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29PL160-B device_id : FLASHWORD(0x2245), block_size : 0x00040000 * CYGNUM_FLASH_INTERLEAVE, block_count: 8, device_size: 0x00200000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x00200000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x038000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV200 { // AM29LV200-T device_id : FLASHWORD(0x223b), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 4, device_size: 0x40000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x40000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x030000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29LV200-B device_id : FLASHWORD(0x22bf), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 4, device_size: 0x40000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x40000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_ST_M29W200B { // ST M29W200BT device_id : FLASHWORD(0x0051), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 4, device_size: 0x40000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x40000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x030000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // ST M29W200BB device_id : FLASHWORD(0x0057), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 4, device_size: 0x40000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x40000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV320D { // AM29LV320DT device_id : FLASHWORD(0x22F6), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x3f0000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29LV320D device_id : FLASHWORD(0x22F9), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29DL322D { // AM29DL322D-T device_id : FLASHWORD(0x2255), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x3f0000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x380000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, { // AM29DL322D-B device_id : FLASHWORD(0x2256), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x80000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29DL323D { // AM29DL323D-T device_id : FLASHWORD(0x2250), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x3f0000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x300000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, { // AM29DL323D-B device_id : FLASHWORD(0x2253), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x100000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29DL324D { // AM29DL324D-T device_id : FLASHWORD(0x225c), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x3f0000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x200000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, { // AM29DL324D-B device_id : FLASHWORD(0x225f), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x400000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x200000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29DL640D { // AM29DL640D long_device_id: true, device_id : FLASHWORD(0x227e), device_id2 : FLASHWORD(0x2202), device_id3 : FLASHWORD(0x2201), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 128, device_size: 0x800000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x800000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x7F0000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x700000 * CYGNUM_FLASH_INTERLEAVE, 0x400000 * CYGNUM_FLASH_INTERLEAVE, 0x100000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV400 { // AM29LV400-T device_id : FLASHWORD(0x22b9), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 8, device_size: 0x80000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x80000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0xf0000 * CYGNUM_FLASH_INTERLEAVE, 0x08000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x04000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29LV400-B device_id : FLASHWORD(0x22ba), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 8, device_size: 0x80000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x80000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29F800 { // AM29F800-T device_id : FLASHWORD(0x22d6), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0xf0000 * CYGNUM_FLASH_INTERLEAVE, 0x08000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x04000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29F800-B device_id : FLASHWORD(0x2258), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV800 { // AM29LV800-T device_id : FLASHWORD(0x22da), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0xf0000 * CYGNUM_FLASH_INTERLEAVE, 0x08000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x02000 * CYGNUM_FLASH_INTERLEAVE, 0x04000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, { // AM29LV800-B device_id : FLASHWORD(0x225b), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV640 { // MBM29LV640xx device_id : FLASHWORD(0x22d7), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 128, device_size: 0x800000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x800000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : false, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_TC58FVB800 { // Toshiba TC58FVB800 (compatible with AM29LV800-B except for IDs.) device_id : FLASHWORD(0xCE), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 16, device_size: 0x100000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x100000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x004000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x002000 * CYGNUM_FLASH_INTERLEAVE, 0x008000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : false, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_AM29LV256 { // AMD AM29LV256 long_device_id: true, device_id : FLASHWORD(0x227e), device_id2 : FLASHWORD(0x2212), device_id3 : FLASHWORD(0x2201), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 512, device_size: 0x2000000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x2000000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : false, banked : false, bufsiz : 16, }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_S29PL032J { // S29PL032J long_device_id: true, device_id : FLASHWORD(0x227e), device_id2 : FLASHWORD(0x220a), device_id3 : FLASHWORD(0x2201), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 64, device_size: 0x0400000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x4000000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x3F0000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x0380000 * CYGNUM_FLASH_INTERLEAVE, 0x0200000 * CYGNUM_FLASH_INTERLEAVE, 0x0080000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_S29PL064J { // S29PL064J long_device_id: true, device_id : FLASHWORD(0x227e), device_id2 : FLASHWORD(0x2202), device_id3 : FLASHWORD(0x2201), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 128, device_size: 0x0800000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x8000000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x7F0000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x0700000 * CYGNUM_FLASH_INTERLEAVE, 0x0400000 * CYGNUM_FLASH_INTERLEAVE, 0x0100000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_S29PL127J { // S29PL127J long_device_id: true, device_id : FLASHWORD(0x227e), device_id2 : FLASHWORD(0x2220), device_id3 : FLASHWORD(0x2200), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 256, device_size: 0x1000000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x1000000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x000000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0xFF0000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x0e00000 * CYGNUM_FLASH_INTERLEAVE, 0x0800000 * CYGNUM_FLASH_INTERLEAVE, 0x0200000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_AMD_S29GL064M { // AMD/SPANSION S29GL064M long_device_id: true, device_id : FLASHWORD(0x227e), device_id2 : FLASHWORD(0x2210), device_id3 : FLASHWORD(0x2201), block_size : 0x10000 * CYGNUM_FLASH_INTERLEAVE, block_count: 128, device_size: 0x0800000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x8000000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x00000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x7F0000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, 0x2000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x0700000 * CYGNUM_FLASH_INTERLEAVE, 0x0400000 * CYGNUM_FLASH_INTERLEAVE, 0x0100000 * CYGNUM_FLASH_INTERLEAVE, 0 }, bufsiz : 1 }, #endif #ifdef CYGHWR_DEVS_FLASH_S29WS256N { // SPANSION S29WS256N (compatible with AM29DL640D except for IDs.) long_device_id: true, device_id : FLASHWORD(0x227e), device_id2 : FLASHWORD(0x2230), device_id3 : FLASHWORD(0x2200), block_size : 0x20000 * CYGNUM_FLASH_INTERLEAVE, block_count: 256, device_size: 0x2000000 * CYGNUM_FLASH_INTERLEAVE, base_mask : ~(0x2000000 * CYGNUM_FLASH_INTERLEAVE - 1), bootblock : true, bootblocks : { 0x00000000 * CYGNUM_FLASH_INTERLEAVE, /* offset not absolute */ 0x8000 * CYGNUM_FLASH_INTERLEAVE, 0x8000 * CYGNUM_FLASH_INTERLEAVE, 0x8000 * CYGNUM_FLASH_INTERLEAVE, 0x8000 * CYGNUM_FLASH_INTERLEAVE, 0x01FE0000 * CYGNUM_FLASH_INTERLEAVE, /* offset not absolute */ 0x8000 * CYGNUM_FLASH_INTERLEAVE, 0x8000 * CYGNUM_FLASH_INTERLEAVE, 0x8000 * CYGNUM_FLASH_INTERLEAVE, 0x8000 * CYGNUM_FLASH_INTERLEAVE, _LAST_BOOTBLOCK }, banked : true, banks : { 0x1E00000 * CYGNUM_FLASH_INTERLEAVE, 0x1C00000 * CYGNUM_FLASH_INTERLEAVE, 0x1A00000 * CYGNUM_FLASH_INTERLEAVE, 0x1800000 * CYGNUM_FLASH_INTERLEAVE, 0x1600000 * CYGNUM_FLASH_INTERLEAVE, 0x1400000 * CYGNUM_FLASH_INTERLEAVE, 0x1200000 * CYGNUM_FLASH_INTERLEAVE, 0x1000000 * CYGNUM_FLASH_INTERLEAVE, 0xE00000 * CYGNUM_FLASH_INTERLEAVE, 0xC00000 * CYGNUM_FLASH_INTERLEAVE, 0xA00000 * CYGNUM_FLASH_INTERLEAVE, 0x800000 * CYGNUM_FLASH_INTERLEAVE, 0x600000 * CYGNUM_FLASH_INTERLEAVE, 0x400000 * CYGNUM_FLASH_INTERLEAVE, 0x200000 * CYGNUM_FLASH_INTERLEAVE, //starting of bank1 0 //starting of bank0 }, bufsiz : 1 }, #endif #endif // 16 bit devices #endif // CYGONCE_DEVS_FLASH_AMD_AM29XXXXX_PARTS_INL