# 开发指导 - [接口说明](#section158501652121514) - [开发流程](#section11841123033618) - [编程实例](#section460018317164) - [结果验证](#section1048572415182) 当产生中断请求时,CPU暂停当前的任务,转而去响应外设请求。用户可以根据需要注册对应的中断处理程序,指定CPU响应中断请求时所执行的具体操作。 ## 接口说明 OpenHarmony LiteOS-M内核的中断模块提供下面几种功能,接口详细信息可以查看API参考。 **表 1** 中断模块接口

功能分类

接口名

描述

创建、删除中断

HalHwiCreate

中断创建,注册中断号、中断触发模式、中断优先级、中断处理程序。中断被触发时,会调用该中断处理程序。

HalHwiDelete

根据指定的中断号,删除中断。

打开、关闭中断

LOS_IntUnLock

开中断,使能当前处理器所有中断响应。

LOS_IntLock

关中断,关闭当前处理器所有中断响应。

LOS_IntRestore

恢复到使用LOS_IntLock、LOS_IntUnLock操作之前的中断状态。

## 开发流程 1. 调用中断创建接口HalHwiCreate创建中断。 2. 调用TestHwiTrigger接口触发指定中断(该接口在测试套中定义,通过写中断控制器的相关寄存器模拟外部中断,一般的外设设备,不需要执行这一步)。 3. 调用HalHwiDelete接口删除指定中断,此接口根据实际情况使用,判断是否需要删除中断。 >![](../public_sys-resources/icon-note.gif) **说明:** >- 根据具体硬件,配置支持的最大中断数及可设置的中断优先级个数。 >- 中断处理程序耗时不能过长,否则会影响CPU对中断的及时响应。 >- 中断响应过程中不能直接、间接执行引起调度的LOS\_Schedule等函数。 >- 中断恢复LOS\_IntRestore\(\)的入参必须是与之对应的LOS\_IntLock\(\)的返回值(即关中断之前的CPSR值)。Cortex-M系列处理器中0-15中断为内部使用,因此不建议用户去申请和创建。 ## 编程实例 本实例实现如下功能: 1. 创建中断。 2. 触发中断。 3. 删除中断。 代码实现如下,演示如何创建中断和删除中断,当指定的中断号HWI\_NUM\_TEST产生中断时,会调用中断处理函数: ``` #include "los_interrupt.h" /*创建中断*/ #define HWI_NUM_TEST 7 STATIC VOID HwiUsrIrq(VOID) { printf("in the func HwiUsrIrq \n"); } static UINT32 Example_Interrupt(VOID) { UINT32 ret; HWI_PRIOR_T hwiPrio = 3; HWI_MODE_T mode = 0; HWI_ARG_T arg = 0; /*创建中断*/ ret = HalHwiCreate(HWI_NUM_TEST, hwiPrio, mode, (HWI_PROC_FUNC)HwiUsrIrq, arg); if(ret == LOS_OK){ printf("Hwi create success!\n"); } else { printf("Hwi create failed!\n"); return LOS_NOK; } /* 延时50个Ticks, 当有硬件中断发生时,会调用函数HwiUsrIrq*/ LOS_TaskDelay(50); /*删除中断*/ ret = HalHwiDelete(HWI_NUM_TEST); if(ret == LOS_OK){ printf("Hwi delete success!\n"); } else { printf("Hwi delete failed!\n"); return LOS_NOK; } return LOS_OK; } ``` ### 结果验证 编译运行得到的结果为: ``` Hwi create success! Hwi delete success!. ```