《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > 用單片機實現SRAM工藝FPGA的加密應用
用單片機實現SRAM工藝FPGA的加密應用
摘要: 在現代電子系統設計中,由于可編程邏輯器件的卓越性能、靈活方便的可升級特性,而得到了廣泛的應用。由于大規模高密度可編程邏輯器件多采用SRAM工藝,要求每次上電,對FPGA器件進行重配置,這就使得可以通過監視配置的位數據流,進行克隆設計。因此,在關鍵、核心設備中,必須采用加密技術保護設計者的知識產權。
關鍵詞: FPGA 加密 單片機 SRAM
Abstract:
Key words :

    在現代電子系統設計中,由于可編程邏輯器件的卓越性能、靈活方便的可升級特性,而得到了廣泛的應用。由于大規模高密度可編程邏輯器件多采用SRAM工藝,要求每次上電,對FPGA器件進行重配置,這就使得可以通過監視配置的位數據流,進行克隆設計。因此,在關鍵、核心設備中,必須采用加密技術保護設計者的知識產權。

  1 基于SRAM工藝FPGA的保密性問題

  通常,采用SRAM工藝的FPGA芯片的的配置方法主要有三種:由計算機通過下載電纜配置、用專用配置芯片(如Altera公司的EPCX系列芯片)配置、采用存儲器加微控制器的方法配置。第一種方法適合調試設計時要用,第二種和第三種在實際產品中使用較多。第二種方法的優點在于外圍電路非常簡單,體積較小,適用于不需要頻繁升級的產品;第三種方法的優點在于成本較低,升級性能好。

 片進行配置,就實現了對FPGA內部設計電路的克隆。典型的克隆方法見圖1。

   

計算克隆方法

  2 對SRAM工藝FPGA進行有效加密的方法

  由于SRAM工藝的FPGA上電時的配置數據是可以被復制的,因此單獨的一塊FPGA芯片是無法實現有效加密的。FPGA芯片供應商對位數據流的定義是不公開的,因此無法通過外部的配置數據流信息推測內部電路。也就是說,通過對FPGA配置引腳的數據進行采樣可得到配置信息。但也不能知道內部電路結構。如果在配置完成后使FPGA處于非工作狀態,利用另外一塊保密性較強的CPU產生密碼驗證信息與FPGA進行通信,僅在驗證成功的情況下使能FPGA正常工作,則能有效地對設計進行加密。具體電路結構見圖2。

   

電路結構

  系統加電時,由單片機對SRAM工藝的FPGA進行配置。配置完成時,FPGA內部功能塊的使能端為低,不能正常工作。此時,單片機判斷到配置完成后,將ASET信號置為高電平,使能FPGA內的偽碼發生電路工作;同時,單片機產生一個偽碼驗證信息,在FPGA中將兩路偽碼進行比較,兩者完全匹配時,FPGA內部電路正常工作,否則不能正常工作。加密電路主要利用了配置完成后處于空閑狀態的單片機和FPGA內部分邏輯單元,沒有增加硬件成本。

  由上述討論可知,系統的加密能力主要由CPU的加密能力決定。這就要求CPU的加密算法要足夠復雜,使得對驗證信息的捕獲與識別足夠困難。最常見的加密算法就是產生兩個偽隨機序列發生器:一個位于SRAM工藝的FPGA內;另一個位于CPU內。當兩者匹配時,通過驗斑點。對PN碼有兩點要求:一方面,要求偽隨機序列的長度足夠長,使得要捕獲整個序列不太可能;另一方面,偽隨機序列的線性復雜度要足夠高,使推測偽隨機序列的結構不易實現。

  通常采用的偽隨機碼發生器的反饋電路如圖3所示。實際中,可采用級數較高的線性反饋移位寄存器來產生偽隨機碼。如采用40級線性移位寄存器產生的最大序列的周期為2?40=10?12。若將所有偽隨機碼截獲并存儲,就需要1000Gb的存儲空間;若碼速率為50Kbps,捕獲時間將長達5555小時;當增加移位寄存器的級數時,所需的存儲空間和捕獲時間都會呈指數增長,以至于難以實現。采用較為簡單的線性反饋電路被推測出反饋結構的可能性較大,因此實際的系統中,除了級數要較多之外,往往通過對多個線性移位寄存器產生的偽碼進行特定運算產生長碼,以增加所產生偽碼的線性復雜度。

   

反饋電路

  3 FPGA內的校驗工作電路

  在此采用40級線性反饋移位寄存器來產生偽隨機碼,特征多項式為20000012000005(八進制表示)。其移位寄存器表示形式為:Bin=B23?XOR?B21XORB2XORB0,FPGA內工作電路見圖4。

   

FPGA內工作電路

  在上電之后,單片機將圖4中的電路配置在FPGA中。配置完成后,單片機發送的ASET信號由低電平跳變為高電平,使得FPGA內的PN碼產生電路開始工作,并于CPU發送過來的PN碼進行比較。比較結果一致就使能USER_DESIGN模塊正常工作。其中PLL_BITSYS模塊用來發生VERIFY_PN的位同步時鐘,采用微分鎖相原理實現。各種參考資料都有較多介紹,在此不再詳述。

  




COMPARE_PN模塊完成對單片機發送的偽隨機碼和PNMA_PRODUCER模塊產生的偽隨機碼的比較:當兩路相同,輸出1,不同時輸出0;若兩路 偽碼完全匹配,則恒定輸出1,使USER_DESIGN電路正常工作,否則,輸出為類似于偽碼的信號,使USER_DESIGN電路不能正常工作。

 

  4 FPGA內的偽隨機碼產生電路

  PNMA_PRODUCER模塊和來產生偽隨機碼,采用移位LPM_SHIFTREG為移位寄存器模塊。移位寄存器ASET端為異步置位端,高電平有效,即ASET為高時,將初值85置入移位寄存器內,LPMSHIFTREG模塊的“DIRECTION”設置為“RIGHT”即移位方向為右移。Q[39..0]表示40位移位寄存器的各個狀態,SHIFTIN為串行輸入,SHIFTIN為Q0、Q2、Q21、Q23四個狀態異或運算的結果。

  系統加電時,單片機將ASET置為低電平,經過一個非門,變成高電平使移位寄存器處于置位狀態。在配置完成后,單片機將ASET信號置為高電平,經非門使移位寄存器正常工作。

  利用移位寄存器電路產生偽隨機碼的電路非常簡單,反饋邏輯也便于修改。

    

  5 單片機驗證偽碼的程序

  在位尋址區(20H~2FH)定義了字節變量WORD1、WORD2、WORD3、WORD4、WORD5,用來存儲移位寄存器的40個狀態。其中Q0對應WORD1.0,Q1對應WORD1.1……Q39對應WORD5.7。同時,在位尋址區定義了WORD6、WORD7、WORD8、WORD9,用來進行后面的反饋邏輯計算。

  單片機一上電,首先將ASET腳清零,同時,也將PNMA腳清零,將初值55H作為移位寄存器的初始狀態,接著完成FPGA的上電配置工作。配置完成后,單片機檢測來自FPGA的外部中斷CONFDONE。如果配置完成,CONFDONE為高電;否則,為低電平。在檢測到CONFDONE為高電平,即配置完成后,單片機將ASET腳置為1,使能FPGA內的偽碼發生電路工作,單片機產生偽隨機碼的流程。配置完成后,首先將Q0輸出到PNMA引腳,接著計算反饋邏輯輸入,將參與反饋運算的幾個狀態運算結果存在中間變量MID_VARY中。然后,對各個狀態進行右移,為了提高運算效率,使用了帶進位C的字節循環右移指令。移位完成后,將MID_VARY存入Q39,再將新的Q0輸出到PNMA引腳,程序循環執行產生偽隨機碼。

  單片機核心源程序如下:

  CLR ASET;單片機上電后將ASET位清0
  CLR PNMA
   
MOV WORD1,#55h
  MOV WORD2,#0
  MOV WORD3,#0
  MOV WORD4,#0
  MOV WORD5,#0;將55H作為移位寄存器的初值PEIZHI:
  ……;進行FPGA的配置工作
  JB CONFDONE,PNPRODUCE;根據CONFDONE判斷配置是否完成
  LJMP PEIZHI;否則繼續配置
  PNPRODUCE:SETB ASET;配置完成后,將ASET腳置1
  XMQLOOP:MOV C,Q0
  MOV PNMA,C;將Q0輸出到PNMA引腳,作為PN碼
  MOV C,Q0
  MOV WORD6.0,C;用WORD6單元的0位來存Q0的狀態
  MOV C,Q2
  MOV WORD7.0,C;用WORD7單元的0位來存Q2的狀態
  MOV C,Q21
  MOV WORD8.0,C;用WORD8單元的0位來存Q21的狀態
  MOV C,Q23
  MOV WORD9.0,C;用WORD9單元的0位來存Q23的狀態
  MOV ACC,WORD6
  XRL A,WORD7
  XRL A,WORD8
  XRL A,WORD9;通過異或指令,計算反饋邏輯
  MOV C,ACC.0;反饋邏輯為Qin=Q0
  ;XOR Q2 XOR Q21 XOR Q23
  MOV MID_VARY,C;將運算后的狀態存到MID_VARY中右移運算
  MOV ACC,WORD1
  RRC A;移位Q7~Q0
  MOV WORD1,A;移位后,保存到WORD1單元中
  MOV ACC,WORD2
  RRC A;移位Q15~Q8
  MOV WORD2,A;移位后,保存到WORD2單元中
  MOV Q7,C;將Q8的值賦到Q7
  MOV ACC,WORD3
  RRC A;移位Q23~Q16
  MOV WORD3,A;移位后,保存到WORD3單元中
  MOV Q15,C;將Q16的值賦到Q15
  MOV ACC,WORD4
  RRC A;移位Q31~Q24
  MOV WORD4,A;移位后,保存到WORD4單元中
  MOV Q23,C;將Q24的值賦到Q23
  MOV ACC,WORD5
  RRC A;移位Q39~Q32
  MOV WORD5,A;移位后,保存到W ORD5單元中
  MOV Q31,C;將Q32的值賦到Q31
  MOV C,MID_VARY;將前面反饋計算的值賦給Q39
  MOV Q39,C
  LJMP XMALOOP ;繼續產生下一代PN碼元

 




此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品久久久久久久久婷婷 | 欧美午夜宅男影院| 蜜桃久久精品乱码一区二区| 久久精品中文字幕一区| 欧美一区二区三区久久精品茉莉花 | 亚洲永久免费| 国产精品99久久久久久人| 一个色综合导航| 亚洲美女黄网| 亚洲最新在线| 一区二区三区日韩精品视频| 一本色道久久88综合亚洲精品ⅰ| 亚洲精品韩国| 99国产精品久久久久老师| 亚洲伦理久久| 99国产一区| 亚洲婷婷综合久久一本伊一区| 一区二区av在线| 亚洲一区视频在线观看视频| 亚洲自拍偷拍麻豆| 午夜视频在线观看一区二区| 欧美一区三区二区在线观看| 久久精品天堂| 免播放器亚洲一区| 欧美另类在线观看| 国产精品白丝黑袜喷水久久久| 国产精品每日更新在线播放网址| 国产精品男女猛烈高潮激情 | 亚洲国产成人精品视频| 亚洲黄色视屏| 99视频在线观看一区三区| 洋洋av久久久久久久一区| 亚洲午夜精品| 欧美一区影院| 亚洲欧洲一区二区天堂久久 | 亚洲福利国产| 亚洲国产99| 亚洲精品综合久久中文字幕| 日韩午夜免费| 亚洲一区在线观看免费观看电影高清| 亚洲砖区区免费| 欧美一区二区视频在线观看| 久久夜色精品国产| 欧美精选一区| 国产精品你懂的在线欣赏| 国产三级精品在线不卡| 玉米视频成人免费看| 亚洲精品免费看| 亚洲色在线视频| 久久国产精品亚洲va麻豆| 日韩午夜激情电影| 亚洲男人影院| 裸体丰满少妇做受久久99精品| 欧美日本韩国一区| 国产毛片精品视频| 亚洲国产欧美国产综合一区| 亚洲视频在线一区观看| 久久成人羞羞网站| 一区二区三区精品视频| 久久国产日韩| 欧美日韩国产不卡在线看| 国产日韩综合一区二区性色av| 91久久国产综合久久| 亚洲欧美国产77777| 亚洲精品乱码| 小黄鸭精品密入口导航| 欧美ed2k| 国产伦精品一区二区三区免费迷| 亚洲电影第1页| 亚洲欧美日韩在线播放| 夜久久久久久| 六月天综合网| 国产精品日韩在线一区| 亚洲国产精品一区二区尤物区| 亚洲综合色婷婷| 99精品视频免费观看| 久久精品国产综合| 国产精品jizz在线观看美国| 一区二区在线视频| 亚洲欧美久久| 一本色道**综合亚洲精品蜜桃冫| 久久久久国产精品厨房| 国产精品久久| 亚洲级视频在线观看免费1级| 亚洲欧美中文在线视频| 亚洲视频在线一区观看| 欧美不卡视频一区发布| 国产亚洲福利| 国产一二三精品| 欧美一区二区三区喷汁尤物| 99re热精品| 午夜精品久久久久久久| aⅴ色国产欧美| 久久野战av| 国产日韩欧美在线视频观看| av成人激情| 亚洲精品国产系列| 久色婷婷小香蕉久久| 国产日韩欧美高清| 亚洲视频一起| 中日韩视频在线观看| 欧美国产日产韩国视频| 国产一区二区三区在线观看免费视频| 亚洲午夜久久久久久久久电影网| 一本色道久久加勒比88综合| 欧美国产成人精品| 亚洲高清视频一区| 亚洲国产日韩欧美| 久久亚洲国产成人| 国产综合在线看| 欧美亚洲一区二区三区| 香蕉久久一区二区不卡无毒影院| 欧美日韩午夜| 一区二区三区成人精品| 亚洲少妇中出一区| 欧美日韩伦理在线免费| 亚洲精品美女久久7777777| 亚洲三级色网| 欧美精品91| 亚洲精品极品| 一本久久a久久免费精品不卡| 欧美精品日日鲁夜夜添| 亚洲国产婷婷香蕉久久久久久99 | 欧美在线观看一区二区| 国产精品另类一区| 亚洲一区二区三区在线观看视频 | 欧美午夜免费电影| 一区二区电影免费在线观看| 亚洲午夜在线观看| 国产精品久久久久天堂| 亚洲制服av| 久久久久国产精品一区二区| 狠狠干狠狠久久| 亚洲国产精品久久久久秋霞蜜臀 | 亚洲精品你懂的| 欧美另类极品videosbest最新版本 | 亚洲精品免费看| 欧美精品一区二区三区在线看午夜 | 亚洲一区精品视频| 一本色道**综合亚洲精品蜜桃冫| 亚洲国产裸拍裸体视频在线观看乱了中文 | 久久国产精品久久久久久| 国产精品久久久久久亚洲调教| 亚洲性视频网址| 欧美在线你懂的| 狠狠色综合色综合网络| 亚洲精品国产精品国自产观看浪潮| 欧美国产欧美综合 | 宅男在线国产精品| 性欧美xxxx大乳国产app| 国产视频久久网| 亚洲福利视频网站| 欧美成人精品一区二区| 亚洲人精品午夜| 亚洲欧美另类在线| 激情欧美一区二区| 一本一道久久综合狠狠老精东影业 | 欧美在线free| 在线观看视频欧美| 中日韩高清电影网| 国产亚洲精品一区二区| 亚洲人线精品午夜| 国产精品wwwwww| 欧美影院视频| 欧美理论电影在线播放| 亚洲图片在线| 另类人畜视频在线| 一本色道久久综合亚洲精品按摩 | 欧美资源在线| 亚洲三级免费电影| 欧美一区二区三区视频| 亚洲激情一区二区三区| 羞羞视频在线观看欧美| 在线视频国内自拍亚洲视频| 亚洲一区二区三区国产| 国产中文一区| 亚洲色图在线视频| 国内精品视频在线播放| 亚洲校园激情| 在线电影国产精品| 午夜在线成人av| 亚洲国产欧美一区| 欧美影院一区| 亚洲精品色婷婷福利天堂| 久久精品九九| 一区二区三区精品国产| 欧美成人中文字幕| 欧美一区二区三区久久精品茉莉花 | 亚洲乱码国产乱码精品精可以看| 国产精品一区二区久久国产| 亚洲国产免费看| 国产精品三级视频| 亚洲精品中文字幕在线观看| 国产偷自视频区视频一区二区| 在线一区亚洲| 影音先锋另类| 欧美一区二区三区另类| 日韩午夜剧场| 欧美高清在线视频| 久久国产99|