Documentation ¶
Overview ¶
Package rpio provides GPIO access on the Raspberry PI without any need for external c libraries (eg. WiringPi or BCM2835).
Supports simple operations such as:
- Pin mode/direction (input/output/clock/pwm,alt0,alt1,alt2,alt3,alt4,alt5)
- Pin write (high/low)
- Pin read (high/low)
- Pin edge detection (no/rise/fall/any)
- Pull up/down/off
Also clock/pwm related oparations:
- Set Clock frequency
- Set Duty cycle
And SPI oparations:
- SPI transmit/recieve/exchange bytes
- Set speed
- Chip select
Example of use:
rpio.Open() defer rpio.Close() pin := rpio.Pin(4) pin.Output() for { pin.Toggle() time.Sleep(time.Second) }
The library use the raw BCM2835 pinouts, not the ports as they are mapped on the output pins for the raspberry pi, and not the wiringPi convention.
Rev 2 and 3 Raspberry Pi Rev 1 Raspberry Pi (legacy) +-----+---------+----------+---------+-----+ +-----+--------+----------+--------+-----+ | BCM | Name | Physical | Name | BCM | | BCM | Name | Physical | Name | BCM | +-----+---------+----++----+---------+-----+ +-----+--------+----++----+--------+-----+ | | 3.3v | 1 || 2 | 5v | | | | 3.3v | 1 || 2 | 5v | | | 2 | SDA 1 | 3 || 4 | 5v | | | 0 | SDA | 3 || 4 | 5v | | | 3 | SCL 1 | 5 || 6 | 0v | | | 1 | SCL | 5 || 6 | 0v | | | 4 | GPIO 7 | 7 || 8 | TxD | 14 | | 4 | GPIO 7 | 7 || 8 | TxD | 14 | | | 0v | 9 || 10 | RxD | 15 | | | 0v | 9 || 10 | RxD | 15 | | 17 | GPIO 0 | 11 || 12 | GPIO 1 | 18 | | 17 | GPIO 0 | 11 || 12 | GPIO 1 | 18 | | 27 | GPIO 2 | 13 || 14 | 0v | | | 21 | GPIO 2 | 13 || 14 | 0v | | | 22 | GPIO 3 | 15 || 16 | GPIO 4 | 23 | | 22 | GPIO 3 | 15 || 16 | GPIO 4 | 23 | | | 3.3v | 17 || 18 | GPIO 5 | 24 | | | 3.3v | 17 || 18 | GPIO 5 | 24 | | 10 | MOSI | 19 || 20 | 0v | | | 10 | MOSI | 19 || 20 | 0v | | | 9 | MISO | 21 || 22 | GPIO 6 | 25 | | 9 | MISO | 21 || 22 | GPIO 6 | 25 | | 11 | SCLK | 23 || 24 | CE0 | 8 | | 11 | SCLK | 23 || 24 | CE0 | 8 | | | 0v | 25 || 26 | CE1 | 7 | | | 0v | 25 || 26 | CE1 | 7 | | 0 | SDA 0 | 27 || 28 | SCL 0 | 1 | +-----+--------+----++----+--------+-----+ | 5 | GPIO 21 | 29 || 30 | 0v | | | 6 | GPIO 22 | 31 || 32 | GPIO 26 | 12 | | 13 | GPIO 23 | 33 || 34 | 0v | | | 19 | GPIO 24 | 35 || 36 | GPIO 27 | 16 | | 26 | GPIO 25 | 37 || 38 | GPIO 28 | 20 | | | 0v | 39 || 40 | GPIO 29 | 21 | +-----+---------+----++----+---------+-----+
See the spec for full details of the BCM2835 controller:
https://www.raspberrypi.org/documentation/hardware/raspberrypi/bcm2835/BCM2835-ARM-Peripherals.pdf and https://elinux.org/BCM2835_datasheet_errata - for errors in that spec
Changes to support the BCM2711, used on the Raspberry Pi 4, were cribbed from https://github.com/RPi-Distro/raspi-gpio/
Index ¶
- Constants
- Variables
- func Close() error
- func DetectEdge(pin Pin, edge Edge)
- func DisableIRQs(irqs uint64)
- func EdgeDetected(pin Pin) bool
- func EnableIRQs(irqs uint64)
- func Open() (err error)
- func PinMode(pin Pin, mode Mode)
- func PullMode(pin Pin, pull Pull)
- func SetDutyCycle(pin Pin, dutyLen, cycleLen uint32)
- func SetDutyCycleWithPwmMode(pin Pin, dutyLen, cycleLen uint32, mode bool)
- func SetFreq(pin Pin, freq int)
- func SpiBegin(dev SpiDev) error
- func SpiChipSelect(chip uint8)
- func SpiChipSelectPolarity(chip uint8, polarity uint8)
- func SpiEnd(dev SpiDev)
- func SpiExchange(data []byte)
- func SpiMode(polarity uint8, phase uint8)
- func SpiReceive(n int) []byte
- func SpiSpeed(speed int)
- func SpiTransmit(data ...byte)
- func StartPwm()
- func StopPwm()
- func TogglePin(pin Pin)
- func WritePin(pin Pin, state State)
- type Edge
- type Mode
- type Pin
- func (pin Pin) Clock()
- func (pin Pin) Detect(edge Edge)
- func (pin Pin) DutyCycle(dutyLen, cycleLen uint32)
- func (pin Pin) DutyCycleWithPwmMode(dutyLen, cycleLen uint32, mode bool)
- func (pin Pin) EdgeDetected() bool
- func (pin Pin) Freq(freq int)
- func (pin Pin) High()
- func (pin Pin) Input()
- func (pin Pin) Low()
- func (pin Pin) Mode(mode Mode)
- func (pin Pin) Output()
- func (pin Pin) Pull(pull Pull)
- func (pin Pin) PullDown()
- func (pin Pin) PullOff()
- func (pin Pin) PullUp()
- func (pin Pin) Pwm()
- func (pin Pin) Read() State
- func (pin Pin) ReadPull() Pull
- func (pin Pin) Toggle()
- func (pin Pin) Write(state State)
- type Pull
- type SpiDev
- type State
Examples ¶
Constants ¶
const ( GPPUPPDN0 = 57 // Pin pull-up/down for pins 15:0 GPPUPPDN1 = 58 // Pin pull-up/down for pins 31:16 GPPUPPDN2 = 59 // Pin pull-up/down for pins 47:32 GPPUPPDN3 = 60 // Pin pull-up/down for pins 57:48 )
BCM 2711 has a different mechanism for pull-up/pull-down/enable
const ( Balanced = true MarkSpace = false )
Which PWM algorithm to use, Balanced or Mark/Space
Variables ¶
var (
SpiMapError = errors.New("SPI registers not mapped correctly - are you root?")
)
Functions ¶
func DetectEdge ¶
DetectEdge: Enable edge event detection on pin.
Combine with pin.EdgeDetected() to check whether event occured.
Note that using this function might conflict with the same functionality of other gpio library.
It also clears previously detected event of this pin if there was any.
Note that call with RiseEdge will disable previously set FallEdge detection and vice versa. You have to call with AnyEdge, to enable detection for both edges. To disable previously enabled detection call it with NoEdge.
WARNING: this might make your Pi unresponsive, if this happens, you should either run the code as root, or add `dtoverlay=gpio-no-irq` to `/boot/config.txt` and restart your pi,
func DisableIRQs ¶ added in v4.4.0
func DisableIRQs(irqs uint64)
DisableIRQs: Disables given IRQs (by setting bit to 1 at intended position). See 'ARM peripherals interrupts table' in pheripherals datasheet. WARNING: you can corrupt your system, only use this if you know what you are doing.
func EdgeDetected ¶
EdgeDetected checks whether edge event occured since last call or since detection was enabled
There is no way (yet) to handle interruption caused by edge event, you have to use polling.
Event detection has to be enabled first, by pin.Detect(edge)
func EnableIRQs ¶ added in v4.4.0
func EnableIRQs(irqs uint64)
EnableIRQs: Enables given IRQs (by setting bit to 1 at intended position). See 'ARM peripherals interrupts table' in pheripherals datasheet. WARNING: you can corrupt your system, only use this if you know what you are doing.
func Open ¶
func Open() (err error)
Open and memory map GPIO memory range from /dev/mem . Some reflection magic is used to convert it to a unsafe []uint32 pointer
func PinMode ¶
PinMode sets the mode of a given pin (Input, Output, Clock, Pwm or Spi)
Clock is possible only for pins 4, 5, 6, 20, 21. Pwm is possible only for pins 12, 13, 18, 19.
Spi mode should not be set by this directly, use SpiBegin instead.
func SetDutyCycle ¶
SetDutyCycle: Set cycle length (range) and duty length (data) for Pwm pin in M/S mode
|<- duty ->| __________ _/ \_____________/ |<------- cycle -------->|
Output frequency is computed as pwm clock frequency divided by cycle length. So, to set Pwm pin to freqency 38kHz with duty cycle 1/4, use this combination:
pin.Pwm() pin.DutyCycle(1, 4) pin.Freq(38000*4)
Note that some pins share common pwm channel, so calling this function will set same duty cycle for all pins belonging to channel. The channels are:
channel 1 (pwm0) for pins 12, 18, 40 channel 2 (pwm1) for pins 13, 19, 41, 45.
NOTE without root permission this function will simply do nothing successfully
func SetDutyCycleWithPwmMode ¶ added in v4.6.0
SetDutyCycleWithPwmMode extends SetDutyCycle to allow for the specification of the PWM algorithm to be used, Balanced or Mark/Space. The constants Balanced or MarkSpace as the value. See 'SetDutyCycle(pin, dutyLen, cycleLen)' above for more information regarding how to use 'SetDutyCycleWithPwmMode()'.
NOTE without root permission this function will simply do nothing successfully
func SetFreq ¶
SetFreq: Set clock speed for given pin in Clock or Pwm mode
Param freq should be in range 4688Hz - 19.2MHz to prevent unexpected behavior, however output frequency of Pwm pins can be further adjusted with SetDutyCycle. So for smaller frequencies use Pwm pin with large cycle range. (Or implement custom software clock using output pin and sleep.)
Note that some pins share the same clock source, it means that changing frequency for one pin will change it also for all pins within a group. The groups are:
gp_clk0: pins 4, 20, 32, 34 gp_clk1: pins 5, 21, 42, 44 gp_clk2: pins 6 and 43 pwm_clk: pins 12, 13, 18, 19, 40, 41, 45
func SpiBegin ¶
SpiBegin: Sets all pins of given SPI device to SPI mode
dev\pin | CE0 | CE1 | CE2 | SCLK | MOSI | MISO | Spi0 | 7 | 8 | - | 9 | 10 | 11 | Spi1 | 16 | 17 | 18 | 19 | 20 | 21 | Spi2 | 40 | 41 | 42 | 43 | 44 | 45 |
It also resets SPI control register.
Note that you should disable SPI interface in raspi-config first!
Example ¶
err := SpiBegin(Spi0) // pins 7 to 11 if err != nil { panic(err) } // any Spi functions must go there... SpiTransmit(42) SpiEnd(Spi0)
Output:
func SpiChipSelect ¶
func SpiChipSelect(chip uint8)
SpiChipSelect: Select chip, one of 0, 1, 2 for selecting slave on CE0, CE1, or CE2 pin
func SpiChipSelectPolarity ¶
SpiChipSelectPolarity: Sets polarity (0/1) of active chip select default active=0
func SpiEnd ¶
func SpiEnd(dev SpiDev)
SpiEnd: Sets SPI pins of given device to default (Input) mode. See SpiBegin.
func SpiExchange ¶
func SpiExchange(data []byte)
SpiExchange: Transmit all bytes in data to slave and simultaneously receives bytes from slave to data.
If you want to only send or only receive, use SpiTransmit/SpiReceive
func SpiReceive ¶
SpiReceive receives n bytes from slave.
Note that n zeroed bytes are send to slave as side effect.
func SpiSpeed ¶
func SpiSpeed(speed int)
SpiSpeed: Set (maximal) speed [Hz] of SPI clock. Param speed may be as big as 125MHz in theory, but only values up to 31.25MHz are considered relayable.
func SpiTransmit ¶
func SpiTransmit(data ...byte)
SpiTransmit takes one or more bytes and send them to slave.
Data received from slave are ignored. Use spread operator to send slice of bytes.
Example ¶
SpiTransmit(0xFF) // send single byte SpiTransmit(0xDE, 0xAD, 0xBE) // send several bytes data := []byte{'H', 'e', 'l', 'l', 'o', 0} SpiTransmit(data...) // send slice of bytes
Output:
Types ¶
type Pin ¶
type Pin uint8
func (Pin) DutyCycleWithPwmMode ¶ added in v4.6.0
DutyCycleWithPwmMode: Set duty cycle for Pwm pin while also specifying which PWM mode to use, Balanced or MarkSpace (see doc of SetDutyCycleWithPwmMode)