options.[ch] must still be valid C++11 because it is used in ndhs.
That means the [static 1] arg specifier cannot be used.
This commit is contained in:
parent
00c9479c4c
commit
d0d8bcf3ff
@ -34,8 +34,7 @@
|
|||||||
|
|
||||||
#include "options.h"
|
#include "options.h"
|
||||||
|
|
||||||
static int do_overload_value(const uint8_t buf[static 1], ssize_t blen,
|
static int do_overload_value(const uint8_t *buf, ssize_t blen, int overload)
|
||||||
int overload)
|
|
||||||
{
|
{
|
||||||
ssize_t i = 0;
|
ssize_t i = 0;
|
||||||
while (i < blen) {
|
while (i < blen) {
|
||||||
@ -59,7 +58,7 @@ static int do_overload_value(const uint8_t buf[static 1], ssize_t blen,
|
|||||||
return overload;
|
return overload;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int overload_value(const struct dhcpmsg packet[static 1])
|
static int overload_value(const struct dhcpmsg * const packet)
|
||||||
{
|
{
|
||||||
int ol = do_overload_value(packet->options, sizeof packet->options, 0);
|
int ol = do_overload_value(packet->options, sizeof packet->options, 0);
|
||||||
if (ol & 1 && ol & 2)
|
if (ol & 1 && ol & 2)
|
||||||
@ -75,9 +74,8 @@ static int overload_value(const struct dhcpmsg packet[static 1])
|
|||||||
return ol; // ol == 0
|
return ol; // ol == 0
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_get_dhcp_opt(const uint8_t sbuf[static 1], ssize_t slen,
|
static void do_get_dhcp_opt(const uint8_t *sbuf, ssize_t slen, uint8_t code,
|
||||||
uint8_t code, uint8_t dbuf[static 1],
|
uint8_t *dbuf, ssize_t dlen, ssize_t *didx)
|
||||||
ssize_t dlen, ssize_t didx[static 1])
|
|
||||||
{
|
{
|
||||||
ssize_t i = 0;
|
ssize_t i = 0;
|
||||||
while (i < slen) {
|
while (i < slen) {
|
||||||
@ -102,8 +100,8 @@ static void do_get_dhcp_opt(const uint8_t sbuf[static 1], ssize_t slen,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ssize_t get_dhcp_opt(const struct dhcpmsg packet[static 1], uint8_t code,
|
ssize_t get_dhcp_opt(const struct dhcpmsg * const packet, uint8_t code,
|
||||||
uint8_t dbuf[static 1], ssize_t dlen)
|
uint8_t *dbuf, ssize_t dlen)
|
||||||
{
|
{
|
||||||
int ol = overload_value(packet);
|
int ol = overload_value(packet);
|
||||||
ssize_t didx = 0;
|
ssize_t didx = 0;
|
||||||
@ -119,7 +117,7 @@ ssize_t get_dhcp_opt(const struct dhcpmsg packet[static 1], uint8_t code,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// return the position of the 'end' option
|
// return the position of the 'end' option
|
||||||
ssize_t get_end_option_idx(const struct dhcpmsg packet[static 1])
|
ssize_t get_end_option_idx(const struct dhcpmsg * const packet)
|
||||||
{
|
{
|
||||||
for (size_t i = 0; i < sizeof packet->options; ++i) {
|
for (size_t i = 0; i < sizeof packet->options; ++i) {
|
||||||
if (packet->options[i] == DCODE_END)
|
if (packet->options[i] == DCODE_END)
|
||||||
@ -144,8 +142,8 @@ static inline size_t sizeof_option_str(uint8_t code, size_t datalen)
|
|||||||
// Add a raw data string to the options. It will take a binary string suitable
|
// Add a raw data string to the options. It will take a binary string suitable
|
||||||
// for use with eg memcpy() and will append it to the options[] field of
|
// for use with eg memcpy() and will append it to the options[] field of
|
||||||
// a dhcp packet with the requested option code and proper length specifier.
|
// a dhcp packet with the requested option code and proper length specifier.
|
||||||
size_t add_option_string(struct dhcpmsg packet[static 1], uint8_t code,
|
size_t add_option_string(struct dhcpmsg *packet, uint8_t code,
|
||||||
const char str[static 1], size_t slen)
|
const char * const str, size_t slen)
|
||||||
{
|
{
|
||||||
size_t len = sizeof_option_str(code, slen);
|
size_t len = sizeof_option_str(code, slen);
|
||||||
if (slen > 255 || len != slen + 2) {
|
if (slen > 255 || len != slen + 2) {
|
||||||
@ -169,7 +167,7 @@ size_t add_option_string(struct dhcpmsg packet[static 1], uint8_t code,
|
|||||||
return len;
|
return len;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ssize_t add_option_check(struct dhcpmsg packet[static 1], uint8_t code,
|
static ssize_t add_option_check(struct dhcpmsg *packet, uint8_t code,
|
||||||
uint8_t rlen)
|
uint8_t rlen)
|
||||||
{
|
{
|
||||||
ssize_t end = get_end_option_idx(packet);
|
ssize_t end = get_end_option_idx(packet);
|
||||||
@ -185,8 +183,7 @@ static ssize_t add_option_check(struct dhcpmsg packet[static 1], uint8_t code,
|
|||||||
return end;
|
return end;
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t add_u8_option(struct dhcpmsg packet[static 1], uint8_t code,
|
static size_t add_u8_option(struct dhcpmsg *packet, uint8_t code, uint8_t data)
|
||||||
uint8_t data)
|
|
||||||
{
|
{
|
||||||
ssize_t end = add_option_check(packet, code, 1);
|
ssize_t end = add_option_check(packet, code, 1);
|
||||||
if (end < 0)
|
if (end < 0)
|
||||||
@ -200,7 +197,7 @@ static size_t add_u8_option(struct dhcpmsg packet[static 1], uint8_t code,
|
|||||||
|
|
||||||
#ifndef NDHS_BUILD
|
#ifndef NDHS_BUILD
|
||||||
// Data should be in network byte order.
|
// Data should be in network byte order.
|
||||||
static size_t add_u16_option(struct dhcpmsg packet[static 1], uint8_t code,
|
static size_t add_u16_option(struct dhcpmsg *packet, uint8_t code,
|
||||||
uint16_t data)
|
uint16_t data)
|
||||||
{
|
{
|
||||||
ssize_t end = add_option_check(packet, code, 2);
|
ssize_t end = add_option_check(packet, code, 2);
|
||||||
@ -217,8 +214,7 @@ static size_t add_u16_option(struct dhcpmsg packet[static 1], uint8_t code,
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Data should be in network byte order.
|
// Data should be in network byte order.
|
||||||
size_t add_u32_option(struct dhcpmsg packet[static 1], uint8_t code,
|
size_t add_u32_option(struct dhcpmsg *packet, uint8_t code, uint32_t data)
|
||||||
uint32_t data)
|
|
||||||
{
|
{
|
||||||
ssize_t end = add_option_check(packet, code, 4);
|
ssize_t end = add_option_check(packet, code, 4);
|
||||||
if (end < 0)
|
if (end < 0)
|
||||||
@ -235,7 +231,7 @@ size_t add_u32_option(struct dhcpmsg packet[static 1], uint8_t code,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Add a parameter request list for stubborn DHCP servers
|
// Add a parameter request list for stubborn DHCP servers
|
||||||
size_t add_option_request_list(struct dhcpmsg packet[static 1])
|
size_t add_option_request_list(struct dhcpmsg *packet)
|
||||||
{
|
{
|
||||||
static const uint8_t reqdata[] = {
|
static const uint8_t reqdata[] = {
|
||||||
DCODE_SUBNET, DCODE_ROUTER, DCODE_DNS, DCODE_HOSTNAME, DCODE_DOMAIN,
|
DCODE_SUBNET, DCODE_ROUTER, DCODE_DNS, DCODE_HOSTNAME, DCODE_DOMAIN,
|
||||||
@ -246,53 +242,52 @@ size_t add_option_request_list(struct dhcpmsg packet[static 1])
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef NDHS_BUILD
|
#ifdef NDHS_BUILD
|
||||||
size_t add_option_domain_name(struct dhcpmsg packet[static 1],
|
size_t add_option_domain_name(struct dhcpmsg *packet, const char * const dom,
|
||||||
const char dom[static 1], size_t domlen)
|
size_t domlen)
|
||||||
{
|
{
|
||||||
return add_option_string(packet, DCODE_DOMAIN, dom, domlen);
|
return add_option_string(packet, DCODE_DOMAIN, dom, domlen);
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_option_subnet_mask(struct dhcpmsg packet[static 1], uint32_t subnet)
|
void add_option_subnet_mask(struct dhcpmsg *packet, uint32_t subnet)
|
||||||
{
|
{
|
||||||
add_u32_option(packet, DCODE_SUBNET, subnet);
|
add_u32_option(packet, DCODE_SUBNET, subnet);
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_option_broadcast(struct dhcpmsg packet[static 1], uint32_t bc)
|
void add_option_broadcast(struct dhcpmsg *packet, uint32_t bc)
|
||||||
{
|
{
|
||||||
add_u32_option(packet, DCODE_BROADCAST, bc);
|
add_u32_option(packet, DCODE_BROADCAST, bc);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void add_option_msgtype(struct dhcpmsg packet[static 1], uint8_t type)
|
void add_option_msgtype(struct dhcpmsg *packet, uint8_t type)
|
||||||
{
|
{
|
||||||
add_u8_option(packet, DCODE_MSGTYPE, type);
|
add_u8_option(packet, DCODE_MSGTYPE, type);
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_option_reqip(struct dhcpmsg packet[static 1], uint32_t ip)
|
void add_option_reqip(struct dhcpmsg *packet, uint32_t ip)
|
||||||
{
|
{
|
||||||
add_u32_option(packet, DCODE_REQIP, ip);
|
add_u32_option(packet, DCODE_REQIP, ip);
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_option_serverid(struct dhcpmsg packet[static 1], uint32_t sid)
|
void add_option_serverid(struct dhcpmsg *packet, uint32_t sid)
|
||||||
{
|
{
|
||||||
add_u32_option(packet, DCODE_SERVER_ID, sid);
|
add_u32_option(packet, DCODE_SERVER_ID, sid);
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_option_clientid(struct dhcpmsg packet[static 1],
|
void add_option_clientid(struct dhcpmsg *packet, const char * const clientid,
|
||||||
const char clientid[static 1],
|
|
||||||
size_t clen)
|
size_t clen)
|
||||||
{
|
{
|
||||||
add_option_string(packet, DCODE_CLIENT_ID, clientid, clen);
|
add_option_string(packet, DCODE_CLIENT_ID, clientid, clen);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef NDHS_BUILD
|
#ifndef NDHS_BUILD
|
||||||
void add_option_maxsize(struct dhcpmsg packet[static 1])
|
void add_option_maxsize(struct dhcpmsg *packet)
|
||||||
{
|
{
|
||||||
add_u16_option(packet, DCODE_MAX_SIZE,
|
add_u16_option(packet, DCODE_MAX_SIZE,
|
||||||
htons(sizeof(struct ip_udp_dhcp_packet)));
|
htons(sizeof(struct ip_udp_dhcp_packet)));
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_option_vendor(struct dhcpmsg packet[static 1])
|
void add_option_vendor(struct dhcpmsg *packet)
|
||||||
{
|
{
|
||||||
size_t len = strlen(client_config.vendor);
|
size_t len = strlen(client_config.vendor);
|
||||||
if (len)
|
if (len)
|
||||||
@ -301,7 +296,7 @@ void add_option_vendor(struct dhcpmsg packet[static 1])
|
|||||||
add_option_string(packet, DCODE_VENDOR, "ndhc", sizeof "ndhc" - 1);
|
add_option_string(packet, DCODE_VENDOR, "ndhc", sizeof "ndhc" - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void add_option_hostname(struct dhcpmsg packet[static 1])
|
void add_option_hostname(struct dhcpmsg *packet)
|
||||||
{
|
{
|
||||||
size_t len = strlen(client_config.hostname);
|
size_t len = strlen(client_config.hostname);
|
||||||
if (len)
|
if (len)
|
||||||
@ -309,7 +304,7 @@ void add_option_hostname(struct dhcpmsg packet[static 1])
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
uint32_t get_option_router(const struct dhcpmsg packet[static 1])
|
uint32_t get_option_router(const struct dhcpmsg * const packet)
|
||||||
{
|
{
|
||||||
ssize_t ol;
|
ssize_t ol;
|
||||||
uint32_t ret = 0;
|
uint32_t ret = 0;
|
||||||
@ -320,7 +315,7 @@ uint32_t get_option_router(const struct dhcpmsg packet[static 1])
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t get_option_msgtype(const struct dhcpmsg packet[static 1])
|
uint8_t get_option_msgtype(const struct dhcpmsg * const packet)
|
||||||
{
|
{
|
||||||
ssize_t ol;
|
ssize_t ol;
|
||||||
uint8_t ret = 0;
|
uint8_t ret = 0;
|
||||||
@ -331,7 +326,7 @@ uint8_t get_option_msgtype(const struct dhcpmsg packet[static 1])
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t get_option_serverid(const struct dhcpmsg packet[static 1], int *found)
|
uint32_t get_option_serverid(const struct dhcpmsg *const packet, int *found)
|
||||||
{
|
{
|
||||||
ssize_t ol;
|
ssize_t ol;
|
||||||
uint32_t ret = 0;
|
uint32_t ret = 0;
|
||||||
@ -345,7 +340,7 @@ uint32_t get_option_serverid(const struct dhcpmsg packet[static 1], int *found)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t get_option_leasetime(const struct dhcpmsg packet[static 1])
|
uint32_t get_option_leasetime(const struct dhcpmsg * const packet)
|
||||||
{
|
{
|
||||||
ssize_t ol;
|
ssize_t ol;
|
||||||
uint32_t ret = 0;
|
uint32_t ret = 0;
|
||||||
@ -359,8 +354,8 @@ uint32_t get_option_leasetime(const struct dhcpmsg packet[static 1])
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Returned buffer is not nul-terminated.
|
// Returned buffer is not nul-terminated.
|
||||||
size_t get_option_clientid(const struct dhcpmsg packet[static 1],
|
size_t get_option_clientid(const struct dhcpmsg * const packet, char *cbuf,
|
||||||
char cbuf[static 1], size_t clen)
|
size_t clen)
|
||||||
{
|
{
|
||||||
if (clen < 1)
|
if (clen < 1)
|
||||||
return 0;
|
return 0;
|
||||||
@ -368,3 +363,4 @@ size_t get_option_clientid(const struct dhcpmsg packet[static 1],
|
|||||||
(uint8_t *)cbuf, clen);
|
(uint8_t *)cbuf, clen);
|
||||||
return ol > 0 ? ol : 0;
|
return ol > 0 ? ol : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,37 +56,37 @@
|
|||||||
|
|
||||||
#define MAX_DOPT_SIZE 500
|
#define MAX_DOPT_SIZE 500
|
||||||
|
|
||||||
ssize_t get_dhcp_opt(const struct dhcpmsg packet[static 1], uint8_t code,
|
ssize_t get_dhcp_opt(const struct dhcpmsg * const packet, uint8_t code,
|
||||||
uint8_t *dbuf, ssize_t dlen);
|
uint8_t *dbuf, ssize_t dlen);
|
||||||
ssize_t get_end_option_idx(const struct dhcpmsg packet[static 1]);
|
ssize_t get_end_option_idx(const struct dhcpmsg * const packet);
|
||||||
|
|
||||||
size_t add_option_string(struct dhcpmsg packet[static 1], uint8_t code,
|
size_t add_option_string(struct dhcpmsg *packet, uint8_t code,
|
||||||
const char str[static 1], size_t slen);
|
const char *str, size_t slen);
|
||||||
size_t add_u32_option(struct dhcpmsg packet[static 1], uint8_t code,
|
size_t add_u32_option(struct dhcpmsg *packet, uint8_t code, uint32_t data);
|
||||||
uint32_t data);
|
|
||||||
|
|
||||||
size_t add_option_request_list(struct dhcpmsg packet[static 1]);
|
size_t add_option_request_list(struct dhcpmsg *packet);
|
||||||
#ifdef NDHS_BUILD
|
#ifdef NDHS_BUILD
|
||||||
size_t add_option_domain_name(struct dhcpmsg packet[static 1],
|
size_t add_option_domain_name(struct dhcpmsg *packet,
|
||||||
const char dom[static 1], size_t domlen);
|
const char * const dom, size_t domlen);
|
||||||
void add_option_subnet_mask(struct dhcpmsg packet[static 1], uint32_t subnet);
|
void add_option_subnet_mask(struct dhcpmsg *packet, uint32_t subnet);
|
||||||
void add_option_broadcast(struct dhcpmsg packet[static 1], uint32_t bc);
|
void add_option_broadcast(struct dhcpmsg *packet, uint32_t bc);
|
||||||
#endif
|
#endif
|
||||||
void add_option_msgtype(struct dhcpmsg packet[static 1], uint8_t type);
|
void add_option_msgtype(struct dhcpmsg *packet, uint8_t type);
|
||||||
void add_option_reqip(struct dhcpmsg packet[static 1], uint32_t ip);
|
void add_option_reqip(struct dhcpmsg *packet, uint32_t ip);
|
||||||
void add_option_serverid(struct dhcpmsg packet[static 1], uint32_t sid);
|
void add_option_serverid(struct dhcpmsg *packet, uint32_t sid);
|
||||||
void add_option_clientid(struct dhcpmsg packet[static 1],
|
void add_option_clientid(struct dhcpmsg *packet,
|
||||||
const char clientid[static 1], size_t clen);
|
const char * const clientid, size_t clen);
|
||||||
#ifndef NDHS_BUILD
|
#ifndef NDHS_BUILD
|
||||||
void add_option_maxsize(struct dhcpmsg packet[static 1]);
|
void add_option_maxsize(struct dhcpmsg *packet);
|
||||||
void add_option_vendor(struct dhcpmsg packet[static 1]);
|
void add_option_vendor(struct dhcpmsg *packet);
|
||||||
void add_option_hostname(struct dhcpmsg packet[static 1]);
|
void add_option_hostname(struct dhcpmsg *packet);
|
||||||
#endif
|
#endif
|
||||||
uint32_t get_option_router(const struct dhcpmsg packet[static 1]);
|
uint32_t get_option_router(const struct dhcpmsg * const packet);
|
||||||
uint8_t get_option_msgtype(const struct dhcpmsg packet[static 1]);
|
uint8_t get_option_msgtype(const struct dhcpmsg * const packet);
|
||||||
uint32_t get_option_serverid(const struct dhcpmsg packet[static 1], int *found);
|
uint32_t get_option_serverid(const struct dhcpmsg * const packet, int *found);
|
||||||
uint32_t get_option_leasetime(const struct dhcpmsg packet[static 1]);
|
uint32_t get_option_leasetime(const struct dhcpmsg *const packet);
|
||||||
size_t get_option_clientid(const struct dhcpmsg packet[static 1],
|
size_t get_option_clientid(const struct dhcpmsg * const packet,
|
||||||
char cbuf[static 1], size_t clen);
|
char *cbuf, size_t clen);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user