Questo contenuto non è disponibile nella lingua selezionata.
Chapter 26. Extending, customizing, and troubleshooting kernel integrity subsystem
Extend, customize, and troubleshoot the kernel integrity subsystem to meet specific security requirements in different operational environments.
26.1. Generate good reference values for IMA appraisal Copia collegamentoCollegamento copiato negli appunti!
Before you deploy an Integrity Measurement Architecture (IMA) policy that includes IMA-appraisal rules, ensure that all files governed by these rules have valid reference values stored in the security.ima extended attribute. If these reference values are missing, IMA might prevent the system from booting properly or deny access to files.
# ima-appraise-file </path/to/file>
26.1.1. Adding IMA signatures as good references for immutable files Copia collegamentoCollegamento copiato negli appunti!
To support integrity verification, you can use IMA signatures as trusted reference values for immutable files. This approach helps ensure that only files with valid signatures are accessed, which strengthens system security and compliance.
Prerequisites
- You have created an IMA policy that includes IMA-appraisal rules.
Procedure
Install the
rpm-plugin-ima:$ sudo dnf install rpm-plugin-ima -yqThis ensures that package files have IMA signature stored in
security.xattrautomatically during package installation, reinstallation, or upgradation.Reinstall all the packages:
$ sudo dnf reinstall "*" -yThis ensures that the
security.xattrextended attribute is updated for all packages.Enable the dracut integrity module so the official IMA code-signing key in
/etc/keys/imaloads automatically on boot:$ sudo dracut -f
Verification
Verify that signature is correctly stored in
security.imaextended attribute:$ # evmctl ima_verify -k /etc/keys/ima/redhatimarelease-10.der /usr/lib/systemd/systemdkeyid d3320449 (from /etc/keys/ima/redhatimarelease-10.der) key 1: d3320449 /etc/keys/ima/redhatimarelease-10.der /usr/lib/systemd/systemd: verification is OK$ # evmctl ima_verify -k /etc/keys/ima/redhatimarelease-10.der /bin/bashkeyid d3320449 (from /etc/keys/ima/redhatimarelease-10.der) key 1: d3320449 /etc/keys/ima/redhatimarelease-10.der /bin/bash: verification is OK ...
26.1.2. Generating good reference values for mutable files Copia collegamentoCollegamento copiato negli appunti!
To maintain integrity for files that might change over time, generate and update reference values as needed. This ensures that the system accurately verifies the authenticity of mutable files and prevent unauthorized modifications.
Prerequisites
- You have root privileges on the system.
- You have created an IMA policy that includes IMA-appraisal rules.
- You have generated good reference values for IMA appraisal.
- Secure Boot is disabled.
Procedure
Optional: Enable your chosen IMA-appraisal policy or skip this step if you only use your custom policy. Take built-in
ima_policy=appraise_tcbas an example:# grubby --update-kernel=/boot/vmlinuz-$(uname -r) --args="ima_policy=appraise_tcb"Additionally for
s390xsystems:# zipl
Enable IMA-appraisal fix mode by adding the
ima_appraise=fixkernel command line parameter:# grubby --update-kernel=/boot/vmlinuz-$(uname -r) --args="ima_appraise=fix"Additionally for
s390xsystems:# zipl
Reboot the system:
# rebootOptional: Load your custom IMA policy:
# echo <path_to_your_custom_ima_policy> > /sys/kernel/security/ima/policyRe-label the whole system:
# find / -fstype xfs -type f -uid 0 -exec head -c 0 '{}' \;Turn off IMA-appraisal fix mode by removing the
ima_appraise=fixkernel command line parameter:# grubby --update-kernel=/boot/vmlinuz-$(uname -r) --remove-args="ima_appraise=fix"Additionally for
s390xsystems:# zipl
- Enable the secure boot if it is disabled.
Additional resources
26.2. Writing custom IMA policy Copia collegamentoCollegamento copiato negli appunti!
If the built-in IMA policies that you enable with kernel command line parameters, such as ima_policy=tcb or ima_policy=critical_data, or the sample policies in /usr/share/ima/policies/ do not meet your requirements, you can create custom IMA policy rules. When systemd loads a policy from /etc/ima/ima-policy, it replaces the built-in IMA policy.
After you define your IMA policy, generate good reference values if the policy includes IMA-appraisal rules before you deploy it. If your policy does not include IMA-appraisal rules, you can verify the policy by running echo /PATH-TO-YOUR-DRAFT-IMA-POLICY > /sys/kernel/security/integrity/ima/policy. This approach helps prevent system boot failures.
Procedure
Review the rule format and an example policy.
An IMA policy rule uses the format
action [condition …]to specify an action that is triggered under certain conditions. For example, the sample policy in/usr/share/ima/policies/01-appraise-executable-and-lib-signaturesincludes the following rules:# Skip some unsupported filesystems # For a list of these filesystems, see # https://www.kernel.org/doc/Documentation/ABI/testing/ima_policy # PROC_SUPER_MAGIC dont_appraise fsmagic=0x9fa0 … appraise func=BPRM_CHECK appraise_type=imasigThe first rule,
dont_appraise fsmagic=0x9fa0, instructs IMA to skip appraising files in thePROC_SUPER_MAGICfilesystem. The last rule,appraise func=BPRM_CHECK appraise_type=imasig, enforces signature verification when a file is executed.
26.3. Creating custom IMA keys by using OpenSSL Copia collegamentoCollegamento copiato negli appunti!
To secure your code, use OpenSSL to generate a Certificate Signing Request (CSR) for your digital certificates.
The kernel searches the .ima keyring for a code signing key to verify an IMA signature. Before you add a code signing key to the .ima keyring, you need to ensure that IMA CA key signed this key in the .builtin_trusted_keys or .secondary_trusted_keys keyrings.
Prerequisites
The custom IMA CA key has the following extensions:
- The basic constraints extension with the CA boolean asserted.
-
The
KeyUsageextension with thekeyCertSignbit asserted but without thedigitalSignatureasserted.
The custom IMA code signing key falls under the following criteria:
- The IMA CA key signed this custom IMA code signing key.
-
The custom key includes the
subjectKeyIdentifierextension.
-
UEFI Secure Boot on
x86_64oraarch64systems or PowerVM Secure Boot onppc64lesystems is enabled.
Procedure
To generate a custom IMA CA key pair, run:
# openssl req -new -x509 -utf8 -sha256 -days 3650 -batch -config ima_ca.conf -outform DER -out custom_ima_ca.der -keyout custom_ima_ca.privOptional: To check the content of the
ima_ca.conffile, run:# cat ima_ca.conf [ req ] default_bits = 2048 distinguished_name = req_distinguished_name prompt = no string_mask = utf8only x509_extensions = ca [ req_distinguished_name ] O = YOUR_ORG CN = YOUR_COMMON_NAME IMA CA emailAddress = YOUR_EMAIL [ ca ] basicConstraints=critical,CA:TRUE subjectKeyIdentifier=hash authorityKeyIdentifier=keyid:always,issuer keyUsage=critical,keyCertSign,cRLSignTo generate a private key and a certificate signing request (CSR) for the IMA code signing key, run:
# openssl req -new -utf8 -sha256 -days 365 -batch -config ima.conf -out custom_ima.csr -keyout custom_ima.privOptional: To check the content of the
ima.conffile, run:# cat ima.conf [ req ] default_bits = 2048 distinguished_name = req_distinguished_name prompt = no string_mask = utf8only x509_extensions = code_signing [ req_distinguished_name ] O = YOUR_ORG CN = YOUR_COMMON_NAME IMA signing key emailAddress = YOUR_EMAIL [ code_signing ] basicConstraints=critical,CA:FALSE keyUsage=digitalSignature subjectKeyIdentifier=hash authorityKeyIdentifier=keyid:always,issuerUse the IMA CA private key to sign the CSR to create the IMA code signing certificate:
# openssl x509 -req -in custom_ima.csr -days 365 -extfile ima.conf -extensions code_signing -CA custom_ima_ca.der -CAkey custom_ima_ca.priv -CAcreateserial -outform DER -out ima.der
26.4. Loading an IMA policy signed by your custom IMA key Copia collegamentoCollegamento copiato negli appunti!
To maintain your system integrity and meet the security requirements for your organization, you can load an Integrity Measurement Architecture (IMA) policy that is signed with your own custom IMA key. This approach ensures that only trusted, authenticated policies are applied during system startup or runtime.
This procedure applies only to x86_64 and aarch64 systems with UEFI Secure Boot enabled, and to ppc64le systems running PowerVM Secure Boot.
Prerequisites
- You must have root privileges on your system.
-
UEFI Secure Boot is enabled for Red Hat Enterprise Linux or the kernel is booted with the
ima_policy=secure_bootparameter to ensure only signed IMA policy can be loaded. - The custom IMA CA key has been added to the MOK list. For more information, see Enrolling public key on target system by adding the public key to the MOK list.
- The kernel version is 5.14 or later.
- Good reference values have been generated for the IMA policy. For more information, see Generate good reference values for IMA appraisal.
Procedure
Add your custom IMA code signing key to the
.imakeyring:# keyctl padd asymmetric <KEY_SUBJECT> %:.ima < <PATH_TO_YOUR_CUSTOM_IMA_KEY>Prepare your IMA policy and sign it with your custom IMA code signing key:
# evmctl ima_sign <PATH_TO_YOUR_CUSTOM_IMA_POLICY> -k <PATH_TO_YOUR_CUSTOM_IMA_KEY>Load the signed IMA policy:
# echo <PATH_TO_YOUR_CUSTOM_SIGNED_IMA_POLICY> > /sys/kernel/security/ima/policyVerify that the policy loaded successfully:
# *echo $?*00indicates that the IMA policy was loaded successfully. If the command returns a nonzero value, the IMA policy was not loaded successfully.
WarningDo not skip this step. If you do, your system might fail to boot and you need to recover your system.
If the IMA policy fails to load, repeat the steps 2 and 3 to fix the issue.
Copy the signed IMA policy to
/etc/ima/ima-policyto enable systemd load it automatically on boot:# cp --preserve=xattr <PATH_TO_YOUR_CUSTOM_IMA_POLICY> /etc/ima/ima-policyCopy your custom IMA key to the
/etc/keys/ima/directory:# cp <PATH_TO_YOUR_CUSTOM_IMA_KEY> /etc/keys/ima/Copy the
dracutintegrity configuration file:# *cp --preserve=xattr /usr/share/ima/dracut-98-integrity.conf /etc/dracut.conf.d/98-integrity.conf*Rebuild the initial RAM disk:
# *dracut -f*Additionally for
s390xsystems:# zipl
Verification
Verify that the IMA policy is loaded successfully:
# cat /sys/kernel/security/ima/policyThe output should include the rules from your custom IMA policy.
26.5. Troubleshooting systemd failure to load the IMA policy Copia collegamentoCollegamento copiato negli appunti!
When systemd does not load /etc/ima/ima-policy, the system hangs with a systemd[1]: Freezing execution error message.
The failure can appear as follows:
[ 5.829882] ima: policy update failed
[ 5.830094] ima: signed policy file (specified as an absolute pathname) required
[!!!!!!] Failed to load IMA policy.
…
[ 5.859994] systemd[1]: Freezing execution.
There are three methods that you can use to recover your system:
- Turn off Secure Boot: Use this method if the error indicates a missing signature on a UEFI system.
-
Booting with
init=/bin/bash: Use this method to open a shell and fix the policy file. -
Booting with
initcall_blacklist=init_ima: Use this method to start the system with IMA disabled.
26.5.1. Turn off Secure Boot Copia collegamentoCollegamento copiato negli appunti!
If a policy is not signed, the kernel prevents it from loading and logs specific error messages.
[ 5.661906] ima: policy update failed
[ 5.662290] ima: signed policy file (specified as an absolute pathname) required
[ 5.662496] systemd[1]: Failed to load the IMA custom policy file /etc/ima/ima-policy1: Permission denied
[ 5.662663] ima: policy update failed
[ 5.662856] audit: type=1800 audit(1744968172.925:7): pid=1 uid=0 auid=4294967295 ses=4294967295 subj=system_u:system_r:init_t:s0 op=appraise_data cause=IMA-signature-required comm="systemd" name="/etc/ima/ima-policy" dev="vda3" ino=25679834 res=0 errno=0
[ 5.663205] audit: type=1802 audit(1744968172.925:8): pid=1 uid=0 auid=4294967295 ses=4294967295 subj=system_u:system_r:init_t:s0 op=policy_update cause=failed comm="systemd" res=0 errno=0
[!!!!!!] Failed to load IMA policy.
As a workaround, you can turn off Secure Boot temporarily and follow Loading an IMA policy signed by your custom IMA key to fix the issue.
26.5.2. Booting the system with the init=/bin/bash kernel parameter Copia collegamentoCollegamento copiato negli appunti!
To start the system with the init=/bin/bash kernel parameter, add it to the boot loader entry and run the required commands in the recovery shell. You can then correct and verify the IMA policy before rebooting normally.
Procedure
Modify the boot loader entry and add the
init=/bin/bashkernel parameter.# grubby --update-kernel="$(grubby --default-kernel)" --args="init=/bin/bash"After you access the shell, remount the system with write permissions:
# mount -o remount,rw /Rename
/etc/ima/ima-policyto/etc/ima/ima-policy.bak:# mv /etc/ima/ima-policy /etc/ima/ima-policy.bakEnable the
SysRqmagic key:# echo 1 > /proc/sys/kernel/sysrqReboot the system:
# printf "s\nb" > /proc/sysrq-triggerResolve any issues in
/etc/ima/ima-policy.bakand verify that the policy can be loaded:# echo /etc/ima/ima-policy.bak >> /sys/kernel/security/integrity/ima/policyRename
/etc/ima/ima-policy.bakto/etc/ima/ima-policy:# mv /etc/ima/ima-policy.bak /etc/ima/ima-policy
26.5.3. Booting the system with the initcall_blacklist=init_ima kernel parameter Copia collegamentoCollegamento copiato negli appunti!
To start the system with the initcall_blacklist=init_ima kernel parameter when the system hangs with systemd[1]: Freezing execution, add the parameter to the boot loader entry and run the required commands. You can then correct and verify the IMA policy before rebooting normally.
Procedure
Modify the boot loader entry and add the
initcall_blacklist=init_imakernel parameter.# grubby --update-kernel="$(grubby --default-kernel)" --args="initcall_blacklist=init_ima"Rename
/etc/ima/ima-policyto/etc/ima/ima-policy.bak:# mv /etc/ima/ima-policy /etc/ima/ima-policy.bakReboot the system:
# systemctl rebootResolve any issues in
/etc/ima/ima-policy.bakand verify that the policy can be loaded:# echo /etc/ima/ima-policy.bak >> /sys/kernel/security/integrity/ima/policyRename
/etc/ima/ima-policy.bakto/etc/ima/ima-policy:# mv /etc/ima/ima-policy.bak /etc/ima/ima-policy
26.6. Signing custom built packages Copia collegamentoCollegamento copiato negli appunti!
To maintain the integrity of your system, it is important to sign custom built packages before deployment. With the rpm-sign tool and IMA code signing key, you can sign your custom built packages.
Prerequisites
- You have root privileges on your system.
- You have a custom built package that you want to sign.
- You have the IMA code signing key.
-
You have the
rpm-signtool installed. - Custom IMA keys are created. See Creating custom IMA keys by using OpenSSL.
Procedure
Use
rpmsign –signfilesto sign package files:# rpmsign --define "gpg_name _<GPG_KEY_NAME>" --addsign --signfiles --fskpass --fskpath=<PATH_TO_YOUR_PRIVATE_IMA_CODE_SIGNING_KEY> <PATH_TO_YOUR_RPM>--define "gpg_name _<GPG_KEY_NAME>"- The GPG key signs the package, and the IMA code signing key signs each file in the package.
--addsign- Adds the signature to the package.
--signfiles- Signs each file in the package.
--fskpass- Avoids repeatedly entering the password for the IMA code signing key.
--fskpath- Specifies the path to the IMA code signing key.
Verification
To verify that the package is signed, you can use the following command:
# rpm -q --queryformat "[%{FILENAMES} %{FILESIGNATURES}\n] <PATH_TO_YOUR_RPM>"/usr/bin/YOUR_BIN 030204... /usr/lib/YOUR_LIB.so 030204... ...
26.7. Selecting between IMA and fapolicyd Copia collegamentoCollegamento copiato negli appunti!
IMA and fapolicyd are two different tools for enforcing file integrity. IMA is a kernel module that enforces file integrity by verifying the integrity of files at boot time. fapolicyd is a daemon that enforces file integrity by verifying the integrity of files at runtime.
The following list can help you determine which tool meets your requirements:
-
IMA verifies digital signatures to ensure integrity, while
fapolicydcurrently supports only hash-based verification. -
IMA operates in kernel space, while
fapolicydoperates in user space. -
fapolicydsupports basic integrity verification by checking file size and can also verify reference hash values stored insecurity.ima. -
IMA and
fapolicyduse different policy syntax. For example,fapolicydsupports path-based policies, but IMA does not.