Makefile: Add security compiling option (RELRO, SC, and FORTIFY)
[platform/upstream/cryptsetup.git] / lib / loopaes / loopaes.h
1 /*
2  * loop-AES compatible volume handling
3  *
4  * Copyright (C) 2011-2023 Red Hat, Inc. All rights reserved.
5  * Copyright (C) 2011-2023 Milan Broz
6  *
7  * This file is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * This file is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with this file; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20  */
21
22 #ifndef _LOOPAES_H
23 #define _LOOPAES_H
24
25 #include <stdint.h>
26 #include <stddef.h>
27
28 struct crypt_device;
29 struct volume_key;
30
31 #define LOOPAES_KEYS_MAX 65
32
33 int LOOPAES_parse_keyfile(struct crypt_device *cd,
34                           struct volume_key **vk,
35                           const char *hash,
36                           unsigned int *keys_count,
37                           char *buffer,
38                           size_t buffer_len);
39
40 int LOOPAES_activate(struct crypt_device *cd,
41                      const char *name,
42                      const char *base_cipher,
43                      unsigned int keys_count,
44                      struct volume_key *vk,
45                      uint32_t flags);
46 #endif