《電子技術應用》
您所在的位置:首頁 > 微波|射頻 > 設計應用 > 采用閃存的微控制器在代碼發布中的代碼保護
采用閃存的微控制器在代碼發布中的代碼保護
摘要: 閃存允許在生產線的終點進行實時編程,也允許在生產之后修改代碼。但是如果通過因特網,公司將面臨IP將泄漏給競爭者的問題。應該采用各種方法來控制更新授權許可,并在泄漏產品的IP的情況下, 提供現場更新。
Abstract:
Key words :

包裝信息可能包含:指定目標設備、代碼版本、大小、日期和其它對用戶有用的信息。這個信息可警告操作員正在使用一個較低版本的固件" title="固件">固件,從而會使設備的部分性能降低,或者正在裝載一個不支持的指定設備。

在如今競爭激烈的市場中,保護公司的知識產權(IP)是最高優先級的事項之一。多年的開發可能產生了包含很多商業秘密或專有算法的設計。隨著基于閃存的微控制器" title="微控制器">微控制器得到更多地應用并集成了更多的特性,許多公司摒棄傳統的一次性可編程(OTP)微控制器(MCU),轉而采用閃存。

閃存允許在生產線的終點進行實時編程,也允許在生產之后修改代碼。但是如果通過因特網,公司將面臨IP將泄漏給競爭者的問題。應該采用各種方法來控制更新授權許可,并在泄漏產品的IP的情況下, 提供現場更新。

代碼保護

保護現場配置的軟件產品的方法很多,采用哪種方法取決于供應商希望保護什么。大多數軟件保護機制是防止對程序或數據進行未經授權的復制。如今復制文件非常容易,通過因特網能很快地找到許多拷貝。當固件是某個硬件平臺的一部分時,保護固件中包含的IP通常比保護對文件的拷貝更重要。當然,如果固件更新需要購買,那么保護拷貝也很重要。

另一個問題涉及基于微控制器產品破解密碼的性能。RSA和DES標準對性能和存儲器的要求都很高。不幸的是,大多數的微控制器在這兩方面的資源都有限,從而要求不同的加密和解密方法。我們必須提供一種通用的或者針對特定設備的密鑰方案。

簡單密碼

循環碼(Rolling-code)產生器" title="產生器">產生器已在車庫門鎖、安全進出卡等多種設備上應用多年。圖1顯示簡單的循環碼產生器是如何工作的。一組具有相同時鐘信號的雙穩態觸發器串聯連接,其輸出端有各種抽頭。在給出的例子中,Q2端沒有被使用,其余的輸出端連接唯一的OR功能端口,該端口在每個時鐘信號沿得到新的輸入位。可能產生的組合數目取決于觸發器的個數和接到OR函數端口的抽頭個數。

 

 

通常將幾個觸發器的輸出用作循環鑰匙碼。實際應用時(如作在車庫門鎖),使用一個完全相同的發生器來測試鑰匙碼。隨著新碼被不斷地使用,會發生整個序列重復出現的情況,這可能是在千萬或幾億個鑰匙碼之后。這時就不能再使用它了。在用于車庫門鎖的情況下,它可以防止罪犯用無線接收機盜聽并簡單地重現鑰匙碼以開門。

在代碼加密的情況下,觸發器的輸出與被加密或解密的數據被送到另外一個OR函數端口(圖2中的A1)。數據的每個字節、字或雙字都與選中的觸發器端口進行OR運算,再加上用戶特定另外函數。那個函數可以簡單到只加上一個常數。這個過程必須是可逆的,所以用戶定義的函數不是隨機的。由安置觸發器抽頭決定的密碼和由移位寄存器的初態、所選定的種子一起提供了加密和解密的算法。可按照串行數字的方法拆分這些密碼,以向特定設備提供唯一的密碼。也就是說,設備的串行號碼僅提供一半的密碼信息,制造商保留其余密碼信息。很明顯,這種方案存在著多種排列。

 

 

在固件更新是向全球發布時,例如,適用所有產品的錯誤的更新,可以使用一個特別的串行碼。解密引擎首先嘗試用全球碼,-----可能是一個特殊數字圖樣。如果全球碼沒有解密出正確的校驗和,才使用唯一的密碼。它可以告訴裝載程序:加密的源文件包含了什么類型的固件更新數據。

傳輸方法

很明顯,產品內必須要有某種解碼引擎和代碼裝載程序。這里討論的技術可以用COP8微控制器來解釋。該目標控制器是包含32KB閃存和1KB RAM的COP8CBR。 對于現場可更新的設備,必須注意這樣一個說明以防止誤解:微控制器必須具有一邊運行程序一邊對閃存進行編程的能力。不能用把控制器保持在重新設置狀態或者要求外部編程來更新存儲著程序的閃存。解碼和裝載程序必須駐留在控制器內部,并且完全可靠。COP8閃存產品能滿足這些要求。

固件的裝載程序是一個代碼模塊,它在重新設置后運行,并能判斷本次裝載是否有效。如果發現被裝載的代碼無效,裝載程序就進入裝載模式(LOAD MODE),直到有能夠操作的固體程序。可通過控制器提供的物理層接口來實現這點。COP8可使用串口。如果當前代碼是有效的,裝載程序會把控制交給固件應用程序的入口。

COP8系列的另一個特性是可以采用軟件陷阱" title="軟件陷阱">軟件陷阱以引導恢復機制。它執行操作碼" title="操作碼">操作碼0x00,可將這個操作碼編程到所有未用單元。如果這個操作碼被執行,操作將從軟件陷阱向量開始,使裝載程序重新評估固件的完整性。這是一個容錯的好特性。不管什么原因,代碼被破壞,裝載程序將得到控制,以便讓技術人員(或用戶)重新裝載固件。

裝載程序使用數據包,數據包有數據頭和校驗和以驗證傳輸。如果數據包傳輸到了控制器并且校驗和是正確的,則裝載程序把它交給解碼引擎(如果它是加密的)。在加密數據的內部有另外一個密碼校驗和,這給解密引擎一個驗證密碼信息的手段。它將首先應用通用碼并測試校驗和,如果失敗,則利用來自串行數字的唯一密碼重試。如果再次失敗,則告訴裝載程序固件對這個設備無效。這也可防止代碼被未經授權的篡改和意外損壞。

如果解密引擎成功地解碼數據, 它將把數據交給在閃存中對實際閃存塊進行編程的程序例程。當然,對于不同產家,這個程序是不同的,在后面的設計實例中將給出COP8的程序。這個程序保留了一個128字節的RAM用于更新閃存。當然,這塊RAM在裝載程序完成后可以存放應用程序的數據。

設計實例

圖3是一個具備解密功能的固件裝載程序的流程圖。裝載程序使用在編程器和系統模擬程序中廣泛使用的修改版Intel HEX數據格式。這將使應用程序現有架構支持標準并易于使用。裝載固件程序用COP8匯編語言編寫,以簡少代碼,并利用器件全部的閃存特性。

簡單來說,Intel HEX格式是一種用ASCII編碼表示的數據記錄格式,用于向設備的存儲器編程對象代碼或數據。該格式由下列字段組成:使用ASCII字符0x3A或者即“:”記錄起始字段、長度范圍為0x00-0xFF的數據長度字段(兩個ASCII字符)、偏移字段、記錄類型字段、信息或數據字段以及校驗和字段。每個字段都由標準的可打印ASCII字符表示。例如,“10”代表十六進制0x10或者十進制16,可表示長度字段。實際上它的編碼是0x31、0x30,這是“0” 和“1” 的ASCII碼。因為內容是可打印的ASCII字符,能被文本編輯器查看,所以需要加密。

表里包括了標準的Intel HEX格式記錄類型。注意該標準只定義了6種記錄類型。為利用現有的結構,裝載程序采用Intel HEX 格式,并指定加密數據為一種新的記錄類型。記錄類型0x10將被用于代表加密數據,這是不能變的。

代碼裝載程序也需要一個流程控制方法,以保證在下一個記錄裝載之前,寫閃存的周期已經完成。在大多數的情況下,應用程序會產生可分成16個字節一組的文件,以方使閱讀。通常閃存是以128或256字節進行分塊,因此必須有一個裝載程序的命令要求從主機來的數據允許可變記錄大小。裝載程序必須能處理256字節的數據,因為按照標準,這是最大的記錄大小。表的底部顯示了本例中新擴展的記錄類型。因為COP8系列器件只有16位地址,無法執行記錄類型0x02到0x05。對于具備更大閃存的處理器,例如CR16,它能直接訪問16M字節的內存,就需要有擴展線性地址的記錄類型。

 

 

觀察圖3中的流程圖,重新設置后的第一個任務是檢驗閃存的內容。這是通過讀取各個128字節的頁面(除了位于閃存頂部的自舉驗證代碼和裝載程序代碼)來完成的。只驗證應用程序的代碼這使計算校驗和非常容易。但如果需要,它也可以包括檢測裝載程序部件。當通過校驗和檢查,控制就被向量轉移到應用程序固件的入口。入口保持不變非常重要。如果它發生了移動,裝載程序會把向量轉到一個不正確的入口,并可能出現崩潰。另外,裝載程序可以從代碼中讀出進入向量,把向量壓入堆棧并返回,以迫使從那個地址開始執行。這個方案允許入口點可變。

如果校檢和失敗,裝載程序將保持控制并不斷地往主機發送信號,用硬件設計實現的任何手段開始裝載。裝載程序也可以控制用戶接口通知這種狀態。在調試系統時,一個表示“固件裝載” 的簡單的LED燈非常有用。

裝載程序將持續地向主機請求記錄,直到主機通過EOF記錄表明沒有記錄了。檢測到的0x10類型記錄 將被送到解碼引擎,并適當解碼數據。這使得實際向閃存寫數據的代碼,既可以操作加密數據,也可操作對未加密數據。對開發和內部測試來說,未加密的數據通路很有價值。當收到EOF記錄后,所有新固件數據都被寫入閃存。然后,裝載程序把控制交還給自舉測試,以驗證新代碼未被破壞。

如上所述,現場可更新設備可以在不曝露IP的情況下得到實現。使用一個簡單的密碼, 制造商的固件就能得到保護,客戶可以在世界各地能夠訪問因特網的地方更新他們的設備。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美一级二级三级蜜桃| 美女视频黄 久久| 久久国产一区二区| 午夜亚洲性色福利视频| 一本色道久久| 一区二区免费在线播放| 日韩视频在线观看免费| 日韩视频免费| 99视频精品免费观看| 日韩一区二区电影网| 日韩午夜黄色| aa级大片欧美| 亚洲夜间福利| 亚洲欧美日韩一区二区三区在线观看 | 久久精品国产第一区二区三区| 国产主播喷水一区二区| 国产精品夜夜嗨| 国产女主播视频一区二区| 国产精品亚洲成人| 国产一级久久| 狠久久av成人天堂| 亚洲国产精品ⅴa在线观看| 亚洲国产三级在线| 日韩视频精品| 亚洲一区二区三区在线观看视频| 国产在线拍偷自揄拍精品| 国产精品视频| 国产亚洲女人久久久久毛片| 国产午夜精品一区理论片飘花 | 久久精品视频播放| 久久精品国产清自在天天线| 亚洲国产你懂的| 久久激情五月婷婷| 亚洲理伦电影| 亚洲一区二区三区影院| 欧美一区视频在线| 开元免费观看欧美电视剧网站| 亚洲欧美日韩天堂一区二区| 精品动漫一区二区| 91久久精品网| 亚洲精品色婷婷福利天堂| 亚洲美女91| 亚洲在线观看视频| 亚洲在线一区二区三区| 久久成人免费电影| 免费看的黄色欧美网站| 欧美日韩精品免费看| 国产精品视频网址| 影院欧美亚洲| 日韩一级在线| 午夜一区二区三区在线观看| 亚洲国产va精品久久久不卡综合| 中文成人激情娱乐网| 亚洲一区在线观看视频 | 国产精品影视天天线| 国产亚洲欧美日韩精品| 亚洲黄色精品| 午夜精品av| 亚洲精品在线观| 欧美一区二区黄色| 欧美精品亚洲一区二区在线播放| 久久久夜夜夜| 欧美日本中文字幕| 国内激情久久| 欧美精品麻豆| 久久精品视频免费| 欧美日韩视频| 红桃视频一区| 中文国产一区| 亚洲国产裸拍裸体视频在线观看乱了中文| 亚洲资源av| 亚洲高清成人| 午夜精品一区二区三区在线播放| 一区二区三区视频在线播放| 欧美一区二区三区久久精品| 欧美高清一区| 国产婷婷一区二区| 一级成人国产| 亚洲韩国一区二区三区| 欧美一级欧美一级在线播放| 欧美福利一区二区| 国产一区亚洲| 亚洲视频欧洲视频| 日韩亚洲欧美综合| 麻豆精品精华液| 国产精品区一区二区三| 日韩特黄影片| 最新亚洲一区| 久久精品亚洲一区二区三区浴池| 久久精品一区二区三区不卡牛牛 | 欧美日韩精品一区二区| 国精品一区二区三区| 亚洲网站啪啪| 一本久久综合亚洲鲁鲁| 蜜桃av噜噜一区| 国产一区二区久久| 亚洲综合三区| 亚洲一区一卡| 欧美日本精品| 亚洲精品久久嫩草网站秘色| 亚洲黄一区二区| 久久久综合激的五月天| 亚洲一区二区三区视频| 国产精品久久久久久久久动漫 | 欧美日韩一区二区视频在线 | 极品少妇一区二区三区| 亚洲一区二区综合| 亚洲深夜激情| 欧美日本中文| 亚洲精品一区二区三区婷婷月 | 亚洲激情小视频| 欧美一区二区三区男人的天堂| 亚洲风情在线资源站| 欧美亚洲网站| 国产精品美女主播| 一区二区三区四区国产精品| 一区二区免费看| 亚洲一区二区免费| 亚洲女ⅴideoshd黑人| 国产精品v亚洲精品v日韩精品| 国产精品网站视频| 在线亚洲一区二区| 亚洲中字黄色| 国产精品国产三级国产普通话蜜臀| 国产一区久久久| 欧美一区二区三区精品电影| 羞羞色国产精品| 国产精品综合视频| 午夜免费日韩视频| 久久精品91| 黄色亚洲网站| 亚洲国产日韩欧美在线图片| 欧美+亚洲+精品+三区| 亚洲国产精品日韩| 夜夜嗨一区二区| 欧美系列亚洲系列| 亚洲男人第一av网站| 久久黄金**| 一区二区在线观看视频| 亚洲精品1234| 欧美理论视频| 亚洲伊人色欲综合网| 久久九九全国免费精品观看| 国内精品免费午夜毛片| 亚洲国产成人tv| 欧美激情一区二区三区在线视频观看 | 国产精品入口尤物| 午夜精品视频在线| 久久噜噜噜精品国产亚洲综合| 国产精品国内视频| 亚洲一区欧美二区| 久久夜色撩人精品| 亚洲日本在线视频观看| 亚洲一级一区| 国产亚洲在线| 99精品国产在热久久婷婷| 国产精品久久一级| 久久国产毛片| 欧美美女视频| 西西人体一区二区| 欧美高清在线精品一区| 一区二区三区日韩精品视频| 久久精品二区三区| 亚洲国产精品久久久久秋霞蜜臀 | 欧美视频二区| 亚洲一区免费网站| 乱中年女人伦av一区二区| 亚洲乱码国产乱码精品精可以看| 久久精品成人一区二区三区蜜臀| 亚洲制服av| 国产亚洲成av人片在线观看桃| 这里只有精品丝袜| 国产在线欧美日韩| 久久精品夜色噜噜亚洲aⅴ| 欧美激情一级片一区二区| 亚洲美女网站| 亚洲免费观看高清完整版在线观看| 蜜臀av国产精品久久久久| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产日韩精品一区| 欧美在线精品免播放器视频| 欧美成人一区二免费视频软件| 国产一区二区高清| 亚洲精品久久久久久久久久久| 午夜久久福利| 欧美午夜电影在线观看| 亚洲精品网站在线播放gif| 欧美伊人精品成人久久综合97| 国产精品久久婷婷六月丁香| 亚洲大胆美女视频| 欧美国产在线电影| 欧美视频手机在线| 亚洲第一天堂无码专区| 国产精品第2页| 最近中文字幕mv在线一区二区三区四区| 久久国产精品久久久久久| 亚洲欧洲在线一区| 久久久精品999| 亚洲深夜av| 欧美美女福利视频|