关于stm32端口的输入输出模式配置的问题
对于stm32的同一个端口,在前一时刻将它配置成输出模式,就可以从该端口输出数据,若下一时刻想从IDR读数据,是不是还要将该端口配制成输入模式呀,但是我在程序中没有发现将...
对于stm32 的同一个端口,在前一时刻将它配置成输出模式,就可以从该端口输出数据,若下一时刻想从IDR读数据,是不是还要将该端口配制成输入模式呀,但是我在程序中没有发现将它配制成输入模式就可以从IDR读取数据了,这是怎么回事
展开
3个回答
展开全部
这是我看到的资料,希望对你有所帮助……
输出配置
当I/O端口被配置为输出时:
●
输出缓冲器被激活
─
开漏模式:输出寄存器上的’0’激活N-MOS,而输出寄存器上的’1’将端口置于高阻状态(P-MOS从不被激活)。
─
推挽模式:输出寄存器上的’0’激活N-MOS,而输出寄存器上的’1’将激活P-MOS。
●
施密特触发输入被激活
●
弱上拉和下拉电阻被禁止
●
出现在I/O脚上的数据在每个APB2时钟被采样到输入数据寄存器
●
在开漏模式时,对输入数据寄存器的读访问可得到I/O状态
●
在推挽式模式时,对输出数据寄存器的读访问得到最后一次写的值。
输出配置
当I/O端口被配置为输出时:
●
输出缓冲器被激活
─
开漏模式:输出寄存器上的’0’激活N-MOS,而输出寄存器上的’1’将端口置于高阻状态(P-MOS从不被激活)。
─
推挽模式:输出寄存器上的’0’激活N-MOS,而输出寄存器上的’1’将激活P-MOS。
●
施密特触发输入被激活
●
弱上拉和下拉电阻被禁止
●
出现在I/O脚上的数据在每个APB2时钟被采样到输入数据寄存器
●
在开漏模式时,对输入数据寄存器的读访问可得到I/O状态
●
在推挽式模式时,对输出数据寄存器的读访问得到最后一次写的值。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你看看你读出来的数据是有规律的还是每次都不一样,或者是不是前一次写入的数据。
一般都是需要,切换GPIO的方向的。我记得stm32的io口有复用推挽输出。
一般都是需要,切换GPIO的方向的。我记得stm32的io口有复用推挽输出。
追问
详细情况是这样的:1:将端口设置为推挽输出模式,然后就可以从该端口输出数据,2:一段时间之后同样是利用这一端口从LCD的一个寄存器读取数据,该寄存器的数据是变化的并且不是从GPIO口输出的数据,为什么不在1和2之间把GPIO的端口设置成输入模式就可以从IDR读取数据了呢
追答
需要设置的,不然读出来的是错的,你不必纠结为什么能够读出来,只要你按照正确的步骤去写代码就行了。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
能不能读出数据,都得按照正常的规则办吧。肯定是要先切换输入输出模式的。习惯要养好。。呵呵
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询