利用ad7705的源代碼,寫一個ADC采集P1.0,P1.1口發送PWM,且PWM_Control函數可以控制其脈寬,占空比,以及模式1,2
然后我定時器完成初始化后,所有程序燒錄進去后,定時器的t并沒有計數(就是沒有發生中斷),ad7705源代碼中使用了串口中斷,是這個原因嗎?還是其他原因?
我單獨將PWM_control拿出來生成hex文件,用proteus的示波器觀察是成功的.
/***************************************主函數**************************************/
#include "bsp.h"
#include "lcd.h"
uchar code first1[]="Vdd=";
uchar code first2[]="Set:";
uchar code second[]="Test=";
uchar t = 0,c = 0,k;//k為脈沖周期
void initial();
void PWM_Control1( uchar Width, uchar DutyCycle, uchar count,uchar partern);
static void TM7705_Demo(void);
/******************************定時器初始化****************************/
void initial() //定時器初始化
{
TMOD |= 0x21; //設置定時器T0,T1 開啟 T0工作模式1
TH0 = (65536-1000)/256;
TL0 = (65536-1000)%256;
EA = 1;
ET0 = 1;
TR0 = 1;
}
/*********************************************************/
/******************* PWM脈沖控制函數**********************/
void PWM_Control1( uchar Width, uchar DutyCycle, uchar count,uchar partern) //1ms為最小單位
{ //uchar k;
//脈寬設置 Wdith
//占空比 X0% DutyCycle
//脈沖個數 count
// pin = ;
k = (Width*10)/DutyCycle; //PWM整個周期
// while(c!=count) //直到發送了count個脈沖,跳出循環
if(partern == 1)
{
if (t<Width){ P1_0 = 1;P1_1 = 0;}else{ P1_0 = 0;P1_1 = 1;}// 控制I/O口輸出 高低電平持續時間
}
if(partern == 2)
{
if (t<Width){ P1_0 = 0;P1_1 = 1;}else{ P1_0 = 1;P1_1 = 0;}
}
}
/*
*********************************************************************************************************
* 函 數 名: main
* 功能說明: C程序入口
* 形 參:無
* 返 回 值: 無
*********************************************************************************************************
*/
void main(void)
{ uchar n = 0,m = 0,k=0,i=0;
bsp_Init(); /* 初始化底層硬件。 該函數在 bsp.c文件 */
lcd_initial(); //lcd初始化
initial();//定時器初始化
delay(10);
while(1)
{
PWM_Control1(7,7,10,2);
lcd_pos(0x00);
for(n=0;n<4;n++)
{
lcd_wdat(first1[n]);
}
// lcd_pos(0x04);
/********Vdd顯示***********/
lcd_pos(0x08);
for(m=0;m<4;m++)
{
lcd_wdat(first2[m]);
}
// lcd_pos(0x0e);
/********調節電壓顯示******/
lcd_pos(0x40);
for(i=0;i<5;i++)
{
lcd_wdat(second[i]);
}
lcd_pos(0x45);
/*********檢測電壓顯示*****/
lcd_wdat(TM7705_ReadAdc(1));
TM7705_Demo();
}
}
/*
*********************************************************************************************************
* 函 數 名: TM7705_Demo
* 功能說明: 定時讀取TM7705的ADC值,并打印到串口。請通過PC機串口工具查看結果。
* 形 參:無
* 返 回 值: 無
*********************************************************************************************************
*/
static void TM7705_Demo(void)
{
uint16_t adc1, adc2;
bsp_InitTM7705(); /* 初始化配置TM7705 */
TM7705_CalibSelf(1); /* 自校準。執行時間較長,約180ms */
adc1 = TM7705_ReadAdc(1);
TM7705_CalibSelf(2); /* 自校準。執行時間較長,約180ms */
adc2 = TM7705_ReadAdc(2);
while (1)
{
bsp_Idle();
#if 1
/* 雙通道切換采樣,執行一輪實際那約 160ms */
adc1 = TM7705_ReadAdc(1); /* 執行時間 80ms */
adc2 = TM7705_ReadAdc(2); /* 執行時間 80ms */
#else
/* 如果只采集1個通道,則刷新速率 50Hz (缺省設置的,最大可以設置為500Hz) */
adc1 = TM7705_ReadAdc(1); /* 執行時間 20ms (50Hz速率刷新時) */
adc2 = 0;
#endif
/* 打印采集數據 */
{
int volt1, volt2;
/* 計算實際電壓值(近似估算的),如需準確,請進行校準 */
volt1 = ((int32_t)adc1 * 5000) / 65535;
volt2 = ((int32_t)adc2 * 5000) / 65535;
/* 打印ADC采樣結果 */
// printf("CH1=%5ld (%5dmV) CH2=%5ld (%5dmV)\r", (long int)adc1, volt1, (long int)adc2, volt2);
}
}
}
/*******************定時器0中斷函數*********************/
void timer0() interrupt 1 using 1
{
TH0 = (65536-1000)/256; //1ms
TL0 = (65536-1000)%256;
t++;
if(t == k)
{
t = 0;
c++;
}
}
還有一個ad7705代碼中串口中斷設置
void bsp_InitUart(void)
{
SCON = 0x50; /* 010 1 0000B,工作方式1, 8位UART,波特率可變,允許接收 */
TMOD = 0x21; /* 設置T1,T0 T1工作于方式2 */
TCON = 0x40; /* 定時器1開始計數 */
TH1 = 250; /* T1計數初值 */
TL1 = 250;
PCON = 0x80; /* SMOD置1,雙倍速率 */
RI = 0;
TI = 0;
}
是什么原因導致定時器t0無法中斷? |