aboutsummaryrefslogtreecommitdiff
path: root/src/flash/at91sam7.h
blob: efc669e36d6a25e072aa712fd711ac3bc25d4f43 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
/***************************************************************************
 *   Copyright (C) 2006 by Magnus Lundin                                   *
 *   lundin@mlu.mine.nu                                                    *
 *                                                                         *
 *   Copyright (C) 2006 by Gheorghe Guran (atlas)                          *
 *                                                                         *
 *   This program 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 of the License, or     *
 *   (at your option) any later version.                                   *
 *                                                                         *
 *   This program 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 this program; if not, write to the                         *
 *   Free Software Foundation, Inc.,                                       *
 *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
 ***************************************************************************/

#ifndef AT91SAM7_H
#define AT91SAM7_H

#include "flash.h"
#include "target.h"


typedef struct at91sam7_flash_bank_s
{
    /* chip id register */
    u32 cidr;
    u16 cidr_ext;
    u16 cidr_nvptyp;
    u16 cidr_arch;
    u16 cidr_sramsiz;
    u16 cidr_nvpsiz;
    u16 cidr_nvpsiz2;
    u16 cidr_eproc;
    u16 cidr_version;
    char *target_name;

    /* flash auto-detection */
    u8  flash_autodetection;

    /* flash geometry */
    u16 pages_per_sector;
    u16 pagesize;
    u16 pages_in_lockregion;

    /* nv memory bits */
    u16 num_lockbits_on;
    u16 lockbits;
    u16 num_nvmbits;
    u16 num_nvmbits_on;
    u16 nvmbits;
    u8  securitybit;

    /* 0: not init
       1: fmcn for nvbits (1uS)
       2: fmcn for flash (1.5uS) */
    u8  flashmode;

    /* main clock status */
    u8  mck_valid;
    u32 mck_freq;

    /* external clock frequency */
    u32 ext_freq;

} at91sam7_flash_bank_t;


/* AT91SAM7 control registers */
#define DBGU_CIDR           0xFFFFF240
#define CKGR_MCFR           0xFFFFFC24
#define CKGR_MOR            0xFFFFFC20
#define CKGR_MCFR_MAINRDY      0x10000
#define CKGR_PLLR           0xFFFFFC2c
#define CKGR_PLLR_DIV             0xff
#define CKGR_PLLR_MUL       0x07ff0000
#define PMC_MCKR            0xFFFFFC30
#define PMC_MCKR_CSS              0x03
#define PMC_MCKR_PRES             0x1c

/* Flash Controller Commands */
#define WP      0x01
#define SLB     0x02
#define WPL     0x03
#define CLB     0x04
#define EA      0x08
#define SGPB    0x0B
#define CGPB    0x0D
#define SSB     0x0F

/* MC_FSR bit definitions */
#define MC_FSR_FRDY         1
#define MC_FSR_EOL          2

/* AT91SAM7 constants */
#define RC_FREQ         32000

/* Flash timing modes */
#define FMR_TIMING_NONE     0
#define FMR_TIMING_NVBITS   1
#define FMR_TIMING_FLASH    2

/* Flash size constants */
#define FLASH_SIZE_8KB      1
#define FLASH_SIZE_16KB     2
#define FLASH_SIZE_32KB     3
#define FLASH_SIZE_64KB     5
#define FLASH_SIZE_128KB    7
#define FLASH_SIZE_256KB    9
#define FLASH_SIZE_512KB    10
#define FLASH_SIZE_1024KB   12
#define FLASH_SIZE_2048KB   14

#endif /* AT91SAM7_H */