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