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