mirror of
https://github.com/status-im/nimbus-eth2.git
synced 2025-01-25 14:00:17 +00:00
* fix #1585 and restore storeLEBytes on big-endian systems * switch to using stew/endians2 * create static endians2-like shim in bitseqs
This commit is contained in:
parent
8c59b92081
commit
5354a0a3d5
@ -1,5 +1,5 @@
|
|||||||
# beacon_chain
|
# beacon_chain
|
||||||
# Copyright (c) 2018 Status Research & Development GmbH
|
# Copyright (c) 2018-2020 Status Research & Development GmbH
|
||||||
# Licensed and distributed under either of
|
# Licensed and distributed under either of
|
||||||
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
|
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
|
||||||
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
|
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
|
||||||
@ -8,7 +8,7 @@
|
|||||||
{.push raises: [Defect].}
|
{.push raises: [Defect].}
|
||||||
|
|
||||||
import
|
import
|
||||||
stew/[bitops2, ptrops]
|
stew/[bitops2, endians2, ptrops]
|
||||||
|
|
||||||
type
|
type
|
||||||
Bytes = seq[byte]
|
Bytes = seq[byte]
|
||||||
@ -52,6 +52,17 @@ func add*(s: var BitSeq, value: bool) =
|
|||||||
s.Bytes[lastBytePos].changeBit 7, value
|
s.Bytes[lastBytePos].changeBit 7, value
|
||||||
s.Bytes.add byte(1)
|
s.Bytes.add byte(1)
|
||||||
|
|
||||||
|
func toBytesLE(x: uint): array[sizeof(x), byte] =
|
||||||
|
# stew/endians2 supports explicitly sized uints only
|
||||||
|
when sizeof(uint) == 4:
|
||||||
|
static: doAssert sizeof(uint) == sizeof(uint32)
|
||||||
|
toBytesLE(x.uint32)
|
||||||
|
elif sizeof(uint) == 8:
|
||||||
|
static: doAssert sizeof(uint) == sizeof(uint64)
|
||||||
|
toBytesLE(x.uint64)
|
||||||
|
else:
|
||||||
|
static: doAssert false, "requires a 32-bit or 64-bit platform"
|
||||||
|
|
||||||
func loadLEBytes(WordType: type, bytes: openarray[byte]): WordType =
|
func loadLEBytes(WordType: type, bytes: openarray[byte]): WordType =
|
||||||
# TODO: this is a temporary proc until the endians API is improved
|
# TODO: this is a temporary proc until the endians API is improved
|
||||||
var shift = 0
|
var shift = 0
|
||||||
@ -61,13 +72,8 @@ func loadLEBytes(WordType: type, bytes: openarray[byte]): WordType =
|
|||||||
|
|
||||||
func storeLEBytes(value: SomeUnsignedInt, dst: var openarray[byte]) =
|
func storeLEBytes(value: SomeUnsignedInt, dst: var openarray[byte]) =
|
||||||
doAssert dst.len <= sizeof(value)
|
doAssert dst.len <= sizeof(value)
|
||||||
when system.cpuEndian == bigEndian:
|
let bytesLE = toBytesLE(value)
|
||||||
var shift = 0
|
copyMem(addr dst[0], unsafeAddr bytesLE[0], dst.len)
|
||||||
for i in 0 ..< dst.len:
|
|
||||||
result[i] = byte((v shr shift) and 0xff)
|
|
||||||
shift += 8
|
|
||||||
else:
|
|
||||||
copyMem(addr dst[0], unsafeAddr value, dst.len)
|
|
||||||
|
|
||||||
template loopOverWords(lhs, rhs: BitSeq,
|
template loopOverWords(lhs, rhs: BitSeq,
|
||||||
lhsIsVar, rhsIsVar: static bool,
|
lhsIsVar, rhsIsVar: static bool,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user