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

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

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

3天內不再提示

淺析基于STM32的除以0運算話題

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

掃碼添加小助手

加入工程師交流群

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

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

首先,這個問題不屬于STM32外設相關的,而是內核相關的。客戶選用的是Cortex M4的內核STM32芯片,那我們就從M4內核手冊中尋找相關內容。

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

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

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

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

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

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

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

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

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

經過測試,當我們置位上面CCR寄存器的DIV_0_TRP位,在發生除以0操作時就會進入HardFault中斷,同時被除數的結果【Result】即商變為0.

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

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

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

我們依然先驗證CCR寄存器的DIV_0_TRP位被置1的情況。經測試,結果跟ARM MDK環境下的測試結果完全一致。

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

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

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

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

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

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

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

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

【注:上面部分截圖來自于Cortex-M4的各種手冊,有需要可以到arm網站自行搜索下載】

編輯:jq

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

    關注

    463

    文章

    54010

    瀏覽量

    466173
  • ARM
    ARM
    +關注

    關注

    135

    文章

    9553

    瀏覽量

    391933
  • 寄存器
    +關注

    關注

    31

    文章

    5608

    瀏覽量

    130002
  • MDK
    MDK
    +關注

    關注

    4

    文章

    211

    瀏覽量

    33647

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    STM32C0x1 基于 Arm? 內核的 32 位高級 MCU參考手冊

    本參考手冊是對 STM32C0x1 微控制器數據手冊的補充,提供了應用(特別是軟件開發)所需的信息,屬于 STM32C0x1 微控制器上提供的功能集的超集。有關特定 STM32C0x1 器件的功能集、訂購信息以及機械和電氣特性的
    發表于 01-04 11:24 ?0次下載

    CW32L012與STM32G431的CORDIC三角函數運算性能對比

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

    CW32L012與STM32F103的三角運算性能對比

    ? ?CW32L012和STM32F103在定位和性能上差異顯著,在三角函數的運算性能上的對比亦非常直觀。 一、 硬件架構對比(性能基礎) 芯片型號 CW32L012C8 STM32
    的頭像 發表于 12-29 15:32 ?2324次閱讀
    CW32L012與<b class='flag-5'>STM32</b>F103的三角<b class='flag-5'>運算</b>性能對比

    IEEE 802.11af 與空白頻譜無線技術的話題

    IEEE 802.11af 與空白頻譜無線技術的話題
    的頭像 發表于 12-14 15:12 ?1604次閱讀

    國產混合信號處理的重要突破:淺析PSOC 7020的可配置運算架構

    本文簡要介紹了國產PSOC?7020芯片內集成的關鍵運算電路模塊,闡述了其作為可編程片上系統(PSoC)的核心模擬處理能力。文章重點分析了其運算放大器、比較器、模數/數模轉換器等模塊的可配置特性,并說明了其在簡化設計、提升系統集成度方面的優勢,展示了該芯片作為國產高性能嵌
    的頭像 發表于 12-04 17:29 ?778次閱讀
    國產混合信號處理的重要突破:<b class='flag-5'>淺析</b>PSOC 7020的可配置<b class='flag-5'>運算</b>架構

    DES加密運算模塊結構設計

    DES加密運算模塊使用純組合邏輯完成初始IP置換、E擴展置換、P盒置換和初始IP逆置換的設計。加以一個以keysel為選通信號的二選一選通器選擇置換結果,1為初始置換結果,0為中間結果,將輸入分為
    發表于 10-30 07:56

    卷積運算分析

    卷積運算的基礎運算是乘加運算(MAC,Multiplication and Accumulation),本文設計了基本運算單元PE模塊來實現MAC
    發表于 10-28 07:31

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

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

    STM32C0116-DK探索套件開發指南與技術解析

    STMicroelectronics STM32C0116-DK探索套件設計用于演示STM32C0 MCU的特性,采用UFQFPN20封裝。STM32C0116-DK套件包括一個
    的頭像 發表于 10-27 14:57 ?637次閱讀
    <b class='flag-5'>STM32</b>C0116-DK探索套件開發指南與技術解析

    浮點數是如何實現開平方運算

    一些特殊處理。 浮點數開平方運算可以表達為以下公式: 這里的符號位是邏輯零,這意味著平方根塊總是期望正浮點數。平方根運算只在尾數部分進行,這可以通過任意一種平方根算法來實現。指數部分除以2,也就是右移
    發表于 10-24 08:42

    【米爾-STM32MP257開發板試用體驗】——測試米爾-STM32MP257開發板外設功能

    /temp 轉換成實際的溫度 除以1000 就是49121/1000 = 49度 因為STM32MP257是雙核,所以查看雙核溫度的指令為 cat /sys/class/thermal
    發表于 07-07 18:22

    同步電機失步淺析

    純分享帖,需要者可點擊附件免費獲取完整資料~~~*附件:同步電機失步淺析.pdf【免責聲明】本文系網絡轉載,版權歸原作者所有。本文所用視頻、圖片、文字如涉及作品版權問題,請第一時間告知,刪除內容!
    發表于 06-20 17:42

    STM32多通道FFT運算異常的原因?怎么解決?

    問題報告:STM32多通道FFT運算異常 報告人:XXX日期:2025年X月X日硬件平臺:STM32F407VGT6開發環境:STM32CubeMX + KeilCMSIS-DSP庫版
    發表于 06-19 06:27

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

    Cortex-Mx內核內部包含了一個SysTick定時器,SysTick是一個24位的倒計數定時器,當計到0時,將從RELOAD寄存器中自動重裝載定時初值。只要不把它在SysTick控制及狀態寄存器
    發表于 04-01 14:52 ?0次下載

    STM32的H5/U5系列處理器內置運放支持負壓運算嗎?

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