国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

CW32L010安全運行庫保護的實現

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

掃碼添加小助手

加入工程師交流群

前言

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

一、工作原理

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

二、設置安全運行庫的具體步驟

2.1.將算法函數指定到目標頁面

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

wKgZPGggaqeAacjeAAAs0mtrR3o682.jpg

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

@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函數的地址為0x0000FE00,所在頁面為127頁
 
void func2 (uint8_t CNT);void func2 (uint8_t) __attribute__((section(".ARM.__at_0x0000FE50")));//指定func函數的地址為0x0000FE50,所在頁面為127頁
 
uint8_t func3 (uint8_t CNT1,uint8_t* p);
uint8_t func3 (uint8_t, uint8_t*) __attribute__(( section(".ARM.__at_0x0000FEA4" )));
//指定func函數的地址為0x0000FEA4,所在頁面為127頁

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

wKgZO2ggaqiAQoN4AALl8rjUp84557.jpg

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

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

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

2.2.開啟相應頁面的安全運行庫

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

wKgZPGggaqmAP5yGAAECAGD6p0o349.jpgwKgZO2ggaqmAJC5nAABz1keOiRc549.jpg

2.3.參考代碼

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

通過網盤分享的文件: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函數的地址為0x0000FE00,所在頁面為127頁
void func2 (uint8_t ) __attribute__((section(".ARM.__at_0x0000FE50")));//指定func函數的地址為0x0000FE50,所在頁面為127頁
uint8_t func3 (uint8_t ,uint8_t* ) __attribute__((section(".ARM.__at_0x0000FEA4")));//指定func函數的地址為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)
    {
        // 開啟安全區失敗
        while(1);
    }    

 func1();

 func2(10);

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

2.4.函數調用

函數調用時需要在指定的地址上加1,因為對于cortex M核的芯片,任何跳轉相關地址的最低位,即BIT0都應是1。該位表示將用到的的指令集為Thumb指令。具體調用方法如下:

@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();//方法一:宏調用
 ((void (*)())(0x0000FE00UL + 1))();//方法二:直接調用
 void (*ppp1) ();//方法三;函數指針調用
 ppp1 = (void (*) ())(0xFE00 + 1);
 ppp1();

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

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

    while (1)
    {

    }
}

2.5.擦除安全運行庫

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

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

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

wKgZPGggaqqAaPjYAAB01jsbjCA934.jpg

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

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

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

2.6.注意事項

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

(2).儲存在安全運行庫頁面里的函數,不可調用安全區外的函數。

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

三、現象演示

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

wKgZO2ggaquARyW3AAFMKuxTQ_k875.jpg

用戶可以在其它工程中調用儲存在安全運行庫頁面的函數,具體調用方法詳情見2.4函數調用章節。

四、視頻講解

CW32L010黑客區安全運行庫保護的實現 :1.FLASH及安全庫區域原理_嗶哩嗶哩_bilibili

CW32L010黑客區安全運行庫保護的實現 :2.算法編程調用及注意事項_嗶哩嗶哩_bilibili

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

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • RAM
    RAM
    +關注

    關注

    8

    文章

    1398

    瀏覽量

    119890
  • 算法
    +關注

    關注

    23

    文章

    4764

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    CW32L010的2種啟動模式介紹

    CW32L010 支持以下 2 種啟動模式: ●從主 FLASH 存儲器啟動,運行用戶程序。 ●從啟動程序存儲器啟動,運行內部 BootLoader。 當運行 Bootloader
    發表于 11-28 08:09

    CW32L010的串口輸出

    CW32L010是一款集成了豐富功能的低功耗微控制器,其串口輸出功能是通過其內部的通用異步收發器(UART)實現的。 一、串口硬件資源 CW32L010提供了二路低功耗UART,這些UART接口支持
    發表于 11-27 07:27

    CW32L010新品安全低功耗MCU性能如何?有哪些優勢?

    CW32L010新品安全低功耗MCU性能如何?有哪些優勢?
    發表于 11-24 07:31

    CW32L010使能讀保護后標志位不正確怎么解決?

    CW32L010使能讀保護后標志位不正確
    發表于 11-20 07:44

    CW32L010用jlink能去除讀保護嗎?

    如題,板上的CW32L010有讀保護,JLINK能識別到內核,但無法擦除下載程序。 要怎么才能去除讀保護
    發表于 11-20 06:23

    CW32L010高速風筒方案的特點

    1、高性能處理能力:主控采用CW32L010F8P6,基于ARM Cortex-M0+ 32位高速處理器內核,能夠實時處理復雜的控制算法,確保風筒在不同風速和溫度設置下的穩定運行。 2、低功耗
    發表于 11-13 06:21

    請問CW32L010 能否使用SysTick中斷?

    CW32L010 能否使用SysTick中斷?
    發表于 11-12 07:25

    CW32L010系列的特點

    ,用戶能依據采樣時機的不同,靈活調整PWM波形的邊沿位置。 RTC補償精度高達060ppm,實現亞秒級讀數 CW32L010在RTC補償機制上進行了精心優化,提供三種可選的補償周期:32秒、128秒
    發表于 11-12 06:51

    CW32L010安全運行庫保護是什么功能?

    它是針對用戶指定的MCU內部FLASH數據,提供的一種讀保護功能;該功能生效后,就可以禁止對安全運行庫進行任何形式的讀取操作(比如CPU、 SWD、 ISP 均無法正確讀取該區數據), 但不影響調用
    發表于 11-12 06:19

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

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

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

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

    基于CW32L010單片機的掃振一體電動牙刷應用方案

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

    武漢芯源半導體CW32L010在兩輪車儀表的應用介紹

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

    武漢芯源半導體CW32L010在兩輪車儀表的應用介紹

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

    CW32L010 Motor Control Driver無刷電機驅動板上手體驗

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