2019-12-31 23:06:20 +08: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
|
|
|
|
|
|
|
|
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
|
2021-01-20 19:53:13 +08:00
|
|
|
$ git clone https://github.com/apache/incubator-nuttx.git
|
|
|
|
$ git clone https://github.com/apache/incubator-nuttx-apps.git
|
2019-12-31 23:06:20 +08: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 08:16:54 +08:00
|
|
|
5. Write nuttx.bin to SPI-Flash
|
|
|
|
|
|
|
|
$ pip3 install kflash
|
|
|
|
$ kflash -p /dev/ttyUSB0 -b 1500000 ./nuttx/nuttx.bin
|
|
|
|
|
2021-01-29 06:59:14 +08:00
|
|
|
NOTE: The kflash_gui is not recommended because it's unstable
|
|
|
|
|
2020-05-05 08:16:54 +08:00
|
|
|
6. TODO
|
2019-12-31 23:06:20 +08:00
|
|
|
|
|
|
|
Support peripherals such as GPIO/SPI/I2C/...
|
2020-01-10 22:04:41 +08:00
|
|
|
Support FPU
|
2021-04-09 12:08:54 +08:00
|
|
|
Support RISC-V U-mode including memory protection
|