溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

SylixOS Zynq平臺私有中斷綁定

發(fā)布時(shí)間:2020-06-09 14:06:34 來源:網(wǎng)絡(luò) 閱讀:1275 作者:翼輝小健健 欄目:系統(tǒng)運(yùn)維

1. 概述

    本篇主要介紹在Zynq平臺編寫中斷相關(guān)的驅(qū)動程序時(shí),涉及CPU私有中斷的相關(guān)綁定辦法。

2. 私有中斷簡介

    私有中斷是多核CPU上特有的中斷,私有中斷只能被其所有者核心獲取和響應(yīng),不會被其他核發(fā)現(xiàn)。常見的私有中斷有全局定時(shí)器,私有看門狗定時(shí)器,私有定時(shí)器等,Zynq平臺上還有來自PL的FIQ\IRQ。

3. 私有中斷的綁定方法

3.1      常規(guī)共享中斷綁定

    Zynq平臺使用的是GIC通用中斷框架,常規(guī)的共享中斷綁定和普通的中斷綁定沒有區(qū)別,在SylixOS上直接調(diào)用API_InterVectorConnect、API_InterVectorEnable這兩個(gè)函數(shù)即可綁定,綁定后中斷可由任意一個(gè)CPU核心響應(yīng)。

3.2      私有中斷綁定

    私有中斷只能有所有者核心獲取和響應(yīng),因此對應(yīng)的中斷和中斷服務(wù)是綁定在相關(guān)的CPU核心上。在SylixOS下綁定私有中斷需要讓常規(guī)共享中斷的綁定流程在對應(yīng)CPU核心上完成才能成功綁定。即在驅(qū)動綁定私有中斷的時(shí)候創(chuàng)建一個(gè)綁定在對應(yīng)CPU核心上的綁定線程,然后由這個(gè)綁定線程去完成私有中斷綁定。綁定流程如圖 3.1示。

SylixOS Zynq平臺私有中斷綁定


圖 3.1私有中斷綁定流程

    Zynq平臺31號私有定時(shí)器中斷綁定框架如程序清單 3.1所示。

程序清單 3.1 Zynq平臺31號私有定時(shí)器中斷綁定框架

#define ZYNQ_VECTOR_NIRQ     31         /* 31號私有中斷           */
static LW_HANDLE  _G_bindthread       = LW_OBJECT_HANDLE_INVALID;
static LW_HANDLE  _G_syncSignal       = LW_OBJECT_HANDLE_INVALID; 
/***************************************************************************
** 函數(shù)名稱: __nIrqIsr
** 功能描述: 中斷服務(wù)程序
** 輸 入  : pvArg
** 輸 出  : NONE
** 返  回  : LW_NULL
***************************************************************************/
static irqreturn_t __nIrqIsr (PVOID  pvArg)
{
return  LW_IRQ_HANDLED;
}
/***************************************************************************
** 函數(shù)名稱: __bindThread
** 功能描述: 私有中斷綁定線程
** 輸 入  : pvArg
** 輸 出  : NONE
** 返  回  : LW_NULL
***************************************************************************/
static PVOID  __bindThread (PVOID  pvArg)
{
API_SemaphoreBPend(_G_syncSignal, 
LW_OPTION_WAIT_INFINITE);              /* 等待同步信號量      */
API_InterVectorConnect(ZYNQ_VECTOR_NIRQ,             /* 連接中斷服務(wù)程序    */
                     (PINT_SVR_ROUTINE)__nIrqIsr,
                     (PVOID)NULL,
                     "nIrq");
API_InterVectorEnable(ZYNQ_VECTOR_NIRQ);             /* 使能中斷            */
}
/***************************************************************************
** 函數(shù)名稱: __nIrqInit
** 功能描述: 中斷服務(wù)初始化
** 輸 入  : NONE
** 輸 出  : NONE
** 返  回  : 成功返回ERROR_NONE,失敗返回PX_ERROR
***************************************************************************/
INT  __nIrqInit (VOID)
{
LW_CLASS_CPUSET            cpuset;
 
_G_syncSignal = API_SemaphoreBCreate("SYNCSEM",     /* 創(chuàng)建同步等待信號    */
                                            0,
                                            LW_OPTION_OBJECT_GLOBAL,
                                            LW_NULL);
if (_G_syncSignal == LW_OBJECT_HANDLE_INVALID) {    /*判斷信號量創(chuàng)建是否成功*/
     printk ("BIND signal init failed !\r\n");
     return PX_ERROR;
}
/*
 *  設(shè)置線程CPU綁定屬性
*/
LW_CPU_ZERO(&cpuset);
LW_CPU_SET(0, &cpuset);
_G_bindthread = API_ThreadCreate("bindThread",      /* 創(chuàng)建綁定線程          */
                                   __bindThread,
                                   LW_NULL,
                                      LW_NULL);
if (_G_bindthread == LW_OBJECT_HANDLE_INVALID) {  /*判斷綁定線程是否創(chuàng)建成功*/
     printk ("BIND thread init failed !\r\n");
     return PX_ERROR;
}
 
API_ThreadSetAffinity(_G_bindthread,               /* 將綁定線程設(shè)置到CPU0上*/
sizeof(cpuset), 
&cpuset);    
API_SemaphoreBPost(_G_syncSignal);                 /* 發(fā)送信號啟動綁定線程    */
}


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI