亚洲精品久久久久久久久久久,亚洲国产精品一区二区制服,亚洲精品午夜精品,国产成人精品综合在线观看,最近2019中文字幕一页二页

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

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

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

CW32L010安全運行庫保護的實現(xiàn)

CW32生態(tài)社區(qū) ? 來源:CW32生態(tài)社區(qū) ? 作者:CW32生態(tài)社區(qū) ? 2025-05-12 14:51 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言

CW32L010的FLASH存儲器支持安全運行庫功能,方案商可將核心算法存儲于安全運行庫區(qū)域以供客戶二次開發(fā)時調(diào)用。使能安全運行庫保護功能后,用戶代碼可正常調(diào)用運行安全運行庫區(qū)域內(nèi)的函數(shù),但無法通過任何方式(CPU、SWD、ISP)讀出安全運行庫區(qū)域的內(nèi)容,只有提供正確的密碼時才能通過ISP協(xié)議禁止安全運行庫保護功能,同 時清空安全運行庫存儲空間的數(shù)據(jù)。

一、工作原理

通過將要保護的算法指定存放到FLASH對應(yīng)的頁面page(0

二、設(shè)置安全運行庫的具體步驟

2.1.將算法函數(shù)指定到目標(biāo)頁面

只需要使用__attribute__((section(".ARM.__at_address")))就可以將變量、數(shù)組、函數(shù)指定到FLASH的任意地址。

wKgZPGggaqeAacjeAAAs0mtrR3o682.jpg

常見的函數(shù)類型指定地址方法如下:

@font-face{
font-family:"Times New Roman";
}
@font-face{
font-family:"宋體";
}
@font-face{
font-family:"Calibri";
}
p.MsoNormal{
mso-style-name:正文;
mso-style-parent:"";
margin:0pt;
margin-bottom:.0001pt;
mso-pagination:none;
text-align:justify;
text-justify:inter-ideograph;
font-family:Calibri;
mso-fareast-font-family:宋體;
mso-bidi-font-family:'Times New Roman';
font-size:10.5000pt;
mso-font-kerning:1.0000pt;
}
p.MsoFooter{
mso-style-name:頁腳;
mso-style-noshow:yes;
margin:0pt;
margin-bottom:.0001pt;
tab-stops:center blank 207.6500pt right blank 415.3000pt ;
layout-grid-mode:char;
mso-pagination:none;
text-align:left;
font-family:Calibri;
mso-fareast-font-family:宋體;
mso-bidi-font-family:'Times New Roman';
font-size:9.0000pt;
mso-font-kerning:1.0000pt;
}
span.msoIns{
mso-style-type:export-only;
mso-style-name:"";
text-decoration:underline;
text-underline:single;
color:blue;
}
span.msoDel{
mso-style-type:export-only;
mso-style-name:"";
text-decoration:line-through;
color:red;
}
@page{mso-page-border-surround-header:no;
	mso-page-border-surround-footer:no;}@page Section0{
}
div.Section0{page:Section0;}
void func1 (void); 
void func1 (void) __attribute__((section(".ARM.__at_0x0000FE00")));
//指定func函數(shù)的地址為0x0000FE00,所在頁面為127頁
 
void func2 (uint8_t CNT);void func2 (uint8_t) __attribute__((section(".ARM.__at_0x0000FE50")));//指定func函數(shù)的地址為0x0000FE50,所在頁面為127頁
 
uint8_t func3 (uint8_t CNT1,uint8_t* p);
uint8_t func3 (uint8_t, uint8_t*) __attribute__(( section(".ARM.__at_0x0000FEA4" )));
//指定func函數(shù)的地址為0x0000FEA4,所在頁面為127頁

多個函數(shù)指定地址儲存時,在指定地址前,需先在KEIL的map文件中找到各個函數(shù)的大小,免得指定地址時內(nèi)存沖突。map文件如下:

wKgZO2ggaqiAQoN4AALl8rjUp84557.jpg

由此可以得到func1、func2、func3的字節(jié)大小分別是0x50、0x54、0x58,接下來就可以指定函數(shù)的存儲地址了。

注意指定地址時,因為32位變量需要4字節(jié)對齊,也就是地址的最低位得是0、4、8、C才行,所以地址不能出現(xiàn),如:0x0000FE01、0x0000FE02、0x0000FE03、0x0000FE05、0x0000FE06、0x0000FE07、0x0000FE09、0x0000FE0A、0x0000FE0B、0x0000FE0D、0x0000FE0E、0x0000FE0F

接著就可以指定func1的地址為0x0000FE00,func2的地址為0x0000FE00+0x50,func3的地址為0x0000FE00+0x50+0x54,如想指定其它地址,依次類推。

2.2.開啟相應(yīng)頁面的安全運行庫

使能安全運行庫保護功能的方法為:在地址0xFFF0~ 0xFFFF 寫入特定控制字,如下表所示:

wKgZPGggaqmAP5yGAAECAGD6p0o349.jpgwKgZO2ggaqmAJC5nAABz1keOiRc549.jpg

2.3.參考代碼

文章及視頻中使用到的例程源碼文件:

通過網(wǎng)盤分享的文件:CW32L010 FLASH PROTECT.zip

鏈接: https://pan.baidu.com/s/1d5tj_zz-b1bQGkJkuAgbdQ?pwd=CW32

提取碼: CW32

@font-face{
font-family:"Times New Roman";
}
@font-face{
font-family:"宋體";
}
@font-face{
font-family:"Calibri";
}
p.MsoNormal{
mso-style-name:正文;
mso-style-parent:"";
margin:0pt;
margin-bottom:.0001pt;
mso-pagination:none;
text-align:justify;
text-justify:inter-ideograph;
font-family:Calibri;
mso-fareast-font-family:宋體;
mso-bidi-font-family:'Times New Roman';
font-size:10.5000pt;
mso-font-kerning:1.0000pt;
}
p.MsoFooter{
mso-style-name:頁腳;
mso-style-noshow:yes;
margin:0pt;
margin-bottom:.0001pt;
tab-stops:center blank 207.6500pt right blank 415.3000pt ;
layout-grid-mode:char;
mso-pagination:none;
text-align:left;
font-family:Calibri;
mso-fareast-font-family:宋體;
mso-bidi-font-family:'Times New Roman';
font-size:9.0000pt;
mso-font-kerning:1.0000pt;
}
span.msoIns{
mso-style-type:export-only;
mso-style-name:"";
text-decoration:underline;
text-underline:single;
color:blue;
}
span.msoDel{
mso-style-type:export-only;
mso-style-name:"";
text-decoration:line-through;
color:red;
}
@page{mso-page-border-surround-header:no;
	mso-page-border-surround-footer:no;}@page Section0{
}
div.Section0{page:Section0;}
void func1 (void) __attribute__((section(".ARM.__at_0x0000FE00")));//指定func函數(shù)的地址為0x0000FE00,所在頁面為127頁
void func2 (uint8_t ) __attribute__((section(".ARM.__at_0x0000FE50")));//指定func函數(shù)的地址為0x0000FE50,所在頁面為127頁
uint8_t func3 (uint8_t ,uint8_t* ) __attribute__((section(".ARM.__at_0x0000FEA4")));//指定func函數(shù)的地址為0x0000FEA4,所在頁面為127頁
 
void func1 (void) 
{
 //PB03---LED1 推挽輸出
    CW_GPIOB->DIR_f.PIN3 = 0;
    CW_GPIOB->ANALOG_f.PIN3 = 0;

 uint8_t cnt = 10;

    while(cnt--)
 {
  CW_GPIOB->TOG_f.PIN3 = 1;
  uint32_t thisCnt = 0X9FFFF;
  while( thisCnt-- )
  {
   ;
  }
 }
}
 
void func2 (uint8_t CNT) 
{
 //PB03---LED1 推挽輸出
    CW_GPIOB->DIR_f.PIN3 = 0;
    CW_GPIOB->ANALOG_f.PIN3 = 0;

 uint8_t cnt = CNT;

    while(cnt--)
 {
  CW_GPIOB->TOG_f.PIN3 = 1;
  uint32_t thisCnt = 0X9FFFF;
  while( thisCnt-- )
  {
   ;
  }
 }
}
 
uint8_t func3 (uint8_t CNT1,uint8_t* p) 
{
 //PB03---LED1 推挽輸出
    CW_GPIOB->DIR_f.PIN3 = 0;
    CW_GPIOB->ANALOG_f.PIN3 = 0;

 uint8_t cnt = CNT1 + *p;

    while(cnt--)
 {
  CW_GPIOB->TOG_f.PIN3 = 1;
  uint32_t thisCnt = 0X9FFFF;
  while( thisCnt-- )
  {
   ;
  }
 }
 return 0;
}
 
int32_t main(void)
{        
    uint8_t ret,temp;
    
    __SYSCTRL_FLASH_CLK_ENABLE();
    __SYSCTRL_CRC_CLK_ENABLE();
 __SYSCTRL_GPIOB_CLK_ENABLE();

    ret = FLASH_SafetyLibraryEnable(SlibKey, 0x7F, 0x7F);
    
    if (ret)
    {
        // 開啟安全區(qū)失敗
        while(1);
    }    

 func1();

 func2(10);

 temp = 5;
 ret = func3(5,&temp);
    
    //結(jié)束
    while(1)
    {
        
    }
}

2.4.函數(shù)調(diào)用

函數(shù)調(diào)用時需要在指定的地址上加1,因為對于cortex M核的芯片,任何跳轉(zhuǎn)相關(guān)地址的最低位,即BIT0都應(yīng)是1。該位表示將用到的的指令集為Thumb指令。具體調(diào)用方法如下:

@font-face{
font-family:"Times New Roman";
}
@font-face{
font-family:"宋體";
}
@font-face{
font-family:"Calibri";
}
p.MsoNormal{
mso-style-name:正文;
mso-style-parent:"";
margin:0pt;
margin-bottom:.0001pt;
mso-pagination:none;
text-align:justify;
text-justify:inter-ideograph;
font-family:Calibri;
mso-fareast-font-family:宋體;
mso-bidi-font-family:'Times New Roman';
font-size:10.5000pt;
mso-font-kerning:1.0000pt;
}
p.MsoFooter{
mso-style-name:頁腳;
mso-style-noshow:yes;
margin:0pt;
margin-bottom:.0001pt;
tab-stops:center blank 207.6500pt right blank 415.3000pt ;
layout-grid-mode:char;
mso-pagination:none;
text-align:left;
font-family:Calibri;
mso-fareast-font-family:宋體;
mso-bidi-font-family:'Times New Roman';
font-size:9.0000pt;
mso-font-kerning:1.0000pt;
}
span.msoIns{
mso-style-type:export-only;
mso-style-name:"";
text-decoration:underline;
text-underline:single;
color:blue;
}
span.msoDel{
mso-style-type:export-only;
mso-style-name:"";
text-decoration:line-through;
color:red;
}
@page{mso-page-border-surround-header:no;
	mso-page-border-surround-footer:no;}@page Section0{
}
div.Section0{page:Section0;}
#define  Slib_Led_Blink1     ((void (*)())(0x0000FE00UL + 1))
#define  Slib_Led_Blink2     ((void (*)(uint8_t))(0x0000FE50UL + 1))
#define  Slib_Led_Blink3     ((uint8_t (*)(uint8_t,uint8_t*))(0x0000FEA4UL + 1))
 
int32_t main(void)
{
    SYSCTRL_HSI_Enable(SYSCTRL_HSIOSC_DIV12);
 __SYSCTRL_GPIOB_CLK_ENABLE();

 Slib_Led_Blink1();//方法一:宏調(diào)用
 ((void (*)())(0x0000FE00UL + 1))();//方法二:直接調(diào)用
 void (*ppp1) ();//方法三;函數(shù)指針調(diào)用
 ppp1 = (void (*) ())(0xFE00 + 1);
 ppp1();

 Slib_Led_Blink2(10);//方法一:宏調(diào)用
 ((void (*)(uint8_t))(0x0000FE50UL + 1))(10);//方法二:直接調(diào)用
 void (*ppp2)(uint8_t);//方法三;函數(shù)指針調(diào)用
 ppp2 = ((void (*)(uint8_t))(0x0000FE50UL + 1));
 ppp2(10);

 uint8_t xx = 5;
 uint8_t temp = Slib_Led_Blink3(5,&xx);//方法一:宏調(diào)用
 ((uint8_t (*)(uint8_t,uint8_t*))(0x0000FEA4UL + 1))(5,&xx);//方法二:直接調(diào)用
 uint8_t (*ppp3)(uint8_t,uint8_t*);//方法三;函數(shù)指針調(diào)用
 ppp3 = (uint8_t (*)(uint8_t,uint8_t*))(0x0000FEA4+1);
 ppp3(5,&xx);

    while (1)
    {

    }
}

2.5.擦除安全運行庫

禁止安全運行庫保護功能共有兩種方法:

(1).通過ISP協(xié)議執(zhí)行片擦操作:芯片接收到片擦指令及正確的安全運行庫密碼時,將自動擦除本芯片的所有數(shù)據(jù)并禁止安全運行庫保護功能;。

需要用到上位機CW-Programmmer,具體連線請按上位機提示進行連接,上位機配置需按下圖配置:

wKgZPGggaqqAaPjYAAB01jsbjCA934.jpg

填寫SDK區(qū)域密碼時,需按16進制來填寫密碼,如:十進制1,0xF,'_','!','@','*','A','1',填寫時為它們對應(yīng)ascii值的16進制,分別是0x01、0x0F、0x5F、0x21、0x40、0x2A、0x41、0x31,所以密碼應(yīng)該填寫010F5F21402A4131。

填寫完密碼后,點擊在線編程,即可擦除安全運行庫。

(2).在RAM中對芯片執(zhí)行片擦操作:配置編譯器參數(shù),使片擦操作從RAM中執(zhí)行。片擦操作完成后,本芯片的所有數(shù)據(jù)均被擦除并禁止安全運行庫保護功能。

2.6.注意事項

(1).指定算法函數(shù)的地址不要太靠前,否則會與下載的代碼起沖突,建議選擇FLASH靠后的頁面。

(2).儲存在安全運行庫頁面里的函數(shù),不可調(diào)用安全區(qū)外的函數(shù)。

(3).安全運行庫代碼下載到MCU后,要進行上電復(fù)位才能生效。

三、現(xiàn)象演示

將安全運行庫的代碼下載到CW32L010F8P6 StartKit REV01板子中后,斷電后重新上電,DEBUG頁面的memory中,127頁顯示不可讀,全0,表示127頁已經(jīng)受到保護了。

wKgZO2ggaquARyW3AAFMKuxTQ_k875.jpg

用戶可以在其它工程中調(diào)用儲存在安全運行庫頁面的函數(shù),具體調(diào)用方法詳情見2.4函數(shù)調(diào)用章節(jié)。

四、視頻講解

CW32L010黑客區(qū)安全運行庫保護的實現(xiàn) :1.FLASH及安全庫區(qū)域原理_嗶哩嗶哩_bilibili

CW32L010黑客區(qū)安全運行庫保護的實現(xiàn) :2.算法編程調(diào)用及注意事項_嗶哩嗶哩_bilibili

CW32L010黑客區(qū)安全運行庫保護的實現(xiàn) :3. 實例代碼運行講解及FLASH讀取驗證_嗶哩嗶哩_bilibili

審核編輯 黃宇

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

    關(guān)注

    8

    文章

    1396

    瀏覽量

    119561
  • 算法
    +關(guān)注

    關(guān)注

    23

    文章

    4744

    瀏覽量

    96930
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    基于CW32L010的高性能溫控器方案

    武漢芯源半導(dǎo)體的明星產(chǎn)品CW32L010系列MCU憑借其ARM Cortex-M0+內(nèi)核、超低功耗特性以及豐富的外設(shè)接口,為溫控器設(shè)計提供了理想的解決方案。 本文將介紹無錫梓軒電子基于武漢芯源半導(dǎo)體低功耗CW32L010單片機開發(fā)的溫控器方案,功能全面,性價比突出。
    的頭像 發(fā)表于 07-02 09:47 ?822次閱讀
    基于<b class='flag-5'>CW32L010</b>的高性能溫控器方案

    基于CW32L010的高性能溫控器方案

    CW32L010溫控器 方案可實現(xiàn): 溫控范圍:5-95℃; 溫度開關(guān)偏差:0.5-10℃可調(diào); 設(shè)定溫度與時鐘輪流顯示,測量溫度直接讀?。?傳感器故障提示; 支持人工控制、時段控制和臨時控制三種
    發(fā)表于 07-02 09:46

    CW32L010 MCU在VSCode+GCC+EIDE+JLink下的使用示例

    、安裝Embedded IDE、Cortex-Debug等插件。 2、下載安裝gcc-arm-none-eabi工具鏈。 3、運行VSCode,打開CW32L010 MCU的GCC示例工程
    的頭像 發(fā)表于 07-01 14:52 ?669次閱讀
    <b class='flag-5'>CW32L010</b> MCU在VSCode+GCC+EIDE+JLink下的使用示例

    CW32L010 ESC Driver 電機控制套件快速上手指南

    在嵌入式系統(tǒng)和電機控制領(lǐng)域,無刷直流電機(BLDC)因其高效、長壽命和低噪音等優(yōu)點而被廣泛應(yīng)用。為了幫助開發(fā)者快速掌握 CW32L010 系列MCU在電機控制方面的應(yīng)用,武漢芯源半導(dǎo)體推出了一款
    發(fā)表于 06-23 22:50

    基于CW32L010單片機的掃振一體電動牙刷應(yīng)用方案

    馬達空間(深圳) 科技有限公司開發(fā)的這款掃振一體電動牙刷方案,憑借CW32L010高集成度、低功耗特性和豐富外設(shè)資源,可實現(xiàn)高效電機控制、多檔刷牙振動切換、TFT 屏幕顯示等功能。
    的頭像 發(fā)表于 06-17 09:49 ?593次閱讀
    基于<b class='flag-5'>CW32L010</b>單片機的掃振一體電動牙刷應(yīng)用方案

    基于CW32L010單片機的掃振一體電動牙刷應(yīng)用方案

    大幅擺動實現(xiàn)了高效的刷牙方式,這種設(shè)計能夠更高效地清潔牙齒和牙齦溝,為用戶帶來全新的潔牙體驗?。本文將介紹武漢芯源半導(dǎo)體CW32L010單片機在掃振一體電動牙刷上的應(yīng)用方案。 圖1:電動牙刷方案
    發(fā)表于 06-17 09:38

    CW32L010 ESC Driver 電機控制套件使用

    開發(fā)板的PCB圖和原理圖上的燒錄引腳,連接DAP-Link,即可將程序燒錄到開發(fā)板上。 3、使用效果 電機的運行效果如下。 4、總結(jié) CW32L010 電機驅(qū)動開發(fā)板組裝簡單,價格低,適合作為入門BLDC控制的選擇。
    發(fā)表于 06-13 18:12

    武漢芯源半導(dǎo)體CW32L010在兩輪車儀表的應(yīng)用介紹

    CW32L010憑借其優(yōu)異的性能、豐富的外設(shè)資源和超低功耗特性,為兩輪車儀表盤應(yīng)用提供了高性價比的解決方案。其寬電壓工作范圍和工業(yè)級溫度特性,特別適合車輛電子應(yīng)用的嚴苛環(huán)境。對于想采用CW32L010進行兩輪車儀表盤開發(fā)的客戶,武漢芯源半導(dǎo)體可提供全面的技術(shù)支持,助力客戶
    的頭像 發(fā)表于 05-13 14:07 ?498次閱讀
    武漢芯源半導(dǎo)體<b class='flag-5'>CW32L010</b>在兩輪車儀表的應(yīng)用介紹

    武漢芯源半導(dǎo)體CW32L010在兩輪車儀表的應(yīng)用介紹

    隨著兩輪電動車的智能化發(fā)展,儀表盤作為人機交互的重要界面,其功能需求日益復(fù)雜。武漢芯源半導(dǎo)體的安全低功耗單片機CW32L010憑借其優(yōu)異的性能和豐富的外設(shè)資源,成為兩輪車儀表盤應(yīng)用的理想選擇。 本文
    發(fā)表于 05-13 14:06

    CW32L010 Motor Control Driver無刷電機驅(qū)動板上手體驗

    CW32L010無刷電機驅(qū)動開發(fā)板上手體驗
    的頭像 發(fā)表于 12-26 09:26 ?1627次閱讀
    <b class='flag-5'>CW32L010</b> Motor Control Driver無刷電機驅(qū)動板上手體驗

    方案介紹|CW32L010安全低功耗MCU:驅(qū)動高速風(fēng)筒新力量

    芯源半導(dǎo)體CW32L010系列MCU可支持低成本、高性能、低功耗、高度集成的高速風(fēng)筒方案,以滿足市場對高效、安全、智能的高速風(fēng)筒需求。 本文將介紹武漢芯源半導(dǎo)體CW32L010系列單片機在高速風(fēng)筒
    發(fā)表于 12-10 09:57

    【產(chǎn)品方案】基于CW32L010低成本電動工具方案

    本方案采用武漢芯源的CW32L010F8P6作為主控實現(xiàn)低成本電動工具方案,通過PWM方波控制算法進行電機轉(zhuǎn)速控制,內(nèi)部高精度AD轉(zhuǎn)換實現(xiàn)電機電壓、反電動勢、電流等信號的采樣,并實時進行故障停機
    的頭像 發(fā)表于 11-28 11:10 ?2123次閱讀
    【產(chǎn)品方案】基于<b class='flag-5'>CW32L010</b>低成本電動工具方案

    CW32L010 Mini Board 測評】簡介、點燈

    Sleep 和 DeepSleep 工作模式。 存儲容量 64K 字節(jié) FLASH,數(shù)據(jù)保持 25 年 @-40℃ ~ +85℃,支持擦寫保護、讀保護安全運行庫
    發(fā)表于 11-17 06:39

    CW32L010學(xué)習(xí)筆記

    記錄CW32L010學(xué)習(xí)過程
    的頭像 發(fā)表于 11-15 17:40 ?3863次閱讀
    <b class='flag-5'>CW32L010</b>學(xué)習(xí)筆記

    CW32L010 新品初體驗

    ,本次體驗的核心板為CW32L010的TSSOP20pin的封裝版本,它集成了完整的最小系統(tǒng),所有輸入輸出接口(GPIO口)均已引出,便于用戶進行各類開發(fā)與測試。核心板上不僅設(shè)有SWD下載接口,還配備了LED指示燈PB0口,通過Type-CUSB接口即可實現(xiàn)便捷供電,為用
    的頭像 發(fā)表于 11-14 17:45 ?1268次閱讀
    <b class='flag-5'>CW32L010</b> 新品初體驗