From 184a2de9a92bb3b0842623ee64d43c3b6ab3b71f Mon Sep 17 00:00:00 2001 From: Brian Johnson Date: Mon, 26 Jun 2017 21:08:16 -0500 Subject: [PATCH 1/2] Added support for rejecting float instructions --- libraries/wasm-jit/Include/IR/Operators.h | 245 ++++++++---------- .../Source/WASM/WASMSerialization.cpp | 7 +- 2 files changed, 117 insertions(+), 135 deletions(-) diff --git a/libraries/wasm-jit/Include/IR/Operators.h b/libraries/wasm-jit/Include/IR/Operators.h index 67cb6397d00..dd1dfcc66a1 100644 --- a/libraries/wasm-jit/Include/IR/Operators.h +++ b/libraries/wasm-jit/Include/IR/Operators.h @@ -123,7 +123,11 @@ namespace IR ATOMICRMW : (i32,T) -> T */ - #define ENUM_NONCONTROL_NONPARAMETRIC_OPERATORS(visitOp) \ + #define ENUM_NONCONTROL_NONPARAMETRIC_OPERATORS(visitOp) \ + ENUM_NONFLOAT_NONCONTROL_NONPARAMETRIC_OPERATORS(visitOp) \ + ENUM_FLOAT_NONCONTROL_NONPARAMETRIC_OPERATORS(visitOp) + + #define ENUM_NONFLOAT_NONCONTROL_NONPARAMETRIC_OPERATORS(visitOp) \ visitOp(0x01,nop,"nop",NoImm,NULLARY(none)) \ \ visitOp(0x3f,current_memory,"current_memory",MemoryImm,NULLARY(i32)) \ @@ -131,8 +135,6 @@ namespace IR \ visitOp(0x28,i32_load,"i32.load",LoadOrStoreImm<2>,LOAD(i32)) \ visitOp(0x29,i64_load,"i64.load",LoadOrStoreImm<3>,LOAD(i64)) \ - visitOp(0x2a,f32_load,"f32.load",LoadOrStoreImm<2>,LOAD(f32)) \ - visitOp(0x2b,f64_load,"f64.load",LoadOrStoreImm<3>,LOAD(f64)) \ visitOp(0x2c,i32_load8_s,"i32.load8_s",LoadOrStoreImm<0>,LOAD(i32)) \ visitOp(0x2d,i32_load8_u,"i32.load8_u",LoadOrStoreImm<0>,LOAD(i32)) \ visitOp(0x2e,i32_load16_s,"i32.load16_s",LoadOrStoreImm<1>,LOAD(i32)) \ @@ -146,8 +148,6 @@ namespace IR \ visitOp(0x36,i32_store,"i32.store",LoadOrStoreImm<2>,STORE(i32)) \ visitOp(0x37,i64_store,"i64.store",LoadOrStoreImm<3>,STORE(i64)) \ - visitOp(0x38,f32_store,"f32.store",LoadOrStoreImm<2>,STORE(f32)) \ - visitOp(0x39,f64_store,"f64.store",LoadOrStoreImm<3>,STORE(f64)) \ visitOp(0x3a,i32_store8,"i32.store8",LoadOrStoreImm<0>,STORE(i32)) \ visitOp(0x3b,i32_store16,"i32.store16",LoadOrStoreImm<1>,STORE(i32)) \ visitOp(0x3c,i64_store8,"i64.store8",LoadOrStoreImm<0>,STORE(i64)) \ @@ -156,8 +156,6 @@ namespace IR \ visitOp(0x41,i32_const,"i32.const",LiteralImm,NULLARY(i32)) \ visitOp(0x42,i64_const,"i64.const",LiteralImm,NULLARY(i64)) \ - visitOp(0x43,f32_const,"f32.const",LiteralImm,NULLARY(f32)) \ - visitOp(0x44,f64_const,"f64.const",LiteralImm,NULLARY(f64)) \ \ visitOp(0x45,i32_eqz,"i32.eqz",NoImm,UNARY(i32,i32)) \ visitOp(0x46,i32_eq,"i32.eq",NoImm,BINARY(i32,i32)) \ @@ -183,20 +181,6 @@ namespace IR visitOp(0x59,i64_ge_s,"i64.ge_s",NoImm,BINARY(i64,i32)) \ visitOp(0x5a,i64_ge_u,"i64.ge_u",NoImm,BINARY(i64,i32)) \ \ - visitOp(0x5b,f32_eq,"f32.eq",NoImm,BINARY(f32,i32)) \ - visitOp(0x5c,f32_ne,"f32.ne",NoImm,BINARY(f32,i32)) \ - visitOp(0x5d,f32_lt,"f32.lt",NoImm,BINARY(f32,i32)) \ - visitOp(0x5e,f32_gt,"f32.gt",NoImm,BINARY(f32,i32)) \ - visitOp(0x5f,f32_le,"f32.le",NoImm,BINARY(f32,i32)) \ - visitOp(0x60,f32_ge,"f32.ge",NoImm,BINARY(f32,i32)) \ - \ - visitOp(0x61,f64_eq,"f64.eq",NoImm,BINARY(f64,i32)) \ - visitOp(0x62,f64_ne,"f64.ne",NoImm,BINARY(f64,i32)) \ - visitOp(0x63,f64_lt,"f64.lt",NoImm,BINARY(f64,i32)) \ - visitOp(0x64,f64_gt,"f64.gt",NoImm,BINARY(f64,i32)) \ - visitOp(0x65,f64_le,"f64.le",NoImm,BINARY(f64,i32)) \ - visitOp(0x66,f64_ge,"f64.ge",NoImm,BINARY(f64,i32)) \ - \ visitOp(0x67,i32_clz,"i32.clz",NoImm,UNARY(i32,i32)) \ visitOp(0x68,i32_ctz,"i32.ctz",NoImm,UNARY(i32,i32)) \ visitOp(0x69,i32_popcnt,"i32.popcnt",NoImm,UNARY(i32,i32)) \ @@ -237,71 +221,99 @@ namespace IR visitOp(0x89,i64_rotl,"i64.rotl",NoImm,BINARY(i64,i64)) \ visitOp(0x8a,i64_rotr,"i64.rotr",NoImm,BINARY(i64,i64)) \ \ - visitOp(0x8b,f32_abs,"f32.abs",NoImm,UNARY(f32,f32)) \ - visitOp(0x8c,f32_neg,"f32.neg",NoImm,UNARY(f32,f32)) \ - visitOp(0x8d,f32_ceil,"f32.ceil",NoImm,UNARY(f32,f32)) \ - visitOp(0x8e,f32_floor,"f32.floor",NoImm,UNARY(f32,f32)) \ - visitOp(0x8f,f32_trunc,"f32.trunc",NoImm,UNARY(f32,f32)) \ - visitOp(0x90,f32_nearest,"f32.nearest",NoImm,UNARY(f32,f32)) \ - visitOp(0x91,f32_sqrt,"f32.sqrt",NoImm,UNARY(f32,f32)) \ - \ - visitOp(0x92,f32_add,"f32.add",NoImm,BINARY(f32,f32)) \ - visitOp(0x93,f32_sub,"f32.sub",NoImm,BINARY(f32,f32)) \ - visitOp(0x94,f32_mul,"f32.mul",NoImm,BINARY(f32,f32)) \ - visitOp(0x95,f32_div,"f32.div",NoImm,BINARY(f32,f32)) \ - visitOp(0x96,f32_min,"f32.min",NoImm,BINARY(f32,f32)) \ - visitOp(0x97,f32_max,"f32.max",NoImm,BINARY(f32,f32)) \ - visitOp(0x98,f32_copysign,"f32.copysign",NoImm,BINARY(f32,f32)) \ - \ - visitOp(0x99,f64_abs,"f64.abs",NoImm,UNARY(f64,f64)) \ - visitOp(0x9a,f64_neg,"f64.neg",NoImm,UNARY(f64,f64)) \ - visitOp(0x9b,f64_ceil,"f64.ceil",NoImm,UNARY(f64,f64)) \ - visitOp(0x9c,f64_floor,"f64.floor",NoImm,UNARY(f64,f64)) \ - visitOp(0x9d,f64_trunc,"f64.trunc",NoImm,UNARY(f64,f64)) \ - visitOp(0x9e,f64_nearest,"f64.nearest",NoImm,UNARY(f64,f64)) \ - visitOp(0x9f,f64_sqrt,"f64.sqrt",NoImm,UNARY(f64,f64)) \ - \ - visitOp(0xa0,f64_add,"f64.add",NoImm,BINARY(f64,f64)) \ - visitOp(0xa1,f64_sub,"f64.sub",NoImm,BINARY(f64,f64)) \ - visitOp(0xa2,f64_mul,"f64.mul",NoImm,BINARY(f64,f64)) \ - visitOp(0xa3,f64_div,"f64.div",NoImm,BINARY(f64,f64)) \ - visitOp(0xa4,f64_min,"f64.min",NoImm,BINARY(f64,f64)) \ - visitOp(0xa5,f64_max,"f64.max",NoImm,BINARY(f64,f64)) \ - visitOp(0xa6,f64_copysign,"f64.copysign",NoImm,BINARY(f64,f64)) \ - \ visitOp(0xa7,i32_wrap_i64,"i32.wrap/i64",NoImm,UNARY(i64,i32)) \ - visitOp(0xa8,i32_trunc_s_f32,"i32.trunc_s/f32",NoImm,UNARY(f32,i32)) \ - visitOp(0xa9,i32_trunc_u_f32,"i32.trunc_u/f32",NoImm,UNARY(f32,i32)) \ - visitOp(0xaa,i32_trunc_s_f64,"i32.trunc_s/f64",NoImm,UNARY(f64,i32)) \ - visitOp(0xab,i32_trunc_u_f64,"i32.trunc_u/f64",NoImm,UNARY(f64,i32)) \ visitOp(0xac,i64_extend_s_i32,"i64.extend_s/i32",NoImm,UNARY(i32,i64)) \ visitOp(0xad,i64_extend_u_i32,"i64.extend_u/i32",NoImm,UNARY(i32,i64)) \ - visitOp(0xae,i64_trunc_s_f32,"i64.trunc_s/f32",NoImm,UNARY(f32,i64)) \ - visitOp(0xaf,i64_trunc_u_f32,"i64.trunc_u/f32",NoImm,UNARY(f32,i64)) \ - visitOp(0xb0,i64_trunc_s_f64,"i64.trunc_s/f64",NoImm,UNARY(f64,i64)) \ - visitOp(0xb1,i64_trunc_u_f64,"i64.trunc_u/f64",NoImm,UNARY(f64,i64)) \ - visitOp(0xb2,f32_convert_s_i32,"f32.convert_s/i32",NoImm,UNARY(i32,f32)) \ - visitOp(0xb3,f32_convert_u_i32,"f32.convert_u/i32",NoImm,UNARY(i32,f32)) \ - visitOp(0xb4,f32_convert_s_i64,"f32.convert_s/i64",NoImm,UNARY(i64,f32)) \ - visitOp(0xb5,f32_convert_u_i64,"f32.convert_u/i64",NoImm,UNARY(i64,f32)) \ - visitOp(0xb6,f32_demote_f64,"f32.demote/f64",NoImm,UNARY(f64,f32)) \ - visitOp(0xb7,f64_convert_s_i32,"f64.convert_s/i32",NoImm,UNARY(i32,f64)) \ - visitOp(0xb8,f64_convert_u_i32,"f64.convert_u/i32",NoImm,UNARY(i32,f64)) \ - visitOp(0xb9,f64_convert_s_i64,"f64.convert_s/i64",NoImm,UNARY(i64,f64)) \ - visitOp(0xba,f64_convert_u_i64,"f64.convert_u/i64",NoImm,UNARY(i64,f64)) \ - visitOp(0xbb,f64_promote_f32,"f64.promote/f32",NoImm,UNARY(f32,f64)) \ - visitOp(0xbc,i32_reinterpret_f32,"i32.reinterpret/f32",NoImm,UNARY(f32,i32)) \ - visitOp(0xbd,i64_reinterpret_f64,"i64.reinterpret/f64",NoImm,UNARY(f64,i64)) \ - visitOp(0xbe,f32_reinterpret_i32,"f32.reinterpret/i32",NoImm,UNARY(i32,f32)) \ - visitOp(0xbf,f64_reinterpret_i64,"f64.reinterpret/i64",NoImm,UNARY(i64,f64)) \ - ENUM_SIMD_OPERATORS(visitOp) \ - ENUM_THREADING_OPERATORS(visitOp) + ENUM_NONFLOAT_SIMD_OPERATORS(visitOp) \ + ENUM_NONFLOAT_THREADING_OPERATORS(visitOp) + + #define ENUM_FLOAT_NONCONTROL_NONPARAMETRIC_OPERATORS(visitOp) \ + visitOp(0x2a,f32_load,"f32.load",LoadOrStoreImm<2>,LOAD(f32)) \ + visitOp(0x2b,f64_load,"f64.load",LoadOrStoreImm<3>,LOAD(f64)) \ + \ + visitOp(0x38,f32_store,"f32.store",LoadOrStoreImm<2>,STORE(f32)) \ + visitOp(0x39,f64_store,"f64.store",LoadOrStoreImm<3>,STORE(f64)) \ + \ + visitOp(0x43,f32_const,"f32.const",LiteralImm,NULLARY(f32)) \ + visitOp(0x44,f64_const,"f64.const",LiteralImm,NULLARY(f64)) \ + \ + visitOp(0x5b,f32_eq,"f32.eq",NoImm,BINARY(f32,i32)) \ + visitOp(0x5c,f32_ne,"f32.ne",NoImm,BINARY(f32,i32)) \ + visitOp(0x5d,f32_lt,"f32.lt",NoImm,BINARY(f32,i32)) \ + visitOp(0x5e,f32_gt,"f32.gt",NoImm,BINARY(f32,i32)) \ + visitOp(0x5f,f32_le,"f32.le",NoImm,BINARY(f32,i32)) \ + visitOp(0x60,f32_ge,"f32.ge",NoImm,BINARY(f32,i32)) \ + \ + visitOp(0x61,f64_eq,"f64.eq",NoImm,BINARY(f64,i32)) \ + visitOp(0x62,f64_ne,"f64.ne",NoImm,BINARY(f64,i32)) \ + visitOp(0x63,f64_lt,"f64.lt",NoImm,BINARY(f64,i32)) \ + visitOp(0x64,f64_gt,"f64.gt",NoImm,BINARY(f64,i32)) \ + visitOp(0x65,f64_le,"f64.le",NoImm,BINARY(f64,i32)) \ + visitOp(0x66,f64_ge,"f64.ge",NoImm,BINARY(f64,i32)) \ + \ + visitOp(0x8b,f32_abs,"f32.abs",NoImm,UNARY(f32,f32)) \ + visitOp(0x8c,f32_neg,"f32.neg",NoImm,UNARY(f32,f32)) \ + visitOp(0x8d,f32_ceil,"f32.ceil",NoImm,UNARY(f32,f32)) \ + visitOp(0x8e,f32_floor,"f32.floor",NoImm,UNARY(f32,f32)) \ + visitOp(0x8f,f32_trunc,"f32.trunc",NoImm,UNARY(f32,f32)) \ + visitOp(0x90,f32_nearest,"f32.nearest",NoImm,UNARY(f32,f32)) \ + visitOp(0x91,f32_sqrt,"f32.sqrt",NoImm,UNARY(f32,f32)) \ + \ + visitOp(0x92,f32_add,"f32.add",NoImm,BINARY(f32,f32)) \ + visitOp(0x93,f32_sub,"f32.sub",NoImm,BINARY(f32,f32)) \ + visitOp(0x94,f32_mul,"f32.mul",NoImm,BINARY(f32,f32)) \ + visitOp(0x95,f32_div,"f32.div",NoImm,BINARY(f32,f32)) \ + visitOp(0x96,f32_min,"f32.min",NoImm,BINARY(f32,f32)) \ + visitOp(0x97,f32_max,"f32.max",NoImm,BINARY(f32,f32)) \ + visitOp(0x98,f32_copysign,"f32.copysign",NoImm,BINARY(f32,f32)) \ + \ + visitOp(0x99,f64_abs,"f64.abs",NoImm,UNARY(f64,f64)) \ + visitOp(0x9a,f64_neg,"f64.neg",NoImm,UNARY(f64,f64)) \ + visitOp(0x9b,f64_ceil,"f64.ceil",NoImm,UNARY(f64,f64)) \ + visitOp(0x9c,f64_floor,"f64.floor",NoImm,UNARY(f64,f64)) \ + visitOp(0x9d,f64_trunc,"f64.trunc",NoImm,UNARY(f64,f64)) \ + visitOp(0x9e,f64_nearest,"f64.nearest",NoImm,UNARY(f64,f64)) \ + visitOp(0x9f,f64_sqrt,"f64.sqrt",NoImm,UNARY(f64,f64)) \ + \ + visitOp(0xa0,f64_add,"f64.add",NoImm,BINARY(f64,f64)) \ + visitOp(0xa1,f64_sub,"f64.sub",NoImm,BINARY(f64,f64)) \ + visitOp(0xa2,f64_mul,"f64.mul",NoImm,BINARY(f64,f64)) \ + visitOp(0xa3,f64_div,"f64.div",NoImm,BINARY(f64,f64)) \ + visitOp(0xa4,f64_min,"f64.min",NoImm,BINARY(f64,f64)) \ + visitOp(0xa5,f64_max,"f64.max",NoImm,BINARY(f64,f64)) \ + visitOp(0xa6,f64_copysign,"f64.copysign",NoImm,BINARY(f64,f64)) \ + \ + visitOp(0xa8,i32_trunc_s_f32,"i32.trunc_s/f32",NoImm,UNARY(f32,i32)) \ + visitOp(0xa9,i32_trunc_u_f32,"i32.trunc_u/f32",NoImm,UNARY(f32,i32)) \ + visitOp(0xaa,i32_trunc_s_f64,"i32.trunc_s/f64",NoImm,UNARY(f64,i32)) \ + visitOp(0xab,i32_trunc_u_f64,"i32.trunc_u/f64",NoImm,UNARY(f64,i32)) \ + visitOp(0xae,i64_trunc_s_f32,"i64.trunc_s/f32",NoImm,UNARY(f32,i64)) \ + visitOp(0xaf,i64_trunc_u_f32,"i64.trunc_u/f32",NoImm,UNARY(f32,i64)) \ + visitOp(0xb0,i64_trunc_s_f64,"i64.trunc_s/f64",NoImm,UNARY(f64,i64)) \ + visitOp(0xb1,i64_trunc_u_f64,"i64.trunc_u/f64",NoImm,UNARY(f64,i64)) \ + visitOp(0xb2,f32_convert_s_i32,"f32.convert_s/i32",NoImm,UNARY(i32,f32)) \ + visitOp(0xb3,f32_convert_u_i32,"f32.convert_u/i32",NoImm,UNARY(i32,f32)) \ + visitOp(0xb4,f32_convert_s_i64,"f32.convert_s/i64",NoImm,UNARY(i64,f32)) \ + visitOp(0xb5,f32_convert_u_i64,"f32.convert_u/i64",NoImm,UNARY(i64,f32)) \ + visitOp(0xb6,f32_demote_f64,"f32.demote/f64",NoImm,UNARY(f64,f32)) \ + visitOp(0xb7,f64_convert_s_i32,"f64.convert_s/i32",NoImm,UNARY(i32,f64)) \ + visitOp(0xb8,f64_convert_u_i32,"f64.convert_u/i32",NoImm,UNARY(i32,f64)) \ + visitOp(0xb9,f64_convert_s_i64,"f64.convert_s/i64",NoImm,UNARY(i64,f64)) \ + visitOp(0xba,f64_convert_u_i64,"f64.convert_u/i64",NoImm,UNARY(i64,f64)) \ + visitOp(0xbb,f64_promote_f32,"f64.promote/f32",NoImm,UNARY(f32,f64)) \ + visitOp(0xbc,i32_reinterpret_f32,"i32.reinterpret/f32",NoImm,UNARY(f32,i32)) \ + visitOp(0xbd,i64_reinterpret_f64,"i64.reinterpret/f64",NoImm,UNARY(f64,i64)) \ + visitOp(0xbe,f32_reinterpret_i32,"f32.reinterpret/i32",NoImm,UNARY(i32,f32)) \ + visitOp(0xbf,f64_reinterpret_i64,"f64.reinterpret/i64",NoImm,UNARY(i64,f64)) \ + ENUM_FLOAT_SIMD_OPERATORS(visitOp) \ + ENUM_FLOAT_THREADING_OPERATORS(visitOp) #if !ENABLE_SIMD_PROTOTYPE - #define ENUM_SIMD_OPERATORS(visitOp) + #define ENUM_NONFLOAT_SIMD_OPERATORS(visitOp) + #define ENUM_FLOAT_SIMD_OPERATORS(visitOp) #else #define SIMDOP(simdOpIndex) (0xfd00|simdOpIndex) - #define ENUM_SIMD_OPERATORS(visitOp) \ + #define ENUM_NONFLOAT_SIMD_OPERATORS(visitOp) \ visitOp(SIMDOP(0),v128_const,"v128.const",LiteralImm,NULLARY(v128)) \ visitOp(SIMDOP(1),v128_load,"v128.load",LoadOrStoreImm<4>,LOAD(v128)) \ visitOp(SIMDOP(2),v128_store,"v128.store",LoadOrStoreImm<4>,STORE(v128)) \ @@ -310,8 +322,6 @@ namespace IR visitOp(SIMDOP(4),i16x8_splat,"i16x8.splat",NoImm,UNARY(i32,v128)) \ visitOp(SIMDOP(5),i32x4_splat,"i32x4.splat",NoImm,UNARY(i32,v128)) \ visitOp(SIMDOP(6),i64x2_splat,"i64x2.splat",NoImm,UNARY(i64,v128)) \ - visitOp(SIMDOP(7),f32x4_splat,"f32x4.splat",NoImm,UNARY(f32,v128)) \ - visitOp(SIMDOP(8),f64x2_splat,"f64x2.splat",NoImm,UNARY(f64,v128)) \ \ visitOp(SIMDOP(9),i8x16_extract_lane_s,"i8x16.extract_lane_s",LaneIndexImm<16>,UNARY(v128,i32)) \ visitOp(SIMDOP(10),i8x16_extract_lane_u,"i8x16.extract_lane_u",LaneIndexImm<16>,UNARY(v128,i32)) \ @@ -319,15 +329,11 @@ namespace IR visitOp(SIMDOP(12),i16x8_extract_lane_u,"i16x8.extract_lane_u",LaneIndexImm<8>,UNARY(v128,i32)) \ visitOp(SIMDOP(13),i32x4_extract_lane,"i32x4.extract_lane",LaneIndexImm<4>,UNARY(v128,i32)) \ visitOp(SIMDOP(14),i64x2_extract_lane,"i64x2.extract_lane",LaneIndexImm<2>,UNARY(v128,i64)) \ - visitOp(SIMDOP(15),f32x4_extract_lane,"f32x4.extract_lane",LaneIndexImm<4>,UNARY(v128,f32)) \ - visitOp(SIMDOP(16),f64x2_extract_lane,"f64x2.extract_lane",LaneIndexImm<2>,UNARY(v128,f64)) \ \ visitOp(SIMDOP(17),i8x16_replace_lane,"i8x16.replace_lane",LaneIndexImm<16>,REPLACELANE(i32,v128)) \ visitOp(SIMDOP(18),i16x8_replace_lane,"i16x8.replace_lane",LaneIndexImm<8>,REPLACELANE(i32,v128)) \ visitOp(SIMDOP(19),i32x4_replace_lane,"i32x4.replace_lane",LaneIndexImm<4>,REPLACELANE(i32,v128)) \ visitOp(SIMDOP(20),i64x2_replace_lane,"i64x2.replace_lane",LaneIndexImm<2>,REPLACELANE(i64,v128)) \ - visitOp(SIMDOP(21),f32x4_replace_lane,"f32x4.replace_lane",LaneIndexImm<4>,REPLACELANE(f32,v128)) \ - visitOp(SIMDOP(22),f64x2_replace_lane,"f64x2.replace_lane",LaneIndexImm<2>,REPLACELANE(f64,v128)) \ \ visitOp(SIMDOP(23),v8x16_shuffle,"v8x16.shuffle",ShuffleImm<16>,BINARY(v128,v128)) \ \ @@ -393,14 +399,10 @@ namespace IR visitOp(SIMDOP(72),i8x16_eq,"i8x16.eq",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(73),i16x8_eq,"i16x8.eq",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(74),i32x4_eq,"i32x4.eq",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(75),f32x4_eq,"f32x4.eq",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(76),f64x2_eq,"f64x2.eq",NoImm,BINARY(v128,v128)) \ \ visitOp(SIMDOP(77),i8x16_ne,"i8x16.ne",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(78),i16x8_ne,"i16x8.ne",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(79),i32x4_ne,"i32x4.ne",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(80),f32x4_ne,"f32x4.ne",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(81),f64x2_ne,"f64x2.ne",NoImm,BINARY(v128,v128)) \ \ visitOp(SIMDOP(82),i8x16_lt_s,"i8x16.lt_s",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(83),i8x16_lt_u,"i8x16.lt_u",NoImm,BINARY(v128,v128)) \ @@ -408,8 +410,6 @@ namespace IR visitOp(SIMDOP(85),i16x8_lt_u,"i16x8.lt_u",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(86),i32x4_lt_s,"i32x4.lt_s",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(87),i32x4_lt_u,"i32x4.lt_u",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(88),f32x4_lt,"f32x4.lt",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(89),f64x2_lt,"f64x2.lt",NoImm,BINARY(v128,v128)) \ \ visitOp(SIMDOP(90),i8x16_le_s,"i8x16.le_s",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(91),i8x16_le_u,"i8x16.le_u",NoImm,BINARY(v128,v128)) \ @@ -417,8 +417,6 @@ namespace IR visitOp(SIMDOP(93),i16x8_le_u,"i16x8.le_u",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(94),i32x4_le_s,"i32x4.le_s",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(95),i32x4_le_u,"i32x4.le_u",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(96),f32x4_le,"f32x4.le",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(97),f64x2_le,"f64x2.le",NoImm,BINARY(v128,v128)) \ \ visitOp(SIMDOP(98),i8x16_gt_s,"i8x16.gt_s",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(99),i8x16_gt_u,"i8x16.gt_u",NoImm,BINARY(v128,v128)) \ @@ -426,8 +424,6 @@ namespace IR visitOp(SIMDOP(101),i16x8_gt_u,"i16x8.gt_u",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(102),i32x4_gt_s,"i32x4.gt_s",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(103),i32x4_gt_u,"i32x4.gt_u",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(104),f32x4_gt,"f32x4.gt",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(105),f64x2_gt,"f64x2.gt",NoImm,BINARY(v128,v128)) \ \ visitOp(SIMDOP(106),i8x16_ge_s,"i8x16.ge_s",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(107),i8x16_ge_u,"i8x16.ge_u",NoImm,BINARY(v128,v128)) \ @@ -435,51 +431,23 @@ namespace IR visitOp(SIMDOP(109),i16x8_ge_u,"i16x8.ge_u",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(110),i32x4_ge_s,"i32x4.ge_s",NoImm,BINARY(v128,v128)) \ visitOp(SIMDOP(111),i32x4_ge_u,"i32x4.ge_u",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(112),f32x4_ge,"f32x4.ge",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(113),f64x2_ge,"f64x2.ge",NoImm,BINARY(v128,v128)) \ - \ - visitOp(SIMDOP(114),f32x4_neg,"f32x4.neg",NoImm,UNARY(v128,v128)) \ - visitOp(SIMDOP(115),f64x2_neg,"f64x2.neg",NoImm,UNARY(v128,v128)) \ - \ - visitOp(SIMDOP(116),f32x4_abs,"f32x4.abs",NoImm,UNARY(v128,v128)) \ - visitOp(SIMDOP(117),f64x2_abs,"f64x2.abs",NoImm,UNARY(v128,v128)) \ - \ - visitOp(SIMDOP(118),f32x4_min,"f32x4.min",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(119),f64x2_min,"f64x2.min",NoImm,BINARY(v128,v128)) \ - \ - visitOp(SIMDOP(120),f32x4_max,"f32x4.max",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(121),f64x2_max,"f64x2.max",NoImm,BINARY(v128,v128)) \ - \ - visitOp(SIMDOP(122),f32x4_add,"f32x4.add",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(123),f64x2_add,"f64x2.add",NoImm,BINARY(v128,v128)) \ - \ - visitOp(SIMDOP(124),f32x4_sub,"f32x4.sub",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(125),f64x2_sub,"f64x2.sub",NoImm,BINARY(v128,v128)) \ - \ - visitOp(SIMDOP(126),f32x4_div,"f32x4.div",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(127),f64x2_div,"f64x2.div",NoImm,BINARY(v128,v128)) \ - \ - visitOp(SIMDOP(128),f32x4_mul,"f32x4.mul",NoImm,BINARY(v128,v128)) \ - visitOp(SIMDOP(129),f64x2_mul,"f64x2.mul",NoImm,BINARY(v128,v128)) \ - \ - visitOp(SIMDOP(130),f32x4_sqrt,"f32x4.sqrt",NoImm,UNARY(v128,v128)) \ - visitOp(SIMDOP(131),f64x2_sqrt,"f64x2.sqrt",NoImm,UNARY(v128,v128)) \ - \ - visitOp(SIMDOP(132),f32x4_convert_s_i32x4,"f32x4.convert_s/i32x4",NoImm,UNARY(v128,v128)) \ - visitOp(SIMDOP(133),f32x4_convert_u_i32x4,"f32x4.convert_u/i32x4",NoImm,UNARY(v128,v128)) \ - visitOp(SIMDOP(134),f64x2_convert_s_i64x2,"f64x2.convert_s/i64x2",NoImm,UNARY(v128,v128)) \ - visitOp(SIMDOP(135),f64x2_convert_u_i64x2,"f64x2.convert_u/i64x2",NoImm,UNARY(v128,v128)) \ \ visitOp(SIMDOP(136),i32x4_trunc_s_f32x4_sat,"i32x4.trunc_s/f32x4:sat",NoImm,UNARY(v128,v128)) \ visitOp(SIMDOP(137),i32x4_trunc_u_f32x4_sat,"i32x4.trunc_u/f32x4:sat",NoImm,UNARY(v128,v128)) \ visitOp(SIMDOP(138),i64x2_trunc_s_f64x2_sat,"i64x2.trunc_s/f64x2:sat",NoImm,UNARY(v128,v128)) \ visitOp(SIMDOP(139),i64x2_trunc_u_f64x2_sat,"i64x2.trunc_u/f64x2:sat",NoImm,UNARY(v128,v128)) + #define ENUM_FLOAT_SIMD_OPERATORS(visitOp) \ + visitOp(SIMDOP(136),i32x4_trunc_s_f32x4_sat,"i32x4.trunc_s/f32x4:sat",NoImm,UNARY(v128,v128)) \ + visitOp(SIMDOP(137),i32x4_trunc_u_f32x4_sat,"i32x4.trunc_u/f32x4:sat",NoImm,UNARY(v128,v128)) \ + visitOp(SIMDOP(138),i64x2_trunc_s_f64x2_sat,"i64x2.trunc_s/f64x2:sat",NoImm,UNARY(v128,v128)) \ + visitOp(SIMDOP(139),i64x2_trunc_u_f64x2_sat,"i64x2.trunc_u/f64x2:sat",NoImm,UNARY(v128,v128)) #endif #if !ENABLE_THREADING_PROTOTYPE - #define ENUM_THREADING_OPERATORS(visitOp) + #define ENUM_NONFLOAT_THREADING_OPERATORS(visitOp) + #define ENUM_FLOAT_THREADING_OPERATORS(visitOp) #else - #define ENUM_THREADING_OPERATORS(visitOp) \ + #define ENUM_NONFLOAT_THREADING_OPERATORS(visitOp) \ visitOp(0xc0,i32_extend_s_i8,"i32.extend_s/i8",NoImm,UNARY(i32,i32)) \ visitOp(0xc1,i32_extend_s_i16,"i32.extend_s/i16",NoImm,UNARY(i32,i32)) \ visitOp(0xc2,i64_extend_s_i8,"i64.extend_s/i8",NoImm,UNARY(i64,i64)) \ @@ -515,8 +483,6 @@ namespace IR visitOp(0xfe27,i64_atomic_load32_u,"i64.atomic.load32_u",AtomicLoadOrStoreImm<2>,LOAD(i64)) \ visitOp(0xfe28,i32_atomic_store,"i32.atomic.store",AtomicLoadOrStoreImm<2>,STORE(i32)) \ visitOp(0xfe29,i64_atomic_store,"i64.atomic.store",AtomicLoadOrStoreImm<3>,STORE(i64)) \ - visitOp(0xfe2a,f32_atomic_store,"f32.atomic.store",AtomicLoadOrStoreImm<2>,STORE(f32)) \ - visitOp(0xfe2b,f64_atomic_store,"f64.atomic.store",AtomicLoadOrStoreImm<3>,STORE(f64)) \ visitOp(0xfe2c,i32_atomic_store8,"i32.atomic.store8",AtomicLoadOrStoreImm<0>,STORE(i32)) \ visitOp(0xfe2d,i32_atomic_store16,"i32.atomic.store16",AtomicLoadOrStoreImm<1>,STORE(i32)) \ visitOp(0xfe2e,i64_atomic_store8,"i64.atomic.store8",AtomicLoadOrStoreImm<0>,STORE(i64)) \ @@ -562,16 +528,27 @@ namespace IR visitOp(0xfe76,i64_atomic_rmw8_u_xor,"i64.atomic.rmw8_u.xor",AtomicLoadOrStoreImm<0>,ATOMICRMW(i64)) \ visitOp(0xfe78,i64_atomic_rmw16_u_xor,"i64.atomic.rmw16_u.xor",AtomicLoadOrStoreImm<1>,ATOMICRMW(i64)) \ visitOp(0xfe7a,i64_atomic_rmw32_u_xor,"i64.atomic.rmw32_u.xor",AtomicLoadOrStoreImm<2>,ATOMICRMW(i64)) + #define ENUM_FLOAT_THREADING_OPERATORS(visitOp) \ + visitOp(0xfe2a,f32_atomic_store,"f32.atomic.store",AtomicLoadOrStoreImm<2>,STORE(f32)) \ + visitOp(0xfe2b,f64_atomic_store,"f64.atomic.store",AtomicLoadOrStoreImm<3>,STORE(f64)) #endif #define ENUM_NONCONTROL_OPERATORS(visitOp) \ ENUM_PARAMETRIC_OPERATORS(visitOp) \ ENUM_NONCONTROL_NONPARAMETRIC_OPERATORS(visitOp) + #define ENUM_NONFLOAT_NONCONTROL_OPERATORS(visitOp) \ + ENUM_PARAMETRIC_OPERATORS(visitOp) \ + ENUM_NONFLOAT_NONCONTROL_NONPARAMETRIC_OPERATORS(visitOp) + #define ENUM_OPERATORS(visitOp) \ ENUM_NONCONTROL_OPERATORS(visitOp) \ ENUM_CONTROL_OPERATORS(visitOp) + #define ENUM_NONFLOAT_OPERATORS(visitOp) \ + ENUM_NONFLOAT_NONCONTROL_OPERATORS(visitOp) \ + ENUM_CONTROL_OPERATORS(visitOp) + enum class Opcode : U16 { #define VISIT_OPCODE(opcode,name,...) name = opcode, @@ -675,4 +652,4 @@ namespace IR }; IR_API const char* getOpcodeName(Opcode opcode); -} \ No newline at end of file +} diff --git a/libraries/wasm-jit/Source/WASM/WASMSerialization.cpp b/libraries/wasm-jit/Source/WASM/WASMSerialization.cpp index 8eafcc89170..b576eacd881 100644 --- a/libraries/wasm-jit/Source/WASM/WASMSerialization.cpp +++ b/libraries/wasm-jit/Source/WASM/WASMSerialization.cpp @@ -514,8 +514,13 @@ namespace WASM irEncoderStream.name(imm); \ break; \ } - ENUM_OPERATORS(VISIT_OPCODE) + ENUM_NONFLOAT_OPERATORS(VISIT_OPCODE) #undef VISIT_OPCODE + #define VISIT_OPCODE(_,name,nameString,...) \ + case Opcode::name: \ + throw FatalSerializationException("float instructions not allowed"); + ENUM_FLOAT_NONCONTROL_NONPARAMETRIC_OPERATORS(VISIT_OPCODE) + #undef VISIT_OPCODE default: throw FatalSerializationException("unknown opcode"); }; }; From 132294d9771be4d86c9dc99a8e9e0c247711ed11 Mon Sep 17 00:00:00 2001 From: Brian Johnson Date: Mon, 26 Jun 2017 21:09:30 -0500 Subject: [PATCH 2/2] Added test to verify float instructions rejected --- tests/tests/block_tests.cpp | 789 ++++++++++++++++++++++++++++++++++++ 1 file changed, 789 insertions(+) diff --git a/tests/tests/block_tests.cpp b/tests/tests/block_tests.cpp index a89e7421645..13a691369d0 100644 --- a/tests/tests/block_tests.cpp +++ b/tests/tests/block_tests.cpp @@ -1256,4 +1256,793 @@ BOOST_FIXTURE_TEST_CASE(wipe, testing_fixture) } } FC_LOG_AND_RETHROW() } +//Test account script float rejection +BOOST_FIXTURE_TEST_CASE(create_script_w_float, testing_fixture) +{ try { + Make_Database(db); + db.produce_blocks(10); + Make_Account(db, simplecoin); + db.produce_blocks(1); + + + +/* + auto c_apply = R"( +typedef long long uint64_t; +typedef unsigned int uint32_t; + +void print( char* string, int length ); +void printi( int ); +void printi64( uint64_t ); +void assert( int test, char* message ); +void store( const char* key, int keylength, const char* value, int valuelen ); +int load( const char* key, int keylength, char* value, int maxlen ); +int remove( const char* key, int keyLength ); +void* memcpy( void* dest, const void* src, uint32_t size ); +int readMessage( char* dest, int destsize ); + +void* malloc( unsigned int size ) { + static char dynamic_memory[1024*8]; + static int start = 0; + int old_start = start; + start += 8*((size+7)/8); + assert( start < sizeof(dynamic_memory), "out of memory" ); + return &dynamic_memory[old_start]; +} + + +typedef struct { + uint64_t name[4]; +} AccountName; + +typedef struct { + uint32_t length; + char data[]; +} String; + + +typedef struct { + char* start; + char* pos; + char* end; +} DataStream; + +void DataStream_init( DataStream* ds, char* start, int length ) { + ds->start = start; + ds->end = start + length; + ds->pos = start; +} +void AccountName_initString( AccountName* a, String* s ) { + assert( s->length <= sizeof(AccountName), "String is longer than account name allows" ); + memcpy( a, s->data, s->length ); +} +void AccountName_initCString( AccountName* a, const char* s, uint32_t len ) { + assert( len <= sizeof(AccountName), "String is longer than account name allows" ); + memcpy( a, s, len ); +} + +void AccountName_unpack( DataStream* ds, AccountName* account ); +void uint64_unpack( DataStream* ds, uint64_t* value ) { + assert( ds->pos + sizeof(uint64_t) <= ds->end, "read past end of stream" ); + memcpy( (char*)value, ds->pos, 8 ); + ds->pos += sizeof(uint64_t); +} +void Varint_unpack( DataStream* ds, uint32_t* value ); +void String_unpack( DataStream* ds, String** value ) { + static uint32_t size; + Varint_unpack( ds, &size ); + assert( ds->pos + size <= ds->end, "read past end of stream"); + String* str = (String*)malloc( size + sizeof(String) ); + memcpy( str->data, ds->pos, size ); + *value = str; +} + +/// END BUILT IN LIBRARY.... everything below this is "user contract" + + +typedef struct { + AccountName from; + AccountName to; + uint64_t amount; + String* memo; +} Transfer; + +void Transfer_unpack( DataStream* ds, Transfer* transfer ) +{ + AccountName_unpack( ds, &transfer->from ); + AccountName_unpack( ds, &transfer->to ); + uint64_unpack( ds, &transfer->amount ); + String_unpack( ds, &transfer->memo ); +} + +typedef struct { + uint64_t balance; +} Balance; + +void onInit() { + static Balance initial; + static AccountName simplecoin; + AccountName_initCString( &simplecoin, "simplecoin", 10 ); + initial.balance = 1000*1000; + + store( (const char*)&simplecoin, sizeof(AccountName), (const char*)&initial, sizeof(Balance)); +} + + +void onApply_Transfer_simplecoin() { + static char buffer[100]; + + int read = readMessage( buffer, 100 ); + static Transfer message; + static DataStream ds; + DataStream_init( &ds, buffer, read ); + Transfer_unpack( &ds, &message ); + + static Balance from_balance; + static Balance to_balance; + to_balance.balance = 0; + + read = load( (const char*)&message.from, sizeof(message.from), (char*)&from_balance.balance, sizeof(from_balance.balance) ); + assert( read == sizeof(Balance), "no existing balance" ); + assert( from_balance.balance >= message.amount, "insufficient funds" ); + read = load( (const char*)&message.to, sizeof(message.to), (char*)&to_balance.balance, sizeof(to_balance.balance) ); + + to_balance.balance += message.amount; + from_balance.balance -= message.amount; + + double bal = to_balance.balance; + if( bal + 0.5 < 50.5 ) + return; + + if( from_balance.balance ) + store( (const char*)&message.from, sizeof(AccountName), (const char*)&from_balance.balance, sizeof(from_balance.balance) ); + else + remove( (const char*)&message.from, sizeof(AccountName) ); + + store( (const char*)&message.to, sizeof(message.to), (const char*)&to_balance.balance, sizeof(to_balance.balance) ); +} + +"); +*/ +std::string wast_apply = +R"( +(module + (type $FUNCSIG$vii (func (param i32 i32))) + (type $FUNCSIG$viiii (func (param i32 i32 i32 i32))) + (type $FUNCSIG$iii (func (param i32 i32) (result i32))) + (type $FUNCSIG$iiiii (func (param i32 i32 i32 i32) (result i32))) + (type $FUNCSIG$iiii (func (param i32 i32 i32) (result i32))) + (import "env" "AccountName_unpack" (func $AccountName_unpack (param i32 i32))) + (import "env" "Varint_unpack" (func $Varint_unpack (param i32 i32))) + (import "env" "assert" (func $assert (param i32 i32))) + (import "env" "load" (func $load (param i32 i32 i32 i32) (result i32))) + (import "env" "memcpy" (func $memcpy (param i32 i32 i32) (result i32))) + (import "env" "readMessage" (func $readMessage (param i32 i32) (result i32))) + (import "env" "remove" (func $remove (param i32 i32) (result i32))) + (import "env" "store" (func $store (param i32 i32 i32 i32))) + (table 0 anyfunc) + (memory $0 1) + (data (i32.const 8224) "out of memory\00") + (data (i32.const 8240) "String is longer than account name allows\00") + (data (i32.const 8288) "read past end of stream\00") + (data (i32.const 8368) "simplecoin\00") + (data (i32.const 8608) "no existing balance\00") + (data (i32.const 8640) "insufficient funds\00") + (export "memory" (memory $0)) + (export "malloc" (func $malloc)) + (export "DataStream_init" (func $DataStream_init)) + (export "AccountName_initString" (func $AccountName_initString)) + (export "AccountName_initCString" (func $AccountName_initCString)) + (export "uint64_unpack" (func $uint64_unpack)) + (export "String_unpack" (func $String_unpack)) + (export "Transfer_unpack" (func $Transfer_unpack)) + (export "onInit" (func $onInit)) + (export "onApply_Transfer_simplecoin" (func $onApply_Transfer_simplecoin)) + (func $malloc (param $0 i32) (result i32) + (local $1 i32) + (i32.store offset=8208 + (i32.const 0) + (tee_local $0 + (i32.add + (tee_local $1 + (i32.load offset=8208 + (i32.const 0) + ) + ) + (i32.and + (i32.add + (get_local $0) + (i32.const 7) + ) + (i32.const -8) + ) + ) + ) + ) + (call $assert + (i32.lt_u + (get_local $0) + (i32.const 8192) + ) + (i32.const 8224) + ) + (i32.add + (get_local $1) + (i32.const 16) + ) + ) + (func $DataStream_init (param $0 i32) (param $1 i32) (param $2 i32) + (i32.store + (get_local $0) + (get_local $1) + ) + (i32.store offset=4 + (get_local $0) + (get_local $1) + ) + (i32.store offset=8 + (get_local $0) + (i32.add + (get_local $1) + (get_local $2) + ) + ) + ) + (func $AccountName_initString (param $0 i32) (param $1 i32) + (call $assert + (i32.lt_u + (i32.load + (get_local $1) + ) + (i32.const 33) + ) + (i32.const 8240) + ) + (drop + (call $memcpy + (get_local $0) + (i32.add + (get_local $1) + (i32.const 4) + ) + (i32.load + (get_local $1) + ) + ) + ) + ) + (func $AccountName_initCString (param $0 i32) (param $1 i32) (param $2 i32) + (call $assert + (i32.lt_u + (get_local $2) + (i32.const 33) + ) + (i32.const 8240) + ) + (drop + (call $memcpy + (get_local $0) + (get_local $1) + (get_local $2) + ) + ) + ) + (func $uint64_unpack (param $0 i32) (param $1 i32) + (call $assert + (i32.le_u + (i32.add + (i32.load offset=4 + (get_local $0) + ) + (i32.const 8) + ) + (i32.load offset=8 + (get_local $0) + ) + ) + (i32.const 8288) + ) + (i64.store align=1 + (get_local $1) + (i64.load align=1 + (i32.load offset=4 + (get_local $0) + ) + ) + ) + (i32.store offset=4 + (get_local $0) + (i32.add + (i32.load offset=4 + (get_local $0) + ) + (i32.const 8) + ) + ) + ) + (func $String_unpack (param $0 i32) (param $1 i32) + (local $2 i32) + (local $3 i32) + (call $Varint_unpack + (get_local $0) + (i32.const 8312) + ) + (call $assert + (i32.le_u + (i32.add + (i32.load offset=4 + (get_local $0) + ) + (i32.load offset=8312 + (i32.const 0) + ) + ) + (i32.load offset=8 + (get_local $0) + ) + ) + (i32.const 8288) + ) + (i32.store offset=8208 + (i32.const 0) + (tee_local $3 + (i32.add + (i32.and + (i32.add + (i32.load offset=8312 + (i32.const 0) + ) + (i32.const 11) + ) + (i32.const -8) + ) + (tee_local $2 + (i32.load offset=8208 + (i32.const 0) + ) + ) + ) + ) + ) + (call $assert + (i32.lt_u + (get_local $3) + (i32.const 8192) + ) + (i32.const 8224) + ) + (drop + (call $memcpy + (i32.add + (get_local $2) + (i32.const 20) + ) + (i32.load offset=4 + (get_local $0) + ) + (i32.load offset=8312 + (i32.const 0) + ) + ) + ) + (i32.store + (get_local $1) + (i32.add + (get_local $2) + (i32.const 16) + ) + ) + ) + (func $Transfer_unpack (param $0 i32) (param $1 i32) + (local $2 i32) + (local $3 i32) + (call $AccountName_unpack + (get_local $0) + (get_local $1) + ) + (call $AccountName_unpack + (get_local $0) + (i32.add + (get_local $1) + (i32.const 32) + ) + ) + (call $assert + (i32.le_u + (i32.add + (i32.load offset=4 + (get_local $0) + ) + (i32.const 8) + ) + (i32.load offset=8 + (get_local $0) + ) + ) + (i32.const 8288) + ) + (i64.store offset=64 align=1 + (get_local $1) + (i64.load align=1 + (i32.load offset=4 + (get_local $0) + ) + ) + ) + (i32.store offset=4 + (get_local $0) + (i32.add + (i32.load offset=4 + (get_local $0) + ) + (i32.const 8) + ) + ) + (call $Varint_unpack + (get_local $0) + (i32.const 8312) + ) + (call $assert + (i32.le_u + (i32.add + (i32.load offset=4 + (get_local $0) + ) + (i32.load offset=8312 + (i32.const 0) + ) + ) + (i32.load offset=8 + (get_local $0) + ) + ) + (i32.const 8288) + ) + (i32.store offset=8208 + (i32.const 0) + (tee_local $3 + (i32.add + (i32.and + (i32.add + (i32.load offset=8312 + (i32.const 0) + ) + (i32.const 11) + ) + (i32.const -8) + ) + (tee_local $2 + (i32.load offset=8208 + (i32.const 0) + ) + ) + ) + ) + ) + (call $assert + (i32.lt_u + (get_local $3) + (i32.const 8192) + ) + (i32.const 8224) + ) + (drop + (call $memcpy + (i32.add + (get_local $2) + (i32.const 20) + ) + (i32.load offset=4 + (get_local $0) + ) + (i32.load offset=8312 + (i32.const 0) + ) + ) + ) + (i32.store offset=72 + (get_local $1) + (i32.add + (get_local $2) + (i32.const 16) + ) + ) + ) + (func $onInit + (call $assert + (i32.const 1) + (i32.const 8240) + ) + (i64.store offset=8320 + (i32.const 0) + (i64.const 1000000) + ) + (i32.store16 offset=8336 + (i32.const 0) + (i32.load16_u offset=8376 align=1 + (i32.const 0) + ) + ) + (i64.store offset=8328 + (i32.const 0) + (i64.load offset=8368 align=1 + (i32.const 0) + ) + ) + (call $store + (i32.const 8328) + (i32.const 32) + (i32.const 8320) + (i32.const 8) + ) + ) + (func $onApply_Transfer_simplecoin + (local $0 i32) + (local $1 i32) + (local $2 i64) + (set_local $0 + (call $readMessage + (i32.const 8384) + (i32.const 100) + ) + ) + (i32.store offset=8568 + (i32.const 0) + (i32.const 8384) + ) + (i32.store offset=8572 + (i32.const 0) + (i32.const 8384) + ) + (i32.store offset=8576 + (i32.const 0) + (i32.add + (get_local $0) + (i32.const 8384) + ) + ) + (call $AccountName_unpack + (i32.const 8568) + (i32.const 8488) + ) + (call $AccountName_unpack + (i32.const 8568) + (i32.const 8520) + ) + (call $assert + (i32.le_u + (i32.add + (i32.load offset=8572 + (i32.const 0) + ) + (i32.const 8) + ) + (i32.load offset=8576 + (i32.const 0) + ) + ) + (i32.const 8288) + ) + (i64.store offset=8552 + (i32.const 0) + (i64.load align=1 + (tee_local $0 + (i32.load offset=8572 + (i32.const 0) + ) + ) + ) + ) + (i32.store offset=8572 + (i32.const 0) + (i32.add + (get_local $0) + (i32.const 8) + ) + ) + (call $Varint_unpack + (i32.const 8568) + (i32.const 8312) + ) + (call $assert + (i32.le_u + (i32.add + (i32.load offset=8572 + (i32.const 0) + ) + (i32.load offset=8312 + (i32.const 0) + ) + ) + (i32.load offset=8576 + (i32.const 0) + ) + ) + (i32.const 8288) + ) + (i32.store offset=8208 + (i32.const 0) + (tee_local $1 + (i32.add + (i32.and + (i32.add + (i32.load offset=8312 + (i32.const 0) + ) + (i32.const 11) + ) + (i32.const -8) + ) + (tee_local $0 + (i32.load offset=8208 + (i32.const 0) + ) + ) + ) + ) + ) + (call $assert + (i32.lt_u + (get_local $1) + (i32.const 8192) + ) + (i32.const 8224) + ) + (drop + (call $memcpy + (i32.add + (get_local $0) + (i32.const 20) + ) + (i32.load offset=8572 + (i32.const 0) + ) + (i32.load offset=8312 + (i32.const 0) + ) + ) + ) + (i64.store offset=8592 + (i32.const 0) + (i64.const 0) + ) + (i32.store offset=8560 + (i32.const 0) + (i32.add + (get_local $0) + (i32.const 16) + ) + ) + (call $assert + (i32.eq + (call $load + (i32.const 8488) + (i32.const 32) + (i32.const 8584) + (i32.const 8) + ) + (i32.const 8) + ) + (i32.const 8608) + ) + (call $assert + (i64.ge_s + (i64.load offset=8584 + (i32.const 0) + ) + (i64.load offset=8552 + (i32.const 0) + ) + ) + (i32.const 8640) + ) + (drop + (call $load + (i32.const 8520) + (i32.const 32) + (i32.const 8592) + (i32.const 8) + ) + ) + (i64.store offset=8592 + (i32.const 0) + (i64.add + (i64.load offset=8592 + (i32.const 0) + ) + (tee_local $2 + (i64.load offset=8552 + (i32.const 0) + ) + ) + ) + ) + (i64.store offset=8584 + (i32.const 0) + (tee_local $2 + (i64.sub + (i64.load offset=8584 + (i32.const 0) + ) + (get_local $2) + ) + ) + ) + (block $label$0 + (br_if $label$0 + (f64.lt + (f64.add + (f64.convert_s/i64 + (get_local $2) + ) + (f64.const 0.5) + ) + (f64.const 50.5) + ) + ) + (block $label$1 + (br_if $label$1 + (i64.eqz + (get_local $2) + ) + ) + (call $store + (i32.const 8488) + (i32.const 32) + (i32.const 8584) + (i32.const 8) + ) + (br $label$0) + ) + (drop + (call $remove + (i32.const 8488) + (i32.const 32) + ) + ) + ) + (call $store + (i32.const 8520) + (i32.const 32) + (i32.const 8592) + (i32.const 8) + ) + ) +) + +)"; + + types::SetCode handler; + handler.account = "simplecoin"; + types::DefineStruct interface; + interface.scope = "simplecoin"; + interface.definition = types::GetStruct::type(); + + auto wasm = assemble_wast( wast_apply ); + handler.code.resize(wasm.size()); + memcpy( handler.code.data(), wasm.data(), wasm.size() ); + + eos::chain::SignedTransaction trx; + trx.messages.resize(2); + trx.messages[0].sender = "simplecoin"; + trx.messages[0].recipient = config::SystemContractName; + trx.setMessage(0, "DefineStruct",interface); + trx.messages[1].sender = "simplecoin"; + trx.messages[1].recipient = config::SystemContractName; + trx.setMessage(1, "SetCode", handler); + trx.expiration = db.head_block_time() + 100; + trx.set_reference_block(db.head_block_id()); + try { + db.push_transaction(trx); + BOOST_FAIL("floating point instructions should be rejected"); +/* } catch (const Serialization::FatalSerializationException& fse) { + BOOST_CHECK_EQUAL("float instructions not allowed", fse.message); +*/ } catch (const std::exception& exp) { + BOOST_FAIL("Serialization::FatalSerializationException does not inherit from std::exception"); + } catch (...) { + // empty throw expected, since + } +} FC_LOG_AND_RETHROW() } + + BOOST_AUTO_TEST_SUITE_END()