feat: Add eject cmd

This commit is contained in:
Felicitas Pojtinger
2021-11-19 14:42:13 +01:00
parent 63fa4c3669
commit 8e822c39f8
3 changed files with 55 additions and 1 deletions

36
cmd/stbak/cmd/eject.go Normal file
View File

@@ -0,0 +1,36 @@
package cmd
import (
"os"
"github.com/pojntfx/stfs/pkg/controllers"
"github.com/spf13/cobra"
"github.com/spf13/viper"
)
var ejectCmd = &cobra.Command{
Use: "eject",
Aliases: []string{"e"},
Short: "Eject the tape (tape only)",
RunE: func(cmd *cobra.Command, args []string) error {
if err := viper.BindPFlags(cmd.PersistentFlags()); err != nil {
return err
}
f, err := os.OpenFile(viper.GetString(tapeFlag), os.O_RDONLY, os.ModeCharDevice)
if err != nil {
panic(err)
}
defer f.Close()
return controllers.EjectTape(f)
},
}
func init() {
ejectCmd.PersistentFlags().StringP(tapeFlag, "t", "/dev/nst0", "Tape drive to get the current record from")
viper.AutomaticEnv()
rootCmd.AddCommand(ejectCmd)
}

View File

@@ -11,7 +11,7 @@ import (
var tellCmd = &cobra.Command{
Use: "tell",
Aliases: []string{"tell"},
Aliases: []string{"t"},
Short: "Get the current record (tape only)",
RunE: func(cmd *cobra.Command, args []string) error {
if err := viper.BindPFlags(cmd.PersistentFlags()); err != nil {

View File

@@ -12,6 +12,7 @@ const (
mtioCtop = 0x40086d01 // Do magnetic tape operation
mtFsf = 1 // Forward space over FileMark, position at first record of next file
mtOffl = 7 // Rewind and put the drive offline (eject?)
mtEom = 12 // Goto end of recorded media (for appending files)
mtSeek = 22 // Seek to block
@@ -96,3 +97,20 @@ func SeekToRecordOnTape(f *os.File, record int32) error {
return nil
}
func EjectTape(f *os.File) error {
if _, _, err := syscall.Syscall(
syscall.SYS_IOCTL,
f.Fd(),
mtioCtop,
uintptr(unsafe.Pointer(
&operation{
op: mtOffl,
},
)),
); err != 0 {
return err
}
return nil
}