Use ed25519_init() for faster failures
This commit is contained in:
committed by
Greg Fitzgerald
parent
8c08e614b7
commit
5d28729b2a
@ -22,6 +22,8 @@ struct Elems {
|
|||||||
#[cfg(feature = "cuda")]
|
#[cfg(feature = "cuda")]
|
||||||
#[link(name = "cuda_verify_ed25519")]
|
#[link(name = "cuda_verify_ed25519")]
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
fn ed25519_init() -> bool;
|
||||||
|
fn ed25519_set_verbose(val: bool);
|
||||||
fn ed25519_verify_many(
|
fn ed25519_verify_many(
|
||||||
vecs: *const Elems,
|
vecs: *const Elems,
|
||||||
num: u32, //number of vecs
|
num: u32, //number of vecs
|
||||||
@ -34,6 +36,11 @@ extern "C" {
|
|||||||
) -> u32;
|
) -> u32;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(not(feature = "cuda"))]
|
||||||
|
pub fn init() {
|
||||||
|
// stub
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(not(feature = "cuda"))]
|
#[cfg(not(feature = "cuda"))]
|
||||||
fn verify_packet(packet: &Packet) -> u8 {
|
fn verify_packet(packet: &Packet) -> u8 {
|
||||||
use ring::signature;
|
use ring::signature;
|
||||||
@ -88,6 +95,17 @@ pub fn ed25519_verify(batches: &Vec<SharedPackets>) -> Vec<Vec<u8>> {
|
|||||||
rv
|
rv
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "cuda")]
|
||||||
|
pub fn init() {
|
||||||
|
unsafe {
|
||||||
|
ed25519_set_verbose(true);
|
||||||
|
if !ed25519_init() {
|
||||||
|
panic!("ed25519_init() failed");
|
||||||
|
}
|
||||||
|
ed25519_set_verbose(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(feature = "cuda")]
|
#[cfg(feature = "cuda")]
|
||||||
pub fn ed25519_verify(batches: &Vec<SharedPackets>) -> Vec<Vec<u8>> {
|
pub fn ed25519_verify(batches: &Vec<SharedPackets>) -> Vec<Vec<u8>> {
|
||||||
use packet::PACKET_DATA_SIZE;
|
use packet::PACKET_DATA_SIZE;
|
||||||
|
@ -25,6 +25,7 @@ pub struct SigVerifyStage {
|
|||||||
|
|
||||||
impl SigVerifyStage {
|
impl SigVerifyStage {
|
||||||
pub fn new(packet_receiver: Receiver<SharedPackets>) -> (Self, Receiver<VerifiedPackets>) {
|
pub fn new(packet_receiver: Receiver<SharedPackets>) -> (Self, Receiver<VerifiedPackets>) {
|
||||||
|
sigverify::init();
|
||||||
let (verified_sender, verified_receiver) = channel();
|
let (verified_sender, verified_receiver) = channel();
|
||||||
let thread_hdls = Self::verifier_services(packet_receiver, verified_sender);
|
let thread_hdls = Self::verifier_services(packet_receiver, verified_sender);
|
||||||
(SigVerifyStage { thread_hdls }, verified_receiver)
|
(SigVerifyStage { thread_hdls }, verified_receiver)
|
||||||
|
Reference in New Issue
Block a user