STM3240G-EVAL: Add kernel build mode support and an NxWM kernel mode configuration
This commit is contained in:
parent
d487d27b41
commit
a463c71ac3
@ -242,7 +242,7 @@ NXFLAT Toolchain
|
|||||||
tools -- just the NXFLAT tools. The buildroot with the NXFLAT tools can
|
tools -- just the NXFLAT tools. The buildroot with the NXFLAT tools can
|
||||||
be downloaded from the NuttX SourceForge download site
|
be downloaded from the NuttX SourceForge download site
|
||||||
(https://sourceforge.net/projects/nuttx/files/).
|
(https://sourceforge.net/projects/nuttx/files/).
|
||||||
|
|
||||||
This GNU toolchain builds and executes in the Linux or Cygwin environment.
|
This GNU toolchain builds and executes in the Linux or Cygwin environment.
|
||||||
|
|
||||||
1. You must have already configured Nuttx in <some-dir>/nuttx.
|
1. You must have already configured Nuttx in <some-dir>/nuttx.
|
||||||
@ -887,14 +887,14 @@ STM3240G-EVAL-specific Configuration Options
|
|||||||
STM32 USB OTG FS Host Driver Support
|
STM32 USB OTG FS Host Driver Support
|
||||||
|
|
||||||
Pre-requisites
|
Pre-requisites
|
||||||
|
|
||||||
CONFIG_USBHOST - Enable USB host support
|
CONFIG_USBHOST - Enable USB host support
|
||||||
CONFIG_STM32_OTGFS - Enable the STM32 USB OTG FS block
|
CONFIG_STM32_OTGFS - Enable the STM32 USB OTG FS block
|
||||||
CONFIG_STM32_SYSCFG - Needed
|
CONFIG_STM32_SYSCFG - Needed
|
||||||
CONFIG_SCHED_WORKQUEUE - Worker thread support is required
|
CONFIG_SCHED_WORKQUEUE - Worker thread support is required
|
||||||
|
|
||||||
Options:
|
Options:
|
||||||
|
|
||||||
CONFIG_STM32_OTGFS_RXFIFO_SIZE - Size of the RX FIFO in 32-bit words.
|
CONFIG_STM32_OTGFS_RXFIFO_SIZE - Size of the RX FIFO in 32-bit words.
|
||||||
Default 128 (512 bytes)
|
Default 128 (512 bytes)
|
||||||
CONFIG_STM32_OTGFS_NPTXFIFO_SIZE - Size of the non-periodic Tx FIFO
|
CONFIG_STM32_OTGFS_NPTXFIFO_SIZE - Size of the non-periodic Tx FIFO
|
||||||
@ -955,6 +955,99 @@ Where <subdir> is one of the following:
|
|||||||
control the configuration. See the section entitled "NuttX Configuration
|
control the configuration. See the section entitled "NuttX Configuration
|
||||||
Tool" in the top-level README.txt file.
|
Tool" in the top-level README.txt file.
|
||||||
|
|
||||||
|
knxwm:
|
||||||
|
-----
|
||||||
|
[WARNING: This is a work in progress].
|
||||||
|
|
||||||
|
This is identical to the nxwm configuration below except that NuttX
|
||||||
|
is built as a kernel-mode, monolithic module and the user applications
|
||||||
|
are built separately. Is is recommended to use a special make command;
|
||||||
|
not just 'make' but make with the following two arguments:
|
||||||
|
|
||||||
|
make pass1 pass2
|
||||||
|
|
||||||
|
In the normal case (just 'make'), make will attempt to build both user-
|
||||||
|
and kernel-mode blobs more or less interleaved. This actual works!
|
||||||
|
However, for me it is very confusing so I prefer the above make command:
|
||||||
|
Make the user-space binaries first (pass1), then make the kernel-space
|
||||||
|
binaries (pass2)
|
||||||
|
|
||||||
|
NOTES:
|
||||||
|
|
||||||
|
1. This configuration uses the mconf-based configuration tool. To
|
||||||
|
change this configuration using that tool, you should:
|
||||||
|
|
||||||
|
a. Build and install the kconfig-mconf tool. See nuttx/README.txt
|
||||||
|
and misc/tools/
|
||||||
|
|
||||||
|
b. Execute 'make menuconfig' in nuttx/ in order to start the
|
||||||
|
reconfiguration process.
|
||||||
|
|
||||||
|
2. This is the default platform/toolchain in the configuration:
|
||||||
|
|
||||||
|
CONFIG_HOST_WINDOWS=y : Windows
|
||||||
|
CONFIG_WINDOWS_CYGWIN=y : Cygwin environment on Windows
|
||||||
|
CONFIG_ARMV7M_TOOLCHAIN_CODESOURCERYW=y : CodeSourcery under Windows
|
||||||
|
|
||||||
|
This is easily changed by modifying the configuration.
|
||||||
|
|
||||||
|
3. At the end of the build, there will be several files in the top-level
|
||||||
|
NuttX build directory:
|
||||||
|
|
||||||
|
PASS1:
|
||||||
|
nuttx_user.elf - The pass1 user-space ELF file
|
||||||
|
nuttx_user.hex - The pass1 Intel HEX format file (selected in defconfig)
|
||||||
|
User.map - Symbols in the user-space ELF file
|
||||||
|
|
||||||
|
PASS2:
|
||||||
|
nuttx - The pass2 kernel-space ELF file
|
||||||
|
nuttx.hex - The pass2 Intel HEX file (selected in defconfig)
|
||||||
|
System.map - Symbols in the kernel-space ELF file
|
||||||
|
|
||||||
|
4. Combining .hex files. If you plan to use the STM32 ST-Link Utility to
|
||||||
|
load the .hex files into FLASH, then you need to combine the two hex
|
||||||
|
files into a single .hex file. Here is how you can do that.
|
||||||
|
|
||||||
|
a. The 'tail' of the nuttx.hex file should look something like this
|
||||||
|
(with my comments added):
|
||||||
|
|
||||||
|
$ tail nuttx.hex
|
||||||
|
# 00, data records
|
||||||
|
...
|
||||||
|
:10 9DC0 00 01000000000800006400020100001F0004
|
||||||
|
:10 9DD0 00 3B005A0078009700B500D400F300110151
|
||||||
|
:08 9DE0 00 30014E016D0100008D
|
||||||
|
# 05, Start Linear Address Record
|
||||||
|
:04 0000 05 0800 0419 D2
|
||||||
|
# 01, End Of File record
|
||||||
|
:00 0000 01 FF
|
||||||
|
|
||||||
|
Use an editor such as vi to remove the 05 and 01 records.
|
||||||
|
|
||||||
|
b. The 'head' of the nuttx_user.hex file should look something like
|
||||||
|
this (again with my comments added):
|
||||||
|
|
||||||
|
$ head nuttx_user.hex
|
||||||
|
# 04, Extended Linear Address Record
|
||||||
|
:02 0000 04 0801 F1
|
||||||
|
# 00, data records
|
||||||
|
:10 8000 00 BD89 01084C800108C8110208D01102087E
|
||||||
|
:10 8010 00 0010 00201C1000201C1000203C16002026
|
||||||
|
:10 8020 00 4D80 01085D80010869800108ED83010829
|
||||||
|
...
|
||||||
|
|
||||||
|
Nothing needs to be done here. The nuttx_user.hex file should
|
||||||
|
be fine.
|
||||||
|
|
||||||
|
c. Combine the edited nuttx.hex and un-edited nuttx_user.hex
|
||||||
|
file to produce a single combined hex file:
|
||||||
|
|
||||||
|
$ cat nuttx.hex nuttx_user.hex >combined.hex
|
||||||
|
|
||||||
|
Then use the combined.hex file with the STM32 ST-Link tool. If
|
||||||
|
you do this a lot, you will probably want to invest a little time
|
||||||
|
to develop a tool to automate these steps.
|
||||||
|
|
||||||
nettest:
|
nettest:
|
||||||
-------
|
-------
|
||||||
|
|
||||||
@ -1097,7 +1190,7 @@ Where <subdir> is one of the following:
|
|||||||
CONFIG_MM_REGIONS=3 : When FSMC is enabled, so is the on-board SRAM memory region
|
CONFIG_MM_REGIONS=3 : When FSMC is enabled, so is the on-board SRAM memory region
|
||||||
|
|
||||||
8. USB OTG FS Device or Host Support
|
8. USB OTG FS Device or Host Support
|
||||||
|
|
||||||
CONFIG_USBDEV - Enable USB device support, OR
|
CONFIG_USBDEV - Enable USB device support, OR
|
||||||
CONFIG_USBHOST - Enable USB host support
|
CONFIG_USBHOST - Enable USB host support
|
||||||
CONFIG_STM32_OTGFS - Enable the STM32 USB OTG FS block
|
CONFIG_STM32_OTGFS - Enable the STM32 USB OTG FS block
|
||||||
@ -1168,7 +1261,7 @@ Where <subdir> is one of the following:
|
|||||||
|
|
||||||
-CONFIG_STM32_RNG=y
|
-CONFIG_STM32_RNG=y
|
||||||
+CONFIG_STM32_RNG=n
|
+CONFIG_STM32_RNG=n
|
||||||
|
|
||||||
-CONFIG_DEV_RANDOM=y
|
-CONFIG_DEV_RANDOM=y
|
||||||
+CONFIG_DEV_RANDOM=n
|
+CONFIG_DEV_RANDOM=n
|
||||||
|
|
||||||
|
2
configs/stm3240g-eval/kernel/.gitignore
vendored
Normal file
2
configs/stm3240g-eval/kernel/.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
/nuttx_user.elf
|
||||||
|
|
122
configs/stm3240g-eval/kernel/Makefile
Normal file
122
configs/stm3240g-eval/kernel/Makefile
Normal file
@ -0,0 +1,122 @@
|
|||||||
|
############################################################################
|
||||||
|
# configs/stm3240g-eval/kernel/Makefile
|
||||||
|
#
|
||||||
|
# Copyright (C) 2013 Gregory Nutt. All rights reserved.
|
||||||
|
# Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
#
|
||||||
|
############################################################################
|
||||||
|
|
||||||
|
-include $(TOPDIR)/Make.defs
|
||||||
|
|
||||||
|
# This is the directory for the board-specific header files
|
||||||
|
|
||||||
|
BOARD_INCLUDE = $(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)include
|
||||||
|
|
||||||
|
# The entry point name (if none is provided in the .config file)
|
||||||
|
|
||||||
|
CONFIG_USER_ENTRYPOINT ?= user_start
|
||||||
|
ENTRYPT = $(patsubst "%",%,$(CONFIG_USER_ENTRYPOINT))
|
||||||
|
|
||||||
|
# Get the paths to the libraries and the links script path in format that
|
||||||
|
# is appropriate for the host OS
|
||||||
|
|
||||||
|
ifeq ($(WINTOOL),y)
|
||||||
|
# Windows-native toolchains
|
||||||
|
USER_LIBPATHS = ${shell for path in $(USERLIBS); do dir=`dirname $(TOPDIR)$(DELIM)$$path`;echo "-L\"`cygpath -w $$dir`\"";done}
|
||||||
|
USER_LDSCRIPT = -T "${shell cygpath -w $(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)memory.ld}"
|
||||||
|
USER_LDSCRIPT += -T "${shell cygpath -w $(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)user-space.ld}"
|
||||||
|
USER_HEXFILE += "${shell cygpath -w $(TOPDIR)$(DELIM)nuttx_user.hex}"
|
||||||
|
USER_SRECFILE += "${shell cygpath -w $(TOPDIR)$(DELIM)nuttx_user.srec}"
|
||||||
|
USER_BINFILE += "${shell cygpath -w $(TOPDIR)$(DELIM)nuttx_user.bin}"
|
||||||
|
else
|
||||||
|
# Linux/Cygwin-native toolchain
|
||||||
|
USER_LIBPATHS = $(addprefix -L$(TOPDIR)$(DELIM),$(dir $(USERLIBS)))
|
||||||
|
USER_LDSCRIPT = -T$(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)memory.ld
|
||||||
|
USER_LDSCRIPT += -T$(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)user-space.ld
|
||||||
|
USER_HEXFILE += "$(TOPDIR)$(DELIM)nuttx_user.hex"
|
||||||
|
USER_SRECFILE += "$(TOPDIR)$(DELIM)nuttx_user.srec"
|
||||||
|
USER_BINFILE += "$(TOPDIR)$(DELIM)nuttx_user.bin"
|
||||||
|
endif
|
||||||
|
|
||||||
|
USER_LDFLAGS = --undefined=$(ENTRYPT) --entry=$(ENTRYPT) $(USER_LDSCRIPT)
|
||||||
|
USER_LDLIBS = $(patsubst lib%,-l%,$(basename $(notdir $(USERLIBS))))
|
||||||
|
USER_LIBGCC = "${shell $(CC) -print-libgcc-file-name}"
|
||||||
|
|
||||||
|
# Source files
|
||||||
|
|
||||||
|
CSRCS = up_userspace.c
|
||||||
|
COBJS = $(CSRCS:.c=$(OBJEXT))
|
||||||
|
OBJS = $(COBJS)
|
||||||
|
|
||||||
|
# Targets:
|
||||||
|
|
||||||
|
all: $(TOPDIR)$(DELIM)nuttx_user.elf $(TOPDIR)$(DELIM)User.map
|
||||||
|
.PHONY: nuttx_user.elf depend clean distclean
|
||||||
|
|
||||||
|
$(COBJS): %$(OBJEXT): %.c
|
||||||
|
$(call COMPILE, $<, $@)
|
||||||
|
|
||||||
|
# Create the nuttx_user.elf file containing all of the user-mode code
|
||||||
|
|
||||||
|
nuttx_user.elf: $(OBJS)
|
||||||
|
$(Q) $(LD) -o $@ $(USER_LDFLAGS) $(USER_LIBPATHS) $(OBJS) --start-group $(USER_LDLIBS) --end-group $(USER_LIBGCC)
|
||||||
|
|
||||||
|
$(TOPDIR)$(DELIM)nuttx_user.elf: nuttx_user.elf
|
||||||
|
@echo "LD: nuttx_user.elf"
|
||||||
|
$(Q) cp -a nuttx_user.elf $(TOPDIR)$(DELIM)nuttx_user.elf
|
||||||
|
ifeq ($(CONFIG_INTELHEX_BINARY),y)
|
||||||
|
@echo "CP: nuttx_user.hex"
|
||||||
|
$(Q) $(OBJCOPY) $(OBJCOPYARGS) -O ihex nuttx_user.elf $(USER_HEXFILE)
|
||||||
|
endif
|
||||||
|
ifeq ($(CONFIG_MOTOROLA_SREC),y)
|
||||||
|
@echo "CP: nuttx_user.srec"
|
||||||
|
$(Q) $(OBJCOPY) $(OBJCOPYARGS) -O srec nuttx_user.elf $(USER_SRECFILE)
|
||||||
|
endif
|
||||||
|
ifeq ($(CONFIG_RAW_BINARY),y)
|
||||||
|
@echo "CP: nuttx_user.bin"
|
||||||
|
$(Q) $(OBJCOPY) $(OBJCOPYARGS) -O binary nuttx_user.elf $(USER_BINFILE)
|
||||||
|
endif
|
||||||
|
|
||||||
|
$(TOPDIR)$(DELIM)User.map: nuttx_user.elf
|
||||||
|
@echo "MK: User.map"
|
||||||
|
$(Q) $(NM) nuttx_user.elf >$(TOPDIR)$(DELIM)User.map
|
||||||
|
$(Q) $(CROSSDEV)size nuttx_user.elf
|
||||||
|
|
||||||
|
.depend:
|
||||||
|
|
||||||
|
depend: .depend
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(call DELFILE, nuttx_user.elf)
|
||||||
|
$(call DELFILE, "$(TOPDIR)$(DELIM)nuttx_user.*")
|
||||||
|
$(call DELFILE, "$(TOPDIR)$(DELIM)User.map")
|
||||||
|
$(call CLEAN)
|
||||||
|
|
||||||
|
distclean: clean
|
142
configs/stm3240g-eval/kernel/up_userspace.c
Normal file
142
configs/stm3240g-eval/kernel/up_userspace.c
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* configs/stm3240g-eval/kernel/up_userspace.c
|
||||||
|
*
|
||||||
|
* Copyright (C) 2013 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#include <nuttx/userspace.h>
|
||||||
|
#include <nuttx/wqueue.h>
|
||||||
|
#include <nuttx/mm.h>
|
||||||
|
|
||||||
|
#if defined(CONFIG_NUTTX_KERNEL) && !defined(__KERNEL__)
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Pre-processor Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
/* Configuration ************************************************************/
|
||||||
|
|
||||||
|
#ifndef CONFIG_NUTTX_USERSPACE
|
||||||
|
# error "CONFIG_NUTTX_USERSPACE not defined"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_NUTTX_USERSPACE != 0x08020000
|
||||||
|
# error "CONFIG_NUTTX_USERSPACE must be 0x08020000 to match memory.ld"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Data
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/* These 'addresses' of these values are setup by the linker script. They are
|
||||||
|
* not actual uint32_t storage locations! They are only used meaningfully in the
|
||||||
|
* following way:
|
||||||
|
*
|
||||||
|
* - The linker script defines, for example, the symbol_sdata.
|
||||||
|
* - The declareion extern uint32_t _sdata; makes C happy. C will believe
|
||||||
|
* that the value _sdata is the address of a uint32_t variable _data (it is
|
||||||
|
* not!).
|
||||||
|
* - We can recoved the linker value then by simply taking the address of
|
||||||
|
* of _data. like: uint32_t *pdata = &_sdata;
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern uint32_t _stext; /* Start of .text */
|
||||||
|
extern uint32_t _etext; /* End_1 of .text + .rodata */
|
||||||
|
extern const uint32_t _eronly; /* End+1 of read only section (.text + .rodata) */
|
||||||
|
extern uint32_t _sdata; /* Start of .data */
|
||||||
|
extern uint32_t _edata; /* End+1 of .data */
|
||||||
|
extern uint32_t _sbss; /* Start of .bss */
|
||||||
|
extern uint32_t _ebss; /* End+1 of .bss */
|
||||||
|
|
||||||
|
/* This is the user space entry point */
|
||||||
|
|
||||||
|
int CONFIG_USER_ENTRYPOINT(int argc, char *argv[]);
|
||||||
|
|
||||||
|
const struct userspace_s userspace __attribute__ ((section (".userspace"))) =
|
||||||
|
{
|
||||||
|
/* General memory map */
|
||||||
|
|
||||||
|
.us_entrypoint = (main_t)CONFIG_USER_ENTRYPOINT,
|
||||||
|
.us_textstart = (uintptr_t)&_stext,
|
||||||
|
.us_textend = (uintptr_t)&_etext,
|
||||||
|
.us_datasource = (uintptr_t)&_eronly,
|
||||||
|
.us_datastart = (uintptr_t)&_sdata,
|
||||||
|
.us_dataend = (uintptr_t)&_edata,
|
||||||
|
.us_bssstart = (uintptr_t)&_sbss,
|
||||||
|
.us_bssend = (uintptr_t)&_ebss,
|
||||||
|
|
||||||
|
/* Task/thread startup routines */
|
||||||
|
|
||||||
|
.task_startup = task_startup,
|
||||||
|
#ifndef CONFIG_DISABLE_PTHREAD
|
||||||
|
.pthread_startup = pthread_startup,
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Signal handler trampoline */
|
||||||
|
|
||||||
|
#ifndef CONFIG_DISABLE_SIGNALS
|
||||||
|
.signal_handler = up_signal_handler,
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Memory manager entry points (declared in include/nuttx/mm.h) */
|
||||||
|
|
||||||
|
.mm_initialize = umm_initialize,
|
||||||
|
.mm_addregion = umm_addregion,
|
||||||
|
.mm_trysemaphore = umm_trysemaphore,
|
||||||
|
.mm_givesemaphore = umm_givesemaphore,
|
||||||
|
|
||||||
|
/* Memory manager entry points (declared in include/stdlib.h) */
|
||||||
|
|
||||||
|
.mm_malloc = malloc,
|
||||||
|
.mm_realloc = realloc,
|
||||||
|
.mm_zalloc = zalloc,
|
||||||
|
.mm_free = free,
|
||||||
|
|
||||||
|
/* User-space work queue support (declared in include/nuttx/wqueue.h) */
|
||||||
|
|
||||||
|
#if defined(CONFIG_SCHED_WORKQUEUE) && defined(CONFIG_SCHED_USRWORK)
|
||||||
|
.work_usrstart = work_usrstart,
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#endif /* CONFIG_NUTTX_KERNEL && !__KERNEL__ */
|
113
configs/stm3240g-eval/knxwm/Make.defs
Normal file
113
configs/stm3240g-eval/knxwm/Make.defs
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
############################################################################
|
||||||
|
# configs/stm3240g-eval/knxwm/Make.defs
|
||||||
|
#
|
||||||
|
# Copyright (C) 2013 Gregory Nutt. All rights reserved.
|
||||||
|
# Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
#
|
||||||
|
############################################################################
|
||||||
|
|
||||||
|
include ${TOPDIR}/.config
|
||||||
|
include ${TOPDIR}/tools/Config.mk
|
||||||
|
include ${TOPDIR}/arch/arm/src/armv7-m/Toolchain.defs
|
||||||
|
|
||||||
|
ifeq ($(WINTOOL),y)
|
||||||
|
# Windows-native toolchains
|
||||||
|
DIRLINK = $(TOPDIR)/tools/copydir.sh
|
||||||
|
DIRUNLINK = $(TOPDIR)/tools/unlink.sh
|
||||||
|
MKDEP = $(TOPDIR)/tools/mknulldeps.sh
|
||||||
|
ARCHINCLUDES = -I. -isystem "${shell cygpath -w $(TOPDIR)$(DELIM)include}"
|
||||||
|
ARCHXXINCLUDES = -I. -isystem "${shell cygpath -w $(TOPDIR)$(DELIM)include}" -isystem "${shell cygpath -w $(TOPDIR)$(DELIM)include$(DELIM)cxx}"
|
||||||
|
ARCHSCRIPT = -T "${shell cygpath -w $(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)memory.ld}"
|
||||||
|
ARCHSCRIPT += -T "${shell cygpath -w $(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)kernel-space.ld}"
|
||||||
|
MAXOPTIMIZATION = -O2
|
||||||
|
else
|
||||||
|
# Linux/Cygwin-native toolchain
|
||||||
|
MKDEP = $(TOPDIR)/tools/mkdeps.sh
|
||||||
|
ARCHINCLUDES = -I. -isystem $(TOPDIR)$(DELIM)include
|
||||||
|
ARCHXXINCLUDES = -I. -isystem $(TOPDIR)$(DELIM)include -isystem $(TOPDIR)$(DELIM)include$(DELIM)cxx
|
||||||
|
ARCHSCRIPT = -T$(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)memory.ld
|
||||||
|
ARCHSCRIPT += -T$(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)kernel-space.ld
|
||||||
|
endif
|
||||||
|
|
||||||
|
CC = $(CROSSDEV)gcc
|
||||||
|
CXX = $(CROSSDEV)g++
|
||||||
|
CPP = $(CROSSDEV)gcc -E
|
||||||
|
LD = $(CROSSDEV)ld
|
||||||
|
AR = $(ARCROSSDEV)ar rcs
|
||||||
|
NM = $(ARCROSSDEV)nm
|
||||||
|
OBJCOPY = $(CROSSDEV)objcopy
|
||||||
|
OBJDUMP = $(CROSSDEV)objdump
|
||||||
|
|
||||||
|
ARCHCCVERSION = ${shell $(CC) -v 2>&1 | sed -n '/^gcc version/p' | sed -e 's/^gcc version \([0-9\.]\)/\1/g' -e 's/[-\ ].*//g' -e '1q'}
|
||||||
|
ARCHCCMAJOR = ${shell echo $(ARCHCCVERSION) | cut -d'.' -f1}
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_DEBUG_SYMBOLS),y)
|
||||||
|
ARCHOPTIMIZATION = -g
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq ($(CONFIG_DEBUG_NOOPT),y)
|
||||||
|
ARCHOPTIMIZATION += $(MAXOPTIMIZATION) -fno-strict-aliasing -fno-strength-reduce -fomit-frame-pointer
|
||||||
|
endif
|
||||||
|
|
||||||
|
ARCHCFLAGS = -fno-builtin
|
||||||
|
ARCHCXXFLAGS = -fno-builtin -fno-exceptions -fno-rtti
|
||||||
|
ARCHWARNINGS = -Wall -Wstrict-prototypes -Wshadow
|
||||||
|
ARCHWARNINGSXX = -Wall -Wshadow
|
||||||
|
ARCHDEFINES =
|
||||||
|
ARCHPICFLAGS = -fpic -msingle-pic-base -mpic-register=r10
|
||||||
|
|
||||||
|
CFLAGS = $(ARCHCFLAGS) $(ARCHWARNINGS) $(ARCHOPTIMIZATION) $(ARCHCPUFLAGS) $(ARCHINCLUDES) $(ARCHDEFINES) $(EXTRADEFINES) -pipe
|
||||||
|
CPICFLAGS = $(ARCHPICFLAGS) $(CFLAGS)
|
||||||
|
CXXFLAGS = $(ARCHCXXFLAGS) $(ARCHWARNINGSXX) $(ARCHOPTIMIZATION) $(ARCHCPUFLAGS) $(ARCHXXINCLUDES) $(ARCHDEFINES) $(EXTRADEFINES) -pipe
|
||||||
|
CXXPICFLAGS = $(ARCHPICFLAGS) $(CXXFLAGS)
|
||||||
|
CPPFLAGS = $(ARCHINCLUDES) $(ARCHDEFINES) $(EXTRADEFINES)
|
||||||
|
AFLAGS = $(CFLAGS) -D__ASSEMBLY__
|
||||||
|
|
||||||
|
NXFLATLDFLAGS1 = -r -d -warn-common
|
||||||
|
NXFLATLDFLAGS2 = $(NXFLATLDFLAGS1) -T$(TOPDIR)/binfmt/libnxflat/gnu-nxflat-pcrel.ld -no-check-sections
|
||||||
|
LDNXFLATFLAGS = -e main -s 2048
|
||||||
|
|
||||||
|
OBJEXT = .o
|
||||||
|
LIBEXT = .a
|
||||||
|
EXEEXT =
|
||||||
|
|
||||||
|
ifneq ($(CROSSDEV),arm-nuttx-elf-)
|
||||||
|
LDFLAGS += -nostartfiles -nodefaultlibs
|
||||||
|
endif
|
||||||
|
ifeq ($(CONFIG_DEBUG_SYMBOLS),y)
|
||||||
|
LDFLAGS += -g
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
|
HOSTCC = gcc
|
||||||
|
HOSTINCLUDES = -I.
|
||||||
|
HOSTCFLAGS = -Wall -Wstrict-prototypes -Wshadow -g -pipe
|
||||||
|
HOSTLDFLAGS =
|
||||||
|
|
1322
configs/stm3240g-eval/knxwm/defconfig
Normal file
1322
configs/stm3240g-eval/knxwm/defconfig
Normal file
File diff suppressed because it is too large
Load Diff
52
configs/stm3240g-eval/nxwm/appconfig → configs/stm3240g-eval/knxwm/setenv.sh
Normal file → Executable file
52
configs/stm3240g-eval/nxwm/appconfig → configs/stm3240g-eval/knxwm/setenv.sh
Normal file → Executable file
@ -1,7 +1,7 @@
|
|||||||
############################################################################
|
#!/bin/bash
|
||||||
# configs/stm3240g-eval/nxwm/appconfig
|
# configs/stm3240g-eval/knxwm/setenv.sh
|
||||||
#
|
#
|
||||||
# Copyright (C) 2012 Gregory Nutt. All rights reserved.
|
# Copyright (C) 2013 Gregory Nutt. All rights reserved.
|
||||||
# Author: Gregory Nutt <gnutt@nuttx.org>
|
# Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
#
|
#
|
||||||
# Redistribution and use in source and binary forms, with or without
|
# Redistribution and use in source and binary forms, with or without
|
||||||
@ -31,23 +31,37 @@
|
|||||||
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
# POSSIBILITY OF SUCH DAMAGE.
|
# POSSIBILITY OF SUCH DAMAGE.
|
||||||
#
|
#
|
||||||
############################################################################
|
|
||||||
|
|
||||||
# The NSH Library -- NOTE: The NxWM unit test must be installed at
|
if [ "$_" = "$0" ] ; then
|
||||||
# apps/external in order to build this example. See
|
echo "You must source this script, not run it!" 1>&2
|
||||||
# NxWidgets/UnitTests/README.txt for additional information
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
CONFIGURED_APPS += system/readline
|
WD=`pwd`
|
||||||
CONFIGURED_APPS += nshlib
|
if [ ! -x "setenv.sh" ]; then
|
||||||
|
echo "This script must be executed from the top-level NuttX build directory"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
# Networking libraries.
|
if [ -z "${PATH_ORIG}" ]; then
|
||||||
|
export PATH_ORIG="${PATH}"
|
||||||
|
fi
|
||||||
|
|
||||||
ifeq ($(CONFIG_NET),y)
|
# This is the Cygwin path to the location where I installed the RIDE
|
||||||
CONFIGURED_APPS += netutils/uiplib
|
# toolchain under windows. You will also have to edit this if you install
|
||||||
CONFIGURED_APPS += netutils/resolv
|
# the RIDE toolchain in any other location
|
||||||
CONFIGURED_APPS += netutils/webclient
|
#export TOOLCHAIN_BIN="/cygdrive/c/Program Files (x86)/Raisonance/Ride/arm-gcc/bin"
|
||||||
CONFIGURED_APPS += netutils/tftpc
|
|
||||||
ifeq ($(CONFIG_NSH_TELNET),y)
|
# This is the Cygwin path to the location where I installed the CodeSourcery
|
||||||
CONFIGURED_APPS += netutils/telnetd
|
# toolchain under windows. You will also have to edit this if you install
|
||||||
endif
|
# the CodeSourcery toolchain in any other location
|
||||||
endif
|
export TOOLCHAIN_BIN="/cygdrive/c/Program Files (x86)/CodeSourcery/Sourcery G++ Lite/bin"
|
||||||
|
|
||||||
|
# This is the Cygwin path to the location where I build the buildroot
|
||||||
|
# toolchain.
|
||||||
|
#export TOOLCHAIN_BIN="${WD}/../misc/buildroot/build_arm_nofpu/staging_dir/bin"
|
||||||
|
|
||||||
|
# Add the path to the toolchain to the PATH varialble
|
||||||
|
export PATH="${TOOLCHAIN_BIN}:/sbin:/usr/sbin:${PATH_ORIG}"
|
||||||
|
|
||||||
|
echo "PATH : ${PATH}"
|
File diff suppressed because it is too large
Load Diff
109
configs/stm3240g-eval/scripts/kernel-space.ld
Executable file
109
configs/stm3240g-eval/scripts/kernel-space.ld
Executable file
@ -0,0 +1,109 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* configs/stm3240g-eval/scripts/kernel-space.ld
|
||||||
|
*
|
||||||
|
* Copyright (C) 2013 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/* NOTE: This depends on the memory.ld script having been included prior to
|
||||||
|
* this script.
|
||||||
|
*/
|
||||||
|
|
||||||
|
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(.);
|
||||||
|
} > kflash
|
||||||
|
|
||||||
|
.init_section : {
|
||||||
|
_sinit = ABSOLUTE(.);
|
||||||
|
*(.init_array .init_array.*)
|
||||||
|
_einit = ABSOLUTE(.);
|
||||||
|
} > kflash
|
||||||
|
|
||||||
|
.ARM.extab : {
|
||||||
|
*(.ARM.extab*)
|
||||||
|
} > kflash
|
||||||
|
|
||||||
|
__exidx_start = ABSOLUTE(.);
|
||||||
|
.ARM.exidx : {
|
||||||
|
*(.ARM.exidx*)
|
||||||
|
} > kflash
|
||||||
|
|
||||||
|
__exidx_end = ABSOLUTE(.);
|
||||||
|
|
||||||
|
_eronly = ABSOLUTE(.);
|
||||||
|
|
||||||
|
.data : {
|
||||||
|
_sdata = ABSOLUTE(.);
|
||||||
|
*(.data .data.*)
|
||||||
|
*(.gnu.linkonce.d.*)
|
||||||
|
CONSTRUCTORS
|
||||||
|
_edata = ABSOLUTE(.);
|
||||||
|
} > ksram AT > kflash
|
||||||
|
|
||||||
|
.bss : {
|
||||||
|
_sbss = ABSOLUTE(.);
|
||||||
|
*(.bss .bss.*)
|
||||||
|
*(.gnu.linkonce.b.*)
|
||||||
|
*(COMMON)
|
||||||
|
_ebss = ABSOLUTE(.);
|
||||||
|
} > ksram
|
||||||
|
|
||||||
|
/* 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) }
|
||||||
|
}
|
@ -33,7 +33,7 @@
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
/* The STM32F103ZET6 has 1024Kb of FLASH beginning at address 0x0800:0000 and
|
/* The STM32F407VG has 1024Kb of FLASH beginning at address 0x0800:0000 and
|
||||||
* 192Kb of SRAM. SRAM is split up into three blocks:
|
* 192Kb of SRAM. SRAM is split up into three blocks:
|
||||||
*
|
*
|
||||||
* 1) 112Kb of SRAM beginning at address 0x2000:0000
|
* 1) 112Kb of SRAM beginning at address 0x2000:0000
|
||||||
|
100
configs/stm3240g-eval/scripts/memory.ld
Normal file
100
configs/stm3240g-eval/scripts/memory.ld
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* configs/stm3240-eval/scripts/memory.ld
|
||||||
|
*
|
||||||
|
* Copyright (C) 2013 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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 STM32F407VG has 1024Kb of FLASH beginning at address 0x0800:0000 and
|
||||||
|
* 192Kb of SRAM. SRAM is split up into three blocks:
|
||||||
|
*
|
||||||
|
* 1) 112KB of SRAM beginning at address 0x2000:0000
|
||||||
|
* 2) 16KB of SRAM beginning at address 0x2001:c000
|
||||||
|
* 3) 64KB of CCM SRAM beginning at address 0x1000:0000
|
||||||
|
*
|
||||||
|
* When booting from FLASH, FLASH memory is aliased to address 0x0000:0000
|
||||||
|
* where the code expects to begin execution by jumping to the entry point in
|
||||||
|
* the 0x0800:0000 address range.
|
||||||
|
*
|
||||||
|
* For MPU support, the kernel-mode NuttX section is assumed to be 128Kb of
|
||||||
|
* FLASH and 4Kb of SRAM. That is an excessive amount for the kernel which
|
||||||
|
* should fit into 64KB and, of course, can be optimized as needed (See
|
||||||
|
* also configs/stm3240g-eval/scripts/kernel-space.ld). Allowing the
|
||||||
|
* additional does permit addition debug instrumentation to be added to the
|
||||||
|
* kernel space without overflowing the partition.
|
||||||
|
*
|
||||||
|
* Alignment of the user space FLASH partition is also a critical factor:
|
||||||
|
* The user space FLASH partition will be spanned with a single region of
|
||||||
|
* size 2**n bytes. The alignment of the user-space region must be the same.
|
||||||
|
* As a consequence, as the user-space increases in size, the alignmment
|
||||||
|
* requirement also increases.
|
||||||
|
*
|
||||||
|
* This alignment requirement means that the largest user space FLASH region
|
||||||
|
* you can have will be 512KB at it would have to be positioned at
|
||||||
|
* 0x08800000. If you change this address, don't forget to change the
|
||||||
|
* CONFIG_NUTTX_USERSPACE configuration setting to match and to modify
|
||||||
|
* the check in kernel/userspace.c.
|
||||||
|
*
|
||||||
|
* For the same reasons, the maximum size of the SRAM mapping is limited to
|
||||||
|
* 4KB. Both of these alignment limitations could be reduced by using
|
||||||
|
* multiple regions to map the FLASH/SDRAM range or perhaps with some
|
||||||
|
* clever use of subregions.
|
||||||
|
*
|
||||||
|
* A detailed memory map for the 112KB SRAM region is as follows:
|
||||||
|
*
|
||||||
|
* 0x20000 0000: Kernel .data region. Typical size: 0.1KB
|
||||||
|
* ------- ---- Kernel .bss region. Typical size: 1.8KB
|
||||||
|
* 0x20000 0800: Kernel IDLE thread stack (approximate). Size is
|
||||||
|
* determined by CONFIG_IDLETHREAD_STACKSIZE and
|
||||||
|
* adjustments for alignment. Typical is 1KB.
|
||||||
|
* ------- ---- Padded to 4KB
|
||||||
|
* 0x20000 1000: User .data region. Size is variable.
|
||||||
|
* ------- ---- User .bss region Size is variable.
|
||||||
|
* 0x20000 2000: Beginning of kernel heap. Size determined by
|
||||||
|
* CONFIG_MM_KERNEL_HEAPSIZE.
|
||||||
|
* ------- ---- Beginning of user heap. Can vary with other settings.
|
||||||
|
* 0x20001 c000: End+1 of CPU RAM
|
||||||
|
*/
|
||||||
|
|
||||||
|
MEMORY
|
||||||
|
{
|
||||||
|
/* 1024Kb FLASH */
|
||||||
|
|
||||||
|
kflash (rx) : ORIGIN = 0x08000000, LENGTH = 128K
|
||||||
|
uflash (rx) : ORIGIN = 0x08020000, LENGTH = 128K
|
||||||
|
xflash (rx) : ORIGIN = 0x08040000, LENGTH = 768K
|
||||||
|
|
||||||
|
/* 112Kb of contiguous SRAM */
|
||||||
|
|
||||||
|
ksram (rwx) : ORIGIN = 0x20000000, LENGTH = 4K
|
||||||
|
usram (rwx) : ORIGIN = 0x20001000, LENGTH = 4K
|
||||||
|
xsram (rwx) : ORIGIN = 0x20001000, LENGTH = 104K
|
||||||
|
}
|
126
configs/stm3240g-eval/scripts/user-space.ld
Normal file
126
configs/stm3240g-eval/scripts/user-space.ld
Normal file
@ -0,0 +1,126 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* configs/stm3240g-eval/scripts/user-space.ld
|
||||||
|
*
|
||||||
|
* Copyright (C) 2013 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/* NOTE: This depends on the memory.ld script having been included prior to
|
||||||
|
* this script.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Make sure that the critical memory management functions are in user-space.
|
||||||
|
* the user heap memory manager will reside in user-space but be usable both
|
||||||
|
* by kernel- and user-space code
|
||||||
|
*/
|
||||||
|
|
||||||
|
EXTERN(umm_initialize)
|
||||||
|
EXTERN(umm_addregion)
|
||||||
|
EXTERN(umm_trysemaphore)
|
||||||
|
EXTERN(umm_givesemaphore)
|
||||||
|
|
||||||
|
EXTERN(malloc)
|
||||||
|
EXTERN(realloc)
|
||||||
|
EXTERN(zalloc)
|
||||||
|
EXTERN(free)
|
||||||
|
|
||||||
|
OUTPUT_ARCH(arm)
|
||||||
|
SECTIONS
|
||||||
|
{
|
||||||
|
.userspace : {
|
||||||
|
*(.userspace)
|
||||||
|
} > uflash
|
||||||
|
|
||||||
|
.text : {
|
||||||
|
_stext = ABSOLUTE(.);
|
||||||
|
*(.text .text.*)
|
||||||
|
*(.fixup)
|
||||||
|
*(.gnu.warning)
|
||||||
|
*(.rodata .rodata.*)
|
||||||
|
*(.gnu.linkonce.t.*)
|
||||||
|
*(.glue_7)
|
||||||
|
*(.glue_7t)
|
||||||
|
*(.got)
|
||||||
|
*(.gcc_except_table)
|
||||||
|
*(.gnu.linkonce.r.*)
|
||||||
|
_etext = ABSOLUTE(.);
|
||||||
|
} > uflash
|
||||||
|
|
||||||
|
.init_section : {
|
||||||
|
_sinit = ABSOLUTE(.);
|
||||||
|
*(.init_array .init_array.*)
|
||||||
|
_einit = ABSOLUTE(.);
|
||||||
|
} > uflash
|
||||||
|
|
||||||
|
.ARM.extab : {
|
||||||
|
*(.ARM.extab*)
|
||||||
|
} > uflash
|
||||||
|
|
||||||
|
__exidx_start = ABSOLUTE(.);
|
||||||
|
.ARM.exidx : {
|
||||||
|
*(.ARM.exidx*)
|
||||||
|
} > uflash
|
||||||
|
|
||||||
|
__exidx_end = ABSOLUTE(.);
|
||||||
|
|
||||||
|
_eronly = ABSOLUTE(.);
|
||||||
|
|
||||||
|
.data : {
|
||||||
|
_sdata = ABSOLUTE(.);
|
||||||
|
*(.data .data.*)
|
||||||
|
*(.gnu.linkonce.d.*)
|
||||||
|
CONSTRUCTORS
|
||||||
|
_edata = ABSOLUTE(.);
|
||||||
|
} > usram AT > uflash
|
||||||
|
|
||||||
|
.bss : {
|
||||||
|
_sbss = ABSOLUTE(.);
|
||||||
|
*(.bss .bss.*)
|
||||||
|
*(.gnu.linkonce.b.*)
|
||||||
|
*(COMMON)
|
||||||
|
_ebss = ABSOLUTE(.);
|
||||||
|
} > usram
|
||||||
|
|
||||||
|
/* 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) }
|
||||||
|
}
|
@ -1,8 +1,7 @@
|
|||||||
/****************************************************************************************************
|
/****************************************************************************************************
|
||||||
* configs/stm3240g_eval/src/stm3240g_internal.h
|
* configs/stm3240g_eval/src/stm3240g_internal.h
|
||||||
* arch/arm/src/board/stm3240g_internal.n
|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2011-2012 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2011-2013 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -70,8 +69,8 @@
|
|||||||
|
|
||||||
/* You can't use CAN1 with FSMC:
|
/* You can't use CAN1 with FSMC:
|
||||||
*
|
*
|
||||||
* PD0 = FSMC_D2 & CAN1_RX
|
* PD0 = FSMC_D2 & CAN1_RX
|
||||||
* PD1 = FSMC_D3 & CAN1_TX
|
* PD1 = FSMC_D3 & CAN1_TX
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if defined(CONFIG_STM32_CAN1) && defined(CONFIG_STM32_FSMC)
|
#if defined(CONFIG_STM32_CAN1) && defined(CONFIG_STM32_FSMC)
|
||||||
@ -127,7 +126,7 @@
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* USB OTG FS
|
/* USB OTG FS
|
||||||
*
|
*
|
||||||
* PA9 VBUS_FS
|
* PA9 VBUS_FS
|
||||||
* PH5 OTG_FS_PowerSwitchOn
|
* PH5 OTG_FS_PowerSwitchOn
|
||||||
@ -145,7 +144,7 @@
|
|||||||
|
|
||||||
/* The STM3240G-EVAL has two STMPE811QTR I/O expanders on board both connected
|
/* The STM3240G-EVAL has two STMPE811QTR I/O expanders on board both connected
|
||||||
* to the STM32 via I2C1. They share a common interrupt line: PI2.
|
* to the STM32 via I2C1. They share a common interrupt line: PI2.
|
||||||
*
|
*
|
||||||
* STMPE811 U24, I2C address 0x41 (7-bit)
|
* STMPE811 U24, I2C address 0x41 (7-bit)
|
||||||
* ------ ---- ---------------- --------------------------------------------
|
* ------ ---- ---------------- --------------------------------------------
|
||||||
* STPE11 PIN BOARD SIGNAL BOARD CONNECTION
|
* STPE11 PIN BOARD SIGNAL BOARD CONNECTION
|
||||||
@ -158,7 +157,7 @@
|
|||||||
* IN2 EXP_IO10
|
* IN2 EXP_IO10
|
||||||
* IN1 EXP_IO11
|
* IN1 EXP_IO11
|
||||||
* IN0 EXP_IO12
|
* IN0 EXP_IO12
|
||||||
*
|
*
|
||||||
* STMPE811 U29, I2C address 0x44 (7-bit)
|
* STMPE811 U29, I2C address 0x44 (7-bit)
|
||||||
* ------ ---- ---------------- --------------------------------------------
|
* ------ ---- ---------------- --------------------------------------------
|
||||||
* STPE11 PIN BOARD SIGNAL BOARD CONNECTION
|
* STPE11 PIN BOARD SIGNAL BOARD CONNECTION
|
||||||
@ -307,7 +306,7 @@ void stm32_disablefsmc(void);
|
|||||||
* Name: stm32_selectsram
|
* Name: stm32_selectsram
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Initialize to access external SRAM. SRAM will be visible at the FSMC Bank
|
* Initialize to access external SRAM. SRAM will be visible at the FSMC Bank
|
||||||
* NOR/SRAM2 base address (0x64000000)
|
* NOR/SRAM2 base address (0x64000000)
|
||||||
*
|
*
|
||||||
* General transaction rules. The requested AHB transaction data size can be 8-,
|
* General transaction rules. The requested AHB transaction data size can be 8-,
|
||||||
@ -369,5 +368,24 @@ void stm32_selectlcd(void);
|
|||||||
void stm32_deselectlcd(void);
|
void stm32_deselectlcd(void);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: nsh_archinitialize
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Perform architecture specific initialization for NSH.
|
||||||
|
*
|
||||||
|
* CONFIG_NSH_ARCHINIT=y :
|
||||||
|
* Called from the NSH library
|
||||||
|
*
|
||||||
|
* CONFIG_BOARD_INITIALIZE=y, CONFIG_NSH_LIBRARY=y, &&
|
||||||
|
* CONFIG_NSH_ARCHINIT=n :
|
||||||
|
* Called from board_initialize().
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_NSH_LIBRARY
|
||||||
|
int nsh_archinitialize(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* __ASSEMBLY__ */
|
#endif /* __ASSEMBLY__ */
|
||||||
#endif /* __CONFIGS_STM3240G_EVAL_SRC_STM3240G_INTERNAL_H */
|
#endif /* __CONFIGS_STM3240G_EVAL_SRC_STM3240G_INTERNAL_H */
|
||||||
|
@ -1,8 +1,7 @@
|
|||||||
/************************************************************************************
|
/************************************************************************************
|
||||||
* configs/stm3240g-eval/src/up_boot.c
|
* configs/stm3240g-eval/src/up_boot.c
|
||||||
* arch/arm/src/board/up_boot.c
|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2011-2012 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2011-2013 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -89,11 +88,11 @@ void stm32_boardinitialize(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Initialize USB if the 1) OTG FS controller is in the configuration and 2)
|
/* Initialize USB if the 1) OTG FS controller is in the configuration and 2)
|
||||||
* disabled, and 3) the weak function stm32_usbinitialize() has been brought
|
* disabled, and 3) the weak function stm32_usbinitialize() has been brought
|
||||||
* the weak function stm32_usbinitialize() has been brought into the build.
|
* the weak function stm32_usbinitialize() has been brought into the build.
|
||||||
* Presumeably either CONFIG_USBDEV or CONFIG_USBHOST is also selected.
|
* Presumeably either CONFIG_USBDEV or CONFIG_USBHOST is also selected.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef CONFIG_STM32_OTGFS
|
#ifdef CONFIG_STM32_OTGFS
|
||||||
if (stm32_usbinitialize)
|
if (stm32_usbinitialize)
|
||||||
{
|
{
|
||||||
@ -107,3 +106,30 @@ void stm32_boardinitialize(void)
|
|||||||
up_ledinit();
|
up_ledinit();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: board_initialize
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* If CONFIG_BOARD_INITIALIZE is selected, then an additional
|
||||||
|
* initialization call will be performed in the boot-up sequence to a
|
||||||
|
* function called board_initialize(). board_initialize() will be
|
||||||
|
* called immediately after up_intiialize() is called and just before the
|
||||||
|
* initial application is started. This additional initialization phase
|
||||||
|
* may be used, for example, to initialize board-specific device drivers.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifdef CONFIG_BOARD_INITIALIZE
|
||||||
|
void board_initialize(void)
|
||||||
|
{
|
||||||
|
/* Perform NSH initialization here instead of from the NSH. This
|
||||||
|
* alternative NSH initialization is necessary when NSH is ran in user-space
|
||||||
|
* but the initialization function must run in kernel space.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if defined(CONFIG_NSH_LIBRARY) && !defined(CONFIG_NSH_ARCHINIT)
|
||||||
|
(void)nsh_archinitialize();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@ memory and 128kbytes. The board features:
|
|||||||
- Easy access to most MCU pins.
|
- Easy access to most MCU pins.
|
||||||
|
|
||||||
Refer to http://www.st.com/internet/evalboard/product/252419.jsp for
|
Refer to http://www.st.com/internet/evalboard/product/252419.jsp for
|
||||||
further information about this board.
|
further information about this board.
|
||||||
|
|
||||||
Contents
|
Contents
|
||||||
========
|
========
|
||||||
@ -53,7 +53,7 @@ GNU Toolchain Options
|
|||||||
toolchain options.
|
toolchain options.
|
||||||
|
|
||||||
1. The CodeSourcery GNU toolchain,
|
1. The CodeSourcery GNU toolchain,
|
||||||
2. The Atollic Toolchain,
|
2. The Atollic Toolchain,
|
||||||
3. The devkitARM GNU toolchain,
|
3. The devkitARM GNU toolchain,
|
||||||
4. Raisonance GNU toolchain, or
|
4. Raisonance GNU toolchain, or
|
||||||
5. The NuttX buildroot Toolchain (see below).
|
5. The NuttX buildroot Toolchain (see below).
|
||||||
@ -132,7 +132,7 @@ GNU Toolchain Options
|
|||||||
In order to compile successfully. Otherwise, you will get errors like:
|
In order to compile successfully. Otherwise, you will get errors like:
|
||||||
|
|
||||||
"C++ Compiler only available in TrueSTUDIO Professional"
|
"C++ Compiler only available in TrueSTUDIO Professional"
|
||||||
|
|
||||||
The make may then fail in some of the post link processing because of some of
|
The make may then fail in some of the post link processing because of some of
|
||||||
the other missing tools. The Make.defs file replaces the ar and nm with
|
the other missing tools. The Make.defs file replaces the ar and nm with
|
||||||
the default system x86 tool versions and these seem to work okay. Disable all
|
the default system x86 tool versions and these seem to work okay. Disable all
|
||||||
@ -154,7 +154,7 @@ IDEs
|
|||||||
|
|
||||||
NuttX is built using command-line make. It can be used with an IDE, but some
|
NuttX is built using command-line make. It can be used with an IDE, but some
|
||||||
effort will be required to create the project.
|
effort will be required to create the project.
|
||||||
|
|
||||||
Makefile Build
|
Makefile Build
|
||||||
--------------
|
--------------
|
||||||
Under Eclipse, it is pretty easy to set up an "empty makefile project" and
|
Under Eclipse, it is pretty easy to set up an "empty makefile project" and
|
||||||
@ -251,7 +251,7 @@ NXFLAT Toolchain
|
|||||||
tools -- just the NXFLAT tools. The buildroot with the NXFLAT tools can
|
tools -- just the NXFLAT tools. The buildroot with the NXFLAT tools can
|
||||||
be downloaded from the NuttX SourceForge download site
|
be downloaded from the NuttX SourceForge download site
|
||||||
(https://sourceforge.net/projects/nuttx/files/).
|
(https://sourceforge.net/projects/nuttx/files/).
|
||||||
|
|
||||||
This GNU toolchain builds and executes in the Linux or Cygwin environment.
|
This GNU toolchain builds and executes in the Linux or Cygwin environment.
|
||||||
|
|
||||||
1. You must have already configured Nuttx in <some-dir>/nuttx.
|
1. You must have already configured Nuttx in <some-dir>/nuttx.
|
||||||
@ -353,10 +353,10 @@ USART6
|
|||||||
with care (See table 5 in the STM32F4Discovery User Guide). The rest are
|
with care (See table 5 in the STM32F4Discovery User Guide). The rest are
|
||||||
free I/O pins.
|
free I/O pins.
|
||||||
** Port G pins are not supported by the MCU
|
** Port G pins are not supported by the MCU
|
||||||
|
|
||||||
Default USART/UART Configuration
|
Default USART/UART Configuration
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
||||||
USART2 is enabled in all configurations (see */defconfig). RX and TX are
|
USART2 is enabled in all configurations (see */defconfig). RX and TX are
|
||||||
configured on pins PA3 and PA2, respectively (see include/board.h).
|
configured on pins PA3 and PA2, respectively (see include/board.h).
|
||||||
|
|
||||||
@ -417,7 +417,7 @@ Quadrature Encode Timer Inputs
|
|||||||
------------------------------
|
------------------------------
|
||||||
|
|
||||||
If enabled (by setting CONFIG_QENCODER=y), then quadrature encoder will
|
If enabled (by setting CONFIG_QENCODER=y), then quadrature encoder will
|
||||||
use either TIM2 or TIM8 (see nsh/defconfig). If TIM2 is selected, the input
|
use either TIM2 or TIM8 (see nsh/defconfig). If TIM2 is selected, the input
|
||||||
pins PA15 and PA1 for CH1 and CH2, respectively). If TIM8 is selected, then
|
pins PA15 and PA1 for CH1 and CH2, respectively). If TIM8 is selected, then
|
||||||
PC6 and PI5 will be used for CH1 and CH2 (see include board.h for pin
|
PC6 and PI5 will be used for CH1 and CH2 (see include board.h for pin
|
||||||
definitions).
|
definitions).
|
||||||
@ -479,7 +479,7 @@ the following lines in each Make.defs file:
|
|||||||
If you are using a toolchain other than the Atollic toolchain, then to use the FPU
|
If you are using a toolchain other than the Atollic toolchain, then to use the FPU
|
||||||
you will also have to modify the CFLAGS to enable compiler support for the ARMv7-M
|
you will also have to modify the CFLAGS to enable compiler support for the ARMv7-M
|
||||||
FPU. As of this writing, there are not many GCC toolchains that will support the
|
FPU. As of this writing, there are not many GCC toolchains that will support the
|
||||||
ARMv7-M FPU.
|
ARMv7-M FPU.
|
||||||
|
|
||||||
As a minimum you will need to add CFLAG options to (1) enable hardware floating point
|
As a minimum you will need to add CFLAG options to (1) enable hardware floating point
|
||||||
code generation, and to (2) select the FPU implementation. You might try the same
|
code generation, and to (2) select the FPU implementation. You might try the same
|
||||||
@ -543,7 +543,7 @@ present in the NuttX configuration file:
|
|||||||
CONFIG_HEAP2_SIZE : The size of the SRAM in the FSMC
|
CONFIG_HEAP2_SIZE : The size of the SRAM in the FSMC
|
||||||
address space
|
address space
|
||||||
CONFIG_MM_REGIONS : Must be set to a large enough value to
|
CONFIG_MM_REGIONS : Must be set to a large enough value to
|
||||||
include the FSMC SRAM
|
include the FSMC SRAM
|
||||||
|
|
||||||
SRAM Configurations
|
SRAM Configurations
|
||||||
-------------------
|
-------------------
|
||||||
@ -773,7 +773,7 @@ STM32F4Discovery-specific Configuration Options
|
|||||||
configuration features.
|
configuration features.
|
||||||
|
|
||||||
CONFIG_ARCH_BOARD_STM32_CUSTOM_CLOCKCONFIG=n
|
CONFIG_ARCH_BOARD_STM32_CUSTOM_CLOCKCONFIG=n
|
||||||
|
|
||||||
CONFIG_ARCH_BOARD - Identifies the configs subdirectory and
|
CONFIG_ARCH_BOARD - Identifies the configs subdirectory and
|
||||||
hence, the board that supports the particular chip or SoC.
|
hence, the board that supports the particular chip or SoC.
|
||||||
|
|
||||||
@ -923,7 +923,7 @@ STM32F4Discovery-specific Configuration Options
|
|||||||
configuration settings:
|
configuration settings:
|
||||||
|
|
||||||
CONFIG_STM32_TIMx_CHANNEL - Specifies the timer output channel {1,..,4}
|
CONFIG_STM32_TIMx_CHANNEL - Specifies the timer output channel {1,..,4}
|
||||||
|
|
||||||
NOTE: The STM32 timers are each capable of generating different signals on
|
NOTE: The STM32 timers are each capable of generating different signals on
|
||||||
each of the four channels with different duty cycles. That capability is
|
each of the four channels with different duty cycles. That capability is
|
||||||
not supported by this driver: Only one output channel per timer.
|
not supported by this driver: Only one output channel per timer.
|
||||||
@ -980,7 +980,7 @@ STM32F4Discovery-specific Configuration Options
|
|||||||
CONFIG_SDIO_DMA - Support DMA data transfers. Requires CONFIG_STM32_SDIO
|
CONFIG_SDIO_DMA - Support DMA data transfers. Requires CONFIG_STM32_SDIO
|
||||||
and CONFIG_STM32_DMA2.
|
and CONFIG_STM32_DMA2.
|
||||||
CONFIG_SDIO_PRI - Select SDIO interrupt prority. Default: 128
|
CONFIG_SDIO_PRI - Select SDIO interrupt prority. Default: 128
|
||||||
CONFIG_SDIO_DMAPRIO - Select SDIO DMA interrupt priority.
|
CONFIG_SDIO_DMAPRIO - Select SDIO DMA interrupt priority.
|
||||||
Default: Medium
|
Default: Medium
|
||||||
CONFIG_SDIO_WIDTH_D1_ONLY - Select 1-bit transfer mode. Default:
|
CONFIG_SDIO_WIDTH_D1_ONLY - Select 1-bit transfer mode. Default:
|
||||||
4-bit transfer mode.
|
4-bit transfer mode.
|
||||||
@ -988,15 +988,15 @@ STM32F4Discovery-specific Configuration Options
|
|||||||
STM32 USB OTG FS Host Driver Support
|
STM32 USB OTG FS Host Driver Support
|
||||||
|
|
||||||
Pre-requisites
|
Pre-requisites
|
||||||
|
|
||||||
CONFIG_USBDEV - Enable USB device support
|
CONFIG_USBDEV - Enable USB device support
|
||||||
CONFIG_USBHOST - Enable USB host support
|
CONFIG_USBHOST - Enable USB host support
|
||||||
CONFIG_STM32_OTGFS - Enable the STM32 USB OTG FS block
|
CONFIG_STM32_OTGFS - Enable the STM32 USB OTG FS block
|
||||||
CONFIG_STM32_SYSCFG - Needed
|
CONFIG_STM32_SYSCFG - Needed
|
||||||
CONFIG_SCHED_WORKQUEUE - Worker thread support is required
|
CONFIG_SCHED_WORKQUEUE - Worker thread support is required
|
||||||
|
|
||||||
Options:
|
Options:
|
||||||
|
|
||||||
CONFIG_STM32_OTGFS_RXFIFO_SIZE - Size of the RX FIFO in 32-bit words.
|
CONFIG_STM32_OTGFS_RXFIFO_SIZE - Size of the RX FIFO in 32-bit words.
|
||||||
Default 128 (512 bytes)
|
Default 128 (512 bytes)
|
||||||
CONFIG_STM32_OTGFS_NPTXFIFO_SIZE - Size of the non-periodic Tx FIFO
|
CONFIG_STM32_OTGFS_NPTXFIFO_SIZE - Size of the non-periodic Tx FIFO
|
||||||
@ -1083,7 +1083,7 @@ Where <subdir> is one of the following:
|
|||||||
vterminate.o that you removed from libsupc++, you can do that with:
|
vterminate.o that you removed from libsupc++, you can do that with:
|
||||||
|
|
||||||
arm-none-eabi-ar.exe rcs libsupc++.a vterminate.o
|
arm-none-eabi-ar.exe rcs libsupc++.a vterminate.o
|
||||||
|
|
||||||
4. Exceptions are enabled and workking (CONFIG_UCLIBCXX_EXCEPTIONS=y)
|
4. Exceptions are enabled and workking (CONFIG_UCLIBCXX_EXCEPTIONS=y)
|
||||||
|
|
||||||
elf:
|
elf:
|
||||||
@ -1094,7 +1094,7 @@ Where <subdir> is one of the following:
|
|||||||
loader.
|
loader.
|
||||||
|
|
||||||
NOTES:
|
NOTES:
|
||||||
|
|
||||||
1. This configuration uses the mconf-based configuration tool. To
|
1. This configuration uses the mconf-based configuration tool. To
|
||||||
change this configuration using that tool, you should:
|
change this configuration using that tool, you should:
|
||||||
|
|
||||||
@ -1112,7 +1112,7 @@ Where <subdir> is one of the following:
|
|||||||
|
|
||||||
3. By default, this project assumes that you are *NOT* using the DFU
|
3. By default, this project assumes that you are *NOT* using the DFU
|
||||||
bootloader.
|
bootloader.
|
||||||
|
|
||||||
4. It appears that you cannot excute from CCM RAM. This is why the
|
4. It appears that you cannot excute from CCM RAM. This is why the
|
||||||
following definition appears in the defconfig file:
|
following definition appears in the defconfig file:
|
||||||
|
|
||||||
@ -1138,7 +1138,7 @@ Where <subdir> is one of the following:
|
|||||||
binaries (pass2)
|
binaries (pass2)
|
||||||
|
|
||||||
NOTES:
|
NOTES:
|
||||||
|
|
||||||
1. This configuration uses the mconf-based configuration tool. To
|
1. This configuration uses the mconf-based configuration tool. To
|
||||||
change this configuration using that tool, you should:
|
change this configuration using that tool, you should:
|
||||||
|
|
||||||
@ -1221,7 +1221,7 @@ Where <subdir> is one of the following:
|
|||||||
builtin applications are selected (see NOTES below).
|
builtin applications are selected (see NOTES below).
|
||||||
|
|
||||||
NOTES:
|
NOTES:
|
||||||
|
|
||||||
1. This configuration uses the mconf-based configuration tool. To
|
1. This configuration uses the mconf-based configuration tool. To
|
||||||
change this configuration using that tool, you should:
|
change this configuration using that tool, you should:
|
||||||
|
|
||||||
@ -1338,7 +1338,7 @@ Where <subdir> is one of the following:
|
|||||||
you can still use certain kinds of debug output (see include/debug.h, all
|
you can still use certain kinds of debug output (see include/debug.h, all
|
||||||
of the interfaces based on lowsyslog will work in this configuration).
|
of the interfaces based on lowsyslog will work in this configuration).
|
||||||
|
|
||||||
- But don't enable USB debug output! Since USB is console is used for
|
- But don't enable USB debug output! Since USB is console is used for
|
||||||
USB debug output and you are using a USB console, there will be
|
USB debug output and you are using a USB console, there will be
|
||||||
infinite loops and deadlocks: Debug output generates USB debug
|
infinite loops and deadlocks: Debug output generates USB debug
|
||||||
output which generatates USB debug output, etc. If you want USB
|
output which generatates USB debug output, etc. If you want USB
|
||||||
@ -1486,7 +1486,7 @@ Where <subdir> is one of the following:
|
|||||||
apps/examples/ostest.
|
apps/examples/ostest.
|
||||||
|
|
||||||
NOTES:
|
NOTES:
|
||||||
|
|
||||||
1. This configuration uses the mconf-based configuration tool. To
|
1. This configuration uses the mconf-based configuration tool. To
|
||||||
change this configuration using that tool, you should:
|
change this configuration using that tool, you should:
|
||||||
|
|
||||||
@ -1502,7 +1502,7 @@ Where <subdir> is one of the following:
|
|||||||
|
|
||||||
3. By default, this project assumes that you are *NOT* using the DFU
|
3. By default, this project assumes that you are *NOT* using the DFU
|
||||||
bootloader.
|
bootloader.
|
||||||
|
|
||||||
4. If you use the Atollic toolchain, then the FPU test can be enabled in the
|
4. If you use the Atollic toolchain, then the FPU test can be enabled in the
|
||||||
examples/ostest by adding the following your NuttX configuration file:
|
examples/ostest by adding the following your NuttX configuration file:
|
||||||
|
|
||||||
@ -1530,7 +1530,7 @@ Where <subdir> is one of the following:
|
|||||||
bytes (see arch/arm/include/armv7-m/irq_lazyfpu.h):
|
bytes (see arch/arm/include/armv7-m/irq_lazyfpu.h):
|
||||||
|
|
||||||
-CONFIG_EXAMPLES_OSTEST_FPUSIZE=(4*33)
|
-CONFIG_EXAMPLES_OSTEST_FPUSIZE=(4*33)
|
||||||
|
|
||||||
pm:
|
pm:
|
||||||
--
|
--
|
||||||
This is a configuration that is used to test STM32 power management, i.e.,
|
This is a configuration that is used to test STM32 power management, i.e.,
|
||||||
@ -1550,7 +1550,7 @@ Where <subdir> is one of the following:
|
|||||||
CONFIG_PM_CUSTOMINIT moves the PM initialization from arch/arm/src/stm32/stm32_pminitialiaze.c
|
CONFIG_PM_CUSTOMINIT moves the PM initialization from arch/arm/src/stm32/stm32_pminitialiaze.c
|
||||||
to configs/stm3210-eval/src/up_pm.c. This allows us to support board-
|
to configs/stm3210-eval/src/up_pm.c. This allows us to support board-
|
||||||
specific PM initialization.
|
specific PM initialization.
|
||||||
|
|
||||||
CONFIG_IDLE_CUSTOM=y
|
CONFIG_IDLE_CUSTOM=y
|
||||||
|
|
||||||
The bulk of the PM activities occur in the IDLE loop. The IDLE loop is
|
The bulk of the PM activities occur in the IDLE loop. The IDLE loop is
|
||||||
@ -1565,7 +1565,7 @@ Where <subdir> is one of the following:
|
|||||||
Here are some additional things to note in the configuration:
|
Here are some additional things to note in the configuration:
|
||||||
|
|
||||||
CONFIG_PM_BUTTONS=y
|
CONFIG_PM_BUTTONS=y
|
||||||
|
|
||||||
CONFIG_PM_BUTTONS enables button support for PM testing. Buttons can drive
|
CONFIG_PM_BUTTONS enables button support for PM testing. Buttons can drive
|
||||||
EXTI interrupts and EXTI interrrupts can be used to wakeup for certain reduced
|
EXTI interrupts and EXTI interrrupts can be used to wakeup for certain reduced
|
||||||
power modes (STOP mode). The use of the buttons here is for PM testing purposes
|
power modes (STOP mode). The use of the buttons here is for PM testing purposes
|
||||||
@ -1584,7 +1584,7 @@ Where <subdir> is one of the following:
|
|||||||
interface using apps/examples/posix_spawn.
|
interface using apps/examples/posix_spawn.
|
||||||
|
|
||||||
NOTES:
|
NOTES:
|
||||||
|
|
||||||
1. This configuration uses the mconf-based configuration tool. To
|
1. This configuration uses the mconf-based configuration tool. To
|
||||||
change this configuration using that tool, you should:
|
change this configuration using that tool, you should:
|
||||||
|
|
||||||
@ -1602,7 +1602,7 @@ Where <subdir> is one of the following:
|
|||||||
|
|
||||||
3. By default, this project assumes that you are *NOT* using the DFU
|
3. By default, this project assumes that you are *NOT* using the DFU
|
||||||
bootloader.
|
bootloader.
|
||||||
|
|
||||||
usbnsh:
|
usbnsh:
|
||||||
-------
|
-------
|
||||||
|
|
||||||
@ -1612,7 +1612,7 @@ Where <subdir> is one of the following:
|
|||||||
builtin RS-232 drivers.
|
builtin RS-232 drivers.
|
||||||
|
|
||||||
NOTES:
|
NOTES:
|
||||||
|
|
||||||
1. This configuration uses the mconf-based configuration tool. To
|
1. This configuration uses the mconf-based configuration tool. To
|
||||||
change this configuration using that tool, you should:
|
change this configuration using that tool, you should:
|
||||||
|
|
||||||
|
@ -49,6 +49,7 @@ else
|
|||||||
ARCHINCLUDES = -I. -isystem $(TOPDIR)$(DELIM)include
|
ARCHINCLUDES = -I. -isystem $(TOPDIR)$(DELIM)include
|
||||||
ARCHXXINCLUDES = -I. -isystem $(TOPDIR)$(DELIM)include -isystem $(TOPDIR)$(DELIM)include$(DELIM)cxx
|
ARCHXXINCLUDES = -I. -isystem $(TOPDIR)$(DELIM)include -isystem $(TOPDIR)$(DELIM)include$(DELIM)cxx
|
||||||
ARCHSCRIPT = -T$(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)memory.ld
|
ARCHSCRIPT = -T$(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)memory.ld
|
||||||
|
ARCHSCRIPT += -T$(TOPDIR)$(DELIM)configs$(DELIM)$(CONFIG_ARCH_BOARD)$(DELIM)scripts$(DELIM)kernel-space.ld
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CC = $(CROSSDEV)gcc
|
CC = $(CROSSDEV)gcc
|
||||||
|
Loading…
Reference in New Issue
Block a user