Extract CryptoNote crypto sources from upstream (fa1608cf). Build as static libcryptonote.a via CMake with compat stubs for external dependencies (warnings, logging, varint, profiling). 37 upstream files, 10 compat stubs, 680KB static library. Co-Authored-By: Charon <charon@lethean.io>
43 lines
1.1 KiB
C
Executable file
43 lines
1.1 KiB
C
Executable file
// Copyright (c) 2014-2018 Zano Project
|
||
// Copyright (c) 2014-2018 The Louisdor Project
|
||
// Copyright (c) 2012-2013 The Boolberry developers
|
||
// Copyright (c) 2017-2025 Lethean (https://lt.hn)
|
||
//
|
||
// Licensed under the European Union Public Licence (EUPL) version 1.2.
|
||
// You may obtain a copy of the licence at:
|
||
//
|
||
// https://joinup.ec.europa.eu/software/page/eupl/licence-eupl
|
||
//
|
||
// The EUPL is a copyleft licence that is compatible with the MIT/X11
|
||
// licence used by the original projects; the MIT terms are therefore
|
||
// considered “grandfathered” under the EUPL for this code.
|
||
//
|
||
// SPDX‑License‑Identifier: EUPL-1.2
|
||
//
|
||
|
||
// keccak.h
|
||
// 19-Nov-11 Markku-Juhani O. Saarinen <mjos@iki.fi>
|
||
|
||
#ifndef KECCAK_H
|
||
#define KECCAK_H
|
||
|
||
#include <stdint.h>
|
||
#include <string.h>
|
||
|
||
#ifndef KECCAK_ROUNDS
|
||
#define KECCAK_ROUNDS 24
|
||
#endif
|
||
|
||
#ifndef ROTL64
|
||
#define ROTL64(x, y) (((x) << (y)) | ((x) >> (64 - (y))))
|
||
#endif
|
||
|
||
// compute a keccak hash (md) of given byte length from "in"
|
||
int keccak(const uint8_t *in, int inlen, uint8_t *md, int mdlen);
|
||
|
||
// update the state
|
||
void keccakf(uint64_t st[25], int norounds);
|
||
|
||
void keccak1600(const uint8_t *in, int inlen, uint8_t *md);
|
||
|
||
#endif
|