/* * QEMU Crypto RSA key parser * * Copyright (c) 2022 Bytedance * Author: lei he * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, see . * */ #include "qemu/osdep.h" #include "der.h" #include "rsakey.h" void qcrypto_akcipher_rsakey_free(QCryptoAkCipherRSAKey *rsa_key) { if (!rsa_key) { return; } g_free(rsa_key->n.data); g_free(rsa_key->e.data); g_free(rsa_key->d.data); g_free(rsa_key->p.data); g_free(rsa_key->q.data); g_free(rsa_key->dp.data); g_free(rsa_key->dq.data); g_free(rsa_key->u.data); g_free(rsa_key); } /** * PKCS#8 private key info for RSA * * PrivateKeyInfo ::= SEQUENCE { * version INTEGER, * privateKeyAlgorithm PrivateKeyAlgorithmIdentifier, * privateKey OCTET STRING, * attributes [0] IMPLICIT Attributes OPTIONAL * } */ void qcrypto_akcipher_rsakey_export_p8info(const uint8_t *key, size_t keylen, uint8_t **dst, size_t *dlen) { QCryptoEncodeContext *ctx = qcrypto_der_encode_ctx_new(); uint8_t version = 0; qcrypto_der_encode_seq_begin(ctx); /* version */ qcrypto_der_encode_int(ctx, &version, sizeof(version)); /* algorithm identifier */ qcrypto_der_encode_seq_begin(ctx); qcrypto_der_encode_oid(ctx, (uint8_t *)QCRYPTO_OID_rsaEncryption, sizeof(QCRYPTO_OID_rsaEncryption) - 1); qcrypto_der_encode_null(ctx); qcrypto_der_encode_seq_end(ctx); /* RSA private key */ qcrypto_der_encode_octet_str(ctx, key, keylen); qcrypto_der_encode_seq_end(ctx); *dlen = qcrypto_der_encode_ctx_buffer_len(ctx); *dst = g_malloc(*dlen); qcrypto_der_encode_ctx_flush_and_free(ctx, *dst); } #if defined(CONFIG_NETTLE) && defined(CONFIG_HOGWEED) #include "rsakey-nettle.c.inc" #else #include "rsakey-builtin.c.inc" #endif