在電子信息與通信系統(tǒng)的研發(fā)中,基于ARM7架構(gòu)的微控制器因其高性能、低功耗的特點(diǎn)被廣泛應(yīng)用。其內(nèi)置的UART(通用異步收發(fā)傳輸器)模塊支持多種工作模式,其中9位數(shù)據(jù)格式的多機(jī)通信模式是實(shí)現(xiàn)主從式網(wǎng)絡(luò)通信的關(guān)鍵技術(shù),能夠有效管理多個(gè)從機(jī)設(shè)備,降低系統(tǒng)復(fù)雜度與總線負(fù)載。
標(biāo)準(zhǔn)的串口通信通常采用8位數(shù)據(jù)格式,而ARM7的UART模塊支持可編程的9位數(shù)據(jù)格式。在此模式下,發(fā)送的每個(gè)數(shù)據(jù)幀由1位起始位、9位數(shù)據(jù)位(含1位可編程的第9位)和1位停止位構(gòu)成。第9位(通常標(biāo)記為TB8/RB8)在多機(jī)通信中扮演“地址/數(shù)據(jù)標(biāo)識(shí)符”的核心角色:
多機(jī)通信的基本流程如下:所有從機(jī)初始化為監(jiān)聽地址幀狀態(tài)(通常通過設(shè)置相關(guān)寄存器,使UART僅在收到第9位為1的幀時(shí)才產(chǎn)生接收中斷)。主機(jī)首先廣播一個(gè)地址幀(第9位=1),其中包含目標(biāo)從機(jī)的地址。所有從機(jī)均收到此地址,但只有地址匹配的從機(jī)被“喚醒”,并將其UART配置為接收后續(xù)的數(shù)據(jù)幀(第9位=0)。未被尋址的從機(jī)則繼續(xù)忽略數(shù)據(jù)幀,直至收到下一個(gè)地址幀。這種機(jī)制避免了總線上的數(shù)據(jù)沖突,實(shí)現(xiàn)了高效的主從式網(wǎng)絡(luò)通信。
以常見的ARM7 TDMI內(nèi)核芯片(如LPC2000系列)為例,實(shí)現(xiàn)9位多機(jī)通信需重點(diǎn)配置以下寄存器:
關(guān)鍵編程步驟:
- 初始化:設(shè)置波特率(訪問除數(shù)鎖存器)、9位數(shù)據(jù)格式、1位停止位、無奇偶校驗(yàn)。
- 從機(jī)地址過濾:利用UART的“特殊多機(jī)通信模式”或通過軟件在中斷服務(wù)程序中檢查接收到的第9位(RB8)和數(shù)據(jù)。例如,在初始化時(shí),可先使從機(jī)僅對(duì)地址幀(RB8=1)產(chǎn)生中斷;在地址匹配后,再改為對(duì)所有幀(RB8=0或1)產(chǎn)生中斷以接收數(shù)據(jù)。
示例代碼框架(偽代碼風(fēng)格):`c
// 從機(jī)初始化片段
void UARTInitSlave(uint8t myAddr) {
// 配置波特率、9位數(shù)據(jù)格式等
UxLCR = 0x83; // 使能DLAB,設(shè)置字長(zhǎng)等
UxDLL = ...; // 設(shè)置波特率除數(shù)低字節(jié)
UxDLM = ...; // 設(shè)置波特率除數(shù)高字節(jié)
UxLCR = 0x0B; // 8位字長(zhǎng)(實(shí)際為9位,具體值需查手冊(cè)),禁用DLAB
UxFCR = 0x01; // 使能FIFO
UxIER = 0x01; // 使能接收中斷
NVICEnableIRQ(UART_IRQn);
}
// 從機(jī)中斷服務(wù)程序
void UARTIRQHandler(void) {
static bool isAddressed = false;
uint8t data = UxRBR; // 讀取數(shù)據(jù),同時(shí)可能自動(dòng)清除中斷標(biāo)志
uint8t rb8 = ...; // 從相應(yīng)寄存器或狀態(tài)位獲取第9位,具體方式依賴芯片
if (rb8 == 1) { // 地址幀
if (data == MYSLAVE_ADDR) {
isAddressed = true; // 進(jìn)入數(shù)據(jù)接收模式
// 可選:發(fā)送應(yīng)答信號(hào)或準(zhǔn)備接收
} else {
isAddressed = false; // 保持監(jiān)聽
}
} else { // 數(shù)據(jù)幀
if (isAddressed) {
// 處理有效數(shù)據(jù) data
// ...
// 若收到特定結(jié)束符,可重置 isAddressed = false;
}
// 否則忽略此數(shù)據(jù)幀
}
}`
###
掌握ARM7串口9位多機(jī)通信的編程技術(shù),是構(gòu)建穩(wěn)定、高效主從式分布式嵌入式系統(tǒng)的關(guān)鍵。開發(fā)者需深入理解硬件寄存器操作、中斷機(jī)制以及通信狀態(tài)機(jī)的軟件實(shí)現(xiàn),并結(jié)合具體的應(yīng)用場(chǎng)景設(shè)計(jì)健壯的通信協(xié)議。隨著技術(shù)發(fā)展,雖然更先進(jìn)的現(xiàn)場(chǎng)總線與通信協(xié)議層出不窮,但在許多對(duì)成本敏感、結(jié)構(gòu)簡(jiǎn)單的設(shè)備網(wǎng)絡(luò)中,此項(xiàng)經(jīng)典技術(shù)因其硬件支持廣泛、實(shí)現(xiàn)直接高效,依然具有重要的實(shí)用價(jià)值。
如若轉(zhuǎn)載,請(qǐng)注明出處:http://www.lelechajm.cn/product/66.html
更新時(shí)間:2026-04-28 15:24:57