2019-06-18 17:00:44 +00:00
|
|
|
/*
|
2024-06-15 15:01:19 +00:00
|
|
|
Copyright 2016-2024 melonDS team
|
2019-06-18 17:00:44 +00:00
|
|
|
|
|
|
|
This file is part of melonDS.
|
|
|
|
|
|
|
|
melonDS is free software: you can redistribute it and/or modify it under
|
|
|
|
the terms of the GNU General Public License as published by the Free
|
|
|
|
Software Foundation, either version 3 of the License, or (at your option)
|
|
|
|
any later version.
|
|
|
|
|
|
|
|
melonDS is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
|
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License along
|
|
|
|
with melonDS. If not, see http://www.gnu.org/licenses/.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef DSI_AES_H
|
|
|
|
#define DSI_AES_H
|
|
|
|
|
2019-06-19 12:24:49 +00:00
|
|
|
#include "types.h"
|
2022-07-27 16:20:31 +00:00
|
|
|
#include "Savestate.h"
|
2023-11-04 16:46:52 +00:00
|
|
|
#include "FIFO.h"
|
|
|
|
#include "tiny-AES-c/aes.hpp"
|
2019-06-19 12:24:49 +00:00
|
|
|
|
2023-11-25 17:32:09 +00:00
|
|
|
namespace melonDS
|
|
|
|
{
|
2023-08-28 18:01:15 +00:00
|
|
|
#pragma GCC diagnostic push
|
|
|
|
#pragma GCC diagnostic ignored "-Wattributes"
|
|
|
|
#if defined(__GNUC__) && (__GNUC__ >= 11) // gcc 11.*
|
|
|
|
// NOTE: Yes, the compiler does *not* recognize this code pattern, so it is indeed an optimization.
|
2023-10-11 15:20:05 +00:00
|
|
|
__attribute((always_inline)) static void Bswap128(void* Dst, const void* Src)
|
2023-08-28 18:01:15 +00:00
|
|
|
{
|
2023-09-02 16:56:58 +00:00
|
|
|
*(__int128*)Dst = __builtin_bswap128(*(__int128*)Src);
|
2023-08-28 18:01:15 +00:00
|
|
|
}
|
|
|
|
#else
|
2023-10-11 15:20:05 +00:00
|
|
|
__attribute((always_inline)) static void Bswap128(void* Dst, const void* Src)
|
2023-08-28 18:01:15 +00:00
|
|
|
{
|
2023-11-03 23:21:46 +00:00
|
|
|
for (int i = 0; i < 16; ++i)
|
|
|
|
{
|
|
|
|
((u8*)Dst)[i] = ((u8*)Src)[15 - i];
|
2023-08-28 18:01:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#pragma GCC diagnostic pop
|
|
|
|
|
2023-11-28 22:16:41 +00:00
|
|
|
class DSi;
|
2023-11-04 16:46:52 +00:00
|
|
|
class DSi_AES
|
2019-06-19 12:24:49 +00:00
|
|
|
{
|
2023-11-04 16:46:52 +00:00
|
|
|
public:
|
2023-11-28 22:16:41 +00:00
|
|
|
DSi_AES(melonDS::DSi& dsi);
|
2023-11-04 16:46:52 +00:00
|
|
|
~DSi_AES();
|
|
|
|
void Reset();
|
|
|
|
void DoSavestate(Savestate* file);
|
2019-06-19 12:24:49 +00:00
|
|
|
|
2023-12-12 10:07:22 +00:00
|
|
|
u32 ReadCnt() const;
|
2023-11-04 16:46:52 +00:00
|
|
|
void WriteCnt(u32 val);
|
|
|
|
void WriteBlkCnt(u32 val);
|
2019-06-19 12:24:49 +00:00
|
|
|
|
2023-11-04 16:46:52 +00:00
|
|
|
u32 ReadOutputFIFO();
|
|
|
|
void WriteInputFIFO(u32 val);
|
|
|
|
void CheckInputDMA();
|
|
|
|
void CheckOutputDMA();
|
|
|
|
void Update();
|
2019-06-19 12:24:49 +00:00
|
|
|
|
2023-11-04 16:46:52 +00:00
|
|
|
void WriteIV(u32 offset, u32 val, u32 mask);
|
|
|
|
void WriteMAC(u32 offset, u32 val, u32 mask);
|
|
|
|
void WriteKeyNormal(u32 slot, u32 offset, u32 val, u32 mask);
|
|
|
|
void WriteKeyX(u32 slot, u32 offset, u32 val, u32 mask);
|
|
|
|
void WriteKeyY(u32 slot, u32 offset, u32 val, u32 mask);
|
2022-01-07 13:00:43 +00:00
|
|
|
|
2023-11-04 16:46:52 +00:00
|
|
|
static void ROL16(u8* val, u32 n);
|
|
|
|
static void DeriveNormalKey(u8* keyX, u8* keyY, u8* normalkey);
|
2019-06-19 12:24:49 +00:00
|
|
|
|
2023-11-04 16:46:52 +00:00
|
|
|
private:
|
2023-11-28 22:16:41 +00:00
|
|
|
melonDS::DSi& DSi;
|
2023-11-04 16:46:52 +00:00
|
|
|
u32 Cnt;
|
2019-06-19 12:24:49 +00:00
|
|
|
|
2023-11-04 16:46:52 +00:00
|
|
|
u32 BlkCnt;
|
|
|
|
u32 RemExtra;
|
|
|
|
u32 RemBlocks;
|
2019-06-19 12:24:49 +00:00
|
|
|
|
2023-11-04 16:46:52 +00:00
|
|
|
bool OutputFlush;
|
2019-08-07 10:57:12 +00:00
|
|
|
|
2023-11-04 16:46:52 +00:00
|
|
|
u32 InputDMASize, OutputDMASize;
|
|
|
|
u32 AESMode;
|
|
|
|
|
|
|
|
FIFO<u32, 16> InputFIFO;
|
|
|
|
FIFO<u32, 16> OutputFIFO;
|
|
|
|
|
|
|
|
u8 IV[16];
|
|
|
|
|
|
|
|
u8 MAC[16];
|
|
|
|
|
|
|
|
u8 KeyNormal[4][16];
|
|
|
|
u8 KeyX[4][16];
|
|
|
|
u8 KeyY[4][16];
|
|
|
|
|
|
|
|
u8 CurKey[16];
|
|
|
|
u8 CurMAC[16];
|
|
|
|
|
|
|
|
// output MAC for CCM encrypt
|
|
|
|
u8 OutputMAC[16];
|
|
|
|
bool OutputMACDue;
|
|
|
|
|
|
|
|
AES_ctx Ctx;
|
|
|
|
|
|
|
|
void ProcessBlock_CCM_Extra();
|
|
|
|
void ProcessBlock_CCM_Decrypt();
|
|
|
|
void ProcessBlock_CCM_Encrypt();
|
|
|
|
void ProcessBlock_CTR();
|
|
|
|
};
|
2019-06-18 17:00:44 +00:00
|
|
|
|
2023-11-25 17:32:09 +00:00
|
|
|
}
|
2019-06-18 17:00:44 +00:00
|
|
|
#endif // DSI_AES_H
|