feat: auto guess port for monitoring

This commit is contained in:
Li Jie
2025-09-06 22:25:00 +08:00
parent 228d7cee31
commit 4e590d42be
11 changed files with 42 additions and 19 deletions

View File

@@ -36,6 +36,8 @@ var Cmd = &base.Command{
func init() { func init() {
Cmd.Run = runCmd Cmd.Run = runCmd
base.PassBuildFlags(Cmd) base.PassBuildFlags(Cmd)
flags.AddCommonFlags(&Cmd.Flag)
flags.AddBuildFlags(&Cmd.Flag) flags.AddBuildFlags(&Cmd.Flag)
flags.AddOutputFlags(&Cmd.Flag) flags.AddOutputFlags(&Cmd.Flag)
} }

View File

@@ -31,6 +31,7 @@ var Cmd = &base.Command{
func init() { func init() {
Cmd.Run = runCmd Cmd.Run = runCmd
flags.AddCommonFlags(&Cmd.Flag)
flags.AddBuildFlags(&Cmd.Flag) flags.AddBuildFlags(&Cmd.Flag)
} }

View File

@@ -27,8 +27,11 @@ var CheckLinkArgs bool
var CheckLLFiles bool var CheckLLFiles bool
var GenLLFiles bool var GenLLFiles bool
func AddCommonFlags(fs *flag.FlagSet) {
fs.BoolVar(&Verbose, "v", false, "Verbose output")
}
func AddBuildFlags(fs *flag.FlagSet) { func AddBuildFlags(fs *flag.FlagSet) {
fs.BoolVar(&Verbose, "v", false, "Verbose mode")
fs.StringVar(&Tags, "tags", "", "Build tags") fs.StringVar(&Tags, "tags", "", "Build tags")
fs.StringVar(&BuildEnv, "buildenv", "", "Build environment") fs.StringVar(&BuildEnv, "buildenv", "", "Build environment")
if buildenv.Dev { if buildenv.Dev {

View File

@@ -35,6 +35,7 @@ var Cmd = &base.Command{
func init() { func init() {
Cmd.Run = runCmd Cmd.Run = runCmd
flags.AddCommonFlags(&Cmd.Flag)
flags.AddBuildFlags(&Cmd.Flag) flags.AddBuildFlags(&Cmd.Flag)
flags.AddEmbeddedFlags(&Cmd.Flag) flags.AddEmbeddedFlags(&Cmd.Flag)
} }

View File

@@ -22,6 +22,7 @@ import (
"github.com/goplus/llgo/cmd/internal/base" "github.com/goplus/llgo/cmd/internal/base"
"github.com/goplus/llgo/cmd/internal/flags" "github.com/goplus/llgo/cmd/internal/flags"
"github.com/goplus/llgo/internal/crosscompile"
"github.com/goplus/llgo/internal/monitor" "github.com/goplus/llgo/internal/monitor"
) )
@@ -32,6 +33,7 @@ var Cmd = &base.Command{
} }
func init() { func init() {
flags.AddCommonFlags(&Cmd.Flag)
flags.AddEmbeddedFlags(&Cmd.Flag) flags.AddEmbeddedFlags(&Cmd.Flag)
Cmd.Run = runMonitor Cmd.Run = runMonitor
} }
@@ -45,24 +47,30 @@ func runMonitor(cmd *base.Command, args []string) {
os.Exit(1) os.Exit(1)
} }
if flags.Port == "" && flags.Target == "" {
fmt.Fprintf(os.Stderr, "llgo monitor: must specify either -port or -target\n")
return
}
var executable string var executable string
if len(args) == 1 { if len(args) == 1 {
executable = args[0] executable = args[0]
} }
var serialPort []string
if flags.Target != "" {
conf, err := crosscompile.UseTarget(flags.Target)
if err != nil {
fmt.Fprintf(os.Stderr, "llgo monitor: %v\n", err)
os.Exit(1)
}
serialPort = conf.Flash.SerialPort
}
config := monitor.MonitorConfig{ config := monitor.MonitorConfig{
Port: flags.Port, Port: flags.Port,
Target: flags.Target, Target: flags.Target,
BaudRate: flags.BaudRate, BaudRate: flags.BaudRate,
Executable: executable, Executable: executable,
SerialPort: serialPort,
} }
if err := monitor.Monitor(config, true); err != nil { if err := monitor.Monitor(config, flags.Verbose); err != nil {
fmt.Fprintf(os.Stderr, "llgo monitor: %v\n", err) fmt.Fprintf(os.Stderr, "llgo monitor: %v\n", err)
os.Exit(1) os.Exit(1)
} }

View File

@@ -48,11 +48,13 @@ func init() {
Cmd.Run = runCmd Cmd.Run = runCmd
CmpTestCmd.Run = runCmpTest CmpTestCmd.Run = runCmpTest
base.PassBuildFlags(Cmd) base.PassBuildFlags(Cmd)
flags.AddCommonFlags(&Cmd.Flag)
flags.AddBuildFlags(&Cmd.Flag) flags.AddBuildFlags(&Cmd.Flag)
flags.AddEmulatorFlags(&Cmd.Flag) flags.AddEmulatorFlags(&Cmd.Flag)
flags.AddEmbeddedFlags(&Cmd.Flag) // for -target support flags.AddEmbeddedFlags(&Cmd.Flag) // for -target support
base.PassBuildFlags(CmpTestCmd) base.PassBuildFlags(CmpTestCmd)
flags.AddCommonFlags(&CmpTestCmd.Flag)
flags.AddBuildFlags(&CmpTestCmd.Flag) flags.AddBuildFlags(&CmpTestCmd.Flag)
flags.AddEmulatorFlags(&CmpTestCmd.Flag) flags.AddEmulatorFlags(&CmpTestCmd.Flag)
flags.AddEmbeddedFlags(&CmpTestCmd.Flag) // for -target support flags.AddEmbeddedFlags(&CmpTestCmd.Flag) // for -target support

View File

@@ -17,6 +17,7 @@ var Cmd = &base.Command{
func init() { func init() {
Cmd.Run = runCmd Cmd.Run = runCmd
flags.AddCommonFlags(&Cmd.Flag)
flags.AddBuildFlags(&Cmd.Flag) flags.AddBuildFlags(&Cmd.Flag)
flags.AddEmulatorFlags(&Cmd.Flag) flags.AddEmulatorFlags(&Cmd.Flag)
flags.AddEmbeddedFlags(&Cmd.Flag) flags.AddEmbeddedFlags(&Cmd.Flag)

View File

@@ -360,12 +360,16 @@ func Do(args []string, conf *Config) ([]Package, error) {
if err != nil { if err != nil {
return nil, err return nil, err
} }
err = monitor.Monitor(monitor.MonitorConfig{ monitorConfig := monitor.MonitorConfig{
Port: ctx.buildConf.Port, Port: ctx.buildConf.Port,
Target: conf.Target, Target: conf.Target,
Executable: finalApp, Executable: finalApp,
BaudRate: conf.BaudRate, BaudRate: conf.BaudRate,
}, verbose) }
if ctx.crossCompile.Flash.Method != "openocd" {
monitorConfig.SerialPort = ctx.crossCompile.Flash.SerialPort
}
err = monitor.Monitor(monitorConfig, verbose)
} }
if err != nil { if err != nil {
return nil, err return nil, err

View File

@@ -491,8 +491,8 @@ func use(goos, goarch string, wasiThreads bool) (export Export, err error) {
return return
} }
// useTarget loads configuration from a target name (e.g., "rp2040", "wasi") // UseTarget loads configuration from a target name (e.g., "rp2040", "wasi")
func useTarget(targetName string) (export Export, err error) { func UseTarget(targetName string) (export Export, err error) {
resolver := targets.NewDefaultResolver() resolver := targets.NewDefaultResolver()
config, err := resolver.Resolve(targetName) config, err := resolver.Resolve(targetName)
@@ -716,7 +716,7 @@ func useTarget(targetName string) (export Export, err error) {
// If targetName is provided, it takes precedence over goos/goarch // If targetName is provided, it takes precedence over goos/goarch
func Use(goos, goarch string, wasiThreads bool, targetName string) (export Export, err error) { func Use(goos, goarch string, wasiThreads bool, targetName string) (export Export, err error) {
if targetName != "" && !strings.HasPrefix(targetName, "wasm") && !strings.HasPrefix(targetName, "wasi") { if targetName != "" && !strings.HasPrefix(targetName, "wasm") && !strings.HasPrefix(targetName, "wasi") {
return useTarget(targetName) return UseTarget(targetName)
} }
return use(goos, goarch, wasiThreads) return use(goos, goarch, wasiThreads)
} }

View File

@@ -214,7 +214,7 @@ func TestUseTarget(t *testing.T) {
for _, tc := range testCases { for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) { t.Run(tc.name, func(t *testing.T) {
export, err := useTarget(tc.targetName) export, err := UseTarget(tc.targetName)
if tc.expectError { if tc.expectError {
if err == nil { if err == nil {

View File

@@ -22,11 +22,12 @@ import (
// MonitorConfig contains configuration for the monitor // MonitorConfig contains configuration for the monitor
type MonitorConfig struct { type MonitorConfig struct {
Port string // Serial port device Port string // Serial port device
Target string // Target name for crosscompile config Target string // Target name for crosscompile config
BaudRate int // Baudrate of serial monitor BaudRate int // Baudrate of serial monitor
Executable string // Optional path to executable for debug info Executable string // Optional path to executable for debug info
WaitTime int // Wait time for port connection (ms) WaitTime int // Wait time for port connection (ms)
SerialPort []string // List of serial ports to use
} }
// Monitor starts serial monitoring with the given configuration // Monitor starts serial monitoring with the given configuration
@@ -40,7 +41,7 @@ func Monitor(config MonitorConfig, verbose bool) error {
} }
// Resolve port using flash.GetPort // Resolve port using flash.GetPort
port, err := flash.GetPort(config.Port, nil) port, err := flash.GetPort(config.Port, config.SerialPort)
if err != nil { if err != nil {
return fmt.Errorf("failed to find port: %w", err) return fmt.Errorf("failed to find port: %w", err)
} }