精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

    關注

    450

    文章

    49648

    瀏覽量

    417255
  • ARM
    ARM
    +關注

    關注

    134

    文章

    8967

    瀏覽量

    365073
  • 寄存器
    +關注

    關注

    31

    文章

    5254

    瀏覽量

    119214
  • MDK
    MDK
    +關注

    關注

    4

    文章

    207

    瀏覽量

    31927

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

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

收藏 人收藏

    評論

    相關推薦

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

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

    聊聊TIMER事件觸發中斷的響應話題

    情況是這樣的,現在使用STM32G4系列的TIM8,工作在中心對齊計數,PWM單脈沖模式,使用內部系統時鐘做時鐘源,計數時不做分頻,即PSC=0。CH2做PWM輸出。
    的頭像 發表于 05-06 16:07 ?775次閱讀
    聊聊TIMER事件觸發中斷的響應<b class='flag-5'>話題</b>

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

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

    當算術運算期間發生除以零或下溢/溢出時,ARM926EJ-S內核的行為是什么?

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

    STM32開發中的位運算以及位帶操作

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

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

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

    淺析流行的LLM推理堆棧和設置

    還有一個與批次大小有關的數量,它們在一個有趣的點上相交。這個點不取決于硬件之外的任何因素。舉例來說,在 A10G 和 A100 上,硬件可以實現的總浮點運算次數的兩倍除以內存帶寬為 400。
    發表于 01-29 14:52 ?294次閱讀
    <b class='flag-5'>淺析</b>流行的LLM推理堆棧和設置

    stm32f407浮點運算速度

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

    智能照明控制設計原則淺析

    電子發燒友網站提供《智能照明控制設計原則淺析.doc》資料免費下載
    發表于 11-03 09:40 ?1次下載
    智能照明控制設計原則<b class='flag-5'>淺析</b>

    為什么STM32的Flash地址要設置到0x08000000?

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

    工程師筆記 | STM32G0 復位后死機

    工程師筆記 | STM32G0 復位后死機
    的頭像 發表于 10-17 15:23 ?1314次閱讀
    工程師筆記 | <b class='flag-5'>STM32G0</b> 復位后死機

    STM32G0系列多通道ADC的問題避坑速看!

    STM32G0系列單片機是ST新推出的一個系列,基于Arm Cortex-M0 +內核,在嚴格的功率預算內提供出色的性能。目前來說相比F系列的,價格也比較實惠。
    的頭像 發表于 10-12 10:04 ?3589次閱讀
    <b class='flag-5'>STM32G0</b>系列多通道ADC的問題避坑速看!

    STM32F0系列MCU硬件電路boot設計

    Boot配置的作用是用于選擇芯片上電后從何處讀取可執行代碼運行,STM32F0系列MCU可以從Main flash memory、System memory、Embedded SRAM三個地方boot。
    的頭像 發表于 09-27 14:21 ?2426次閱讀
    <b class='flag-5'>STM32F0</b>系列MCU硬件電路boot設計

    STM32F0系列MCU硬件電路外設設計

    STM32F0系列MCU的I2C和SPI是板子上芯片之間最常用的通信方式,I2C有SDA和SCL兩個信號構成,電路設計非常簡單。
    的頭像 發表于 09-27 11:08 ?1395次閱讀
    <b class='flag-5'>STM32F0</b>系列MCU硬件電路外設設計

    STM32L0xx硬件開發入門

    電子發燒友網站提供《STM32L0xx硬件開發入門.pdf》資料免費下載
    發表于 09-25 11:10 ?1次下載
    <b class='flag-5'>STM32L0</b>xx硬件開發入門