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

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

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

STM32中使用快速編程時有哪些需要注意的地方?

Q4MP_gh_c472c21 ? 來源:STM32 ? 作者:STM32 ? 2021-02-02 10:26 ? 次閱讀

在一些新的 STM32 系列中,比如 STM32L4、STM32G0、STM32G4 等,除了 Flash 標(biāo)準(zhǔn)編程之外,還可以支持 Flash 的快速編程。那么對于 STM32G0 來說,在使用快速編程時,有哪些需要注意之處?

難點

某STM32用戶在其產(chǎn)品設(shè)計中,采用了 STM32G070RBT6,開發(fā)工程師希望在進行代碼升級的時候使用快速編程來提高編程速度,但是寫代碼時遇到很多問題。而在目前的 STM32G0 的 Cube 庫中并沒有 FLASH_FastProgram 例程,所以客戶希望得到一個參考例程來快速實現(xiàn)設(shè)計。

調(diào)研

1

了解問題

檢查最新版本的STM32Cube_FW_G0_V1.3.0/Projects/STM32CubeProjectsList.html 文件,確實可以看到現(xiàn)有的 STM32G0Cube 庫中并沒有 FLASH_FastProgram 例程,根據(jù)參考手冊,參考STM32Cube_FW_L4_V1.16.0ProjectsNUCLEO-L452REExamplesFLASHFLASH_FastProgram 例程,對 STM32Cube_FW_G0_V1.2.0ProjectsNUCLEO-G070RBExamplesFLASHFLASH_EraseProgram 進行修改以移植代碼。以下就撰寫例程代碼時,需要注意的問題簡單地介紹一下。

2

分析問題

首先,先來看一下 STM32L4 中 FLASH_FastProgram 例程中 readme.txt 對本示例的解釋,可以看到這是一個演示如何配置和使用 API 函數(shù)對內(nèi)部 Flash 存儲器進行擦除和快速編程的示例。

先來看一下 FastProgram 最核心的函數(shù) FLASH_Program_Fast()。

在 STM32L4Cube 中的 stm32l4xx_hal_flash,它是這么定義的:

static void FLASH_Program_Fast(uint32_t Address, uint32_t DataAddress)

而在 STM32G0Cube 中的 stm32g0xx_hal_flash,其定義是:

static __RAM_FUNC void FLASH_Program_Fast(uint32_t Address, uint32_t DataAddress)

這兩者有什么區(qū)別呢?就是在 STM32G0Cube 庫中使用了__RAM_FUNC 指明了這個函數(shù)是位于 RAM 區(qū)域的。為什么呢?

第一個要點:對 Flash 進行快速編程的時候不允許對 Flash 進行讀取,所以需要將這個快速編程的代碼放置于 RAM 中運行,以避免對 Flash 進行命令讀取。

那么,大家可能又有疑問了,那為什么 STM32L4Cube 中并沒有使用__RAM_FUNC 關(guān)鍵字,STM32L452 的 Flash 是 single bank,難道它就不需要放到RAM 里?如果大家細(xì)心的話,可以看到STM32L4這個例程中的鏈接文件是 stm32l452xx_sram.icf,在icf 文件中定義了ROM的地址為 0x20000000~0x20015FFF,也就是說這個示例代碼是跑在 RAM的,所以就不需要在這邊使用__RAM_FUNC 關(guān)鍵字了。還可以在 STM32L4 示例代碼中看到對整片 Flash 進行擦除而猜到這一點。從 STM32G0Cube 庫中 FLASH_Program_Fast() 這個函數(shù)的定義,可以看出它是可以直接使用 stm32l452xx_flash.icf 將快速編程核心代碼以外的其他代碼都放在 Flash 上面跑的,這個可能更符合用戶做 IAP 升級的習(xí)慣,當(dāng)然,在這個情況下,我們就可能需要在程序中使用頁擦除而不是整片擦除了。

第二個要點:因為 Flash 進行快速編程的時候不允許對 Flash 進行讀取,所以還需要注意快速編程的源數(shù)據(jù)應(yīng)該位于 RAM 而非 Flash,以避免對 Flash 進行數(shù)據(jù)讀取。

因為在 Flash 快速編程的時候,需要將 64 個 word 一個行 (256 Bytes) 的數(shù)據(jù)寫到目標(biāo)地址中,所以也就是說快速編程時,還會去訪問源數(shù)據(jù),如果源數(shù)據(jù)放在Flash就會導(dǎo)致問題產(chǎn)生。下面,我們解答一個移植中常見問題。

在從 STM32L4 到 STM32G0 的移植中,直接將 STM32L4 示例代碼中定義的源數(shù)據(jù)的數(shù)組代碼:

/* Table used for fast programming */ static const uint64_t Data64_To_Prog[FLASH_ROW_SIZE] = {0x0000000000000000, 0x1111111111111111, 0x2222222222222222, 0x3333333333333333, 0x4444444444444444, 0x5555555555555555, 0x6666666666666666, 0x7777777777777777, 0x8888888888888888,0x9999999999999999, 0xAAAAAAAAAAAAAAAA,0xBBBBBBBBBBBBBBBB,0xCCCCCCCCCCCCCCCC,0xDDDDDDDDDDDDDDDD, 0xEEEEEEEEEEEEEEEE, 0xFFFFFFFFFFFFFFFF, 0x0011001100110011, 0x2233223322332233, 0x4455445544554455, 0x6677667766776677, 0x8899889988998899,0xAABBAABBAABBAABB, 0xCCDDCCDDCCDDCCDD,0xEEFFEEFFEEFFEEFF, 0x2200220022002200, 0x3311331133113311, 0x6644664466446644, 0x7755775577557755, 0xAA88AA88AA88AA88,0xBB99BB99BB99BB99, 0xEECCEECCEECCEECC, 0xFFDDFFDDFFDDFFDD};

原封不動地拷貝到 STM32G0 的項目中,在測試的時候,總是會發(fā)現(xiàn)程序會死在快速編程的過程中。最后檢查才發(fā)現(xiàn)問題出現(xiàn)在這個數(shù)組的定義上。STM32L4 使用 stm32l452xx_sram.icf 定義了 ROM 的地址為 0x20000000~0x20015FFF,因此這個 const 關(guān)鍵字的數(shù)據(jù)實際上也是位于 RAM 中的。但是將這個數(shù)組搬到 STM32G0 的項目時,因為使用的是stm32l452xx_flash.icf,導(dǎo)致這個數(shù)組位于 Flash 中,在快速編程的時候程序就會去訪問 Flash 讀取源數(shù)據(jù),就導(dǎo)致程序死在快速編程過程。所以,需要將數(shù)組修改為:

/* Table used for fast programming */ uint64_t Data64_To_Prog[FLASH_ROW_SIZE] = { 0x0000000000000000, 0x1111111111111111, 0x2222222222222222, 0x3333333333333333, 0x4444444444444444, 0x5555555555555555, 0x6666666666666666, 0x7777777777777777, 0x8888888888888888,0x9999999999999999, 0xAAAAAAAAAAAAAAAA,0xBBBBBBBBBBBBBBBB, 0xCCCCCCCCCCCCCCCC,0xDDDDDDDDDDDDDDDD, 0xEEEEEEEEEEEEEEEE,0xFFFFFFFFFFFFFFFF,0x0011001100110011,0x2233223322332233, 0x4455445544554455, 0x6677667766776677, 0x8899889988998899,0xAABBAABBAABBAABB, 0xCCDDCCDDCCDDCCDD,0xEEFFEEFFEEFFEEFF, 0x2200220022002200, 0x3311331133113311, 0x6644664466446644, 0x7755775577557755, 0xAA88AA88AA88AA88,0xBB99BB99BB99BB99, 0xEECCEECCEECCEECC, 0xFFDDFFDDFFDDFFDD};

這樣程序就可以正常運行。

第三個要點:使用在 Flash 上跑 IAP 代碼進行快速編程的話,建議看一下參考手冊里快速編程的步驟,在步驟中的第一步時使用 Page Erase 對當(dāng)前頁進行擦除后對當(dāng)前頁進行快速編程,每次一頁,也就是“擦除當(dāng)前頁→快速編程當(dāng)前頁→擦除下一頁→快速編程下一頁→……”。

下面來仔細(xì)閱讀參考手冊,關(guān)注一下另外幾個要點。

第四要點:關(guān)于時鐘,在快速編程的過程中,CPU 的時鐘頻率(HCLK)不得低于 8MHz。這個在大家的應(yīng)用中一般都是滿足的,所以還好。另外,在“注”里邊說明,F(xiàn)STPG 位置 1 時,內(nèi)部振蕩器 HSI16 會自動使能,在 FSTPG 位清零時自動禁止,但 HSI16 之前已經(jīng)通過 HSION 使能的情況除外。

第五要點:這一行 32 個雙字必須連續(xù)寫入,兩個雙字寫入請求的最大時間間隔大約為 20us。如果后面的寫入請求時間超出了這個范圍,那么將導(dǎo)致 MISSERR 錯誤產(chǎn)生。一般來說,只要您使用的是庫文件的函數(shù),不用擔(dān)心這個問題。

第六要點:在兩次擦除之間,每一行的寫入,高壓持續(xù)時間不能大于8ms。一般來說,只要HCLK 的時鐘保證在8MHz以上,對32個雙字的連續(xù)寫序列,時間上還是沒問題的。如果真的程序沒寫好,導(dǎo)致存在這種情況,那么在芯片內(nèi)部有個7ms 的檢測機制,超時就會自動停止編程,并置位 FASTERR。

第七要點:關(guān)中斷。至于為什么?大家都知道,就不多說了。如果大家使用 Cube 庫,也可以看到在 FLASH_Program_Fast() 在進行關(guān)中斷,但是示例中并沒有恢復(fù)打開中斷,所以大家在實際應(yīng)用中根據(jù)情況看是否需要將中斷打開。

3

問題解決

上面幾個要點,如果軟件工程師使用的是 STM32Cube 庫,那么在撰寫代碼上最主要是檢查一下前面三個要點的情況。后面幾個要點稍微了解就可以了。

結(jié)論

Flash的快速編程可以節(jié)省編程的時間,但是在使用上因為有不少限制因素,使得它的軟件設(shè)計比標(biāo)準(zhǔn)編程復(fù)雜,需要工程師細(xì)心調(diào)試。

建議

軟件工程師在撰寫Flash快速編程時,仔細(xì)閱讀下參考手冊,并參考本文中的各個要點,然后根據(jù)自己的實際應(yīng)用情況,理清邏輯,來撰寫完整的 Flash 編程代碼。

原文標(biāo)題:被STM32G0快速編程難倒的,看這里

文章出處:【微信公眾號:嵌入式ARM】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

責(zé)任編輯:haq

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

    關(guān)注

    2263

    文章

    10847

    瀏覽量

    353783
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3544

    瀏覽量

    93474

原文標(biāo)題:被STM32G0快速編程難倒的,看這里

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    TLV320aic33進行ADC的使用時,為什么沒有輸出?ADC使用時有什么要注意地方嗎?

    您好!在使用貴司TLV320aic33 進行ADC的使用時,LINE1LP接輸入信號,LINE1LM接地,根據(jù)用戶指南上進行ADC的配置,測量PGA輸出正常,BCLK,WCLK正常,但ADC始終無輸出,請問ADC使用時有什么要注意
    發(fā)表于 10-22 08:10

    THS4001在設(shè)計電路上有什么特別需要注意地方嗎?

    為了放大DDS出來的信號(f=1MHz,Vpp=1V),前段時間買了THS4001這個芯片??墒前凑帐謨?b class='flag-5'>中簡單地搭了一個閉環(huán)增益為6的同相比例放大器,卻發(fā)現(xiàn)輸出的波形Vpp連1V都不到。請教這款運放在設(shè)計電路上有什么特別需要注意地方
    發(fā)表于 08-27 06:49

    使用THS3091有什么要注意地方嗎?

    THS3091好像燒了。引腳3和4或6和7是通的,不知道怎么回事。用的正負(fù)15V的電源。沒有放大,沒有輸入的輸入時,輸出就有一個直流,大概7到8V。測引腳,引腳6、7是通的,芯片還特燙。THS3091使用有什么要注意地方嗎?
    發(fā)表于 08-16 06:26

    請問下LM239N替代LM339N, 在應(yīng)用時有什么需要注意的嗎?

    你好,請問下LM239N 替代LM339N, 在應(yīng)用時有什么需要注意的嗎?周邊器件是否需要做些調(diào)整?謝謝!
    發(fā)表于 08-07 07:31

    在用運算放大器做比較器使用時有什么需要注意哪些參數(shù)呢?

    在用運算放大器做比較器使用時有什么需要注意哪些參數(shù)呢?我測試和仿真了LM358做滯回比較器,設(shè)計電路如下圖,當(dāng)反相輸入端比較信號是50Hz時是可以的,當(dāng)反相輸入端比較信號是20k時輸出跟不上了,感覺應(yīng)該是壓擺率的問題,所以想問一下在用運算放大器設(shè)計做為比較器
    發(fā)表于 08-06 08:01

    應(yīng)用PLC需要注意哪些問題

    PLC(可編程邏輯控制器)作為現(xiàn)代工業(yè)控制的核心設(shè)備,其應(yīng)用的廣泛性和重要性不言而喻。然而,在應(yīng)用PLC的過程,也需要注意一系列問題,以確保PLC系統(tǒng)的穩(wěn)定運行和高效控制。本文將結(jié)合實際應(yīng)用經(jīng)驗,詳細(xì)探討應(yīng)用PLC時
    的頭像 發(fā)表于 06-17 11:29 ?411次閱讀

    pcb電路板元件布局需要注意什么

    pcb電路板元件布局需要注意什么
    的頭像 發(fā)表于 03-14 15:24 ?699次閱讀

    使用電容降壓時都需要注意哪些?

    的事項,以確保電路的安全運行和降壓效果的可靠性。下面將詳細(xì)介紹電容降壓時需要注意的各個方面。 第一,電容的選擇。在電容降壓電路,電容的選擇是非常重要的。首先需要確定所需降壓電壓范圍和輸出電流負(fù)載的大小,根據(jù)這
    的頭像 發(fā)表于 02-02 15:27 ?469次閱讀

    電源濾波器在接線時有哪些需要注意的事項?

    電源濾波器在接線時有哪些需要注意的事項?|維愛普電源濾波器
    的頭像 發(fā)表于 01-31 09:35 ?543次閱讀

    柔性電流探頭原理和測量需要注意的問題

    柔性電流探頭原理和測量需要注意的問題 柔性電流探頭是一種用于測量電流的傳感器,它采用了柔性材料,使其能夠適應(yīng)不同形狀和尺寸的導(dǎo)線,從而實現(xiàn)了非侵入式測量。在本文中,我們將詳細(xì)介紹柔性電流探頭
    的頭像 發(fā)表于 01-05 15:08 ?752次閱讀

    面粉加工項目使用PLC要注意哪些事項呢?

    在面粉加工項目中使用PLC(可編程邏輯控制器)時,有幾個方面需要注意
    的頭像 發(fā)表于 01-05 09:27 ?625次閱讀

    電感選型需要注意哪些參數(shù)

    電子發(fā)燒友網(wǎng)站提供《電感選型需要注意哪些參數(shù).docx》資料免費下載
    發(fā)表于 12-28 09:25 ?0次下載

    設(shè)計軟板pcb需要注意哪些事項

    設(shè)計軟板pcb需要注意哪些事項
    的頭像 發(fā)表于 12-19 10:06 ?591次閱讀

    在ATE測試需要注意哪些事項呢?

    在ATE測試,需要注意哪些事項呢? ATE(Automated Test Equipment,自動化測試設(shè)備)測試在現(xiàn)代電子制造業(yè)扮演著重要的角色。它能夠快速、高效地對電子器件、模
    的頭像 發(fā)表于 11-09 15:30 ?693次閱讀

    對微小信號進行放大的時候有什么要注意地方?

    對微小信號進行放大的時候有什么要注意地方?在器件選擇和布局布線上有什么要考慮的? 微小信號放大是一種常見的電子設(shè)計技術(shù),在各種應(yīng)用中廣泛使用。這種技術(shù)通常用于檢測和放大傳感器、檢測儀器、接收無線電
    的頭像 發(fā)表于 11-09 10:02 ?623次閱讀