mirror of
https://gitee.com/seekfree/TC264_Library.git
synced 2026-06-04 03:32:56 +00:00
146 lines
6.6 KiB
C
146 lines
6.6 KiB
C
/*********************************************************************************************************************
|
||
* TC264 Opensourec Library 即(TC264 开源库)是一个基于官方 SDK 接口的第三方开源库
|
||
* Copyright (c) 2022 SEEKFREE 逐飞科技
|
||
*
|
||
* 本文件是 TC264 开源库的一部分
|
||
*
|
||
* TC264 开源库 是免费软件
|
||
* 您可以根据自由软件基金会发布的 GPL(GNU General Public License,即 GNU通用公共许可证)的条款
|
||
* 即 GPL 的第3版(即 GPL3.0)或(您选择的)任何后来的版本,重新发布和/或修改它
|
||
*
|
||
* 本开源库的发布是希望它能发挥作用,但并未对其作任何的保证
|
||
* 甚至没有隐含的适销性或适合特定用途的保证
|
||
* 更多细节请参见 GPL
|
||
*
|
||
* 您应该在收到本开源库的同时收到一份 GPL 的副本
|
||
* 如果没有,请参阅<https://www.gnu.org/licenses/>
|
||
*
|
||
* 额外注明:
|
||
* 本开源库使用 GPL3.0 开源许可证协议 以上许可申明为译文版本
|
||
* 许可申明英文版在 libraries/doc 文件夹下的 GPL3_permission_statement.txt 文件中
|
||
* 许可证副本在 libraries 文件夹下 即该文件夹下的 LICENSE 文件
|
||
* 欢迎各位使用并传播本程序 但修改内容时必须保留逐飞科技的版权声明(即本声明)
|
||
*
|
||
* 文件名称 cpu0_main
|
||
* 公司名称 成都逐飞科技有限公司
|
||
* 版本信息 查看 libraries/doc 文件夹内 version 文件 版本说明
|
||
* 开发环境 ADS v1.8.0
|
||
* 适用平台 TC264D
|
||
* 店铺链接 https://seekfree.taobao.com/
|
||
*
|
||
* 修改记录
|
||
* 日期 作者 备注
|
||
* 2022-09-15 pudding first version
|
||
********************************************************************************************************************/
|
||
#include "zf_common_headfile.h"
|
||
#pragma section all "cpu0_dsram"
|
||
// 将本语句与#pragma section all restore语句之间的全局变量都放在CPU0的RAM中
|
||
|
||
|
||
// 工程导入到软件之后,应该选中工程然后点击refresh刷新一下之后再编译
|
||
// 工程默认设置为关闭优化,可以自己右击工程选择properties->C/C++ Build->Setting
|
||
// 然后在右侧的窗口中找到C/C++ Compiler->Optimization->Optimization level处设置优化等级
|
||
// 一般默认新建立的工程都会默认开2级优化,因此大家也可以设置为2级优化
|
||
|
||
// 对于TC系列默认是不支持中断嵌套的,希望支持中断嵌套需要在中断内使用 interrupt_global_enable(); 来开启中断嵌套
|
||
// 简单点说实际上进入中断后TC系列的硬件自动调用了 interrupt_global_disable(); 来拒绝响应任何的中断,因此需要我们自己手动调用 interrupt_global_enable(); 来开启中断的响应。
|
||
|
||
// *************************** 例程硬件连接说明 ***************************
|
||
// 核心板正常供电即可 无需额外连接
|
||
// 如果使用主板测试 主板必须要用电池供电
|
||
|
||
|
||
// *************************** 例程测试说明 ***************************
|
||
// 1.核心板烧录完成本例程,完成上电
|
||
// 2.可以看到核心板上四个 LED 呈流水灯状闪烁
|
||
// 3.将 SWITCH1 / SWITCH2 两个宏定义对应的引脚分别按照 00 01 10 11 的组合接到 1-VCC 0-GND 或者波动对应主板的拨码开关
|
||
// 3.不同的组合下,四个 LED 流水灯状闪烁的频率会发生变化
|
||
// 4.将 KEY1 / KEY2 / KEY3 / KEY4 两个宏定义对应的引脚接到 1-VCC 0-GND 或者 按对应按键
|
||
// 5.任意引脚接 GND 或者 按键按下会使得所有LED一起闪烁 松开后恢复流水灯
|
||
// 如果发现现象与说明严重不符 请参照本文件最下方 例程常见问题说明 进行排查
|
||
|
||
// **************************** 代码区域 ****************************
|
||
#define LED1 (P20_9)
|
||
#define LED2 (P20_8)
|
||
#define LED3 (P21_5)
|
||
#define LED4 (P21_4)
|
||
|
||
#define KEY1 (P22_0)
|
||
#define KEY2 (P22_1)
|
||
#define KEY3 (P22_2)
|
||
#define KEY4 (P22_3)
|
||
|
||
#define SWITCH1 (P33_12)
|
||
#define SWITCH2 (P33_13)
|
||
|
||
uint16 delay_time = 0;
|
||
uint8 led_state = 0;
|
||
|
||
int core0_main(void)
|
||
{
|
||
clock_init(); // 获取时钟频率<务必保留>
|
||
debug_init(); // 初始化默认调试串口
|
||
// 此处编写用户代码 例如外设初始化代码等
|
||
|
||
gpio_init(LED1, GPO, GPIO_LOW, GPO_PUSH_PULL); // 初始化 LED1 输出 默认高电平 推挽输出模式
|
||
gpio_init(LED2, GPO, GPIO_HIGH, GPO_PUSH_PULL); // 初始化 LED2 输出 默认高电平 推挽输出模式
|
||
gpio_init(LED3, GPO, GPIO_LOW, GPO_PUSH_PULL); // 初始化 LED3 输出 默认高电平 推挽输出模式
|
||
gpio_init(LED4, GPO, GPIO_HIGH, GPO_PUSH_PULL); // 初始化 LED4 输出 默认高电平 推挽输出模式
|
||
|
||
gpio_init(KEY1, GPI, GPIO_HIGH, GPI_PULL_UP); // 初始化 KEY1 输入 默认高电平 上拉输入
|
||
gpio_init(KEY2, GPI, GPIO_HIGH, GPI_PULL_UP); // 初始化 KEY2 输入 默认高电平 上拉输入
|
||
gpio_init(KEY3, GPI, GPIO_HIGH, GPI_PULL_UP); // 初始化 KEY3 输入 默认高电平 上拉输入
|
||
gpio_init(KEY4, GPI, GPIO_HIGH, GPI_PULL_UP); // 初始化 KEY4 输入 默认高电平 上拉输入
|
||
|
||
gpio_init(SWITCH1, GPI, GPIO_HIGH, GPI_FLOATING_IN); // 初始化 SWITCH1 输入 默认高电平 浮空输入
|
||
gpio_init(SWITCH2, GPI, GPIO_HIGH, GPI_FLOATING_IN); // 初始化 SWITCH2 输入 默认高电平 浮空输入
|
||
|
||
// 此处编写用户代码 例如外设初始化代码等
|
||
cpu_wait_event_ready(); // 等待所有核心初始化完毕
|
||
while (TRUE)
|
||
{
|
||
// 此处编写需要循环执行的代码
|
||
delay_time = 300;
|
||
if(gpio_get_level(SWITCH1)) delay_time /= 2;
|
||
if(gpio_get_level(SWITCH2)) delay_time /= 2;
|
||
if( !gpio_get_level(KEY1) || !gpio_get_level(KEY2) || !gpio_get_level(KEY3) || !gpio_get_level(KEY4) ) // 获取 KEYx 电平为低
|
||
{
|
||
gpio_set_level(LED1, led_state);
|
||
gpio_set_level(LED2, led_state);
|
||
gpio_set_level(LED3, led_state);
|
||
gpio_set_level(LED4, led_state);
|
||
}
|
||
else
|
||
{
|
||
gpio_set_level(LED1, led_state);
|
||
gpio_set_level(LED2, !led_state);
|
||
gpio_set_level(LED3, led_state);
|
||
gpio_set_level(LED4, !led_state);
|
||
}
|
||
led_state = !led_state;
|
||
system_delay_ms(delay_time);
|
||
// 此处编写需要循环执行的代码
|
||
}
|
||
}
|
||
|
||
#pragma section all restore
|
||
// **************************** 代码区域 ****************************
|
||
|
||
// *************************** 例程常见问题说明 ***************************
|
||
// 遇到问题时请按照以下问题检查列表检查
|
||
// 问题1:LED 不闪烁
|
||
// 如果使用主板测试,主板必须要用电池供电
|
||
// 查看程序是否正常烧录,是否下载报错,确认正常按下复位按键
|
||
// 万用表测量对应 LED 引脚电压是否变化,如果不变化证明程序未运行,如果变化证明 LED 灯珠损坏
|
||
// 问题2:SWITCH1 / SWITCH2 更改组合流水灯频率无变化
|
||
// 如果使用主板测试,主板必须要用电池供电
|
||
// 查看程序是否正常烧录,是否下载报错,确认正常按下复位按键
|
||
// 万用表测量对应 LED 引脚电压是否变化,如果不变化证明程序未运行,如果变化证明 LED 灯珠损坏
|
||
// 万用表检查对应 SWITCH1 / SWITCH2 引脚电压是否正常变化,是否跟接入信号不符,引脚是否接错
|
||
// 问题2:KEY1 / KEY2 / KEY3 / KEY4 接GND或者按键按下无变化
|
||
// 如果使用主板测试,主板必须要用电池供电
|
||
// 查看程序是否正常烧录,是否下载报错,确认正常按下复位按键
|
||
// 万用表测量对应 LED 引脚电压是否变化,如果不变化证明程序未运行,如果变化证明 LED 灯珠损坏
|
||
// 万用表检查对应 KEY1 / KEY2 / KEY3 / KEY4 引脚电压是否正常变化,是否跟接入信号不符,引脚是否接错
|
||
|