提交 276d6050 编写于 作者: V Vasily Gorbik 提交者: Martin Schwidefsky

s390/tape: fix gcc 8 stringop-truncation warning

Replace strncpy which is used to deliberately avoid string NUL-termination
with memcpy. This allows to get rid of gcc 8 stringop-truncation warning:

    inlined from 'ext_to_int_kekl' at drivers/s390/char/tape_3590.c:123:2:
./include/linux/string.h:246:9: warning: '__builtin_strncpy'
output may be truncated copying 64 bytes from a string of length 64
[-Wstringop-truncation]

Also replaces "for" loop on memset.
Reviewed-by: NHeiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
上级 5d2f6e26
...@@ -113,16 +113,16 @@ static int crypt_enabled(struct tape_device *device) ...@@ -113,16 +113,16 @@ static int crypt_enabled(struct tape_device *device)
static void ext_to_int_kekl(struct tape390_kekl *in, static void ext_to_int_kekl(struct tape390_kekl *in,
struct tape3592_kekl *out) struct tape3592_kekl *out)
{ {
int i; int len;
memset(out, 0, sizeof(*out)); memset(out, 0, sizeof(*out));
if (in->type == TAPE390_KEKL_TYPE_HASH) if (in->type == TAPE390_KEKL_TYPE_HASH)
out->flags |= 0x40; out->flags |= 0x40;
if (in->type_on_tape == TAPE390_KEKL_TYPE_HASH) if (in->type_on_tape == TAPE390_KEKL_TYPE_HASH)
out->flags |= 0x80; out->flags |= 0x80;
strncpy(out->label, in->label, 64); len = min(sizeof(out->label), strlen(in->label));
for (i = strlen(in->label); i < sizeof(out->label); i++) memcpy(out->label, in->label, len);
out->label[i] = ' '; memset(out->label + len, ' ', sizeof(out->label) - len);
ASCEBC(out->label, sizeof(out->label)); ASCEBC(out->label, sizeof(out->label));
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册