CLK提供时钟信号至少在复位应答期间,时钟f的频率值应在以下范围内:
1-5MHz:A类
1-4MHz:B类
//TIM4_PWM_Init(20-1,0);//3.4Mhz 50%Duty 输出
void TIM4_PWM_Init(u16 arr,u16 psc)
{
GPIO_InitTypeDef GPIO_InitStructure;
TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
TIM_OCInitTypeDef TIM_OCInitStructure;
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);// 使能TIM4时钟
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB , ENABLE); //使能GPIOB时钟
//设置该引脚为复用输出功能,输出TIM4 CH1的PWM脉冲波形
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6; //TIM_CH1
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽输出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOB, &GPIO_InitStructure);//PB6
TIM_TimeBaseStructure.TIM_Period = arr; //设置在下一个更新事件装入活动的自动重装载寄存器周期的值 80K
TIM_TimeBaseStructure.TIM_Prescaler =psc; //设置用来作为TIMx时钟频率除数的预分频值 不分频
TIM_TimeBaseStructure.TIM_ClockDivision = 0; //设置时钟分割:TDTS = Tck_tim
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; //TIM向上计数模式
TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure); //根据TIM_TimeBaseInitStruct中指定的参数初始化TIMx的时间基数单位
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //选择定时器模式:TIM脉冲宽度调制模式2
TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能
TIM_OCInitStructure.TIM_Pulse = 10; //设置待装入捕获比较寄存器的脉冲值
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; //输出极性:TIM输出比较极性高
TIM_OC1Init(TIM4, &TIM_OCInitStructure); //根据TIM_OCInitStruct中指定的参数初始化外设TIMx
//TIM_CtrlPWMOutputs(TIM4,ENABLE); //MOE
TIM_OC1PreloadConfig(TIM4, TIM_OCPreload_Enable); //CH1预装载使能
TIM_ARRPreloadConfig(TIM4, ENABLE); //使能TIMx在ARR上的预装载寄存器
TIM_Cmd(TIM4, ENABLE); //使能TIM4
}
在这种情况下可以直接利用串口发送和接收数据,网上很多代码也都是这种使用方式:(格式:1位起始位+8位数据+1位偶校验位)
unsigned char Psam_RecvByte(u8 cChannel)
{
unsigned char i,data=0;
unsigned int j=0;
SAM_DATA_DIR(GP_IO_Data[cChannel],GP_Pin_Data[cChannel],GPIO_Mode_IN_FLOATING); //DATA脚配置为输入
//INTX_DISABLE(); //close EA
while((SAM_DATA_GET[cChannel]()!=0) /*&& (j++<65000)*/ );//等待IO口为低,超时退出 起始位
//delay_us(GCDELAYTIME);
for(i=0; i<8; i++)
{
data >>= 1;
delay_us(GCDELAYTIME);
if(SAM_DATA_GET[cChannel]() != 0)
data |= 0x80;
}
delay_us(GCDELAYTIME);
delay_us(GCDELAYTIME/2);
return data;
}
void Psam_Reset(u8 cChannel)
{
Set_SAM_RST[cChannel]();//拉高RST
delay_ms(20);
Clr_SAM_RST[cChannel]();//拉低RST
delay_ms(10);
Set_SAM_RST[cChannel]();//拉高RST 完成热复位
}