diff options
| author | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2016-03-21 18:24:24 -0400 | 
|---|---|---|
| committer | Zbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl> | 2016-03-21 18:24:24 -0400 | 
| commit | afec45395fb019f19ac1e157fce9128b0137b25e (patch) | |
| tree | 89af2437f2ec80a41576ce30180055fb8b830b73 /src | |
| parent | e31512b1c93a7ebd7e67730ac6d5d9a15b9b51ab (diff) | |
Revert "DHCP DUID and IAID configurability"
Diffstat (limited to 'src')
| -rw-r--r-- | src/libsystemd-network/dhcp-identifier.c | 2 | ||||
| -rw-r--r-- | src/libsystemd-network/dhcp-identifier.h | 41 | ||||
| -rw-r--r-- | src/libsystemd-network/dhcp6-protocol.h | 7 | ||||
| -rw-r--r-- | src/libsystemd-network/network-internal.c | 28 | ||||
| -rw-r--r-- | src/libsystemd-network/network-internal.h | 4 | ||||
| -rw-r--r-- | src/libsystemd-network/sd-dhcp-client.c | 48 | ||||
| -rw-r--r-- | src/libsystemd-network/sd-dhcp6-client.c | 49 | ||||
| -rw-r--r-- | src/network/networkd-conf.c | 133 | ||||
| -rw-r--r-- | src/network/networkd-conf.h | 32 | ||||
| -rw-r--r-- | src/network/networkd-dhcp4.c | 8 | ||||
| -rw-r--r-- | src/network/networkd-dhcp6.c | 10 | ||||
| -rw-r--r-- | src/network/networkd-gperf.gperf | 18 | ||||
| -rw-r--r-- | src/network/networkd-link.c | 18 | ||||
| -rw-r--r-- | src/network/networkd-manager.c | 2 | ||||
| -rw-r--r-- | src/network/networkd-network-gperf.gperf | 1 | ||||
| -rw-r--r-- | src/network/networkd-network.h | 2 | ||||
| -rw-r--r-- | src/network/networkd.c | 5 | ||||
| -rw-r--r-- | src/network/networkd.h | 5 | ||||
| -rw-r--r-- | src/systemd/sd-dhcp-client.h | 4 | ||||
| -rw-r--r-- | src/systemd/sd-dhcp6-client.h | 7 | 
20 files changed, 44 insertions, 380 deletions
| diff --git a/src/libsystemd-network/dhcp-identifier.c b/src/libsystemd-network/dhcp-identifier.c index 1bef368852..1d9ec7be82 100644 --- a/src/libsystemd-network/dhcp-identifier.c +++ b/src/libsystemd-network/dhcp-identifier.c @@ -43,7 +43,7 @@ int dhcp_identifier_set_duid_en(struct duid *duid, size_t *len) {          if (r < 0)                  return r; -        unaligned_write_be16(&duid->type, DHCP_DUID_TYPE_EN); +        unaligned_write_be16(&duid->type, DHCP6_DUID_EN);          unaligned_write_be32(&duid->en.pen, SYSTEMD_PEN);          *len = sizeof(duid->type) + sizeof(duid->en); diff --git a/src/libsystemd-network/dhcp-identifier.h b/src/libsystemd-network/dhcp-identifier.h index cb953cb416..93f06f5938 100644 --- a/src/libsystemd-network/dhcp-identifier.h +++ b/src/libsystemd-network/dhcp-identifier.h @@ -25,23 +25,13 @@  #include "sparse-endian.h"  #include "unaligned.h" -typedef enum DHCPDUIDType { -        DHCP_DUID_TYPE_RAW       = 0, -        DHCP_DUID_TYPE_LLT       = 1, -        DHCP_DUID_TYPE_EN        = 2, -        DHCP_DUID_TYPE_LL        = 3, -        DHCP_DUID_TYPE_UUID      = 4, -        _DHCP_DUID_TYPE_MAX, -        _DHCP_DUID_TYPE_INVALID  = -1, -} DHCPDUIDType; -  /* RFC 3315 section 9.1:   *      A DUID can be no more than 128 octets long (not including the type code).   */  #define MAX_DUID_LEN 128  struct duid { -        be16_t type; +        uint16_t type;          union {                  struct {                          /* DHCP6_DUID_LLT */ @@ -71,32 +61,3 @@ struct duid {  int dhcp_identifier_set_duid_en(struct duid *duid, size_t *len);  int dhcp_identifier_set_iaid(int ifindex, uint8_t *mac, size_t mac_len, void *_id); - -static inline int dhcp_validate_duid_len(be16_t duid_type, size_t duid_len) { -        struct duid d; - -        assert_return(duid_len > 0 && duid_len <= MAX_DUID_LEN, -EINVAL); - -        switch (be16toh(duid_type)) { -        case DHCP_DUID_TYPE_LLT: -                if (duid_len <= sizeof(d.llt)) -                        return -EINVAL; -                break; -        case DHCP_DUID_TYPE_EN: -                if (duid_len != sizeof(d.en)) -                        return -EINVAL; -                break; -        case DHCP_DUID_TYPE_LL: -                if (duid_len <= sizeof(d.ll)) -                        return -EINVAL; -                break; -        case DHCP_DUID_TYPE_UUID: -                if (duid_len != sizeof(d.uuid)) -                        return -EINVAL; -                break; -        default: -                /* accept unknown type in order to be forward compatible */ -                break; -        } -        return 0; -} diff --git a/src/libsystemd-network/dhcp6-protocol.h b/src/libsystemd-network/dhcp6-protocol.h index 2487c470ab..ee4bdfb07f 100644 --- a/src/libsystemd-network/dhcp6-protocol.h +++ b/src/libsystemd-network/dhcp6-protocol.h @@ -62,6 +62,13 @@ enum {  #define DHCP6_REB_TIMEOUT                       10 * USEC_PER_SEC  #define DHCP6_REB_MAX_RT                        600 * USEC_PER_SEC +enum { +        DHCP6_DUID_LLT                          = 1, +        DHCP6_DUID_EN                           = 2, +        DHCP6_DUID_LL                           = 3, +        DHCP6_DUID_UUID                         = 4, +}; +  enum DHCP6State {          DHCP6_STATE_STOPPED                     = 0,          DHCP6_STATE_INFORMATION_REQUEST         = 1, diff --git a/src/libsystemd-network/network-internal.c b/src/libsystemd-network/network-internal.c index 7c21f42591..cb7252bbeb 100644 --- a/src/libsystemd-network/network-internal.c +++ b/src/libsystemd-network/network-internal.c @@ -335,34 +335,6 @@ int config_parse_hwaddr(const char *unit,          return 0;  } -int config_parse_iaid_value(const char *unit, -                            const char *filename, -                            unsigned line, -                            const char *section, -                            unsigned section_line, -                            const char *lvalue, -                            int ltype, -                            const char *rvalue, -                            void *data, -                            void *userdata) { -        uint32_t iaid_value; -        int r; - -        assert(filename); -        assert(lvalue); -        assert(rvalue); -        assert(data); - -        if ((r = safe_atou32(rvalue, &iaid_value)) < 0) { -                log_syntax(unit, LOG_ERR, filename, line, 0, "Unable to read IAID: %s", rvalue); -                return r; -        } - -        *((be32_t *)data) = htobe32(iaid_value); - -        return 0; -} -  void serialize_in_addrs(FILE *f, const struct in_addr *addresses, size_t size) {          unsigned i; diff --git a/src/libsystemd-network/network-internal.h b/src/libsystemd-network/network-internal.h index d8b551e8ce..c8a531ab0f 100644 --- a/src/libsystemd-network/network-internal.h +++ b/src/libsystemd-network/network-internal.h @@ -62,10 +62,6 @@ int config_parse_ifalias(const char *unit, const char *filename, unsigned line,                           const char *section, unsigned section_line, const char *lvalue,                           int ltype, const char *rvalue, void *data, void *userdata); -int config_parse_iaid_value(const char *unit, const char *filename, unsigned line, -                            const char *section, unsigned section_line, const char *lvalue, -                            int ltype, const char *rvalue, void *data, void *userdata); -  int net_get_unique_predictable_data(struct udev_device *device, uint64_t *result);  const char *net_get_name(struct udev_device *device); diff --git a/src/libsystemd-network/sd-dhcp-client.c b/src/libsystemd-network/sd-dhcp-client.c index b108e35386..1188b31500 100644 --- a/src/libsystemd-network/sd-dhcp-client.c +++ b/src/libsystemd-network/sd-dhcp-client.c @@ -82,7 +82,7 @@ struct sd_dhcp_client {                          } _packed_ ll;                          struct {                                  /* 255: Node-specific (RFC 4361) */ -                                be32_t iaid; +                                uint32_t iaid;                                  struct duid duid;                          } _packed_ ns;                          struct { @@ -298,51 +298,6 @@ int sd_dhcp_client_set_client_id(sd_dhcp_client *client, uint8_t type,          return 0;  } -int sd_dhcp_client_set_iaid_duid(sd_dhcp_client *client, be32_t iaid, -                                 size_t duid_len, struct duid *duid) { -        DHCP_CLIENT_DONT_DESTROY(client); -        int r; -        assert_return(client, -EINVAL); -        zero(client->client_id); - -        client->client_id.type = 255; - -        /* If IAID is not configured, generate it. */ -        if (iaid == 0) { -                r = dhcp_identifier_set_iaid(client->index, client->mac_addr, -                                             client->mac_addr_len, -                                             &client->client_id.ns.iaid); -                if (r < 0) -                        return r; -        } else -                client->client_id.ns.iaid = iaid; - -        /* If DUID is not configured, generate DUID-EN. */ -        if (duid_len == 0) { -                r = dhcp_identifier_set_duid_en(&client->client_id.ns.duid, -                                                &duid_len); -                if (r < 0) -                        return r; -        } else { -                r = dhcp_validate_duid_len(client->client_id.type, -                                           duid_len - sizeof(client->client_id.type)); -                if (r < 0) -                        return r; -                memcpy(&client->client_id.ns.duid, duid, duid_len); -        } - -        client->client_id_len = sizeof(client->client_id.type) + duid_len + -                                sizeof(client->client_id.ns.iaid); - -        if (!IN_SET(client->state, DHCP_STATE_INIT, DHCP_STATE_STOPPED)) { -                log_dhcp_client(client, "Configured IAID+DUID, restarting."); -                client_stop(client, SD_DHCP_CLIENT_EVENT_STOP); -                sd_dhcp_client_start(client); -        } - -        return 0; -} -  int sd_dhcp_client_set_hostname(sd_dhcp_client *client,                                  const char *hostname) {          char *new_hostname = NULL; @@ -514,6 +469,7 @@ static int client_message_init(sd_dhcp_client *client, DHCPPacket **ret,          if (client->arp_type == ARPHRD_ETHER)                  memcpy(&packet->dhcp.chaddr, &client->mac_addr, ETH_ALEN); +        /* If no client identifier exists, construct an RFC 4361-compliant one */          if (client->client_id_len == 0) {                  size_t duid_len; diff --git a/src/libsystemd-network/sd-dhcp6-client.c b/src/libsystemd-network/sd-dhcp6-client.c index 7cecba120c..af4709d788 100644 --- a/src/libsystemd-network/sd-dhcp6-client.c +++ b/src/libsystemd-network/sd-dhcp6-client.c @@ -180,30 +180,41 @@ static int client_ensure_duid(sd_dhcp6_client *client) {          return dhcp_identifier_set_duid_en(&client->duid, &client->duid_len);  } -int sd_dhcp6_client_set_duid(sd_dhcp6_client *client, size_t duid_len, -                             struct duid *duid) { -        int r; +int sd_dhcp6_client_set_duid( +                sd_dhcp6_client *client, +                uint16_t type, +                uint8_t *duid, size_t duid_len) {          assert_return(client, -EINVAL); -        assert_return(IN_SET(client->state, DHCP6_STATE_STOPPED), -EBUSY); +        assert_return(duid, -EINVAL); +        assert_return(duid_len > 0 && duid_len <= MAX_DUID_LEN, -EINVAL); -        if (duid_len > 0) { -                r = dhcp_validate_duid_len(duid->type, -                                           duid_len - sizeof(duid->type)); -                if (r < 0) -                        return r; +        assert_return(IN_SET(client->state, DHCP6_STATE_STOPPED), -EBUSY); -                memcpy(&client->duid, duid, duid_len); -                client->duid_len = duid_len; +        switch (type) { +        case DHCP6_DUID_LLT: +                if (duid_len <= sizeof(client->duid.llt)) +                        return -EINVAL; +                break; +        case DHCP6_DUID_EN: +                if (duid_len != sizeof(client->duid.en)) +                        return -EINVAL; +                break; +        case DHCP6_DUID_LL: +                if (duid_len <= sizeof(client->duid.ll)) +                        return -EINVAL; +                break; +        case DHCP6_DUID_UUID: +                if (duid_len != sizeof(client->duid.uuid)) +                        return -EINVAL; +                break; +        default: +                /* accept unknown type in order to be forward compatible */ +                break;          } -        return 0; -} - -int sd_dhcp6_client_set_iaid(sd_dhcp6_client *client, be32_t iaid) { -        assert_return(client, -EINVAL); -        assert_return(IN_SET(client->state, DHCP6_STATE_STOPPED), -EBUSY); - -        client->ia_na.id = iaid; +        client->duid.type = htobe16(type); +        memcpy(&client->duid.raw.data, duid, duid_len); +        client->duid_len = duid_len + sizeof(client->duid.type);          return 0;  } diff --git a/src/network/networkd-conf.c b/src/network/networkd-conf.c deleted file mode 100644 index 4bc92b8171..0000000000 --- a/src/network/networkd-conf.c +++ /dev/null @@ -1,133 +0,0 @@ -/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ - -/*** -  This file is part of systemd. - -  Copyright 2014 Tom Gundersen <teg@jklm.no> - -  systemd is free software; you can redistribute it and/or modify it -  under the terms of the GNU Lesser General Public License as published by -  the Free Software Foundation; either version 2.1 of the License, or -  (at your option) any later version. - -  systemd is distributed in the hope that it will be useful, but -  WITHOUT ANY WARRANTY; without even the implied warranty of -  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -  Lesser General Public License for more details. - -  You should have received a copy of the GNU Lesser General Public License -  along with systemd; If not, see <http://www.gnu.org/licenses/>. - ***/ - -#include <ctype.h> - -#include "conf-parser.h" -#include "def.h" -#include "dhcp-identifier.h" -#include "networkd-conf.h" -#include "string-table.h" - -int manager_parse_config_file(Manager *m) { -        assert(m); - -        return config_parse_many(PKGSYSCONFDIR "/networkd.conf", -                                 CONF_PATHS_NULSTR("systemd/networkd.conf.d"), -                                 "DUID\0", -                                 config_item_perf_lookup, networkd_gperf_lookup, -                                 false, m); -} - -static const char* const dhcp_duid_type_table[_DHCP_DUID_TYPE_MAX] = { -        [DHCP_DUID_TYPE_RAW]  = "raw", -        [DHCP_DUID_TYPE_LLT]  = "link-layer-time", -        [DHCP_DUID_TYPE_EN]   = "vendor", -        [DHCP_DUID_TYPE_LL]   = "link-layer", -        [DHCP_DUID_TYPE_UUID] = "uuid" -}; -DEFINE_PRIVATE_STRING_TABLE_LOOKUP_FROM_STRING(dhcp_duid_type, DHCPDUIDType); -DEFINE_CONFIG_PARSE_ENUM(config_parse_dhcp_duid_type, dhcp_duid_type, DHCPDUIDType, "Failed to parse DHCP DUID type"); - -int config_parse_dhcp_duid_raw( -                const char *unit, -                const char *filename, -                unsigned line, -                const char *section, -                unsigned section_line, -                const char *lvalue, -                int ltype, -                const char *rvalue, -                void *data, -                void *userdata) { -        int r; -        long byte; -        char *cbyte, *pnext; -        const char *pduid = (const char *)rvalue; -        size_t count = 0, duid_len = 0; -        Manager *m = userdata; - -        assert(filename); -        assert(lvalue); -        assert(rvalue); -        assert(m); -        assert(m->dhcp_duid_type != _DHCP_DUID_TYPE_INVALID); - -        switch (m->dhcp_duid_type) { -        case DHCP_DUID_TYPE_LLT: -                /* RawData contains DUID-LLT link-layer address (offset 6) */ -                duid_len = 6; -                break; -        case DHCP_DUID_TYPE_EN: -                /* RawData contains DUID-EN identifier (offset 4) */ -                duid_len = 4; -                break; -        case DHCP_DUID_TYPE_LL: -                /* RawData contains DUID-LL link-layer address (offset 2) */ -                duid_len = 2; -                break; -        case DHCP_DUID_TYPE_UUID: -                /* RawData specifies UUID (offset 0) - fall thru */ -        case DHCP_DUID_TYPE_RAW: -                /* First two bytes of RawData is DUID Type - fall thru */ -        default: -                break; -        } - -        if (m->dhcp_duid_type != DHCP_DUID_TYPE_RAW) -                m->dhcp_duid.type = htobe16(m->dhcp_duid_type); - -        /* RawData contains DUID in format " NN:NN:NN... " */ -        while (true) { -                r = extract_first_word(&pduid, &cbyte, ":", 0); -                if (r < 0) { -                        log_error("Failed to read DUID."); -                        return -EINVAL; -                } -                if (r == 0) -                        break; -                if (duid_len >= MAX_DUID_LEN) { -                        log_error("DUID length exceeds maximum length."); -                        return -EINVAL; -                } - -                errno = 0; -                byte = strtol(cbyte, &pnext, 16); -                if ((errno == ERANGE && (byte == LONG_MAX || byte == LONG_MIN)) -                    || (errno != 0 && byte == 0) || (cbyte == pnext)) { -                        log_error("Invalid DUID byte: %s.", cbyte); -                        return -EINVAL;  -                } - -                /* If DHCP_DUID_TYPE_RAW, first two bytes holds DUID Type */ -                if ((m->dhcp_duid_type == DHCP_DUID_TYPE_RAW) && (count < 2)) { -                        m->dhcp_duid.type |= (byte << (8 * count)); -                        count++; -                        continue; -                } - -                m->dhcp_duid.raw.data[duid_len++] = byte; -        } - -        m->dhcp_duid_len = sizeof(m->dhcp_duid.type) + duid_len; - -        return 0; -} diff --git a/src/network/networkd-conf.h b/src/network/networkd-conf.h deleted file mode 100644 index 6d9ce010e3..0000000000 --- a/src/network/networkd-conf.h +++ /dev/null @@ -1,32 +0,0 @@ -/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ - -#pragma once - -/*** -  This file is part of systemd. - -  Copyright 2014 Tom Gundersen <teg@jklm.no> - -  systemd is free software; you can redistribute it and/or modify it -  under the terms of the GNU Lesser General Public License as published by -  the Free Software Foundation; either version 2.1 of the License, or -  (at your option) any later version. - -  systemd is distributed in the hope that it will be useful, but -  WITHOUT ANY WARRANTY; without even the implied warranty of -  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU -  Lesser General Public License for more details. - -  You should have received a copy of the GNU Lesser General Public License -  along with systemd; If not, see <http://www.gnu.org/licenses/>. -***/ - -#include "networkd.h" - - -int manager_parse_config_file(Manager *m); - -const struct ConfigPerfItem* networkd_gperf_lookup(const char *key, unsigned length); - -int config_parse_dhcp_duid_type(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); -int config_parse_dhcp_duid_raw(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); diff --git a/src/network/networkd-dhcp4.c b/src/network/networkd-dhcp4.c index 3bbb21295c..68998eabf2 100644 --- a/src/network/networkd-dhcp4.c +++ b/src/network/networkd-dhcp4.c @@ -625,13 +625,7 @@ int dhcp4_configure(Link *link) {          switch (link->network->dhcp_client_identifier) {          case DHCP_CLIENT_ID_DUID: -                /* If configured, apply user specified DUID and/or IAID */ -                r = sd_dhcp_client_set_iaid_duid(link->dhcp_client, -                                                 link->network->iaid_value, -                                                 link->manager->dhcp_duid_len, -                                                 &link->manager->dhcp_duid); -                if (r < 0) -                        return r; +                /* Library defaults to this. */                  break;          case DHCP_CLIENT_ID_MAC:                  r = sd_dhcp_client_set_client_id(link->dhcp_client, diff --git a/src/network/networkd-dhcp6.c b/src/network/networkd-dhcp6.c index 9f59cb3f8a..5f7a005c36 100644 --- a/src/network/networkd-dhcp6.c +++ b/src/network/networkd-dhcp6.c @@ -230,16 +230,6 @@ int dhcp6_configure(Link *link) {          if (r < 0)                  goto error; -        r = sd_dhcp6_client_set_iaid(client, link->network->iaid_value); -        if (r < 0) -                goto error; - -        r = sd_dhcp6_client_set_duid(client, -                                     link->manager->dhcp_duid_len, -                                     &link->manager->dhcp_duid); -        if (r < 0) -                goto error; -          r = sd_dhcp6_client_set_index(client, link->ifindex);          if (r < 0)                  goto error; diff --git a/src/network/networkd-gperf.gperf b/src/network/networkd-gperf.gperf deleted file mode 100644 index 3ef4155476..0000000000 --- a/src/network/networkd-gperf.gperf +++ /dev/null @@ -1,18 +0,0 @@ -%{ -#include <stddef.h> -#include "conf-parser.h" -#include "networkd-conf.h" -%} -struct ConfigPerfItem; -%null_strings -%language=ANSI-C -%define slot-name section_and_lvalue -%define hash-function-name networkd_gperf_hash -%define lookup-function-name networkd_gperf_lookup -%readonly-tables -%omit-struct-type -%struct-type -%includes -%% -DUID.Type,           config_parse_dhcp_duid_type,            0,            offsetof(Manager, dhcp_duid_type) -DUID.RawData,        config_parse_dhcp_duid_raw,             0,            offsetof(Manager, dhcp_duid) diff --git a/src/network/networkd-link.c b/src/network/networkd-link.c index 67b04560cd..ff4bd76554 100644 --- a/src/network/networkd-link.c +++ b/src/network/networkd-link.c @@ -2781,13 +2781,6 @@ int link_update(Link *link, sd_netlink_message *m) {                                                             ARPHRD_ETHER);                                  if (r < 0)                                          return log_link_warning_errno(link, r, "Could not update MAC address in DHCP client: %m"); - -                                r = sd_dhcp_client_set_iaid_duid(link->dhcp_client, -                                                                 link->network->iaid_value, -                                                                 link->manager->dhcp_duid_len, -                                                                 &link->manager->dhcp_duid); -                                if (r < 0) -                                        return log_link_warning_errno(link, r, "Could not update DUID/IAID in DHCP client: %m");                          }                          if (link->dhcp6_client) { @@ -2797,17 +2790,6 @@ int link_update(Link *link, sd_netlink_message *m) {                                                              ARPHRD_ETHER);                                  if (r < 0)                                          return log_link_warning_errno(link, r, "Could not update MAC address in DHCPv6 client: %m"); - -                                r = sd_dhcp6_client_set_iaid(link->dhcp6_client, -                                                             link->network->iaid_value); -                                if (r < 0) -                                        return log_link_warning_errno(link, r, "Could not update DHCPv6 IAID: %m"); - -                                r = sd_dhcp6_client_set_duid(link->dhcp6_client, -                                                             link->manager->dhcp_duid_len, -                                                             &link->manager->dhcp_duid); -                                if (r < 0) -                                        return log_link_warning_errno(link, r, "Could not update DHCPv6 DUID: %m");                          }                  }          } diff --git a/src/network/networkd-manager.c b/src/network/networkd-manager.c index 8d443f7b0f..b8cb7f875d 100644 --- a/src/network/networkd-manager.c +++ b/src/network/networkd-manager.c @@ -1037,8 +1037,6 @@ int manager_new(Manager **ret) {          if (r < 0)                  return r; -        m->dhcp_duid_type = _DHCP_DUID_TYPE_INVALID; -          *ret = m;          m = NULL; diff --git a/src/network/networkd-network-gperf.gperf b/src/network/networkd-network-gperf.gperf index 7a9a136d5b..a5d1714293 100644 --- a/src/network/networkd-network-gperf.gperf +++ b/src/network/networkd-network-gperf.gperf @@ -26,7 +26,6 @@ Match.KernelCommandLine,                config_parse_net_condition,  Match.Architecture,                     config_parse_net_condition,                     CONDITION_ARCHITECTURE,        offsetof(Network, match_arch)  Link.MACAddress,                        config_parse_hwaddr,                            0,                             offsetof(Network, mac)  Link.MTUBytes,                          config_parse_iec_size,                          0,                             offsetof(Network, mtu) -Link.IAIDValue,                         config_parse_iaid_value,                        0,                             offsetof(Network, iaid_value)  Network.Description,                    config_parse_string,                            0,                             offsetof(Network, description)  Network.Bridge,                         config_parse_netdev,                            0,                             offsetof(Network, bridge)  Network.Bond,                           config_parse_netdev,                            0,                             offsetof(Network, bond) diff --git a/src/network/networkd-network.h b/src/network/networkd-network.h index c5530cdfba..4a13e2b574 100644 --- a/src/network/networkd-network.h +++ b/src/network/networkd-network.h @@ -30,7 +30,6 @@ typedef struct Network Network;  #include "networkd-route.h"  #include "networkd-util.h"  #include "networkd.h" -#include "sparse-endian.h"  #define DHCP_ROUTE_METRIC 1024  #define IPV4LL_ROUTE_METRIC 2048 @@ -145,7 +144,6 @@ struct Network {          struct ether_addr *mac;          unsigned mtu; -        be32_t iaid_value;          LLDPMode lldp_mode; /* LLDP reception */          bool lldp_emit;     /* LLDP transmission */ diff --git a/src/network/networkd.c b/src/network/networkd.c index c8f81a2ca6..3a2615e6fd 100644 --- a/src/network/networkd.c +++ b/src/network/networkd.c @@ -21,7 +21,6 @@  #include "capability-util.h"  #include "networkd.h" -#include "networkd-conf.h"  #include "signal-util.h"  #include "user-util.h" @@ -90,10 +89,6 @@ int main(int argc, char *argv[]) {                  goto out;          } -        r = manager_parse_config_file(m); -        if (r < 0) -                log_warning_errno(r, "Failed to parse configuration file: %m"); -          r = manager_load_config(m);          if (r < 0) {                  log_error_errno(r, "Could not load configuration files: %m"); diff --git a/src/network/networkd.h b/src/network/networkd.h index d815f30610..6bdd8302a0 100644 --- a/src/network/networkd.h +++ b/src/network/networkd.h @@ -35,7 +35,6 @@ typedef struct Manager Manager;  #include "networkd-link.h"  #include "networkd-network.h"  #include "networkd-util.h" -#include "dhcp-identifier.h"  struct Manager {          sd_netlink *rtnl; @@ -62,10 +61,6 @@ struct Manager {          LIST_HEAD(AddressPool, address_pools);          usec_t network_dirs_ts_usec; - -        DHCPDUIDType dhcp_duid_type; -        size_t dhcp_duid_len; -        struct duid dhcp_duid;  };  extern const char* const network_dirs[]; diff --git a/src/systemd/sd-dhcp-client.h b/src/systemd/sd-dhcp-client.h index 7873cb1e04..ef45370505 100644 --- a/src/systemd/sd-dhcp-client.h +++ b/src/systemd/sd-dhcp-client.h @@ -27,7 +27,6 @@  #include "sd-dhcp-lease.h"  #include "sd-event.h" -#include "sparse-endian.h"  #include "_sd-common.h" @@ -83,7 +82,6 @@ enum {          SD_DHCP_OPTION_END                         = 255,  }; -struct duid;  typedef struct sd_dhcp_client sd_dhcp_client;  typedef void (*sd_dhcp_client_callback_t)(sd_dhcp_client *client, int event, @@ -100,8 +98,6 @@ int sd_dhcp_client_set_mac(sd_dhcp_client *client, const uint8_t *addr,                             size_t addr_len, uint16_t arp_type);  int sd_dhcp_client_set_client_id(sd_dhcp_client *client, uint8_t type,                                   const uint8_t *data, size_t data_len); -int sd_dhcp_client_set_iaid_duid(sd_dhcp_client *client, be32_t iaid, -                                 size_t duid_len, struct duid *duid);  int sd_dhcp_client_get_client_id(sd_dhcp_client *client, uint8_t *type,                                   const uint8_t **data, size_t *data_len);  int sd_dhcp_client_set_mtu(sd_dhcp_client *client, uint32_t mtu); diff --git a/src/systemd/sd-dhcp6-client.h b/src/systemd/sd-dhcp6-client.h index ebdd017628..1bedc941aa 100644 --- a/src/systemd/sd-dhcp6-client.h +++ b/src/systemd/sd-dhcp6-client.h @@ -26,7 +26,6 @@  #include "sd-dhcp6-lease.h"  #include "sd-event.h" -#include "sparse-endian.h"  #include "_sd-common.h" @@ -75,7 +74,6 @@ enum {          /* option codes 144-65535 are unassigned */  }; -struct duid;  typedef struct sd_dhcp6_client sd_dhcp6_client;  typedef void (*sd_dhcp6_client_callback_t)(sd_dhcp6_client *client, int event, @@ -87,9 +85,8 @@ int sd_dhcp6_client_set_index(sd_dhcp6_client *client, int interface_index);  int sd_dhcp6_client_set_local_address(sd_dhcp6_client *client, const struct in6_addr *local_address);  int sd_dhcp6_client_set_mac(sd_dhcp6_client *client, const uint8_t *addr,                              size_t addr_len, uint16_t arp_type); -int sd_dhcp6_client_set_duid(sd_dhcp6_client *client, size_t duid_len, -                             struct duid *duid); -int sd_dhcp6_client_set_iaid(sd_dhcp6_client *client, be32_t iaid); +int sd_dhcp6_client_set_duid(sd_dhcp6_client *client, uint16_t type, uint8_t *duid, +                             size_t duid_len);  int sd_dhcp6_client_set_information_request(sd_dhcp6_client *client, int enabled);  int sd_dhcp6_client_get_information_request(sd_dhcp6_client *client, int *enabled);  int sd_dhcp6_client_set_request_option(sd_dhcp6_client *client, | 
