Generalise system_verify_data() to provide access to internal content through a callback. This allows all the PKCS#7 stuff to be hidden inside this function and removed from the PE file parser and the PKCS#7 test key. If external content is not required, NULL should be passed as data to the function. If the callback is not required, that can be set to NULL. The function is now called verify_pkcs7_signature() to contrast with verify_pefile_signature() and the definitions of both have been moved into linux/verification.h along with the key_being_used_for enum. Signed-off-by: David Howells <dhowells@redhat.com>
58 lines
1.3 KiB
C
58 lines
1.3 KiB
C
/* System keyring containing trusted public keys.
|
|
*
|
|
* Copyright (C) 2013 Red Hat, Inc. All Rights Reserved.
|
|
* Written by David Howells (dhowells@redhat.com)
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public Licence
|
|
* as published by the Free Software Foundation; either version
|
|
* 2 of the Licence, or (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef _KEYS_SYSTEM_KEYRING_H
|
|
#define _KEYS_SYSTEM_KEYRING_H
|
|
|
|
#ifdef CONFIG_SYSTEM_TRUSTED_KEYRING
|
|
|
|
#include <linux/key.h>
|
|
#include <linux/verification.h>
|
|
#include <crypto/public_key.h>
|
|
|
|
extern struct key *system_trusted_keyring;
|
|
static inline struct key *get_system_trusted_keyring(void)
|
|
{
|
|
return system_trusted_keyring;
|
|
}
|
|
#else
|
|
static inline struct key *get_system_trusted_keyring(void)
|
|
{
|
|
return NULL;
|
|
}
|
|
#endif
|
|
|
|
#ifdef CONFIG_IMA_MOK_KEYRING
|
|
extern struct key *ima_mok_keyring;
|
|
extern struct key *ima_blacklist_keyring;
|
|
|
|
static inline struct key *get_ima_mok_keyring(void)
|
|
{
|
|
return ima_mok_keyring;
|
|
}
|
|
static inline struct key *get_ima_blacklist_keyring(void)
|
|
{
|
|
return ima_blacklist_keyring;
|
|
}
|
|
#else
|
|
static inline struct key *get_ima_mok_keyring(void)
|
|
{
|
|
return NULL;
|
|
}
|
|
static inline struct key *get_ima_blacklist_keyring(void)
|
|
{
|
|
return NULL;
|
|
}
|
|
#endif /* CONFIG_IMA_MOK_KEYRING */
|
|
|
|
|
|
#endif /* _KEYS_SYSTEM_KEYRING_H */
|