找回密码
 立即注册
查看: 24|回复: 2

一起学AiCube@Ai8051U 定时器0/1,INT0/INT1,中断组合应用实验打卡

[复制链接]
  • 打卡等级:常住居民III
  • 打卡总天数:147
  • 最近打卡:2025-06-17 13:25:11

16

主题

471

回帖

2578

积分

超级版主

积分
2578
发表于 昨天 10:11 | 显示全部楼层 |阅读模式
1.在深圳国芯人工智能有限公司-工具软件下载最新ISP软件,重新安装KEIL驱动,添加头文件。如果已使用6.95Q及后续版本安装过Keil驱动和头文件,则不用再次安装。
截图202506161002028736.jpg
截图202506161007237102.jpg
截图202506161008164529.jpg
打开AiCube,创建项目文件夹。
截图202506161010031753.jpg
项目设置里用默认设置即可。
截图202506161020527673.jpg
图形化I/O口配置里将P3.2设置为高阻输入模式并使能上拉电阻,将P3.3设置为高阻输入模式并使能上拉电阻。
截图202506161019284132.jpg
截图202506161114221516.jpg
勾选USB通用串行总线,USB协议选择CDC。
截图202506161025227524.jpg
勾选INT0外部中断0,中断模式设置为边沿中断(上升沿+下降沿)。
截图202506161026578890.jpg
勾选INT1外部中断1,中断模式设置为下降沿中断。
截图202506161029127714.jpg
勾选TIMER0定时器0,定时器时钟设置为40MHz,12T模式;定时器周期设置为2s;使能定时器0中断。
截图202506161033049167.jpg
勾选TIMER1定时器1,定时器时钟设置为40MHz,12T模式;定时器周期设置为500ms;使能定时器1中断。
截图202506161039348320.jpg
点击保存项目、创建项目。
截图202506161043167649.jpg
2.keil自动打开项目文件,添加程序,编译成功。
截图202506161133328896.jpg
3.成功下载程序,测试效果:
截图202506161138173268.jpg

T0_T1_INT0_INT1_TEST.zip (13.94 MB, 下载次数: 0)

程序如下:

//<<AICUBE_USER_HEADER_REMARK_BEGIN>>
////////////////////////////////////////
// 在此添加用户文件头说明信息
// 文件名称: main.c
// 文件描述:
// 文件版本: V1.0
// 修改记录:
//   1. (2025-06-16) 创建文件
////////////////////////////////////////
//<<AICUBE_USER_HEADER_REMARK_END>>


#include "config.h"                     //默认已包含stdio.h、intrins.h、ai_usb.h等头文件


//<<AICUBE_USER_INCLUDE_BEGIN>>
// 在此添加用户头文件包含
//<<AICUBE_USER_INCLUDE_END>>


//<<AICUBE_USER_GLOBAL_DEFINE_BEGIN>>
// 在此添加用户全局变量定义、用户宏定义以及函数声明
bit int0_flag = 0; //定义 1 个位变量,INT0 事件位变量标志,记录 INT0 已产生中断
// 供主循环查询 INT0 是否已产生中断,在主循环中处理 INT0 的中断事件任务,不堵塞其他中断
bit int1_flag = 0; //定义 1 个位变量,INT1 事件位变量标志,记录 INT1 已产生中断
// 供主循环查询 INT1 是否已产生中断,在主循环中处理 INT1 的中断事件任务,不堵塞其他中断
bit t0_flag = 0; //定义 1 个位变量,T0 事件位变量标志,记录定时器 0 已产生中断
// 供主循环查询定时器 0 是否已产生中断,在主循环中处理定时器 0 的中断事件任务,不堵塞其他中断
bit t1_flag = 0; //定义 1 个位变量,T1 事件位变量标志,记录定时器 1 已产生中断
// 供主循环查询定时器 1 是否已产生中断,在主循环中处理定时器 1 的中断事件任务,不堵塞其他中断
//<<AICUBE_USER_GLOBAL_DEFINE_END>>




////////////////////////////////////////
// 项目主函数
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void main(void)
{
    //<<AICUBE_USER_MAIN_INITIAL_BEGIN>>
    // 在此添加用户主函数初始化代码
    //<<AICUBE_USER_MAIN_INITIAL_END>>

    SYS_Init();

    //<<AICUBE_USER_MAIN_CODE_BEGIN>>
    // 在此添加主函数中运行一次的用户代码
          P40 = 0; //打开 LED 灯供电
    //<<AICUBE_USER_MAIN_CODE_END>>

    while (1)
    {
        USBLIB_OUT_Done();              //查询方式处理USB接收的数据

        //<<AICUBE_USER_MAIN_LOOP_BEGIN>>
        // 在此添加主函数中用户主循环代码
                          if(int0_flag) //主循环中查询,INT0 是否已产生中断,是否有需要处理的 INT 0 事件
        {
            int0_flag = 0; //清 0,INT0 事件位变量标志
            _nop_(); //用户在此添加需要处理的事件
            _nop_();
        }
        if(int1_flag) //主循环中查询,INT1 是否已产生中断,是否有需要处理的 INT1 事件
        {
            int1_flag = 0; //清 0,INT1 事件位变量标志
            _nop_(); //用户在此添加需要处理的事件
            _nop_();
        }
        if(t0_flag) //主循环中查询,定时器 0 是否已产生中断,是否有需要处理的定时器 0 事件
        {
            t0_flag = 0; //清 0,T0 事件位变量标志
            printf_usb("Timer0!\r\n");
            //向电脑 USB-CDC 串口助手输出“Timer0!”字符串,代表主循环在处理 T0 不急的任务
        }
        if(t1_flag) //主循环中查询,定时器 1 是否已产生中断,是否有需要处理的定时器 1 事件
        {
            t1_flag = 0; //清 0,T1 事件位变量标志
            printf_usb("Timer1!\r\n");
            //向电脑 USB-CDC 串口助手输出“Timer1!”字符串,代表主循环在处理 T1 不急的任务
        }
        //<<AICUBE_USER_MAIN_LOOP_END>>
    }
}

////////////////////////////////////////
// 系统初始化函数
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void SYS_Init(void)
{
    EnableAccessXFR();                  //使能访问扩展XFR
    AccessCodeFastest();                //设置最快速度访问程序代码
    AccessIXramFastest();               //设置最快速度访问内部XDATA
    IAP_SetTimeBase();                  //设置IAP等待参数,产生1us时基

    P0M0 = 0x00; P0M1 = 0x00;           //初始化P0口为准双向口模式
    P1M0 = 0x00; P1M1 = 0x00;           //初始化P1口为准双向口模式
    P2M0 = 0x00; P2M1 = 0x00;           //初始化P2口为准双向口模式
    P3M0 = 0x00; P3M1 = 0x00;           //初始化P3口为准双向口模式
    P4M0 = 0x00; P4M1 = 0x00;           //初始化P4口为准双向口模式
    P5M0 = 0x00; P5M1 = 0x00;           //初始化P5口为准双向口模式
    P6M0 = 0x00; P6M1 = 0x00;           //初始化P6口为准双向口模式
    P7M0 = 0x00; P7M1 = 0x00;           //初始化P7口为准双向口模式

    PORT3_Init();                       //P3口初始化
    TIMER0_Init();                      //定时器0初始化
    TIMER1_Init();                      //定时器1初始化
    EXTI0_Init();                       //INT0初始化
    EXTI1_Init();                       //INT1初始化
    USBLIB_Init();                      //USB库初始化

    //<<AICUBE_USER_INITIAL_CODE_BEGIN>>
    // 在此添加用户初始化代码
    //<<AICUBE_USER_INITIAL_CODE_END>>

    EnableGlobalInt();                  //使能全局中断
}

////////////////////////////////////////
// 微秒延时函数
// 入口参数: us (设置延时的微秒值)
// 函数返回: 无
////////////////////////////////////////
void delay_us(uint16_t us)
{
    do
    {
        NOP(34);                        //(MAIN_Fosc + 500000) / 1000000 - 6
    } while (--us);
}


////////////////////////////////////////
// 毫秒延时函数
// 入口参数: ms (设置延时的毫秒值)
// 函数返回: 无
////////////////////////////////////////
void delay_ms(uint16_t ms)
{
    uint16_t i;

    do
    {
        i = MAIN_Fosc / 6000;
        while (--i);
    } while (--ms);
}

////////////////////////////////////////
// 定时器0中断服务程序
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void TIMER0_ISR(void) interrupt TMR0_VECTOR
{
    //<<AICUBE_USER_TIMER0_ISR_CODE1_BEGIN>>
    // 在此添加中断函数用户代码
          P00 = ~P00; //P00 灯闪烁,中断服务程序中尽量少执行长的任务,防止堵塞其他中断
    //以上程序代表部分需特急处理的中断事件,可在中断服务程序中直接处理
    //但时间不要太长,否则会影响其他中断事件的实时响应速度
    t0_flag = 1; // t0_flag 置 1 是通知主循环处理部分 T0 中断事件不需要特急处理的任务
    //置 1,记录定时器 0 已产生中断,供主循环查询判断有无需处理的定时器 0 任务
    //<<AICUBE_USER_TIMER0_ISR_CODE1_END>>
}

////////////////////////////////////////
// 定时器1中断服务程序
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void TIMER1_ISR(void) interrupt TMR1_VECTOR
{
    //<<AICUBE_USER_TIMER1_ISR_CODE1_BEGIN>>
    // 在此添加中断函数用户代码
          P07 = ~P07; //P07 灯闪烁,中断服务程序中尽量少执行长的任务,防止堵塞其他中断
    //以上程序代表部分需特急处理的中断事件,可在中断服务程序中直接处理
    //但时间不要太长,否则会影响其他中断事件的实时响应速度
    t1_flag = 1; // t1_flag 置 1 是通知主循环处理部分 T1 中断事件不需要特急处理的任务
    //置 1,记录定时器 1 已产生中断,供主循环查询判断有无需处理的定时器 1 任务
    //<<AICUBE_USER_TIMER1_ISR_CODE1_END>>
}

////////////////////////////////////////
// 外部中断INT0中断服务程序
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void EXTI0_ISR(void) interrupt INT0_VECTOR
{
    //<<AICUBE_USER_EXTI0_ISR_CODE1_BEGIN>>
    // 在此添加中断函数用户代码
          int0_flag = 1; // int0_flag 置 1 是通知主循环处理部分 INT0 中断事件不需要特急处理的任务
    //置 1,记录 INT0 已产生中断,供主循环查询判断有无需处理的 INT0 任务
    if(INT0) //边沿中断,进入后再次判断电平从而判断是什么样的电平
    {
        // P01 = 0; //判断为高电平,则当前为上升沿,点亮 P01 端口上的 LED 灯
        // _nop_(); //可以在这里插入断点进行观察现象
        // P01 = 1; //关闭 LED 灯
        P01 = ~P01; //如果用外部按键触发 INT0,则需另外添加去抖动处理
    }
    else
    {
        // P06 = 0; //判断为低电平,则当前为下降沿,点亮 P06 端口上的 LED 灯
        // _nop_(); //可以在这里插入断点进行观察现象
        // P06 = 1; //关闭 LED 灯
        P06 = ~P06; //如果用外部按键触发 INT0,则需另外添加去抖动处理
    }
    //<<AICUBE_USER_EXTI0_ISR_CODE1_END>>
}

////////////////////////////////////////
// 外部中断INT1中断服务程序
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void EXTI1_ISR(void) interrupt INT1_VECTOR
{
    //<<AICUBE_USER_EXTI1_ISR_CODE1_BEGIN>>
    // 在此添加中断函数用户代码
          int1_flag = 1; // int1_flag 置 1 是通知主循环处理部分 INT1 中断事件不需要特急处理的任务
    //置 1,记录 INT1 已产生中断,供主循环查询判断有无需处理的 INT1 任务
    // P02= 0; //点亮 P02 端口上的 LED 灯
    // _nop_(); //可以在这里插入断点观察现象
    // P02 = 1; //关闭 LED 灯
    P02 = ~P02; //如果用外部按键触发 INT1,则需另外添加去抖动处理
    //<<AICUBE_USER_EXTI1_ISR_CODE1_END>>
}


////////////////////////////////////////
// P3口初始化函数
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void PORT3_Init(void)
{
    SetP3nQuasiMode(0xf0);              //设置P3.7,P3.6,P3.5,P3.4为准双向口模式
    SetP3nHighZInputMode(0x0f);         //设置P3.3,P3.2,P3.1,P3.0为高阻输入模式

    EnableP3nPullUp(0x0c);              //使能P3.3,P3.2内部上拉电阻
    DisableP3nPullUp(0xf3);             //关闭P3.7,P3.6,P3.5,P3.4,P3.1,P3.0内部上拉电阻
    DisableP3nPullDown(BIT_ALL);        //关闭P3内部下拉电阻
    DisableP3nSchmitt(BIT_ALL);         //使能P3施密特触发
    SetP3nSlewRateNormal(BIT_ALL);      //设置P3一般翻转速度
    SetP3nDrivingNormal(BIT_ALL);       //设置P3一般驱动能力
    SetP3nDigitalInput(BIT_ALL);        //使能P3数字信号输入功能

    //<<AICUBE_USER_PORT3_INITIAL_BEGIN>>
    // 在此添加用户初始化代码
    //<<AICUBE_USER_PORT3_INITIAL_END>>
}

////////////////////////////////////////
// 定时器0初始化函数
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void TIMER0_Init(void)
{
#define T0_PSCR     (102)
#define T0_RELOAD       (65536 - (float)SYSCLK / 12 / (T0_PSCR + 1) * 2 / 1)

    TIMER0_TimerMode();                 //设置定时器0为定时模式
    TIMER0_12TMode();                   //设置定时器0为12T模式
    TIMER0_Mode0();                     //设置定时器0为模式0 (13位不自动重载模式)
    TIMER0_DisableGateINT0();           //禁止定时器0门控
    TIMER0_SetIntPriority(0);           //设置中断为最低优先级
    TIMER0_EnableInt();                 //使能定时器0中断
    TIMER0_SetPrescale(T0_PSCR);        //设置定时器0的8位预分频
    TIMER0_SetReload16(T0_RELOAD);      //设置定时器0的16位重载值
    TIMER0_Run();                       //定时器0开始运行

    //<<AICUBE_USER_TIMER0_INITIAL_BEGIN>>
    // 在此添加用户初始化代码
    //<<AICUBE_USER_TIMER0_INITIAL_END>>
}

////////////////////////////////////////
// 定时器1初始化函数
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void TIMER1_Init(void)
{
#define T1_PSCR     (25)
#define T1_RELOAD       (65536 - (float)SYSCLK / 12 / (T1_PSCR + 1) * 500 / 1000)

    TIMER1_TimerMode();                 //设置定时器1为定时模式
    TIMER1_12TMode();                   //设置定时器1为12T模式
    TIMER1_Mode0();                     //设置定时器1为模式0 (13位不自动重载模式)
    TIMER1_DisableGateINT1();           //禁止定时器1门控
    TIMER1_SetIntPriority(0);           //设置中断为最低优先级
    TIMER1_EnableInt();                 //使能定时器1中断
    TIMER1_SetPrescale(T1_PSCR);        //设置定时器1的8位预分频
    TIMER1_SetReload16(T1_RELOAD);      //设置定时器1的16位重载值
    TIMER1_Run();                       //定时器1开始运行

    //<<AICUBE_USER_TIMER1_INITIAL_BEGIN>>
    // 在此添加用户初始化代码
    //<<AICUBE_USER_TIMER1_INITIAL_END>>
}

////////////////////////////////////////
// 外部中断INT0初始化函数
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void EXTI0_Init(void)
{
    INT0_FallingRisingInt();            //设置外部中断为边沿中断 (上升沿+下降沿)
    INT0_SetIntPriority(0);             //设置中断为最低优先级
    INT0_EnableInt();                   //使能外部中断

    //<<AICUBE_USER_EXTI0_INITIAL_BEGIN>>
    // 在此添加用户初始化代码
    //<<AICUBE_USER_EXTI0_INITIAL_END>>
}

////////////////////////////////////////
// 外部中断INT1初始化函数
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void EXTI1_Init(void)
{
    INT1_FallingInt();                  //设置外部中断为下降沿中断
    INT1_SetIntPriority(0);             //设置中断为最低优先级
    INT1_EnableInt();                   //使能外部中断

    //<<AICUBE_USER_EXTI1_INITIAL_BEGIN>>
    // 在此添加用户初始化代码
    //<<AICUBE_USER_EXTI1_INITIAL_END>>
}

////////////////////////////////////////
// USB库初始化函数
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void USBLIB_Init(void)
{
    usb_init();                         //初始化USB模块
    USB_SetIntPriority(0);              //设置中断为最低优先级
    set_usb_ispcmd("@STCISP#");         //设置USB不停电下载命令

    //<<AICUBE_USER_USBLIB_INITIAL_BEGIN>>
    // 在此添加用户初始化代码
    //<<AICUBE_USER_USBLIB_INITIAL_END>>
}

////////////////////////////////////////
// 等待USB配置完成函数
// 入口参数: 无
// 函数返回: 无
////////////////////////////////////////
void USBLIB_WaitConfiged(void)
{
    while (DeviceState != DEVSTATE_CONFIGURED) //等待USB完成配置
        WDT_Clear();                    //清看门狗定时器 (防止硬件自动使能看门狗)
}

////////////////////////////////////////
// USB设备接收数据处理程序
// 入口参数: 无
// 函数返回: 无
// bUsbOutReady:USB设备接收数据标志位
// OutNumber:USB设备接收到的数据长度
// UsbOutBuffer:保存USB设备接收到的数据
////////////////////////////////////////
void USBLIB_OUT_Done(void)
{
    if (bUsbOutReady)                   //查询是否有接收到USB主机发送数据
    {
        //<<AICUBE_USER_USBLIB_ISR_CODE1_BEGIN>>
        // 在此添加中断函数用户代码
        USB_SendData(UsbOutBuffer, OutNumber); //原路返回, 用于测试
                                        //在此处添加用户处理接收数据的代码
        //<<AICUBE_USER_USBLIB_ISR_CODE1_END>>
        usb_OUT_done();                 //当前包的数据处理完成,通知USB主机可以发送下一包数据
    }
}


//<<AICUBE_USER_FUNCTION_IMPLEMENT_BEGIN>>
// 在此添加用户函数实现代码
//<<AICUBE_USER_FUNCTION_IMPLEMENT_END>>











回复

使用道具 举报 送花

3

主题

704

回帖

119

积分

等待验证会员

积分
119
发表于 昨天 10:12 | 显示全部楼层
在进行AICube定时器和中断组合应用实验时,以下是一些关键步骤说明,供您参考:

1. 安装KEIL驱动和头文件  
下载并安装ISP软件。  
安装KEIL驱动,并选择合适的头文件。  
如果已使用过695Q及后续版本安装过KEIL驱动和头文件,建议避免再次安装,以节省时间和资源。  

2. 打开项目文件夹  
在AICube中打开项目文件夹。  
如果需要添加项目文件或配置,请根据实验要求进行操作。  

3. 配置应用  
根据实验需求配置AICube定时器和中断组合的应用。  
确保所有配置参数正确无误。  

4. 运行实验  
按照实验步骤启动AICube定时器和中断组合的应用。  
观察实验结果,并进行相应的数据分析和处理。  

5. 注意事项  
确保网络连接稳定,避免因网络问题影响实验运行。  
注意实验过程中可能出现的错误,及时排查并修复。  

希望以上信息对您进行实验有所帮助!如果需要更多细节或进一步的指导,请随时告知。

[本文内容由国芯人工智能辅助生成,仅供参考]
回复 支持 反对

使用道具 举报 送花

3

主题

704

回帖

119

积分

等待验证会员

积分
119
发表于 昨天 10:12 | 显示全部楼层
在深圳国芯人工智能有限公司-工具软件中实现AiCube定时器组合实验

在深圳国芯人工智能有限公司-工具软件中,我们正在进行一系列AI开发实验,包括定时器组合应用的实现。本次实验旨在验证AI cube定时器组合应用的稳定性和可靠性。实验的核心是使用Keil驱动系统和定时器组合,通过中断组合的应用,实现定时器的高效切换和切换事件的响应。

实验背景

AI cube定时器组合应用是一种常用的AI开发工具,用于自动化AI模型的训练和调参过程。这种组合应用能够通过中断模式实现定时器的高效切换,并通过中断事件响应特定的AI调参参数。本实验旨在验证AI cube定时器组合应用的稳定性和可靠性,通过中断组合的应用,实现定时器的高效切换和切换事件的响应。

实验步骤

1. 软件下载
下载并安装最新版本的ISP软件。在软件下载页面中,找到并打开“深圳国芯人工智能有限公司-工具软件”链接。

2. 软件安装
在ISP软件中,点击“下载最新ISP软件”按钮,进入软件下载页面。在下载页面中,找到并打开“深圳国芯人工智能有限公司-工具软件”链接。在下载页面中,找到并打开“KEIL驱动”和“头文件”链接。完成下载后,将KEIL驱动和头文件添加到软件中。

3. 安装中断组合
在KEIL驱动中,打开中断组合应用。在KEIL驱动中,打开中断组合应用,选择“打开中断组合应用”功能。在应用中,选择中断组合名称,点击“应用启动”按钮。完成启动后,检查中断组合是否正常工作。

4. 实验启动
打开AI cube,创建项目文件夹。在项目文件夹中,选择“AI cube定时器组合应用”项目。在项目中,点击“创建项目文件”按钮,完成项目创建。

5. 实验完成
实验完成!AI cube定时器组合应用通过中断组合的应用,实现了定时器的高效切换和切换事件的响应。

提示
如果你已使用695Q及以上版本的Keil驱动和头文件,无需再次安装。如果你尚未使用,按照上述步骤进行安装和配置。

如果你有进一步的问题或需要查看更多细节,请随时告知!

[本文内容由国芯人工智能辅助生成,仅供参考]
回复 支持 反对

使用道具 举报 送花

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|深圳国芯人工智能有限公司 ( 粤ICP备2022108929号-2 )

GMT+8, 2025-6-17 18:58 , Processed in 0.178899 second(s), 62 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表