blob: 49a0b593d6a3e376dc8d6b4fca0d6588aa3b5855 [file] [log] [blame]
"Robert P. J. Day"63fc1a92006-07-02 19:47:05 +00001/* vi: set sw=4 ts=4: */
Denys Vlasenko385b4562010-03-26 10:09:34 +01002/*
Mike Frysinger7031f622006-05-08 03:20:50 +00003 * Russ Dill <Russ.Dill@asu.edu> September 2001
4 * Rewritten by Vladimir Oleynik <dzo@simtreas.ru> (C) 2003
5 *
Denys Vlasenko0ef64bd2010-08-16 20:14:46 +02006 * Licensed under GPLv2 or later, see file LICENSE in this source tree.
Mike Frysinger7031f622006-05-08 03:20:50 +00007 */
Denis Vlasenkof81e8db2009-04-09 12:35:13 +00008#ifndef UDHCP_COMMON_H
9#define UDHCP_COMMON_H 1
Mike Frysinger7031f622006-05-08 03:20:50 +000010
Denis Vlasenkob6adbf12007-05-26 19:00:18 +000011#include "libbb.h"
Denys Vlasenkoe6a2f4c2016-04-21 16:26:30 +020012#include "common_bufsiz.h"
Denis Vlasenko98636eb2008-05-09 17:59:34 +000013#include <netinet/udp.h>
14#include <netinet/ip.h>
15
Denis Vlasenkof81e8db2009-04-09 12:35:13 +000016PUSH_AND_SET_FUNCTION_VISIBILITY_TO_HIDDEN
Denis Vlasenko5a3395b2006-11-18 19:51:32 +000017
Denys Vlasenko5cfb8182012-07-26 12:58:41 +020018extern const uint8_t MAC_BCAST_ADDR[6] ALIGN2; /* six all-ones */
Denis Vlasenko5a3395b2006-11-18 19:51:32 +000019
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +010020
21/*** DHCP packet ***/
Denis Vlasenko5a3395b2006-11-18 19:51:32 +000022
Denys Vlasenkoc7dc79e2010-03-21 06:15:28 +010023/* DHCP protocol. See RFC 2131 */
24#define DHCP_MAGIC 0x63825363
Denys Vlasenkoc7dc79e2010-03-21 06:15:28 +010025#define DHCP_OPTIONS_BUFSIZE 308
Denys Vlasenkoc7dc79e2010-03-21 06:15:28 +010026#define BOOTREQUEST 1
27#define BOOTREPLY 2
Denis Vlasenko72e76042007-11-25 03:15:24 +000028
Denys Vlasenko31af3d52009-06-17 11:57:09 +020029//TODO: rename ciaddr/yiaddr/chaddr
30struct dhcp_packet {
Denys Vlasenkoc7dc79e2010-03-21 06:15:28 +010031 uint8_t op; /* BOOTREQUEST or BOOTREPLY */
Denis Vlasenko739e30f2008-09-26 23:45:20 +000032 uint8_t htype; /* hardware address type. 1 = 10mb ethernet */
33 uint8_t hlen; /* hardware address length */
34 uint8_t hops; /* used by relay agents only */
35 uint32_t xid; /* unique id */
36 uint16_t secs; /* elapsed since client began acquisition/renewal */
37 uint16_t flags; /* only one flag so far: */
38#define BROADCAST_FLAG 0x8000 /* "I need broadcast replies" */
39 uint32_t ciaddr; /* client IP (if client is in BOUND, RENEW or REBINDING state) */
40 uint32_t yiaddr; /* 'your' (client) IP address */
Denys Vlasenko8aa626f2021-09-04 01:50:42 +020041 /* IP address of "next server" (usually meant to be an TFTP server)
42 * to use in bootstrap, returned in DHCPOFFER, DHCPACK by server: */
Denys Vlasenko56f2d062009-06-16 10:25:35 +020043 uint32_t siaddr_nip;
Denys Vlasenko8aa626f2021-09-04 01:50:42 +020044 /* RFC 951 (BOOTP): "place my (server) IP address in the 'siaddr' field"
45 * (IOW: unconditionally, not just if we are also a TFTP server).
46 * DHCP servers don't have to do this, they add SERVER_ID option
47 * to their reply packets to let client identify lease-giving server.
48 */
49 uint32_t gateway_nip; /* aka 'giaddr': relay agent IP address, else 0 */
Denys Vlasenko56f2d062009-06-16 10:25:35 +020050 uint8_t chaddr[16]; /* link-layer client hardware address (MAC) */
51 uint8_t sname[64]; /* server host name (ASCIZ) */
Denys Vlasenko8aa626f2021-09-04 01:50:42 +020052 /* RFC 951 (BOOTP): "If the client wishes to restrict booting
53 * to a particular server name, it may place [it] in 'sname'"
54 */
Denys Vlasenko56f2d062009-06-16 10:25:35 +020055 uint8_t file[128]; /* boot file name (ASCIZ) */
Denys Vlasenko8aa626f2021-09-04 01:50:42 +020056 /* RFC 951 (BOOTP): in client requests, "...can be a 'generic' name
57 * such as 'unix' or 'gateway'; this means 'boot the named program
58 * configured for my machine'"
59 */
60 /* BOOTP fields end here, BOOTP says optional uint8_t vend[64] follows */
61 uint32_t cookie; /* DHCP magic bytes: 99,130,83,99 decimal */
Denis Vlasenko72e76042007-11-25 03:15:24 +000062 uint8_t options[DHCP_OPTIONS_BUFSIZE + CONFIG_UDHCPC_SLACK_FOR_BUGGY_SERVERS];
Denys Vlasenkoa90a54a2020-10-01 23:49:16 +020063};
Denys Vlasenkoe5ce91b2010-03-21 00:43:11 +010064#define DHCP_PKT_SNAME_LEN 64
65#define DHCP_PKT_FILE_LEN 128
66#define DHCP_PKT_SNAME_LEN_STR "64"
67#define DHCP_PKT_FILE_LEN_STR "128"
Denis Vlasenko5a3395b2006-11-18 19:51:32 +000068
Denys Vlasenko31af3d52009-06-17 11:57:09 +020069struct ip_udp_dhcp_packet {
Denis Vlasenko5a3395b2006-11-18 19:51:32 +000070 struct iphdr ip;
71 struct udphdr udp;
Denys Vlasenko31af3d52009-06-17 11:57:09 +020072 struct dhcp_packet data;
Denys Vlasenkoa90a54a2020-10-01 23:49:16 +020073};
Denis Vlasenko6884f662007-11-23 00:08:54 +000074
Denys Vlasenkob7d19cc2010-05-30 23:41:23 +020075struct udp_dhcp_packet {
76 struct udphdr udp;
77 struct dhcp_packet data;
Denys Vlasenkoa90a54a2020-10-01 23:49:16 +020078};
Denys Vlasenkob7d19cc2010-05-30 23:41:23 +020079
80enum {
Denys Vlasenko2c3b71a2010-10-20 18:04:36 +020081 IP_UDP_DHCP_SIZE = sizeof(struct ip_udp_dhcp_packet) - CONFIG_UDHCPC_SLACK_FOR_BUGGY_SERVERS,
82 UDP_DHCP_SIZE = sizeof(struct udp_dhcp_packet) - CONFIG_UDHCPC_SLACK_FOR_BUGGY_SERVERS,
Denys Vlasenkob7d19cc2010-05-30 23:41:23 +020083 DHCP_SIZE = sizeof(struct dhcp_packet) - CONFIG_UDHCPC_SLACK_FOR_BUGGY_SERVERS,
84};
85
Denis Vlasenko6884f662007-11-23 00:08:54 +000086/* Let's see whether compiler understood us right */
Denys Vlasenko31af3d52009-06-17 11:57:09 +020087struct BUG_bad_sizeof_struct_ip_udp_dhcp_packet {
Denys Vlasenko2c3b71a2010-10-20 18:04:36 +020088 char c[IP_UDP_DHCP_SIZE == 576 ? 1 : -1];
Denis Vlasenko5a3395b2006-11-18 19:51:32 +000089};
90
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +010091
92/*** Options ***/
93
94enum {
Martin Lewisd30d1eb2020-06-09 16:59:54 -050095 OPTION_IP = 0,
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +010096 OPTION_IP_PAIR,
97 OPTION_STRING,
Denys Vlasenko7280d202011-12-08 16:41:05 +010098 /* Opts of STRING_HOST type will be sanitized before they are passed
99 * to udhcpc script's environment: */
100 OPTION_STRING_HOST,
Denys Vlasenkoa8f6b992010-03-26 08:35:24 +0100101// OPTION_BOOLEAN,
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100102 OPTION_U8,
103 OPTION_U16,
Denys Vlasenkoa8f6b992010-03-26 08:35:24 +0100104// OPTION_S16,
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100105 OPTION_U32,
106 OPTION_S32,
Denys Vlasenko4f3aa512010-04-04 15:31:12 +0200107 OPTION_BIN,
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100108 OPTION_STATIC_ROUTES,
Denys Vlasenko1f56e512011-10-19 22:40:35 +0200109 OPTION_6RD,
Denys Vlasenkoba4fbca2017-06-28 19:18:17 +0200110#if ENABLE_FEATURE_UDHCP_RFC3397 || ENABLE_FEATURE_UDHCPC6_RFC3646 || ENABLE_FEATURE_UDHCPC6_RFC4704
Denys Vlasenko4f3aa512010-04-04 15:31:12 +0200111 OPTION_DNS_STRING, /* RFC1035 compressed domain name list */
Denys Vlasenkoba4fbca2017-06-28 19:18:17 +0200112#endif
113#if ENABLE_FEATURE_UDHCP_RFC3397
Denys Vlasenko4f3aa512010-04-04 15:31:12 +0200114 OPTION_SIP_SERVERS,
115#endif
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100116
117 OPTION_TYPE_MASK = 0x0f,
118 /* Client requests this option by default */
119 OPTION_REQ = 0x10,
120 /* There can be a list of 1 or more of these */
121 OPTION_LIST = 0x20,
122};
123
Martin Lewisacdc8ee2020-06-23 15:25:08 -0500124struct dhcp_scan_state {
125 int overload;
126 int rem;
127 uint8_t *optionptr;
128};
129
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100130/* DHCP option codes (partial list). See RFC 2132 and
131 * http://www.iana.org/assignments/bootp-dhcp-parameters/
132 * Commented out options are handled by common option machinery,
Denys Vlasenkof4613852011-10-20 08:54:16 +0200133 * uncommented ones have special cases (grep for them to see).
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100134 */
135#define DHCP_PADDING 0x00
136#define DHCP_SUBNET 0x01
137//#define DHCP_TIME_OFFSET 0x02 /* (localtime - UTC_time) in seconds. signed */
138//#define DHCP_ROUTER 0x03
139//#define DHCP_TIME_SERVER 0x04 /* RFC 868 time server (32-bit, 0 = 1.1.1900) */
140//#define DHCP_NAME_SERVER 0x05 /* IEN 116 _really_ ancient kind of NS */
141//#define DHCP_DNS_SERVER 0x06
Denys Vlasenko74d9f1b2019-01-07 15:33:42 +0100142//#define DHCP_LOG_SERVER 0x07 /* port 704 UDP log (not syslog) */
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100143//#define DHCP_COOKIE_SERVER 0x08 /* "quote of the day" server */
144//#define DHCP_LPR_SERVER 0x09
Denys Vlasenko2cd81692018-07-04 16:05:48 +0200145#define DHCP_HOST_NAME 0x0c /* 12: either client informs server or server gives name to client */
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100146//#define DHCP_BOOT_SIZE 0x0d
Denys Vlasenko2cd81692018-07-04 16:05:48 +0200147//#define DHCP_DOMAIN_NAME 0x0f /* 15: server gives domain suffix */
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100148//#define DHCP_SWAP_SERVER 0x10
149//#define DHCP_ROOT_PATH 0x11
150//#define DHCP_IP_TTL 0x17
151//#define DHCP_MTU 0x1a
152//#define DHCP_BROADCAST 0x1c
Vladislav Grishenko7d3a48a2010-09-26 00:15:12 +0200153//#define DHCP_ROUTES 0x21
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100154//#define DHCP_NIS_DOMAIN 0x28
155//#define DHCP_NIS_SERVER 0x29
156//#define DHCP_NTP_SERVER 0x2a
157//#define DHCP_WINS_SERVER 0x2c
Denys Vlasenko2cd81692018-07-04 16:05:48 +0200158#define DHCP_REQUESTED_IP 0x32 /* 50: sent by client if specific IP is wanted */
Denys Vlasenko8aa626f2021-09-04 01:50:42 +0200159#define DHCP_LEASE_TIME 0x33 /* 51: 32bit big-endian */
160#define DHCP_OPTION_OVERLOAD 0x34 /* 52: 1 byte */
161#define DHCP_MESSAGE_TYPE 0x35 /* 53: 1 byte */
Denys Vlasenko2cd81692018-07-04 16:05:48 +0200162#define DHCP_SERVER_ID 0x36 /* 54: server's IP */
163#define DHCP_PARAM_REQ 0x37 /* 55: list of options client wants */
164//#define DHCP_ERR_MESSAGE 0x38 /* 56: error message when sending NAK etc */
Denys Vlasenko8aa626f2021-09-04 01:50:42 +0200165#define DHCP_MAX_SIZE 0x39 /* 57: 16bit big-endian */
166// 0x3a /* 58: from server: renew time, 32bit big-endian */
167// 0x3b /* 59: from server: rebind time, 32bit big-endian */
Denys Vlasenko2cd81692018-07-04 16:05:48 +0200168#define DHCP_VENDOR 0x3c /* 60: client's vendor (a string) */
169#define DHCP_CLIENT_ID 0x3d /* 61: by default client's MAC addr, but may be arbitrarily long */
170//#define DHCP_TFTP_SERVER_NAME 0x42 /* 66: same as 'sname' field */
171//#define DHCP_BOOT_FILE 0x43 /* 67: same as 'file' field */
172//#define DHCP_USER_CLASS 0x4d /* 77: RFC 3004. set of LASCII strings. "I am a printer" etc */
Denys Vlasenko8aa626f2021-09-04 01:50:42 +0200173// 0x50 /* 80: rapid commit ("I'm ok with getting immediate ACK, not just OFFER"), 0 bytes */
Denys Vlasenko2cd81692018-07-04 16:05:48 +0200174#define DHCP_FQDN 0x51 /* 81: client asks to update DNS to map its FQDN to its new IP */
Antoine Girard-Vallée0e7bd692019-03-08 09:24:42 -0500175//#define DHCP_PCODE 0x64 /* 100: RFC 4833. IEEE 1003.1 TZ string */
176//#define DHCP_TCODE 0x65 /* 101: RFC 4833. Reference to the TZ database string */
Denys Vlasenko2cd81692018-07-04 16:05:48 +0200177//#define DHCP_DOMAIN_SEARCH 0x77 /* 119: RFC 3397. set of ASCIZ string, DNS-style compressed */
178//#define DHCP_SIP_SERVERS 0x78 /* 120: RFC 3361. flag byte, then: 0: domain names, 1: IP addrs */
179//#define DHCP_STATIC_ROUTES 0x79 /* 121: RFC 3442. (mask,ip,router) tuples */
180//#define DHCP_VLAN_ID 0x84 /* 132: 802.1P VLAN ID */
181//#define DHCP_VLAN_PRIORITY 0x85 /* 133: 802.1Q VLAN priority */
Denys Vlasenkoedb74f42019-01-15 13:19:01 +0100182//#define DHCP_PXE_CONF_FILE 0xd1 /* 209: RFC 5071 Configuration file */
183//#define DHCP_PXE_PATH_PREFIX 0xd2 /* 210: RFC 5071 Path prefix */
Denys Vlasenko2cd81692018-07-04 16:05:48 +0200184//#define DHCP_REBOOT_TIME 0xd3 /* 211: RFC 5071 Reboot time */
185//#define DHCP_MS_STATIC_ROUTES 0xf9 /* 249: Microsoft's pre-RFC 3442 code for 0x79? */
186//#define DHCP_WPAD 0xfc /* 252: MSIE's Web Proxy Autodiscovery Protocol */
187#define DHCP_END 0xff /* 255: */
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100188
189/* Offsets in option byte sequence */
190#define OPT_CODE 0
191#define OPT_LEN 1
192#define OPT_DATA 2
Denys Vlasenko60275972018-05-14 11:06:35 +0200193/* Offsets in option byte sequence for DHCPv6 */
Denys Vlasenko2cd81692018-07-04 16:05:48 +0200194#define D6_OPT_CODE 0
195#define D6_OPT_LEN 2
196#define D6_OPT_DATA 4
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100197/* Bits in "overload" option */
198#define OPTION_FIELD 0
199#define FILE_FIELD 1
200#define SNAME_FIELD 2
201
202/* DHCP_MESSAGE_TYPE values */
203#define DHCPDISCOVER 1 /* client -> server */
204#define DHCPOFFER 2 /* client <- server */
205#define DHCPREQUEST 3 /* client -> server */
206#define DHCPDECLINE 4 /* client -> server */
207#define DHCPACK 5 /* client <- server */
208#define DHCPNAK 6 /* client <- server */
209#define DHCPRELEASE 7 /* client -> server */
210#define DHCPINFORM 8 /* client -> server */
211#define DHCP_MINTYPE DHCPDISCOVER
212#define DHCP_MAXTYPE DHCPINFORM
213
Denys Vlasenkoc03602b2010-04-04 15:28:49 +0200214struct dhcp_optflag {
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100215 uint8_t flags;
216 uint8_t code;
217};
218
Denys Vlasenko7e6add12010-03-25 20:32:38 +0100219struct option_set {
220 uint8_t *data;
221 struct option_set *next;
222};
223
Denys Vlasenkoba4fbca2017-06-28 19:18:17 +0200224#if ENABLE_UDHCPC || ENABLE_UDHCPD
Denys Vlasenkoc03602b2010-04-04 15:28:49 +0200225extern const struct dhcp_optflag dhcp_optflags[];
Michael Tokarev32f774c2012-07-24 15:56:37 +0200226extern const char dhcp_option_strings[] ALIGN1;
Denys Vlasenkoba4fbca2017-06-28 19:18:17 +0200227#endif
Michael Tokarev32f774c2012-07-24 15:56:37 +0200228extern const uint8_t dhcp_option_lengths[] ALIGN1;
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100229
Denys Vlasenkoba4fbca2017-06-28 19:18:17 +0200230unsigned FAST_FUNC udhcp_option_idx(const char *name, const char *option_strings);
Denys Vlasenko9107b632010-03-27 23:23:41 +0100231
Martin Lewisacdc8ee2020-06-23 15:25:08 -0500232void init_scan_state(struct dhcp_packet *packet, struct dhcp_scan_state *scan_state) FAST_FUNC;
233uint8_t *udhcp_scan_options(struct dhcp_packet *packet, struct dhcp_scan_state *scan_state) FAST_FUNC;
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100234uint8_t *udhcp_get_option(struct dhcp_packet *packet, int code) FAST_FUNC;
Denys Vlasenko6d3b4bb2018-12-17 18:07:18 +0100235/* Same as above + ensures that option length is 4 bytes
236 * (returns NULL if size is different)
237 */
238uint8_t *udhcp_get_option32(struct dhcp_packet *packet, int code) FAST_FUNC;
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100239int udhcp_end_option(uint8_t *optionptr) FAST_FUNC;
Denys Vlasenko7724c762010-03-26 09:32:09 +0100240void udhcp_add_binary_option(struct dhcp_packet *packet, uint8_t *addopt) FAST_FUNC;
Denys Vlasenkoba4fbca2017-06-28 19:18:17 +0200241#if ENABLE_UDHCPC || ENABLE_UDHCPD
Denys Vlasenko7724c762010-03-26 09:32:09 +0100242void udhcp_add_simple_option(struct dhcp_packet *packet, uint8_t code, uint32_t data) FAST_FUNC;
Denys Vlasenkoba4fbca2017-06-28 19:18:17 +0200243#endif
244#if ENABLE_FEATURE_UDHCP_RFC3397 || ENABLE_FEATURE_UDHCPC6_RFC3646 || ENABLE_FEATURE_UDHCPC6_RFC4704
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100245char *dname_dec(const uint8_t *cstr, int clen, const char *pre) FAST_FUNC;
Denys Vlasenko0cad5f92020-06-09 17:22:06 +0200246uint8_t *dname_enc(/*const uint8_t *cstr, int clen,*/ const char *src, int *retlen) FAST_FUNC;
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100247#endif
Denys Vlasenkoe67b80f2021-12-12 17:13:54 +0100248#if !ENABLE_UDHCPC6
249#define udhcp_find_option(opt_list, code, dhcpv6) \
250 udhcp_find_option(opt_list, code)
251#endif
252struct option_set *udhcp_find_option(struct option_set *opt_list, uint8_t code, bool dhcpv6) FAST_FUNC;
Denys Vlasenko7e6add12010-03-25 20:32:38 +0100253
Denys Vlasenkoc7dc79e2010-03-21 06:15:28 +0100254// RFC 2131 Table 5: Fields and options used by DHCP clients
255//
Denys Vlasenko1115e402019-05-23 15:24:03 +0200256// Fields 'hops', 'yiaddr', 'siaddr', 'giaddr' are always zero, 'chaddr' is always client's MAC
Denys Vlasenkoc7dc79e2010-03-21 06:15:28 +0100257//
Denys Vlasenko6b616292010-03-22 15:22:14 +0100258// Field DHCPDISCOVER DHCPINFORM DHCPREQUEST DHCPDECLINE DHCPRELEASE
259// ----- ------------ ------------ ----------- ----------- -----------
260// 'xid' selected by client selected by client 'xid' from server selected by client selected by client
261// DHCPOFFER message
262// 'secs' 0 or seconds since 0 or seconds since 0 or seconds since 0 0
263// DHCP process started DHCP process started DHCP process started
264// 'flags' Set 'BROADCAST' Set 'BROADCAST' Set 'BROADCAST' 0 0
Denys Vlasenko1115e402019-05-23 15:24:03 +0200265// flag if client needs flag if client needs flag if client needs
266// broadcast reply broadcast reply broadcast reply
Denys Vlasenko6b616292010-03-22 15:22:14 +0100267// 'ciaddr' 0 client's IP 0 or client's IP 0 client's IP
268// (BOUND/RENEW/REBIND)
Denys Vlasenko6b616292010-03-22 15:22:14 +0100269// 'sname' options or sname options or sname options or sname (unused) (unused)
270// 'file' options or file options or file options or file (unused) (unused)
271// 'options' options options options message type opt message type opt
272//
Denys Vlasenko1115e402019-05-23 15:24:03 +0200273// Option DHCPDISCOVER DHCPINFORM DHCPREQUEST DHCPDECLINE DHCPRELEASE
274// ------ ------------ ---------- ----------- ----------- -----------
275// Requested IP address MAY MUST NOT MUST (in SELECTING MUST MUST NOT
276// or INIT-REBOOT)
277// MUST NOT (in BOUND
278// or RENEWING)
279// IP address lease time MAY MUST NOT MAY MUST NOT MUST NOT
280// Use 'file'/'sname' fields MAY MAY MAY MAY MAY
281// Client identifier MAY MAY MAY MAY MAY
282// Vendor class identifier MAY MAY MAY MUST NOT MUST NOT
283// Server identifier MUST NOT MUST NOT MUST (after SELECTING) MUST MUST
Denys Vlasenko6b616292010-03-22 15:22:14 +0100284// MUST NOT (after
Denys Vlasenko1115e402019-05-23 15:24:03 +0200285// INIT-REBOOT, BOUND,
286// RENEWING or REBINDING)
287// Parameter request list MAY MAY MAY MUST NOT MUST NOT
288// Maximum message size MAY MAY MAY MUST NOT MUST NOT
289// Message SHOULD NOT SHOULD NOT SHOULD NOT SHOULD SHOULD
290// Site-specific MAY MAY MAY MUST NOT MUST NOT
291// All others MAY MAY MAY MUST NOT MUST NOT
Denys Vlasenkoc7dc79e2010-03-21 06:15:28 +0100292
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100293/*** Logging ***/
Mike Frysinger7031f622006-05-08 03:20:50 +0000294
Denys Vlasenkoac906fa2009-06-17 11:54:52 +0200295#if defined CONFIG_UDHCP_DEBUG && CONFIG_UDHCP_DEBUG >= 1
Leonid Lisovskiy6c9c0a12011-10-18 00:35:47 +0200296# define IF_UDHCP_VERBOSE(...) __VA_ARGS__
Denys Vlasenko6947d2c2009-06-17 13:24:03 +0200297extern unsigned dhcp_verbose;
James Byrne253c4e72019-04-12 17:01:51 +0000298# define log1(...) do { if (dhcp_verbose >= 1) bb_info_msg(__VA_ARGS__); } while (0)
Denys Vlasenko774020c2021-06-03 11:12:20 +0200299//# define log1s(msg) do { if (dhcp_verbose >= 1) bb_simple_info_msg(msg); } while (0)
300void log1s(const char *msg) FAST_FUNC;
Denys Vlasenkoac906fa2009-06-17 11:54:52 +0200301# if CONFIG_UDHCP_DEBUG >= 2
Denys Vlasenko31af3d52009-06-17 11:57:09 +0200302void udhcp_dump_packet(struct dhcp_packet *packet) FAST_FUNC;
James Byrne253c4e72019-04-12 17:01:51 +0000303# define log2(...) do { if (dhcp_verbose >= 2) bb_info_msg(__VA_ARGS__); } while (0)
James Byrne69374872019-07-02 11:35:03 +0200304# define log2s(msg) do { if (dhcp_verbose >= 2) bb_simple_info_msg(msg); } while (0)
Denys Vlasenkoac906fa2009-06-17 11:54:52 +0200305# else
306# define udhcp_dump_packet(...) ((void)0)
307# define log2(...) ((void)0)
James Byrne69374872019-07-02 11:35:03 +0200308# define log2s(msg) ((void)0)
Denys Vlasenkoac906fa2009-06-17 11:54:52 +0200309# endif
Denys Vlasenko31af3d52009-06-17 11:57:09 +0200310# if CONFIG_UDHCP_DEBUG >= 3
James Byrne253c4e72019-04-12 17:01:51 +0000311# define log3(...) do { if (dhcp_verbose >= 3) bb_info_msg(__VA_ARGS__); } while (0)
James Byrne69374872019-07-02 11:35:03 +0200312# define log3s(msg) do { if (dhcp_verbose >= 3) bb_simple_info_msg(msg); } while (0)
Denys Vlasenko31af3d52009-06-17 11:57:09 +0200313# else
314# define log3(...) ((void)0)
James Byrne69374872019-07-02 11:35:03 +0200315# define log3s(msg) ((void)0)
Denys Vlasenko31af3d52009-06-17 11:57:09 +0200316# endif
Mike Frysinger7031f622006-05-08 03:20:50 +0000317#else
Leonid Lisovskiy6c9c0a12011-10-18 00:35:47 +0200318# define IF_UDHCP_VERBOSE(...)
Denys Vlasenkoac906fa2009-06-17 11:54:52 +0200319# define udhcp_dump_packet(...) ((void)0)
320# define log1(...) ((void)0)
James Byrne69374872019-07-02 11:35:03 +0200321# define log1s(msg) ((void)0)
Denys Vlasenkoac906fa2009-06-17 11:54:52 +0200322# define log2(...) ((void)0)
James Byrne69374872019-07-02 11:35:03 +0200323# define log2s(msg) ((void)0)
Denys Vlasenko31af3d52009-06-17 11:57:09 +0200324# define log3(...) ((void)0)
James Byrne69374872019-07-02 11:35:03 +0200325# define log3s(msg) ((void)0)
Mike Frysinger7031f622006-05-08 03:20:50 +0000326#endif
327
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100328/*** Other shared functions ***/
329
Denys Vlasenkoa8f6b992010-03-26 08:35:24 +0100330/* 2nd param is "uint32_t*" */
331int FAST_FUNC udhcp_str2nip(const char *str, void *arg);
Denys Vlasenko265fcdd2021-06-02 13:50:26 +0200332
333#if !ENABLE_UDHCPC6
Denys Vlasenko949e9622021-06-02 15:51:50 +0200334#define udhcp_insert_new_option(opt_list, code, length, dhcpv6) \
335 udhcp_insert_new_option(opt_list, code, length)
Denys Vlasenko265fcdd2021-06-02 13:50:26 +0200336#endif
337void* FAST_FUNC udhcp_insert_new_option(struct option_set **opt_list,
338 unsigned code,
Denys Vlasenko265fcdd2021-06-02 13:50:26 +0200339 unsigned length,
340 bool dhcpv6);
341
Denys Vlasenkoa8f6b992010-03-26 08:35:24 +0100342/* 2nd param is "struct option_set**" */
Denys Vlasenko60275972018-05-14 11:06:35 +0200343#if !ENABLE_UDHCPC6
344#define udhcp_str2optset(str, arg, optflags, option_strings, dhcpv6) \
345 udhcp_str2optset(str, arg, optflags, option_strings)
346#endif
Denys Vlasenkoba4fbca2017-06-28 19:18:17 +0200347int FAST_FUNC udhcp_str2optset(const char *str,
348 void *arg,
349 const struct dhcp_optflag *optflags,
Denys Vlasenko60275972018-05-14 11:06:35 +0200350 const char *option_strings,
351 bool dhcpv6);
Denys Vlasenkoa8f6b992010-03-26 08:35:24 +0100352
Denys Vlasenko4ee824f2017-07-03 01:22:13 +0200353#if ENABLE_UDHCPC || ENABLE_UDHCPD
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100354void udhcp_init_header(struct dhcp_packet *packet, char type) FAST_FUNC;
Denys Vlasenko4ee824f2017-07-03 01:22:13 +0200355#endif
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100356
357int udhcp_recv_kernel_packet(struct dhcp_packet *packet, int fd) FAST_FUNC;
358
359int udhcp_send_raw_packet(struct dhcp_packet *dhcp_pkt,
Denys Vlasenkoe58c6e22010-05-30 23:43:35 +0200360 uint32_t source_nip, int source_port,
361 uint32_t dest_nip, int dest_port, const uint8_t *dest_arp,
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100362 int ifindex) FAST_FUNC;
363
364int udhcp_send_kernel_packet(struct dhcp_packet *dhcp_pkt,
Denys Vlasenkoe58c6e22010-05-30 23:43:35 +0200365 uint32_t source_nip, int source_port,
Michal Kaziorb8176992020-12-15 09:53:40 +0000366 uint32_t dest_nip, int dest_port,
367 const char *ifname) FAST_FUNC;
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100368
369void udhcp_sp_setup(void) FAST_FUNC;
Denys Vlasenko52a515d2017-02-16 23:25:44 +0100370void udhcp_sp_fd_set(struct pollfd *pfds, int extra_fd) FAST_FUNC;
Denys Vlasenko3293bc12018-03-10 19:01:48 +0100371int udhcp_sp_read(void) FAST_FUNC;
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100372
Denys Vlasenko301ef962022-12-15 11:49:00 +0100373int udhcp_read_interface(const char *interface,
374 int *ifindex, uint32_t *nip, uint8_t *mac) FAST_FUNC;
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100375
376int udhcp_listen_socket(/*uint32_t ip,*/ int port, const char *inf) FAST_FUNC;
377
378/* Returns 1 if no reply received */
379int arpping(uint32_t test_nip,
380 const uint8_t *safe_mac,
381 uint32_t from_ip,
382 uint8_t *from_mac,
Michel Stam9f412712014-10-30 11:59:04 +0100383 const char *interface,
384 unsigned timeo) FAST_FUNC;
Denys Vlasenkodde8bdc2010-03-22 14:29:13 +0100385
Denys Vlasenkoa092a892011-11-16 20:17:12 +0100386/* note: ip is a pointer to an IPv6 in network order, possibly misaliged */
387int sprint_nip6(char *dest, /*const char *pre,*/ const uint8_t *ip) FAST_FUNC;
388
Denis Vlasenkof81e8db2009-04-09 12:35:13 +0000389POP_SAVED_FUNCTION_VISIBILITY
Denis Vlasenko98636eb2008-05-09 17:59:34 +0000390
Mike Frysinger7031f622006-05-08 03:20:50 +0000391#endif