Skip to content

Latest commit

 

History

History
117 lines (79 loc) · 6.05 KB

README.md

File metadata and controls

117 lines (79 loc) · 6.05 KB

Bastl-ARM-Tools

Install Tools

Eclipse

  • You will need a Version > 4.3 (Juno, Kepler, Luna...)
  • Mac Users: Download and install Binaries
  • Debian Users: sudo apt-get install eclipse-cdt

Toolchain

  • Mac Users: Follow the installation instructions on the Official Website
  • Debian Users: sudo apt-get install gcc-arm-none-eabi

Debugger

OpenOCD

  • Mac Users: Download and install the latest OpenOCD binary from Sourceforge
  • Debian Users: sudo apt-get install openocd

For using the Nucelo F334 you need at least version 0.9.0

GDB

  • Debian Users: sudo apt-get install gdb-arm-none-eabi
  • Mac users might want to use Mac Ports with port install arm-none-eabi-gdb configure.compiler=gcc

Eclipse Plug-in

  • Open Eclipse and select Help > Install New Software
  • Paste http://gnuarmeclipse.sourceforge.net/updates and hit enter
  • Uncheck Contact all Update sites during install
  • Follow the further instructions to install the plugin

Setup Eclipse

Start Eclipse and select the workspace you want to work in

Save before build

Window > Preferences > General > Workspace

Build shortcuts

Window > Preferences > General > Keys Ctrl + Alt + B Build All Ctrl + B Build Project

Showing Peripheral Registers in Debug Perspective

  • Set up path where you want to store the downloaded hardware description files in Windows > Preferences > C/C++ > Packages
  • Switch to Packs-View and refresh
  • Install latest version of STM32F429IDISCO

Remember last Debug configuration

Set Always launch the previously launched configuration at Window > Preferences > Run/Debug > Launching

Clone Repository

The content of this repository need to be placed inside your workspace in a folder called Bastl-ARM-Tools

Create your project

Complete Templates

For some chips, the Eclipse Plugin provides template projects that configure everything for you. Go to New > C Project > STM32XX... and try your luck.

Abstract Templates

If there is not a complete template for your chip, you can create your project based on the more general Cortex-M template. Select chup frequency and memory sizes and fill in your device name as Vendor CMSIS name

In this state, your project is still missing the device specify information (peripherals and some stuff that touches the cortex like interrupt vectors). This information is provided by vendors as header and source files. You should find them online (for STM for example, you'll find and overview http://www.st.com/stonline/stappl/productcatalog/app?page=partNumberSearchPage&levelid=SC1169&parentid=2004&resourcetype=SW)

First look for CMSIS header and source files and copy them in the right place in your project directory. Provided you entered stm32f3xx as the device name in the project wizard:

System > Include > CMSIS system_stm32f3xx.h stm32f3xx.h complete_device_name.h

System > Source > CMSIS > vectors_stm32f3xx.h Here, you need to explicity paste the vector table in the correct format and create default interrupt handlers

ldscripts > mem.ld Something like this:

MEMORY
{
FLASH (rx)      : ORIGIN = 0x08000000, LENGTH = 64K
RAM (xrw)       : ORIGIN = 0x20000000, LENGTH = 12K
CCMRAM (rw)     : ORIGIN = 0x10000000, LENGTH = 4K
}

To automatically choose the correct header files on build, add a define with your complete device name in the build settings. To test if things work, check if the correct header file is included from stm32f3xx.h

Usage

You now upload the hex file by selecting the active project and then clicking on external tools or debug it by clicking on the debug button

Select device description files to be able to see peripheral registers when debugging: Project Properties > C/C++ Build > Settings > Devices

Startup Procedure

This partly defined by the chip and partly by the implementation

  • Pins BOOT0 and BOOT1 define from which memory the chips starts. Default setting is Flash. Practially, this determines a memory offset. For Flash on F334 it is 0x08000000
  • The first 4 Bytes at this memory offset is interpreted as the stack pointer
  • The second address is the Reset Handler. This is where the programm branches on startup. In Debug Configuration, this is a separate function, allowing you to place a Breakpoint. In Release Configuration it's directly _start()
  • Next comes __initialize_hardware_early() which contains nothing but SystemInit() but can be redefined by the user because it is a weak reference.
  • SystemInit() basically puts a couple of peripheral registers into their default state.
  • Initialized global variables are allocated in RAM but their initialization values (.data and .bss) come with the flash image so they need to copied into the right place. This is handled by __initialize_data() which is called from _start()
  • Furthermore the borders of the segments are checked to lie within some guard intervals. This probably is generated by the linker script because only there memory size is known.
  • _initialize_hardware() is the second redefinable hook. By Default it only calls SystemCoreClockUpdate()
  • In SystemCoreClockUpdate(), registers are read to determine which clock source is used and which frequency the chip is running at. This is written to the variable SystemCoreClock which is used in different other locations in the code.
  • In Semihosting, the main function can receive parameters just like a 'regular' program. Those are prepared in __initialize_args(&argc, &argv)
  • __run_init_array() runs all constructors. It basically executes function pointers in an array it gets from the linker
  • Finally, we branch into main(int argc, char* argv[]) including the semihosting parameters
  • After returning from main, destructors are called and then _exit() which is redefinable and halts in debug configuration or resets by calling NVIC_SystemReset()