2019-07-18 08:46:15 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 Microsoft Corporation.
|
|
|
|
*
|
|
|
|
* Author: Jaskaran Singh Khurana <jaskarankhurana@linux.microsoft.com>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#ifndef DM_VERITY_SIG_VERIFICATION_H
|
|
|
|
#define DM_VERITY_SIG_VERIFICATION_H
|
|
|
|
|
|
|
|
#define DM_VERITY_ROOT_HASH_VERIFICATION "DM Verity Sig Verification"
|
|
|
|
#define DM_VERITY_ROOT_HASH_VERIFICATION_OPT_SIG_KEY "root_hash_sig_key_desc"
|
|
|
|
|
|
|
|
struct dm_verity_sig_opts {
|
|
|
|
unsigned int sig_size;
|
|
|
|
u8 *sig;
|
|
|
|
};
|
|
|
|
|
|
|
|
#ifdef CONFIG_DM_VERITY_VERIFY_ROOTHASH_SIG
|
|
|
|
|
|
|
|
#define DM_VERITY_ROOT_HASH_VERIFICATION_OPTS 2
|
|
|
|
|
|
|
|
int verity_verify_root_hash(const void *data, size_t data_len,
|
|
|
|
const void *sig_data, size_t sig_len);
|
|
|
|
bool verity_verify_is_sig_opt_arg(const char *arg_name);
|
|
|
|
|
|
|
|
int verity_verify_sig_parse_opt_args(struct dm_arg_set *as, struct dm_verity *v,
|
|
|
|
struct dm_verity_sig_opts *sig_opts,
|
|
|
|
unsigned int *argc, const char *arg_name);
|
|
|
|
|
|
|
|
void verity_verify_sig_opts_cleanup(struct dm_verity_sig_opts *sig_opts);
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define DM_VERITY_ROOT_HASH_VERIFICATION_OPTS 0
|
|
|
|
|
2020-07-16 12:38:12 +08:00
|
|
|
static inline int verity_verify_root_hash(const void *data, size_t data_len,
|
|
|
|
const void *sig_data, size_t sig_len)
|
2019-07-18 08:46:15 +08:00
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2020-07-16 12:38:12 +08:00
|
|
|
static inline bool verity_verify_is_sig_opt_arg(const char *arg_name)
|
2019-07-18 08:46:15 +08:00
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-07-16 12:38:12 +08:00
|
|
|
static inline int verity_verify_sig_parse_opt_args(struct dm_arg_set *as,
|
|
|
|
struct dm_verity *v, struct dm_verity_sig_opts *sig_opts,
|
|
|
|
unsigned int *argc, const char *arg_name)
|
2019-07-18 08:46:15 +08:00
|
|
|
{
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
2020-07-16 12:38:12 +08:00
|
|
|
static inline void verity_verify_sig_opts_cleanup(struct dm_verity_sig_opts *sig_opts)
|
2019-07-18 08:46:15 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* CONFIG_DM_VERITY_VERIFY_ROOTHASH_SIG */
|
|
|
|
#endif /* DM_VERITY_SIG_VERIFICATION_H */
|