mirror of
https://github.com/golang/go.git
synced 2025-05-30 19:52:53 +00:00
runtime: remove slow time compatibility hacks for wine
This reapplies CL 191759, which was reverted in CL 192622.
Wine fixed the compatibility issue more than 3 years
ago, in version 5.10 (see [1]). We no longer have to keep the compatibility hack on our side.
Updates #34021
[1]: 1ae1088964
Change-Id: I3b77701d01fdf58fbf350321fc0a957c0f247d32
Reviewed-on: https://go-review.googlesource.com/c/go/+/526358
Reviewed-by: Daniel Martí <mvdan@mvdan.cc>
Reviewed-by: Cherry Mui <cherryyz@google.com>
Reviewed-by: Bryan Mills <bcmills@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Run-TryBot: Quim Muntal <quimmuntal@gmail.com>
LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com>
This commit is contained in:
parent
31c1f4a611
commit
4beb33018b
@ -91,14 +91,12 @@ var (
|
||||
_GetStdHandle,
|
||||
_GetSystemDirectoryA,
|
||||
_GetSystemInfo,
|
||||
_GetSystemTimeAsFileTime,
|
||||
_GetThreadContext,
|
||||
_SetThreadContext,
|
||||
_LoadLibraryExW,
|
||||
_LoadLibraryW,
|
||||
_PostQueuedCompletionStatus,
|
||||
_QueryPerformanceCounter,
|
||||
_QueryPerformanceFrequency,
|
||||
_RaiseFailFastException,
|
||||
_ResumeThread,
|
||||
_SetConsoleCtrlHandler,
|
||||
@ -300,11 +298,6 @@ func loadOptionalSyscalls() {
|
||||
if _WSAGetOverlappedResult == nil {
|
||||
throw("WSAGetOverlappedResult not found")
|
||||
}
|
||||
|
||||
if windowsFindfunc(n32, []byte("wine_get_version\000")) != nil {
|
||||
// running on Wine
|
||||
initWine(k32)
|
||||
}
|
||||
}
|
||||
|
||||
func monitorSuspendResume() {
|
||||
@ -548,77 +541,6 @@ func osinit() {
|
||||
stdcall2(_SetProcessPriorityBoost, currentProcess, 1)
|
||||
}
|
||||
|
||||
// useQPCTime controls whether time.now and nanotime use QueryPerformanceCounter.
|
||||
// This is only set to 1 when running under Wine.
|
||||
var useQPCTime uint8
|
||||
|
||||
var qpcStartCounter int64
|
||||
var qpcMultiplier int64
|
||||
|
||||
//go:nosplit
|
||||
func nanotimeQPC() int64 {
|
||||
var counter int64 = 0
|
||||
stdcall1(_QueryPerformanceCounter, uintptr(unsafe.Pointer(&counter)))
|
||||
|
||||
// returns number of nanoseconds
|
||||
return (counter - qpcStartCounter) * qpcMultiplier
|
||||
}
|
||||
|
||||
//go:nosplit
|
||||
func nowQPC() (sec int64, nsec int32, mono int64) {
|
||||
var ft int64
|
||||
stdcall1(_GetSystemTimeAsFileTime, uintptr(unsafe.Pointer(&ft)))
|
||||
|
||||
t := (ft - 116444736000000000) * 100
|
||||
|
||||
sec = t / 1000000000
|
||||
nsec = int32(t - sec*1000000000)
|
||||
|
||||
mono = nanotimeQPC()
|
||||
return
|
||||
}
|
||||
|
||||
func initWine(k32 uintptr) {
|
||||
_GetSystemTimeAsFileTime = windowsFindfunc(k32, []byte("GetSystemTimeAsFileTime\000"))
|
||||
if _GetSystemTimeAsFileTime == nil {
|
||||
throw("could not find GetSystemTimeAsFileTime() syscall")
|
||||
}
|
||||
|
||||
_QueryPerformanceCounter = windowsFindfunc(k32, []byte("QueryPerformanceCounter\000"))
|
||||
_QueryPerformanceFrequency = windowsFindfunc(k32, []byte("QueryPerformanceFrequency\000"))
|
||||
if _QueryPerformanceCounter == nil || _QueryPerformanceFrequency == nil {
|
||||
throw("could not find QPC syscalls")
|
||||
}
|
||||
|
||||
// We can not simply fallback to GetSystemTimeAsFileTime() syscall, since its time is not monotonic,
|
||||
// instead we use QueryPerformanceCounter family of syscalls to implement monotonic timer
|
||||
// https://msdn.microsoft.com/en-us/library/windows/desktop/dn553408(v=vs.85).aspx
|
||||
|
||||
var tmp int64
|
||||
stdcall1(_QueryPerformanceFrequency, uintptr(unsafe.Pointer(&tmp)))
|
||||
if tmp == 0 {
|
||||
throw("QueryPerformanceFrequency syscall returned zero, running on unsupported hardware")
|
||||
}
|
||||
|
||||
// This should not overflow, it is a number of ticks of the performance counter per second,
|
||||
// its resolution is at most 10 per usecond (on Wine, even smaller on real hardware), so it will be at most 10 millions here,
|
||||
// panic if overflows.
|
||||
if tmp > (1<<31 - 1) {
|
||||
throw("QueryPerformanceFrequency overflow 32 bit divider, check nosplit discussion to proceed")
|
||||
}
|
||||
qpcFrequency := int32(tmp)
|
||||
stdcall1(_QueryPerformanceCounter, uintptr(unsafe.Pointer(&qpcStartCounter)))
|
||||
|
||||
// Since we are supposed to run this time calls only on Wine, it does not lose precision,
|
||||
// since Wine's timer is kind of emulated at 10 Mhz, so it will be a nice round multiplier of 100
|
||||
// but for general purpose system (like 3.3 Mhz timer on i7) it will not be very precise.
|
||||
// We have to do it this way (or similar), since multiplying QPC counter by 100 millions overflows
|
||||
// int64 and resulted time will always be invalid.
|
||||
qpcMultiplier = int64(timediv(1000000000, qpcFrequency, nil))
|
||||
|
||||
useQPCTime = 1
|
||||
}
|
||||
|
||||
//go:nosplit
|
||||
func getRandomData(r []byte) {
|
||||
n := 0
|
||||
|
@ -251,8 +251,6 @@ TEXT runtime·switchtothread(SB),NOSPLIT,$0
|
||||
RET
|
||||
|
||||
TEXT runtime·nanotime1(SB),NOSPLIT,$0-8
|
||||
CMPB runtime·useQPCTime(SB), $0
|
||||
JNE useQPC
|
||||
loop:
|
||||
MOVL (_INTERRUPT_TIME+time_hi1), AX
|
||||
MOVL (_INTERRUPT_TIME+time_lo), CX
|
||||
@ -269,9 +267,6 @@ loop:
|
||||
MOVL AX, ret_lo+0(FP)
|
||||
MOVL DX, ret_hi+4(FP)
|
||||
RET
|
||||
useQPC:
|
||||
JMP runtime·nanotimeQPC(SB)
|
||||
RET
|
||||
|
||||
// This is called from rt0_go, which runs on the system stack
|
||||
// using the initial stack allocated by the OS.
|
||||
|
@ -265,16 +265,11 @@ TEXT runtime·switchtothread(SB),NOSPLIT,$0
|
||||
RET
|
||||
|
||||
TEXT runtime·nanotime1(SB),NOSPLIT,$0-8
|
||||
CMPB runtime·useQPCTime(SB), $0
|
||||
JNE useQPC
|
||||
MOVQ $_INTERRUPT_TIME, DI
|
||||
MOVQ time_lo(DI), AX
|
||||
IMULQ $100, AX
|
||||
MOVQ AX, ret+0(FP)
|
||||
RET
|
||||
useQPC:
|
||||
JMP runtime·nanotimeQPC(SB)
|
||||
RET
|
||||
|
||||
// func osSetupTLS(mp *m)
|
||||
// Setup TLS. for use by needm on Windows.
|
||||
|
@ -231,11 +231,6 @@ TEXT runtime·read_tls_fallback(SB),NOSPLIT,$0
|
||||
RET
|
||||
|
||||
TEXT runtime·nanotime1(SB),NOSPLIT,$0-8
|
||||
MOVW $0, R0
|
||||
MOVB runtime·useQPCTime(SB), R0
|
||||
CMP $0, R0
|
||||
BNE useQPC
|
||||
MOVW $_INTERRUPT_TIME, R3
|
||||
loop:
|
||||
MOVW time_hi1(R3), R1
|
||||
DMB MB_ISH
|
||||
@ -254,8 +249,6 @@ loop:
|
||||
MOVW R3, ret_lo+0(FP)
|
||||
MOVW R4, ret_hi+4(FP)
|
||||
RET
|
||||
useQPC:
|
||||
RET runtime·nanotimeQPC(SB) // tail call
|
||||
|
||||
// save_g saves the g register (R10) into thread local memory
|
||||
// so that we can call externally compiled
|
||||
|
@ -249,17 +249,12 @@ TEXT runtime·switchtothread(SB),NOSPLIT,$16-0
|
||||
RET
|
||||
|
||||
TEXT runtime·nanotime1(SB),NOSPLIT,$0-8
|
||||
MOVB runtime·useQPCTime(SB), R0
|
||||
CMP $0, R0
|
||||
BNE useQPC
|
||||
MOVD $_INTERRUPT_TIME, R3
|
||||
MOVD time_lo(R3), R0
|
||||
MOVD $100, R1
|
||||
MUL R1, R0
|
||||
MOVD R0, ret+0(FP)
|
||||
RET
|
||||
useQPC:
|
||||
RET runtime·nanotimeQPC(SB) // tail call
|
||||
|
||||
// This is called from rt0_go, which runs on the system stack
|
||||
// using the initial stack allocated by the OS.
|
||||
|
@ -9,8 +9,6 @@
|
||||
#include "time_windows.h"
|
||||
|
||||
TEXT time·now(SB),NOSPLIT,$0-20
|
||||
CMPB runtime·useQPCTime(SB), $0
|
||||
JNE useQPC
|
||||
loop:
|
||||
MOVL (_INTERRUPT_TIME+time_hi1), AX
|
||||
MOVL (_INTERRUPT_TIME+time_lo), CX
|
||||
@ -79,6 +77,3 @@ wall:
|
||||
MOVL AX, sec+0(FP)
|
||||
MOVL DX, sec+4(FP)
|
||||
RET
|
||||
useQPC:
|
||||
JMP runtime·nowQPC(SB)
|
||||
RET
|
||||
|
@ -9,9 +9,6 @@
|
||||
#include "time_windows.h"
|
||||
|
||||
TEXT time·now(SB),NOSPLIT,$0-24
|
||||
CMPB runtime·useQPCTime(SB), $0
|
||||
JNE useQPC
|
||||
|
||||
MOVQ $_INTERRUPT_TIME, DI
|
||||
MOVQ time_lo(DI), AX
|
||||
IMULQ $100, AX
|
||||
@ -37,6 +34,3 @@ TEXT time·now(SB),NOSPLIT,$0-24
|
||||
SUBQ DX, CX
|
||||
MOVL CX, nsec+8(FP)
|
||||
RET
|
||||
useQPC:
|
||||
JMP runtime·nowQPC(SB)
|
||||
RET
|
||||
|
@ -9,10 +9,6 @@
|
||||
#include "time_windows.h"
|
||||
|
||||
TEXT time·now(SB),NOSPLIT,$0-20
|
||||
MOVW $0, R0
|
||||
MOVB runtime·useQPCTime(SB), R0
|
||||
CMP $0, R0
|
||||
BNE useQPC
|
||||
MOVW $_INTERRUPT_TIME, R3
|
||||
loop:
|
||||
MOVW time_hi1(R3), R1
|
||||
@ -85,6 +81,4 @@ wall:
|
||||
MOVW R7,sec_hi+4(FP)
|
||||
MOVW R1,nsec+8(FP)
|
||||
RET
|
||||
useQPC:
|
||||
RET runtime·nowQPC(SB) // tail call
|
||||
|
||||
|
@ -9,10 +9,6 @@
|
||||
#include "time_windows.h"
|
||||
|
||||
TEXT time·now(SB),NOSPLIT,$0-24
|
||||
MOVB runtime·useQPCTime(SB), R0
|
||||
CMP $0, R0
|
||||
BNE useQPC
|
||||
|
||||
MOVD $_INTERRUPT_TIME, R3
|
||||
MOVD time_lo(R3), R0
|
||||
MOVD $100, R1
|
||||
@ -42,6 +38,4 @@ TEXT time·now(SB),NOSPLIT,$0-24
|
||||
MSUB R1, R0, R2, R0
|
||||
MOVW R0, nsec+8(FP)
|
||||
RET
|
||||
useQPC:
|
||||
RET runtime·nowQPC(SB) // tail call
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user