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拨号的影响。
以前就用过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拨号的影响。
相关文章推荐
- ORACLE物化视图--物化视图日志如何避免系统时间变化带来的影响
- ORACLE物化视图--物化视图日志如何避免系统时间变化带来的影响
- 花了近两个月的时间设计一BLOG系统,准备开放源码,望大家批评指教
- [VB.NET源码]时间管理系统
- Ubuntu U盘启动盘修复更新后无法启动系统的bug
- Excel单元格内容变化时,自动添加系统时间批注(亲自实践)
- 360发现Android系统存在彩信调用BUG 谷歌称未来将修复
- 通过分析系统日志,统计你的电脑开机时间的小程序PC PowerOn Time,附源码
- 解决 alarm 受影响不按照设置时间间隔运行的bug
- 修改jsp文件,访问时没有变化。可能是修改了系统的时间,,,郁闷呢
- openx开源广告系统修复中文乱码bug问题
- [正式发布]库存管理系统v1.1!修复大量BUG,以及UI显示!
- TextView显示系统时间(秒针变化)
- openx开源广告系统修复中文乱码bug问题
- 关于服务器时间对微博,新闻系统的影响
- [VB.NET源码]时间管理系统
- linux 下系统时间对make的影响
- VB.Net 获取或者转换时间不受系统时间格式影响
- 利用excel的数据有效性记录不随系统时间变化的时间
- 苹果OS X 10.8.4正式版修复大量bug 提高系统兼容性、稳定性和安全性