1 /***************************************************************************
2 * Copyright (C) 2006 by Magnus Lundin *
5 * Copyright (C) 2006 by Gheorghe Guran (atlas) *
7 * This program is free software; you can redistribute it and/or modify *
8 * it under the terms of the GNU General Public License as published by *
9 * the Free Software Foundation; either version 2 of the License, or *
10 * (at your option) any later version. *
12 * This program is distributed in the hope that it will be useful, *
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
15 * GNU General Public License for more details. *
17 * You should have received a copy of the GNU General Public License *
18 * along with this program; if not, write to the *
19 * Free Software Foundation, Inc., *
20 * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
21 ***************************************************************************/
28 typedef struct at91sam7_flash_bank_s
30 /* chip id register */
35 uint16_t cidr_sramsiz
;
37 uint16_t cidr_nvpsiz2
;
39 uint16_t cidr_version
;
42 /* flash auto-detection */
43 uint8_t flash_autodetection
;
46 uint16_t pages_per_sector
;
48 uint16_t pages_in_lockregion
;
51 uint16_t num_lockbits_on
;
54 uint16_t num_nvmbits_on
;
59 * 1: fmcn for nvbits (1uS)
60 * 2: fmcn for flash (1.5uS) */
63 /* main clock status */
67 /* external clock frequency */
70 } at91sam7_flash_bank_t
;
73 /* AT91SAM7 control registers */
74 #define DBGU_CIDR 0xFFFFF240
75 #define CKGR_MCFR 0xFFFFFC24
76 #define CKGR_MOR 0xFFFFFC20
77 #define CKGR_MCFR_MAINRDY 0x10000
78 #define CKGR_PLLR 0xFFFFFC2c
79 #define CKGR_PLLR_DIV 0xff
80 #define CKGR_PLLR_MUL 0x07ff0000
81 #define PMC_MCKR 0xFFFFFC30
82 #define PMC_MCKR_CSS 0x03
83 #define PMC_MCKR_PRES 0x1c
85 /* Flash Controller Commands */
95 /* MC_FSR bit definitions */
99 /* AT91SAM7 constants */
100 #define RC_FREQ 32000
102 /* Flash timing modes */
103 #define FMR_TIMING_NONE 0
104 #define FMR_TIMING_NVBITS 1
105 #define FMR_TIMING_FLASH 2
107 /* Flash size constants */
108 #define FLASH_SIZE_8KB 1
109 #define FLASH_SIZE_16KB 2
110 #define FLASH_SIZE_32KB 3
111 #define FLASH_SIZE_64KB 5
112 #define FLASH_SIZE_128KB 7
113 #define FLASH_SIZE_256KB 9
114 #define FLASH_SIZE_512KB 10
115 #define FLASH_SIZE_1024KB 12
116 #define FLASH_SIZE_2048KB 14
118 #endif /* AT91SAM7_H */