本文整理匯總了Golang中github.com/lunixbochs/usercorn/go/kernel/common.Buf類的典型用法代碼示例。如果您正苦於以下問題:Golang Buf類的具體用法?Golang Buf怎麽用?Golang Buf使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Buf類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: Sendto
func (k *PosixKernel) Sendto(fd co.Fd, buf co.Buf, size co.Len, flags int, sa syscall.Sockaddr, socklen co.Len) uint64 {
msg := make([]byte, size)
if err := buf.Unpack(msg); err != nil {
return UINT64_MAX // FIXME
}
return Errno(syscall.Sendto(int(fd), msg, flags, sa))
}
示例2: Pack
func Pack(buf co.Buf, i interface{}) error {
switch v := i.(type) {
case *syscall.Statfs_t:
return buf.Pack(native.StatfsToLinux(v))
default:
return argjoy.NoMatch
}
}
示例3: Write
func (k *PosixKernel) Write(fd co.Fd, buf co.Buf, size co.Len) uint64 {
tmp := make([]byte, size)
if err := buf.Unpack(tmp); err != nil {
return UINT64_MAX // FIXME
}
n, err := syscall.Write(int(fd), tmp)
if err != nil {
return Errno(err)
}
return uint64(n)
}
示例4: Lstat
func (k *PosixKernel) Lstat(path string, buf co.Buf) uint64 {
var stat syscall.Stat_t
if err := syscall.Lstat(path, &stat); err != nil {
return Errno(err)
}
targetStat := NewTargetStat(&stat, k.U.OS(), k.U.Bits())
if err := buf.Pack(targetStat); err != nil {
panic(err)
}
return 0
}
示例5: Fstat
func (k *PosixKernel) Fstat(fd co.Fd, buf co.Buf) uint64 {
var stat syscall.Stat_t
if err := syscall.Fstat(int(fd), &stat); err != nil {
return Errno(err)
}
targetStat := NewTargetStat(&stat, k.U.OS(), k.U.Bits())
if err := buf.Pack(targetStat); err != nil {
panic(err)
}
return 0
}
示例6: Getcwd
func (k *PosixKernel) Getcwd(buf co.Buf, size co.Len) uint64 {
wd, _ := os.Getwd()
size -= 1
if co.Len(len(wd)) > size {
wd = wd[:size]
}
if err := buf.Pack(wd + "\x00"); err != nil {
return UINT64_MAX // FIXME
}
return 0
}
示例7: Pwrite64
func (k *PosixKernel) Pwrite64(fd co.Fd, buf co.Buf, size co.Len, offset int64) uint64 {
p := make([]byte, size)
if err := buf.Unpack(p); err != nil {
return UINT64_MAX // FIXME
}
n, err := syscall.Pwrite(int(fd), p, offset)
if err != nil {
return Errno(err)
}
return uint64(n)
}
示例8: MachVmAllocate
func (k *MachKernel) MachVmAllocate(unk int, size co.Len, addrOut co.Buf) uint64 {
mmap, err := k.U.Mmap(0, uint64(size))
if err != nil {
return posix.UINT64_MAX // FIXME
}
var tmp [8]byte
buf, _ := k.U.PackAddr(tmp[:], mmap.Addr)
if err := addrOut.Pack(buf); err != nil {
return posix.UINT64_MAX // FIXME
}
return 0
}
示例9: Recvfrom
func (k *PosixKernel) Recvfrom(fd co.Fd, buf co.Buf, size co.Len, flags int, from co.Buf, fromlen co.Len) uint64 {
p := make([]byte, size)
if n, _, err := syscall.Recvfrom(int(fd), p, flags); err != nil {
// TODO: need kernel.Pack() so we can pack a sockaddr into from
if err := buf.Pack(p); err != nil {
return UINT64_MAX // FIXME
}
return uint64(n)
} else {
return UINT64_MAX // FIXME
}
}
示例10: Setsockopt
func (k *PosixKernel) Setsockopt(fd co.Fd, level, opt int, valueIn co.Buf, size int) uint64 {
// TODO: dispatch/support all setsockopt types
if size != 4 {
fmt.Fprintf(os.Stderr, "WARNING: unsupported Setsockopt type %d\n", size)
return UINT64_MAX // FIXME
}
var value int32
if err := valueIn.Unpack(&value); err != nil {
return UINT64_MAX // FIXME
}
if err := syscall.SetsockoptInt(int(fd), level, opt, opt); err != nil {
return Errno(err)
}
return 0
}
示例11: Pipe
func (k *PosixKernel) Pipe(files co.Buf) uint64 {
var fds [2]int
err := syscall.Pipe(fds[:])
if err == nil {
st := files.Struc()
err := st.Pack(int32(fds[0]))
if err == nil {
err = st.Pack(int32(fds[1]))
}
if err != nil {
return UINT64_MAX // FIXME
}
}
return Errno(err)
}
示例12: Stat
func (k *PosixKernel) Stat(path string, buf co.Buf) uint64 {
// TODO: centralize path hook
if strings.Contains(path, "/lib/") {
path = k.U.PrefixPath(path, false)
}
var stat syscall.Stat_t
if err := syscall.Stat(path, &stat); err != nil {
return Errno(err)
}
targetStat := NewTargetStat(&stat, k.U.OS(), k.U.Bits())
if err := buf.Pack(targetStat); err != nil {
panic(err)
}
return 0
}
示例13: Socketcall
func (k *LinuxKernel) Socketcall(index int, params co.Buf) uint64 {
if name, ok := socketCallMap[index]; ok {
if sys := co.Lookup(k.U, k, name); sys != nil {
rawArgs := make([]uint32, len(sys.In))
if err := params.Unpack(rawArgs); err != nil {
return posix.UINT64_MAX
}
args := make([]uint64, len(rawArgs))
for i, v := range rawArgs {
args[i] = uint64(v)
}
return sys.Call(args)
}
}
return posix.UINT64_MAX // FIXME
}
示例14: Getsockopt
func (k *PosixKernel) Getsockopt(fd co.Fd, level, opt int, valueOut, valueSizeOut co.Buf) uint64 {
// TODO: dispatch/support both addr and int types
value, err := syscall.GetsockoptInt(int(fd), level, opt)
if err != nil {
return Errno(err)
}
value32 := int32(value)
size := int32(4)
if err := valueOut.Pack(value32); err != nil {
return UINT64_MAX // FIXME
}
if err := valueSizeOut.Pack(size); err != nil {
return UINT64_MAX // FIXME
}
return 0
}
示例15: Sendfile
func (k *LinuxKernel) Sendfile(out, in co.Fd, off co.Buf, count uint64) uint64 {
// TODO: the in_fd argument must correspond to a file which supports mmap(2)-like operations (i.e., it cannot be a socket).
outFile := out.File()
inFile := in.File()
var offset struc.Off_t
if off.Addr != 0 {
if err := off.Unpack(&offset); err != nil {
return UINT64_MAX // FIXME
}
}
written, err := io.CopyN(outFile, inFile, int64(count))
// TODO: is EOF handling correct here?
if (err != nil && err != io.EOF) || written < 0 {
return UINT64_MAX // FIXME
}
return uint64(written)
}