Getting Started
These instructions will get you a copy of the project up and running on your local
machine (STM32WB Firefly Developer Board) for development and testing purposes.
Prerequisites
- Firefly BLE Development Board with STM32WB55 MCU (Cortex ARM M4) runs at a 32 MHz (the Bluetooth stack runs on a Cortex ARM M0+ core). If you want to debug C and assembler programs you need an ST-Link debugger/programmer e.g. STLINK-V3MINIE.
- Terminal emulator application for PC, e.g.:
- PuTTY - Windows and Linux
- Tera Term - Windows
- Realterm - Windows
- minicom, microcom, screen - Linux
- Use the built in Eclipse console (but no LF)
Flash the Mecrisp-Cube
binary (
MecrispCubeFirefly.bin
) or the
FS-binary (
MecrispCubeFireflyFS.bin
, everything included e.g. internal flash drive and Forth utilities) to the Firefly Board.
- Connect the Firefly Board USB to the PC
- Hold the BTN button (BOOTP Pin), push the nRST button, release the nRST button
- Program the binary (
MecrispCubeFirefly.bin
or MecrispCubeFireflyFS.bin
) with the STMCubeProgrammer (select USB Device)
- Reset or power cycle the Firefly board
Start the terminal emulator application on the PC.
Check for the serial communication port (e.g. for Linux
/dev/ttyACM0
).
I set the putty terminal configuration to
- Implicit CR in every LF
- Local echo: Auto
- Local line editing: Auto
- Keyboard Backspace: Control-H
- Keyboard Function: Keys VT100
- Remote character set: CP850
Mecrisp-Stellaris RA 2.5.4 by Matthias Koch.
Mecrisp-Cube 1.5.0 for STM32WB Firefly, 63/128 KiB RAM/FLASH dictionary (C) 2022 peter@spyr.ch
* Firmware Package STM32Cube FW_WB V1.14.1, USB-CDC, BLE Stack 5.3 (C) 2022 STMicroelectronics
* CMSIS-RTOS V2 FreeRTOS wrapper, FreeRTOS Kernel V10.3.1 (C) 2020 Amazon.com
* FatFs for internal flash and microSD - Generic FAT fs module R0.12c (C) 2017 ChaN
* tiny vi - part of BusyBox (C) 2000, 2001 Sterling Huxley
include 0:/etc/rc.local
23 5 / .[CR] 4 ok.
: hello ." World" ;[CR] ok.
hello[CR] World ok.
Special Functions on Startup
USB-CDC is the default console.
- Button BTN
- start STM bootloader
- blue LED
- the LED lights up during the initialization phase
Neopixel as Status Indicator
The optional
NeoPixel displays the status
- dimmed Green
- USB enumeration successfull
- dimmed Blue
- BLE connected
- flashing Red
- "disk" (serial flash or SD) write operation
- flashing Yellow
- "disk" (serial flash or SD) read operation
Additional Tools and Local Filesystem
There are two drives available, drive 0: is the flash drive (384
KiB internal flash, see
MicroSdBlocks#Flash_Drive) and drive 1: is the microSD drive (optional
MicroSdBlocks#SD_Drive).
Populate a microSD with the contents of
sdcard. Put the microSD into the uSD Card slot and reset or power cycle the board.
The directory should look like this:
ls -l 1:[CR]
drw- 0 2021-04-18T18:12:38 boot
drw- 0 2021-03-21T18:47:52 etc
drw- 0 2021-03-21T18:47:54 fsr
drw- 0 2021-03-21T18:47:54 home
drw- 0 2021-03-21T18:47:56 man
-rwa 7219 2021-01-08T19:42:36 README.md
ok.
You can use the local CLI commands like
mkfs
,
mkdir
and
cp
to create a filesystem on the serial flash and fill it with files and folders. But this is tedious job because I haven't yet implemented a recursive copy for MecrispCube. But there is prepared disk image
(for details see
MicroSdBlocks#Serial_Flash) on microSD and the tool
dd
. You can copy the disk image to the drive 0: (this takes about 2 Minutes):
dd 1:/boot/fd-384k.img 0:[CR]
ok.
mount 0:[CR]
ok.
ls 0:[CR]
man fsr README.md boot
etc home
ok.
The Mecrisp have some tools bundled in its distribution e.g. assembler, disassembler, dump, float. I put those tools and some more into the folder
/fsr
. With the "init.fs script" I compile my favorite ones into the flash directory (if you use the
FS-binary or
util-binary binary, these tools are already compiled in):
compiletoflash[CR] ok.
include /etc/init.fs[CR]
init.fs Loading started
RAM Dictionary: 392991 KiB
utils.fs loading ...
conditional.fs loading ...
dump.fs loading ...
disassembler-m3.fs loading ...
float.fs loading ...
threads.fs loading ...
RAM Dictionary: 392981 KiB
init.fs finished ok.
For example, the word disassember is available now:
see dump[CR]
080405F0: B500 push { lr }
080405F2: F7C2 bl 08002A3E --> cr
080405F4: FA24
080405F6: CF08 ldmia r7 { r3 }
080405F8: F013 ands r2 r3 #F
080405FA: 020F
080405FC: F847 str r3 [ r7 #-4 ]!
080405FE: 3D04
08040600: 2A00 cmp r2 #0
08040602: D000 beq 08040606
08040604: 3610 adds r6 #10
08040606: CF08 ldmia r7 { r3 }
08040608: F847 str r6 [ r7 #-4 ]!