PIC久没摸了,寄存器也全忘了,可我只在这给你谈谈串口调试的经验,第一在刚开始时最好用低波特率调试,如1200甚至用600,这样先把时钟上的误差,硬件上的原因排出,在能收到后再加高波特率,在这加高过程中你有可能看到很多怪现象,多半就因这二个原因造成的,这是很重要的,很多一来就用高波特率给自己找了很多麻烦,再就是通讯机两边的各种位数一定要设的一致,这再试试去吧,
函数_write_com和_delay_ms在中断和主程序中都有调用,会导致混合调用。
英文写的很明白了,会上网就不会查英文单词吗还是不知道什么是混合调用。
比如你主程序调用_delay_ms做100ms延时,正在做循环延时,结果一个中断进来,中断处理程序也调用了_delay_ms,结果就是_delay_ms原有的数据冲掉,从头再来,这次执行是对的。等中断处理完,再执行走到一半的_delay_ms程序,因为数据被冲掉了,天知道是什么结果。
用的是PIC的C语言吧?不好好看书,PIC的C语言最不灵光的(之一)就是程序的混合调用。资源不够啊!
其它单片机看编译器,有的也会报错,有的会很聪明(比如KEIL)的知道要保护原始数据,在中断里帮你保护了。
STM32停止模式是一种省电模式,可以将芯片的功耗降至最低,但同时也会导致一些外设无法正常工作。在停止模式下,串口等外设会被关闭,需要通过唤醒来重新启动。
如果在停止模式下唤醒后串口不通,可能是以下原因:
1 时钟配置问题:在停止模式下,芯片的时钟会被关闭,唤醒后需要重新配置时钟。如果时钟配置不正确,可能会导致串口无法正常工作。需要检查时钟配置是否正确。
2 中断配置问题:如果串口中断没有正确配置,可能会导致串口无法正常工作。需要检查中断配置是否正确。
3 电源管理问题:在停止模式下,芯片的电源管理也会被关闭,唤醒后需要重新配置电源管理。如果电源管理配置不正确,可能会导致串口无法正常工作。需要检查电源管理配置是否正确。
4 程序问题:如果程序中存在问题,可能会导致串口无法正常工作。需要检查程序是否正确。
综上所述,如果在停止模式下唤醒后串口不通,需要检查时钟配置、中断配置、电源管理配置和程序是否正确。如果以上都没有问题,可能需要进一步调试和排查。
PIC18的串口,啥时候用得上这么多的头文件??你从哪里抄来的程序?
我平时用PIC18F4680,习惯就只加载#include <PIC18F4680h>,不管是串口、AD、CAN等都没用过你所说的那些头文件。
以上就是关于pic单片机串口问题全部的内容,包括:pic单片机串口问题、PIC单片机与PC机的串口通信程序出现下面的错误,这是什么错误啊错误原因可能是什么请单片机高手指点、stm32停止模式唤醒串口不通等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)