Annotation of embedaddon/strongswan/src/libimcv/pts/pts_pcr.h, revision 1.1
1.1 ! misho 1: /*
! 2: * Copyright (C) 2012-2016 Andreas Steffen
! 3: * HSR Hochschule fuer Technik Rapperswil
! 4: *
! 5: * This program is free software; you can redistribute it and/or modify it
! 6: * under the terms of the GNU General Public License as published by the
! 7: * Free Software Foundation; either version 2 of the License, or (at your
! 8: * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
! 9: *
! 10: * This program is distributed in the hope that it will be useful, but
! 11: * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
! 12: * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
! 13: * for more details.
! 14: */
! 15:
! 16: /**
! 17: * @defgroup pts_pcr pts_pcr
! 18: * @{ @ingroup pts
! 19: */
! 20:
! 21: #ifndef PTS_PCR_H_
! 22: #define PTS_PCR_H_
! 23:
! 24: typedef struct pts_pcr_t pts_pcr_t;
! 25:
! 26: #include <library.h>
! 27:
! 28: #include <tpm_tss_quote_info.h>
! 29:
! 30: /**
! 31: * Maximum number of PCR's of TPM, TPM Spec 1.2
! 32: */
! 33: #define PTS_PCR_MAX_NUM 24
! 34:
! 35: /**
! 36: * Number of bytes that can be saved in a PCR of TPM, TPM Spec 1.2
! 37: */
! 38: #define PTS_PCR_LEN 20
! 39:
! 40: /**
! 41: * Class implementing a shadow PCR register set
! 42: */
! 43: struct pts_pcr_t {
! 44:
! 45: /**
! 46: * Get the number of selected PCRs
! 47: *
! 48: * @return number of selected PCRs
! 49: */
! 50: uint32_t (*get_count)(pts_pcr_t *this);
! 51:
! 52: /**
! 53: * Mark a PCR as selected
! 54: *
! 55: * @param pcr index of PCR
! 56: * @return TRUE if PCR index exists
! 57: */
! 58: bool (*select_pcr)(pts_pcr_t *this, uint32_t pcr);
! 59:
! 60: /**
! 61: * Get the size of the selection field in bytes
! 62: *
! 63: * @return number of bytes written
! 64: */
! 65: size_t (*get_selection_size)(pts_pcr_t *this);
! 66:
! 67: /**
! 68: * Create an enumerator over all selected PCR indexes
! 69: *
! 70: * @return enumerator
! 71: */
! 72: enumerator_t* (*create_enumerator)(pts_pcr_t *this);
! 73:
! 74: /**
! 75: * Get the current content of a PCR
! 76: *
! 77: * @param pcr index of PCR
! 78: * @return content of PCR
! 79: */
! 80: chunk_t (*get)(pts_pcr_t *this, uint32_t pcr);
! 81:
! 82: /**
! 83: * Set the content of a PCR
! 84: *
! 85: * @param pcr index of PCR
! 86: * @param value new value of PCR
! 87: * @return TRUE if value could be set
! 88: */
! 89: bool (*set)(pts_pcr_t *this, uint32_t pcr, chunk_t value);
! 90:
! 91: /**
! 92: * Extend the content of a PCR
! 93: *
! 94: * @param pcr index of PCR
! 95: * @param measurement measurement value to be extended into PCR
! 96: * @return new content of PCR
! 97: */
! 98: chunk_t (*extend)(pts_pcr_t *this, uint32_t pcr, chunk_t measurement);
! 99:
! 100: /**
! 101: * Create a PCR Composite object over all selected PCRs
! 102: *
! 103: * @return PCR Composite object (must be freed)
! 104: */
! 105: tpm_tss_pcr_composite_t* (*get_composite)(pts_pcr_t *this);
! 106:
! 107: /**
! 108:
! 109: * Destroys a pts_pcr_t object.
! 110: */
! 111: void (*destroy)(pts_pcr_t *this);
! 112:
! 113: };
! 114:
! 115: /**
! 116: * Creates an pts_pcr_t object
! 117: */
! 118: pts_pcr_t* pts_pcr_create(void);
! 119:
! 120: #endif /** PTS_PCR_H_ @}*/
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>