在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

AS32X601驅(qū)動系列教程 PLIC_中斷應(yīng)用詳解

安芯 ? 來源:jf_29981791 ? 作者:jf_29981791 ? 2025-05-23 17:10 ? 次閱讀

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

硬件設(shè)計

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

軟件設(shè)計

代碼分析

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

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

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

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

  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. }

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

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

復(fù)制之前的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é)完全一樣,不再重復(fù)進(jìn)行說明。第46行,調(diào)用串口的中斷使能函數(shù),使能串口接收中斷,該處形參中的中斷類型已經(jīng)定義好,可以自行查詢,之后需要開啟PLIC的中斷通道以及優(yōu)先級配置,之后調(diào)用PLIC_Init函數(shù)進(jìn)行初始化。

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

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

下板驗證

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

審核編輯 黃宇

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

    關(guān)注

    12

    文章

    1890

    瀏覽量

    86472
  • 中斷控制器
    +關(guān)注

    關(guān)注

    0

    文章

    61

    瀏覽量

    9628
收藏 人收藏

    評論

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

    AS32X601驅(qū)動系列教程 USART_串口通訊詳解

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

    AS32X601驅(qū)動系列教程 GPIO_按鍵檢測詳解

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

    AS32X601驅(qū)動系列教程 GPIO_點亮LED詳解

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

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

    時鐘和復(fù)位的管理。在默認(rèn)狀態(tài)下SMU工作在IDLE狀態(tài)。只有接收到PMU的使能信號后才開始工作。SMU模塊會根據(jù)PMU的指令自動配置COR、AXIBUS0/1/2等總線的時鐘和復(fù)位。 需要注意的是,MCU芯片AS32X601可通過BOOT選擇從外部QSPI Flash啟動和內(nèi)部PFlash啟動,
    的頭像 發(fā)表于 05-23 16:01 ?70次閱讀
    <b class='flag-5'>AS32X601</b><b class='flag-5'>驅(qū)動</b><b class='flag-5'>系列</b>教程 SMU_系統(tǒng)時鐘<b class='flag-5'>詳解</b>

    面向工業(yè)與汽車領(lǐng)域的高安全可靠MCU——AS32X601系列芯片解析

    AS32X601系列是國科安芯研發(fā)的32位RISC-V架構(gòu)MCU,專為高安全性、高可靠性場景設(shè)計,覆蓋工業(yè)控制、汽車電子等關(guān)鍵領(lǐng)域。其核心優(yōu)勢在于通過硬件級安全機(jī)制、多重冗余設(shè)計及功能安全認(rèn)證,滿足
    的頭像 發(fā)表于 03-14 16:40 ?328次閱讀

    AS32X601芯片技術(shù)剖析

    芯片簡介 AS32X601系列MCU是國產(chǎn)高可靠嵌入式處理器的重要突破,其企業(yè)宇航級型號AS32S601針對空間輻射環(huán)境與極端溫度條件優(yōu)化,滿足衛(wèi)星載荷控制、航天器運動控制等場景需求。該芯片采用
    的頭像 發(fā)表于 03-14 16:17 ?342次閱讀

    AS32X601雙核鎖步MCU技術(shù)優(yōu)勢分析

    AS32X601是國科安芯公司研制的一系列基于32位RISC-V指令集車規(guī)級MCU處理器芯片。主頻高達(dá)180MHz,支持雙核鎖步架構(gòu),基于軟錯誤防護(hù)技術(shù)加持,顯著提高芯片安全性能。產(chǎn)品具有高安全、低
    的頭像 發(fā)表于 03-07 16:12 ?328次閱讀

    單片機(jī)中斷技術(shù)詳解

    在現(xiàn)代電子設(shè)備中,單片機(jī)作為控制核心發(fā)揮著舉足輕重的作用。而在其高效運作的背后,中斷機(jī)制是推動單片機(jī)實現(xiàn)實時響應(yīng)與高效執(zhí)行的關(guān)鍵因素。本文將深入探討單片機(jī)中的中斷概念、中斷系統(tǒng)的結(jié)構(gòu)、中斷
    的頭像 發(fā)表于 02-02 15:57 ?730次閱讀

    請問關(guān)于DSP2802x,2803x或者2806x的AD轉(zhuǎn)換模塊中斷的問題

    請問關(guān)于DSP2802x,2803x或者2806x的AD轉(zhuǎn)換模塊中斷的問題 DSP2802x,2803
    發(fā)表于 01-20 07:44

    EE-188:使用C語言在ADSP-219x DSP上實現(xiàn)中斷驅(qū)動系統(tǒng)

    電子發(fā)燒友網(wǎng)站提供《EE-188:使用C語言在ADSP-219x DSP上實現(xiàn)中斷驅(qū)動系統(tǒng).pdf》資料免費下載
    發(fā)表于 01-15 16:06 ?0次下載
    EE-188:使用C語言在ADSP-219<b class='flag-5'>x</b> DSP上實現(xiàn)<b class='flag-5'>中斷</b><b class='flag-5'>驅(qū)動</b>系統(tǒng)

    TMS320x280x、2801x、2804x DSP系統(tǒng)控制和中斷參考指南

    電子發(fā)燒友網(wǎng)站提供《TMS320x280x、2801x、2804x DSP系統(tǒng)控制和中斷參考指南.pdf》資料免費下載
    發(fā)表于 12-17 16:02 ?0次下載
    TMS320<b class='flag-5'>x280x</b>、2801<b class='flag-5'>x</b>、2804<b class='flag-5'>x</b> DSP系統(tǒng)控制和<b class='flag-5'>中斷</b>參考指南

    納芯微推出智能隔離柵極驅(qū)動器NSI67X0系列

    納芯微正式推出具有隔離模擬采樣功能的智能隔離驅(qū)動 NSI67X0 系列,該系列適用于驅(qū)動 SiC、IGBT 和 MOSFET 等功率器件,兼
    的頭像 發(fā)表于 12-09 14:02 ?741次閱讀
    納芯微推出智能隔離柵極<b class='flag-5'>驅(qū)動</b>器NSI67<b class='flag-5'>X</b>0<b class='flag-5'>系列</b>

    常見液晶驅(qū)動控制芯片詳解

    常見液晶驅(qū)動控制芯片詳解 前言 因此各位朋友在選擇 LCD液晶模塊的時候,在考慮到串行,還是并行的方式時,可根據(jù)其驅(qū)動控制 IC的型號來判別,當(dāng)然你還需要看你選擇的LCD模塊引腳定義是固定支持并行
    的頭像 發(fā)表于 10-12 16:35 ?3760次閱讀

    rk1126實現(xiàn)BT601輸入,輸入不帶IIC接口的驅(qū)動程序

    大家好!我先使用RV1126對接CIF接口,現(xiàn)在我的輸入是BT601格式的,但是我這個輸入接口沒有IIC的所以在驅(qū)動層不知道怎么弄,我看其他驅(qū)動程序的都是有IIC接口的,不知道哪位可否發(fā)一下沒有IIC
    發(fā)表于 08-10 12:03

    SN75LVCP601雙通道6Gbps SATA驅(qū)動器數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《SN75LVCP601雙通道6Gbps SATA驅(qū)動器數(shù)據(jù)表.pdf》資料免費下載
    發(fā)表于 07-02 09:26 ?0次下載
    SN75LVCP<b class='flag-5'>601</b>雙通道6Gbps SATA<b class='flag-5'>驅(qū)動</b>器數(shù)據(jù)表
    主站蜘蛛池模板: 在线观看精品国产入口 | 国产高清在线免费 | 日本69式xxx视频 | 人人草人人插 | xxxx日本在线播放免费不卡 | 国产一级特黄在线播放 | 亚洲涩综合 | 色婷婷激婷婷深爱五月老司机 | 色婷婷色婷婷 | 喷潮白浆直流在线播放 | 在线免费成人网 | 最新人妖shemaletube人妖 最新日本免费一区二区三区中文 | 六月丁香激情 | 操操操操网 | 久久夜色精品 | 欧美成人免费高清网站 | 啪啪免费看 | 欧美日韩国产一区二区三区不卡 | 国产精品天天影视久久综合网 | 国模私拍在线视频 | 人人人人草 | 国产h在线播放 | 日本aaaaa特黄毛片 | 伊人久久综合成人亚洲 | 色综合久久天天综合观看 | 色一欲一性一乱一区二区三区 | 亚洲午夜一级毛片 | 中文字幕在线视频第一页 | 5566在线观看| 三级毛片在线免费观看 | 国产精品黄网站免费进入 | 性欧美视频在线观看 | 久久五月天婷婷 | 黄色大片视频网站 | 热99精品| 国产性色视频 | 欧美日本色 | 欧美性幼 | 老司机精品视频免费 | 国产精品久久久香蕉 | 日本午夜大片 |