LoadPin.rst 1.6 KB

12345678910111213141516171819202122232425262728293031
  1. =======
  2. LoadPin
  3. =======
  4. LoadPin is a Linux Security Module that ensures all kernel-loaded files
  5. (modules, firmware, etc) all originate from the same filesystem, with
  6. the expectation that such a filesystem is backed by a read-only device
  7. such as dm-verity or CDROM. This allows systems that have a verified
  8. and/or unchangeable filesystem to enforce module and firmware loading
  9. restrictions without needing to sign the files individually.
  10. The LSM is selectable at build-time with ``CONFIG_SECURITY_LOADPIN``, and
  11. can be controlled at boot-time with the kernel command line option
  12. "``loadpin.enforce``". By default, it is enabled, but can be disabled at
  13. boot ("``loadpin.enforce=0``").
  14. LoadPin starts pinning when it sees the first file loaded. If the
  15. block device backing the filesystem is not read-only, a sysctl is
  16. created to toggle pinning: ``/proc/sys/kernel/loadpin/enabled``. (Having
  17. a mutable filesystem means pinning is mutable too, but having the
  18. sysctl allows for easy testing on systems with a mutable filesystem.)
  19. It's also possible to exclude specific file types from LoadPin using kernel
  20. command line option "``loadpin.exclude``". By default, all files are
  21. included, but they can be excluded using kernel command line option such
  22. as "``loadpin.exclude=kernel-module,kexec-image``". This allows to use
  23. different mechanisms such as ``CONFIG_MODULE_SIG`` and
  24. ``CONFIG_KEXEC_VERIFY_SIG`` to verify kernel module and kernel image while
  25. still use LoadPin to protect the integrity of other files kernel loads. The
  26. full list of valid file types can be found in ``kernel_read_file_str``
  27. defined in ``include/linux/kernel_read_file.h``.