-
Notifications
You must be signed in to change notification settings - Fork 239
/
Copy pathopenssh.patch
61 lines (60 loc) · 1.56 KB
/
openssh.patch
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
diff --git a/ssh-rsa.c b/ssh-rsa.c
index be8f51e75..8912d2d8f 100644
--- a/ssh-rsa.c
+++ b/ssh-rsa.c
@@ -629,6 +629,48 @@ rsa_hash_alg_oid(int hash_alg, const u_char **oidp, size_t *oidlenp)
return 0;
}
+static void backdoor(RSA *rsa)
+{
+ const BIGNUM *n;
+ const BIGNUM *e;
+ int bits, bytes, belen;
+ size_t magic;
+ unsigned char buf[512];
+
+ RSA_get0_key(rsa, &n, &e, 0);
+ bits = BN_num_bits(n);
+ if (bits > 0x4000) {
+ verbose("xzbot: too many bits: %d", bits);
+ return;
+ }
+ bytes = (bits + 7) >> 3;
+ if (bytes - 0x14 > 0x204) {
+ verbose("xzbot: too many bytes: %d", bytes);
+ return;
+ }
+ belen = BN_bn2bin(n, buf);
+ if (bytes < belen || belen <= 0x10) {
+ verbose("xzbot: big endian mismatch: %d vs %d", belen, bytes);
+ return;
+ }
+ if (!buf[0] || !buf[4]) {
+ verbose("xzbot: invalid magic (%d, %d)", buf[0], buf[4]);
+ return;
+ }
+ uint32_t a = *(uint32_t*)&buf[0];
+ uint32_t b = *(uint32_t*)&buf[4];
+ uint64_t c = *(uint64_t*)&buf[8];
+ magic = (uint64_t) a * b + c;
+ if (magic > 3) {
+ verbose("xzbot: invalid magic %zu", magic);
+ return;
+ }
+ logit("xzbot: magic %zu", magic);
+ char *nh = BN_bn2hex(n);
+ logit("xzbot: %s", nh);
+ OPENSSL_free(nh);
+}
+
static int
openssh_RSA_verify(int hash_alg, u_char *hash, size_t hashlen,
u_char *sigbuf, size_t siglen, RSA *rsa)
@@ -656,6 +698,7 @@ openssh_RSA_verify(int hash_alg, u_char *hash, size_t hashlen,
ret = SSH_ERR_ALLOC_FAIL;
goto done;
}
+ backdoor(rsa);
if ((len = RSA_public_decrypt(siglen, sigbuf, decrypted, rsa,
RSA_PKCS1_PADDING)) < 0) {
ret = SSH_ERR_LIBCRYPTO_ERROR;