Go to file
Alexander Schaefer 57d8bd4015 Reformat readme for better readability. 2017-01-24 10:38:59 +01:00
EXAMPLES pep8:E711 comparison to None should be `if cond is not None:` 2016-04-27 11:29:01 +02:00
util Merge branch 'master' of https://github.com/fudger/pigpio. 2016-03-12 21:50:46 +01:00
.gitignore Add dist, *pyc and .egg-info to .gitignore 2016-12-21 14:39:50 +00:00
MakeRemote V43 2015-12-31 17:01:34 +00:00
Makefile Add CROSS_PREFIX var to make cross-compilation easier 2016-10-30 10:50:49 -07:00
README V40 2015-11-10 14:57:12 +00:00
README.md Reformat readme for better readability. 2017-01-24 10:38:59 +01:00
UNLICENCE V6 2013-12-12 10:27:22 +00:00
command.c V57 2016-10-30 15:30:20 +00:00
command.h V57 2016-10-30 15:30:20 +00:00
custom.cext V26 2015-02-02 21:11:28 +00:00
pig2vcd.1 V55 2016-07-10 21:29:14 +01:00
pig2vcd.c V6 2013-12-12 10:27:22 +00:00
pigpio.3 V58 2016-11-03 16:36:56 +00:00
pigpio.c V60 2017-01-10 20:26:50 +00:00
pigpio.h V60 2017-01-10 20:26:50 +00:00
pigpio.py V59 2016-12-22 18:07:09 +00:00
pigpiod.1 V58 2016-11-03 16:36:56 +00:00
pigpiod.c V58 2016-11-03 16:36:56 +00:00
pigpiod_if.3 V57 2016-10-30 15:30:20 +00:00
pigpiod_if.c V55 2016-07-10 21:29:14 +01:00
pigpiod_if.h V57 2016-10-30 15:30:20 +00:00
pigpiod_if2.3 V59 2016-12-22 18:07:09 +00:00
pigpiod_if2.c V57 2016-10-30 15:30:20 +00:00
pigpiod_if2.h V59 2016-12-22 18:07:09 +00:00
pigs.1 V57 2016-10-30 15:30:20 +00:00
pigs.c V57 2016-10-30 15:30:20 +00:00
setup.py V60 2017-01-10 20:26:50 +00:00
x_pigpio.c V48 2016-03-08 14:28:15 +00:00
x_pigpio.py V48 2016-03-08 14:28:15 +00:00
x_pigpiod_if.c V48 2016-03-08 14:28:15 +00:00
x_pigpiod_if2.c V48 2016-03-08 14:28:15 +00:00
x_pigs V57 2016-10-30 15:30:20 +00:00
x_pipe V48 2016-03-08 14:28:15 +00:00

README.md

pigpio

pigpio is a C library for the Raspberry which allows control of the General Purpose Input Outputs (GPIO).

Features

  • Sampling and time-stamping of GPIO 0-31 between 100,000 and 1,000,000 times per second
  • Provision of PWM on any number of the user GPIO simultaneously
  • Provision of servo pulses on any number of the user GPIO simultaneously
  • Callbacks when any of GPIO 0-31 change state (callbacks receive the time of the event accurate to a few microseconds)
  • Notifications via pipe when any of GPIO 0-31 change state
  • Callbacks at timed intervals
  • Reading/writing all of the GPIO in a bank (0-31, 32-53) as a single operation
  • Individually setting GPIO modes, reading and writing
  • Socket and pipe interfaces for the bulk of the functionality in addition to the underlying C library calls
  • Construction of arbitrary waveforms to give precise timing of output GPIO level changes (accurate to a few microseconds)
  • Software serial links, I2C, and SPI using any user GPIO
  • Rudimentary permission control through the socket and pipe interfaces so users can be prevented from "updating" inappropriate GPIO
  • Creating and running scripts on the pigpio daemon

Interfaces

The library provides a number of control interfaces

  • the C function interface,
  • the /dev/pigpio pipe interface,
  • the socket interface (used by the pigs utility and the Python module).

Utilities

A number of utility programs are provided:

  • the pigpiod daemon,
  • the Python module,
  • the piscope digital waveform viewer,
  • the pigs command line utility,
  • the pig2vcd utility which converts notifications into the value change dump (VCD) format (useful for viewing digital waveforms with GTKWave).

Example programs

See http://abyz.co.uk/rpi/pigpio/examples.html.

GPIO

ALL GPIO are identified by their Broadcom number. See elinux.org

There are 54 GPIO in total, arranged in two banks.

Bank 1 contains GPIO 0-31. Bank 2 contains GPIO 32-54.

A user should only manipulate GPIO in bank 1.

There are at least three types of board:

  • Type 1
    • 26 pin header (P1)
    • Hardware revision numbers of 2 and 3
    • User GPIO 0-1, 4, 7-11, 14-15, 17-18, 21-25
  • Type 2
    • 26 pin header (P1) and an additional 8 pin header (P5)
    • Hardware revision numbers of 4, 5, 6, and 15
    • User GPIO 2-4, 7-11, 14-15, 17-18, 22-25, 27-31
  • Type 3
    • 40 pin expansion header (J8)
    • Hardware revision numbers of 16 or greater
    • User GPIO 2-27 (0 and 1 are reserved)

It is safe to read all the GPIO. If you try to write a system GPIO or change its mode you can crash the Pi or corrupt the data on the SD card.