hash_to_p3 builds using cmake but fails to link with cc-rs

This commit is contained in:
rishflab 2021-04-19 22:04:18 +10:00
parent a93396d9a6
commit 00648d2747
7 changed files with 5176 additions and 101 deletions

View File

@ -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)

View File

@ -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");

File diff suppressed because it is too large Load Diff

View 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);

View File

@ -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;
} }

View 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

View File

@ -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);
}
} }