4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-22 22:47:33 +08:00
Fan Yang 96ba787e25
Bugfix/fix weak handle trap in riscv common crash rv64 trap handling (#9189)
* [bsp][hpmicro] add weak handle_trap implementation

- added weak handle_trap implementation

Signed-off-by: Fan YANG <fan.yang@hpmicro.com>

* [libcpu][risc-v][common] remove weak handle_trap function

- removed weak handle_trap function from trap_common.c

Signed-off-by: Fan YANG <fan.yang@hpmicro.com>

---------

Signed-off-by: Fan YANG <fan.yang@hpmicro.com>
2024-07-15 17:51:32 +08:00
..

HPMicro HPM5300EVK BSP(Board Support Package) Introduction

中文页 |

Introduction

This document provides brief introduction of the BSP (board support package) for the HPM5300EVK development board.

The document consists of the following parts:

  • HPM5300EVK Board Resources Introduction
  • Quickly Getting Started
  • Refreences

By reading the Quickly Get Started section developers can quickly get their hands on this BSP and run RT-Thread on the board. More advanced features will be introduced in the Advanced Features section to help developers take advantage of RT-Thread to drive more on-board resources.

Board Resources Introduction

HPM5300EVK is a development board based on the RISC-V core launched by HPMicro, with rich on-board resources and on-chip resources for motor control, etc. board

Peripheral Condition

Each peripheral supporting condition for this BSP is as follows:

On-board Peripherals Support Note
USB
QSPI Flash
GPIO
SPI
I2C
CAN
On-Board Debugger ft2232

Execution Instruction

Quickly Getting Started

The BSP support being build via the 'scons' command, below is the steps of compiling the example via the 'scons' command

Parpare Environment

  • Step 1: Prepare RT-Thread ENV
  • Step 2: Prepare toolcahin
    • Download the package and extract it into a specified directory, for example: C:\DevTools\riscv32-gnu-toolchain
  • Step 3: Set environment variable RTT_RISCV_TOOLCHAIN to <TOOLCHAIN_DIR>\bin
    • For example: C:\DevTools\riscv32-gnu-toolchain\bin
  • Step 4: Prepare OpenOCD
    • Download and extract it to specified directory, for example: C:\DevTools\openocd-hpmicro
    • Add OpenOCD environment variable OPENOCD_HPMICRO to <OPENOCD_HPMICRO_DIR>\bin
      • For example: C:\DevTools\openocd-hpmicro\bin

Configure and Build project

Open RT-Thread ENV command-line, and change directory to this BSP directory, then users can:

  • Configure the project via menuconfig in RT-Thread ENV
  • Build the project using scons -jN, N equals to the number of CPU cores
  • Clean the project using scons -c

Hardware Connection

  • Switch BOOT pin to 2'b00
  • Connect the PWR_DEBUG port to PC via TYPE-C cable

Dowload / Debug

  • Users can download the project via the below command:

    %OPENOCD_HPMICRO%\openocd.exe -f boards\debug_scripts\probes\ft2232.cfg -f boards\debug_scripts\soc\hpm5300.cfg -f boards\debug_scripts\boards\hpm5300evk.cfg -c "init; halt; flash write_image erase rtthread.elf; reset; shutdown"
    
  • Users can debug the project via the below command:

    • Connect debugger via OpenOCD:
%OPENOCD_HPMICRO%\openocd.exe -f boards\debug_scripts\probes\ft2232.cfg -f boards\debug_scripts\soc\hpm5300.cfg -f boards\debug_scripts\boards\hpm5300evk.cfg
  • Start Debugger via GDB:
%RTT_EXEC_PATH%\riscv32-unknown-elf-gdb.exe rtthread.elf
  • In the gdb shell, type the following commands:
load
c

Running Results

Once the project is successfully downloaded, the system runs automatically. The LED on the board will flash periodically.

Connect the serial port of the board to the PC, communicate with it via a serial terminal tool(115200-8-1-N). Reset the board and the startup information of RT-Thread will be observed:

 \ | /
- RT -     Thread Operating System
 / | \     5.1.0 build Aug 16 2023 18:18:18
 2006 - 2024 Copyright by RT-Thread team

References