mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 09:58:01 +00:00
Remove vestiges of attempt at MS Crypto API support.
There was a time, back when the USA was more vigorously against cryptography, when we toyed with the idea of having a version of PuTTY that outsourced its cryptographic primitives to the Microsoft optional encryption API, which would effectively create a tool that acted like PuTTY proper on a system with that API installed, but automatically degraded to being PuTTYtel on a system without, and meanwhile (so went the theory) it could be moved freely across national borders with crypto restrictions, because it didn't _contain_ any of the actual crypto. I don't recall that we ever got it working at all. And certainly the vestiges of it here and there in the current code are completely unworkable - they refer to an 'mscrypto.c' that doesn't even exist, and the ifdefs in the definitions of structures like RSAKey and MD5Context are not matched by any corresponding ifdefs in the code. So I ought to have got round to removing it long ago, in order to avoid misleading anyone.
This commit is contained in:
parent
2bfbf15c65
commit
43ec3397b6
8
putty.h
8
putty.h
@ -1259,14 +1259,6 @@ int mk_wcswidth(const unsigned int *pwcs, size_t n);
|
|||||||
int mk_wcwidth_cjk(unsigned int ucs);
|
int mk_wcwidth_cjk(unsigned int ucs);
|
||||||
int mk_wcswidth_cjk(const unsigned int *pwcs, size_t n);
|
int mk_wcswidth_cjk(const unsigned int *pwcs, size_t n);
|
||||||
|
|
||||||
/*
|
|
||||||
* Exports from mscrypto.c
|
|
||||||
*/
|
|
||||||
#ifdef MSCRYPTOAPI
|
|
||||||
int crypto_startup();
|
|
||||||
void crypto_wrapup();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Exports from pageantc.c.
|
* Exports from pageantc.c.
|
||||||
*
|
*
|
||||||
|
29
ssh.c
29
ssh.c
@ -1555,7 +1555,7 @@ static void ssh1_rdpkt(Ssh ssh)
|
|||||||
}
|
}
|
||||||
|
|
||||||
st->pktin->maxlen = st->biglen;
|
st->pktin->maxlen = st->biglen;
|
||||||
st->pktin->data = snewn(st->biglen + APIEXTRA, unsigned char);
|
st->pktin->data = snewn(st->biglen, unsigned char);
|
||||||
|
|
||||||
crMaybeWaitUntilV(bufchain_try_fetch_consume(
|
crMaybeWaitUntilV(bufchain_try_fetch_consume(
|
||||||
&ssh->incoming_data,
|
&ssh->incoming_data,
|
||||||
@ -1594,8 +1594,7 @@ static void ssh1_rdpkt(Ssh ssh)
|
|||||||
|
|
||||||
if (st->pktin->maxlen < st->pad + decomplen) {
|
if (st->pktin->maxlen < st->pad + decomplen) {
|
||||||
st->pktin->maxlen = st->pad + decomplen;
|
st->pktin->maxlen = st->pad + decomplen;
|
||||||
st->pktin->data = sresize(st->pktin->data,
|
st->pktin->data = sresize(st->pktin->data, st->pktin->maxlen,
|
||||||
st->pktin->maxlen + APIEXTRA,
|
|
||||||
unsigned char);
|
unsigned char);
|
||||||
st->pktin->body = st->pktin->data + st->pad + 1;
|
st->pktin->body = st->pktin->data + st->pad + 1;
|
||||||
}
|
}
|
||||||
@ -1812,7 +1811,7 @@ static void ssh2_rdpkt(Ssh ssh)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* May as well allocate the whole lot now. */
|
/* May as well allocate the whole lot now. */
|
||||||
st->pktin->data = snewn(OUR_V2_PACKETLIMIT + st->maclen + APIEXTRA,
|
st->pktin->data = snewn(OUR_V2_PACKETLIMIT + st->maclen,
|
||||||
unsigned char);
|
unsigned char);
|
||||||
|
|
||||||
/* Read an amount corresponding to the MAC. */
|
/* Read an amount corresponding to the MAC. */
|
||||||
@ -1853,11 +1852,10 @@ static void ssh2_rdpkt(Ssh ssh)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
st->pktin->maxlen = st->packetlen + st->maclen;
|
st->pktin->maxlen = st->packetlen + st->maclen;
|
||||||
st->pktin->data = sresize(st->pktin->data,
|
st->pktin->data = sresize(st->pktin->data, st->pktin->maxlen,
|
||||||
st->pktin->maxlen + APIEXTRA,
|
|
||||||
unsigned char);
|
unsigned char);
|
||||||
} else if (ssh->scmac && ssh->scmac_etm) {
|
} else if (ssh->scmac && ssh->scmac_etm) {
|
||||||
st->pktin->data = snewn(4 + APIEXTRA, unsigned char);
|
st->pktin->data = snewn(4, unsigned char);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* OpenSSH encrypt-then-MAC mode: the packet length is
|
* OpenSSH encrypt-then-MAC mode: the packet length is
|
||||||
@ -1897,8 +1895,7 @@ static void ssh2_rdpkt(Ssh ssh)
|
|||||||
* Allocate memory for the rest of the packet.
|
* Allocate memory for the rest of the packet.
|
||||||
*/
|
*/
|
||||||
st->pktin->maxlen = st->packetlen + st->maclen;
|
st->pktin->maxlen = st->packetlen + st->maclen;
|
||||||
st->pktin->data = sresize(st->pktin->data,
|
st->pktin->data = sresize(st->pktin->data, st->pktin->maxlen,
|
||||||
st->pktin->maxlen + APIEXTRA,
|
|
||||||
unsigned char);
|
unsigned char);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -1925,7 +1922,7 @@ static void ssh2_rdpkt(Ssh ssh)
|
|||||||
st->pktin->data + 4,
|
st->pktin->data + 4,
|
||||||
st->packetlen - 4);
|
st->packetlen - 4);
|
||||||
} else {
|
} else {
|
||||||
st->pktin->data = snewn(st->cipherblk + APIEXTRA, unsigned char);
|
st->pktin->data = snewn(st->cipherblk, unsigned char);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Acquire and decrypt the first block of the packet. This will
|
* Acquire and decrypt the first block of the packet. This will
|
||||||
@ -1964,8 +1961,7 @@ static void ssh2_rdpkt(Ssh ssh)
|
|||||||
* Allocate memory for the rest of the packet.
|
* Allocate memory for the rest of the packet.
|
||||||
*/
|
*/
|
||||||
st->pktin->maxlen = st->packetlen + st->maclen;
|
st->pktin->maxlen = st->packetlen + st->maclen;
|
||||||
st->pktin->data = sresize(st->pktin->data,
|
st->pktin->data = sresize(st->pktin->data, st->pktin->maxlen,
|
||||||
st->pktin->maxlen + APIEXTRA,
|
|
||||||
unsigned char);
|
unsigned char);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2026,7 +2022,7 @@ static void ssh2_rdpkt(Ssh ssh)
|
|||||||
if (st->pktin->maxlen < newlen + 5) {
|
if (st->pktin->maxlen < newlen + 5) {
|
||||||
st->pktin->maxlen = newlen + 5;
|
st->pktin->maxlen = newlen + 5;
|
||||||
st->pktin->data = sresize(st->pktin->data,
|
st->pktin->data = sresize(st->pktin->data,
|
||||||
st->pktin->maxlen + APIEXTRA,
|
st->pktin->maxlen,
|
||||||
unsigned char);
|
unsigned char);
|
||||||
}
|
}
|
||||||
st->pktin->length = 5 + newlen;
|
st->pktin->length = 5 + newlen;
|
||||||
@ -2311,7 +2307,7 @@ static void ssh_pkt_ensure(struct Packet *pkt, int length)
|
|||||||
unsigned char *body = pkt->body;
|
unsigned char *body = pkt->body;
|
||||||
int offset = body ? body - pkt->data : 0;
|
int offset = body ? body - pkt->data : 0;
|
||||||
pkt->maxlen = length + 256;
|
pkt->maxlen = length + 256;
|
||||||
pkt->data = sresize(pkt->data, pkt->maxlen + APIEXTRA, unsigned char);
|
pkt->data = sresize(pkt->data, pkt->maxlen, unsigned char);
|
||||||
if (body) pkt->body = pkt->data + offset;
|
if (body) pkt->body = pkt->data + offset;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -12308,11 +12304,6 @@ static const char *ssh_init(void *frontend_handle, void **backend_handle,
|
|||||||
|
|
||||||
*backend_handle = ssh;
|
*backend_handle = ssh;
|
||||||
|
|
||||||
#ifdef MSCRYPTOAPI
|
|
||||||
if (crypto_startup() == 0)
|
|
||||||
return "Microsoft high encryption pack not installed!";
|
|
||||||
#endif
|
|
||||||
|
|
||||||
ssh->frontend = frontend_handle;
|
ssh->frontend = frontend_handle;
|
||||||
ssh->term_width = conf_get_int(ssh->conf, CONF_width);
|
ssh->term_width = conf_get_int(ssh->conf, CONF_width);
|
||||||
ssh->term_height = conf_get_int(ssh->conf, CONF_height);
|
ssh->term_height = conf_get_int(ssh->conf, CONF_height);
|
||||||
|
17
ssh.h
17
ssh.h
@ -70,12 +70,6 @@ void share_setup_x11_channel(void *csv, void *chanv,
|
|||||||
#define SSH_CIPHER_3DES 3
|
#define SSH_CIPHER_3DES 3
|
||||||
#define SSH_CIPHER_BLOWFISH 6
|
#define SSH_CIPHER_BLOWFISH 6
|
||||||
|
|
||||||
#ifdef MSCRYPTOAPI
|
|
||||||
#define APIEXTRA 8
|
|
||||||
#else
|
|
||||||
#define APIEXTRA 0
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef BIGNUM_INTERNAL
|
#ifndef BIGNUM_INTERNAL
|
||||||
typedef void *Bignum;
|
typedef void *Bignum;
|
||||||
#endif
|
#endif
|
||||||
@ -83,17 +77,12 @@ typedef void *Bignum;
|
|||||||
struct RSAKey {
|
struct RSAKey {
|
||||||
int bits;
|
int bits;
|
||||||
int bytes;
|
int bytes;
|
||||||
#ifdef MSCRYPTOAPI
|
|
||||||
unsigned long exponent;
|
|
||||||
unsigned char *modulus;
|
|
||||||
#else
|
|
||||||
Bignum modulus;
|
Bignum modulus;
|
||||||
Bignum exponent;
|
Bignum exponent;
|
||||||
Bignum private_exponent;
|
Bignum private_exponent;
|
||||||
Bignum p;
|
Bignum p;
|
||||||
Bignum q;
|
Bignum q;
|
||||||
Bignum iqmp;
|
Bignum iqmp;
|
||||||
#endif
|
|
||||||
char *comment;
|
char *comment;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -242,14 +231,10 @@ typedef struct {
|
|||||||
} MD5_Core_State;
|
} MD5_Core_State;
|
||||||
|
|
||||||
struct MD5Context {
|
struct MD5Context {
|
||||||
#ifdef MSCRYPTOAPI
|
|
||||||
unsigned long hHash;
|
|
||||||
#else
|
|
||||||
MD5_Core_State core;
|
MD5_Core_State core;
|
||||||
unsigned char block[64];
|
unsigned char block[64];
|
||||||
int blkused;
|
int blkused;
|
||||||
uint32 lenhi, lenlo;
|
uint32 lenhi, lenlo;
|
||||||
#endif
|
|
||||||
BinarySink_IMPLEMENTATION;
|
BinarySink_IMPLEMENTATION;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -507,9 +492,7 @@ extern const char sshver[];
|
|||||||
*/
|
*/
|
||||||
extern int ssh_fallback_cmd(void *handle);
|
extern int ssh_fallback_cmd(void *handle);
|
||||||
|
|
||||||
#ifndef MSCRYPTOAPI
|
|
||||||
void SHATransform(word32 * digest, word32 * data);
|
void SHATransform(word32 * digest, word32 * data);
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check of compiler version
|
* Check of compiler version
|
||||||
|
@ -26,9 +26,6 @@ void cleanup_exit(int code)
|
|||||||
sk_cleanup();
|
sk_cleanup();
|
||||||
|
|
||||||
random_save_seed();
|
random_save_seed();
|
||||||
#ifdef MSCRYPTOAPI
|
|
||||||
crypto_wrapup();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
exit(code);
|
exit(code);
|
||||||
}
|
}
|
||||||
|
@ -894,9 +894,6 @@ void cleanup_exit(int code)
|
|||||||
|
|
||||||
if (conf_get_int(conf, CONF_protocol) == PROT_SSH) {
|
if (conf_get_int(conf, CONF_protocol) == PROT_SSH) {
|
||||||
random_save_seed();
|
random_save_seed();
|
||||||
#ifdef MSCRYPTOAPI
|
|
||||||
crypto_wrapup();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
shutdown_help();
|
shutdown_help();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user