色婷婷AⅤ一区二区三区|亚洲精品第一国产综合亚AV|久久精品官方网视频|日本28视频香蕉

          新聞中心

          EEPW首頁 > 電源與新能源 > 設(shè)計應(yīng)用 > 基于FPGA的錯誤檢測與自動糾正的設(shè)計實現(xiàn)

          基于FPGA的錯誤檢測與自動糾正的設(shè)計實現(xiàn)

          作者: 時間:2012-03-11 來源:網(wǎng)絡(luò) 收藏

          引言

          在一些電磁環(huán)境比較惡劣的情況下,一些大規(guī)模集成電路常常會受到干擾,導致不能正常工作。特別是像RAM這種利用雙穩(wěn)態(tài)進行存儲的器件,往往會在強干擾下發(fā)生翻轉(zhuǎn),使原來存儲的"0"變?yōu)?1",或者"1"變?yōu)?0",造成的后果往往是很嚴重的。例如導致一些控制程序跑飛,存儲的關(guān)鍵數(shù)據(jù)出錯等等?,F(xiàn)在,隨著芯片集成度的增加,發(fā)生錯誤的可能性也在增大。在一些特定的應(yīng)用中,這已經(jīng)成為一個不能忽視的問題。例如在空間電子應(yīng)用領(lǐng)域,單粒子翻轉(zhuǎn)效應(yīng)就成為困擾設(shè)計師的一個難題。

          在這種情況下,我們可以采用錯誤檢測與糾正C(ErrorDetectionAndCorrection)電路來有效地減少或避免這種情況的出現(xiàn)。根據(jù)檢錯、糾錯的原理,主要思想是在數(shù)據(jù)寫入時,根據(jù)寫入的數(shù)據(jù)生成一定位數(shù)的校驗碼,與相應(yīng)的數(shù)據(jù)一起保存起來;當讀出時,同時也將校驗碼讀出,進行判決。如果出現(xiàn)一位錯誤則自動糾正,將正確的數(shù)據(jù)送出,并同時將改正以后的數(shù)據(jù)回寫覆蓋原來錯誤的數(shù)據(jù);如果出現(xiàn)兩位錯誤則產(chǎn)生中斷報告,通知CPU進行異常處理。所有這一切動作都是靠硬件設(shè)計自動完成的,具有實時性和自動完成的特點。通過這樣的C電路,能大大提高系統(tǒng)的抗干擾能力,從而提高系統(tǒng)的可靠性。

          當然,有一些現(xiàn)成的集成電路芯片可以完成上述功能,如74系列的74630芯片等。但由于嵌入式系統(tǒng)中,往往由于集成化的需要,要將這樣的功能集成到F中去實現(xiàn),因此采用VHDL語言進行設(shè)計具有靈活性和通用性的特點。

          1檢錯與糾錯原理

          首先來看看檢錯和糾錯的基本原理。進行差錯控制的基本思想是在信息碼組中以一定規(guī)則加入不同方式的冗余碼,以便在信息讀出的時候依靠多余的監(jiān)督碼或校驗碼來發(fā)現(xiàn)或自動糾正錯誤。

          針對誤碼發(fā)生的特點,即錯誤發(fā)生的隨機性和小概率性,它幾乎總是隨機地影響某個字節(jié)中的某一位(bit),因此,如果能夠設(shè)計自動糾正一位錯誤,而檢測兩位錯誤的編碼方式,就可以大大的提高系統(tǒng)的可靠性。

          現(xiàn)在我們以16位的CPU數(shù)據(jù)總線為例,假定信息源的位數(shù)為16,要構(gòu)造一種能夠糾正一位錯誤,檢查兩位錯誤的編碼方式。根據(jù)"糾錯定理",需要設(shè)計最小漢明距離≥4的碼組。我們可以采用線形分組碼,利用線性分組碼的概念可以構(gòu)造六位監(jiān)督碼,它們由如下線性關(guān)系產(chǎn)生:

          其中,d0~d15為16位數(shù)據(jù)(15為最高位MSB,0為最低位LSB),C0~C5為產(chǎn)生的六位監(jiān)督碼,表示進行異或運算。

          在數(shù)據(jù)讀出時,我們只需要考察伴隨式S=[S0S1S2S3S4S5],其中:

          很容易證明,根據(jù)伴隨式進行誤差診斷,符合表1所列情況。

          表1誤差診斷碼表

          伴隨式

          錯誤位置

          數(shù)據(jù)位

          校驗位

          無錯

          d0

          d1

          d2

          d3

          d4

          d5

          d6

          d7

          d8

          d9

          d10

          d11

          d12

          d13

          d14

          d15

          C0

          C1

          C2

          C3

          C4

          C5

          S0

          1

          1

          0

          1

          1

          0

          0

          0

          1

          1

          1

          0

          0

          1

          0

          0

          1

          0

          0

          0

          0

          0

          0

          S1

          1

          0

          1

          1

          0

          1

          1

          0

          1

          0

          0

          1

          0

          0

          1

          0

          0

          1

          0

          0

          0

          0

          0

          S2

          0

          1

          1

          0

          1

          1

          0

          1

          0

          1

          0

          0

          1

          0

          0

          1

          0

          0

          1

          0

          0

          0

          0

          S3

          1

          1

          1

          0

          0

          0

          1

          1

          0

          0

          1

          1

          1

          0

          0

          0

          0

          0

          0

          1

          0

          0

          0

          S4

          0

          0

          0

          1

          1

          1

          1

          1

          0

          0

          0

          0

          0

          1

          1

          1

          0

          0

          0

          0

          1

          0

          0

          S5

          0

          0

          0

          0

          0

          0

          0

          0

          1

          1

          1

          1

          1

          1

          1

          1

          0

          0

          0

          0

          0

          1

          0


          當S=[000000]時,數(shù)據(jù)正確無誤;
          當S=[001011]時,數(shù)據(jù)錯一位,并且錯誤發(fā)生在d0位,可將d0位的數(shù)據(jù)取反加以糾正;
          當S=[001101]時,數(shù)據(jù)錯一位,并且錯誤發(fā)生在d1位,可將d1位的數(shù)據(jù)取反加以糾正;
          .
          .
          .
          當S=[110100]時,數(shù)據(jù)錯一位,并且錯誤發(fā)生在d15位,可將d15位的數(shù)據(jù)取反加以糾正;
          當S=[000001]時,數(shù)據(jù)錯一位,并且錯誤發(fā)生在C0位;
          .
          .
          .
          當S=[100000]時,數(shù)據(jù)錯一位,并且錯誤發(fā)生在


          上一頁 1 2 3 下一頁

          關(guān)鍵詞: EDA CVHDLF PGA

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉