日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

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

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

茶話(huà)MCU ? 來(lái)源:茶話(huà)MCU ? 作者:Miler ? 2021-11-26 11:42 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

有人使用STM32G4系列芯片開(kāi)發(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)前變量類(lèi)型所支持的最大值,比如,若被除數(shù)為16位變量,則經(jīng)過(guò)該除以零操作后直接為其賦值為0xffff。【實(shí)際應(yīng)用中客戶(hù)的需求往往也是五彩斑斕的。^_^】

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

首先,這個(gè)問(wèn)題不屬于STM32外設(shè)相關(guān)的,而是內(nèi)核相關(guān)的??蛻?hù)選用的是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ì)齊訪(fǎng)問(wèn)操作是否觸發(fā)異常是可以配置的。詳見(jiàn)下方綠色方框內(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芯片的開(kāi)發(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)感覺(jué)不到任何阻滯。

上面是基于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é)果跟開(kāi)篇客戶(hù)所期望的不一致,這是由硬件決定的,不同的硬件在這個(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

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

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

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀(guā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)注

    463

    文章

    54465

    瀏覽量

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

    關(guān)注

    135

    文章

    9594

    瀏覽量

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

    關(guān)注

    31

    文章

    5620

    瀏覽量

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

    關(guān)注

    4

    文章

    211

    瀏覽量

    33737

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

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    淺析激光焊膏在電子互連領(lǐng)域中的應(yīng)用

    激光焊膏作為一種先進(jìn)的焊接材料,在電子互連領(lǐng)域中展現(xiàn)出了顯著的應(yīng)用優(yōu)勢(shì)和廣闊的發(fā)展前景。以下從激光焊膏的原理、優(yōu)勢(shì)、應(yīng)用領(lǐng)域及發(fā)展趨勢(shì)等方面,對(duì)其在電子互連領(lǐng)域中的應(yīng)用進(jìn)行淺析。
    的頭像 發(fā)表于 04-29 09:15 ?107次閱讀

    STM32G0 系列 CSS 功能及應(yīng)用問(wèn)題

    1. 前言STM32 G0 系列 MCU 自帶時(shí)鐘丟失功能,即 CSS 功能,能自動(dòng)檢測(cè) HSE 和 LSE 是否丟失。本文對(duì) CSS 功能進(jìn)行簡(jiǎn)單介紹,并對(duì)客戶(hù)在應(yīng)用 LSECSS 功能的過(guò)程中
    發(fā)表于 04-15 16:16 ?0次下載

    STM32L072xx 超低功耗32位MCU,基于ArmR的Cortex-M0+規(guī)格書(shū)

    電子發(fā)燒友網(wǎng)站提供《STM32L072xx 超低功耗32位MCU,基于ArmR的Cortex-M0+規(guī)格書(shū).pdf》資料免費(fèi)下載
    發(fā)表于 03-20 15:58 ?0次下載

    LAT1599_STM32G0 系列 CSS 功能及應(yīng)用問(wèn)題

    STM32 G0 系列 MCU 自帶時(shí)鐘丟失功能,即 CSS 功能,能自動(dòng)檢測(cè) HSE 和 LSE 是否丟失。本文對(duì) CSS 功能進(jìn)行簡(jiǎn)單介紹,并對(duì)客戶(hù)在應(yīng)用 LSECSS 功能的過(guò)程中發(fā)現(xiàn)的問(wèn)題進(jìn)
    發(fā)表于 03-11 10:49 ?0次下載

    STM32C0x1 基于 Arm? 內(nèi)核的 32 位高級(jí) MCU參考手冊(cè)

    本參考手冊(cè)是對(duì) STM32C0x1 微控制器數(shù)據(jù)手冊(cè)的補(bǔ)充,提供了應(yīng)用(特別是軟件開(kāi)發(fā))所需的信息,屬于 STM32C0x1 微控制器上提供的功能集的超集。有關(guān)特定 STM32C0x1 器件的功能集、訂購(gòu)信息以及機(jī)械和電氣特性的
    發(fā)表于 01-04 11:24 ?0次下載

    CW32L012與STM32G431的CORDIC三角函數(shù)運(yùn)算性能對(duì)比

    本文對(duì)比均為作者實(shí)測(cè),結(jié)果僅供參考,可附代碼供有意者評(píng)估~ STM32G431是STM32家族中較新的產(chǎn)品。CW32L012也是武漢芯源半導(dǎo)體最新推出的混合信號(hào)MCU,讓我們深入分析基于各自芯片
    的頭像 發(fā)表于 12-29 15:55 ?2834次閱讀
    CW32L012與<b class='flag-5'>STM32</b>G431的CORDIC三角函數(shù)<b class='flag-5'>運(yùn)算</b>性能對(duì)比

    CW32L012與STM32F103的三角運(yùn)算性能對(duì)比

    ? ?CW32L012和STM32F103在定位和性能上差異顯著,在三角函數(shù)的運(yùn)算性能上的對(duì)比亦非常直觀(guān)。 一、 硬件架構(gòu)對(duì)比(性能基礎(chǔ)) 芯片型號(hào) CW32L012C8 STM32
    的頭像 發(fā)表于 12-29 15:32 ?2549次閱讀
    CW32L012與<b class='flag-5'>STM32</b>F103的三角<b class='flag-5'>運(yùn)算</b>性能對(duì)比

    IEEE 802.11af 與空白頻譜無(wú)線(xiàn)技術(shù)的話(huà)題

    IEEE 802.11af 與空白頻譜無(wú)線(xiàn)技術(shù)的話(huà)題
    的頭像 發(fā)表于 12-14 15:12 ?1990次閱讀

    國(guó)產(chǎn)混合信號(hào)處理的重要突破:淺析PSOC 7020的可配置運(yùn)算架構(gòu)

    本文簡(jiǎn)要介紹了國(guó)產(chǎn)PSOC?7020芯片內(nèi)集成的關(guān)鍵運(yùn)算電路模塊,闡述了其作為可編程片上系統(tǒng)(PSoC)的核心模擬處理能力。文章重點(diǎn)分析了其運(yùn)算放大器、比較器、模數(shù)/數(shù)模轉(zhuǎn)換器等模塊的可配置特性,并說(shuō)明了其在簡(jiǎn)化設(shè)計(jì)、提升系統(tǒng)集成度方面的優(yōu)勢(shì),展示了該芯片作為國(guó)產(chǎn)高性能嵌
    的頭像 發(fā)表于 12-04 17:29 ?1126次閱讀
    國(guó)產(chǎn)混合信號(hào)處理的重要突破:<b class='flag-5'>淺析</b>PSOC 7020的可配置<b class='flag-5'>運(yùn)算</b>架構(gòu)

    卷積運(yùn)算分析

    卷積運(yùn)算的基礎(chǔ)運(yùn)算是乘加運(yùn)算(MAC,Multiplication and Accumulation),本文設(shè)計(jì)了基本運(yùn)算單元PE模塊來(lái)實(shí)現(xiàn)MAC運(yùn)
    發(fā)表于 10-28 07:31

    STM32C031x4/x6:面向主流應(yīng)用的Arm? Cortex?-M0+ 微控制器

    STMicroelectronics的STM32C0x Arm^? ^Cortex ^?^ -M0+ 32位MCU安裝了高性能Arm Cortex-M0+ 32位RISC內(nèi)核,工作頻率高達(dá)48MHz
    的頭像 發(fā)表于 10-27 15:05 ?1098次閱讀
    <b class='flag-5'>STM32</b>C031x4/x6:面向主流應(yīng)用的Arm? Cortex?-M<b class='flag-5'>0</b>+ 微控制器

    浮點(diǎn)數(shù)是如何實(shí)現(xiàn)開(kāi)平方運(yùn)算

    一些特殊處理。 浮點(diǎn)數(shù)開(kāi)平方運(yùn)算可以表達(dá)為以下公式: 這里的符號(hào)位是邏輯零,這意味著平方根塊總是期望正浮點(diǎn)數(shù)。平方根運(yùn)算只在尾數(shù)部分進(jìn)行,這可以通過(guò)任意一種平方根算法來(lái)實(shí)現(xiàn)。指數(shù)部分除以2,也就是右移
    發(fā)表于 10-24 08:42

    【米爾-STM32MP257開(kāi)發(fā)板試用體驗(yàn)】——測(cè)試米爾-STM32MP257開(kāi)發(fā)板外設(shè)功能

    /temp 轉(zhuǎn)換成實(shí)際的溫度 除以1000 就是49121/1000 = 49度 因?yàn)?b class='flag-5'>STM32MP257是雙核,所以查看雙核溫度的指令為 cat /sys/class/thermal
    發(fā)表于 07-07 18:22

    同步電機(jī)失步淺析

    純分享帖,需要者可點(diǎn)擊附件免費(fèi)獲取完整資料~~~*附件:同步電機(jī)失步淺析.pdf【免責(zé)聲明】本文系網(wǎng)絡(luò)轉(zhuǎn)載,版權(quán)歸原作者所有。本文所用視頻、圖片、文字如涉及作品版權(quán)問(wèn)題,請(qǐng)第一時(shí)間告知,刪除內(nèi)容!
    發(fā)表于 06-20 17:42

    STM32多通道FFT運(yùn)算異常的原因?怎么解決?

    問(wèn)題報(bào)告:STM32多通道FFT運(yùn)算異常 報(bào)告人:XXX日期:2025年X月X日硬件平臺(tái):STM32F407VGT6開(kāi)發(fā)環(huán)境:STM32CubeMX + KeilCMSIS-DSP庫(kù)版
    發(fā)表于 06-19 06:27
    巨鹿县| 邹城市| 遂川县| 叶城县| 眉山市| 漠河县| 贵州省| 新巴尔虎左旗| 金秀| 朝阳市| 斗六市| 肥城市| 富顺县| 南充市| 晋城| 门源| 山阳县| 迭部县| 绥中县| 福清市| 丹东市| 鲜城| 乌拉特前旗| 洛浦县| 措美县| 班戈县| 金寨县| 龙岩市| 桃园县| 鹤岗市| 保康县| 武夷山市| 湟源县| 偏关县| 高邮市| 炎陵县| 巴中市| 孝感市| 蛟河市| 时尚| 璧山县|