libnx
v4.8.0
include
switch
crypto
aes_xts.h
Go to the documentation of this file.
1
/**
2
* @file aes_xts.h
3
* @brief Hardware accelerated AES-XTS implementation.
4
* @copyright libnx Authors
5
*/
6
#pragma once
7
#include "
aes.h
"
8
9
/// Context for AES-128 XTS.
10
typedef
struct
{
11
Aes128Context
aes_ctx;
12
Aes128Context
tweak_ctx;
13
u8
tweak[AES_BLOCK_SIZE];
14
u8
buffer[AES_BLOCK_SIZE];
15
size_t
num_buffered;
16
}
Aes128XtsContext
;
17
18
/// Context for AES-192 XTS.
19
typedef
struct
{
20
Aes192Context
aes_ctx;
21
Aes192Context
tweak_ctx;
22
u8
tweak[AES_BLOCK_SIZE];
23
u8
buffer[AES_BLOCK_SIZE];
24
size_t
num_buffered;
25
}
Aes192XtsContext
;
26
27
/// Context for AES-256 XTS.
28
typedef
struct
{
29
Aes256Context
aes_ctx;
30
Aes256Context
tweak_ctx;
31
u8
tweak[AES_BLOCK_SIZE];
32
u8
buffer[AES_BLOCK_SIZE];
33
size_t
num_buffered;
34
}
Aes256XtsContext
;
35
36
/// 128-bit XTS API.
37
void
aes128XtsContextCreate
(
Aes128XtsContext
*out,
const
void
*key0,
const
void
*key1,
bool
is_encryptor);
38
void
aes128XtsContextResetTweak(
Aes128XtsContext
*ctx,
const
void
*tweak);
39
void
aes128XtsContextResetSector(
Aes128XtsContext
*ctx, uint64_t sector,
bool
is_nintendo);
40
size_t
aes128XtsEncrypt(
Aes128XtsContext
*ctx,
void
*dst,
const
void
*src,
size_t
size);
41
size_t
aes128XtsDecrypt(
Aes128XtsContext
*ctx,
void
*dst,
const
void
*src,
size_t
size);
42
43
/// 192-bit XTS API.
44
void
aes192XtsContextCreate
(
Aes192XtsContext
*out,
const
void
*key0,
const
void
*key1,
bool
is_encryptor);
45
void
aes192XtsContextResetTweak(
Aes192XtsContext
*ctx,
const
void
*tweak);
46
void
aes192XtsContextResetSector(
Aes192XtsContext
*ctx, uint64_t sector,
bool
is_nintendo);
47
size_t
aes192XtsEncrypt(
Aes192XtsContext
*ctx,
void
*dst,
const
void
*src,
size_t
size);
48
size_t
aes192XtsDecrypt(
Aes192XtsContext
*ctx,
void
*dst,
const
void
*src,
size_t
size);
49
50
/// 256-bit XTS API.
51
void
aes256XtsContextCreate
(
Aes256XtsContext
*out,
const
void
*key0,
const
void
*key1,
bool
is_encryptor);
52
void
aes256XtsContextResetTweak(
Aes256XtsContext
*ctx,
const
void
*tweak);
53
void
aes256XtsContextResetSector(
Aes256XtsContext
*ctx, uint64_t sector,
bool
is_nintendo);
54
size_t
aes256XtsEncrypt(
Aes256XtsContext
*ctx,
void
*dst,
const
void
*src,
size_t
size);
55
size_t
aes256XtsDecrypt(
Aes256XtsContext
*ctx,
void
*dst,
const
void
*src,
size_t
size);
aes.h
Hardware accelerated AES-ECB implementation.
aes128XtsContextCreate
void aes128XtsContextCreate(Aes128XtsContext *out, const void *key0, const void *key1, bool is_encryptor)
128-bit XTS API.
aes192XtsContextCreate
void aes192XtsContextCreate(Aes192XtsContext *out, const void *key0, const void *key1, bool is_encryptor)
192-bit XTS API.
aes256XtsContextCreate
void aes256XtsContextCreate(Aes256XtsContext *out, const void *key0, const void *key1, bool is_encryptor)
256-bit XTS API.
Aes128Context
Context for AES-128 operations.
Definition:
aes.h:41
Aes128XtsContext
Context for AES-128 XTS.
Definition:
aes_xts.h:10
Aes192Context
Context for AES-192 operations.
Definition:
aes.h:46
Aes192XtsContext
Context for AES-192 XTS.
Definition:
aes_xts.h:19
Aes256Context
Context for AES-256 operations.
Definition:
aes.h:51
Aes256XtsContext
Context for AES-256 XTS.
Definition:
aes_xts.h:28
u8
uint8_t u8
8-bit unsigned integer.
Definition:
types.h:19
Generated by
1.9.1