91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

為什么中斷處理函數(shù)不能直接調(diào)用不可重入函數(shù)

strongerHuang ? 來源:strongerHuang ? 作者:C語言與CPP編程 ? 2021-02-17 09:33 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1 前言

最近在公司維護(hù)的項(xiàng)目中碰到一個(gè)解決了定位很久的 bug , bug 找到的時(shí)候發(fā)現(xiàn)犯了很低級(jí)的錯(cuò)誤——在中斷處理函數(shù)中調(diào)用了 printf 函數(shù),因?yàn)橹袛嗵幚砗瘮?shù)的調(diào)用了不可重入函數(shù),導(dǎo)致中斷丟失和系統(tǒng)位置錯(cuò)誤,這里直接導(dǎo)致嵌入式 linux 系統(tǒng)應(yīng)用進(jìn)程中的所有線程停掉,進(jìn)而導(dǎo)致看門狗進(jìn)程得不到喂狗,設(shè)備重啟。

那什么是不可重入函數(shù)呢?

為什么中斷處理函數(shù)不能直接調(diào)用不可重入函數(shù)?

怎樣寫可重入函數(shù)?

就以上三個(gè)問題展開小短文:

2 什么是不可重入函數(shù)?

可重入函數(shù)主要用于多任務(wù)環(huán)境中,一個(gè)可重入的函數(shù)簡(jiǎn)單來說就是可以被中斷的函數(shù),也就是說,可以在這個(gè)函數(shù)執(zhí)行的任何時(shí)刻中斷它,轉(zhuǎn)入 OS 調(diào)度下去執(zhí)行另外一段代碼,而返回控制時(shí)不會(huì)出現(xiàn)什么錯(cuò)誤;而不可重入的函數(shù)由于使用了一些系統(tǒng)資源,比如全局變量區(qū),中斷向量表等,所以它如果被中斷的話,可能會(huì)出現(xiàn)問題,這類函數(shù)是不能運(yùn)行在多任務(wù)環(huán)境下的。

滿足下列條件的函數(shù)多數(shù)是不可重入的:

函數(shù)體內(nèi)使用了靜態(tài)(static)的數(shù)據(jù)結(jié)構(gòu);

函數(shù)體內(nèi)調(diào)用了 malloc() 或者 free() 函數(shù);

函數(shù)體內(nèi)調(diào)用了標(biāo)準(zhǔn) I/O 函數(shù);

A. 可重入函數(shù)

o4YBAF_2ZTuAc1xyAAAeslwkBXY186.jpg

B. 不可重入函數(shù)1

o4YBAF_2ZU2AR4Z7AAAkUu9cugE344.jpg

C. 不可重入函數(shù)2

pIYBAF_2ZV6AJsskAAAo5ZMEv4M490.jpg

3 為什么中斷處理函數(shù)不能直接調(diào)用不可重入函數(shù)?

在多任務(wù)系統(tǒng)下,中斷可能在任務(wù)執(zhí)行的任何時(shí)間發(fā)生;如果一個(gè)函數(shù)的執(zhí)行期間被中斷后,到重新恢復(fù)到斷點(diǎn)進(jìn)行執(zhí)行的過程中,函數(shù)所依賴的環(huán)境沒有發(fā)生改變,那么這個(gè)函數(shù)就是可重入的,否則就不可重入。

在中斷前后不都要保存和恢復(fù)上下文嗎,怎么會(huì)出現(xiàn)函數(shù)所依賴的環(huán)境發(fā)生改變了呢?我們知道中斷時(shí)確實(shí)保存一些上下文,但是僅限于返回地址,cpu 寄存器等之類的少量上下文,而函數(shù)內(nèi)部使用的諸如全局或靜態(tài)變量,buffer 等并不在保護(hù)之列,所以如果這些值在函數(shù)被中斷期間發(fā)生了改變,那么當(dāng)函數(shù)回到斷點(diǎn)繼續(xù)執(zhí)行時(shí),其結(jié)果就不可預(yù)料了。

在中斷處理函數(shù)中調(diào)用有互斥鎖保護(hù)的全局變量,如果恰好該變量正在被另一個(gè)線程調(diào)用,會(huì)導(dǎo)致中斷處理函數(shù)不能及時(shí)返回,導(dǎo)致中斷丟失等嚴(yán)重問題。

并且在多線程環(huán)境中使用,在沒有加鎖的情況下,對(duì)同一段內(nèi)存塊進(jìn)行并發(fā)讀寫,就會(huì)造成 segmentfault/coredump 之類的問題。

總而言之,中斷處理函數(shù)做的事情越簡(jiǎn)單越好。

4 如何寫出可重入的函數(shù)?

在函數(shù)體內(nèi)不訪問那些全局變量;

如果必須訪問全局變量,記住利用互斥信號(hào)量來保護(hù)全局變量。或者調(diào)用該函數(shù)前關(guān)中斷,調(diào)用后再開中斷;

不使用靜態(tài)局部變量;

堅(jiān)持只使用缺省態(tài)(auto)局部變量;

在和硬件發(fā)生交互的時(shí)候,切記關(guān)閉硬件中斷。完成交互記得打開中斷,在有些系列上,這叫做“進(jìn)入/退出核心”或者用 OS_ENTER_KERNAL/OS_EXIT_KERNAL 來描述;

不能調(diào)用任何不可重入的函數(shù);

謹(jǐn)慎使用堆棧。最好先在使用前先 OS_ENTER_KERNAL;

責(zé)任編輯:xj

原文標(biāo)題:中斷函數(shù)調(diào)用不可重入函數(shù)的后果

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

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

    關(guān)注

    183

    文章

    7644

    瀏覽量

    145643
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4417

    瀏覽量

    67543
  • 中斷函數(shù)
    +關(guān)注

    關(guān)注

    0

    文章

    13

    瀏覽量

    5650

原文標(biāo)題:中斷函數(shù)調(diào)用不可重入函數(shù)的后果

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    嵌入式開發(fā)常用函數(shù)速查表

    在嵌入式開發(fā)中,掌握常用函數(shù)的用法可以大大提高開發(fā)效率。無論是單片機(jī)初學(xué)者還是有一定經(jīng)驗(yàn)的工程師,熟悉函數(shù)庫(kù)和調(diào)用方式都是必備技能。今天,我們?yōu)榇蠹艺硪环萸度胧介_發(fā)常用函數(shù)速查表,覆
    的頭像 發(fā)表于 01-19 09:06 ?314次閱讀
    嵌入式開發(fā)常用<b class='flag-5'>函數(shù)</b>速查表

    瑞薩RA系列FSP庫(kù)開發(fā)實(shí)戰(zhàn)指南之DMAC中斷回調(diào)函數(shù)

    調(diào)用R_DMAC_SoftwareStart函數(shù)來發(fā)起軟件觸發(fā)請(qǐng)求信號(hào)來啟動(dòng)DMAC傳輸。
    的頭像 發(fā)表于 12-26 09:25 ?4852次閱讀

    西門子PLC中函數(shù)FC的使用方法

    函數(shù)函數(shù)塊作為模塊化編程的重要組成部分,在PLC 用戶程序中有著相當(dāng)頻繁的應(yīng)用。兩者在生成與使用的過程中都有一定的相似,且都不能單獨(dú)使用。而需要賦予特定的功能,由組織塊(OB)直接
    的頭像 發(fā)表于 12-19 11:26 ?4222次閱讀
    西門子PLC中<b class='flag-5'>函數(shù)</b>FC的使用方法

    中斷函數(shù)問題

    main.c中:// 適配啟動(dòng)文件cstartup.asm:綁定中斷函數(shù)中斷向量 #define CSCC_INTERRUPT_FUNCTION_ADDR INT_FUNCTION void
    發(fā)表于 12-14 21:24

    函數(shù)調(diào)用性能消耗

    函數(shù)調(diào)用對(duì)于處理器的性能消耗是很小的,只占有函數(shù)執(zhí)行工作中性能消耗的一小部分。參數(shù)傳入函數(shù)變量寄存器中有一定的限制。這些參數(shù)必須是整型兼容的
    發(fā)表于 12-12 07:50

    使用setjmp及l(fā)ongjmp函數(shù)處理異常

    ,例如在發(fā)生錯(cuò)誤或異常時(shí),直接跳轉(zhuǎn)到錯(cuò)誤處理或資源釋放的代碼,而不需要逐層返回。setjmp和longjmp函數(shù)定義在setjmp.h頭文件中,其語法為: int setjmp(jmp_buf
    發(fā)表于 12-11 08:00

    回調(diào)函數(shù)例子的應(yīng)用

    步驟,這里的的例子就是,利用一個(gè)狀態(tài)機(jī)函數(shù)(根據(jù)不同狀態(tài)依次調(diào)用不同實(shí)現(xiàn)方法的函數(shù)),通過回調(diào)函數(shù)的方式依次調(diào)用不同的
    發(fā)表于 12-11 07:23

    使用信號(hào)處理函數(shù)

    使用信號(hào)處理函數(shù):這是一種用于處理運(yùn)行時(shí)異常的方法,就是在程序中注冊(cè)一些信號(hào)處理函數(shù),用于響應(yīng)系統(tǒng)或用戶發(fā)送的一些信號(hào)。信號(hào)是一種軟件
    發(fā)表于 12-11 06:40

    如何用函數(shù)指針調(diào)用函數(shù)

    ;please enter a and b:\"); scanf(\"%d%d\",a,b); c = (*p)(a, b);//通過函數(shù)指針調(diào)用Max函數(shù)
    發(fā)表于 12-11 06:26

    控制流和函數(shù)調(diào)用的精細(xì)調(diào)整

    特性,避免不必要的計(jì)算。 函數(shù)調(diào)用涉及開銷,因?yàn)樗枰4娈?dāng)前執(zhí)行環(huán)境并跳轉(zhuǎn)到新的執(zhí)行環(huán)境。減少函數(shù)調(diào)用,尤其是在頻繁執(zhí)行的循環(huán)中,可以顯著提高性能。 對(duì)于簡(jiǎn)單且頻繁
    發(fā)表于 11-14 06:32

    詳解hal_entry入口函數(shù)

    當(dāng)使用RTOS時(shí),程序從main函數(shù)開始進(jìn)行線程調(diào)度;當(dāng)沒有使用RTOS時(shí),C語言程序的入口函數(shù)main函數(shù)調(diào)用了hal_entry函數(shù)。由
    的頭像 發(fā)表于 07-25 15:34 ?2004次閱讀

    C語言中的內(nèi)聯(lián)函數(shù)與宏

    在C編程中,內(nèi)聯(lián)函數(shù)和宏都用于避免函數(shù)調(diào)用的開銷并編寫可復(fù)用的邏輯部分,但它們?cè)诠ぷ鞣绞胶桶踩苑矫娲嬖陲@著差異。
    的頭像 發(fā)表于 07-25 15:10 ?1922次閱讀
    C語言中的內(nèi)聯(lián)<b class='flag-5'>函數(shù)</b>與宏

    為什么中斷回調(diào)函數(shù)不能使用接收中斷開啟函數(shù)?

    我看(書是基于stm32f407編寫)書上說在串口接收中斷回調(diào)函數(shù)里面不能使用 接收中斷開啟函數(shù),書上是利用自己創(chuàng)建了空閑
    發(fā)表于 05-28 07:19

    為什么中斷回調(diào)函數(shù)不能使用接收中斷開啟函數(shù)?

    我看(書是基于stm32f407編寫)書上說在串口接收中斷回調(diào)函數(shù)里面不能使用 接收中斷開啟函數(shù),書上是利用自己創(chuàng)建了空閑
    發(fā)表于 04-22 08:19

    函數(shù)指針的六個(gè)常見應(yīng)用場(chǎng)景

    函數(shù)指針在嵌入式開發(fā)中有著廣泛的應(yīng)用,它讓代碼更加靈活,減少冗余,提高可擴(kuò)展性。很多時(shí)候,我們需要根據(jù)不同的情況動(dòng)態(tài)調(diào)用不同的函數(shù),而函數(shù)指針正是實(shí)現(xiàn)這一需求的重要工具。本文將介紹六個(gè)
    的頭像 發(fā)表于 04-07 11:58 ?1485次閱讀
    <b class='flag-5'>函數(shù)</b>指針的六個(gè)常見應(yīng)用場(chǎng)景