aboutsummaryrefslogtreecommitdiffstats
path: root/os/hal/lib/complex/serial_nor/devices/micron_n25q/hal_flash_device.h
blob: 1f13f0c82d0abd7bbbbbe13bb03e5adbb85a8e0c (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
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
/*
    ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio

    Licensed under the Apache License, Version 2.0 (the "License");
    you may not use this file except in compliance with the License.
    You may obtain a copy of the License at

        http://www.apache.org/licenses/LICENSE-2.0

    Unless required by applicable law or agreed to in writing, software
    distributed under the License is distributed on an "AS IS" BASIS,
    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
    See the License for the specific language governing permissions and
    limitations under the License.
*/

/**
 * @file    hal_flash_device.h
 * @brief   Micron N25Q serial flash driver header.
 *
 * @addtogroup MICRON_N25Q
 * @ingroup MICRON_N25Q
 * @{
 */

#ifndef HAL_FLASH_DEVICE_H
#define HAL_FLASH_DEVICE_H

/*===========================================================================*/
/* Driver constants.                                                         */
/*===========================================================================*/

/**
 * @name    Device identification
 * @{
 */
#define N25Q_SUPPORTED_MANUFACTURE_IDS      {0x20}
#define N25Q_SUPPORTED_MEMORY_TYPE_IDS      {0xBA, 0xBB}
/** @} */

/**
 * @name    Command codes
 * @{
 */
#define N25Q_CMD_RESET_ENABLE                       0x66
#define N25Q_CMD_RESET_MEMORY                       0x99
#define N25Q_CMD_READ_ID                            0x9F
#define N25Q_CMD_MULTIPLE_IO_READ_ID                0xAF
#define N25Q_CMD_READ_DISCOVERY_PARAMETER           0x5A
#define N25Q_CMD_READ                               0x03
#define N25Q_CMD_FAST_READ                          0x0B
#define N25Q_CMD_WRITE_ENABLE                       0x06
#define N25Q_CMD_WRITE_DISABLE                      0x04
#define N25Q_CMD_READ_STATUS_REGISTER               0x05
#define N25Q_CMD_WRITE_STATUS_REGISTER              0x01
#define N25Q_CMD_READ_LOCK_REGISTER                 0xE8
#define N25Q_CMD_WRITE_LOCK_REGISTER                0xE5
#define N25Q_CMD_READ_FLAG_STATUS_REGISTER          0x70
#define N25Q_CMD_CLEAR_FLAG_STATUS_REGISTER         0x50
#define N25Q_CMD_READ_NV_CONFIGURATION_REGISTER     0xB5
#define N25Q_CMD_WRITE_NV_CONFIGURATION_REGISTER    0xB1
#define N25Q_CMD_READ_V_CONF_REGISTER               0x85
#define N25Q_CMD_WRITE_V_CONF_REGISTER              0x81
#define N25Q_CMD_READ_ENHANCED_V_CONF_REGISTER      0x65
#define N25Q_CMD_WRITE_ENHANCED_V_CONF_REGISTER     0x61
#define N25Q_CMD_PAGE_PROGRAM                       0x02
#define N25Q_CMD_SUBSECTOR_ERASE                    0x20
#define N25Q_CMD_SECTOR_ERASE                       0xD8
#define N25Q_CMD_BULK_ERASE                         0xC7
#define N25Q_CMD_PROGRAM_ERASE_RESUME               0x7A
#define N25Q_CMD_PROGRAM_ERASE_SUSPEND              0x75
#define N25Q_CMD_READ_OTP_ARRAY                     0x4B
#define N25Q_CMD_PROGRAM_OTP_ARRAY                  0x42
/** @} */

/**
 * @name    Flags status register bits
 * @{
 */
#define N25Q_FLAGS_PROGRAM_ERASE                    0x80U
#define N25Q_FLAGS_ERASE_SUSPEND                    0x40U
#define N25Q_FLAGS_ERASE_ERROR                      0x20U
#define N25Q_FLAGS_PROGRAM_ERROR                    0x10U
#define N25Q_FLAGS_VPP_ERROR                        0x08U
#define N25Q_FLAGS_PROGRAM_SUSPEND                  0x04U
#define N25Q_FLAGS_PROTECTION_ERROR                 0x02U
#define N25Q_FLAGS_RESERVED                         0x01U
#define N25Q_FLAGS_ALL_ERRORS                   (N25Q_FLAGS_ERASE_ERROR |   \
                                                 N25Q_FLAGS_PROGRAM_ERROR | \
                                                 N25Q_FLAGS_VPP_ERROR |     \
                                                 N25Q_FLAGS_PROTECTION_ERROR)
/** @} */

/*===========================================================================*/
/* Driver pre-compile time settings.                                         */
/*===========================================================================*/

/**
 * @brief   Switch WSPI bus width on initialization.
 * @details A bus width initialization is performed by writing the
 *          Enhanced Volatile Configuration Register. If the flash
 *          device is configured using the Non Volatile Configuration
 *          Register then this option is not required.
 * @note    This option is only valid in QSPI bus modes.
 */
#if !defined(N25Q_SWITCH_WIDTH) || defined(__DOXYGEN__)
#define N25Q_SWITCH_WIDTH                   TRUE
#endif

/**
 * @brief   Delays insertions.
 * @details If enabled this options inserts delays into the flash waiting
 *          routines releasing some extra CPU time for threads with lower
 *          priority, this may slow down the driver a bit however.
 */
#if !defined(N25Q_NICE_WAITING) || defined(__DOXYGEN__)
#define N25Q_NICE_WAITING                   TRUE
#endif

/**
 * @brief   Uses 4kB sub-sectors rather than 64kB sectors.
 */
#if !defined(N25Q_USE_SUB_SECTORS) || defined(__DOXYGEN__)
#define N25Q_USE_SUB_SECTORS                FALSE
#endif

/**
 * @brief   Size of the compare buffer.
 * @details This buffer is allocated in the stack frame of the function
 *          @p flashVerifyErase() and its size must be a power of two.
 *          Larger buffers lead to better verify performance but increase
 *          stack usage for that function.
 */
#if !defined(N25Q_COMPARE_BUFFER_SIZE) || defined(__DOXYGEN__)
#define N25Q_COMPARE_BUFFER_SIZE            32
#endif

/**
 * @brief   Number of dummy cycles for fast read (1..15).
 * @details This is the number of dummy cycles to be used for fast read
 *          operations.
 */
#if !defined(N25Q_READ_DUMMY_CYCLES) || defined(__DOXYGEN__)
#define N25Q_READ_DUMMY_CYCLES              8
#endif

/*===========================================================================*/
/* Derived constants and error checks.                                       */
/*===========================================================================*/

#if (N25Q_COMPARE_BUFFER_SIZE & (N25Q_COMPARE_BUFFER_SIZE - 1)) != 0
#error "invalid N25Q_COMPARE_BUFFER_SIZE value"
#endif

#if (N25Q_READ_DUMMY_CYCLES < 1) || (N25Q_READ_DUMMY_CYCLES > 15)
#error "invalid N25Q_READ_DUMMY_CYCLES value (1..15)"
#endif

/*===========================================================================*/
/* Driver data structures and types.                                         */
/*===========================================================================*/

/*===========================================================================*/
/* Driver macros.                                                            */
/*===========================================================================*/

/*===========================================================================*/
/* External declarations.                                                    */
/*===========================================================================*/

#if !defined(__DOXYGEN__)
extern flash_descriptor_t snor_descriptor;
#endif

#if (SNOR_BUS_MODE != SNOR_BUS_MODE_SPI) && (WSPI_SUPPORTS_MEMMAP == TRUE)
extern const wspi_command_t snor_memmap_read;
#endif

#ifdef __cplusplus
extern "C" {
#endif
  void snor_device_init(SNORDriver *devp);
  const flash_descriptor_t *snor_get_descriptor(void *instance);
  flash_error_t snor_device_read(SNORDriver *devp, flash_offset_t offset,
                                 size_t n, uint8_t *rp);
  flash_error_t snor_device_program(SNORDriver *devp, flash_offset_t offset,
                                    size_t n, const uint8_t *pp);
  flash_error_t snor_device_start_erase_all(SNORDriver *devp);
  flash_error_t snor_device_start_erase_sector(SNORDriver *devp,
                                               flash_sector_t sector);
  flash_error_t snor_device_verify_erase(SNORDriver *devp,
                                         flash_sector_t sector);
  flash_error_t snor_device_query_erase(SNORDriver *devp, uint32_t *msec);
  flash_error_t snor_device_read_sfdp(SNORDriver *devp, flash_offset_t offset,
                                      size_t n, uint8_t *rp);
#if SNOR_BUS_MODE != SNOR_BUS_MODE_SPI
  void snor_activate_xip(SNORDriver *devp);
  void snor_reset_xip(SNORDriver *devp);
#endif
#ifdef __cplusplus
}
#endif

#endif /* HAL_FLASH_DEVICE_H */

/** @} */