某日,一工程師使用STM8S芯片開(kāi)發(fā)產(chǎn)品,其管腳資源比較緊張。某一GPIO口被復(fù)用為AD輸入 腳做相關(guān)AD檢測(cè)。之后,把該腳AD功能禁用掉,把該口配置切換為帶下降沿觸發(fā)的EXTI觸發(fā)腳,
之后讓芯片進(jìn)入睡眠。當(dāng)然,休眠時(shí)該口處于高電平。 奇怪的是,那樣設(shè)置后根本沒(méi)法喚醒。即使不做休眠,做好切換配置后,直接查看該腳的IDR位的電平,
發(fā)現(xiàn)始終提示為0. 后來(lái)一起查看代碼,發(fā)現(xiàn)在配置AD時(shí),他配置了ADC_TDR寄存器,目的是關(guān)閉跟該腳相關(guān)的GPIO
模塊里的一個(gè)施密特觸發(fā)器。IO口復(fù)用為AD時(shí),關(guān)閉它是合理的。但它作為AD完成使命后,切換為
GPIO功能時(shí),工程師忽略了ADC_TDR寄存器,讓它依舊保持原值。結(jié)果是,AD雖然關(guān)了,但施密特
觸發(fā)器還是關(guān)閉的。麻煩就出在這里。看看下圖就明白了,當(dāng)那施密特被關(guān)閉時(shí),它的輸出始終是0,
即紅色箭頭所指位置。那此時(shí)讀輸入寄存器【IDR】,自然提示輸入為0,還哪來(lái)下降沿呢。 后來(lái),讓他在做從AD切換到GPIO功能時(shí),同時(shí)修改了ADC_TDR寄存器讓施密特
打開(kāi)后就都正常了。
整理:Miler Shao
|