在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

淺析基于STM32的除以0運(yùn)算話題

茶話MCU ? 來(lái)源:茶話MCU ? 作者:Miler ? 2021-11-26 11:42 ? 次閱讀

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

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

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

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

68412096-4ddc-11ec-9eda-dac502259ad0.png

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

68a05afc-4ddc-11ec-9eda-dac502259ad0.png

690568ac-4ddc-11ec-9eda-dac502259ad0.png

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

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

測(cè)試代碼很簡(jiǎn)單,就是下面截圖中的幾行,簡(jiǎn)單的閃燈操作,里面夾了一句除法操作。SCB-》CCR被賦值0x00000210即置位了DIV_0_TRP,當(dāng)被賦值0x00000200時(shí)對(duì)其進(jìn)行清零。

6976770e-4ddc-11ec-9eda-dac502259ad0.png

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

69e1d44a-4ddc-11ec-9eda-dac502259ad0.png

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

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

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

6a73de8a-4ddc-11ec-9eda-dac502259ad0.png

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

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

6adaa07a-4ddc-11ec-9eda-dac502259ad0.png

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

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

6b412dcc-4ddc-11ec-9eda-dac502259ad0.png

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

【注:上面部分截圖來(lái)自于Cortex-M4的各種手冊(cè),有需要可以到arm網(wǎng)站自行搜索下載】

編輯:jq

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

    關(guān)注

    459

    文章

    51988

    瀏覽量

    434231
  • ARM
    ARM
    +關(guān)注

    關(guān)注

    134

    文章

    9279

    瀏覽量

    373966
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5403

    瀏覽量

    122937
  • MDK
    MDK
    +關(guān)注

    關(guān)注

    4

    文章

    210

    瀏覽量

    32448

原文標(biāo)題:基于STM32的除以0運(yùn)算話題

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

收藏 人收藏

    評(píng)論

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

    0STM32中的SysTick是個(gè)啥?咋用?(可下載)

    Cortex-Mx內(nèi)核內(nèi)部包含了一個(gè)SysTick定時(shí)器,SysTick是一個(gè)24位的倒計(jì)數(shù)定時(shí)器,當(dāng)計(jì)到0時(shí),將從RELOAD寄存器中自動(dòng)重裝載定時(shí)初值。只要不把它在SysTick控制及狀態(tài)寄存器
    發(fā)表于 04-01 14:52 ?0次下載

    STM32的H5/U5系列處理器內(nèi)置運(yùn)放支持負(fù)壓運(yùn)算嗎?

    STM32的H5/U5系列處理器內(nèi)置運(yùn)放支持負(fù)壓運(yùn)算嗎?比如輸入-1V,放大倍數(shù)為2時(shí)輸出-2V
    發(fā)表于 03-11 07:53

    stm32G474RE cordic外設(shè)的1~101的ln運(yùn)算怎么配置?

    有哪位大神用過(guò)stm32G474RE cordic外設(shè),咨詢一下1~101的ln運(yùn)算怎么配置?
    發(fā)表于 03-07 08:29

    基本積分運(yùn)算電路和微分運(yùn)算電路公式推導(dǎo)(可下載)

    ,可以實(shí)現(xiàn)這兩種運(yùn)算電路。在上圖積分的運(yùn)算電路中,由于集成運(yùn)放的同相輸入端通過(guò) R5 接地, Up=Un=0,Un 為虛地。當(dāng)輸入信號(hào)為階躍信號(hào)時(shí),若 t0 時(shí)刻電
    發(fā)表于 02-28 14:26 ?2次下載

    技術(shù)科普 | 芯片設(shè)計(jì)中的LEF文件淺析

    技術(shù)科普 | 芯片設(shè)計(jì)中的LEF文件淺析
    的頭像 發(fā)表于 11-13 01:03 ?619次閱讀
    技術(shù)科普 | 芯片設(shè)計(jì)中的LEF文件<b class='flag-5'>淺析</b>

    STM32WB0系列無(wú)線微控制器滿足低功耗藍(lán)牙應(yīng)用需求

    藍(lán)牙技術(shù)作為應(yīng)用最為廣泛的2.4GHz短距離通信技術(shù),對(duì)無(wú)線微控制器芯片的集成度、功耗、性能、安全性等有較高要求。STM32WB0系列,是兼具高性價(jià)比和低功耗的無(wú)線微控制器,可充分滿足無(wú)線藍(lán)牙應(yīng)用對(duì)芯片的要求。
    的頭像 發(fā)表于 10-12 11:03 ?887次閱讀
    <b class='flag-5'>STM32WB0</b>系列無(wú)線微控制器滿足低功耗藍(lán)牙應(yīng)用需求

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

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

    MATLAB(4)--MATLAB基本運(yùn)算

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

    如何提高單片機(jī)的運(yùn)算效率之FPU

    只要STM32或者其他32位單片機(jī),自帶FPU功能,就可以加速float類型數(shù)據(jù)的加減乘除運(yùn)算。在STM32中要啟用FPU,需要啟動(dòng)滿足兩個(gè)宏:(__FPU_PRESENT==1)&&
    的頭像 發(fā)表于 08-30 11:47 ?1052次閱讀
    如何提高單片機(jī)的<b class='flag-5'>運(yùn)算</b>效率之FPU

    stm32boot0和boot1對(duì)應(yīng)哪個(gè)p引腳

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

    開路電壓除以短路電流是等效電阻嗎

    開路電壓除以短路電流是等效電阻的計(jì)算方法之一,但并不是唯一的方法。在電路分析中,等效電阻是一個(gè)重要的概念,它可以幫助我們更好地理解和分析電路的行為。 開路電壓和短路電流的概念 開路電壓是指在電路中
    的頭像 發(fā)表于 08-07 14:28 ?2238次閱讀

    LMH6554負(fù)載電流可以直接按照輸出電壓除以負(fù)載來(lái)計(jì)算嗎?

    手冊(cè)里有幾個(gè)電流數(shù)據(jù)要請(qǐng)教一下 上圖的Iout和Isc有啥區(qū)別,Iout=+/-150mA是在Vout=0V下定義的輸出電流,是否也可以認(rèn)為是短路電流。 還有個(gè)問(wèn)題是上圖的Is,為什么在負(fù)載
    發(fā)表于 08-07 07:32

    STM32CubeIDE環(huán)境下使用DSP加速運(yùn)算,但不能下載DSP庫(kù),為什么?

    STM32CubeIDE 環(huán)境下使用DSP 加速運(yùn)算,但不能下載DSP庫(kù)!(芯片為STM32G474RBT6) copy all used libraries into the project folder :復(fù)制所有庫(kù)文件 ;
    發(fā)表于 07-05 07:35

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

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

    STM32F4或者STM32L4自帶的DSP庫(kù)做FFT運(yùn)算是不是只能做基2的點(diǎn)數(shù)?

    請(qǐng)教,用STM32F4或者STM32L4自帶的DSP庫(kù)做FFT運(yùn)算是不是只能做基2的點(diǎn)數(shù),如果采樣200點(diǎn),還能用dsp庫(kù)來(lái)進(jìn)行FFT嘛,或者自己找個(gè)任意點(diǎn)數(shù)的FFT算法計(jì)算。
    發(fā)表于 05-11 08:32
    主站蜘蛛池模板: 天堂资源在线www中文 | 美女黄色一级片 | 天天伊人网| 亚洲一区二区中文字5566 | 日日干日日爽 | 成人国产精品高清在线观看 | 手机看片神马午夜 | 婷婷激情五月 | 国产视频三级 | 荡女妇边被c边呻吟久久 | 五月婷婷开心综合 | 精品久久久久久 | 一级毛片免费在线观看网站 | 欧美人与禽 | 天天操夜夜操夜夜操 | 七月丁香八月婷婷综合激情 | 欧美人成网站免费大全 | 激情综合五月网 | 四虎永久免费网站入口2020 | 午夜亚洲 | 日韩三级 | 天堂在线bt| 一级特级片 | 国产秦先生大战白丝97在线 | 天天影视网天天影网 | 色偷偷尼玛图亚洲综合 | 免费爱做网站在线看 | 男生脱美女内裤内衣动态图 | 天堂精品视频 | 在线精品视频成人网 | 日本色www | 美女18黄| 92香蕉视频 | 欧美性色xo影院在线观看 | 婷婷精品视频 | 特黄一级毛片 | 黄色三级在线观看 | 四虎精品影院4hutv四虎 | 日本精品视频 | 日本电影在线观看黄 | 手机看片福利盒子 |