mirror of
https://github.com/mudler/luet.git
synced 2025-06-25 06:52:59 +00:00
Instead of using gox on one side and an action to release, we can merge them together with goreleaser which will build for extra targets (arm, mips if needed in the future) and it also takes care of creating checksums, a source archive, and a changelog and creating a release with all the artifacts. All binaries should respect the old naming convention, so any scripts out there should still work. Signed-off-by: Itxaka <igarcia@suse.com>
165 lines
4.1 KiB
Go
165 lines
4.1 KiB
Go
// Copyright 2020 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.
|
|
|
|
//go:build zos && s390x
|
|
// +build zos,s390x
|
|
|
|
package unix
|
|
|
|
import (
|
|
"unsafe"
|
|
)
|
|
|
|
// This file simulates fstatfs on z/OS using fstatvfs and w_getmntent.
|
|
|
|
func Fstatfs(fd int, stat *Statfs_t) (err error) {
|
|
var stat_v Statvfs_t
|
|
err = Fstatvfs(fd, &stat_v)
|
|
if err == nil {
|
|
// populate stat
|
|
stat.Type = 0
|
|
stat.Bsize = stat_v.Bsize
|
|
stat.Blocks = stat_v.Blocks
|
|
stat.Bfree = stat_v.Bfree
|
|
stat.Bavail = stat_v.Bavail
|
|
stat.Files = stat_v.Files
|
|
stat.Ffree = stat_v.Ffree
|
|
stat.Fsid = stat_v.Fsid
|
|
stat.Namelen = stat_v.Namemax
|
|
stat.Frsize = stat_v.Frsize
|
|
stat.Flags = stat_v.Flag
|
|
for passn := 0; passn < 5; passn++ {
|
|
switch passn {
|
|
case 0:
|
|
err = tryGetmntent64(stat)
|
|
break
|
|
case 1:
|
|
err = tryGetmntent128(stat)
|
|
break
|
|
case 2:
|
|
err = tryGetmntent256(stat)
|
|
break
|
|
case 3:
|
|
err = tryGetmntent512(stat)
|
|
break
|
|
case 4:
|
|
err = tryGetmntent1024(stat)
|
|
break
|
|
default:
|
|
break
|
|
}
|
|
//proceed to return if: err is nil (found), err is nonnil but not ERANGE (another error occurred)
|
|
if err == nil || err != nil && err != ERANGE {
|
|
break
|
|
}
|
|
}
|
|
}
|
|
return err
|
|
}
|
|
|
|
func tryGetmntent64(stat *Statfs_t) (err error) {
|
|
var mnt_ent_buffer struct {
|
|
header W_Mnth
|
|
filesys_info [64]W_Mntent
|
|
}
|
|
var buffer_size int = int(unsafe.Sizeof(mnt_ent_buffer))
|
|
fs_count, err := W_Getmntent((*byte)(unsafe.Pointer(&mnt_ent_buffer)), buffer_size)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
err = ERANGE //return ERANGE if no match is found in this batch
|
|
for i := 0; i < fs_count; i++ {
|
|
if stat.Fsid == uint64(mnt_ent_buffer.filesys_info[i].Dev) {
|
|
stat.Type = uint32(mnt_ent_buffer.filesys_info[i].Fstname[0])
|
|
err = nil
|
|
break
|
|
}
|
|
}
|
|
return err
|
|
}
|
|
|
|
func tryGetmntent128(stat *Statfs_t) (err error) {
|
|
var mnt_ent_buffer struct {
|
|
header W_Mnth
|
|
filesys_info [128]W_Mntent
|
|
}
|
|
var buffer_size int = int(unsafe.Sizeof(mnt_ent_buffer))
|
|
fs_count, err := W_Getmntent((*byte)(unsafe.Pointer(&mnt_ent_buffer)), buffer_size)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
err = ERANGE //return ERANGE if no match is found in this batch
|
|
for i := 0; i < fs_count; i++ {
|
|
if stat.Fsid == uint64(mnt_ent_buffer.filesys_info[i].Dev) {
|
|
stat.Type = uint32(mnt_ent_buffer.filesys_info[i].Fstname[0])
|
|
err = nil
|
|
break
|
|
}
|
|
}
|
|
return err
|
|
}
|
|
|
|
func tryGetmntent256(stat *Statfs_t) (err error) {
|
|
var mnt_ent_buffer struct {
|
|
header W_Mnth
|
|
filesys_info [256]W_Mntent
|
|
}
|
|
var buffer_size int = int(unsafe.Sizeof(mnt_ent_buffer))
|
|
fs_count, err := W_Getmntent((*byte)(unsafe.Pointer(&mnt_ent_buffer)), buffer_size)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
err = ERANGE //return ERANGE if no match is found in this batch
|
|
for i := 0; i < fs_count; i++ {
|
|
if stat.Fsid == uint64(mnt_ent_buffer.filesys_info[i].Dev) {
|
|
stat.Type = uint32(mnt_ent_buffer.filesys_info[i].Fstname[0])
|
|
err = nil
|
|
break
|
|
}
|
|
}
|
|
return err
|
|
}
|
|
|
|
func tryGetmntent512(stat *Statfs_t) (err error) {
|
|
var mnt_ent_buffer struct {
|
|
header W_Mnth
|
|
filesys_info [512]W_Mntent
|
|
}
|
|
var buffer_size int = int(unsafe.Sizeof(mnt_ent_buffer))
|
|
fs_count, err := W_Getmntent((*byte)(unsafe.Pointer(&mnt_ent_buffer)), buffer_size)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
err = ERANGE //return ERANGE if no match is found in this batch
|
|
for i := 0; i < fs_count; i++ {
|
|
if stat.Fsid == uint64(mnt_ent_buffer.filesys_info[i].Dev) {
|
|
stat.Type = uint32(mnt_ent_buffer.filesys_info[i].Fstname[0])
|
|
err = nil
|
|
break
|
|
}
|
|
}
|
|
return err
|
|
}
|
|
|
|
func tryGetmntent1024(stat *Statfs_t) (err error) {
|
|
var mnt_ent_buffer struct {
|
|
header W_Mnth
|
|
filesys_info [1024]W_Mntent
|
|
}
|
|
var buffer_size int = int(unsafe.Sizeof(mnt_ent_buffer))
|
|
fs_count, err := W_Getmntent((*byte)(unsafe.Pointer(&mnt_ent_buffer)), buffer_size)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
err = ERANGE //return ERANGE if no match is found in this batch
|
|
for i := 0; i < fs_count; i++ {
|
|
if stat.Fsid == uint64(mnt_ent_buffer.filesys_info[i].Dev) {
|
|
stat.Type = uint32(mnt_ent_buffer.filesys_info[i].Fstname[0])
|
|
err = nil
|
|
break
|
|
}
|
|
}
|
|
return err
|
|
}
|