mirror of
https://github.com/comit-network/xmr-btc-swap.git
synced 2025-01-21 21:01:15 -05:00
hash_to_p3 builds using cmake but fails to link with cc-rs
This commit is contained in:
parent
a93396d9a6
commit
00648d2747
@ -8,4 +8,7 @@ include_directories(monero-adaptor/depend/hash)
|
|||||||
add_library(xmr_btc_swap_comit
|
add_library(xmr_btc_swap_comit
|
||||||
monero-adaptor/depend/hash/hash.c
|
monero-adaptor/depend/hash/hash.c
|
||||||
monero-adaptor/depend/hash/hash.h
|
monero-adaptor/depend/hash/hash.h
|
||||||
monero-adaptor/depend/hash/int-util.h)
|
monero-adaptor/depend/hash/int-util.h
|
||||||
|
monero-adaptor/depend/hash/crypto-ops.c
|
||||||
|
monero-adaptor/depend/hash/crypto-ops.h
|
||||||
|
monero-adaptor/depend/hash/warnings.h)
|
||||||
|
@ -10,6 +10,7 @@ fn main() {
|
|||||||
let mut base_config = cc::Build::new();
|
let mut base_config = cc::Build::new();
|
||||||
base_config.include("depend/hash");
|
base_config.include("depend/hash");
|
||||||
base_config.file("depend/hash/hash.c");
|
base_config.file("depend/hash/hash.c");
|
||||||
|
base_config.file("depend/hash/crypto-ops.c");
|
||||||
base_config.compile("hash");
|
base_config.compile("hash");
|
||||||
|
|
||||||
println!("cargo:rustc-link-lib=static=hash");
|
println!("cargo:rustc-link-lib=static=hash");
|
||||||
|
4734
monero-adaptor/depend/hash/crypto-ops.c
Normal file
4734
monero-adaptor/depend/hash/crypto-ops.c
Normal file
File diff suppressed because it is too large
Load Diff
199
monero-adaptor/depend/hash/crypto-ops.h
Normal file
199
monero-adaptor/depend/hash/crypto-ops.h
Normal file
@ -0,0 +1,199 @@
|
|||||||
|
// Copyright (c) 2014-2020, The Monero Project
|
||||||
|
//
|
||||||
|
// All rights reserved.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without modification, are
|
||||||
|
// permitted provided that the following conditions are met:
|
||||||
|
//
|
||||||
|
// 1. Redistributions of source code must retain the above copyright notice, this list of
|
||||||
|
// conditions and the following disclaimer.
|
||||||
|
//
|
||||||
|
// 2. 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.
|
||||||
|
//
|
||||||
|
// 3. 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.
|
||||||
|
//
|
||||||
|
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
/* From fe.h */
|
||||||
|
|
||||||
|
typedef int32_t fe[10];
|
||||||
|
|
||||||
|
/* From ge.h */
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
fe X;
|
||||||
|
fe Y;
|
||||||
|
fe Z;
|
||||||
|
} ge_p2;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
fe X;
|
||||||
|
fe Y;
|
||||||
|
fe Z;
|
||||||
|
fe T;
|
||||||
|
} ge_p3;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
fe X;
|
||||||
|
fe Y;
|
||||||
|
fe Z;
|
||||||
|
fe T;
|
||||||
|
} ge_p1p1;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
fe yplusx;
|
||||||
|
fe yminusx;
|
||||||
|
fe xy2d;
|
||||||
|
} ge_precomp;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
fe YplusX;
|
||||||
|
fe YminusX;
|
||||||
|
fe Z;
|
||||||
|
fe T2d;
|
||||||
|
} ge_cached;
|
||||||
|
|
||||||
|
/* From ge_add.c */
|
||||||
|
|
||||||
|
void ge_add(ge_p1p1 *, const ge_p3 *, const ge_cached *);
|
||||||
|
|
||||||
|
/* From ge_double_scalarmult.c, modified */
|
||||||
|
|
||||||
|
typedef ge_cached ge_dsmp[8];
|
||||||
|
extern const ge_precomp ge_Bi[8];
|
||||||
|
|
||||||
|
void ge_dsm_precomp(ge_dsmp r, const ge_p3 *s);
|
||||||
|
|
||||||
|
void ge_double_scalarmult_base_vartime(ge_p2 *, const unsigned char *, const ge_p3 *, const unsigned char *);
|
||||||
|
|
||||||
|
void ge_triple_scalarmult_base_vartime(ge_p2 *, const unsigned char *, const unsigned char *, const ge_dsmp,
|
||||||
|
const unsigned char *, const ge_dsmp);
|
||||||
|
|
||||||
|
void ge_double_scalarmult_base_vartime_p3(ge_p3 *, const unsigned char *, const ge_p3 *, const unsigned char *);
|
||||||
|
|
||||||
|
/* From ge_frombytes.c, modified */
|
||||||
|
|
||||||
|
extern const fe fe_sqrtm1;
|
||||||
|
extern const fe fe_d;
|
||||||
|
|
||||||
|
int ge_frombytes_vartime(ge_p3 *, const unsigned char *);
|
||||||
|
|
||||||
|
/* From ge_p1p1_to_p2.c */
|
||||||
|
|
||||||
|
void ge_p1p1_to_p2(ge_p2 *, const ge_p1p1 *);
|
||||||
|
|
||||||
|
/* From ge_p1p1_to_p3.c */
|
||||||
|
|
||||||
|
void ge_p1p1_to_p3(ge_p3 *, const ge_p1p1 *);
|
||||||
|
|
||||||
|
/* From ge_p2_dbl.c */
|
||||||
|
|
||||||
|
void ge_p2_dbl(ge_p1p1 *, const ge_p2 *);
|
||||||
|
|
||||||
|
/* From ge_p3_to_cached.c */
|
||||||
|
|
||||||
|
extern const fe fe_d2;
|
||||||
|
|
||||||
|
void ge_p3_to_cached(ge_cached *, const ge_p3 *);
|
||||||
|
|
||||||
|
/* From ge_p3_to_p2.c */
|
||||||
|
|
||||||
|
void ge_p3_to_p2(ge_p2 *, const ge_p3 *);
|
||||||
|
|
||||||
|
/* From ge_p3_tobytes.c */
|
||||||
|
|
||||||
|
void ge_p3_tobytes(unsigned char *, const ge_p3 *);
|
||||||
|
|
||||||
|
/* From ge_scalarmult_base.c */
|
||||||
|
|
||||||
|
extern const ge_precomp ge_base[32][8];
|
||||||
|
|
||||||
|
void ge_scalarmult_base(ge_p3 *, const unsigned char *);
|
||||||
|
|
||||||
|
/* From ge_tobytes.c */
|
||||||
|
|
||||||
|
void ge_tobytes(unsigned char *, const ge_p2 *);
|
||||||
|
|
||||||
|
/* From sc_reduce.c */
|
||||||
|
|
||||||
|
void sc_reduce(unsigned char *);
|
||||||
|
|
||||||
|
/* New code */
|
||||||
|
|
||||||
|
void ge_scalarmult(ge_p2 *, const unsigned char *, const ge_p3 *);
|
||||||
|
|
||||||
|
void ge_scalarmult_p3(ge_p3 *, const unsigned char *, const ge_p3 *);
|
||||||
|
|
||||||
|
void ge_double_scalarmult_precomp_vartime(ge_p2 *, const unsigned char *, const ge_p3 *, const unsigned char *,
|
||||||
|
const ge_dsmp);
|
||||||
|
|
||||||
|
void ge_triple_scalarmult_precomp_vartime(ge_p2 *, const unsigned char *, const ge_dsmp, const unsigned char *,
|
||||||
|
const ge_dsmp, const unsigned char *, const ge_dsmp);
|
||||||
|
|
||||||
|
void ge_double_scalarmult_precomp_vartime2(ge_p2 *, const unsigned char *, const ge_dsmp, const unsigned char *,
|
||||||
|
const ge_dsmp);
|
||||||
|
|
||||||
|
void ge_double_scalarmult_precomp_vartime2_p3(ge_p3 *, const unsigned char *, const ge_dsmp, const unsigned char *,
|
||||||
|
const ge_dsmp);
|
||||||
|
|
||||||
|
void ge_mul8(ge_p1p1 *, const ge_p2 *);
|
||||||
|
|
||||||
|
extern const fe fe_ma2;
|
||||||
|
extern const fe fe_ma;
|
||||||
|
extern const fe fe_fffb1;
|
||||||
|
extern const fe fe_fffb2;
|
||||||
|
extern const fe fe_fffb3;
|
||||||
|
extern const fe fe_fffb4;
|
||||||
|
extern const ge_p3 ge_p3_identity;
|
||||||
|
extern const ge_p3 ge_p3_H;
|
||||||
|
|
||||||
|
void ge_fromfe_frombytes_vartime(ge_p2 *, const unsigned char *);
|
||||||
|
|
||||||
|
void sc_0(unsigned char *);
|
||||||
|
|
||||||
|
void sc_reduce32(unsigned char *);
|
||||||
|
|
||||||
|
void sc_add(unsigned char *, const unsigned char *, const unsigned char *);
|
||||||
|
|
||||||
|
void sc_sub(unsigned char *, const unsigned char *, const unsigned char *);
|
||||||
|
|
||||||
|
void sc_mulsub(unsigned char *, const unsigned char *, const unsigned char *, const unsigned char *);
|
||||||
|
|
||||||
|
void sc_mul(unsigned char *, const unsigned char *, const unsigned char *);
|
||||||
|
|
||||||
|
void sc_muladd(unsigned char *s, const unsigned char *a, const unsigned char *b, const unsigned char *c);
|
||||||
|
|
||||||
|
int sc_check(const unsigned char *);
|
||||||
|
|
||||||
|
int sc_isnonzero(const unsigned char *); /* Doesn't normalize */
|
||||||
|
|
||||||
|
// internal
|
||||||
|
uint64_t load_3(const unsigned char *in);
|
||||||
|
|
||||||
|
uint64_t load_4(const unsigned char *in);
|
||||||
|
|
||||||
|
void ge_sub(ge_p1p1 *r, const ge_p3 *p, const ge_cached *q);
|
||||||
|
|
||||||
|
void fe_add(fe h, const fe f, const fe g);
|
||||||
|
|
||||||
|
void fe_tobytes(unsigned char *, const fe);
|
||||||
|
|
||||||
|
void fe_invert(fe out, const fe z);
|
||||||
|
|
||||||
|
int ge_p3_is_point_at_infinity(const ge_p3 *p);
|
@ -5,6 +5,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include "int-util.h"
|
#include "int-util.h"
|
||||||
|
#include "crypto-ops.h"
|
||||||
|
|
||||||
#ifndef ROTL64
|
#ifndef ROTL64
|
||||||
#define ROTL64(x, y) (((x) << (y)) | ((x) >> (64 - (y))))
|
#define ROTL64(x, y) (((x) << (y)) | ((x) >> (64 - (y))))
|
||||||
@ -19,15 +20,25 @@ static void local_abort(const char *msg) {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
typedef uint64_t state_t[25];
|
typedef uint64_t state_t[25];
|
||||||
|
|
||||||
|
|
||||||
void hash_to_scalar(const uint8_t *in, size_t inlen, uint8_t *md, int mdlen) {
|
void hash_to_scalar(const uint8_t *in, size_t inlen, uint8_t *md, int mdlen) {
|
||||||
keccak(in, inlen, md, mdlen);
|
keccak(in, inlen, md, mdlen);
|
||||||
sc_reduce32(md);
|
sc_reduce32(md);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Hash a key to p3 representation
|
||||||
|
void hash_to_p3(ge_p3 *hash8_p3, const uint8_t *in, size_t inlen) {
|
||||||
|
uint8_t md[32];
|
||||||
|
keccak(in, 32, md, inlen);
|
||||||
|
ge_p2 hash_p2;
|
||||||
|
|
||||||
|
ge_fromfe_frombytes_vartime(&hash_p2, in);
|
||||||
|
ge_p1p1 hash8_p1p1;
|
||||||
|
ge_mul8(&hash8_p1p1, &hash_p2);
|
||||||
|
ge_p1p1_to_p3(hash8_p3, &hash8_p1p1);
|
||||||
|
}
|
||||||
|
|
||||||
const uint64_t keccakf_rndc[24] =
|
const uint64_t keccakf_rndc[24] =
|
||||||
{
|
{
|
||||||
0x0000000000000001, 0x0000000000008082, 0x800000000000808a,
|
0x0000000000000001, 0x0000000000008082, 0x800000000000808a,
|
||||||
@ -164,108 +175,178 @@ void sc_reduce32(unsigned char *s) {
|
|||||||
int64_t s5 = 2097151 & (load_3(s + 13) >> 1);
|
int64_t s5 = 2097151 & (load_3(s + 13) >> 1);
|
||||||
int64_t s6 = 2097151 & (load_4(s + 15) >> 6);
|
int64_t s6 = 2097151 & (load_4(s + 15) >> 6);
|
||||||
int64_t s7 = 2097151 & (load_3(s + 18) >> 3);
|
int64_t s7 = 2097151 & (load_3(s + 18) >> 3);
|
||||||
int64_t s8 = 2097151 & load_3(s + 21);
|
int64_t s8 = 2097151 & load_3(s + 21);
|
||||||
int64_t s9 = 2097151 & (load_4(s + 23) >> 5);
|
int64_t s9 = 2097151 & (load_4(s + 23) >> 5);
|
||||||
int64_t s10 = 2097151 & (load_3(s + 26) >> 2);
|
int64_t s10 = 2097151 & (load_3(s + 26) >> 2);
|
||||||
int64_t s11 = (load_4(s + 28) >> 7);
|
int64_t s11 = (load_4(s + 28) >> 7);
|
||||||
int64_t s12 = 0;
|
int64_t s12 = 0;
|
||||||
int64_t carry0;
|
int64_t carry0;
|
||||||
int64_t carry1;
|
int64_t carry1;
|
||||||
int64_t carry2;
|
int64_t carry2;
|
||||||
int64_t carry3;
|
int64_t carry3;
|
||||||
int64_t carry4;
|
int64_t carry4;
|
||||||
int64_t carry5;
|
int64_t carry5;
|
||||||
int64_t carry6;
|
int64_t carry6;
|
||||||
int64_t carry7;
|
int64_t carry7;
|
||||||
int64_t carry8;
|
int64_t carry8;
|
||||||
int64_t carry9;
|
int64_t carry9;
|
||||||
int64_t carry10;
|
int64_t carry10;
|
||||||
int64_t carry11;
|
int64_t carry11;
|
||||||
|
|
||||||
carry0 = (s0 + (1<<20)) >> 21; s1 += carry0; s0 -= carry0 << 21;
|
carry0 = (s0 + (1 << 20)) >> 21;
|
||||||
carry2 = (s2 + (1<<20)) >> 21; s3 += carry2; s2 -= carry2 << 21;
|
s1 += carry0;
|
||||||
carry4 = (s4 + (1<<20)) >> 21; s5 += carry4; s4 -= carry4 << 21;
|
s0 -= carry0 << 21;
|
||||||
carry6 = (s6 + (1<<20)) >> 21; s7 += carry6; s6 -= carry6 << 21;
|
carry2 = (s2 + (1 << 20)) >> 21;
|
||||||
carry8 = (s8 + (1<<20)) >> 21; s9 += carry8; s8 -= carry8 << 21;
|
s3 += carry2;
|
||||||
carry10 = (s10 + (1<<20)) >> 21; s11 += carry10; s10 -= carry10 << 21;
|
s2 -= carry2 << 21;
|
||||||
|
carry4 = (s4 + (1 << 20)) >> 21;
|
||||||
|
s5 += carry4;
|
||||||
|
s4 -= carry4 << 21;
|
||||||
|
carry6 = (s6 + (1 << 20)) >> 21;
|
||||||
|
s7 += carry6;
|
||||||
|
s6 -= carry6 << 21;
|
||||||
|
carry8 = (s8 + (1 << 20)) >> 21;
|
||||||
|
s9 += carry8;
|
||||||
|
s8 -= carry8 << 21;
|
||||||
|
carry10 = (s10 + (1 << 20)) >> 21;
|
||||||
|
s11 += carry10;
|
||||||
|
s10 -= carry10 << 21;
|
||||||
|
|
||||||
carry1 = (s1 + (1<<20)) >> 21; s2 += carry1; s1 -= carry1 << 21;
|
carry1 = (s1 + (1 << 20)) >> 21;
|
||||||
carry3 = (s3 + (1<<20)) >> 21; s4 += carry3; s3 -= carry3 << 21;
|
s2 += carry1;
|
||||||
carry5 = (s5 + (1<<20)) >> 21; s6 += carry5; s5 -= carry5 << 21;
|
s1 -= carry1 << 21;
|
||||||
carry7 = (s7 + (1<<20)) >> 21; s8 += carry7; s7 -= carry7 << 21;
|
carry3 = (s3 + (1 << 20)) >> 21;
|
||||||
carry9 = (s9 + (1<<20)) >> 21; s10 += carry9; s9 -= carry9 << 21;
|
s4 += carry3;
|
||||||
carry11 = (s11 + (1<<20)) >> 21; s12 += carry11; s11 -= carry11 << 21;
|
s3 -= carry3 << 21;
|
||||||
|
carry5 = (s5 + (1 << 20)) >> 21;
|
||||||
|
s6 += carry5;
|
||||||
|
s5 -= carry5 << 21;
|
||||||
|
carry7 = (s7 + (1 << 20)) >> 21;
|
||||||
|
s8 += carry7;
|
||||||
|
s7 -= carry7 << 21;
|
||||||
|
carry9 = (s9 + (1 << 20)) >> 21;
|
||||||
|
s10 += carry9;
|
||||||
|
s9 -= carry9 << 21;
|
||||||
|
carry11 = (s11 + (1 << 20)) >> 21;
|
||||||
|
s12 += carry11;
|
||||||
|
s11 -= carry11 << 21;
|
||||||
|
|
||||||
s0 += s12 * 666643;
|
s0 += s12 * 666643;
|
||||||
s1 += s12 * 470296;
|
s1 += s12 * 470296;
|
||||||
s2 += s12 * 654183;
|
s2 += s12 * 654183;
|
||||||
s3 -= s12 * 997805;
|
s3 -= s12 * 997805;
|
||||||
s4 += s12 * 136657;
|
s4 += s12 * 136657;
|
||||||
s5 -= s12 * 683901;
|
s5 -= s12 * 683901;
|
||||||
s12 = 0;
|
s12 = 0;
|
||||||
|
|
||||||
carry0 = s0 >> 21; s1 += carry0; s0 -= carry0 << 21;
|
carry0 = s0 >> 21;
|
||||||
carry1 = s1 >> 21; s2 += carry1; s1 -= carry1 << 21;
|
s1 += carry0;
|
||||||
carry2 = s2 >> 21; s3 += carry2; s2 -= carry2 << 21;
|
s0 -= carry0 << 21;
|
||||||
carry3 = s3 >> 21; s4 += carry3; s3 -= carry3 << 21;
|
carry1 = s1 >> 21;
|
||||||
carry4 = s4 >> 21; s5 += carry4; s4 -= carry4 << 21;
|
s2 += carry1;
|
||||||
carry5 = s5 >> 21; s6 += carry5; s5 -= carry5 << 21;
|
s1 -= carry1 << 21;
|
||||||
carry6 = s6 >> 21; s7 += carry6; s6 -= carry6 << 21;
|
carry2 = s2 >> 21;
|
||||||
carry7 = s7 >> 21; s8 += carry7; s7 -= carry7 << 21;
|
s3 += carry2;
|
||||||
carry8 = s8 >> 21; s9 += carry8; s8 -= carry8 << 21;
|
s2 -= carry2 << 21;
|
||||||
carry9 = s9 >> 21; s10 += carry9; s9 -= carry9 << 21;
|
carry3 = s3 >> 21;
|
||||||
carry10 = s10 >> 21; s11 += carry10; s10 -= carry10 << 21;
|
s4 += carry3;
|
||||||
carry11 = s11 >> 21; s12 += carry11; s11 -= carry11 << 21;
|
s3 -= carry3 << 21;
|
||||||
|
carry4 = s4 >> 21;
|
||||||
|
s5 += carry4;
|
||||||
|
s4 -= carry4 << 21;
|
||||||
|
carry5 = s5 >> 21;
|
||||||
|
s6 += carry5;
|
||||||
|
s5 -= carry5 << 21;
|
||||||
|
carry6 = s6 >> 21;
|
||||||
|
s7 += carry6;
|
||||||
|
s6 -= carry6 << 21;
|
||||||
|
carry7 = s7 >> 21;
|
||||||
|
s8 += carry7;
|
||||||
|
s7 -= carry7 << 21;
|
||||||
|
carry8 = s8 >> 21;
|
||||||
|
s9 += carry8;
|
||||||
|
s8 -= carry8 << 21;
|
||||||
|
carry9 = s9 >> 21;
|
||||||
|
s10 += carry9;
|
||||||
|
s9 -= carry9 << 21;
|
||||||
|
carry10 = s10 >> 21;
|
||||||
|
s11 += carry10;
|
||||||
|
s10 -= carry10 << 21;
|
||||||
|
carry11 = s11 >> 21;
|
||||||
|
s12 += carry11;
|
||||||
|
s11 -= carry11 << 21;
|
||||||
|
|
||||||
s0 += s12 * 666643;
|
s0 += s12 * 666643;
|
||||||
s1 += s12 * 470296;
|
s1 += s12 * 470296;
|
||||||
s2 += s12 * 654183;
|
s2 += s12 * 654183;
|
||||||
s3 -= s12 * 997805;
|
s3 -= s12 * 997805;
|
||||||
s4 += s12 * 136657;
|
s4 += s12 * 136657;
|
||||||
s5 -= s12 * 683901;
|
s5 -= s12 * 683901;
|
||||||
|
|
||||||
carry0 = s0 >> 21; s1 += carry0; s0 -= carry0 << 21;
|
carry0 = s0 >> 21;
|
||||||
carry1 = s1 >> 21; s2 += carry1; s1 -= carry1 << 21;
|
s1 += carry0;
|
||||||
carry2 = s2 >> 21; s3 += carry2; s2 -= carry2 << 21;
|
s0 -= carry0 << 21;
|
||||||
carry3 = s3 >> 21; s4 += carry3; s3 -= carry3 << 21;
|
carry1 = s1 >> 21;
|
||||||
carry4 = s4 >> 21; s5 += carry4; s4 -= carry4 << 21;
|
s2 += carry1;
|
||||||
carry5 = s5 >> 21; s6 += carry5; s5 -= carry5 << 21;
|
s1 -= carry1 << 21;
|
||||||
carry6 = s6 >> 21; s7 += carry6; s6 -= carry6 << 21;
|
carry2 = s2 >> 21;
|
||||||
carry7 = s7 >> 21; s8 += carry7; s7 -= carry7 << 21;
|
s3 += carry2;
|
||||||
carry8 = s8 >> 21; s9 += carry8; s8 -= carry8 << 21;
|
s2 -= carry2 << 21;
|
||||||
carry9 = s9 >> 21; s10 += carry9; s9 -= carry9 << 21;
|
carry3 = s3 >> 21;
|
||||||
carry10 = s10 >> 21; s11 += carry10; s10 -= carry10 << 21;
|
s4 += carry3;
|
||||||
|
s3 -= carry3 << 21;
|
||||||
|
carry4 = s4 >> 21;
|
||||||
|
s5 += carry4;
|
||||||
|
s4 -= carry4 << 21;
|
||||||
|
carry5 = s5 >> 21;
|
||||||
|
s6 += carry5;
|
||||||
|
s5 -= carry5 << 21;
|
||||||
|
carry6 = s6 >> 21;
|
||||||
|
s7 += carry6;
|
||||||
|
s6 -= carry6 << 21;
|
||||||
|
carry7 = s7 >> 21;
|
||||||
|
s8 += carry7;
|
||||||
|
s7 -= carry7 << 21;
|
||||||
|
carry8 = s8 >> 21;
|
||||||
|
s9 += carry8;
|
||||||
|
s8 -= carry8 << 21;
|
||||||
|
carry9 = s9 >> 21;
|
||||||
|
s10 += carry9;
|
||||||
|
s9 -= carry9 << 21;
|
||||||
|
carry10 = s10 >> 21;
|
||||||
|
s11 += carry10;
|
||||||
|
s10 -= carry10 << 21;
|
||||||
|
|
||||||
s[0] = s0 >> 0;
|
s[0] = s0 >> 0;
|
||||||
s[1] = s0 >> 8;
|
s[1] = s0 >> 8;
|
||||||
s[2] = (s0 >> 16) | (s1 << 5);
|
s[2] = (s0 >> 16) | (s1 << 5);
|
||||||
s[3] = s1 >> 3;
|
s[3] = s1 >> 3;
|
||||||
s[4] = s1 >> 11;
|
s[4] = s1 >> 11;
|
||||||
s[5] = (s1 >> 19) | (s2 << 2);
|
s[5] = (s1 >> 19) | (s2 << 2);
|
||||||
s[6] = s2 >> 6;
|
s[6] = s2 >> 6;
|
||||||
s[7] = (s2 >> 14) | (s3 << 7);
|
s[7] = (s2 >> 14) | (s3 << 7);
|
||||||
s[8] = s3 >> 1;
|
s[8] = s3 >> 1;
|
||||||
s[9] = s3 >> 9;
|
s[9] = s3 >> 9;
|
||||||
s[10] = (s3 >> 17) | (s4 << 4);
|
s[10] = (s3 >> 17) | (s4 << 4);
|
||||||
s[11] = s4 >> 4;
|
s[11] = s4 >> 4;
|
||||||
s[12] = s4 >> 12;
|
s[12] = s4 >> 12;
|
||||||
s[13] = (s4 >> 20) | (s5 << 1);
|
s[13] = (s4 >> 20) | (s5 << 1);
|
||||||
s[14] = s5 >> 7;
|
s[14] = s5 >> 7;
|
||||||
s[15] = (s5 >> 15) | (s6 << 6);
|
s[15] = (s5 >> 15) | (s6 << 6);
|
||||||
s[16] = s6 >> 2;
|
s[16] = s6 >> 2;
|
||||||
s[17] = s6 >> 10;
|
s[17] = s6 >> 10;
|
||||||
s[18] = (s6 >> 18) | (s7 << 3);
|
s[18] = (s6 >> 18) | (s7 << 3);
|
||||||
s[19] = s7 >> 5;
|
s[19] = s7 >> 5;
|
||||||
s[20] = s7 >> 13;
|
s[20] = s7 >> 13;
|
||||||
s[21] = s8 >> 0;
|
s[21] = s8 >> 0;
|
||||||
s[22] = s8 >> 8;
|
s[22] = s8 >> 8;
|
||||||
s[23] = (s8 >> 16) | (s9 << 5);
|
s[23] = (s8 >> 16) | (s9 << 5);
|
||||||
s[24] = s9 >> 3;
|
s[24] = s9 >> 3;
|
||||||
s[25] = s9 >> 11;
|
s[25] = s9 >> 11;
|
||||||
s[26] = (s9 >> 19) | (s10 << 2);
|
s[26] = (s9 >> 19) | (s10 << 2);
|
||||||
s[27] = s10 >> 6;
|
s[27] = s10 >> 6;
|
||||||
s[28] = (s10 >> 14) | (s11 << 7);
|
s[28] = (s10 >> 14) | (s11 << 7);
|
||||||
s[29] = s11 >> 1;
|
s[29] = s11 >> 1;
|
||||||
s[30] = s11 >> 9;
|
s[30] = s11 >> 9;
|
||||||
s[31] = s11 >> 17;
|
s[31] = s11 >> 17;
|
||||||
}
|
}
|
||||||
|
30
monero-adaptor/depend/hash/warnings.h
Normal file
30
monero-adaptor/depend/hash/warnings.h
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#if defined(_MSC_VER)
|
||||||
|
|
||||||
|
#define PUSH_WARNINGS __pragma(warning(push))
|
||||||
|
#define POP_WARNINGS __pragma(warning(pop))
|
||||||
|
#define DISABLE_VS_WARNINGS(w) __pragma(warning(disable: w))
|
||||||
|
#define DISABLE_GCC_WARNING(w)
|
||||||
|
#define DISABLE_CLANG_WARNING(w)
|
||||||
|
#define DISABLE_GCC_AND_CLANG_WARNING(w)
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
//#include <boost/preprocessor/stringize.hpp>
|
||||||
|
|
||||||
|
#define PUSH_WARNINGS _Pragma("GCC diagnostic push")
|
||||||
|
#define POP_WARNINGS _Pragma("GCC diagnostic pop")
|
||||||
|
#define DISABLE_VS_WARNINGS(w)
|
||||||
|
|
||||||
|
#if defined(__clang__)
|
||||||
|
#define DISABLE_GCC_WARNING(w)
|
||||||
|
#define DISABLE_CLANG_WARNING DISABLE_GCC_AND_CLANG_WARNING
|
||||||
|
#else
|
||||||
|
#define DISABLE_GCC_WARNING DISABLE_GCC_AND_CLANG_WARNING
|
||||||
|
#define DISABLE_CLANG_WARNING(w)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//#define DISABLE_GCC_AND_CLANG_WARNING(w) _Pragma(BOOST_PP_STRINGIZE(GCC diagnostic ignored BOOST_PP_STRINGIZE(-W##w)))
|
||||||
|
|
||||||
|
#endif
|
@ -5,7 +5,8 @@
|
|||||||
// include!(concat!(env!("OUT_DIR"), "/bindings.rs"));
|
// include!(concat!(env!("OUT_DIR"), "/bindings.rs"));
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
fn hash_to_scalar(i: *const u8, i_len: usize, md: *mut u8, md_len: usize);
|
fn hash_to_scalar(hash: *const u8, hash_len: usize, scalar: *mut u8, scalar_len: usize);
|
||||||
|
fn hash_to_p3(hash8_p3: *mut ge_p3, hash: *const u8, hash_len: usize);
|
||||||
}
|
}
|
||||||
|
|
||||||
use anyhow::{bail, Result};
|
use anyhow::{bail, Result};
|
||||||
@ -21,6 +22,15 @@ const RING_SIZE: usize = 11;
|
|||||||
const KEY_TAG: &str = "CSLAG_0";
|
const KEY_TAG: &str = "CSLAG_0";
|
||||||
const DOMAIN_TAG: &str = "CSLAG_c";
|
const DOMAIN_TAG: &str = "CSLAG_c";
|
||||||
|
|
||||||
|
#[repr(C)]
|
||||||
|
#[derive(Debug)]
|
||||||
|
struct ge_p3 {
|
||||||
|
X: [u32; 10],
|
||||||
|
Y: [u32; 10],
|
||||||
|
Z: [u32; 10],
|
||||||
|
T: [u32; 10],
|
||||||
|
}
|
||||||
|
|
||||||
fn challenge(
|
fn challenge(
|
||||||
s_i: Scalar,
|
s_i: Scalar,
|
||||||
pk_i: RistrettoPoint,
|
pk_i: RistrettoPoint,
|
||||||
@ -723,4 +733,21 @@ mod tests2 {
|
|||||||
"24f9167e1a3eaab18119c225577f0ecc7a488a309e54e2721cbaea62c3db3a06"
|
"24f9167e1a3eaab18119c225577f0ecc7a488a309e54e2721cbaea62c3db3a06"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_hash_to_p3() {
|
||||||
|
let input = "0b6a0ae839214674e9b275aa1986c6352ec7ec6c4ae583ab5a62b947a9dee972";
|
||||||
|
let decoded_input = hex::decode(input).unwrap();
|
||||||
|
|
||||||
|
let mut p3 = ge_p3 {
|
||||||
|
X: [0; 10],
|
||||||
|
Y: [0; 10],
|
||||||
|
Z: [0; 10],
|
||||||
|
T: [0; 10],
|
||||||
|
};
|
||||||
|
|
||||||
|
unsafe { hash_to_p3(&mut p3, decoded_input.as_ptr() as *const u8, 32) };
|
||||||
|
|
||||||
|
dbg!(p3);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user