| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- // MIT License
- // Copyright (c) 2019 Ewan Chou
- // Permission is hereby granted, free of charge, to any person obtaining a copy
- // of this software and associated documentation files (the "Software"), to deal
- // in the Software without restriction, including without limitation the rights
- // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- // copies of the Software, and to permit persons to whom the Software is
- // furnished to do so, subject to the following conditions:
- // The above copyright notice and this permission notice shall be included in all
- // copies or substantial portions of the Software.
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- // SOFTWARE.
- package z
- import (
- "unsafe"
- )
- // NanoTime returns the current time in nanoseconds from a monotonic clock.
- //
- //go:linkname NanoTime runtime.nanotime
- func NanoTime() int64
- // CPUTicks is a faster alternative to NanoTime to measure time duration.
- //
- //go:linkname CPUTicks runtime.cputicks
- func CPUTicks() int64
- type stringStruct struct {
- str unsafe.Pointer
- len int
- }
- //go:noescape
- //go:linkname memhash runtime.memhash
- func memhash(p unsafe.Pointer, h, s uintptr) uintptr
- // MemHash is the hash function used by go map, it utilizes available hardware instructions(behaves
- // as aeshash if aes instruction is available).
- // NOTE: The hash seed changes for every process. So, this cannot be used as a persistent hash.
- func MemHash(data []byte) uint64 {
- ss := (*stringStruct)(unsafe.Pointer(&data))
- return uint64(memhash(ss.str, 0, uintptr(ss.len)))
- }
- // MemHashString is the hash function used by go map, it utilizes available hardware instructions
- // (behaves as aeshash if aes instruction is available).
- // NOTE: The hash seed changes for every process. So, this cannot be used as a persistent hash.
- func MemHashString(str string) uint64 {
- ss := (*stringStruct)(unsafe.Pointer(&str))
- return uint64(memhash(ss.str, 0, uintptr(ss.len)))
- }
- // FastRand is a fast thread local random function.
- //
- //go:linkname FastRand runtime.fastrand
- func FastRand() uint32
- //go:linkname memclrNoHeapPointers runtime.memclrNoHeapPointers
- func memclrNoHeapPointers(p unsafe.Pointer, n uintptr)
- func Memclr(b []byte) {
- if len(b) == 0 {
- return
- }
- p := unsafe.Pointer(&b[0])
- memclrNoHeapPointers(p, uintptr(len(b)))
- }
|