Compare commits

...

15 Commits

Author SHA1 Message Date
Adrian 03fd7508de prettifying 2025-01-24 21:35:56 -06:00
Adrian e9096c36f7 removed unused dep 2025-01-24 21:34:44 -06:00
Adrian c6ba93c46f cleaned up settings file 2025-01-24 21:22:14 -06:00
Adrian afebc2dd1e cleanup 2025-01-24 21:10:04 -06:00
Adrian 8108597740 cleanup 2025-01-24 21:07:32 -06:00
Adrian 61477e1795 cleanup 2025-01-24 21:04:17 -06:00
Adrian ac377c4953 cleanup 2025-01-24 21:02:09 -06:00
Adrian e9b68f8131 cleanup 2025-01-24 21:01:17 -06:00
Adrian 3be51a106f cleanup 2025-01-24 20:44:52 -06:00
Adrian 30385f8ae3 cleanup 2025-01-24 19:35:43 -06:00
Adrian 8c54eac167 cleanup 2025-01-24 19:34:35 -06:00
Adrian fd6e2fa7df cleanup 2025-01-24 19:19:37 -06:00
Adrian 789f2bef65 cleanup 2025-01-24 19:17:45 -06:00
Adrian f8e668349b cleanup 2025-01-24 19:16:09 -06:00
Adrian 8329137bae cleanup 2025-01-24 18:49:08 -06:00
3 changed files with 43 additions and 69 deletions

View File

@ -479,17 +479,15 @@ func rpcSetUsbEmulationState(enabled bool) error {
}
func rpcSetUsbConfig(usbConfig UsbConfig) error {
log.Printf("[jsonrpc.go:rpcSetUsbConfig] called")
LoadConfig()
config.UsbConfig = usbConfig
err2 := UpdateGadgetConfig()
if err2 != nil {
return fmt.Errorf("failed to write gadget config: %w", err2)
err := UpdateGadgetConfig()
if err != nil {
return fmt.Errorf("failed to write gadget config: %w", err)
}
err := SaveConfig()
err = SaveConfig()
if err != nil {
return fmt.Errorf("failed to save usb config: %w", err)
}

View File

@ -103,6 +103,12 @@ export default function SettingsSidebar() {
} | null>(null);
const [usbEmulationEnabled, setUsbEmulationEnabled] = useState(false);
const getUsbEmulationState = useCallback(() => {
send("getUsbEmulationState", {}, resp => {
if ("error" in resp) return;
setUsbEmulationEnabled(resp.result as boolean);
});
}, [send]);
const [usbConfig, setUsbConfig] = useState({
usb_product_id: '',
@ -112,13 +118,6 @@ export default function SettingsSidebar() {
usb_name: '',
})
const getUsbEmulationState = useCallback(() => {
send("getUsbEmulationState", {}, resp => {
if ("error" in resp) return;
setUsbEmulationEnabled(resp.result as boolean);
});
}, [send]);
const handleUsbEmulationToggle = useCallback(
(enabled: boolean) => {
send("setUsbEmulationState", { enabled: enabled }, resp => {
@ -225,7 +224,7 @@ export default function SettingsSidebar() {
return;
}
});
}, [send, usbConfig]);
}, [send]);
const handleSSHKeyChange = (newKey: string) => {
setSSHKey(newKey);

75
usb.go
View File

@ -3,7 +3,6 @@ package kvm
import (
"errors"
"fmt"
gadget "github.com/openstadia/go-usb-gadget"
"log"
"os"
"os/exec"
@ -12,6 +11,8 @@ import (
"strings"
"sync"
"time"
gadget "github.com/openstadia/go-usb-gadget"
)
const configFSPath = "/sys/kernel/config"
@ -19,6 +20,19 @@ const gadgetPath = "/sys/kernel/config/usb_gadget"
const kvmGadgetPath = "/sys/kernel/config/usb_gadget/jetkvm"
const configC1Path = "/sys/kernel/config/usb_gadget/jetkvm/configs/c.1"
func mountConfigFS() error {
_, err := os.Stat(gadgetPath)
if os.IsNotExist(err) {
err = exec.Command("mount", "-t", "configfs", "none", configFSPath).Run()
if err != nil {
return fmt.Errorf("failed to mount configfs: %w", err)
}
} else {
return fmt.Errorf("unable to access usb gadget path: %w", err)
}
return nil
}
func init() {
_ = os.MkdirAll(imagesFolder, 0755)
udcs := gadget.GetUdcs()
@ -72,7 +86,7 @@ func UpdateGadgetConfig() error {
return err
}
log.Printf("Successfully updated string attributes: %s", strAttrs)
log.Printf("Successfully updated usb string attributes: %s", strAttrs)
err = rebindUsb()
if err != nil {
@ -82,22 +96,6 @@ func UpdateGadgetConfig() error {
return nil
}
func mountConfigFS() error {
logger.Infof("Checking for gadgetPath: %s ...", gadgetPath)
_, err := os.Stat(gadgetPath)
if os.IsNotExist(err) {
logger.Infof("running mount command...")
err = exec.Command("mount", "-t", "configfs", "none", configFSPath).Run()
if err != nil {
return fmt.Errorf("failed to mount configfs: %w", err)
}
} else {
return fmt.Errorf("unable to access usb gadget path: %w", err)
}
logger.Infof("Successfully mounted usb gadget at %s", gadgetPath)
return nil
}
func writeGadgetAttrs(basePath string, attrs [][]string) error {
for _, item := range attrs {
filePath := filepath.Join(basePath, item[0])
@ -119,35 +117,30 @@ func writeGadgetConfig() error {
return err
}
LoadConfig()
gadgetAttrs := [][]string{
err = writeGadgetAttrs(kvmGadgetPath, [][]string{
{"bcdUSB", "0x0200"}, //USB 2.0
{"idVendor", config.UsbConfig.UsbVendorId},
{"idProduct", config.UsbConfig.UsbProductId},
{"idVendor", "0x1d6b"}, //The Linux Foundation
{"idProduct", "0104"}, //Multifunction Composite Gadget¬
{"bcdDevice", "0100"},
}
err = writeGadgetAttrs(kvmGadgetPath, gadgetAttrs)
})
if err != nil {
return err
}
logger.Infof("Successfully wrote gadget attributes: %s", gadgetAttrs)
gadgetStringsPath := filepath.Join(kvmGadgetPath, "strings", "0x409")
err = os.MkdirAll(gadgetStringsPath, 0755)
if err != nil {
return err
}
strAttrs := [][]string{
{"serialnumber", config.UsbConfig.UsbSerialNumber},
{"manufacturer", config.UsbConfig.UsbManufacturer},
{"product", config.UsbConfig.UsbName},
}
err = writeGadgetAttrs(gadgetStringsPath, strAttrs)
err = writeGadgetAttrs(gadgetStringsPath, [][]string{
{"serialnumber", GetDeviceID()},
{"manufacturer", "JetKVM"},
{"product", "JetKVM USB Emulation Device"},
})
if err != nil {
return err
}
logger.Infof("Successfully wrote string attributes: %s", strAttrs)
configC1StringsPath := path.Join(configC1Path, "strings", "0x409")
err = os.MkdirAll(configC1StringsPath, 0755)
@ -261,27 +254,11 @@ func writeGadgetConfig() error {
}
func rebindUsb() error {
unbindErr := unbindUsb()
if unbindErr != nil {
return unbindErr
}
bindErr := bindUsb()
if bindErr != nil {
return bindErr
}
return nil
}
func unbindUsb() error {
err := os.WriteFile("/sys/bus/platform/drivers/dwc3/unbind", []byte(udc), 0644)
if err != nil {
return err
}
return nil
}
func bindUsb() error {
err := os.WriteFile("/sys/bus/platform/drivers/dwc3/bind", []byte(udc), 0644)
err = os.WriteFile("/sys/bus/platform/drivers/dwc3/bind", []byte(udc), 0644)
if err != nil {
return err
}