MACRAW net stack, slog, load -target flag, LED blink, net_poll disabled pending SPI fix
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
"os"
|
"os"
|
||||||
@@ -13,7 +14,10 @@ import (
|
|||||||
"github.com/theater/picomap/lib/picotool"
|
"github.com/theater/picomap/lib/picotool"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
var target = flag.String("target", "all", "which firmware to load: picomap, picomap_test, or all")
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
flag.Parse()
|
||||||
wd, err := os.Getwd()
|
wd, err := os.Getwd()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
slog.Error("fatal", "err", err)
|
slog.Error("fatal", "err", err)
|
||||||
@@ -51,6 +55,13 @@ func boardSerial(id [8]byte) string {
|
|||||||
id[0], id[1], id[2], id[3], id[4], id[5], id[6], id[7])
|
id[0], id[1], id[2], id[3], id[4], id[5], id[6], id[7])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type deviceInfo struct {
|
||||||
|
dev string
|
||||||
|
serial string
|
||||||
|
uf2 string
|
||||||
|
name string
|
||||||
|
}
|
||||||
|
|
||||||
func run(buildDir string) error {
|
func run(buildDir string) error {
|
||||||
if err := build(buildDir); err != nil {
|
if err := build(buildDir); err != nil {
|
||||||
return err
|
return err
|
||||||
@@ -60,16 +71,39 @@ func run(buildDir string) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if len(devs) < 2 {
|
|
||||||
return fmt.Errorf("expected 2 devices, found %d", len(devs))
|
allTargets := []struct {
|
||||||
|
name string
|
||||||
|
uf2 string
|
||||||
|
}{
|
||||||
|
{"picomap", filepath.Join(buildDir, "picomap.uf2")},
|
||||||
|
{"picomap_test", filepath.Join(buildDir, "picomap_test.uf2")},
|
||||||
}
|
}
|
||||||
|
|
||||||
serials := make([]string, 2)
|
var targets []struct {
|
||||||
errs := make([]error, 2)
|
name string
|
||||||
uf2Names := []string{"picomap", "picomap_test"}
|
uf2 string
|
||||||
|
}
|
||||||
|
switch *target {
|
||||||
|
case "all":
|
||||||
|
targets = allTargets
|
||||||
|
case "picomap":
|
||||||
|
targets = allTargets[:1]
|
||||||
|
case "picomap_test":
|
||||||
|
targets = allTargets[1:]
|
||||||
|
default:
|
||||||
|
return fmt.Errorf("unknown target %q", *target)
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(devs) < len(targets) {
|
||||||
|
return fmt.Errorf("need %d device(s), found %d", len(targets), len(devs))
|
||||||
|
}
|
||||||
|
|
||||||
|
devices := make([]deviceInfo, len(targets))
|
||||||
|
errs := make([]error, len(targets))
|
||||||
|
|
||||||
var wg sync.WaitGroup
|
var wg sync.WaitGroup
|
||||||
for i := range 2 {
|
for i := range targets {
|
||||||
log := slog.With("dev", devs[i])
|
log := slog.With("dev", devs[i])
|
||||||
wg.Go(func() {
|
wg.Go(func() {
|
||||||
log.Info("connecting for info")
|
log.Info("connecting for info")
|
||||||
@@ -84,8 +118,13 @@ func run(buildDir string) error {
|
|||||||
errs[i] = err
|
errs[i] = err
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
serials[i] = boardSerial(info.BoardID)
|
devices[i] = deviceInfo{
|
||||||
log.Info("got info", "serial", serials[i], "firmware", info.FirmwareName)
|
dev: devs[i],
|
||||||
|
serial: boardSerial(info.BoardID),
|
||||||
|
uf2: targets[i].uf2,
|
||||||
|
name: targets[i].name,
|
||||||
|
}
|
||||||
|
log.Info("got info", "serial", devices[i].serial, "firmware", info.FirmwareName)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
@@ -95,11 +134,11 @@ func run(buildDir string) error {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for i := range 2 {
|
for i := range devices {
|
||||||
log := slog.With("serial", serials[i])
|
log := slog.With("serial", devices[i].serial)
|
||||||
wg.Go(func() {
|
wg.Go(func() {
|
||||||
log.Info("sending PICOBOOT")
|
log.Info("sending PICOBOOT")
|
||||||
c, err := client.NewSerial(devs[i], 2*time.Second)
|
c, err := client.NewSerial(devices[i].dev, 2*time.Second)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
errs[i] = err
|
errs[i] = err
|
||||||
return
|
return
|
||||||
@@ -107,38 +146,33 @@ func run(buildDir string) error {
|
|||||||
err = c.PICOBOOT()
|
err = c.PICOBOOT()
|
||||||
c.Close()
|
c.Close()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
errs[i] = fmt.Errorf("PICOBOOT %s: %w", serials[i], err)
|
errs[i] = fmt.Errorf("PICOBOOT %s: %w", devices[i].serial, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
log.Info("PICOBOOT sent")
|
log.Info("PICOBOOT sent")
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
for _, err := range errs {
|
for i, err := range errs {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return fmt.Errorf("[%s] %w", devices[i].serial, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uf2s := []string{
|
for i := range devices {
|
||||||
filepath.Join(buildDir, "picomap.uf2"),
|
log := slog.With("serial", devices[i].serial)
|
||||||
filepath.Join(buildDir, "picomap_test.uf2"),
|
|
||||||
}
|
|
||||||
|
|
||||||
for i := range 2 {
|
|
||||||
log := slog.With("serial", serials[i])
|
|
||||||
wg.Go(func() {
|
wg.Go(func() {
|
||||||
log.Info("loading", "uf2", uf2Names[i])
|
log.Info("loading", "uf2", devices[i].name)
|
||||||
errs[i] = picotool.Load(uf2s[i], serials[i], 10*time.Second)
|
errs[i] = picotool.Load(devices[i].uf2, devices[i].serial, 10*time.Second)
|
||||||
if errs[i] == nil {
|
if errs[i] == nil {
|
||||||
log.Info("loaded", "uf2", uf2Names[i])
|
log.Info("loaded", "uf2", devices[i].name)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
wg.Wait()
|
wg.Wait()
|
||||||
for i, err := range errs {
|
for i, err := range errs {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("[%s] load: %w", serials[i], err)
|
return fmt.Errorf("[%s] load: %w", devices[i].serial, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -172,6 +172,7 @@ const net_state& net_get_state() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void net_poll() {
|
void net_poll() {
|
||||||
|
if (w6300::get_socket_recv_buf(raw_socket) == 0) return;
|
||||||
static uint8_t rx_buf[1518];
|
static uint8_t rx_buf[1518];
|
||||||
w6300::ip_address dummy_addr = {};
|
w6300::ip_address dummy_addr = {};
|
||||||
w6300::port_num dummy_port{0};
|
w6300::port_num dummy_port{0};
|
||||||
|
|||||||
Reference in New Issue
Block a user