| OLD | NEW |
| 1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef TEST_SIGNATURES_H | 5 #ifndef TEST_SIGNATURES_H |
| 6 #define TEST_SIGNATURES_H | 6 #define TEST_SIGNATURES_H |
| 7 | 7 |
| 8 #include "src/signature.h" | 8 #include "src/signature.h" |
| 9 #include "src/wasm/wasm-opcodes.h" | 9 #include "src/wasm/wasm-opcodes.h" |
| 10 | 10 |
| (...skipping 17 matching lines...) Expand all Loading... |
| 28 sig_i_dd(1, 2, kIntDoubleTypes4), | 28 sig_i_dd(1, 2, kIntDoubleTypes4), |
| 29 sig_l_v(1, 0, kLongTypes4), | 29 sig_l_v(1, 0, kLongTypes4), |
| 30 sig_l_l(1, 1, kLongTypes4), | 30 sig_l_l(1, 1, kLongTypes4), |
| 31 sig_l_ll(1, 2, kLongTypes4), | 31 sig_l_ll(1, 2, kLongTypes4), |
| 32 sig_i_ll(1, 2, kIntLongTypes4), | 32 sig_i_ll(1, 2, kIntLongTypes4), |
| 33 sig_f_ff(1, 2, kFloatTypes4), | 33 sig_f_ff(1, 2, kFloatTypes4), |
| 34 sig_d_dd(1, 2, kDoubleTypes4), | 34 sig_d_dd(1, 2, kDoubleTypes4), |
| 35 sig_v_v(0, 0, kIntTypes4), | 35 sig_v_v(0, 0, kIntTypes4), |
| 36 sig_v_i(0, 1, kIntTypes4), | 36 sig_v_i(0, 1, kIntTypes4), |
| 37 sig_v_ii(0, 2, kIntTypes4), | 37 sig_v_ii(0, 2, kIntTypes4), |
| 38 sig_v_iii(0, 3, kIntTypes4), | 38 sig_v_iii(0, 3, kIntTypes4) { |
| 39 sig_s_i(1, 1, kSimd128IntTypes4) { | |
| 40 // I used C++ and you won't believe what happened next.... | 39 // I used C++ and you won't believe what happened next.... |
| 41 for (int i = 0; i < 4; i++) kIntTypes4[i] = kAstI32; | 40 for (int i = 0; i < 4; i++) kIntTypes4[i] = kAstI32; |
| 42 for (int i = 0; i < 4; i++) kLongTypes4[i] = kAstI64; | 41 for (int i = 0; i < 4; i++) kLongTypes4[i] = kAstI64; |
| 43 for (int i = 0; i < 4; i++) kFloatTypes4[i] = kAstF32; | 42 for (int i = 0; i < 4; i++) kFloatTypes4[i] = kAstF32; |
| 44 for (int i = 0; i < 4; i++) kDoubleTypes4[i] = kAstF64; | 43 for (int i = 0; i < 4; i++) kDoubleTypes4[i] = kAstF64; |
| 45 for (int i = 0; i < 4; i++) kIntLongTypes4[i] = kAstI64; | 44 for (int i = 0; i < 4; i++) kIntLongTypes4[i] = kAstI64; |
| 46 for (int i = 0; i < 4; i++) kIntFloatTypes4[i] = kAstF32; | 45 for (int i = 0; i < 4; i++) kIntFloatTypes4[i] = kAstF32; |
| 47 for (int i = 0; i < 4; i++) kIntDoubleTypes4[i] = kAstF64; | 46 for (int i = 0; i < 4; i++) kIntDoubleTypes4[i] = kAstF64; |
| 48 for (int i = 0; i < 4; i++) kSimd128IntTypes4[i] = kAstS128; | |
| 49 kIntLongTypes4[0] = kAstI32; | 47 kIntLongTypes4[0] = kAstI32; |
| 50 kIntFloatTypes4[0] = kAstI32; | 48 kIntFloatTypes4[0] = kAstI32; |
| 51 kIntDoubleTypes4[0] = kAstI32; | 49 kIntDoubleTypes4[0] = kAstI32; |
| 52 kSimd128IntTypes4[1] = kAstI32; | |
| 53 } | 50 } |
| 54 | 51 |
| 55 FunctionSig* i_v() { return &sig_i_v; } | 52 FunctionSig* i_v() { return &sig_i_v; } |
| 56 FunctionSig* i_i() { return &sig_i_i; } | 53 FunctionSig* i_i() { return &sig_i_i; } |
| 57 FunctionSig* i_ii() { return &sig_i_ii; } | 54 FunctionSig* i_ii() { return &sig_i_ii; } |
| 58 FunctionSig* i_iii() { return &sig_i_iii; } | 55 FunctionSig* i_iii() { return &sig_i_iii; } |
| 59 | 56 |
| 60 FunctionSig* i_f() { return &sig_i_f; } | 57 FunctionSig* i_f() { return &sig_i_f; } |
| 61 FunctionSig* i_ff() { return &sig_i_ff; } | 58 FunctionSig* i_ff() { return &sig_i_ff; } |
| 62 FunctionSig* i_d() { return &sig_i_d; } | 59 FunctionSig* i_d() { return &sig_i_d; } |
| 63 FunctionSig* i_dd() { return &sig_i_dd; } | 60 FunctionSig* i_dd() { return &sig_i_dd; } |
| 64 | 61 |
| 65 FunctionSig* l_v() { return &sig_l_v; } | 62 FunctionSig* l_v() { return &sig_l_v; } |
| 66 FunctionSig* l_l() { return &sig_l_l; } | 63 FunctionSig* l_l() { return &sig_l_l; } |
| 67 FunctionSig* l_ll() { return &sig_l_ll; } | 64 FunctionSig* l_ll() { return &sig_l_ll; } |
| 68 FunctionSig* i_ll() { return &sig_i_ll; } | 65 FunctionSig* i_ll() { return &sig_i_ll; } |
| 69 | 66 |
| 70 FunctionSig* f_ff() { return &sig_f_ff; } | 67 FunctionSig* f_ff() { return &sig_f_ff; } |
| 71 FunctionSig* d_dd() { return &sig_d_dd; } | 68 FunctionSig* d_dd() { return &sig_d_dd; } |
| 72 | 69 |
| 73 FunctionSig* v_v() { return &sig_v_v; } | 70 FunctionSig* v_v() { return &sig_v_v; } |
| 74 FunctionSig* v_i() { return &sig_v_i; } | 71 FunctionSig* v_i() { return &sig_v_i; } |
| 75 FunctionSig* v_ii() { return &sig_v_ii; } | 72 FunctionSig* v_ii() { return &sig_v_ii; } |
| 76 FunctionSig* v_iii() { return &sig_v_iii; } | 73 FunctionSig* v_iii() { return &sig_v_iii; } |
| 77 FunctionSig* s_i() { return &sig_s_i; } | |
| 78 | 74 |
| 79 FunctionSig* many(Zone* zone, LocalType ret, LocalType param, int count) { | 75 FunctionSig* many(Zone* zone, LocalType ret, LocalType param, int count) { |
| 80 FunctionSig::Builder builder(zone, ret == kAstStmt ? 0 : 1, count); | 76 FunctionSig::Builder builder(zone, ret == kAstStmt ? 0 : 1, count); |
| 81 if (ret != kAstStmt) builder.AddReturn(ret); | 77 if (ret != kAstStmt) builder.AddReturn(ret); |
| 82 for (int i = 0; i < count; i++) { | 78 for (int i = 0; i < count; i++) { |
| 83 builder.AddParam(param); | 79 builder.AddParam(param); |
| 84 } | 80 } |
| 85 return builder.Build(); | 81 return builder.Build(); |
| 86 } | 82 } |
| 87 | 83 |
| 88 private: | 84 private: |
| 89 LocalType kIntTypes4[4]; | 85 LocalType kIntTypes4[4]; |
| 90 LocalType kLongTypes4[4]; | 86 LocalType kLongTypes4[4]; |
| 91 LocalType kFloatTypes4[4]; | 87 LocalType kFloatTypes4[4]; |
| 92 LocalType kDoubleTypes4[4]; | 88 LocalType kDoubleTypes4[4]; |
| 93 LocalType kIntLongTypes4[4]; | 89 LocalType kIntLongTypes4[4]; |
| 94 LocalType kIntFloatTypes4[4]; | 90 LocalType kIntFloatTypes4[4]; |
| 95 LocalType kIntDoubleTypes4[4]; | 91 LocalType kIntDoubleTypes4[4]; |
| 96 LocalType kSimd128IntTypes4[4]; | |
| 97 | 92 |
| 98 FunctionSig sig_i_v; | 93 FunctionSig sig_i_v; |
| 99 FunctionSig sig_i_i; | 94 FunctionSig sig_i_i; |
| 100 FunctionSig sig_i_ii; | 95 FunctionSig sig_i_ii; |
| 101 FunctionSig sig_i_iii; | 96 FunctionSig sig_i_iii; |
| 102 | 97 |
| 103 FunctionSig sig_i_f; | 98 FunctionSig sig_i_f; |
| 104 FunctionSig sig_i_ff; | 99 FunctionSig sig_i_ff; |
| 105 FunctionSig sig_i_d; | 100 FunctionSig sig_i_d; |
| 106 FunctionSig sig_i_dd; | 101 FunctionSig sig_i_dd; |
| 107 | 102 |
| 108 FunctionSig sig_l_v; | 103 FunctionSig sig_l_v; |
| 109 FunctionSig sig_l_l; | 104 FunctionSig sig_l_l; |
| 110 FunctionSig sig_l_ll; | 105 FunctionSig sig_l_ll; |
| 111 FunctionSig sig_i_ll; | 106 FunctionSig sig_i_ll; |
| 112 | 107 |
| 113 FunctionSig sig_f_ff; | 108 FunctionSig sig_f_ff; |
| 114 FunctionSig sig_d_dd; | 109 FunctionSig sig_d_dd; |
| 115 | 110 |
| 116 FunctionSig sig_v_v; | 111 FunctionSig sig_v_v; |
| 117 FunctionSig sig_v_i; | 112 FunctionSig sig_v_i; |
| 118 FunctionSig sig_v_ii; | 113 FunctionSig sig_v_ii; |
| 119 FunctionSig sig_v_iii; | 114 FunctionSig sig_v_iii; |
| 120 FunctionSig sig_s_i; | |
| 121 }; | 115 }; |
| 122 } // namespace wasm | 116 } // namespace wasm |
| 123 } // namespace internal | 117 } // namespace internal |
| 124 } // namespace v8 | 118 } // namespace v8 |
| 125 | 119 |
| 126 #endif // TEST_SIGNATURES_H | 120 #endif // TEST_SIGNATURES_H |
| OLD | NEW |