diff options
Diffstat (limited to 'software/communication')
-rw-r--r-- | software/communication/interface.go | 52 | ||||
-rw-r--r-- | software/communication/physical.go | 28 |
2 files changed, 57 insertions, 23 deletions
diff --git a/software/communication/interface.go b/software/communication/interface.go new file mode 100644 index 0000000..d6111cc --- /dev/null +++ b/software/communication/interface.go @@ -0,0 +1,52 @@ +package communication + +import ( + "fmt" + "log" + + "go.bug.st/serial" +) + +type SerialInterface struct { + port serial.Port +} + +func NewSerialInterface() (SerialInterface, error) { + iface := SerialInterface{} + + devices, err := getStSerials() + if err != nil { + return iface, err + } + + if len(devices) != 1 { + return iface, fmt.Errorf("Require exactly one serial device from STMicroelectronics but %d attached", len(devices)) + } + device := devices[0] + + iface.port, err = openSerial(device) + if err != nil { + return iface, err + } + + return iface, nil +} + +func (i *SerialInterface) Log() { + for { + data, err := i.Read() + if err != nil { + log.Fatal(err) + } + log.Printf("RX: '%s'\n", string(data)) + } +} + +func (i *SerialInterface) Read() ([]byte, error) { + buff := make([]byte, 100) + n, err := i.port.Read(buff) + if err != nil { + return []byte{}, err + } + return buff[:n], nil +} diff --git a/software/communication/physical.go b/software/communication/physical.go index f79d382..853e4c4 100644 --- a/software/communication/physical.go +++ b/software/communication/physical.go @@ -1,8 +1,6 @@ package communication import ( - "fmt" - "go.bug.st/serial" "go.bug.st/serial/enumerator" ) @@ -11,11 +9,7 @@ const ( ST_VID = `0483` ) -type Phy struct { - port serial.Port -} - -func GetStSerials() ([]string, error) { +func getStSerials() ([]string, error) { retval := make([]string, 0) ports, err := enumerator.GetDetailedPortsList() @@ -34,26 +28,14 @@ func GetStSerials() ([]string, error) { return retval, nil } -func NewPhy(device string) (Phy, error) { - p := Phy{} +func openSerial(device string) (serial.Port, error) { + var port serial.Port mode := &serial.Mode{ BaudRate: 115200, } port, err := serial.Open(device, mode) if err != nil { - return p, err - } - p.port = port - return p, nil -} - -func (phy *Phy) Cat() error { - buff := make([]byte, 100) - for { - n, err := phy.port.Read(buff) - if err != nil { - return err - } - fmt.Printf("%s", string(buff[:n])) + return port, err } + return port, nil } |