當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式教程
[導(dǎo)讀]嵌入式單總線控制器設(shè)計(jì)

DS1820是美國(guó)DALLAS公司生產(chǎn)的一種單總線(1-wire)數(shù)字溫度傳感器,采用1-wire總線通信協(xié)議。具有獨(dú)特的單總線通信方式以及較高的測(cè)量精度,從而獲得了廣泛應(yīng)用。參考文獻(xiàn)[1]詳細(xì)介紹了DS1820的基本原理和通信時(shí)序,提出由單片機(jī)的I/O端口模擬單總線時(shí)序來(lái)控制DS1820的方法[1]。參考文獻(xiàn)[2]更進(jìn)一步地將DS1820測(cè)量溫度的分辨率由0.5 ℃提高到了0.1 ℃。將DS1820應(yīng)用于不同領(lǐng)域,同樣取得了較好的效果[3-5]。上述文獻(xiàn)在使用DS1820時(shí)均采用微處理器作為總線主機(jī),利用微處理器的I/O端口,用軟件模擬單總線時(shí)序,實(shí)現(xiàn)與DS1820的通信。因?yàn)?-wire器件對(duì)總線時(shí)序要求嚴(yán)格,因此,為了保證與DS1820的可靠通信,微處理器需要采用關(guān)閉中斷的辦法,以防止操作時(shí)序被中斷服務(wù)所破壞。這種方法增加了軟件的設(shè)計(jì)難度,影響了系統(tǒng)的實(shí)時(shí)性[6]。

  VHDL作為電子設(shè)計(jì)主流硬件描述語(yǔ)言,采用了層次化設(shè)計(jì)方式,具有電路行為描述能力強(qiáng)、靈活、通用、運(yùn)算速度快的特點(diǎn),能夠較容易地實(shí)現(xiàn)時(shí)序邏輯控制[7]。以數(shù)字溫度傳感器DS1820為例,設(shè)計(jì)一個(gè)基于VHDL的單總線控制器,實(shí)現(xiàn)與DS1820的通信。本文介紹的單總線控制器,有較強(qiáng)的可擴(kuò)展性,可以連接多種單總線器件,且微處理器可以不用被迫關(guān)閉中斷,滿足實(shí)時(shí)性嚴(yán)格要求的應(yīng)用。

  1 DS1820簡(jiǎn)介

  1.1 DS1820內(nèi)部結(jié)構(gòu)

  DS1820主要由4部分組成:64 bit光刻ROM、溫度敏感器件、高速暫存存儲(chǔ)器和溫度報(bào)警觸發(fā)器TH、TL。64 bit光刻ROM保存DS1820的唯一64 bit的ROM編碼。高速暫存存儲(chǔ)器包含9個(gè)連續(xù)的字節(jié),存放測(cè)得的溫度(補(bǔ)碼)、TH和TL的拷貝、計(jì)數(shù)器余值和CRC校驗(yàn)等數(shù)據(jù),其結(jié)構(gòu)如圖1所示。所有數(shù)據(jù)均以最低有效位在前的方式讀寫(xiě)。

  DS1820可以采用寄生電源的方式供電,在信號(hào)線為高電平的時(shí)間周期內(nèi),把能量?jī)?chǔ)存在內(nèi)部電容器中,在信號(hào)線為低電平期間,由存儲(chǔ)在電容器內(nèi)的電荷供電。DS1820工作時(shí)信號(hào)線須接4.7 kΩ的上拉電阻,以保證信號(hào)線有足夠的驅(qū)動(dòng)能力。

  1.2 DS1820時(shí)序及工作方式

  DS1820時(shí)序如圖2所示,時(shí)序波形的電平分為3種類(lèi)型:主機(jī)作用的高低電平、DS1820輸出的高低電平和由上拉電阻拉起的高電平(后2種情況主機(jī)釋放信號(hào)線)。DS1820閑置時(shí)信號(hào)線應(yīng)保持高電平。對(duì)DS1820的任何操作(讀、寫(xiě)、復(fù)位等)都是由主機(jī)對(duì)信號(hào)線由邏輯高電平拉至低電平開(kāi)始。

  由時(shí)序圖可知,單總線的通信協(xié)議由6種信號(hào)類(lèi)別組成:復(fù)位脈沖、存在脈沖、寫(xiě)0、寫(xiě)1、讀0、讀1。所有這些信號(hào)除了存在脈沖之外,均由總線主機(jī)產(chǎn)生。

  主機(jī)通過(guò)單總線對(duì)DS1820的操作必須首先由ROM操作命令之一開(kāi)始?,F(xiàn)以單總線只掛接一個(gè)DS1820,讀取溫度數(shù)據(jù)為例,其工作過(guò)程如下:

  (1)主機(jī)產(chǎn)生復(fù)位脈沖,DS1820返回響應(yīng)脈沖;

  (2)主機(jī)寫(xiě)入Skip ROM(CCH,跳過(guò)ROM)命令,該命令為5種ROM操作命令之一;

  (3)主機(jī)寫(xiě)入溫度轉(zhuǎn)換(44H)命令;

  (4)主機(jī)再次產(chǎn)生復(fù)位脈沖,DS1820返回響應(yīng)脈沖;

  (5)主機(jī)寫(xiě)入Skip ROM(CCH,跳過(guò)ROM)命令;

  (6)主機(jī)寫(xiě)入讀暫存存儲(chǔ)器命令(BEH);

  (7)讀暫存存儲(chǔ)器的溫度數(shù)據(jù)。[!--empirenews.page--]

  2 控制器設(shè)計(jì)

  2.1 控制器結(jié)構(gòu)

  控制器結(jié)構(gòu)如圖3所示,控制器由4部分組成,即邏輯控制、單總線時(shí)序控制、數(shù)據(jù)緩存和計(jì)數(shù)器。邏輯控制部分用于實(shí)現(xiàn)與CPU的通信,D0~D7為8位雙向數(shù)據(jù)線,EN為啟動(dòng)信號(hào),下降沿有效。A1、A0為地址信號(hào),其組合決定控制器的工作狀態(tài)。A1A0=00,控制器對(duì)DS1820執(zhí)行復(fù)位操作;A1A0=01,控制器執(zhí)行寫(xiě)入操作;A1A0=10,控制器執(zhí)行讀出操作??刂破饔赏獠刻峁?00 kHz的時(shí)鐘信號(hào)CLK,產(chǎn)生5 μs的計(jì)數(shù)周期,控制器以5 μs為一個(gè)時(shí)間片形成DS1820的讀寫(xiě)時(shí)序。計(jì)數(shù)器的計(jì)數(shù)輸出值控制讀寫(xiě)周期。單總線時(shí)序控制部分的主要功能是產(chǎn)生單總線的讀寫(xiě)時(shí)序,并向DS1820輸出控制命令,讀出DS1820測(cè)得的數(shù)字溫度值及其他輸出信息。

2.2 讀寫(xiě)時(shí)序的實(shí)現(xiàn)

  DS1820要求引腳驅(qū)動(dòng)必須是漏極開(kāi)路引腳,控制器用三態(tài)門(mén)與DS1820連接,如圖4所示。其中ctrl為三態(tài)門(mén)控制信號(hào),當(dāng)ctrl=0時(shí)輸出信號(hào),ctrl=1時(shí)輸入信號(hào)??刂破鞑捎? μs作為基本計(jì)時(shí)單位,可以保證DS1820時(shí)序關(guān)系有一定的余地。

  寫(xiě)字節(jié)部分VHDL代碼:

  3 仿真波形

  控制器的VHDL程序在MAX+plusII平臺(tái)編譯通過(guò),并獲得了正確的復(fù)位、讀、寫(xiě)時(shí)序。圖5為寫(xiě)時(shí)序波形,寫(xiě)入77H字節(jié)。每次寫(xiě)入新的bit前,控制器將總線電平拉底10 μs。

 

  基于VHDL的嵌入式DS1820控制器,具有轉(zhuǎn)換速度快、精度高、通用性好等優(yōu)點(diǎn)。同時(shí),嵌入軟核的FPGA可以分擔(dān)許多微處理器的工作,降低系統(tǒng)對(duì)CPU實(shí)時(shí)性的要求,也降低了軟件開(kāi)發(fā)的難度。本文雖然是針對(duì)DS1820設(shè)計(jì)的控制器,但由于單總線通信協(xié)議的通用性,也可以用于其他單總線器件。

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

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

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

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

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

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(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ì)日本游戲市場(chǎng)的投資。

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

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

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

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

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

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

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

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

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

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

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