On Wed, 2013-01-30 at 16:53 -0500, Vivek Goyal wrote: > On Tue, Jan 22, 2013 at 05:07:31PM -0500, Mimi Zohar wrote: > > [..] > > /* iint cache flags */ > > +#define IMA_ACTION_FLAGS 0xff00 > > #define IMA_DIGSIG 0x0100 > > +#define IMA_DIGSIG_REQUIRED 0x0200 > > Hi Mimi, > > IMA_DIGSIG_REQUIRED state does not really have to be stored in iint I guess. > This is needed only if we go on to appraise and then we want to make > sure digital signatures are present. Once appraisal is done, IMG_DIGSIG > will be set and saved in iint->flags but looks like we don't require > IMA_DIGSIG_REQUIRED to be saved. > > If yes, will it make sense to not save it in iint. There are still 8 > bits left unused. We can mark these 8 bits for temporary flags like > IMA_DIGSIG_REQUIRED. If that works, I can use same space for defining > additional temporary flags like IMA_DIGSIG_SIGNED_ONLY to handle the > case of appraise_type=imasig,signed_only. That flag also does not have > to be persistent in iint.
Interesting idea. My only concern would be that we're not leaving room for additional hooks (eg. firmware). thanks, Mimi > Here is a quick patch compile tested only. > > Thanks > Vivek > > --- > security/integrity/ima/ima.h | 5 +++-- > security/integrity/ima/ima_appraise.c | 5 +++-- > security/integrity/ima/ima_main.c | 8 ++++++-- > security/integrity/ima/ima_policy.c | 2 +- > security/integrity/integrity.h | 5 ++++- > 5 files changed, 17 insertions(+), 8 deletions(-) > > Index: linux-integrity/security/integrity/integrity.h > =================================================================== > --- linux-integrity.orig/security/integrity/integrity.h 2013-01-30 > 16:22:04.000000000 -0500 > +++ linux-integrity/security/integrity/integrity.h 2013-01-30 > 16:25:03.736892034 -0500 > @@ -28,7 +28,10 @@ > /* iint cache flags */ > #define IMA_ACTION_FLAGS 0xff000000 > #define IMA_DIGSIG 0x01000000 > -#define IMA_DIGSIG_REQUIRED 0x02000000 > + > +/* Temp flags not stored in iint */ > +#define IMA_TEMP_FLAGS 0x00ff0000 > +#define IMA_DIGSIG_REQUIRED 0x00010000 > > #define IMA_DO_MASK (IMA_MEASURE | IMA_APPRAISE | IMA_AUDIT | \ > IMA_APPRAISE_SUBMASK) > Index: linux-integrity/security/integrity/ima/ima_main.c > =================================================================== > --- linux-integrity.orig/security/integrity/ima/ima_main.c 2013-01-29 > 17:13:05.000000000 -0500 > +++ linux-integrity/security/integrity/ima/ima_main.c 2013-01-30 > 16:39:09.414918012 -0500 > @@ -146,7 +146,7 @@ static int process_measurement(struct fi > struct integrity_iint_cache *iint; > char *pathbuf = NULL; > const char *pathname = NULL; > - int rc = -ENOMEM, action, must_appraise, _func; > + int rc = -ENOMEM, action, must_appraise, _func, temp_flags; > > if (!ima_initialized || !S_ISREG(inode->i_mode)) > return 0; > @@ -174,6 +174,9 @@ static int process_measurement(struct fi > * (IMA_MEASURE, IMA_MEASURED, IMA_XXXX_APPRAISE, IMA_XXXX_APPRAISED, > * IMA_AUDIT, IMA_AUDITED) > */ > + /* Temp flags don't have to be stored in iint */ > + temp_flags = action & IMA_TEMP_FLAGS; > + action &= ~IMA_TEMP_FLAGS; > iint->flags |= action; > action &= IMA_DO_MASK; > action &= ~((iint->flags & IMA_DONE_MASK) >> 1); > @@ -198,7 +201,8 @@ static int process_measurement(struct fi > if (action & IMA_MEASURE) > ima_store_measurement(iint, file, pathname); > if (action & IMA_APPRAISE_SUBMASK) > - rc = ima_appraise_measurement(_func, iint, file, pathname); > + rc = ima_appraise_measurement(_func, iint, file, pathname, > + temp_flags); > if (action & IMA_AUDIT) > ima_audit_measurement(iint, pathname); > kfree(pathbuf); > Index: linux-integrity/security/integrity/ima/ima_appraise.c > =================================================================== > --- linux-integrity.orig/security/integrity/ima/ima_appraise.c > 2013-01-30 16:22:04.000000000 -0500 > +++ linux-integrity/security/integrity/ima/ima_appraise.c 2013-01-30 > 16:37:11.667914395 -0500 > @@ -116,7 +116,8 @@ static void ima_cache_flags(struct integ > * Return 0 on success, error code otherwise > */ > int ima_appraise_measurement(int func, struct integrity_iint_cache *iint, > - struct file *file, const unsigned char *filename) > + struct file *file, const unsigned char *filename, > + int flags) > { > struct dentry *dentry = file->f_dentry; > struct inode *inode = dentry->d_inode; > @@ -154,7 +155,7 @@ int ima_appraise_measurement(int func, s > } > switch (xattr_value->type) { > case IMA_XATTR_DIGEST: > - if (iint->flags & IMA_DIGSIG_REQUIRED) { > + if (flags & IMA_DIGSIG_REQUIRED) { > cause = "IMA signature required"; > status = INTEGRITY_FAIL; > break; > Index: linux-integrity/security/integrity/ima/ima.h > =================================================================== > --- linux-integrity.orig/security/integrity/ima/ima.h 2013-01-30 > 10:46:32.000000000 -0500 > +++ linux-integrity/security/integrity/ima/ima.h 2013-01-30 > 16:38:40.800917133 -0500 > @@ -143,7 +143,7 @@ void ima_delete_rules(void); > > #ifdef CONFIG_IMA_APPRAISE > int ima_appraise_measurement(int func, struct integrity_iint_cache *iint, > - struct file *file, const unsigned char *filename); > + struct file *file, const unsigned char *filename, int flags); > int ima_must_appraise(struct inode *inode, int mask, enum ima_hooks func); > void ima_update_xattr(struct integrity_iint_cache *iint, struct file *file); > enum integrity_status ima_get_cache_status(struct integrity_iint_cache *iint, > @@ -153,7 +153,8 @@ enum integrity_status ima_get_cache_stat > static inline int ima_appraise_measurement(int func, > struct integrity_iint_cache *iint, > struct file *file, > - const unsigned char *filename) > + const unsigned char *filename, > + int flags) > { > return INTEGRITY_UNKNOWN; > } > Index: linux-integrity/security/integrity/ima/ima_policy.c > =================================================================== > --- linux-integrity.orig/security/integrity/ima/ima_policy.c 2013-01-30 > 16:41:39.000000000 -0500 > +++ linux-integrity/security/integrity/ima/ima_policy.c 2013-01-30 > 16:41:56.151923133 -0500 > @@ -267,7 +267,7 @@ int ima_match_policy(struct inode *inode > if (!ima_match_rules(entry, inode, func, mask)) > continue; > > - action |= entry->flags & IMA_ACTION_FLAGS; > + action |= entry->flags & IMA_TEMP_FLAGS; > > action |= entry->action & IMA_DO_MASK; > if (entry->action & IMA_APPRAISE) > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/