Annotation of embedaddon/strongswan/src/libtpmtss/plugins/tpm/tpm_rng.c, revision 1.1
1.1 ! misho 1: /*
! 2: * Copyright (C) 2017 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: #include "tpm_rng.h"
! 17:
! 18: #include <tpm_tss.h>
! 19: #include <utils/debug.h>
! 20:
! 21: typedef struct private_tpm_rng_t private_tpm_rng_t;
! 22:
! 23: /**
! 24: * Private data of an tpm_rng_t object.
! 25: */
! 26: struct private_tpm_rng_t {
! 27:
! 28: /**
! 29: * Public interface.
! 30: */
! 31: tpm_rng_t public;
! 32:
! 33: /**
! 34: * Trusted Platform Module
! 35: */
! 36: tpm_tss_t *tpm;
! 37:
! 38: };
! 39:
! 40: METHOD(rng_t, get_bytes, bool,
! 41: private_tpm_rng_t *this, size_t bytes, uint8_t *buffer)
! 42: {
! 43: return this->tpm->get_random(this->tpm, bytes, buffer);
! 44: }
! 45:
! 46: METHOD(rng_t, allocate_bytes, bool,
! 47: private_tpm_rng_t *this, size_t bytes, chunk_t *chunk)
! 48: {
! 49: *chunk = chunk_alloc(bytes);
! 50: if (!get_bytes(this, chunk->len, chunk->ptr))
! 51: {
! 52: chunk_clear(chunk);
! 53: return FALSE;
! 54: }
! 55: return TRUE;
! 56: }
! 57:
! 58: METHOD(rng_t, destroy, void,
! 59: private_tpm_rng_t *this)
! 60: {
! 61: this->tpm->destroy(this->tpm);
! 62: free(this);
! 63: }
! 64:
! 65: /*
! 66: * Described in header.
! 67: */
! 68: tpm_rng_t *tpm_rng_create(rng_quality_t quality)
! 69: {
! 70: private_tpm_rng_t *this;
! 71: tpm_tss_t *tpm;
! 72:
! 73: /* try to find a TPM 2.0 */
! 74: tpm = tpm_tss_probe(TPM_VERSION_2_0);
! 75: if (!tpm)
! 76: {
! 77: DBG1(DBG_LIB, "no TPM 2.0 found");
! 78: return NULL;
! 79: }
! 80:
! 81: INIT(this,
! 82: .public = {
! 83: .rng = {
! 84: .get_bytes = _get_bytes,
! 85: .allocate_bytes = _allocate_bytes,
! 86: .destroy = _destroy,
! 87: },
! 88: },
! 89: .tpm = tpm,
! 90: );
! 91:
! 92: return &this->public;
! 93: }
! 94:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>