From 7515580072188846f6529e2ce2654001edec6ca8 Mon Sep 17 00:00:00 2001 From: patacongo Date: Sun, 4 Oct 2009 17:48:35 +0000 Subject: [PATCH] Started a RIDE project for STM32 git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@2120 42af7a65-404d-4744-a932-0658087f49c3 --- configs/stm3210e-eval/README.txt | 34 ++++++- configs/stm3210e-eval/RIDE/nuttx.ctx | 22 +++++ configs/stm3210e-eval/RIDE/nuttx.dbi | 20 ++++ configs/stm3210e-eval/RIDE/nuttx.elf.ld | 19 ++++ configs/stm3210e-eval/RIDE/nuttx.rapp | 51 ++++++++++ configs/stm3210e-eval/RIDE/nuttx.rdb | Bin 0 -> 63488 bytes configs/stm3210e-eval/RIDE/nuttx.rprj | 4 + configs/stm3210e-eval/ostest/Make.defs | 10 +- configs/stm3210e-eval/ostest/defconfig | 3 +- configs/stm3210e-eval/ostest/ld.script | 6 +- configs/stm3210e-eval/ostest/ld.script.dfu | 110 +++++++++++++++++++++ configs/stm3210e-eval/ostest/setenv.sh | 3 +- 12 files changed, 269 insertions(+), 13 deletions(-) create mode 100755 configs/stm3210e-eval/RIDE/nuttx.ctx create mode 100755 configs/stm3210e-eval/RIDE/nuttx.dbi create mode 100755 configs/stm3210e-eval/RIDE/nuttx.elf.ld create mode 100755 configs/stm3210e-eval/RIDE/nuttx.rapp create mode 100755 configs/stm3210e-eval/RIDE/nuttx.rdb create mode 100755 configs/stm3210e-eval/RIDE/nuttx.rprj create mode 100755 configs/stm3210e-eval/ostest/ld.script.dfu diff --git a/configs/stm3210e-eval/README.txt b/configs/stm3210e-eval/README.txt index d955a7c149..0a2cc0b1a1 100755 --- a/configs/stm3210e-eval/README.txt +++ b/configs/stm3210e-eval/README.txt @@ -7,7 +7,7 @@ Development Environment Either Linux or Cygwin on Windows can be used for the development environment. The source has been built only using the GNU toolchain (see below). Other toolchains will likely cause problems. Testing was performed using the Cygwin - environment because the Raisonance R-Link emulate and some RIDE7 development tools + environment because the Raisonance R-Link emulatator and some RIDE7 development tools were used and those tools works only under Windows. GNU Toolchain Options @@ -78,6 +78,25 @@ GNU Toolchain Options the paths to Cygwin's /bin and /usr/bin directories appear BEFORE the devkitARM path or will get the wrong version of make. +IDEs +^^^^ + + NuttX is built using command-line make. It can be used with an IDE, but some + effort will be required to create the project (There is a simple RIDE project + in the RIDE subdirectory). Here are a few tip before you start that effort: + + 1) Select the toolchain that you will be using in your .config file + 2) Start the NuttX build at least one time from the Cygwin command line + before trying to create your project. This is necessary to create + certain auto-generated files and directories that will be needed. + 3) Set up include pathes: You will need include/, arch/arm/src/stm32, + arch/arm/src/common, arch/arm/src/cortexm3, and sched/. + 4) All assembly files need to have the definition option -D __ASSEMBLY__ + on the command line. + + Startup files will probably cause you some headaches. The NuttX startup file + is arch/arm/src/stm32/stm32_vectors.S + NuttX buildroot Toolchain ^^^^^^^^^^^^^^^^^^^^^^^^^ @@ -118,11 +137,16 @@ NuttX buildroot Toolchain DFU ^^^ - The linker files in these projects assume that you will be loading code - using STMicro built-in USB DFU loader. In this case, the code will not + The linker files in these projects can be configured to indicate that you + will be loading code using STMicro built-in USB DFU loader. You can specify + that by adding: + + CONFIG_STM32_DFU=y + + To you .config file. If CONFIG_STM32_DFU is defined, the code will not be positioned at the beginning of FLASH (0x08000000) but will be offset - to 0x08003000. If you need to change that origin, you will need to - edit the file(s) ld.script for each configuration. + to 0x08003000. If you need to change that origin for some other bootloader, + you will need to edit the file(s) ld.script.dfu for each configuration. The DFU SE PC-based software is available from the STMicro website, http://www.st.com. General usage instructions: diff --git a/configs/stm3210e-eval/RIDE/nuttx.ctx b/configs/stm3210e-eval/RIDE/nuttx.ctx new file mode 100755 index 0000000000..a0085389fa --- /dev/null +++ b/configs/stm3210e-eval/RIDE/nuttx.ctx @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/configs/stm3210e-eval/RIDE/nuttx.dbi b/configs/stm3210e-eval/RIDE/nuttx.dbi new file mode 100755 index 0000000000..76dbcbc6ae --- /dev/null +++ b/configs/stm3210e-eval/RIDE/nuttx.dbi @@ -0,0 +1,20 @@ +[Application] +ApplicationPath=C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\nuttx.elf +CSX=0 +HighBankAddr=400000 +BootMode=0 +Format=ELF +CodeOffset=0x0 +DataOffset=0x0 +LoaderTool=ARM +Target=ARM +DebugTool=RLINK_CORTEX +[Device] +Name=STM32F101VET6 +[ARMSigDrv options] +CXS=0 +[Debug] +Explore=No +Startup=1 +StartupSymb=main +ToolName=RLINK_CORTEX diff --git a/configs/stm3210e-eval/RIDE/nuttx.elf.ld b/configs/stm3210e-eval/RIDE/nuttx.elf.ld new file mode 100755 index 0000000000..cd09bda625 --- /dev/null +++ b/configs/stm3210e-eval/RIDE/nuttx.elf.ld @@ -0,0 +1,19 @@ + +SEARCH_DIR(".") +SEARCH_DIR("C:\Program Files\Raisonance\Ride\Lib\ARM") +STARTUP("C:\Program Files\Raisonance\Ride\lib\ARM\crt0_STM32x_HD.o") +INPUT("C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\stm32_timerisr.o") +INPUT("C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\stm32_vectors.o") +INPUT("C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\stm32_gpio.o") +INPUT("C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\stm32_irq.o") +INPUT("C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\stm32_lowputc.o") +INPUT("C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\stm32_rcc.o") +INPUT("C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\stm32_serial.o") +INPUT("C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\stm32_start.o") +EXTERN( __io_putchar ) +EXTERN( _write ) +INPUT("STM32x_io_putchar_thumb.a") +INPUT("e_stdio_thumb.a") +INPUT("STM32F10x_thumb.lib") +OUTPUT("C:\cygwin\home\Owner\projects\nuttx\nuttx\configs\stm3210e-eval\RIDE\nuttx.elf") +INCLUDE "C:\Program Files\Raisonance\Ride\lib\ARM\STM32F101_32K_32K_FLASH.ld" diff --git a/configs/stm3210e-eval/RIDE/nuttx.rapp b/configs/stm3210e-eval/RIDE/nuttx.rapp new file mode 100755 index 0000000000..e47cb3c8b8 --- /dev/null +++ b/configs/stm3210e-eval/RIDE/nuttx.rapp @@ -0,0 +1,51 @@ + + + + + + + + + + + + + +
+ + +
+
+ + +
+ +
+ +
+ + +
+
+ + +
+ +
+ +
+ + +
+ +
+ +
+ + +
+ +
+
+
+
\ No newline at end of file diff --git a/configs/stm3210e-eval/RIDE/nuttx.rdb b/configs/stm3210e-eval/RIDE/nuttx.rdb new file mode 100755 index 0000000000000000000000000000000000000000..ce32c4f61cafa85d6b11fcd1baa85e1457391ccf GIT binary patch literal 63488 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 + + \ No newline at end of file diff --git a/configs/stm3210e-eval/ostest/Make.defs b/configs/stm3210e-eval/ostest/Make.defs index f0f3e62b72..773b3e71ca 100644 --- a/configs/stm3210e-eval/ostest/Make.defs +++ b/configs/stm3210e-eval/ostest/Make.defs @@ -37,6 +37,12 @@ include ${TOPDIR}/.config # Setup for the selected toolchain +ifeq ($(CONFIG_STM32_DFU)y) + LDSCRIPT = ld.script.dfu +else + LDSCRIPT = ld.script +endif + ifneq ($(CONFIG_STM32_BUILDROOT),y) # Windows-native toolchains ifeq ($(CONFIG_STM32_DEVKITARM),y) @@ -51,7 +57,7 @@ endif ARCHCPUFLAGS = -mcpu=cortex-m3 -mthumb -mfloat-abi=soft ARCHINCLUDES = -I. -isystem "${shell cygpath -w $(TOPDIR)/include}" ARCHXXINCLUDES = -I. -isystem "${shell cygpath -w $(TOPDIR)/include}" -isystem "${shell cygpath -w $(TOPDIR)/include/cxx}" - ARCHSCRIPT = -T "${shell cygpath -w $(TOPDIR)/configs/$(CONFIG_ARCH_BOARD)/ostest/ld.script}" + ARCHSCRIPT = -T "${shell cygpath -w $(TOPDIR)/configs/$(CONFIG_ARCH_BOARD)/ostest/$(LDSCRIPT)}" MAXOPTIMIZATION = -O2 # The NuttX buildroot toolchain else @@ -61,7 +67,7 @@ else ARCHCPUFLAGS = -mtune=cortex-m3 -march=armv7-m -mfloat-abi=soft ARCHINCLUDES = -I. -isystem $(TOPDIR)/include ARCHXXINCLUDES = -I. -isystem $(TOPDIR)/include -isystem $(TOPDIR)/include/cxx - ARCHSCRIPT = -T$(TOPDIR)/configs/$(CONFIG_ARCH_BOARD)/ostest/ld.script + ARCHSCRIPT = -T$(TOPDIR)/configs/$(CONFIG_ARCH_BOARD)/ostest/$(LDSCRIPT) MAXOPTIMIZATION = -Os endif diff --git a/configs/stm3210e-eval/ostest/defconfig b/configs/stm3210e-eval/ostest/defconfig index 0a71545caf..7c5afbdf78 100755 --- a/configs/stm3210e-eval/ostest/defconfig +++ b/configs/stm3210e-eval/ostest/defconfig @@ -87,11 +87,12 @@ CONFIG_ARCH_LEDS=y CONFIG_ARCH_CALIBRATION=n # -# Identify toolchain +# Identify toolchain and liner options CONFIG_STM32_CODESOURCERY=n CONFIG_STM32_DEVKITARM=n CONFIG_STM32_RAISONANCE=n CONFIG_STM32_BUILDROOT=y +CONFIG_STM32_DFU=n # # Individual subsystems can be enabled: diff --git a/configs/stm3210e-eval/ostest/ld.script b/configs/stm3210e-eval/ostest/ld.script index 9ae632a113..41cb641136 100755 --- a/configs/stm3210e-eval/ostest/ld.script +++ b/configs/stm3210e-eval/ostest/ld.script @@ -34,14 +34,12 @@ ****************************************************************************/ /* The STM32F103ZET6 has 512Kb of FLASH beginning at address 0x0800:0000 and - * 64Kb of SRAM beginning at address 0x2000:0000. Here we assume that the - * STM3210E-EVAL's DFU bootloader is being used. In that case, the corrct - * load .text load address is 0x08003000 (leaving 464Kb). + * 64Kb of SRAM beginning at address 0x2000:0000. */ MEMORY { - flash (rx) : ORIGIN = 0x08003000, LENGTH = 464K + flash (rx) : ORIGIN = 0x08000000, LENGTH = 512K sram (rwx) : ORIGIN = 0x20000000, LENGTH = 64K } diff --git a/configs/stm3210e-eval/ostest/ld.script.dfu b/configs/stm3210e-eval/ostest/ld.script.dfu new file mode 100755 index 0000000000..720195871a --- /dev/null +++ b/configs/stm3210e-eval/ostest/ld.script.dfu @@ -0,0 +1,110 @@ +/**************************************************************************** + * configs/stm3210e-eval/ostest/ld.script.dfu + * + * Copyright (C) 2009 Gregory Nutt. All rights reserved. + * Author: Gregory Nutt + * + * 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. + * + ****************************************************************************/ + +/* The STM32F103ZET6 has 512Kb of FLASH beginning at address 0x0800:0000 and + * 64Kb of SRAM beginning at address 0x2000:0000. Here we assume that the + * STM3210E-EVAL's DFU bootloader is being used. In that case, the corrct + * load .text load address is 0x08003000 (leaving 464Kb). + */ + +MEMORY +{ + flash (rx) : ORIGIN = 0x08003000, LENGTH = 464K + sram (rwx) : ORIGIN = 0x20000000, LENGTH = 64K +} + +OUTPUT_ARCH(arm) +ENTRY(_stext) +SECTIONS +{ + .text : { + _stext = ABSOLUTE(.); + *(.vectors) + *(.text .text.*) + *(.fixup) + *(.gnu.warning) + *(.rodata .rodata.*) + *(.gnu.linkonce.t.*) + *(.glue_7) + *(.glue_7t) + *(.got) + *(.gcc_except_table) + *(.gnu.linkonce.r.*) + _etext = ABSOLUTE(.); + } > flash + + _eronly = ABSOLUTE(.); /* See below */ + + /* The STM32F103Z has 64Kb of SRAM beginning at the following address */ + + .data : { + _sdata = ABSOLUTE(.); + *(.data .data.*) + *(.gnu.linkonce.d.*) + CONSTRUCTORS + _edata = ABSOLUTE(.); + } > sram AT > flash + + .ARM.extab : { + *(.ARM.extab*) + } >sram + + .ARM.exidx : { + __exidx_start = ABSOLUTE(.); + *(.ARM.exidx*) + __exidx_end = ABSOLUTE(.); + } >sram + + .bss : { /* BSS */ + _sbss = ABSOLUTE(.); + *(.bss .bss.*) + *(.gnu.linkonce.b.*) + *(COMMON) + _ebss = ABSOLUTE(.); + } > sram + /* Stabs debugging sections. */ + .stab 0 : { *(.stab) } + .stabstr 0 : { *(.stabstr) } + .stab.excl 0 : { *(.stab.excl) } + .stab.exclstr 0 : { *(.stab.exclstr) } + .stab.index 0 : { *(.stab.index) } + .stab.indexstr 0 : { *(.stab.indexstr) } + .comment 0 : { *(.comment) } + .debug_abbrev 0 : { *(.debug_abbrev) } + .debug_info 0 : { *(.debug_info) } + .debug_line 0 : { *(.debug_line) } + .debug_pubnames 0 : { *(.debug_pubnames) } + .debug_aranges 0 : { *(.debug_aranges) } +} diff --git a/configs/stm3210e-eval/ostest/setenv.sh b/configs/stm3210e-eval/ostest/setenv.sh index e017111258..fcb428c2ff 100755 --- a/configs/stm3210e-eval/ostest/setenv.sh +++ b/configs/stm3210e-eval/ostest/setenv.sh @@ -40,7 +40,8 @@ fi if [ -z "${PATH_ORIG}" ]; then export PATH_ORIG="${PATH}"; fi WD=`pwd` +export RIDE_BIN="/cygdrive/c/Program Files/Raisonance/Ride/arm-gcc/bin" export BUILDROOT_BIN="${WD}/../buildroot/build_arm_nofpu/staging_dir/bin" -export PATH="${BUILDROOT_BIN}:/sbin:/usr/sbin:${PATH_ORIG}" +export PATH="${BUILDROOT_BIN}:${RIDE_BIN}:/sbin:/usr/sbin:${PATH_ORIG}" echo "PATH : ${PATH}"