aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/namei.c2
-rw-r--r--fs/nfsd/vfs.c2
-rw-r--r--include/linux/ima.h4
-rw-r--r--security/integrity/ima/ima.h4
-rw-r--r--security/integrity/ima/ima_appraise.c4
-rw-r--r--security/integrity/ima/ima_main.c16
6 files changed, 16 insertions, 16 deletions
diff --git a/fs/namei.c b/fs/namei.c
index 985c6f368485..005771f97189 100644
--- a/fs/namei.c
+++ b/fs/namei.c
@@ -3058,7 +3058,7 @@ opened:
3058 error = open_check_o_direct(file); 3058 error = open_check_o_direct(file);
3059 if (error) 3059 if (error)
3060 goto exit_fput; 3060 goto exit_fput;
3061 error = ima_file_check(file, op->acc_mode); 3061 error = ima_file_check(file, op->acc_mode, *opened);
3062 if (error) 3062 if (error)
3063 goto exit_fput; 3063 goto exit_fput;
3064 3064
diff --git a/fs/nfsd/vfs.c b/fs/nfsd/vfs.c
index 140c496f612c..d49c778faecb 100644
--- a/fs/nfsd/vfs.c
+++ b/fs/nfsd/vfs.c
@@ -709,7 +709,7 @@ nfsd_open(struct svc_rqst *rqstp, struct svc_fh *fhp, umode_t type,
709 host_err = PTR_ERR(*filp); 709 host_err = PTR_ERR(*filp);
710 *filp = NULL; 710 *filp = NULL;
711 } else { 711 } else {
712 host_err = ima_file_check(*filp, may_flags); 712 host_err = ima_file_check(*filp, may_flags, 0);
713 713
714 if (may_flags & NFSD_MAY_64BIT_COOKIE) 714 if (may_flags & NFSD_MAY_64BIT_COOKIE)
715 (*filp)->f_mode |= FMODE_64BITHASH; 715 (*filp)->f_mode |= FMODE_64BITHASH;
diff --git a/include/linux/ima.h b/include/linux/ima.h
index 7cf5e9b32550..120ccc53fcb7 100644
--- a/include/linux/ima.h
+++ b/include/linux/ima.h
@@ -15,7 +15,7 @@ struct linux_binprm;
15 15
16#ifdef CONFIG_IMA 16#ifdef CONFIG_IMA
17extern int ima_bprm_check(struct linux_binprm *bprm); 17extern int ima_bprm_check(struct linux_binprm *bprm);
18extern int ima_file_check(struct file *file, int mask); 18extern int ima_file_check(struct file *file, int mask, int opened);
19extern void ima_file_free(struct file *file); 19extern void ima_file_free(struct file *file);
20extern int ima_file_mmap(struct file *file, unsigned long prot); 20extern int ima_file_mmap(struct file *file, unsigned long prot);
21extern int ima_module_check(struct file *file); 21extern int ima_module_check(struct file *file);
@@ -27,7 +27,7 @@ static inline int ima_bprm_check(struct linux_binprm *bprm)
27 return 0; 27 return 0;
28} 28}
29 29
30static inline int ima_file_check(struct file *file, int mask) 30static inline int ima_file_check(struct file *file, int mask, int opened)
31{ 31{
32 return 0; 32 return 0;
33} 33}
diff --git a/security/integrity/ima/ima.h b/security/integrity/ima/ima.h
index 57da4bd7ba0c..0fb456c20eda 100644
--- a/security/integrity/ima/ima.h
+++ b/security/integrity/ima/ima.h
@@ -177,7 +177,7 @@ void ima_delete_rules(void);
177int ima_appraise_measurement(int func, struct integrity_iint_cache *iint, 177int ima_appraise_measurement(int func, struct integrity_iint_cache *iint,
178 struct file *file, const unsigned char *filename, 178 struct file *file, const unsigned char *filename,
179 struct evm_ima_xattr_data *xattr_value, 179 struct evm_ima_xattr_data *xattr_value,
180 int xattr_len); 180 int xattr_len, int opened);
181int ima_must_appraise(struct inode *inode, int mask, enum ima_hooks func); 181int ima_must_appraise(struct inode *inode, int mask, enum ima_hooks func);
182void ima_update_xattr(struct integrity_iint_cache *iint, struct file *file); 182void ima_update_xattr(struct integrity_iint_cache *iint, struct file *file);
183enum integrity_status ima_get_cache_status(struct integrity_iint_cache *iint, 183enum integrity_status ima_get_cache_status(struct integrity_iint_cache *iint,
@@ -193,7 +193,7 @@ static inline int ima_appraise_measurement(int func,
193 struct file *file, 193 struct file *file,
194 const unsigned char *filename, 194 const unsigned char *filename,
195 struct evm_ima_xattr_data *xattr_value, 195 struct evm_ima_xattr_data *xattr_value,
196 int xattr_len) 196 int xattr_len, int opened)
197{ 197{
198 return INTEGRITY_UNKNOWN; 198 return INTEGRITY_UNKNOWN;
199} 199}
diff --git a/security/integrity/ima/ima_appraise.c b/security/integrity/ima/ima_appraise.c
index a4605d677248..225fd944a4ef 100644
--- a/security/integrity/ima/ima_appraise.c
+++ b/security/integrity/ima/ima_appraise.c
@@ -183,7 +183,7 @@ int ima_read_xattr(struct dentry *dentry,
183int ima_appraise_measurement(int func, struct integrity_iint_cache *iint, 183int ima_appraise_measurement(int func, struct integrity_iint_cache *iint,
184 struct file *file, const unsigned char *filename, 184 struct file *file, const unsigned char *filename,
185 struct evm_ima_xattr_data *xattr_value, 185 struct evm_ima_xattr_data *xattr_value,
186 int xattr_len) 186 int xattr_len, int opened)
187{ 187{
188 static const char op[] = "appraise_data"; 188 static const char op[] = "appraise_data";
189 char *cause = "unknown"; 189 char *cause = "unknown";
@@ -203,7 +203,7 @@ int ima_appraise_measurement(int func, struct integrity_iint_cache *iint,
203 203
204 cause = "missing-hash"; 204 cause = "missing-hash";
205 status = INTEGRITY_NOLABEL; 205 status = INTEGRITY_NOLABEL;
206 if (inode->i_size == 0) { 206 if (opened & FILE_CREATED) {
207 iint->flags |= IMA_NEW_FILE; 207 iint->flags |= IMA_NEW_FILE;
208 status = INTEGRITY_PASS; 208 status = INTEGRITY_PASS;
209 } 209 }
diff --git a/security/integrity/ima/ima_main.c b/security/integrity/ima/ima_main.c
index 0a2298f90c9c..f82cf9b8e92b 100644
--- a/security/integrity/ima/ima_main.c
+++ b/security/integrity/ima/ima_main.c
@@ -157,7 +157,7 @@ void ima_file_free(struct file *file)
157} 157}
158 158
159static int process_measurement(struct file *file, const char *filename, 159static int process_measurement(struct file *file, const char *filename,
160 int mask, int function) 160 int mask, int function, int opened)
161{ 161{
162 struct inode *inode = file_inode(file); 162 struct inode *inode = file_inode(file);
163 struct integrity_iint_cache *iint; 163 struct integrity_iint_cache *iint;
@@ -226,7 +226,7 @@ static int process_measurement(struct file *file, const char *filename,
226 xattr_value, xattr_len); 226 xattr_value, xattr_len);
227 if (action & IMA_APPRAISE_SUBMASK) 227 if (action & IMA_APPRAISE_SUBMASK)
228 rc = ima_appraise_measurement(_func, iint, file, pathname, 228 rc = ima_appraise_measurement(_func, iint, file, pathname,
229 xattr_value, xattr_len); 229 xattr_value, xattr_len, opened);
230 if (action & IMA_AUDIT) 230 if (action & IMA_AUDIT)
231 ima_audit_measurement(iint, pathname); 231 ima_audit_measurement(iint, pathname);
232 kfree(pathbuf); 232 kfree(pathbuf);
@@ -255,7 +255,7 @@ out:
255int ima_file_mmap(struct file *file, unsigned long prot) 255int ima_file_mmap(struct file *file, unsigned long prot)
256{ 256{
257 if (file && (prot & PROT_EXEC)) 257 if (file && (prot & PROT_EXEC))
258 return process_measurement(file, NULL, MAY_EXEC, MMAP_CHECK); 258 return process_measurement(file, NULL, MAY_EXEC, MMAP_CHECK, 0);
259 return 0; 259 return 0;
260} 260}
261 261
@@ -277,7 +277,7 @@ int ima_bprm_check(struct linux_binprm *bprm)
277 return process_measurement(bprm->file, 277 return process_measurement(bprm->file,
278 (strcmp(bprm->filename, bprm->interp) == 0) ? 278 (strcmp(bprm->filename, bprm->interp) == 0) ?
279 bprm->filename : bprm->interp, 279 bprm->filename : bprm->interp,
280 MAY_EXEC, BPRM_CHECK); 280 MAY_EXEC, BPRM_CHECK, 0);
281} 281}
282 282
283/** 283/**
@@ -290,12 +290,12 @@ int ima_bprm_check(struct linux_binprm *bprm)
290 * On success return 0. On integrity appraisal error, assuming the file 290 * On success return 0. On integrity appraisal error, assuming the file
291 * is in policy and IMA-appraisal is in enforcing mode, return -EACCES. 291 * is in policy and IMA-appraisal is in enforcing mode, return -EACCES.
292 */ 292 */
293int ima_file_check(struct file *file, int mask) 293int ima_file_check(struct file *file, int mask, int opened)
294{ 294{
295 ima_rdwr_violation_check(file); 295 ima_rdwr_violation_check(file);
296 return process_measurement(file, NULL, 296 return process_measurement(file, NULL,
297 mask & (MAY_READ | MAY_WRITE | MAY_EXEC), 297 mask & (MAY_READ | MAY_WRITE | MAY_EXEC),
298 FILE_CHECK); 298 FILE_CHECK, opened);
299} 299}
300EXPORT_SYMBOL_GPL(ima_file_check); 300EXPORT_SYMBOL_GPL(ima_file_check);
301 301
@@ -318,7 +318,7 @@ int ima_module_check(struct file *file)
318#endif 318#endif
319 return 0; /* We rely on module signature checking */ 319 return 0; /* We rely on module signature checking */
320 } 320 }
321 return process_measurement(file, NULL, MAY_EXEC, MODULE_CHECK); 321 return process_measurement(file, NULL, MAY_EXEC, MODULE_CHECK, 0);
322} 322}
323 323
324int ima_fw_from_file(struct file *file, char *buf, size_t size) 324int ima_fw_from_file(struct file *file, char *buf, size_t size)
@@ -329,7 +329,7 @@ int ima_fw_from_file(struct file *file, char *buf, size_t size)
329 return -EACCES; /* INTEGRITY_UNKNOWN */ 329 return -EACCES; /* INTEGRITY_UNKNOWN */
330 return 0; 330 return 0;
331 } 331 }
332 return process_measurement(file, NULL, MAY_EXEC, FIRMWARE_CHECK); 332 return process_measurement(file, NULL, MAY_EXEC, FIRMWARE_CHECK, 0);
333} 333}
334 334
335static int __init init_ima(void) 335static int __init init_ima(void)