Skip to content

Commit 8bd7b59

Browse files
committed
Move flash_api.c to STM32F4 level + add flash_data.h for STM32F412 device
add FLASH to targets.json
1 parent acdd7dd commit 8bd7b59

File tree

6 files changed

+78
-199
lines changed

6 files changed

+78
-199
lines changed
Lines changed: 59 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
/* mbed Microcontroller Library
2+
*******************************************************************************
3+
* Copyright (c) 2016, STMicroelectronics
4+
* All rights reserved.
5+
*
6+
* Redistribution and use in source and binary forms, with or without
7+
* modification, are permitted provided that the following conditions are met:
8+
*
9+
* 1. Redistributions of source code must retain the above copyright notice,
10+
* this list of conditions and the following disclaimer.
11+
* 2. Redistributions in binary form must reproduce the above copyright notice,
12+
* this list of conditions and the following disclaimer in the documentation
13+
* and/or other materials provided with the distribution.
14+
* 3. Neither the name of STMicroelectronics nor the names of its contributors
15+
* may be used to endorse or promote products derived from this software
16+
* without specific prior written permission.
17+
*
18+
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19+
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20+
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
21+
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
22+
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23+
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
24+
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
25+
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
26+
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27+
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28+
*******************************************************************************
29+
*/
30+
#ifndef MBED_FLASH_DATA_H
31+
#define MBED_FLASH_DATA_H
32+
33+
#include "device.h"
34+
#include <stdint.h>
35+
36+
#if DEVICE_FLASH
37+
38+
/* Exported types ------------------------------------------------------------*/
39+
/* Exported constants --------------------------------------------------------*/
40+
/* Exported macro ------------------------------------------------------------*/
41+
/* Flash size */
42+
#define FLASH_SIZE (uint32_t) 0x100000
43+
44+
/* Base address of the Flash sectors Bank 1 */
45+
#define ADDR_FLASH_SECTOR_0 ((uint32_t)0x08000000) /* Base @ of Sector 0, 16 Kbytes */
46+
#define ADDR_FLASH_SECTOR_1 ((uint32_t)0x08004000) /* Base @ of Sector 1, 16 Kbytes */
47+
#define ADDR_FLASH_SECTOR_2 ((uint32_t)0x08008000) /* Base @ of Sector 2, 16 Kbytes */
48+
#define ADDR_FLASH_SECTOR_3 ((uint32_t)0x0800C000) /* Base @ of Sector 3, 16 Kbytes */
49+
#define ADDR_FLASH_SECTOR_4 ((uint32_t)0x08010000) /* Base @ of Sector 4, 64 Kbytes */
50+
#define ADDR_FLASH_SECTOR_5 ((uint32_t)0x08020000) /* Base @ of Sector 5, 128 Kbytes */
51+
#define ADDR_FLASH_SECTOR_6 ((uint32_t)0x08040000) /* Base @ of Sector 6, 128 Kbytes */
52+
#define ADDR_FLASH_SECTOR_7 ((uint32_t)0x08060000) /* Base @ of Sector 7, 128 Kbytes */
53+
#define ADDR_FLASH_SECTOR_8 ((uint32_t)0x08080000) /* Base @ of Sector 8, 128 Kbytes */
54+
#define ADDR_FLASH_SECTOR_9 ((uint32_t)0x080A0000) /* Base @ of Sector 9, 128 Kbytes */
55+
#define ADDR_FLASH_SECTOR_10 ((uint32_t)0x080C0000) /* Base @ of Sector 10, 128 Kbytes */
56+
#define ADDR_FLASH_SECTOR_11 ((uint32_t)0x080E0000) /* Base @ of Sector 11, 128 Kbytes */
57+
58+
#endif
59+
#endif

targets/TARGET_STM/TARGET_STM32F4/TARGET_STM32F429xI/device/flash_data.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -38,6 +38,9 @@
3838
/* Exported types ------------------------------------------------------------*/
3939
/* Exported constants --------------------------------------------------------*/
4040
/* Exported macro ------------------------------------------------------------*/
41+
/* FLASH SIZE */
42+
#define FLASH_SIZE (uint32_t) 0x200000
43+
4144
/* Base address of the Flash sectors Bank 1 */
4245
#define ADDR_FLASH_SECTOR_0 ((uint32_t)0x08000000) /* Base @ of Sector 0, 16 Kbytes */
4346
#define ADDR_FLASH_SECTOR_1 ((uint32_t)0x08004000) /* Base @ of Sector 1, 16 Kbytes */

targets/TARGET_STM/TARGET_STM32F4/TARGET_STM32F439xI/device/flash_api.c

Lines changed: 0 additions & 192 deletions
This file was deleted.

targets/TARGET_STM/TARGET_STM32F4/TARGET_STM32F439xI/device/flash_data.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -38,6 +38,9 @@
3838
/* Exported types ------------------------------------------------------------*/
3939
/* Exported constants --------------------------------------------------------*/
4040
/* Exported macro ------------------------------------------------------------*/
41+
/* Flash Size */
42+
#define FLASH_SIZE (uint32_t) 0x200000
43+
4144
/* Base address of the Flash sectors Bank 1 */
4245
#define ADDR_FLASH_SECTOR_0 ((uint32_t)0x08000000) /* Base @ of Sector 0, 16 Kbytes */
4346
#define ADDR_FLASH_SECTOR_1 ((uint32_t)0x08004000) /* Base @ of Sector 1, 16 Kbytes */

targets/TARGET_STM/TARGET_STM32F4/TARGET_STM32F429xI/device/flash_api.c renamed to targets/TARGET_STM/TARGET_STM32F4/flash_api.c

Lines changed: 12 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -36,10 +36,6 @@
3636

3737
#if DEVICE_FLASH
3838

39-
#if defined (STM32F429xx) || defined (STM32F439xx)
40-
#define FLASH_SIZE (uint32_t) 0x200000
41-
#endif
42-
4339
static uint32_t GetSector(uint32_t Address);
4440
static uint32_t GetSectorSize(uint32_t Sector);
4541

@@ -154,10 +150,13 @@ static uint32_t GetSector(uint32_t address)
154150
{
155151
uint32_t sector = 0;
156152
uint32_t tmp = address - ADDR_FLASH_SECTOR_0;
153+
/* This function supports 1Mb and 2Mb flash sizes */
154+
#if defined(FLASH_SECTOR_12)
157155
if (address & 0x100000) { // handle 2nd bank
158156
sector = FLASH_SECTOR_12;
159157
tmp = address - ADDR_FLASH_SECTOR_12;
160158
}
159+
#endif
161160
if (address < ADDR_FLASH_SECTOR_4) { // 16k sectorsize
162161
sector += tmp >>14;
163162
} else if (address < ADDR_FLASH_SECTOR_5) { //64k sector size
@@ -176,11 +175,18 @@ static uint32_t GetSector(uint32_t address)
176175
static uint32_t GetSectorSize(uint32_t Sector)
177176
{
178177
uint32_t sectorsize = 0x00;
178+
#if defined(FLASH_SECTOR_12)
179179
if((Sector == FLASH_SECTOR_0) || (Sector == FLASH_SECTOR_1) || (Sector == FLASH_SECTOR_2) ||\
180180
(Sector == FLASH_SECTOR_3) || (Sector == FLASH_SECTOR_12) || (Sector == FLASH_SECTOR_13) ||\
181181
(Sector == FLASH_SECTOR_14) || (Sector == FLASH_SECTOR_15)) {
182-
sectorsize = 16 * 1024;
183-
} else if((Sector == FLASH_SECTOR_4) || (Sector == FLASH_SECTOR_16)) {
182+
sectorsize = 16 * 1024;
183+
} else if((Sector == FLASH_SECTOR_4) || (Sector == FLASH_SECTOR_16)) {
184+
#else
185+
if((Sector == FLASH_SECTOR_0) || (Sector == FLASH_SECTOR_1) || (Sector == FLASH_SECTOR_2) ||\
186+
(Sector == FLASH_SECTOR_3)) {
187+
sectorsize = 16 * 1024;
188+
} else if(Sector == FLASH_SECTOR_4) {
189+
#endif
184190
sectorsize = 64 * 1024;
185191
} else {
186192
sectorsize = 128 * 1024;

targets/targets.json

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1022,7 +1022,7 @@
10221022
},
10231023
"detect_code": ["0826"],
10241024
"macros_add": ["USB_STM_HAL", "USBHOST_OTHER"],
1025-
"device_has_add": ["CAN", "ERROR_RED", "LOWPOWERTIMER", "SERIAL_ASYNCH", "SERIAL_FC", "TRNG"],
1025+
"device_has_add": ["CAN", "ERROR_RED", "LOWPOWERTIMER", "SERIAL_ASYNCH", "SERIAL_FC", "TRNG", "FLASH"],
10261026
"release_versions": ["2", "5"],
10271027
"device_name": "STM32F412ZG"
10281028
},

0 commit comments

Comments
 (0)