mirror of
https://github.com/KusakabeShi/EtherGuard-VPN.git
synced 2025-01-28 15:08:43 +01:00
3d83df9bf3
Since _32 and _64 aren't valid goarchs, they don't match _GOOS_GOARCH, and so the existing tags wind up not being restricted to windows-only. This fixes the problem by adding windows to the tags explicitly. We could also fix it by calling the files _32_windows or _64_windows, but that changes the convention with the other single-arch files. Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
37 lines
838 B
Go
37 lines
838 B
Go
// +build windows,amd64 windows,arm64
|
|
|
|
/* SPDX-License-Identifier: MIT
|
|
*
|
|
* Copyright (C) 2020 WireGuard LLC. All Rights Reserved.
|
|
*/
|
|
|
|
package memmod
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"golang.org/x/sys/windows"
|
|
)
|
|
|
|
func (opthdr *IMAGE_OPTIONAL_HEADER) imageOffset() uintptr {
|
|
return uintptr(opthdr.ImageBase & 0xffffffff00000000)
|
|
}
|
|
|
|
func (module *Module) check4GBBoundaries(alignedImageSize uintptr) (err error) {
|
|
for (module.codeBase >> 32) < ((module.codeBase + alignedImageSize) >> 32) {
|
|
node := &addressList{
|
|
next: module.blockedMemory,
|
|
address: module.codeBase,
|
|
}
|
|
module.blockedMemory = node
|
|
module.codeBase, err = windows.VirtualAlloc(0,
|
|
alignedImageSize,
|
|
windows.MEM_RESERVE|windows.MEM_COMMIT,
|
|
windows.PAGE_READWRITE)
|
|
if err != nil {
|
|
return fmt.Errorf("Error allocating memory block: %w", err)
|
|
}
|
|
}
|
|
return
|
|
}
|