Tor 0.4.9.2-alpha-dev
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
solver.h
1/* Copyright (c) 2020 tevador <tevador@gmail.com> */
2/* See LICENSE for licensing information */
3
4#ifndef SOLVER_H
5#define SOLVER_H
6
7#include <equix.h>
8#include <hashx_endian.h>
9#include <stdbool.h>
10#include "context.h"
11
12#define EQUIX_STAGE1_MASK ((1ull << 15) - 1)
13#define EQUIX_STAGE2_MASK ((1ull << 30) - 1)
14#define EQUIX_FULL_MASK ((1ull << 60) - 1)
15
16static inline bool tree_cmp1(const equix_idx* left, const equix_idx* right) {
17 return *left <= *right;
18}
19
20static inline uint32_t tree_idx2(const equix_idx* idx) {
21 return
22 (uint32_t)idx[1] << 1*16 |
23 (uint32_t)idx[0] << 0*16;
24}
25
26static inline bool tree_cmp2(const equix_idx* left, const equix_idx* right) {
27 return tree_idx2(left) <= tree_idx2(right);
28}
29
30static inline uint64_t tree_idx4(const equix_idx* idx) {
31 return
32 (uint64_t)idx[3] << 3*16 |
33 (uint64_t)idx[2] << 2*16 |
34 (uint64_t)idx[1] << 1*16 |
35 (uint64_t)idx[0] << 0*16;
36}
37
38static inline bool tree_cmp4(const equix_idx* left, const equix_idx* right) {
39 return tree_idx4(left) <= tree_idx4(right);
40}
41
42EQUIX_PRIVATE int equix_solver_solve(hashx_ctx* hash_func, solver_heap* heap, equix_solution output[EQUIX_MAX_SOLS]);
43
44#endif