<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > C8051F120與RS422息線的時鐘同步技術

          C8051F120與RS422息線的時鐘同步技術

          作者: 時間:2011-10-15 來源:網(wǎng)絡 收藏

          引 言
          由于指令的速度不斷加快,單片機在各個方面的性能大為提高,比如多個單片機之間的時鐘同步。Silicon Labs公司的C8051F系列單片機的執(zhí)行速度最高可以達到100MIPS,這使得更高精度的時鐘同步成為可能。時鐘同步是一個在多單片機相互配合時經(jīng)常遇到的問題,主要有兩種同步方式——絕對同步和相對同步。絕對同步是指各個控制器和一個標準的時間進行同步,比如北京時間、華盛頓時間等等;而相對時鐘同步是指各個單片機和一個相對穩(wěn)定的時鐘進行同步,與外界的時間沒有聯(lián)系。本文主要針對RS422總線組成的網(wǎng)絡的高精度時鐘同步問題,提出了一種相對時鐘同步解決方案。


          1 整體框架結構
          RS422網(wǎng)絡中,多個單片機的連接如圖1所示。這是一個典型的“一主多從”式結構:主單片機通過向從單片機發(fā)送命令,實現(xiàn)管理功能;從單片機主要執(zhí)行具體的功能,比如數(shù)據(jù)采集、D/A轉換輸出等。為了使多個單片機能夠同步工作,需要一種同步方式,所以從單片機不但要實現(xiàn)各自的具體功能,而且還要能夠進行多個單片機的時鐘同步。本方案設計了從單片機的幾種工作狀態(tài)。R和T分別表示R+、R-和T+、T-。

          2 從單片機的狀態(tài)機
          本文重點介紹系統(tǒng)時鐘同步功能的實現(xiàn),但是在實際應用過程中,該系統(tǒng)必定要實現(xiàn)其他的功能,比如數(shù)據(jù)采集、模擬量輸出等。主單片機的作用是控制從單片機工作,所以要使從單片機具有不同的工作狀態(tài)。本文設計了3種工作狀態(tài):準備態(tài)、時鐘同步態(tài)、工作態(tài)。3種工作狀態(tài)之間的相互轉換過程如圖2所示。圖中,①代表主單片機向從單片機發(fā)送“工作”命令;②代表主單片機向從單片機發(fā)送“時鐘同步”命令;③代表主單片機向從單片機發(fā)送“工作態(tài)向時鐘同步態(tài)轉換”命令;④代表主單片機向從單片機發(fā)送“時鐘同步態(tài)向工作態(tài)轉換”命令。

          準備態(tài)是從單片機上電后的工作狀態(tài),當主單片機向某一從單片機發(fā)送“是否準備好”命令后,若從單片機回復“準備好”,則說明從設備已經(jīng)處于準備好的狀態(tài),可以向時鐘同步態(tài)和工作態(tài)進行轉換。如果從單片機處于工作態(tài),主單片機發(fā)送“工作態(tài)向時鐘同步態(tài)轉換”命令,則從時鐘進入時鐘同步態(tài);如果從單片機處于時鐘同步態(tài),主單片機發(fā)送“時鐘同步態(tài)向工作態(tài)轉換”命令,則從單片機由時鐘同步態(tài)轉換到工作態(tài)。

          3 時鐘同步設計的基本原理
          本方案采用多個單片機組成RS422網(wǎng)絡。單片機具有高達100MIPS的執(zhí)行速度,也就是1μs可以執(zhí)行100條單周期指令,所以定時器定時1μs可以達到1%的精度。而RS4.22總線組成的網(wǎng)絡是“一主多從”式結構,網(wǎng)絡中每個設備都有自己的時鐘,時鐘采用定時器實現(xiàn),1μs觸發(fā)一次。主設備和從設備的時鐘偏差產(chǎn)生有兩個原因;一是某些隨機因素產(chǎn)生的誤差;二是由于晶振的運行速度不同引起的誤差,此誤差的產(chǎn)生主要受溫度的影響,而溫度又是由工作環(huán)境來決定的。本文采用相對時鐘同步的方法來減小這種誤差的影響。
          該方法分為2步:
          ①主設備每2 s進行一次時鐘同步。主設備首先發(fā)送報文master_a(該報文本身不含發(fā)送時間),之后再發(fā)送一幀帶有該報文發(fā)送時間信息的報文master_b。這樣,從設備可以分析出主設備的同步報文的發(fā)送時間T1和接收時間T2(如無特殊標注,文中所涉及的時間變量都是以μs為單位的)。從設備再發(fā)送一個報文slave_c,并記下這個報文的發(fā)送時間T3,主設備接到該報文后記下接收時間T4,并把T4發(fā)給從設備,從設備就有了T1、T2、T3、T4的值。由于主設備和從設備都采用同一波特率進行串行通信,所以只要保證主設備的報文和從設備的報文發(fā)送的字節(jié)數(shù)相同,就可以看成主設備和從設備的發(fā)送時間和接收時間是相同的,即圖3中的T1、T2、T3、T4四點構成的是等腰梯形。所以主設備和從設備之間的時間偏差:


          從設備的時間T_Slave減去從設備和主設備之間的偏差△,即校正后的時間。但此時校正后的結果只是改變從設備的時鐘誤差,并沒有改變從時鐘的時鐘頻率。隨著時間的增長,這個誤差就又會出現(xiàn),因此想要減小這個誤差必須采用進一步的方法。
          ②進行時鐘頻率的校正。單片機的指令速度很快(可達100MIPS),這就為單片機應用內部定時器實現(xiàn)頻率可調時鐘創(chuàng)造了有利條件。本文多次測量從設備和主設備之間的時間誤差來求取平均值,作為主從時鐘在規(guī)定時間內的從設備和主設備之間的誤差,通過這個誤差來修正從設備的時鐘頻率。具體做法為:測量5次從設備和主設備之間的偏差△1~△5,采用平均值濾波法得到的結果△z作為2 s的時間偏差。

          其中,t代表1μs內時鐘的偏差量,單位是0.01 μs。只須修改定時器的相應寄存器,就可以達到調整時鐘頻率的目的。

          4 系統(tǒng)的硬件連接
          各個單片機采用RS422總線進行互聯(lián),形成一個“一主多從”的結構。RS422接口電路如圖4所示。接口芯片采用Maxim公司的MAX489,其中DI、RO連接在C8051F120單片機的串口上,用端子J將各個RS422的各路信號引出。

          5 時鐘同步軟件設計
          時鐘同步部分的軟件設計包括主、從單片機的工作過程,以及頻率可調時鐘部分和時鐘校準部分的實現(xiàn),但不包括狀態(tài)轉換功能的實現(xiàn)。
          編者注:主從機程序略。


          結 語
          時鐘同步問題是多單片機同步工作面臨的一個重要問題。本文針對RS422網(wǎng)絡的時鐘同步工作問題,提出了一種相對時鐘同步解決方案;并應用單片機片內定時器設計了一個頻率可調時鐘,在沒有增加硬件成本的前提下,明顯地減小了不同單片機之間的時鐘偏差。



          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();