ima: forbid write access to files with digital signatures
authorDmitry Kasatkin <dmitry.kasatkin@intel.com>
Thu, 27 Sep 2012 12:06:28 +0000 (15:06 +0300)
committerMimi Zohar <zohar@linux.vnet.ibm.com>
Wed, 16 Jan 2013 22:50:05 +0000 (17:50 -0500)
This patch forbids write access to files with digital signatures, as they
are considered immutable.

Signed-off-by: Dmitry Kasatkin <dmitry.kasatkin@intel.com>
Signed-off-by: Mimi Zohar <zohar@linux.vnet.ibm.com>
security/integrity/ima/ima_main.c

index d743c9a0a4b4e9b8ae881eb4d3b87b7ce5e9f59b..cd00ba39e8e060dbcefa986b953d5400e9f696af 100644 (file)
@@ -175,12 +175,12 @@ static int process_measurement(struct file *file, const char *filename,
        if (!action) {
                if (iint->flags & IMA_APPRAISED)
                        rc = iint->ima_status;
-               goto out;
+               goto out_digsig;
        }
 
        rc = ima_collect_measurement(iint, file);
        if (rc != 0)
-               goto out;
+               goto out_digsig;
 
        if (function != BPRM_CHECK)
                pathname = ima_d_path(&file->f_path, &pathbuf);
@@ -195,6 +195,9 @@ static int process_measurement(struct file *file, const char *filename,
        if (action & IMA_AUDIT)
                ima_audit_measurement(iint, pathname);
        kfree(pathbuf);
+out_digsig:
+       if ((mask & MAY_WRITE) && (iint->flags & IMA_DIGSIG))
+               rc = -EACCES;
 out:
        mutex_unlock(&inode->i_mutex);
        if ((rc && must_appraise) && (ima_appraise & IMA_APPRAISE_ENFORCE))