sha256 builtin + tests.
This commit is contained in:
parent
8f4637ecbc
commit
d94fcbd839
@ -14,6 +14,7 @@ rustc-serialize = "0.3"
|
|||||||
flate2 = "0.2"
|
flate2 = "0.2"
|
||||||
rocksdb = "0.2.1"
|
rocksdb = "0.2.1"
|
||||||
heapsize = "0.2.0"
|
heapsize = "0.2.0"
|
||||||
|
rust-crypto = "0.2.34"
|
||||||
|
|
||||||
evmjit = { path = "rust-evmjit", optional = true }
|
evmjit = { path = "rust-evmjit", optional = true }
|
||||||
|
|
||||||
|
@ -7,6 +7,8 @@ use util::bytes::*;
|
|||||||
use rustc_serialize::json::Json;
|
use rustc_serialize::json::Json;
|
||||||
use std::io::Write;
|
use std::io::Write;
|
||||||
use util::crypto::*;
|
use util::crypto::*;
|
||||||
|
use crypto::sha2::Sha256;
|
||||||
|
use crypto::digest::Digest;
|
||||||
|
|
||||||
/// Definition of a contract whose implementation is built-in.
|
/// Definition of a contract whose implementation is built-in.
|
||||||
pub struct Builtin {
|
pub struct Builtin {
|
||||||
@ -57,18 +59,13 @@ impl Builtin {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
pub fn copy_to(src: &[u8], dest: &mut[u8]) {
|
||||||
ETH_REGISTER_PRECOMPILED(sha256)(bytesConstRef _in, bytesRef _out)
|
// NICE: optimise
|
||||||
{
|
for i in 0..min(src.len(), dest.len()) {
|
||||||
dev::sha256(_in).ref().copyTo(_out);
|
dest[i] = src[i];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ETH_REGISTER_PRECOMPILED(ripemd160)(bytesConstRef _in, bytesRef _out)
|
|
||||||
{
|
|
||||||
h256(dev::ripemd160(_in), h256::AlignRight).ref().copyTo(_out);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
/// Create a new builtin executor according to `name`.
|
/// Create a new builtin executor according to `name`.
|
||||||
/// TODO: turn in to a factory with dynamic registration.
|
/// TODO: turn in to a factory with dynamic registration.
|
||||||
pub fn new_builtin_exec(name: &str) -> Option<Box<Fn(&[u8], &mut [u8])>> {
|
pub fn new_builtin_exec(name: &str) -> Option<Box<Fn(&[u8], &mut [u8])>> {
|
||||||
@ -78,7 +75,7 @@ pub fn new_builtin_exec(name: &str) -> Option<Box<Fn(&[u8], &mut [u8])>> {
|
|||||||
output[i] = input[i];
|
output[i] = input[i];
|
||||||
}
|
}
|
||||||
})),
|
})),
|
||||||
"ecrecover" => Some(Box::new(move|_input: &[u8], _output: &mut[u8]| {
|
"ecrecover" => Some(Box::new(move|input: &[u8], output: &mut[u8]| {
|
||||||
#[repr(packed)]
|
#[repr(packed)]
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
struct InType {
|
struct InType {
|
||||||
@ -88,7 +85,7 @@ pub fn new_builtin_exec(name: &str) -> Option<Box<Fn(&[u8], &mut [u8])>> {
|
|||||||
s: H256,
|
s: H256,
|
||||||
}
|
}
|
||||||
let mut it: InType = InType { hash: H256::new(), v: H256::new(), r: H256::new(), s: H256::new() };
|
let mut it: InType = InType { hash: H256::new(), v: H256::new(), r: H256::new(), s: H256::new() };
|
||||||
it.populate_raw(_input);
|
it.populate_raw(input);
|
||||||
if it.v == H256::from(&U256::from(27)) || it.v == H256::from(&U256::from(28)) {
|
if it.v == H256::from(&U256::from(27)) || it.v == H256::from(&U256::from(28)) {
|
||||||
let s = Signature::from_rsv(&it.r, &it.s, it.v[31] - 27);
|
let s = Signature::from_rsv(&it.r, &it.s, it.v[31] - 27);
|
||||||
if is_valid(&s) {
|
if is_valid(&s) {
|
||||||
@ -96,8 +93,8 @@ pub fn new_builtin_exec(name: &str) -> Option<Box<Fn(&[u8], &mut [u8])>> {
|
|||||||
Ok(p) => {
|
Ok(p) => {
|
||||||
let r = p.as_slice().sha3();
|
let r = p.as_slice().sha3();
|
||||||
// NICE: optimise and separate out into populate-like function
|
// NICE: optimise and separate out into populate-like function
|
||||||
for i in 0..min(32, _output.len()) {
|
for i in 0..min(32, output.len()) {
|
||||||
_output[i] = if i < 12 {0} else {r[i]};
|
output[i] = if i < 12 {0} else {r[i]};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_ => {}
|
_ => {}
|
||||||
@ -105,11 +102,20 @@ pub fn new_builtin_exec(name: &str) -> Option<Box<Fn(&[u8], &mut [u8])>> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
})),
|
})),
|
||||||
"sha256" => Some(Box::new(move|_input: &[u8], _output: &mut[u8]| {
|
"sha256" => Some(Box::new(move|input: &[u8], output: &mut[u8]| {
|
||||||
unimplemented!();
|
let mut sha = Sha256::new();
|
||||||
|
sha.input(input);
|
||||||
|
if output.len() >= 32 {
|
||||||
|
sha.result(output);
|
||||||
|
} else {
|
||||||
|
let mut ret = H256::new();
|
||||||
|
sha.result(ret.as_slice_mut());
|
||||||
|
copy_to(&ret, output);
|
||||||
|
}
|
||||||
|
// dev::sha256(_in).ref().copyTo(_out);
|
||||||
})),
|
})),
|
||||||
"ripemd160" => Some(Box::new(move|_input: &[u8], _output: &mut[u8]| {
|
"ripemd160" => Some(Box::new(move|_input: &[u8], _output: &mut[u8]| {
|
||||||
unimplemented!();
|
// h256(dev::ripemd160(_in), h256::AlignRight).ref().copyTo(_out);
|
||||||
})),
|
})),
|
||||||
_ => None
|
_ => None
|
||||||
}
|
}
|
||||||
@ -134,6 +140,25 @@ fn identity() {
|
|||||||
assert_eq!([255u8; 4], o8[4..]);
|
assert_eq!([255u8; 4], o8[4..]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn sha256() {
|
||||||
|
use rustc_serialize::hex::FromHex;
|
||||||
|
let f = new_builtin_exec("sha256").unwrap();
|
||||||
|
let i = [0u8; 0];
|
||||||
|
|
||||||
|
let mut o = [255u8; 32];
|
||||||
|
f(&i[..], &mut o[..]);
|
||||||
|
assert_eq!(&o[..], &(FromHex::from_hex("e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855").unwrap())[..]);
|
||||||
|
|
||||||
|
let mut o8 = [255u8; 8];
|
||||||
|
f(&i[..], &mut o8[..]);
|
||||||
|
assert_eq!(&o8[..], &(FromHex::from_hex("e3b0c44298fc1c14").unwrap())[..]);
|
||||||
|
|
||||||
|
let mut o34 = [255u8; 34];
|
||||||
|
f(&i[..], &mut o34[..]);
|
||||||
|
assert_eq!(&o34[..], &(FromHex::from_hex("e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855ffff").unwrap())[..]);
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn ecrecover() {
|
fn ecrecover() {
|
||||||
use rustc_serialize::hex::FromHex;
|
use rustc_serialize::hex::FromHex;
|
||||||
|
@ -77,6 +77,7 @@ extern crate rustc_serialize;
|
|||||||
extern crate flate2;
|
extern crate flate2;
|
||||||
extern crate rocksdb;
|
extern crate rocksdb;
|
||||||
extern crate heapsize;
|
extern crate heapsize;
|
||||||
|
extern crate crypto;
|
||||||
|
|
||||||
extern crate env_logger;
|
extern crate env_logger;
|
||||||
#[cfg(feature = "jit" )]
|
#[cfg(feature = "jit" )]
|
||||||
|
Loading…
Reference in New Issue
Block a user