1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Forbid variable length arrays

Although C99 introduces variable length array (VLA) feature, it is
not supported by MS Visual Studio (being C++ compiler first of all).
In this commit, we add Clang and GCC options to disable VLA, so they
would be disabled in non-MSVC builds as well.
This commit is contained in:
Pavel I. Kryukov 2019-01-02 22:03:13 +03:00 committed by Simon Tatham
parent 38e0a3d22e
commit 53f0ce3d0c
3 changed files with 10 additions and 10 deletions

View File

@ -190,7 +190,7 @@ AS_IF([test AS_VAR_GET(x_cv_linux_so_peercred) = yes],
if test "x$GCC" = "xyes"; then if test "x$GCC" = "xyes"; then
: :
AC_SUBST(WARNINGOPTS, ['-Wall -Werror -Wpointer-arith']) AC_SUBST(WARNINGOPTS, ['-Wall -Werror -Wpointer-arith -Wvla'])
else else
: :
AC_SUBST(WARNINGOPTS, []) AC_SUBST(WARNINGOPTS, [])

View File

@ -543,7 +543,7 @@ if (defined $makefiles{'clangcl'}) {
"LD = lld-link\n". "LD = lld-link\n".
"\n". "\n".
"# C compilation flags\n". "# C compilation flags\n".
&splitline("CFLAGS = --target=\$(CCTARGET) /nologo /W3 /O1 " . &splitline("CFLAGS = --target=\$(CCTARGET) /nologo /W3 /O1 -Wvla " .
(join " ", map {"-I$dirpfx$_"} @srcdirs) . (join " ", map {"-I$dirpfx$_"} @srcdirs) .
" /D_WINDOWS /D_WIN32_WINDOWS=0x500 /DWINVER=0x500 ". " /D_WINDOWS /D_WIN32_WINDOWS=0x500 /DWINVER=0x500 ".
"/D_CRT_SECURE_NO_WARNINGS /D_WINSOCK_DEPRECATED_NO_WARNINGS"). "/D_CRT_SECURE_NO_WARNINGS /D_WINSOCK_DEPRECATED_NO_WARNINGS").
@ -627,7 +627,7 @@ if (defined $makefiles{'cygwin'}) {
"# You may also need to tell windres where to find include files:\n". "# You may also need to tell windres where to find include files:\n".
"# RCINC = --include-dir c:\\cygwin\\include\\\n". "# RCINC = --include-dir c:\\cygwin\\include\\\n".
"\n". "\n".
&splitline("CFLAGS = -Wall -O2 -std=gnu99 -D_WINDOWS -DDEBUG". &splitline("CFLAGS = -Wall -O2 -std=gnu99 -Wvla -D_WINDOWS -DDEBUG".
" -DWIN32S_COMPAT -D_NO_OLDNAMES " . " -DWIN32S_COMPAT -D_NO_OLDNAMES " .
(join " ", map {"-I$dirpfx$_"} @srcdirs)) . (join " ", map {"-I$dirpfx$_"} @srcdirs)) .
"\n". "\n".
@ -1420,7 +1420,7 @@ if (defined $makefiles{'gtk'}) {
"\n". "\n".
"unexport CFLAGS # work around a weird issue with krb5-config\n". "unexport CFLAGS # work around a weird issue with krb5-config\n".
"\n". "\n".
&splitline("CFLAGS = -O2 -Wall -Werror -std=gnu99 -g " . &splitline("CFLAGS = -O2 -Wall -Werror -std=gnu99 -Wvla -g " .
(join " ", map {"-I$dirpfx$_"} @srcdirs) . (join " ", map {"-I$dirpfx$_"} @srcdirs) .
" \$(shell \$(GTK_CONFIG) --cflags)"). " \$(shell \$(GTK_CONFIG) --cflags)").
" -D _FILE_OFFSET_BITS=64\n". " -D _FILE_OFFSET_BITS=64\n".
@ -1501,7 +1501,7 @@ if (defined $makefiles{'unix'}) {
"\n". "\n".
"unexport CFLAGS # work around a weird issue with krb5-config\n". "unexport CFLAGS # work around a weird issue with krb5-config\n".
"\n". "\n".
&splitline("CFLAGS = -O2 -Wall -Werror -std=gnu99 -g " . &splitline("CFLAGS = -O2 -Wall -Werror -std=gnu99 -Wvla -g " .
(join " ", map {"-I$dirpfx$_"} @srcdirs)). (join " ", map {"-I$dirpfx$_"} @srcdirs)).
" -D _FILE_OFFSET_BITS=64\n". " -D _FILE_OFFSET_BITS=64\n".
"ULDFLAGS = \$(LDFLAGS)\n". "ULDFLAGS = \$(LDFLAGS)\n".
@ -1743,7 +1743,7 @@ if (defined $makefiles{'osx'}) {
print print
"CC = \$(TOOLPATH)gcc\n". "CC = \$(TOOLPATH)gcc\n".
"\n". "\n".
&splitline("CFLAGS = -O2 -Wall -Werror -std=gnu99 -g " . &splitline("CFLAGS = -O2 -Wall -Werror -std=gnu99 -Wvla -g " .
(join " ", map {"-I$dirpfx$_"} @srcdirs))."\n". (join " ", map {"-I$dirpfx$_"} @srcdirs))."\n".
"MLDFLAGS = -framework Cocoa\n". "MLDFLAGS = -framework Cocoa\n".
"ULDFLAGS =\n". "ULDFLAGS =\n".

View File

@ -311,7 +311,7 @@ EdwardsPoint *eddsa_public(mp_int *private_key, const ssh_keyalg *alg)
for (size_t i = 0; i < curve->fieldBytes; ++i) for (size_t i = 0; i < curve->fieldBytes; ++i)
put_byte(h, mp_get_byte(private_key, i)); put_byte(h, mp_get_byte(private_key, i));
unsigned char hash[extra->hash->hlen]; unsigned char hash[MAX_HASH_LEN];
ssh_hash_final(h, hash); ssh_hash_final(h, hash);
mp_int *exponent = eddsa_exponent_from_hash( mp_int *exponent = eddsa_exponent_from_hash(
@ -826,7 +826,7 @@ static mp_int *ecdsa_signing_exponent_from_data(
ptrlen data) ptrlen data)
{ {
/* Hash the data being signed. */ /* Hash the data being signed. */
unsigned char hash[extra->hash->hlen]; unsigned char hash[MAX_HASH_LEN];
ssh_hash *h = ssh_hash_new(extra->hash); ssh_hash *h = ssh_hash_new(extra->hash);
put_data(h, data.ptr, data.len); put_data(h, data.ptr, data.len);
ssh_hash_final(h, hash); ssh_hash_final(h, hash);
@ -919,7 +919,7 @@ static mp_int *eddsa_signing_exponent_from_data(
ptrlen r_encoded, ptrlen data) ptrlen r_encoded, ptrlen data)
{ {
/* Hash (r || public key || message) */ /* Hash (r || public key || message) */
unsigned char hash[extra->hash->hlen]; unsigned char hash[MAX_HASH_LEN];
ssh_hash *h = ssh_hash_new(extra->hash); ssh_hash *h = ssh_hash_new(extra->hash);
put_data(h, r_encoded.ptr, r_encoded.len); put_data(h, r_encoded.ptr, r_encoded.len);
put_epoint(h, ek->publicKey, ek->curve, true); /* omit string header */ put_epoint(h, ek->publicKey, ek->curve, true); /* omit string header */
@ -1055,7 +1055,7 @@ static void eddsa_sign(ssh_key *key, const void *data, int datalen,
* First, we hash the private key integer (bare, little-endian) * First, we hash the private key integer (bare, little-endian)
* into a hash generating 2*fieldBytes of output. * into a hash generating 2*fieldBytes of output.
*/ */
unsigned char hash[extra->hash->hlen]; unsigned char hash[MAX_HASH_LEN];
ssh_hash *h = ssh_hash_new(extra->hash); ssh_hash *h = ssh_hash_new(extra->hash);
for (size_t i = 0; i < ek->curve->fieldBytes; ++i) for (size_t i = 0; i < ek->curve->fieldBytes; ++i)
put_byte(h, mp_get_byte(ek->privateKey, i)); put_byte(h, mp_get_byte(ek->privateKey, i));