新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 錯誤檢測與糾正電路的設計方案

        錯誤檢測與糾正電路的設計方案

        作者: 時間:2010-03-11 來源:網絡 收藏

        摘要:針對一些惡劣的電磁環境對隨機存儲器(RAM)誤碼影響的情況,根據糾錯編碼的基本原理,提出簡單實用的能檢查兩位并自動一位的EDAC算法;通過VHDL語言編程,由FPGA器件來實現,并給出仿真結果。

        本文引用地址:http://www.104case.com/article/152039.htm

        引 言

          在一些電磁環境比較惡劣的情況下,一些大規模集成常常會受到干擾,導致不能正常工作。特別是像RAM這種利用雙穩態進行存儲的器件,往往會在強干擾下發生翻轉,使原來存儲的0變為1,或者1變為0,造成的后果往往是很嚴重的。例如導致一些控制程序跑飛,存儲的關鍵數據出錯等等。現在,隨著芯片集成度的增加,發生的可能性也在增大。在一些特定的應用中,這已經成為一個不能忽視的問題。例如在空間電子應用領域,單粒子翻轉效應就成為困擾師的一個難題。

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

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

        1 檢錯與糾錯原理

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

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

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

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

        在數據讀出時,我們只需要考察伴隨式S=[S0 S1 S2 S3 S4 S5],其中:

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

        表1 誤差診斷碼表

        伴隨式

        錯 誤 位 置

        數 據 位

        校 驗 位

        無錯
        d0d1d2d3d4d5d6d7d8d9d10d11d12d13d14d15C0C1C2C3C4C5
        S011011000111001001000000
        S110110110100100100100000
        S201101101010010010010000
        S311100011001110000001000
        S400011111000001110000100
        S500000000111111110000010

        當S = [0 0 0 0 0 0]時,數據正確無誤;

        當S = [0 0 1 0 1 1]時,數據錯一位,并且錯誤發生在d0位,可將d0位的數據取反加以糾正;

        當S = [0 0 1 1 0 1]時,數據錯一位,并且錯誤發生在d1位,可將d1位的數據取反加以糾正;

        .

        .

        .

        當S= [1 1 0 1 0 0]時,數據錯一位,并且錯誤發生在d15位,可將d15位的數據取反加以糾正;

        當S = [0 0 0 0 0 1]時,數據錯一位,并且錯誤發生在C0位;

        .

        .

        .

        當S = [1 0 0 0 0 0]時,數據錯一位,并且錯誤發生在C5位;

        當S為其它情況時,至少發生兩位錯誤。

          可以看出,這種編碼方式可以滿足自動糾正一位錯誤,而發現兩位錯誤的要求。下面就進一步討論如何用電路來實現。

        DIY機械鍵盤相關社區:機械鍵盤DIY



        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 府谷县| 临漳县| 瓦房店市| 云南省| 泾源县| 胶州市| 东山县| 吴川市| 永丰县| 微山县| 莲花县| 苏尼特右旗| 潮州市| 沛县| 长阳| 天门市| 区。| 尉氏县| 安康市| 新建县| 白河县| 邳州市| 三亚市| 平山县| 安图县| 邵阳市| 罗平县| 喀喇沁旗| 抚州市| 天全县| 峨眉山市| 轮台县| 静宁县| 涞源县| 锡林郭勒盟| 北票市| 庄浪县| 东方市| 安乡县| 抚远县| 锡林郭勒盟|