Go to file
Yanfeng Liu 87c9a0ee76 risc-v/k230: add NUTTSBI based kernel build support
Previously k230 kernel build needs OpenSBI wrapping for use on
target, thus leading to larger program and memory overheads.
This patch adds alternative small overhead kernel build support.

Changes:

- in arch/risc-v/src/k230:
  - k230_head.S          entrance renamed for sake of NUTTSBI
  - k230_irq.c           add M-mode handling for NUTTSBI case
  - k230_mm_init.c       add L3 table for smaller RAM case
  - hardware/k230_plic.h add PLIC_CTRL definition
  - Make.defs            use CHIP_ASRCS to fix entrance selection
- in boards/risc-v/canmv230/scripts:
  - Make.defs            add support for NUTTSBI case

Additions:

- in boards/riscv/canmv230/:
  - scripts/ld-nuttsbi.script  link script for NUTTSBI case
  - configs/nsbi/defconfig     config for NUTTSBI case

The artifact nuttx.bin from this configuration can be used directly
on target as OpenSBI wrapping is not needed.

Signed-off-by: Yanfeng Liu <yfliu2008@qq.com>

fix typo
2024-01-17 10:31:29 -03:00
.github tools/ci: add initial support for MSYS2 2024-01-09 05:50:09 -08:00
arch risc-v/k230: add NUTTSBI based kernel build support 2024-01-17 10:31:29 -03:00
audio Documentation: remove all migrated READMEs 2023-10-29 21:03:54 -03:00
binfmt log messages of binfmt are very much. 2023-12-29 17:36:47 +08:00
boards risc-v/k230: add NUTTSBI based kernel build support 2024-01-17 10:31:29 -03:00
cmake Revert "cmake: restore old behavior for savedefconfig" 2023-12-20 16:05:19 +01:00
crypto sched: explicitly select the cpuload clock source configuration 2023-11-01 09:27:56 +08:00
Documentation docs/comments: fix some typos 2024-01-15 13:22:13 +08:00
drivers drivers/usbhost: Add a USB bluetooth driver. 2024-01-16 16:02:15 +01:00
dummy build: add initial cmake build system 2023-07-08 13:50:48 +08:00
fs rptun: Strip rpmsg and rptun 2024-01-16 15:58:32 +01:00
graphics poll: pollsetup should notify only one fd passd by caller 2023-11-21 09:07:17 +01:00
include drivers/usbhost: Add a USB bluetooth driver. 2024-01-16 16:02:15 +01:00
libs libcxx: Fix CMake compile with correct CMAKE_CXX_STANDARD 2024-01-16 21:54:30 -08:00
mm fs: procfs add poll support 2023-12-26 19:23:13 -08:00
net net/route: Support longest prefix match for routing 2024-01-09 05:58:10 -08:00
openamp rptun: Select OPENMAP under RPTUN 2023-12-28 11:08:57 +08:00
pass1
sched sched/logging: add task activation/exit logs 2024-01-14 23:04:42 -08:00
syscall sched/semaphore: Move named semaphores to user space 2023-11-27 04:52:54 -08:00
tools linux/Dockerfile: Add the python3 coloredlogs package for the matter build 2024-01-10 09:47:54 -08:00
video build: add initial cmake build system 2023-07-08 13:50:48 +08:00
wireless bluetooth: Prevent btsak from repeatedly showing the same error. 2024-01-14 02:16:48 -08:00
.asf.yaml
.gitignore .gitignore: Added ignore file .fakelnk 2024-01-08 17:38:27 -08:00
.yamllint
AUTHORS
CMakeLists.txt cmake: use -fvisibility=default for sim_head 2024-01-06 04:21:52 -08:00
CONTRIBUTING.md
INVIOLABLES.md
Kconfig xtensa/esp/rmt: Add the lower-half implementation of the RMT driver 2023-12-24 16:38:06 -08:00
LICENSE free disk space action added to fix docker image build issue 2023-12-08 14:42:17 +01:00
Makefile
NOTICE
README.md Gathering community recommendations 2023-10-28 13:55:56 +08:00
ReleaseNotes Documentation: move ReleaseNotes 2023-09-26 20:41:00 +08:00

POSIX Badge License Issues Tracking Badge Contributors GitHub Build Badge Documentation Badge

Apache NuttX is a real-time operating system (RTOS) with an emphasis on standards compliance and small footprint. Scalable from 8-bit to 64-bit microcontroller environments, the primary governing standards in NuttX are POSIX and ANSI standards. Additional standard APIs from Unix and other common RTOSs (such as VxWorks) are adopted for functionality not available under these standards, or for functionality that is not appropriate for deeply-embedded environments (such as fork()).

For brevity, many parts of the documentation will refer to Apache NuttX as simply NuttX.

Getting Started

First time on NuttX? Read the Getting Started guide! If you don't have a board available, NuttX has its own simulator that you can run on terminal.

Documentation

You can find the current NuttX documentation on the Documentation Page.

Alternatively, you can build the documentation yourself by following the Documentation Build Instructions.

The old NuttX documentation is still available in the Apache wiki.

Supported Boards

NuttX supports a wide variety of platforms. See the full list on the Supported Platforms page.

Contributing

If you wish to contribute to the NuttX project, read the Contributing guidelines for information on Git usage, coding standard, workflow and the NuttX principles.

License

The code in this repository is under either the Apache 2 license, or a license compatible with the Apache 2 license. See the License Page for more information.