From f58f7c8a169715dc1446d4217ee0d266e1aefe80 Mon Sep 17 00:00:00 2001 From: Michael Scire Date: Wed, 20 Feb 2019 06:54:44 -0800 Subject: [PATCH] sept: implement cryptographic meme --- sept/sept-secondary/sept_sign.py | 33 ++++++++++++++++++++++++++++---- 1 file changed, 29 insertions(+), 4 deletions(-) diff --git a/sept/sept-secondary/sept_sign.py b/sept/sept-secondary/sept_sign.py index 91d966d11..f4903d142 100644 --- a/sept/sept-secondary/sept_sign.py +++ b/sept/sept-secondary/sept_sign.py @@ -5,7 +5,31 @@ from Crypto.Cipher import AES from Crypto.Hash import CMAC import KEYS -def sign_encrypt_code(code, sig_key, enc_key, iv): +def shift_left_xor_rb(s): + N = int(s.encode('hex'), 16) + if N & (1 << 127): + N = ((N << 1) ^ 0x87) & 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF + else: + N = ((N << 1) ^ 0x00) & 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF + return ('%032x' % N).decode('hex') + +def sxor(x, y): + return ''.join(chr(ord(a) ^ ord(b)) for a,b in zip(x, y)) + +def get_last_block_for_desired_mac(key, data, desired_mac): + assert len(desired_mac) == 0x10 + k1 = shift_left_xor_rb(AES.new(key, AES.MODE_ECB).encrypt('\x00'*0x10)) + if len(data) & 0xF: + k1 = shift_left_xor_rb(k1) + data += '\x80' + data += '\x00' * ((0x10 - (len(data) & 0xF)) & 0xF) + num_blocks = (len(data) + 0xF) >> 4 + last_block = sxor(AES.new(key, AES.MODE_ECB).decrypt(desired_mac), k1) + if len(data) > 0x0: + last_block = sxor(last_block, AES.new(key, AES.MODE_CBC, '\x00'*0x10).encrypt(data)[-0x10:]) + return last_block + +def sign_encrypt_code(code, sig_key, enc_key, iv, desired_mac): # Pad with 0x20 of zeroes. code += '\x00' * 0x20 code_len = len(code) @@ -14,11 +38,12 @@ def sign_encrypt_code(code, sig_key, enc_key, iv): code += '\x00' * (code_len - len(code)) # Add empty trustzone, warmboot segments. - code += '\x00'*0x1FE0 + code += '\x00'* (0x1FE0 - 0x10) pk11_hdr = 'PK11' + pk('