mirror of
https://github.com/aaru-dps/Aaru.Checksums.Native.git
synced 2025-12-16 11:14:29 +00:00
Implement Fletcher-32 using SSSE3 instructions.
This commit is contained in:
11
fletcher32.c
11
fletcher32.c
@@ -55,6 +55,17 @@ AARU_EXPORT int AARU_CALL fletcher32_update(fletcher32_ctx* ctx, const uint8_t*
|
||||
}
|
||||
#endif
|
||||
|
||||
#if defined(__x86_64__) || defined(__amd64) || defined(_M_AMD64) || defined(_M_X64) || defined(__I386__) || \
|
||||
defined(__i386__) || defined(__THW_INTEL) || defined(_M_IX86)
|
||||
if(have_ssse3())
|
||||
{
|
||||
fletcher32_ssse3(&ctx->sum1, &ctx->sum2, data, len);
|
||||
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
uint32_t sum1 = ctx->sum1;
|
||||
uint32_t sum2 = ctx->sum2;
|
||||
unsigned n;
|
||||
|
||||
Reference in New Issue
Block a user