mirror of
https://gitlab.com/pulsechaincom/go-pulse.git
synced 2025-01-19 00:24:12 +00:00
9effd64290
* core, eth, trie: bloom filter for trie node dedup during fast sync * eth/downloader, trie: address review comments * core, ethdb, trie: restart fast-sync bloom construction now and again * eth/downloader: initialize fast sync bloom on startup * eth: reenable eth/62 until we properly remove it
65 lines
1.4 KiB
ArmAsm
65 lines
1.4 KiB
ArmAsm
//
|
|
// hamming distance calculations in Go
|
|
//
|
|
// https://github.com/steakknife/hamming
|
|
//
|
|
// Copyright © 2014, 2015, 2016 Barry Allard
|
|
//
|
|
// MIT license
|
|
//
|
|
|
|
#include "textflag.h"
|
|
|
|
TEXT ·CountBitsInt8PopCnt(SB),NOSPLIT,$0
|
|
JMP ·CountBitsBytePopCnt(SB)
|
|
|
|
TEXT ·CountBitsInt16PopCnt(SB),NOSPLIT,$0
|
|
JMP ·CountBitsUint16PopCnt(SB)
|
|
|
|
TEXT ·CountBitsInt32PopCnt(SB),NOSPLIT,$0
|
|
JMP ·CountBitsUint32PopCnt(SB)
|
|
|
|
TEXT ·CountBitsInt64PopCnt(SB),NOSPLIT,$0
|
|
JMP ·CountBitsUint64PopCnt(SB)
|
|
|
|
TEXT ·CountBitsBytePopCnt(SB),NOSPLIT,$0
|
|
JMP ·CountBitsUint8PopCnt(SB)
|
|
|
|
TEXT ·CountBitsRunePopCnt(SB),NOSPLIT,$0
|
|
JMP ·CountBitsUint32PopCnt(SB)
|
|
|
|
TEXT ·CountBitsUint8PopCnt(SB),NOSPLIT,$0
|
|
XORQ AX, AX
|
|
MOVB x+0(FP), AX
|
|
POPCNTQ AX, AX
|
|
MOVQ AX, ret+8(FP)
|
|
RET
|
|
|
|
TEXT ·CountBitsUint16PopCnt(SB),NOSPLIT,$0
|
|
XORQ AX, AX
|
|
MOVW x+0(FP), AX
|
|
POPCNTQ AX, AX
|
|
MOVQ AX, ret+8(FP)
|
|
RET
|
|
|
|
TEXT ·CountBitsUint32PopCnt(SB),NOSPLIT,$0
|
|
XORQ AX, AX
|
|
MOVL x+0(FP), AX
|
|
POPCNTQ AX, AX
|
|
MOVQ AX, ret+8(FP)
|
|
RET
|
|
|
|
TEXT ·CountBitsUint64PopCnt(SB),NOSPLIT,$0
|
|
POPCNTQ x+0(FP), AX
|
|
MOVQ AX, ret+8(FP)
|
|
RET
|
|
|
|
// func hasPopCnt() (ret bool)
|
|
TEXT ·HasPopCnt(SB),NOSPLIT,$0
|
|
MOVL $1, AX
|
|
CPUID
|
|
SHRL $23, CX // bit 23: Advanced Bit Manipulation Bit (ABM) -> POPCNTQ
|
|
ANDL $1, CX
|
|
MOVB CX, ret+0(FP)
|
|
RET
|