summaryrefslogtreecommitdiff
path: root/usr.sbin/dhcrelay/dhcrelay.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.sbin/dhcrelay/dhcrelay.c')
-rw-r--r--usr.sbin/dhcrelay/dhcrelay.c172
1 files changed, 67 insertions, 105 deletions
diff --git a/usr.sbin/dhcrelay/dhcrelay.c b/usr.sbin/dhcrelay/dhcrelay.c
index fa9b3bff4ee..3f0011767bd 100644
--- a/usr.sbin/dhcrelay/dhcrelay.c
+++ b/usr.sbin/dhcrelay/dhcrelay.c
@@ -1,8 +1,5 @@
-/* dhcrelay.c
-
- DHCP/BOOTP Relay Agent. */
-
/*
+ * Copyright (c) 2004 Henning Brauer <henning@cvs.openbsd.org>
* Copyright (c) 1997, 1998, 1999 The Internet Software Consortium.
* All rights reserved.
*
@@ -64,9 +61,8 @@ struct server_list {
struct sockaddr_in to;
} *servers;
-int main (argc, argv)
- int argc;
- char **argv;
+int
+main(int argc, char *argv[])
{
int ch, quiet = 0, no_daemon = 0;
extern char *__progname;
@@ -126,7 +122,7 @@ int main (argc, argv)
if (iap) {
if ((sp = calloc(1, sizeof *sp)) == NULL)
error("calloc");
- sp -> next = servers;
+ sp->next = servers;
servers = sp;
memcpy (&sp->to.sin_addr, iap, sizeof *iap);
}
@@ -142,25 +138,24 @@ int main (argc, argv)
/* Default to the DHCP/BOOTP port. */
if (!local_port) {
- ent = getservbyname ("dhcps", "udp");
+ ent = getservbyname("dhcps", "udp");
if (!ent)
- local_port = htons (67);
+ local_port = htons(67);
else
- local_port = ent -> s_port;
- endservent ();
+ local_port = ent->s_port;
+ endservent();
}
- remote_port = htons (ntohs (local_port) + 1);
+ remote_port = htons(ntohs(local_port) + 1);
/* We need at least one server. */
- if (!sp) {
+ if (!sp)
usage();
- }
/* Set up the server sockaddrs. */
- for (sp = servers; sp; sp = sp -> next) {
- sp -> to.sin_port = local_port;
- sp -> to.sin_family = AF_INET;
- sp -> to.sin_len = sizeof sp -> to;
+ for (sp = servers; sp; sp = sp->next) {
+ sp->to.sin_port = local_port;
+ sp->to.sin_family = AF_INET;
+ sp->to.sin_len = sizeof sp->to;
}
/* Get the current time... */
@@ -177,102 +172,96 @@ int main (argc, argv)
daemon(0, 0);
/* Start dispatching packets and timeouts... */
- dispatch ();
+ dispatch();
+ /* not reached */
- /*NOTREACHED*/
- return 0;
+ exit (0);
}
-void relay (ip, packet, length, from_port, from, hfrom)
- struct interface_info *ip;
- struct dhcp_packet *packet;
- int length;
- unsigned int from_port;
- struct iaddr from;
- struct hardware *hfrom;
+void
+relay(struct interface_info *ip, struct dhcp_packet *packet, int length,
+ unsigned int from_port, struct iaddr from, struct hardware *hfrom)
{
- struct server_list *sp;
- struct sockaddr_in to;
- struct interface_info *out;
- struct hardware hto;
+ struct server_list *sp;
+ struct sockaddr_in to;
+ struct interface_info *out;
+ struct hardware hto;
- if (packet -> hlen > sizeof packet -> chaddr) {
- note ("Discarding packet with invalid hlen.");
+ if (packet->hlen > sizeof packet->chaddr) {
+ note("Discarding packet with invalid hlen.");
return;
}
/* If it's a bootreply, forward it to the client. */
- if (packet -> op == BOOTREPLY) {
- memset(&to, 0, sizeof(to));
- if (!(packet -> flags & htons (BOOTP_BROADCAST))) {
- to.sin_addr = packet -> yiaddr;
+ if (packet->op == BOOTREPLY) {
+ bzero(&to, sizeof(to));
+ if (!(packet->flags & htons(BOOTP_BROADCAST))) {
+ to.sin_addr = packet->yiaddr;
to.sin_port = remote_port;
} else {
- to.sin_addr.s_addr = htonl (INADDR_BROADCAST);
+ to.sin_addr.s_addr = htonl(INADDR_BROADCAST);
to.sin_port = remote_port;
}
to.sin_family = AF_INET;
to.sin_len = sizeof to;
/* Set up the hardware destination address. */
- hto.hlen = packet -> hlen;
+ hto.hlen = packet->hlen;
if (hto.hlen > sizeof hto.haddr)
hto.hlen = sizeof hto.haddr;
- memcpy (hto.haddr, packet -> chaddr, hto.hlen);
- hto.htype = packet -> htype;
+ memcpy(hto.haddr, packet->chaddr, hto.hlen);
+ hto.htype = packet->htype;
+/* XXX broken */
/* Find the interface that corresponds to the giaddr
in the packet. */
- for (out = interfaces; out; out = out -> next) {
- if (!memcmp (&out -> primary_address,
- &packet -> giaddr,
- sizeof packet -> giaddr))
+ for (out = interfaces; out; out = out->next) {
+ if (!memcmp (&out->primary_address,
+ &packet->giaddr,
+ sizeof packet->giaddr))
break;
}
if (!out) {
warn ("packet to bogus giaddr %s.",
- inet_ntoa (packet -> giaddr));
+ inet_ntoa (packet->giaddr));
return;
}
if (send_packet (out,
(struct packet *)0,
- packet, length, out -> primary_address,
+ packet, length, out->primary_address,
&to, &hto) != -1)
debug ("forwarded BOOTREPLY for %s to %s",
- print_hw_addr (packet -> htype, packet -> hlen,
- packet -> chaddr),
- inet_ntoa (to.sin_addr));
-
+ print_hw_addr(packet->htype, packet->hlen,
+ packet->chaddr), inet_ntoa (to.sin_addr));
+/* XXX */
return;
}
/* If giaddr is set on a BOOTREQUEST, ignore it - it's already
been gatewayed. */
- if (packet -> giaddr.s_addr) {
- note ("ignoring BOOTREQUEST with giaddr of %s\n",
- inet_ntoa (packet -> giaddr));
+ if (packet->giaddr.s_addr) {
+ note("ignoring BOOTREQUEST with giaddr of %s\n",
+ inet_ntoa(packet->giaddr));
return;
}
/* Set the giaddr so the server can figure out what net it's
from and so that we can later forward the response to the
correct net. */
- packet -> giaddr = ip -> primary_address;
+ packet->giaddr = ip->primary_address;
/* Otherwise, it's a BOOTREQUEST, so forward it to all the
servers. */
- for (sp = servers; sp; sp = sp -> next) {
- if (send_packet (interfaces,
- (struct packet *)0,
- packet, length, ip -> primary_address,
- &sp -> to, (struct hardware *)0) != -1) {
- debug ("forwarded BOOTREQUEST for %s to %s",
- print_hw_addr (packet -> htype, packet -> hlen,
- packet -> chaddr),
- inet_ntoa (sp -> to.sin_addr));
+ for (sp = servers; sp; sp = sp->next) {
+ if (send_packet(interfaces, NULL, packet, length,
+ ip->primary_address, &sp->to, NULL) != -1) {
+ debug("forwarded BOOTREQUEST for %s to %s",
+ print_hw_addr(packet->htype, packet->hlen,
+ packet->chaddr), inet_ntoa(sp->to.sin_addr));
}
}
+
}
void
@@ -285,59 +274,32 @@ usage(void)
exit (1);
}
-void cleanup ()
-{
-}
-
-int write_lease (lease)
- struct lease *lease;
-{
- return 1;
-}
-
-int commit_leases ()
-{
- return 1;
-}
-
-void bootp (packet)
- struct packet *packet;
-{
-}
-
-void dhcp (packet)
- struct packet *packet;
-{
-}
-
-char *print_hw_addr (htype, hlen, data)
- int htype;
- int hlen;
- unsigned char *data;
+char *
+print_hw_addr(int htype, int hlen, unsigned char *data)
{
- static char habuf [49];
- char *s;
- int i;
+ static char habuf[49];
+ char *s;
+ int i;
- if (htype == 0 || hlen == 0) {
+ if (htype == 0 || hlen == 0)
goto bad;
- } else {
- int slen = sizeof(habuf);
+ else {
+ int slen = sizeof(habuf);
s = habuf;
for (i = 0; i < hlen; i++) {
- int j;
- j = snprintf (s, slen, "%02x", data [i]);
+ int j;
+ j = snprintf(s, slen, "%02x", data[i]);
if (j <= 0)
goto bad;
s += strlen (s);
slen -= (strlen(s) + 1);
- *s++ = ':';
+ *s++ = ':';
}
*--s = 0;
}
return habuf;
- bad:
+bad:
strlcpy (habuf, "<null>", sizeof habuf);
return habuf;