|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
From 87c237865b445906e3df7873b0fcd0a9f8483f13 Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
From: Dan Williams <dcbw@redhat.com>
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
Date: Fri, 31 Oct 2014 12:20:21 -0500
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
Subject: [PATCH] sd-dhcp6-client: fix off-by-two error in DUID length
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
The duid data passed by the caller does not include the DUID type,
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
but sd_dhcp6_client_set_duid() was treating it like it did.
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
(cherry picked from commit 393b6f28ecec537f05567c4ec8af8c499d0ea226)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
---
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
src/libsystemd-network/sd-dhcp6-client.c | 10 +++++-----
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
1 file changed, 5 insertions(+), 5 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
diff --git a/src/libsystemd-network/sd-dhcp6-client.c b/src/libsystemd-network/sd-dhcp6-client.c
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
index fa4f9b5dc2..dbec1a2a8b 100644
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
--- a/src/libsystemd-network/sd-dhcp6-client.c
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+++ b/src/libsystemd-network/sd-dhcp6-client.c
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
@@ -200,19 +200,19 @@ int sd_dhcp6_client_set_duid(sd_dhcp6_client *client, uint16_t type, uint8_t *du
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
switch (type) {
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
case DHCP6_DUID_LLT:
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
- if (duid_len <= sizeof(client->duid.llt))
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ if (duid_len <= sizeof(client->duid.llt) - 2)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
return -EINVAL;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
break;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
case DHCP6_DUID_EN:
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
- if (duid_len != sizeof(client->duid.en))
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ if (duid_len != sizeof(client->duid.en) - 2)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
return -EINVAL;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
break;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
case DHCP6_DUID_LL:
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
- if (duid_len <= sizeof(client->duid.ll))
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ if (duid_len <= sizeof(client->duid.ll) - 2)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
return -EINVAL;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
break;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
case DHCP6_DUID_UUID:
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
- if (duid_len != sizeof(client->duid.uuid))
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ if (duid_len != sizeof(client->duid.uuid) - 2)
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
return -EINVAL;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
break;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
default:
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
@@ -222,7 +222,7 @@ int sd_dhcp6_client_set_duid(sd_dhcp6_client *client, uint16_t type, uint8_t *du
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
client->duid.raw.type = htobe16(type);
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
memcpy(&client->duid.raw.data, duid, duid_len);
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
- client->duid_len = duid_len;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
+ client->duid_len = duid_len + 2; /* +2 for sizeof(type) */
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
return 0;
|
|
Zbigniew Jędrzejewski-Szmek |
ea1976 |
}
|