次のようなプログラムがあります。
EVP_PKEY *generate_RSA_key_and_uuid(unsigned char uuid[16])
{
EVP_PKEY *key_p;
key_p = EVP_PKEY_new();
return key_p;
}
int build_and_save_csr(int dn_entries, X509_REQ *req_p, EVP_PKEY *priv_key_p, char *passphrase)
{
priv_key_p = generate_RSA_key_and_uuid(uuid);
}
int makecsr(X509_REQ *req_p, EVP_PKEY *priv_key_p, char *passphrase)
{
if (build_and_save_csr(2, req_p, priv_key_p, passphrase) != 0) {
fprintf(stderr, "Could not create csr file / private key...\n");
exit(1);
}
return 0;
}
int main(int argc, char *argv[])
{
EVP_PKEY *priv_key_p;
X509_REQ *req_p;
makecsr(req_p, priv_key_p, passphrase);
return 0;
}
これが実行された後、*priv_key_p
から返された値が含まれている必要があります*generate_RSA_key_and_uuid
。
gdb では、最後に正しい値が含まれていることがわかりますが、実行後generate_RSA_and_uuid
は空です。key_p
priv_key_p = generate_RSA_key_and_uuid(uuid);
priv_key_p
ポインターに値を適切に割り当てる方法を知っている人はいますか?