RM新时代网站-首页

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

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

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

Linux 搶占機制與中斷狀態(tài)機

麥辣雞腿堡 ? 來源:嵌入式Linux系統(tǒng)開發(fā) ? 作者:Jasonangel ? 2023-09-27 17:40 ? 次閱讀

中斷狀態(tài)機

對于 GIC-V2 而言,中斷的狀態(tài)機由 Distributor 維護,每個中斷都有一個狀態(tài)機。

Inactive :中斷未激活(未發(fā)生)。

Pending:中斷到達 GIC ,等待 CPU 的處理。

Active:中斷得到 CPU 的應答,中斷被CPU處理。

Active and pending :某個中斷正在被 CPU 處理,這時候該中斷又來了。

來看一個例子:

圖片

(a)N 和 M 用來標識兩個外設(shè)中斷,N 的優(yōu)先級大于 M

(b)兩個中斷都是 SPI 類型,level trigger,active-high

(c)兩個中斷被配置為去同一個 CPU

(d)都被配置成 group 0,通過 FIQ 觸發(fā)中斷

Linux 搶占機制

GIC中斷控制器支持中斷優(yōu)先級搶占,一個高優(yōu)先級中斷可以搶占一個低優(yōu)先級且處于active狀態(tài)的中斷,即GIC仲裁單元會記錄和比較當前優(yōu)先級最高的pending狀態(tài),然后去搶占當前中斷,并且發(fā)送這個最高優(yōu)先級的中斷請求給CPU。

從GIC角度看,GIC會發(fā)送高優(yōu)先級中斷請求給CPU。但是CPU不一定響應?。?!因為在中斷處理過程中,CPU處于關(guān)中斷狀態(tài)(關(guān)閉本CPU),需要等低優(yōu)先級中斷處理完畢,直到發(fā)送EOI 給GIC,然后CPU才會響應pending狀態(tài)中優(yōu)先級最高的中斷進行處理。所以 Linux 下:

1、高優(yōu)先級中斷無法搶占正在執(zhí)行的低優(yōu)先級中斷。

2、同處于 pending 狀態(tài)的中斷,優(yōu)先響應高優(yōu)先級中斷進行處理。

3、同優(yōu)先級同是 pending 狀態(tài)的中斷,選擇硬件中斷號 ID 最小的一個發(fā)給CPU。

這樣是可以理解的,如果萬一中斷大量爆發(fā),中斷如果允許嵌套的話,棧會越來越大,會爆掉,所以為了防止這種情況發(fā)生,Linux中中斷不允許嵌套,單CPU中,在一個中斷處理完之前,不會相應另外一個中斷,哪怕優(yōu)先級比它高。

FreeRTOS 中是允許高優(yōu)先級中斷搶占正在執(zhí)行的低優(yōu)先級中斷,不同系統(tǒng)設(shè)定不一樣。

中斷與進程

進程調(diào)度是一個復雜的機制, 根據(jù)需求的不同,在不同時刻會切換調(diào)度機制,CPU會根據(jù)進程優(yōu)先級、時間片等信息,對不同進程進行調(diào)度。

中斷可以打斷進程的運行,任意一個中斷的優(yōu)先級都比所有的進程高。

在中斷處理過程中,主要是 GIC 和 CPU 的交互,即便 GIC 支持高優(yōu)先級中斷搶占正在執(zhí)行的低優(yōu)先級中斷,發(fā)信號給 CPU core,但是CPU core 可以不處理,因為 Linux 中當 CPU core 執(zhí)行中斷處理時,是關(guān)中斷和關(guān)搶占的狀態(tài),不再相應中斷信號。

也就意味著,在中斷優(yōu)先級這個概念中,只有當 GIC 同時存在多個 pending的中斷,這時候會選擇優(yōu)先級最高的去執(zhí)行,高優(yōu)先級會搶占低優(yōu)先級中斷(哪怕低優(yōu)先級先來)。如果低優(yōu)先級中斷處于 active
狀態(tài),是不可以被搶占的,這是前后關(guān)系。搶占只存在于同時是pending 狀態(tài)的時候。

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

    關(guān)注

    87

    文章

    11292

    瀏覽量

    209322
  • 狀態(tài)機
    +關(guān)注

    關(guān)注

    2

    文章

    492

    瀏覽量

    27528
  • 進程
    +關(guān)注

    關(guān)注

    0

    文章

    203

    瀏覽量

    13960
收藏 人收藏

    評論

    相關(guān)推薦

    Verilog狀態(tài)機+設(shè)計實例

    在verilog中狀態(tài)機的一種很常用的邏輯結(jié)構(gòu),學習和理解狀態(tài)機的運行規(guī)律能夠幫助我們更好地書寫代碼,同時作為一種思想方法,在別的代碼設(shè)計中也會有所幫助。 一、簡介 在使用過程中我們常說
    的頭像 發(fā)表于 02-12 19:07 ?4039次閱讀
    Verilog<b class='flag-5'>狀態(tài)機</b>+設(shè)計實例

    labview狀態(tài)機制作的提款

    labview狀態(tài)機制作的提款
    發(fā)表于 03-31 22:55

    詳解Linux內(nèi)核搶占實現(xiàn)機制

    本文詳解了Linux內(nèi)核搶占實現(xiàn)機制。首先介紹了內(nèi)核搶占和用戶搶占的概念和區(qū)別,接著分析了不可搶占
    發(fā)表于 08-06 06:16

    采用狀態(tài)機和消息機制的串口接收程序

    采用狀態(tài)機和消息機制的串口接收程序
    發(fā)表于 05-16 14:51 ?48次下載

    狀態(tài)機舉例

    狀態(tài)機舉例 你可以指定狀態(tài)寄存器和狀態(tài)機狀態(tài)。以下是一個有四種狀態(tài)的普通狀態(tài)機。 // Th
    發(fā)表于 03-28 15:18 ?982次閱讀

    狀態(tài)機代碼生成工具

    狀態(tài)機代碼生成工具狀態(tài)機代碼生成工具狀態(tài)機代碼生成工具狀態(tài)機代碼生成工具
    發(fā)表于 11-19 15:12 ?9次下載

    狀態(tài)機原理及用法

    狀態(tài)機原理及用法狀態(tài)機原理及用法狀態(tài)機原理及用法
    發(fā)表于 03-15 15:25 ?0次下載

    基于有限狀態(tài)機Linux多點觸摸屏驅(qū)動設(shè)計劉斌

    基于有限狀態(tài)機Linux多點觸摸屏驅(qū)動設(shè)計_劉斌
    發(fā)表于 03-15 08:00 ?0次下載

    狀態(tài)機概述 如何理解狀態(tài)機

    本篇文章包括狀態(tài)機的基本概述以及通過簡單的實例理解狀態(tài)機
    的頭像 發(fā)表于 01-02 18:03 ?1w次閱讀
    <b class='flag-5'>狀態(tài)機</b>概述  如何理解<b class='flag-5'>狀態(tài)機</b>

    FPGA:狀態(tài)機簡述

    本文目錄 前言 狀態(tài)機簡介 狀態(tài)機分類 Mealy 型狀態(tài)機 Moore 型狀態(tài)機 狀態(tài)機描述 一段式
    的頭像 發(fā)表于 11-05 17:58 ?7368次閱讀
    FPGA:<b class='flag-5'>狀態(tài)機</b>簡述

    什么是狀態(tài)機狀態(tài)機5要素

    玩單片還可以,各個外設(shè)也都會驅(qū)動,但是如果讓你完整的寫一套代碼時,卻無邏輯與框架可言。這說明編程還處于比較低的水平,你需要學會一種好的編程框架或者一種編程思想!比如模塊化編程、狀態(tài)機編程、分層思想
    的頭像 發(fā)表于 07-27 11:23 ?2w次閱讀
    什么是<b class='flag-5'>狀態(tài)機</b>?<b class='flag-5'>狀態(tài)機</b>5要素

    狀態(tài)模式(狀態(tài)機)

    以前寫狀態(tài)機,比較常用的方式是用 if-else 或 switch-case,高級的一點是函數(shù)指針列表。最近,看了一文章《c語言設(shè)計模式–狀態(tài)模式(狀態(tài)機)》(來源:embed linux
    發(fā)表于 12-16 16:53 ?9次下載
    <b class='flag-5'>狀態(tài)</b>模式(<b class='flag-5'>狀態(tài)機</b>)

    51中斷系統(tǒng)與vhdl狀態(tài)機

    51中斷系統(tǒng)與vhdl狀態(tài)機51中斷系統(tǒng)與vhdl狀態(tài)機51單片中斷系統(tǒng)1.為什么要引入
    發(fā)表于 01-14 14:58 ?2次下載
    51<b class='flag-5'>中斷</b>系統(tǒng)與vhdl<b class='flag-5'>狀態(tài)機</b>

    如何構(gòu)建基于狀態(tài)機的軟件系統(tǒng)

    模式(Design Pattern)。本文介紹如何構(gòu)建基于狀態(tài)機的軟件系統(tǒng),以及如何利用Linux下的工具來自動生成實用的狀態(tài)機框架。
    的頭像 發(fā)表于 09-14 10:55 ?1541次閱讀

    什么是狀態(tài)機?狀態(tài)機的種類與實現(xiàn)

    狀態(tài)機,又稱有限狀態(tài)機(Finite State Machine,F(xiàn)SM)或米利狀態(tài)機(Mealy Machine),是一種描述系統(tǒng)狀態(tài)變化的模型。在芯片設(shè)計中,
    的頭像 發(fā)表于 10-19 10:27 ?9437次閱讀
    RM新时代网站-首页