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

Assorted benign warning fixes.

These were just too footling for even me to bother splitting up into
multiple commits:

 - a couple of int -> size_t changes left out of the big-bang commit
   0cda34c6f

 - a few 'const' added to pointer-type casts that are only going to be
   read from (leaving out the const provokes a warning if the pointer
   was const _before_ the cast)

 - a couple of 'return' statements trying to pass the void return of
   one function through to another.

 - another missing (void) in a declaration in putty.h (but this one
   didn't cause any knock-on confusion).

 - a few tweaks to macros, to arrange that they eat a semicolon after
   the macro call (extra do ... while (0) wrappers, mostly, and one
   case where I had to do it another way because the macro included a
   variable declaration intended to remain in scope)

 - reworked key_type_to_str to stop putting an unreachable 'break'
   statement after every 'return'

 - removed yet another type-check of a function loaded from a Windows
   system DLL

 - and finally, a totally spurious semicolon right after an open brace
   in mainchan.c.
This commit is contained in:
Simon Tatham 2020-01-29 06:35:53 +00:00
parent 8d747d8029
commit 76430f8237
12 changed files with 63 additions and 50 deletions

View File

@ -858,9 +858,8 @@ int cmdline_process_param(const char *p, char *value,
void cmdline_run_saved(Conf *conf) void cmdline_run_saved(Conf *conf)
{ {
int pri, i; for (size_t pri = 0; pri < NPRIORITIES; pri++) {
for (pri = 0; pri < NPRIORITIES; pri++) { for (size_t i = 0; i < saves[pri].nsaved; i++) {
for (i = 0; i < saves[pri].nsaved; i++) {
cmdline_process_param(saves[pri].params[i].p, cmdline_process_param(saves[pri].params[i].p,
saves[pri].params[i].value, 0, conf); saves[pri].params[i].value, 0, conf);
sfree(saves[pri].params[i].p); sfree(saves[pri].params[i].p);

View File

@ -364,7 +364,7 @@ void log_packet(LogContext *ctx, int direction, int type,
c = 'X'; c = 'X';
sprintf(smalldata, "XX"); sprintf(smalldata, "XX");
} else { /* PKTLOG_EMIT */ } else { /* PKTLOG_EMIT */
c = ((unsigned char *)data)[p]; c = ((const unsigned char *)data)[p];
sprintf(smalldata, "%02x", c); sprintf(smalldata, "%02x", c);
} }
dumpdata[10+2+3*(p%16)] = smalldata[0]; dumpdata[10+2+3*(p%16)] = smalldata[0];

View File

@ -142,7 +142,7 @@ static void mainchan_open_confirmation(Channel *chan)
struct X11FakeAuth *x11auth; struct X11FakeAuth *x11auth;
bool retry_cmd_now = false; bool retry_cmd_now = false;
if (conf_get_bool(mc->conf, CONF_x11_forward)) {; if (conf_get_bool(mc->conf, CONF_x11_forward)) {
char *x11_setup_err; char *x11_setup_err;
if ((x11disp = x11_setup_display( if ((x11disp = x11_setup_display(
conf_get_str(mc->conf, CONF_x11_display), conf_get_str(mc->conf, CONF_x11_display),

View File

@ -187,7 +187,7 @@ mp_int *mp_from_decimal_pl(ptrlen decimal)
mp_int *x = mp_make_sized(words); mp_int *x = mp_make_sized(words);
for (size_t i = 0; i < decimal.len; i++) { for (size_t i = 0; i < decimal.len; i++) {
mp_add_integer_into(x, x, ((char *)decimal.ptr)[i] - '0'); mp_add_integer_into(x, x, ((const char *)decimal.ptr)[i] - '0');
if (i+1 == decimal.len) if (i+1 == decimal.len)
break; break;
@ -216,7 +216,7 @@ mp_int *mp_from_hex_pl(ptrlen hex)
words = size_t_max(words, 1); words = size_t_max(words, 1);
mp_int *x = mp_make_sized(words); mp_int *x = mp_make_sized(words);
for (size_t nibble = 0; nibble < hex.len; nibble++) { for (size_t nibble = 0; nibble < hex.len; nibble++) {
BignumInt digit = ((char *)hex.ptr)[hex.len-1 - nibble]; BignumInt digit = ((const char *)hex.ptr)[hex.len-1 - nibble];
BignumInt lmask = ~-((BignumInt)((digit-'a')|('f'-digit)) BignumInt lmask = ~-((BignumInt)((digit-'a')|('f'-digit))
>> (BIGNUM_INT_BITS-1)); >> (BIGNUM_INT_BITS-1));

View File

@ -283,8 +283,8 @@ static void list_keys(BinarySink *bs, int ssh_version)
} }
} }
void pageant_make_keylist1(BinarySink *bs) { return list_keys(bs, 1); } void pageant_make_keylist1(BinarySink *bs) { list_keys(bs, 1); }
void pageant_make_keylist2(BinarySink *bs) { return list_keys(bs, 2); } void pageant_make_keylist2(BinarySink *bs) { list_keys(bs, 2); }
void pageant_register_client(PageantClient *pc) void pageant_register_client(PageantClient *pc)
{ {

View File

@ -1790,7 +1790,7 @@ void random_unref(void);
void random_clear(void); void random_clear(void);
/* random_setup_special is used by PuTTYgen. It makes an extra-big /* random_setup_special is used by PuTTYgen. It makes an extra-big
* random number generator. */ * random number generator. */
void random_setup_special(); void random_setup_special(void);
/* Manually drop a random seed into the random number generator, e.g. /* Manually drop a random seed into the random number generator, e.g.
* just before generating a key. */ * just before generating a key. */
void random_reseed(ptrlen seed); void random_reseed(ptrlen seed);

3
ssh.c
View File

@ -457,7 +457,8 @@ static void ssh_initiate_connection_close(Ssh *ssh)
va_list ap; \ va_list ap; \
va_start(ap, fmt); \ va_start(ap, fmt); \
msg = dupvprintf(fmt, ap); \ msg = dupvprintf(fmt, ap); \
va_end(ap); va_end(ap); \
((void)0) /* eat trailing semicolon */
void ssh_remote_error(Ssh *ssh, const char *fmt, ...) void ssh_remote_error(Ssh *ssh, const char *fmt, ...)
{ {

4
ssh.h
View File

@ -720,8 +720,8 @@ struct ssh_hashalg {
void (*copyfrom)(ssh_hash *dest, ssh_hash *src); void (*copyfrom)(ssh_hash *dest, ssh_hash *src);
void (*digest)(ssh_hash *, unsigned char *); void (*digest)(ssh_hash *, unsigned char *);
void (*free)(ssh_hash *); void (*free)(ssh_hash *);
int hlen; /* output length in bytes */ size_t hlen; /* output length in bytes */
int blocklen; /* length of the hash's input block, or 0 for N/A */ size_t blocklen; /* length of the hash's input block, or 0 for N/A */
const char *text_basename; /* the semantic name of the hash */ const char *text_basename; /* the semantic name of the hash */
const char *annotation; /* extra info, e.g. which of multiple impls */ const char *annotation; /* extra info, e.g. which of multiple impls */
const char *text_name; /* both combined, e.g. "SHA-n (unaccelerated)" */ const char *text_name; /* both combined, e.g. "SHA-n (unaccelerated)" */

14
sshcr.h
View File

@ -25,19 +25,19 @@
* Database for Edit and Continue'. * Database for Edit and Continue'.
*/ */
#define crBegin(v) { int *crLine = &v; switch(v) { case 0:; #define crBegin(v) do { int *crLine = &v; switch(v) { case 0:
#define crBeginState crBegin(s->crLine) #define crBeginState crBegin(s->crLine)
#define crStateP(t, v) \ #define crStateP(t, v) \
struct t *s; \ struct t *s; \
if (!(v)) { s = (v) = snew(struct t); s->crLine = 0; } \ if (!(v)) { s = (v) = snew(struct t); s->crLine = 0; } \
s = (v); s = (v);
#define crState(t) crStateP(t, ssh->t) #define crState(t) crStateP(t, ssh->t)
#define crFinish(z) } *crLine = 0; return (z); } #define crFinish(z) } *crLine = 0; return (z); } while (0)
#define crFinishV } *crLine = 0; return; } #define crFinishV } *crLine = 0; return; } while (0)
#define crFinishFreed(z) } return (z); } #define crFinishFreed(z) } return (z); } while (0)
#define crFinishFreedV } return; } #define crFinishFreedV } return; } while (0)
#define crFinishFree(z) } sfree(s); return (z); } #define crFinishFree(z) } sfree(s); return (z); } while (0)
#define crFinishFreeV } sfree(s); return; } #define crFinishFreeV } sfree(s); return; } while (0)
#define crReturn(z) \ #define crReturn(z) \
do {\ do {\
*crLine =__LINE__; return (z); case __LINE__:;\ *crLine =__LINE__; return (z); case __LINE__:;\

View File

@ -1664,23 +1664,36 @@ int key_type(const Filename *filename)
const char *key_type_to_str(int type) const char *key_type_to_str(int type)
{ {
switch (type) { switch (type) {
case SSH_KEYTYPE_UNOPENABLE: return "unable to open file"; break; case SSH_KEYTYPE_UNOPENABLE:
case SSH_KEYTYPE_UNKNOWN: return "not a recognised key file format"; break; return "unable to open file";
case SSH_KEYTYPE_SSH1_PUBLIC: return "SSH-1 public key"; break; case SSH_KEYTYPE_UNKNOWN:
case SSH_KEYTYPE_SSH2_PUBLIC_RFC4716: return "SSH-2 public key (RFC 4716 format)"; break; return "not a recognised key file format";
case SSH_KEYTYPE_SSH2_PUBLIC_OPENSSH: return "SSH-2 public key (OpenSSH format)"; break; case SSH_KEYTYPE_SSH1_PUBLIC:
case SSH_KEYTYPE_SSH1: return "SSH-1 private key"; break; return "SSH-1 public key";
case SSH_KEYTYPE_SSH2: return "PuTTY SSH-2 private key"; break; case SSH_KEYTYPE_SSH2_PUBLIC_RFC4716:
case SSH_KEYTYPE_OPENSSH_PEM: return "OpenSSH SSH-2 private key (old PEM format)"; break; return "SSH-2 public key (RFC 4716 format)";
case SSH_KEYTYPE_OPENSSH_NEW: return "OpenSSH SSH-2 private key (new format)"; break; case SSH_KEYTYPE_SSH2_PUBLIC_OPENSSH:
case SSH_KEYTYPE_SSHCOM: return "ssh.com SSH-2 private key"; break; return "SSH-2 public key (OpenSSH format)";
case SSH_KEYTYPE_SSH1:
return "SSH-1 private key";
case SSH_KEYTYPE_SSH2:
return "PuTTY SSH-2 private key";
case SSH_KEYTYPE_OPENSSH_PEM:
return "OpenSSH SSH-2 private key (old PEM format)";
case SSH_KEYTYPE_OPENSSH_NEW:
return "OpenSSH SSH-2 private key (new format)";
case SSH_KEYTYPE_SSHCOM:
return "ssh.com SSH-2 private key";
/* /*
* This function is called with a key type derived from * This function is called with a key type derived from
* looking at an actual key file, so the output-only type * looking at an actual key file, so the output-only type
* OPENSSH_AUTO should never get here, and is much an INTERNAL * OPENSSH_AUTO should never get here, and is much an INTERNAL
* ERROR as a code we don't even understand. * ERROR as a code we don't even understand.
*/ */
case SSH_KEYTYPE_OPENSSH_AUTO: return "INTERNAL ERROR (OPENSSH_AUTO)"; break; case SSH_KEYTYPE_OPENSSH_AUTO:
default: return "INTERNAL ERROR"; break; unreachable("OPENSSH_AUTO should never reach key_type_to_str");
default:
unreachable("bad key type in key_type_to_str");
} }
} }

View File

@ -150,7 +150,7 @@ static void SHA512_Block(SHA512_State *s, uint64_t *block) {
for (t = 0; t < 80; t+=8) { for (t = 0; t < 80; t+=8) {
uint64_t tmp, p, q, r; uint64_t tmp, p, q, r;
#define ROUND(j,a,b,c,d,e,f,g,h) \ #define ROUND(j,a,b,c,d,e,f,g,h) do { \
bigsigma1(p, tmp, e); \ bigsigma1(p, tmp, e); \
Ch(q, tmp, e, f, g); \ Ch(q, tmp, e, f, g); \
add(r, p, q); \ add(r, p, q); \
@ -162,7 +162,8 @@ static void SHA512_Block(SHA512_State *s, uint64_t *block) {
add(q, tmp, p); \ add(q, tmp, p); \
add(p, r, d); \ add(p, r, d); \
d = p; \ d = p; \
add(h, q, r); add(h, q, r); \
} while (0)
ROUND(t+0, a,b,c,d,e,f,g,h); ROUND(t+0, a,b,c,d,e,f,g,h);
ROUND(t+1, h,a,b,c,d,e,f,g); ROUND(t+1, h,a,b,c,d,e,f,g);

View File

@ -299,13 +299,12 @@ void sk_init(void)
GET_WINDOWS_FUNCTION(winsock_module, getservbyname); GET_WINDOWS_FUNCTION(winsock_module, getservbyname);
GET_WINDOWS_FUNCTION(winsock_module, inet_addr); GET_WINDOWS_FUNCTION(winsock_module, inet_addr);
GET_WINDOWS_FUNCTION(winsock_module, inet_ntoa); GET_WINDOWS_FUNCTION(winsock_module, inet_ntoa);
#if (defined _MSC_VER && _MSC_VER < 1900) || defined __MINGW32__
/* Older Visual Studio, and MinGW as of Ubuntu 16.04, don't know /* Older Visual Studio, and MinGW as of Ubuntu 16.04, don't know
* about this function at all, so can't type-check it */ * about this function at all, so can't type-check it. Also there
* seems to be some disagreement in the VS headers about whether
* the second argument is void * or const void *, so I omit the
* type check. */
GET_WINDOWS_FUNCTION_NO_TYPECHECK(winsock_module, inet_ntop); GET_WINDOWS_FUNCTION_NO_TYPECHECK(winsock_module, inet_ntop);
#else
GET_WINDOWS_FUNCTION(winsock_module, inet_ntop);
#endif
GET_WINDOWS_FUNCTION(winsock_module, connect); GET_WINDOWS_FUNCTION(winsock_module, connect);
GET_WINDOWS_FUNCTION(winsock_module, bind); GET_WINDOWS_FUNCTION(winsock_module, bind);
GET_WINDOWS_FUNCTION(winsock_module, setsockopt); GET_WINDOWS_FUNCTION(winsock_module, setsockopt);