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

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

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

3天內不再提示

AS32X601驅動系列教程 PLIC_中斷應用詳解

安芯 ? 來源:jf_29981791 ? 作者:jf_29981791 ? 2025-05-23 17:10 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

平臺中斷控制器(Platform Level Interrupt Controller,PLIC)是國科安芯AS32系列MCU芯片的中斷控制器,主要對中斷源進行采樣,優(yōu)先級仲裁和分發(fā)。各外設中斷統(tǒng)一連到PLIC,PLIC統(tǒng)一管理并輸出中斷請求到內核。

硬件設計

本節(jié)硬件同USART章節(jié)一致。

軟件設計

代碼分析

在之前的按鍵章節(jié)我們已經對AS32的中斷進行了簡單實用,本節(jié)將用串口的接收中斷實驗進一步加深一下使用過程。

回顧之前的啟動文件章節(jié),有如下一段代碼:
圖片 1.png

RISCV指令集中,在機器模式下中斷相關的寄存器有MSTATUS、MIE和MTVEC,其中前兩個寄存器控制系統(tǒng)中斷使能,具體內容顆翻看啟動文件講解,MTVEC用于保存中斷入口地址,當中斷發(fā)生時,程序指針會自動跳轉到TrapEntry地址處開始執(zhí)行,該段代碼位于as32x601_trapentry.S文件中,用匯編文件編寫,在這個函數下,我們會將RISCV內核所有相關寄存器,包括PC指針等全部進行保存,然后調用中斷入口處理函數,完成后恢復現場寄存器值,從而實現中斷功能。

中斷處理函數位于as32x601_plic.c文件中,我們找到如下函數:

  1. / *
    • Function: PLIC_TrapHandler
    • Description: Interrupt handler type selection.
    • Param: Mcause: determine the type of exception or interrupt based on the value of the mcause register.
    • Return: None
  2. */
  3. void PLIC_TrapHandler(uint32_t Mcause)
  4. {
  5. */* Initializes the external interrupt structure */*
    
  6. 
    

PLIC_EXTITypeDef ExtInt = {{0}, 0};

11. 
12. ```
if((Mcause & 0x80000000) != 0)
  1. 
    

{

14. ```
switch (Mcause & 0x0fff)
  1. 
    

{

16. ```
case 3: */* Machine software interrupt */*
  1. 
    

MSoftWare_IRQ_Handler();

18. ```
break;
  1. 
    

case 7: / Machine timer interrupt /

20. ```
MTimer_IRQ_Handler();
  1. 
    

break;

22. ```
case 11: */* Machine external interrupt */*
  1. 
    

PLIC_SwitchMEXTI(&ExtInt);

24. ```
break;
  1. 
    

default:

26. ```
break;
  1. 
    

}

28. ```
}
  1. 
    

else

30. ```
{
  1. 
    

switch (Mcause & 0xfff)

32. ```
{
  1. 
    

case 0: / Instruction address misaligned /

34. ```
InstAddrMisalign_Handler();
  1. 
    

break;

36. ```
case 1: */* Instruction access fault */*
  1. 
    

InstAccessFault_Handler();

38. ```
break;
  1. 
    

case 2: / Illegal instruction /

40. ```
IllegalInst_Handler();
  1. 
    

break;

42. ```
case 3: */* Breakpoint */*
  1. 
    

Breakpoint_Handler();

44. ```
break;
  1. 
    

case 4: / Load address misaligned /

46. ```
LoadAddrMisalign_Handler();
  1. 
    

break;

48. ```
case 5: */* Load access fault */*
  1. 
    

LoadAccessFault_Handler();

50. ```
break;
  1. 
    

case 6: / Store/AMO address misaligned /

52. ```
StoreAMOAddrMisalign_Handler();
  1. 
    

break;

54. ```
case 7: */* Store/AMO access fault */*
  1. 
    

StoreAMOAccessFault_Handler();

56. ```
break;
  1. 
    

case 11: / Environment call from M-mode /

58. ```
ECall_Handler();
  1. 
    

break;

60. ```
case 12: */* Instruction page fault */*
  1. 
    

InstPageFault_Handler();

62. ```
break;
  1. 
    

case 13: / Load page fault /

64. ```
LoadPageFault_Handler();
  1. 
    

break;

66. ```
case 15: */* Store/AMO page fault */*
  1. 
    

StoreAMOPageFalut_Handler();

68. ```
break;
  1. 
    

default:

70. ```
break;
  1. 
    

}

72. ```
}
  1. }

在這個函數中,系統(tǒng)中斷首先會讀取MCAUSE寄存器的最高位,如果最高位為0,代表此事件為異常,RISCV定義了此類型,具體可直接查看MCAUSE寄存器定義;如果最高位為1,證明此事件為系統(tǒng)中斷,此時可根據低位去選擇處理的中斷類型。

AS32除了系統(tǒng)定時中斷和軟件中斷外,plic定義了64個plic中斷,之前的的異常和中斷均為向量類型,但進入plic中斷后即為非向量模式,但可以軟件支持嵌套,64個中斷類型均已經在此文件中定義,所有定義均為弱函數,因此可以復制中斷處理函數名寫在自定義位置。接下來以串口中斷為例介紹用法:

復制之前的usart工程,在print.c中修改初始化代碼如下:

  1. / *
    • Function: User_Print_Init
    • Description: Configure Print USART.
    • Param: BaudRate: USART communication baud rate.
    • Return: None.
  2. */
  3. void User_Print_Init(uint32_t BaudRate)
  4. {
  5. USART_InitTypeDef USART_InitStructure;
    
  6. 
    

GPIO_InitTypeDef GPIO_InitStructure;

11. ```
PLIC_InitTypeDef PLIC_InitStructure;
  1. 
    

GPIOD_CLK_ENABLE();

14. ```
USART0_CLK_ENABLE();
  1. 
    

/ Set GPIO multiplex mapping /

17. ```
GPIO_PinAFConfig(GPIOD, GPIO_PinSource8, GPIO_AF_USART0);       */* USART0_TX */*
  1. 
    

GPIO_PinAFConfig(GPIOD, GPIO_PinSource9, GPIO_AF_USART0); / USART0_RX /

19. ```
*/* GPIO Configure */*
  1. 
    

GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;

21. ```
GPIO_InitStructure.GPIO_Mode      = GPIO_Mode_OUT;
  1. 
    

GPIO_InitStructure.GPIO_OType = GPIO_Out_PP;

23. ```
GPIO_InitStructure.GPIO_OStrength = GPIO_OStrength_4_5mA;
  1. 
    

GPIO_Init(GPIOD, &GPIO_InitStructure);

25. ```
GPIO_InitStructure.GPIO_Pin       = GPIO_Pin_9;
  1. 
    

GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN;

27. ```
GPIO_InitStructure.GPIO_IType     = GPIO_IN_FLOATING;
  1. 
    

GPIO_InitStructure.GPIO_OStrength = GPIO_OStrength_4_5mA;

29. ```
GPIO_Init(GPIOD, &GPIO_InitStructure);
  1. 
    

USART_DeInit(USART0);

32. 
33. ```
USART_StructInit(&USART_InitStructure);
  1. 
    

/ Initializes the USART0 /

36. ```
USART_InitStructure.USART_BaudRate     = BaudRate;
  1. 
    

USART_InitStructure.USART_WordLength = USART_WordLength_8b;

38. ```
USART_InitStructure.USART_StopBits     = USART_StopBits_1;
  1. 
    

USART_InitStructure.USART_Parity = USART_Parity_No;

40. ```
USART_InitStructure.USART_Mode         = USART_Mode_Rx | USART_Mode_Tx;
  1. 
    

USART_InitStructure.USART_OverSampling = USART_OverSampling_16;

42. ```
USART_Init(USART0, &USART_InitStructure);
  1. 
    

USART_Cmd(USART0, ENABLE);

45. 
46. ```
USART_ITConfig(USART0, USART_IT_RXNE, ENABLE);
  1. 
    

/ Configer the USART0 interrupt /

49. ```
PLIC_InitStructure.PLIC_IRQChannel = USART0_IRQn;
  1. 
    

PLIC_InitStructure.PLIC_IRQPriority = 1;

51. ```
PLIC_InitStructure.PLIC_IRQChannelCmd = ENABLE;
  1. 
    

PLIC_Init(&PLIC_InitStructure);

53. }
54. 
55. */* *
56. * Function: USART0_IRQ_Handler
57. * Description: USART0 interrupt handler function.
58. * Param: None.
59. * Return: None.
60. */
61. 
62. void USART0_IRQ_Handler()
63. {
64. 
65. ```
if(USART_GetFlagStatus(USART0, USART_FLAG_RXNE) != RESET)
  1. 
    

{

67. ```
*/* Clear the interrupt pending bits */*
  1. 
    

USART_SendData(USART0,USART_ReceiveData(USART0));

69. ```
}
  1. }

在這個代碼中,44行之前和串口章節(jié)完全一樣,不再重復進行說明。第46行,調用串口的中斷使能函數,使能串口接收中斷,該處形參中的中斷類型已經定義好,可以自行查詢,之后需要開啟PLIC的中斷通道以及優(yōu)先級配置,之后調用PLIC_Init函數進行初始化。

接下來,需要重寫中斷處理函數,該函數名已經在PLIC庫文件中定義完成,直接復制過來即可,在這個函數中首先判斷終端的來源,之后通過調用發(fā)送函數原路徑發(fā)出,當然這只是一個實驗,功能比較簡單,實際使用過程中切忌這種用法。

最后主函數中對上述代碼只需要做初始化即可,沒有實際邏輯,因此在這不做展示。

下板驗證

將上述代碼編譯燒錄完成,連接串口線與上位機,觀察現象。
圖片 2.png

審核編輯 黃宇

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

    關注

    12

    文章

    1994

    瀏覽量

    88735
  • 中斷控制器
    +關注

    關注

    0

    文章

    64

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    探索DRV601立體聲線路驅動器:特性、應用與設計要點

    探索DRV601立體聲線路驅動器:特性、應用與設計要點 在電子設備的音頻處理領域,線路驅動器起著至關重要的作用。德州儀器(TI)推出的DRV601立體聲線路
    的頭像 發(fā)表于 02-02 15:45 ?342次閱讀

    UCC2753x系列單通道高速柵極驅動器:特性、應用與設計要點詳解

    UCC2753x系列單通道高速柵極驅動器:特性、應用與設計要點詳解 引言 在電子電路設計中,柵極驅動器扮演著至關重要的角色,它能夠有效
    的頭像 發(fā)表于 01-09 16:05 ?946次閱讀

    AS32X601的I2C模塊操作EEPROM詳解

    國科安芯推出的AS32X601系列MCU芯片內置的I2C模塊提供了符合工業(yè)標準的兩線串行制接口,可用于MCU和外部I2C設備的通訊。I2C總線使用兩條串行線:串行數據線SDA和串行時鐘線SCL
    的頭像 發(fā)表于 12-21 21:39 ?1668次閱讀
    <b class='flag-5'>AS32X601</b>的I2C模塊操作EEPROM<b class='flag-5'>詳解</b>

    串口中斷觸發(fā)卡死怎么解決?

    ;IIR; break;} } /* 到這兒 IIR bit0 為 1(無掛起中斷) */ return 0;}/* UART0 PLIC 中斷服務函數 */void
    發(fā)表于 11-11 06:17

    e203添加中斷源,中斷源無法使能怎么解決?

    大家好: 硬件平臺為arty a7,我們給E203添加了一個以太網外設,按照順序把中斷源設置為53號,可是發(fā)現外設的確產生了中斷信號(邊沿),可是plic模塊的plic_ext_ir
    發(fā)表于 11-10 07:45

    淺析riscv中的plic與eclic

    1.PLIC中斷處理 在RISC V體系架構中,對中斷有著一些定義,下面來分析一下這種定義的實現策略。 在riscv中一共定義了三種狀態(tài)中斷,對于hart層面,hart包含local
    發(fā)表于 10-31 07:23

    蜂鳥E203內核中斷管理模塊sirv_plic_man代碼分析

    這段代碼是一個 System-level Interrupt Request (PLIC) 控制器的 Verilog HDL 模塊,它用于管理來自多個源的中斷請求并將它們分派給處理器的中斷請求線
    發(fā)表于 10-23 06:05

    瑞薩RA系列MCU的外部引腳中斷詳解

    上一章節(jié)我們已經詳細介紹了NVIC、ICU、ELC、NMI并對RA系列MCU的中斷管理系統(tǒng)有個全局的了解,我們這一章節(jié)的內容是如何控制外部中斷,也是內核里的NVIC的實例應用,這也是RA系列
    的頭像 發(fā)表于 09-23 09:38 ?2181次閱讀
    瑞薩RA<b class='flag-5'>系列</b>MCU的外部引腳<b class='flag-5'>中斷</b><b class='flag-5'>詳解</b>

    基于 AS32X601 微控制器的定時器模塊(TIM)技術研究與應用實踐

    摘要: 本文全面介紹了國科安芯推出的AS32X601系列微控制器的定時器模塊(TIM),包括其系統(tǒng)架構、功能特性、應用場景以及工程實踐要點。通過對芯片的詳細分析,揭示了其高性能運行的基礎。本文詳細
    的頭像 發(fā)表于 08-19 16:44 ?1033次閱讀

    AS32X601芯片Flash擦寫調試技術解析

    本文聚焦于 國科安芯推出的AS32X601 芯片的 Flash 擦寫調試工作,深入剖析其片內 Flash 存儲器架構,詳述 Flash 控制器功能與運作機制。通過對 Flash 指令集的解讀,梳理
    的頭像 發(fā)表于 07-22 13:47 ?939次閱讀
    <b class='flag-5'>AS32X601</b>芯片Flash擦寫調試技術解析

    AS32X601系列MCU硬件最小系統(tǒng)設計與調試方案探析

    推出的AS32X601 系列 MCU 為例,深入探討硬件最小系統(tǒng)設計要點以及硬件調試方案,旨在為相關領域的研究人員和技術人員提供有價值的參考。
    的頭像 發(fā)表于 07-22 13:46 ?857次閱讀

    AS32X601驅動系列教程 USART_串口通訊詳解

    國科安芯的AS32系列MCU芯片集成7路USART,能夠靈活地與外部設備進行全雙工數據交換,滿足外部設備對工業(yè)標準 NRZ 異步串行數據格式的要求。USART 通過小數波特率發(fā)生器實現了多種波特率
    的頭像 發(fā)表于 05-23 16:54 ?1054次閱讀
    <b class='flag-5'>AS32X601</b><b class='flag-5'>驅動</b><b class='flag-5'>系列</b>教程 USART_串口通訊<b class='flag-5'>詳解</b>

    AS32X601驅動系列教程 GPIO_按鍵檢測詳解

    在嵌入式系統(tǒng)開發(fā)中,GPIO(通用輸入輸出端口)是實現硬件與軟件交互的關鍵組件。本節(jié)主要利用的時GPIO的輸入采集功能,本節(jié)的主要功能為,讀取板載按鍵,當按鍵按下時,對應led亮起,抬起按鍵,對應led熄滅。 硬件設計 評估板板載三個機械按鍵,分別接入MCU的PE10、PB4、PB3,當按鍵按下時,控制引腳通過按鍵接地,表現為低電平,當按鍵抬起時,io通過電阻連接到VCC,此時表現為高電平。 軟件設計 代碼分析 本節(jié)主要驗證GPIO的輸入功能,所不同的是
    的頭像 發(fā)表于 05-23 16:44 ?992次閱讀
    <b class='flag-5'>AS32X601</b><b class='flag-5'>驅動</b><b class='flag-5'>系列</b>教程 GPIO_按鍵檢測<b class='flag-5'>詳解</b>

    AS32X601驅動系列教程 GPIO_點亮LED詳解

    的大門。自本章開始,正式開始用代碼控制AS32x601各外設完成功能配置。 需要注意的是,AS32X601提供了8組GPIO,其中GPIOA~GPIOG寄存器操作完全一致,但在使用GPIOH的時候,寄存器列表中間少了一個32位寄存器,因此在使用過程中容易造成誤操作,我們在
    的頭像 發(fā)表于 05-23 16:14 ?933次閱讀
    <b class='flag-5'>AS32X601</b><b class='flag-5'>驅動</b><b class='flag-5'>系列</b>教程 GPIO_點亮LED<b class='flag-5'>詳解</b>

    AS32X601驅動系列教程 SMU_系統(tǒng)時鐘詳解

    時鐘和復位的管理。在默認狀態(tài)下SMU工作在IDLE狀態(tài)。只有接收到PMU的使能信號后才開始工作。SMU模塊會根據PMU的指令自動配置COR、AXIBUS0/1/2等總線的時鐘和復位。 需要注意的是,MCU芯片AS32X601可通過BOOT選擇從外部QSPI Flash啟動和內部PFlash啟動,
    的頭像 發(fā)表于 05-23 16:01 ?908次閱讀
    <b class='flag-5'>AS32X601</b><b class='flag-5'>驅動</b><b class='flag-5'>系列</b>教程 SMU_系統(tǒng)時鐘<b class='flag-5'>詳解</b>
    专栏| 江门市| 荃湾区| 上林县| 宁阳县| 余江县| 唐海县| 襄垣县| 嫩江县| 金华市| 安丘市| 上高县| 太仆寺旗| 东丰县| 出国| 新巴尔虎右旗| 雷波县| 时尚| 盐津县| 遂川县| 阳谷县| 宁晋县| 沙河市| 东光县| 浦东新区| 交城县| 绥宁县| 临西县| 孝昌县| 滦平县| 安溪县| 缙云县| 浑源县| 南投市| 巴塘县| 沁阳市| 高要市| 盘山县| 攀枝花市| 北安市| 章丘市|