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

          新聞中心

          EEPW首頁 > 模擬技術(shù) > 設(shè)計(jì)應(yīng)用 > 基于EDA軟件和FPGA的IP核保護(hù)技術(shù)

          基于EDA軟件和FPGA的IP核保護(hù)技術(shù)

          作者: 時(shí)間:2009-07-31 來源:網(wǎng)絡(luò) 收藏
          在將優(yōu)化后的門級(jí)網(wǎng)表寫入文件之前,該工具先用自己的私鑰對網(wǎng)表進(jìn)行加密處理,再用布局布線工具提供商的公鑰對網(wǎng)表進(jìn)行加密處理。這樣設(shè)計(jì)者還是無法查看到綜合和技術(shù)映射后的網(wǎng)表,從而防止了設(shè)計(jì)者用逆向工程的方法來竊取。
          布局布線工具先用自己的私鑰對加密的網(wǎng)表進(jìn)行一次解密,再用前端的工具開發(fā)商的公鑰進(jìn)行第二次解密,從而得到解密后的網(wǎng)表。利用該網(wǎng)表,布局布線工具可以完成設(shè)計(jì)在芯片上的布局布線,最終生成用于配置的bit-stream文件。

          本文引用地址:http://www.ex-cimer.com/article/188783.htm

          3 中實(shí)現(xiàn)IP保護(hù)
          生成了用于配置的bit-stream后,將bit-stream加載到FPGA中,就可以完成對FPGA的編程,F(xiàn)PGA實(shí)現(xiàn)設(shè)計(jì)者期望的功能。FPGA分為非易失性(Don―volatile)和易失性(volatile)兩種,前者包括基于反熔絲技術(shù)和Flash技術(shù),后者主要是基于SRAM技術(shù)。對于基于SRAM的FPGA,因?yàn)槠渑渲眯畔⒃诘綦娭缶蜁?huì)丟失,因此一般需要用PROM存儲(chǔ)FPGA的配置信息,以使FPGA在重新加電后能夠再次根據(jù)這些信息進(jìn)行配置。FPGA的配置信息就是設(shè)計(jì)在FPGA上的最終實(shí)現(xiàn),因此需要相應(yīng)的技術(shù)手段來保護(hù)這些配置信息。
          因此FPGA的bit-stream是二進(jìn)制信息,它是依賴于設(shè)計(jì)本身和具體的FPGA結(jié)構(gòu)。一般來說,bit-stream的生成工具都是由FPGA的生產(chǎn)商提供。FPGA的生產(chǎn)商雖然會(huì)給出一些bit-stream生成工具的使用信息,但一般都不會(huì)公開FPGA的bit-stream編碼格式。由于不知道FPGA的bit-stream文件格式,目前尚未發(fā)現(xiàn)對FPGA的編程bit-stream文件成功實(shí)現(xiàn)逆向工程,所以絕大多數(shù)的FPGA使用者都不考慮FPGA中的設(shè)計(jì)會(huì)被破解。
          雖然bit-stream文件難以被逆向工程方法破解,但如果這些bit-stream被復(fù)制,利用這些bit-stream,再使用同樣的FPGA,競爭對手就可以生產(chǎn)同樣產(chǎn)品。也這是說,設(shè)計(jì)還是有可能被盜竊。因此,需要相應(yīng)的安全機(jī)制來防止bit-stream被復(fù)制。針對基于SRAM的FPGA,下面討論兩種防范機(jī)制。
          3.1 一次加載
          保證FPGA的編程bit-stream文件安全的一種簡單辦法就是在安全環(huán)境下對FPGA編程后,不再向FPGA配置任何器件,而是對FPGA持續(xù)供電。因?yàn)樗械目删幊踢壿嬙O(shè)備都具有保密設(shè)置,可阻止從FPGA中讀取編程bit-stream文件,而且編程bit-stream文件也不會(huì)暴露在器件之外,這種方法既能夠使FPGA的設(shè)計(jì)不被偷竊,也不被篡改。這種保護(hù)機(jī)制的安全級(jí)別與基于反熔絲技術(shù)或者其他的非易失性的FPGA相似,但是這種方法的缺點(diǎn)是需要對系統(tǒng)持續(xù)供電。
          3.2 bit-stream加密
          Bit-stream加密技術(shù)是對FPGA的編程bit-stream文件加密處理,加密過程是EDA的最后一個(gè)處理步驟,如圖1所示。加密后的bit-stream存儲(chǔ)在FPGA的配置器件中,在配置FPGA器件前,要先把加密的bit-stream寫入FPGA中,然后進(jìn)行解密,再用解密后的bit-stream對FPGA進(jìn)行配置。這一方法既增加對bit-stream文件逆向工程的難度,又阻止編程文件被非法復(fù)制。加密采用對稱密鑰加密算法,密鑰由設(shè)計(jì)者指定。設(shè)計(jì)者需要將密鑰存儲(chǔ)到FPGA,F(xiàn)PGA中的解密功能模塊可以用這一密鑰來對bit-stream解密。
          如果最終生成的bit-stream文件是加密的,F(xiàn)PGA就需有一個(gè)專用的片上解密器和專用的密碼存儲(chǔ)器。為了使FPGA既能支持加密的bit-stream,又能支持未加密的bit-stream,bit-stream文件包含有未加密的指令,這些指令可用于啟動(dòng)和解密配置數(shù)據(jù)。如果bit-stream是加密的,F(xiàn)PGA在真正編程配置前,需要先用存儲(chǔ)的密鑰對其解密。這樣,在FPGA使用過程中,雖然攻擊者很容易從配置器件和FPGA的連接線路上獲取bit-stream,但是因?yàn)檫@些bit-stream是加密的,即使把這些bit-stream配置到同樣的FPGA上,但由于不知道解密的密鑰,F(xiàn)PGA也無法對其解密,從而無法配置FPGA。使用這種保護(hù)方法,攻擊者不知道密鑰就無法復(fù)制FPGA中的設(shè)計(jì)。
          攻擊者可能轉(zhuǎn)而試圖從FPGA中盜取密鑰。在FPGA中,密鑰可存儲(chǔ)在RAM中,通過芯片上的一個(gè)電池為其供電。如果切斷電源,則存儲(chǔ)信息即密鑰丟失。為了竊取密鑰,攻擊者需要打開FPGA的封裝,打磨掉多個(gè)金屬層,然后用掃描電子顯微鏡(SEM)掃描表示密鑰的數(shù)據(jù)位。在進(jìn)行這些操作的同時(shí),還必須保持對存儲(chǔ)密鑰的存儲(chǔ)器供電。顯然這種攻擊是難以實(shí)現(xiàn)的。
          此外,還可以在FPGA內(nèi)部設(shè)計(jì)一些邏輯來限制對配置和密鑰的訪問。例如:當(dāng)載入一個(gè)加密的bit―stream文件時(shí),只能進(jìn)行單獨(dú)的、整個(gè)芯片的配置;在加載了加密的配置流后,就不允許再讀取其中信息;試圖讀取或?qū)懭朊荑€就會(huì)清除所有的密鑰和所有的配置數(shù)據(jù);解密后的bit-stream在用于配置操作前,必須要通過數(shù)據(jù)的完整性檢驗(yàn)。通過這些限制,使得攻擊者無法讀取解密后的bit-stream,也無法獲得FPGA存儲(chǔ)的密鑰,從而阻止攻擊者復(fù)制FPGA中的設(shè)計(jì)。

          4 結(jié)語
          隨著電路設(shè)計(jì)規(guī)模的不斷擴(kuò)大,越來越多的設(shè)計(jì)者開始應(yīng)用來提高設(shè)計(jì)速度和系統(tǒng)可靠性。提出在EDA工具中加入保護(hù)機(jī)制,防止被竊取,以及在FPGA中加入保護(hù)機(jī)制防止最終在FPGA上實(shí)現(xiàn)的設(shè)計(jì)被非法復(fù)制。這種機(jī)制的實(shí)現(xiàn)前提條件是要求FPGA的生產(chǎn)商和EDA工具的開發(fā)商都是可信的。如何在兩者不可信的情況下實(shí)現(xiàn)IP核保護(hù),還需進(jìn)一步研究。


          上一頁 1 2 下一頁

          關(guān)鍵詞: FPGA EDA 軟件 IP核

          評(píng)論


          相關(guān)推薦

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

          關(guān)閉
          看屁屁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); })();