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:
parent
38e0a3d22e
commit
53f0ce3d0c
@ -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, [])
|
||||||
|
10
mkfiles.pl
10
mkfiles.pl
@ -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".
|
||||||
|
8
sshecc.c
8
sshecc.c
@ -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));
|
||||||
|
Loading…
Reference in New Issue
Block a user