Bunu değiştirip kullanabileceğim herhangi bir basit kaynak kodu var mı?
Intel RDRAND
motorunun anlaşılması oldukça kolaydır.
unsigned long err = 0;
int rc = 0;
OPENSSL_cpuid_setup();
ENGINE_load_rdrand();
ENGINE* eng = ENGINE_by_id("rdrand");
err = ERR_get_error();
if(NULL == eng) {
fprintf(stderr, "ENGINE_load_rdrand failed, err = 0x%lx\n", err);
abort(); /* failed */
}
rc = ENGINE_init(eng);
err = ERR_get_error();
if(0 == rc) {
fprintf(stderr, "ENGINE_init failed, err = 0x%lx\n", err);
abort(); /* failed */
}
rc = ENGINE_set_default(eng, ENGINE_METHOD_RAND);
err = ERR_get_error();
if(0 == rc) {
fprintf(stderr, "ENGINE_set_default failed, err = 0x%lx\n", err);
abort(); /* failed */
}
/* OK to proceed */
...
ENGINE_finish(eng);
ENGINE_free(eng);
Geç ama muhtemelen alakalı başkası için: [Gelişmekte yüklemek ve (Random Numbers|Hardware itibaren) varsayılan rasgele sayı üreteci motoru olarak ayarlayabilirsiniz nasıl
İşte: Sen onun kaynaklardan bulabilirsiniz OpenSSL için bir motor] (http://sinodun.com/2009/02/developing-an-engine-for-openssl/). – javex
Tüm arayanlar için, OpenSSL Wiki 'da eklenmiş Kaynaklar ile daha iyi bir örnek bulmak mümkün: https://wiki.openssl.org/index.php/Creating_an_OpenSSL_Engine_to_use_indigenous_ECDH_ECDSA_and_HASH_Algorithms iyi şanslar. – Jonas