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

Fix AES build on real Visual Studio.

Apparently a nasty trick I did in one of the selector vtable macros
was not acceptable to VS, which thinks that "string" ? NULL : NULL is
not a constant expression - it can't tell that the string literal has
a non-null value _or_ that it doesn't matter whether the value is null
or not.

Redone the vtable name construction in a way that depends only on the
actual preprocessor, not on the followup C expression semantics.
This commit is contained in:
Simon Tatham 2022-09-02 18:14:21 +01:00
parent c8b66101ee
commit fbb979aa98

View File

@ -39,7 +39,7 @@ static ssh_cipher *aes_select(const ssh_cipheralg *alg)
#define IF_NEON(...) #define IF_NEON(...)
#endif #endif
#define AES_SELECTOR_VTABLE(mode_c, mode_protocol, mode_display, bits, ...) \ #define AES_SELECTOR_VTABLE(mode_c, namemaker, mode_display, bits, ...) \
static const ssh_cipheralg * \ static const ssh_cipheralg * \
ssh_aes ## bits ## _ ## mode_c ## _impls[] = { \ ssh_aes ## bits ## _ ## mode_c ## _impls[] = { \
IF_NI(&ssh_aes ## bits ## _ ## mode_c ## _ni,) \ IF_NI(&ssh_aes ## bits ## _ ## mode_c ## _ni,) \
@ -49,7 +49,7 @@ static ssh_cipher *aes_select(const ssh_cipheralg *alg)
}; \ }; \
const ssh_cipheralg ssh_aes ## bits ## _ ## mode_c = { \ const ssh_cipheralg ssh_aes ## bits ## _ ## mode_c = { \
.new = aes_select, \ .new = aes_select, \
.ssh2_id = "aes" #bits "-" mode_protocol, \ .ssh2_id = namemaker(bits), \
.blksize = 16, \ .blksize = 16, \
.real_keybits = bits, \ .real_keybits = bits, \
.padded_keybytes = bits/8, \ .padded_keybytes = bits/8, \
@ -59,22 +59,27 @@ static ssh_cipher *aes_select(const ssh_cipheralg *alg)
__VA_ARGS__ \ __VA_ARGS__ \
} }
AES_SELECTOR_VTABLE(cbc, "cbc", "CBC", 128); #define cbc_namemaker(bits) "aes" #bits "-cbc"
AES_SELECTOR_VTABLE(cbc, "cbc", "CBC", 192); #define ctr_namemaker(bits) "aes" #bits "-ctr"
AES_SELECTOR_VTABLE(cbc, "cbc", "CBC", 256); #define gcm_namemaker(bits) "aes" #bits "-gcm@openssh.com"
AES_SELECTOR_VTABLE(sdctr, "ctr", "SDCTR", 128);
AES_SELECTOR_VTABLE(sdctr, "ctr", "SDCTR", 192); AES_SELECTOR_VTABLE(cbc, cbc_namemaker, "CBC", 128);
AES_SELECTOR_VTABLE(sdctr, "ctr", "SDCTR", 256); AES_SELECTOR_VTABLE(cbc, cbc_namemaker, "CBC", 192);
AES_SELECTOR_VTABLE(gcm, "gcm@openssh.com", "GCM", 128, AES_SELECTOR_VTABLE(cbc, cbc_namemaker, "CBC", 256);
AES_SELECTOR_VTABLE(sdctr, ctr_namemaker, "SDCTR", 128);
AES_SELECTOR_VTABLE(sdctr, ctr_namemaker, "SDCTR", 192);
AES_SELECTOR_VTABLE(sdctr, ctr_namemaker, "SDCTR", 256);
AES_SELECTOR_VTABLE(gcm, gcm_namemaker, "GCM", 128,
.required_mac = &ssh2_aesgcm_mac); .required_mac = &ssh2_aesgcm_mac);
AES_SELECTOR_VTABLE(gcm, "gcm@openssh.com", "GCM", 256, AES_SELECTOR_VTABLE(gcm, gcm_namemaker, "GCM", 256,
.required_mac = &ssh2_aesgcm_mac); .required_mac = &ssh2_aesgcm_mac);
/* 192-bit AES-GCM is included only so that testcrypt can run standard /* 192-bit AES-GCM is included only so that testcrypt can run standard
* test vectors against it. OpenSSH doesn't define a protocol id for * test vectors against it. OpenSSH doesn't define a protocol id for
* it. Hence the silly macro trick here to set its ssh2_id to 0, and * it. Hence the use of null_namemaker here to set its ssh2_id to NULL,
* more importantly, leaving it out of aesgcm_list[] below. */ * and more importantly, leaving it out of aesgcm_list[] below. */
AES_SELECTOR_VTABLE(gcm, ?NULL:NULL, "GCM", 192, #define null_namemaker(bits) NULL
AES_SELECTOR_VTABLE(gcm, null_namemaker, "GCM", 192,
.required_mac = &ssh2_aesgcm_mac); .required_mac = &ssh2_aesgcm_mac);
static const ssh_cipheralg ssh_rijndael_lysator = { static const ssh_cipheralg ssh_rijndael_lysator = {