2015-12-02 23:48:25 +08:00
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// Copyright (C) 2015 piwi
|
|
|
|
//
|
|
|
|
// This code is licensed to you under the terms of the GNU GPL, version 2 or,
|
|
|
|
// at your option, any later version. See the LICENSE.txt file for the text of
|
|
|
|
// the license.
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
// hf mf hardnested command
|
|
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
2016-10-21 22:06:53 +08:00
|
|
|
#ifndef CMDHFMFHARD_H__
|
|
|
|
#define CMDHFMFHARD_H__
|
|
|
|
|
2019-08-08 22:57:33 +08:00
|
|
|
#include "common.h"
|
2017-07-28 02:58:59 +08:00
|
|
|
|
2019-03-10 06:35:06 +08:00
|
|
|
#define NUM_SUMS 19 // number of possible sum property values
|
2017-07-28 02:58:59 +08:00
|
|
|
|
|
|
|
typedef struct guess_sum_a8 {
|
2019-03-10 06:35:06 +08:00
|
|
|
float prob;
|
|
|
|
uint64_t num_states;
|
|
|
|
uint8_t sum_a8_idx;
|
2017-07-28 02:58:59 +08:00
|
|
|
} guess_sum_a8_t;
|
2016-10-21 22:06:53 +08:00
|
|
|
|
2017-07-28 02:58:59 +08:00
|
|
|
typedef struct noncelistentry {
|
2019-03-10 06:35:06 +08:00
|
|
|
uint32_t nonce_enc;
|
|
|
|
uint8_t par_enc;
|
|
|
|
void *next;
|
2017-07-28 02:58:59 +08:00
|
|
|
} noncelistentry_t;
|
|
|
|
|
|
|
|
typedef struct noncelist {
|
2019-03-10 06:35:06 +08:00
|
|
|
uint16_t num;
|
|
|
|
uint16_t Sum;
|
|
|
|
guess_sum_a8_t sum_a8_guess[NUM_SUMS];
|
|
|
|
bool sum_a8_guess_dirty;
|
|
|
|
float expected_num_brute_force;
|
|
|
|
uint8_t BitFlips[0x400];
|
|
|
|
uint32_t *states_bitarray[2];
|
|
|
|
uint32_t num_states_bitarray[2];
|
|
|
|
bool all_bitflips_dirty[2];
|
|
|
|
noncelistentry_t *first;
|
2017-07-28 02:58:59 +08:00
|
|
|
} noncelist_t;
|
|
|
|
|
2019-04-06 06:38:22 +08:00
|
|
|
int mfnestedhard(uint8_t blockNo, uint8_t keyType, uint8_t *key, uint8_t trgBlockNo, uint8_t trgKeyType, uint8_t *trgkey, bool nonce_file_read, bool nonce_file_write, bool slow, int tests, uint64_t *foundkey, char *filename);
|
2019-04-10 16:21:42 +08:00
|
|
|
void hardnested_print_progress(uint32_t nonces, const char *activity, float brute_force, uint64_t min_diff_print_time);
|
2016-10-21 22:06:53 +08:00
|
|
|
|
|
|
|
#endif
|
2017-07-28 02:58:59 +08:00
|
|
|
|