BeagleBone Hardware Controls (GPIO,PWM,TTY,DTO) for the go language (and for other Linux Embedded Devices)
This is a small library to make dealing with Linux embedded devices in go easier. It is mainly written for the BeagleBone Black but with the exception of the Memory Mapped Fast GPIO, is works well on the Raspberry or other embedded Linux devices (e.g.: TP-Link, PC-Engines) as well.
The library currently does three things:
- It implements memory mapped GPIOs for the AM335xx, the beagle bone CPU, which allows us to toggle about 800 times faster than sysfs controlled GPIOs.
- For other Linux embedded devices it implements a comprehensive normal GPIO library
- It provides an extensive interface to the BeagleBone's PWM control
- It provides tools to interface with character oriented rawtty serial devices (as opposed to line oriented)
Before writing it, I had a look at aqua's raspberry lib, which was too basic for my needs, but which is why the SysFSGPIO Interface looks similar. You should check out his repository if you are looking for go-support for OneWire / DS18x20 devices.
I've also written two blogs about using PINS on the BeagleBone Black and making Device-Tree Overlays to configure the BeagleBone Black.
%> go get github.com/btittelbach/go-bbhw
import "github.com/btittelbach/go-bbhw"
bbhw.
View the API docs here
Control GPIOs using the GPIOControllablePin
interface for which four implemenations are provided
type GPIOControllablePin interface {
SetState(bool) error
SetStateNow(bool) error
GetState() (bool, error)
CheckDirection() (int, error)
SetActiveLow(bool) error
}
Use FakeGPIO for testing and debugging. Does not actually toogle GPIOs and works even on your normal computer.
func NewFakeGPIO(gpionum uint, direction int) (gpio *FakeGPIO)
same signature as all the other New*GPIO implementations. logs to
FakeGPIODefaultLogTarget_ which is an exported field and thus you can
set it to point to the log.Logger of your choice
func NewFakeNamedGPIO(name string, direction int, logTarget *log.Logger) (gpio *FakeGPIO)
slightly more fancy FakeGPIO for debugging. takes a name for easy
recognition in debugging output and an optional logger (or nil) of your
choice, thus you could route debug output of different GPIOs to
different destinations
Uses the /sys/class/gpio/**/*
file-interface provided by the linux kernel.
Slightly slower than mmapped implementations but will work on any linux system with GPIOs.
func NewSysfsGPIO(number uint, direction int) (gpio *SysfsGPIO, err error)
Instantinate a new GPIO to control through sysfs. Takes GPIO numer (same
as in sysfs) and direction bbhw.IN or bbhw.OUT
func NewSysfsGPIOOrPanic(number uint, direction int) (gpio *SysfsGPIO)
Wrapper around NewSysfsGPIO. Does not return an error but panics
instead. Useful to avoid multiple return values. This is the function
with the same signature as all the other New*GPIO*s
Uses the memory mapped IO to directly interface with AM335x registers. Toggles GPIOs about 800 times faster than SysFS.
func NewMMappedGPIO(number uint, direction int) (gpio *MMappedGPIO)
Instantinate a new and fast GPIO controlled using direct access to
AM335x registers. Takes GPIO numer (same as in sysfs) and direction
bbhw.IN or bbhw.OUT Only works on AM335x and address compatible SoCs
Same as MMappedGPIO, but part of a collection of GPIOs you can set all at once using database-like transactions. Records SetState() calls after BeginTransactionRecordSetStates() has been called and delays their effect until EndTransactionApplySetStates() is called. Use it to toggle many GPIOs in the very same instant.
func NewMMappedGPIOCollectionFactory() (gpiocf *MMappedGPIOCollectionFactory)
Create a collection of GPIOs. Doubles as factory for the
MMappedGPIOInCollection type.
func (gpiocf *MMappedGPIOCollectionFactory) NewMMappedGPIO(number uint, direction int) (gpio *MMappedGPIOInCollection)
Same as NewMMappedGPIO but part of a MMappedGPIOCollectionFactory
go golang raspberry beaglebone black white GPIO PWM fast mmap memory mapped am33xx am335xx serial tty serial raw rawtty pinmux 0x194 0x190 0x44E07000 cleardataout setdataout