SylixOS Zynq平台私有中断绑定
admin
2023-02-05 07:00:03
0

1. 概述

    本篇主要介绍在Zynq平台编写中断相关的驱动程序时,涉及CPU私有中断的相关绑定办法。

2. 私有中断简介

    私有中断是多核CPU上特有的中断,私有中断只能被其所有者核心获取和响应,不会被其他核发现。常见的私有中断有全局定时器,私有看门狗定时器,私有定时器等,Zynq平台上还有来自PL的FIQ\IRQ。

3. 私有中断的绑定方法

3.1      常规共享中断绑定

    Zynq平台使用的是GIC通用中断框架,常规的共享中断绑定和普通的中断绑定没有区别,在SylixOS上直接调用API_InterVectorConnectAPI_InterVectorEnable这两个函数即可绑定,绑定后中断可由任意一个CPU核心响应。

3.2      私有中断绑定

    私有中断只能有所有者核心获取和响应,因此对应的中断和中断服务是绑定在相关的CPU核心上。在SylixOS下绑定私有中断需要让常规共享中断的绑定流程在对应CPU核心上完成才能成功绑定。即在驱动绑定私有中断的时候创建一个绑定在对应CPU核心上的绑定线程,然后由这个绑定线程去完成私有中断绑定。绑定流程如图 3.1示。

SylixOS Zynq平台私有中断绑定


图 3.1私有中断绑定流程

    Zynq平台31号私有定时器中断绑定框架如程序清单 3.1所示。

程序清单 3.1 Zynq平台31号私有定时器中断绑定框架

#define ZYNQ_VECTOR_NIRQ     31         /* 31号私有中断           */
static LW_HANDLE  _G_bindthread       = LW_OBJECT_HANDLE_INVALID;
static LW_HANDLE  _G_syncSignal       = LW_OBJECT_HANDLE_INVALID; 
/***************************************************************************
** 函数名称: __nIrqIsr
** 功能描述: 中断服务程序
** 输 入  : pvArg
** 输 出  : NONE
** 返  回  : LW_NULL
***************************************************************************/
static irqreturn_t __nIrqIsr (PVOID  pvArg)
{
return  LW_IRQ_HANDLED;
}
/***************************************************************************
** 函数名称: __bindThread
** 功能描述: 私有中断绑定线程
** 输 入  : pvArg
** 输 出  : NONE
** 返  回  : LW_NULL
***************************************************************************/
static PVOID  __bindThread (PVOID  pvArg)
{
API_SemaphoreBPend(_G_syncSignal, 
LW_OPTION_WAIT_INFINITE);              /* 等待同步信号量      */
API_InterVectorConnect(ZYNQ_VECTOR_NIRQ,             /* 连接中断服务程序    */
                     (PINT_SVR_ROUTINE)__nIrqIsr,
                     (PVOID)NULL,
                     "nIrq");
API_InterVectorEnable(ZYNQ_VECTOR_NIRQ);             /* 使能中断            */
}
/***************************************************************************
** 函数名称: __nIrqInit
** 功能描述: 中断服务初始化
** 输 入  : NONE
** 输 出  : NONE
** 返  回  : 成功返回ERROR_NONE,失败返回PX_ERROR
***************************************************************************/
INT  __nIrqInit (VOID)
{
LW_CLASS_CPUSET            cpuset;
 
_G_syncSignal = API_SemaphoreBCreate("SYNCSEM",     /* 创建同步等待信号    */
                                            0,
                                            LW_OPTION_OBJECT_GLOBAL,
                                            LW_NULL);
if (_G_syncSignal == LW_OBJECT_HANDLE_INVALID) {    /*判断信号量创建是否成功*/
     printk ("BIND signal init failed !\r\n");
     return PX_ERROR;
}
/*
 *  设置线程CPU绑定属性
*/
LW_CPU_ZERO(&cpuset);
LW_CPU_SET(0, &cpuset);
_G_bindthread = API_ThreadCreate("bindThread",      /* 创建绑定线程          */
                                   __bindThread,
                                   LW_NULL,
                                      LW_NULL);
if (_G_bindthread == LW_OBJECT_HANDLE_INVALID) {  /*判断绑定线程是否创建成功*/
     printk ("BIND thread init failed !\r\n");
     return PX_ERROR;
}
 
API_ThreadSetAffinity(_G_bindthread,               /* 将绑定线程设置到CPU0上*/
sizeof(cpuset), 
&cpuset);    
API_SemaphoreBPost(_G_syncSignal);                 /* 发送信号启动绑定线程    */
}


相关内容

热门资讯

德国总理:美国正在被伊朗羞辱 德国之声4月27日报道,德国总理默茨在访问一所学校时表示,在当前的持续冲突中,伊朗领导层正试图羞辱美...
理响中国|“长”歌以行,风云激... 光阴如梭,东方潮阔。这里是中国的长三角,世界的长三角。无论过去、现在还是未来,这片土地都因时代而生,...
白宫:特朗普及其国安团队开会讨... 新华社华盛顿4月27日电 美国白宫新闻秘书莱维特27日在记者会上证实,总统特朗普及其国家安全团队当天...
人民日报刊文:日本放开杀伤性武... 日本放开杀伤性武器出口推高地缘冲突风险(国际论坛)常思纯《人民日报》(2026年04月28日 第 0...
医疗保障法草案二审:明确生育保... 满足多样化健康保障需求本报记者 彭 波4月27日,医疗保障法草案二审稿提请十四届全国人大常委会第二十...
天津一景区发生自转旋翼机事故1... 澎湃新闻记者 吕新文中国民用航空华北地区管理局4月22日公布《豪客通航“10•1”天津长芦汉盐旅游区...
卡塔尔埃米尔与美国总统特朗普通... 当地时间24日,卡塔尔埃米尔塔米姆与美国总统特朗普通电话,重点就中东地区局势以及伊朗与美国谈判问题交...
男子30年前被扣押2859克黄... 澎湃新闻记者 王鑫家住辽宁省大连市的潘永嘉近日向澎湃新闻反映称,三十年前,他在大连周水子机场被盖州市...
商务部:取消反制欧盟两家金融机... 中华人民共和国商务部令二〇二六年 第1号鉴于欧盟已取消对中国两家金融机构的制裁措施,现公布《关于取消...
过去24小时共有5艘船只通过霍... 总台记者当地时间24日获悉,过去24小时内,共有5艘船只通过霍尔木兹海峡,其中包括一艘伊朗油轮。(总...