|
Zbigniew Jędrzejewski-Szmek |
f1004d |
From 82279e696605fe4eeadd1ca3744c76c8790f885b Mon Sep 17 00:00:00 2001
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
From: Lukasz Skalski <l.skalski@samsung.com>
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
Date: Fri, 10 Oct 2014 12:29:04 +0200
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
Subject: [PATCH] kdbus: fix buffer overflow in bus_get_owner_kdbus() function
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
Commit 710fc9779b7c (kdbus repo) introduced attaching items[]
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
instead of name[] in kdbus_cmd_conn_info struct. Commit 581fe6c81
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
(systemd repo) caught up with this change, but item size was not
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
properly calculated.
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
---
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
src/libsystemd/sd-bus/bus-control.c | 11 +++++------
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
1 file changed, 5 insertions(+), 6 deletions(-)
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
diff --git a/src/libsystemd/sd-bus/bus-control.c b/src/libsystemd/sd-bus/bus-control.c
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
index dbd94fc46b..7b106a3274 100644
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
--- a/src/libsystemd/sd-bus/bus-control.c
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
+++ b/src/libsystemd/sd-bus/bus-control.c
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
@@ -398,7 +398,7 @@ static int bus_get_owner_kdbus(
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
struct kdbus_cmd_conn_info *cmd;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
struct kdbus_conn_info *conn_info;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
struct kdbus_item *item;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
- size_t size;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
+ size_t size, l;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
uint64_t m, id;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
int r;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
@@ -410,13 +410,12 @@ static int bus_get_owner_kdbus(
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
cmd = alloca0_align(size, 8);
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
cmd->id = id;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
} else {
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
- size_t item_size = KDBUS_ITEM_HEADER_SIZE + strlen(name) + 1;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
-
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
- size = offsetof(struct kdbus_cmd_conn_info, items) + item_size;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
+ l = strlen(name) + 1;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
+ size = offsetof(struct kdbus_cmd_conn_info, items) + KDBUS_ITEM_SIZE(l);
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
cmd = alloca0_align(size, 8);
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
- cmd->items[0].size = item_size;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
+ cmd->items[0].size = KDBUS_ITEM_HEADER_SIZE + l;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
cmd->items[0].type = KDBUS_ITEM_NAME;
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
- strcpy(cmd->items[0].str, name);
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
+ memcpy(cmd->items[0].str, name, l);
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
}
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
|
|
Zbigniew Jędrzejewski-Szmek |
f1004d |
cmd->size = size;
|