Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 12 Jan 2001 13:08:32 -0500
From:      Larry Baird <lab@gta.com>
To:        freebsd-net@freebsd.org
Subject:   Strange source address problem
Message-ID:  <3A5F4820.634D626B@gta.com>

next in thread | raw e-mail | index | archive | help
This is a multi-part message in MIME format.
--------------BDE51CF92238A25D9C323930
Content-Type: text/plain; charset=us-ascii
Content-Transfer-Encoding: 7bit

Hopefully somebody can shed some light in helping me to understand 
something I am seeing on a 4.2 box.  I am experimenting with a daemon 
that implements something very close to the VRRP (Virtual Router 
Redundancy Protocol).   The VRRP portion of the daemon works correctly.  
The problem I am having has to do with the source IP address after a
host
has transitioned from "slave" to "master" mode.  

The problem can be illustrated on a standard 4.2 system not
running the VRRP daemon by the following command line actions:

Script started on Fri Jan 12 12:42:35 2001
sukebe# ifconfig xl0 inet 192.168.23.85
sukebe#
sukebe# ifconfig xl0
xl0: flags=8843<UP,BROADCAST,RUNNING,SIMPLEX,MULTICAST> mtu 1500
        inet6 fe80::260:8ff:feaf:2bf5%xl0 prefixlen 64 scopeid 0x1 
        inet 192.168.23.85 netmask 0xffffff00 broadcast 192.168.23.255
        ether 00:60:08:af:2b:f5 
        media: autoselect (none) status: no carrier
        supported media: autoselect 100baseTX <full-duplex> 100baseTX
10baseT/UTP <full-duplex> 10baseT/UTP 100baseTX <hw-loopback>
sukebe#
sukebe# ./getLocalIP 192.168.23.90
local = 192.168.23.85:1178
sukebe#
sukebe# ifconfig xl0 inet 192.168.23.86
sukebe#
sukebe# ifconfig xl0
xl0: flags=8843<UP,BROADCAST,RUNNING,SIMPLEX,MULTICAST> mtu 1500
        inet6 fe80::260:8ff:feaf:2bf5%xl0 prefixlen 64 scopeid 0x1 
        inet 192.168.23.86 netmask 0xffffff00 broadcast 192.168.23.255
        ether 00:60:08:af:2b:f5 
        media: autoselect (none) status: no carrier
        supported media: autoselect 100baseTX <full-duplex> 100baseTX
10baseT/UTP <full-duplex> 10baseT/UTP 100baseTX <hw-loopback>
sukebe#
sukebe# ./getLocalIP 192.168.23.90
local = 192.168.23.85:1179

^^^^ why is 192.168.23.85 still showing up?? This address should be
gone.
sukebe#
sukebe# exit

Script done on Fri Jan 12 12:44:35 2001

I have attached the source code to the getLocalIP program.  Can 
anybody explain this?  Thanks in advance for your help.


-- 
------------------------------------------------------------------------
Larry Baird                             
Global Technology Associates, Inc.  | Orlando, FL
Email: lab@gta.com                  | TEL 407-380-0220, FAX 407-380-6080
--------------BDE51CF92238A25D9C323930
Content-Type: text/plain; charset=us-ascii;
 name="getLocalIP.c"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline;
 filename="getLocalIP.c"

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>

#include <sys/types.h>
#include <sys/socket.h>

#include <netinet/in.h>
#include <arpa/inet.h>

int main(int argc, char *argv[])
{
    int s;

    if ( argc != 2 )
	fprintf( stderr, "USAGE: %s destIP[:port]\n", argv[0] );

    else {
	if ( (s = socket( PF_INET, SOCK_DGRAM, 0 )) < 0 )
	    perror( "Unable to create socket" );

	else {
	    struct sockaddr_in servAddr;
	    short              port = 7;
	    char              *p;

	    if ((p = strchr(argv[1], ':')) != NULL) {
		port = atoi(p + 1);
		*p = 0;
	    }

	    bzero(&servAddr, sizeof(servAddr));

	    servAddr.sin_family = AF_INET;
	    servAddr.sin_port   = htons( port );

	    if ( ! inet_aton( argv[1], &servAddr.sin_addr ) )
		fprintf( stderr, "IP address invalid.\n" );
	    else {
		if ( connect( s,
			      (struct sockaddr *)&servAddr,
			      sizeof(servAddr) ) )
		    perror( "connect() failed" );
		else {
		    struct sockaddr_in local;
		    int                local_len = sizeof(local);

		    if ( getsockname( s,
				      (struct sockaddr *)&local,
				      &local_len))
			perror( "getsockname() failed" );
		    else {
			printf( "local = %s:%d\n",
				inet_ntoa(local.sin_addr),
				ntohs(local.sin_port));
			exit( 0 );
		    }
		}
	    }

	    close(s);
	}
    }

    exit( 1 );
}

--------------BDE51CF92238A25D9C323930--



To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-net" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3A5F4820.634D626B>