Add STM32 FLASH driver
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@3573 42af7a65-404d-4744-a932-0658087f49c3
This commit is contained in:
parent
9ecda2e9fa
commit
65a6ec4693
@ -1727,5 +1727,7 @@
|
||||
|
||||
* Remove clock_getutc(). It is replaces with clock_gettime(CLOCK_ACTIVETIME).
|
||||
Add other RTC related changes provided by Uros Platise.
|
||||
* arch/arm/src/stm32/stm32_flash.c: Add support for access to on-chp STM32
|
||||
FLASH; beginning of integration with NXFFS (Uros Platise).
|
||||
|
||||
|
||||
|
@ -12,7 +12,7 @@
|
||||
<h1><big><font color="#3c34ec">
|
||||
<i>NuttX RTOS Porting Guide</i>
|
||||
</font></big></h1>
|
||||
<p>Last Updated: April 14, 2011</p>
|
||||
<p>Last Updated: May 6, 2011</p>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
@ -886,6 +886,9 @@ fs/
|
||||
|-- fat/
|
||||
| |-- Make.defs
|
||||
| `-- <i>(fat file system source files)</i>
|
||||
|-- nxffs/
|
||||
| |-- Make.defs
|
||||
| `-- <i>(NXFFS file system source files)</i>
|
||||
|-- romfs/
|
||||
| |-- Make.defs
|
||||
| `-- <i>(romfs file system source files)</i>
|
||||
@ -1949,7 +1952,8 @@ extern void up_ledoff(int led);
|
||||
NuttX supports the standard <code>mount()</code> command that allows
|
||||
a block driver to be bound to a mountpoint within the pseudo file system
|
||||
and to a file system.
|
||||
At present, NuttX supports only the VFAT file system.
|
||||
At present, NuttX supports the standard VFAT and ROMFS file systems and
|
||||
well as a special, wear-leveling NuttX FLASH File System (NXFFS).
|
||||
</p>
|
||||
|
||||
<p><b>Comparison to Linux</b>
|
||||
@ -3440,6 +3444,39 @@ build
|
||||
<li>
|
||||
<code>CONFIG_FAT_SECTORSIZE</code>: Max supported sector size.
|
||||
</li>
|
||||
<li>
|
||||
<code>CONFIG_FS_NXFFS</code>: Enable NuttX FLASH file system (NXFF) support.
|
||||
</li>
|
||||
<li>
|
||||
<code>CONFIG_NXFFS_ERASEDSTATE</code>: The erased state of FLASH.
|
||||
This must have one of the values of <code>0xff</code> or <code>0x00</code>.
|
||||
Default: <code>0xff</code>.
|
||||
</li>
|
||||
<li>
|
||||
<code>CONFIG_NXFFS_PACKTHRESHOLD</code>: When packing flash file data,
|
||||
don't both with file chunks smaller than this number of data bytes.
|
||||
Default: 32.
|
||||
</li>
|
||||
<li>
|
||||
<code>CONFIG_NXFFS_MAXNAMLEN</code>: The maximum size of an NXFFS file name.
|
||||
Default: 255.
|
||||
</li>
|
||||
<li>
|
||||
<code>CONFIG_NXFFS_PACKTHRESHOLD</code>: When packing flash file data,
|
||||
don't both with file chunks smaller than this number of data bytes.
|
||||
Default: 32.
|
||||
</li>
|
||||
<li>
|
||||
<code>CONFIG_NXFFS_TAILTHRESHOLD</code>: clean-up can either mean
|
||||
packing files together toward the end of the file or, if file are
|
||||
deleted at the end of the file, clean up can simply mean erasing
|
||||
the end of FLASH memory so that it can be re-used again. However,
|
||||
doing this can also harm the life of the FLASH part because it can
|
||||
mean that the tail end of the FLASH is re-used too often. This
|
||||
threshold determines if/when it is worth erased the tail end of FLASH
|
||||
and making it available for re-use (and possible over-wear).
|
||||
Default: 8192.
|
||||
</li>
|
||||
<li>
|
||||
<code>CONFIG_FS_ROMFS</code>: Enable ROMFS file system support
|
||||
</li>
|
||||
|
37
TODO
37
TODO
@ -1,4 +1,4 @@
|
||||
NuttX TODO List (Last updated April 19 2011)
|
||||
NuttX TODO List (Last updated May 6, 2011)
|
||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
nuttx/
|
||||
@ -14,7 +14,7 @@ nuttx/
|
||||
(2) USB (drivers/usbdev, drivers/usbhost)
|
||||
(5) Libraries (lib/)
|
||||
(13) File system/Generic drivers (fs/, drivers/)
|
||||
(2) Graphics subystem (graphics/)
|
||||
(1) Graphics subystem (graphics/)
|
||||
(1) Pascal add-on (pcode/)
|
||||
(1) Documentation (Documentation/)
|
||||
(4) Build system / Toolchains
|
||||
@ -23,7 +23,7 @@ nuttx/
|
||||
(1) ARM/C5471 (arch/arm/src/c5471/)
|
||||
(3) ARM/DM320 (arch/arm/src/dm320/)
|
||||
(2) ARM/i.MX (arch/arm/src/imx/)
|
||||
(4) ARM/LPC17xx (arch/arm/src/lpc17xx/)
|
||||
(3) ARM/LPC17xx (arch/arm/src/lpc17xx/)
|
||||
(7) ARM/LPC214x (arch/arm/src/lpc214x/)
|
||||
(2) ARM/LPC313x (arch/arm/src/lpc313x/)
|
||||
(3) ARM/STR71x (arch/arm/src/str71x/)
|
||||
@ -53,6 +53,8 @@ o Task/Scheduler (sched/)
|
||||
|
||||
Description: atexit() supports registration of one function called on exit().
|
||||
Should task_delete() also cause atexit() function to be called?
|
||||
Update: atexit() is only built into the system if CONFIG_SCHED_ATEXT
|
||||
is defined in the configuration.
|
||||
Status: Open
|
||||
Priority: Low, task_delete() is non-standard and its behavior is
|
||||
unspecified.
|
||||
@ -64,6 +66,9 @@ o Task/Scheduler (sched/)
|
||||
Description: Implement sys/wait.h and functions. Consider implementing wait,
|
||||
waitpid, waitid. At present, a parent has no information about
|
||||
child tasks.
|
||||
Update: A simple but usable version of waitpid() has been included.
|
||||
This version is not compliant with all specifications and can be
|
||||
enabled with CONFIG_SCHED_WAITPID.
|
||||
Status: Open
|
||||
Priority: Low
|
||||
|
||||
@ -182,7 +187,7 @@ o Binary loaders (binfmt/)
|
||||
Status: Open
|
||||
Priority: Low
|
||||
|
||||
Description: Windows build issue. Almost all configurations that use NXFLAT have
|
||||
Description: Windows build issue. Some of the configurations that use NXFLAT have
|
||||
the linker script specified like this:
|
||||
|
||||
NXFLATLDFLAGS2 = $(NXFLATLDFLAGS1) -T$(TOPDIR)/binfmt/libnxflat/gnu-nxflat.ld -no-check-sections
|
||||
@ -226,7 +231,7 @@ o Network (net/, drivers/net)
|
||||
Priority: Medium, The feature is not important, but it is important
|
||||
for NuttX to resolve the architectural issues.
|
||||
|
||||
Description: Sendoto() and multiple network interface support:
|
||||
Description: sendto() and multiple network interface support:
|
||||
When polled, would have to assure that the destination IP
|
||||
is on the subnet served by the polling driver.
|
||||
Status: Open
|
||||
@ -457,7 +462,7 @@ o File system / Generic drivers (fs/, drivers/)
|
||||
Status: Open
|
||||
Priority: Low
|
||||
|
||||
Description: Time stamping is no implemented in the NuttX FA file system.
|
||||
Description: Time stamping is not implemented in the NuttX FA file system.
|
||||
See the following functions in fs/fat/fs_fat32util.c:
|
||||
fat_systime2fattime() and fat_fattime2systime()
|
||||
Status: Open
|
||||
@ -466,14 +471,6 @@ o File system / Generic drivers (fs/, drivers/)
|
||||
o Graphics subystem (graphics/)
|
||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
Description: If CONFIG_NX is enabled, the build fails the first time
|
||||
saying that there is "No rule to make target..." for one of the
|
||||
auto-generated graphics files. This is a nuisance, but if you
|
||||
simply build again (with the source files already auto-generated)
|
||||
the problem does not reoccur.
|
||||
Status: Open
|
||||
Priority: Low, the work-around is simple
|
||||
|
||||
Description: Testing of all APIs is not complete. See
|
||||
http://nuttx.sourceforge.net/NXGraphicsSubsystem.html#testcoverage
|
||||
Status: Open
|
||||
@ -662,10 +659,10 @@ o ARM/DM320 (arch/arm/src/dm320/)
|
||||
o ARM/i.MX (arch/arm/src/imx/)
|
||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
Description: The basic port of the i.MX1 architecuture is underway. The port
|
||||
Description: The basic port of the i.MX1 architecuture was never finished. The port
|
||||
is incomplete (as of this writing, is still lacks a timer, interrupt
|
||||
decoding, USB, network) and untested.
|
||||
Status: Open (and in work)
|
||||
Status: Open
|
||||
Priority: Medium (high if you need i.MX1/L support)
|
||||
|
||||
Description: SPI methods are not thread safe. Needs a semaphore to protect from re-entrancy.
|
||||
@ -697,14 +694,6 @@ o ARM/LPC17xx (arch/arm/src/lpc17xx/)
|
||||
Status: Open
|
||||
Priority: Medium-Low (unless you need the display on the LPC1766STK!)
|
||||
|
||||
Description: SLIP (Configuration olimex-lpc1766stk/slip-httpd) only works with VERBOSE
|
||||
debug disabled. For some reason, certain debug statements hang(?).
|
||||
Also, this example does not use UART1's hardware flow control. UART1
|
||||
hardware flow control is partially implemented but does not behave as
|
||||
expected. Hardware flow control needs a little more work.
|
||||
Status: Open
|
||||
Priority: Low
|
||||
|
||||
o ARM/LPC214x (arch/arm/src/lpc214x/)
|
||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
|
@ -45,8 +45,9 @@ CMN_CSRCS = up_allocateheap.c up_assert.c up_blocktask.c up_copystate.c \
|
||||
up_usestack.c up_doirq.c up_hardfault.c up_svcall.c
|
||||
|
||||
CHIP_ASRCS =
|
||||
CHIP_CSRCS = stm32_start.c stm32_rcc.c stm32_gpio.c stm32_idle.c \
|
||||
CHIP_CSRCS = stm32_start.c stm32_rcc.c stm32_gpio.c stm32_flash.c \
|
||||
stm32_irq.c stm32_timerisr.c stm32_dma.c stm32_lowputc.c \
|
||||
stm32_serial.c stm32_spi.c stm32_usbdev.c stm32_sdio.c \
|
||||
stm32_tim.c stm32_i2c.c stm32_pwr.c stm32_rtc.c stm32_waste.c
|
||||
stm32_tim.c stm32_i2c.c stm32_pwr.c stm32_rtc.c \
|
||||
stm32_idle.c stm32_waste.c
|
||||
|
||||
|
115
arch/arm/src/stm32/chip/stm32_flash.h
Executable file
115
arch/arm/src/stm32/chip/stm32_flash.h
Executable file
@ -0,0 +1,115 @@
|
||||
/************************************************************************************
|
||||
* arch/arm/src/stm32/chip/stm32_flash.h
|
||||
*
|
||||
* Copyright (C) 2009, 2011 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
************************************************************************************/
|
||||
|
||||
#ifndef __ARCH_ARM_SRC_STM32_CHIP_STM32_FLASH_H
|
||||
#define __ARCH_ARM_SRC_STM32_CHIP_STM32_FLASH_H
|
||||
|
||||
/************************************************************************************
|
||||
* Pre-processor Definitions
|
||||
************************************************************************************/
|
||||
|
||||
#ifdef CONFIG_STM32_LOWDENSITY
|
||||
# define STM32_FLASH_NPAGES 32
|
||||
# define STM32_FLASH_PAGESIZE 1024
|
||||
#elif CONFIG_STM32_MEDIUMDENSITY
|
||||
# define STM32_FLASH_NPAGES 128
|
||||
# define STM32_FLASH_PAGESIZE 1024
|
||||
#elif CONFIG_STM32_CONNECTIVITYLINE
|
||||
# define STM32_FLASH_NPAGES 128
|
||||
# define STM32_FLASH_PAGESIZE 2048
|
||||
#elif CONFIG_STM32_HIGHDENSITY
|
||||
# define STM32_FLASH_NPAGES 256
|
||||
# define STM32_FLASH_PAGESIZE 2048
|
||||
#endif
|
||||
|
||||
#define STM32_FLASH_SIZE (STM32_FLASH_NPAGES * STM32_FLASH_PAGESIZE)
|
||||
|
||||
/* Register Offsets *****************************************************************/
|
||||
|
||||
#define STM32_FLASH_ACR_OFFSET 0x0000
|
||||
#define STM32_FLASH_KEYR_OFFSET 0x0004
|
||||
#define STM32_FLASH_OPTKEYR_OFFSET 0x0008
|
||||
#define STM32_FLASH_SR_OFFSET 0x000c
|
||||
#define STM32_FLASH_CR_OFFSET 0x0010
|
||||
#define STM32_FLASH_AR_OFFSET 0x0014
|
||||
#define STM32_FLASH_OBR_OFFSET 0x001c
|
||||
#define STM32_FLASH_WRPR_OFFSET 0x0020
|
||||
|
||||
/* Register Addresses ***************************************************************/
|
||||
|
||||
#define STM32_FLASH_ACR (STM32_FLASHIF_BASE+STM32_FLASH_ACR_OFFSET)
|
||||
#define STM32_FLASH_KEYR (STM32_FLASHIF_BASE+STM32_FLASH_KEYR_OFFSET)
|
||||
#define STM32_FLASH_OPTKEYR (STM32_FLASHIF_BASE+STM32_FLASH_OPTKEYR_OFFSET)
|
||||
#define STM32_FLASH_SR (STM32_FLASHIF_BASE+STM32_FLASH_SR_OFFSET)
|
||||
#define STM32_FLASH_CR (STM32_FLASHIF_BASE+STM32_FLASH_CR_OFFSET)
|
||||
#define STM32_FLASH_AR (STM32_FLASHIF_BASE+STM32_FLASH_AR_OFFSET)
|
||||
#define STM32_FLASH_OBR (STM32_FLASHIF_BASE+STM32_FLASH_OBR_OFFSET)
|
||||
#define STM32_FLASH_WRPR (STM32_FLASHIF_BASE+STM32_FLASH_WRPR_OFFSET)
|
||||
|
||||
/* Register Bitfield Definitions ****************************************************/
|
||||
/* TODO: Complete FLASH details from the STM32F10xxx Flash programming manual. */
|
||||
|
||||
/* Flash Status Register (SR) */
|
||||
|
||||
#define FLASH_SR_BSY (1 << 0) /* Busy */
|
||||
#define FLASH_SR_PGERR (1 << 2) /* Programming Error */
|
||||
#define FLASH_SR_WRPRT_ERR (1 << 4) /* Write Protection Error */
|
||||
#define FLASH_SR_EOP (1 << 5) /* End of Operation */
|
||||
|
||||
/* Flash Control Register (CR) */
|
||||
|
||||
#define FLASH_CR_PG (1 << 0) /* Program Page */
|
||||
#define FLASH_CR_PER (1 << 1) /* Page Erase */
|
||||
#define FLASH_CR_MER (1 << 2) /* Mass Erase */
|
||||
#define FLASH_CR_OPTPG (1 << 4) /* Option Byte Programming */
|
||||
#define FLASH_CR_OPTER (1 << 5) /* Option Byte Erase */
|
||||
#define FLASH_CR_STRT (1 << 6) /* Start Erase */
|
||||
#define FLASH_CR_LOCK (1 << 7) /* Page Locked or Lock Page */
|
||||
#define FLASH_CR_OPTWRE (1 << 9) /* Option Bytes Write Enable */
|
||||
#define FLASH_CR_ERRIE (1 << 10) /* Error Interrupt Enable */
|
||||
#define FLASH_CR_EOPIE (1 << 12) /* End of Program Interrupt Enable */
|
||||
|
||||
/* Flash Access Control Register (ACR) */
|
||||
|
||||
#define FLASH_ACR_LATENCY_SHIFT (0)
|
||||
#define FLASH_ACR_LATENCY_MASK (7 << FLASH_ACR_LATENCY_SHIFT)
|
||||
# define FLASH_ACR_LATENCY_0 (0 << FLASH_ACR_LATENCY_SHIFT) /* FLASH Zero Latency cycle */
|
||||
# define FLASH_ACR_LATENCY_1 (1 << FLASH_ACR_LATENCY_SHIFT) /* FLASH One Latency cycle */
|
||||
# define FLASH_ACR_LATENCY_2 (2 << FLASH_ACR_LATENCY_SHIFT) /* FLASH Two Latency cycles */
|
||||
#define FLASH_ACR_HLFCYA (1 << 3) /* FLASH half cycle access */
|
||||
#define FLASH_ACR_PRTFBE (1 << 4) /* FLASH prefetch enable */
|
||||
|
||||
#endif /* __ARCH_ARM_SRC_STM32_CHIP_STM32_FLASH_H */
|
||||
|
228
arch/arm/src/stm32/stm32_flash.c
Normal file
228
arch/arm/src/stm32/stm32_flash.c
Normal file
@ -0,0 +1,228 @@
|
||||
/************************************************************************************
|
||||
* arch/arm/src/stm32/stm32_flash.c
|
||||
*
|
||||
* Copyright (C) 2011 Uros Platise. All rights reserved.
|
||||
* Author: Uros Platise <uros.platise@isotel.eu>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
************************************************************************************/
|
||||
|
||||
/** \file
|
||||
* \author Uros Platise
|
||||
* \brief STM32 Flash - Program and Data Memory
|
||||
*
|
||||
* Provides standard flash access function, to be used also by the
|
||||
* drivers/mtd/progmem.c program memory flash mtd driver.
|
||||
* The interface is to be defined in the include/nuttx/progmem.h
|
||||
*
|
||||
* Requirements:
|
||||
* - During write/erase operatoins on FLASH, HSI must be ON.
|
||||
* - Low Power Modes are not permitted during write/erase
|
||||
*/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
#include <nuttx/arch.h>
|
||||
#include <errno.h>
|
||||
|
||||
#include "stm32_flash.h"
|
||||
#include "stm32_rcc.h"
|
||||
#include "stm32_waste.h"
|
||||
#include "up_arch.h"
|
||||
|
||||
|
||||
/************************************************************************************
|
||||
* Declarations
|
||||
************************************************************************************/
|
||||
|
||||
#define FLASH_KEY1 0x45670123
|
||||
#define FLASH_KEY2 0xCDEF89AB
|
||||
|
||||
|
||||
/************************************************************************************
|
||||
* Private Functions
|
||||
************************************************************************************/
|
||||
|
||||
void stm32_flash_unlock(void)
|
||||
{
|
||||
while( getreg32(STM32_FLASH_SR) & FLASH_SR_BSY ) up_waste();
|
||||
|
||||
if ( getreg32(STM32_FLASH_CR) & FLASH_CR_LOCK ) {
|
||||
|
||||
/* Unlock sequence */
|
||||
|
||||
putreg32(FLASH_KEY1, STM32_FLASH_KEYR);
|
||||
putreg32(FLASH_KEY2, STM32_FLASH_KEYR);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void stm32_flash_lock(void)
|
||||
{
|
||||
modifyreg16(STM32_FLASH_CR, 0, FLASH_CR_LOCK);
|
||||
}
|
||||
|
||||
|
||||
/************************************************************************************
|
||||
* Public Functions
|
||||
************************************************************************************/
|
||||
|
||||
uint16_t up_progmem_npages(void)
|
||||
{
|
||||
return STM32_FLASH_NPAGES;
|
||||
}
|
||||
|
||||
|
||||
bool up_progmem_isuniform(void)
|
||||
{
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
|
||||
uint16_t up_progmem_pagesize(uint16_t page)
|
||||
{
|
||||
return STM32_FLASH_PAGESIZE;
|
||||
}
|
||||
|
||||
|
||||
int up_progmem_getpage(uint32_t addr)
|
||||
{
|
||||
if (addr >= STM32_FLASH_SIZE)
|
||||
return -EFAULT;
|
||||
|
||||
return addr / STM32_FLASH_PAGESIZE;
|
||||
}
|
||||
|
||||
|
||||
int up_progmem_erasepage(uint16_t page)
|
||||
{
|
||||
uint32_t addr;
|
||||
uint16_t count;
|
||||
|
||||
if (page >= STM32_FLASH_NPAGES)
|
||||
return -EFAULT;
|
||||
|
||||
/* Get flash ready and begin erasing single page */
|
||||
|
||||
if ( !(getreg32(STM32_RCC_CR) & RCC_CR_HSION) )
|
||||
return -EPERM;
|
||||
|
||||
stm32_flash_unlock();
|
||||
|
||||
modifyreg32(STM32_FLASH_CR, 0, FLASH_CR_PER);
|
||||
putreg32(page * STM32_FLASH_PAGESIZE, STM32_FLASH_AR);
|
||||
modifyreg32(STM32_FLASH_CR, 0, FLASH_CR_STRT);
|
||||
|
||||
while( getreg32(STM32_FLASH_SR) & FLASH_SR_BSY ) up_waste();
|
||||
|
||||
modifyreg32(STM32_FLASH_CR, FLASH_CR_PER, 0);
|
||||
|
||||
/* Verify */
|
||||
|
||||
for (addr = page * STM32_FLASH_PAGESIZE + STM32_FLASH_BASE, count = STM32_FLASH_PAGESIZE;
|
||||
count; count-=4, addr += 4) {
|
||||
|
||||
if (getreg32(addr) != 0xFFFFFFFF)
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
return STM32_FLASH_PAGESIZE;
|
||||
}
|
||||
|
||||
|
||||
int up_progmem_ispageerased(uint16_t page)
|
||||
{
|
||||
uint32_t addr;
|
||||
uint16_t count;
|
||||
uint16_t bwritten = 0;
|
||||
uint16_t hword;
|
||||
|
||||
if (page >= STM32_FLASH_NPAGES)
|
||||
return -EFAULT;
|
||||
|
||||
/* Verify */
|
||||
|
||||
for (addr = page * STM32_FLASH_PAGESIZE + STM32_FLASH_BASE, count = STM32_FLASH_PAGESIZE;
|
||||
count; count--, addr++) {
|
||||
|
||||
if (getreg8(addr) != 0xFF) bwritten++;
|
||||
}
|
||||
|
||||
return bwritten;
|
||||
}
|
||||
|
||||
|
||||
int up_progmem_write(uint32_t addr, const void *buf, size_t count)
|
||||
{
|
||||
uint16_t *hword = (uint16_t *)buf;
|
||||
size_t written = count;
|
||||
|
||||
/* STM32 requires half-word access */
|
||||
|
||||
if (count & 1)
|
||||
return -EINVAL;
|
||||
|
||||
/* Check for valid address range */
|
||||
|
||||
if ( (addr+count) >= STM32_FLASH_SIZE)
|
||||
return -EFAULT;
|
||||
|
||||
/* Get flash ready and begin flashing */
|
||||
|
||||
if ( !(getreg32(STM32_RCC_CR) & RCC_CR_HSION) )
|
||||
return -EPERM;
|
||||
|
||||
stm32_flash_unlock();
|
||||
|
||||
modifyreg32(STM32_FLASH_CR, 0, FLASH_CR_PG);
|
||||
|
||||
for (addr += STM32_FLASH_BASE; count; count--, hword++, addr+=2) {
|
||||
|
||||
/* Write half-word and wait to complete */
|
||||
|
||||
putreg16(*hword, addr);
|
||||
|
||||
while( getreg32(STM32_FLASH_SR) & FLASH_SR_BSY ) up_waste();
|
||||
|
||||
/* Verify */
|
||||
|
||||
if (getreg32(STM32_FLASH_SR) & FLASH_SR_WRPRT_ERR) {
|
||||
modifyreg32(STM32_FLASH_CR, FLASH_CR_PG, 0);
|
||||
return -EROFS;
|
||||
}
|
||||
|
||||
if (getreg16(addr) != *hword) {
|
||||
modifyreg32(STM32_FLASH_CR, FLASH_CR_PG, 0);
|
||||
return -EIO;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
modifyreg32(STM32_FLASH_CR, FLASH_CR_PG, 0);
|
||||
return written;
|
||||
}
|
@ -1,8 +1,8 @@
|
||||
/************************************************************************************
|
||||
* arch/arm/src/stm32/stm32_flash.h
|
||||
*
|
||||
* Copyright (C) 2009, 2011 Gregory Nutt. All rights reserved.
|
||||
* Author: Gregory Nutt <spudmonkey@racsa.co.cr>
|
||||
* Copyright (C) 2011 Uros Platise. All rights reserved.
|
||||
* Author: Uros Platise <uros.platise@isotel.eu>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
@ -36,64 +36,10 @@
|
||||
#ifndef __ARCH_ARM_SRC_STM32_STM32_FLASH_H
|
||||
#define __ARCH_ARM_SRC_STM32_STM32_FLASH_H
|
||||
|
||||
/************************************************************************************
|
||||
* Included Files
|
||||
************************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
#include <nuttx/progmem.h>
|
||||
|
||||
#include "chip.h"
|
||||
|
||||
/************************************************************************************
|
||||
* Pre-processor Definitions
|
||||
************************************************************************************/
|
||||
|
||||
/* Register Offsets *****************************************************************/
|
||||
|
||||
#define STM32_FLASH_ACR_OFFSET 0x0000
|
||||
#define STM32_FLASH_KEYR_OFFSET 0x0004
|
||||
#define STM32_FLASH_OPTKEYR_OFFSET 0x0008
|
||||
#define STM32_FLASH_SR_OFFSET 0x000c
|
||||
#define STM32_FLASH_CR_OFFSET 0x0010
|
||||
#define STM32_FLASH_AR_OFFSET 0x0014
|
||||
#define STM32_FLASH_OBR_OFFSET 0x001c
|
||||
#define STM32_FLASH_WRPR_OFFSET 0x0020
|
||||
|
||||
/* Register Addresses ***************************************************************/
|
||||
|
||||
#define STM32_FLASH_ACR (STM32_FLASHIF_BASE+STM32_FLASH_ACR_OFFSET)
|
||||
#define STM32_FLASH_KEYR (STM32_FLASHIF_BASE+STM32_FLASH_KEYR_OFFSET)
|
||||
#define STM32_FLASH_OPTKEYR (STM32_FLASHIF_BASE+STM32_FLASH_OPTKEYR_OFFSET)
|
||||
#define STM32_FLASH_SR (STM32_FLASHIF_BASE+STM32_FLASH_SR_OFFSET)
|
||||
#define STM32_FLASH_CR (STM32_FLASHIF_BASE+STM32_FLASH_CR_OFFSET)
|
||||
#define STM32_FLASH_AR (STM32_FLASHIF_BASE+STM32_FLASH_AR_OFFSET)
|
||||
#define STM32_FLASH_OBR (STM32_FLASHIF_BASE+STM32_FLASH_OBR_OFFSET)
|
||||
#define STM32_FLASH_WRPR (STM32_FLASHIF_BASE+STM32_FLASH_WRPR_OFFSET)
|
||||
|
||||
/* Register Bitfield Definitions ****************************************************/
|
||||
/* TODO: FLASH details from the STM32F10xxx Flash programming manual. */
|
||||
|
||||
/* Flash Access Control Register (ACR) */
|
||||
|
||||
#define ACR_LATENCY_SHIFT (0)
|
||||
#define ACR_LATENCY_MASK (7 << ACR_LATENCY_SHIFT)
|
||||
# define ACR_LATENCY_0 (0 << ACR_LATENCY_SHIFT) /* FLASH Zero Latency cycle */
|
||||
# define ACR_LATENCY_1 (1 << ACR_LATENCY_SHIFT) /* FLASH One Latency cycle */
|
||||
# define ACR_LATENCY_2 (2 << ACR_LATENCY_SHIFT) /* FLASH Two Latency cycles */
|
||||
#define ACR_HLFCYA (1 << 3) /* FLASH half cycle access */
|
||||
#define ACR_PRTFBE (1 << 4) /* FLASH prefetch enable */
|
||||
|
||||
/************************************************************************************
|
||||
* Public Types
|
||||
************************************************************************************/
|
||||
|
||||
/************************************************************************************
|
||||
* Public Data
|
||||
************************************************************************************/
|
||||
|
||||
/************************************************************************************
|
||||
* Public Functions
|
||||
************************************************************************************/
|
||||
#include "chip/stm32_flash.h"
|
||||
|
||||
#endif /* __ARCH_ARM_SRC_STM32_STM32_FLASH_H */
|
||||
|
||||
|
@ -413,8 +413,8 @@ static inline void stm32_stdclockconfig(void)
|
||||
/* Enable FLASH prefetch buffer and 2 wait states */
|
||||
|
||||
regval = getreg32(STM32_FLASH_ACR);
|
||||
regval &= ~ACR_LATENCY_MASK;
|
||||
regval |= (ACR_LATENCY_2|ACR_PRTFBE);
|
||||
regval &= ~FLASH_ACR_LATENCY_MASK;
|
||||
regval |= (FLASH_ACR_LATENCY_2|FLASH_ACR_PRTFBE);
|
||||
putreg32(regval, STM32_FLASH_ACR);
|
||||
|
||||
/* Set the HCLK source/divider */
|
||||
|
@ -518,6 +518,27 @@ defconfig -- This is a configuration file similar to the Linux
|
||||
Filesystem configuration
|
||||
CONFIG_FS_FAT - Enable FAT filesystem support
|
||||
CONFIG_FAT_SECTORSIZE - Max supported sector size
|
||||
CONFIG_FS_NXFFS: Enable NuttX FLASH file system (NXFF) support.
|
||||
CONFIG_NXFFS_ERASEDSTATE: The erased state of FLASH.
|
||||
This must have one of the values of 0xff or 0x00.
|
||||
Default: 0xff.
|
||||
CONFIG_NXFFS_PACKTHRESHOLD: When packing flash file data,
|
||||
don't both with file chunks smaller than this number of data bytes.
|
||||
Default: 32.
|
||||
CONFIG_NXFFS_MAXNAMLEN: The maximum size of an NXFFS file name.
|
||||
Default: 255.
|
||||
CONFIG_NXFFS_PACKTHRESHOLD: When packing flash file data,
|
||||
don't both with file chunks smaller than this number of data bytes.
|
||||
Default: 32.
|
||||
CONFIG_NXFFS_TAILTHRESHOLD: clean-up can either mean
|
||||
packing files together toward the end of the file or, if file are
|
||||
deleted at the end of the file, clean up can simply mean erasing
|
||||
the end of FLASH memory so that it can be re-used again. However,
|
||||
doing this can also harm the life of the FLASH part because it can
|
||||
mean that the tail end of the FLASH is re-used too often. This
|
||||
threshold determines if/when it is worth erased the tail end of FLASH
|
||||
and making it available for re-use (and possible over-wear).
|
||||
Default: 8192.
|
||||
CONFIG_FS_ROMFS - Enable ROMFS filesystem support
|
||||
|
||||
SPI driver
|
||||
|
@ -522,8 +522,10 @@ CONFIG_PREALLOC_TIMERS=4
|
||||
#
|
||||
# CONFIG_FS_FAT - Enable FAT filesystem support
|
||||
# CONFIG_FAT_SECTORSIZE - Max supported sector size
|
||||
# CONFIG_FS_NXFFS - Enable NX Flash File System
|
||||
# CONFIG_FS_ROMFS - Enable ROMFS filesystem support
|
||||
CONFIG_FS_FAT=y
|
||||
CONFIG_FS_NXFFS=y
|
||||
CONFIG_FS_ROMFS=y
|
||||
|
||||
#
|
||||
@ -891,15 +893,3 @@ CONFIG_APPS_DIR="../apps"
|
||||
|
||||
# Provide /dev/ramX and then: mount -t binfs /dev/ram0 /bin
|
||||
CONFIG_APPS_BINDIR=y
|
||||
|
||||
# Application configuration
|
||||
|
||||
CONFIG_APPS_DIR="../apps"
|
||||
|
||||
# Application configuration
|
||||
|
||||
CONFIG_APPS_DIR="../apps"
|
||||
|
||||
# Application configuration
|
||||
|
||||
CONFIG_APPS_DIR="../apps"
|
||||
|
@ -74,6 +74,7 @@
|
||||
#include <nuttx/clock.h>
|
||||
#include <nuttx/time.h>
|
||||
#include <nuttx/rtc.h>
|
||||
#include <nuttx/progmem.h>
|
||||
|
||||
#include <nuttx/i2c.h>
|
||||
#include <nuttx/sensors/st_lis331dl.h>
|
||||
@ -512,6 +513,36 @@ int sif_main(int argc, char *argv[])
|
||||
t_set.tv_sec = atoi(argv[2]);
|
||||
clock_settime(CLOCK_REALTIME, &t_set);
|
||||
}
|
||||
else if (!strcmp(argv[1], "free") ) {
|
||||
uint16_t page = 0, stpage = 0xFFFF;
|
||||
int status;
|
||||
do {
|
||||
status = up_progmem_ispageerased(page++);
|
||||
|
||||
/* Is this beginning of new free space section */
|
||||
if (status == 0) {
|
||||
if (stpage == 0xFFFF) stpage = page-1;
|
||||
}
|
||||
else if (status != 0) {
|
||||
if (stpage != 0xFFFF) {
|
||||
printf("Free Range:\t%d\t-\t%d\n", stpage, page-2);
|
||||
stpage = 0xFFFF;
|
||||
}
|
||||
}
|
||||
}
|
||||
while (status >= 0);
|
||||
}
|
||||
else if (!strcmp(argv[1], "erase") && argc == 3 ) {
|
||||
int page = atoi(argv[2]);
|
||||
printf("Erase result: %d\n", up_progmem_erasepage(page) );
|
||||
}
|
||||
else if (!strcmp(argv[1], "flash") && argc == 3 ) {
|
||||
uint16_t page = atoi(argv[2]);
|
||||
uint32_t addr = page * up_progmem_pagesize(page);
|
||||
|
||||
printf("Write result: %d (writing to address %xh)\n",
|
||||
up_progmem_write( addr, "Test", 4 ), addr);
|
||||
}
|
||||
else if (!strcmp(argv[1], "i2c") && argc == 3) {
|
||||
int val = atoi(argv[2]);
|
||||
|
||||
@ -520,7 +551,7 @@ int sif_main(int argc, char *argv[])
|
||||
struct st_lis331dl_dev_s * lis = st_lis331dl_init(vsn_sif.i2c1, val);
|
||||
|
||||
if (lis) {
|
||||
struct st_lis331dl_vector_s * a;
|
||||
const struct st_lis331dl_vector_s * a;
|
||||
int i;
|
||||
uint32_t time_stamp = clock_systimer();
|
||||
|
||||
|
@ -78,8 +78,8 @@ void sysclock_select_hsi(void)
|
||||
|
||||
// Set FLASH prefetch buffer and 1 wait state
|
||||
regval = getreg32(STM32_FLASH_ACR);
|
||||
regval &= ~ACR_LATENCY_MASK;
|
||||
regval |= (ACR_LATENCY_1|ACR_PRTFBE);
|
||||
regval &= ~FLASH_ACR_LATENCY_MASK;
|
||||
regval |= (FLASH_ACR_LATENCY_1|FLASH_ACR_PRTFBE);
|
||||
putreg32(regval, STM32_FLASH_ACR);
|
||||
|
||||
// Set the HCLK source/divider
|
||||
|
@ -139,7 +139,7 @@ EXTERN const char *namedapp_getname(int index);
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
EXTERN int exec_namedapp(FAR const char *appname, FAR const char *argv[]);
|
||||
EXTERN int exec_namedapp(FAR const char *appname, FAR const char **argv);
|
||||
|
||||
#undef EXTERN
|
||||
#if defined(__cplusplus)
|
||||
|
143
include/nuttx/progmem.h
Normal file
143
include/nuttx/progmem.h
Normal file
@ -0,0 +1,143 @@
|
||||
/****************************************************************************
|
||||
* include/nuttx/progmem.h
|
||||
*
|
||||
* Copyright(C) 2011 Uros Platise. All rights reserved.
|
||||
* Author: Uros Platise <uros.platise@isotel.eu>
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions
|
||||
* are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* 2. Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the
|
||||
* distribution.
|
||||
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software
|
||||
* without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES(INCLUDING,
|
||||
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||
* LIABILITY, OR TORT(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||
* POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef __INCLUDE_NUTTX_PROGMEM_H
|
||||
#define __INCLUDE_NUTTX_PROGMEM_H
|
||||
|
||||
/****************************************************************************
|
||||
* Included Files
|
||||
****************************************************************************/
|
||||
|
||||
#include <nuttx/config.h>
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stdbool.h>
|
||||
|
||||
/****************************************************************************
|
||||
* Pre-processor Definitions
|
||||
****************************************************************************/
|
||||
|
||||
#undef EXTERN
|
||||
#if defined(__cplusplus)
|
||||
#define EXTERN extern "C"
|
||||
extern "C" {
|
||||
#else
|
||||
#define EXTERN extern
|
||||
#endif
|
||||
|
||||
/****************************************************************************
|
||||
* Public Functions
|
||||
****************************************************************************/
|
||||
|
||||
/* Return number of pages */
|
||||
|
||||
uint16_t up_progmem_npages(void);
|
||||
|
||||
/* Is program memory uniform or page size differs */
|
||||
|
||||
bool up_progmem_isuniform(void);
|
||||
|
||||
/* Return page size */
|
||||
|
||||
uint16_t up_progmem_pagesize(uint16_t page);
|
||||
|
||||
/* Address to page conversion
|
||||
* \param addr Address without flash offet (aligned to page0)
|
||||
* \return Page or negative value on error
|
||||
*
|
||||
* The following errors are reported (errno is not set!)
|
||||
* - EFAULT: On invalid address
|
||||
*/
|
||||
|
||||
int up_progmem_getpage(uint32_t addr);
|
||||
|
||||
/* Erase selected page.
|
||||
* \return page size or negative value on error
|
||||
*
|
||||
* The following errors are reported (errno is not set!)
|
||||
* - EFAULT: On invalid page
|
||||
* - EIO: On unsuccessful erase
|
||||
* - EROFS: On access to write protected area
|
||||
* - EACCES: Insufficient permissions (read/write protected)
|
||||
* - EPERM: If operation is not permitted due to some other constraints
|
||||
* (i.e. some internal block is not running etc.)
|
||||
*/
|
||||
|
||||
int up_progmem_erasepage(uint16_t page);
|
||||
|
||||
/* Checks whether page is erased
|
||||
*
|
||||
* Returns number of bytes written or negative value on error.
|
||||
* If it returns zero then complete page is empty (erased).
|
||||
*
|
||||
* The following errors are reported (errno is not set!)
|
||||
* - EFAULT: On invalid page
|
||||
*/
|
||||
|
||||
int up_progmem_ispageerased(uint16_t page);
|
||||
|
||||
/* Program data at given address
|
||||
* \return bytes written or negative value on error
|
||||
* \param addr Address without flash offet (aligned to page0)
|
||||
* \param buf Pointer to buffer
|
||||
* \param count Number of bytes to write
|
||||
*
|
||||
* Note: this function is not limited to single page and nor it requires
|
||||
* the address be aligned inside the page boundaries.
|
||||
*
|
||||
* The following errors are reported (errno is not set!)
|
||||
* - EINVAL: if count is not aligned with the flash boundaries (i.e.
|
||||
* some MCU's require per half-word or even word access)
|
||||
* - EFAULT: On invalid address
|
||||
* - EIO: On unsuccessful write
|
||||
* - EROFS: On access to write protected area
|
||||
* - EACCES: Insufficient permissions (read/write protected)
|
||||
* - EPERM: If operation is not permitted due to some other constraints
|
||||
* (i.e. some internal block is not running etc.)
|
||||
*/
|
||||
|
||||
int up_progmem_write(uint32_t addr, const void *buf, size_t count);
|
||||
|
||||
/* \todo: Define the following functions and their options:
|
||||
* - up_progmem_protect()
|
||||
* - up_progmem_unprotect()
|
||||
*/
|
||||
|
||||
#undef EXTERN
|
||||
#if defined(__cplusplus)
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* __INCLUDE_NUTTX_PROGMEM_H */
|
@ -49,7 +49,7 @@
|
||||
|
||||
#include "os_internal.h"
|
||||
|
||||
#ifdef CONFIG_SCHED_ATEXiT
|
||||
#ifdef CONFIG_SCHED_ATEXIT
|
||||
|
||||
/************************************************************************
|
||||
* Definitions
|
||||
|
@ -89,7 +89,7 @@ uint32_t clock_systimer(void)
|
||||
|
||||
if (g_rtc_enabled)
|
||||
{
|
||||
return up_rtc_getclock();
|
||||
// return up_rtc_getclock();
|
||||
}
|
||||
#endif
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user