吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

對主流MCU的程序加密進行講解

UtFs_Zlgmcu7890 ? 來源:未知 ? 作者:李倩 ? 2018-07-06 09:17 ? 次閱讀

隨著物聯(lián)網(wǎng)和邊緣計算的出現(xiàn),五花八門的MCU也被應(yīng)用其中,如何保證我們的程序安全和知識產(chǎn)權(quán)不受侵犯呢,本文我們將對主流MCU的程序加密進行講解,希望能夠幫助你選擇最適合自己應(yīng)用的微處理器

1. MCU加密

通常所說的MCU加密是指將用戶的程序固件保護起來,防止別人通過外部調(diào)試接口或者其他方法讀取燒寫在Flash中的程序。保護自家方案不輕易被別家抄襲,從硬件上保護自己的知識產(chǎn)權(quán)。MCU加密還指防止自家程序被惡意讀取破解。

2. 常用MCU加密方式

通過寫特定配置字;

增加外部加密芯片

程序代碼進行密碼加密,使程序變成密文;

程序校驗芯片的唯一ID。

2.1 配置字加密

2.1.1 原理

MCU廠商在設(shè)計芯片時在芯片中增加特定的非易失存儲,該存儲也可能是Flash的特定地址區(qū)域。用戶可以通過外部工具或在程序的特定地址寫入使能存儲保護的值。

配置字加密在芯片完成上電時序后才會生效,一般包含以下功能:

禁能調(diào)試接口(JTAG/SWD);

不禁能調(diào)試接口,但不允許調(diào)試器連接內(nèi)核和訪問Flash和RAM空間;

關(guān)閉讀寫Flash的ISP指令;

禁止除芯片正常執(zhí)行程序外讀Flash操作;

禁能芯片從外部接口或RAM啟動執(zhí)行代碼。

2.1.2 應(yīng)用場景

這種加密方式通常用在程序存儲在芯片內(nèi)部Flash的系統(tǒng)中。例如NXP LPC系列MCU、GD32系列MCU、NXP Kineits Cortex-M系列。

2.2 外接加密芯片

2.2.1 原理

加密芯片保護程序的方式,是通過程序與外部加密IC的交互來確認程序是否進一步執(zhí)行。

利用芯片隨機數(shù)外設(shè)或者其他能夠產(chǎn)生隨機數(shù)的機制,在每次上電后系統(tǒng)取得一個隨機數(shù),并將這個隨機數(shù)通過類似IIC的協(xié)議傳給外部的硬件加密IC。隨后系統(tǒng)按先前約定的算法進行結(jié)果計算,等待外部IC接收到隨機數(shù)并也算出結(jié)果后,外部IC會將計算結(jié)果傳回給系統(tǒng)。如果系統(tǒng)的計算結(jié)果和外部IC的計算結(jié)果相同,則說明外部的加密IC存在。

2.2.2 應(yīng)用場景

這種加密方式主要用在用戶對代碼中關(guān)鍵算法的加密,算法通常會以Lib的方式提供,只有購買了對應(yīng)加密芯片(類似于產(chǎn)品密鑰)的客戶才能夠使用算法程序。

2.3 UID檢驗加密

2.3.1 原理

UID加密一種用戶主動加密的方式。當(dāng)下幾乎所有處理器內(nèi)部都包含UID,可以通過直接尋址讀取或者IAP指令獲得。

UID加密通常分為二種方式:

用戶在燒寫程序時,讀取一次芯片UID將其寫入Flash特定區(qū)域。在程序啟動時直接讀取UID和Flash內(nèi)部的數(shù)值進行比較決定是否啟動;

用戶讀取UID后通過私有密鑰將UID加密之后的信息寫入Flash特定地址,例如Flash的最后一個扇區(qū)。程序啟動時,首先讀取芯片UID并通過同樣的密鑰和算法進行計算后與Flash中的數(shù)值進行比較決定是否啟動。

其中第一種最容易被破解,第二種也存在潛在風(fēng)險,為了增強第二種的安全性,可以將加密后的數(shù)據(jù)拆分后分別存放到Flash的不同位置,運行時再組合。

2.3.2 應(yīng)用場景

主要用在一些不需要太多保護的協(xié)議棧上,例如LoRa協(xié)議棧、文件系統(tǒng)、私有操作系統(tǒng)等。協(xié)議棧相對算法的價值會低一些,增加加密芯片的成本顯得過高。

同時這種方式也可延伸為使用PID(每個型號的ID相同)來區(qū)分設(shè)備型號。

2.4 程序固件加密

2.4.1 原理

程序固件加密是指通過私有密鑰將整個程序固件加密計算后生成密文,使得程序即使被其他人拿到后也不可能被反編譯。這種加密方式通常需要有一段地址存儲密鑰和解密程序,他們可以是芯片內(nèi)部Bootloader或用戶自己的Bootloader。

2.4.2 應(yīng)用場景

這種加密方式主要用于芯片沒有內(nèi)部Flash或Flash較小,以及需要給用戶升級固件的產(chǎn)品上。例如:

芯片從外部Flash啟動時,外部Flash很容易被拷貝,盜版。這種應(yīng)用通常芯片內(nèi)部具備OTP區(qū)域用于編程密鑰;

芯片內(nèi)部Flash較小時可以將算法等文件放置在外部Flash中,運行時解密到內(nèi)部RAM執(zhí)行。密鑰通常和內(nèi)部Flash的程序一同存儲;

使用在產(chǎn)品需要后期升級功能算法的項目中,可以在Bootloader中放置解密程序,升級的過程中,Bootloader將收到的固件解密燒寫到內(nèi)部Flash中。這樣既可以隨意發(fā)送產(chǎn)品更新固件,同時不用擔(dān)心知識產(chǎn)權(quán)被侵害。

例如i.MX RT1050系列芯片就是使用程序固件加密,程序被放置在外部Flash中,執(zhí)行時邊解密邊執(zhí)行,對i.MX RT1050系列的加密問題可以聯(lián)系我們。

3. 常用芯片的加密方式

3.1 NXP LPC系列

LPC系列MCU大多采用配置字加密方式,即CRP(Code Read Protection)加密。將配置字(CRP Key)寫入特定的Flash地址中。芯片上電啟動后內(nèi)部boot會根據(jù)配置選擇禁用相應(yīng)的功能。

CRP是一種允許用戶在系統(tǒng)中啟用不同級別的安全性的機制,從而可以限制對片上閃存的訪問和ISP的使用。當(dāng)需要時,通過在0x0002FC中閃存位置編程特定模式來調(diào)用CRP。IAP命令不受代碼讀取保護的影響。

以LPC824位例,在啟動文件(*.s)中找到CRP Key根據(jù)需要進行修改,如圖3.1。

圖3.1 CRP Key示例

注:切記在產(chǎn)品最終固件中才可使用CRP3,否則芯片將被鎖死不能再被解鎖。

3.2 NXP Kineits Cortex-M系列

Kineits Cortex-M系列的加密同樣使用配置字的方式寫入Flash特定區(qū)域,但它比LPC系列相對復(fù)雜一些功能也更加強大。

Kineits Cortex-M系列的加密包含在FlashConfig區(qū)域,F(xiàn)lashConfig包含一些用于芯片內(nèi)部Boot的配置信息,比如使能或禁能NMI引腳中斷。

圖3.2 FSL的FlashConfig段

使用keil工具可以快速使用UI配置,如圖3.3所示:

圖3.3 啟動文件配置

3.3 GD32系列

GD32系列加密與和STM32系列加密方式類似。GD32內(nèi)部包含一個FMC外設(shè)。FMC提供了一個安全保護功能來阻止非法讀取閃存。此功能可以很好地保護軟件和固件免受非法的用戶操作。

FMC包含一個OB_RDPT字節(jié)與其補字節(jié):

當(dāng)將OB_RDPT字節(jié)和它的補字節(jié)被設(shè)置為0x5AA5,系統(tǒng)復(fù)位以后,閃存將處于非安全保護狀態(tài);

當(dāng)設(shè)置OB_RDPT字節(jié)和它的補字節(jié)值為任何除0x5AA5外的值,系統(tǒng)復(fù)位以后,安全保護狀態(tài)生效;

在安全保護狀態(tài)下,主存儲閃存塊僅能被用戶代碼訪問且前4KB的閃存自動處于頁擦除/編程保護狀態(tài)下。在調(diào)試模式下,或從SRAM中啟動時,以及從boot loader區(qū)啟動時,這些模式下對主存儲塊的操作都被禁止;

如果將OB_RDPT字節(jié)和它的補字節(jié)設(shè)置為0x5AA5,安全保護功能將失效,并自動觸發(fā)一次整片擦除操作。

GD官方提供加密工具GigaDevice_MCU_ISP_Programmer或者使用FlyMCU等工具,操作界面如圖3.4所示:

圖3.4 GD32使用FlyMCU加密

3.4 i.MX RT系列

i.MX RT系列是NXP公司發(fā)布的跨界處理器,MPU的處理性能、MCU的開發(fā)方式。該系列不包含用戶可用的內(nèi)部Flash,所有代碼都要存儲在外部存儲介質(zhì)中。它使用FSL獨有的HAB安全機制,能夠達到比前面更安全的加密機制。

i.MX RT的加密是將程序固件完全通過工具轉(zhuǎn)換為密文,不能夠被反編譯,同時i.MX RT內(nèi)部包含OTP區(qū)域,用于編程密鑰信息和啟動信息,加密后不可讀取。

芯片使用QSPI或HypeFlash時,可以實現(xiàn)邊運行邊解密,不占用額外的RAM空間,同時硬件解密配合內(nèi)核中32KB ICache和32KB DCache使得程序運行不會受到固件加密的影響;

芯片還支持Boot時完全解密程序到內(nèi)部RAM或外部SDRAM,這種方式代碼的啟動速度略微變慢,但是能夠支持更多的啟動方式:SD卡、MMC、Nand Flash等。

NXP提供加密工具CSF和密鑰燒寫工具FlashLoader,用于程序固件的加密和燒寫。如有任何疑問可聯(lián)系我們的FAE獲得支持。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 芯片
    +關(guān)注

    關(guān)注

    456

    文章

    51182

    瀏覽量

    427276
  • mcu
    mcu
    +關(guān)注

    關(guān)注

    146

    文章

    17321

    瀏覽量

    352650
  • 加密
    +關(guān)注

    關(guān)注

    0

    文章

    305

    瀏覽量

    24007

原文標(biāo)題:安全加密(一):這些MCU加密方法你都知道嗎?

文章出處:【微信號:Zlgmcu7890,微信公眾號:周立功單片機】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    這些MCU加密方法你都知道嗎?

    本文導(dǎo)讀隨著物聯(lián)網(wǎng)和邊緣計算的出現(xiàn),五花八門的MCU也被應(yīng)用其中,如何保證我們的程序安全和知識產(chǎn)權(quán)不受侵犯呢,本文我們將對主流MCU程序
    發(fā)表于 07-12 15:33

    MCU加密方法你知道多少?

    隨著物聯(lián)網(wǎng)和邊緣計算的出現(xiàn),五花八門的MCU也被應(yīng)用其中,如何保證我們的程序安全和知識產(chǎn)權(quán)不受侵犯呢,本文我們將對主流MCU程序
    發(fā)表于 10-10 14:53

    MCU加密手段有哪些

    關(guān)注、星標(biāo)公眾號,不錯過精彩內(nèi)容編輯:黃工參考素材來源:網(wǎng)絡(luò)現(xiàn)在的MCU程序可能別人花幾百塊錢就能破解,為了防止大家的程序不被剽竊,今天給大家分享點加密的內(nèi)容。一、常見
    發(fā)表于 11-01 07:29

    MCU加密的方法

    本文導(dǎo)讀隨著物聯(lián)網(wǎng)和邊緣計算的出現(xiàn),五花八門的MCU也被應(yīng)用其中,如何保證我們的程序安全和知識產(chǎn)權(quán)不受侵犯呢,本文我們將對主流MCU程序
    發(fā)表于 11-04 07:24

    有什么方法可以對STM32 MCU進行加密

    STM32 MCU加密的原理是什么?有什么方法可以對STM32 MCU進行加密呢?
    發(fā)表于 11-08 07:05

    對單片機程序的動態(tài)加密措施

    對單片機的加密還要在程序的運行上進行加密處理, 也就是程序的動態(tài)加密措施。
    發(fā)表于 06-01 14:59 ?2508次閱讀

    使用51單片機進行PWM的程序講解免費下載

    本文檔的主要內(nèi)容詳細介紹的是使用51單片機進行PWM的程序講解免費下載。
    發(fā)表于 06-17 17:44 ?7次下載
    使用51單片機<b class='flag-5'>進行</b>PWM的<b class='flag-5'>程序</b>和<b class='flag-5'>講解</b>免費下載

    MCU常見的加密手段

    關(guān)注、星標(biāo)公眾號,不錯過精彩內(nèi)容編輯:黃工參考素材來源:網(wǎng)絡(luò)現(xiàn)在的MCU程序可能別人花幾百塊錢就能破解,為了防止大家的程序不被剽竊,今天給大家分享點加密的內(nèi)容。一、常見
    發(fā)表于 10-25 14:21 ?1次下載
    <b class='flag-5'>MCU</b>常見的<b class='flag-5'>加密</b>手段

    MCU常見的加密手段

    MCU常見的加密手段
    發(fā)表于 10-25 16:36 ?16次下載
    <b class='flag-5'>MCU</b>常見的<b class='flag-5'>加密</b>手段

    【轉(zhuǎn)】安全加密(一):這些MCU加密方法你都知道嗎?

    本文導(dǎo)讀隨著物聯(lián)網(wǎng)和邊緣計算的出現(xiàn),五花八門的MCU也被應(yīng)用其中,如何保證我們的程序安全和知識產(chǎn)權(quán)不受侵犯呢,本文我們將對主流MCU程序
    發(fā)表于 10-28 20:36 ?15次下載
    【轉(zhuǎn)】安全<b class='flag-5'>加密</b>(一):這些<b class='flag-5'>MCU</b><b class='flag-5'>加密</b>方法你都知道嗎?

    MCU加密技術(shù)分析(二)

    上期提到了嵌入式MCU破解技術(shù),雖不全面,但足夠起到警示作用。? ? ?本期主要講述嵌入式產(chǎn)品如何進行安全防護。? ??因為MCU端的程序很容易被獲取到,所以
    發(fā)表于 11-01 16:24 ?10次下載
    <b class='flag-5'>MCU</b><b class='flag-5'>加密</b>技術(shù)分析(二)

    AN5281_在STM32 MCU的受信任環(huán)境中使用OTFDEC進行加密/解密

    AN5281_在STM32 MCU的受信任環(huán)境中使用OTFDEC進行加密/解密
    發(fā)表于 11-21 08:11 ?0次下載
    AN5281_在STM32 <b class='flag-5'>MCU</b>的受信任環(huán)境中使用OTFDEC<b class='flag-5'>進行</b><b class='flag-5'>加密</b>/解密

    MCU加密

    MCU加密
    的頭像 發(fā)表于 09-26 17:01 ?1096次閱讀
    <b class='flag-5'>MCU</b>之<b class='flag-5'>加密</b>

    HASH算法加密芯片的工作原理及其在STM32 MCU上的應(yīng)用

    本文主要研究了HASH算法加密芯片的工作原理及其在STM32 MCU上的應(yīng)用,實現(xiàn)了外部加密芯片對STM32 MCU程序保護,目前的技術(shù)手
    的頭像 發(fā)表于 10-24 15:01 ?4138次閱讀
    HASH算法<b class='flag-5'>加密</b>芯片的工作原理及其在STM32 <b class='flag-5'>MCU</b>上的應(yīng)用

    如何對GD32 MCU進行加密

    GD32MCU有哪些加密方法呢?大家在平時項目開發(fā)的過程中,最后都可能會面臨如何對出廠產(chǎn)品的MCU代碼進行加密,避免產(chǎn)品流向市場被別人讀取復(fù)
    的頭像 發(fā)表于 01-20 09:30 ?1635次閱讀
    如何對GD32 <b class='flag-5'>MCU</b><b class='flag-5'>進行</b><b class='flag-5'>加密</b>?
    百家乐官网反缆公式| 百家乐游戏规则介绍| 华盛顿百家乐的玩法技巧和规则 | 平台百家乐的区别| 大发888登陆| 澳门百家乐官网牌规| 百家乐视频游戏帐号| 三晋棋牌中心| 现场百家乐官网能赢吗| 万达百家乐娱乐城| 百家乐官网视频游戏平台| 百家乐视频双扣游戏| 棋牌游戏平台开发| 百家乐官网博娱乐赌百家乐官网的玩法技巧和规则 | 风水24山向| 大发888娱乐真钱游戏下载| 赌博百家乐官网玩法| BB百家乐HD| 梨树县| 百家乐赌场作弊| 香港六合彩曾道人| 百家乐官网计划工具| 元游棋牌游戏下载| G3百家乐官网的玩法技巧和规则| 大发888游戏平台 送1666元礼金领取lrm | 基础百家乐官网博牌规| 顶级赌场是真的吗| 爱赢百家乐官网的玩法技巧和规则 | 大发888官网df888| 百家乐官网赌场论坛在线| 百家乐微笑玩| 菲律宾百家乐官网太阳城| 百家乐五湖四海娱乐| 百家乐官网扑克发牌器| 百佬汇百家乐的玩法技巧和规则| 百家乐官网在线投注顺势法| 上市百家乐.评论| 百家乐官网翻天快播粤语| 威尼斯人娱乐城信誉好不好 | 百家乐博赌场娱乐网规则| 百家乐官网怎么开户|