1 #ifndef CYGONCE_DEVS_FLASH_TRITON270_WIRELESSFLASH_INL
2 #define CYGONCE_DEVS_FLASH_TRITON270_WIRELESSFLASH_INL
3 //==========================================================================
5 // triton270_wirelessflash.c
7 // Flash programming - device constants, etc.
9 //####ECOSGPLCOPYRIGHTBEGIN####
10 // -------------------------------------------
11 // This file is part of eCos, the Embedded Configurable Operating System.
12 // Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.
14 // eCos is free software; you can redistribute it and/or modify it under
15 // the terms of the GNU General Public License as published by the Free
16 // Software Foundation; either version 2 or (at your option) any later version.
18 // eCos is distributed in the hope that it will be useful, but WITHOUT ANY
19 // WARRANTY; without even the implied warranty of MERCHANTABILITY or
20 // FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
23 // You should have received a copy of the GNU General Public License along
24 // with eCos; if not, write to the Free Software Foundation, Inc.,
25 // 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
27 // As a special exception, if other files instantiate templates or use macros
28 // or inline functions from this file, or you compile this file and link it
29 // with other works to produce a work based on this file, this file does not
30 // by itself cause the resulting work to be covered by the GNU General Public
31 // License. However the source code for this file must still be made available
32 // in accordance with section (3) of the GNU General Public License.
34 // This exception does not invalidate any other reasons why a work based on
35 // this file might be covered by the GNU General Public License.
37 // Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.
38 // at http://sources.redhat.com/ecos/ecos-license/
39 // -------------------------------------------
40 //####ECOSGPLCOPYRIGHTEND####
41 //==========================================================================
42 //#####DESCRIPTIONBEGIN####
44 // Author(s): usteinkohl
45 // Contributors: usteinkohl
46 // Date: 14th January 2003 (last modification)
50 //####DESCRIPTIONEND####
52 //==========================================================================
54 #include <pkgconf/system.h> // System-wide configuration info
56 #ifdef TRITON270_FLASH16_16
57 // Platform code must define the below
58 #define CYGNUM_FLASH_INTERLEAVE (1) // Number of interleaved devices (in parallel)
59 #define CYGNUM_FLASH_SERIES (1) // Number of devices in series
60 #define CYGNUM_FLASH_WIDTH (16) // Width of devices on platform
61 #define CYGNUM_FLASH_BASE (0x00000000u) // Address of first device
63 #define FLASH_P2V(x) ((volatile flash_data_t *)(((unsigned)(x) < 0x1000) ? \
64 ((unsigned)(x) | 0xa0000000) : \
67 #include "cyg/io/flash_28fxxx_w18.inl"
70 #ifdef TRITON270_FLASH16_16_P30
71 // Platform code must define the below
72 #define CYGNUM_FLASH_INTERLEAVE (1) // Number of interleaved devices (in parallel)
73 #define CYGNUM_FLASH_SERIES (1) // Number of devices in series
74 #define CYGNUM_FLASH_WIDTH (16) // Width of devices on platform
75 #define CYGNUM_FLASH_BASE (0x00000000u) // Address of first device
77 #define FLASH_P2V(x) ((volatile flash_data_t *)(((unsigned)(x) < 0x1000) ? \
78 ((unsigned)(x) | 0xa0000000) : \
81 #include "cyg/io/flash_28fxxx_p30.inl"
84 #ifdef TRITON270_FLASH16_64
85 // Platform code must define the below
86 #define CYGNUM_FLASH_INTERLEAVE (1) // Number of interleaved devices (in parallel)
87 #define CYGNUM_FLASH_SERIES (2) // Number of devices in series
88 #define CYGNUM_FLASH_WIDTH (16) // Width of devices on platform
89 #define CYGNUM_FLASH_BASE (0x00000000u) // Address of first device
91 #define FLASH_P2V(x) ((volatile flash_data_t *)(((unsigned)(x) < 0x1000) ? \
92 ((unsigned)(x) | 0xa0000000) : \
95 #include "cyg/io/flash_28fxxx_p30.inl"
98 #ifdef TRITON270_FLASH16_32
99 // Platform code must define the below
100 #define CYGNUM_FLASH_INTERLEAVE (1) // Number of interleaved devices (in parallel)
101 #define CYGNUM_FLASH_SERIES (1) // Number of devices in series
102 #define CYGNUM_FLASH_WIDTH (16) // Width of devices on platform
103 #define CYGNUM_FLASH_BASE (0x00000000u) // Address of first device
105 #define FLASH_P2V(x) ((volatile flash_data_t *)(((unsigned)(x) < 0x1000) ? \
106 ((unsigned)(x) | 0xa0000000) : \
109 #include "cyg/io/flash_28fxxx_p30.inl"
111 #endif // CYGONCE_DEVS_FLASH_TRITON270_WIRELESSFLASH_INL
112 // ------------------------------------------------------------------------
113 // EOF triton270_wirelessflash.inl