LWIP实现GPRS联网过程中,总是会连不上移动公司的服务器,后来发现这是协议实现与工程实现的一个差别导致的。从PPP连接数据流中可以发现,服务器也向GPRS终端申请IP地址,在被GPRS终端拒绝之后,服务器坚持要求,最后GPRS终端同意服务器使用0x0000的IP地址。这是因为根据PPP协议的规定,PPP链路的双方都必须知道对端IP。但是由于服务器端的IP为0,这会导致LWIP报错。这种情况的出现要依据实际情况而定,有的移动运营商会告知服务器IP,有的如中国移动就不会告知服务器IP。解决的方法是修改LWIP源码。ipcp.c中某处代码为:
if (ho->hisaddr == 0)
{
IPCPDEBUG(LOG_ERR, ("Could not determine remote IP address\n"));
ipcp_close(f->unit, "Could not determine remote IP address");
return;
}
可见若是对端IP为0,LWIP内核会报错,并且直接返回。解决这一问题的办法是使用一个宏定义或者直接注释该段代码,修改如下:
if (ho->hisaddr == 0)
{
#ifdef PPP_HISADDR_WARNING
IPCPDEBUG(LOG_ERR, ("Warning: Remote IP address is 0\n"));
#else
IPCPDEBUG(LOG_ERR, ("Could not determine remote IP address\n"));
ipcp_close(f->unit, "Could not determine remote IP address");
return;
#endif
}
修改后的代码实际上是违反PPP协议的规定的,但是由于GPRS中特殊的应用,在这里做出这样的修改是合适的。