Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stianeikeland/go-rpio
:electric_plug: Raspberry Pi GPIO library for go-lang
https://github.com/stianeikeland/go-rpio
Last synced: 4 days ago
JSON representation
:electric_plug: Raspberry Pi GPIO library for go-lang
- Host: GitHub
- URL: https://github.com/stianeikeland/go-rpio
- Owner: stianeikeland
- License: mit
- Created: 2013-07-30T03:58:33.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2023-09-30T11:50:31.000Z (over 1 year ago)
- Last Synced: 2025-01-02T15:11:31.798Z (11 days ago)
- Language: Go
- Homepage:
- Size: 111 KB
- Stars: 2,209
- Watchers: 63
- Forks: 222
- Open Issues: 42
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-go - go-rpio - GPIO for Go, doesn't require cgo. (Hardware / Search and Analytic Databases)
- awesome-go - go-rpio - GPIO for Go, doesn't require cgo. Stars:`2.2K`. (Hardware / Search and Analytic Databases)
- awesome-go-extra - go-rpio - lang|1919|213|35|2013-07-30T03:58:33Z|2022-03-26T04:49:13Z| (Hardware / Tutorials)
- awesome-go - go-rpio - GPIO控制库,适用于树莓派,不需要cgo。 (硬件交互常用库 / 交互工具)
- awesome-go - go-rpio - GPIO控制库,适用于树莓派,不需要cgo。 (硬件交互常用库 / 交互工具)
README
go-rpio
=======Native GPIO-Gophers for your Pi!
**Documentation:** [![GoDoc](https://pkg.go.dev/badge/github.com/stianeikeland/go-rpio)](https://pkg.go.dev/github.com/stianeikeland/go-rpio/v4)
go-rpio is a Go library for accessing [GPIO](http://elinux.org/Rpi_Low-level_peripherals)-pins
on the [Raspberry Pi](https://en.wikipedia.org/wiki/Raspberry_Pi).It requires no external c libraries such as
[WiringPI](https://projects.drogon.net/raspberry-pi/wiringpi/) or [bcm2835](http://www.open.com.au/mikem/bcm2835).There's a tiny bit of additional information over at my [blog](https://blog.eikeland.se/2013/07/30/go-gpio-library-for-raspberry-pi/).
![raspberrypi-blink](https://blog.eikeland.se/images/2013-07-30-go-gpio-library-for-raspberry-pi/animated.gif)
## Releases ##
- 1.0.0 - Supports original rpi A/B/B+
- 2.0.0 - Adds support for rpi 2, by @akramer
- 3.0.0 - Adds support for /dev/gpiomem, by @dotdoom
- 4.0.0 - Adds support for PWM and Clock modes, by @drahoslove
- 4.1.0 - Adds support for edge detection, by @drahoslove
- 4.2.0 - Faster write and toggle of output pins, by @drahoslove
- 4.3.0 - Adds support for SPI, by @drahoslove
- 4.4.0 - Support for disabling interrupts (workaround for #35), by @drahoslove
- 4.5.0 - Improve rpi 4 support, by @wfd3
- 4.6.0 - Adds Balanced PWM mode, by @youngkin## Usage ##
```go
import "github.com/stianeikeland/go-rpio/v4"
```If you're using an older go.mod incompatible you should instead use:
```go
import "github.com/stianeikeland/go-rpio"
```Open memory range for GPIO access in /dev/mem
```go
err := rpio.Open()
```Initialize a pin, run basic operations.
Pin refers to the bcm2835 pin, not the physical pin on the raspberry pi header. Pin 10 here is exposed on the pin header as physical pin 19.```go
pin := rpio.Pin(10)pin.Output() // Output mode
pin.High() // Set pin High
pin.Low() // Set pin Low
pin.Toggle() // Toggle pin (Low -> High -> Low)pin.Input() // Input mode
res := pin.Read() // Read state from pin (High / Low)pin.Mode(rpio.Output) // Alternative syntax
pin.Write(rpio.High) // Alternative syntax
```Pull up/down/off can be set using:
```go
pin.PullUp()
pin.PullDown()
pin.PullOff()pin.Pull(rpio.PullUp)
```Unmap memory when done
```go
rpio.Close()
```Also see example [examples/blinker/blinker.go](examples/blinker/blinker.go)
### SPI
#### setup/teardown
- `rpio.SpiBegin(rpio.Spi0)` has to be called first before using any Spi func. It will change pin modes to `Spi` and initialize default setting.
- `rpio.SpiEnd(rpio.Spi0)` should be called at the end, it will switch pin modes to `Input`.#### transferring data
- `rpio.SpiTransmit(byte)` or `rpio.SpiTransmit(bytes...)` will transmit byte or bytes to slave.
- `rpio.SpiReceive(n)` will return n bytes received from slave.
- `rpio.SpiExchange(buffer)` will simultaneously transmit data from the buffer to slave and data from slave to the same buffer in full duplex way.#### settings
- `rpio.SpiSpeed(hz)` will set transmit speed of SPI
- `rpio.SpiChipSelect(n)` will select chip/slave (ce0, ce1, or ce2) to which transferring will be done
- `rpio.SpiChipSelectPolarity(n, pol)` set chip select polarity (low enabled is used by default which usually works most of the time)
- `rpio.SpiMode(cpol, cpha)` set clock/communication mode (=combination of clock polarity and clock phase; cpol=0, cpha=0 is used by default which usually works most of the time)## Other ##
Currently, it supports basic functionality such as:
- Pin Direction (Input / Output)
- Write (High / Low)
- Read (High / Low)
- Pull (Up / Down / Off)
- PWM (hardware, on supported pins)
- Clock
- Edge detectionIt works by memory-mapping the bcm2835 gpio range, and therefore require root/administrative-rights to run.
## Using without root ##
This library can utilize the new [/dev/gpiomem](https://github.com/raspberrypi/linux/pull/1112/files)
memory range if available.You will probably need to upgrade to the latest kernel (or wait for the next raspbian release) if you're missing /dev/gpiomem. You will also need to add a `gpio` group, add your user to the group, and then set up udev rules. I would recommend using [create_gpio_user_permissions.py](https://github.com/waveform80/rpi-gpio/blob/master/create_gpio_user_permissions.py) if you're unsure how to do this.
PWM modes will still require root.