stm8s開(kāi)發(fā)(四) CLOCK的使用:時(shí)鐘控制!
STM8S具有一個(gè)強(qiáng)大的時(shí)鐘系統(tǒng),內(nèi)部提供一個(gè)高速16M的RC振蕩器,和一個(gè)低速128K的RC振蕩器。
時(shí)鐘控制器功能強(qiáng)大而且靈活易用。其目的在于使用戶在獲得最好性能的同時(shí),亦能保證消耗的功率最低。用戶可獨(dú)立地管理各個(gè)時(shí)鐘源,并將它們分配到CPU或各個(gè)外設(shè)。主時(shí)鐘和CPU時(shí)鐘均帶有預(yù)分頻器。具有安全可靠的無(wú)故障時(shí)鐘切換機(jī)制,可在程序運(yùn)行中將主時(shí)鐘從一個(gè)時(shí)鐘源切換到另一個(gè)時(shí)鐘源。
一般來(lái)說(shuō),時(shí)鐘樹是配置時(shí)鐘、控制時(shí)鐘的依據(jù),所以需要掌握,以下是STM8S時(shí)鐘樹圖:
從圖中看出,一共有3個(gè)時(shí)鐘源,分別是HSE(高速外部時(shí)鐘)、HSI(高速內(nèi)部時(shí)鐘)、LSI(低速內(nèi)部時(shí)鐘)。
HSE(高速外部時(shí)鐘)可通過(guò)外部晶振提供,HSI(高速內(nèi)部時(shí)鐘)為16M的RC振蕩器,LSI(低速內(nèi)部時(shí)鐘)為128K的RC振蕩器。
高速時(shí)鐘(HSE和HSI)可以通過(guò)分頻器進(jìn)行降頻。降頻過(guò)后的時(shí)鐘和原本的時(shí)鐘都可以通過(guò)Master Clock Switch進(jìn)行選擇,
以下是初始化系統(tǒng)時(shí)鐘的函數(shù)(默認(rèn)使用16M內(nèi)部RC):
voidSet_HSISpeed(void)
{
//啟用內(nèi)部高速晶振且無(wú)分頻16MHz
CLK_ICKR|=0x01;//開(kāi)啟內(nèi)部HSI
while(!(CLK_ICKR&0x02));//HSI準(zhǔn)備就緒
CLK_SWR=0xe1;//HSI為主時(shí)鐘源
CLK_CKDIVR=0x00;//HSI不分頻
}
如果需要切換時(shí)鐘,需要先等待時(shí)鐘穩(wěn)定:
voidSwitch_LSISpeed(void)
{
CLK_SWCR|=0x02;//開(kāi)啟切換
CLK_ICKR|=0x08;//開(kāi)啟LSI
while(!(CLK_ICKR&0x10));//HSI準(zhǔn)備就緒
CLK_SWR=0xd2;//LSR為主時(shí)鐘源
while((CLK_SWCR&0x01)==0x01);//等待切換完成
CLK_CKDIVR=0x00;//LSI不分頻
CLK_SWCR&=(~0x02);//關(guān)閉切換
}
voidSwitch_HSISpeed(void)
{
CLK_SWCR|=0x02;//開(kāi)啟切換
CLK_ICKR|=0x01;//開(kāi)啟內(nèi)部HSI
while(!(CLK_ICKR&0x02));//HSI準(zhǔn)備就緒
CLK_SWR=0xe1;//HSI為主時(shí)鐘源
while((CLK_SWCR&0x01)==0x01);//等待切換完成
CLK_CKDIVR=0x00;//HSI不分頻
CLK_SWCR&=(~0x02);//關(guān)閉切換
}
如果想直接降頻,只需要設(shè)置始終分頻:
voidSet_CPU_Full_Speed(void)
{
CLK_CKDIVR=0x00;//HSI不分頻
}
voidSet_CPU_Low_Speed(void)
{
CLK_CKDIVR=0x07;//HSI128分頻
}
以上就是初始化時(shí)鐘的代碼,一般用于mian函數(shù)的第一句話,方便以后計(jì)算其他外設(shè)的時(shí)鐘頻率。
附上stm8s在IAR環(huán)境下的項(xiàng)目工程,包括了SPI、IIC、PWM、AWU、USART、EEPROM等片上硬件的初始化代碼。
http://download.csdn.net/detail/devintt/9454188