|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From fe4b2156256c5bdf52341576571ce9f095d9f085 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
From: Tom Gundersen <teg@jklm.no>
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Date: Thu, 2 Oct 2014 16:25:08 +0200
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
Subject: [PATCH] sd-dhcp6: do basic sanity-checking of supplied DUID
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
src/libsystemd-network/sd-dhcp6-client.c | 37 ++++++++++++++++++++++++++++++++
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
1 file changed, 37 insertions(+)
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
diff --git a/src/libsystemd-network/sd-dhcp6-client.c b/src/libsystemd-network/sd-dhcp6-client.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
index 42ad41887d..6ea68c915f 100644
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
--- a/src/libsystemd-network/sd-dhcp6-client.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+++ b/src/libsystemd-network/sd-dhcp6-client.c
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -69,11 +69,26 @@ struct sd_dhcp6_client {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
void *userdata;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
union {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
struct {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ uint16_t type; /* DHCP6_DUID_LLT */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ uint16_t htype;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ uint32_t time;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ uint8_t haddr[0];
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ } _packed_ llt;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ struct {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
uint16_t type; /* DHCP6_DUID_EN */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
uint32_t pen;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
uint8_t id[8];
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
} _packed_ en;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
struct {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ uint16_t type; /* DHCP6_DUID_LL */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ uint16_t htype;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ uint8_t haddr[0];
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ } _packed_ ll;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ struct {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ uint16_t type; /* DHCP6_DUID_UUID */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ sd_id128_t uuid;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ } _packed_ uuid;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ struct {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
uint16_t type;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
uint8_t data[MAX_DUID_LEN];
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
} _packed_ raw;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
@@ -165,6 +180,28 @@ int sd_dhcp6_client_set_duid(sd_dhcp6_client *client, uint16_t type, uint8_t *du
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
assert_return(duid, -EINVAL);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
assert_return(duid_len > 0 && duid_len <= MAX_DUID_LEN, -EINVAL);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ switch (type) {
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ case DHCP6_DUID_LLT:
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ if (duid_len <= sizeof(client->duid.llt))
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ return -EINVAL;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ break;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ case DHCP6_DUID_EN:
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ if (duid_len != sizeof(client->duid.en))
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ return -EINVAL;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ break;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ case DHCP6_DUID_LL:
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ if (duid_len <= sizeof(client->duid.ll))
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ return -EINVAL;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ break;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ case DHCP6_DUID_UUID:
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ if (duid_len != sizeof(client->duid.uuid))
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ return -EINVAL;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ break;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ default:
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ /* accept unknown type in order to be forward compatible */
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ break;
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+ }
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
+
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
client->duid.raw.type = htobe16(type);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
memcpy(&client->duid.raw.data, duid, duid_len);
|
|
Zbigniew Jędrzejewski-Szmek |
62fe94 |
client->duid_len = duid_len;
|