• David Howells's avatar
    lockdown: Enforce module signatures if the kernel is locked down · 49fcf732
    David Howells authored
    If the kernel is locked down, require that all modules have valid
    signatures that we can verify.
    
    I have adjusted the errors generated:
    
     (1) If there's no signature (ENODATA) or we can't check it (ENOPKG,
         ENOKEY), then:
    
         (a) If signatures are enforced then EKEYREJECTED is returned.
    
         (b) If there's no signature or we can't check it, but the kernel is
    	 locked down then EPERM is returned (this is then consistent with
    	 other lockdown cases).
    
     (2) If the signature is unparseable (EBADMSG, EINVAL), the signature fails
         the check (EKEYREJECTED) or a system error occurs (eg. ENOMEM), we
         return the error we got.
    
    Note that the X.509 code doesn't check for key expiry as the RTC might not
    be valid or might not have been transferred to the kernel's clock yet.
    
     [Modified by Matthew Garrett to remove the IMA integration. This will
      be replaced with integration with the IMA architecture policy
      patchset.]
    Signed-off-by: default avatarDavid Howells <dhowells@redhat.com>
    Signed-off-by: default avatarMatthew Garrett <matthewgarrett@google.com>
    Reviewed-by: default avatarKees Cook <keescook@chromium.org>
    Cc: Jessica Yu <jeyu@kernel.org>
    Signed-off-by: default avatarJames Morris <jmorris@namei.org>
    49fcf732
Kconfig 66.6 KB