2017-01-01 12:58:02 +00:00
|
|
|
// Copyright 2017 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
#include <functional>
|
|
|
|
#include "core/hw/aes/arithmetic128.h"
|
|
|
|
|
2019-02-19 01:34:18 +00:00
|
|
|
namespace HW::AES {
|
2017-01-01 12:58:02 +00:00
|
|
|
|
|
|
|
AESKey Lrot128(const AESKey& in, u32 rot) {
|
|
|
|
AESKey out;
|
|
|
|
rot %= 128;
|
|
|
|
const u32 byte_shift = rot / 8;
|
|
|
|
const u32 bit_shift = rot % 8;
|
|
|
|
|
|
|
|
for (u32 i = 0; i < 16; i++) {
|
|
|
|
const u32 wrap_index_a = (i + byte_shift) % 16;
|
|
|
|
const u32 wrap_index_b = (i + byte_shift + 1) % 16;
|
|
|
|
out[i] = ((in[wrap_index_a] << bit_shift) | (in[wrap_index_b] >> (8 - bit_shift))) & 0xFF;
|
|
|
|
}
|
|
|
|
return out;
|
|
|
|
}
|
|
|
|
|
|
|
|
AESKey Add128(const AESKey& a, const AESKey& b) {
|
|
|
|
AESKey out;
|
|
|
|
u32 carry = 0;
|
|
|
|
u32 sum = 0;
|
|
|
|
|
|
|
|
for (int i = 15; i >= 0; i--) {
|
|
|
|
sum = a[i] + b[i] + carry;
|
|
|
|
carry = sum >> 8;
|
|
|
|
out[i] = static_cast<u8>(sum & 0xff);
|
|
|
|
}
|
|
|
|
|
|
|
|
return out;
|
|
|
|
}
|
|
|
|
|
2019-04-15 14:56:55 +00:00
|
|
|
AESKey Add128(const AESKey& a, u64 b) {
|
|
|
|
AESKey out = a;
|
|
|
|
u32 carry = 0;
|
|
|
|
u32 sum = 0;
|
|
|
|
|
|
|
|
for (int i = 15; i >= 8; i--) {
|
|
|
|
sum = a[i] + static_cast<u8>((b >> ((15 - i) * 8)) & 0xff) + carry;
|
|
|
|
carry = sum >> 8;
|
|
|
|
out[i] = static_cast<u8>(sum & 0xff);
|
|
|
|
}
|
|
|
|
|
|
|
|
return out;
|
|
|
|
}
|
|
|
|
|
2017-01-01 12:58:02 +00:00
|
|
|
AESKey Xor128(const AESKey& a, const AESKey& b) {
|
|
|
|
AESKey out;
|
|
|
|
std::transform(a.cbegin(), a.cend(), b.cbegin(), out.begin(), std::bit_xor<>());
|
|
|
|
return out;
|
|
|
|
}
|
|
|
|
|
2019-02-19 01:34:18 +00:00
|
|
|
} // namespace HW::AES
|