您的位置:首页 > 运维架构

openwrt pppd源码bug修复(系统时间变化对pppd的影响)

2016-09-18 16:57 661 查看
openwrt 版本:15.05

以前就用过pppd,不过是arm架构的linux,而且当时的开发板都带有实时时钟,没有发现过系统时间变化对pppd拨号的影响。

现在在openwrt上进行pppd拨号,偶尔发现了这个问题。

这个问题就是,假如当前时间是18:00:00,在拨号的时候,我突然把时间变为18:10:00.那么pppd进程就会等待这个时间差,也就是说它的超时时间变成了10分钟了。这样就会影响pppd的正常拨号。当然如果你已经拨号成功,那么此操作对pppd没有影响。

分析pppd源码的main.c,会发现已经有了一个补丁文件



该补丁文件试图去修复,系统时间对pppd拨号的影响。通过check_time函数去弥补时间变化产生的差值,但它只修复了时间变小所产生的bug,没有修复时间变大所产生的bug。

时间变小就是把时间往前调整,时间变大就是把时间往后调整。

通过下面修改,可修复时间变大对pppd拨号所产生的影响,本人亲测ok。



就是这么简单的在timeout函数中调用check_time函数,加上时间偏差。解决系统时间对pppd拨号的影响。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: