mirror of
https://github.com/golang/go
synced 2024-11-19 09:54:49 -07:00
[dev.cc] runtime: convert power64-specific .c and .h files to Go
The power64 equivalent of CL 174860043 LGTM=rsc R=rsc CC=golang-codereviews https://golang.org/cl/179890043
This commit is contained in:
parent
3f27c3ae37
commit
0da27cb8b0
15
src/runtime/arch1_power64.go
Normal file
15
src/runtime/arch1_power64.go
Normal file
@ -0,0 +1,15 @@
|
||||
// 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.
|
||||
|
||||
package runtime
|
||||
|
||||
const (
|
||||
thechar = '9'
|
||||
_BigEndian = 1
|
||||
_CacheLineSize = 64
|
||||
_RuntimeGogoBytes = 64
|
||||
_PhysPageSize = 65536
|
||||
_PCQuantum = 4
|
||||
_Int64Align = 8
|
||||
)
|
15
src/runtime/arch1_power64le.go
Normal file
15
src/runtime/arch1_power64le.go
Normal file
@ -0,0 +1,15 @@
|
||||
// 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.
|
||||
|
||||
package runtime
|
||||
|
||||
const (
|
||||
thechar = '9'
|
||||
_BigEndian = 0
|
||||
_CacheLineSize = 64
|
||||
_RuntimeGogoBytes = 64
|
||||
_PhysPageSize = 65536
|
||||
_PCQuantum = 4
|
||||
_Int64Align = 8
|
||||
)
|
@ -1,14 +0,0 @@
|
||||
// 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.
|
||||
|
||||
enum {
|
||||
thechar = '9',
|
||||
BigEndian = 1,
|
||||
CacheLineSize = 64,
|
||||
RuntimeGogoBytes = 64,
|
||||
PhysPageSize = 65536,
|
||||
PCQuantum = 4,
|
||||
Int64Align = 8
|
||||
};
|
||||
|
@ -1,14 +0,0 @@
|
||||
// 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.
|
||||
|
||||
enum {
|
||||
thechar = '9',
|
||||
BigEndian = 0,
|
||||
CacheLineSize = 64,
|
||||
RuntimeGogoBytes = 64,
|
||||
PhysPageSize = 65536,
|
||||
PCQuantum = 4,
|
||||
Int64Align = 8
|
||||
};
|
||||
|
69
src/runtime/atomic_power64x.go
Normal file
69
src/runtime/atomic_power64x.go
Normal file
@ -0,0 +1,69 @@
|
||||
// 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 power64 power64le
|
||||
|
||||
package runtime
|
||||
|
||||
import "unsafe"
|
||||
|
||||
//go:noescape
|
||||
func xadd(ptr *uint32, delta int32) uint32
|
||||
|
||||
//go:noescape
|
||||
func xadd64(ptr *uint64, delta int64) uint64
|
||||
|
||||
//go:noescape
|
||||
func xchg(ptr *uint32, new uint32) uint32
|
||||
|
||||
//go:noescape
|
||||
func xchg64(ptr *uint64, new uint64) uint64
|
||||
|
||||
// xchgp cannot have a go:noescape annotation, because
|
||||
// while ptr does not escape, new does. If new is marked as
|
||||
// not escaping, the compiler will make incorrect escape analysis
|
||||
// decisions about the value being xchg'ed.
|
||||
// Instead, make xchgp a wrapper around the actual atomic.
|
||||
// When calling the wrapper we mark ptr as noescape explicitly.
|
||||
|
||||
//go:nosplit
|
||||
func xchgp(ptr unsafe.Pointer, new unsafe.Pointer) unsafe.Pointer {
|
||||
return xchgp1(noescape(ptr), new)
|
||||
}
|
||||
|
||||
func xchgp1(ptr unsafe.Pointer, new unsafe.Pointer) unsafe.Pointer
|
||||
|
||||
//go:noescape
|
||||
func xchguintptr(ptr *uintptr, new uintptr) uintptr
|
||||
|
||||
//go:noescape
|
||||
func atomicload(ptr *uint32) uint32
|
||||
|
||||
//go:noescape
|
||||
func atomicload64(ptr *uint64) uint64
|
||||
|
||||
//go:noescape
|
||||
func atomicloadp(ptr unsafe.Pointer) unsafe.Pointer
|
||||
|
||||
//go:noescape
|
||||
func atomicor8(ptr *uint8, val uint8)
|
||||
|
||||
//go:noescape
|
||||
func cas64(ptr *uint64, old, new uint64) bool
|
||||
|
||||
//go:noescape
|
||||
func atomicstore(ptr *uint32, val uint32)
|
||||
|
||||
//go:noescape
|
||||
func atomicstore64(ptr *uint64, val uint64)
|
||||
|
||||
// atomicstorep cannot have a go:noescape annotation.
|
||||
// See comment above for xchgp.
|
||||
|
||||
//go:nosplit
|
||||
func atomicstorep(ptr unsafe.Pointer, new unsafe.Pointer) {
|
||||
atomicstorep1(noescape(ptr), new)
|
||||
}
|
||||
|
||||
func atomicstorep1(ptr unsafe.Pointer, val unsafe.Pointer)
|
@ -1,38 +0,0 @@
|
||||
// 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 power64 power64le
|
||||
|
||||
#include "runtime.h"
|
||||
|
||||
// adjust Gobuf as if it executed a call to fn with context ctxt
|
||||
// and then did an immediate Gosave.
|
||||
void
|
||||
runtime·gostartcall(Gobuf *gobuf, void (*fn)(void), void *ctxt)
|
||||
{
|
||||
if(gobuf->lr != 0)
|
||||
runtime·throw("invalid use of gostartcall");
|
||||
gobuf->lr = gobuf->pc;
|
||||
gobuf->pc = (uintptr)fn;
|
||||
gobuf->ctxt = ctxt;
|
||||
}
|
||||
|
||||
// Called to rewind context saved during morestack back to beginning of function.
|
||||
// To help us, the linker emits a jmp back to the beginning right after the
|
||||
// call to morestack. We just have to decode and apply that jump.
|
||||
void
|
||||
runtime·rewindmorestack(Gobuf *gobuf)
|
||||
{
|
||||
uint32 inst;
|
||||
|
||||
inst = *(uint32*)gobuf->pc;
|
||||
if((gobuf->pc&3) == 0 && (inst>>24) == 0x4b && (inst&3) == 0) {
|
||||
//runtime·printf("runtime: rewind pc=%p to pc=%p\n", gobuf->pc, gobuf->pc + ((int32)(inst<<8)>>8));
|
||||
gobuf->pc += (int32)(inst<<8)>>8;
|
||||
return;
|
||||
}
|
||||
runtime·printf("runtime: pc=%p %x\n", gobuf->pc, inst);
|
||||
runtime·throw("runtime: misuse of rewindmorestack");
|
||||
}
|
||||
|
37
src/runtime/sys_power64x.go
Normal file
37
src/runtime/sys_power64x.go
Normal file
@ -0,0 +1,37 @@
|
||||
// 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 power64 power64le
|
||||
|
||||
package runtime
|
||||
|
||||
import "unsafe"
|
||||
|
||||
// adjust Gobuf as if it executed a call to fn with context ctxt
|
||||
// and then did an immediate Gosave.
|
||||
func gostartcall(buf *gobuf, fn, ctxt unsafe.Pointer) {
|
||||
if buf.lr != 0 {
|
||||
gothrow("invalid use of gostartcall")
|
||||
}
|
||||
buf.lr = buf.pc
|
||||
buf.pc = uintptr(fn)
|
||||
buf.ctxt = ctxt
|
||||
}
|
||||
|
||||
// Called to rewind context saved during morestack back to beginning of function.
|
||||
// To help us, the linker emits a jmp back to the beginning right after the
|
||||
// call to morestack. We just have to decode and apply that jump.
|
||||
func rewindmorestack(buf *gobuf) {
|
||||
var inst uint32
|
||||
if buf.pc&3 == 0 && buf.pc != 0 {
|
||||
inst = *(*uint32)(unsafe.Pointer(buf.pc))
|
||||
if inst>>24 == 0x4b && inst&3 == 0 {
|
||||
//print("runtime: rewind pc=", hex(buf.pc), " to pc=", hex(uintptr(buf.pc + int32(inst<<8)>>8)), "\n");
|
||||
buf.pc += uintptr(int32(inst<<8) >> 8)
|
||||
return
|
||||
}
|
||||
}
|
||||
print("runtime: pc=", hex(buf.pc), " ", hex(inst), "\n")
|
||||
gothrow("runtime: misuse of rewindmorestack")
|
||||
}
|
Loading…
Reference in New Issue
Block a user