mirror of
https://gitlab.isc.org/isc-projects/dhcp
synced 2025-09-01 06:45:27 +00:00
*** empty log message ***
This commit is contained in:
@@ -43,6 +43,7 @@
|
|||||||
#include "dhctoken.h"
|
#include "dhctoken.h"
|
||||||
|
|
||||||
TIME cur_time;
|
TIME cur_time;
|
||||||
|
unsigned char packbuf [65536]; /* Should cover the gnarliest MTU... */
|
||||||
|
|
||||||
int main (argc, argv, envp)
|
int main (argc, argv, envp)
|
||||||
int argc;
|
int argc;
|
||||||
@@ -51,7 +52,23 @@ int main (argc, argv, envp)
|
|||||||
{
|
{
|
||||||
FILE *cfile = stdin;
|
FILE *cfile = stdin;
|
||||||
char *val;
|
char *val;
|
||||||
|
struct sockaddr_in name;
|
||||||
|
int sock;
|
||||||
|
int flag;
|
||||||
int token;
|
int token;
|
||||||
|
struct dhcp_packet incoming, raw;
|
||||||
|
struct packet ip, outgoing;
|
||||||
|
struct sockaddr_in from, to;
|
||||||
|
struct iaddr ifrom;
|
||||||
|
int fromlen = sizeof from;
|
||||||
|
int max = 0;
|
||||||
|
int count;
|
||||||
|
int result;
|
||||||
|
int i;
|
||||||
|
struct host_decl decl;
|
||||||
|
int xid = 1;
|
||||||
|
|
||||||
|
memset (&ip, 0, sizeof ip);
|
||||||
|
|
||||||
/* Set up the initial dhcp option universe. */
|
/* Set up the initial dhcp option universe. */
|
||||||
initialize_universes ();
|
initialize_universes ();
|
||||||
@@ -59,31 +76,164 @@ int main (argc, argv, envp)
|
|||||||
/* Get the current time... */
|
/* Get the current time... */
|
||||||
GET_TIME (&cur_time);
|
GET_TIME (&cur_time);
|
||||||
|
|
||||||
|
name.sin_family = AF_INET;
|
||||||
|
name.sin_port = htons (2000);
|
||||||
|
name.sin_addr.s_addr = htonl (INADDR_ANY);
|
||||||
|
memset (name.sin_zero, 0, sizeof (name.sin_zero));
|
||||||
|
|
||||||
|
/* List addresses on which we're listening. */
|
||||||
|
note ("Receiving on %s, port %d",
|
||||||
|
inet_ntoa (name.sin_addr), htons (name.sin_port));
|
||||||
|
if ((sock = socket (AF_INET, SOCK_DGRAM, IPPROTO_UDP)) < 0)
|
||||||
|
error ("Can't create dhcp socket: %m");
|
||||||
|
|
||||||
|
flag = 1;
|
||||||
|
if (setsockopt (sock, SOL_SOCKET, SO_REUSEADDR,
|
||||||
|
&flag, sizeof flag) < 0)
|
||||||
|
error ("Can't set SO_REUSEADDR option on dhcp socket: %m");
|
||||||
|
|
||||||
|
if (setsockopt (sock, SOL_SOCKET, SO_BROADCAST,
|
||||||
|
&flag, sizeof flag) < 0)
|
||||||
|
error ("Can't set SO_BROADCAST option on dhcp socket: %m");
|
||||||
|
|
||||||
|
if (bind (sock, (struct sockaddr *)&name, sizeof name) < 0)
|
||||||
|
error ("Can't bind to dhcp address: %m");
|
||||||
|
|
||||||
do {
|
do {
|
||||||
token = peek_token (&val, cfile);
|
fd_set r, w, x;
|
||||||
if (token == EOF)
|
FD_ZERO (&r);
|
||||||
break;
|
FD_ZERO (&w);
|
||||||
parse_client_statement (cfile);
|
FD_ZERO (&x);
|
||||||
|
FD_SET (sock, &r);
|
||||||
|
FD_SET (0, &r); /* stdin */
|
||||||
|
|
||||||
|
if (select (sock + 1, &r, &w, &x, (struct timeval *)0) < 0) {
|
||||||
|
error ("select: %m");
|
||||||
|
}
|
||||||
|
if (FD_ISSET (sock, &r)) {
|
||||||
|
if ((result =
|
||||||
|
recvfrom (sock, packbuf, sizeof packbuf, 0,
|
||||||
|
(struct sockaddr *)&from, &fromlen))
|
||||||
|
< 0) {
|
||||||
|
warn ("recvfrom failed: %m");
|
||||||
|
sleep (5);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
note ("request from %s, port %d",
|
||||||
|
inet_ntoa (from.sin_addr),
|
||||||
|
htons (from.sin_port));
|
||||||
|
ifrom.len = 4;
|
||||||
|
memcpy (ifrom.iabuf, &from.sin_addr, ifrom.len);
|
||||||
|
memcpy (&incoming, packbuf, result);
|
||||||
|
memset (&ip, 0, sizeof ip);
|
||||||
|
ip.raw = &incoming;
|
||||||
|
ip.packet_length = result;
|
||||||
|
ip.client_port = ntohs (from.sin_port);
|
||||||
|
ip.client_addr = ifrom;
|
||||||
|
ip.client_sock = sock;
|
||||||
|
parse_options (&ip);
|
||||||
|
printf ("\nPacket from %s, port %d\n",
|
||||||
|
piaddr (ip.client_addr), ip.client_port);
|
||||||
|
for (i = 0; i < 256; i++)
|
||||||
|
if (ip.options [i].len)
|
||||||
|
printf ("%s = %s;\n",
|
||||||
|
dhcp_options [i].name,
|
||||||
|
pretty_print_option
|
||||||
|
(i,
|
||||||
|
ip.options [i].data,
|
||||||
|
ip.options [i].len));
|
||||||
|
} else if (FD_ISSET (0, &r)) {
|
||||||
|
int bufs = 0;
|
||||||
|
|
||||||
|
/* Parse a packet declaration from stdin, or
|
||||||
|
exit if we've hit EOF. */
|
||||||
|
token = peek_token (&val, cfile);
|
||||||
|
if (token == EOF)
|
||||||
|
break;
|
||||||
|
memset (&decl, 0, sizeof decl);
|
||||||
|
parse_client_statement (cfile, &decl);
|
||||||
|
|
||||||
|
/* Fill in a packet based on the information
|
||||||
|
entered by the user. */
|
||||||
|
memset (&outgoing, 0, sizeof outgoing);
|
||||||
|
memset (&raw, 0, sizeof raw);
|
||||||
|
outgoing.raw = &raw;
|
||||||
|
|
||||||
|
/* Copy in the filename if given; otherwise, flag
|
||||||
|
the filename buffer as available for options. */
|
||||||
|
if (decl.filename)
|
||||||
|
strncpy (raw.file,
|
||||||
|
decl.filename, sizeof raw.file);
|
||||||
|
else
|
||||||
|
bufs |= 1;
|
||||||
|
|
||||||
|
/* Copy in the server name if given; otherwise, flag
|
||||||
|
the server_name buffer as available for options. */
|
||||||
|
if (decl.server_name)
|
||||||
|
strncpy (raw.sname,
|
||||||
|
decl.server_name, sizeof raw.sname);
|
||||||
|
else
|
||||||
|
bufs |= 2;
|
||||||
|
|
||||||
|
if (decl.interface_count) {
|
||||||
|
memcpy (raw.chaddr,
|
||||||
|
decl.interfaces [0].haddr,
|
||||||
|
decl.interfaces [0].hlen);
|
||||||
|
raw.htype = decl.interfaces [0].htype;
|
||||||
|
raw.hlen = decl.interfaces [0].hlen;
|
||||||
|
if (decl.interface_count > 1)
|
||||||
|
note ("Only one interface used.");
|
||||||
|
} else {
|
||||||
|
raw.htype = raw.hlen = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
cons_options ((struct packet *)0,
|
||||||
|
&outgoing, &decl, bufs);
|
||||||
|
memset (&raw.ciaddr, 0, sizeof raw.ciaddr);
|
||||||
|
memset (&raw.yiaddr, 0, sizeof raw.ciaddr);
|
||||||
|
memset (&raw.siaddr, 0, sizeof raw.ciaddr);
|
||||||
|
memset (&raw.giaddr, 0, sizeof raw.ciaddr);
|
||||||
|
|
||||||
|
raw.xid = xid++;
|
||||||
|
raw.xid = htons (raw.xid);
|
||||||
|
raw.secs = 0;
|
||||||
|
raw.flags = 0;
|
||||||
|
raw.hops = 0;
|
||||||
|
raw.op = BOOTREQUEST;
|
||||||
|
|
||||||
|
to.sin_port = htons (2001);
|
||||||
|
inet_aton ("206.119.204.48", &to.sin_addr);
|
||||||
|
to.sin_family = AF_INET;
|
||||||
|
to.sin_len = sizeof to;
|
||||||
|
memset (to.sin_zero, 0, sizeof to.sin_zero);
|
||||||
|
|
||||||
|
note ("Sending dhcp request to %s, port %d",
|
||||||
|
inet_ntoa (to.sin_addr), htons (to.sin_port));
|
||||||
|
|
||||||
|
errno = 0;
|
||||||
|
result = sendto (sock, &raw,
|
||||||
|
outgoing.packet_length,
|
||||||
|
0, (struct sockaddr *)&to, sizeof to);
|
||||||
|
if (result < 0)
|
||||||
|
warn ("sendto: %m");
|
||||||
|
}
|
||||||
} while (1);
|
} while (1);
|
||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* statement :== host_statement */
|
/* statement :== host_statement */
|
||||||
|
|
||||||
void parse_client_statement (cfile)
|
void parse_client_statement (cfile, decl)
|
||||||
FILE *cfile;
|
FILE *cfile;
|
||||||
|
struct host_decl *decl;
|
||||||
{
|
{
|
||||||
char *val;
|
char *val;
|
||||||
jmp_buf bc;
|
jmp_buf bc;
|
||||||
struct host_decl decl;
|
|
||||||
int token;
|
int token;
|
||||||
struct dhcp_packet raw;
|
|
||||||
struct packet outpacket, inpacket;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
switch (next_token (&val, cfile)) {
|
switch (next_token (&val, cfile)) {
|
||||||
case PACKET:
|
case PACKET:
|
||||||
memset (&decl, 0, sizeof decl);
|
memset (decl, 0, sizeof decl);
|
||||||
if (!setjmp (bc)) {
|
if (!setjmp (bc)) {
|
||||||
do {
|
do {
|
||||||
token = peek_token (&val, cfile);
|
token = peek_token (&val, cfile);
|
||||||
@@ -91,31 +241,9 @@ void parse_client_statement (cfile)
|
|||||||
token = next_token (&val, cfile);
|
token = next_token (&val, cfile);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
parse_host_decl (cfile, &bc, &decl);
|
parse_host_decl (cfile, &bc, decl);
|
||||||
} while (1);
|
} while (1);
|
||||||
}
|
}
|
||||||
for (i = 0; i < 256; i++)
|
|
||||||
if (decl.options [i])
|
|
||||||
printf ("option %s\n", dhcp_options [i].name);
|
|
||||||
memset (&outpacket, 0, sizeof outpacket);
|
|
||||||
memset (&raw, 0, sizeof raw);
|
|
||||||
outpacket.raw = &raw;
|
|
||||||
cons_options ((struct packet *)0, &outpacket, &decl, 3);
|
|
||||||
inpacket.raw = &raw;
|
|
||||||
inpacket.packet_length = outpacket.packet_length;
|
|
||||||
parse_options (&inpacket);
|
|
||||||
for (i = 0; i < 256; i++)
|
|
||||||
if (inpacket.options [i].len)
|
|
||||||
printf ("%s=%s\n",
|
|
||||||
dhcp_options [i].name,
|
|
||||||
pretty_print_option
|
|
||||||
(i,
|
|
||||||
inpacket.options [i].data,
|
|
||||||
inpacket.options [i].len));
|
|
||||||
for (i = 0; i < 20; i++)
|
|
||||||
printf ("%s%x", i == 0 ? "" : " ",
|
|
||||||
(unsigned char)raw.options [i]);
|
|
||||||
printf ("\noptions_valid: %d\n", inpacket.options_valid);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
parse_warn ("expecting a declaration.");
|
parse_warn ("expecting a declaration.");
|
||||||
|
@@ -250,13 +250,6 @@ void cons_options (inpacket, outpacket, hp, overload)
|
|||||||
if (!tree_evaluate (hp -> options [code]))
|
if (!tree_evaluate (hp -> options [code]))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
printf ("hp -> options [%d] = %x %d %d %d %x\n",
|
|
||||||
code, (unsigned long)(hp -> options [code] -> value),
|
|
||||||
hp -> options [code] -> len, hp -> options [code] -> buf_size,
|
|
||||||
hp -> options [code] -> timeout,
|
|
||||||
(unsigned long)(hp -> options [code] -> tree));
|
|
||||||
printf ("buffer = %x buflen = %d bufix = %d\n",
|
|
||||||
(unsigned int)buffer, buflen, bufix);
|
|
||||||
/* We should now have a constant length for the option. */
|
/* We should now have a constant length for the option. */
|
||||||
length = (hp -> options [code] -> len - stored_length [code]);
|
length = (hp -> options [code] -> len - stored_length [code]);
|
||||||
|
|
||||||
|
@@ -105,6 +105,7 @@ struct dns_host_entry *enter_dns_host (name)
|
|||||||
strcpy (dh -> hostname, name);
|
strcpy (dh -> hostname, name);
|
||||||
dh -> data = (unsigned char *)0;
|
dh -> data = (unsigned char *)0;
|
||||||
dh -> data_len = 0;
|
dh -> data_len = 0;
|
||||||
|
dh -> buf_len = 0;
|
||||||
dh -> timeout = 0;
|
dh -> timeout = 0;
|
||||||
return dh;
|
return dh;
|
||||||
}
|
}
|
||||||
@@ -354,9 +355,10 @@ static TIME do_host_lookup (bufix, bufp, bufcount, dns)
|
|||||||
|
|
||||||
/* Addresses are conveniently stored one to the buffer, so we
|
/* Addresses are conveniently stored one to the buffer, so we
|
||||||
have to copy them out one at a time... :'( */
|
have to copy them out one at a time... :'( */
|
||||||
for (i = 0; i < new_len / h -> h_length; i++)
|
for (i = 0; i < new_len / h -> h_length; i++) {
|
||||||
memcpy (dns -> data + h -> h_length * i,
|
memcpy (dns -> data + h -> h_length * i,
|
||||||
h -> h_addr_list [i], h -> h_length);
|
h -> h_addr_list [i], h -> h_length);
|
||||||
|
}
|
||||||
debug ("dns -> data: %x h -> h_addr_list [0]: %x",
|
debug ("dns -> data: %x h -> h_addr_list [0]: %x",
|
||||||
*(int *)(dns -> data), h -> h_addr_list [0]);
|
*(int *)(dns -> data), h -> h_addr_list [0]);
|
||||||
dns -> data_len = new_len;
|
dns -> data_len = new_len;
|
||||||
|
194
dhclient.c
194
dhclient.c
@@ -43,6 +43,7 @@
|
|||||||
#include "dhctoken.h"
|
#include "dhctoken.h"
|
||||||
|
|
||||||
TIME cur_time;
|
TIME cur_time;
|
||||||
|
unsigned char packbuf [65536]; /* Should cover the gnarliest MTU... */
|
||||||
|
|
||||||
int main (argc, argv, envp)
|
int main (argc, argv, envp)
|
||||||
int argc;
|
int argc;
|
||||||
@@ -51,7 +52,23 @@ int main (argc, argv, envp)
|
|||||||
{
|
{
|
||||||
FILE *cfile = stdin;
|
FILE *cfile = stdin;
|
||||||
char *val;
|
char *val;
|
||||||
|
struct sockaddr_in name;
|
||||||
|
int sock;
|
||||||
|
int flag;
|
||||||
int token;
|
int token;
|
||||||
|
struct dhcp_packet incoming, raw;
|
||||||
|
struct packet ip, outgoing;
|
||||||
|
struct sockaddr_in from, to;
|
||||||
|
struct iaddr ifrom;
|
||||||
|
int fromlen = sizeof from;
|
||||||
|
int max = 0;
|
||||||
|
int count;
|
||||||
|
int result;
|
||||||
|
int i;
|
||||||
|
struct host_decl decl;
|
||||||
|
int xid = 1;
|
||||||
|
|
||||||
|
memset (&ip, 0, sizeof ip);
|
||||||
|
|
||||||
/* Set up the initial dhcp option universe. */
|
/* Set up the initial dhcp option universe. */
|
||||||
initialize_universes ();
|
initialize_universes ();
|
||||||
@@ -59,31 +76,164 @@ int main (argc, argv, envp)
|
|||||||
/* Get the current time... */
|
/* Get the current time... */
|
||||||
GET_TIME (&cur_time);
|
GET_TIME (&cur_time);
|
||||||
|
|
||||||
|
name.sin_family = AF_INET;
|
||||||
|
name.sin_port = htons (2000);
|
||||||
|
name.sin_addr.s_addr = htonl (INADDR_ANY);
|
||||||
|
memset (name.sin_zero, 0, sizeof (name.sin_zero));
|
||||||
|
|
||||||
|
/* List addresses on which we're listening. */
|
||||||
|
note ("Receiving on %s, port %d",
|
||||||
|
inet_ntoa (name.sin_addr), htons (name.sin_port));
|
||||||
|
if ((sock = socket (AF_INET, SOCK_DGRAM, IPPROTO_UDP)) < 0)
|
||||||
|
error ("Can't create dhcp socket: %m");
|
||||||
|
|
||||||
|
flag = 1;
|
||||||
|
if (setsockopt (sock, SOL_SOCKET, SO_REUSEADDR,
|
||||||
|
&flag, sizeof flag) < 0)
|
||||||
|
error ("Can't set SO_REUSEADDR option on dhcp socket: %m");
|
||||||
|
|
||||||
|
if (setsockopt (sock, SOL_SOCKET, SO_BROADCAST,
|
||||||
|
&flag, sizeof flag) < 0)
|
||||||
|
error ("Can't set SO_BROADCAST option on dhcp socket: %m");
|
||||||
|
|
||||||
|
if (bind (sock, (struct sockaddr *)&name, sizeof name) < 0)
|
||||||
|
error ("Can't bind to dhcp address: %m");
|
||||||
|
|
||||||
do {
|
do {
|
||||||
token = peek_token (&val, cfile);
|
fd_set r, w, x;
|
||||||
if (token == EOF)
|
FD_ZERO (&r);
|
||||||
break;
|
FD_ZERO (&w);
|
||||||
parse_client_statement (cfile);
|
FD_ZERO (&x);
|
||||||
|
FD_SET (sock, &r);
|
||||||
|
FD_SET (0, &r); /* stdin */
|
||||||
|
|
||||||
|
if (select (sock + 1, &r, &w, &x, (struct timeval *)0) < 0) {
|
||||||
|
error ("select: %m");
|
||||||
|
}
|
||||||
|
if (FD_ISSET (sock, &r)) {
|
||||||
|
if ((result =
|
||||||
|
recvfrom (sock, packbuf, sizeof packbuf, 0,
|
||||||
|
(struct sockaddr *)&from, &fromlen))
|
||||||
|
< 0) {
|
||||||
|
warn ("recvfrom failed: %m");
|
||||||
|
sleep (5);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
note ("request from %s, port %d",
|
||||||
|
inet_ntoa (from.sin_addr),
|
||||||
|
htons (from.sin_port));
|
||||||
|
ifrom.len = 4;
|
||||||
|
memcpy (ifrom.iabuf, &from.sin_addr, ifrom.len);
|
||||||
|
memcpy (&incoming, packbuf, result);
|
||||||
|
memset (&ip, 0, sizeof ip);
|
||||||
|
ip.raw = &incoming;
|
||||||
|
ip.packet_length = result;
|
||||||
|
ip.client_port = ntohs (from.sin_port);
|
||||||
|
ip.client_addr = ifrom;
|
||||||
|
ip.client_sock = sock;
|
||||||
|
parse_options (&ip);
|
||||||
|
printf ("\nPacket from %s, port %d\n",
|
||||||
|
piaddr (ip.client_addr), ip.client_port);
|
||||||
|
for (i = 0; i < 256; i++)
|
||||||
|
if (ip.options [i].len)
|
||||||
|
printf ("%s = %s;\n",
|
||||||
|
dhcp_options [i].name,
|
||||||
|
pretty_print_option
|
||||||
|
(i,
|
||||||
|
ip.options [i].data,
|
||||||
|
ip.options [i].len));
|
||||||
|
} else if (FD_ISSET (0, &r)) {
|
||||||
|
int bufs = 0;
|
||||||
|
|
||||||
|
/* Parse a packet declaration from stdin, or
|
||||||
|
exit if we've hit EOF. */
|
||||||
|
token = peek_token (&val, cfile);
|
||||||
|
if (token == EOF)
|
||||||
|
break;
|
||||||
|
memset (&decl, 0, sizeof decl);
|
||||||
|
parse_client_statement (cfile, &decl);
|
||||||
|
|
||||||
|
/* Fill in a packet based on the information
|
||||||
|
entered by the user. */
|
||||||
|
memset (&outgoing, 0, sizeof outgoing);
|
||||||
|
memset (&raw, 0, sizeof raw);
|
||||||
|
outgoing.raw = &raw;
|
||||||
|
|
||||||
|
/* Copy in the filename if given; otherwise, flag
|
||||||
|
the filename buffer as available for options. */
|
||||||
|
if (decl.filename)
|
||||||
|
strncpy (raw.file,
|
||||||
|
decl.filename, sizeof raw.file);
|
||||||
|
else
|
||||||
|
bufs |= 1;
|
||||||
|
|
||||||
|
/* Copy in the server name if given; otherwise, flag
|
||||||
|
the server_name buffer as available for options. */
|
||||||
|
if (decl.server_name)
|
||||||
|
strncpy (raw.sname,
|
||||||
|
decl.server_name, sizeof raw.sname);
|
||||||
|
else
|
||||||
|
bufs |= 2;
|
||||||
|
|
||||||
|
if (decl.interface_count) {
|
||||||
|
memcpy (raw.chaddr,
|
||||||
|
decl.interfaces [0].haddr,
|
||||||
|
decl.interfaces [0].hlen);
|
||||||
|
raw.htype = decl.interfaces [0].htype;
|
||||||
|
raw.hlen = decl.interfaces [0].hlen;
|
||||||
|
if (decl.interface_count > 1)
|
||||||
|
note ("Only one interface used.");
|
||||||
|
} else {
|
||||||
|
raw.htype = raw.hlen = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
cons_options ((struct packet *)0,
|
||||||
|
&outgoing, &decl, bufs);
|
||||||
|
memset (&raw.ciaddr, 0, sizeof raw.ciaddr);
|
||||||
|
memset (&raw.yiaddr, 0, sizeof raw.ciaddr);
|
||||||
|
memset (&raw.siaddr, 0, sizeof raw.ciaddr);
|
||||||
|
memset (&raw.giaddr, 0, sizeof raw.ciaddr);
|
||||||
|
|
||||||
|
raw.xid = xid++;
|
||||||
|
raw.xid = htons (raw.xid);
|
||||||
|
raw.secs = 0;
|
||||||
|
raw.flags = 0;
|
||||||
|
raw.hops = 0;
|
||||||
|
raw.op = BOOTREQUEST;
|
||||||
|
|
||||||
|
to.sin_port = htons (2001);
|
||||||
|
inet_aton ("206.119.204.48", &to.sin_addr);
|
||||||
|
to.sin_family = AF_INET;
|
||||||
|
to.sin_len = sizeof to;
|
||||||
|
memset (to.sin_zero, 0, sizeof to.sin_zero);
|
||||||
|
|
||||||
|
note ("Sending dhcp request to %s, port %d",
|
||||||
|
inet_ntoa (to.sin_addr), htons (to.sin_port));
|
||||||
|
|
||||||
|
errno = 0;
|
||||||
|
result = sendto (sock, &raw,
|
||||||
|
outgoing.packet_length,
|
||||||
|
0, (struct sockaddr *)&to, sizeof to);
|
||||||
|
if (result < 0)
|
||||||
|
warn ("sendto: %m");
|
||||||
|
}
|
||||||
} while (1);
|
} while (1);
|
||||||
exit (0);
|
exit (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* statement :== host_statement */
|
/* statement :== host_statement */
|
||||||
|
|
||||||
void parse_client_statement (cfile)
|
void parse_client_statement (cfile, decl)
|
||||||
FILE *cfile;
|
FILE *cfile;
|
||||||
|
struct host_decl *decl;
|
||||||
{
|
{
|
||||||
char *val;
|
char *val;
|
||||||
jmp_buf bc;
|
jmp_buf bc;
|
||||||
struct host_decl decl;
|
|
||||||
int token;
|
int token;
|
||||||
struct dhcp_packet raw;
|
|
||||||
struct packet outpacket, inpacket;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
switch (next_token (&val, cfile)) {
|
switch (next_token (&val, cfile)) {
|
||||||
case PACKET:
|
case PACKET:
|
||||||
memset (&decl, 0, sizeof decl);
|
memset (decl, 0, sizeof decl);
|
||||||
if (!setjmp (bc)) {
|
if (!setjmp (bc)) {
|
||||||
do {
|
do {
|
||||||
token = peek_token (&val, cfile);
|
token = peek_token (&val, cfile);
|
||||||
@@ -91,31 +241,9 @@ void parse_client_statement (cfile)
|
|||||||
token = next_token (&val, cfile);
|
token = next_token (&val, cfile);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
parse_host_decl (cfile, &bc, &decl);
|
parse_host_decl (cfile, &bc, decl);
|
||||||
} while (1);
|
} while (1);
|
||||||
}
|
}
|
||||||
for (i = 0; i < 256; i++)
|
|
||||||
if (decl.options [i])
|
|
||||||
printf ("option %s\n", dhcp_options [i].name);
|
|
||||||
memset (&outpacket, 0, sizeof outpacket);
|
|
||||||
memset (&raw, 0, sizeof raw);
|
|
||||||
outpacket.raw = &raw;
|
|
||||||
cons_options ((struct packet *)0, &outpacket, &decl, 3);
|
|
||||||
inpacket.raw = &raw;
|
|
||||||
inpacket.packet_length = outpacket.packet_length;
|
|
||||||
parse_options (&inpacket);
|
|
||||||
for (i = 0; i < 256; i++)
|
|
||||||
if (inpacket.options [i].len)
|
|
||||||
printf ("%s=%s\n",
|
|
||||||
dhcp_options [i].name,
|
|
||||||
pretty_print_option
|
|
||||||
(i,
|
|
||||||
inpacket.options [i].data,
|
|
||||||
inpacket.options [i].len));
|
|
||||||
for (i = 0; i < 20; i++)
|
|
||||||
printf ("%s%x", i == 0 ? "" : " ",
|
|
||||||
(unsigned char)raw.options [i]);
|
|
||||||
printf ("\noptions_valid: %d\n", inpacket.options_valid);
|
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
parse_warn ("expecting a declaration.");
|
parse_warn ("expecting a declaration.");
|
||||||
|
1
dhcp.c
1
dhcp.c
@@ -49,4 +49,5 @@ static char copyright[] =
|
|||||||
void dhcp (packet)
|
void dhcp (packet)
|
||||||
struct packet *packet;
|
struct packet *packet;
|
||||||
{
|
{
|
||||||
|
dump_packet (packet);
|
||||||
}
|
}
|
||||||
|
2
dhcpd.c
2
dhcpd.c
@@ -233,6 +233,8 @@ void dump_packet (tp)
|
|||||||
((unsigned char *)(tdp -> chaddr)) [3],
|
((unsigned char *)(tdp -> chaddr)) [3],
|
||||||
((unsigned char *)(tdp -> chaddr)) [4],
|
((unsigned char *)(tdp -> chaddr)) [4],
|
||||||
((unsigned char *)(tdp -> chaddr)) [5]);
|
((unsigned char *)(tdp -> chaddr)) [5]);
|
||||||
|
debug ("filename = %s\n", tdp -> file);
|
||||||
|
debug ("server_name = %s\n", tdp -> sname);
|
||||||
if (tp -> options_valid) {
|
if (tp -> options_valid) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
2
dhcpd.h
2
dhcpd.h
@@ -289,5 +289,5 @@ int addr_eq (struct iaddr, struct iaddr);
|
|||||||
char *piaddr (struct iaddr);
|
char *piaddr (struct iaddr);
|
||||||
|
|
||||||
/* dhclient.c */
|
/* dhclient.c */
|
||||||
void parse_client_statement (FILE *);
|
void parse_client_statement (FILE *, struct host_decl *);
|
||||||
|
|
||||||
|
@@ -289,5 +289,5 @@ int addr_eq (struct iaddr, struct iaddr);
|
|||||||
char *piaddr (struct iaddr);
|
char *piaddr (struct iaddr);
|
||||||
|
|
||||||
/* dhclient.c */
|
/* dhclient.c */
|
||||||
void parse_client_statement (FILE *);
|
void parse_client_statement (FILE *, struct host_decl *);
|
||||||
|
|
||||||
|
@@ -250,13 +250,6 @@ void cons_options (inpacket, outpacket, hp, overload)
|
|||||||
if (!tree_evaluate (hp -> options [code]))
|
if (!tree_evaluate (hp -> options [code]))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
printf ("hp -> options [%d] = %x %d %d %d %x\n",
|
|
||||||
code, (unsigned long)(hp -> options [code] -> value),
|
|
||||||
hp -> options [code] -> len, hp -> options [code] -> buf_size,
|
|
||||||
hp -> options [code] -> timeout,
|
|
||||||
(unsigned long)(hp -> options [code] -> tree));
|
|
||||||
printf ("buffer = %x buflen = %d bufix = %d\n",
|
|
||||||
(unsigned int)buffer, buflen, bufix);
|
|
||||||
/* We should now have a constant length for the option. */
|
/* We should now have a constant length for the option. */
|
||||||
length = (hp -> options [code] -> len - stored_length [code]);
|
length = (hp -> options [code] -> len - stored_length [code]);
|
||||||
|
|
||||||
|
@@ -49,4 +49,5 @@ static char copyright[] =
|
|||||||
void dhcp (packet)
|
void dhcp (packet)
|
||||||
struct packet *packet;
|
struct packet *packet;
|
||||||
{
|
{
|
||||||
|
dump_packet (packet);
|
||||||
}
|
}
|
||||||
|
@@ -233,6 +233,8 @@ void dump_packet (tp)
|
|||||||
((unsigned char *)(tdp -> chaddr)) [3],
|
((unsigned char *)(tdp -> chaddr)) [3],
|
||||||
((unsigned char *)(tdp -> chaddr)) [4],
|
((unsigned char *)(tdp -> chaddr)) [4],
|
||||||
((unsigned char *)(tdp -> chaddr)) [5]);
|
((unsigned char *)(tdp -> chaddr)) [5]);
|
||||||
|
debug ("filename = %s\n", tdp -> file);
|
||||||
|
debug ("server_name = %s\n", tdp -> sname);
|
||||||
if (tp -> options_valid) {
|
if (tp -> options_valid) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
4
tree.c
4
tree.c
@@ -105,6 +105,7 @@ struct dns_host_entry *enter_dns_host (name)
|
|||||||
strcpy (dh -> hostname, name);
|
strcpy (dh -> hostname, name);
|
||||||
dh -> data = (unsigned char *)0;
|
dh -> data = (unsigned char *)0;
|
||||||
dh -> data_len = 0;
|
dh -> data_len = 0;
|
||||||
|
dh -> buf_len = 0;
|
||||||
dh -> timeout = 0;
|
dh -> timeout = 0;
|
||||||
return dh;
|
return dh;
|
||||||
}
|
}
|
||||||
@@ -354,9 +355,10 @@ static TIME do_host_lookup (bufix, bufp, bufcount, dns)
|
|||||||
|
|
||||||
/* Addresses are conveniently stored one to the buffer, so we
|
/* Addresses are conveniently stored one to the buffer, so we
|
||||||
have to copy them out one at a time... :'( */
|
have to copy them out one at a time... :'( */
|
||||||
for (i = 0; i < new_len / h -> h_length; i++)
|
for (i = 0; i < new_len / h -> h_length; i++) {
|
||||||
memcpy (dns -> data + h -> h_length * i,
|
memcpy (dns -> data + h -> h_length * i,
|
||||||
h -> h_addr_list [i], h -> h_length);
|
h -> h_addr_list [i], h -> h_length);
|
||||||
|
}
|
||||||
debug ("dns -> data: %x h -> h_addr_list [0]: %x",
|
debug ("dns -> data: %x h -> h_addr_list [0]: %x",
|
||||||
*(int *)(dns -> data), h -> h_addr_list [0]);
|
*(int *)(dns -> data), h -> h_addr_list [0]);
|
||||||
dns -> data_len = new_len;
|
dns -> data_len = new_len;
|
||||||
|
Reference in New Issue
Block a user