flash_am29xxxxx_parts.inl

来自「eCos操作系统源码」· INL 代码 · 共 1,099 行 · 第 1/3 页

INL
1,099
字号
#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_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

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?