Path: blob/master/security/integrity/ima/ima_audit.c
10820 views
/*1* Copyright (C) 2008 IBM Corporation2* Author: Mimi Zohar <[email protected]>3*4* This program is free software; you can redistribute it and/or modify5* it under the terms of the GNU General Public License as published by6* the Free Software Foundation, version 2 of the License.7*8* File: integrity_audit.c9* Audit calls for the integrity subsystem10*/1112#include <linux/fs.h>13#include <linux/gfp.h>14#include <linux/audit.h>15#include "ima.h"1617static int ima_audit;1819#ifdef CONFIG_IMA_AUDIT2021/* ima_audit_setup - enable informational auditing messages */22static int __init ima_audit_setup(char *str)23{24unsigned long audit;2526if (!strict_strtoul(str, 0, &audit))27ima_audit = audit ? 1 : 0;28return 1;29}30__setup("ima_audit=", ima_audit_setup);31#endif3233void integrity_audit_msg(int audit_msgno, struct inode *inode,34const unsigned char *fname, const char *op,35const char *cause, int result, int audit_info)36{37struct audit_buffer *ab;3839if (!ima_audit && audit_info == 1) /* Skip informational messages */40return;4142ab = audit_log_start(current->audit_context, GFP_KERNEL, audit_msgno);43audit_log_format(ab, "pid=%d uid=%u auid=%u ses=%u",44current->pid, current_cred()->uid,45audit_get_loginuid(current),46audit_get_sessionid(current));47audit_log_task_context(ab);48audit_log_format(ab, " op=");49audit_log_string(ab, op);50audit_log_format(ab, " cause=");51audit_log_string(ab, cause);52audit_log_format(ab, " comm=");53audit_log_untrustedstring(ab, current->comm);54if (fname) {55audit_log_format(ab, " name=");56audit_log_untrustedstring(ab, fname);57}58if (inode)59audit_log_format(ab, " dev=%s ino=%lu",60inode->i_sb->s_id, inode->i_ino);61audit_log_format(ab, " res=%d", !result ? 0 : 1);62audit_log_end(ab);63}646566