1. UART 簡(jiǎn)介?
Rockchip UART (Universal Asynchronous Receiver/Transmitter) 基于16550A串口標(biāo)準(zhǔn),完整模塊支持以下功能:
- 支持5、6、7、8 bits數(shù)據(jù)位。
 - 支持1、1.5、2 bits停止位。
 - 支持奇校驗(yàn)和偶校驗(yàn),不支持mark校驗(yàn)和space校驗(yàn)。
 - 支持接收FIFO和發(fā)送FIFO,一般為32字節(jié)或者64字節(jié)。
 - 支持最高4M波特率,實(shí)際支持波特率需要芯片時(shí)鐘分頻策略配合。
 - 支持中斷傳輸模式和DMA傳輸模式。
 - 支持硬件自動(dòng)流控,RTS+CTS。
 
2. 普通串口?
- 在ArmSoM-Sige7中,普通UART集成在40PIN中,可供用戶復(fù)用為UART功能。
 - 在40PIN中可供復(fù)用的UART有:uart2-m2,uart3-m1,uart4-m2,uart7-m1,uart7-m2,uart8-m0
 
2.1 如何使用40PIN中的UART ??
用戶只需參考 overlay 設(shè)置,在overlay屬性中添加上UART的overlay文件:
例如:
- 使用UART3:
 
overlays=rk3588-uart3-m1
- 使用uart4
 
overlays=rk3588-uart4-m2
- 使用uart7
 
overlays=rk3588-uart7-m1
- 使用uart8
 
overlays=rk3588-uart8-m0
2.2 內(nèi)核menuconfig配置?
Device Drivers() ---> Character devices() ---> Serial drivers
2.3 dts配置?
2.3.1 芯片級(jí)公共配置?
kernel/arch/arm64/boot/dts/rockchip/rk3588s.dtsi
uart2: serial@feb50000 {
        compatible = "rockchip,rk3588-uart", "snps,dw-apb-uart";
        reg = ?0x0 0xfeb50000 0x0 0x100??>;
        interrupts = ?GIC_SPI 333 IRQ_TYPE_LEVEL_HIGH??>;
        clocks = ?&cru SCLK_UART2??>, ?&cru PCLK_UART2??>;
        clock-names = "baudclk", "apb_pclk";
        reg-shift = ?2??>;
        reg-io-width = ?4??>;
        dmas = ?&dmac0 10??>, ?&dmac0 11??>;
        pinctrl-names = "default";
        pinctrl-0 = ?&uart2m1_xfer??>;
        status = "disabled";
    };
2.3.2 板級(jí)配置?
kernel/arch/arm64/boot/dts/rockchip/rk3588-armsom-sige7.dts
UART的板級(jí)dts配置只有以下參數(shù)允許修改:
dma-names:
- "tx" 打開(kāi)tx dma
 - "rx" 打開(kāi)rx dma
 - "!tx" 關(guān)閉tx dma
 - "!rx" 關(guān)閉rx dma
 
pinctrl-0:
- &uart1m0_xfer 配置tx和rx引腳為iomux group 0
 - &uart1m1_xfer 配置tx和rx引腳為iomux group 1
 - &uart1m0_ctsn和&uart1m0_rtsn 配置硬件自動(dòng)流控cts和rts引腳為iomux group 0
 - &uart1m1_ctsn和&uart1m1_rtsn 配置硬件自動(dòng)流控cts和rts引腳為iomux group 1
 
status:
- 
		"okay" 打開(kāi)
		
- "disabled" 關(guān)閉
 
 
&uart2 {
    status = "okay";
    pinctrl-names = "default";
    pinctrl-0 = ?&uart2m2_xfer??>;
}
2.4 UART設(shè)備節(jié)點(diǎn)?
配置好串口后,硬件接口對(duì)應(yīng)軟件上的節(jié)點(diǎn)分別為:
UART3:   /dev/ttyS3
UART4:   /dev/ttyS4
...
2.5 使用串口喚醒系統(tǒng)?
串口喚醒系統(tǒng)功能是在系統(tǒng)待機(jī)時(shí)串口保持打開(kāi),并且把串口中斷設(shè)置為喚醒源。使用時(shí)需要在dts中增 加以下參數(shù):
&uart1 {    wakeup-source;};
3. 控制臺(tái)串口?
- 在ArmSoM-Sige7中,UART2是作為控制臺(tái)串口使用,可供用戶查看開(kāi)機(jī)啟動(dòng)的信息以及日常調(diào)試使用。
 
3.1 驅(qū)動(dòng)?
kernel/drivers/soc/rockchip/fiq_debugger/rk_fiq_debugger.c
3.2 dts配置?
由于fiq_debugger和普通串口互斥,在使能fiq_debugger節(jié)點(diǎn)后必須禁用對(duì)應(yīng)的普通串口uart節(jié)點(diǎn)
fiq_debugger: fiq-debugger {
        compatible = "rockchip,fiq-debugger";
        rockchip,serial-id = ?2??>;
        rockchip,wake-irq = ?0??>;
        /* If enable uart uses irq instead of fiq */
        rockchip,irq-mode-enable = ?1??>;
        rockchip,baudrate = ?1500000??>;  /* Only 115200 and 1500000 */
        interrupts = ?GIC_SPI 423 IRQ_TYPE_LEVEL_LOW??>;
        pinctrl-names = "default";
        pinctrl-0 = ?&uart2m0_xfer??>;
        status = "okay";
    };
    
&uart2 {
    status = "disabled";
};
以下對(duì)幾個(gè)參數(shù)進(jìn)行說(shuō)明:
- rockchip,serial-id:使用的UART編號(hào)。修改serial-id到不同UART,fiq_debugger設(shè)備也會(huì)注冊(cè)成ttyFIQ0設(shè)備。
 - rockchip,irq-mode-enable:配置為1使用irq中斷,配置為0使用fiq中斷。
 - interrupts:配置的輔助中斷,保持默認(rèn)即可。
 
4. 測(cè)試?
UART調(diào)試提供一個(gè)官方測(cè)試程序:ts_uart.uart(存放在網(wǎng)盤:1. 開(kāi)發(fā)工具->測(cè)試工具)、兩個(gè)測(cè)試用文件send_0x55和send_00_ff,該程序可以聯(lián)系A(chǔ)rmSoM客服獲取。 通過(guò)adb工具將測(cè)試程序放在開(kāi)發(fā)板上一個(gè)可執(zhí)行的路徑下,以下放在data路徑:
adb rootadb remountadb push ts_uart.uart /dataadb push send_0x55 /dataadb push send_00_ff /data
在開(kāi)發(fā)板上修改測(cè)試程序權(quán)限:
sudo chmod +x /data/ts_uart.uart
使用以下命令可以獲取程序幫助:
console:/ # ./data/ts_uart.uart
Use the following format to run the HS-UART TEST PROGRAM
ts_uart v1.1
For sending data:
./ts_uart ?tx_rx(s/r)??> ?file_name??>  ?flow_control(0/1)??> ?max_delay(0-
100)??> ?random_size(0/1)??>
tx_rx : send data from file (s) or receive data (r) to put in file
file_name : file name to send data from or place data in
baudrate : baud rate used for TX/RX
flow_control : enables (1) or disables (0) Hardware flow control using RTS/CTS
lines
max_delay : defines delay in seconds between each data burst when sending.
Choose 0 for continuous stream.
random_size : enables (1) or disables (0) random size data bursts when sending.
Choose 0 for max size.
max_delay and random_size are useful for sleep/wakeup over UART testing. ONLY
meaningful when sending data
Examples:
Sending data (no delays)
ts_uart s init.rc 1500000 0 0 0 /dev/ttyS0
loop back mode:
ts_uart m init.rc 1500000 0 0 0 /dev/ttyS0
receive, data must be 0x55
ts_uart r init.rc 1500000 0 0 0 /dev/ttyS0
4.1 測(cè)試發(fā)送?
測(cè)試發(fā)送的命令如下,send_0x55和send_00_ff為發(fā)送的文件:
./data/ts_uart.uart s ./data/send_0x55 1500000 0 0 0 /dev/ttyS3./data/ts_uart.uart s ./data/send_00_ff 1500000 0 0 0 /dev/ttyS3
	發(fā)送成功可以通過(guò)USB轉(zhuǎn)UART小板連接PC端,使用PC端串口調(diào)在這里插入代碼片試工具驗(yàn)證。
4.2 測(cè)試接收?
測(cè)試接收的命令如下,receive_0x55為接收的文件:
./data/ts_uart.uart r ./data/receive_0x55 1500000 0 0 0 /dev/ttyS1
可以使用PC端串口調(diào)試工具發(fā)送數(shù)據(jù),測(cè)試程序?qū)⒆詣?dòng)檢測(cè),檢測(cè)到U(0x55)接收正確,檢測(cè)到其它 字符將打印16進(jìn)制ASCII碼值,可以對(duì)照查詢接收是否正確。
4.3 測(cè)試內(nèi)部自發(fā)自收?
測(cè)試內(nèi)部自發(fā)自收的命令如下:
./data/ts_uart.uart m ./data/send_00_ff 1500000 0 0 0 /dev/ttyS3
按下Ctrl+C停止測(cè)試,可以觀察到結(jié)束log如下。比較發(fā)送和接收的數(shù)據(jù)是否一致:
Sending data from file to port...send:1172, receive:1172 total:1172 # 收發(fā)數(shù)據(jù)一致,測(cè)試成功send:3441, receive:3537 total:3441 # 收發(fā)數(shù)據(jù)不一致,測(cè)試失敗
如果測(cè)試失敗,說(shuō)明當(dāng)前串口存在問(wèn)題或者有其他程序也在使用同一個(gè)串口??梢允褂靡韵旅畈榭茨?些程序打開(kāi)了這個(gè)串口:
lsof | grep ttyS3
審核編輯 黃宇
                                        - 
                                串口
                                +關(guān)注
關(guān)注
15文章
1603瀏覽量
81655 - 
                                uart
                                +關(guān)注
關(guān)注
22文章
1293瀏覽量
105899 - 
                                Rockchip
                                +關(guān)注
關(guān)注
0文章
82瀏覽量
19448 
發(fā)布評(píng)論請(qǐng)先 登錄
基美通用貼片電容C0805C和C0805X系列產(chǎn)品特點(diǎn)和應(yīng)用場(chǎng)景介紹
    
新潔能推出增強(qiáng)型N溝道MOSFET系列產(chǎn)品
    
先輯半導(dǎo)體HPM6E00系列產(chǎn)品能用來(lái)做EtherCAT的主站嗎
N32A455xxL8系列產(chǎn)品簡(jiǎn)介
    
N32A455xxL7系列產(chǎn)品簡(jiǎn)介
    
N32G451系列產(chǎn)品簡(jiǎn)介
    
PIC32CM MC00系列產(chǎn)品簡(jiǎn)介
    
ArmSoM RK3588/RK3576核心板,Rockchip攝像頭使用
    
ArmSoM RK3588/RK3576核心板,開(kāi)發(fā)板網(wǎng)絡(luò)設(shè)置
    
上海貝嶺150V SGT MOSFET系列產(chǎn)品介紹
    
Banana Pi 攜手 ArmSoM 推出人工智能加速 RK3576 CM5 計(jì)算模塊
Banana Pi攜手ArmSoM推出人工智能加速 RK3576 CM5
    
Rockchip SoC 賦能 AI 與視覺(jué)創(chuàng)新:推動(dòng)智能設(shè)備的未來(lái)發(fā)展
    
          
        
        
ArmSoM Rockchip系列產(chǎn)品 通用教程 之 UART 使用
                
 
    
    
           
            
            
                
            
評(píng)論