[發(fā)明專利]一種單片機(jī)代碼的防破解方法有效
| 申請(qǐng)?zhí)枺?/td> | 201710310694.2 | 申請(qǐng)日: | 2017-05-05 |
| 公開(公告)號(hào): | CN107194210B | 公開(公告)日: | 2019-07-30 |
| 發(fā)明(設(shè)計(jì))人: | 劉家斌;劉全喜;魏肅;柴智;劉雙春 | 申請(qǐng)(專利權(quán))人: | 廈門芯陽(yáng)科技股份有限公司 |
| 主分類號(hào): | G06F21/12 | 分類號(hào): | G06F21/12 |
| 代理公司: | 廈門市精誠(chéng)新創(chuàng)知識(shí)產(chǎn)權(quán)代理有限公司 35218 | 代理人: | 何家富 |
| 地址: | 361000 福建省*** | 國(guó)省代碼: | 福建;35 |
| 權(quán)利要求書: | 查看更多 | 說明書: | 查看更多 |
| 摘要: | |||
| 搜索關(guān)鍵詞: | 一種 單片機(jī) 代碼 破解 方法 | ||
本發(fā)明涉及一種單片機(jī)代碼的防破解方法,其在帶有EEROM功能的單片機(jī)代碼中植入保護(hù)程序,在單片機(jī)代碼被執(zhí)行時(shí)可以讀取EEROM中的數(shù)據(jù)進(jìn)行校驗(yàn),程序能自動(dòng)判斷出是破解代碼還是原廠代碼,如果是原廠代碼,則執(zhí)行正常功能,如果是破解代碼則啟動(dòng)相應(yīng)的壽命倒計(jì)時(shí)功能,使基板正常工作一段時(shí)間后失效,導(dǎo)致破解者為破解行為負(fù)出慘痛代價(jià),最終導(dǎo)致破解無效。
技術(shù)領(lǐng)域
本發(fā)明屬于單片機(jī)代碼保護(hù)技術(shù)領(lǐng)域,具體地涉及一種單片機(jī)代碼的防破解方法。
背景技術(shù)
現(xiàn)有的電子產(chǎn)品研發(fā)投入越來越大,疊代越來越快,很多工廠因?yàn)槿鄙傺邪l(fā)投入和技術(shù)沉淀,便通過抄襲硬件和破解芯片代碼的方式達(dá)到快速量產(chǎn)的目的,嚴(yán)重的破壞了市場(chǎng)的公平和損害了研發(fā)公司的利益。
目前芯片的破解主要有以下兩種方式:非侵入式和侵入式。非侵入式利用芯片設(shè)計(jì)或編程時(shí)序中的漏洞對(duì)芯片進(jìn)行破解,隨著芯片技術(shù)的發(fā)展,目前這種情況少之又少。侵入式的方式是破壞芯片封裝,利用半導(dǎo)體測(cè)試設(shè)備等儀器找到芯片保護(hù)點(diǎn)并進(jìn)行修復(fù),然后利用特殊編程器讀出燒錄文件。以上兩種方式都能快速破解出單片機(jī)的程序,可以直接實(shí)現(xiàn)量產(chǎn)。
中國(guó)專利公開號(hào)CN103761456A,公開日2014年4月30日,發(fā)明的名稱為一種單片機(jī)核心代碼防破解的方法,該申請(qǐng)案公開了一種將單片機(jī)內(nèi)核心代碼以密文形式存在特定的存儲(chǔ)區(qū)域,MPU內(nèi)存保護(hù)模塊產(chǎn)生一個(gè)中斷,在中斷中,采用AES模塊將密文代碼解密成明文代碼,CRC校驗(yàn)正確后,將明文代碼回傳到特定存儲(chǔ)區(qū)域,中斷返回,單片機(jī)執(zhí)行特定存儲(chǔ)區(qū)域的明文代碼,代碼執(zhí)行完畢后,AES模塊將特定存儲(chǔ)區(qū)域的明文代碼加密成密文代碼,CRC校驗(yàn)正確后,將密文代碼回傳到特定存儲(chǔ)區(qū)域。其不足之處在于:以上專利是把核心算法切塊并且加密保存,算法需要分區(qū)域存儲(chǔ)并加密,執(zhí)行時(shí)又需要解密和校驗(yàn),極其浪費(fèi)程序空間,而且算法復(fù)雜并不適用于大多數(shù)的單片機(jī)應(yīng)用。
發(fā)明內(nèi)容
本發(fā)明旨在提供一種單片機(jī)代碼的防破解方法,以能夠有效地解決現(xiàn)有的單片機(jī)代碼的防破解方法存在的不足。為此,本發(fā)明采用的具體技術(shù)方案如下:
一種單片機(jī)代碼的防破解方法,包括以下步驟:
S1、單片機(jī)上電后,讀取其EEROM中的校驗(yàn)數(shù)據(jù)地址中保存的校驗(yàn)數(shù)據(jù);
S2、對(duì)步驟S1讀取到的校驗(yàn)數(shù)據(jù)進(jìn)行判斷,若等于表示單片機(jī)程序燒錄后第一次上電的數(shù)值,則進(jìn)入步驟S3;若不等于表示單片機(jī)程序燒錄后第一次上電的數(shù)值,則進(jìn)入步驟S6;
S3、單片機(jī)等待預(yù)定時(shí)間,以確定是否有解鎖動(dòng)作,若解鎖成功,則進(jìn)入步驟S4;若解鎖不成功且已超過解鎖時(shí)間,進(jìn)入步驟S5;
S4、將設(shè)置值更新到EEROM的校驗(yàn)數(shù)據(jù)地址中,將正常壽命值更新到EEROM的壽命數(shù)據(jù)地址中,進(jìn)入步驟S8;
S5、將異常值更新到EEROM的校驗(yàn)數(shù)據(jù)地址中,若通過S3步驟進(jìn)入,則將正常壽命值賦到EEROM中的壽命數(shù)據(jù)地址中,若通過其余步驟進(jìn)入,則壽命數(shù)據(jù)地址的壽命數(shù)據(jù)減一,進(jìn)入步驟S8;
S6:判斷EEROM中的校驗(yàn)數(shù)據(jù)地址的校驗(yàn)數(shù)據(jù)是否等于設(shè)置值,若不相等,則進(jìn)入步驟S5,若相等,則進(jìn)入步驟S7;
S7:將正常壽命值賦到EEROM的壽命數(shù)據(jù)地址中,進(jìn)入步驟S8;
S8:讀取EEROM中的壽命數(shù)據(jù)地址的壽命數(shù)據(jù),判斷是否等于異常壽命值,若相等,則進(jìn)入步驟S9;若不相等,則進(jìn)入步驟S10;
S9:?jiǎn)?dòng)保護(hù)程序;
S10:正常工作。
進(jìn)一步的,所述步驟S3中的解鎖動(dòng)作可包括:鍵盤的數(shù)字密碼輸入、按鍵的單擊或多擊組合或者指定IO口收到的數(shù)據(jù)信號(hào)等。
該專利技術(shù)資料僅供研究查看技術(shù)是否侵權(quán)等信息,商用須獲得專利權(quán)人授權(quán)。該專利全部權(quán)利屬于廈門芯陽(yáng)科技股份有限公司,未經(jīng)廈門芯陽(yáng)科技股份有限公司許可,擅自商用是侵權(quán)行為。如果您想購(gòu)買此專利、獲得商業(yè)授權(quán)和技術(shù)合作,請(qǐng)聯(lián)系【客服】
本文鏈接:http://www.szxzyx.cn/pat/books/201710310694.2/2.html,轉(zhuǎn)載請(qǐng)聲明來源鉆瓜專利網(wǎng)。
- 同類專利
- 專利分類
G06F 電數(shù)字?jǐn)?shù)據(jù)處理
G06F21-00 防止未授權(quán)行為的保護(hù)計(jì)算機(jī)或計(jì)算機(jī)系統(tǒng)的安全裝置
G06F21-02 .通過保護(hù)計(jì)算機(jī)的特定內(nèi)部部件
G06F21-04 .通過保護(hù)特定的外圍設(shè)備,如鍵盤或顯示器
G06F21-06 .通過感知越權(quán)操作或外圍侵?jǐn)_
G06F21-20 .通過限制訪問計(jì)算機(jī)系統(tǒng)或計(jì)算機(jī)網(wǎng)絡(luò)中的節(jié)點(diǎn)
G06F21-22 .通過限制訪問或處理程序或過程
- 遙控器代碼格式結(jié)構(gòu)及其收發(fā)信方法及裝置
- 在虛擬機(jī)中驗(yàn)證代碼模塊的方法及裝置
- 一種用于代碼的管理方法及裝置
- 虛擬代碼提供系統(tǒng)、生成裝置、驗(yàn)證裝置、提供方法
- 一種自動(dòng)化代碼質(zhì)量檢查方法及系統(tǒng)
- 代碼掃描方法、裝置、計(jì)算設(shè)備及計(jì)算機(jī)存儲(chǔ)介質(zhì)
- 用于更新代碼的方法和裝置
- 前端代碼打包方法、裝置、電子設(shè)備及存儲(chǔ)介質(zhì)
- 一種代碼審查服務(wù)同步方法、裝置及計(jì)算機(jī)設(shè)備
- 一種高效智能源代碼安全管理平臺(tái)
- 一種數(shù)據(jù)庫(kù)讀寫分離的方法和裝置
- 一種手機(jī)動(dòng)漫人物及背景創(chuàng)作方法
- 一種通訊綜合測(cè)試終端的測(cè)試方法
- 一種服裝用人體測(cè)量基準(zhǔn)點(diǎn)的獲取方法
- 系統(tǒng)升級(jí)方法及裝置
- 用于虛擬和接口方法調(diào)用的裝置和方法
- 線程狀態(tài)監(jiān)控方法、裝置、計(jì)算機(jī)設(shè)備和存儲(chǔ)介質(zhì)
- 一種JAVA智能卡及其虛擬機(jī)組件優(yōu)化方法
- 檢測(cè)程序中方法耗時(shí)的方法、裝置及存儲(chǔ)介質(zhì)
- 函數(shù)的執(zhí)行方法、裝置、設(shè)備及存儲(chǔ)介質(zhì)





