From 60b3766b89b9cc664d9bbdc9ab34b283e0374d21 Mon Sep 17 00:00:00 2001 From: "Jason A. Donenfeld" Date: Wed, 11 Nov 2020 18:51:44 +0100 Subject: wintun: load from filesystem by default We let people loading this from resources opt in via: go build -tags load_wintun_from_rsrc Signed-off-by: Jason A. Donenfeld --- tun/wintun/dll_windows.go | 40 +--------------------------------------- 1 file changed, 1 insertion(+), 39 deletions(-) (limited to 'tun/wintun/dll_windows.go') diff --git a/tun/wintun/dll_windows.go b/tun/wintun/dll_windows.go index 4a55e97..9f04f73 100644 --- a/tun/wintun/dll_windows.go +++ b/tun/wintun/dll_windows.go @@ -10,50 +10,12 @@ import ( "sync" "sync/atomic" "unsafe" - - "golang.org/x/sys/windows" - "golang.zx2c4.com/wireguard/tun/wintun/memmod" - "golang.zx2c4.com/wireguard/tun/wintun/resource" ) -type lazyDLL struct { - Name string - mu sync.Mutex - module *memmod.Module -} - func newLazyDLL(name string) *lazyDLL { return &lazyDLL{Name: name} } -func (d *lazyDLL) Load() error { - if atomic.LoadPointer((*unsafe.Pointer)(unsafe.Pointer(&d.module))) != nil { - return nil - } - d.mu.Lock() - defer d.mu.Unlock() - if d.module != nil { - return nil - } - - const ourModule windows.Handle = 0 - resInfo, err := resource.FindByName(ourModule, d.Name, resource.RT_RCDATA) - if err != nil { - return fmt.Errorf("Unable to find \"%v\" RCDATA resource: %w", d.Name, err) - } - data, err := resource.Load(ourModule, resInfo) - if err != nil { - return fmt.Errorf("Unable to load resource: %w", err) - } - module, err := memmod.LoadLibrary(data) - if err != nil { - return fmt.Errorf("Unable to load library: %w", err) - } - - atomic.StorePointer((*unsafe.Pointer)(unsafe.Pointer(&d.module)), unsafe.Pointer(module)) - return nil -} - func (d *lazyDLL) NewProc(name string) *lazyProc { return &lazyProc{dll: d, Name: name} } @@ -79,7 +41,7 @@ func (p *lazyProc) Find() error { if err != nil { return fmt.Errorf("Error loading %v DLL: %w", p.dll.Name, err) } - addr, err := p.dll.module.ProcAddressByName(p.Name) + addr, err := p.nameToAddr() if err != nil { return fmt.Errorf("Error getting %v address: %w", p.Name, err) } -- cgit v1.2.3