1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- // +build linux,cgo
- package loopback
- import (
- "syscall"
- "unsafe"
- )
- func ioctlLoopCtlGetFree(fd uintptr) (int, error) {
- index, _, err := syscall.Syscall(syscall.SYS_IOCTL, fd, LoopCtlGetFree, 0)
- if err != 0 {
- return 0, err
- }
- return int(index), nil
- }
- func ioctlLoopSetFd(loopFd, sparseFd uintptr) error {
- if _, _, err := syscall.Syscall(syscall.SYS_IOCTL, loopFd, LoopSetFd, sparseFd); err != 0 {
- return err
- }
- return nil
- }
- func ioctlLoopSetStatus64(loopFd uintptr, loopInfo *loopInfo64) error {
- if _, _, err := syscall.Syscall(syscall.SYS_IOCTL, loopFd, LoopSetStatus64, uintptr(unsafe.Pointer(loopInfo))); err != 0 {
- return err
- }
- return nil
- }
- func ioctlLoopClrFd(loopFd uintptr) error {
- if _, _, err := syscall.Syscall(syscall.SYS_IOCTL, loopFd, LoopClrFd, 0); err != 0 {
- return err
- }
- return nil
- }
- func ioctlLoopGetStatus64(loopFd uintptr) (*loopInfo64, error) {
- loopInfo := &loopInfo64{}
- if _, _, err := syscall.Syscall(syscall.SYS_IOCTL, loopFd, LoopGetStatus64, uintptr(unsafe.Pointer(loopInfo))); err != 0 {
- return nil, err
- }
- return loopInfo, nil
- }
- func ioctlLoopSetCapacity(loopFd uintptr, value int) error {
- if _, _, err := syscall.Syscall(syscall.SYS_IOCTL, loopFd, LoopSetCapacity, uintptr(value)); err != 0 {
- return err
- }
- return nil
- }
|