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拨号的影响。