2019-12-31 16:06:20 +01:00
|
|
|
1. Download and install toolchain and openocd-k210
|
|
|
|
|
|
|
|
$ curl https://static.dev.sifive.com/dev-tools/riscv64-unknown-elf-gcc-8.3.0-2019.08.0-x86_64-linux-ubuntu14.tar.gz
|
2021-05-24 11:48:55 +02:00
|
|
|
$ export PATH=$PATH:/$TOOL_CHAIN_PATH/bin
|
2019-12-31 16:06:20 +01:00
|
|
|
|
|
|
|
2. Build openocd-k210
|
|
|
|
|
|
|
|
$ git clone https://github.com/kendryte/openocd-kendryte
|
|
|
|
$ cd openocd-kendryte
|
|
|
|
$ ./bootstrap & ./configure & make
|
|
|
|
|
|
|
|
3. Configure and build NuttX
|
|
|
|
|
|
|
|
$ mkdir ./nuttx; cd ./nuttx
|
2022-11-22 19:59:48 +01:00
|
|
|
$ git clone https://github.com/apache/nuttx.git nuttx
|
|
|
|
$ git clone https://github.com/apache/nuttx-apps.git apps
|
2019-12-31 16:06:20 +01:00
|
|
|
$ cd nuttx
|
|
|
|
$ make distclean
|
|
|
|
$ ./tools/configure.sh maix-bit:nsh
|
|
|
|
$ make V=1
|
|
|
|
|
|
|
|
4. Download and run the nuttx from SRAM (not SPI-Flash)
|
|
|
|
|
|
|
|
$ picocom -b 115200 /dev/ttyUSB0
|
|
|
|
$ sudo ./src/openocd -s ./tcl -f ./tcl/kendryte.cfg -m 0
|
|
|
|
$ riscv64-unknown-elf-gdb ./nuttx
|
|
|
|
(gdb) target extended-remote :3333
|
|
|
|
(gdb) load nuttx
|
|
|
|
(gdb) c
|
|
|
|
|
2020-05-05 02:16:54 +02:00
|
|
|
5. Write nuttx.bin to SPI-Flash
|
|
|
|
|
|
|
|
$ pip3 install kflash
|
|
|
|
$ kflash -p /dev/ttyUSB0 -b 1500000 ./nuttx/nuttx.bin
|
|
|
|
|
2021-01-28 23:59:14 +01:00
|
|
|
NOTE: The kflash_gui is not recommended because it's unstable
|
|
|
|
|
2020-05-05 02:16:54 +02:00
|
|
|
6. TODO
|
2019-12-31 16:06:20 +01:00
|
|
|
|
|
|
|
Support peripherals such as GPIO/SPI/I2C/...
|
2020-01-10 15:04:41 +01:00
|
|
|
Support FPU
|
2021-04-09 06:08:54 +02:00
|
|
|
Support RISC-V U-mode including memory protection
|