1a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// Copyright 2015 The Chromium OS Authors. All rights reserved. 2a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// Use of this source code is governed by a BSD-style license that can be 3a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// found in the LICENSE file. 447c1919099ac4924be23e858a41b0c25af7a8ca5Vadim Bendebury 5a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// THIS CODE IS GENERATED - DO NOT MODIFY! 6a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr 7776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury#ifndef TPM2_HMAC_FP_H_ 8776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury#define TPM2_HMAC_FP_H_ 9a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr 10a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr#include "tpm_generated.h" 1147c1919099ac4924be23e858a41b0c25af7a8ca5Vadim Bendebury 1247c1919099ac4924be23e858a41b0c25af7a8ca5Vadim Bendeburytypedef struct { 13f788ffb5e5b4493cb4c1deaa12a97c80c2694b01Vadim Bendebury TPMI_DH_OBJECT handle; 14a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr TPM2B_MAX_BUFFER buffer; 15a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr TPMI_ALG_HASH hashAlg; 1647c1919099ac4924be23e858a41b0c25af7a8ca5Vadim Bendebury} HMAC_In; 1747c1919099ac4924be23e858a41b0c25af7a8ca5Vadim Bendebury 18a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohrtypedef struct { TPM2B_DIGEST outHMAC; } HMAC_Out; 19a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr 20a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// Executes HMAC with request handles and parameters from 21a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// |in| and computes response handles and parameters to |out|. 22a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn BohrTPM_RC TPM2_HMAC(HMAC_In* in, HMAC_Out* out); 23a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr 24776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury// Initializes handle fields in |target| from |request_handles|. Unmarshals 25a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// parameter fields in |target| from |buffer|. 26a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn BohrTPM_RC HMAC_In_Unmarshal(HMAC_In* target, 27776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury TPM_HANDLE request_handles[], 28a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr BYTE** buffer, 29a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr INT32* size); 30a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr 31a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// Marshals response handles and parameters from |source| to |buffer|. Computes 32a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// and marshals the size of the parameter area (parameter_size) if |tag| == 33a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// TPM_ST_SESSIONS. Returns size of (parameter area + handle area) in bytes. 34776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury// Return value does not include parameter_size field. 35a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn BohrUINT16 HMAC_Out_Marshal(HMAC_Out* source, 36a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr TPMI_ST_COMMAND_TAG tag, 37a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr BYTE** buffer, 38a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr INT32* size); 3947c1919099ac4924be23e858a41b0c25af7a8ca5Vadim Bendebury 40776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury// Unmarshals any request parameters starting at |request_parameter_buffer|. 41a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// Executes command. Marshals any response handles and parameters to the 42776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury// global response buffer and computes |*response_handle_buffer_size| and 43776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury// |*response_parameter_buffer_size|. If |tag| == TPM_ST_SESSIONS, marshals 44a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// parameter_size indicating the size of the parameter area. parameter_size 45a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr// field is located between the handle area and parameter area. 46a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn BohrTPM_RC Exec_HMAC(TPMI_ST_COMMAND_TAG tag, 47776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury BYTE** request_parameter_buffer, 48776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury INT32* request_parameter_buffer_size, 49776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury TPM_HANDLE request_handles[], 50776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury UINT32* response_handle_buffer_size, 51776e23689ddfb58cf6d6a111a3741a308e3fe60fVadim Bendebury UINT32* response_parameter_buffer_size); 5247c1919099ac4924be23e858a41b0c25af7a8ca5Vadim Bendebury 53a4ed3aa64664a1241ea982d685db744caaae3ffaJocelyn Bohr#endif // TPM2_HMAC_FP_H 54