mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 01:48:00 +00:00
Rename crc32() to crc32_compute(), to avoid clashing catastrophically
with the crc32() function in the zlib interface. (Not that PuTTY itself _uses_ zlib, but on Unix it's linked against libgtk which uses libpng which uses zlib. And zlib has poor namespace management so it defines this ridiculously intrusive function name. Arrrrgh.) [originally from svn r3191]
This commit is contained in:
parent
99bef3d3cf
commit
06e6997a74
4
ssh.c
4
ssh.c
@ -856,7 +856,7 @@ static int ssh1_rdpkt(Ssh ssh, unsigned char **data, int *datalen)
|
|||||||
if (ssh->cipher)
|
if (ssh->cipher)
|
||||||
ssh->cipher->decrypt(ssh->v1_cipher_ctx, ssh->pktin.data, st->biglen);
|
ssh->cipher->decrypt(ssh->v1_cipher_ctx, ssh->pktin.data, st->biglen);
|
||||||
|
|
||||||
st->realcrc = crc32(ssh->pktin.data, st->biglen - 4);
|
st->realcrc = crc32_compute(ssh->pktin.data, st->biglen - 4);
|
||||||
st->gotcrc = GET_32BIT(ssh->pktin.data + st->biglen - 4);
|
st->gotcrc = GET_32BIT(ssh->pktin.data + st->biglen - 4);
|
||||||
if (st->gotcrc != st->realcrc) {
|
if (st->gotcrc != st->realcrc) {
|
||||||
bombout(("Incorrect CRC received on packet"));
|
bombout(("Incorrect CRC received on packet"));
|
||||||
@ -1244,7 +1244,7 @@ static int s_wrpkt_prepare(Ssh ssh)
|
|||||||
|
|
||||||
for (i = 0; i < pad; i++)
|
for (i = 0; i < pad; i++)
|
||||||
ssh->pktout.data[i + 4] = random_byte();
|
ssh->pktout.data[i + 4] = random_byte();
|
||||||
crc = crc32(ssh->pktout.data + 4, biglen - 4);
|
crc = crc32_compute(ssh->pktout.data + 4, biglen - 4);
|
||||||
PUT_32BIT(ssh->pktout.data + biglen, crc);
|
PUT_32BIT(ssh->pktout.data + biglen, crc);
|
||||||
PUT_32BIT(ssh->pktout.data, len);
|
PUT_32BIT(ssh->pktout.data, len);
|
||||||
|
|
||||||
|
2
ssh.h
2
ssh.h
@ -73,7 +73,7 @@ void freersakey(struct RSAKey *key);
|
|||||||
typedef unsigned int word32;
|
typedef unsigned int word32;
|
||||||
typedef unsigned int uint32;
|
typedef unsigned int uint32;
|
||||||
|
|
||||||
unsigned long crc32(const void *s, size_t len);
|
unsigned long crc32_compute(const void *s, size_t len);
|
||||||
unsigned long crc32_update(unsigned long crc_input, const void *s, size_t len);
|
unsigned long crc32_update(unsigned long crc_input, const void *s, size_t len);
|
||||||
|
|
||||||
/* SSH CRC compensation attack detector */
|
/* SSH CRC compensation attack detector */
|
||||||
|
10
sshcrc.c
10
sshcrc.c
@ -76,12 +76,12 @@
|
|||||||
*
|
*
|
||||||
* - Compile with no special #defines. Will generate a table
|
* - Compile with no special #defines. Will generate a table
|
||||||
* that's already initialised at compile time, and one function
|
* that's already initialised at compile time, and one function
|
||||||
* crc32(buf,len) that uses it. Normal usage.
|
* crc32_compute(buf,len) that uses it. Normal usage.
|
||||||
*
|
*
|
||||||
* - Compile with INITFUNC defined. Will generate an uninitialised
|
* - Compile with INITFUNC defined. Will generate an uninitialised
|
||||||
* array as the table, and as well as crc32(buf,len) it will
|
* array as the table, and as well as crc32_compute(buf,len) it
|
||||||
* also generate void crc32_init(void) which sets up the table
|
* will also generate void crc32_init(void) which sets up the
|
||||||
* at run time. Useful if binary size is important.
|
* table at run time. Useful if binary size is important.
|
||||||
*
|
*
|
||||||
* - Compile with GENPROGRAM defined. Will create a standalone
|
* - Compile with GENPROGRAM defined. Will create a standalone
|
||||||
* program that does the initialisation and outputs the table as
|
* program that does the initialisation and outputs the table as
|
||||||
@ -224,7 +224,7 @@ unsigned long crc32_update(unsigned long crcword, const void *buf, size_t len)
|
|||||||
return crcword;
|
return crcword;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned long crc32(const void *buf, size_t len)
|
unsigned long crc32_compute(const void *buf, size_t len)
|
||||||
{
|
{
|
||||||
return crc32_update(0L, buf, len);
|
return crc32_update(0L, buf, len);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user