EthenetIP
Posted: Thu Sep 18, 2014 8:50 pm
				
				I have been using this 'variable' to tell me what IP address the netburner module is accessible on. If EthernetIP == 0, there is no ethernet available, otherwise it is equal to the IP address. This was all working fine until AutoIP was introduced, now I find that if the IP address being used is generated by the AutoIP function, EthernetIP remains at zero.
Is there a simple way to find which IP address is being used, regardless of whether it is static, DHCP'd or AutoIP'd, I just want some function that will return the IP address being used (as it appears in IPSetup or AutoUpdate)
this is my initialisation, I do not time out on getting DHCP'd on powerup, I want to handle situation where the ethernet is not necessarily connected at powerup, but should be able to be connected / disconnected to either a network (DHCP) or a laptop (AutoIP) at any time
I have come up with a function that I think will do what I want
this is not intended to be useful in all systems, my system has just the single ethernet connection, but the ip address could be static, dhcp or autoip. I will be testing soon.
			Is there a simple way to find which IP address is being used, regardless of whether it is static, DHCP'd or AutoIP'd, I just want some function that will return the IP address being used (as it appears in IPSetup or AutoUpdate)
this is my initialisation, I do not time out on getting DHCP'd on powerup, I want to handle situation where the ethernet is not necessarily connected at powerup, but should be able to be connected / disconnected to either a network (DHCP) or a laptop (AutoIP) at any time
Code: Select all
    InitializeStack();
    if (EthernetIP == 0)
    {
        DhcpObject * pDhcpObj = new DhcpObject();
        pDhcpObj->StartDHCP();
    }
    OSChangePrio(MY_MAIN_PRIO);
    EnableAutoUpdate();
    EnableSmartTraps();
    EnableTaskMonitor();
I have come up with a function that I think will do what I want
Code: Select all
IPADDR GetCurrentIP(void)
{
	// search through interface blocks in sequence until a non-zero IP is found, return the non-zero IP, or return 0 if cannot find any non-zero IP
	IPADDR ip=0;
	int i=0;
	while( !ip && (i=GetnextInterface(i)) )		// GetFirstInterface() is the same as GetnextInterface(0)
	{
		ip = InterfaceIP(i);
	}
	return ip;
}