| // SPDX-License-Identifier: GPL-2.0+ |
| /* |
| * Platform keyring for firmware/platform keys |
| * |
| * Copyright IBM Corporation, 2018 |
| * Author(s): Nayna Jain <[email protected]> |
| */ |
| |
| #include <linux/export.h> |
| #include <linux/kernel.h> |
| #include <linux/sched.h> |
| #include <linux/cred.h> |
| #include <linux/err.h> |
| #include <linux/slab.h> |
| #include "../integrity.h" |
| |
| static struct key_acl platform_key_acl = { |
| .usage = REFCOUNT_INIT(1), |
| .nr_ace = 2, |
| .aces = { |
| KEY_POSSESSOR_ACE(KEY_ACE_SEARCH | KEY_ACE_READ), |
| KEY_OWNER_ACE(KEY_ACE_VIEW), |
| } |
| }; |
| |
| /** |
| * add_to_platform_keyring - Add to platform keyring without validation. |
| * @source: Source of key |
| * @data: The blob holding the key |
| * @len: The length of the data blob |
| * |
| * Add a key to the platform keyring without checking its trust chain. This |
| * is available only during kernel initialisation. |
| */ |
| void __init add_to_platform_keyring(const char *source, const void *data, |
| size_t len) |
| { |
| int rc; |
| |
| rc = integrity_load_cert(INTEGRITY_KEYRING_PLATFORM, source, data, len, |
| &platform_key_acl); |
| if (rc) |
| pr_info("Error adding keys to platform keyring %s\n", source); |
| } |
| |
| /* |
| * Create the trusted keyrings. |
| */ |
| static __init int platform_keyring_init(void) |
| { |
| int rc; |
| |
| rc = integrity_init_keyring(INTEGRITY_KEYRING_PLATFORM); |
| if (rc) |
| return rc; |
| |
| pr_notice("Platform Keyring initialized\n"); |
| return 0; |
| } |
| |
| /* |
| * Must be initialised before we try and load the keys into the keyring. |
| */ |
| device_initcall(platform_keyring_init); |