mirror of
https://git.openafs.org/openafs.git
synced 2025-01-22 17:00:15 +00:00
ukernel: get an ip address even when dns and hosts suck
gethostname plus gethostbyname being useless make things fun make things less fun Change-Id: I5595698b0b7f2448b8c86448bedd8b16ab088510 Reviewed-on: http://gerrit.openafs.org/5600 Tested-by: Derrick Brashear <shadow@dementix.org> Reviewed-by: Derrick Brashear <shadow@dementix.org>
This commit is contained in:
parent
7829e71523
commit
6f59c71988
@ -64,6 +64,9 @@
|
||||
# include "afs/sysincludes.h"
|
||||
# include "afsincludes.h"
|
||||
#endif
|
||||
#ifdef UKERNEL
|
||||
# include "rx/rx_prototypes.h"
|
||||
#endif
|
||||
|
||||
typedef struct {
|
||||
char eaddr[6]; /* 6 bytes of ethernet hardware address */
|
||||
@ -405,28 +408,28 @@ static int
|
||||
uuid_get_address(uuid_address_p_t addr)
|
||||
{
|
||||
afs_int32 code;
|
||||
afs_uint32 addr1;
|
||||
struct hostent *he;
|
||||
afs_uint32 addr1 = 0;
|
||||
struct hostent *he = NULL;
|
||||
|
||||
code = gethostname(hostName1, 64);
|
||||
if (code) {
|
||||
printf("gethostname() failed\n");
|
||||
if (!code)
|
||||
he = gethostbyname(hostName1);
|
||||
|
||||
if (he)
|
||||
memcpy(&addr1, he->h_addr_list[0], 4);
|
||||
#ifdef UKERNEL
|
||||
else
|
||||
addr1=rxi_getaddr();
|
||||
#endif
|
||||
|
||||
if (!addr1) {
|
||||
#ifdef AFS_NT40_ENV
|
||||
return ENOENT;
|
||||
#else
|
||||
return errno;
|
||||
#endif
|
||||
}
|
||||
he = gethostbyname(hostName1);
|
||||
if (!he) {
|
||||
printf("Can't find address for '%s'\n", hostName1);
|
||||
#ifdef AFS_NT40_ENV
|
||||
return ENOENT;
|
||||
#else
|
||||
return errno;
|
||||
#endif
|
||||
} else {
|
||||
memcpy(&addr1, he->h_addr_list[0], 4);
|
||||
|
||||
addr1 = ntohl(addr1);
|
||||
memcpy(addr->eaddr, &addr1, 4);
|
||||
addr->eaddr[4] = 0xaa;
|
||||
@ -436,7 +439,6 @@ uuid_get_address(uuid_address_p_t addr)
|
||||
addr->eaddr[0], addr->eaddr[1], addr->eaddr[2], addr->eaddr[3],
|
||||
addr->eaddr[4], addr->eaddr[5]);
|
||||
#endif
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user