Finally, remove the ifdef's around i_readcount, making it a full inode citizen so that other subsystems, such as leases, could use it. Signed-off-by: Mimi Zohar <zohar@xxxxxxxxxx> --- fs/file_table.c | 11 +++++++++++ include/linux/fs.h | 13 ------------- security/integrity/ima/Makefile | 2 +- security/integrity/ima/ima_readcount.c | 25 ------------------------- 4 files changed, 12 insertions(+), 39 deletions(-) delete mode 100644 security/integrity/ima/ima_readcount.c diff --git a/fs/file_table.c b/fs/file_table.c index e575e78..a658adb 100644 --- a/fs/file_table.c +++ b/fs/file_table.c @@ -92,6 +92,17 @@ int proc_nr_files(ctl_table *table, int write, } #endif +void iput_readcount(struct inode *inode) +{ + spin_lock(&inode->i_lock); + if (unlikely((atomic_read(&inode->i_readcount) == 0))) + printk(KERN_INFO "i_readcount: imbalance ino %ld\n", + inode->i_ino); + else + atomic_dec(&inode->i_readcount); + spin_unlock(&inode->i_lock); +} + /* Find an unused file structure and return a pointer to it. * Returns NULL, if there are no more free file structures or * we run out of memory. diff --git a/include/linux/fs.h b/include/linux/fs.h index 7f5939d..9e296b3 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h @@ -786,10 +786,8 @@ struct inode { unsigned int i_flags; -#ifdef CONFIG_IMA /* protected by i_lock */ atomic_t i_readcount; /* struct files open RO */ -#endif atomic_t i_writecount; #ifdef CONFIG_SECURITY void *i_security; @@ -2178,22 +2176,11 @@ static inline void allow_write_access(struct file *file) if (file) atomic_inc(&file->f_path.dentry->d_inode->i_writecount); } -#ifdef CONFIG_IMA extern void iput_readcount(struct inode *inode); static inline void iget_readcount(struct inode *inode) { atomic_inc(&inode->i_readcount); } -#else -static inline void iput_readcount(struct inode *inode) -{ - return; -} -static inline void iget_readcount(struct inode *inode) -{ - return; -} -#endif extern int do_pipe_flags(int *, int); extern struct file *create_read_pipe(struct file *f, int flags); extern struct file *create_write_pipe(int flags); diff --git a/security/integrity/ima/Makefile b/security/integrity/ima/Makefile index 131eb1f..787c4cb 100644 --- a/security/integrity/ima/Makefile +++ b/security/integrity/ima/Makefile @@ -6,4 +6,4 @@ obj-$(CONFIG_IMA) += ima.o ima-y := ima_fs.o ima_queue.o ima_init.o ima_main.o ima_crypto.o ima_api.o \ - ima_policy.o ima_iint.o ima_audit.o ima_readcount.o + ima_policy.o ima_iint.o ima_audit.o diff --git a/security/integrity/ima/ima_readcount.c b/security/integrity/ima/ima_readcount.c deleted file mode 100644 index d139e2a9..0000000 --- a/security/integrity/ima/ima_readcount.c +++ /dev/null @@ -1,25 +0,0 @@ -/* - * Copyright (C) 2010 IBM Corporation - * - * Authors: - * Mimi Zohar <zohar@xxxxxxxxxx> - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation, version 2 of the - * License. - */ -#include <linux/module.h> -#include <linux/spinlock.h> -#include <linux/fs.h> - -void iput_readcount(struct inode *inode) -{ - spin_lock(&inode->i_lock); - if (unlikely((atomic_read(&inode->i_readcount) == 0))) - printk(KERN_INFO "i_readcount: imbalance ino %ld\n", - inode->i_ino); - else - atomic_dec(&inode->i_readcount); - spin_unlock(&inode->i_lock); -} -- 1.7.2.2 -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html