SylixOS 中断响应时间测试

1.应用场景

在一些情况下,对于一些紧急的中断任务,系统需要为其提供稳定可靠的中断响应时间,但一般的中断服务函数,它的响应时间可能会受到其他中断向量的影响,延迟响应。在SylixOS中有两种解方案。

1.提高该中断向量优先级,打开中断嵌套来确保紧急中断的响应时间。

2.对于多核处理器,可以采用中断绑核的形式,即将紧急中断绑定到某一核上,该核只处理紧急任务。

下面通过测试正常情况下、中断嵌套情况下、中断绑核情况下的中断响应时间,来对比采用上述两种方式的优点。

2.中断响应时间测试方案

使用示波器自带的1KHZ输出方波作为CPU的中断源,下降沿中断,在中断服务里改变CPU引脚输出电平并捕获。中断响应时间为1KHZ方波由从高电平上升到0.7*VCC开始到CPU输出低电平的时间差。具体测试方案见PPT支持SMP的大型实时操作系统(IDE目录下的ppt目录里)。硬件连接图如图2- 1所示。

图2- 1 中断响应时间测试硬件连接

测试以zynq7000开发板为例,zynq7000处理器为双核处理器,中断控制器为GIC pl350,它支持中断嵌套和中断绑核。测试程序如程序清单2- 1所示。

程序清单2- 1 中断响应时间测试代码

/*********************************************************************************************************
* 函数名称: __doIsr
** 功能描述: 中断服务函数
** 输 入 : VOID
** 输 出 :
** 全局变量:
** 调用模块:
*********************************************************************************************************/
static irqreturn_t __doIsr (PVOID pvArg, ULONG iVector)
{
    API_GpioClearIrq(GPIO_NUM); /* 清中断 */
    writel(readl(0xE000A204) | (1 << 0), 0xE000A204); /* 11号脚,设置为出输出 */
    writel(readl(0xE000A208) | (1 << 0), 0xE000A208); /* 11号脚,设置为出输出使能 */
    writel(readl(0xE000A200) | (1 << 0), 0xE000A000); /* 11号脚,设置为低电平 */
    bspDelayUs(1); /* 延迟1us */
    writel(readl(0xE000A200) | (0 << 0), 0xE000A000); /* 11号脚,设置为高电平 */
    return LW_IRQ_HANDLED;
}
/*********************************************************************************************************
** 函数名称: module_init
** 功能描述: 模块加载函数
** 输 入 : VOID
** 输 出 : 0 表示成功,非0表示失败
** 全局变量:
** 调用模块:
*********************************************************************************************************/
int module_init (void)
{
system("shfile /etc/thread_affinity.sh");
 
     LW_CLASS_CPUSET cpuset;
     LW_CPU_ZERO(&cpuset);
     LW_CPU_SET(1, &cpuset);
     API_GpioRequestOne(GPIO_NUM, LW_GPIOF_IN, "intIn"); /* 下降沿触发中断 */
     LW_IRQ = API_GpioSetupIrq(GPIO_NUM, LW_FALSE, 0);
     API_InterVectorConnect(LW_IRQ, /* 安装操作系统中断向量表 */
                            (PINT_SVR_ROUTINE)__doIsr,
                             (PVOID)LW_NULL,
                             "isr");
 
    API_InterSetTarget(LW_IRQ, sizeof(LW_CLASS_CPUSET), &cpuset); /* 设置中断目标CPU1 */
 
    API_InterVectorEnable(LW_IRQ); /* 中断使能 */
 
    return 0;
}

在不开中断嵌套和中断不绑核的情况下,用上述方案进行测试。在不加负载的情况下,其中断响应时间如图3- 1所示。3.正常情况下中断响应时间测试

图3- 1 无负载下中断响应时间测试

由图3- 1可以看出其中断响应时间大概为3.5us,并且实际测试时波动较大,中断响应时间不稳定。在加负载的情况下(内存拷贝负载和CPU负载),其中断响应时间测试结果如下图3- 2所示。

图3- 2 加负载下中断响应时间测试

由图3- 2可以看出,加负载后,内存拷贝等任务可能会产生中断,从而影响测试中断向量的中断响应时间,测试中断向量的中断响应时间已经达到7us,并且实际响应时间很不稳定,有时可能出现十几微妙的情况。对于紧急任务,这种不稳定情况是不允许出现的。

4.中断嵌套下中断响应时间测试

在SylixOS下,可以采用中断嵌套的方式加快高优先级中断向量的响应时间,将测试中断向量的优先级设置为最高,并且打开中断嵌套,测试中断响应时间,图4- 1可以看出各个中断向量分布在不同的CPU核上。

图4- 1

如图4- 2所示,测试中断向量的中断响应时间为3.5us,并且实际响应时没有太大波动(响应时间稳定在3.5us)。

图4- 2 中断嵌套下无压力中断响应时间测试

如图4- 3所示是在加负载(CPU负载和内存拷贝负载)的情况下,测试中断向量的响应时间为5us左右,并且实际响应没有太大波动(响应时间稳定在5us)。

图4- 3 中断嵌套下加负载中断响应时间测试

由测试结果可以看出,中断嵌套可以提高中断的响应时间。

在单核处理器下,只能通过中断嵌套来保证紧急中断的响应时间,但多级中断嵌套存在中断栈溢出的风险,用户在使用时需要注意这一点。

大部分中断控制器为了防止中断栈溢出,一般会限制中断嵌套的层数,例如AIC支持最多8级中断嵌套,GIC支持最多7级中断嵌套。

SylixOS中用户可以手动配置中断栈的大小,通过memory_cfg.h 下的LW_CFG_INT_STK_SIZE选项进行中断栈大小的设置,SylixOS默认中断栈大小为4K,用户可以根据自身情况进行配置,配置选项程序如程序清单4- 1所示。

程序清单4- 1 中断栈大小配置

/*********************************************************************************************************
* 基本二进制大小单位定义
*********************************************************************************************************/
#ifndef LW_CFG_KB_SIZE
#define LW_CFG_KB_SIZE (1024)
#define LW_CFG_MB_SIZE (1024 * LW_CFG_KB_SIZE)
#define LW_CFG_GB_SIZE (1024 * LW_CFG_MB_SIZE)
#endif
 
/*********************************************************************************************************
* KERNEL THREAD & INTERUPT STACK
* (不包括网络与其他扩展子系统相关线程)
*********************************************************************************************************/
#define LW_CFG_INT_STK_SIZE (4 * LW_CFG_KB_SIZE)/* 系统中断堆栈大小 (字节) */
... …


5.中断绑核下中断响应时间测试

开中断嵌套存在一定风险,在多核处理器下,中断控制器一般都支持中断绑核。可以采用中断绑核的方式提高紧急中断向量的响应时间,中断绑核程序如程序清单5- 1所示。

程序清单5- 1 中断绑核设置

    LW_CLASS_CPUSET cpuset;
    LW_CPU_ZERO(&cpuset);
    LW_CPU_SET(1, &cpuset);
    API_GpioRequestOne(GPIO_NUM, LW_GPIOF_IN, "intIn"); /* 下降沿触发中断 */
    LW_IRQ = API_GpioSetupIrq(GPIO_NUM, LW_FALSE, 0);
    API_InterVectorConnect(LW_IRQ, /* 安装操作系统中断向量表 */
                           (PINT_SVR_ROUTINE)__doIsr,
                           (PVOID)LW_NULL,
                           "isr");
 
    API_InterSetTarget(LW_IRQ, sizeof(LW_CLASS_CPUSET), &cpuset); /* 设置中断目标CPU1 */
 
    API_InterVectorEnable(LW_IRQ); /* 中断使能 */

程序运行后,如图5- 2所示可以看出,测试中断向量绑定到CPU 1,其他中断向量绑定到了CPU 0。

图5- 2 中断绑核

在不加负载的情况下,中断响应时间测试结果如图5- 3所示,可以看出中断响应时间在3us左右,并且实际测试时响应时间没有太大波动。

图5- 3 绑核无负载中断响应时间测试结果

在加负载(CPU负载和内存拷贝负载)的情况下,响应测试结果如图5- 4所示,响应时间为4us,并且实际测试时响应时间没有太大波动,负载对紧急任务的中断响应时间影响很小。

图5- 4 绑核有负载中断响应时间测试结果

根据上述测试结果可以看出,中断绑核也可以保证中断响应时间的稳定可靠

时间: 2024-12-23 19:46:28

SylixOS 中断响应时间测试的相关文章

SylixOS 中断流程

说明 本文章分析了ARM架构下SylixOS内核中断流程,共包含三部分: 分析SylixOS运用数组和双向链表实现中断服务函数的注册 阐述ARM硬件中断机制 分析SylixOS中断处理流程 SylixOS中断注册 SylixOS中断注册是通过数组和双向链表实现的. 系统中断向量结构索引数组 _K_idescTable [256]是SylixOS内核中的系统中断向量结构索引数组,用于索引注册的中断服务函数,其类型如清单 21所示 清单 21 typedef struct {     LW_LIST

SylixOS 中断系统分析

SylixOS中断系统分析 中断向量表 在SylixOS中,系统默认存在一张大小为256(可以手动配置)的中断向量表,用于管理SylixOS中的每一个中断向量.该向量表存在于k_globalvar.h文件中,其定义格式如程序清单1-1所示. 程序清单1-1 系统中断向量表定义 /*********************************************************************************************************   系统

android应用APP中的页面响应时间测试

说明:这里只介绍基本测试逻辑 整理出 整个APP需要关注的一级页面列表 基本工具:ut(内部工具,不便透露细节) 在开发代码中引入TimeProfile类:这个类是ut的最上层,暴露出一些简单的时间打点方法,start(),end()等方法: 在整理出来的一级页面对应的代码中,主要是指activity类中,Oncreat()方法体中 initview()方法调用之前,打点start(),用于记录当前的时间戳: 再然后在 请求回调函数体的onsucess()方法体内部,获取到回传data数据后,调

Stm32的中断在测试FREERTOS的时候的问题

在测试FreeRTOS在stm32上运行的时候,需要用到timer的中断,则打开了中断,但是如下的代码则让系统死机: /* 选择优先级分组0 */ NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0); /* 开启 TIM2 中断, 0级先占优先级,0级后占优先级 */ NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPr

中断方法测试

package com.fh.interview; /** * 中断测试 * * @author * @create 2018-05-27 下午3:18 **/ public class InterruptDemo { public static void main(String[] args) { Thread sleepThread = new Thread(){ @Override public void run() { try { Thread.sleep(1000); }catch (

页面响应时间测试

1.测试工具:a. 格式转换工具 videoconverter.zip b. 帧率分析工具 VirtualDub.zip (只支持.avi格式) 2.测试方法:开发者选项中打开 显示触摸操作 以及 指针位置 的开关 (1)  执行命令 adb shell screenrecord /sdcard/test.mp4 后开始录屏(手机自带的录屏软件格式不能转换),期间执行测试项,完毕后ctrl+c退出录屏,录屏文件在sdcard根目录下 (2)  将test.mp4用 videoconverter

SylixOS周期定时抖动分析

1.概述 自动化与控制行业中有很多场景需要循环周期控制,而运动控制领域对循环周期控制的时间确定性要求尤为严格,周期抖动的时间确定性和周期控制的极限范围直接影响运动控制产品的质量和性能.SylixOS作为一款嵌入式实时操作系统,针对不同循环周期和不同程度的时间确定性要求均有对应的周期控制方式,其中就有为周期性任务解决多任务调度冲突并且时间确定性良好的速率单调调度(Rate Monotonic Scheduling RMS),还有传统的以硬件平台定时器作为中断源,以中断服务程序作为实时任务运行载体的

测试基础知识(白盒测试,黑盒测试,测试用例,功能测试等等)

测试基础知识 找实习工作的过程中总结了下测试基础知识,编程能力重要,测试基础同样重要,希望对大家有帮助 软件测试方法:静态测试和动态测试                     白盒测试和黑盒测试                     传统测试与面向对象测试 软件测试过程:单元测试,集成测试,系统测试,验收测试 按测试类型:功能.性能.界面.易用性测试.兼容性测试.安全性测试.安装测试 (单元测试:在编码过程中,对每个小程序单元测试) (集成测试:将单元集成在一起后,可称为组件) 回归测试.冒

移动app测试流程与测试点

移动app测试流程和测试点1.接收版本2.版本送测检查 3.ui测试4.功能测试5.性能Test6.兼容性测试7.上线步骤测试8.联调测试 功能测试:各个功能点 测试客户端与pc端的交互,数据一致性 数据对比:在真机或者模拟器中进行,与在数据库实际插入的数据进行对比 1.静态代码分析 2.集成测试 3.系统测试 4.覆盖率 app清空数据后或强制性退出是否能正常运行 切面是否正常 app切换(最小化.最大化) 关机或者待机状态app是否正常运行 性能测试: 1.cpu占用 2.内存占用 3.耗电