1. read函数读串口的过程中,如果有线程切换而且恰好是发生在read的过程中,read读的动作暂停。当线程切换回来后,造成读超时。
答:在一次数据发,收之前将线程优先级用nice(-20)升高,禁止线程切换。 请求,接受完成之后再用nice(20)将优先级还原。
在Linux中,进程运行的优先级分为-20~19等40个级别,其中,数值越小运行优先级越高,数值越大运行优先级越低。
2.丢包率非常高,发现是write函数还没有写完,就将io拉低。 解决方法
答:write后加上如下代码。
do {
ioctl(fd, TIOCSERGETLSR, &status);
} while( !status & TIOCSER_TEMT );
等待发送缓冲区为空时再往下执行。
3.全双工改为单工后收到的数据总是有自己的数据
答:将读到的数据跳过第一个数据包。第二个即为自己的数据。
4.概率性挂机后又来一个未接电话
答:程序中用strcmp函数比较两个数组中的电话号码,数组长度为8个字节,电话号码占两个字节,其他都用0xff填充,所以比较长度超出了数组之外。
出现概率性又来未接来电。
5.debugstation下发一串基站的重启命令,结果只有传输接口重启了。其他基站没有重启。
答:重启命令的机制是,传输接口收到命令后转发给其他基站,然后sleep(1) 一秒保证命令已经被发出去, 然后自己再重启。
但sleep(1) 导致了整个线程的挂起。命令反而没有发出去。 解决办法是置一个重启标志,在polltask中轮询这个标志,如果检测到则在polltask线程中sleep,然后重启。