當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]隨著信息技術(shù)與網(wǎng)絡(luò)技術(shù)的飛速發(fā)展,信息交互應(yīng)用業(yè)務(wù)給人類生活帶來更多的便利,信息終端表現(xiàn)出巨大的市場潛力。但是由于終端用戶環(huán)境不同,用戶信息交互方式可能不同,目前常用的有IP方式、FSK方式以及無線通信方式

隨著信息技術(shù)與網(wǎng)絡(luò)技術(shù)的飛速發(fā)展,信息交互應(yīng)用業(yè)務(wù)給人類生活帶來更多的便利,信息終端表現(xiàn)出巨大的市場潛力。但是由于終端用戶環(huán)境不同,用戶信息交互方式可能不同,目前常用的有IP方式、FSK方式以及無線通信方式等。為了能夠提高終端市場競爭力,減少系統(tǒng)開發(fā)成本投入,通信模塊與終端程序獨(dú)立設(shè)計(jì)是較為理想的解決方案。本文采用ATmega48芯片及CMX865芯片實(shí)現(xiàn)FSK通信模塊,基于此模塊,用戶與業(yè)務(wù)平臺(tái)之間進(jìn)行FSK信息交互,相對(duì)于終端來說就是簡單的串口通信。

1 ATmega48介紹

ATmega48是基于AVR增強(qiáng)型RISC(精簡指令集)結(jié)構(gòu)的高性能、低功耗的8位CMOS微控制器。微控制器具有可控制的上電復(fù)位和可編程的掉電檢測電路、經(jīng)過標(biāo)定的片內(nèi)RC振蕩器、片內(nèi)外18個(gè)中斷源和5種休眠模式。由于其先進(jìn)的指令集以及單時(shí)鐘周期指令執(zhí)行時(shí)間,ATmega48的數(shù)據(jù)吞吐率高達(dá)1 MIPs/MHz,運(yùn)行速度比普通的單片機(jī)高出10倍,從而可以緩解系統(tǒng)在功耗和處理速度之間的矛盾。

其片內(nèi)集成了4 KB的系統(tǒng)內(nèi)可編程Flash、256字節(jié)的EEPROM、512字節(jié)的SRAM。其外設(shè)具有可編程的串行USART接口、可工作于主機(jī)/從機(jī)模式的SPI串行接口;存在2個(gè)具有獨(dú)立預(yù)分頻器和比較器功能的8位定時(shí)/計(jì)數(shù)器和1個(gè)具有預(yù)分頻器、比較功能和捕捉功能的16位定時(shí)/計(jì)數(shù)器、具有獨(dú)立片內(nèi)振蕩器的可編程看門狗定時(shí)器等。ATmega48/88/168芯片硬件電路可以完全兼容,完全可以根據(jù)軟件實(shí)際需求靈活選擇AVR芯片,極大地方便系統(tǒng)的開發(fā)與研制。

2 CMX865簡介

CMX865是CML公司新出的一款DTMF編/解碼器/FSK調(diào)制解調(diào)器復(fù)合IC芯片,它采用單個(gè)高速串行總線控制,與大多數(shù)串行接口兼容。 CMX865的主要特征是:

◆供電電壓2.7~5.5 V,低功耗操作模式;

◆支持V.23、Bell202 FSK 1200 bps編碼/解碼;

◆集成高可靠性DTMF、編碼器/解碼器;

◆集成振鈴檢測功能,支持語音探測功能。

3 硬件設(shè)計(jì)

圖1為串口轉(zhuǎn)FSK通信模塊電路。系統(tǒng)主要以AVR單片機(jī)ATmega48芯片和CMX865調(diào)制/解調(diào)芯片為硬件架構(gòu),ATmega48芯片利用C-BUS總線對(duì)CMX865芯片進(jìn)行控制操作,實(shí)現(xiàn)FSK通信。CMX865芯片的IRQN終端與CPU芯片的外部中斷0(INT0)相連,確保軟件可以采用中斷方式接收/發(fā)送FSK數(shù)據(jù)。CMX865芯片的時(shí)鐘信號(hào)、片選信號(hào)、響應(yīng)應(yīng)答數(shù)據(jù)信號(hào)、接收控制數(shù)據(jù)信號(hào)分別與ATmega48芯片的普通I/O接口引腳相連,CPU可以通過模擬口線方式對(duì)CMX865芯片進(jìn)行控制。

圖1還提供了基本的FSK接收/發(fā)送數(shù)據(jù)接口電路和振鈴檢測電路。在FSK發(fā)送電路中,CMX865芯片TXA(15引腳)處外接電阻的目的是匹配芯片接口對(duì)線路的交流阻抗。在FSK接收電路中,CMX865芯片RXAFB(9引腳)與RXAN(10引腳)之間的電容以及隔離變壓器之間電容設(shè)計(jì)的目的是濾除高頻噪聲;通過調(diào)節(jié)接收電路中兩個(gè)電阻R1、R2的阻值即可改變接收端提供給CMX865芯片信號(hào)的幅度。在振鈴檢測電路中,IC1是光電耦合器,不振鈴時(shí)光電三極管截止,RING為高電平;振鈴時(shí),振鈴信號(hào)經(jīng)過電容耦合及穩(wěn)壓管穩(wěn)壓,振鈴電壓使IC1內(nèi)發(fā)光二極管發(fā)光,照射到光電三極管的基極上導(dǎo)致光電三極管導(dǎo)通,RING為低電平,通過ATmega48引腳檢測到低電平的振鈴信號(hào)。

4 軟件實(shí)現(xiàn)

ATmega48芯片具有4 KB內(nèi)部Flash和512字節(jié)的片內(nèi)SRAM,軟件實(shí)現(xiàn)需考慮資源分配問題,特別是SRAM使用情況。由于程序涉及串口通信、DTMF通信和FSK通信3種情況,理論上需要開辟6個(gè)緩沖區(qū)。如果這樣,每一個(gè)緩沖區(qū)的大小顯然不能確保達(dá)到實(shí)際通信數(shù)據(jù)量的需求。結(jié)合FSK通信特點(diǎn),DTMF數(shù)據(jù)傳輸與FSK數(shù)據(jù)傳輸不可能同時(shí)發(fā)生,因此FSK與DTMF可共用相同緩沖區(qū)。同樣串口接收與FSK發(fā)送、串口發(fā)送與FSK接收都不會(huì)同時(shí)發(fā)生,這樣通信只需要開辟兩個(gè)緩沖區(qū)就可以確保模塊正常通信,考慮實(shí)際業(yè)務(wù)平臺(tái)數(shù)據(jù)量情況,軟件設(shè)計(jì)中為FSK接收開辟255字節(jié)緩沖區(qū)復(fù)用;FSK發(fā)送開辟45字節(jié)緩沖區(qū)復(fù)用。

4.1 主程序?qū)崿F(xiàn)流程

通信模塊主程序包括:CPU初始化、CMX865初始化、初始化建鏈、串口通信和FSK通信子程序等。主程序流程如圖2所示。初始化建鏈環(huán)節(jié)是模塊正常工作的基礎(chǔ),通過初始化建鏈操作,信息終端可以根據(jù)線路環(huán)境以及平臺(tái)超時(shí)機(jī)制對(duì)通信模塊參數(shù)進(jìn)行設(shè)置,確保通信的穩(wěn)定性。通信主流程循環(huán)執(zhí)行3個(gè)子功能函數(shù):線路狀態(tài)處理函數(shù)、串口數(shù)據(jù)解析與處理函數(shù)、鏈路保持函數(shù)。線路狀態(tài)處理函數(shù)設(shè)計(jì)了3種線路狀態(tài),即初始狀態(tài)、空閑狀態(tài)和摘機(jī)狀態(tài);正常工作時(shí)僅在空閑狀態(tài)和摘機(jī)狀態(tài)之間切換。其中在空閑狀態(tài)檢測振鈴、根據(jù)狀態(tài)位執(zhí)行摘機(jī)、DTMF撥號(hào)等操作;在摘機(jī)狀態(tài)根據(jù)狀態(tài)位執(zhí)行FSK收發(fā)、脫線檢測、掛機(jī)控制等操作。串口數(shù)據(jù)解析與處理函數(shù)包含串口數(shù)據(jù)按命令集解析、對(duì)解析命令進(jìn)行應(yīng)答和狀態(tài)置位處理部分。這樣線路狀態(tài)處理函數(shù)和串口數(shù)據(jù)解析與處理函數(shù)通過狀態(tài)置位標(biāo)志緊密連接起來。FSK數(shù)據(jù)采用中斷方式直接接收,接收完畢后在摘機(jī)狀態(tài)下直接通過串口發(fā)送給信息終端。由于串口發(fā)送應(yīng)用相對(duì)單一,為簡單處理串口發(fā)送采用即時(shí)應(yīng)答處理方式,分散在通信主流程各子功能函數(shù)中實(shí)現(xiàn),提高了通信效率。通過鏈路保持函數(shù)判斷串口通信是否異常,通信模塊周期性地向信息終端發(fā)送鏈路保持命令,如果3次重發(fā)均未收到終端應(yīng)答命令,通信模塊將自動(dòng)鎖閉線路,重新執(zhí)行初始化建鏈操作,實(shí)現(xiàn)串口異常的處理。

4.2 對(duì)外串口通信協(xié)議

模塊采用標(biāo)準(zhǔn)串口通信,波特率為19 200 bps,10位異步方式。定義串口通信數(shù)據(jù)包格式為:0x1E+命令+校驗(yàn)和反碼(對(duì)命令的校驗(yàn)和反碼),其中部分命令以變長方式發(fā)送。串口通信主要命令有:模塊初始化、鏈路保持、DTMF接收/發(fā)送、FSK接收/發(fā)送、振鈴、掛機(jī)等,命令具體格式和描述此處不加詳述。模塊初始化上電后由通信模塊自動(dòng)發(fā)起,直到正確接收到終端應(yīng)答初始化命令后,通信模塊才建鏈成功。信息終端初始化應(yīng)答命令主要提供FSK通信模塊參數(shù)配置信息。上電后如果FSK模塊未收到終端初始化應(yīng)答信息,則周期性地(每2 s)發(fā)送一次初始化建鏈命令,直到成功為止;模塊FSK通信過程中周期性地向終端發(fā)送鏈路保持命令,如果未收到終端應(yīng)答信息,則斷開FSK鏈接重新開始模塊初始化。

4.3 串口通信實(shí)現(xiàn)

AVR單片機(jī)串口通信往往采用SPI通信方式,通信模塊串口通信采用UART0控制/狀態(tài)寄存器和數(shù)據(jù)寄存器實(shí)現(xiàn)。串口通信子程序主要由串口發(fā)送/接收中斷子程序、串口接收命令解析子程序和串口組包發(fā)送子程序3部分組成。其中串口中斷接收程序?yàn)椋?/p>

具體執(zhí)行串口數(shù)據(jù)發(fā)送時(shí),需要提供發(fā)送數(shù)據(jù)長度、發(fā)送起始地址、置UCSROB寄存器值(UCSR0B |=0x28)。串口接收命令解析子程序按照對(duì)外串口通信協(xié)議解析串口命令,并根據(jù)命令描述調(diào)用子程序代碼執(zhí)行相應(yīng)子功能操作。為了通信容錯(cuò)處理,通信模塊需對(duì)接收串口數(shù)據(jù)進(jìn)行校驗(yàn),如果解析的串口命令格式正確,則向終端發(fā)送肯定應(yīng)答;否則發(fā)送否定應(yīng)答,等待終端重傳命令數(shù)據(jù)。串口組包發(fā)送子程序?qū)邮盏腇SK數(shù)據(jù)以及線路狀態(tài)等信息數(shù)據(jù),按照串口通信協(xié)議組包發(fā)送給信息終端。

4.4 FSK通信實(shí)現(xiàn)

FSK通信子程序主要由CMX865芯片寄存器操作、FSK收/發(fā)、DTMF收/發(fā)以及線路狀態(tài)檢測等子程序組成。ATmega48芯片采用模擬口線的方式對(duì)CMX865寄存器進(jìn)行讀/寫操作,其中對(duì)CMX865芯片寄存器讀操作程序?yàn)椋?/p>

FSK收/發(fā)、DTMF收/發(fā)子程序均以CMX865寄存器讀/寫操作函數(shù)為基礎(chǔ),通過設(shè)置CMX865寄存器的值,確定其工作模式。FSK數(shù)據(jù)發(fā)送、接收都可以通過CMX865芯片的IRQ中斷口線引起ATmega48芯片中斷,因此FSK數(shù)據(jù)收/發(fā)都通過中斷實(shí)現(xiàn)。芯片程序采用10 ms定時(shí)器循環(huán)檢測線路狀態(tài)。

結(jié)語

本文利用ATmega48芯片和CMX865芯片為硬件架構(gòu)設(shè)計(jì)了串口轉(zhuǎn)FSK通信模塊。由于ATmega48芯片與ATmega88芯片除了Flash、EEPROM、SR AM容量差異外,性能完全相同。通信模塊可以不更改硬件電路,僅配置相應(yīng)AVR芯片,對(duì)軟件稍作調(diào)整,能夠滿足通信業(yè)務(wù)對(duì)通信數(shù)據(jù)量增加的需求,節(jié)約模塊二次開發(fā)的成本。目前本通信模塊已在一款新型的電子交易終端上使用,并與中興、精倫等電子交易平臺(tái)進(jìn)行信息交互,運(yùn)行效果良好。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉