2020-11-17 17:56:07 +00:00
|
|
|
/*
|
|
|
|
This file is part of solidity.
|
|
|
|
|
|
|
|
solidity is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
solidity is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with solidity. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
// SPDX-License-Identifier: GPL-3.0
|
|
|
|
|
|
|
|
// NOTE: This file is used to generate `ewasmPolyfills/Conversion.h`.
|
|
|
|
|
|
|
|
function u256_to_u128(x1, x2, x3, x4) -> v1, v2 {
|
|
|
|
if i64.ne(0, i64.or(x1, x2)) { invalid() }
|
|
|
|
v2 := x4
|
|
|
|
v1 := x3
|
|
|
|
}
|
|
|
|
|
|
|
|
function u256_to_i64(x1, x2, x3, x4) -> v {
|
|
|
|
if i64.ne(0, i64.or(i64.or(x1, x2), x3)) { invalid() }
|
|
|
|
v := x4
|
|
|
|
}
|
|
|
|
|
|
|
|
function u256_to_i32(x1, x2, x3, x4) -> v:i32 {
|
|
|
|
if i64.ne(0, i64.or(i64.or(x1, x2), x3)) { invalid() }
|
|
|
|
if i64.ne(0, i64.shr_u(x4, 32)) { invalid() }
|
|
|
|
v := i32.wrap_i64(x4)
|
|
|
|
}
|
|
|
|
|
|
|
|
function u256_to_byte(x1, x2, x3, x4) -> v {
|
|
|
|
if i64.ne(0, i64.or(i64.or(x1, x2), x3)) { invalid() }
|
|
|
|
if i64.gt_u(x4, 255) { invalid() }
|
|
|
|
v := x4
|
|
|
|
}
|
|
|
|
|
|
|
|
function u256_to_i32ptr(x1, x2, x3, x4) -> v:i32 {
|
|
|
|
v := u256_to_i32(x1, x2, x3, x4)
|
|
|
|
}
|
|
|
|
|
|
|
|
function to_internal_i32ptr(x1, x2, x3, x4) -> r:i32 {
|
|
|
|
let p:i32 := u256_to_i32ptr(x1, x2, x3, x4)
|
|
|
|
r := i32.add(p, 64:i32)
|
|
|
|
if i32.lt_u(r, p) { invalid() }
|
|
|
|
}
|
|
|
|
|
|
|
|
function u256_to_address(x1, x2, x3, x4) -> r1, r2, r3 {
|
|
|
|
if i64.ne(0, x1) { invalid() }
|
|
|
|
if i64.ne(0, i64.shr_u(x2, 32)) { invalid() }
|
|
|
|
r1 := x2
|
|
|
|
r2 := x3
|
|
|
|
r3 := x4
|
|
|
|
}
|
|
|
|
|
2020-11-21 20:04:29 +00:00
|
|
|
function bswap16(x:i32) -> y:i32 {
|
|
|
|
let hi:i32 := i32.and(i32.shl(x, 8:i32), 0xff00:i32)
|
|
|
|
let lo:i32 := i32.and(i32.shr_u(x, 8:i32), 0xff:i32)
|
|
|
|
y := i32.or(hi, lo)
|
2020-11-17 17:56:07 +00:00
|
|
|
}
|
|
|
|
|
2020-11-21 20:04:29 +00:00
|
|
|
function bswap32(x:i32) -> y:i32 {
|
|
|
|
let hi:i32 := i32.shl(bswap16(x), 16:i32)
|
|
|
|
let lo:i32 := bswap16(i32.shr_u(x, 16:i32))
|
|
|
|
y := i32.or(hi, lo)
|
2020-11-17 17:56:07 +00:00
|
|
|
}
|
|
|
|
|
2020-11-21 20:04:29 +00:00
|
|
|
|
2020-11-18 02:30:06 +00:00
|
|
|
function bswap64(x) -> y {
|
2020-11-21 20:04:29 +00:00
|
|
|
let hi := i64.shl(i64.extend_i32_u(bswap32(i32.wrap_i64(x))), 32)
|
|
|
|
let lo := i64.extend_i32_u(bswap32(i32.wrap_i64(i64.shr_u(x, 32))))
|
2020-11-17 17:56:07 +00:00
|
|
|
y := i64.or(hi, lo)
|
|
|
|
}
|