From 554fd8c5195424bdbcabf5de30fdc183aba391bd Mon Sep 17 00:00:00 2001 From: upstream source tree Date: Sun, 15 Mar 2015 20:14:05 -0400 Subject: obtained gcc-4.6.4.tar.bz2 from upstream website; verified gcc-4.6.4.tar.bz2.sig; imported gcc-4.6.4 source tree from verified upstream tarball. downloading a git-generated archive based on the 'upstream' tag should provide you with a source tree that is binary identical to the one extracted from the above tarball. if you have obtained the source via the command 'git clone', however, do note that line-endings of files in your working directory might differ from line-endings of the respective files in the upstream repository. --- libgo/go/net/fd_rtems.go | 137 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 137 insertions(+) create mode 100644 libgo/go/net/fd_rtems.go (limited to 'libgo/go/net/fd_rtems.go') diff --git a/libgo/go/net/fd_rtems.go b/libgo/go/net/fd_rtems.go new file mode 100644 index 000000000..61759ca6e --- /dev/null +++ b/libgo/go/net/fd_rtems.go @@ -0,0 +1,137 @@ +// Copyright 2010 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. + +// Waiting for FDs via select(2). + +package net + +import ( + "os" + "syscall" +) + +type pollster struct { + readFds, writeFds, repeatFds *syscall.FdSet_t + maxFd int + readyReadFds, readyWriteFds *syscall.FdSet_t + nReady int + lastFd int +} + +func newpollster() (p *pollster, err os.Error) { + p = new(pollster) + p.readFds = new(syscall.FdSet_t) + p.writeFds = new(syscall.FdSet_t) + p.repeatFds = new(syscall.FdSet_t) + p.readyReadFds = new(syscall.FdSet_t) + p.readyWriteFds = new(syscall.FdSet_t) + p.maxFd = -1 + p.nReady = 0 + p.lastFd = 0 + return p, nil +} + +func (p *pollster) AddFD(fd int, mode int, repeat bool) os.Error { + if mode == 'r' { + syscall.FDSet(fd, p.readFds) + } else { + syscall.FDSet(fd, p.writeFds) + } + + if repeat { + syscall.FDSet(fd, p.repeatFds) + } + + if fd > p.maxFd { + p.maxFd = fd + } + + return nil +} + +func (p *pollster) DelFD(fd int, mode int) { + if mode == 'r' { + if !syscall.FDIsSet(fd, p.readFds) { + print("Select unexpected fd=", fd, " for read\n") + return + } + syscall.FDClr(fd, p.readFds) + } else { + if !syscall.FDIsSet(fd, p.writeFds) { + print("Select unexpected fd=", fd, " for write\n") + return + } + syscall.FDClr(fd, p.writeFds) + } + + // Doesn't matter if not already present. + syscall.FDClr(fd, p.repeatFds) + + // We don't worry about maxFd here. +} + +func (p *pollster) WaitFD(nsec int64) (fd int, mode int, err os.Error) { + if p.nReady == 0 { + var timeout *syscall.Timeval + var tv syscall.Timeval + timeout = nil + if nsec > 0 { + tv = syscall.NsecToTimeval(nsec) + timeout = &tv + } + + var n, e int + var tmpReadFds, tmpWriteFds syscall.FdSet_t + for { + // Temporary syscall.FdSet_ts into which the values are copied + // because select mutates the values. + tmpReadFds = *p.readFds + tmpWriteFds = *p.writeFds + + n, e = syscall.Select(p.maxFd + 1, &tmpReadFds, &tmpWriteFds, nil, timeout) + if e != syscall.EINTR { + break + } + } + if e != 0 { + return -1, 0, os.NewSyscallError("select", e) + } + if n == 0 { + return -1, 0, nil + } + + p.nReady = n + *p.readyReadFds = tmpReadFds + *p.readyWriteFds = tmpWriteFds + p.lastFd = 0 + } + + flag := false + for i := p.lastFd; i < p.maxFd + 1; i++ { + if syscall.FDIsSet(i, p.readyReadFds) { + flag = true + mode = 'r' + syscall.FDClr(i, p.readyReadFds) + } else if syscall.FDIsSet(i, p.readyWriteFds) { + flag = true + mode = 'w' + syscall.FDClr(i, p.readyWriteFds) + } + if flag { + if !syscall.FDIsSet(i, p.repeatFds) { + p.DelFD(i, mode) + } + p.nReady-- + p.lastFd = i + return i, mode, nil + } + } + + // Will not reach here. Just to shut up the compiler. + return -1, 0, nil +} + +func (p *pollster) Close() os.Error { + return nil +} -- cgit v1.2.3