rt-thread-official/bsp/tkm32F499/Libraries/CMSIS_and_startup/sys.c

163 lines
4.0 KiB
C
Raw Normal View History

2021-10-14 19:21:16 +08:00
#include "sys.h"
2021-10-14 18:50:35 +08:00
#include "HAL_misc.h"
void RemapVtorTable(void)
2021-10-14 19:21:16 +08:00
{
2021-10-14 19:46:54 +08:00
int i;
2021-10-14 18:50:35 +08:00
RCC->AHB1ENR |= 1<<13;//bkp clk,enable sram
2021-10-14 19:46:54 +08:00
//关ROM区中断
2021-10-14 18:50:35 +08:00
for(i = 0;i<90;i++)
2021-10-14 19:21:16 +08:00
{
NVIC_DisableIRQ((IRQn_Type)i);
2021-10-14 18:50:35 +08:00
}
2021-10-14 19:46:54 +08:00
SCB->VTOR = 0;
SCB->VTOR |= 0x1<<29;
for(i = 0;i < 512;i+=4)
*(u32*)(T_SRAM_BASE + i) = *(u32*)(T_SDRAM_BASE+i);
2021-10-14 18:50:35 +08:00
}
void AI_Responder_enable(void)
{
AI_Responder->ADDR1= 0x70807040;
2021-10-14 19:46:54 +08:00
// AI_Responder->ADDR0 = 0x70027080;
2021-10-14 18:50:35 +08:00
AI_Responder->ADDR1 = 0;
AI_Responder->CCR &= ~(0x3<<3);
AI_Responder->CCR |= 1;
while((AI_Responder->SR & 0x3) != 2);
}
void AI_Responder_disable(void)
{
AI_Responder->CCR &= ~1;
}
2021-10-14 19:21:16 +08:00
//外部中断配置函数
//只针对GPIOA~E
//参数:
//GPIOx:0~4,代表GPIOA~E
//BITx:需要使能的位例如PB12就填 12;
//TRIM:触发模式,1,下降沿;2,上升沿;3任意电平触发
//该函数一次只能配置1个IO口,多个IO口,需多次调用
//该函数会自动开启对应中断,以及屏蔽线
void Ex_NVIC_Config(u8 GPIOx,u8 BITx,u8 TRIM)
{
2021-10-14 19:46:54 +08:00
u8 EXTOFFSET=(BITx%4)*4;
RCC->APB2ENR|=1<<14; //使能SYSCFG时钟
SYSCFG->EXTICR[BITx/4]&=~(0x000F<<EXTOFFSET);//清除原来设置!!!
SYSCFG->EXTICR[BITx/4]|=GPIOx<<EXTOFFSET; //EXTI.BITx映射到GPIOx.BITx
//自动设置
EXTI->IMR|=1<<BITx; //开启line BITx上的中断(如果要禁止中断,则反操作即可)
if(TRIM&0x01)EXTI->FTSR|=1<<BITx; //line BITx事件下降沿触发
if(TRIM&0x02)EXTI->RTSR|=1<<BITx; //line BITx事件上升沿触发
2021-10-14 19:21:16 +08:00
}
//THUMB指令不支持汇编内联
//采用如下方法实现执行汇编指令WFI
2021-10-14 18:50:35 +08:00
void WFI_SET(void)
{
2021-10-14 19:46:54 +08:00
__ASM volatile("wfi");
2021-10-14 18:50:35 +08:00
}
2021-10-14 19:21:16 +08:00
//关闭所有中断(但是不包括fault和NMI中断)
2021-10-14 18:50:35 +08:00
void INTX_DISABLE(void)
{
2021-10-14 19:46:54 +08:00
__ASM volatile("cpsid i");
2021-10-14 18:50:35 +08:00
}
2021-10-14 19:21:16 +08:00
//开启所有中断
2021-10-14 18:50:35 +08:00
void INTX_ENABLE(void)
{
2021-10-14 19:46:54 +08:00
__ASM volatile("cpsie i");
2021-10-14 18:50:35 +08:00
}
2021-10-14 19:21:16 +08:00
//设置栈顶地址 __set_MSP(0x70002000);
2021-10-14 18:50:35 +08:00
2021-10-14 19:21:16 +08:00
//进入待机模式
2021-10-14 18:50:35 +08:00
void Sys_Standby(void)
2021-10-14 19:21:16 +08:00
{
2021-10-14 19:46:54 +08:00
SCB->SCR|=1<<2; //使能SLEEPDEEP位 (SYS->CTRL)
RCC->APB1ENR|=1<<28;//使能电源时钟
PWR->CSR|=1<<8; //设置WKUP用于唤醒
PWR->CR|=1<<2; //清除Wake-up 标志
PWR->CR|=1<<1; //PDDS置位
WFI_SET(); //执行WFI指令,进入待机模式
2021-10-14 19:21:16 +08:00
}
//系统软复位
2021-10-14 18:50:35 +08:00
void Sys_Soft_Reset(void)
2021-10-14 19:21:16 +08:00
{
2021-10-14 19:46:54 +08:00
SCB->AIRCR =0X05FA0000|(u32)0x04;
2021-10-14 19:21:16 +08:00
}
2021-10-14 19:46:54 +08:00
// TK499_NVIC_Init(2,2,TK80_IRQn,2);
2021-10-14 19:21:16 +08:00
//设置NVIC
//NVIC_PreemptionPriority:抢占优先级
//NVIC_SubPriority :响应优先级
//NVIC_Channel :中断编号
//NVIC_Group :中断分组 0~4
//注意优先级不能超过设定的组的范围!否则会有意想不到的错误
//组划分:
//组0:0位抢占优先级,4位响应优先级
//组1:1位抢占优先级,3位响应优先级
//组2:2位抢占优先级,2位响应优先级
//组3:3位抢占优先级,1位响应优先级
//组4:4位抢占优先级,0位响应优先级
//NVIC_SubPriority和NVIC_PreemptionPriority的原则是,数值越小,越优先
void TK499_NVIC_Init(u8 NVIC_PreemptionPriority,u8 NVIC_SubPriority,u8 NVIC_Channel,u8 NVIC_Group)
2021-10-14 18:50:35 +08:00
{
2021-10-14 19:46:54 +08:00
u32 temp;
NVIC_SetPriorityGrouping(NVIC_Group);//设置分组
temp=NVIC_PreemptionPriority<<(4-NVIC_Group);
temp|=NVIC_SubPriority&(0x0f>>NVIC_Group);
temp&=0xf; //取低四位
NVIC->ISER[NVIC_Channel/32]|=1<<NVIC_Channel%32;//使能中断位(要清除的话,设置ICER对应位为1即可)
NVIC->IP[NVIC_Channel]|=temp<<4; //设置响应优先级和抢断优先级
2021-10-14 18:50:35 +08:00
}
void TK80_IRQHandler(void)
{
if(TK80->SR & 0x1)
{
2021-10-14 19:21:16 +08:00
2021-10-14 18:50:35 +08:00
}
if(TK80->SR & 0x2)
{
2021-10-14 19:21:16 +08:00
2021-10-14 18:50:35 +08:00
}
if(TK80->SR & 0x4)
{
2021-10-14 19:21:16 +08:00
2021-10-14 18:50:35 +08:00
}
if(TK80->SR & 0x8)
{
2021-10-14 19:21:16 +08:00
2021-10-14 18:50:35 +08:00
}
TK80->SR |= 0;
}
2021-10-14 19:21:16 +08:00
//备用函数
2021-10-14 18:50:35 +08:00
//#define T_SRAM_FUN1 0x20000400
2021-10-14 19:21:16 +08:00
//copyAtoB((u32)LCD_PutPixel&0xFFFFFFFE,T_SRAM_FUN1,800);//加载函数到SRAM
2021-10-14 18:50:35 +08:00
//void copyAtoB(u32 srcAdd,u32 dstAdd,u16 len)
//{
// len = (len + 3)/4;
// while(len--)
// {
// *(u32*)dstAdd = *(u32*)srcAdd;
// dstAdd += 4 ;
// srcAdd +=4 ;
// }
//}