2c5499b57c
Add support for the 32-bit RISC-V (RV32) ISA matching the 64-bit RISC-V (RV64) port except for async preemption added as a stub only. Reviewed-on: https://go-review.googlesource.com/c/gofrontend/+/251179
20 lines
599 B
Go
20 lines
599 B
Go
// Copyright 2014 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// +build 386 amd64p32 arm armbe m68k mips mipsle mips64p32 mips64p32le nios2 ppc riscv s390 sh shbe sparc
|
|
|
|
package runtime
|
|
|
|
import "unsafe"
|
|
|
|
// On 32-bit systems, the stored uint64 has a 32-bit pointer and 32-bit count.
|
|
|
|
func lfstackPack(node *lfnode, cnt uintptr) uint64 {
|
|
return uint64(uintptr(unsafe.Pointer(node)))<<32 | uint64(cnt)
|
|
}
|
|
|
|
func lfstackUnpack(val uint64) *lfnode {
|
|
return (*lfnode)(unsafe.Pointer(uintptr(val >> 32)))
|
|
}
|