2019-06-29 11:44:30 +02:00
|
|
|
/**
|
|
|
|
@defgroup boards_openlabs-kw41z-mini openlabs.co kw41z-mini board
|
|
|
|
@ingroup boards
|
|
|
|
@brief Support for openlabs-kw41z-mini
|
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
### General information
|
2019-06-29 11:44:30 +02:00
|
|
|
|
|
|
|
This is an open-source development board shipped by openlabs.co with
|
|
|
|
source files located at https://openlabs.co/OSHW/kw41z-mini
|
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
A driver for the radio transceiver is available in [#12277](https://github.com/RIOT-OS/RIOT/pull/12277)
|
|
|
|
(802.15.4 only).
|
2019-06-29 11:44:30 +02:00
|
|
|
|
2020-03-11 16:02:05 +01:00
|
|
|
@note A version of this board exists that comes with the `M41W8VT4` (256k ROM)
|
|
|
|
instead of the `M41W9VT4` (512k ROM). The boards are otherwise identical.
|
|
|
|
See @ref boards_openlabs-kw41z-mini-256kib if you happen to have this version.
|
2019-06-29 11:44:30 +02:00
|
|
|
|
|
|
|
### Programming Pinout
|
|
|
|
|
|
|
|
Programming and debugging can be done with a Raspberry Pi (or equivalent)
|
|
|
|
running OpenOCD.
|
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
Pi GPIO Pins kw41z-mini
|
|
|
|
====================================
|
|
|
|
||
|
|
|
|
GPIO_19 ------||------- RST
|
|
|
|
||
|
|
|
|
GPIO_20 ------||------- SWDCLK
|
|
|
|
||
|
|
|
|
GPIO_21 ------||------- SWDIO
|
|
|
|
||
|
|
|
|
3.3V -------||------- 3.3V
|
|
|
|
||
|
|
|
|
GND -------||------- GND
|
|
|
|
||
|
2019-06-29 11:44:30 +02:00
|
|
|
|
|
|
|
### Compiling and Flashing
|
|
|
|
|
|
|
|
# install build deps for openocd
|
2020-03-11 15:43:25 +01:00
|
|
|
|
|
|
|
apt install git build-essential libtool automake
|
|
|
|
|
2019-06-29 11:44:30 +02:00
|
|
|
# fetch and build openocd with support for JTAG via RPi or generic GPIO
|
2020-03-11 15:43:25 +01:00
|
|
|
|
|
|
|
git clone https://github.com/beduino-project/openocd.git
|
|
|
|
cd openocd
|
|
|
|
./bootstrap
|
|
|
|
./configure --enable-bcm2835gpio --enable-sysfsgpio
|
|
|
|
make -j4 && sudo make install
|
2019-06-29 11:44:30 +02:00
|
|
|
|
|
|
|
# install arm toolchain
|
2020-03-11 15:43:25 +01:00
|
|
|
|
|
|
|
apt install git gcc-arm-none-eabi gdb-arm-none-eabi
|
|
|
|
|
2019-06-29 11:44:30 +02:00
|
|
|
# fetch Riot
|
2020-03-11 15:43:25 +01:00
|
|
|
|
|
|
|
git clone https://github.com/RIOT-OS/RIOT.git
|
|
|
|
|
2019-06-29 11:44:30 +02:00
|
|
|
# build and flash the gnrc_networking example
|
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
cd RIOT/examples/gnrc_networking
|
|
|
|
BOARD=openlabs-kw41z-mini CFLAGS+="-DKW41ZRF_ENABLE_LEDS=1" make -j4 flash
|
2019-06-29 11:44:30 +02:00
|
|
|
|
|
|
|
### Debug Uart Pinout
|
|
|
|
|
|
|
|
It is also possible to use the Pi for connecting to the debug uart.
|
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
Pi GPIO Pins kw41z-mini
|
|
|
|
==================================
|
|
|
|
||
|
|
|
|
UART TX ----||------ RXI
|
|
|
|
||
|
|
|
|
UART RX ----||------ TXO
|
|
|
|
||
|
|
|
|
GND ------||------ GND
|
|
|
|
||
|
2019-06-29 11:44:30 +02:00
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
# enable the uart on the Pi
|
2019-06-29 11:44:30 +02:00
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
echo "enable_uart=1" >> /boot/config.txt
|
|
|
|
reboot
|
2019-06-29 11:44:30 +02:00
|
|
|
|
|
|
|
# install serial terminal
|
2020-03-11 15:43:25 +01:00
|
|
|
|
|
|
|
apt install picocom
|
|
|
|
|
2019-06-29 11:44:30 +02:00
|
|
|
# run serial terminal to access debug uart
|
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
picocom -b115200 /dev/serial0
|
2019-06-29 11:44:30 +02:00
|
|
|
|
|
|
|
It is recommended (if possible) to switch the Pi to the better-clocked
|
|
|
|
uart for higher baud rates:
|
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
echo "dtoverlay=disable-bt" >> /boot/config.txt
|
|
|
|
reboot
|
2019-06-29 11:44:30 +02:00
|
|
|
|
|
|
|
### Notes
|
|
|
|
|
|
|
|
To get a working radio, add #12277 and uncomment the lines in
|
2020-03-11 15:43:25 +01:00
|
|
|
`boards/openlabs-kw41z-mini/Makefile.dep`
|
2019-06-29 11:44:30 +02:00
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
The DAC output is on pin `PTB18`.
|
2019-06-29 11:44:30 +02:00
|
|
|
|
2020-03-11 15:43:25 +01:00
|
|
|
ADC input A3 needs a hack applied to `cpu/kinetis/periph/adc.c` to remove
|
|
|
|
`ADC_CFG2_MUXSEL_MASK` from `CFG2` to switch to the correct mux setting.
|
2019-06-29 11:44:30 +02:00
|
|
|
|
|
|
|
The PWM peripheral on this board isn't supported in the Kinetis PWM driver yet.
|
|
|
|
|
|
|
|
Use external I2C pullup resistors if I2C is used.
|
|
|
|
*/
|