/* * This file is part of the Aaru Data Preservation Suite. * Copyright (c) 2019-2023 Natalia Portillo. * * This library is free software; you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of the * License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, see . */ #ifndef AARU_CHECKSUMS_NATIVE_FLETCHER32_H #define AARU_CHECKSUMS_NATIVE_FLETCHER32_H #define FLETCHER32_MODULE 0xFFFF /* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(ADLER_MODULE-1) <= 2^32-1 */ #define NMAX 5552 typedef struct { uint16_t sum1; uint16_t sum2; } fletcher32_ctx; AARU_EXPORT fletcher32_ctx* AARU_CALL fletcher32_init(); AARU_EXPORT int AARU_CALL fletcher32_update(fletcher32_ctx* ctx, const uint8_t* data, uint32_t len); AARU_EXPORT int AARU_CALL fletcher32_final(fletcher32_ctx* ctx, uint32_t* checksum); AARU_EXPORT void AARU_CALL fletcher32_free(fletcher32_ctx* ctx); #if defined(__aarch64__) || defined(_M_ARM64) || defined(__arm__) || defined(_M_ARM) AARU_EXPORT void AARU_CALL fletcher32_neon(uint16_t* sum1, uint16_t* sum2, const uint8_t* data, uint32_t len); #endif #endif // AARU_CHECKSUMS_NATIVE_FLETCHER32_H