0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

HPM SDK指南 | 我的板子我做主!

先楫半導體HPMicro ? 2022-12-12 17:56 ? 次閱讀

本文介紹了基于HPM SDK如何新建一個新的工程供用戶項目開發(fā),包括HPM SDK代碼結構介紹,新BOARD適配驅動運行以及新工程的建立和注意事項。

先楫半導體面向用戶同時提供HPM SDK的集成工具集sdk_env,本文的介紹基于hpm sdk版本0.14.0,基于工具集sdk_env_v0.14.0。搭配以下費教授的教程視頻,體驗更佳哦,趕緊來一睹為快!

【先楫“芯”教程】如何創(chuàng)建HPM_SDK例程?

----- 以下為本指南的詳細內(nèi)容 -----?

HPMSDK組成結構介紹

一、SDK ENV組成結構

整個SDK ENV組成結構如下圖所示:

d12bf0be-78aa-11ed-b116-dac502259ad0.png

doc:主要是先楫半導體官方開發(fā)的用戶指導手冊,包含 HPM6750EVK和HPM6750EVK mini的用戶指導手冊。

hpm_sdk: HPM SDK的核心軟件包。

toolchains:編譯工具鏈,主要為rv32imadc-ilp32d-x86_64-w64-mingw32

tools:主要第三方軟件和相應的處理腳本。

其他:SDK運行環(huán)境配置腳本和說明文件。

二、HPM SDK核心軟件包架構

SDK核心軟件包主要是支持完成應用軟件開發(fā)的各種組件,包含了驅動、板級支持文件、中間件、soc定義文件、實例、處理腳本、幫助文件等。如下圖所示

d1529bc4-78aa-11ed-b116-dac502259ad0.png

各個目錄的主要內(nèi)容:

arch:risc-v架構相關的操作接口。

boards:與開發(fā)板相關的硬件定義和接口,主要為HPM6300EVK、HPM6750 EVK和HPM6750 EVK mini相關的板卡硬件信息。

cmake:與cmake和工程管理相關配置文件。

components:常用板載模塊驅動、處理邏輯和控制接口,包括camera、codec、debug_console、enet_phy、serial_nor、touch、usb等。

doc:SDK支持文檔和軟件API的支持文檔。

drivers:soc片上硬件模塊驅動、處理邏輯和控制接口。

middleware:常見算法庫、圖形庫、組件庫、RTOS等。

samples:各種應用例程。

script:與工程管理、編譯相關的處理腳本。

soc:soc片上資源寄存器定義。

utils:其他通用處理組件。

其他:處理腳步和說明文件。

新 board 添加適配

集成工具集sdk_env壓縮包解壓目錄下的start_cmd.cmd腳本可以啟動命令行環(huán)境sdk prompt, 可通過命令generate_project -list 查看當前支持的boards,可以查詢到當前支持的boards如下:

hpm6300evk

hpm6750evk

hpm6750evk2

hpm6750evkmini

d17c4e4c-78aa-11ed-b116-dac502259ad0.png

在目錄hpm_sdk/boards下添加新board目錄,例如名稱:hpm6750demo,如下:

d1930e0c-78aa-11ed-b116-dac502259ad0.png

參考官方board添加新board的適配code,代碼介紹如下:

注:建議按照官方代碼結構添加。

d1a9bd3c-78aa-11ed-b116-dac502259ad0.png

board.c:新board硬件初始化,包括clock/console/pmp/ahb等以新board實際硬件添加相關code。

pinmux.c:新board硬件pin腳復用選擇,以新board實際外設功能添加相關code(可使用HPM pinmux tool 泡泡龍工具自動生成)。

CMakeList.txt: cmake構建腳本文件,必須添加。

hpm6750evk.yaml:yaml配置文件, 名稱同新board名稱一致。文件中包含了board的相關信息,包括openocd 仿真器的相關信息。

*openocd目錄下同步添加board cfg文件:

d1c8c768-78aa-11ed-b116-dac502259ad0.png

board硬件初始化核心內(nèi)容詳解:

注意:新board以實際功能添加、刪減、修改。


(1).flash配置信息:在區(qū)域.nor_cfg_option存放flash的配置信息,包括:flash類型、頻率、電壓、片選等。

注:當新board外掛的flash和官方的型號參數(shù)不一致時,注意修改此配置。

#if defined(FLASH_XIP) && FLASH_XIP__attribute__ ((section(".nor_cfg_option"))) const uint32_t option[4] = {0xfcf90001, 0x00000007, 0x0, 0x0};#endif

(2).UF2固件頭部的簽名信息:當固件是UF2類型,簽名存放在空間.uf2_signature區(qū)域。

if defined(FLASH_UF2) && FLASH_UF2ATTR_PLACE_AT(".uf2_signature") const uint32_t uf2_signature = BOARD_UF2_SIGNATURE;#endif

(3).終端初始化:串口終端初始化。

void board_init_console(void)

(4).時鐘初始化:系統(tǒng)時鐘及各個外設IP時鐘組選擇初始化。

void board_init_clock(void)

(5).外設初始化及外設時鐘源配置:各個外設的初始化,包括PINMUX及功能配置。

//外設初始化void board_init_uart(UART_Type *ptr) //UART 串口初始化void board_init_ahb(void) //AHB總線初始化void board_init_sdram_pins(void) //SDRAM PIN初始化void board_init_lcd(void) //LCD初始化void board_init_i2c(I2C_Type *ptr) //I2C初始化void board_init_cap_touch(void) //TOUCH觸摸屏初始化void board_init_gpio_pins(void) //GPIO PIN初始化void board_init_spi_pins(SPI_Type *ptr) //SPI PIN初始化void board_init_led_pins(void) //LED PIN初始化void board_init_cam_pins(void) //CAM PIN初始化void board_init_can(CAN_Type *ptr) //CAN 初始化void board_init_sd_pins(SDXC_Type *ptr) //SD PIN初始化void board_init_usb_pins(void) //USB PIN初始化void board_init_pmp(void) //PMP 初始化void board_init_adc12_pins(void) //ADC12 PIN初始化

void board_init_adc16_pins(void) //ADC16 PIN初始化hpm_stat_t board_init_enet_pins(ENET_Type *ptr) //ENEN PIN初始化//外設時鐘源配置uint32_t board_init_spi_clock(SPI_Type *ptr) //SPI CLOCK配置uint32_t board_init_uart_clock(UART_Type *ptr) //UART CLOCK配置uint32_t board_init_dram_clock(void) //DRAM CLOCK配置uint32_t board_init_lcd_clock(void) //LCD CLOCK 配置uint32_t board_init_cam_clock(CAM_Type *ptr) //CAM CLOCK配置uint32_t board_init_adc12_clock(ADC12_Type *ptr) //ADC12 CLOCK配置uint32_t board_init_dao_clock(void) //DAO CLOCK配置uint32_t board_init_pdm_clock(void) //PDM CLOCK配置uint32_t board_init_i2s_clock(I2S_Type *ptr) //I2S CLOCK 配置uint32_t board_init_adc16_clock(ADC16_Type *ptr) //ADC16 CLOCK配置uint32_t board_init_can_clock(CAN_Type *ptr) //CAN CLOCK配置uint32_t board_sd_configure_clock(SDXC_Type *ptr, uint32_t freq) //SD CLOCK配置hpm_stat_t board_init_enet_ptp_clock(ENET_Type *ptr) //ENET PTP CLOCK配置hpm_stat_t board_init_enet_rmii_reference_clock(ENET_Type *ptr, bool internal) //ENET RMII CLOCK配置hpm_stat_t board_init_enet_rgmii_clock_delay(ENET_Type *ptr) //ENET RGMII delay CLOCK配置

(6). 外部SDRAM初始化:外部SDRAM初始化。

注意:當初始數(shù)據(jù)有放到外部SDRAM,必須要定義宏:INIT_EXT_RAM_FOR_DATA。(此函數(shù)在啟動start.s中被調(diào)用)

#ifdef INIT_EXT_RAM_FOR_DATA/** this function will be called during startup to initialize external memory for data use*/void _init_ext_ram(void)

通過命令generate_project -list 查看當前支持的boards:

d1e1be12-78aa-11ed-b116-dac502259ad0.png

新 工 程 創(chuàng) 建

在目錄hpm_sdk/samples 下包含了官方的所有參考用例。參考官方用例來創(chuàng)建新的工程,新的工程路徑原則上是任意的,建議用戶放到hpm_sdk之外的目錄,方便用戶后續(xù)更新hpm_sdk而不影響用戶工程。例如創(chuàng)建兩個工程demo1,demo2,路徑和hpm_sdk在同一個目錄下:

d1fb07d2-78aa-11ed-b116-dac502259ad0.png

新工程組成介紹:

d21a880a-78aa-11ed-b116-dac502259ad0.png

CMakeList.txt:cmake構建腳本文件,必須添加。

Linkers當前工程使用的linker文件。當然也可以通過-t 使用官方的linker文件。

inc:工程頭文件。

src:工程源文件。

CMakeList.txt腳本文件內(nèi)容介紹:

d237260e-78aa-11ed-b116-dac502259ad0.png

cmake_minimum_required(xxx):cmake最低版本要求,使用默認3.13即可。

set(xxx):設置要使用到的中間件、組件或linker文件。例如:set(CONFIG_LVGL 1)使能中間件LVGL(middleware/littlevgl)。set(CUSTOM_GCC_LINKER_FILE xxx)設置工程使用的linker文件。

set_compile_definitions(xxx):設置編譯器選項及宏定義。例如:set_compile_definitions(-DFLASH_XIP=1):宏定義 FLASH_XIP=1

注意:如果是FLASH_XIP的方式,一定要宏定義FLASH_XIP=1;如果初始數(shù)據(jù)使用了外部SDRAM,一定要宏定義INIT_EXT_RAM_FOR_DATA=1;或通過構建命令-t 指定。當-t指定工程類型,則當前cmakelist.txtset(CUSTOM_GCC_LINKER_FILE)指定的linker文件無效;

project(xxx): 工程名稱xxx。例如:project(demo1),demo1工程。

sdk_inc(xxx):工程頭文件路徑。

sdk_app_src(xxx):工程源文件添加,也可使用sdk_ses_src(xxx)或sdk_gcc_src(xxx)來指定為SES工程文件還是GCC工程文件。

generate_ses_project(): 構建為ses工程。

通過命令:generate_project -b hpm6750demo -f 構建生成SES工程。

注意:如果cmakelist.txt中指定了linker文件及工程類型,無需-t指定。

d25ed578-78aa-11ed-b116-dac502259ad0.png

雙擊工程xxx_build/segger_embedded_studio/xxx.emProject文件,打開SES工程編譯調(diào)試。

d26f79c8-78aa-11ed-b116-dac502259ad0.png

至此新建工程已完成。本文主要介紹了基于sdk_env_v0.14.0如何新建一個工程。詳細介紹了新BOARD適配驅動運行以及新工程建立的注意事項。HPM SDK基于CMAKE工具來為Segger構建工程,同時用戶也可通過添加修改cmake腳本來快速新建工程,為用戶省去了繁瑣的工程配置及編譯調(diào)試環(huán)境配置,大大提升了用戶的開發(fā)效率。(欲了解參考文獻,可點擊“閱讀原文”獲取)


本期的內(nèi)容就分享到這兒,如果有其他感興趣的內(nèi)容,歡迎隨時留言給小編,先楫芯上人會在接下來的分享中陸續(xù)為大家呈現(xiàn)~

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • SDK
    SDK
    +關注

    關注

    3

    文章

    1015

    瀏覽量

    45612
  • HPM
    HPM
    +關注

    關注

    1

    文章

    23

    瀏覽量

    7705
收藏 人收藏

    評論

    相關推薦

    SDK里面是否能添加HPM5300系列芯片支持包?

    SDK里面是否能添加HPM5300系列芯片支持包?只發(fā)現(xiàn)板級支持包。
    發(fā)表于 09-27 10:01

    HPM SDK 1.6.0 FreeRTOS LTS更改及適配指南

    √√RISCV中斷向量模式支持×√Ticklessmode支持×√DSP擴展支持×√二、FreeRTOS新特性適配2.1支持tickless模式HPM_SDK1.6.0中使
    的頭像 發(fā)表于 07-06 08:17 ?486次閱讀
    <b class='flag-5'>HPM</b> <b class='flag-5'>SDK</b> 1.6.0 FreeRTOS LTS更改及適配<b class='flag-5'>指南</b>

    板子為什么測不了損耗

    關于損耗的測試需求真的是五花八門,今天我們就來一起簡單普及下為什么實物板可以測試阻抗而不能測損耗。
    的頭像 發(fā)表于 05-06 17:30 ?325次閱讀
    <b class='flag-5'>我</b>的<b class='flag-5'>板子</b>為什么測不了損耗

    先楫半導體 hpm_sdk v1.5.0 正式發(fā)布

    先楫半導體 hpm_sdk v1.5.0 正式發(fā)布
    的頭像 發(fā)表于 04-12 08:17 ?466次閱讀
    先楫半導體 <b class='flag-5'>hpm_sdk</b> v1.5.0 正式發(fā)布

    先楫半導體 hpm_sdk v1.5.0 正式發(fā)布

    先楫半導體 hpm_sdk v1.5.0 正式發(fā)布!功能升級更強大 版本更新概況 新支持的IDE IAR Embedded Workbench for RISC-V (測試版本3.20.1) 新增
    發(fā)表于 04-08 11:14

    先楫半導體hpm_sdk v1.5.0正式發(fā)布!

    可以將當前app所使用到hpm_sdk的文件復制到app本地, 同時更新app的CMakeLists.txt使之使用本地化之后的hpm_sdk。
    的頭像 發(fā)表于 04-08 10:02 ?815次閱讀
    先楫半導體<b class='flag-5'>hpm_sdk</b> v1.5.0正式發(fā)布!

    Linux 下編譯HPM_Math 工程報錯

    /hpm_sdk/samples/hpm_math/rfft/build roma@roma-PICO-TGU4 ~/t/c/h/h/s/h/r/build> cmake -GNinja
    發(fā)表于 12-20 12:54

    【先楫HPM5361EVK開發(fā)板試用體驗】coremark軟件跑分測試HPM5361EVK性能

    hpm5300evk,因為我們連接的是hpm5300evk SDK samples選中coremark,這里要測試coremark跑分程序 Build type選中flash_xip
    發(fā)表于 12-10 19:32

    【先楫HPM5361EVK開發(fā)板試用體驗】coremark軟件跑分測試HPM5361EVK性能

    hpm5300evk,因為我們連接的是hpm5300evk SDK samples選中coremark,這里要測試coremark跑分程序 Build type選中flash_xip
    發(fā)表于 12-07 10:15

    【先楫HPM5361EVK開發(fā)板試用體驗】coremark測試HPM5361EVK性能

    hpm5300evk,因為我們連接的是hpm5300evk SDK samples選中coremark,這里要測試coremark跑分程序 Build type選中flash_xip
    發(fā)表于 12-07 09:23

    【先楫HPM5361EVK開發(fā)板試用體驗】搭建開發(fā)環(huán)境1

    /hpmicro/hpm_sdk 下面總結了一下步驟: 1.安裝SEGGER Embedded Studio for RISC-V 下載地址:https://www.segger.com/downloads
    發(fā)表于 12-03 14:42

    HPM5300找不到的情況

    原來的沒有5300選項 后來的有了5300選項 注意是 hpm_sdk-main的下載地址:https://gitee.com/hpmicro 路徑參考: 這個問題不大,但困擾了3天,希望生態(tài)你的小伙伴不踩踩過的坑
    發(fā)表于 12-02 19:27

    【先楫HPM5361EVK開發(fā)板試用體驗】在windows系統(tǒng)下搭建開發(fā)環(huán)境

    _env 目前最新版的是v1.3.0 3.下載hpm_sdk 下載地址:https://github.com/hpmicro/hpm_sdk 4. 運行sdk_env的hello_world 解壓并進
    發(fā)表于 11-29 21:15

    哪位大佬發(fā)一下HPM5300的SDK壓縮包啊?

    哪位大佬發(fā)一下HPM5300的SDK壓縮包?。?
    發(fā)表于 11-29 12:55

    【先楫HPM5361EVK開發(fā)板試用體驗】-- HPM5361初體驗

    =a313eb8f-afbf-4d12-95a2-ce22bda8d3c0。 注意下載env SDK的界面是需要在先楫半導體官網(wǎng)注冊賬號才能下載的。SDK里面包括了HPM SDK代碼
    發(fā)表于 11-29 11:26