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

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

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

關(guān)于STM32的除以0運算問題

茶話MCU ? 來源:茶話MCU ? 作者:Miler ? 2021-11-19 10:15 ? 次閱讀

有人使用STM32G4系列芯片開發(fā)產(chǎn)品。他發(fā)現(xiàn)程序中如果遇到除以0的操作時,會跑進出錯異常中斷而影響程序運行。他想知道能否通過設(shè)置,即使發(fā)生除以0操作也不讓程序跑進異常中斷,并期望此時的除法運行結(jié)果【也就是商】直接等于當前變量類型所支持的最大值,比如,若被除數(shù)為16位變量,則經(jīng)過該除以零操作后直接為其賦值為0xffff?!緦嶋H應(yīng)用中客戶的需求往往也是五彩斑斕的。^_^】

事實上是否可以如該STM32用戶所愿呢?我們不妨一起看看。

首先,這個問題不屬于STM32外設(shè)相關(guān)的,而是內(nèi)核相關(guān)的??蛻暨x用的是Cortex M4的內(nèi)核STM32芯片,那我們就從M4內(nèi)核手冊中尋找相關(guān)內(nèi)容。

我們通過查看ARM M4的內(nèi)核手冊,可以看到除以0操作會導(dǎo)致用法異常[UsageFault],同時它又說了,該操作和非對齊訪問操作是否觸發(fā)異常是可以配置的。詳見下方綠色方框內(nèi)文字。

那么對該用法異常的監(jiān)測控制是通過哪個寄存器進行配置的呢?經(jīng)瀏覽手冊得知它是通過配置控制寄存器[SCB-》CCR]進行配置的。

根據(jù)上面描述可知,當CCR寄存器的DIV_0_TRP位被配置0時,即使發(fā)生除以0操作也不會觸發(fā)異常,只有當該位被置1前提下,當發(fā)生除以0操作時才觸發(fā)異常事件并產(chǎn)生相應(yīng)中斷。

下面我們具體驗證下。我找了塊M4內(nèi)核的STM32芯片的開發(fā)板。我們先使用ARM MDK來驗證。

測試代碼很簡單,就是下面截圖中的幾行,簡單的閃燈操作,里面夾了一句除法操作。SCB-》CCR被賦值0x00000210即置位了DIV_0_TRP,當被賦值0x00000200時對其進行清零。

經(jīng)過測試,當我們置位上面CCR寄存器的DIV_0_TRP位,在發(fā)生除以0操作時就會進入HardFault中斷,同時被除數(shù)的結(jié)果【Result】即商變?yōu)?.

而當我們對DIV_0_TRP位清零,即SCB-》CCR被賦值0x00000200時發(fā)生除以0操作不會觸發(fā)Hardfault中斷,但被除數(shù)除以0后其結(jié)果依然保持為0。整個程序運行起來感覺不到任何阻滯。

上面是基于ARM MDK環(huán)境測試的,我們換為IAR IDE測試看看。

我們依然先驗證CCR寄存器的DIV_0_TRP位被置1的情況。經(jīng)測試,結(jié)果跟ARM MDK環(huán)境下的測試結(jié)果完全一致。

當我們對CCR寄存器的DIV_0_TRP位清零時,測試結(jié)果也跟ARM MDK環(huán)境下的一致。

顯然,結(jié)合Cortex M4內(nèi)核手冊的描述和實際驗證,當發(fā)生除以0操作時是否觸發(fā)異常事件是可以配置的,至于發(fā)生除以0操作后的商,它始終是0,這個結(jié)果其實在上面截圖有明確提及,這里再單獨截圖出來。

不過,這個結(jié)果跟開篇客戶所期望的不一致,這是由硬件決定的,不同的硬件在這個地方處理不盡相同。其實,其它Cortex M內(nèi)核芯片這個地方約定是一樣的。

聊到這里,或許有人發(fā)現(xiàn)了一個問題。從手冊上看,這個除以0操作觸發(fā)的應(yīng)該是用法異常【UsageFault】,而我們在實際測試時進入的中斷卻是HardFault異常,這兩個異常并不一樣???

這是怎么回事呢?在此拋磚引玉吧,有興趣的話不妨查找相關(guān)資料繼續(xù)尋找相關(guān)答案。

責任編輯: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

    文章

    10849

    瀏覽量

    353826

原文標題:基于STM32的除以0運算話題

文章出處:【微信號:stmcu832,微信公眾號:茶話MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    STM32到基于Arm的MSPM0的遷移指南

    電子發(fā)燒友網(wǎng)站提供《從STM32到基于Arm的MSPM0的遷移指南.pdf》資料免費下載
    發(fā)表于 09-07 11:31 ?0次下載
    從<b class='flag-5'>STM32</b>到基于Arm的MSPM<b class='flag-5'>0</b>的遷移指南

    MATLAB(4)--MATLAB基本運算

    )。 當兩個比較量是標量時,直接比較兩數(shù)的大小。若成立,關(guān)系表達式結(jié)果為1.否則為0。 當參與比較的量是兩個同型的矩陣時,比較是對兩矩陣相同位置的元素按標量關(guān)系運算規(guī)則逐個進行,最終的的結(jié)果是一個
    發(fā)表于 09-06 10:18

    stm32boot0和boot1對應(yīng)哪個p引腳

    STM32系列微控制器是一種廣泛應(yīng)用于嵌入式系統(tǒng)領(lǐng)域的32位微控制器。在STM32系列微控制器中,BOOT0和BOOT1是兩個重要的引腳,它們用于設(shè)置設(shè)備的啟動模式。 首先,讓我們了解STM3
    的頭像 發(fā)表于 08-22 09:40 ?1633次閱讀

    十進位、除以十二和二進制計數(shù)器數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《十進位、除以十二和二進制計數(shù)器數(shù)據(jù)表.pdf》資料免費下載
    發(fā)表于 05-13 11:03 ?0次下載
    十進位、<b class='flag-5'>除以</b>十二和二進制計數(shù)器數(shù)據(jù)表

    STM32G474除以0會進錯誤中斷,為什么?

    我的編譯環(huán)境為STM32CubeIDE,芯片為STM32G474,我發(fā)現(xiàn)程序中如果有除以0的操作時,會跑到錯誤中斷中。請問能不能通過設(shè)置,可以讓程序不要跑進錯誤中斷,直接等于當前變量類
    發(fā)表于 04-01 06:32

    關(guān)于比例運算電路的疑惑

    如下圖下劃線標注所示,我不明白為什么在反相比例運算電路中 ,但是在正相比例運算電路中,認為 ,這豈不是矛盾了嗎?在我看來,兩種運算電路應(yīng)當都同時滿足虛地,虛短,虛斷的,那么到底如何判斷N點的電壓呢(時而為 ,時而為
    發(fā)表于 03-31 16:32

    關(guān)于STM32 DMAMUX模塊具體的應(yīng)用示例代碼

    有人通過公眾號微信留言,詢問是否有關(guān)于STM32 DMAMUX模塊具體的應(yīng)用示例代碼。同時,個人也發(fā)現(xiàn),雖然STM32片內(nèi)的DMAMUX不是什么新模塊,似乎還是很多人并不太熟悉。這里借機聊聊這方面的內(nèi)容,重點演示相關(guān)功能的實現(xiàn),
    的頭像 發(fā)表于 03-25 09:15 ?2145次閱讀
    <b class='flag-5'>關(guān)于</b><b class='flag-5'>STM32</b> DMAMUX模塊具體的應(yīng)用示例代碼

    STSPIN32F0支持硬件浮點運算嗎?

    STSPIN32F0 支不支持硬件浮點運算
    發(fā)表于 03-13 06:32

    當算術(shù)運算期間發(fā)生除以零或下溢/溢出時,ARM926EJ-S內(nèi)核的行為是什么?

    當算術(shù)運算期間發(fā)生除以零或下溢/溢出時,ARM926EJ-S 內(nèi)核的行為是什么。 我知道有些架構(gòu)已經(jīng)定義了行為,或者可以將其配置為觸發(fā)中斷以響應(yīng)其中一個算術(shù)異常。 該處理器是否具有在運行時檢測其中一種情況的功能?
    發(fā)表于 02-22 07:35

    STM32開發(fā)中的位運算以及位帶操作

    操作。同時,STM32還提供了位帶操作,使得對單個位進行操作更加方便。本文將詳細介紹STM32開發(fā)中的位運算和位帶操作。 1. 位運算運算
    的頭像 發(fā)表于 02-02 14:38 ?1384次閱讀

    在TIM模塊 (CMU_CLK0) 中使用Fgtm頻率,GTM時鐘系統(tǒng)為什么總是將Fgtm除以2?

    或者將 CMU_CLK0_CTRL 中的 CNT 設(shè)置為 1,我會得到同樣的行為,看起來 GTM 時鐘系統(tǒng)總是將 Fgtm 除以 2 你能幫我解決這個問題嗎?,這是 Aurix 中的已知錯誤嗎?
    發(fā)表于 01-30 07:48

    stm32f407浮點運算速度

    支持硬件浮點運算單元(FPU),可以提供快速和高效的浮點運算性能。本文將詳細介紹 STM32F407 的浮點運算速度。 浮點運算是很多應(yīng)用中
    的頭像 發(fā)表于 01-04 10:58 ?3121次閱讀

    STM32C0開發(fā)(2)----開發(fā)板介紹

    STM32C011F4P6-TSSOP20評估套件可以使用戶能夠無縫評估TSSOP20封裝中STM32C0S系列微控制器的功能,具備高效的處理能力與穩(wěn)定的性能表現(xiàn),能夠適應(yīng)各種物聯(lián)網(wǎng)場景和應(yīng)用需求。該套件可通過標準的USB Type-c ?至Micro-B電纜將其插入電腦
    的頭像 發(fā)表于 12-01 14:48 ?815次閱讀
    <b class='flag-5'>STM32C0</b>開發(fā)(2)----開發(fā)板介紹

    關(guān)于運算放大器軌到軌輸出的問題

      昨天群友在群里問了一個關(guān)于運算放大器軌到軌輸出的問題,對此我寫一下我對此的理解,以及結(jié)合仿真,梳理給各位同好。
    的頭像 發(fā)表于 11-03 18:10 ?2020次閱讀
    <b class='flag-5'>關(guān)于</b><b class='flag-5'>運算</b>放大器軌到軌輸出的問題

    為什么STM32的Flash地址要設(shè)置到0x08000000?

    為什么STM32的Flash地址要設(shè)置到0x08000000?
    的頭像 發(fā)表于 10-26 15:50 ?1532次閱讀
    為什么<b class='flag-5'>STM32</b>的Flash地址要設(shè)置到<b class='flag-5'>0</b>x08000000?