systemd: update code from upstream (2019-01-06)
This is a direct dump from systemd git. ====== SYSTEMD_DIR=../systemd COMMIT=4a2c3dc318fab4e3cbe33e9835372f67e5114d54 ( cd "$SYSTEMD_DIR" git checkout "$COMMIT" git reset --hard git clean -fdx ) git ls-files -z :/src/systemd/src/ \ :/shared/systemd/src/ \ :/shared/nm-utils/unaligned.h | \ xargs -0 rm -f nm_copy_sd_shared() { mkdir -p "./shared/systemd/$(dirname "$1")" cp "$SYSTEMD_DIR/$1" "./shared/systemd/$1" } nm_copy_sd_core() { mkdir -p "./src/systemd/$(dirname "$1")" cp "$SYSTEMD_DIR/$1" "./src/systemd/$1" } nm_copy_sd_nmutils() { mkdir -p "./shared/nm-utils/" cp "$SYSTEMD_DIR/$1" "./shared/nm-utils/${1##*/}" } nm_copy_sd_core "src/libsystemd-network/arp-util.c" nm_copy_sd_core "src/libsystemd-network/arp-util.h" nm_copy_sd_core "src/libsystemd-network/dhcp-identifier.c" nm_copy_sd_core "src/libsystemd-network/dhcp-identifier.h" nm_copy_sd_core "src/libsystemd-network/dhcp-internal.h" nm_copy_sd_core "src/libsystemd-network/dhcp-lease-internal.h" nm_copy_sd_core "src/libsystemd-network/dhcp-network.c" nm_copy_sd_core "src/libsystemd-network/dhcp-option.c" nm_copy_sd_core "src/libsystemd-network/dhcp-packet.c" nm_copy_sd_core "src/libsystemd-network/dhcp-protocol.h" nm_copy_sd_core "src/libsystemd-network/dhcp6-internal.h" nm_copy_sd_core "src/libsystemd-network/dhcp6-lease-internal.h" nm_copy_sd_core "src/libsystemd-network/dhcp6-network.c" nm_copy_sd_core "src/libsystemd-network/dhcp6-option.c" nm_copy_sd_core "src/libsystemd-network/dhcp6-protocol.h" nm_copy_sd_core "src/libsystemd-network/lldp-internal.h" nm_copy_sd_core "src/libsystemd-network/lldp-neighbor.c" nm_copy_sd_core "src/libsystemd-network/lldp-neighbor.h" nm_copy_sd_core "src/libsystemd-network/lldp-network.c" nm_copy_sd_core "src/libsystemd-network/lldp-network.h" nm_copy_sd_core "src/libsystemd-network/network-internal.c" nm_copy_sd_core "src/libsystemd-network/network-internal.h" nm_copy_sd_core "src/libsystemd-network/sd-dhcp-client.c" nm_copy_sd_core "src/libsystemd-network/sd-dhcp-lease.c" nm_copy_sd_core "src/libsystemd-network/sd-dhcp6-client.c" nm_copy_sd_core "src/libsystemd-network/sd-dhcp6-lease.c" nm_copy_sd_core "src/libsystemd-network/sd-ipv4acd.c" nm_copy_sd_core "src/libsystemd-network/sd-ipv4ll.c" nm_copy_sd_core "src/libsystemd-network/sd-lldp.c" nm_copy_sd_core "src/libsystemd/sd-event/event-source.h" nm_copy_sd_core "src/libsystemd/sd-event/event-util.c" nm_copy_sd_core "src/libsystemd/sd-event/event-util.h" nm_copy_sd_core "src/libsystemd/sd-event/sd-event.c" nm_copy_sd_core "src/libsystemd/sd-id128/id128-util.c" nm_copy_sd_core "src/libsystemd/sd-id128/id128-util.h" nm_copy_sd_core "src/libsystemd/sd-id128/sd-id128.c" nm_copy_sd_core "src/shared/dns-domain.c" nm_copy_sd_core "src/shared/dns-domain.h" nm_copy_sd_core "src/systemd/_sd-common.h" nm_copy_sd_core "src/systemd/sd-dhcp-client.h" nm_copy_sd_core "src/systemd/sd-dhcp-lease.h" nm_copy_sd_core "src/systemd/sd-dhcp6-client.h" nm_copy_sd_core "src/systemd/sd-dhcp6-lease.h" nm_copy_sd_core "src/systemd/sd-event.h" nm_copy_sd_core "src/systemd/sd-id128.h" nm_copy_sd_core "src/systemd/sd-ipv4acd.h" nm_copy_sd_core "src/systemd/sd-ipv4ll.h" nm_copy_sd_core "src/systemd/sd-lldp.h" nm_copy_sd_core "src/systemd/sd-ndisc.h" nm_copy_sd_nmutils "src/basic/unaligned.h" nm_copy_sd_shared "src/basic/alloc-util.c" nm_copy_sd_shared "src/basic/alloc-util.h" nm_copy_sd_shared "src/basic/async.h" nm_copy_sd_shared "src/basic/env-file.c" nm_copy_sd_shared "src/basic/env-file.h" nm_copy_sd_shared "src/basic/env-util.c" nm_copy_sd_shared "src/basic/env-util.h" nm_copy_sd_shared "src/basic/escape.c" nm_copy_sd_shared "src/basic/escape.h" nm_copy_sd_shared "src/basic/ether-addr-util.c" nm_copy_sd_shared "src/basic/ether-addr-util.h" nm_copy_sd_shared "src/basic/extract-word.c" nm_copy_sd_shared "src/basic/extract-word.h" nm_copy_sd_shared "src/basic/fd-util.c" nm_copy_sd_shared "src/basic/fd-util.h" nm_copy_sd_shared "src/basic/fileio.c" nm_copy_sd_shared "src/basic/fileio.h" nm_copy_sd_shared "src/basic/fs-util.c" nm_copy_sd_shared "src/basic/fs-util.h" nm_copy_sd_shared "src/basic/hash-funcs.c" nm_copy_sd_shared "src/basic/hash-funcs.h" nm_copy_sd_shared "src/basic/hashmap.c" nm_copy_sd_shared "src/basic/hashmap.h" nm_copy_sd_shared "src/basic/hexdecoct.c" nm_copy_sd_shared "src/basic/hexdecoct.h" nm_copy_sd_shared "src/basic/hostname-util.c" nm_copy_sd_shared "src/basic/hostname-util.h" nm_copy_sd_shared "src/basic/in-addr-util.c" nm_copy_sd_shared "src/basic/in-addr-util.h" nm_copy_sd_shared "src/basic/io-util.c" nm_copy_sd_shared "src/basic/io-util.h" nm_copy_sd_shared "src/basic/list.h" nm_copy_sd_shared "src/basic/log.h" nm_copy_sd_shared "src/basic/macro.h" nm_copy_sd_shared "src/basic/mempool.c" nm_copy_sd_shared "src/basic/mempool.h" nm_copy_sd_shared "src/basic/missing_type.h" nm_copy_sd_shared "src/basic/parse-util.c" nm_copy_sd_shared "src/basic/parse-util.h" nm_copy_sd_shared "src/basic/path-util.c" nm_copy_sd_shared "src/basic/path-util.h" nm_copy_sd_shared "src/basic/prioq.c" nm_copy_sd_shared "src/basic/prioq.h" nm_copy_sd_shared "src/basic/process-util.c" nm_copy_sd_shared "src/basic/process-util.h" nm_copy_sd_shared "src/basic/random-util.c" nm_copy_sd_shared "src/basic/random-util.h" nm_copy_sd_shared "src/basic/refcnt.h" nm_copy_sd_shared "src/basic/set.h" nm_copy_sd_shared "src/basic/signal-util.h" nm_copy_sd_shared "src/basic/siphash24.h" nm_copy_sd_shared "src/basic/socket-util.c" nm_copy_sd_shared "src/basic/socket-util.h" nm_copy_sd_shared "src/basic/sparse-endian.h" nm_copy_sd_shared "src/basic/stat-util.c" nm_copy_sd_shared "src/basic/stat-util.h" nm_copy_sd_shared "src/basic/stdio-util.h" nm_copy_sd_shared "src/basic/string-table.c" nm_copy_sd_shared "src/basic/string-table.h" nm_copy_sd_shared "src/basic/string-util.c" nm_copy_sd_shared "src/basic/string-util.h" nm_copy_sd_shared "src/basic/strv.c" nm_copy_sd_shared "src/basic/strv.h" nm_copy_sd_shared "src/basic/time-util.c" nm_copy_sd_shared "src/basic/time-util.h" nm_copy_sd_shared "src/basic/tmpfile-util.c" nm_copy_sd_shared "src/basic/tmpfile-util.h" nm_copy_sd_shared "src/basic/umask-util.h" nm_copy_sd_shared "src/basic/utf8.c" nm_copy_sd_shared "src/basic/utf8.h" nm_copy_sd_shared "src/basic/util.c" nm_copy_sd_shared "src/basic/util.h"
This commit is contained in:
@@ -70,7 +70,7 @@ int safe_close(int fd) {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void safe_close_pair(int p[]) {
|
void safe_close_pair(int p[static 2]) {
|
||||||
assert(p);
|
assert(p);
|
||||||
|
|
||||||
if (p[0] == p[1]) {
|
if (p[0] == p[1]) {
|
||||||
|
@@ -14,7 +14,7 @@
|
|||||||
|
|
||||||
int close_nointr(int fd);
|
int close_nointr(int fd);
|
||||||
int safe_close(int fd);
|
int safe_close(int fd);
|
||||||
void safe_close_pair(int p[]);
|
void safe_close_pair(int p[static 2]);
|
||||||
|
|
||||||
static inline int safe_close_above_stdio(int fd) {
|
static inline int safe_close_above_stdio(int fd) {
|
||||||
if (fd < 3) /* Don't close stdin/stdout/stderr, but still invalidate the fd by returning -1 */
|
if (fd < 3) /* Don't close stdin/stdout/stderr, but still invalidate the fd by returning -1 */
|
||||||
|
@@ -15,14 +15,14 @@ struct siphash {
|
|||||||
size_t inlen;
|
size_t inlen;
|
||||||
};
|
};
|
||||||
|
|
||||||
void siphash24_init(struct siphash *state, const uint8_t k[16]);
|
void siphash24_init(struct siphash *state, const uint8_t k[static 16]);
|
||||||
void siphash24_compress(const void *in, size_t inlen, struct siphash *state);
|
void siphash24_compress(const void *in, size_t inlen, struct siphash *state);
|
||||||
#define siphash24_compress_byte(byte, state) siphash24_compress((const uint8_t[]) { (byte) }, 1, (state))
|
#define siphash24_compress_byte(byte, state) siphash24_compress((const uint8_t[]) { (byte) }, 1, (state))
|
||||||
|
|
||||||
uint64_t siphash24_finalize(struct siphash *state);
|
uint64_t siphash24_finalize(struct siphash *state);
|
||||||
|
|
||||||
uint64_t siphash24(const void *in, size_t inlen, const uint8_t k[16]);
|
uint64_t siphash24(const void *in, size_t inlen, const uint8_t k[static 16]);
|
||||||
|
|
||||||
static inline uint64_t siphash24_string(const char *s, const uint8_t k[16]) {
|
static inline uint64_t siphash24_string(const char *s, const uint8_t k[static 16]) {
|
||||||
return siphash24(s, strlen(s) + 1, k);
|
return siphash24(s, strlen(s) + 1, k);
|
||||||
}
|
}
|
||||||
|
@@ -742,7 +742,7 @@ char *strreplace(const char *text, const char *old_string, const char *new_strin
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void advance_offsets(ssize_t diff, size_t offsets[2], size_t shift[2], size_t size) {
|
static void advance_offsets(ssize_t diff, size_t offsets[static 2], size_t shift[static 2], size_t size) {
|
||||||
if (!offsets)
|
if (!offsets)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@@ -24,7 +24,6 @@
|
|||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "process-util.h"
|
#include "process-util.h"
|
||||||
#include "serialize.h"
|
|
||||||
#include "stat-util.h"
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
|
@@ -557,7 +557,7 @@ uint64_t system_tasks_max_scale(uint64_t v, uint64_t max) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int version(void) {
|
int version(void) {
|
||||||
puts(PACKAGE_STRING "\n"
|
puts("systemd " STRINGIFY(PROJECT_VERSION) " (" GIT_VERSION ")\n"
|
||||||
SYSTEMD_FEATURES);
|
SYSTEMD_FEATURES);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@@ -691,7 +691,7 @@ _public_ int sd_lldp_neighbor_tlv_is_type(sd_lldp_neighbor *n, uint8_t type) {
|
|||||||
return type == k;
|
return type == k;
|
||||||
}
|
}
|
||||||
|
|
||||||
_public_ int sd_lldp_neighbor_tlv_get_oui(sd_lldp_neighbor *n, uint8_t oui[3], uint8_t *subtype) {
|
_public_ int sd_lldp_neighbor_tlv_get_oui(sd_lldp_neighbor *n, uint8_t oui[_SD_ARRAY_STATIC 3], uint8_t *subtype) {
|
||||||
const uint8_t *d;
|
const uint8_t *d;
|
||||||
size_t length;
|
size_t length;
|
||||||
int r;
|
int r;
|
||||||
@@ -720,7 +720,7 @@ _public_ int sd_lldp_neighbor_tlv_get_oui(sd_lldp_neighbor *n, uint8_t oui[3], u
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
_public_ int sd_lldp_neighbor_tlv_is_oui(sd_lldp_neighbor *n, const uint8_t oui[3], uint8_t subtype) {
|
_public_ int sd_lldp_neighbor_tlv_is_oui(sd_lldp_neighbor *n, const uint8_t oui[_SD_ARRAY_STATIC 3], uint8_t subtype) {
|
||||||
uint8_t k[3], st;
|
uint8_t k[3], st;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
|
@@ -118,19 +118,19 @@ static const uint8_t default_req_opts[] = {
|
|||||||
*/
|
*/
|
||||||
/* NOTE: using PRL options that Windows 10 RFC7844 implementation uses */
|
/* NOTE: using PRL options that Windows 10 RFC7844 implementation uses */
|
||||||
static const uint8_t default_req_opts_anonymize[] = {
|
static const uint8_t default_req_opts_anonymize[] = {
|
||||||
SD_DHCP_OPTION_SUBNET_MASK, /* 1 */
|
SD_DHCP_OPTION_SUBNET_MASK, /* 1 */
|
||||||
SD_DHCP_OPTION_ROUTER, /* 3 */
|
SD_DHCP_OPTION_ROUTER, /* 3 */
|
||||||
SD_DHCP_OPTION_DOMAIN_NAME_SERVER, /* 6 */
|
SD_DHCP_OPTION_DOMAIN_NAME_SERVER, /* 6 */
|
||||||
SD_DHCP_OPTION_DOMAIN_NAME, /* 15 */
|
SD_DHCP_OPTION_DOMAIN_NAME, /* 15 */
|
||||||
SD_DHCP_OPTION_ROUTER_DISCOVER, /* 31 */
|
SD_DHCP_OPTION_ROUTER_DISCOVER, /* 31 */
|
||||||
SD_DHCP_OPTION_STATIC_ROUTE, /* 33 */
|
SD_DHCP_OPTION_STATIC_ROUTE, /* 33 */
|
||||||
SD_DHCP_OPTION_VENDOR_SPECIFIC, /* 43 */
|
SD_DHCP_OPTION_VENDOR_SPECIFIC, /* 43 */
|
||||||
SD_DHCP_OPTION_NETBIOS_NAMESERVER, /* 44 */
|
SD_DHCP_OPTION_NETBIOS_NAMESERVER, /* 44 */
|
||||||
SD_DHCP_OPTION_NETBIOS_NODETYPE, /* 46 */
|
SD_DHCP_OPTION_NETBIOS_NODETYPE, /* 46 */
|
||||||
SD_DHCP_OPTION_NETBIOS_SCOPE, /* 47 */
|
SD_DHCP_OPTION_NETBIOS_SCOPE, /* 47 */
|
||||||
SD_DHCP_OPTION_CLASSLESS_STATIC_ROUTE, /* 121 */
|
SD_DHCP_OPTION_CLASSLESS_STATIC_ROUTE, /* 121 */
|
||||||
SD_DHCP_OPTION_PRIVATE_CLASSLESS_STATIC_ROUTE, /* 249 */
|
SD_DHCP_OPTION_PRIVATE_CLASSLESS_STATIC_ROUTE, /* 249 */
|
||||||
SD_DHCP_OPTION_PRIVATE_PROXY_AUTODISCOVERY, /* 252 */
|
SD_DHCP_OPTION_PRIVATE_PROXY_AUTODISCOVERY, /* 252 */
|
||||||
};
|
};
|
||||||
|
|
||||||
static int client_receive_message_raw(
|
static int client_receive_message_raw(
|
||||||
@@ -353,9 +353,9 @@ static int dhcp_client_set_iaid_duid_internal(
|
|||||||
size_t len;
|
size_t len;
|
||||||
|
|
||||||
assert_return(client, -EINVAL);
|
assert_return(client, -EINVAL);
|
||||||
assert_return(duid_len == 0 || duid != NULL, -EINVAL);
|
assert_return(duid_len == 0 || duid, -EINVAL);
|
||||||
|
|
||||||
if (duid != NULL) {
|
if (duid) {
|
||||||
r = dhcp_validate_duid_len(duid_type, duid_len, true);
|
r = dhcp_validate_duid_len(duid_type, duid_len, true);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return r;
|
||||||
@@ -377,7 +377,7 @@ static int dhcp_client_set_iaid_duid_internal(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (duid != NULL) {
|
if (duid) {
|
||||||
client->client_id.ns.duid.type = htobe16(duid_type);
|
client->client_id.ns.duid.type = htobe16(duid_type);
|
||||||
memcpy(&client->client_id.ns.duid.raw.data, duid, duid_len);
|
memcpy(&client->client_id.ns.duid.raw.data, duid, duid_len);
|
||||||
len = sizeof(client->client_id.ns.duid.type) + duid_len;
|
len = sizeof(client->client_id.ns.duid.type) + duid_len;
|
||||||
@@ -1795,7 +1795,7 @@ static int client_receive_message_raw(
|
|||||||
} else if ((size_t)len < sizeof(DHCPPacket))
|
} else if ((size_t)len < sizeof(DHCPPacket))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
CMSG_FOREACH(cmsg, &msg) {
|
CMSG_FOREACH(cmsg, &msg)
|
||||||
if (cmsg->cmsg_level == SOL_PACKET &&
|
if (cmsg->cmsg_level == SOL_PACKET &&
|
||||||
cmsg->cmsg_type == PACKET_AUXDATA &&
|
cmsg->cmsg_type == PACKET_AUXDATA &&
|
||||||
cmsg->cmsg_len == CMSG_LEN(sizeof(struct tpacket_auxdata))) {
|
cmsg->cmsg_len == CMSG_LEN(sizeof(struct tpacket_auxdata))) {
|
||||||
@@ -1804,7 +1804,6 @@ static int client_receive_message_raw(
|
|||||||
checksum = !(aux->tp_status & TP_STATUS_CSUMNOTREADY);
|
checksum = !(aux->tp_status & TP_STATUS_CSUMNOTREADY);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
r = dhcp_packet_verify_headers(packet, len, checksum, client->port);
|
r = dhcp_packet_verify_headers(packet, len, checksum, client->port);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
|
@@ -18,7 +18,7 @@
|
|||||||
#include "user-util.h"
|
#include "user-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
_public_ char *sd_id128_to_string(sd_id128_t id, char s[SD_ID128_STRING_MAX]) {
|
_public_ char *sd_id128_to_string(sd_id128_t id, char s[_SD_ARRAY_STATIC SD_ID128_STRING_MAX]) {
|
||||||
unsigned n;
|
unsigned n;
|
||||||
|
|
||||||
assert_return(s, NULL);
|
assert_return(s, NULL);
|
||||||
|
@@ -72,6 +72,14 @@ typedef void (*_sd_destroy_t)(void *userdata);
|
|||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifndef _SD_ARRAY_STATIC
|
||||||
|
# if __STDC_VERSION__ >= 199901L
|
||||||
|
# define _SD_ARRAY_STATIC static
|
||||||
|
# else
|
||||||
|
# define _SD_ARRAY_STATIC
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#define _SD_DEFINE_POINTER_CLEANUP_FUNC(type, func) \
|
#define _SD_DEFINE_POINTER_CLEANUP_FUNC(type, func) \
|
||||||
static __inline__ void func##p(type **p) { \
|
static __inline__ void func##p(type **p) { \
|
||||||
if (*p) \
|
if (*p) \
|
||||||
|
@@ -35,7 +35,7 @@ union sd_id128 {
|
|||||||
|
|
||||||
#define SD_ID128_STRING_MAX 33
|
#define SD_ID128_STRING_MAX 33
|
||||||
|
|
||||||
char *sd_id128_to_string(sd_id128_t id, char s[SD_ID128_STRING_MAX]);
|
char *sd_id128_to_string(sd_id128_t id, char s[_SD_ARRAY_STATIC SD_ID128_STRING_MAX]);
|
||||||
int sd_id128_from_string(const char *s, sd_id128_t *ret);
|
int sd_id128_from_string(const char *s, sd_id128_t *ret);
|
||||||
|
|
||||||
int sd_id128_randomize(sd_id128_t *ret);
|
int sd_id128_randomize(sd_id128_t *ret);
|
||||||
|
@@ -27,7 +27,7 @@
|
|||||||
|
|
||||||
_SD_BEGIN_DECLARATIONS;
|
_SD_BEGIN_DECLARATIONS;
|
||||||
|
|
||||||
/* IEEE 802.3AB Clause 9: TLV Types */
|
/* IEEE 802.1AB-2009 Clause 8: TLV Types */
|
||||||
enum {
|
enum {
|
||||||
SD_LLDP_TYPE_END = 0,
|
SD_LLDP_TYPE_END = 0,
|
||||||
SD_LLDP_TYPE_CHASSIS_ID = 1,
|
SD_LLDP_TYPE_CHASSIS_ID = 1,
|
||||||
@@ -41,7 +41,7 @@ enum {
|
|||||||
SD_LLDP_TYPE_PRIVATE = 127,
|
SD_LLDP_TYPE_PRIVATE = 127,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* IEEE 802.3AB Clause 9.5.2: Chassis subtypes */
|
/* IEEE 802.1AB-2009 Clause 8.5.2: Chassis subtypes */
|
||||||
enum {
|
enum {
|
||||||
SD_LLDP_CHASSIS_SUBTYPE_RESERVED = 0,
|
SD_LLDP_CHASSIS_SUBTYPE_RESERVED = 0,
|
||||||
SD_LLDP_CHASSIS_SUBTYPE_CHASSIS_COMPONENT = 1,
|
SD_LLDP_CHASSIS_SUBTYPE_CHASSIS_COMPONENT = 1,
|
||||||
@@ -53,7 +53,7 @@ enum {
|
|||||||
SD_LLDP_CHASSIS_SUBTYPE_LOCALLY_ASSIGNED = 7,
|
SD_LLDP_CHASSIS_SUBTYPE_LOCALLY_ASSIGNED = 7,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* IEEE 802.3AB Clause 9.5.3: Port subtype */
|
/* IEEE 802.1AB-2009 Clause 8.5.3: Port subtype */
|
||||||
enum {
|
enum {
|
||||||
SD_LLDP_PORT_SUBTYPE_RESERVED = 0,
|
SD_LLDP_PORT_SUBTYPE_RESERVED = 0,
|
||||||
SD_LLDP_PORT_SUBTYPE_INTERFACE_ALIAS = 1,
|
SD_LLDP_PORT_SUBTYPE_INTERFACE_ALIAS = 1,
|
||||||
@@ -65,6 +65,7 @@ enum {
|
|||||||
SD_LLDP_PORT_SUBTYPE_LOCALLY_ASSIGNED = 7,
|
SD_LLDP_PORT_SUBTYPE_LOCALLY_ASSIGNED = 7,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* IEEE 802.1AB-2009 Clause 8.5.8: System capabilities */
|
||||||
enum {
|
enum {
|
||||||
SD_LLDP_SYSTEM_CAPABILITIES_OTHER = 1 << 0,
|
SD_LLDP_SYSTEM_CAPABILITIES_OTHER = 1 << 0,
|
||||||
SD_LLDP_SYSTEM_CAPABILITIES_REPEATER = 1 << 1,
|
SD_LLDP_SYSTEM_CAPABILITIES_REPEATER = 1 << 1,
|
||||||
@@ -95,6 +96,7 @@ enum {
|
|||||||
#define SD_LLDP_OUI_802_1 (uint8_t[]) { 0x00, 0x80, 0xc2 }
|
#define SD_LLDP_OUI_802_1 (uint8_t[]) { 0x00, 0x80, 0xc2 }
|
||||||
#define SD_LLDP_OUI_802_3 (uint8_t[]) { 0x00, 0x12, 0x0f }
|
#define SD_LLDP_OUI_802_3 (uint8_t[]) { 0x00, 0x12, 0x0f }
|
||||||
|
|
||||||
|
/* IEEE 802.1AB-2009 Annex E */
|
||||||
enum {
|
enum {
|
||||||
SD_LLDP_OUI_802_1_SUBTYPE_PORT_VLAN_ID = 1,
|
SD_LLDP_OUI_802_1_SUBTYPE_PORT_VLAN_ID = 1,
|
||||||
SD_LLDP_OUI_802_1_SUBTYPE_PORT_PROTOCOL_VLAN_ID = 2,
|
SD_LLDP_OUI_802_1_SUBTYPE_PORT_PROTOCOL_VLAN_ID = 2,
|
||||||
@@ -105,6 +107,14 @@ enum {
|
|||||||
SD_LLDP_OUI_802_1_SUBTYPE_LINK_AGGREGATION = 7,
|
SD_LLDP_OUI_802_1_SUBTYPE_LINK_AGGREGATION = 7,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* IEEE 802.1AB-2009 Annex F */
|
||||||
|
enum {
|
||||||
|
SD_LLDP_OUI_802_3_SUBTYPE_MAC_PHY_CONFIG_STATUS = 1,
|
||||||
|
SD_LLDP_OUI_802_3_SUBTYPE_POWER_VIA_MDI = 2,
|
||||||
|
SD_LLDP_OUI_802_3_SUBTYPE_LINK_AGGREGATION = 3,
|
||||||
|
SD_LLDP_OUI_802_3_SUBTYPE_MAXIMUM_FRAME_SIZE = 4,
|
||||||
|
};
|
||||||
|
|
||||||
typedef struct sd_lldp sd_lldp;
|
typedef struct sd_lldp sd_lldp;
|
||||||
typedef struct sd_lldp_neighbor sd_lldp_neighbor;
|
typedef struct sd_lldp_neighbor sd_lldp_neighbor;
|
||||||
|
|
||||||
@@ -168,8 +178,8 @@ int sd_lldp_neighbor_tlv_rewind(sd_lldp_neighbor *n);
|
|||||||
int sd_lldp_neighbor_tlv_next(sd_lldp_neighbor *n);
|
int sd_lldp_neighbor_tlv_next(sd_lldp_neighbor *n);
|
||||||
int sd_lldp_neighbor_tlv_get_type(sd_lldp_neighbor *n, uint8_t *type);
|
int sd_lldp_neighbor_tlv_get_type(sd_lldp_neighbor *n, uint8_t *type);
|
||||||
int sd_lldp_neighbor_tlv_is_type(sd_lldp_neighbor *n, uint8_t type);
|
int sd_lldp_neighbor_tlv_is_type(sd_lldp_neighbor *n, uint8_t type);
|
||||||
int sd_lldp_neighbor_tlv_get_oui(sd_lldp_neighbor *n, uint8_t oui[3], uint8_t *subtype);
|
int sd_lldp_neighbor_tlv_get_oui(sd_lldp_neighbor *n, uint8_t oui[_SD_ARRAY_STATIC 3], uint8_t *subtype);
|
||||||
int sd_lldp_neighbor_tlv_is_oui(sd_lldp_neighbor *n, const uint8_t oui[3], uint8_t subtype);
|
int sd_lldp_neighbor_tlv_is_oui(sd_lldp_neighbor *n, const uint8_t oui[_SD_ARRAY_STATIC 3], uint8_t subtype);
|
||||||
int sd_lldp_neighbor_tlv_get_raw(sd_lldp_neighbor *n, const void **ret, size_t *size);
|
int sd_lldp_neighbor_tlv_get_raw(sd_lldp_neighbor *n, const void **ret, size_t *size);
|
||||||
|
|
||||||
_SD_DEFINE_POINTER_CLEANUP_FUNC(sd_lldp, sd_lldp_unref);
|
_SD_DEFINE_POINTER_CLEANUP_FUNC(sd_lldp, sd_lldp_unref);
|
||||||
|
Reference in New Issue
Block a user