|
10年前學(xué)習(xí)單片機記得是從AT89C51開始的,回想起那時候做遙控器解碼等很多東西用到它,用到TR1,很多接觸單片機的人我想對這個語句非常的收悉,TR1 = 1; 或 SETB TR1 .這是當(dāng)年用Keil編譯器的語句,10年后的我改變了對Keil的看法,覺得它太肆無忌憚了,雖然很方便,語句也很簡潔,可是我感覺計算機語言不應(yīng)該那么隨意,應(yīng)該規(guī)范化,這樣才容易移植.自從我接觸AVR單片機,一直用的是IAR編譯器,自從IAR編譯器后,我才知道什么才是計算機語言.比如剛才那句TR1 = 1; 應(yīng)該這樣寫TCON_bit.TR1 = 1;至少在IAR中是這么約定的,TCON_bit代表一個結(jié)構(gòu),TR1是它的一個成員,這樣更容易理解而且如果移植到其他平臺上,TR1發(fā)生沖突的幾率至少會少很多以下是我回到8051寫的timer1
程序,它設(shè)定了一個時間,MCU_OSC在宏里已經(jīng)定義,它指定了MCU的工作頻率,MCU_SPEED指定了MCU的工作速度,STC有兩種模式6T和12T,nReship_timer1是一個全局變量,它指定了timer1的重裝值,在timer1的中斷函數(shù)里重新裝載到TR1里.我準(zhǔn)備再做一個音頻指示燈,10年前的作品現(xiàn)在重新做一次,我手頭還有很多STC12C2052AD,讓他們發(fā)揮出當(dāng)年的色彩.
/*********** 設(shè)定定時器1為定時器 ***********************/
bool set_timer1_us(unsigned long time)
{
float scale = 1000000.0 / MCU_OSC * MCU_SPEED;// 計算分辨率(us)
if(scale * 0xFFFF < time)
{
err0 = 1;// 標(biāo)記錯誤
err1 = 0;
return false;
}
TMOD_bit.M01 = 1;
TMOD_bit.M11 = 0;// 設(shè)置為16位定時器模式
nReship_timer1 = 0x10000 - (unsigned int)(time / scale);//計算重裝載值
IE_bit.ET1 = 1;// 打開定時器1中斷
TCON_bit.TR1 = 1;// 打開定時器1
return true;
}
|
|