當(dāng)前位置:首頁 > 通信技術(shù) > 通信技術(shù)
[導(dǎo)讀]借助系統(tǒng)模型,闡明GSM模塊收發(fā)短信的基本概念以及串口控制SMS的基本原理。詳細(xì)介紹單片機控制GSM模塊工作的軟件實現(xiàn)過程,對怎樣用單片機控制GSM模塊收發(fā)短信進(jìn)行探討,也對程序設(shè)計的主體思想作了較為細(xì)致的分析。

   摘要:借助系統(tǒng)模型,闡明GSM模塊收發(fā)短信的基本概念以及串口控制SMS的基本原理。詳細(xì)介紹單片機控制GSM模塊工作的軟件實現(xiàn)過程,對怎樣用單片機控制GSM模塊收發(fā)短信進(jìn)行探討,也對程序設(shè)計的主體思想作了較為細(xì)致的分析。

    關(guān)鍵詞:單片機 短信收發(fā) 軟件設(shè)計

GSM(Global System for Mobile communication)系統(tǒng)是目前基于時分多址技術(shù)的移動通信體制中,比較成熟完善,且應(yīng)用最廣泛的一種系統(tǒng)。目前已建成的覆蓋全國的GSM數(shù)字蜂窩移動通信網(wǎng),是我國公眾移動通信網(wǎng)的主要方式?;贕SM的短信信息服務(wù),是一種在移動網(wǎng)絡(luò)上傳送簡短信息的無線應(yīng)用,是一種信息在移動網(wǎng)絡(luò)上存儲和轉(zhuǎn)寄的過程。由于公眾GSM網(wǎng)絡(luò)在全球范圍內(nèi)實現(xiàn)了聯(lián)網(wǎng)和漫游,建議上述系統(tǒng)不需再組建專用通信網(wǎng)絡(luò),所以具有實時傳輸數(shù)據(jù)功能的短信應(yīng)用將得到迅速普及。筆者開發(fā)設(shè)計的基于GSM網(wǎng)絡(luò)的溫度數(shù)據(jù)采集與無線傳輸系統(tǒng)正是借助該網(wǎng)絡(luò)平臺,利用短信息業(yè)務(wù)實現(xiàn)數(shù)據(jù)的自動雙向傳遞。系統(tǒng)模型圖如圖1所示。

本系統(tǒng)由數(shù)據(jù)采集部分、數(shù)據(jù)接收和發(fā)送部分、終端處理部分三個模塊組成。數(shù)據(jù)采集模塊將采集到的溫度數(shù)據(jù)存入存儲器中。數(shù)據(jù)收發(fā)模塊采用雙單片機共用E2RPOM的方式,單片機2控制數(shù)據(jù)從存儲器轉(zhuǎn)存入E2PROM中;單片機1負(fù)責(zé)將數(shù)據(jù)從E2PROM中讀出,并經(jīng)GSM模塊2借助GSM網(wǎng)絡(luò)將數(shù)據(jù)發(fā)送出去。單片機1不僅控制數(shù)據(jù)的發(fā)送,也控制數(shù)據(jù)的接收。在這里,E2PROM是溫度數(shù)據(jù)臨時存儲和上傳的中轉(zhuǎn)站。終端處理模塊負(fù)責(zé)將接收到的數(shù)據(jù)交給計算機處理,并將處理后的結(jié)果存放到數(shù)據(jù)庫中,以供查詢。當(dāng)終端處理模塊需要向GSM模塊2發(fā)送控制命令時,GSM模塊2接收過程正好與上述過程相反,從而實現(xiàn)數(shù)據(jù)的自動雙向傳遞。

    系統(tǒng)中,三個模塊相互獨立,彼此又相互依賴,共同完成數(shù)據(jù)的傳輸。數(shù)據(jù)收發(fā)模塊在系統(tǒng)中起著承上啟下的作用,是系統(tǒng)的核心模塊。該模塊以雙單片機為核心,以RS232通信接口,在物理層上實現(xiàn)與GSM模塊的連接。由于篇幅的限制,本文主要介紹單片機控制這一模塊工作的軟件實現(xiàn)過程,旨在對怎樣用單片機控制GSM模塊收發(fā)短信息進(jìn)行探討。

1 GSM模塊MZ28

MZ28是中興通訊推出的GSM無線雙頻調(diào)制解調(diào)器,主要為語音傳輸、短信發(fā)送和數(shù)據(jù)業(yè)務(wù)提供無線接口。MZ28集成了完整的射頻電路和GSM的基帶處理器,特別適合于迅速開發(fā)基于GSM無線網(wǎng)絡(luò)的無線應(yīng)用產(chǎn)品。帶有人機接口(MMI)界面的應(yīng)用產(chǎn)品內(nèi)部與MZ28的通信可通過標(biāo)準(zhǔn)的串行接口(RS232)進(jìn)行。MZ28使用簡單的20-PIN ZIP插座與用戶自己的應(yīng)用系統(tǒng)相連,此ZIP連接方式提供開發(fā)所需的數(shù)據(jù)通信、音頻和電源等接口信號。MZ28可以作為無線引擎,嵌入到用戶自己的產(chǎn)品當(dāng)中,用戶可以用單片機或其它CPU的UART口,使用相應(yīng)的AT命令,對模塊進(jìn)行控制,達(dá)到使其產(chǎn)品可以輕松進(jìn)入GSM網(wǎng)絡(luò)的目的。

2 串口控制SMS的工作原理

單片機與GSM模塊一般采用串行異步通信接口,通信速度可設(shè)定,通常為19200bps。采用這種RSM232電纜方式進(jìn)行連接時,數(shù)據(jù)傳輸?shù)目煽啃暂^好。RS232接口方式連接,通過串行接口集成電路和電平轉(zhuǎn)換電路與GSM模塊連接,電路比較簡單,所涉及的芯片包括單片機89C52和電平轉(zhuǎn)換芯片MAX232,是非常常見的接口電路。需要說明的是,該接口通過I2C總線擴展了一個E2PROM存儲器芯片AT24C64,它的主要作用是存儲數(shù)據(jù),而且斷電信息也不會丟失,這些特性正是存儲數(shù)據(jù)所必須的。

GSM的短信息業(yè)務(wù)SMS利用信令信道傳輸,這是GSM通信網(wǎng)所特有的。它不用撥號建立連接,把要發(fā)的信息加上目的數(shù)據(jù)發(fā)送到短信息服務(wù)中心,經(jīng)短信服務(wù)中心完成存儲后再發(fā)送給最終的信宿。所以當(dāng)目的GSM終端沒開機時信息不會丟失。每個短信的信息量限制為160字節(jié)。

現(xiàn)在市場上大多數(shù)手機均支持GSM07.05規(guī)定的AT指令集。該指令集是ETSI(歐洲通信技術(shù)委員會)發(fā)布的,其中包含了對SMS的控制。利用GSM手機的串行接口,單片機向手機收發(fā)一系列的AT命令,就能達(dá)到控制GSM模塊收發(fā)SMS的目的。必須注意的是,用單片機實現(xiàn)時,編程必須注意它發(fā)送指令與接收到的響應(yīng)都是字符的ASCII碼。用單片機控制GSM模塊收發(fā)短信息所涉及以的AT指令如表1所列。

表1 AT指令

AT指令

功  能  描  述

AT+OFF 關(guān)機并重新啟動
AT+CSDH=0 在TEXT模式下在返回值中不顯示詳細(xì)的頭信息
ATE0 關(guān)閉回顯
AT+CMGF=1 選擇短信格式為TEXT模式
AT+CMGS 發(fā)送短信息
AT+CMGR 讀取短信息
AT+CMGD=0 刪除全部短信息

3 軟件實現(xiàn)

3.1 上位機模塊和下位機模塊半雙工通信協(xié)議的實現(xiàn)

3.1.1 應(yīng)答和重發(fā)

上位機模塊和下位模塊的通信雙方遵照半雙工通信方式進(jìn)行,即數(shù)據(jù)傳送是雙向的。但是,任何時刻只能由其中的一方發(fā)送數(shù)據(jù),另一方接收數(shù)據(jù),因為E2PROM的讀出和寫入不能同時進(jìn)行。為了避免一方在發(fā)送信息幀時(這里的信息幀指的是下位機模塊發(fā)送的數(shù)據(jù)幀和上位機模塊發(fā)送的命令幀,下同),另一方也會發(fā)送數(shù)據(jù),必須把信道變成半雙工方式。盡管這樣效率可能不如全雙工方式,但通過此舉犧牲效率可以換取模塊工作性能的穩(wěn)定。雙方采取的順序是:發(fā)→收到應(yīng)答后→再發(fā)。

按照整個系統(tǒng)的設(shè)計思路,上位機模塊(即圖1中的GSM模塊1,下同)發(fā)送的幀包括命令幀、確認(rèn)幀和非確認(rèn)幀;下位機模塊(即圖1中的GSM模塊2,下同)發(fā)送的幀包括數(shù)據(jù)幀、確認(rèn)幀和非確認(rèn)幀。其中確認(rèn)幀和非確認(rèn)幀是發(fā)送數(shù)據(jù)后等待對方發(fā)送的應(yīng)答幀,以此作為繼續(xù)發(fā)送下一幀和重新發(fā)送上一幀的依據(jù)。命令幀和數(shù)據(jù)幀是信息幀,當(dāng)一方先發(fā)送完信息幀,如果收方接收到對方的信息幀,而又沒有信息幀需要發(fā)送,那么情況就比較簡單,收方將根據(jù)信息幀的正確與否決定發(fā)送確認(rèn)幀還是非確認(rèn)幀,以使對方?jīng)Q定是繼續(xù)發(fā)送還是重新發(fā)送;如果此刻收方也有信息幀需要發(fā)送,那么收方將不立即發(fā)送應(yīng)答幀,而是立即發(fā)送本方的信息幀給對方,并等待對方對此幀的應(yīng)的應(yīng)答幀,在收到對方的應(yīng)答幀后,收方將依據(jù)應(yīng)答幀的內(nèi)容(即確認(rèn)幀或者是非確認(rèn)幀,下同)決定是繼續(xù)發(fā)送下一信息幀,還是重新發(fā)送原來的信息幀。如果由于鏈路本身不可靠等因素造成應(yīng)答幀的丟失,收方將在一定時間內(nèi)因為沒有收到應(yīng)答幀而延時重發(fā)原來的信息幀。在收到對方的應(yīng)答幀后,收方將繼續(xù)發(fā)送下一信息幀,并等待對方的應(yīng)答幀,如此反復(fù),直到收方全部發(fā)送完信息幀。在本方收到對方最后一個應(yīng)答幀后,表明本方全部的信息幀發(fā)送完畢。然后收方將發(fā)送對方仍然等待的應(yīng)答幀,通知對方收到的信息幀正確與否。

圖2

    3.1.2 延時重發(fā)

在雙方通信過程中,有兩個時間t1和t2,分別表示重新發(fā)送信息幀的最大延時。t1表示一方發(fā)送完信息幀到收到對方應(yīng)答幀的時間,如果等待應(yīng)答幀的時間超過了t1,則發(fā)方會重新發(fā)送原來的信息幀;當(dāng)收方接收到對方發(fā)送的信息幀,如果收方此時有需要發(fā)送的信息幀,則收方此記得不發(fā)送應(yīng)答幀,而是發(fā)送信息幀給對方。也就是說,利用對方等待收方應(yīng)答幀的時間t1內(nèi),收方插入發(fā)送本文的信息幀,同樣本方的發(fā)送也存在一個延時重發(fā)的問題。在規(guī)定的時間內(nèi),如果沒有收到對方應(yīng)答幀,收方也同樣需要重發(fā)原來的信息幀,這個規(guī)定的時間就是t2。顯然由于收方是利用間隙時間發(fā)送本方信息幀,所以t2<t1。

圖2以下位機模塊先發(fā)數(shù)據(jù)幀為例,闡述雙方通信的具體實現(xiàn)過程。

需要說明的是,由于版面的限制,圖2所示的通信過程沒有涉及到發(fā)送非確認(rèn)幀的情況,如果收方發(fā)送非常認(rèn)幀,發(fā)方的發(fā)送過程跟發(fā)送數(shù)據(jù)幀是一樣的,只不過這種情況下需要重發(fā)同一幀號的數(shù)據(jù)幀。如果上位機模塊先發(fā)命令幀,雙方通信的實現(xiàn)過程跟圖2類似,所不同的是數(shù)據(jù)幀此時變成命令幀,命令幀變成數(shù)據(jù)幀。在延時的時間上,無論是下位機發(fā)送數(shù)據(jù)幀還是上位機發(fā)送命令幀,t2的大小都應(yīng)該是一樣的,都是利用時間間隔t2發(fā)送收方信息幀,延時的時間是相同的。然而,對于t1而方,情況就有所不同。因為下位機模塊先發(fā)送數(shù)據(jù)幀時,利用t1的間隔時間上位機模塊發(fā)送的命令幀可靠較少,因此當(dāng)下位機模塊先發(fā)送數(shù)據(jù)幀時所定義的t1應(yīng)該小于當(dāng)上位機模塊先發(fā)送命令幀時,所定義的t1。這是因為當(dāng)上位機模塊先發(fā)送命令幀時,利用t1的間隔時間下位機模塊發(fā)送的數(shù)據(jù)幀可能比較多。

3.2 幀格式

GSM模塊通過異步通信接口實現(xiàn)對SMS的控制共有三種接入?yún)f(xié)議:Block Mode;基于AT指令的Text Mode;基于AT指令PDU Mode。本系統(tǒng)發(fā)送和接收的數(shù)據(jù)都是基于數(shù)字的溫度數(shù)據(jù)和命令字,為了保證系統(tǒng)的適用性,SMS的收發(fā)采用TEXT模式。TEXT模式是基于字符的,更具體地說是基于ASCII碼的一種結(jié)構(gòu)模式。在該模式下,模塊發(fā)送和接收的信息幀格式如下:

幀頭 幀序號 數(shù)據(jù) 校驗子

信息幀包括數(shù)據(jù)幀和命令幀。

幀頭表示數(shù)據(jù)幀的標(biāo)記,是由固定的字符“WQ”構(gòu)成。

幀序號表示數(shù)據(jù)幀的序號,由兩個字節(jié)組成。幀序號表示下位機模塊發(fā)送的遞增數(shù)據(jù)幀序號和上位機模塊發(fā)送的命令幀序號。為了簡化幀結(jié)構(gòu),命令幀的序號統(tǒng)一為00H。

數(shù)據(jù)字段的長度為154字節(jié),最多發(fā)送77個字符(采用TEXT模式,不能發(fā)送漢字)。

檢驗子為數(shù)據(jù)字段所有字節(jié)累加和的初碼(原碼取反加1),由一個字節(jié)組成。

除了信息幀外,雙向傳遞的還有應(yīng)答幀,它包括確認(rèn)幀和非確認(rèn)幀。確認(rèn)幀是雙方反饋給發(fā)方的應(yīng)答幀,表示收方已經(jīng)正確接收到了發(fā)方發(fā)送的信息幀。確認(rèn)幀格式僅包括兩個字段,且兩個字段的內(nèi)容都是固定的,即幀頭“WQ”和數(shù)據(jù)字段“ACK”,確認(rèn)幀格式如下。

WQ ACK

非確認(rèn)幀是收方給發(fā)方的應(yīng)答幀,表示收方收到的是無效的信息幀,其格式與應(yīng)答幀格式類似,幀格式如下。

WQ NACK

3.3 E2PROM空間的分配

采用8KB的E2PROM,按照每77個字節(jié)為一個塊進(jìn)行劃分,共106塊,如圖3所示。

第00、01塊留作系統(tǒng)使用,第02塊~第105塊是數(shù)據(jù)塊,用作存放數(shù)據(jù)。

3.4 收發(fā)端與采集端的握手協(xié)議

收發(fā)端與采集端共用一個存儲器,即雙CPU對同一個E2PROM進(jìn)行操作。實現(xiàn)方案是分別使兩個微處理器的一個I/O腳相連,兩個CPU采用查詢方式對此I/O端進(jìn)行查詢。如果某時候收發(fā)端查詢到本地I/O端為高電平,則單片機1擁有此存儲器的操作權(quán),可以對E2PROM進(jìn)行讀寫操作。如果采集端查詢到本地I/O端為高電平,則單片機2擁有此存儲器的操作權(quán),可以對它進(jìn)行寫操作。一方操作完畢后將I2C總線置為高電平,表明本端已經(jīng)釋放I2C總線,E2PROM目前處于可用狀態(tài)。

3.5 程序的設(shè)計

3.5.1 主函數(shù)的設(shè)計思路

開機上電后,程序在主函數(shù)中運行,單片機和GSM模塊分別進(jìn)行初始化。單片機的初始化包括設(shè)置串口工作方式、波特率,并初始化變量參數(shù)和標(biāo)志位。GSM模塊初始化包括重新啟動、關(guān)閉回顯、設(shè)置在TEXT模式下的返回值中不顯示詳細(xì)的頭信息、選擇短信格式為TEXT模式、開發(fā)串口中斷準(zhǔn)備接收數(shù)據(jù)。

3.5.2 GSM返回參數(shù)的處理—SHELL函數(shù)

SHELL函數(shù)是進(jìn)入時鐘中斷程序時被調(diào)用時,該函數(shù)是對GSM模塊返回參數(shù)進(jìn)行處理的函數(shù)。根據(jù)系統(tǒng)設(shè)計的要求,需要對GSM模塊進(jìn)行下列操作:呼叫對方模塊號碼、發(fā)送數(shù)據(jù)、閱讀短信、刪除短信?;谝陨喜僮髦噶睿绻僮鞒晒?strong>GSM模塊會分別返回不同的參數(shù):>、+CMGS、+CMGR、OK。根據(jù)接收到的不同參數(shù),下位機模塊將轉(zhuǎn)向不同的操作步驟,判斷并改變標(biāo)志位的值。比如,如果某時刻接收到>,這表明呼叫對方模塊號碼獲得成功,接下來需要發(fā)送數(shù)據(jù)。這時SHELL函數(shù)將檢查發(fā)送不同數(shù)據(jù)所代表的標(biāo)志位f_sending、f_ack、f_nack,從而決定需要發(fā)送何種類型的數(shù)據(jù)。

    3.5.3 短信數(shù)據(jù)的處理—ExecData函數(shù)

進(jìn)入時鐘中斷調(diào)用SHELL函數(shù)時,如果接收到了返回的參數(shù)+CMTI,表明上位機模塊向下位機模塊發(fā)送了短信數(shù)據(jù),可能是命令幀,也可能是確認(rèn)幀或者非確認(rèn)幀。在這種情況下,SHELL函數(shù)需要對短信內(nèi)容進(jìn)行分析,并根據(jù)短信的內(nèi)容進(jìn)行不同的處理,負(fù)責(zé)完成以上功能的就是ExecData函數(shù),它是被SHELL函數(shù)調(diào)用的,用來分析并處理短信數(shù)據(jù)。

結(jié)語

通過以上的分析不難發(fā)現(xiàn),整個程序錯綜復(fù)雜,函數(shù)之間相互牽扯。標(biāo)志位在程序的實現(xiàn)過程中扮演著非常重要的角色,正是依靠這些標(biāo)志位,程序才能很好地實現(xiàn)各個功能之間的切換,而標(biāo)志位的值是通過OSM模塊返回的參數(shù)修改的。因此程序的實現(xiàn)過程應(yīng)該是閱讀參數(shù)→修改標(biāo)志位→發(fā)送指令。

主函數(shù)、時鐘中斷和串口中斷程序、SHELL函數(shù)、ExecData函數(shù)貫穿整個程序的主線和核心部分,對它們的分析可以理解程序的主體思想,這也正是筆者著重介紹的原因所在。然而這些函數(shù)和中斷程序的實現(xiàn),還需要依靠其它函數(shù)的配合,比如基于I2C總線的E2PROM操作函數(shù)、字符串操作函數(shù)以及串口發(fā)送函數(shù)等,由于篇幅所限,在此不再介紹。GSM網(wǎng)絡(luò)本身是不完全可靠的,可能會發(fā)生幀發(fā)送錯誤、幀丟失的現(xiàn)象。但是由于重發(fā)、延時重發(fā)機制的存在,程序可以最大程度避免上述情況的發(fā)生。在實際應(yīng)用過程中,模塊運行正常,性能穩(wěn)定,實時性好。

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

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

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

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

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

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

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

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

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

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

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

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

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

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

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

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

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(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)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

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