色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

DshanMCU-R128s2 SDK 架構與目錄結構

嵌入式Linux那些事 ? 來源:嵌入式Linux那些事 ? 作者:嵌入式Linux那些事 ? 2023-12-22 15:57 ? 次閱讀

R128 S2 是全志提供的一款 M33(ARM)+C906(RISCV-64)+HIFI5(Xtensa) 三核異構 SoC,同時芯片內部 SIP 有 1M SRAM、8M LSPSRAM、8M HSPSRAM 以及 16M NORFLASH。

本文檔作為 R128 FreeRTOS SDK 開發指南,旨在幫助軟件開發工程師、技術支持工程師快速上手,熟悉 R128 FreeRTOS SDK 的開發流程。

SDK 架構

R128 包含 3 個核,需要編譯 M33+C906+HIFI5 共3 個核的鏡像。啟動時同時運行三個 RTOS 系統。其中 M33 與 C906 使用的是 FreeRTOS v10.4.3,從 [https://www.freertos.org/RTOS.html] 獲取,HIFI5 使用的 FreeRTOS 是根據Cadence Support 的推薦的 [https://github.com/foss?xtensa/amazon?freertos](tag:v1.7?xtensa)版本

開發 HIFI5 需要 Cadence Xtensa 的 IDE 工具, DSP 的 XCC 工具鏈包。Cadence Xtensa 的授權 License,用于服務器代碼編譯和 Xplorer 仿真使用。 這些工具需要向 Cadence 申請授權 ,鏈接:[https://www.cadence.com/en_US/home/tools/ip/tensilica-ip/technologies.html],Xplorer 下載鏈接:[https://www.cadence.com/en_US/home/tools/ip/tensilica-ip/sdk-download.html]

SDK 軟件框架

image1

R128 軟件框架如上圖所示,一共4 層,分別為硬件層、內核層、組件層、應用層。

  • Hardware。硬件層包括處理器、內存、存儲介質、無線網卡、總線以及外設等。
  • Kernel。內核層包括FreeRTOS 核心系統、文件系統、網絡系統、BSP 驅動等。
  • Component。組件層包括控制臺、多媒體、功耗管理、OTA、音頻系統、顯示系統、圖像采集等。
  • APP。應用層包括各種應用demo。

SDK 目錄結構

以R128-S2芯片為例,SDK 目錄結構如下,重點目錄進行了展開處理

.
├── board               # 板級配置目錄
│   ├── common          # 公共板級配置目錄
│   │   ├── configs     # 公共板級配置
│   │   └── data        # 公共數據
│   │       ├── reserve # Wi-Fi & BT 固件
│   │       ├── secret  # 公共安全區
│   │       └── UDISK   # 公共 UDISK 分區
│   └── r128s2          # R128 S2 芯片配置目錄
│       ├── 86panel     # R128 S2 86面板開發板 板級配置目錄
│       │   ├── bin     # 86面板開發板固件,引導等bin
│       │   ├── configs # 86面板開發板配置文件,引腳復用,分區表等配置文件
│       │   │   └── ota # 86面板開發板配置文件,OTA相關配置文件
│       │   └── data    # 86面板開發板數據
│       │       ├── reserve
│       │       ├── secret
│       │       └── UDISK
│       └── module      # R128 S2 Module 模塊板級配置目錄
│           ├── bin     # R128 S2 Module 固件,引導等bin
│           ├── configs # R128 S2 Module 配置文件,引腳復用,分區表等配置文件
│           │   └── ota # R128 S2 Module 配置文件,OTA相關配置文件
│           └── data    # R128 S2 Module 數據
│               ├── reserve
│               ├── secret
│               └── UDISK
├── lichee              # 系統源碼目錄
│   ├── brandy-2.0      # 啟動相關目錄
│   │   ├── tools       # U-Boot 使用的工具鏈
│   │   └── u-boot-2018 # U-Boot 啟動代碼
│   ├── rtos            # M33/C906 FreeRTOS 系統、組件、應用
│   │   ├── arch        # 處理器架構相關代碼
│   │   │   ├── arm     # ARM 處理器初始化、中斷處理、異常處理、內存映射相關功能的實現
│   │   │   │   ├── armv8m
│   │   │   │   └── common
│   │   │   ├── common
│   │   │   └── risc-v  # RISC-V 處理器初始化、中斷處理、異常處理、內存映射相關功能的實現
│   │   │       ├── c906
│   │   │       ├── common
│   │   │       ├── includes
│   │   │       └── sun20iw2p1
│   │   ├── build       # 編譯臨時文件輸出目錄
│   │   ├── components  # 應用組件,libc、多媒體、lvgl
│   │   │   ├── aw      # Allwinner 提供的組件
│   │   │   │   ├── blkpart
│   │   │   │   ├── bluetooth
│   │   │   │   ├── ...
│   │   │   │   └── wireless_video
│   │   │   ├── common - > ../../rtos-components
│   │   │   └── thirdparty # 第三方提供的組件
│   │   │       ├── common
│   │   │       ├── console
│   │   │       ├── ...
│   │   │       └── vfs
│   │   ├── drivers     # RTOS 驅動
│   │   │   ├── drv
│   │   │   │   ├── bluetooth
│   │   │   │   ├── ...
│   │   │   │   └── wireless
│   │   │   ├── osal
│   │   │   │   └── src
│   │   │   └── rtos-hal - > ../../rtos-hal/
│   │   ├── include     # RTOS 頭文件目錄
│   │   │   ├── arch    # 架構相關頭文件
│   │   │   │   ├── arm
│   │   │   │   └── riscv
│   │   │   ├── drivers # 驅動相關頭文件
│   │   │   ├── FreeRTOS_POSIX
│   │   │   ├── ...
│   │   │   └── sys
│   │   ├── kernel      # FreeRTOS 內核
│   │   ├── projects    # 方案工程目錄,后文有詳細介紹
│   │   ├── scripts     # 編譯腳手架腳本
│   │   └── tools       # RTOS 使用的工具鏈
│   ├── rtos-components # 公共應用組件,libc、多媒體、lvgl等
│   │   ├── aw          # Allwinner 提供的公共應用組件
│   │   └── thirdparty  # 第三方提供的公共應用組件
│   └── rtos-hal        # RTOS HAL驅動
│       ├── hal         # HAL 驅動
│       ├── include     # HAL 頭文件
│       └── tools       # HAL 相關工具
├── out                 # 打包輸出的臨時文件與最終鏡像文件
│   └── r128s2
│       └── pro
└── tools               # 用于存放打包相關的腳本、工具
├── image-file
├── scripts
├── tool
│   └── cppcheck
├── win-tools
└── xradio-tools
├── data
├── HcidumpXr
├── NLink
├── NTest
└── sdd_editor

R128 SDK 目錄結構如上所示,主要包括如下幾個關鍵目錄:

  • board:板級配置目錄,用于存放芯片方案的配置文件,主要包括 env 配置、分區表配置、
    sys_config.fex 引腳復用配置等。
  • lichee/brandy?2.0:主要存放uboot 等代碼。
  • lichee/rtos:存放 M33/C906 FreeRTOS 系統、組件、應用。
  • lichee/rtos?components:公共組件目錄。
  • lichee/rtos?hal:HAL BSP 驅動目錄。用于存放各種驅動代碼。
  • out:用于保存打包時輸出的臨時文件與最終鏡像文件。打包時自動生成此目錄。
  • tools:工具目錄,用于存放打包相關的腳本、工具等。

lichee/rtos 目錄

lichee/rtos
├── arch        # 處理器架構相關
├── build       # 編譯臨時文件輸出目錄
├── components  # 組件
├── drivers     # 驅動
├── include
├── kernel      # FreeRTOS內核
├── projects    # 方案工程
├── scripts
└── tools       # 工具鏈

lichee/rtos 目錄主要包括arch(架構相關)、components(組件)、drivers(驅動)、include(頭文件)、kernel(內核)、projects(工程)、toos(工具鏈) 幾個目錄。

arch 目錄

arch 目錄主要放置跟SoC 架構相關的內容,每個SoC 單獨目錄管理,主要包括跟R128 處理器相關的ARCH 初始化、中斷處理、異常處理、內存映射相關功能的實現。

drivers 目錄

drivers 目錄包含R128 所需的外設驅動,主要包括各外設控制器驅動的具體實現(rtos?hal 軟連接)以及OSAL 層接口實現(osal)。

kernel 目錄

kernel 目錄主要包含FreeRTOS 的kernel 源碼,ARMv8M 的portable 源碼以及全志實現的系統功能相關代碼。

.
├── FreeRTOS
│   ├── Makefile
│   └── Source
├── FreeRTOS-orig
│   ├── License
│   ├── Makefile
│   └── Source
├── Kconfig
├── Makefile
├── objects.mk
└── Posix
├── CMakeLists.txt
├── include
├── Makefile
└── source

projects 目錄

projects 目錄下的每一個子目錄代表一個SoC 類別,每個 SoC 類別下面存放對應的方案,每個方案都有 m33 與c906 目錄,在這些目錄下面實現各處理器上第一個任務,選擇不同的 project 編譯出來的 bin 具有不同功能。每個 project 有獨立的 FreeRTOSConfig 配置。

.
├── config.h                       # 公共配置頭文件
├── Kconfig                        # Kconfig 引索文件
├── Makefile                       # Makefile
├── objects.mk                     # Makefile 構建腳本
└── r128s2                         # R128 S2 平臺方案
├── bt.lds.S                   # 藍牙協議棧等鏈接腳本
├── Makefile                   # Makefile 構建腳本
├── 86panel_c906               # 86panel 方案 C906 RISC-V 核相關文件
│   ├── defconfig              # 軟件包配置文件
│   ├── freertos.lds.S         # 鏈接腳本
│   ├── Kconfig                # Kconfig 引索文件
│   ├── Makefile               # Makefile 構建腳本
│   └── src                    # 86panel 方案 C906 RISC-V 核相關源碼
│       ├── alsa_config.c      # alsa 框架插件配置文件
│       ├── assert.c           # 斷言處理
│       ├── card_default.c     # 聲卡配置文件
│       ├── FreeRTOSConfig.h   # FreeRTOS 配置文件
│       ├── hooks.c            # FreeRTOS 相關鉤子函數配置
│       └── main.c             # FreeRTOS 程序入口
├── wlan.lds.S                 # WiFi 鏈接文件
└── xip.lds.S                  # xip 鏈接文件

Tools 目錄

這個目錄主要包含一些預編譯好的交叉編譯工具鏈,目前M33 基于GCC 8.3.1 的交叉編譯環境,C906 基于GCC 8.4.0 的交叉編譯器。

M33 編譯器
Using built-in specs.
COLLECT_GCC=./arm-none-eabi-gcc
COLLECT_LTO_WRAPPER=/R128-FreeRTOS/lichee/rtos/tools/gcc-arm-none-eabi-8-2019-q3-update/bin/../lib/gcc/arm-none-eabi/8.3.1/lto-wrapper
Target: arm-none-eabi
Configured with: /tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/src/gcc/configure --target=arm-none-eabi --prefix=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/install-native --libexecdir=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/install-native/lib --infodir=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/install-native/share/doc/gcc-arm-none-eabi/info --mandir=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/install-native/share/doc/gcc-arm-none-eabi/man --htmldir=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/install-native/share/doc/gcc-arm-none-eabi/html --pdfdir=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/install-native/share/doc/gcc-arm-none-eabi/pdf --enable-languages=c,c++ --enable-plugins --disable-decimal-float --disable-libffi --disable-libgomp --disable-libmudflap --disable-libquadmath --disable-libssp --disable-libstdcxx-pch --disable-nls --disable-shared --disable-threads --disable-tls --with-gnu-as --with-gnu-ld --with-newlib --with-headers=yes --with-python-dir=share/gcc-arm-none-eabi --with-sysroot=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/install-native/arm-none-eabi --build=x86_64-linux-gnu --host=x86_64-linux-gnu --with-gmp=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/build-native/host-libs/usr --with-mpfr=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/build-native/host-libs/usr --with-mpc=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/build-native/host-libs/usr --with-isl=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/build-native/host-libs/usr --with-libelf=/tmp/jenkins/jenkins-GCC-8-build_toolchain_docker-594_20190704_1562200936/build-native/host-libs/usr --with-host-libstdcxx='-static-libgcc -Wl,-Bstatic,-lstdc++,-Bdynamic -lm' --with-pkgversion='GNU Tools for Arm Embedded Processors 8-2019-q3-update' --with-multilib-list=rmprofile
Thread model: single
gcc version 8.3.1 20190703 (release) [gcc-8-branch revision 273027] (GNU Tools for Arm Embedded Processors 8-2019-q3-update)
C906 RISC-V 編譯器
Using built-in specs.
COLLECT_GCC=./riscv64-unknown-elf-gcc
COLLECT_LTO_WRAPPER=/R128-FreeRTOS/lichee/rtos/tools/riscv64-elf-x86_64-20201104/bin/../libexec/gcc/riscv64-unknown-elf/8.4.0/lto-wrapper
Target: riscv64-unknown-elf
Configured with: /ldhome/software/toolsbuild/slave/workspace/riscv64_build_elf_x86_64/build/../source/riscv/riscv-gcc/configure --target=riscv64-unknown-elf --with-mpc=/ldhome/software/toolsbuild/slave/workspace/riscv64_build_elf_x86_64/lib-for-gcc-x86_64-linux/ --with-mpfr=/ldhome/software/toolsbuild/slave/workspace/riscv64_build_elf_x86_64/lib-for-gcc-x86_64-linux/ --with-gmp=/ldhome/software/toolsbuild/slave/workspace/riscv64_build_elf_x86_64/lib-for-gcc-x86_64-linux/ --prefix=/ldhome/software/toolsbuild/slave/workspace/riscv64_build_elf_x86_64/install --disable-shared --disable-threads --enable-languages=c,c++ --with-system-zlib --enable-tls --enable-libgcctf --with-newlib --with-sysroot=/ldhome/software/toolsbuild/slave/workspace/riscv64_build_elf_x86_64/install/riscv64-unknown-elf --with-native-system-header-dir=/include --disable-libmudflap --disable-libssp --disable-libquadmath --disable-libgomp --disable-nls --src=../../source/riscv/riscv-gcc --with-pkgversion='T-HEAD RISCV Tools V1.10.2 B20201104' --enable-multilib --with-abi=lp64d --with-arch=rv64gcxthead 'CFLAGS_FOR_TARGET=-Os  -mcmodel=medany' 'CXXFLAGS_FOR_TARGET=-Os  -mcmodel=medany' CC=gcc CXX=g++
Thread model: single
gcc version 8.4.0 (T-HEAD RISCV Tools V1.10.2 B20201104)

審核編輯 黃宇

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

    關注

    146

    文章

    17316

    瀏覽量

    352267
  • SDK
    SDK
    +關注

    關注

    3

    文章

    1045

    瀏覽量

    46154
  • R128
    +關注

    關注

    0

    文章

    41

    瀏覽量

    112
收藏 人收藏

    評論

    相關推薦

    聯盛德微電子WM IoT SDK 2.X正式發布

    WM IoT SDK 2.X 是聯盛德微電子(WinnerMicro)秉承開源和組件式架構的設計理念所自研的新版IoT SDK,2025年1月15日正式發布。
    的頭像 發表于 01-15 15:24 ?222次閱讀
    聯盛德微電子WM IoT <b class='flag-5'>SDK</b> <b class='flag-5'>2</b>.X正式發布

    ADC128S022的驅動架構參考 ti-adc128s052.c,要如何做移位生成12bit結果呢?

    ADC128S022的驅動架構參考 ti-adc128s052.c, 具體如下圖所示。 上層讀取buf[1], buf[2]請問要如何做移位生成12bit結果呢?
    發表于 12-16 06:32

    ADC128S102EVM評估模塊

    電子發燒友網站提供《ADC128S102EVM評估模塊.pdf》資料免費下載
    發表于 12-05 14:22 ?1次下載
    ADC<b class='flag-5'>128S</b>102EVM評估模塊

    鴻蒙Flutter實戰:11-使用 Flutter SDK 3.22.0

    配置 1.進入項目根目錄,如果項目還未創建,則使用 flutter create 命令創建項目 flutter create my_app 2.在當前項目目錄,設置使用的 Flutter S
    發表于 11-01 15:03

    涂鴉的Link SDK如何連接到涂鴉IOT平臺教程

    。 該 Kit 的 C 代碼文件通過以下目錄結構提供: certs:設備私鑰,設備證書,服務端 CA 根證書 docs:參考文檔 libraries:外部依賴庫,包
    的頭像 發表于 09-25 16:41 ?693次閱讀
    涂鴉的Link <b class='flag-5'>SDK</b>如何連接到涂鴉IOT平臺教程

    【龍芯2K0300蜂鳥板試用】SDK部署與構建

    的默認鏈接下載速度很慢。 sdk目錄結構如下 1.uboot構建uboot下面有個set_env.sh腳本,將里面的setup_loongarch_env函數的CC_PREFIX目錄
    發表于 09-02 00:15

    ADC128S052、ADC128S052-Q1模數轉換器數據表

    電子發燒友網站提供《ADC128S052、ADC128S052-Q1模數轉換器數據表.pdf》資料免費下載
    發表于 07-22 11:12 ?0次下載
    ADC<b class='flag-5'>128S</b>052、ADC<b class='flag-5'>128S</b>052-Q1模數轉換器數據表

    esp32-s2r2芯片無法下載是什么原因導致的?

    求助, 我現在遇到esp32-s2r2芯片無法下載問題,一開始懷疑是我電路設計問題。于是我將樂鑫ESP32-S2-WROVER-I模組內ESP32-S2芯片替換為esp32-s2r2
    發表于 07-01 08:29

    全志D1s軟件入門之Tina Linux編譯教程

    的是 d1s_nezha 板子,也正是 D1s Nezha 開發板。輸入 5 回車即可。如果是其他板子,也可以輸入對應板子的序號選擇方案。 lunch 之后 SDK 會自動根據你所選擇的方案解壓編譯工具鏈,創建環境
    發表于 06-05 09:50

    全志R128 SDK HAL 模塊開發指南之 MSGBOX

    機制 對于 R128 平臺,CPU Remote ID如下 CPU Remote ID ARM M33 Star 0 RISC-V C906 1 HIFI5 DSP 2 模塊配置 配置路徑如下
    發表于 05-15 09:58

    全志R128 SDK HAL 模塊開發指南——TWI

    0. */ S_TWI_MASTER_1,/**< S_TWI master 1. */ S_TWI_MASTER_2,/**< S_TWI master
    發表于 04-10 16:58

    全志R128 SDK HAL 模塊開發指南——G2D

    ; G2D devices ---> [*] enable g2d driver [*] enbale g2d hal APIs Test command 源碼結構
    發表于 04-01 13:31

    全志R128 SDK HAL 模塊開發指南——Flash Controller

    Flash Controller Flash Controller 為 R128 內置的一個 Nor Flash 讀寫控制器,用于控制命令的收發、數據讀寫和執行 XIP,兼容 Standard
    發表于 03-25 10:11

    SLAMWARE ROS SDK的基礎架構、部署方法和應用示例介紹

    ROS作為機器人行業應用最廣泛的基礎架構之一,是很多用戶開發機器人應用的首選框架,如果要在基于ROS開發的系統中集成思嵐科技的機器人底盤或者SLAMKit建圖定位解決方案,有什么最便捷的方法呢?ROS SDK就是為此而生。
    的頭像 發表于 03-21 10:44 ?980次閱讀
    SLAMWARE ROS <b class='flag-5'>SDK</b>的基礎<b class='flag-5'>架構</b>、部署方法和應用示例介紹

    R2R和電阻串DAC架構之間的差異分析

    同樣,對于大多數人來說,DAC 只不過是一個輸入端為數字信號數據而輸出端為模擬信號數據的“黑匣子”。只有為數不多的人知道其在架構方面的區別,以及與 R2R 梯形架構相比一個電阻串架構
    發表于 02-15 16:45 ?1260次閱讀
    <b class='flag-5'>R2R</b>和電阻串DAC<b class='flag-5'>架構</b>之間的差異分析
    主站蜘蛛池模板: 午夜黄视频 | 两个客户一起吃我的奶 | 国产成人精选免费视频 | 亚洲高清在线视频 | 国产麻豆剧看黄在线观看 | 兽交白浆喷水高潮 | 午夜亚洲动漫精品AV网站 | 久久日韩精品无码一区 | 久草在在线免视频在线观看 | 国产黄a三级三级三级 | 在教室伦流澡到高潮H女攻视频 | jizz黑丝| 饥渴的护士自慰被发现 | 久久精品国产亚洲AV忘忧草蜜臀 | 久久精品男人影院 | 魔乳 堕乳漫画acg产卵 | 国产人妻麻豆蜜桃色 | 成人亚洲精品 | 99re久久热在这里精品 | 国产在线高清视频无码不卡 | 偷拍精品视频一区二区三区 | 日本强好片久久久久久AAA | 欧美牲交视频免费观看K8经典 | 中文字幕乱码在线人视频 | 强奷漂亮女老板在线播放 | 毛片在线网址 | 十八禁久久成人一区二区 | 国产成人女人视频在线观看 | 国产麻豆精品传媒AV国产在线 | 国产成人精品亚洲线观看 | 野花韩国高清完整版在线观看5 | 野花日本韩国视频免费高清观看 | 牛牛精品专区在线 | 精品亚洲一区二区三区在线播放 | 人人妻免费线 | xxxx69日本| 久久精品麻豆国产天美传媒果冻 | 亚洲免费人成 久久 | 大乳牛奶女在线观看 | 污文乖不疼的 | 芭乐视频免费资源在线观看 |