From eca1e5f973f3ef837ce7dc926901c7fbcab6ffc2 Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Sun, 17 Sep 2017 21:09:23 +0200 Subject: [PATCH 1/2] make keys_size not return 4096 all the time. --- src/attributes/key.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/src/attributes/key.c b/src/attributes/key.c index 6841bbd71..00f81a80e 100644 --- a/src/attributes/key.c +++ b/src/attributes/key.c @@ -67,8 +67,12 @@ static int keys_size(int n) { assert(n > 0 && n <= 4096); if (n <= 1) return 1; if (n <= 4) return 4; + if (n <= 8) return 8; if (n <= 16) return 16; if (n <= 256) return 256; + if (n <= 512) return 512; + if (n <= 1024) return 1024; + if (n <= 2048) return 2048; return 4096; } From 97dc98862b405b3e14e13f13bab147265f94c6e1 Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Mon, 18 Sep 2017 07:53:02 +0200 Subject: [PATCH 2/2] do not use strncpy, then --- src/kernel/equipment.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/kernel/equipment.c b/src/kernel/equipment.c index ca2f68a02..98d6b1e70 100644 --- a/src/kernel/equipment.c +++ b/src/kernel/equipment.c @@ -225,13 +225,15 @@ equipment *get_equipment(const char *eqname) equipment *create_equipment(const char *eqname) { + size_t len = strlen(eqname); eq_entry ent; - if (strlen(eqname) > EQNAMELEN) { + if (len > EQNAMELEN) { log_error("equipment names should be no longer than %d bytes: %s", EQNAMELEN, eqname); + len = EQNAMELEN; } - /* OBS: we require the nul-padding property of strncpy here, so do not use strlcpy: */ - strncpy(ent.key, eqname, EQNAMELEN); + memset(ent.key, 0, EQNAMELEN); + memcpy(ent.key, eqname, len); ent.value = (equipment *)calloc(1, sizeof(equipment)); ent.value->name = strdup(eqname);