An object-oriented wrapper to the gpio Linux Userspace ABI

Fund package maintenance!
flavioheleno

Installs: 0

Dependents: 0

Suggesters: 0

Security: 0

Stars: 1

Watchers: 1

Forks: 1

Open Issues: 1

Language:C

Type:php-ext

dev-main 2024-12-24 12:32 UTC

This package is auto-updated.

Last update: 2024-12-24 12:39:43 UTC


README

The GPIO PHP Extension provides an object-oriented wrapper to the gpio Linux Userspace ABI that gives users the ability to write code that interacts with the general-purpose input/output pins available in Linux-based Single-Board Computers such as the Raspberry Pi.

Acknowledgements

The initial version of this extension was based on libgpiod and still is heavily inspired by it.

Requirements

  • PHP >= 8.0 (either NTS or ZTS version);

Note: if you are using this extension on Raspbian or Raspberry Pi OS, the user executing the script must belong to the gpio group or you may run into "Permission denied" errors.

On Raspbian or Raspberry Pi OS:

PHP 8.0:

sudo apt install php8.0-cli php8.0-dev php8.0-phpdbg

PHP 8.1:

sudo apt install php8.1-cli php8.1-dev php8.1-phpdbg

Building

phpize
./configure
make
make test

Quick start

A simple "softwire" example that reads the value from input pin #2 and writes its value to output pin #3:

$chip = new GPIO\Chip('/dev/gpiochip0');
$p2 = $chip
  ->getPin(2)
  ->asInput('softwire');
$p3 = $chip
  ->getPin(3)
  ->asOutput('softwire');

$p2->isHigh() ? $p3->setHigh() : $p3->setLow();

Stubs

After changing any of the stubs, the main stub file must be updated by running the command below.

php stubs/update-main-stup.php

Once the stub is updated, the regular build process can be executed.

Note: The main stub file (phpgpio.stub.php) is a generated file, edit the files on the stubs folder instead.

Classes

Tools

Supported Hardware

The table below lists the supported and tested chips.

Alternatives

Other Languages

Resources

License

This library is licensed under the PHP License.