Hi Sergei, On Mon, 2024-07-15 at 22:23 +0100, Sergei Trofimovich wrote: > `gcc-15` added a new warning in https://gcc.gnu.org/PR115185: > > i386_regs.c:88:11: error: initializer-string for array of 'char' is too > long [-Werror=unterminated-string-initialization] > 88 | "ax", "cx", "dx", "bx", "sp", "bp", "si", "di", "ip" > | ^~~~
OK, I see why you want to warn for this. There is a real chance you use those char array's with some str functions and then there is trouble. > `elfutils` does not need to store '\0'. We could either initialize the > arrays with individual bytes or allocate extra byte for null. With initialize with individual bytes you mean: diff --git a/backends/i386_regs.c b/backends/i386_regs.c index 7ec93bb9fc13..ead55ef7f931 100644 --- a/backends/i386_regs.c +++ b/backends/i386_regs.c @@ -85,7 +85,15 @@ i386_register_info (Ebl *ebl __attribute__ ((unused)), { static const char baseregs[][2] = { - "ax", "cx", "dx", "bx", "sp", "bp", "si", "di", "ip" + {'a', 'x'}, + {'c', 'x'}, + {'d', 'x'}, + {'b', 'x'}, + {'s', 'p'}, + {'b', 'p'}, + {'s', 'i'}, + {'d', 'i'}, + {'i', 'p'}, }; case 4: ? Since the use of this array is basically just: name[0] = 'r'; name[1] = baseregs[regno][0]; name[2] = baseregs[regno][1]; I think I prefer the individual bytes init way. It makes more clear what we really use these arrays for. imho. Thanks, Mark