URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [rtos/] [ecos-2.0/] [packages/] [devs/] [flash/] [amd/] [am29xxxxx/] [v2_0/] [include/] [flash_am29xxxxx_parts.inl] - Rev 174
Compare with Previous | Blame | View Log
#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:
// <address of start of boot block area 1>
// <size of sub-block 1>
// <size of sub-block 2>
// ...
// <size of sub-block n>
// <address of start of boot block area 2>
// <size of sub-block 1>
// <size of sub-block 2>
// ...
// <size of sub-block n>
// _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_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
},
#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
},
{ // 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
},
#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
},
{ // 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
},
#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
},
{ // 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
},
#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
}
},
{ // 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
}
},
#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
}
},
{ // 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
}
},
#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
}
},
{ // 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
}
},
#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
}
}
#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
},
{ // 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
},
#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
},
{ // 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
},
#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
},
#endif
#else // 16 bit devices
#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
},
{ // 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
},
#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
},
{ // 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
},
#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
},
{ // 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
},
#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
},
{ // 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
},
#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
}
},
{ // 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
}
},
#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
}
},
{ // 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
}
},
#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
}
},
{ // 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
}
},
#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
}
}
#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
},
{ // 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
},
#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
},
{ // 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
},
#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
},
#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
},
#endif
#endif // 16 bit devices
#endif // CYGONCE_DEVS_FLASH_AMD_AM29XXXXX_PARTS_INL