Commit 0448558a authored by Marko Mäkelä's avatar Marko Mäkelä

Fix GCC 10.2.0 -Og -fsanitize=undefined -Wformat-overflow

For some reason, adding -fsanitize=undefined (cmake -DWITH_UBSAN=ON)
to the compilation flags will cause even more warnings to be emitted.
The warning was a bogus one:

tests/mysql_client_test.c:8632:22: error: '%d' directive writing between
1 and 11 bytes into a region of size 9 [-Werror=format-overflow=]
 8632 |     sprintf(field, "c%d int", i);
      |                      ^~
tests/mysql_client_test.c:8632:20: note: directive argument
in the range [-2147483648, 999]

The warning does not take into account that the lower bound of the
variable actually is 0. But, we can help the compiler and use an
unsigned variable.
parent 594c11ff
/* Copyright (c) 2002, 2014, Oracle and/or its affiliates. /* Copyright (c) 2002, 2014, Oracle and/or its affiliates.
Copyright (c) 2008, 2017, MariaDB Copyright (c) 2008, 2020, MariaDB
This program is free software; you can redistribute it and/or modify This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by it under the terms of the GNU General Public License as published by
...@@ -8457,7 +8457,8 @@ static void test_mem_overun() ...@@ -8457,7 +8457,8 @@ static void test_mem_overun()
char buffer[10000], field[10]; char buffer[10000], field[10];
MYSQL_STMT *stmt; MYSQL_STMT *stmt;
MYSQL_RES *field_res; MYSQL_RES *field_res;
int rc, i, length; int rc, length;
unsigned i;
myheader("test_mem_overun"); myheader("test_mem_overun");
...@@ -8471,7 +8472,7 @@ static void test_mem_overun() ...@@ -8471,7 +8472,7 @@ static void test_mem_overun()
strxmov(buffer, "create table t_mem_overun(", NullS); strxmov(buffer, "create table t_mem_overun(", NullS);
for (i= 0; i < 1000; i++) for (i= 0; i < 1000; i++)
{ {
sprintf(field, "c%d int", i); sprintf(field, "c%u int", i);
strxmov(buffer, buffer, field, ", ", NullS); strxmov(buffer, buffer, field, ", ", NullS);
} }
length= strlen(buffer); length= strlen(buffer);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment