"GPIO" (General Purpose I/O)
"GPIO" provides low-level general-purpose input and output through digital pins directly connected to the processor running the Wolfram Language.
Note: By default, "GPIO" allows any pin to be used interchangeably in read and write mode. DeviceConfigure can be used to configure specific pins as read or write.
Device Discovery
data:image/s3,"s3://crabby-images/80bc8/80bc8506b26fc39e6b2e3bda0cd95719da1e6b12" alt=""
- FindDevices["GPIO"] gives a GPIO DeviceObject if GPIO is available on your computer system.
Opening the Device
data:image/s3,"s3://crabby-images/600f4/600f4e6327a15ab36e1350bb5739e6e218655f6f" alt=""
- If GPIO is present, it is always accessible and does not require a connection step.
- DeviceOpen["GPIO"] is not required, but can be used to obtain a DeviceObject whose properties can be queried.
Configuring the Device
data:image/s3,"s3://crabby-images/e7cb5/e7cb5f7d39de574008dc1519b29d4e3fec8f6254" alt=""
- Configuration is not required for GPIO. Without configuration, any pin will automatically switch between input and output on read and write. Note that if a pin is used in a direction that is not intended, this may damage your system.
- Possible directions are "Input", "Output", and None.
- Setting the direction to None releases a pin if it has previously been configured.
- DeviceConfigure ignores requests to configure any pin that is being accessed by an asynchronous task.
- If an attempt is made to use a GPIO pin in a direction inconsistent with its configuration, an error will be generated.
DeviceConfigure["GPIO",n->dir]
sets the direction of pin n to be dir.
DeviceConfigure["GPIO",{n1->dir1,n2->dir2,…}]
sets direction diri for pin pini.
Reading Data
data:image/s3,"s3://crabby-images/7fb7c/7fb7ccbd16d60d48574d5799e82f2b0f1601f631" alt=""
- The value of a GPIO pin is always either 0 or 1.
-
Note By default, "GPIO" allows any pin to be used interchangeably in read and write mode. DeviceConfigure can be used to configure specific pins as read or write.
DeviceRead["GPIO",p]
gives the value of GPIO pin p.
DeviceRead["GPIO",{p1,p2,…}]
gives a list of the values of GPIO pins pi.
Writing Data
data:image/s3,"s3://crabby-images/df61b/df61b0603caeece68b06d6a88a7051a881e19ce5" alt=""
- The value v must be either 0 or 1.
-
Note By default, "GPIO" allows any pin to be used interchangeably in read and write mode. DeviceConfigure can be used to configure specific pins as read or write.
DeviceWrite["GPIO",p->v]
writes the value v to GPIO pin p.
Closing and Releasing Resources
data:image/s3,"s3://crabby-images/74a85/74a85175d819c05eddd3d57f1d62bded4fa8159a" alt=""
- DeviceClose["GPIO"] is not required, but can effectively be used to reset all pins to their default state and marks the corresponding DeviceObject as closed.