Newer
Older
minerva / Meta / Lagom / Fuzzers / FuzzPoly1305.cpp
@minerva minerva on 13 Jul 584 bytes Initial commit
/*
 * Copyright (c) 2022, stelar7 <dudedbz@gmail.com>
 *
 * SPDX-License-Identifier: BSD-2-Clause
 */

#include <AK/Format.h>
#include <LibCrypto/Authentication/Poly1305.h>
#include <stddef.h>
#include <stdint.h>

extern "C" int LLVMFuzzerTestOneInput(uint8_t const* data, size_t size)
{
    AK::set_debug_enabled(false);

    if (size < 32)
        return 0;

    auto initial = ReadonlyBytes { data, 32 };
    auto message = ReadonlyBytes { data + 32, size - 32 };

    Crypto::Authentication::Poly1305 mac(initial);
    mac.update(message);
    (void)mac.digest();
    return 0;
}