Shell 65c9947225
[libcpu] rv64: support for ARCH_REMAP_KERNEL (#9067)
* [libcpu] support for ARCH_REMAP_KERNEL

These changes introduce support for the ARCH_REMAP_KERNEL configuration,
which isolates kernel space in high virtual address regions. This feature
is necessary to enhance memory protection and management by segregating
user and kernel spaces more effectively.

Changes:
- Updated conditional macros to check for ARCH_REMAP_KERNEL instead of
  ARCH_KERNEL_IN_HIGH_VA in board initialization files to reflect the new
  configuration option.
- Modified qemu-virt64-riscv Kconfig and SConstruct files to include and
  utilize ARCH_REMAP_KERNEL.
- Created a new linker script `link_smart.lds` for smart linking in qemu-virt64-riscv.
- Updated rtconfig.py to use a more flexible execution path setup.
- Enhanced user address space definitions in `lwp_arch.h` to support the
  new virtual address mappings.
- Adjusted kernel memory initialization and mapping logic in `c906/mmu.c`
  and `virt64/mmu.c` to account for high virtual address regions.
- Added Kconfig option to enable ARCH_REMAP_KERNEL for RISCV64 architectures.
- Enhanced memory setup functions to support new mapping scheme, including
  updates to early page table setup and address relocation logic.

These modifications ensure that the system can utilize high memory
addresses for the kernel, improving memory isolation and system stability.

Signed-off-by: Shell <smokewood@qq.com>

* fixup: CI run failed

* bsp: default config without using smart

* fixup: static checks

* restore rt_hw_mmu_kernel_map_init for D1

---------

Signed-off-by: Shell <smokewood@qq.com>
2024-06-18 11:15:59 +08:00
..
2024-03-21 11:23:29 +08:00
2024-03-21 11:23:29 +08:00
2023-06-30 21:00:18 +08:00
2023-06-30 21:00:18 +08:00

English | 中文

BL808 Board Support Package Documentation

1. Introduction

BL808 is a highly integrated AIoT chip with wireless connectivity units such as Wi-Fi/BT/BLE/Zigbee, multiple CPUs, audio and video codec, and AI hardware accelerator. It is suitable for various high-performance and low-power applications.

The BL808 chip consists of two subsystems: wireless and multimedia.

The wireless subsystem includes a RISC-V 32-bit high-performance CPU (m0) and integrated Wi-Fi/BT/Zigbee wireless subsystem, which enables various wireless connections and data transmission for diverse connectivity and user experiences. The multimedia subsystem includes a RISC-V 64-bit ultra-high-performance CPU (d0) and integrated DVP/CSI/H264/NPU video processing modules, which can be widely used in video surveillance, smart speakers, and other AI applications.

The components of the multimedia subsystem include:

  • NPU HW NN co-processor (BLAI-100) for AI applications
  • Camera interface
  • Audio codec
  • Video codec
  • Sensors
  • Display interface

The power management unit controls the low-power mode. It also supports various security features.

Peripheral interfaces include USB2.0, Ethernet, SD/MMC, SPI, UART, I2C, I2S, PWM, GPDAC/GPADC, ACOMP, PIR, Touch, IR remote, Display, and GPIO.

It supports flexible GPIO configuration, with a maximum of 40 GPIO pins.

The chip specifications are as follows:

Hardware Description
Chip Model bl808
CPU Three-core heterogeneous RISC-V CPUs:
RV64GCV 480MHz
RV32GCP 320MHz
RV32EMC 160MHz
RAM 768KB SRAM + 64MB UHS PSRAM
Peripherals Built-in AES and SHA256 algorithm accelerators
AI NN general hardware accelerator BLAI-100 for video/audio detection/recognition, 100GOPS computational power
Camera Interface DVP and MIPI-CSI
Display Interface SPI, DBI, DPI (RGB)
Wireless Supports Wi-Fi 802.11 b/g/n
Supports Bluetooth 5.x Dual-mode (BT+BLE)
Supports Wi-Fi/Bluetooth coexistence

2. RT-Thread Versions

BL808 is a three-core heterogeneous architecture, including m0, lp, and d0 cores. The current BSP supports all three cores running simultaneously and uses different RT-Thread versions for each core.

Name Core RT-Thread Version
M0 E907 RT-Thread Standard Edition
LP E902 RT-Thread Nano
D0 C906 RT-SMART

3. Compilation Instructions

BL808 is a three-core heterogeneous architecture, including m0, lp, and d0 cores. Each core needs to be compiled separately and burned to the corresponding location.

Flashing addresses:

Name Core Flash Address Description
M0 E907 0x00000
LP E902 0xC0000 Modify the lp flash address in bsp/bouffalo_lab/bl808/lp/board/linker_scripts/bl808_flash_lp.ld and bsp/bouffalo_lab/bl808/m0/board/board.h CONFIG_LP_FLASH_ADDR address
D0 C906 0x100000 Set in the SPL file. To adjust the d0 flash address, the SPL file and the packaged file bsp/bouffalo_lab/bl808/d0/merge_rtsmart.py need to be recompiled

3.1. m0/lp

  • Toolchain Download

Download the RISC-V toolchain from Download Link 1 or Download Link 2.

For Windows, use the [env tool][1] and extract the cross-compiler with the command tar -xvf Xuantie-900-gcc-elf-newlib-mingw-V2.6.1-20220906.tar.gz. Extracting the cross-compiler directly with Windows tools may cause compilation errors on Windows.

Add the path of the RISC-V toolchain to EXEC_PATH in rtconfig.py or specify the path using the RTT_EXEC_PATH environment variable.

Windows:

set RTT_EXEC_PATH=C:\Users\xxxx\Downloads\Xuantie-900-gcc-elf-newlib-x86_64-V2.6.1\bin

Linux:

export RTT_EXEC_PATH=/opt/Xuantie-900-gcc-elf-newlib-x86_64-V2.6.1/bin
  • Compilation

For Windows, it is recommended to use the [env tool][1]. Open the console and navigate to the bsp/bl808 directory, then select the core, m0 or lp, and run:

cd bsp/bl808/m0
menuconfig
pkgs --update

If you are using Linux, you can execute:

scons --menuconfig

It will automatically download the env-related scripts to the ~/.env directory, then execute:

source ~/.env/env.sh

cd bsp/bl808/m0
pkgs --update

After updating the software packages, use the command scons -j10 or scons -j10 --verbose to compile the board support package. Alternatively, you can use the scons --exec-path="GCC toolchain path" command to specify the toolchain path and compile at the same time.

If the compilation is successful, the rtthread.elf and rtthread_m0.bin files will be generated. The rtthread_m0.bin file needs to be burned into the device for execution.

  • Note

    Since BL808 is a three-core heterogeneous architecture, the lp and d0 cores are started through the m0 core. It is necessary to burn the m0 core correctly to enable all three cores to run properly.

    Configuration file for m0 flashing: bsp/bouffalo_lab/bl808/m0/flash_prog_cfg.ini

3.2. d0

bl808-d0 runs in S-mode and supports RT-Smart. The cross-compiler used is riscv64-unknown-linux-musl-gcc. Please refer to the Build Kernel Image for compilation instructions.

The starting address of the kernel virtual address is 0x50000000.

kernel_start

After the bl808-d0 is compiled, use the merge_rtsmart.py script to merge hw.dtb.5M, spl_bl808_d0.bin, opensbi_v0.6.bin, and rtthread_d0.bin into the final flash file whole_img_d0.bin, which should be burned at address 0x100000. Otherwise, the board will not be able to start.

The pre-compiled bin files are located in the bsp/bouffalo_lab/bl808/d0/pre_build_bin folder. If there are any modification requirements, you can download the Low-Starup-BL808 repository and modify it.

The separate flashing file for d0 is bsp/bouffalo_lab/bl808/d0/flash_prog_cfg.ini.

d0

3.3. Compilation and Flashing of Three Cores Simultaneously

  • You can run bsp/bouffalo_lab/bl808/build_bl808_all.sh to compile m0, lp, d0 cores one by one.
  • You can use the bsp/bouffalo_lab/bl808/flash_prog_cfg.ini flashing configuration file to flash m0, lp, and d0 cores simultaneously.

bl808

4. FAQ

  • In a Windows environment, when connecting the development board to the computer via the UART interface, only two USB converter devices are recognized, but the corresponding serial port device is not recognized.
    • Go to Device Manager, right-click on the corresponding USB converter device, go to Properties, and in the Advanced Settings, check the vcp option. After refreshing, you will see the corresponding serial port device.
    • Alternatively, you can install the following driver to solve the problem: https://dl.sipeed.com/shareURL/MAIX/tools/ftdi_vcp_driver
  • When connecting the computer to the board's UART port using a TypeC data cable, two serial ports will appear on the computer (if the mouse cannot move, unplug the USB and check Updating the board's bl702 firmware for a solution).