Annotation of embedaddon/strongswan/src/libtpmtss/plugins/tpm/tpm_cert.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_cert.h"
! 17:
! 18: #include <tpm_tss.h>
! 19:
! 20: #include <utils/debug.h>
! 21:
! 22:
! 23: /**
! 24: * See header.
! 25: */
! 26: certificate_t *tpm_cert_load(certificate_type_t type, va_list args)
! 27: {
! 28: tpm_tss_t *tpm;
! 29: chunk_t keyid = chunk_empty, pin = chunk_empty, data = chunk_empty;
! 30: certificate_t *cert;
! 31: char handle_str[4];
! 32: size_t len;
! 33: uint32_t hierarchy = 0x40000001; /* TPM_RH_OWNER */
! 34: uint32_t handle;
! 35: bool success;
! 36:
! 37: while (TRUE)
! 38: {
! 39: switch (va_arg(args, builder_part_t))
! 40: {
! 41: case BUILD_PKCS11_KEYID:
! 42: keyid = va_arg(args, chunk_t);
! 43: continue;
! 44: case BUILD_PKCS11_SLOT:
! 45: hierarchy = va_arg(args, int);
! 46: continue;
! 47: case BUILD_PKCS11_MODULE:
! 48: va_arg(args, char*);
! 49: continue;
! 50: case BUILD_END:
! 51: break;
! 52: default:
! 53: return NULL;
! 54: }
! 55: break;
! 56: }
! 57:
! 58: /* convert keyid into 32 bit TPM key object handle */
! 59: if (!keyid.len)
! 60: {
! 61: return NULL;
! 62: }
! 63: len = min(keyid.len, 4);
! 64: memset(handle_str, 0x00, 4);
! 65: memcpy(handle_str + 4 - len, keyid.ptr + keyid.len - len, len);
! 66: handle = untoh32(handle_str);
! 67:
! 68: /* try to find a TPM 2.0 */
! 69: tpm = tpm_tss_probe(TPM_VERSION_2_0);
! 70: if (!tpm)
! 71: {
! 72: DBG1(DBG_LIB, "no TPM 2.0 found");
! 73: return NULL;
! 74: }
! 75: success = tpm->get_data(tpm, hierarchy, handle, pin, &data);
! 76: tpm->destroy(tpm);
! 77:
! 78: if (!success)
! 79: {
! 80: DBG1(DBG_LIB, "loading certificate from TPM NV index 0x%08x failed",
! 81: handle);
! 82: return NULL;
! 83: }
! 84: cert = lib->creds->create(lib->creds, CRED_CERTIFICATE, CERT_X509,
! 85: BUILD_BLOB_ASN1_DER, data, BUILD_END);
! 86: free(data.ptr);
! 87:
! 88: if (!cert)
! 89: {
! 90: DBG1(DBG_LIB, "parsing certificate from TPM NV index 0x%08x failed",
! 91: handle);
! 92: return NULL;
! 93: }
! 94: DBG1(DBG_LIB, "loaded certificate from TPM NV index 0x%08x", handle);
! 95:
! 96: return cert;
! 97: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>