mirror of
https://github.com/Thealexbarney/LibHac.git
synced 2024-11-14 10:49:41 +01:00
Make GenerateKek signature match similar functions'
This commit is contained in:
parent
3db06782a2
commit
c04ae4c7c0
2 changed files with 10 additions and 9 deletions
|
@ -76,16 +76,17 @@ namespace LibHac
|
||||||
public static void EncryptCbc(byte[] key, byte[] iv, byte[] src, byte[] dest, int length) =>
|
public static void EncryptCbc(byte[] key, byte[] iv, byte[] src, byte[] dest, int length) =>
|
||||||
EncryptCbc(key, iv, src, 0, dest, 0, length);
|
EncryptCbc(key, iv, src, 0, dest, 0, length);
|
||||||
|
|
||||||
public static void GenerateKek(byte[] dst, byte[] src, byte[] masterKey, byte[] kekSeed, byte[] keySeed)
|
public static void GenerateKek(byte[] key, byte[] src, byte[] dest, byte[] kekSeed, byte[] keySeed)
|
||||||
{
|
{
|
||||||
var kek = new byte[Aes128Size];
|
var kek = new byte[Aes128Size];
|
||||||
var srcKek = new byte[Aes128Size];
|
var srcKek = new byte[Aes128Size];
|
||||||
DecryptEcb(masterKey, kekSeed, kek, Aes128Size);
|
|
||||||
|
DecryptEcb(key, kekSeed, kek, Aes128Size);
|
||||||
DecryptEcb(kek, src, srcKek, Aes128Size);
|
DecryptEcb(kek, src, srcKek, Aes128Size);
|
||||||
|
|
||||||
if (keySeed != null)
|
if (keySeed != null)
|
||||||
{
|
{
|
||||||
DecryptEcb(srcKek, keySeed, dst, Aes128Size);
|
DecryptEcb(srcKek, keySeed, dest, Aes128Size);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -172,7 +172,7 @@ namespace LibHac
|
||||||
Crypto.DecryptEcb(device_key, retail_specific_aes_key_source, kek, 0x10);
|
Crypto.DecryptEcb(device_key, retail_specific_aes_key_source, kek, 0x10);
|
||||||
Crypto.DecryptEcb(kek, bis_key_source[0], bis_keys[0], 0x20);
|
Crypto.DecryptEcb(kek, bis_key_source[0], bis_keys[0], 0x20);
|
||||||
|
|
||||||
Crypto.GenerateKek(kek, bis_kek_source, device_key, aes_kek_generation_source, aes_key_generation_source);
|
Crypto.GenerateKek(device_key, bis_kek_source, kek, aes_kek_generation_source, aes_key_generation_source);
|
||||||
|
|
||||||
Crypto.DecryptEcb(kek, bis_key_source[1], bis_keys[1], 0x20);
|
Crypto.DecryptEcb(kek, bis_key_source[1], bis_keys[1], 0x20);
|
||||||
Crypto.DecryptEcb(kek, bis_key_source[2], bis_keys[2], 0x20);
|
Crypto.DecryptEcb(kek, bis_key_source[2], bis_keys[2], 0x20);
|
||||||
|
@ -198,19 +198,19 @@ namespace LibHac
|
||||||
|
|
||||||
if (haveKakSource0)
|
if (haveKakSource0)
|
||||||
{
|
{
|
||||||
Crypto.GenerateKek(key_area_keys[i][0], key_area_key_application_source, master_keys[i],
|
Crypto.GenerateKek(master_keys[i], key_area_key_application_source, key_area_keys[i][0],
|
||||||
aes_kek_generation_source, aes_key_generation_source);
|
aes_kek_generation_source, aes_key_generation_source);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (haveKakSource1)
|
if (haveKakSource1)
|
||||||
{
|
{
|
||||||
Crypto.GenerateKek(key_area_keys[i][1], key_area_key_ocean_source, master_keys[i],
|
Crypto.GenerateKek(master_keys[i], key_area_key_ocean_source, key_area_keys[i][1],
|
||||||
aes_kek_generation_source, aes_key_generation_source);
|
aes_kek_generation_source, aes_key_generation_source);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (haveKakSource2)
|
if (haveKakSource2)
|
||||||
{
|
{
|
||||||
Crypto.GenerateKek(key_area_keys[i][2], key_area_key_system_source, master_keys[i],
|
Crypto.GenerateKek(master_keys[i], key_area_key_system_source, key_area_keys[i][2],
|
||||||
aes_kek_generation_source, aes_key_generation_source);
|
aes_kek_generation_source, aes_key_generation_source);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -232,7 +232,7 @@ namespace LibHac
|
||||||
|
|
||||||
var headerKek = new byte[0x10];
|
var headerKek = new byte[0x10];
|
||||||
|
|
||||||
Crypto.GenerateKek(headerKek, header_kek_source, master_keys[0], aes_kek_generation_source,
|
Crypto.GenerateKek(master_keys[0], header_kek_source, headerKek, aes_kek_generation_source,
|
||||||
aes_key_generation_source);
|
aes_key_generation_source);
|
||||||
Crypto.DecryptEcb(headerKek, header_key_source, header_key, 0x20);
|
Crypto.DecryptEcb(headerKek, header_key_source, header_key, 0x20);
|
||||||
}
|
}
|
||||||
|
@ -240,7 +240,7 @@ namespace LibHac
|
||||||
private void DeriveSdCardKeys()
|
private void DeriveSdCardKeys()
|
||||||
{
|
{
|
||||||
var sdKek = new byte[0x10];
|
var sdKek = new byte[0x10];
|
||||||
Crypto.GenerateKek(sdKek, sd_card_kek_source, master_keys[0], aes_kek_generation_source, aes_key_generation_source);
|
Crypto.GenerateKek(master_keys[0], sd_card_kek_source, sdKek, aes_kek_generation_source, aes_key_generation_source);
|
||||||
|
|
||||||
for (int k = 0; k < sd_card_key_sources.Length; k++)
|
for (int k = 0; k < sd_card_key_sources.Length; k++)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue