X-Git-Url: https://git.distorted.org.uk/~mdw/catacomb/blobdiff_plain/a4c2e267f29d601a9d68ecfedc66852379e429ae..e10e6494b18a62339497db09d9712cd5df555714:/symm/salsa20.c diff --git a/symm/salsa20.c b/symm/salsa20.c index 0104e5e5..d3fb69a7 100644 --- a/symm/salsa20.c +++ b/symm/salsa20.c @@ -7,11 +7,14 @@ /*----- Header files ------------------------------------------------------*/ +#include "config.h" + #include #include #include "arena.h" +#include "dispatch.h" #include "gcipher.h" #include "grand.h" #include "keysz.h" @@ -39,9 +42,28 @@ const octet salsa20_keysz[] = { KSZ_SET, 32, 16, 10, 0 }; * the feedforward step. */ -static void core(unsigned r, const salsa20_matrix src, salsa20_matrix dest) +CPU_DISPATCH(static, (void), + void, core, (unsigned r, const salsa20_matrix src, + salsa20_matrix dest), + (r, src, dest), + pick_core, simple_core); + +static void simple_core(unsigned r, const salsa20_matrix src, + salsa20_matrix dest) { SALSA20_nR(dest, src, r); SALSA20_FFWD(dest, src); } +#ifdef CPUFAM_X86 +extern core__functype salsa20_core_x86_sse2; +#endif + +static core__functype *pick_core(void) +{ +#ifdef CPUFAM_X86 + if (cpu_feature_p(CPUFEAT_X86_SSE2)) return salsa20_core_x86_sse2; +#endif + return simple_core; +} + /* --- @populate@ --- * * * Arguments: @salsa20_matrix a@ = a matrix to fill in