> > @@ -228,9 +229,28 @@ static int process_measurement(struct file *file, char 
> > *buf, loff_t size,
> >                              IMA_APPRAISE_SUBMASK | IMA_APPRAISED_SUBMASK |
> >                              IMA_ACTION_FLAGS);
> >  
> > -   if (test_and_clear_bit(IMA_CHANGE_XATTR, &iint->atomic_flags))
> > -           /* reset all flags if ima_inode_setxattr was called */
> > +   /*
> > +    * Reset the measure, appraise and audit cached flags either if:
> > +    * - ima_inode_setxattr was called, or
> > +    * - based on filesystem feature flag
> > +    * forcing the file to be re-evaluated.
> > +    */
> > +   if (test_and_clear_bit(IMA_CHANGE_XATTR, &iint->atomic_flags)) {
> >             iint->flags &= ~IMA_DONE_MASK;
> > +   } else if (inode->i_sb->s_type->fs_flags & FS_IMA_NO_CACHE) {
> > +           if (action & IMA_MEASURE) {
> > +                   iint->measured_pcrs = 0;
> > +                   iint->flags &=
> > +                       ~(IMA_COLLECTED | IMA_MEASURE | IMA_MEASURED);
> > +           }
> > +           if (action & IMA_APPRAISE)
> > +                   iint->flags &=
> > +                       ~(IMA_COLLECTED | IMA_APPRAISE | IMA_APPRAISED |
> > +                         IMA_APPRAISE_SUBMASK | IMA_APPRAISED_SUBMASK);
> > +           if (action & IMA_AUDIT)
> > +                   iint->flags &=
> > +                       ~(IMA_COLLECTED | IMA_AUDIT | IMA_AUDITED);
> > +   }
> > 

Alban, I don't know what I was thinking, but this can be simplified
like for the IMA_CHANGE_XATTR case.  Except in the IMA_CHANGE_XATTR
case, "measured_pcrs" was already reset, whereas in this case
"measured_pcrs" needs to be reset.

Mimi

Reply via email to