aboutsummaryrefslogtreecommitdiffstats
path: root/tun (follow)
Commit message (Collapse)AuthorAgeFilesLines
* tun: windows: expose GUIDJason A. Donenfeld2019-03-011-0/+4
|
* tun: allow special methods in NativeTunJason A. Donenfeld2019-03-016-65/+65
|
* tun: linux: netpoll is broken for tun's epollJason A. Donenfeld2019-02-271-27/+48
| | | | | | So this mostly reverts the switch to Sysconn for Linux. Issue: https://github.com/golang/go/issues/30426
* tun: linux: netlink sock needs cleaning up but file will be gc'dJason A. Donenfeld2019-02-271-4/+2
|
* tun: use netpoll instead of rwcancelJason A. Donenfeld2019-02-275-138/+34
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The new sysconn function of Go 1.12 makes this possible: package main import "log" import "os" import "unsafe" import "time" import "syscall" import "sync" import "golang.org/x/sys/unix" func main() { fd, err := os.OpenFile("/dev/net/tun", os.O_RDWR, 0) if err != nil { log.Fatal(err) } var ifr [unix.IFNAMSIZ + 64]byte copy(ifr[:], []byte("cheese")) *(*uint16)(unsafe.Pointer(&ifr[unix.IFNAMSIZ])) = unix.IFF_TUN var errno syscall.Errno s, _ := fd.SyscallConn() s.Control(func(fd uintptr) { _, _, errno = unix.Syscall( unix.SYS_IOCTL, fd, uintptr(unix.TUNSETIFF), uintptr(unsafe.Pointer(&ifr[0])), ) }) if errno != 0 { log.Fatal(errno) } b := [4]byte{} wait := sync.WaitGroup{} wait.Add(1) go func() { _, err := fd.Read(b[:]) log.Print("Read errored: ", err) wait.Done() }() time.Sleep(time.Second) log.Print("Closing") err = fd.Close() if err != nil { log.Print("Close errored: " , err) } wait.Wait() log.Print("Exiting") }
* tun: use sysconn instead of .Fd with Go 1.12Jason A. Donenfeld2019-02-275-54/+79
|
* wintun: Read/write packet size from/to exchange buffer directlySimon Rozman2019-02-221-3/+3
| | | | | | Driver <-> user-space communication is local and using native endian. Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Make two-step slicing a one stepSimon Rozman2019-02-221-3/+3
| | | | | | | Stop relying to Go compiler optimizations and calculate the end offset directly. Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Write exchange buffer increased back to 1MiBSimon Rozman2019-02-201-5/+4
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Migrate from unsafe buffer handling to encoding/binarySimon Rozman2019-02-201-5/+8
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Adopt new packet data alignmentSimon Rozman2019-02-201-10/+10
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: CleanupSimon Rozman2019-02-201-2/+2
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Add TUN device lockingSimon Rozman2019-02-201-40/+64
| | | | | | | | | | | | In case reading from TUN device detected TUN device was closed, it closed the file handle and set tunFile to nil. The tunFile is automatically reopened on retry, but... If another packet comes in the WireGuard calls Write() method. With tunFile set to nil, this will cause access violation. Therefore, locking was introduced. Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Move exchange buffer in separate struct on heapSimon Rozman2019-02-201-33/+44
| | | | | | | | | This allows buffer alignment and keeps it together with its meta-data. Furthermore, the write buffer has been reduced - as long as we flush after _every_ write, we don't need a 1MiB write buffer. Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Switch to dynamic packet sizesSimon Rozman2019-02-191-50/+46
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* Change package pathJason A. Donenfeld2019-02-187-8/+8
|
* wintun: Auto-calculate TUN exchange buffer sizeSimon Rozman2019-02-081-8/+7
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Simplify Read method()Simon Rozman2019-02-081-51/+51
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Make constants private and adopt Go recommended caseSimon Rozman2019-02-081-29/+29
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Check for user close in read loop regardless the loadSimon Rozman2019-02-081-24/+22
| | | | | | | | | Do the WaitForSingleObject() always to provide high-load responsiveness. Reorder events so TUN_SIGNAL_CLOSE has priority over TUN_SIGNAL_DATA_AVAIL, to provide high-load responsiveness at all. Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Adjust tunRWQueue.left member to match Wintun driverSimon Rozman2019-02-081-2/+2
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* setupapi: Merge _SP_DRVINFO_DETAIL_DATA and DrvInfoDetailDataSimon Rozman2019-02-074-55/+60
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* setupapi: Merge SP_DRVINFO_DATA and DrvInfoDataSimon Rozman2019-02-074-78/+78
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* setupapi: Rename SP_REMOVEDEVICE_PARAMS to RemoveDeviceParamsSimon Rozman2019-02-072-4/+4
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* setupapi: Rename SP_CLASSINSTALL_HEADER to ClassInstallHeaderSimon Rozman2019-02-074-20/+20
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* setupapi: Merge _SP_DEVINSTALL_PARAMS and DevInstallParamsSimon Rozman2019-02-074-63/+25
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* setupapi: Merge _SP_DEVINFO_LIST_DETAIL_DATA and DevInfoListDetailDataSimon Rozman2019-02-074-26/+26
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* setupapi: Rename SP_DEVINFO_DATA to DevInfoDataSimon Rozman2019-02-074-81/+81
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Detect if a foreign interface with the same name existsSimon Rozman2019-02-072-6/+49
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Clean excessive setupapi.DevInfo.GetDeviceInfoListDetail() callSimon Rozman2019-02-071-14/+0
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Explain rationale behind case-insensitive interface namesSimon Rozman2019-02-071-1/+5
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: Implement TODO in TestSetupDiGetDeviceRegistryProperty()Simon Rozman2019-02-071-3/+11
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* wintun: add FlushInterface stubJason A. Donenfeld2019-02-072-4/+18
|
* wintun: Compare values of GUID, not pointers, when removingJason A. Donenfeld2019-02-071-1/+1
|
* wintun: Introduce new package for obscuring Windows bitsJason A. Donenfeld2019-02-0711-481/+2424
|
* tun_windows: StyleJason A. Donenfeld2019-02-071-11/+13
|
* tun_windows: Introduce preliminary TUN interface creationSimon Rozman2019-02-062-5/+541
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* tun_windows: Stop checking minimum size of received TUN packetsSimon Rozman2019-02-061-2/+1
| | | | Signed-off-by: Simon Rozman <simon@rozman.si>
* Fix up errors and pathsJason A. Donenfeld2019-02-051-7/+7
|
* Import windows scafoldingJason A. Donenfeld2019-02-051-0/+286
|
* Update copyrightJason A. Donenfeld2019-02-055-10/+10
|
* tun: remove nonblock hack for linuxJason A. Donenfeld2018-12-061-10/+0
| | | | | | This is no longer necessary and actually breaks things Reported-by: Chris Branch <cbranch@cloudflare.com>
* Use darwin tun on iosJason A. Donenfeld2018-11-061-2/+0
|
* tun: only call .Fd() onceJason A. Donenfeld2018-10-174-61/+67
| | | | | Doing so tends to make the tunnel blocking, so we only retrieve it once before we call SetNonblock, and then cache the result.
* global: fix up copyright headersJason A. Donenfeld2018-09-165-8/+5
|
* Fix duplicate copyright lineJason A. Donenfeld2018-07-301-2/+0
|
* Do not build tun device on iosJason A. Donenfeld2018-06-091-0/+2
|
* Disable broadcast mode on *BSDJason A. Donenfeld2018-05-272-26/+0
| | | | Keeping it on makes IPv6 problematic and confuses routing daemons.
* Catch EINTRJason A. Donenfeld2018-05-244-12/+24
|
* Adopt GOPATHJason A. Donenfeld2018-05-234-4/+4
| | | | | GOPATH is annoying, but the Go community pushing me to adopt it is even more annoying.