2018-12-11 20:00:30 +00:00
|
|
|
/*
|
2019-05-18 12:21:47 +00:00
|
|
|
Copyright (c) 2018-2019, tevador <tevador@gmail.com>
|
|
|
|
|
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in the
|
|
|
|
documentation and/or other materials provided with the distribution.
|
|
|
|
* Neither the name of the copyright holder nor the
|
|
|
|
names of its contributors may be used to endorse or promote products
|
|
|
|
derived from this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
|
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
|
|
|
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
|
|
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
|
|
|
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
2018-12-11 20:00:30 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/* Original code from Argon2 reference source code package used under CC0 Licence
|
|
|
|
* https://github.com/P-H-C/phc-winner-argon2
|
|
|
|
* Copyright 2015
|
|
|
|
* Daniel Dinu, Dmitry Khovratovich, Jean-Philippe Aumasson, and Samuel Neves
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ARGON2_CORE_H
|
|
|
|
#define ARGON2_CORE_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "argon2.h"
|
|
|
|
|
|
|
|
#if defined(__cplusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define CONST_CAST(x) (x)(uintptr_t)
|
|
|
|
|
|
|
|
/**********************Argon2 internal constants*******************************/
|
|
|
|
|
|
|
|
enum argon2_core_constants {
|
|
|
|
/* Memory block size in bytes */
|
|
|
|
ARGON2_BLOCK_SIZE = 1024,
|
|
|
|
ARGON2_QWORDS_IN_BLOCK = ARGON2_BLOCK_SIZE / 8,
|
|
|
|
ARGON2_OWORDS_IN_BLOCK = ARGON2_BLOCK_SIZE / 16,
|
|
|
|
ARGON2_HWORDS_IN_BLOCK = ARGON2_BLOCK_SIZE / 32,
|
|
|
|
ARGON2_512BIT_WORDS_IN_BLOCK = ARGON2_BLOCK_SIZE / 64,
|
|
|
|
|
|
|
|
/* Number of pseudo-random values generated by one call to Blake in Argon2i
|
|
|
|
to
|
|
|
|
generate reference block positions */
|
|
|
|
ARGON2_ADDRESSES_IN_BLOCK = 128,
|
|
|
|
|
|
|
|
/* Pre-hashing digest length and its extension*/
|
|
|
|
ARGON2_PREHASH_DIGEST_LENGTH = 64,
|
|
|
|
ARGON2_PREHASH_SEED_LENGTH = 72
|
|
|
|
};
|
|
|
|
|
|
|
|
/*************************Argon2 internal data types***********************/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Structure for the (1KB) memory block implemented as 128 64-bit words.
|
|
|
|
* Memory blocks can be copied, XORed. Internal words can be accessed by [] (no
|
|
|
|
* bounds checking).
|
|
|
|
*/
|
|
|
|
typedef struct block_ { uint64_t v[ARGON2_QWORDS_IN_BLOCK]; } block;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Argon2 instance: memory pointer, number of passes, amount of memory, type,
|
|
|
|
* and derived values.
|
|
|
|
* Used to evaluate the number and location of blocks to construct in each
|
|
|
|
* thread
|
|
|
|
*/
|
|
|
|
typedef struct Argon2_instance_t {
|
|
|
|
block *memory; /* Memory pointer */
|
|
|
|
uint32_t version;
|
|
|
|
uint32_t passes; /* Number of passes */
|
|
|
|
uint32_t memory_blocks; /* Number of blocks in memory */
|
|
|
|
uint32_t segment_length;
|
|
|
|
uint32_t lane_length;
|
|
|
|
uint32_t lanes;
|
|
|
|
uint32_t threads;
|
|
|
|
argon2_type type;
|
|
|
|
int print_internals; /* whether to print the memory blocks */
|
|
|
|
argon2_context *context_ptr; /* points back to original context */
|
2019-10-05 22:43:01 +00:00
|
|
|
randomx_argon2_impl *impl;
|
2018-12-11 20:00:30 +00:00
|
|
|
} argon2_instance_t;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Argon2 position: where we construct the block right now. Used to distribute
|
|
|
|
* work between threads.
|
|
|
|
*/
|
|
|
|
typedef struct Argon2_position_t {
|
|
|
|
uint32_t pass;
|
|
|
|
uint32_t lane;
|
|
|
|
uint8_t slice;
|
|
|
|
uint32_t index;
|
|
|
|
} argon2_position_t;
|
|
|
|
|
|
|
|
/*Struct that holds the inputs for thread handling FillSegment*/
|
|
|
|
typedef struct Argon2_thread_data {
|
|
|
|
argon2_instance_t *instance_ptr;
|
|
|
|
argon2_position_t pos;
|
|
|
|
} argon2_thread_data;
|
|
|
|
|
|
|
|
/*************************Argon2 core functions********************************/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Computes absolute position of reference block in the lane following a skewed
|
|
|
|
* distribution and using a pseudo-random value as input
|
|
|
|
* @param instance Pointer to the current instance
|
|
|
|
* @param position Pointer to the current position
|
|
|
|
* @param pseudo_rand 32-bit pseudo-random value used to determine the position
|
|
|
|
* @param same_lane Indicates if the block will be taken from the current lane.
|
|
|
|
* If so we can reference the current segment
|
|
|
|
* @pre All pointers must be valid
|
|
|
|
*/
|
2019-10-05 22:43:01 +00:00
|
|
|
uint32_t randomx_argon2_index_alpha(const argon2_instance_t *instance,
|
2018-12-11 20:00:30 +00:00
|
|
|
const argon2_position_t *position, uint32_t pseudo_rand,
|
|
|
|
int same_lane);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Function that validates all inputs against predefined restrictions and return
|
|
|
|
* an error code
|
|
|
|
* @param context Pointer to current Argon2 context
|
|
|
|
* @return ARGON2_OK if everything is all right, otherwise one of error codes
|
|
|
|
* (all defined in <argon2.h>
|
|
|
|
*/
|
2019-10-05 22:43:01 +00:00
|
|
|
int randomx_argon2_validate_inputs(const argon2_context *context);
|
2018-12-11 20:00:30 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Function allocates memory, hashes the inputs with Blake, and creates first
|
|
|
|
* two blocks. Returns the pointer to the main memory with 2 blocks per lane
|
|
|
|
* initialized
|
|
|
|
* @param context Pointer to the Argon2 internal structure containing memory
|
|
|
|
* pointer, and parameters for time and space requirements.
|
|
|
|
* @param instance Current Argon2 instance
|
|
|
|
* @return Zero if successful, -1 if memory failed to allocate. @context->state
|
|
|
|
* will be modified if successful.
|
|
|
|
*/
|
2019-10-05 22:43:01 +00:00
|
|
|
int randomx_argon2_initialize(argon2_instance_t *instance, argon2_context *context);
|
2018-12-11 20:00:30 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Function that fills the entire memory t_cost times based on the first two
|
|
|
|
* blocks in each lane
|
|
|
|
* @param instance Pointer to the current instance
|
|
|
|
* @return ARGON2_OK if successful, @context->state
|
|
|
|
*/
|
2019-10-05 22:43:01 +00:00
|
|
|
int randomx_argon2_fill_memory_blocks(argon2_instance_t* instance);
|
2018-12-11 20:00:30 +00:00
|
|
|
|
|
|
|
#if defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|