C++程序  |  71行  |  2.23 KB

// This file was extracted from the TCG Published
// Trusted Platform Module Library
// Part 3: Commands
// Family "2.0"
// Level 00 Revision 01.16
// October 30, 2014

#include "InternalRoutines.h"
#include "SetCommandCodeAuditStatus_fp.h"
TPM_RC
TPM2_SetCommandCodeAuditStatus(
   SetCommandCodeAuditStatus_In      *in             // IN: input parameter list
   )
{
   TPM_RC          result;
   UINT32          i;
   BOOL            changed = FALSE;

   // The command needs NV update. Check if NV is available.
   // A TPM_RC_NV_UNAVAILABLE or TPM_RC_NV_RATE error may be returned at
   // this point
   result = NvIsAvailable();
   if(result != TPM_RC_SUCCESS)
       return result;

// Internal Data Update

   // Update hash algorithm
   if(   in->auditAlg != TPM_ALG_NULL
      && in->auditAlg != gp.auditHashAlg)
   {
       // Can't change the algorithm and command list at the same time
       if(in->setList.count != 0 || in->clearList.count != 0)
           return TPM_RC_VALUE + RC_SetCommandCodeAuditStatus_auditAlg;

       // Change the hash algorithm for audit
       gp.auditHashAlg = in->auditAlg;

       // Set the digest size to a unique value that indicates that the digest
       // algorithm has been changed. The size will be cleared to zero in the
       // command audit processing on exit.
       gr.commandAuditDigest.t.size = 1;

       // Save the change of command audit data (this sets g_updateNV so that NV
       // will be updated on exit.)
       NvWriteReserved(NV_AUDIT_HASH_ALG, &gp.auditHashAlg);

   } else {

       // Process set list
       for(i = 0; i < in->setList.count; i++)

            // If change is made in CommandAuditSet, set changed flag
            if(CommandAuditSet(in->setList.commandCodes[i]))
                changed = TRUE;

       // Process clear list
       for(i = 0; i < in->clearList.count; i++)
           // If change is made in CommandAuditClear, set changed flag
           if(CommandAuditClear(in->clearList.commandCodes[i]))
               changed = TRUE;

       // if change was made to command list, update NV
       if(changed)
           // this sets g_updateNV so that NV will be updated on exit.
           NvWriteReserved(NV_AUDIT_COMMANDS, &gp.auditComands);
   }

   return TPM_RC_SUCCESS;
}