TCP/IP的是事件驱动还是时间驱动?
最近在想办法改进自己的状态机,所以研究了一下TCP/IP的状态转换图和定时器,图很好理解,不过在研究LINUX的TCP/IP定时器时,最后只能跟到TCP/IP的定时器是以系统的计时器为基准,将自己的定时器挂到系统计时队列里,到一定时间后系统就会执行所挂在的回调函数进而执行超时操作。但是在研究LWip时,在无OS模式下一直没搞懂它是靠什么知道计时器超时的。。。。收发过程中有通过当前时间和预期时间比较的办法计算是否超时,但如果没数据包收发时又是如何确定的呢? 当然是事件驱动了,超时也是一个事件呀。 LWIP在无全无多任务的情况下,是要主循环不断地调用他的超时检查函数去判断定时器的状态的。详情请见:
http://git.savannah.gnu.org/cgit/lwip.git/tree/src/core/timers.c?id=2b3db52c704dcbd5fa24adb5eea77d9b8d7da394
/**
* Create a one-shot timer (aka timeout). Timeouts are processed in the
* following cases:
* - while waiting for a message using sys_timeouts_mbox_fetch()--》有系统的情况底下
* - by calling sys_check_timeouts() (NO_SYS==1 only) ---》没有系统的情况底下
*
* @param msecs time in milliseconds after that the timer should expire
* @param handler callback function to call when msecs have elapsed
* @param arg argument to pass to the callback function
*/
具体的详情,自己看那个timers.c就很清楚了。当然,不想轮训的话,自己通过CPU里头的定时器也可以。lwip的timeout机制还是很简单的,自己实现sys_timeout也不难。
页:
[1]