123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- /*
- This file is part of ethash.
- ethash is free software: you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation, either version 3 of the License, or
- (at your option) any later version.
- ethash 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 General Public License for more details.
- You should have received a copy of the GNU General Public License
- along with ethash. If not, see <http://www.gnu.org/licenses/>.
- */
- /** @file ethash.h
- * @date 2015
- */
- #pragma once
- #include <stdint.h>
- #include <stdbool.h>
- #include <string.h>
- #include <stddef.h>
- #include "compiler.h"
- #define ETHASH_REVISION 23
- #define ETHASH_DATASET_BYTES_INIT 1073741824U // 2**30
- #define ETHASH_DATASET_BYTES_GROWTH 8388608U // 2**23
- #define ETHASH_CACHE_BYTES_INIT 1073741824U // 2**24
- #define ETHASH_CACHE_BYTES_GROWTH 131072U // 2**17
- #define ETHASH_EPOCH_LENGTH 30000U
- #define ETHASH_MIX_BYTES 128
- #define ETHASH_HASH_BYTES 64
- #define ETHASH_DATASET_PARENTS 256
- #define ETHASH_CACHE_ROUNDS 3
- #define ETHASH_ACCESSES 64
- #define ETHASH_DAG_MAGIC_NUM_SIZE 8
- #define ETHASH_DAG_MAGIC_NUM 0xFEE1DEADBADDCAFE
- #ifdef __cplusplus
- extern "C" {
- #endif
- /// Type of a seedhash/blockhash e.t.c.
- typedef struct ethash_h256 { uint8_t b[32]; } ethash_h256_t;
- // convenience macro to statically initialize an h256_t
- // usage:
- // ethash_h256_t a = ethash_h256_static_init(1, 2, 3, ... )
- // have to provide all 32 values. If you don't provide all the rest
- // will simply be unitialized (not guranteed to be 0)
- #define ethash_h256_static_init(...) \
- { {__VA_ARGS__} }
- struct ethash_light;
- typedef struct ethash_light* ethash_light_t;
- struct ethash_full;
- typedef struct ethash_full* ethash_full_t;
- typedef int(*ethash_callback_t)(unsigned);
- typedef struct ethash_return_value {
- ethash_h256_t result;
- ethash_h256_t mix_hash;
- bool success;
- } ethash_return_value_t;
- /**
- * Allocate and initialize a new ethash_light handler
- *
- * @param block_number The block number for which to create the handler
- * @return Newly allocated ethash_light handler or NULL in case of
- * ERRNOMEM or invalid parameters used for @ref ethash_compute_cache_nodes()
- */
- ethash_light_t ethash_light_new(uint64_t block_number);
- /**
- * Frees a previously allocated ethash_light handler
- * @param light The light handler to free
- */
- void ethash_light_delete(ethash_light_t light);
- /**
- * Calculate the light client data
- *
- * @param light The light client handler
- * @param header_hash The header hash to pack into the mix
- * @param nonce The nonce to pack into the mix
- * @return an object of ethash_return_value_t holding the return values
- */
- ethash_return_value_t ethash_light_compute(
- ethash_light_t light,
- ethash_h256_t const header_hash,
- uint64_t nonce
- );
- /**
- * Allocate and initialize a new ethash_full handler
- *
- * @param light The light handler containing the cache.
- * @param callback A callback function with signature of @ref ethash_callback_t
- * It accepts an unsigned with which a progress of DAG calculation
- * can be displayed. If all goes well the callback should return 0.
- * If a non-zero value is returned then DAG generation will stop.
- * Be advised. A progress value of 100 means that DAG creation is
- * almost complete and that this function will soon return succesfully.
- * It does not mean that the function has already had a succesfull return.
- * @return Newly allocated ethash_full handler or NULL in case of
- * ERRNOMEM or invalid parameters used for @ref ethash_compute_full_data()
- */
- ethash_full_t ethash_full_new(ethash_light_t light, ethash_callback_t callback);
- /**
- * Frees a previously allocated ethash_full handler
- * @param full The light handler to free
- */
- void ethash_full_delete(ethash_full_t full);
- /**
- * Calculate the full client data
- *
- * @param full The full client handler
- * @param header_hash The header hash to pack into the mix
- * @param nonce The nonce to pack into the mix
- * @return An object of ethash_return_value to hold the return value
- */
- ethash_return_value_t ethash_full_compute(
- ethash_full_t full,
- ethash_h256_t const header_hash,
- uint64_t nonce
- );
- /**
- * Get a pointer to the full DAG data
- */
- void const* ethash_full_dag(ethash_full_t full);
- /**
- * Get the size of the DAG data
- */
- uint64_t ethash_full_dag_size(ethash_full_t full);
- /**
- * Calculate the seedhash for a given block number
- */
- ethash_h256_t ethash_get_seedhash(uint64_t block_number);
- #ifdef __cplusplus
- }
- #endif
|