From de9b34b6d4250056ae2c483cf22844880504bccc Mon Sep 17 00:00:00 2001 From: Tom Gundersen Date: Sun, 5 Apr 2015 12:17:29 +0200 Subject: sd-device: don't use alloca() within loops I shall not use alloca() within loops I shall not use alloca() within loops I shall not use alloca() within loops I shall not use alloca() within loops ... --- src/libsystemd/sd-device/device-private.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'src') diff --git a/src/libsystemd/sd-device/device-private.c b/src/libsystemd/sd-device/device-private.c index 86d760cddf..9788df769c 100644 --- a/src/libsystemd/sd-device/device-private.c +++ b/src/libsystemd/sd-device/device-private.c @@ -423,9 +423,10 @@ static int device_amend(sd_device *device, const char *key, const char *value) { size_t l; FOREACH_WORD(word, l, value, state) { - char *devlink; + char devlink[l + 1]; - devlink = strndupa(word, l); + strncpy(devlink, word, l); + devlink[l] = '\0'; r = device_add_devlink(device, devlink); if (r < 0) @@ -436,9 +437,10 @@ static int device_amend(sd_device *device, const char *key, const char *value) { size_t l; FOREACH_WORD_SEPARATOR(word, l, value, ":", state) { - char *tag; + char tag[l + 1]; - tag = strndupa(word, l); + (void)strncpy(tag, word, l); + tag[l] = '\0'; r = device_add_tag(device, tag); if (r < 0) -- cgit v1.2.3-54-g00ecf