mirror of
https://gitlab.com/cryptsetup/cryptsetup.git
synced 2025-12-12 03:10:08 +01:00
Use one file for macros and basic constants for the whole project.
And avoid some dual definitions between tools and library.
This commit is contained in:
@@ -50,6 +50,7 @@ libcryptsetup_la_SOURCES = \
|
|||||||
lib/bitops.h \
|
lib/bitops.h \
|
||||||
lib/nls.h \
|
lib/nls.h \
|
||||||
lib/libcryptsetup.h \
|
lib/libcryptsetup.h \
|
||||||
|
lib/libcryptsetup_macros.h \
|
||||||
lib/utils.c \
|
lib/utils.c \
|
||||||
lib/utils_benchmark.c \
|
lib/utils_benchmark.c \
|
||||||
lib/utils_crypt.c \
|
lib/utils_crypt.c \
|
||||||
|
|||||||
@@ -46,38 +46,13 @@
|
|||||||
|
|
||||||
#include "libcryptsetup.h"
|
#include "libcryptsetup.h"
|
||||||
|
|
||||||
/* to silent gcc -Wcast-qual for const cast */
|
#include "libcryptsetup_macros.h"
|
||||||
#define CONST_CAST(x) (x)(uintptr_t)
|
|
||||||
|
|
||||||
#define SHIFT_4K 12
|
|
||||||
#define SECTOR_SHIFT 9
|
|
||||||
#define SECTOR_SIZE (1 << SECTOR_SHIFT)
|
|
||||||
#define MAX_SECTOR_SIZE 4096 /* min page size among all platforms */
|
|
||||||
#define DEFAULT_DISK_ALIGNMENT 1048576 /* 1MiB */
|
|
||||||
#define DEFAULT_MEM_ALIGNMENT 4096
|
|
||||||
#define LOG_MAX_LEN 4096
|
#define LOG_MAX_LEN 4096
|
||||||
#define MAX_DM_DEPS 32
|
#define MAX_DM_DEPS 32
|
||||||
|
|
||||||
#define CRYPT_SUBDEV "SUBDEV" /* prefix for sublayered devices underneath public crypt types */
|
#define CRYPT_SUBDEV "SUBDEV" /* prefix for sublayered devices underneath public crypt types */
|
||||||
|
|
||||||
#define at_least(a, b) ({ __typeof__(a) __at_least = (a); (__at_least >= (b))?__at_least:(b); })
|
|
||||||
|
|
||||||
#define MISALIGNED(a, b) ((a) & ((b) - 1))
|
|
||||||
#define MISALIGNED_4K(a) MISALIGNED((a), 1 << SHIFT_4K)
|
|
||||||
#define MISALIGNED_512(a) MISALIGNED((a), 1 << SECTOR_SHIFT)
|
|
||||||
#define NOTPOW2(a) MISALIGNED((a), (a))
|
|
||||||
|
|
||||||
#ifndef ARRAY_SIZE
|
|
||||||
# define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define MOVE_REF(x, y) \
|
|
||||||
do { \
|
|
||||||
__typeof__(x) *_px = &(x), *_py = &(y); \
|
|
||||||
*_px = *_py; \
|
|
||||||
*_py = NULL; \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
#ifndef O_CLOEXEC
|
#ifndef O_CLOEXEC
|
||||||
#define O_CLOEXEC 0
|
#define O_CLOEXEC 0
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
59
lib/libcryptsetup_macros.h
Normal file
59
lib/libcryptsetup_macros.h
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
/*
|
||||||
|
* Definitions of common constant and generic macros fo libcryptsetup
|
||||||
|
*
|
||||||
|
* Copyright (C) 2009-2021 Red Hat, Inc. All rights reserved.
|
||||||
|
* Copyright (C) 2009-2021 Milan Broz
|
||||||
|
*
|
||||||
|
* This program 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 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program 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 this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _LIBCRYPTSETUP_MACROS_H
|
||||||
|
#define _LIBCRYPTSETUP_MACROS_H
|
||||||
|
|
||||||
|
/* to silent gcc -Wcast-qual for const cast */
|
||||||
|
#define CONST_CAST(x) (x)(uintptr_t)
|
||||||
|
|
||||||
|
#define UNUSED(x) (void)(x)
|
||||||
|
|
||||||
|
#ifndef ARRAY_SIZE
|
||||||
|
# define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define MOVE_REF(x, y) \
|
||||||
|
do { \
|
||||||
|
__typeof__(x) *_px = &(x), *_py = &(y); \
|
||||||
|
*_px = *_py; \
|
||||||
|
*_py = NULL; \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
#define FREE_AND_NULL(x) do { free(x); x = NULL; } while (0)
|
||||||
|
|
||||||
|
#define AT_LEAST(a, b) ({ __typeof__(a) __at_least = (a); (__at_least >= (b))?__at_least:(b); })
|
||||||
|
|
||||||
|
#define SHIFT_4K 12
|
||||||
|
#define SECTOR_SHIFT 9
|
||||||
|
#define SECTOR_SIZE (1 << SECTOR_SHIFT)
|
||||||
|
#define MAX_SECTOR_SIZE 4096 /* min page size among all platforms */
|
||||||
|
#define ROUND_SECTOR(x) (((x) + SECTOR_SIZE - 1) / SECTOR_SIZE)
|
||||||
|
|
||||||
|
#define MISALIGNED(a, b) ((a) & ((b) - 1))
|
||||||
|
#define MISALIGNED_4K(a) MISALIGNED((a), 1 << SHIFT_4K)
|
||||||
|
#define MISALIGNED_512(a) MISALIGNED((a), 1 << SECTOR_SHIFT)
|
||||||
|
#define NOTPOW2(a) MISALIGNED((a), (a))
|
||||||
|
|
||||||
|
#define DEFAULT_DISK_ALIGNMENT 1048576 /* 1MiB */
|
||||||
|
#define DEFAULT_MEM_ALIGNMENT 4096
|
||||||
|
|
||||||
|
#endif /* _LIBCRYPTSETUP_MACROS_H */
|
||||||
@@ -800,7 +800,7 @@ int LUKS_generate_phdr(struct luks_phdr *header,
|
|||||||
|
|
||||||
if (PBKDF2_temp > (double)UINT32_MAX)
|
if (PBKDF2_temp > (double)UINT32_MAX)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
header->mkDigestIterations = at_least((uint32_t)PBKDF2_temp, LUKS_MKD_ITERATIONS_MIN);
|
header->mkDigestIterations = AT_LEAST((uint32_t)PBKDF2_temp, LUKS_MKD_ITERATIONS_MIN);
|
||||||
assert(header->mkDigestIterations);
|
assert(header->mkDigestIterations);
|
||||||
|
|
||||||
r = crypt_pbkdf(CRYPT_KDF_PBKDF2, header->hashSpec, vk->key,vk->keylength,
|
r = crypt_pbkdf(CRYPT_KDF_PBKDF2, header->hashSpec, vk->key,vk->keylength,
|
||||||
@@ -874,7 +874,7 @@ int LUKS_set_key(unsigned int keyIndex,
|
|||||||
* Final iteration count is at least LUKS_SLOT_ITERATIONS_MIN
|
* Final iteration count is at least LUKS_SLOT_ITERATIONS_MIN
|
||||||
*/
|
*/
|
||||||
hdr->keyblock[keyIndex].passwordIterations =
|
hdr->keyblock[keyIndex].passwordIterations =
|
||||||
at_least(pbkdf->iterations, LUKS_SLOT_ITERATIONS_MIN);
|
AT_LEAST(pbkdf->iterations, LUKS_SLOT_ITERATIONS_MIN);
|
||||||
log_dbg(ctx, "Key slot %d use %" PRIu32 " password iterations.", keyIndex,
|
log_dbg(ctx, "Key slot %d use %" PRIu32 " password iterations.", keyIndex,
|
||||||
hdr->keyblock[keyIndex].passwordIterations);
|
hdr->keyblock[keyIndex].passwordIterations);
|
||||||
|
|
||||||
|
|||||||
@@ -30,8 +30,6 @@
|
|||||||
#include "base64.h"
|
#include "base64.h"
|
||||||
#include "luks2.h"
|
#include "luks2.h"
|
||||||
|
|
||||||
#define UNUSED(x) (void)(x)
|
|
||||||
|
|
||||||
/* override useless forward slash escape when supported by json-c */
|
/* override useless forward slash escape when supported by json-c */
|
||||||
#ifndef JSON_C_TO_STRING_NOSLASHESCAPE
|
#ifndef JSON_C_TO_STRING_NOSLASHESCAPE
|
||||||
#define JSON_C_TO_STRING_NOSLASHESCAPE 0
|
#define JSON_C_TO_STRING_NOSLASHESCAPE 0
|
||||||
|
|||||||
@@ -196,7 +196,7 @@ int crypt_benchmark_pbkdf_internal(struct crypt_device *cd,
|
|||||||
PBKDF2_tmp = ((double)pbkdf->iterations * pbkdf->time_ms / 1000.);
|
PBKDF2_tmp = ((double)pbkdf->iterations * pbkdf->time_ms / 1000.);
|
||||||
if (PBKDF2_tmp > (double)UINT32_MAX)
|
if (PBKDF2_tmp > (double)UINT32_MAX)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
pbkdf->iterations = at_least((uint32_t)PBKDF2_tmp, pbkdf_limits.min_iterations);
|
pbkdf->iterations = AT_LEAST((uint32_t)PBKDF2_tmp, pbkdf_limits.min_iterations);
|
||||||
} else {
|
} else {
|
||||||
/* Already benchmarked */
|
/* Already benchmarked */
|
||||||
if (pbkdf->iterations) {
|
if (pbkdf->iterations) {
|
||||||
|
|||||||
@@ -46,22 +46,15 @@
|
|||||||
#include "lib/utils_fips.h"
|
#include "lib/utils_fips.h"
|
||||||
#include "lib/utils_io.h"
|
#include "lib/utils_io.h"
|
||||||
#include "lib/utils_blkid.h"
|
#include "lib/utils_blkid.h"
|
||||||
|
#include "lib/libcryptsetup_macros.h"
|
||||||
|
|
||||||
#include "libcryptsetup.h"
|
#include "libcryptsetup.h"
|
||||||
|
|
||||||
#define CONST_CAST(x) (x)(uintptr_t)
|
|
||||||
#define DEFAULT_CIPHER(type) (DEFAULT_##type##_CIPHER "-" DEFAULT_##type##_MODE)
|
#define DEFAULT_CIPHER(type) (DEFAULT_##type##_CIPHER "-" DEFAULT_##type##_MODE)
|
||||||
#define SECTOR_SIZE 512
|
|
||||||
#define MAX_SECTOR_SIZE 4096
|
|
||||||
#define ROUND_SECTOR(x) (((x) + SECTOR_SIZE - 1) / SECTOR_SIZE)
|
|
||||||
|
|
||||||
#define DEFAULT_WIPE_BLOCK 1048576 /* 1 MiB */
|
#define DEFAULT_WIPE_BLOCK 1048576 /* 1 MiB */
|
||||||
#define MAX_ACTIONS 16
|
#define MAX_ACTIONS 16
|
||||||
|
|
||||||
#ifndef ARRAY_SIZE
|
|
||||||
# define ARRAY_SIZE(arr) (sizeof(arr) / sizeof((arr)[0]))
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Common tools */
|
/* Common tools */
|
||||||
void tool_log(int level, const char *msg, void *usrptr __attribute__((unused)));
|
void tool_log(int level, const char *msg, void *usrptr __attribute__((unused)));
|
||||||
void quiet_log(int level, const char *msg, void *usrptr);
|
void quiet_log(int level, const char *msg, void *usrptr);
|
||||||
@@ -123,8 +116,6 @@ int tools_lookup_crypt_device(struct crypt_device *cd, const char *type,
|
|||||||
/* each utility is required to implement it */
|
/* each utility is required to implement it */
|
||||||
void tools_cleanup(void);
|
void tools_cleanup(void);
|
||||||
|
|
||||||
#define FREE_AND_NULL(x) do { free(x); x = NULL; } while (0)
|
|
||||||
|
|
||||||
/* Log */
|
/* Log */
|
||||||
#define log_dbg(x...) crypt_logf(NULL, CRYPT_LOG_DEBUG, x)
|
#define log_dbg(x...) crypt_logf(NULL, CRYPT_LOG_DEBUG, x)
|
||||||
#define log_std(x...) crypt_logf(NULL, CRYPT_LOG_NORMAL, x)
|
#define log_std(x...) crypt_logf(NULL, CRYPT_LOG_NORMAL, x)
|
||||||
|
|||||||
Reference in New Issue
Block a user