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>