Line: 1 to 1 | ||||||||
---|---|---|---|---|---|---|---|---|
%DASHBOARD{ section="banner" | ||||||||
Line: 21 to 21 | ||||||||
Added: | ||||||||
> > | The standard Mecrisp-Cube features like RTOS, Filesystem, USB, etc. | |||||||
| ||||||||
Changed: | ||||||||
< < |
| |||||||
> > |
| |||||||
| ||||||||
Line: 42 to 39 | ||||||||
| ||||||||
Changed: | ||||||||
< < |
| |||||||
> > |
| |||||||
Changed: | ||||||||
< < |
| |||||||
> > | Feather Wings
| |||||||
| ||||||||
Deleted: | ||||||||
< < |
| |||||||
For more BSP details see BoardSupportPackageWBfeather. |
Line: 1 to 1 | ||||||||
---|---|---|---|---|---|---|---|---|
%DASHBOARD{ section="banner"
image="/twiki/pub/MecrispCube/BoardSupportPackageWBfeather/WB_Feather_header.jpg" | ||||||||
Changed: | ||||||||
< < | title="!MecrispCube for the STM32WB Feather Developer Board" | |||||||
> > | title="Mecrisp-Cube for the STM32WB Feather Developer Board" | |||||||
titlestyle="color:#F00000;"
}%
Intro
|
Line: 1 to 1 | ||||||||
---|---|---|---|---|---|---|---|---|
%DASHBOARD{ section="banner" | ||||||||
Line: 112 to 112 | ||||||||
USB-CDC is the default console. | ||||||||
Changed: | ||||||||
< < |
| |||||||
> > |
| |||||||
|
Line: 1 to 1 | ||||||||
---|---|---|---|---|---|---|---|---|
%DASHBOARD{ section="banner" | ||||||||
Line: 7 to 7 | ||||||||
titlestyle="color:#F00000;"
}%
Intro
| ||||||||
Added: | ||||||||
> > | After discovering Adafruit's Feather STM32F405 for myself, I wanted to develop a Feather board for the STM32WB. Luckily I found the STM32WB Feather Development Board from Reclaimer Labs![]() | |||||||
Instant real-time programming with Forth. | ||||||||
Line: 22 to 23 | ||||||||
| ||||||||
Changed: | ||||||||
< < |
| |||||||
> > |
| |||||||
| ||||||||
Changed: | ||||||||
< < |
| |||||||
> > |
| |||||||
| ||||||||
Line: 40 to 41 | ||||||||
| ||||||||
Changed: | ||||||||
< < |
| |||||||
> > |
| |||||||
| ||||||||
Line: 62 to 63 | ||||||||
Getting StartedThese instructions will get you a copy of the project up and running on your local | ||||||||
Changed: | ||||||||
< < | machine (STM32WB Feather Developer Board) for development and testing purposes. | |||||||
> > | machine (STM32WB Feather Developer Board) for development and testing purposes. | |||||||
Prerequisites |
Line: 1 to 1 | ||||||||
---|---|---|---|---|---|---|---|---|
%DASHBOARD{ section="banner" | ||||||||
Line: 20 to 20 | ||||||||
Added: | ||||||||
> > |
| |||||||
| ||||||||
Line: 59 to 95 | ||||||||
Mecrisp-Stellaris RA 2.5.4 by Matthias Koch. | ||||||||
Changed: | ||||||||
< < | Mecrisp-Cube 1.4.3 for STM32F405, 31/768 KiB RAM/FLASH dictionary (C) 2021 peter@spyr.ch * Firmware Package STM32Cube F4 V1.26.0, USB-CDC (C) 2021 STMicroelectronics | |||||||
> > | Mecrisp-Cube 1.4.4 for STM32WB Feather, 63/384 KiB RAM/FLASH dictionary (C) 2021 peter@spyr.ch * Firmware Package STM32Cube FW_WB V1.11.0, USB-CDC, BLE Stack 5.0 (C) 2021 STMicroelectronics | |||||||
* CMSIS-RTOS V2 FreeRTOS wrapper, FreeRTOS Kernel V10.3.1 (C) 2020 Amazon.com | ||||||||
Changed: | ||||||||
< < | * FatFs for serial flash and microSD - Generic FAT fs module R0.12c (C) 2017 ChaN | |||||||
> > | * 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 | ||||||||
Line: 66 to 102 | ||||||||
* tiny vi - part of BusyBox (C) 2000, 2001 Sterling Huxley include 0:/etc/rc.local | ||||||||
Deleted: | ||||||||
< < | ||||||||
23 5 / .[CR] 4 ok. : hello ." World" ;[CR] ok. hello[CR] World ok. | ||||||||
Added: | ||||||||
> > | Special Functions on StartupUSB-CDC is the default console.
Neopixel as Status IndicatorThe optional NeoPixel displays the status
| |||||||
Additional Tools and Local FilesystemPopulate a microSD with the contents of sdcard![]() | ||||||||
Line: 189 to 239 | ||||||||
Deleted: | ||||||||
< < | Adafruit Feather STM32F405 Express Board![]()
| |||||||
Line: 1 to 1 | ||||||||
---|---|---|---|---|---|---|---|---|
%DASHBOARD{ section="banner"
image="/twiki/pub/MecrispCube/BoardSupportPackageWBfeather/WB_Feather_header.jpg" | ||||||||
Changed: | ||||||||
< < | title="!MecrispCube for the STM32WB Feather Developer Board" | |||||||
> > | title="!MecrispCube for the STM32WB Feather Developer Board" | |||||||
titlestyle="color:#F00000;"
}%
Intro
| ||||||||
Line: 26 to 26 | ||||||||
Getting StartedThese instructions will get you a copy of the project up and running on your local | ||||||||
Changed: | ||||||||
< < | machine (Adafruit Feather STM32F405 Express board) for development and testing purposes. | |||||||
> > | machine (STM32WB Feather Developer Board) for development and testing purposes. | |||||||
Prerequisites | ||||||||
Changed: | ||||||||
< < |
| |||||||
> > |
| |||||||
Line: 38 to 38 | ||||||||
| ||||||||
Changed: | ||||||||
< < | Flash the Mecrisp-Cube binary![]() MecrispCubeF405.bin ) or the util-binary![]() MecrispCubeF405Util.bin ) to the Feather Board. | |||||||
> > | Flash the Mecrisp-Cube binary![]() MecrispCubeWBfeather.bin ) or the util-binary![]() MecrispCubeWBfeatherUtil.bin ) to the Feather Board. | |||||||
Changed: | ||||||||
< < |
| |||||||
> > |
| |||||||
Start the terminal emulator application on the PC.
Check for the serial communication port (e.g. for Linux /dev/ttyACM0 ). | ||||||||
Line: 75 to 74 | ||||||||
Additional Tools and Local Filesystem | ||||||||
Changed: | ||||||||
< < | Populate a microSD with the contents of sdcard![]() | |||||||
> > | Populate a microSD with the contents of sdcard![]() | |||||||
The directory should look like this:
| ||||||||
Line: 90 to 89 | ||||||||
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 | ||||||||
Changed: | ||||||||
< < | (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): | |||||||
> > | (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 8 Minutes): | |||||||
Changed: | ||||||||
< < | dd 1:/boot/fd-2MiB.img 0:[CR] | |||||||
> > | dd 1:/boot/fd-16MiB.img 0:[CR] | |||||||
ok. mount 0:[CR] ok. | ||||||||
Line: 102 to 101 | ||||||||
ok. | ||||||||
Changed: | ||||||||
< < | 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: | |||||||
> > | 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 util-binary![]() | |||||||
compiletoflash[CR] ok. include /etc/init.fs[CR] | ||||||||
Line: 150 to 149 | ||||||||
Get the sources from github:
| ||||||||
Changed: | ||||||||
< < | psi@homer:~> git clone --branch F405 https://github.com/spyren/Mecrisp-Cube![]() | |||||||
> > | psi@homer:~> git clone --branch WBfeather https://github.com/spyren/Mecrisp-Cube![]() | |||||||
Klone nach 'Mecrisp-Cube' ... remote: Enumerating objects: 1157, done. remote: Counting objects: 100% (1157/1157), done. | ||||||||
Line: 168 to 167 | ||||||||
Browse to Mecrisp-Cube directory | ||||||||
Changed: | ||||||||
< < | Generate code from the STM32CubeMX MecrispCubeF405.ioc file: | |||||||
> > | Generate code from the STM32CubeMX MecrispCubeWBfeather.ioc file: | |||||||
Project -> Generate Code |
Line: 1 to 1 | ||||||||
---|---|---|---|---|---|---|---|---|
Added: | ||||||||
> > |
MecrispCube for the STM32WB Feather Developer Board
Intro
Instant real-time programming with Forth.
Sources on GitHub
![]() Getting StartedThese instructions will get you a copy of the project up and running on your local machine (Adafruit Feather STM32F405 Express board) for development and testing purposes.Prerequisites
![]() MecrispCubeF405.bin ) or the util-binary![]() MecrispCubeF405Util.bin ) to the Feather Board.
/dev/ttyACM0 ).
I set the putty terminal configuration to
Mecrisp-Stellaris RA 2.5.4 by Matthias Koch. Mecrisp-Cube 1.4.3 for STM32F405, 31/768 KiB RAM/FLASH dictionary (C) 2021 peter@spyr.ch * Firmware Package STM32Cube F4 V1.26.0, USB-CDC (C) 2021 STMicroelectronics * CMSIS-RTOS V2 FreeRTOS wrapper, FreeRTOS Kernel V10.3.1 (C) 2020 Amazon.com * FatFs for serial 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. Additional Tools and Local FilesystemPopulate a microSD with the contents of sdcard![]() 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-2MiB.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:
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 ]! InstallingA step by step series of examples that tell you how to get a development env running Install the IDE STM32CubeIDE![]() ![]() psi@homer:~> git clone --branch F405 https://github.com/spyren/Mecrisp-Cube Klone nach 'Mecrisp-Cube' ... remote: Enumerating objects: 1157, done. remote: Counting objects: 100% (1157/1157), done. remote: Compressing objects: 100% (620/620), done. remote: Total 3183 (delta 720), reused 934 (delta 525), pack-reused 2026 Empfange Objekte: 100% (3183/3183), 41.60 MiB | 6.96 MiB/s, Fertig. Löse Unterschiede auf: 100% (2100/2100), Fertig.Import the project into the IDE: File -> Import -> General -> Existing Projects into Workspace -> Select root directory Copy project into workspace Browse to Mecrisp-Cube directoryGenerate code from the STM32CubeMX MecrispCubeF405.ioc file:
Project -> Generate CodeRestore changed source files $ git status {list of changed files} $ git restore {files to restore}Select the Build Configuration (Debug if you want to debug the project) and Build the project: Project -> Build Configurations -> Set Active -> Debug/Release Project -> Build Project Adafruit Feather STM32F405 Express Board![]()
![]() ![]() This work by Peter Schmid is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License.
|