現代工業數據采集與控制系統中,高效、可靠、實時的數據傳輸是構建高性能嵌入式系統的關鍵。瑞芯微RK3506芯片平臺集成的硬件級FlexBus并行總線,為實現多通道、高采樣率的應用提供解決方案。

本文基于觸覺智能的RK3506核心板/開發板,介紹FlexBus總線的技術架構、設備樹配置、驅動實現與測試方法,為嵌入式開發者提供從理論到實戰的一站式指南。
FlexBus簡介
FlexBus是一種高速、并行、可配置的外部總線接口,主要用于芯片與外部設備之間進行高速數據交互,是嵌入式 / 工業控制里非常關鍵的通信接口。
- FlexBus與RK3506技術特性
瑞芯微RK3506定位高性能工業控制與數據采集領域設計的專用SoC,具備以下核心特性:
- 異構多核架構
- 3核Cortex-A7核與Cortex-M0實時協處理器協同工作,實現任務分離與實時響應。
- 集成高速FlexBus 總線
- 支持并行數據傳輸,適用于多通道同步采集。
- 雙系統協同架構
- 實現實時數據采集與應用處理的硬件隔離。
- 工業級可靠性
- 工作溫度范圍?40℃~85℃,支持強抗干擾設計與電磁兼容性優化。
- 豐富外設接口
- SPI、I2C、UART、PWM等,便于系統擴展。
觸覺智能-瑞芯微硬件方案商,提供RK3506核心板、開發板/主板硬件解決方案。
- FlexBus技術優勢
FlexBus技術優勢可總結為以下4點:
- 確定性實時傳輸
- (1)硬件級并行傳輸,消除軟件協議棧延遲。
- (2)專用 DMA 通道,實現零拷貝數據傳輸。
- (3)中斷響應時間<1μs(微秒),滿足高速控制與采集需求。
- 數據完整性保障
- (1)內置硬件校驗機制(如 CRC)。
- (2)支持自動錯誤檢測與數據重傳。
- (3)數據同步與時間戳對齊,確保時序一致性。
- 系統可擴展性
- (1)支持多設備級聯,靈活擴展采集通道。
- (2)可配置的時鐘與數據傳輸速率。
- (3)標準化的設備樹接口,便于驅動開發與集成。
- 工業環境適應性
- 寬溫工作范圍+強抗干擾設計,通過 EMI/EMC測試,適應惡劣環境。支持長距離傳輸與信號完整性保持。
- FlexBus實現的框圖
FlexBus構成了系統內部的高速數據通道,連接Cortex-M0協處理器與外部數據采集設備(如 AD7616),實現低延遲、高吞吐量的并行數據傳輸。

- 典型應用場景
瑞芯微RK3506平臺集成的硬件級FlexBus并行總線,可廣泛應用于工業過程監控、科學儀器測量、自動化測試系統及醫療設備監測等多種高性能實時場景。
FlexBus 數據采集模式使用教程
- 內核配置與設備樹修改
根據觸覺智能RK3506網盤下的SDK,修改多個配置。
(1)引腳配置rk3506-pinctrl.dtsi
目錄kernel/arch/arm/boot/dts/rk3506-pinctrl.dtsi,修改內容如下:
@@ -358,13 +358,13 @@ flexbus0_clk_pins: flexbus0-clk-pins { flexbus0_d0_pins: flexbus0-d0-pins { rockchip,pins = /* flexbus0_d0 */ - <1 RK_PD3 3 &pcfg_pull_none>; + <1 RK_PD3 3 &pcfg_pull_up>; }; /omit-if-no-ref/ flexbus0_d1_pins: flexbus0-d1-pins { rockchip,pins = /* flexbus0_d1 */ - <1 RK_PD2 3 &pcfg_pull_none>; + <1 RK_PD2 3 &pcfg_pull_up>; }; /omit-if-no-ref/ flexbus0_d2_pins: flexbus0-d2-pins {
(2)FlexBus控制器節點配置rk3502.dtsi
目錄arch/arm/boot/dts/rk3502.dtsi,修改內容如下:
@@ -1237,6 +1237,12 @@ flexbus: flexbus@ff880000 { rockchip,grf = <&grf>; status = "disabled"; + flexbus_ad7616_par_hw: ad7616 { + compatible = "rockchip,flexbus-ad7616-par-hw"; + #io -channel-cells = <0>; + status = "disabled"; + }; + flexbus_adc: adc { compatible = "rockchip,flexbus-adc"; #io -channel-cells = <0>;
(3)啟用板級設備樹ido-evb3506-v1a-nand.dtsi
目錄arch/arm/boot/dts/ido-evb3506-v1a-nand.dtsi,修改內容如下:
@@ -8,6 +8,7 @@ #include #include #include "rk3506.dtsi" + #include / { model = "Rockchip RK3506 IDO EVB3506 V10 Board"; @@ -633,3 +634,22 @@ &usb20_otg1 { dr_mode = "host"; status = "okay"; }; + +&flexbus { + rockchip,flexbus0-opmode = ; + rockchip,flexbus1-opmode = ; + status = "okay"; +}; + +&flexbus_ad7616_par_hw { + pinctrl-names = "default"; + /* flexbus0_d0: RD, flexbus0_d1: CS */ + //pinctrl-0 = <&flexbus0_d0_pins &flexbus0_d1_pins + pinctrl-0 = <&flexbus1_clk_pins &flexbus1m4_pins + &flexbus1_d0_pins &flexbus1_d1_pins &flexbus1_d2_pins + &flexbus1_d3_pins &flexbus1_d4_pins &flexbus1_d5_pins + &flexbus1_d6_pins &flexbus1_d7_pins &flexbus1_d8_pins + &flexbus1_d9_pins &flexbus1_d10_pins &flexbus1_d11_pins + &flexbus1_d12_pins &flexbus1_d13_pins &flexbus1_d14_pins + &flexbus1_d15_pins>; + status = "okay"; +}; +&uart4 { + status = "disabled"; +}; + +&uart2 { + status = "disabled"; +}; + +&can0 { + status = "disabled"; +}; + +&saradc { + status = "disabled"; +};
(4)設備數修改
修改kernel/drivers/iio/adc/Makefile:
obj-$(CONFIG_RCAR_GYRO_ADC) += rcar-gyroadc.o obj-$(CONFIG_RN5T618_ADC) += rn5t618-adc.o obj-$(CONFIG_ROCKCHIP_FLEXBUS_ADC) += rockchip-flexbus-adc.o + obj-$(CONFIG_ROCKCHIP_FLEXBUS_ADC) += rockchip-flexbus-ad7616-par-hw.o obj-$(CONFIG_ROCKCHIP_SARADC) += rockchip_saradc.o obj-$(CONFIG_RICHTEK_RTQ6056) += rtq6056.o obj-$(CONFIG_RZG2L_ADC) += rzg2l_adc.o
修改kernel/include/linux/mfd/rockchip-flexbus.h:
#define FLEXBUS_DST_WAT_LVL_SHIFT 0 /* Bit fields in IMR, RISR, ISR and ICR */ + #define FLEXBUS_CCI BIT(31) #define FLEXBUS_DMA_TIMEOUT_ISR BIT(13) #define FLEXBUS_DMA_ERR_ISR BIT(12) #define FLEXBUS_DMA_DST1_ISR BIT(11)
新建kernel/drivers/iio/adc/rockchip-flexbus-ad7616-par-hw.c,附件請關注觸覺智能獲取。
測調整頻率參數
加載驅動后,會產生/sys/bus/iio/devices/iio:device0節點,進行修改采樣頻率:
root@rk3506-buildroot:/root# ls /sys/bus/iio/devices/iio:device0 in_voltage_raw power in_voltage_sampling_frequency subsystem name uevent of_no de waiting_for_supplier
獲取 ADC命令如下:
cat /sys/bus/iio/devices/iio:device0/in_voltage_raw
設置采樣頻率,命令如下:
echo 1000000 > /sys/bus/iio/devices/iio\:device0/in_voltage_sampling_frequency
測試方法與示例
以下為測試腳本示例,用于連續讀取多通道ADC數據:
# init 1MHz clk echo 1000000 > /sys/bus/iio/devices/iio\:device0/in_voltage_sampling_frequency # reset 1 gpioset gpiochip0 2=1 sleep 0.3 gpioset gpiochip0 3=1 gpioset gpiochip1 18=1 gpioset gpiochip1 19=1 sleep 0.1 # convst 1 -> 0 gpioset gpiochip0 4=1 sleep 0.01 gpioset gpiochip0 4=0 sleep 0.1 if [ $1 -eq 3 ]; then # cs 0 # adc3_cs 0 gpioset gpiochip1 23=0 # adc2_cs 1 gpioset gpiochip1 22=1 # adc1_cs 1 gpioset gpiochip1 21=1 # adc0_cs 1 gpioset gpiochip1 20=1 elif [ $1 -eq 2 ]; then # cs 0 # adc3_cs 0 gpioset gpiochip1 23=1 # adc2_cs 1 gpioset gpiochip1 22=0 # adc1_cs 1 gpioset gpiochip1 21=1 # adc0_cs 1 gpioset gpiochip1 20=1 elif [ $1 -eq 1 ]; then # cs 0 # adc3_cs 0 gpioset gpiochip1 23=1 # adc2_cs 1 gpioset gpiochip1 22=1 # adc1_cs 1 gpioset gpiochip1 21=0 # adc0_cs 1 gpioset gpiochip1 20=1 elif [ $1 -eq 0 ]; then # cs 0 # adc3_cs 0 gpioset gpiochip1 23=1 # adc2_cs 1 gpioset gpiochip1 22=1 # adc1_cs 1 gpioset gpiochip1 21=1 # adc0_cs 1 gpioset gpiochip1 20=0 fi sleep 0.1 #觸發采樣并讀取數據 cat /sys/bus/iio/devices/iio:device0/in_voltage_raw dmesg -c
觀察內核打印(只需要關注0x00-0x0f的值):
[ 1182.468572] 0x00: 0x0c00 [ 1182.468639] 0x01: 0x141a [ 1182.468668] 0x02: 0x2ba4 [ 1182.468695] 0x03: 0x2bbd [ 1182.468722] 0x04: 0x2ba1 [ 1182.468748] 0x05: 0x2bd1 [ 1182.468774] 0x06: 0x2ba4 [ 1182.468800] 0x07: 0x2bcd [ 1182.468826] 0x08: 0x2bba [ 1182.468852] 0x09: 0x2bca [ 1182.468879] 0x0a: 0x2ba8 [ 1182.468905] 0x0b: 0x141a [ 1182.468931] 0x0c: 0x2ba4 [ 1182.468957] 0x0d: 0x2bbd [ 1182.468983] 0x0e: 0x2bbd [ 1182.469010] 0x0f: 0x2ba1
FlexBus ADC 寄存器與通道對應關系如下:

電壓計算公式:
Vin = (raw÷32768)×5.0v
比如測試日志0x01: 0x141a,表示A0通道。
-
adc
+關注
關注
100文章
7527瀏覽量
556228 -
flexbus
+關注
關注
0文章
4瀏覽量
3179 -
RK3506
+關注
關注
0文章
96瀏覽量
945
發布評論請先 登錄
米爾基于RK3562與RK3506開發板有什么區別?
【米爾RK3506國產開發板評測試用】開箱體體驗
嵌入式瑞芯微VS-RK3399板卡Linux WIFI BT開發指南
米爾基于瑞芯微RK3506核心板開發板
RK3506 MIPI轉HDMI顯示開發實戰:從硬件到驅動全解析
瑞芯微RK3506 Flexbus技術開發指南,從原理、內核配置到測試的完整攻略
評論