wiringpi-2.50/0000775000175000017500000000000013442550153012722 5ustar ubuntuubuntuwiringpi-2.50/build0000775000175000017500000001205213442550153013747 0ustar ubuntuubuntu#!/bin/sh -e # build # Simple wiringPi build and install script # # Copyright (c) 2012-2015 Gordon Henderson ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# # # wiringPi is designed to run on a Raspberry Pi only. # However if you're clever enough to actually look at this script to # see why it's not building for you, then good luck. # # To everyone else: Stop using cheap alternatives. Support the # Raspberry Pi Foundation as they're the only ones putting money # back into education! ################################################################################# check_make_ok() { if [ $? != 0 ]; then echo "" echo "Make Failed..." echo "Please check the messages and fix any problems. If you're still stuck," echo "then please email all the output and as many details as you can to" echo " projects@drogon.net" echo "" exit 1 fi } sudo=${WIRINGPI_SUDO-sudo} if [ x$1 = "xclean" ]; then cd wiringPi echo -n "wiringPi: " ; make clean cd ../devLib echo -n "DevLib: " ; make clean cd ../gpio echo -n "gpio: " ; make clean cd ../examples echo -n "Examples: " ; make clean cd Gertboard echo -n "Gertboard: " ; make clean cd ../PiFace echo -n "PiFace: " ; make clean cd ../q2w echo -n "Quick2Wire: " ; make clean cd ../PiGlow echo -n "PiGlow: " ; make clean cd ../scrollPhat echo -n "scrollPhat: " ; make clean cd ../.. echo -n "Deb: " ; rm -f debian-template/wiringpi*.deb echo exit fi if [ x$1 = "xuninstall" ]; then cd wiringPi echo -n "wiringPi: " ; $sudo make uninstall cd ../devLib echo -n "DevLib: " ; $sudo make uninstall cd ../gpio echo -n "gpio: " ; $sudo make uninstall exit fi # Only if you know what you're doing! if [ x$1 = "xdebian" ]; then here=`pwd` cd debian-template/wiringPi rm -rf usr cd $here/wiringPi make install-deb cd $here/devLib make install-deb INCLUDE='-I. -I../wiringPi' cd $here/gpio make install-deb INCLUDE='-I../wiringPi -I../devLib' LDFLAGS=-L../debian-template/wiringPi/usr/lib cd $here/debian-template fakeroot dpkg-deb --build wiringPi mv wiringPi.deb wiringpi-`cat $here/VERSION`-1.deb exit fi if [ x$1 != "x" ]; then echo "Usage: $0 [clean | uninstall]" exit 1 fi echo "wiringPi Build script" echo "=====================" echo hardware=`fgrep Hardware /proc/cpuinfo | head -1 | awk '{ print $3 }'` # if [ x$hardware != "xBCM2708" ]; then # echo "" # echo " +------------------------------------------------------------+" # echo " | wiringPi is designed to run on the Raspberry Pi only. |" # echo " | This processor does not appear to be a Raspberry Pi. |" # echo " +------------------------------------------------------------+" # echo " | In the unlikely event that you think it is a Raspberry Pi, |" # echo " | then please accept my apologies and email the contents of |" # echo " | /proc/cpuinfo to projects@drogon.net. |" # echo " | - Thanks, Gordon |" # echo " +------------------------------------------------------------+" # echo "" # exit 1 # fi echo echo "WiringPi Library" cd wiringPi $sudo make uninstall if [ x$1 = "xstatic" ]; then make -j5 static check_make_ok $sudo make install-static else make -j5 check_make_ok $sudo make install fi check_make_ok echo echo "WiringPi Devices Library" cd ../devLib $sudo make uninstall if [ x$1 = "xstatic" ]; then make -j5 static check_make_ok $sudo make install-static else make -j5 check_make_ok $sudo make install fi check_make_ok echo echo "GPIO Utility" cd ../gpio make -j5 check_make_ok $sudo make install check_make_ok # echo # echo "wiringPi Daemon" # cd ../wiringPiD # make -j5 # check_make_ok # $sudo make install # check_make_ok # echo # echo "Examples" # cd ../examples # make # cd .. echo echo All Done. echo "" echo "NOTE: To compile programs with wiringPi, you need to add:" echo " -lwiringPi" echo " to your compile line(s) To use the Gertboard, MaxDetect, etc." echo " code (the devLib), you need to also add:" echo " -lwiringPiDev" echo " to your compile line(s)." echo "" wiringpi-2.50/wiringPi/0000775000175000017500000000000013442550153014512 5ustar ubuntuubuntuwiringpi-2.50/wiringPi/wpiExtensions.h0000664000175000017500000000224513442550153017545 0ustar ubuntuubuntu/* * extensions.h: * Part of the GPIO program to test, peek, poke and otherwise * noodle with the GPIO hardware on the Raspberry Pi. * Copyright (c) 2012-2015 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ extern int loadWPiExtension (char *progName, char *extensionData, int verbose) ; wiringpi-2.50/wiringPi/mcp23s17.h0000664000175000017500000000223513442550153016144 0ustar ubuntuubuntu/* * 23s17.h: * Extend wiringPi with the MCP 23s17 SPI GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int mcp23s17Setup (int pinBase, int spiPort, int devId) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp23x0817.h0000664000175000017500000000503413442550153016321 0ustar ubuntuubuntu/* * mcp23xxx: * Copyright (c) 2012-2013 Gordon Henderson * * Header file for code using the MCP23x08 and 17 GPIO expander * chips. * This comes in 2 flavours: MCP230xx (08/17) which has an I2C * interface, and the MXP23Sxx (08/17) which has an SPI interface. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ // MCP23x08 Registers #define MCP23x08_IODIR 0x00 #define MCP23x08_IPOL 0x01 #define MCP23x08_GPINTEN 0x02 #define MCP23x08_DEFVAL 0x03 #define MCP23x08_INTCON 0x04 #define MCP23x08_IOCON 0x05 #define MCP23x08_GPPU 0x06 #define MCP23x08_INTF 0x07 #define MCP23x08_INTCAP 0x08 #define MCP23x08_GPIO 0x09 #define MCP23x08_OLAT 0x0A // MCP23x17 Registers #define MCP23x17_IODIRA 0x00 #define MCP23x17_IPOLA 0x02 #define MCP23x17_GPINTENA 0x04 #define MCP23x17_DEFVALA 0x06 #define MCP23x17_INTCONA 0x08 #define MCP23x17_IOCON 0x0A #define MCP23x17_GPPUA 0x0C #define MCP23x17_INTFA 0x0E #define MCP23x17_INTCAPA 0x10 #define MCP23x17_GPIOA 0x12 #define MCP23x17_OLATA 0x14 #define MCP23x17_IODIRB 0x01 #define MCP23x17_IPOLB 0x03 #define MCP23x17_GPINTENB 0x05 #define MCP23x17_DEFVALB 0x07 #define MCP23x17_INTCONB 0x09 #define MCP23x17_IOCONB 0x0B #define MCP23x17_GPPUB 0x0D #define MCP23x17_INTFB 0x0F #define MCP23x17_INTCAPB 0x11 #define MCP23x17_GPIOB 0x13 #define MCP23x17_OLATB 0x15 // Bits in the IOCON register #define IOCON_UNUSED 0x01 #define IOCON_INTPOL 0x02 #define IOCON_ODR 0x04 #define IOCON_HAEN 0x08 #define IOCON_DISSLW 0x10 #define IOCON_SEQOP 0x20 #define IOCON_MIRROR 0x40 #define IOCON_BANK_MODE 0x80 // Default initialisation mode #define IOCON_INIT (IOCON_SEQOP) // SPI Command codes #define CMD_WRITE 0x40 #define CMD_READ 0x41 wiringpi-2.50/wiringPi/softTone.h0000664000175000017500000000262413442550153016470 0ustar ubuntuubuntu/* * softTone.c: * For that authentic retro sound... * Er... A little experiment to produce tones out of a Pi using * one (or 2) GPIO pins and a piezeo "speaker" element. * (Or a high impedance speaker, but don'y blame me if you blow-up * the GPIO pins!) * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int softToneCreate (int pin) ; extern void softToneStop (int pin) ; extern void softToneWrite (int pin, int freq) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp23s17.c0000664000175000017500000001245413442550153016143 0ustar ubuntuubuntu/* * mcp23s17.c: * Extend wiringPi with the MCP 23s17 SPI GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" #include "wiringPiSPI.h" #include "mcp23x0817.h" #include "mcp23s17.h" #define MCP_SPEED 4000000 /* * writeByte: * Write a byte to a register on the MCP23s17 on the SPI bus. ********************************************************************************* */ static void writeByte (uint8_t spiPort, uint8_t devId, uint8_t reg, uint8_t data) { uint8_t spiData [4] ; spiData [0] = CMD_WRITE | ((devId & 7) << 1) ; spiData [1] = reg ; spiData [2] = data ; wiringPiSPIDataRW (spiPort, spiData, 3) ; } /* * readByte: * Read a byte from a register on the MCP23s17 on the SPI bus. ********************************************************************************* */ static uint8_t readByte (uint8_t spiPort, uint8_t devId, uint8_t reg) { uint8_t spiData [4] ; spiData [0] = CMD_READ | ((devId & 7) << 1) ; spiData [1] = reg ; wiringPiSPIDataRW (spiPort, spiData, 3) ; return spiData [2] ; } /* * myPinMode: ********************************************************************************* */ static void myPinMode (struct wiringPiNodeStruct *node, int pin, int mode) { int mask, old, reg ; pin -= node->pinBase ; if (pin < 8) // Bank A reg = MCP23x17_IODIRA ; else { reg = MCP23x17_IODIRB ; pin &= 0x07 ; } mask = 1 << pin ; old = readByte (node->data0, node->data1, reg) ; if (mode == OUTPUT) old &= (~mask) ; else old |= mask ; writeByte (node->data0, node->data1, reg, old) ; } /* * myPullUpDnControl: ********************************************************************************* */ static void myPullUpDnControl (struct wiringPiNodeStruct *node, int pin, int mode) { int mask, old, reg ; pin -= node->pinBase ; if (pin < 8) // Bank A reg = MCP23x17_GPPUA ; else { reg = MCP23x17_GPPUB ; pin &= 0x07 ; } mask = 1 << pin ; old = readByte (node->data0, node->data1, reg) ; if (mode == PUD_UP) old |= mask ; else old &= (~mask) ; writeByte (node->data0, node->data1, reg, old) ; } /* * myDigitalWrite: ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { int bit, old ; pin -= node->pinBase ; // Pin now 0-15 bit = 1 << (pin & 7) ; if (pin < 8) // Bank A { old = node->data2 ; if (value == LOW) old &= (~bit) ; else old |= bit ; writeByte (node->data0, node->data1, MCP23x17_GPIOA, old) ; node->data2 = old ; } else // Bank B { old = node->data3 ; if (value == LOW) old &= (~bit) ; else old |= bit ; writeByte (node->data0, node->data1, MCP23x17_GPIOB, old) ; node->data3 = old ; } } /* * myDigitalRead: ********************************************************************************* */ static int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { int mask, value, gpio ; pin -= node->pinBase ; if (pin < 8) // Bank A gpio = MCP23x17_GPIOA ; else { gpio = MCP23x17_GPIOB ; pin &= 0x07 ; } mask = 1 << pin ; value = readByte (node->data0, node->data1, gpio) ; if ((value & mask) == 0) return LOW ; else return HIGH ; } /* * mcp23s17Setup: * Create a new instance of an MCP23s17 SPI GPIO interface. We know it * has 16 pins, so all we need to know here is the SPI address and the * user-defined pin base. ********************************************************************************* */ int mcp23s17Setup (const int pinBase, const int spiPort, const int devId) { struct wiringPiNodeStruct *node ; if (wiringPiSPISetup (spiPort, MCP_SPEED) < 0) return FALSE ; writeByte (spiPort, devId, MCP23x17_IOCON, IOCON_INIT | IOCON_HAEN) ; writeByte (spiPort, devId, MCP23x17_IOCONB, IOCON_INIT | IOCON_HAEN) ; node = wiringPiNewNode (pinBase, 16) ; node->data0 = spiPort ; node->data1 = devId ; node->pinMode = myPinMode ; node->pullUpDnControl = myPullUpDnControl ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; node->data2 = readByte (spiPort, devId, MCP23x17_OLATA) ; node->data3 = readByte (spiPort, devId, MCP23x17_OLATB) ; return TRUE ; } wiringpi-2.50/wiringPi/pcf8591.c0000664000175000017500000000475313442550153015766 0ustar ubuntuubuntu/* * pcf8591.c: * Extend wiringPi with the PCF8591 I2C GPIO Analog expander chip * The chip has 1 8-bit DAC and 4 x 8-bit ADCs * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include "wiringPi.h" #include "wiringPiI2C.h" #include "pcf8591.h" /* * myAnalogWrite: ********************************************************************************* */ static void myAnalogWrite (struct wiringPiNodeStruct *node, UNU int pin, int value) { unsigned char b [2] ; b [0] = 0x40 ; b [1] = value & 0xFF ; write (node->fd, b, 2) ; } /* * myAnalogRead: ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { int x ; wiringPiI2CWrite (node->fd, 0x40 | ((pin - node->pinBase) & 3)) ; x = wiringPiI2CRead (node->fd) ; // Throw away the first read x = wiringPiI2CRead (node->fd) ; return x ; } /* * pcf8591Setup: * Create a new instance of a PCF8591 I2C GPIO interface. We know it * has 4 pins, (4 analog inputs and 1 analog output which we'll shadow * input 0) so all we need to know here is the I2C address and the * user-defined pin base. ********************************************************************************* */ int pcf8591Setup (const int pinBase, const int i2cAddress) { int fd ; struct wiringPiNodeStruct *node ; if ((fd = wiringPiI2CSetup (i2cAddress)) < 0) return FALSE ; node = wiringPiNewNode (pinBase, 4) ; node->fd = fd ; node->analogRead = myAnalogRead ; node->analogWrite = myAnalogWrite ; return TRUE ; } wiringpi-2.50/wiringPi/mcp3002.c0000664000175000017500000000416713442550153015752 0ustar ubuntuubuntu/* * mcp3002.c: * Extend wiringPi with the MCP3002 SPI Analog to Digital convertor * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "mcp3002.h" /* * myAnalogRead: * Return the analog value of the given pin ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { unsigned char spiData [2] ; unsigned char chanBits ; int chan = pin - node->pinBase ; if (chan == 0) chanBits = 0b11010000 ; else chanBits = 0b11110000 ; spiData [0] = chanBits ; spiData [1] = 0 ; wiringPiSPIDataRW (node->fd, spiData, 2) ; return ((spiData [0] << 8) | (spiData [1] >> 1)) & 0x3FF ; } /* * mcp3002Setup: * Create a new wiringPi device node for an mcp3002 on the Pi's * SPI interface. ********************************************************************************* */ int mcp3002Setup (const int pinBase, int spiChannel) { struct wiringPiNodeStruct *node ; if (wiringPiSPISetup (spiChannel, 1000000) < 0) return FALSE ; node = wiringPiNewNode (pinBase, 2) ; node->fd = spiChannel ; node->analogRead = myAnalogRead ; return TRUE ; } wiringpi-2.50/wiringPi/mcp3004.h0000664000175000017500000000224213442550153015751 0ustar ubuntuubuntu/* * mcp3004.c: * Extend wiringPi with the MCP3004 SPI Analog to Digital convertor * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int mcp3004Setup (int pinBase, int spiChannel) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp3004.c0000664000175000017500000000426013442550153015746 0ustar ubuntuubuntu/* * mcp3004.c: * Extend wiringPi with the MCP3004 SPI Analog to Digital convertor * Copyright (c) 2012-2013 Gordon Henderson * * Thanks also to "ShorTie" on IRC for some remote debugging help! *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "mcp3004.h" /* * myAnalogRead: * Return the analog value of the given pin ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { unsigned char spiData [3] ; unsigned char chanBits ; int chan = pin - node->pinBase ; chanBits = 0b10000000 | (chan << 4) ; spiData [0] = 1 ; // Start bit spiData [1] = chanBits ; spiData [2] = 0 ; wiringPiSPIDataRW (node->fd, spiData, 3) ; return ((spiData [1] << 8) | spiData [2]) & 0x3FF ; } /* * mcp3004Setup: * Create a new wiringPi device node for an mcp3004 on the Pi's * SPI interface. ********************************************************************************* */ int mcp3004Setup (const int pinBase, int spiChannel) { struct wiringPiNodeStruct *node ; if (wiringPiSPISetup (spiChannel, 1000000) < 0) return FALSE ; node = wiringPiNewNode (pinBase, 8) ; node->fd = spiChannel ; node->analogRead = myAnalogRead ; return TRUE ; } wiringpi-2.50/wiringPi/wiringSerial.h0000664000175000017500000000273013442550153017324 0ustar ubuntuubuntu/* * wiringSerial.h: * Handle a serial port *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int serialOpen (const char *device, const int baud) ; extern void serialClose (const int fd) ; extern void serialFlush (const int fd) ; extern void serialPutchar (const int fd, const unsigned char c) ; extern void serialPuts (const int fd, const char *s) ; extern void serialPrintf (const int fd, const char *message, ...) ; extern int serialDataAvail (const int fd) ; extern int serialGetchar (const int fd) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/wpiExtensions.c0000664000175000017500000004744513442550153017553 0ustar ubuntuubuntu/* * extensions.c: * Originally part of the GPIO program to test, peek, poke and otherwise * noodle with the GPIO hardware on the Raspberry Pi. * Now used as a general purpose library to allow systems to dynamically * add in new devices into wiringPi at program run-time. * Copyright (c) 2012-2015 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include #include #include "mcp23008.h" #include "mcp23016.h" #include "mcp23017.h" #include "mcp23s08.h" #include "mcp23s17.h" #include "sr595.h" #include "pcf8574.h" #include "pcf8591.h" #include "mcp3002.h" #include "mcp3004.h" #include "mcp4802.h" #include "mcp3422.h" #include "max31855.h" #include "max5322.h" #include "ads1115.h" #include "sn3218.h" #include "drcSerial.h" #include "drcNet.h" #include "../wiringPiD/drcNetCmd.h" #include "pseudoPins.h" #include "bmp180.h" #include "htu21d.h" #include "ds18b20.h" #include "rht03.h" #include "wpiExtensions.h" extern int wiringPiDebug ; static int verbose ; static char errorMessage [1024] ; // Local structure to hold details struct extensionFunctionStruct { const char *name ; int (*function)(char *progName, int pinBase, char *params) ; } ; /* * verbError: * Convenient error handling ********************************************************************************* */ static void verbError (const char *message, ...) { va_list argp ; va_start (argp, message) ; vsnprintf (errorMessage, 1023, message, argp) ; va_end (argp) ; if (verbose) fprintf (stderr, "%s\n", errorMessage) ; } /* * extractInt: * Check & return an integer at the given location (prefixed by a :) ********************************************************************************* */ static char *extractInt (char *progName, char *p, int *num) { if (*p != ':') { verbError ("%s: colon expected", progName) ; return NULL ; } ++p ; if (!isdigit (*p)) { verbError ("%s: digit expected", progName) ; return NULL ; } *num = strtol (p, NULL, 0) ; // Increment p, but we need to check for hex 0x if ((*p == '0') && (*(p + 1) == 'x')) p +=2 ; while (isxdigit (*p)) ++p ; return p ; } /* * extractStr: * Check & return a string at the given location (prefixed by a :) * Note: The string can be enclosed in []'s to escape colons. This is * so we can handle IPv6 addresses which contain colons and the []'s is * a common way to prepresent them. ********************************************************************************* */ static char *extractStr (char *progName, char *p, char **str) { char *q, *r ; int quoted = FALSE ; if (*p != ':') { verbError ("%s: colon expected", progName) ; return NULL ; } ++p ; if (*p == '[') { quoted = TRUE ; ++p ; } if (!isprint (*p)) // Is this needed? { verbError ("%s: character expected", progName) ; return NULL ; } q = p ; if (quoted) { while ((*q != 0) && (*q != ']')) ++q ; } else { while ((*q != 0) && (*q != ':')) ++q ; } *str = r = calloc (q - p + 2, 1) ; // Zeros it while (p != q) *r++ = *p++ ; if (quoted) // Skip over the ] to the : ++p ; return p ; } /* * doExtensionMcp23008: * MCP23008 - 8-bit I2C GPIO expansion chip * mcp23002:base:i2cAddr ********************************************************************************* */ static int doExtensionMcp23008 (char *progName, int pinBase, char *params) { int i2c ; if ((params = extractInt (progName, params, &i2c)) == NULL) return FALSE ; if ((i2c < 0x01) || (i2c > 0x77)) { verbError ("%s: i2c address (0x%X) out of range", progName, i2c) ; return FALSE ; } mcp23008Setup (pinBase, i2c) ; return TRUE ; } /* * doExtensionMcp23016: * MCP230016- 16-bit I2C GPIO expansion chip * mcp23016:base:i2cAddr ********************************************************************************* */ static int doExtensionMcp23016 (char *progName, int pinBase, char *params) { int i2c ; if ((params = extractInt (progName, params, &i2c)) == NULL) return FALSE ; if ((i2c < 0x03) || (i2c > 0x77)) { verbError ("%s: i2c address (0x%X) out of range", progName, i2c) ; return FALSE ; } mcp23016Setup (pinBase, i2c) ; return TRUE ; } /* * doExtensionMcp23017: * MCP230017- 16-bit I2C GPIO expansion chip * mcp23017:base:i2cAddr ********************************************************************************* */ static int doExtensionMcp23017 (char *progName, int pinBase, char *params) { int i2c ; if ((params = extractInt (progName, params, &i2c)) == NULL) return FALSE ; if ((i2c < 0x03) || (i2c > 0x77)) { verbError ("%s: i2c address (0x%X) out of range", progName, i2c) ; return FALSE ; } mcp23017Setup (pinBase, i2c) ; return TRUE ; } /* * doExtensionMcp23s08: * MCP23s08 - 8-bit SPI GPIO expansion chip * mcp23s08:base:spi:port ********************************************************************************* */ static int doExtensionMcp23s08 (char *progName, int pinBase, char *params) { int spi, port ; if ((params = extractInt (progName, params, &spi)) == NULL) return FALSE ; if ((spi < 0) || (spi > 1)) { verbError ("%s: SPI address (%d) out of range", progName, spi) ; return FALSE ; } if ((params = extractInt (progName, params, &port)) == NULL) return FALSE ; if ((port < 0) || (port > 7)) { verbError ("%s: port address (%d) out of range", progName, port) ; return FALSE ; } mcp23s08Setup (pinBase, spi, port) ; return TRUE ; } /* * doExtensionMcp23s17: * MCP23s17 - 16-bit SPI GPIO expansion chip * mcp23s17:base:spi:port ********************************************************************************* */ static int doExtensionMcp23s17 (char *progName, int pinBase, char *params) { int spi, port ; if ((params = extractInt (progName, params, &spi)) == NULL) return FALSE ; if ((spi < 0) || (spi > 1)) { verbError ("%s: SPI address (%d) out of range", progName, spi) ; return FALSE ; } if ((params = extractInt (progName, params, &port)) == NULL) return FALSE ; if ((port < 0) || (port > 7)) { verbError ("%s: port address (%d) out of range", progName, port) ; return FALSE ; } mcp23s17Setup (pinBase, spi, port) ; return TRUE ; } /* * doExtensionSr595: * Shift Register 74x595 * sr595:base:pins:data:clock:latch ********************************************************************************* */ static int doExtensionSr595 (char *progName, int pinBase, char *params) { int pins, data, clock, latch ; // Extract pins if ((params = extractInt (progName, params, &pins)) == NULL) return FALSE ; if ((pins < 8) || (pins > 32)) { verbError ("%s: pin count (%d) out of range - 8-32 expected.", progName, pins) ; return FALSE ; } if ((params = extractInt (progName, params, &data)) == NULL) return FALSE ; if ((params = extractInt (progName, params, &clock)) == NULL) return FALSE ; if ((params = extractInt (progName, params, &latch)) == NULL) return FALSE ; sr595Setup (pinBase, pins, data, clock, latch) ; return TRUE ; } /* * doExtensionPcf8574: * Digital IO (Crude!) * pcf8574:base:i2cAddr ********************************************************************************* */ static int doExtensionPcf8574 (char *progName, int pinBase, char *params) { int i2c ; if ((params = extractInt (progName, params, &i2c)) == NULL) return FALSE ; if ((i2c < 0x03) || (i2c > 0x77)) { verbError ("%s: i2c address (0x%X) out of range", progName, i2c) ; return FALSE ; } pcf8574Setup (pinBase, i2c) ; return TRUE ; } /* * doExtensionAds1115: * Analog Input * ads1115:base:i2cAddr ********************************************************************************* */ static int doExtensionAds1115 (char *progName, int pinBase, char *params) { int i2c ; if ((params = extractInt (progName, params, &i2c)) == NULL) return FALSE ; if ((i2c < 0x03) || (i2c > 0x77)) { verbError ("%s: i2c address (0x%X) out of range", progName, i2c) ; return FALSE ; } ads1115Setup (pinBase, i2c) ; return TRUE ; } /* * doExtensionPcf8591: * Analog IO * pcf8591:base:i2cAddr ********************************************************************************* */ static int doExtensionPcf8591 (char *progName, int pinBase, char *params) { int i2c ; if ((params = extractInt (progName, params, &i2c)) == NULL) return FALSE ; if ((i2c < 0x03) || (i2c > 0x77)) { verbError ("%s: i2c address (0x%X) out of range", progName, i2c) ; return FALSE ; } pcf8591Setup (pinBase, i2c) ; return TRUE ; } /* * doExtensionPseudoPins: * 64 Memory resident pseudo pins * pseudoPins:base ********************************************************************************* */ static int doExtensionPseudoPins (UNU char *progName, int pinBase, UNU char *params) { pseudoPinsSetup (pinBase) ; return TRUE ; } /* * doExtensionBmp180: * Analog Temp + Pressure * bmp180:base ********************************************************************************* */ static int doExtensionBmp180 (UNU char *progName, int pinBase, UNU char *params) { bmp180Setup (pinBase) ; return TRUE ; } /* * doExtensionHtu21d: * Analog humidity + Pressure * htu21d:base ********************************************************************************* */ static int doExtensionHtu21d (UNU char *progName, int pinBase, UNU char *params) { htu21dSetup (pinBase) ; return TRUE ; } /* * doExtensionDs18b20: * 1-Wire Temperature * htu21d:base:serialNum ********************************************************************************* */ static int doExtensionDs18b20 (char *progName, int pinBase, char *params) { char *serialNum ; if ((params = extractStr (progName, params, &serialNum)) == NULL) return FALSE ; return ds18b20Setup (pinBase, serialNum) ; } /* * doExtensionRht03: * Maxdetect 1-Wire Temperature & Humidity * rht03:base:piPin ********************************************************************************* */ static int doExtensionRht03 (char *progName, int pinBase, char *params) { int piPin ; if ((params = extractInt (progName, params, &piPin)) == NULL) return FALSE ; return rht03Setup (pinBase, piPin) ; } /* * doExtensionMax31855: * Analog IO * max31855:base:spiChan ********************************************************************************* */ static int doExtensionMax31855 (char *progName, int pinBase, char *params) { int spi ; if ((params = extractInt (progName, params, &spi)) == NULL) return FALSE ; if ((spi < 0) || (spi > 1)) { verbError ("%s: SPI channel (%d) out of range", progName, spi) ; return FALSE ; } max31855Setup (pinBase, spi) ; return TRUE ; } /* * doExtensionMcp3002: * Analog IO * mcp3002:base:spiChan ********************************************************************************* */ static int doExtensionMcp3002 (char *progName, int pinBase, char *params) { int spi ; if ((params = extractInt (progName, params, &spi)) == NULL) return FALSE ; if ((spi < 0) || (spi > 1)) { verbError ("%s: SPI channel (%d) out of range", progName, spi) ; return FALSE ; } mcp3002Setup (pinBase, spi) ; return TRUE ; } /* * doExtensionMcp3004: * Analog IO * mcp3004:base:spiChan ********************************************************************************* */ static int doExtensionMcp3004 (char *progName, int pinBase, char *params) { int spi ; if ((params = extractInt (progName, params, &spi)) == NULL) return FALSE ; if ((spi < 0) || (spi > 1)) { verbError ("%s: SPI channel (%d) out of range", progName, spi) ; return FALSE ; } mcp3004Setup (pinBase, spi) ; return TRUE ; } /* * doExtensionMax5322: * Analog O * max5322:base:spiChan ********************************************************************************* */ static int doExtensionMax5322 (char *progName, int pinBase, char *params) { int spi ; if ((params = extractInt (progName, params, &spi)) == NULL) return FALSE ; if ((spi < 0) || (spi > 1)) { verbError ("%s: SPI channel (%d) out of range", progName, spi) ; return FALSE ; } max5322Setup (pinBase, spi) ; return TRUE ; } /* * doExtensionMcp4802: * Analog IO * mcp4802:base:spiChan ********************************************************************************* */ static int doExtensionMcp4802 (char *progName, int pinBase, char *params) { int spi ; if ((params = extractInt (progName, params, &spi)) == NULL) return FALSE ; if ((spi < 0) || (spi > 1)) { verbError ("%s: SPI channel (%d) out of range", progName, spi) ; return FALSE ; } mcp4802Setup (pinBase, spi) ; return TRUE ; } /* * doExtensionSn3218: * Analog Output (LED Driver) * sn3218:base ********************************************************************************* */ static int doExtensionSn3218 (UNU char *progName, int pinBase, UNU char *params) { sn3218Setup (pinBase) ; return TRUE ; } /* * doExtensionMcp3422: * Analog IO * mcp3422:base:i2cAddr ********************************************************************************* */ static int doExtensionMcp3422 (char *progName, int pinBase, char *params) { int i2c, sampleRate, gain ; if ((params = extractInt (progName, params, &i2c)) == NULL) return FALSE ; if ((i2c < 0x03) || (i2c > 0x77)) { verbError ("%s: i2c address (0x%X) out of range", progName, i2c) ; return FALSE ; } if ((params = extractInt (progName, params, &sampleRate)) == NULL) return FALSE ; if ((sampleRate < 0) || (sampleRate > 3)) { verbError ("%s: sample rate (%d) out of range", progName, sampleRate) ; return FALSE ; } if ((params = extractInt (progName, params, &gain)) == NULL) return FALSE ; if ((gain < 0) || (gain > 3)) { verbError ("%s: gain (%d) out of range", progName, gain) ; return FALSE ; } mcp3422Setup (pinBase, i2c, sampleRate, gain) ; return TRUE ; } /* * doExtensionDrcS: * Interface to a DRC Serial system * drcs:base:pins:serialPort:baud ********************************************************************************* */ static int doExtensionDrcS (char *progName, int pinBase, char *params) { char *port ; int pins, baud ; if ((params = extractInt (progName, params, &pins)) == NULL) return FALSE ; if ((pins < 1) || (pins > 1000)) { verbError ("%s: pins (%d) out of range (2-1000)", progName, pins) ; return FALSE ; } if ((params = extractStr (progName, params, &port)) == NULL) return FALSE ; if (strlen (port) == 0) { verbError ("%s: serial port device name required", progName) ; return FALSE ; } if ((params = extractInt (progName, params, &baud)) == NULL) return FALSE ; if ((baud < 1) || (baud > 4000000)) { verbError ("%s: baud rate (%d) out of range", progName, baud) ; return FALSE ; } drcSetupSerial (pinBase, pins, port, baud) ; return TRUE ; } /* * doExtensionDrcNet: * Interface to a DRC Network system * drcn:base:pins:ipAddress:port:password ********************************************************************************* */ static int doExtensionDrcNet (char *progName, int pinBase, char *params) { int pins ; char *ipAddress, *port, *password ; char pPort [1024] ; if ((params = extractInt (progName, params, &pins)) == NULL) return FALSE ; if ((pins < 1) || (pins > 1000)) { verbError ("%s: pins (%d) out of range (2-1000)", progName, pins) ; return FALSE ; } if ((params = extractStr (progName, params, &ipAddress)) == NULL) return FALSE ; if (strlen (ipAddress) == 0) { verbError ("%s: ipAddress required", progName) ; return FALSE ; } if ((params = extractStr (progName, params, &port)) == NULL) return FALSE ; if (strlen (port) == 0) { sprintf (pPort, "%d", DEFAULT_SERVER_PORT) ; port = pPort ; } if ((params = extractStr (progName, params, &password)) == NULL) return FALSE ; if (strlen (password) == 0) { verbError ("%s: password required", progName) ; return FALSE ; } return drcSetupNet (pinBase, pins, ipAddress, port, password) ; } /* * Function list ********************************************************************************* */ static struct extensionFunctionStruct extensionFunctions [] = { { "mcp23008", &doExtensionMcp23008 }, { "mcp23016", &doExtensionMcp23016 }, { "mcp23017", &doExtensionMcp23017 }, { "mcp23s08", &doExtensionMcp23s08 }, { "mcp23s17", &doExtensionMcp23s17 }, { "sr595", &doExtensionSr595 }, { "pcf8574", &doExtensionPcf8574 }, { "pcf8591", &doExtensionPcf8591 }, { "bmp180", &doExtensionBmp180 }, { "pseudoPins", &doExtensionPseudoPins }, { "htu21d", &doExtensionHtu21d }, { "ds18b20", &doExtensionDs18b20 }, { "rht03", &doExtensionRht03 }, { "mcp3002", &doExtensionMcp3002 }, { "mcp3004", &doExtensionMcp3004 }, { "mcp4802", &doExtensionMcp4802 }, { "mcp3422", &doExtensionMcp3422 }, { "max31855", &doExtensionMax31855 }, { "ads1115", &doExtensionAds1115 }, { "max5322", &doExtensionMax5322 }, { "sn3218", &doExtensionSn3218 }, { "drcs", &doExtensionDrcS }, { "drcn", &doExtensionDrcNet }, { NULL, NULL }, } ; /* * loadWPiExtension: * Load in a wiringPi extension * The extensionData always starts with the name, a colon then the pinBase * number. Other parameters after that are decoded by the module in question. ********************************************************************************* */ int loadWPiExtension (char *progName, char *extensionData, int printErrors) { char *p ; char *extension = extensionData ; struct extensionFunctionStruct *extensionFn ; int pinBase = 0 ; verbose = printErrors ; // Get the extension name by finding the first colon p = extension ; while (*p != ':') { if (!*p) // ran out of characters { verbError ("%s: extension name not terminated by a colon", progName) ; return FALSE ; } ++p ; } *p++ = 0 ; // Simple ATOI code if (!isdigit (*p)) { verbError ("%s: decimal pinBase number expected after extension name", progName) ; return FALSE ; } while (isdigit (*p)) { if (pinBase > 2147483647) // 2^31-1 ... Lets be realistic here... { verbError ("%s: pinBase too large", progName) ; return FALSE ; } pinBase = pinBase * 10 + (*p - '0') ; ++p ; } if (pinBase < 64) { verbError ("%s: pinBase (%d) too small. Minimum is 64.", progName, pinBase) ; return FALSE ; } // Search for extensions: for (extensionFn = extensionFunctions ; extensionFn->name != NULL ; ++extensionFn) { if (strcmp (extensionFn->name, extension) == 0) return extensionFn->function (progName, pinBase, p) ; } fprintf (stderr, "%s: extension %s not found", progName, extension) ; return FALSE ; } wiringpi-2.50/wiringPi/rht03.c0000664000175000017500000001344613442550153015626 0ustar ubuntuubuntu/* * rht03.c: * Extend wiringPi with the rht03 Maxdetect 1-Wire sensor. * Copyright (c) 2016-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include "wiringPi.h" #include "rht03.h" /* * maxDetectLowHighWait: * Wait for a transition from low to high on the bus ********************************************************************************* */ static int maxDetectLowHighWait (const int pin) { struct timeval now, timeOut, timeUp ; // If already high then wait for pin to go low gettimeofday (&now, NULL) ; timerclear (&timeOut) ; timeOut.tv_usec = 1000 ; timeradd (&now, &timeOut, &timeUp) ; while (digitalRead (pin) == HIGH) { gettimeofday (&now, NULL) ; if (timercmp (&now, &timeUp, >)) return FALSE ; } // Wait for it to go HIGH gettimeofday (&now, NULL) ; timerclear (&timeOut) ; timeOut.tv_usec = 1000 ; timeradd (&now, &timeOut, &timeUp) ; while (digitalRead (pin) == LOW) { gettimeofday (&now, NULL) ; if (timercmp (&now, &timeUp, >)) return FALSE ; } return TRUE ; } /* * maxDetectClockByte: * Read in a single byte from the MaxDetect bus ********************************************************************************* */ static unsigned int maxDetectClockByte (const int pin) { unsigned int byte = 0 ; int bit ; for (bit = 0 ; bit < 8 ; ++bit) { if (!maxDetectLowHighWait (pin)) return 0 ; // bit starting now - we need to time it. delayMicroseconds (30) ; byte <<= 1 ; if (digitalRead (pin) == HIGH) // It's a 1 byte |= 1 ; } return byte ; } /* * maxDetectRead: * Read in and return the 4 data bytes from the MaxDetect sensor. * Return TRUE/FALSE depending on the checksum validity ********************************************************************************* */ static int maxDetectRead (const int pin, unsigned char buffer [4]) { int i ; unsigned int checksum ; unsigned char localBuf [5] ; struct timeval now, then, took ; // See how long we took gettimeofday (&then, NULL) ; // Wake up the RHT03 by pulling the data line low, then high // Low for 10mS, high for 40uS. pinMode (pin, OUTPUT) ; digitalWrite (pin, 0) ; delay (10) ; digitalWrite (pin, 1) ; delayMicroseconds (40) ; pinMode (pin, INPUT) ; // Now wait for sensor to pull pin low if (!maxDetectLowHighWait (pin)) return FALSE ; // and read in 5 bytes (40 bits) for (i = 0 ; i < 5 ; ++i) localBuf [i] = maxDetectClockByte (pin) ; checksum = 0 ; for (i = 0 ; i < 4 ; ++i) { buffer [i] = localBuf [i] ; checksum += localBuf [i] ; } checksum &= 0xFF ; // See how long we took gettimeofday (&now, NULL) ; timersub (&now, &then, &took) ; // Total time to do this should be: // 10mS + 40µS - reset // + 80µS + 80µS - sensor doing its low -> high thing // + 40 * (50µS + 27µS (0) or 70µS (1) ) // = 15010µS // so if we take more than that, we've had a scheduling interruption and the // reading is probably bogus. if ((took.tv_sec != 0) || (took.tv_usec > 16000)) return FALSE ; return checksum == localBuf [4] ; } /* * myReadRHT03: * Read the Temperature & Humidity from an RHT03 sensor * Values returned are *10, so 123 is 12.3. ********************************************************************************* */ static int myReadRHT03 (const int pin, int *temp, int *rh) { int result ; unsigned char buffer [4] ; // Read ... result = maxDetectRead (pin, buffer) ; if (!result) return FALSE ; *rh = (buffer [0] * 256 + buffer [1]) ; *temp = (buffer [2] * 256 + buffer [3]) ; if ((*temp & 0x8000) != 0) // Negative { *temp &= 0x7FFF ; *temp = -*temp ; } // Discard obviously bogus readings - the checksum can't detect a 2-bit error // (which does seem to happen - no realtime here) if ((*rh > 999) || (*temp > 800) || (*temp < -400)) return FALSE ; return TRUE ; } /* * myAnalogRead: ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { int piPin = node->fd ; int chan = pin - node->pinBase ; int temp = -9997 ; int rh = -9997 ; int try ; if (chan > 1) return -9999 ; // Bad parameters for (try = 0 ; try < 10 ; ++try) { if (myReadRHT03 (piPin, &temp, &rh)) return chan == 0 ? temp : rh ; } return -9998 ; } /* * rht03Setup: * Create a new instance of an RHT03 temperature sensor. ********************************************************************************* */ int rht03Setup (const int pinBase, const int piPin) { struct wiringPiNodeStruct *node ; if ((piPin & PI_GPIO_MASK) != 0) // Must be an on-board pin return FALSE ; // 2 pins - temperature and humidity node = wiringPiNewNode (pinBase, 2) ; node->fd = piPin ; node->analogRead = myAnalogRead ; return TRUE ; } wiringpi-2.50/wiringPi/Makefile0000664000175000017500000001265313442550153016161 0ustar ubuntuubuntu# # Makefile: # wiringPi - Wiring Compatable library for the Raspberry Pi # # Copyright (c) 2012-2015 Gordon Henderson ################################################################################# # This file is part of wiringPi: # https://projects.drogon.net/raspberry-pi/wiringpi/ # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# VERSION=$(shell cat ../VERSION) DESTDIR?=/usr PREFIX?=/local LDCONFIG?=ldconfig ifneq ($V,1) Q ?= @ endif STATIC=libwiringPi.a DYNAMIC=libwiringPi.so.$(VERSION) #DEBUG = -g -O0 DEBUG = -O2 INCLUDE = -I. DEFS = -D_GNU_SOURCE CFLAGS = $(DEBUG) $(DEFS) -Wformat=2 -Wall -Wextra -Winline $(INCLUDE) -pipe -fPIC #CFLAGS = $(DEBUG) $(DEFS) -Wformat=2 -Wall -Wextra -Wconversion -Winline $(INCLUDE) -pipe -fPIC LIBS = -lm -lpthread -lrt -lcrypt ############################################################################### SRC = wiringPi.c \ wiringSerial.c wiringShift.c \ piHiPri.c piThread.c \ wiringPiSPI.c wiringPiI2C.c \ softPwm.c softTone.c \ mcp23008.c mcp23016.c mcp23017.c \ mcp23s08.c mcp23s17.c \ sr595.c \ pcf8574.c pcf8591.c \ mcp3002.c mcp3004.c mcp4802.c mcp3422.c \ max31855.c max5322.c ads1115.c \ sn3218.c \ bmp180.c htu21d.c ds18b20.c rht03.c \ drcSerial.c drcNet.c \ pseudoPins.c \ wpiExtensions.c HEADERS = $(shell ls *.h) OBJ = $(SRC:.c=.o) all: $(DYNAMIC) .PHONY: static static: $Q cat noMoreStatic $(DYNAMIC): $(OBJ) $Q echo "[Link (Dynamic)]" $Q $(CC) -shared -Wl,-soname,libwiringPi.so$(WIRINGPI_SONAME_SUFFIX) -o libwiringPi.so.$(VERSION) $(LIBS) $(OBJ) .c.o: $Q echo [Compile] $< $Q $(CC) -c $(CFLAGS) $< -o $@ .PHONY: clean clean: $Q echo "[Clean]" $Q rm -f $(OBJ) $(OBJ_I2C) *~ core tags Makefile.bak libwiringPi.* .PHONY: tags tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) .PHONY: install install: $(DYNAMIC) $Q echo "[Install Headers]" $Q install -m 0755 -d $(DESTDIR)$(PREFIX)/include $Q install -m 0644 $(HEADERS) $(DESTDIR)$(PREFIX)/include $Q echo "[Install Dynamic Lib]" $Q install -m 0755 -d $(DESTDIR)$(PREFIX)/lib $Q install -m 0755 libwiringPi.so.$(VERSION) $(DESTDIR)$(PREFIX)/lib/libwiringPi.so.$(VERSION) $Q ln -sf $(DESTDIR)$(PREFIX)/lib/libwiringPi.so.$(VERSION) $(DESTDIR)/lib/libwiringPi.so $Q $(LDCONFIG) .PHONY: install-deb install-deb: $(DYNAMIC) $Q echo "[Install Headers: deb]" $Q install -m 0755 -d ~/wiringPi/debian-template/wiringPi/usr/include $Q install -m 0644 $(HEADERS) ~/wiringPi/debian-template/wiringPi/usr/include $Q echo "[Install Dynamic Lib: deb]" install -m 0755 -d ~/wiringPi/debian-template/wiringPi/usr/lib install -m 0755 libwiringPi.so.$(VERSION) ~/wiringPi/debian-template/wiringPi/usr/lib/libwiringPi.so.$(VERSION) ln -sf ~/wiringPi/debian-template/wiringPi/usr/lib/libwiringPi.so.$(VERSION) ~/wiringPi/debian-template/wiringPi/usr/lib/libwiringPi.so .PHONY: uninstall uninstall: $Q echo "[UnInstall]" $Q cd $(DESTDIR)$(PREFIX)/include/ && rm -f $(HEADERS) $Q cd $(DESTDIR)$(PREFIX)/lib/ && rm -f libwiringPi.* $Q $(LDCONFIG) .PHONY: depend depend: makedepend -Y $(SRC) $(SRC_I2C) # DO NOT DELETE wiringPi.o: softPwm.h softTone.h wiringPi.h ../version.h wiringSerial.o: wiringSerial.h wiringShift.o: wiringPi.h wiringShift.h piHiPri.o: wiringPi.h piThread.o: wiringPi.h wiringPiSPI.o: wiringPi.h wiringPiSPI.h wiringPiI2C.o: wiringPi.h wiringPiI2C.h softPwm.o: wiringPi.h softPwm.h softTone.o: wiringPi.h softTone.h mcp23008.o: wiringPi.h wiringPiI2C.h mcp23x0817.h mcp23008.h mcp23016.o: wiringPi.h wiringPiI2C.h mcp23016.h mcp23016reg.h mcp23017.o: wiringPi.h wiringPiI2C.h mcp23x0817.h mcp23017.h mcp23s08.o: wiringPi.h wiringPiSPI.h mcp23x0817.h mcp23s08.h mcp23s17.o: wiringPi.h wiringPiSPI.h mcp23x0817.h mcp23s17.h sr595.o: wiringPi.h sr595.h pcf8574.o: wiringPi.h wiringPiI2C.h pcf8574.h pcf8591.o: wiringPi.h wiringPiI2C.h pcf8591.h mcp3002.o: wiringPi.h wiringPiSPI.h mcp3002.h mcp3004.o: wiringPi.h wiringPiSPI.h mcp3004.h mcp4802.o: wiringPi.h wiringPiSPI.h mcp4802.h mcp3422.o: wiringPi.h wiringPiI2C.h mcp3422.h max31855.o: wiringPi.h wiringPiSPI.h max31855.h max5322.o: wiringPi.h wiringPiSPI.h max5322.h ads1115.o: wiringPi.h wiringPiI2C.h ads1115.h sn3218.o: wiringPi.h wiringPiI2C.h sn3218.h bmp180.o: wiringPi.h wiringPiI2C.h bmp180.h htu21d.o: wiringPi.h wiringPiI2C.h htu21d.h ds18b20.o: wiringPi.h ds18b20.h drcSerial.o: wiringPi.h wiringSerial.h drcSerial.h pseudoPins.o: wiringPi.h pseudoPins.h wpiExtensions.o: wiringPi.h mcp23008.h mcp23016.h mcp23017.h mcp23s08.h wpiExtensions.o: mcp23s17.h sr595.h pcf8574.h pcf8591.h mcp3002.h mcp3004.h wpiExtensions.o: mcp4802.h mcp3422.h max31855.h max5322.h ads1115.h sn3218.h wpiExtensions.o: drcSerial.h pseudoPins.h bmp180.h htu21d.h ds18b20.h wpiExtensions.o: wpiExtensions.h wiringpi-2.50/wiringPi/max31855.h0000664000175000017500000000223513442550153016060 0ustar ubuntuubuntu/* * max31855.c: * Extend wiringPi with the MAX31855 SPI Thermocouple driver * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int max31855Setup (int pinBase, int spiChannel) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/max5322.c0000664000175000017500000000450613442550153015764 0ustar ubuntuubuntu/* * max5322.c: * Extend wiringPi with the MAX5322 SPI Digital to Analog convertor * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "max5322.h" /* * myAnalogWrite: * Write analog value on the given pin ********************************************************************************* */ static void myAnalogWrite (struct wiringPiNodeStruct *node, int pin, int value) { unsigned char spiData [2] ; unsigned char chanBits, dataBits ; int chan = pin - node->pinBase ; if (chan == 0) chanBits = 0b01000000 ; else chanBits = 0b01010000 ; chanBits |= ((value >> 12) & 0x0F) ; dataBits = ((value ) & 0xFF) ; spiData [0] = chanBits ; spiData [1] = dataBits ; wiringPiSPIDataRW (node->fd, spiData, 2) ; } /* * max5322Setup: * Create a new wiringPi device node for an max5322 on the Pi's * SPI interface. ********************************************************************************* */ int max5322Setup (const int pinBase, int spiChannel) { struct wiringPiNodeStruct *node ; unsigned char spiData [2] ; if (wiringPiSPISetup (spiChannel, 8000000) < 0) // 10MHz Max return FALSE ; node = wiringPiNewNode (pinBase, 2) ; node->fd = spiChannel ; node->analogWrite = myAnalogWrite ; // Enable both DACs spiData [0] = 0b11100000 ; spiData [1] = 0 ; wiringPiSPIDataRW (node->fd, spiData, 2) ; return TRUE ; } wiringpi-2.50/wiringPi/drcNet.h0000664000175000017500000000252413442550153016105 0ustar ubuntuubuntu/* * drcNet.h: * Extend wiringPi with the DRC Network protocol (e.g. to another Pi) * Copyright (c) 2016-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ /********* struct drcNetStruct { uint32_t pin ; uint32_t cmd ; uint32_t data ; } ; **************/ #ifdef __cplusplus extern "C" { #endif extern int drcSetupNet (const int pinBase, const int numPins, const char *ipAddress, const char *port, const char *password) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/drcNet.c0000664000175000017500000002352213442550153016101 0ustar ubuntuubuntu/* * drcNet.h: * Extend wiringPi with the DRC Network protocol (e.g. to another Pi) * Copyright (c) 2016-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include #include "wiringPi.h" #include "drcNet.h" #include "../wiringPiD/drcNetCmd.h" /* * remoteReadline: * Read in a line of data from the remote server, ending with a newline * character which is not stored. Returns the length or < 0 on * any sort of failure. ********************************************************************************* */ static int remoteReadline (int fd, char *buf, int max) { int len = 0 ; char c ; for (;;) { if (read (fd, &c, 1) < 1) return -1 ; if (c == '\n') return len ; *buf++ = c ; if (++len == max) return len ; } } /* * getChallenge: * Read in lines from the remote site until we get one identified * as the challenge. This line contains the password salt. ********************************************************************************* */ static char *getChallenge (int fd) { static char buf [1024] ; int num ; for (;;) { if ((num = remoteReadline (fd, buf, 1023)) < 0) return NULL ; buf [num] = 0 ; if (strncmp (buf, "Challenge ", 10) == 0) return &buf [10] ; } } /* * authenticate: * Read in the challenge from the server, use it to encrypt our password * and send it back to the server. Wait for a reply back from the server * to say that we're good to go. * The server will simply disconnect on a bad response. No 3 chances here. ********************************************************************************* */ static int authenticate (int fd, const char *pass) { char *challenge ; char *encrypted ; char salted [1024] ; if ((challenge = getChallenge (fd)) == NULL) return -1 ; sprintf (salted, "$6$%s$", challenge) ; encrypted = crypt (pass, salted) ; // This is an assertion, or sanity check on my part... // The '20' comes from the $6$ then the 16 characters of the salt, // then the terminating $. if (strncmp (encrypted, salted, 20) != 0) { errno = EBADE ; return -1 ; } // 86 characters is the length of the SHA-256 hash if (write (fd, encrypted + 20, 86) == 86) return 0 ; else return -1 ; } /* * _drcSetupNet: * Do the hard work of establishing a network connection and authenticating * the password. ********************************************************************************* */ int _drcSetupNet (const char *ipAddress, const char *port, const char *password) { struct addrinfo hints; struct addrinfo *result, *rp ; struct in6_addr serveraddr ; int remoteFd ; // Start by seeing if we've been given a (textual) numeric IP address // which will save lookups in getaddrinfo() memset (&hints, 0, sizeof (hints)) ; hints.ai_flags = AI_NUMERICSERV ; hints.ai_family = AF_UNSPEC ; hints.ai_socktype = SOCK_STREAM ; hints.ai_protocol = 0 ; if (inet_pton (AF_INET, ipAddress, &serveraddr) == 1) // Valid IPv4 { hints.ai_family = AF_INET ; hints.ai_flags |= AI_NUMERICHOST ; } else { if (inet_pton (AF_INET6, ipAddress, &serveraddr) == 1) // Valid IPv6 { hints.ai_family = AF_INET6 ; hints.ai_flags |= AI_NUMERICHOST ; } } // Now use getaddrinfo() with the newly supplied hints if (getaddrinfo (ipAddress, port, &hints, &result) != 0) return -1 ; // Now try each address in-turn until we get one that connects... for (rp = result; rp != NULL; rp = rp->ai_next) { if ((remoteFd = socket (rp->ai_family, rp->ai_socktype, rp->ai_protocol)) < 0) continue ; if (connect (remoteFd, rp->ai_addr, rp->ai_addrlen) < 0) continue ; if (authenticate (remoteFd, password) < 0) { close (remoteFd) ; errno = EACCES ; // Permission denied return -1 ; } else return remoteFd ; } errno = EHOSTUNREACH ; // Host unreachable - may not be right, but good enough return -1 ; // Nothing connected } /* * myPinMode: * Change the pin mode on the remote DRC device ********************************************************************************* */ static void myPinMode (struct wiringPiNodeStruct *node, int pin, int mode) { struct drcNetComStruct cmd ; cmd.pin = pin - node->pinBase ; cmd.cmd = DRCN_PIN_MODE ; cmd.data = mode ; (void)send (node->fd, &cmd, sizeof (cmd), 0) ; (void)recv (node->fd, &cmd, sizeof (cmd), 0) ; } /* * myPullUpDnControl: ********************************************************************************* */ static void myPullUpDnControl (struct wiringPiNodeStruct *node, int pin, int mode) { struct drcNetComStruct cmd ; cmd.pin = pin - node->pinBase ; cmd.cmd = DRCN_PULL_UP_DN ; cmd.data = mode ; (void)send (node->fd, &cmd, sizeof (cmd), 0) ; (void)recv (node->fd, &cmd, sizeof (cmd), 0) ; } /* * myDigitalWrite: ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { struct drcNetComStruct cmd ; cmd.pin = pin - node->pinBase ; cmd.cmd = DRCN_DIGITAL_WRITE ; cmd.data = value ; (void)send (node->fd, &cmd, sizeof (cmd), 0) ; (void)recv (node->fd, &cmd, sizeof (cmd), 0) ; } /* * myDigitalWrite8: ********************************************************************************* static void myDigitalWrite8 (struct wiringPiNodeStruct *node, int pin, int value) { struct drcNetComStruct cmd ; cmd.pin = pin - node->pinBase ; cmd.cmd = DRCN_DIGITAL_WRITE8 ; cmd.data = value ; (void)send (node->fd, &cmd, sizeof (cmd), 0) ; (void)recv (node->fd, &cmd, sizeof (cmd), 0) ; } */ /* * myAnalogWrite: ********************************************************************************* */ static void myAnalogWrite (struct wiringPiNodeStruct *node, int pin, int value) { struct drcNetComStruct cmd ; cmd.pin = pin - node->pinBase ; cmd.cmd = DRCN_ANALOG_WRITE ; cmd.data = value ; (void)send (node->fd, &cmd, sizeof (cmd), 0) ; (void)recv (node->fd, &cmd, sizeof (cmd), 0) ; } /* * myPwmWrite: ********************************************************************************* */ static void myPwmWrite (struct wiringPiNodeStruct *node, int pin, int value) { struct drcNetComStruct cmd ; cmd.pin = pin - node->pinBase ; cmd.cmd = DRCN_PWM_WRITE ; cmd.data = value ; (void)send (node->fd, &cmd, sizeof (cmd), 0) ; (void)recv (node->fd, &cmd, sizeof (cmd), 0) ; } /* * myAnalogRead: ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { struct drcNetComStruct cmd ; cmd.pin = pin - node->pinBase ; cmd.cmd = DRCN_ANALOG_READ ; cmd.data = 0 ; (void)send (node->fd, &cmd, sizeof (cmd), 0) ; (void)recv (node->fd, &cmd, sizeof (cmd), 0) ; return cmd.data ; } /* * myDigitalRead: ********************************************************************************* */ static int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { struct drcNetComStruct cmd ; cmd.pin = pin - node->pinBase ; cmd.cmd = DRCN_DIGITAL_READ ; cmd.data = 0 ; (void)send (node->fd, &cmd, sizeof (cmd), 0) ; (void)recv (node->fd, &cmd, sizeof (cmd), 0) ; return cmd.data ; } /* * myDigitalRead8: ********************************************************************************* static unsigned int myDigitalRead8 (struct wiringPiNodeStruct *node, int pin) { struct drcNetComStruct cmd ; cmd.pin = pin - node->pinBase ; cmd.cmd = DRCN_DIGITAL_READ8 ; cmd.data = 0 ; (void)send (node->fd, &cmd, sizeof (cmd), 0) ; (void)recv (node->fd, &cmd, sizeof (cmd), 0) ; return cmd.data ; } */ /* * drcNet: * Create a new instance of an DRC GPIO interface. * Could be a variable nunber of pins here - we might not know in advance. ********************************************************************************* */ int drcSetupNet (const int pinBase, const int numPins, const char *ipAddress, const char *port, const char *password) { int fd, len ; struct wiringPiNodeStruct *node ; if ((fd = _drcSetupNet (ipAddress, port, password)) < 0) return FALSE ; len = sizeof (struct drcNetComStruct) ; if (setsockopt (fd, SOL_SOCKET, SO_RCVLOWAT, (void *)&len, sizeof (len)) < 0) return FALSE ; node = wiringPiNewNode (pinBase, numPins) ; node->fd = fd ; node->pinMode = myPinMode ; node->pullUpDnControl = myPullUpDnControl ; node->analogRead = myAnalogRead ; node->analogRead = myAnalogRead ; node->analogWrite = myAnalogWrite ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; //node->digitalRead8 = myDigitalRead8 ; //node->digitalWrite8 = myDigitalWrite8 ; node->pwmWrite = myPwmWrite ; return TRUE ; } wiringpi-2.50/wiringPi/htu21d.c0000664000175000017500000000671313442550153015774 0ustar ubuntuubuntu/* * htu21d.c: * Extend wiringPi with the HTU21D I2C humidity and Temperature * sensor. This is used in the Pi Weather station. * Copyright (c) 2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include "wiringPi.h" #include "wiringPiI2C.h" #include "htu21d.h" #define DEBUG #undef FAKE_SENSOR #define I2C_ADDRESS 0x40 int checksum (UNU uint8_t data [4]) { return TRUE ; } /* * myAnalogRead: ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { int chan = pin - node->pinBase ; int fd = node->fd ; uint8_t data [4] ; uint32_t sTemp, sHumid ; double fTemp, fHumid ; int cTemp, cHumid ; /**/ if (chan == 0) // Read Temperature { // Send read temperature command: data [0] = 0xF3 ; if (write (fd, data, 1) != 1) return -9999 ; // Wait then read the data delay (50) ; if (read (fd, data, 3) != 3) return -9998 ; if (!checksum (data)) return -9997 ; // Do the calculation sTemp = (data [0] << 8) | data [1] ; fTemp = -48.85 + 175.72 * (double)sTemp / 63356.0 ; cTemp = (int)rint (((100.0 * fTemp) + 0.5) / 10.0) ; return cTemp ; } else if (chan == 1) // humidity { // Send read humidity command: data [0] = 0xF5 ; if (write (fd, data, 1) != 1) return -9999 ; // Wait then read the data delay (50) ; if (read (fd, data, 3) != 3) return -9998 ; if (!checksum (data)) return -9997 ; sHumid = (data [0] << 8) | data [1] ; fHumid = -6.0 + 125.0 * (double)sHumid / 65536.0 ; cHumid = (int)rint (((100.0 * fHumid) + 0.5) / 10.0) ; return cHumid ; } else return -9999 ; } /* * htu21dSetup: * Create a new instance of a HTU21D I2C GPIO interface. * This chip has a fixed I2C address, so we are not providing any * allowance to change this. ********************************************************************************* */ int htu21dSetup (const int pinBase) { int fd ; struct wiringPiNodeStruct *node ; uint8_t data ; int status ; if ((fd = wiringPiI2CSetup (I2C_ADDRESS)) < 0) return FALSE ; node = wiringPiNewNode (pinBase, 2) ; node->fd = fd ; node->analogRead = myAnalogRead ; // Send a reset code to it: data = 0xFE ; if (write (fd, &data, 1) != 1) return FALSE ; delay (15) ; // Read the status register to check it's really there status = wiringPiI2CReadReg8 (fd, 0xE7) ; return (status == 0x02) ? TRUE : FALSE ; } wiringpi-2.50/wiringPi/softServo.h0000664000175000017500000000240313442550153016654 0ustar ubuntuubuntu/* * softServo.h: * Provide N channels of software driven PWM suitable for RC * servo motors. * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern void softServoWrite (int pin, int value) ; extern int softServoSetup (int p0, int p1, int p2, int p3, int p4, int p5, int p6, int p7) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp23x08.h0000664000175000017500000000375213442550153016156 0ustar ubuntuubuntu/* * mcp23x17: * Copyright (c) 2012-2013 Gordon Henderson * * Header file for code using the MCP23x17 GPIO expander chip. * This comes in 2 flavours: MCP23017 which has an I2C interface, * an the MXP23S17 which has an SPI interface. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ // MCP23x17 Registers #define IODIRA 0x00 #define IPOLA 0x02 #define GPINTENA 0x04 #define DEFVALA 0x06 #define INTCONA 0x08 #define IOCON 0x0A #define GPPUA 0x0C #define INTFA 0x0E #define INTCAPA 0x10 #define GPIOA 0x12 #define OLATA 0x14 #define IODIRB 0x01 #define IPOLB 0x03 #define GPINTENB 0x05 #define DEFVALB 0x07 #define INTCONB 0x09 #define IOCONB 0x0B #define GPPUB 0x0D #define INTFB 0x0F #define INTCAPB 0x11 #define GPIOB 0x13 #define OLATB 0x15 // Bits in the IOCON register #define IOCON_UNUSED 0x01 #define IOCON_INTPOL 0x02 #define IOCON_ODR 0x04 #define IOCON_HAEN 0x08 #define IOCON_DISSLW 0x10 #define IOCON_SEQOP 0x20 #define IOCON_MIRROR 0x40 #define IOCON_BANK_MODE 0x80 // Default initialisation mode #define IOCON_INIT (IOCON_SEQOP) // SPI Command codes #define CMD_WRITE 0x40 #define CMD_READ 0x41 wiringpi-2.50/wiringPi/ads1115.c0000664000175000017500000002131313442550153015735 0ustar ubuntuubuntu/* * ads1115.c: * Extend wiringPi with the ADS1115 I2C 16-bit ADC * Copyright (c) 2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ /* ********************************************************************************* * We're going to work in a hybrid mode to fit in with the wiringPi way of * doing things, so there will be 4 analog pin which read the 4 single-ended * channels as usual, also some fake digitalOutputs - these are the control * registers that allow the user to put it into single/diff mode, set the * gain and data rates. ********************************************************************************* */ #include #include #include #include #include #include "ads1115.h" // Bits in the config register (it's a 16-bit register) #define CONFIG_OS_MASK (0x8000) // Operational Status Register #define CONFIG_OS_SINGLE (0x8000) // Write - Starts a single-conversion // Read 1 = Conversion complete // The multiplexor #define CONFIG_MUX_MASK (0x7000) // Differential modes #define CONFIG_MUX_DIFF_0_1 (0x0000) // Pos = AIN0, Neg = AIN1 (default) #define CONFIG_MUX_DIFF_0_3 (0x1000) // Pos = AIN0, Neg = AIN3 #define CONFIG_MUX_DIFF_1_3 (0x2000) // Pos = AIN1, Neg = AIN3 #define CONFIG_MUX_DIFF_2_3 (0x3000) // Pos = AIN2, Neg = AIN3 (2nd differential channel) // Single-ended modes #define CONFIG_MUX_SINGLE_0 (0x4000) // AIN0 #define CONFIG_MUX_SINGLE_1 (0x5000) // AIN1 #define CONFIG_MUX_SINGLE_2 (0x6000) // AIN2 #define CONFIG_MUX_SINGLE_3 (0x7000) // AIN3 // Programmable Gain Amplifier #define CONFIG_PGA_MASK (0x0E00) #define CONFIG_PGA_6_144V (0x0000) // +/-6.144V range = Gain 2/3 #define CONFIG_PGA_4_096V (0x0200) // +/-4.096V range = Gain 1 #define CONFIG_PGA_2_048V (0x0400) // +/-2.048V range = Gain 2 (default) #define CONFIG_PGA_1_024V (0x0600) // +/-1.024V range = Gain 4 #define CONFIG_PGA_0_512V (0x0800) // +/-0.512V range = Gain 8 #define CONFIG_PGA_0_256V (0x0A00) // +/-0.256V range = Gain 16 #define CONFIG_MODE (0x0100) // 0 is continuous, 1 is single-shot (default) // Data Rate #define CONFIG_DR_MASK (0x00E0) #define CONFIG_DR_8SPS (0x0000) // 8 samples per second #define CONFIG_DR_16SPS (0x0020) // 16 samples per second #define CONFIG_DR_32SPS (0x0040) // 32 samples per second #define CONFIG_DR_64SPS (0x0060) // 64 samples per second #define CONFIG_DR_128SPS (0x0080) // 128 samples per second (default) #define CONFIG_DR_475SPS (0x00A0) // 475 samples per second #define CONFIG_DR_860SPS (0x00C0) // 860 samples per second // Comparator mode #define CONFIG_CMODE_MASK (0x0010) #define CONFIG_CMODE_TRAD (0x0000) // Traditional comparator with hysteresis (default) #define CONFIG_CMODE_WINDOW (0x0010) // Window comparator // Comparator polarity - the polarity of the output alert/rdy pin #define CONFIG_CPOL_MASK (0x0008) #define CONFIG_CPOL_ACTVLOW (0x0000) // Active low (default) #define CONFIG_CPOL_ACTVHI (0x0008) // Active high // Latching comparator - does the alert/rdy pin latch #define CONFIG_CLAT_MASK (0x0004) #define CONFIG_CLAT_NONLAT (0x0000) // Non-latching comparator (default) #define CONFIG_CLAT_LATCH (0x0004) // Latching comparator // Comparitor queue #define CONFIG_CQUE_MASK (0x0003) #define CONFIG_CQUE_1CONV (0x0000) // Assert after one conversions #define CONFIG_CQUE_2CONV (0x0001) // Assert after two conversions #define CONFIG_CQUE_4CONV (0x0002) // Assert after four conversions #define CONFIG_CQUE_NONE (0x0003) // Disable the comparator (default) #define CONFIG_DEFAULT (0x8583) // From the datasheet static const uint16_t dataRates [8] = { CONFIG_DR_8SPS, CONFIG_DR_16SPS, CONFIG_DR_32SPS, CONFIG_DR_64SPS, CONFIG_DR_128SPS, CONFIG_DR_475SPS, CONFIG_DR_860SPS } ; static const uint16_t gains [6] = { CONFIG_PGA_6_144V, CONFIG_PGA_4_096V, CONFIG_PGA_2_048V, CONFIG_PGA_1_024V, CONFIG_PGA_0_512V, CONFIG_PGA_0_256V } ; /* * analogRead: * Pin is the channel to sample on the device. * Channels 0-3 are single ended inputs, * channels 4-7 are the various differential combinations. ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { int chan = pin - node->pinBase ; int16_t result ; uint16_t config = CONFIG_DEFAULT ; chan &= 7 ; // Setup the configuration register // Set PGA/voltage range config &= ~CONFIG_PGA_MASK ; config |= node->data0 ; // Set sample speed config &= ~CONFIG_DR_MASK ; config |= node->data1 ; // Set single-ended channel or differential mode config &= ~CONFIG_MUX_MASK ; switch (chan) { case 0: config |= CONFIG_MUX_SINGLE_0 ; break ; case 1: config |= CONFIG_MUX_SINGLE_1 ; break ; case 2: config |= CONFIG_MUX_SINGLE_2 ; break ; case 3: config |= CONFIG_MUX_SINGLE_3 ; break ; case 4: config |= CONFIG_MUX_DIFF_0_1 ; break ; case 5: config |= CONFIG_MUX_DIFF_2_3 ; break ; case 6: config |= CONFIG_MUX_DIFF_0_3 ; break ; case 7: config |= CONFIG_MUX_DIFF_1_3 ; break ; } // Start a single conversion config |= CONFIG_OS_SINGLE ; config = __bswap_16 (config) ; wiringPiI2CWriteReg16 (node->fd, 1, config) ; // Wait for the conversion to complete for (;;) { result = wiringPiI2CReadReg16 (node->fd, 1) ; result = __bswap_16 (result) ; if ((result & CONFIG_OS_MASK) != 0) break ; delayMicroseconds (100) ; } result = wiringPiI2CReadReg16 (node->fd, 0) ; result = __bswap_16 (result) ; // Sometimes with a 0v input on a single-ended channel the internal 0v reference // can be higher than the input, so you get a negative result... if ( (chan < 4) && (result < 0) ) return 0 ; else return (int)result ; } /* * digitalWrite: * It may seem odd to have a digital write here, but it's the best way * to pass paramters into the chip in the wiringPi way of things. * We have 2 digital registers: * 0 is the gain control * 1 is the data rate control ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int data) { int chan = pin - node->pinBase ; chan &= 3 ; if (chan == 0) // Gain Control { if ( (data < 0) || (data > 6) ) // Use default if out of range data = 2 ; node->data0 = gains [data] ; } else // Data rate control { if ( (data < 0) || (data > 7) ) // Use default if out of range data = 4 ; node->data1 = dataRates [data] ; // Bugfix 0-1 by "Eric de jong (gm)" - Thanks. } } /* * analogWrite: * We're using this to write to the 2 comparitor threshold registers. * We could use a digitalWrite here but as it's an analog comparison * then it feels better to do it this way. ********************************************************************************* */ static void myAnalogWrite (struct wiringPiNodeStruct *node, int pin, int data) { int chan = pin - node->pinBase ; int reg ; int16_t ndata ; chan &= 3 ; reg = chan + 2 ; /**/ if (data < -32767) ndata = -32767 ; else if (data > 32767) ndata = 32767 ; else ndata = (int16_t)data ; ndata = __bswap_16 (ndata) ; wiringPiI2CWriteReg16 (node->fd, reg, data) ; } /* * ads1115Setup: * Create a new wiringPi device node for an ads1115 on the Pi's * I2C interface. ********************************************************************************* */ int ads1115Setup (const int pinBase, int i2cAddr) { struct wiringPiNodeStruct *node ; int fd ; if ((fd = wiringPiI2CSetup (i2cAddr)) < 0) return FALSE ; node = wiringPiNewNode (pinBase, 8) ; node->fd = fd ; node->data0 = CONFIG_PGA_4_096V ; // Gain in data0 node->data1 = CONFIG_DR_128SPS ; // Samples/sec in data1 node->analogRead = myAnalogRead ; node->analogWrite = myAnalogWrite ; node->digitalWrite = myDigitalWrite ; return TRUE ; } wiringpi-2.50/wiringPi/mcp4802.c0000664000175000017500000000422613442550153015757 0ustar ubuntuubuntu/* * mcp4802.c: * Extend wiringPi with the MCP4802 SPI Digital to Analog convertor * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "mcp4802.h" /* * myAnalogWrite: * Write analog value on the given pin ********************************************************************************* */ static void myAnalogWrite (struct wiringPiNodeStruct *node, int pin, int value) { unsigned char spiData [2] ; unsigned char chanBits, dataBits ; int chan = pin - node->pinBase ; if (chan == 0) chanBits = 0x30 ; else chanBits = 0xB0 ; chanBits |= ((value >> 4) & 0x0F) ; dataBits = ((value << 4) & 0xF0) ; spiData [0] = chanBits ; spiData [1] = dataBits ; wiringPiSPIDataRW (node->fd, spiData, 2) ; } /* * mcp4802Setup: * Create a new wiringPi device node for an mcp4802 on the Pi's * SPI interface. ********************************************************************************* */ int mcp4802Setup (const int pinBase, int spiChannel) { struct wiringPiNodeStruct *node ; if (wiringPiSPISetup (spiChannel, 1000000) < 0) return FALSE ; node = wiringPiNewNode (pinBase, 2) ; node->fd = spiChannel ; node->analogWrite = myAnalogWrite ; return TRUE ; } wiringpi-2.50/wiringPi/max5322.h0000664000175000017500000000224213442550153015764 0ustar ubuntuubuntu/* * max5322.h: * Extend wiringPi with the MAX5322 SPI Digital to Analog convertor * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int max5322Setup (int pinBase, int spiChannel) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/ads1115.h0000664000175000017500000000310413442550153015740 0ustar ubuntuubuntu/* * ads1115.c: * Extend wiringPi with the ADS1115 I2C 16-bit ADC * Copyright (c) 2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ // Constants for some of the internal functions // Gain #define ADS1115_GAIN_6 0 #define ADS1115_GAIN_4 1 #define ADS1115_GAIN_2 2 #define ADS1115_GAIN_1 3 #define ADS1115_GAIN_HALF 4 #define ADS1115_GAIN_QUARTER 5 // Data rate #define ADS1115_DR_8 0 #define ADS1115_DR_16 1 #define ADS1115_DR_32 2 #define ADS1115_DR_64 3 #define ADS1115_DR_128 4 #define ADS1115_DR_250 5 #define ADS1115_DR_475 6 #define ADS1115_DR_860 7 #ifdef __cplusplus extern "C" { #endif extern int ads1115Setup (int pinBase, int i2cAddress) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/htu21d.h0000664000175000017500000000223013442550153015767 0ustar ubuntuubuntu/* * htu21d.h: * Extend wiringPi with the HTU21D I2C Humidity and Temperature * sensor. * Copyright (c) 2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int htu21dSetup (const int pinBase) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/noMoreStatic0000664000175000017500000000162613442550153017051 0ustar ubuntuubuntu wiringPi is no-longer shipped with the ability to statically link it. Many reasons but the biggest issue is people who have statically linked wiringPi into their product - for example a Pi UPS device or a Tetris-like game and not subsequently shipped their modified sources. These people are no better than common thieves with complete disregard to the conditions of the LGPL that wiringPi ships with. Additionally, many think it's a good idea to statically link wiringPi into their favourite language - like Node, and Java and other itsy bitsy little things. These people have a complete and utter disregard to what happens underneath when e.g. the Linux kernel changes on the Pi then wiringPi stops as it depends on some Pi kernel features, then the poor user get in-touch with me and I've had over 10,000 emails so-far and it's now beyond a joke. DO NOT STATICALLY LINK WIRINGPI. Gordon Henderson, March 2018. wiringpi-2.50/wiringPi/pseudoPins.h0000664000175000017500000000216713442550153017022 0ustar ubuntuubuntu/* * pseudoPins.h: * Extend wiringPi with a number of pseudo pins which can be * digitally or analog written/read. * Copyright (c) 2012-2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ extern int pseudoPinsSetup (const int pinBase) ; wiringpi-2.50/wiringPi/mcp23008.c0000664000175000017500000000721713442550153016041 0ustar ubuntuubuntu/* * mcp23008.c: * Extend wiringPi with the MCP 23008 I2C GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" #include "wiringPiI2C.h" #include "mcp23x0817.h" #include "mcp23008.h" /* * myPinMode: ********************************************************************************* */ static void myPinMode (struct wiringPiNodeStruct *node, int pin, int mode) { int mask, old, reg ; reg = MCP23x08_IODIR ; mask = 1 << (pin - node->pinBase) ; old = wiringPiI2CReadReg8 (node->fd, reg) ; if (mode == OUTPUT) old &= (~mask) ; else old |= mask ; wiringPiI2CWriteReg8 (node->fd, reg, old) ; } /* * myPullUpDnControl: ********************************************************************************* */ static void myPullUpDnControl (struct wiringPiNodeStruct *node, int pin, int mode) { int mask, old, reg ; reg = MCP23x08_GPPU ; mask = 1 << (pin - node->pinBase) ; old = wiringPiI2CReadReg8 (node->fd, reg) ; if (mode == PUD_UP) old |= mask ; else old &= (~mask) ; wiringPiI2CWriteReg8 (node->fd, reg, old) ; } /* * myDigitalWrite: ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { int bit, old ; bit = 1 << ((pin - node->pinBase) & 7) ; old = node->data2 ; if (value == LOW) old &= (~bit) ; else old |= bit ; wiringPiI2CWriteReg8 (node->fd, MCP23x08_GPIO, old) ; node->data2 = old ; } /* * myDigitalRead: ********************************************************************************* */ static int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { int mask, value ; mask = 1 << ((pin - node->pinBase) & 7) ; value = wiringPiI2CReadReg8 (node->fd, MCP23x08_GPIO) ; if ((value & mask) == 0) return LOW ; else return HIGH ; } /* * mcp23008Setup: * Create a new instance of an MCP23008 I2C GPIO interface. We know it * has 8 pins, so all we need to know here is the I2C address and the * user-defined pin base. ********************************************************************************* */ int mcp23008Setup (const int pinBase, const int i2cAddress) { int fd ; struct wiringPiNodeStruct *node ; if ((fd = wiringPiI2CSetup (i2cAddress)) < 0) return FALSE ; wiringPiI2CWriteReg8 (fd, MCP23x08_IOCON, IOCON_INIT) ; node = wiringPiNewNode (pinBase, 8) ; node->fd = fd ; node->pinMode = myPinMode ; node->pullUpDnControl = myPullUpDnControl ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; node->data2 = wiringPiI2CReadReg8 (fd, MCP23x08_OLAT) ; return TRUE ; } wiringpi-2.50/wiringPi/softServo.c0000664000175000017500000001431613442550153016655 0ustar ubuntuubuntu/* * softServo.c: * Provide N channels of software driven PWM suitable for RC * servo motors. * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ //#include #include #include #include #include #include "wiringPi.h" #include "softServo.h" // RC Servo motors are a bit of an oddity - designed in the days when // radio control was experimental and people were tryin to make // things as simple as possible as it was all very expensive... // // So... To drive an RC Servo motor, you need to send it a modified PWM // signal - it needs anything from 1ms to 2ms - with 1ms meaning // to move the server fully left, and 2ms meaning to move it fully // right. Then you need a long gap before sending the next pulse. // The reason for this is that you send a multiplexed stream of these // pulses up the radio signal into the reciever which de-multiplexes // them into the signals for each individual servo. Typically there // might be 8 channels, so you need at least 8 "slots" of 2mS pulses // meaning the entire frame must fit into a 16mS slot - which would // then be repeated... // // In practice we have a total slot width of about 20mS - so we're sending 50 // updates per second to each servo. // // In this code, we don't need to be too fussy about the gap as we're not doing // the multipexing, but it does need to be at least 10mS, and preferably 16 // from what I've been able to determine. // WARNING: // This code is really experimental. It was written in response to some people // asking for a servo driver, however while it works, there is too much // jitter to successfully drive a small servo - I have tried it with a micro // servo and it worked, but the servo ran hot due to the jitter in the signal // being sent to it. // // If you want servo control for the Pi, then use the servoblaster kernel // module. #define MAX_SERVOS 8 static int pinMap [MAX_SERVOS] ; // Keep track of our pins static int pulseWidth [MAX_SERVOS] ; // microseconds /* * softServoThread: * Thread to do the actual Servo PWM output ********************************************************************************* */ static PI_THREAD (softServoThread) { register int i, j, k, m, tmp ; int lastDelay, pin, servo ; int myDelays [MAX_SERVOS] ; int myPins [MAX_SERVOS] ; struct timeval tNow, tStart, tPeriod, tGap, tTotal ; struct timespec tNs ; tTotal.tv_sec = 0 ; tTotal.tv_usec = 8000 ; piHiPri (50) ; for (;;) { gettimeofday (&tStart, NULL) ; memcpy (myDelays, pulseWidth, sizeof (myDelays)) ; memcpy (myPins, pinMap, sizeof (myPins)) ; // Sort the delays (& pins), shortest first for (m = MAX_SERVOS / 2 ; m > 0 ; m /= 2 ) for (j = m ; j < MAX_SERVOS ; ++j) for (i = j - m ; i >= 0 ; i -= m) { k = i + m ; if (myDelays [k] >= myDelays [i]) break ; else // Swap { tmp = myDelays [i] ; myDelays [i] = myDelays [k] ; myDelays [k] = tmp ; tmp = myPins [i] ; myPins [i] = myPins [k] ; myPins [k] = tmp ; } } // All on lastDelay = 0 ; for (servo = 0 ; servo < MAX_SERVOS ; ++servo) { if ((pin = myPins [servo]) == -1) continue ; digitalWrite (pin, HIGH) ; myDelays [servo] = myDelays [servo] - lastDelay ; lastDelay += myDelays [servo] ; } // Now loop, turning them all off as required for (servo = 0 ; servo < MAX_SERVOS ; ++servo) { if ((pin = myPins [servo]) == -1) continue ; delayMicroseconds (myDelays [servo]) ; digitalWrite (pin, LOW) ; } // Wait until the end of an 8mS time-slot gettimeofday (&tNow, NULL) ; timersub (&tNow, &tStart, &tPeriod) ; timersub (&tTotal, &tPeriod, &tGap) ; tNs.tv_sec = tGap.tv_sec ; tNs.tv_nsec = tGap.tv_usec * 1000 ; nanosleep (&tNs, NULL) ; } return NULL ; } /* * softServoWrite: * Write a Servo value to the given pin ********************************************************************************* */ void softServoWrite (int servoPin, int value) { int servo ; servoPin &= 63 ; /**/ if (value < -250) value = -250 ; else if (value > 1250) value = 1250 ; for (servo = 0 ; servo < MAX_SERVOS ; ++servo) if (pinMap [servo] == servoPin) pulseWidth [servo] = value + 1000 ; // uS } /* * softServoSetup: * Setup the software servo system ********************************************************************************* */ int softServoSetup (int p0, int p1, int p2, int p3, int p4, int p5, int p6, int p7) { int servo ; if (p0 != -1) { pinMode (p0, OUTPUT) ; digitalWrite (p0, LOW) ; } if (p1 != -1) { pinMode (p1, OUTPUT) ; digitalWrite (p1, LOW) ; } if (p2 != -1) { pinMode (p2, OUTPUT) ; digitalWrite (p2, LOW) ; } if (p3 != -1) { pinMode (p3, OUTPUT) ; digitalWrite (p3, LOW) ; } if (p4 != -1) { pinMode (p4, OUTPUT) ; digitalWrite (p4, LOW) ; } if (p5 != -1) { pinMode (p5, OUTPUT) ; digitalWrite (p5, LOW) ; } if (p6 != -1) { pinMode (p6, OUTPUT) ; digitalWrite (p6, LOW) ; } if (p7 != -1) { pinMode (p7, OUTPUT) ; digitalWrite (p7, LOW) ; } pinMap [0] = p0 ; pinMap [1] = p1 ; pinMap [2] = p2 ; pinMap [3] = p3 ; pinMap [4] = p4 ; pinMap [5] = p5 ; pinMap [6] = p6 ; pinMap [7] = p7 ; for (servo = 0 ; servo < MAX_SERVOS ; ++servo) pulseWidth [servo] = 1500 ; // Mid point return piThreadCreate (softServoThread) ; } wiringpi-2.50/wiringPi/wiringPiI2C.c0000664000175000017500000001440213442550153016745 0ustar ubuntuubuntu/* * wiringPiI2C.c: * Simplified I2C access routines * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ /* * Notes: * The Linux I2C code is actually the same (almost) as the SMBus code. * SMBus is System Management Bus - and in essentially I2C with some * additional functionality added, and stricter controls on the electrical * specifications, etc. however I2C does work well with it and the * protocols work over both. * * I'm directly including the SMBus functions here as some Linux distros * lack the correct header files, and also some header files are GPLv2 * rather than the LGPL that wiringPi is released under - presumably because * originally no-one expected I2C/SMBus to be used outside the kernel - * however enter the Raspberry Pi with people now taking directly to I2C * devices without going via the kernel... * * This may ultimately reduce the flexibility of this code, but it won't be * hard to maintain it and keep it current, should things change. * * Information here gained from: kernel/Documentation/i2c/dev-interface * as well as other online resources. ********************************************************************************* */ #include #include #include #include #include #include #include #include #include "wiringPi.h" #include "wiringPiI2C.h" // I2C definitions #define I2C_SLAVE 0x0703 #define I2C_SMBUS 0x0720 /* SMBus-level access */ #define I2C_SMBUS_READ 1 #define I2C_SMBUS_WRITE 0 // SMBus transaction types #define I2C_SMBUS_QUICK 0 #define I2C_SMBUS_BYTE 1 #define I2C_SMBUS_BYTE_DATA 2 #define I2C_SMBUS_WORD_DATA 3 #define I2C_SMBUS_PROC_CALL 4 #define I2C_SMBUS_BLOCK_DATA 5 #define I2C_SMBUS_I2C_BLOCK_BROKEN 6 #define I2C_SMBUS_BLOCK_PROC_CALL 7 /* SMBus 2.0 */ #define I2C_SMBUS_I2C_BLOCK_DATA 8 // SMBus messages #define I2C_SMBUS_BLOCK_MAX 32 /* As specified in SMBus standard */ #define I2C_SMBUS_I2C_BLOCK_MAX 32 /* Not specified but we use same structure */ // Structures used in the ioctl() calls union i2c_smbus_data { uint8_t byte ; uint16_t word ; uint8_t block [I2C_SMBUS_BLOCK_MAX + 2] ; // block [0] is used for length + one more for PEC } ; struct i2c_smbus_ioctl_data { char read_write ; uint8_t command ; int size ; union i2c_smbus_data *data ; } ; static inline int i2c_smbus_access (int fd, char rw, uint8_t command, int size, union i2c_smbus_data *data) { struct i2c_smbus_ioctl_data args ; args.read_write = rw ; args.command = command ; args.size = size ; args.data = data ; return ioctl (fd, I2C_SMBUS, &args) ; } /* * wiringPiI2CRead: * Simple device read ********************************************************************************* */ int wiringPiI2CRead (int fd) { union i2c_smbus_data data ; if (i2c_smbus_access (fd, I2C_SMBUS_READ, 0, I2C_SMBUS_BYTE, &data)) return -1 ; else return data.byte & 0xFF ; } /* * wiringPiI2CReadReg8: wiringPiI2CReadReg16: * Read an 8 or 16-bit value from a regsiter on the device ********************************************************************************* */ int wiringPiI2CReadReg8 (int fd, int reg) { union i2c_smbus_data data; if (i2c_smbus_access (fd, I2C_SMBUS_READ, reg, I2C_SMBUS_BYTE_DATA, &data)) return -1 ; else return data.byte & 0xFF ; } int wiringPiI2CReadReg16 (int fd, int reg) { union i2c_smbus_data data; if (i2c_smbus_access (fd, I2C_SMBUS_READ, reg, I2C_SMBUS_WORD_DATA, &data)) return -1 ; else return data.word & 0xFFFF ; } /* * wiringPiI2CWrite: * Simple device write ********************************************************************************* */ int wiringPiI2CWrite (int fd, int data) { return i2c_smbus_access (fd, I2C_SMBUS_WRITE, data, I2C_SMBUS_BYTE, NULL) ; } /* * wiringPiI2CWriteReg8: wiringPiI2CWriteReg16: * Write an 8 or 16-bit value to the given register ********************************************************************************* */ int wiringPiI2CWriteReg8 (int fd, int reg, int value) { union i2c_smbus_data data ; data.byte = value ; return i2c_smbus_access (fd, I2C_SMBUS_WRITE, reg, I2C_SMBUS_BYTE_DATA, &data) ; } int wiringPiI2CWriteReg16 (int fd, int reg, int value) { union i2c_smbus_data data ; data.word = value ; return i2c_smbus_access (fd, I2C_SMBUS_WRITE, reg, I2C_SMBUS_WORD_DATA, &data) ; } /* * wiringPiI2CSetupInterface: * Undocumented access to set the interface explicitly - might be used * for the Pi's 2nd I2C interface... ********************************************************************************* */ int wiringPiI2CSetupInterface (const char *device, int devId) { int fd ; if ((fd = open (device, O_RDWR)) < 0) return wiringPiFailure (WPI_ALMOST, "Unable to open I2C device: %s\n", strerror (errno)) ; if (ioctl (fd, I2C_SLAVE, devId) < 0) return wiringPiFailure (WPI_ALMOST, "Unable to select I2C device: %s\n", strerror (errno)) ; return fd ; } /* * wiringPiI2CSetup: * Open the I2C device, and regsiter the target device ********************************************************************************* */ int wiringPiI2CSetup (const int devId) { int rev ; const char *device ; rev = piGpioLayout () ; if (rev == 1) device = "/dev/i2c-0" ; else device = "/dev/i2c-1" ; return wiringPiI2CSetupInterface (device, devId) ; } wiringpi-2.50/wiringPi/softPwm.c0000664000175000017500000001071713442550153016323 0ustar ubuntuubuntu/* * softPwm.c: * Provide many channels of software driven PWM. * Copyright (c) 2012-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include "wiringPi.h" #include "softPwm.h" // MAX_PINS: // This is more than the number of Pi pins because we can actually softPwm. // Once upon a time I let pins on gpio expanders be softPwm'd, but it's really // really not a good thing. #define MAX_PINS 64 // The PWM Frequency is derived from the "pulse time" below. Essentially, // the frequency is a function of the range and this pulse time. // The total period will be range * pulse time in µS, so a pulse time // of 100 and a range of 100 gives a period of 100 * 100 = 10,000 µS // which is a frequency of 100Hz. // // It's possible to get a higher frequency by lowering the pulse time, // however CPU uage will skyrocket as wiringPi uses a hard-loop to time // periods under 100µS - this is because the Linux timer calls are just // not accurate at all, and have an overhead. // // Another way to increase the frequency is to reduce the range - however // that reduces the overall output accuracy... #define PULSE_TIME 100 static volatile int marks [MAX_PINS] ; static volatile int range [MAX_PINS] ; static volatile pthread_t threads [MAX_PINS] ; static volatile int newPin = -1 ; /* * softPwmThread: * Thread to do the actual PWM output ********************************************************************************* */ static void *softPwmThread (void *arg) { int pin, mark, space ; struct sched_param param ; param.sched_priority = sched_get_priority_max (SCHED_RR) ; pthread_setschedparam (pthread_self (), SCHED_RR, ¶m) ; pin = *((int *)arg) ; free (arg) ; pin = newPin ; newPin = -1 ; piHiPri (90) ; for (;;) { mark = marks [pin] ; space = range [pin] - mark ; if (mark != 0) digitalWrite (pin, HIGH) ; delayMicroseconds (mark * 100) ; if (space != 0) digitalWrite (pin, LOW) ; delayMicroseconds (space * 100) ; } return NULL ; } /* * softPwmWrite: * Write a PWM value to the given pin ********************************************************************************* */ void softPwmWrite (int pin, int value) { if (pin < MAX_PINS) { /**/ if (value < 0) value = 0 ; else if (value > range [pin]) value = range [pin] ; marks [pin] = value ; } } /* * softPwmCreate: * Create a new softPWM thread. ********************************************************************************* */ int softPwmCreate (int pin, int initialValue, int pwmRange) { int res ; pthread_t myThread ; int *passPin ; if (pin >= MAX_PINS) return -1 ; if (range [pin] != 0) // Already running on this pin return -1 ; if (pwmRange <= 0) return -1 ; passPin = malloc (sizeof (*passPin)) ; if (passPin == NULL) return -1 ; digitalWrite (pin, LOW) ; pinMode (pin, OUTPUT) ; marks [pin] = initialValue ; range [pin] = pwmRange ; *passPin = pin ; newPin = pin ; res = pthread_create (&myThread, NULL, softPwmThread, (void *)passPin) ; while (newPin != -1) delay (1) ; threads [pin] = myThread ; return res ; } /* * softPwmStop: * Stop an existing softPWM thread ********************************************************************************* */ void softPwmStop (int pin) { if (pin < MAX_PINS) { if (range [pin] != 0) { pthread_cancel (threads [pin]) ; pthread_join (threads [pin], NULL) ; range [pin] = 0 ; digitalWrite (pin, LOW) ; } } } wiringpi-2.50/wiringPi/wiringPi.h0000664000175000017500000002000413442550153016447 0ustar ubuntuubuntu/* * wiringPi.h: * Arduino like Wiring library for the Raspberry Pi. * Copyright (c) 2012-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #ifndef __WIRING_PI_H__ #define __WIRING_PI_H__ // C doesn't have true/false by default and I can never remember which // way round they are, so ... // (and yes, I know about stdbool.h but I like capitals for these and I'm old) #ifndef TRUE # define TRUE (1==1) # define FALSE (!TRUE) #endif // GCC warning suppressor #define UNU __attribute__((unused)) // Mask for the bottom 64 pins which belong to the Raspberry Pi // The others are available for the other devices #define PI_GPIO_MASK (0xFFFFFFC0) // Handy defines // wiringPi modes #define WPI_MODE_PINS 0 #define WPI_MODE_GPIO 1 #define WPI_MODE_GPIO_SYS 2 #define WPI_MODE_PHYS 3 #define WPI_MODE_PIFACE 4 #define WPI_MODE_UNINITIALISED -1 // Pin modes #define INPUT 0 #define OUTPUT 1 #define PWM_OUTPUT 2 #define GPIO_CLOCK 3 #define SOFT_PWM_OUTPUT 4 #define SOFT_TONE_OUTPUT 5 #define PWM_TONE_OUTPUT 6 #define LOW 0 #define HIGH 1 // Pull up/down/none #define PUD_OFF 0 #define PUD_DOWN 1 #define PUD_UP 2 // PWM #define PWM_MODE_MS 0 #define PWM_MODE_BAL 1 // Interrupt levels #define INT_EDGE_SETUP 0 #define INT_EDGE_FALLING 1 #define INT_EDGE_RISING 2 #define INT_EDGE_BOTH 3 // Pi model types and version numbers // Intended for the GPIO program Use at your own risk. #define PI_MODEL_A 0 #define PI_MODEL_B 1 #define PI_MODEL_AP 2 #define PI_MODEL_BP 3 #define PI_MODEL_2 4 #define PI_ALPHA 5 #define PI_MODEL_CM 6 #define PI_MODEL_07 7 #define PI_MODEL_3B 8 #define PI_MODEL_ZERO 9 #define PI_MODEL_CM3 10 #define PI_MODEL_ZERO_W 12 #define PI_MODEL_3BP 13 #define PI_MODEL_3AP 14 #define PI_MODEL_CM3P 16 #define PI_VERSION_1 0 #define PI_VERSION_1_1 1 #define PI_VERSION_1_2 2 #define PI_VERSION_2 3 #define PI_MAKER_SONY 0 #define PI_MAKER_EGOMAN 1 #define PI_MAKER_EMBEST 2 #define PI_MAKER_UNKNOWN 3 extern const char *piModelNames [20] ; extern const char *piRevisionNames [16] ; extern const char *piMakerNames [16] ; extern const int piMemorySize [ 8] ; // Intended for the GPIO program Use at your own risk. // Threads #define PI_THREAD(X) void *X (UNU void *dummy) // Failure modes #define WPI_FATAL (1==1) #define WPI_ALMOST (1==2) // wiringPiNodeStruct: // This describes additional device nodes in the extended wiringPi // 2.0 scheme of things. // It's a simple linked list for now, but will hopefully migrate to // a binary tree for efficiency reasons - but then again, the chances // of more than 1 or 2 devices being added are fairly slim, so who // knows.... struct wiringPiNodeStruct { int pinBase ; int pinMax ; int fd ; // Node specific unsigned int data0 ; // ditto unsigned int data1 ; // ditto unsigned int data2 ; // ditto unsigned int data3 ; // ditto void (*pinMode) (struct wiringPiNodeStruct *node, int pin, int mode) ; void (*pullUpDnControl) (struct wiringPiNodeStruct *node, int pin, int mode) ; int (*digitalRead) (struct wiringPiNodeStruct *node, int pin) ; //unsigned int (*digitalRead8) (struct wiringPiNodeStruct *node, int pin) ; void (*digitalWrite) (struct wiringPiNodeStruct *node, int pin, int value) ; // void (*digitalWrite8) (struct wiringPiNodeStruct *node, int pin, int value) ; void (*pwmWrite) (struct wiringPiNodeStruct *node, int pin, int value) ; int (*analogRead) (struct wiringPiNodeStruct *node, int pin) ; void (*analogWrite) (struct wiringPiNodeStruct *node, int pin, int value) ; struct wiringPiNodeStruct *next ; } ; extern struct wiringPiNodeStruct *wiringPiNodes ; // Export variables for the hardware pointers extern volatile unsigned int *_wiringPiGpio ; extern volatile unsigned int *_wiringPiPwm ; extern volatile unsigned int *_wiringPiClk ; extern volatile unsigned int *_wiringPiPads ; extern volatile unsigned int *_wiringPiTimer ; extern volatile unsigned int *_wiringPiTimerIrqRaw ; // Function prototypes // c++ wrappers thanks to a comment by Nick Lott // (and others on the Raspberry Pi forums) #ifdef __cplusplus extern "C" { #endif // Data // Internal extern int wiringPiFailure (int fatal, const char *message, ...) ; // Core wiringPi functions extern struct wiringPiNodeStruct *wiringPiFindNode (int pin) ; extern struct wiringPiNodeStruct *wiringPiNewNode (int pinBase, int numPins) ; extern void wiringPiVersion (int *major, int *minor) ; extern int wiringPiSetup (void) ; extern int wiringPiSetupSys (void) ; extern int wiringPiSetupGpio (void) ; extern int wiringPiSetupPhys (void) ; extern void pinModeAlt (int pin, int mode) ; extern void pinMode (int pin, int mode) ; extern void pullUpDnControl (int pin, int pud) ; extern int digitalRead (int pin) ; extern void digitalWrite (int pin, int value) ; extern unsigned int digitalRead8 (int pin) ; extern void digitalWrite8 (int pin, int value) ; extern void pwmWrite (int pin, int value) ; extern int analogRead (int pin) ; extern void analogWrite (int pin, int value) ; // PiFace specifics // (Deprecated) extern int wiringPiSetupPiFace (void) ; extern int wiringPiSetupPiFaceForGpioProg (void) ; // Don't use this - for gpio program only // On-Board Raspberry Pi hardware specific stuff extern int piGpioLayout (void) ; extern int piBoardRev (void) ; // Deprecated extern void piBoardId (int *model, int *rev, int *mem, int *maker, int *overVolted) ; extern int wpiPinToGpio (int wpiPin) ; extern int physPinToGpio (int physPin) ; extern void setPadDrive (int group, int value) ; extern int getAlt (int pin) ; extern void pwmToneWrite (int pin, int freq) ; extern void pwmSetMode (int mode) ; extern void pwmSetRange (unsigned int range) ; extern void pwmSetClock (int divisor) ; extern void gpioClockSet (int pin, int freq) ; extern unsigned int digitalReadByte (void) ; extern unsigned int digitalReadByte2 (void) ; extern void digitalWriteByte (int value) ; extern void digitalWriteByte2 (int value) ; // Interrupts // (Also Pi hardware specific) extern int waitForInterrupt (int pin, int mS) ; extern int wiringPiISR (int pin, int mode, void (*function)(void)) ; // Threads extern int piThreadCreate (void *(*fn)(void *)) ; extern void piLock (int key) ; extern void piUnlock (int key) ; // Schedulling priority extern int piHiPri (const int pri) ; // Extras from arduino land extern void delay (unsigned int howLong) ; extern void delayMicroseconds (unsigned int howLong) ; extern unsigned int millis (void) ; extern unsigned int micros (void) ; #ifdef __cplusplus } #endif #endif wiringpi-2.50/wiringPi/mcp23016.h0000664000175000017500000000224413442550153016040 0ustar ubuntuubuntu/* * mcp23016.h: * Extend wiringPi with the MCP 23016 I2C GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int mcp23016Setup (const int pinBase, const int i2cAddress) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp23017.h0000664000175000017500000000224113442550153016036 0ustar ubuntuubuntu/* * 23017.h: * Extend wiringPi with the MCP 23017 I2C GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int mcp23017Setup (const int pinBase, const int i2cAddress) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp23016.c0000664000175000017500000000741613442550153016041 0ustar ubuntuubuntu/* * mcp23016.c: * Extend wiringPi with the MCP 23016 I2C GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" #include "wiringPiI2C.h" #include "mcp23016.h" #include "mcp23016reg.h" /* * myPinMode: ********************************************************************************* */ static void myPinMode (struct wiringPiNodeStruct *node, int pin, int mode) { int mask, old, reg ; pin -= node->pinBase ; if (pin < 8) // Bank A reg = MCP23016_IODIR0 ; else { reg = MCP23016_IODIR1 ; pin &= 0x07 ; } mask = 1 << pin ; old = wiringPiI2CReadReg8 (node->fd, reg) ; if (mode == OUTPUT) old &= (~mask) ; else old |= mask ; wiringPiI2CWriteReg8 (node->fd, reg, old) ; } /* * myDigitalWrite: ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { int bit, old ; pin -= node->pinBase ; // Pin now 0-15 bit = 1 << (pin & 7) ; if (pin < 8) // Bank A { old = node->data2 ; if (value == LOW) old &= (~bit) ; else old |= bit ; wiringPiI2CWriteReg8 (node->fd, MCP23016_GP0, old) ; node->data2 = old ; } else // Bank B { old = node->data3 ; if (value == LOW) old &= (~bit) ; else old |= bit ; wiringPiI2CWriteReg8 (node->fd, MCP23016_GP1, old) ; node->data3 = old ; } } /* * myDigitalRead: ********************************************************************************* */ static int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { int mask, value, gpio ; pin -= node->pinBase ; if (pin < 8) // Bank A gpio = MCP23016_GP0 ; else { gpio = MCP23016_GP1 ; pin &= 0x07 ; } mask = 1 << pin ; value = wiringPiI2CReadReg8 (node->fd, gpio) ; if ((value & mask) == 0) return LOW ; else return HIGH ; } /* * mcp23016Setup: * Create a new instance of an MCP23016 I2C GPIO interface. We know it * has 16 pins, so all we need to know here is the I2C address and the * user-defined pin base. ********************************************************************************* */ int mcp23016Setup (const int pinBase, const int i2cAddress) { int fd ; struct wiringPiNodeStruct *node ; if ((fd = wiringPiI2CSetup (i2cAddress)) < 0) return FALSE ; wiringPiI2CWriteReg8 (fd, MCP23016_IOCON0, IOCON_INIT) ; wiringPiI2CWriteReg8 (fd, MCP23016_IOCON1, IOCON_INIT) ; node = wiringPiNewNode (pinBase, 16) ; node->fd = fd ; node->pinMode = myPinMode ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; node->data2 = wiringPiI2CReadReg8 (fd, MCP23016_OLAT0) ; node->data3 = wiringPiI2CReadReg8 (fd, MCP23016_OLAT1) ; return TRUE ; } wiringpi-2.50/wiringPi/bmp180.c0000664000175000017500000001400413442550153015664 0ustar ubuntuubuntu/* * bmp180.c: * Extend wiringPi with the BMP180 I2C Pressure and Temperature * sensor. This is used in the Pi Weather Station * Copyright (c) 2016 Gordon Henderson * * Information from the document held at: * http://wmrx00.sourceforge.net/Arduino/BMP085-Calcs.pdf * was very useful when building this code. * *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include "wiringPi.h" #include "wiringPiI2C.h" #include "bmp180.h" #undef DEBUG #define I2C_ADDRESS 0x77 #define BMP180_OSS 0 // Static calibration data // The down-side of this is that there can only be one BMP180 in // a system - which is practice isn't an issue as it's I2C // address is fixed. static int16_t AC1, AC2, AC3 ; static uint16_t AC4, AC5, AC6 ; static int16_t VB1, VB2 ; static int16_t MB, MC, MD ; static double c5, c6, mc, md, x0, x1, x2, yy0, yy1, yy2, p0, p1, p2 ; // Pressure & Temp variables uint32_t cPress, cTemp ; static int altitude ; /* * read16: * Quick hack to read the 16-bit data with the correct endian ********************************************************************************* */ uint16_t read16 (int fd, int reg) { return (wiringPiI2CReadReg8 (fd, reg) << 8) | wiringPiI2CReadReg8 (fd, reg + 1) ; } /* * bmp180ReadTempPress: * Does the hard work of reading the sensor ********************************************************************************* */ static void bmp180ReadTempPress (int fd) { double fTemp, fPress ; double tu, a ; double pu, s, x, y, z ; uint8_t data [4] ; // Start a temperature sensor reading wiringPiI2CWriteReg8 (fd, 0xF4, 0x2E) ; delay (5) ; // Read the raw data data [0] = wiringPiI2CReadReg8 (fd, 0xF6) ; data [1] = wiringPiI2CReadReg8 (fd, 0xF7) ; // And calculate... tu = (data [0] * 256.0) + data [1] ; a = c5 * (tu - c6) ; fTemp = a + (mc / (a + md)) ; cTemp = (int)rint (((100.0 * fTemp) + 0.5) / 10.0) ; #ifdef DEBUG printf ("fTemp: %f, cTemp: %6d\n", fTemp, cTemp) ; #endif // Start a pressure snsor reading wiringPiI2CWriteReg8 (fd, 0xF4, 0x34 | (BMP180_OSS << 6)) ; delay (5) ; // Read the raw data data [0] = wiringPiI2CReadReg8 (fd, 0xF6) ; data [1] = wiringPiI2CReadReg8 (fd, 0xF7) ; data [2] = wiringPiI2CReadReg8 (fd, 0xF8) ; // And calculate... pu = ((double)data [0] * 256.0) + (double)data [1] + ((double)data [2] / 256.0) ; s = fTemp - 25.0 ; x = (x2 * pow (s, 2.0)) + (x1 * s) + x0 ; y = (yy2 * pow (s, 2.0)) + (yy1 * s) + yy0 ; z = (pu - x) / y ; fPress = (p2 * pow (z, 2.0)) + (p1 * z) + p0 ; cPress = (int)rint (((100.0 * fPress) + 0.5) / 10.0) ; #ifdef DEBUG printf ("fPress: %f, cPress: %6d\n", fPress, cPress) ; #endif } /* * myAnalogWrite: * Write to a fake register to represent the height above sea level * so that the peudo millibar register can read the pressure in mB ********************************************************************************* */ static void myAnalogWrite (struct wiringPiNodeStruct *node, int pin, int value) { int chan = pin - node->pinBase ; if (chan == 0) altitude = value ; } /* * myAnalogRead: ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { int chan = pin - node->pinBase ; bmp180ReadTempPress (node->fd) ; /**/ if (chan == 0) // Read Temperature return cTemp ; else if (chan == 1) // Pressure return cPress ; else if (chan == 2) // Pressure in mB return cPress / pow (1 - ((double)altitude / 44330.0), 5.255) ; else return -9999 ; } /* * bmp180Setup: * Create a new instance of a PCF8591 I2C GPIO interface. We know it * has 4 pins, (4 analog inputs and 1 analog output which we'll shadow * input 0) so all we need to know here is the I2C address and the * user-defined pin base. ********************************************************************************* */ int bmp180Setup (const int pinBase) { double c3, c4, b1 ; int fd ; struct wiringPiNodeStruct *node ; if ((fd = wiringPiI2CSetup (I2C_ADDRESS)) < 0) return FALSE ; node = wiringPiNewNode (pinBase, 4) ; node->fd = fd ; node->analogRead = myAnalogRead ; node->analogWrite = myAnalogWrite ; // Read calibration data AC1 = read16 (fd, 0xAA) ; AC2 = read16 (fd, 0xAC) ; AC3 = read16 (fd, 0xAE) ; AC4 = read16 (fd, 0xB0) ; AC5 = read16 (fd, 0xB2) ; AC6 = read16 (fd, 0xB4) ; VB1 = read16 (fd, 0xB6) ; VB2 = read16 (fd, 0xB8) ; MB = read16 (fd, 0xBA) ; MC = read16 (fd, 0xBC) ; MD = read16 (fd, 0xBE) ; // Calculate coefficients c3 = 160.0 * pow (2.0, -15.0) * AC3 ; c4 = pow (10.0, -3.0) * pow(2.0,-15.0) * AC4 ; b1 = pow (160.0, 2.0) * pow(2.0,-30.0) * VB1 ; c5 = (pow (2.0, -15.0) / 160.0) * AC5 ; c6 = AC6 ; mc = (pow (2.0, 11.0) / pow(160.0,2.0)) * MC ; md = MD / 160.0 ; x0 = AC1 ; x1 = 160.0 * pow (2.0, -13.0) * AC2 ; x2 = pow (160.0, 2.0) * pow(2.0,-25.0) * VB2 ; yy0 = c4 * pow (2.0, 15.0) ; yy1 = c4 * c3 ; yy2 = c4 * b1 ; p0 = (3791.0 - 8.0) / 1600.0 ; p1 = 1.0 - 7357.0 * pow (2.0, -20.0) ; p2 = 3038.0 * 100.0 * pow (2.0, -36.0) ; return TRUE ; } wiringpi-2.50/wiringPi/wiringPiI2C.h0000664000175000017500000000305313442550153016752 0ustar ubuntuubuntu/* * wiringPiI2C.h: * Simplified I2C access routines * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int wiringPiI2CRead (int fd) ; extern int wiringPiI2CReadReg8 (int fd, int reg) ; extern int wiringPiI2CReadReg16 (int fd, int reg) ; extern int wiringPiI2CWrite (int fd, int data) ; extern int wiringPiI2CWriteReg8 (int fd, int reg, int data) ; extern int wiringPiI2CWriteReg16 (int fd, int reg, int data) ; extern int wiringPiI2CSetupInterface (const char *device, int devId) ; extern int wiringPiI2CSetup (const int devId) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/piThread.c0000664000175000017500000000341613442550153016422 0ustar ubuntuubuntu/* * piThread.c: * Provide a simplified interface to pthreads * * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include "wiringPi.h" static pthread_mutex_t piMutexes [4] ; /* * piThreadCreate: * Create and start a thread ********************************************************************************* */ int piThreadCreate (void *(*fn)(void *)) { pthread_t myThread ; return pthread_create (&myThread, NULL, fn, NULL) ; } /* * piLock: piUnlock: * Activate/Deactivate a mutex. * We're keeping things simple here and only tracking 4 mutexes which * is more than enough for out entry-level pthread programming ********************************************************************************* */ void piLock (int key) { pthread_mutex_lock (&piMutexes [key]) ; } void piUnlock (int key) { pthread_mutex_unlock (&piMutexes [key]) ; } wiringpi-2.50/wiringPi/piHiPri.c0000664000175000017500000000312313442550153016221 0ustar ubuntuubuntu/* * piHiPri: * Simple way to get your program running at high priority * with realtime schedulling. * * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" /* * piHiPri: * Attempt to set a high priority schedulling for the running program ********************************************************************************* */ int piHiPri (const int pri) { struct sched_param sched ; memset (&sched, 0, sizeof(sched)) ; if (pri > sched_get_priority_max (SCHED_RR)) sched.sched_priority = sched_get_priority_max (SCHED_RR) ; else sched.sched_priority = pri ; return sched_setscheduler (0, SCHED_RR, &sched) ; } wiringpi-2.50/wiringPi/pcf8574.h0000664000175000017500000000224013442550153015761 0ustar ubuntuubuntu/* * pcf8574.h: * Extend wiringPi with the PCF8574 I2C GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int pcf8574Setup (const int pinBase, const int i2cAddress) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/wiringPiSPI.h0000664000175000017500000000245613442550153017036 0ustar ubuntuubuntu/* * wiringPiSPI.h: * Simplified SPI access routines * Copyright (c) 2012-2015 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif int wiringPiSPIGetFd (int channel) ; int wiringPiSPIDataRW (int channel, unsigned char *data, int len) ; int wiringPiSPISetupMode (int channel, int speed, int mode) ; int wiringPiSPISetup (int channel, int speed) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp3422.h0000664000175000017500000000251313442550153015756 0ustar ubuntuubuntu/* * mcp3422.h: * Extend wiringPi with the MCP3422/3/4 I2C ADC chip *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #define MCP3422_SR_240 0 #define MCP3422_SR_60 1 #define MCP3422_SR_15 2 #define MCP3422_SR_3_75 3 #define MCP3422_GAIN_1 0 #define MCP3422_GAIN_2 1 #define MCP3422_GAIN_4 2 #define MCP3422_GAIN_8 3 #ifdef __cplusplus extern "C" { #endif extern int mcp3422Setup (int pinBase, int i2cAddress, int sampleRate, int gain) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/wiringPi.c0000664000175000017500000021262713442550153016460 0ustar ubuntuubuntu/* * wiringPi: * Arduino look-a-like Wiring library for the Raspberry Pi * Copyright (c) 2012-2017 Gordon Henderson * Additional code for pwmSetClock by Chris Hall * * Thanks to code samples from Gert Jan van Loo and the * BCM2835 ARM Peripherals manual, however it's missing * the clock section /grr/mutter/ *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ // Revisions: // 19 Jul 2012: // Moved to the LGPL // Added an abstraction layer to the main routines to save a tiny // bit of run-time and make the clode a little cleaner (if a little // larger) // Added waitForInterrupt code // Added piHiPri code // // 9 Jul 2012: // Added in support to use the /sys/class/gpio interface. // 2 Jul 2012: // Fixed a few more bugs to do with range-checking when in GPIO mode. // 11 Jun 2012: // Fixed some typos. // Added c++ support for the .h file // Added a new function to allow for using my "pin" numbers, or native // GPIO pin numbers. // Removed my busy-loop delay and replaced it with a call to delayMicroseconds // // 02 May 2012: // Added in the 2 UART pins // Change maxPins to numPins to more accurately reflect purpose #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "softPwm.h" #include "softTone.h" #include "wiringPi.h" #include "../version.h" // Environment Variables #define ENV_DEBUG "WIRINGPI_DEBUG" #define ENV_CODES "WIRINGPI_CODES" #define ENV_GPIOMEM "WIRINGPI_GPIOMEM" // Extend wiringPi with other pin-based devices and keep track of // them in this structure struct wiringPiNodeStruct *wiringPiNodes = NULL ; // BCM Magic #define BCM_PASSWORD 0x5A000000 // The BCM2835 has 54 GPIO pins. // BCM2835 data sheet, Page 90 onwards. // There are 6 control registers, each control the functions of a block // of 10 pins. // Each control register has 10 sets of 3 bits per GPIO pin - the ALT values // // 000 = GPIO Pin X is an input // 001 = GPIO Pin X is an output // 100 = GPIO Pin X takes alternate function 0 // 101 = GPIO Pin X takes alternate function 1 // 110 = GPIO Pin X takes alternate function 2 // 111 = GPIO Pin X takes alternate function 3 // 011 = GPIO Pin X takes alternate function 4 // 010 = GPIO Pin X takes alternate function 5 // // So the 3 bits for port X are: // X / 10 + ((X % 10) * 3) // Port function select bits #define FSEL_INPT 0b000 #define FSEL_OUTP 0b001 #define FSEL_ALT0 0b100 #define FSEL_ALT1 0b101 #define FSEL_ALT2 0b110 #define FSEL_ALT3 0b111 #define FSEL_ALT4 0b011 #define FSEL_ALT5 0b010 // Access from ARM Running Linux // Taken from Gert/Doms code. Some of this is not in the manual // that I can find )-: // // Updates in September 2015 - all now static variables (and apologies for the caps) // due to the Pi v2, v3, etc. and the new /dev/gpiomem interface static volatile unsigned int GPIO_PADS ; static volatile unsigned int GPIO_CLOCK_BASE ; static volatile unsigned int GPIO_BASE ; static volatile unsigned int GPIO_TIMER ; static volatile unsigned int GPIO_PWM ; #define PAGE_SIZE (4*1024) #define BLOCK_SIZE (4*1024) static unsigned int usingGpioMem = FALSE ; static int wiringPiSetuped = FALSE ; // PWM // Word offsets into the PWM control region #define PWM_CONTROL 0 #define PWM_STATUS 1 #define PWM0_RANGE 4 #define PWM0_DATA 5 #define PWM1_RANGE 8 #define PWM1_DATA 9 // Clock regsiter offsets #define PWMCLK_CNTL 40 #define PWMCLK_DIV 41 #define PWM0_MS_MODE 0x0080 // Run in MS mode #define PWM0_USEFIFO 0x0020 // Data from FIFO #define PWM0_REVPOLAR 0x0010 // Reverse polarity #define PWM0_OFFSTATE 0x0008 // Ouput Off state #define PWM0_REPEATFF 0x0004 // Repeat last value if FIFO empty #define PWM0_SERIAL 0x0002 // Run in serial mode #define PWM0_ENABLE 0x0001 // Channel Enable #define PWM1_MS_MODE 0x8000 // Run in MS mode #define PWM1_USEFIFO 0x2000 // Data from FIFO #define PWM1_REVPOLAR 0x1000 // Reverse polarity #define PWM1_OFFSTATE 0x0800 // Ouput Off state #define PWM1_REPEATFF 0x0400 // Repeat last value if FIFO empty #define PWM1_SERIAL 0x0200 // Run in serial mode #define PWM1_ENABLE 0x0100 // Channel Enable // Timer // Word offsets #define TIMER_LOAD (0x400 >> 2) #define TIMER_VALUE (0x404 >> 2) #define TIMER_CONTROL (0x408 >> 2) #define TIMER_IRQ_CLR (0x40C >> 2) #define TIMER_IRQ_RAW (0x410 >> 2) #define TIMER_IRQ_MASK (0x414 >> 2) #define TIMER_RELOAD (0x418 >> 2) #define TIMER_PRE_DIV (0x41C >> 2) #define TIMER_COUNTER (0x420 >> 2) // Locals to hold pointers to the hardware static volatile unsigned int *gpio ; static volatile unsigned int *pwm ; static volatile unsigned int *clk ; static volatile unsigned int *pads ; static volatile unsigned int *timer ; static volatile unsigned int *timerIrqRaw ; // Export variables for the hardware pointers volatile unsigned int *_wiringPiGpio ; volatile unsigned int *_wiringPiPwm ; volatile unsigned int *_wiringPiClk ; volatile unsigned int *_wiringPiPads ; volatile unsigned int *_wiringPiTimer ; volatile unsigned int *_wiringPiTimerIrqRaw ; // Data for use with the boardId functions. // The order of entries here to correspond with the PI_MODEL_X // and PI_VERSION_X defines in wiringPi.h // Only intended for the gpio command - use at your own risk! // piGpioBase: // The base address of the GPIO memory mapped hardware IO #define GPIO_PERI_BASE_OLD 0x20000000 #define GPIO_PERI_BASE_NEW 0x3F000000 static volatile unsigned int piGpioBase = 0 ; const char *piModelNames [20] = { "Model A", // 0 "Model B", // 1 "Model A+", // 2 "Model B+", // 3 "Pi 2", // 4 "Alpha", // 5 "CM", // 6 "Unknown07", // 07 "Pi 3", // 08 "Pi Zero", // 09 "CM3", // 10 "Unknown11", // 11 "Pi Zero-W", // 12 "Pi 3B+", // 13 "Pi 3A+", // 14 "Unknown15", // 15 "CM3+", // 16 "Unknown17", // 17 "Unknown18", // 18 "Unknown19", // 19 } ; const char *piRevisionNames [16] = { "00", "01", "02", "03", "04", "05", "06", "07", "08", "09", "10", "11", "12", "13", "14", "15", } ; const char *piMakerNames [16] = { "Sony", // 0 "Egoman", // 1 "Embest", // 2 "Unknown", // 3 "Embest", // 4 "Unknown05", // 5 "Unknown06", // 6 "Unknown07", // 7 "Unknown08", // 8 "Unknown09", // 9 "Unknown10", // 10 "Unknown11", // 11 "Unknown12", // 12 "Unknown13", // 13 "Unknown14", // 14 "Unknown15", // 15 } ; const int piMemorySize [8] = { 256, // 0 512, // 1 1024, // 2 0, // 3 0, // 4 0, // 5 0, // 6 0, // 7 } ; // Time for easy calculations static uint64_t epochMilli, epochMicro ; // Misc static int wiringPiMode = WPI_MODE_UNINITIALISED ; static volatile int pinPass = -1 ; static pthread_mutex_t pinMutex ; // Debugging & Return codes int wiringPiDebug = FALSE ; int wiringPiReturnCodes = FALSE ; // Use /dev/gpiomem ? int wiringPiTryGpioMem = FALSE ; // sysFds: // Map a file descriptor from the /sys/class/gpio/gpioX/value static int sysFds [64] = { -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, } ; // ISR Data static void (*isrFunctions [64])(void) ; // Doing it the Arduino way with lookup tables... // Yes, it's probably more innefficient than all the bit-twidling, but it // does tend to make it all a bit clearer. At least to me! // pinToGpio: // Take a Wiring pin (0 through X) and re-map it to the BCM_GPIO pin // Cope for 3 different board revisions here. static int *pinToGpio ; // Revision 1, 1.1: static int pinToGpioR1 [64] = { 17, 18, 21, 22, 23, 24, 25, 4, // From the Original Wiki - GPIO 0 through 7: wpi 0 - 7 0, 1, // I2C - SDA1, SCL1 wpi 8 - 9 8, 7, // SPI - CE1, CE0 wpi 10 - 11 10, 9, 11, // SPI - MOSI, MISO, SCLK wpi 12 - 14 14, 15, // UART - Tx, Rx wpi 15 - 16 // Padding: -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // ... 31 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // ... 47 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // ... 63 } ; // Revision 2: static int pinToGpioR2 [64] = { 17, 18, 27, 22, 23, 24, 25, 4, // From the Original Wiki - GPIO 0 through 7: wpi 0 - 7 2, 3, // I2C - SDA0, SCL0 wpi 8 - 9 8, 7, // SPI - CE1, CE0 wpi 10 - 11 10, 9, 11, // SPI - MOSI, MISO, SCLK wpi 12 - 14 14, 15, // UART - Tx, Rx wpi 15 - 16 28, 29, 30, 31, // Rev 2: New GPIOs 8 though 11 wpi 17 - 20 5, 6, 13, 19, 26, // B+ wpi 21, 22, 23, 24, 25 12, 16, 20, 21, // B+ wpi 26, 27, 28, 29 0, 1, // B+ wpi 30, 31 // Padding: -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // ... 47 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // ... 63 } ; // physToGpio: // Take a physical pin (1 through 26) and re-map it to the BCM_GPIO pin // Cope for 2 different board revisions here. // Also add in the P5 connector, so the P5 pins are 3,4,5,6, so 53,54,55,56 static int *physToGpio ; static int physToGpioR1 [64] = { -1, // 0 -1, -1, // 1, 2 0, -1, 1, -1, 4, 14, -1, 15, 17, 18, 21, -1, 22, 23, -1, 24, 10, -1, 9, 25, 11, 8, -1, 7, // 25, 26 -1, -1, -1, -1, -1, // ... 31 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // ... 47 -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, // ... 63 } ; static int physToGpioR2 [64] = { -1, // 0 -1, -1, // 1, 2 2, -1, 3, -1, 4, 14, -1, 15, 17, 18, 27, -1, 22, 23, -1, 24, 10, -1, 9, 25, 11, 8, -1, 7, // 25, 26 // B+ 0, 1, 5, -1, 6, 12, 13, -1, 19, 16, 26, 20, -1, 21, // the P5 connector on the Rev 2 boards: -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 28, 29, 30, 31, -1, -1, -1, -1, -1, -1, -1, -1, } ; // gpioToGPFSEL: // Map a BCM_GPIO pin to it's Function Selection // control port. (GPFSEL 0-5) // Groups of 10 - 3 bits per Function - 30 bits per port static uint8_t gpioToGPFSEL [] = { 0,0,0,0,0,0,0,0,0,0, 1,1,1,1,1,1,1,1,1,1, 2,2,2,2,2,2,2,2,2,2, 3,3,3,3,3,3,3,3,3,3, 4,4,4,4,4,4,4,4,4,4, 5,5,5,5,5,5,5,5,5,5, } ; // gpioToShift // Define the shift up for the 3 bits per pin in each GPFSEL port static uint8_t gpioToShift [] = { 0,3,6,9,12,15,18,21,24,27, 0,3,6,9,12,15,18,21,24,27, 0,3,6,9,12,15,18,21,24,27, 0,3,6,9,12,15,18,21,24,27, 0,3,6,9,12,15,18,21,24,27, 0,3,6,9,12,15,18,21,24,27, } ; // gpioToGPSET: // (Word) offset to the GPIO Set registers for each GPIO pin static uint8_t gpioToGPSET [] = { 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, 8, } ; // gpioToGPCLR: // (Word) offset to the GPIO Clear registers for each GPIO pin static uint8_t gpioToGPCLR [] = { 10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10,10, 11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11, } ; // gpioToGPLEV: // (Word) offset to the GPIO Input level registers for each GPIO pin static uint8_t gpioToGPLEV [] = { 13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13, 14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14, } ; #ifdef notYetReady // gpioToEDS // (Word) offset to the Event Detect Status static uint8_t gpioToEDS [] = { 16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16,16, 17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17,17, } ; // gpioToREN // (Word) offset to the Rising edge ENable register static uint8_t gpioToREN [] = { 19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19,19, 20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20,20, } ; // gpioToFEN // (Word) offset to the Falling edgde ENable register static uint8_t gpioToFEN [] = { 22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22,22, 23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23,23, } ; #endif // GPPUD: // GPIO Pin pull up/down register #define GPPUD 37 // gpioToPUDCLK // (Word) offset to the Pull Up Down Clock regsiter static uint8_t gpioToPUDCLK [] = { 38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38,38, 39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39,39, } ; // gpioToPwmALT // the ALT value to put a GPIO pin into PWM mode static uint8_t gpioToPwmALT [] = { 0, 0, 0, 0, 0, 0, 0, 0, // 0 -> 7 0, 0, 0, 0, FSEL_ALT0, FSEL_ALT0, 0, 0, // 8 -> 15 0, 0, FSEL_ALT5, FSEL_ALT5, 0, 0, 0, 0, // 16 -> 23 0, 0, 0, 0, 0, 0, 0, 0, // 24 -> 31 0, 0, 0, 0, 0, 0, 0, 0, // 32 -> 39 FSEL_ALT0, FSEL_ALT0, 0, 0, 0, FSEL_ALT0, 0, 0, // 40 -> 47 0, 0, 0, 0, 0, 0, 0, 0, // 48 -> 55 0, 0, 0, 0, 0, 0, 0, 0, // 56 -> 63 } ; // gpioToPwmPort // The port value to put a GPIO pin into PWM mode static uint8_t gpioToPwmPort [] = { 0, 0, 0, 0, 0, 0, 0, 0, // 0 -> 7 0, 0, 0, 0, PWM0_DATA, PWM1_DATA, 0, 0, // 8 -> 15 0, 0, PWM0_DATA, PWM1_DATA, 0, 0, 0, 0, // 16 -> 23 0, 0, 0, 0, 0, 0, 0, 0, // 24 -> 31 0, 0, 0, 0, 0, 0, 0, 0, // 32 -> 39 PWM0_DATA, PWM1_DATA, 0, 0, 0, PWM1_DATA, 0, 0, // 40 -> 47 0, 0, 0, 0, 0, 0, 0, 0, // 48 -> 55 0, 0, 0, 0, 0, 0, 0, 0, // 56 -> 63 } ; // gpioToGpClkALT: // ALT value to put a GPIO pin into GP Clock mode. // On the Pi we can really only use BCM_GPIO_4 and BCM_GPIO_21 // for clocks 0 and 1 respectively, however I'll include the full // list for completeness - maybe one day... #define GPIO_CLOCK_SOURCE 1 // gpioToGpClkALT0: static uint8_t gpioToGpClkALT0 [] = { 0, 0, 0, 0, FSEL_ALT0, FSEL_ALT0, FSEL_ALT0, 0, // 0 -> 7 0, 0, 0, 0, 0, 0, 0, 0, // 8 -> 15 0, 0, 0, 0, FSEL_ALT5, FSEL_ALT5, 0, 0, // 16 -> 23 0, 0, 0, 0, 0, 0, 0, 0, // 24 -> 31 FSEL_ALT0, 0, FSEL_ALT0, 0, 0, 0, 0, 0, // 32 -> 39 0, 0, FSEL_ALT0, FSEL_ALT0, FSEL_ALT0, 0, 0, 0, // 40 -> 47 0, 0, 0, 0, 0, 0, 0, 0, // 48 -> 55 0, 0, 0, 0, 0, 0, 0, 0, // 56 -> 63 } ; // gpioToClk: // (word) Offsets to the clock Control and Divisor register static uint8_t gpioToClkCon [] = { -1, -1, -1, -1, 28, 30, 32, -1, // 0 -> 7 -1, -1, -1, -1, -1, -1, -1, -1, // 8 -> 15 -1, -1, -1, -1, 28, 30, -1, -1, // 16 -> 23 -1, -1, -1, -1, -1, -1, -1, -1, // 24 -> 31 28, -1, 28, -1, -1, -1, -1, -1, // 32 -> 39 -1, -1, 28, 30, 28, -1, -1, -1, // 40 -> 47 -1, -1, -1, -1, -1, -1, -1, -1, // 48 -> 55 -1, -1, -1, -1, -1, -1, -1, -1, // 56 -> 63 } ; static uint8_t gpioToClkDiv [] = { -1, -1, -1, -1, 29, 31, 33, -1, // 0 -> 7 -1, -1, -1, -1, -1, -1, -1, -1, // 8 -> 15 -1, -1, -1, -1, 29, 31, -1, -1, // 16 -> 23 -1, -1, -1, -1, -1, -1, -1, -1, // 24 -> 31 29, -1, 29, -1, -1, -1, -1, -1, // 32 -> 39 -1, -1, 29, 31, 29, -1, -1, -1, // 40 -> 47 -1, -1, -1, -1, -1, -1, -1, -1, // 48 -> 55 -1, -1, -1, -1, -1, -1, -1, -1, // 56 -> 63 } ; /* * Functions ********************************************************************************* */ /* * wiringPiFailure: * Fail. Or not. ********************************************************************************* */ int wiringPiFailure (int fatal, const char *message, ...) { va_list argp ; char buffer [1024] ; if (!fatal && wiringPiReturnCodes) return -1 ; va_start (argp, message) ; vsnprintf (buffer, 1023, message, argp) ; va_end (argp) ; fprintf (stderr, "%s", buffer) ; exit (EXIT_FAILURE) ; return 0 ; } /* * setupCheck * Another sanity check because some users forget to call the setup * function. Mosty because they need feeding C drip by drip )-: ********************************************************************************* */ static void setupCheck (const char *fName) { if (!wiringPiSetuped) { fprintf (stderr, "%s: You have not called one of the wiringPiSetup\n" " functions, so I'm aborting your program before it crashes anyway.\n", fName) ; exit (EXIT_FAILURE) ; } } /* * gpioMemCheck: * See if we're using the /dev/gpiomem interface, if-so then some operations * can't be done and will crash the Pi. ********************************************************************************* */ static void usingGpioMemCheck (const char *what) { if (usingGpioMem) { fprintf (stderr, "%s: Unable to do this when using /dev/gpiomem. Try sudo?\n", what) ; exit (EXIT_FAILURE) ; } } /* * piGpioLayout: * Return a number representing the hardware revision of the board. * This is not strictly the board revision but is used to check the * layout of the GPIO connector - and there are 2 types that we are * really interested in here. The very earliest Pi's and the * ones that came after that which switched some pins .... * * Revision 1 really means the early Model A and B's. * Revision 2 is everything else - it covers the B, B+ and CM. * ... and the Pi 2 - which is a B+ ++ ... * ... and the Pi 0 - which is an A+ ... * * The main difference between the revision 1 and 2 system that I use here * is the mapping of the GPIO pins. From revision 2, the Pi Foundation changed * 3 GPIO pins on the (original) 26-way header - BCM_GPIO 22 was dropped and * replaced with 27, and 0 + 1 - I2C bus 0 was changed to 2 + 3; I2C bus 1. * * Additionally, here we set the piModel2 flag too. This is again, nothing to * do with the actual model, but the major version numbers - the GPIO base * hardware address changed at model 2 and above (not the Zero though) * ********************************************************************************* */ static void piGpioLayoutOops (const char *why) { fprintf (stderr, "Oops: Unable to determine board revision from /proc/cpuinfo\n") ; fprintf (stderr, " -> %s\n", why) ; fprintf (stderr, " -> You'd best google the error to find out why.\n") ; //fprintf (stderr, " -> http://www.raspberrypi.org/phpBB3/viewtopic.php?p=184410#p184410\n") ; exit (EXIT_FAILURE) ; } int piGpioLayout (void) { FILE *cpuFd ; char line [120] ; char *c ; static int gpioLayout = -1 ; if (gpioLayout != -1) // No point checking twice return gpioLayout ; if ((cpuFd = fopen ("/proc/cpuinfo", "r")) == NULL) piGpioLayoutOops ("Unable to open /proc/cpuinfo") ; // Start by looking for the Architecture to make sure we're really running // on a Pi. I'm getting fed-up with people whinging at me because // they can't get it to work on weirdFruitPi boards... while (fgets (line, 120, cpuFd) != NULL) if (strncmp (line, "Hardware", 8) == 0) break ; if (strncmp (line, "Hardware", 8) != 0) piGpioLayoutOops ("No \"Hardware\" line") ; if (wiringPiDebug) printf ("piGpioLayout: Hardware: %s\n", line) ; // See if it's BCM2708 or BCM2709 or the new BCM2835. // OK. As of Kernel 4.8, we have BCM2835 only, regardless of model. // However I still want to check because it will trap the cheapskates and rip- // off merchants who want to use wiringPi on non-Raspberry Pi platforms - which // I do not support so don't email me your bleating whinges about anything // other than a genuine Raspberry Pi. #ifdef DONT_CARE_ANYMORE if (! (strstr (line, "BCM2708") || strstr (line, "BCM2709") || strstr (line, "BCM2835"))) { fprintf (stderr, "Unable to determine hardware version. I see: %s,\n", line) ; fprintf (stderr, " - expecting BCM2708, BCM2709 or BCM2835.\n") ; fprintf (stderr, "If this is a genuine Raspberry Pi then please report this\n") ; fprintf (stderr, "to projects@drogon.net. If this is not a Raspberry Pi then you\n") ; fprintf (stderr, "are on your own as wiringPi is designed to support the\n") ; fprintf (stderr, "Raspberry Pi ONLY.\n") ; exit (EXIT_FAILURE) ; } #endif // Actually... That has caused me more than 10,000 emails so-far. Mosty by // people who think they know better by creating a statically linked // version that will not run with a new 4.9 kernel. I utterly hate and // despise those people. // // I also get bleats from people running other than Raspbian with another // distros compiled kernel rather than a foundation compiled kernel, so // this might actually help them. It might not - I only have the capacity // to support Raspbian. // // However, I've decided to leave this check out and rely purely on the // Revision: line for now. It will not work on a non-pi hardware or weird // kernels that don't give you a suitable revision line. // So - we're Probably on a Raspberry Pi. Check the revision field for the real // hardware type // In-future, I ought to use the device tree as there are now Pi entries in // /proc/device-tree/ ... // but I'll leave that for the next revision. Or the next. // Isolate the Revision line rewind (cpuFd) ; while (fgets (line, 120, cpuFd) != NULL) if (strncmp (line, "Revision", 8) == 0) break ; fclose (cpuFd) ; if (strncmp (line, "Revision", 8) != 0) piGpioLayoutOops ("No \"Revision\" line") ; // Chomp trailing CR/NL for (c = &line [strlen (line) - 1] ; (*c == '\n') || (*c == '\r') ; --c) *c = 0 ; if (wiringPiDebug) printf ("piGpioLayout: Revision string: %s\n", line) ; // Scan to the first character of the revision number for (c = line ; *c ; ++c) if (*c == ':') break ; if (*c != ':') piGpioLayoutOops ("Bogus \"Revision\" line (no colon)") ; // Chomp spaces ++c ; while (isspace (*c)) ++c ; if (!isxdigit (*c)) piGpioLayoutOops ("Bogus \"Revision\" line (no hex digit at start of revision)") ; // Make sure its long enough if (strlen (c) < 4) piGpioLayoutOops ("Bogus revision line (too small)") ; // Isolate last 4 characters: (in-case of overvolting or new encoding scheme) c = c + strlen (c) - 4 ; if (wiringPiDebug) printf ("piGpioLayout: last4Chars are: \"%s\"\n", c) ; if ( (strcmp (c, "0002") == 0) || (strcmp (c, "0003") == 0)) gpioLayout = 1 ; else gpioLayout = 2 ; // Covers everything else from the B revision 2 to the B+, the Pi v2, v3, zero and CM's. if (wiringPiDebug) printf ("piGpioLayoutOops: Returning revision: %d\n", gpioLayout) ; return gpioLayout ; } /* * piBoardRev: * Deprecated, but does the same as piGpioLayout ********************************************************************************* */ int piBoardRev (void) { return piGpioLayout () ; } /* * piBoardId: * Return the real details of the board we have. * * This is undocumented and really only intended for the GPIO command. * Use at your own risk! * * Seems there are some boards with 0000 in them (mistake in manufacture) * So the distinction between boards that I can see is: * * 0000 - Error * 0001 - Not used * * Original Pi boards: * 0002 - Model B, Rev 1, 256MB, Egoman * 0003 - Model B, Rev 1.1, 256MB, Egoman, Fuses/D14 removed. * * Newer Pi's with remapped GPIO: * 0004 - Model B, Rev 1.2, 256MB, Sony * 0005 - Model B, Rev 1.2, 256MB, Egoman * 0006 - Model B, Rev 1.2, 256MB, Egoman * * 0007 - Model A, Rev 1.2, 256MB, Egoman * 0008 - Model A, Rev 1.2, 256MB, Sony * 0009 - Model A, Rev 1.2, 256MB, Egoman * * 000d - Model B, Rev 1.2, 512MB, Egoman (Red Pi, Blue Pi?) * 000e - Model B, Rev 1.2, 512MB, Sony * 000f - Model B, Rev 1.2, 512MB, Egoman * * 0010 - Model B+, Rev 1.2, 512MB, Sony * 0013 - Model B+ Rev 1.2, 512MB, Embest * 0016 - Model B+ Rev 1.2, 512MB, Sony * 0019 - Model B+ Rev 1.2, 512MB, Egoman * * 0011 - Pi CM, Rev 1.1, 512MB, Sony * 0014 - Pi CM, Rev 1.1, 512MB, Embest * 0017 - Pi CM, Rev 1.1, 512MB, Sony * 001a - Pi CM, Rev 1.1, 512MB, Egoman * * 0012 - Model A+ Rev 1.1, 256MB, Sony * 0015 - Model A+ Rev 1.1, 512MB, Embest * 0018 - Model A+ Rev 1.1, 256MB, Sony * 001b - Model A+ Rev 1.1, 256MB, Egoman * * A small thorn is the olde style overvolting - that will add in * 1000000 * * The Pi compute module has an revision of 0011 or 0014 - since we only * check the last digit, then it's 1, therefore it'll default to not 2 or * 3 for a Rev 1, so will appear as a Rev 2. This is fine for the most part, but * we'll properly detect the Compute Module later and adjust accordingly. * * And then things changed with the introduction of the v2... * * For Pi v2 and subsequent models - e.g. the Zero: * * [USER:8] [NEW:1] [MEMSIZE:3] [MANUFACTURER:4] [PROCESSOR:4] [TYPE:8] [REV:4] * NEW 23: will be 1 for the new scheme, 0 for the old scheme * MEMSIZE 20: 0=256M 1=512M 2=1G * MANUFACTURER 16: 0=SONY 1=EGOMAN 2=EMBEST * PROCESSOR 12: 0=2835 1=2836 * TYPE 04: 0=MODELA 1=MODELB 2=MODELA+ 3=MODELB+ 4=Pi2 MODEL B 5=ALPHA 6=CM * REV 00: 0=REV0 1=REV1 2=REV2 ********************************************************************************* */ void piBoardId (int *model, int *rev, int *mem, int *maker, int *warranty) { FILE *cpuFd ; char line [120] ; char *c ; unsigned int revision ; int bRev, bType, bProc, bMfg, bMem, bWarranty ; // Will deal with the properly later on - for now, lets just get it going... // unsigned int modelNum ; (void)piGpioLayout () ; // Call this first to make sure all's OK. Don't care about the result. if ((cpuFd = fopen ("/proc/cpuinfo", "r")) == NULL) piGpioLayoutOops ("Unable to open /proc/cpuinfo") ; while (fgets (line, 120, cpuFd) != NULL) if (strncmp (line, "Revision", 8) == 0) break ; fclose (cpuFd) ; if (strncmp (line, "Revision", 8) != 0) piGpioLayoutOops ("No \"Revision\" line") ; // Chomp trailing CR/NL for (c = &line [strlen (line) - 1] ; (*c == '\n') || (*c == '\r') ; --c) *c = 0 ; if (wiringPiDebug) printf ("piBoardId: Revision string: %s\n", line) ; // Need to work out if it's using the new or old encoding scheme: // Scan to the first character of the revision number for (c = line ; *c ; ++c) if (*c == ':') break ; if (*c != ':') piGpioLayoutOops ("Bogus \"Revision\" line (no colon)") ; // Chomp spaces ++c ; while (isspace (*c)) ++c ; if (!isxdigit (*c)) piGpioLayoutOops ("Bogus \"Revision\" line (no hex digit at start of revision)") ; revision = (unsigned int)strtol (c, NULL, 16) ; // Hex number with no leading 0x // Check for new way: if ((revision & (1 << 23)) != 0) // New way { if (wiringPiDebug) printf ("piBoardId: New Way: revision is: %08X\n", revision) ; bRev = (revision & (0x0F << 0)) >> 0 ; bType = (revision & (0xFF << 4)) >> 4 ; bProc = (revision & (0x0F << 12)) >> 12 ; // Not used for now. bMfg = (revision & (0x0F << 16)) >> 16 ; bMem = (revision & (0x07 << 20)) >> 20 ; bWarranty = (revision & (0x03 << 24)) != 0 ; *model = bType ; *rev = bRev ; *mem = bMem ; *maker = bMfg ; *warranty = bWarranty ; if (wiringPiDebug) printf ("piBoardId: rev: %d, type: %d, proc: %d, mfg: %d, mem: %d, warranty: %d\n", bRev, bType, bProc, bMfg, bMem, bWarranty) ; } else // Old way { if (wiringPiDebug) printf ("piBoardId: Old Way: revision is: %s\n", c) ; if (!isdigit (*c)) piGpioLayoutOops ("Bogus \"Revision\" line (no digit at start of revision)") ; // Make sure its long enough if (strlen (c) < 4) piGpioLayoutOops ("Bogus \"Revision\" line (not long enough)") ; // If longer than 4, we'll assume it's been overvolted *warranty = strlen (c) > 4 ; // Extract last 4 characters: c = c + strlen (c) - 4 ; // Fill out the replys as appropriate /**/ if (strcmp (c, "0002") == 0) { *model = PI_MODEL_B ; *rev = PI_VERSION_1 ; *mem = 0 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "0003") == 0) { *model = PI_MODEL_B ; *rev = PI_VERSION_1_1 ; *mem = 0 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "0004") == 0) { *model = PI_MODEL_B ; *rev = PI_VERSION_1_2 ; *mem = 0 ; *maker = PI_MAKER_SONY ; } else if (strcmp (c, "0005") == 0) { *model = PI_MODEL_B ; *rev = PI_VERSION_1_2 ; *mem = 0 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "0006") == 0) { *model = PI_MODEL_B ; *rev = PI_VERSION_1_2 ; *mem = 0 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "0007") == 0) { *model = PI_MODEL_A ; *rev = PI_VERSION_1_2 ; *mem = 0 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "0008") == 0) { *model = PI_MODEL_A ; *rev = PI_VERSION_1_2 ; *mem = 0 ; *maker = PI_MAKER_SONY ; ; } else if (strcmp (c, "0009") == 0) { *model = PI_MODEL_A ; *rev = PI_VERSION_1_2 ; *mem = 0 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "000d") == 0) { *model = PI_MODEL_B ; *rev = PI_VERSION_1_2 ; *mem = 1 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "000e") == 0) { *model = PI_MODEL_B ; *rev = PI_VERSION_1_2 ; *mem = 1 ; *maker = PI_MAKER_SONY ; } else if (strcmp (c, "000f") == 0) { *model = PI_MODEL_B ; *rev = PI_VERSION_1_2 ; *mem = 1 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "0010") == 0) { *model = PI_MODEL_BP ; *rev = PI_VERSION_1_2 ; *mem = 1 ; *maker = PI_MAKER_SONY ; } else if (strcmp (c, "0013") == 0) { *model = PI_MODEL_BP ; *rev = PI_VERSION_1_2 ; *mem = 1 ; *maker = PI_MAKER_EMBEST ; } else if (strcmp (c, "0016") == 0) { *model = PI_MODEL_BP ; *rev = PI_VERSION_1_2 ; *mem = 1 ; *maker = PI_MAKER_SONY ; } else if (strcmp (c, "0019") == 0) { *model = PI_MODEL_BP ; *rev = PI_VERSION_1_2 ; *mem = 1 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "0011") == 0) { *model = PI_MODEL_CM ; *rev = PI_VERSION_1_1 ; *mem = 1 ; *maker = PI_MAKER_SONY ; } else if (strcmp (c, "0014") == 0) { *model = PI_MODEL_CM ; *rev = PI_VERSION_1_1 ; *mem = 1 ; *maker = PI_MAKER_EMBEST ; } else if (strcmp (c, "0017") == 0) { *model = PI_MODEL_CM ; *rev = PI_VERSION_1_1 ; *mem = 1 ; *maker = PI_MAKER_SONY ; } else if (strcmp (c, "001a") == 0) { *model = PI_MODEL_CM ; *rev = PI_VERSION_1_1 ; *mem = 1 ; *maker = PI_MAKER_EGOMAN ; } else if (strcmp (c, "0012") == 0) { *model = PI_MODEL_AP ; *rev = PI_VERSION_1_1 ; *mem = 0 ; *maker = PI_MAKER_SONY ; } else if (strcmp (c, "0015") == 0) { *model = PI_MODEL_AP ; *rev = PI_VERSION_1_1 ; *mem = 1 ; *maker = PI_MAKER_EMBEST ; } else if (strcmp (c, "0018") == 0) { *model = PI_MODEL_AP ; *rev = PI_VERSION_1_1 ; *mem = 0 ; *maker = PI_MAKER_SONY ; } else if (strcmp (c, "001b") == 0) { *model = PI_MODEL_AP ; *rev = PI_VERSION_1_1 ; *mem = 0 ; *maker = PI_MAKER_EGOMAN ; } else { *model = 0 ; *rev = 0 ; *mem = 0 ; *maker = 0 ; } } } /* * wpiPinToGpio: * Translate a wiringPi Pin number to native GPIO pin number. * Provided for external support. ********************************************************************************* */ int wpiPinToGpio (int wpiPin) { return pinToGpio [wpiPin & 63] ; } /* * physPinToGpio: * Translate a physical Pin number to native GPIO pin number. * Provided for external support. ********************************************************************************* */ int physPinToGpio (int physPin) { return physToGpio [physPin & 63] ; } /* * setPadDrive: * Set the PAD driver value ********************************************************************************* */ void setPadDrive (int group, int value) { uint32_t wrVal ; if ((wiringPiMode == WPI_MODE_PINS) || (wiringPiMode == WPI_MODE_PHYS) || (wiringPiMode == WPI_MODE_GPIO)) { if ((group < 0) || (group > 2)) return ; wrVal = BCM_PASSWORD | 0x18 | (value & 7) ; *(pads + group + 11) = wrVal ; if (wiringPiDebug) { printf ("setPadDrive: Group: %d, value: %d (%08X)\n", group, value, wrVal) ; printf ("Read : %08X\n", *(pads + group + 11)) ; } } } /* * getAlt: * Returns the ALT bits for a given port. Only really of-use * for the gpio readall command (I think) ********************************************************************************* */ int getAlt (int pin) { int fSel, shift, alt ; pin &= 63 ; /**/ if (wiringPiMode == WPI_MODE_PINS) pin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) pin = physToGpio [pin] ; else if (wiringPiMode != WPI_MODE_GPIO) return 0 ; fSel = gpioToGPFSEL [pin] ; shift = gpioToShift [pin] ; alt = (*(gpio + fSel) >> shift) & 7 ; return alt ; } /* * pwmSetMode: * Select the native "balanced" mode, or standard mark:space mode ********************************************************************************* */ void pwmSetMode (int mode) { if ((wiringPiMode == WPI_MODE_PINS) || (wiringPiMode == WPI_MODE_PHYS) || (wiringPiMode == WPI_MODE_GPIO)) { if (mode == PWM_MODE_MS) *(pwm + PWM_CONTROL) = PWM0_ENABLE | PWM1_ENABLE | PWM0_MS_MODE | PWM1_MS_MODE ; else *(pwm + PWM_CONTROL) = PWM0_ENABLE | PWM1_ENABLE ; } } /* * pwmSetRange: * Set the PWM range register. We set both range registers to the same * value. If you want different in your own code, then write your own. ********************************************************************************* */ void pwmSetRange (unsigned int range) { if ((wiringPiMode == WPI_MODE_PINS) || (wiringPiMode == WPI_MODE_PHYS) || (wiringPiMode == WPI_MODE_GPIO)) { *(pwm + PWM0_RANGE) = range ; delayMicroseconds (10) ; *(pwm + PWM1_RANGE) = range ; delayMicroseconds (10) ; } } /* * pwmSetClock: * Set/Change the PWM clock. Originally my code, but changed * (for the better!) by Chris Hall, * after further study of the manual and testing with a 'scope ********************************************************************************* */ void pwmSetClock (int divisor) { uint32_t pwm_control ; divisor &= 4095 ; if ((wiringPiMode == WPI_MODE_PINS) || (wiringPiMode == WPI_MODE_PHYS) || (wiringPiMode == WPI_MODE_GPIO)) { if (wiringPiDebug) printf ("Setting to: %d. Current: 0x%08X\n", divisor, *(clk + PWMCLK_DIV)) ; pwm_control = *(pwm + PWM_CONTROL) ; // preserve PWM_CONTROL // We need to stop PWM prior to stopping PWM clock in MS mode otherwise BUSY // stays high. *(pwm + PWM_CONTROL) = 0 ; // Stop PWM // Stop PWM clock before changing divisor. The delay after this does need to // this big (95uS occasionally fails, 100uS OK), it's almost as though the BUSY // flag is not working properly in balanced mode. Without the delay when DIV is // adjusted the clock sometimes switches to very slow, once slow further DIV // adjustments do nothing and it's difficult to get out of this mode. *(clk + PWMCLK_CNTL) = BCM_PASSWORD | 0x01 ; // Stop PWM Clock delayMicroseconds (110) ; // prevents clock going sloooow while ((*(clk + PWMCLK_CNTL) & 0x80) != 0) // Wait for clock to be !BUSY delayMicroseconds (1) ; *(clk + PWMCLK_DIV) = BCM_PASSWORD | (divisor << 12) ; *(clk + PWMCLK_CNTL) = BCM_PASSWORD | 0x11 ; // Start PWM clock *(pwm + PWM_CONTROL) = pwm_control ; // restore PWM_CONTROL if (wiringPiDebug) printf ("Set to: %d. Now : 0x%08X\n", divisor, *(clk + PWMCLK_DIV)) ; } } /* * gpioClockSet: * Set the frequency on a GPIO clock pin ********************************************************************************* */ void gpioClockSet (int pin, int freq) { int divi, divr, divf ; pin &= 63 ; /**/ if (wiringPiMode == WPI_MODE_PINS) pin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) pin = physToGpio [pin] ; else if (wiringPiMode != WPI_MODE_GPIO) return ; divi = 19200000 / freq ; divr = 19200000 % freq ; divf = (int)((double)divr * 4096.0 / 19200000.0) ; if (divi > 4095) divi = 4095 ; *(clk + gpioToClkCon [pin]) = BCM_PASSWORD | GPIO_CLOCK_SOURCE ; // Stop GPIO Clock while ((*(clk + gpioToClkCon [pin]) & 0x80) != 0) // ... and wait ; *(clk + gpioToClkDiv [pin]) = BCM_PASSWORD | (divi << 12) | divf ; // Set dividers *(clk + gpioToClkCon [pin]) = BCM_PASSWORD | 0x10 | GPIO_CLOCK_SOURCE ; // Start Clock } /* * wiringPiFindNode: * Locate our device node ********************************************************************************* */ struct wiringPiNodeStruct *wiringPiFindNode (int pin) { struct wiringPiNodeStruct *node = wiringPiNodes ; while (node != NULL) if ((pin >= node->pinBase) && (pin <= node->pinMax)) return node ; else node = node->next ; return NULL ; } /* * wiringPiNewNode: * Create a new GPIO node into the wiringPi handling system ********************************************************************************* */ static void pinModeDummy (UNU struct wiringPiNodeStruct *node, UNU int pin, UNU int mode) { return ; } static void pullUpDnControlDummy (UNU struct wiringPiNodeStruct *node, UNU int pin, UNU int pud) { return ; } static unsigned int digitalRead8Dummy (UNU struct wiringPiNodeStruct *node, UNU int UNU pin) { return 0 ; } static void digitalWrite8Dummy (UNU struct wiringPiNodeStruct *node, UNU int pin, UNU int value) { return ; } static int digitalReadDummy (UNU struct wiringPiNodeStruct *node, UNU int UNU pin) { return LOW ; } static void digitalWriteDummy (UNU struct wiringPiNodeStruct *node, UNU int pin, UNU int value) { return ; } static void pwmWriteDummy (UNU struct wiringPiNodeStruct *node, UNU int pin, UNU int value) { return ; } static int analogReadDummy (UNU struct wiringPiNodeStruct *node, UNU int pin) { return 0 ; } static void analogWriteDummy (UNU struct wiringPiNodeStruct *node, UNU int pin, UNU int value) { return ; } struct wiringPiNodeStruct *wiringPiNewNode (int pinBase, int numPins) { int pin ; struct wiringPiNodeStruct *node ; // Minimum pin base is 64 if (pinBase < 64) (void)wiringPiFailure (WPI_FATAL, "wiringPiNewNode: pinBase of %d is < 64\n", pinBase) ; // Check all pins in-case there is overlap: for (pin = pinBase ; pin < (pinBase + numPins) ; ++pin) if (wiringPiFindNode (pin) != NULL) (void)wiringPiFailure (WPI_FATAL, "wiringPiNewNode: Pin %d overlaps with existing definition\n", pin) ; node = (struct wiringPiNodeStruct *)calloc (sizeof (struct wiringPiNodeStruct), 1) ; // calloc zeros if (node == NULL) (void)wiringPiFailure (WPI_FATAL, "wiringPiNewNode: Unable to allocate memory: %s\n", strerror (errno)) ; node->pinBase = pinBase ; node->pinMax = pinBase + numPins - 1 ; node->pinMode = pinModeDummy ; node->pullUpDnControl = pullUpDnControlDummy ; node->digitalRead = digitalReadDummy ; //node->digitalRead8 = digitalRead8Dummy ; node->digitalWrite = digitalWriteDummy ; //node->digitalWrite8 = digitalWrite8Dummy ; node->pwmWrite = pwmWriteDummy ; node->analogRead = analogReadDummy ; node->analogWrite = analogWriteDummy ; node->next = wiringPiNodes ; wiringPiNodes = node ; return node ; } #ifdef notYetReady /* * pinED01: * pinED10: * Enables edge-detect mode on a pin - from a 0 to a 1 or 1 to 0 * Pin must already be in input mode with appropriate pull up/downs set. ********************************************************************************* */ void pinEnableED01Pi (int pin) { pin = pinToGpio [pin & 63] ; } #endif /* ********************************************************************************* * Core Functions ********************************************************************************* */ /* * pinModeAlt: * This is an un-documented special to let you set any pin to any mode ********************************************************************************* */ void pinModeAlt (int pin, int mode) { int fSel, shift ; setupCheck ("pinModeAlt") ; if ((pin & PI_GPIO_MASK) == 0) // On-board pin { /**/ if (wiringPiMode == WPI_MODE_PINS) pin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) pin = physToGpio [pin] ; else if (wiringPiMode != WPI_MODE_GPIO) return ; fSel = gpioToGPFSEL [pin] ; shift = gpioToShift [pin] ; *(gpio + fSel) = (*(gpio + fSel) & ~(7 << shift)) | ((mode & 0x7) << shift) ; } } /* * pinMode: * Sets the mode of a pin to be input, output or PWM output ********************************************************************************* */ void pinMode (int pin, int mode) { int fSel, shift, alt ; struct wiringPiNodeStruct *node = wiringPiNodes ; int origPin = pin ; setupCheck ("pinMode") ; if ((pin & PI_GPIO_MASK) == 0) // On-board pin { /**/ if (wiringPiMode == WPI_MODE_PINS) pin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) pin = physToGpio [pin] ; else if (wiringPiMode != WPI_MODE_GPIO) return ; softPwmStop (origPin) ; softToneStop (origPin) ; fSel = gpioToGPFSEL [pin] ; shift = gpioToShift [pin] ; /**/ if (mode == INPUT) *(gpio + fSel) = (*(gpio + fSel) & ~(7 << shift)) ; // Sets bits to zero = input else if (mode == OUTPUT) *(gpio + fSel) = (*(gpio + fSel) & ~(7 << shift)) | (1 << shift) ; else if (mode == SOFT_PWM_OUTPUT) softPwmCreate (origPin, 0, 100) ; else if (mode == SOFT_TONE_OUTPUT) softToneCreate (origPin) ; else if (mode == PWM_TONE_OUTPUT) { pinMode (origPin, PWM_OUTPUT) ; // Call myself to enable PWM mode pwmSetMode (PWM_MODE_MS) ; } else if (mode == PWM_OUTPUT) { if ((alt = gpioToPwmALT [pin]) == 0) // Not a hardware capable PWM pin return ; usingGpioMemCheck ("pinMode PWM") ; // Set pin to PWM mode *(gpio + fSel) = (*(gpio + fSel) & ~(7 << shift)) | (alt << shift) ; delayMicroseconds (110) ; // See comments in pwmSetClockWPi pwmSetMode (PWM_MODE_BAL) ; // Pi default mode pwmSetRange (1024) ; // Default range of 1024 pwmSetClock (32) ; // 19.2 / 32 = 600KHz - Also starts the PWM } else if (mode == GPIO_CLOCK) { if ((alt = gpioToGpClkALT0 [pin]) == 0) // Not a GPIO_CLOCK pin return ; usingGpioMemCheck ("pinMode CLOCK") ; // Set pin to GPIO_CLOCK mode and set the clock frequency to 100KHz *(gpio + fSel) = (*(gpio + fSel) & ~(7 << shift)) | (alt << shift) ; delayMicroseconds (110) ; gpioClockSet (pin, 100000) ; } } else { if ((node = wiringPiFindNode (pin)) != NULL) node->pinMode (node, pin, mode) ; return ; } } /* * pullUpDownCtrl: * Control the internal pull-up/down resistors on a GPIO pin. ********************************************************************************* */ void pullUpDnControl (int pin, int pud) { struct wiringPiNodeStruct *node = wiringPiNodes ; setupCheck ("pullUpDnControl") ; if ((pin & PI_GPIO_MASK) == 0) // On-Board Pin { /**/ if (wiringPiMode == WPI_MODE_PINS) pin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) pin = physToGpio [pin] ; else if (wiringPiMode != WPI_MODE_GPIO) return ; *(gpio + GPPUD) = pud & 3 ; delayMicroseconds (5) ; *(gpio + gpioToPUDCLK [pin]) = 1 << (pin & 31) ; delayMicroseconds (5) ; *(gpio + GPPUD) = 0 ; delayMicroseconds (5) ; *(gpio + gpioToPUDCLK [pin]) = 0 ; delayMicroseconds (5) ; } else // Extension module { if ((node = wiringPiFindNode (pin)) != NULL) node->pullUpDnControl (node, pin, pud) ; return ; } } /* * digitalRead: * Read the value of a given Pin, returning HIGH or LOW ********************************************************************************* */ int digitalRead (int pin) { char c ; struct wiringPiNodeStruct *node = wiringPiNodes ; if ((pin & PI_GPIO_MASK) == 0) // On-Board Pin { /**/ if (wiringPiMode == WPI_MODE_GPIO_SYS) // Sys mode { if (sysFds [pin] == -1) return LOW ; lseek (sysFds [pin], 0L, SEEK_SET) ; read (sysFds [pin], &c, 1) ; return (c == '0') ? LOW : HIGH ; } else if (wiringPiMode == WPI_MODE_PINS) pin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) pin = physToGpio [pin] ; else if (wiringPiMode != WPI_MODE_GPIO) return LOW ; if ((*(gpio + gpioToGPLEV [pin]) & (1 << (pin & 31))) != 0) return HIGH ; else return LOW ; } else { if ((node = wiringPiFindNode (pin)) == NULL) return LOW ; return node->digitalRead (node, pin) ; } } /* * digitalRead8: * Read 8-bits (a byte) from given start pin. ********************************************************************************* unsigned int digitalRead8 (int pin) { struct wiringPiNodeStruct *node = wiringPiNodes ; if ((pin & PI_GPIO_MASK) == 0) // On-Board Pin return 0 ; else { if ((node = wiringPiFindNode (pin)) == NULL) return LOW ; return node->digitalRead8 (node, pin) ; } } */ /* * digitalWrite: * Set an output bit ********************************************************************************* */ void digitalWrite (int pin, int value) { struct wiringPiNodeStruct *node = wiringPiNodes ; if ((pin & PI_GPIO_MASK) == 0) // On-Board Pin { /**/ if (wiringPiMode == WPI_MODE_GPIO_SYS) // Sys mode { if (sysFds [pin] != -1) { if (value == LOW) write (sysFds [pin], "0\n", 2) ; else write (sysFds [pin], "1\n", 2) ; } return ; } else if (wiringPiMode == WPI_MODE_PINS) pin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) pin = physToGpio [pin] ; else if (wiringPiMode != WPI_MODE_GPIO) return ; if (value == LOW) *(gpio + gpioToGPCLR [pin]) = 1 << (pin & 31) ; else *(gpio + gpioToGPSET [pin]) = 1 << (pin & 31) ; } else { if ((node = wiringPiFindNode (pin)) != NULL) node->digitalWrite (node, pin, value) ; } } /* * digitalWrite8: * Set an output 8-bit byte on the device from the given pin number ********************************************************************************* void digitalWrite8 (int pin, int value) { struct wiringPiNodeStruct *node = wiringPiNodes ; if ((pin & PI_GPIO_MASK) == 0) // On-Board Pin return ; else { if ((node = wiringPiFindNode (pin)) != NULL) node->digitalWrite8 (node, pin, value) ; } } */ /* * pwmWrite: * Set an output PWM value ********************************************************************************* */ void pwmWrite (int pin, int value) { struct wiringPiNodeStruct *node = wiringPiNodes ; setupCheck ("pwmWrite") ; if ((pin & PI_GPIO_MASK) == 0) // On-Board Pin { /**/ if (wiringPiMode == WPI_MODE_PINS) pin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) pin = physToGpio [pin] ; else if (wiringPiMode != WPI_MODE_GPIO) return ; usingGpioMemCheck ("pwmWrite") ; *(pwm + gpioToPwmPort [pin]) = value ; } else { if ((node = wiringPiFindNode (pin)) != NULL) node->pwmWrite (node, pin, value) ; } } /* * analogRead: * Read the analog value of a given Pin. * There is no on-board Pi analog hardware, * so this needs to go to a new node. ********************************************************************************* */ int analogRead (int pin) { struct wiringPiNodeStruct *node = wiringPiNodes ; if ((node = wiringPiFindNode (pin)) == NULL) return 0 ; else return node->analogRead (node, pin) ; } /* * analogWrite: * Write the analog value to the given Pin. * There is no on-board Pi analog hardware, * so this needs to go to a new node. ********************************************************************************* */ void analogWrite (int pin, int value) { struct wiringPiNodeStruct *node = wiringPiNodes ; if ((node = wiringPiFindNode (pin)) == NULL) return ; node->analogWrite (node, pin, value) ; } /* * pwmToneWrite: * Pi Specific. * Output the given frequency on the Pi's PWM pin ********************************************************************************* */ void pwmToneWrite (int pin, int freq) { int range ; setupCheck ("pwmToneWrite") ; if (freq == 0) pwmWrite (pin, 0) ; // Off else { range = 600000 / freq ; pwmSetRange (range) ; pwmWrite (pin, freq / 2) ; } } /* * digitalWriteByte: * digitalReadByte: * Pi Specific * Write an 8-bit byte to the first 8 GPIO pins - try to do it as * fast as possible. * However it still needs 2 operations to set the bits, so any external * hardware must not rely on seeing a change as there will be a change * to set the outputs bits to zero, then another change to set the 1's * Reading is just bit fiddling. * These are wiringPi pin numbers 0..7, or BCM_GPIO pin numbers * 17, 18, 22, 23, 24, 24, 4 on a Pi v1 rev 0-3 * 17, 18, 27, 23, 24, 24, 4 on a Pi v1 rev 3 onwards or B+, 2, 3, zero ********************************************************************************* */ void digitalWriteByte (const int value) { uint32_t pinSet = 0 ; uint32_t pinClr = 0 ; int mask = 1 ; int pin ; /**/ if (wiringPiMode == WPI_MODE_GPIO_SYS) { for (pin = 0 ; pin < 8 ; ++pin) { digitalWrite (pinToGpio [pin], value & mask) ; mask <<= 1 ; } return ; } else { for (pin = 0 ; pin < 8 ; ++pin) { if ((value & mask) == 0) pinClr |= (1 << pinToGpio [pin]) ; else pinSet |= (1 << pinToGpio [pin]) ; mask <<= 1 ; } *(gpio + gpioToGPCLR [0]) = pinClr ; *(gpio + gpioToGPSET [0]) = pinSet ; } } unsigned int digitalReadByte (void) { int pin, x ; uint32_t raw ; uint32_t data = 0 ; /**/ if (wiringPiMode == WPI_MODE_GPIO_SYS) { for (pin = 0 ; pin < 8 ; ++pin) { x = digitalRead (pinToGpio [pin]) ; data = (data << 1) | x ; } } else { raw = *(gpio + gpioToGPLEV [0]) ; // First bank for these pins for (pin = 0 ; pin < 8 ; ++pin) { x = pinToGpio [pin] ; data = (data << 1) | (((raw & (1 << x)) == 0) ? 0 : 1) ; } } return data ; } /* * digitalWriteByte2: * digitalReadByte2: * Pi Specific * Write an 8-bit byte to the second set of 8 GPIO pins. This is marginally * faster than the first lot as these are consecutive BCM_GPIO pin numbers. * However they overlap with the original read/write bytes. ********************************************************************************* */ void digitalWriteByte2 (const int value) { register int mask = 1 ; register int pin ; /**/ if (wiringPiMode == WPI_MODE_GPIO_SYS) { for (pin = 20 ; pin < 28 ; ++pin) { digitalWrite (pin, value & mask) ; mask <<= 1 ; } return ; } else { *(gpio + gpioToGPCLR [0]) = (~value & 0xFF) << 20 ; // 0x0FF00000; ILJ > CHANGE: Old causes glitch *(gpio + gpioToGPSET [0]) = ( value & 0xFF) << 20 ; } } unsigned int digitalReadByte2 (void) { int pin, x ; uint32_t data = 0 ; /**/ if (wiringPiMode == WPI_MODE_GPIO_SYS) { for (pin = 20 ; pin < 28 ; ++pin) { x = digitalRead (pin) ; data = (data << 1) | x ; } } else data = ((*(gpio + gpioToGPLEV [0])) >> 20) & 0xFF ; // First bank for these pins return data ; } /* * waitForInterrupt: * Pi Specific. * Wait for Interrupt on a GPIO pin. * This is actually done via the /sys/class/gpio interface regardless of * the wiringPi access mode in-use. Maybe sometime it might get a better * way for a bit more efficiency. ********************************************************************************* */ int waitForInterrupt (int pin, int mS) { int fd, x ; uint8_t c ; struct pollfd polls ; /**/ if (wiringPiMode == WPI_MODE_PINS) pin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) pin = physToGpio [pin] ; if ((fd = sysFds [pin]) == -1) return -2 ; // Setup poll structure polls.fd = fd ; polls.events = POLLPRI | POLLERR ; // Wait for it ... x = poll (&polls, 1, mS) ; // If no error, do a dummy read to clear the interrupt // A one character read appars to be enough. if (x > 0) { lseek (fd, 0, SEEK_SET) ; // Rewind (void)read (fd, &c, 1) ; // Read & clear } return x ; } /* * interruptHandler: * This is a thread and gets started to wait for the interrupt we're * hoping to catch. It will call the user-function when the interrupt * fires. ********************************************************************************* */ static void *interruptHandler (UNU void *arg) { int myPin ; (void)piHiPri (55) ; // Only effective if we run as root myPin = pinPass ; pinPass = -1 ; for (;;) if (waitForInterrupt (myPin, -1) > 0) isrFunctions [myPin] () ; return NULL ; } /* * wiringPiISR: * Pi Specific. * Take the details and create an interrupt handler that will do a call- * back to the user supplied function. ********************************************************************************* */ int wiringPiISR (int pin, int mode, void (*function)(void)) { pthread_t threadId ; const char *modeS ; char fName [64] ; char pinS [8] ; pid_t pid ; int count, i ; char c ; int bcmGpioPin ; if ((pin < 0) || (pin > 63)) return wiringPiFailure (WPI_FATAL, "wiringPiISR: pin must be 0-63 (%d)\n", pin) ; /**/ if (wiringPiMode == WPI_MODE_UNINITIALISED) return wiringPiFailure (WPI_FATAL, "wiringPiISR: wiringPi has not been initialised. Unable to continue.\n") ; else if (wiringPiMode == WPI_MODE_PINS) bcmGpioPin = pinToGpio [pin] ; else if (wiringPiMode == WPI_MODE_PHYS) bcmGpioPin = physToGpio [pin] ; else bcmGpioPin = pin ; // Now export the pin and set the right edge // We're going to use the gpio program to do this, so it assumes // a full installation of wiringPi. It's a bit 'clunky', but it // is a way that will work when we're running in "Sys" mode, as // a non-root user. (without sudo) if (mode != INT_EDGE_SETUP) { /**/ if (mode == INT_EDGE_FALLING) modeS = "falling" ; else if (mode == INT_EDGE_RISING) modeS = "rising" ; else modeS = "both" ; sprintf (pinS, "%d", bcmGpioPin) ; if ((pid = fork ()) < 0) // Fail return wiringPiFailure (WPI_FATAL, "wiringPiISR: fork failed: %s\n", strerror (errno)) ; if (pid == 0) // Child, exec { /**/ if (access ("/usr/local/bin/gpio", X_OK) == 0) { execl ("/usr/local/bin/gpio", "gpio", "edge", pinS, modeS, (char *)NULL) ; return wiringPiFailure (WPI_FATAL, "wiringPiISR: execl failed: %s\n", strerror (errno)) ; } else if (access ("/usr/bin/gpio", X_OK) == 0) { execl ("/usr/bin/gpio", "gpio", "edge", pinS, modeS, (char *)NULL) ; return wiringPiFailure (WPI_FATAL, "wiringPiISR: execl failed: %s\n", strerror (errno)) ; } else return wiringPiFailure (WPI_FATAL, "wiringPiISR: Can't find gpio program\n") ; } else // Parent, wait wait (NULL) ; } // Now pre-open the /sys/class node - but it may already be open if // we are in Sys mode... if (sysFds [bcmGpioPin] == -1) { sprintf (fName, "/sys/class/gpio/gpio%d/value", bcmGpioPin) ; if ((sysFds [bcmGpioPin] = open (fName, O_RDWR)) < 0) return wiringPiFailure (WPI_FATAL, "wiringPiISR: unable to open %s: %s\n", fName, strerror (errno)) ; } // Clear any initial pending interrupt ioctl (sysFds [bcmGpioPin], FIONREAD, &count) ; for (i = 0 ; i < count ; ++i) read (sysFds [bcmGpioPin], &c, 1) ; isrFunctions [pin] = function ; pthread_mutex_lock (&pinMutex) ; pinPass = pin ; pthread_create (&threadId, NULL, interruptHandler, NULL) ; while (pinPass != -1) delay (1) ; pthread_mutex_unlock (&pinMutex) ; return 0 ; } /* * initialiseEpoch: * Initialise our start-of-time variable to be the current unix * time in milliseconds and microseconds. ********************************************************************************* */ static void initialiseEpoch (void) { #ifdef OLD_WAY struct timeval tv ; gettimeofday (&tv, NULL) ; epochMilli = (uint64_t)tv.tv_sec * (uint64_t)1000 + (uint64_t)(tv.tv_usec / 1000) ; epochMicro = (uint64_t)tv.tv_sec * (uint64_t)1000000 + (uint64_t)(tv.tv_usec) ; #else struct timespec ts ; clock_gettime (CLOCK_MONOTONIC_RAW, &ts) ; epochMilli = (uint64_t)ts.tv_sec * (uint64_t)1000 + (uint64_t)(ts.tv_nsec / 1000000L) ; epochMicro = (uint64_t)ts.tv_sec * (uint64_t)1000000 + (uint64_t)(ts.tv_nsec / 1000L) ; #endif } /* * delay: * Wait for some number of milliseconds ********************************************************************************* */ void delay (unsigned int howLong) { struct timespec sleeper, dummy ; sleeper.tv_sec = (time_t)(howLong / 1000) ; sleeper.tv_nsec = (long)(howLong % 1000) * 1000000 ; nanosleep (&sleeper, &dummy) ; } /* * delayMicroseconds: * This is somewhat intersting. It seems that on the Pi, a single call * to nanosleep takes some 80 to 130 microseconds anyway, so while * obeying the standards (may take longer), it's not always what we * want! * * So what I'll do now is if the delay is less than 100uS we'll do it * in a hard loop, watching a built-in counter on the ARM chip. This is * somewhat sub-optimal in that it uses 100% CPU, something not an issue * in a microcontroller, but under a multi-tasking, multi-user OS, it's * wastefull, however we've no real choice )-: * * Plan B: It seems all might not be well with that plan, so changing it * to use gettimeofday () and poll on that instead... ********************************************************************************* */ void delayMicrosecondsHard (unsigned int howLong) { struct timeval tNow, tLong, tEnd ; gettimeofday (&tNow, NULL) ; tLong.tv_sec = howLong / 1000000 ; tLong.tv_usec = howLong % 1000000 ; timeradd (&tNow, &tLong, &tEnd) ; while (timercmp (&tNow, &tEnd, <)) gettimeofday (&tNow, NULL) ; } void delayMicroseconds (unsigned int howLong) { struct timespec sleeper ; unsigned int uSecs = howLong % 1000000 ; unsigned int wSecs = howLong / 1000000 ; /**/ if (howLong == 0) return ; else if (howLong < 100) delayMicrosecondsHard (howLong) ; else { sleeper.tv_sec = wSecs ; sleeper.tv_nsec = (long)(uSecs * 1000L) ; nanosleep (&sleeper, NULL) ; } } /* * millis: * Return a number of milliseconds as an unsigned int. * Wraps at 49 days. ********************************************************************************* */ unsigned int millis (void) { uint64_t now ; #ifdef OLD_WAY struct timeval tv ; gettimeofday (&tv, NULL) ; now = (uint64_t)tv.tv_sec * (uint64_t)1000 + (uint64_t)(tv.tv_usec / 1000) ; #else struct timespec ts ; clock_gettime (CLOCK_MONOTONIC_RAW, &ts) ; now = (uint64_t)ts.tv_sec * (uint64_t)1000 + (uint64_t)(ts.tv_nsec / 1000000L) ; #endif return (uint32_t)(now - epochMilli) ; } /* * micros: * Return a number of microseconds as an unsigned int. * Wraps after 71 minutes. ********************************************************************************* */ unsigned int micros (void) { uint64_t now ; #ifdef OLD_WAY struct timeval tv ; gettimeofday (&tv, NULL) ; now = (uint64_t)tv.tv_sec * (uint64_t)1000000 + (uint64_t)tv.tv_usec ; #else struct timespec ts ; clock_gettime (CLOCK_MONOTONIC_RAW, &ts) ; now = (uint64_t)ts.tv_sec * (uint64_t)1000000 + (uint64_t)(ts.tv_nsec / 1000) ; #endif return (uint32_t)(now - epochMicro) ; } /* * wiringPiVersion: * Return our current version number ********************************************************************************* */ void wiringPiVersion (int *major, int *minor) { *major = VERSION_MAJOR ; *minor = VERSION_MINOR ; } /* * wiringPiSetup: * Must be called once at the start of your program execution. * * Default setup: Initialises the system into wiringPi Pin mode and uses the * memory mapped hardware directly. * * Changed now to revert to "gpio" mode if we're running on a Compute Module. ********************************************************************************* */ int wiringPiSetup (void) { int fd ; int model, rev, mem, maker, overVolted ; // It's actually a fatal error to call any of the wiringPiSetup routines more than once, // (you run out of file handles!) but I'm fed-up with the useless twats who email // me bleating that there is a bug in my code, so screw-em. if (wiringPiSetuped) return 0 ; wiringPiSetuped = TRUE ; if (getenv (ENV_DEBUG) != NULL) wiringPiDebug = TRUE ; if (getenv (ENV_CODES) != NULL) wiringPiReturnCodes = TRUE ; if (wiringPiDebug) printf ("wiringPi: wiringPiSetup called\n") ; // Get the board ID information. We're not really using the information here, // but it will give us information like the GPIO layout scheme (2 variants // on the older 26-pin Pi's) and the GPIO peripheral base address. // and if we're running on a compute module, then wiringPi pin numbers // don't really many anything, so force native BCM mode anyway. piBoardId (&model, &rev, &mem, &maker, &overVolted) ; if ((model == PI_MODEL_CM) || (model == PI_MODEL_CM3) || (model == PI_MODEL_CM3P)) wiringPiMode = WPI_MODE_GPIO ; else wiringPiMode = WPI_MODE_PINS ; /**/ if (piGpioLayout () == 1) // A, B, Rev 1, 1.1 { pinToGpio = pinToGpioR1 ; physToGpio = physToGpioR1 ; } else // A2, B2, A+, B+, CM, Pi2, Pi3, Zero { pinToGpio = pinToGpioR2 ; physToGpio = physToGpioR2 ; } // ... switch (model) { case PI_MODEL_A: case PI_MODEL_B: case PI_MODEL_AP: case PI_MODEL_BP: case PI_ALPHA: case PI_MODEL_CM: case PI_MODEL_ZERO: case PI_MODEL_ZERO_W: piGpioBase = GPIO_PERI_BASE_OLD ; break ; default: piGpioBase = GPIO_PERI_BASE_NEW ; break ; } // Open the master /dev/ memory control device // Device strategy: December 2016: // Try /dev/mem. If that fails, then // try /dev/gpiomem. If that fails then game over. if ((fd = open ("/dev/mem", O_RDWR | O_SYNC | O_CLOEXEC)) < 0) { if ((fd = open ("/dev/gpiomem", O_RDWR | O_SYNC | O_CLOEXEC) ) >= 0) // We're using gpiomem { piGpioBase = 0 ; usingGpioMem = TRUE ; } else return wiringPiFailure (WPI_ALMOST, "wiringPiSetup: Unable to open /dev/mem or /dev/gpiomem: %s.\n" " Aborting your program because if it can not access the GPIO\n" " hardware then it most certianly won't work\n" " Try running with sudo?\n", strerror (errno)) ; } // Set the offsets into the memory interface. GPIO_PADS = piGpioBase + 0x00100000 ; GPIO_CLOCK_BASE = piGpioBase + 0x00101000 ; GPIO_BASE = piGpioBase + 0x00200000 ; GPIO_TIMER = piGpioBase + 0x0000B000 ; GPIO_PWM = piGpioBase + 0x0020C000 ; // Map the individual hardware components // GPIO: gpio = (uint32_t *)mmap(0, BLOCK_SIZE, PROT_READ|PROT_WRITE, MAP_SHARED, fd, GPIO_BASE) ; if (gpio == MAP_FAILED) return wiringPiFailure (WPI_ALMOST, "wiringPiSetup: mmap (GPIO) failed: %s\n", strerror (errno)) ; // PWM pwm = (uint32_t *)mmap(0, BLOCK_SIZE, PROT_READ|PROT_WRITE, MAP_SHARED, fd, GPIO_PWM) ; if (pwm == MAP_FAILED) return wiringPiFailure (WPI_ALMOST, "wiringPiSetup: mmap (PWM) failed: %s\n", strerror (errno)) ; // Clock control (needed for PWM) clk = (uint32_t *)mmap(0, BLOCK_SIZE, PROT_READ|PROT_WRITE, MAP_SHARED, fd, GPIO_CLOCK_BASE) ; if (clk == MAP_FAILED) return wiringPiFailure (WPI_ALMOST, "wiringPiSetup: mmap (CLOCK) failed: %s\n", strerror (errno)) ; // The drive pads pads = (uint32_t *)mmap(0, BLOCK_SIZE, PROT_READ|PROT_WRITE, MAP_SHARED, fd, GPIO_PADS) ; if (pads == MAP_FAILED) return wiringPiFailure (WPI_ALMOST, "wiringPiSetup: mmap (PADS) failed: %s\n", strerror (errno)) ; // The system timer timer = (uint32_t *)mmap(0, BLOCK_SIZE, PROT_READ|PROT_WRITE, MAP_SHARED, fd, GPIO_TIMER) ; if (timer == MAP_FAILED) return wiringPiFailure (WPI_ALMOST, "wiringPiSetup: mmap (TIMER) failed: %s\n", strerror (errno)) ; // Set the timer to free-running, 1MHz. // 0xF9 is 249, the timer divide is base clock / (divide+1) // so base clock is 250MHz / 250 = 1MHz. *(timer + TIMER_CONTROL) = 0x0000280 ; *(timer + TIMER_PRE_DIV) = 0x00000F9 ; timerIrqRaw = timer + TIMER_IRQ_RAW ; // Export the base addresses for any external software that might need them _wiringPiGpio = gpio ; _wiringPiPwm = pwm ; _wiringPiClk = clk ; _wiringPiPads = pads ; _wiringPiTimer = timer ; initialiseEpoch () ; return 0 ; } /* * wiringPiSetupGpio: * Must be called once at the start of your program execution. * * GPIO setup: Initialises the system into GPIO Pin mode and uses the * memory mapped hardware directly. ********************************************************************************* */ int wiringPiSetupGpio (void) { (void)wiringPiSetup () ; if (wiringPiDebug) printf ("wiringPi: wiringPiSetupGpio called\n") ; wiringPiMode = WPI_MODE_GPIO ; return 0 ; } /* * wiringPiSetupPhys: * Must be called once at the start of your program execution. * * Phys setup: Initialises the system into Physical Pin mode and uses the * memory mapped hardware directly. ********************************************************************************* */ int wiringPiSetupPhys (void) { (void)wiringPiSetup () ; if (wiringPiDebug) printf ("wiringPi: wiringPiSetupPhys called\n") ; wiringPiMode = WPI_MODE_PHYS ; return 0 ; } /* * wiringPiSetupSys: * Must be called once at the start of your program execution. * * Initialisation (again), however this time we are using the /sys/class/gpio * interface to the GPIO systems - slightly slower, but always usable as * a non-root user, assuming the devices are already exported and setup correctly. */ int wiringPiSetupSys (void) { int pin ; char fName [128] ; if (wiringPiSetuped) return 0 ; wiringPiSetuped = TRUE ; if (getenv (ENV_DEBUG) != NULL) wiringPiDebug = TRUE ; if (getenv (ENV_CODES) != NULL) wiringPiReturnCodes = TRUE ; if (wiringPiDebug) printf ("wiringPi: wiringPiSetupSys called\n") ; if (piGpioLayout () == 1) { pinToGpio = pinToGpioR1 ; physToGpio = physToGpioR1 ; } else { pinToGpio = pinToGpioR2 ; physToGpio = physToGpioR2 ; } // Open and scan the directory, looking for exported GPIOs, and pre-open // the 'value' interface to speed things up for later for (pin = 0 ; pin < 64 ; ++pin) { sprintf (fName, "/sys/class/gpio/gpio%d/value", pin) ; sysFds [pin] = open (fName, O_RDWR) ; } initialiseEpoch () ; wiringPiMode = WPI_MODE_GPIO_SYS ; return 0 ; } wiringpi-2.50/wiringPi/mcp23008.h0000664000175000017500000000224113442550153016036 0ustar ubuntuubuntu/* * 23008.h: * Extend wiringPi with the MCP 23008 I2C GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int mcp23008Setup (const int pinBase, const int i2cAddress) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp3002.h0000664000175000017500000000224213442550153015747 0ustar ubuntuubuntu/* * mcp3002.c: * Extend wiringPi with the MCP3002 SPI Analog to Digital convertor * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int mcp3002Setup (int pinBase, int spiChannel) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/wiringPiSPI.c0000664000175000017500000001004113442550153017016 0ustar ubuntuubuntu/* * wiringPiSPI.c: * Simplified SPI access routines * Copyright (c) 2012-2015 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include "wiringPi.h" #include "wiringPiSPI.h" // The SPI bus parameters // Variables as they need to be passed as pointers later on //static const char *spiDev0 = "/dev/spidev0.0" ; //static const char *spiDev1 = "/dev/spidev0.1" ; static const uint8_t spiBPW = 8 ; static const uint16_t spiDelay = 0 ; static uint32_t spiSpeeds [2] ; static int spiFds [2] ; /* * wiringPiSPIGetFd: * Return the file-descriptor for the given channel ********************************************************************************* */ int wiringPiSPIGetFd (int channel) { return spiFds [channel & 1] ; } /* * wiringPiSPIDataRW: * Write and Read a block of data over the SPI bus. * Note the data ia being read into the transmit buffer, so will * overwrite it! * This is also a full-duplex operation. ********************************************************************************* */ int wiringPiSPIDataRW (int channel, unsigned char *data, int len) { struct spi_ioc_transfer spi ; channel &= 1 ; // Mentioned in spidev.h but not used in the original kernel documentation // test program )-: memset (&spi, 0, sizeof (spi)) ; spi.tx_buf = (unsigned long)data ; spi.rx_buf = (unsigned long)data ; spi.len = len ; spi.delay_usecs = spiDelay ; spi.speed_hz = spiSpeeds [channel] ; spi.bits_per_word = spiBPW ; return ioctl (spiFds [channel], SPI_IOC_MESSAGE(1), &spi) ; } /* * wiringPiSPISetupMode: * Open the SPI device, and set it up, with the mode, etc. ********************************************************************************* */ int wiringPiSPISetupMode (int channel, int speed, int mode) { int fd ; char spiDev [32] ; mode &= 3 ; // Mode is 0, 1, 2 or 3 // Channel can be anything - lets hope for the best // channel &= 1 ; // Channel is 0 or 1 snprintf (spiDev, 31, "/dev/spidev0.%d", channel) ; if ((fd = open (spiDev, O_RDWR)) < 0) return wiringPiFailure (WPI_ALMOST, "Unable to open SPI device: %s\n", strerror (errno)) ; spiSpeeds [channel] = speed ; spiFds [channel] = fd ; // Set SPI parameters. if (ioctl (fd, SPI_IOC_WR_MODE, &mode) < 0) return wiringPiFailure (WPI_ALMOST, "SPI Mode Change failure: %s\n", strerror (errno)) ; if (ioctl (fd, SPI_IOC_WR_BITS_PER_WORD, &spiBPW) < 0) return wiringPiFailure (WPI_ALMOST, "SPI BPW Change failure: %s\n", strerror (errno)) ; if (ioctl (fd, SPI_IOC_WR_MAX_SPEED_HZ, &speed) < 0) return wiringPiFailure (WPI_ALMOST, "SPI Speed Change failure: %s\n", strerror (errno)) ; return fd ; } /* * wiringPiSPISetup: * Open the SPI device, and set it up, etc. in the default MODE 0 ********************************************************************************* */ int wiringPiSPISetup (int channel, int speed) { return wiringPiSPISetupMode (channel, speed, 0) ; } wiringpi-2.50/wiringPi/pseudoPins.c0000664000175000017500000000531713442550153017015 0ustar ubuntuubuntu/* * pseudoPins.c: * Extend wiringPi with a number of pseudo pins which can be * digitally or analog written/read. * * Note: * Just one set of pseudo pins can exist per Raspberry Pi. * These pins are shared between all programs running on * that Raspberry Pi. The values are also persistant as * they live in shared RAM. This gives you a means for * temporary variable storing/sharing between programs, * or for other cunning things I've not thought of yet.. * * Copyright (c) 2012-2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #define SHARED_NAME "wiringPiPseudoPins" #define PSEUDO_PINS 64 #include #include #include #include #include #include #include "pseudoPins.h" static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { int *ptr = (int *)node->data0 ; int myPin = pin - node->pinBase ; return *(ptr + myPin) ; } static void myAnalogWrite (struct wiringPiNodeStruct *node, int pin, int value) { int *ptr = (int *)node->data0 ; int myPin = pin - node->pinBase ; *(ptr + myPin) = value ; } /* * pseudoPinsSetup: * Create a new wiringPi device node for the pseudoPins driver ********************************************************************************* */ int pseudoPinsSetup (const int pinBase) { struct wiringPiNodeStruct *node ; void *ptr ; node = wiringPiNewNode (pinBase, PSEUDO_PINS) ; node->fd = shm_open (SHARED_NAME, O_CREAT | O_RDWR, 0666) ; if (node->fd < 0) return FALSE ; if (ftruncate (node->fd, PSEUDO_PINS * sizeof (int)) < 0) return FALSE ; ptr = mmap (NULL, PSEUDO_PINS * sizeof (int), PROT_READ | PROT_WRITE, MAP_SHARED, node->fd, 0) ; node->data0 = (unsigned int)ptr ; node->analogRead = myAnalogRead ; node->analogWrite = myAnalogWrite ; return TRUE ; } wiringpi-2.50/wiringPi/sn3218.c0000664000175000017500000000452513442550153015622 0ustar ubuntuubuntu/* * sn3218.c: * Extend wiringPi with the SN3218 I2C LEd Driver * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "sn3218.h" /* * myAnalogWrite: * Write analog value on the given pin ********************************************************************************* */ static void myAnalogWrite (struct wiringPiNodeStruct *node, int pin, int value) { int fd = node->fd ; int chan = 0x01 + (pin - node->pinBase) ; wiringPiI2CWriteReg8 (fd, chan, value & 0xFF) ; // Value wiringPiI2CWriteReg8 (fd, 0x16, 0x00) ; // Update } /* * sn3218Setup: * Create a new wiringPi device node for an sn3218 on the Pi's * SPI interface. ********************************************************************************* */ int sn3218Setup (const int pinBase) { int fd ; struct wiringPiNodeStruct *node ; if ((fd = wiringPiI2CSetup (0x54)) < 0) return FALSE ; // Setup the chip - initialise all 18 LEDs to off //wiringPiI2CWriteReg8 (fd, 0x17, 0) ; // Reset wiringPiI2CWriteReg8 (fd, 0x00, 1) ; // Not Shutdown wiringPiI2CWriteReg8 (fd, 0x13, 0x3F) ; // Enable LEDs 0- 5 wiringPiI2CWriteReg8 (fd, 0x14, 0x3F) ; // Enable LEDs 6-11 wiringPiI2CWriteReg8 (fd, 0x15, 0x3F) ; // Enable LEDs 12-17 wiringPiI2CWriteReg8 (fd, 0x16, 0x00) ; // Update node = wiringPiNewNode (pinBase, 18) ; node->fd = fd ; node->analogWrite = myAnalogWrite ; return TRUE ; } wiringpi-2.50/wiringPi/mcp4802.h0000664000175000017500000000224213442550153015760 0ustar ubuntuubuntu/* * mcp4802.c: * Extend wiringPi with the MCP4802 SPI Digital to Analog convertor * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int mcp4802Setup (int pinBase, int spiChannel) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp3422.c0000664000175000017500000000651613442550153015760 0ustar ubuntuubuntu/* * mcp3422.c: * Extend wiringPi with the MCP3422/3/4 I2C ADC chip * This code assumes single-ended mode only. * Tested on actual hardware: 20th Feb 2016. * Copyright (c) 2013-2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include "mcp3422.h" /* * waitForConversion: * Common code to wait for the ADC to finish conversion ********************************************************************************* */ void waitForConversion (int fd, unsigned char *buffer, int n) { for (;;) { read (fd, buffer, n) ; if ((buffer [n-1] & 0x80) == 0) break ; delay (1) ; } } /* * myAnalogRead: * Read a channel from the device ********************************************************************************* */ int myAnalogRead (struct wiringPiNodeStruct *node, int chan) { unsigned char config ; unsigned char buffer [4] ; int value = 0 ; int realChan = (chan & 3) - node->pinBase ; // One-shot mode, trigger plus the other configs. config = 0x80 | (realChan << 5) | (node->data0 << 2) | (node->data1) ; wiringPiI2CWrite (node->fd, config) ; switch (node->data0) // Sample rate { case MCP3422_SR_3_75: // 18 bits waitForConversion (node->fd, &buffer [0], 4) ; value = ((buffer [0] & 3) << 16) | (buffer [1] << 8) | buffer [2] ; break ; case MCP3422_SR_15: // 16 bits waitForConversion (node->fd, buffer, 3) ; value = (buffer [0] << 8) | buffer [1] ; break ; case MCP3422_SR_60: // 14 bits waitForConversion (node->fd, buffer, 3) ; value = ((buffer [0] & 0x3F) << 8) | buffer [1] ; break ; case MCP3422_SR_240: // 12 bits - default waitForConversion (node->fd, buffer, 3) ; value = ((buffer [0] & 0x0F) << 8) | buffer [1] ; break ; } return value ; } /* * mcp3422Setup: * Create a new wiringPi device node for the mcp3422 ********************************************************************************* */ int mcp3422Setup (int pinBase, int i2cAddress, int sampleRate, int gain) { int fd ; struct wiringPiNodeStruct *node ; if ((fd = wiringPiI2CSetup (i2cAddress)) < 0) return FALSE ; node = wiringPiNewNode (pinBase, 4) ; node->fd = fd ; node->data0 = sampleRate ; node->data1 = gain ; node->analogRead = myAnalogRead ; return TRUE ; } wiringpi-2.50/wiringPi/mcp23s08.h0000664000175000017500000000225713442550153016150 0ustar ubuntuubuntu/* * 23s08.h: * Extend wiringPi with the MCP 23s08 SPI GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int mcp23s08Setup (const int pinBase, const int spiPort, const int devId) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/sr595.h0000664000175000017500000000231613442550153015554 0ustar ubuntuubuntu/* * sr595.h: * Extend wiringPi with the 74x595 shift registers. * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int sr595Setup (const int pinBase, const int numPins, const int dataPin, const int clockPin, const int latchPin) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/rht03.h0000664000175000017500000000213313442550153015622 0ustar ubuntuubuntu/* * rht03.h: * Extend wiringPi with the rht03 Maxdetect 1-Wire sensor. * Copyright (c) 2016-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ extern int rht03Setup (const int pinBase, const int devicePin) ; wiringpi-2.50/wiringPi/pcf8574.c0000664000175000017500000000626413442550153015766 0ustar ubuntuubuntu/* * pcf8574.c: * Extend wiringPi with the PCF8574 I2C GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" #include "wiringPiI2C.h" #include "pcf8574.h" /* * myPinMode: * The PCF8574 is an odd chip - the pins are effectively bi-directional, * however the pins should be drven high when used as an input pin... * So, we're effectively copying digitalWrite... ********************************************************************************* */ static void myPinMode (struct wiringPiNodeStruct *node, int pin, int mode) { int bit, old ; bit = 1 << ((pin - node->pinBase) & 7) ; old = node->data2 ; if (mode == OUTPUT) old &= (~bit) ; // Write bit to 0 else old |= bit ; // Write bit to 1 wiringPiI2CWrite (node->fd, old) ; node->data2 = old ; } /* * myDigitalWrite: ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { int bit, old ; bit = 1 << ((pin - node->pinBase) & 7) ; old = node->data2 ; if (value == LOW) old &= (~bit) ; else old |= bit ; wiringPiI2CWrite (node->fd, old) ; node->data2 = old ; } /* * myDigitalRead: ********************************************************************************* */ static int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { int mask, value ; mask = 1 << ((pin - node->pinBase) & 7) ; value = wiringPiI2CRead (node->fd) ; if ((value & mask) == 0) return LOW ; else return HIGH ; } /* * pcf8574Setup: * Create a new instance of a PCF8574 I2C GPIO interface. We know it * has 8 pins, so all we need to know here is the I2C address and the * user-defined pin base. ********************************************************************************* */ int pcf8574Setup (const int pinBase, const int i2cAddress) { int fd ; struct wiringPiNodeStruct *node ; if ((fd = wiringPiI2CSetup (i2cAddress)) < 0) return FALSE ; node = wiringPiNewNode (pinBase, 8) ; node->fd = fd ; node->pinMode = myPinMode ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; node->data2 = wiringPiI2CRead (fd) ; return TRUE ; } wiringpi-2.50/wiringPi/softPwm.h0000664000175000017500000000234213442550153016323 0ustar ubuntuubuntu/* * softPwm.h: * Provide 2 channels of software driven PWM. * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int softPwmCreate (int pin, int value, int range) ; extern void softPwmWrite (int pin, int value) ; extern void softPwmStop (int pin) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/softTone.c0000664000175000017500000000645113442550153016465 0ustar ubuntuubuntu/* * softTone.c: * For that authentic retro sound... * Er... A little experiment to produce tones out of a Pi using * one (or 2) GPIO pins and a piezeo "speaker" element. * (Or a high impedance speaker, but don'y blame me if you blow-up * the GPIO pins!) * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" #include "softTone.h" #define MAX_PINS 64 #define PULSE_TIME 100 static int freqs [MAX_PINS] ; static pthread_t threads [MAX_PINS] ; static int newPin = -1 ; /* * softToneThread: * Thread to do the actual PWM output ********************************************************************************* */ static PI_THREAD (softToneThread) { int pin, freq, halfPeriod ; struct sched_param param ; param.sched_priority = sched_get_priority_max (SCHED_RR) ; pthread_setschedparam (pthread_self (), SCHED_RR, ¶m) ; pin = newPin ; newPin = -1 ; piHiPri (50) ; for (;;) { freq = freqs [pin] ; if (freq == 0) delay (1) ; else { halfPeriod = 500000 / freq ; digitalWrite (pin, HIGH) ; delayMicroseconds (halfPeriod) ; digitalWrite (pin, LOW) ; delayMicroseconds (halfPeriod) ; } } return NULL ; } /* * softToneWrite: * Write a frequency value to the given pin ********************************************************************************* */ void softToneWrite (int pin, int freq) { pin &= 63 ; /**/ if (freq < 0) freq = 0 ; else if (freq > 5000) // Max 5KHz freq = 5000 ; freqs [pin] = freq ; } /* * softToneCreate: * Create a new tone thread. ********************************************************************************* */ int softToneCreate (int pin) { int res ; pthread_t myThread ; pinMode (pin, OUTPUT) ; digitalWrite (pin, LOW) ; if (threads [pin] != 0) return -1 ; freqs [pin] = 0 ; newPin = pin ; res = pthread_create (&myThread, NULL, softToneThread, NULL) ; while (newPin != -1) delay (1) ; threads [pin] = myThread ; return res ; } /* * softToneStop: * Stop an existing softTone thread ********************************************************************************* */ void softToneStop (int pin) { if (threads [pin] != 0) { pthread_cancel (threads [pin]) ; pthread_join (threads [pin], NULL) ; threads [pin] = 0 ; digitalWrite (pin, LOW) ; } } wiringpi-2.50/wiringPi/drcSerial.c0000664000175000017500000001200213442550153016561 0ustar ubuntuubuntu/* * drcSerial.c: * Extend wiringPi with the DRC Serial protocol (e.g. to Arduino) * Copyright (c) 2013-2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include "wiringPi.h" #include "wiringSerial.h" #include "drcSerial.h" /* * myPinMode: * Change the pin mode on the remote DRC device ********************************************************************************* */ static void myPinMode (struct wiringPiNodeStruct *node, int pin, int mode) { /**/ if (mode == OUTPUT) serialPutchar (node->fd, 'o') ; // Input else if (mode == PWM_OUTPUT) serialPutchar (node->fd, 'p') ; // PWM else serialPutchar (node->fd, 'i') ; // Default to input serialPutchar (node->fd, pin - node->pinBase) ; } /* * myPullUpDnControl: * ATmegas only have pull-up's on of off. No pull-downs. ********************************************************************************* */ static void myPullUpDnControl (struct wiringPiNodeStruct *node, int pin, int mode) { // Force pin into input mode serialPutchar (node->fd, 'i' ) ; serialPutchar (node->fd, pin - node->pinBase) ; /**/ if (mode == PUD_UP) { serialPutchar (node->fd, '1') ; serialPutchar (node->fd, pin - node->pinBase) ; } else if (mode == PUD_OFF) { serialPutchar (node->fd, '0') ; serialPutchar (node->fd, pin - node->pinBase) ; } } /* * myDigitalWrite: ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { serialPutchar (node->fd, value == 0 ? '0' : '1') ; serialPutchar (node->fd, pin - node->pinBase) ; } /* * myPwmWrite: ********************************************************************************* */ static void myPwmWrite (struct wiringPiNodeStruct *node, int pin, int value) { serialPutchar (node->fd, 'v') ; serialPutchar (node->fd, pin - node->pinBase) ; serialPutchar (node->fd, value & 0xFF) ; } /* * myAnalogRead: ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { int vHi, vLo ; serialPutchar (node->fd, 'a') ; serialPutchar (node->fd, pin - node->pinBase) ; vHi = serialGetchar (node->fd) ; vLo = serialGetchar (node->fd) ; return (vHi << 8) | vLo ; } /* * myDigitalRead: ********************************************************************************* */ static int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { serialPutchar (node->fd, 'r') ; // Send read command serialPutchar (node->fd, pin - node->pinBase) ; return (serialGetchar (node->fd) == '0') ? 0 : 1 ; } /* * drcSetup: * Create a new instance of an DRC GPIO interface. * Could be a variable nunber of pins here - we might not know in advance * if it's an ATmega with 14 pins, or something with less or more! ********************************************************************************* */ int drcSetupSerial (const int pinBase, const int numPins, const char *device, const int baud) { int fd ; int ok, tries ; time_t then ; struct wiringPiNodeStruct *node ; if ((fd = serialOpen (device, baud)) < 0) return FALSE ; delay (10) ; // May need longer if it's an Uno that reboots on the open... // Flush any pending input while (serialDataAvail (fd)) (void)serialGetchar (fd) ; ok = FALSE ; for (tries = 1 ; (tries < 5) && (!ok) ; ++tries) { serialPutchar (fd, '@') ; // Ping then = time (NULL) + 2 ; while (time (NULL) < then) if (serialDataAvail (fd)) { if (serialGetchar (fd) == '@') { ok = TRUE ; break ; } } } if (!ok) { serialClose (fd) ; return FALSE ; } node = wiringPiNewNode (pinBase, numPins) ; node->fd = fd ; node->pinMode = myPinMode ; node->pullUpDnControl = myPullUpDnControl ; node->analogRead = myAnalogRead ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; node->pwmWrite = myPwmWrite ; return TRUE ; } wiringpi-2.50/wiringPi/wiringShift.c0000664000175000017500000000435313442550153017160 0ustar ubuntuubuntu/* * wiringShift.c: * Emulate some of the Arduino wiring functionality. * * Copyright (c) 2009-2012 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include "wiringPi.h" #include "wiringShift.h" /* * shiftIn: * Shift data in from a clocked source ********************************************************************************* */ uint8_t shiftIn (uint8_t dPin, uint8_t cPin, uint8_t order) { uint8_t value = 0 ; int8_t i ; if (order == MSBFIRST) for (i = 7 ; i >= 0 ; --i) { digitalWrite (cPin, HIGH) ; value |= digitalRead (dPin) << i ; digitalWrite (cPin, LOW) ; } else for (i = 0 ; i < 8 ; ++i) { digitalWrite (cPin, HIGH) ; value |= digitalRead (dPin) << i ; digitalWrite (cPin, LOW) ; } return value; } /* * shiftOut: * Shift data out to a clocked source ********************************************************************************* */ void shiftOut (uint8_t dPin, uint8_t cPin, uint8_t order, uint8_t val) { int8_t i; if (order == MSBFIRST) for (i = 7 ; i >= 0 ; --i) { digitalWrite (dPin, val & (1 << i)) ; digitalWrite (cPin, HIGH) ; digitalWrite (cPin, LOW) ; } else for (i = 0 ; i < 8 ; ++i) { digitalWrite (dPin, val & (1 << i)) ; digitalWrite (cPin, HIGH) ; digitalWrite (cPin, LOW) ; } } wiringpi-2.50/wiringPi/ds18b20.c0000664000175000017500000000667713442550153015761 0ustar ubuntuubuntu/* * ds18b20.c: * Extend wiringPi with the DS18B20 1-Wire temperature sensor. * This is used in the Pi Weather Station and many other places. * Copyright (c) 2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include "wiringPi.h" #include "ds18b20.h" #define W1_PREFIX "/sys/bus/w1/devices/28-" #define W1_POSTFIX "/w1_slave" /* * myAnalogRead: ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { int chan = pin - node->pinBase ; int fd = node->fd ; char buffer [4096] ; char *p ; int temp, sign ; if (chan != 0) return -9999 ; // Rewind the file - we're keeping it open to keep things going // smoothly lseek (fd, 0, SEEK_SET) ; // Read the file - we know it's only a couple of lines, so this ought to be // more than enough if (read (fd, buffer, 4096) <= 0) // Read nothing, or it failed in some odd way return -9998 ; // Look for YES, then t= if (strstr (buffer, "YES") == NULL) return -9997 ; if ((p = strstr (buffer, "t=")) == NULL) return -9996 ; // p points to the 't', so we skip over it... p += 2 ; // and extract the number // (without caring about overflow) if (*p == '-') // Negative number? { sign = -1 ; ++p ; } else sign = 1 ; temp = 0 ; while (isdigit (*p)) { temp = temp * 10 + (*p - '0') ; ++p ; } // We know it returns temp * 1000, but we only really want temp * 10, so // do a bit of rounding... temp = (temp + 50) / 100 ; return temp * sign ; } /* * ds18b20Setup: * Create a new instance of a DS18B20 temperature sensor. ********************************************************************************* */ int ds18b20Setup (const int pinBase, const char *deviceId) { int fd ; struct wiringPiNodeStruct *node ; char *fileName ; // Allocate space for the filename if ((fileName = malloc (strlen (W1_PREFIX) + strlen (W1_POSTFIX) + strlen (deviceId) + 1)) == NULL) return FALSE ; sprintf (fileName, "%s%s%s", W1_PREFIX, deviceId, W1_POSTFIX) ; fd = open (fileName, O_RDONLY) ; free (fileName) ; if (fd < 0) return FALSE ; // We'll keep the file open, to make access a little faster // although it's very slow reading these things anyway )-: node = wiringPiNewNode (pinBase, 1) ; node->fd = fd ; node->analogRead = myAnalogRead ; return TRUE ; } wiringpi-2.50/wiringPi/wiringSerial.c0000664000175000017500000001324313442550153017320 0ustar ubuntuubuntu/* * wiringSerial.c: * Handle a serial port *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include #include #include "wiringSerial.h" /* * serialOpen: * Open and initialise the serial port, setting all the right * port parameters - or as many as are required - hopefully! ********************************************************************************* */ int serialOpen (const char *device, const int baud) { struct termios options ; speed_t myBaud ; int status, fd ; switch (baud) { case 50: myBaud = B50 ; break ; case 75: myBaud = B75 ; break ; case 110: myBaud = B110 ; break ; case 134: myBaud = B134 ; break ; case 150: myBaud = B150 ; break ; case 200: myBaud = B200 ; break ; case 300: myBaud = B300 ; break ; case 600: myBaud = B600 ; break ; case 1200: myBaud = B1200 ; break ; case 1800: myBaud = B1800 ; break ; case 2400: myBaud = B2400 ; break ; case 4800: myBaud = B4800 ; break ; case 9600: myBaud = B9600 ; break ; case 19200: myBaud = B19200 ; break ; case 38400: myBaud = B38400 ; break ; case 57600: myBaud = B57600 ; break ; case 115200: myBaud = B115200 ; break ; case 230400: myBaud = B230400 ; break ; case 460800: myBaud = B460800 ; break ; case 500000: myBaud = B500000 ; break ; case 576000: myBaud = B576000 ; break ; case 921600: myBaud = B921600 ; break ; case 1000000: myBaud = B1000000 ; break ; case 1152000: myBaud = B1152000 ; break ; case 1500000: myBaud = B1500000 ; break ; case 2000000: myBaud = B2000000 ; break ; case 2500000: myBaud = B2500000 ; break ; case 3000000: myBaud = B3000000 ; break ; case 3500000: myBaud = B3500000 ; break ; case 4000000: myBaud = B4000000 ; break ; default: return -2 ; } if ((fd = open (device, O_RDWR | O_NOCTTY | O_NDELAY | O_NONBLOCK)) == -1) return -1 ; fcntl (fd, F_SETFL, O_RDWR) ; // Get and modify current options: tcgetattr (fd, &options) ; cfmakeraw (&options) ; cfsetispeed (&options, myBaud) ; cfsetospeed (&options, myBaud) ; options.c_cflag |= (CLOCAL | CREAD) ; options.c_cflag &= ~PARENB ; options.c_cflag &= ~CSTOPB ; options.c_cflag &= ~CSIZE ; options.c_cflag |= CS8 ; options.c_lflag &= ~(ICANON | ECHO | ECHOE | ISIG) ; options.c_oflag &= ~OPOST ; options.c_cc [VMIN] = 0 ; options.c_cc [VTIME] = 100 ; // Ten seconds (100 deciseconds) tcsetattr (fd, TCSANOW, &options) ; ioctl (fd, TIOCMGET, &status); status |= TIOCM_DTR ; status |= TIOCM_RTS ; ioctl (fd, TIOCMSET, &status); usleep (10000) ; // 10mS return fd ; } /* * serialFlush: * Flush the serial buffers (both tx & rx) ********************************************************************************* */ void serialFlush (const int fd) { tcflush (fd, TCIOFLUSH) ; } /* * serialClose: * Release the serial port ********************************************************************************* */ void serialClose (const int fd) { close (fd) ; } /* * serialPutchar: * Send a single character to the serial port ********************************************************************************* */ void serialPutchar (const int fd, const unsigned char c) { write (fd, &c, 1) ; } /* * serialPuts: * Send a string to the serial port ********************************************************************************* */ void serialPuts (const int fd, const char *s) { write (fd, s, strlen (s)) ; } /* * serialPrintf: * Printf over Serial ********************************************************************************* */ void serialPrintf (const int fd, const char *message, ...) { va_list argp ; char buffer [1024] ; va_start (argp, message) ; vsnprintf (buffer, 1023, message, argp) ; va_end (argp) ; serialPuts (fd, buffer) ; } /* * serialDataAvail: * Return the number of bytes of data avalable to be read in the serial port ********************************************************************************* */ int serialDataAvail (const int fd) { int result ; if (ioctl (fd, FIONREAD, &result) == -1) return -1 ; return result ; } /* * serialGetchar: * Get a single character from the serial device. * Note: Zero is a valid character and this function will time-out after * 10 seconds. ********************************************************************************* */ int serialGetchar (const int fd) { uint8_t x ; if (read (fd, &x, 1) != 1) return -1 ; return ((int)x) & 0xFF ; } wiringpi-2.50/wiringPi/mcp23017.c0000664000175000017500000001046013442550153016033 0ustar ubuntuubuntu/* * mcp23017.c: * Extend wiringPi with the MCP 23017 I2C GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" #include "wiringPiI2C.h" #include "mcp23x0817.h" #include "mcp23017.h" /* * myPinMode: ********************************************************************************* */ static void myPinMode (struct wiringPiNodeStruct *node, int pin, int mode) { int mask, old, reg ; pin -= node->pinBase ; if (pin < 8) // Bank A reg = MCP23x17_IODIRA ; else { reg = MCP23x17_IODIRB ; pin &= 0x07 ; } mask = 1 << pin ; old = wiringPiI2CReadReg8 (node->fd, reg) ; if (mode == OUTPUT) old &= (~mask) ; else old |= mask ; wiringPiI2CWriteReg8 (node->fd, reg, old) ; } /* * myPullUpDnControl: ********************************************************************************* */ static void myPullUpDnControl (struct wiringPiNodeStruct *node, int pin, int mode) { int mask, old, reg ; pin -= node->pinBase ; if (pin < 8) // Bank A reg = MCP23x17_GPPUA ; else { reg = MCP23x17_GPPUB ; pin &= 0x07 ; } mask = 1 << pin ; old = wiringPiI2CReadReg8 (node->fd, reg) ; if (mode == PUD_UP) old |= mask ; else old &= (~mask) ; wiringPiI2CWriteReg8 (node->fd, reg, old) ; } /* * myDigitalWrite: ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { int bit, old ; pin -= node->pinBase ; // Pin now 0-15 bit = 1 << (pin & 7) ; if (pin < 8) // Bank A { old = node->data2 ; if (value == LOW) old &= (~bit) ; else old |= bit ; wiringPiI2CWriteReg8 (node->fd, MCP23x17_GPIOA, old) ; node->data2 = old ; } else // Bank B { old = node->data3 ; if (value == LOW) old &= (~bit) ; else old |= bit ; wiringPiI2CWriteReg8 (node->fd, MCP23x17_GPIOB, old) ; node->data3 = old ; } } /* * myDigitalRead: ********************************************************************************* */ static int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { int mask, value, gpio ; pin -= node->pinBase ; if (pin < 8) // Bank A gpio = MCP23x17_GPIOA ; else { gpio = MCP23x17_GPIOB ; pin &= 0x07 ; } mask = 1 << pin ; value = wiringPiI2CReadReg8 (node->fd, gpio) ; if ((value & mask) == 0) return LOW ; else return HIGH ; } /* * mcp23017Setup: * Create a new instance of an MCP23017 I2C GPIO interface. We know it * has 16 pins, so all we need to know here is the I2C address and the * user-defined pin base. ********************************************************************************* */ int mcp23017Setup (const int pinBase, const int i2cAddress) { int fd ; struct wiringPiNodeStruct *node ; if ((fd = wiringPiI2CSetup (i2cAddress)) < 0) return FALSE ; wiringPiI2CWriteReg8 (fd, MCP23x17_IOCON, IOCON_INIT) ; node = wiringPiNewNode (pinBase, 16) ; node->fd = fd ; node->pinMode = myPinMode ; node->pullUpDnControl = myPullUpDnControl ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; node->data2 = wiringPiI2CReadReg8 (fd, MCP23x17_OLATA) ; node->data3 = wiringPiI2CReadReg8 (fd, MCP23x17_OLATB) ; return TRUE ; } wiringpi-2.50/wiringPi/ds18b20.h0000664000175000017500000000226013442550153015746 0ustar ubuntuubuntu/* * bmp180.h: * Extend wiringPi with the BMP180 I2C Pressure and Temperature * sensor. * Copyright (c) 2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int ds18b20Setup (const int pinBase, const char *serialNum) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/max31855.c0000664000175000017500000000537313442550153016061 0ustar ubuntuubuntu/* * max31855.c: * Extend wiringPi with the max31855 SPI Analog to Digital convertor * Copyright (c) 2012-2015 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include "max31855.h" static int myAnalogRead (struct wiringPiNodeStruct *node, int pin) { uint32_t spiData ; int temp ; int chan = pin - node->pinBase ; wiringPiSPIDataRW (node->fd, (unsigned char *)&spiData, 4) ; spiData = __bswap_32(spiData) ; switch (chan) { case 0: // Existing read - return raw value * 4 spiData >>= 18 ; temp = spiData & 0x1FFF ; // Bottom 13 bits if ((spiData & 0x2000) != 0) // Negative temp = -temp ; return temp ; case 1: // Return error bits return spiData & 0x7 ; case 2: // Return temp in C * 10 spiData >>= 18 ; temp = spiData & 0x1FFF ; // Bottom 13 bits if ((spiData & 0x2000) != 0) // Negative temp = -temp ; return (int)((((double)temp * 25) + 0.5) / 10.0) ; case 3: // Return temp in F * 10 spiData >>= 18 ; temp = spiData & 0x1FFF ; // Bottom 13 bits if ((spiData & 0x2000) != 0) // Negative temp = -temp ; return (int)((((((double)temp * 0.25 * 9.0 / 5.0) + 32.0) * 100.0) + 0.5) / 10.0) ; default: // Who knows... return 0 ; } } /* * max31855Setup: * Create a new wiringPi device node for an max31855 on the Pi's * SPI interface. ********************************************************************************* */ int max31855Setup (const int pinBase, int spiChannel) { struct wiringPiNodeStruct *node ; if (wiringPiSPISetup (spiChannel, 5000000) < 0) // 5MHz - prob 4 on the Pi return FALSE ; node = wiringPiNewNode (pinBase, 4) ; node->fd = spiChannel ; node->analogRead = myAnalogRead ; return TRUE ; } wiringpi-2.50/wiringPi/mcp23s08.c0000664000175000017500000001105613442550153016140 0ustar ubuntuubuntu/* * mcp23s08.c: * Extend wiringPi with the MCP 23s08 SPI GPIO expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" #include "wiringPiSPI.h" #include "mcp23x0817.h" #include "mcp23s08.h" #define MCP_SPEED 4000000 /* * writeByte: * Write a byte to a register on the MCP23s08 on the SPI bus. ********************************************************************************* */ static void writeByte (uint8_t spiPort, uint8_t devId, uint8_t reg, uint8_t data) { uint8_t spiData [4] ; spiData [0] = CMD_WRITE | ((devId & 7) << 1) ; spiData [1] = reg ; spiData [2] = data ; wiringPiSPIDataRW (spiPort, spiData, 3) ; } /* * readByte: * Read a byte from a register on the MCP23s08 on the SPI bus. ********************************************************************************* */ static uint8_t readByte (uint8_t spiPort, uint8_t devId, uint8_t reg) { uint8_t spiData [4] ; spiData [0] = CMD_READ | ((devId & 7) << 1) ; spiData [1] = reg ; wiringPiSPIDataRW (spiPort, spiData, 3) ; return spiData [2] ; } /* * myPinMode: ********************************************************************************* */ static void myPinMode (struct wiringPiNodeStruct *node, int pin, int mode) { int mask, old, reg ; reg = MCP23x08_IODIR ; mask = 1 << (pin - node->pinBase) ; old = readByte (node->data0, node->data1, reg) ; if (mode == OUTPUT) old &= (~mask) ; else old |= mask ; writeByte (node->data0, node->data1, reg, old) ; } /* * myPullUpDnControl: ********************************************************************************* */ static void myPullUpDnControl (struct wiringPiNodeStruct *node, int pin, int mode) { int mask, old, reg ; reg = MCP23x08_GPPU ; mask = 1 << (pin - node->pinBase) ; old = readByte (node->data0, node->data1, reg) ; if (mode == PUD_UP) old |= mask ; else old &= (~mask) ; writeByte (node->data0, node->data1, reg, old) ; } /* * myDigitalWrite: ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { int bit, old ; bit = 1 << ((pin - node->pinBase) & 7) ; old = node->data2 ; if (value == LOW) old &= (~bit) ; else old |= bit ; writeByte (node->data0, node->data1, MCP23x08_GPIO, old) ; node->data2 = old ; } /* * myDigitalRead: ********************************************************************************* */ static int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { int mask, value ; mask = 1 << ((pin - node->pinBase) & 7) ; value = readByte (node->data0, node->data1, MCP23x08_GPIO) ; if ((value & mask) == 0) return LOW ; else return HIGH ; } /* * mcp23s08Setup: * Create a new instance of an MCP23s08 SPI GPIO interface. We know it * has 8 pins, so all we need to know here is the SPI address and the * user-defined pin base. ********************************************************************************* */ int mcp23s08Setup (const int pinBase, const int spiPort, const int devId) { struct wiringPiNodeStruct *node ; if (wiringPiSPISetup (spiPort, MCP_SPEED) < 0) return FALSE ; writeByte (spiPort, devId, MCP23x08_IOCON, IOCON_INIT) ; node = wiringPiNewNode (pinBase, 8) ; node->data0 = spiPort ; node->data1 = devId ; node->pinMode = myPinMode ; node->pullUpDnControl = myPullUpDnControl ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; node->data2 = readByte (spiPort, devId, MCP23x08_OLAT) ; return TRUE ; } wiringpi-2.50/wiringPi/pcf8591.h0000664000175000017500000000224713442550153015767 0ustar ubuntuubuntu/* * pcf8591.h: * Extend wiringPi with the PCF8591 I2C GPIO Analog expander chip * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int pcf8591Setup (const int pinBase, const int i2cAddress) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/mcp23016reg.h0000664000175000017500000000301113442550153016527 0ustar ubuntuubuntu/* * mcp23016: * Copyright (c) 2012-2013 Gordon Henderson * * Header file for code using the MCP23016 GPIO expander * chip. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ // MCP23016 Registers #define MCP23016_GP0 0x00 #define MCP23016_GP1 0x01 #define MCP23016_OLAT0 0x02 #define MCP23016_OLAT1 0x03 #define MCP23016_IPOL0 0x04 #define MCP23016_IPOL1 0x05 #define MCP23016_IODIR0 0x06 #define MCP23016_IODIR1 0x07 #define MCP23016_INTCAP0 0x08 #define MCP23016_INTCAP1 0x09 #define MCP23016_IOCON0 0x0A #define MCP23016_IOCON1 0x0B // Bits in the IOCON register #define IOCON_IARES 0x01 // Default initialisation mode #define IOCON_INIT 0 wiringpi-2.50/wiringPi/bmp180.h0000664000175000017500000000223013442550153015667 0ustar ubuntuubuntu/* * bmp180.h: * Extend wiringPi with the BMP180 I2C Pressure and Temperature * sensor. * Copyright (c) 2016 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int bmp180Setup (const int pinBase) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/sr595.c0000664000175000017500000000622013442550153015545 0ustar ubuntuubuntu/* * sr595.c: * Extend wiringPi with the 74x595 shift register as a GPIO * expander chip. * Note that the code can cope with a number of 595's * daisy-chained together - up to 4 for now as we're storing * the output "register" in a single unsigned int. * * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include "wiringPi.h" #include "sr595.h" /* * myDigitalWrite: ********************************************************************************* */ static void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { unsigned int mask ; int dataPin, clockPin, latchPin ; int bit, bits, output ; pin -= node->pinBase ; // Normalise pin number bits = node->pinMax - node->pinBase + 1 ; // ie. number of clock pulses dataPin = node->data0 ; clockPin = node->data1 ; latchPin = node->data2 ; output = node->data3 ; mask = 1 << pin ; if (value == LOW) output &= (~mask) ; else output |= mask ; node->data3 = output ; // A low -> high latch transition copies the latch to the output pins digitalWrite (latchPin, LOW) ; delayMicroseconds (1) ; for (bit = bits - 1 ; bit >= 0 ; --bit) { digitalWrite (dataPin, output & (1 << bit)) ; digitalWrite (clockPin, HIGH) ; delayMicroseconds (1) ; digitalWrite (clockPin, LOW) ; delayMicroseconds (1) ; } digitalWrite (latchPin, HIGH) ; delayMicroseconds (1) ; } /* * sr595Setup: * Create a new instance of a 74x595 shift register GPIO expander. ********************************************************************************* */ int sr595Setup (const int pinBase, const int numPins, const int dataPin, const int clockPin, const int latchPin) { struct wiringPiNodeStruct *node ; node = wiringPiNewNode (pinBase, numPins) ; node->data0 = dataPin ; node->data1 = clockPin ; node->data2 = latchPin ; node->data3 = 0 ; // Output register node->digitalWrite = myDigitalWrite ; // Initialise the underlying hardware digitalWrite (dataPin, LOW) ; digitalWrite (clockPin, LOW) ; digitalWrite (latchPin, HIGH) ; pinMode (dataPin, OUTPUT) ; pinMode (clockPin, OUTPUT) ; pinMode (latchPin, OUTPUT) ; return TRUE ; } wiringpi-2.50/wiringPi/COPYING.LESSER0000664000175000017500000001674313442550153016554 0ustar ubuntuubuntu GNU LESSER GENERAL PUBLIC LICENSE Version 3, 29 June 2007 Copyright (C) 2007 Free Software Foundation, Inc. Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below. 0. Additional Definitions. As used herein, "this License" refers to version 3 of the GNU Lesser General Public License, and the "GNU GPL" refers to version 3 of the GNU General Public License. "The Library" refers to a covered work governed by this License, other than an Application or a Combined Work as defined below. An "Application" is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library. A "Combined Work" is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the "Linked Version". The "Minimal Corresponding Source" for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version. The "Corresponding Application Code" for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work. 1. Exception to Section 3 of the GNU GPL. You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL. 2. Conveying Modified Versions. If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version: a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy. 3. Object Code Incorporating Material from Library Header Files. The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following: a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the object code with a copy of the GNU GPL and this license document. 4. Combined Works. You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following: a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the Combined Work with a copy of the GNU GPL and this license document. c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document. d) Do one of the following: 0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source. 1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version. e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.) 5. Combined Libraries. You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following: a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License. b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. 6. Revised Versions of the GNU Lesser General Public License. The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License "or any later version" applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation. If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library. wiringpi-2.50/wiringPi/drcSerial.h0000664000175000017500000000231413442550153016573 0ustar ubuntuubuntu/* * drcSerial.h: * Extend wiringPi with the DRC Serial protocol (e.g. to Arduino) * Copyright (c) 2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int drcSetupSerial (const int pinBase, const int numPins, const char *device, const int baud) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/sn3218.h0000664000175000017500000000220513442550153015620 0ustar ubuntuubuntu/* * sn3218.c: * Extend wiringPi with the SN3218 I2C LED driver board. * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int sn3218Setup (int pinBase) ; #ifdef __cplusplus } #endif wiringpi-2.50/wiringPi/wiringShift.h0000664000175000017500000000252713442550153017166 0ustar ubuntuubuntu/* * wiringShift.h: * Emulate some of the Arduino wiring functionality. * * Copyright (c) 2009-2012 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #define LSBFIRST 0 #define MSBFIRST 1 #ifndef _STDINT_H # include #endif #ifdef __cplusplus extern "C" { #endif extern uint8_t shiftIn (uint8_t dPin, uint8_t cPin, uint8_t order) ; extern void shiftOut (uint8_t dPin, uint8_t cPin, uint8_t order, uint8_t val) ; #ifdef __cplusplus } #endif wiringpi-2.50/debian/0000775000175000017500000000000013442550153014144 5ustar ubuntuubuntuwiringpi-2.50/debian/wiringpi.dirs0000664000175000017500000000001013442550153016646 0ustar ubuntuubuntuusr/bin wiringpi-2.50/debian/libwiringpi-dev.install0000664000175000017500000000012713442550153020627 0ustar ubuntuubuntudebian/tmp/usr/include debian/tmp/usr/lib/*.so examples usr/share/doc/libwiringpi-dev wiringpi-2.50/debian/rules0000775000175000017500000000167013442550153015230 0ustar ubuntuubuntu#!/usr/bin/make -f .PHONY: build VERSION:=$(shell cat VERSION) export VERSION soname:=$(shell echo $${VERSION%%.*}) WIRINGPI_SONAME_SUFFIX:=.$(soname) export soname export WIRINGPI_SONAME_SUFFIX build: dh $@ override_dh_auto_configure: override_dh_prep: dh_prep -Xdebian/tmp dirs: dh_installdirs -A mkdir debian/tmp set -e; for p in `dh_listpackages`; do \ (cd debian/$$p; find -type d) | \ (cd debian/tmp; xargs mkdir -p) \ done override_dh_clean: dh_clean WIRINGPI_SUDO= bash -xe ./build clean override_dh_auto_build: dirs V=1 LDCONFIG=: WIRINGPI_SUDO= WIRINGPI_SUID=0 \ DESTDIR=`pwd`/debian/tmp/usr \ PREFIX= WIRINGPI_SUDO= \ bash -xe ./build override_dh_auto_install: dh_install set -ex; for l in libwiringPi libwiringPiDev; do \ ln -sf $$l.so.$${VERSION} \ debian/libwiringpi$$soname/usr/lib/$$l.so.$$soname; \ ln -sf $$l.so.$${VERSION} \ debian/libwiringpi-dev/usr/lib/$$l.so; \ done %: dh $@ wiringpi-2.50/debian/compat0000664000175000017500000000000213442550153015342 0ustar ubuntuubuntu8 wiringpi-2.50/debian/copyright0000664000175000017500000000125513442550153016102 0ustar ubuntuubuntuwiringPi is Copyright (C) 2012-2015 Gordon Henderson. wiringPi is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License, as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. wiringPi is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. On all Debian and Raspbian systems, a copy of the GNU Lesser General Public License version 3 can be found in `/usr/share/common-licenses/LGPL-3'. wiringpi-2.50/debian/libwiringpi2.shlibs0000664000175000017500000000007113442550153017751 0ustar ubuntuubuntulibwiringPi 2 libwiringpi2 libwiringPiDev 2 libwiringpi2 wiringpi-2.50/debian/libwiringpi-dev.dirs0000664000175000017500000000002413442550153020116 0ustar ubuntuubuntuusr/lib usr/include wiringpi-2.50/debian/libwiringpi2.install0000664000175000017500000000003513442550153020133 0ustar ubuntuubuntudebian/tmp/usr/lib/lib*.so.* wiringpi-2.50/debian/changelog0000664000175000017500000000027713442550153016024 0ustar ubuntuubuntuwiringpi (2.26~iwj) rpi-unstable; urgency=low * Initial version with real Debian source package build. -- Ian Jackson Sat, 12 Sep 2015 18:31:35 +0100 wiringpi-2.50/debian/wiringpi.install0000664000175000017500000000016313442550153017364 0ustar ubuntuubuntudebian/tmp/usr/bin debian/tmp/usr/man usr/share README.TXT usr/share/doc/wiringpi People usr/share/doc/wiringpi wiringpi-2.50/debian/control0000664000175000017500000000161513442550153015552 0ustar ubuntuubuntuSource: wiringpi Section: electronics Priority: optional Maintainer: Ian Jackson Standards-Version: 3.8.0 Homepage: http://wiringpi.com/ Build-Depends: debhelper (>= 8) Package: libwiringpi2 Section: libs Architecture: armhf Depends: ${shlibs:Depends}, ${misc:Depends} Description: GPIO librariees for Raspberry Pi (runtime). Runtime for the popular wiringPi library. Package: wiringpi Architecture: armhf Depends: ${shlibs:Depends}, ${misc:Depends} Description: gpio utility for Raspberry Pi The wiringPi gpio command line utility, for GPIO access on a Raspberry Pi from the command line. Package: libwiringpi-dev Architecture: armhf Depends: libwiringpi2 (= ${binary:Version}), libc6-dev, ${misc:Depends} Suggests: wiringpi Description: GPIO development library for Raspberry Pi Development libraries to allow GPIO access on a Raspberry Pi from C and C++ programs. wiringpi-2.50/INSTALL0000664000175000017500000000105113442550153013750 0ustar ubuntuubuntu How to install wiringPi ======================= The easiest way is to use the supplied 'build' script: ./build that should do a complete install or upgrade of wiringPi for you. That will install a dynamic library. Some distributions do not have /usr/local/lib in the default LD_LIBRARY_PATH. To fix this, you need to edit /etc/ld.so.conf and add in a single line: /usr/local/lib then run the ldconfig command. sudo ldconfig To un-install wiringPi: ./build uninstall Gordon Henderson projects@drogon.net https://projects.drogon.net/ wiringpi-2.50/VERSION0000664000175000017500000000000513442550153013765 0ustar ubuntuubuntu2.50 wiringpi-2.50/update0000775000175000017500000000022713442550153014133 0ustar ubuntuubuntu#!/bin/sh # update - update source files from master on yakko rsync -aHx --exclude='*.o' --exclude='*~' -v --delete gordon@yakko:rpi/git/wiringPi/ . wiringpi-2.50/debian-template/0000775000175000017500000000000013442550153015755 5ustar ubuntuubuntuwiringpi-2.50/debian-template/wiringPi/0000775000175000017500000000000013442550153017545 5ustar ubuntuubuntuwiringpi-2.50/debian-template/wiringPi/DEBIAN/0000775000175000017500000000000013442550153020467 5ustar ubuntuubuntuwiringpi-2.50/debian-template/wiringPi/DEBIAN/postrm0000775000175000017500000000003113442550153021733 0ustar ubuntuubuntu#!/bin/sh /sbin/ldconfig wiringpi-2.50/debian-template/wiringPi/DEBIAN/postinst0000775000175000017500000000014213442550153022275 0ustar ubuntuubuntu#!/bin/sh set -e /bin/chown root.root /usr/bin/gpio /bin/chmod 4755 /usr/bin/gpio /sbin/ldconfig wiringpi-2.50/debian-template/wiringPi/DEBIAN/control0000664000175000017500000000052213442550153022071 0ustar ubuntuubuntuPackage: wiringpi Version: 2.50 Section: libraries Priority: optional Architecture: armhf Depends: libc6 Maintainer: Gordon Henderson Description: The wiringPi libraries, headers and gpio command Libraries to allow GPIO access on a Raspberry Pi from C and C++ and BASIC programs as well as from the command-line wiringpi-2.50/pins/0000775000175000017500000000000013442550153013673 5ustar ubuntuubuntuwiringpi-2.50/pins/pins.tex0000664000175000017500000001033513442550153015370 0ustar ubuntuubuntu\documentclass[12pt,a4paper]{article} \parskip 1ex \parindent 0em \thispagestyle{empty} \pagestyle{plain} \pagenumbering{arabic} \setlength{\topmargin}{0pt} \setlength{\headheight}{0pt} \setlength{\headsep}{0pt} \setlength{\topskip}{0pt} \setlength{\textheight}{240mm} \setlength{\footskip}{5ex} \setlength{\oddsidemargin}{0pt} \setlength{\evensidemargin}{0pt} \setlength{\textwidth}{160mm} \usepackage[dvips]{graphics,color} \usepackage{helvet} \renewcommand{\familydefault}{\sfdefault} \begin{document} \begin{sffamily} \definecolor{rtb-black}{rgb} {0.0, 0.0, 0.0} \definecolor{rtb-navy}{rgb} {0.0, 0.0, 0.5} \definecolor{rtb-green}{rgb} {0.0, 0.5, 0.0} \definecolor{rtb-teal}{rgb} {0.0, 0.5, 0.5} \definecolor{rtb-maroon}{rgb} {0.5, 0.0, 0.0} \definecolor{rtb-purple}{rgb} {0.5, 0.0, 0.5} \definecolor{rtb-olive}{rgb} {0.5, 0.5, 0.0} \definecolor{rtb-silver}{rgb} {0.7, 0.7, 0.7} \definecolor{rtb-grey}{rgb} {0.5, 0.5, 0.5} \definecolor{rtb-blue}{rgb} {0.0, 0.0, 1.0} \definecolor{rtb-lime}{rgb} {0.0, 1.0, 0.0} \definecolor{rtb-aqua}{rgb} {0.0, 1.0, 1.0} \definecolor{rtb-red}{rgb} {1.0, 0.0, 0.0} \definecolor{rtb-fuchsia}{rgb}{1.0, 0.0, 1.0} \definecolor{rtb-yellow}{rgb} {1.0, 1.0, 0.0} \definecolor{rtb-white}{rgb} {1.0, 1.0, 1.0} \begin{center} \bfseries{WiringPi: GPIO Pin Numbering Tables}\\ \tt{http://wiringpi.com/} \end{center} \begin{center} \begin{tabular}{|c|c|c||p{8mm}|p{8mm}||c|c|c|c|} \hline \multicolumn{8}{|c|}{\bfseries{P1: The Main GPIO connector}}\\ \hline \hline WiringPi Pin & BCM GPIO & Name & \multicolumn{2}{|c||}{Header} & Name & BCM GPIO & WiringPi Pin\\ \hline \hline & & \textcolor{rtb-red}{3.3v} & \raggedleft{1} & 2 & \textcolor{rtb-maroon}{5v} & & \\ \hline 8 & Rv1:0 - Rv2:2 & \textcolor{rtb-aqua}{SDA} & \raggedleft{3} & 4 & \textcolor{rtb-maroon}{5v} & & \\ \hline 9 & Rv1:1 - Rv2:3 & \textcolor{rtb-aqua}{SCL} & \raggedleft{5} & 6 & \textcolor{rtb-black}{0v} & & \\ \hline 7 & 4 & \textcolor{rtb-green}{GPIO7} & \raggedleft{7} & 8 & \textcolor{rtb-yellow}{TxD} & 14 & 15\\ \hline & & \textcolor{rtb-black}{0v} & \raggedleft{9} & 10 & \textcolor{rtb-yellow}{RxD} & 15 & 16\\ \hline 0 & 17 & \textcolor{rtb-green}{GPIO0} & \raggedleft{11} & 12 & \textcolor{rtb-green}{GPIO1} & 18 & 1\\ \hline 2 & Rv1:21 - Rv2:27 & \textcolor{rtb-green}{GPIO2} & \raggedleft{13} & 14 & \textcolor{rtb-black}{0v} & & \\ \hline 3 & 22 & \textcolor{rtb-green}{GPIO3} & \raggedleft{15} & 16 & \textcolor{rtb-green}{GPIO4} & 23 & 4\\ \hline & & \textcolor{rtb-red}{3.3v} & \raggedleft{17} & 18 & \textcolor{rtb-green}{GPIO5} & 24 & 5\\ \hline 12 & 10 & \textcolor{rtb-teal}{MOSI} & \raggedleft{19} & 20 & \textcolor{rtb-black}{0v} & & \\ \hline 13 & 9 & \textcolor{rtb-teal}{MISO} & \raggedleft{21} & 22 & \textcolor{rtb-green}{GPIO6} & 25 & 6\\ \hline 14 & 11 & \textcolor{rtb-teal}{SCLK} & \raggedleft{23} & 24 & \textcolor{rtb-teal}{CE0} & 8 & 10\\ \hline & & \textcolor{rtb-black}{0v} & \raggedleft{25} & 26 & \textcolor{rtb-teal}{CE1} & 7 & 11\\ \hline \hline WiringPi Pin & BCM GPIO & Name & \multicolumn{2}{|c||}{Header} & Name & BCM GPIO & WiringPi Pin\\ \hline \end{tabular} \end{center} Note the differences between Revision 1 and Revision 2 Raspberry Pi's. The Revision 2 is readily identifiable by the presence of the 2 mounting holes. The revision 2 Raspberry Pi has an additional GPIO connector, P5, which is next to the main P1 GPIO connector: \begin{center} \begin{tabular}{|c|c|c||p{8mm}|p{8mm}||c|c|c|c|} \hline \multicolumn{8}{|c|}{\bfseries{P5: Secondary GPIO connector (Rev. 2 Pi only)}}\\ \hline \hline WiringPi Pin & BCM GPIO & Name & \multicolumn{2}{|c||}{Header} & Name & BCM GPIO & WiringPi Pin\\ \hline \hline & & \textcolor{rtb-maroon}{5v} & \raggedleft{1} & 2 & \textcolor{rtb-red}{3.3v} & & \\ \hline 17 & 28 & \textcolor{rtb-green}{GPIO8} & \raggedleft{3} & 4 & \textcolor{rtb-green}{GPIO9} & 29 & 18 \\ \hline 19 & 30 & \textcolor{rtb-green}{GPIO10} & \raggedleft{5} & 6 & \textcolor{rtb-green}{GPIO11} & 31 & 20 \\ \hline & & \textcolor{rtb-black}{0v} & \raggedleft{7} & 8 & \textcolor{rtb-black}{0v} & & \\ \hline \hline WiringPi Pin & BCM GPIO & Name & \multicolumn{2}{|c||}{Header} & Name & BCM GPIO & WiringPi Pin\\ \hline \end{tabular} \end{center} \end{sffamily} \end{document} wiringpi-2.50/pins/Makefile0000664000175000017500000000037013442550153015333 0ustar ubuntuubuntu SRC = pins.tex ifneq ($V,1) Q ?= @ endif all: ${SRC} $Q echo Generating DVI $Q latex pins.tex pins.dvi: pins.tex $Q latex pins.tex pdf: pins.dvi $Q dvipdf pins.dvi .PHONY: clean clean: $Q rm -f *.dvi *.aux *.log *.ps *.toc *.bak *~ wiringpi-2.50/pins/pins.pdf0000664000175000017500000002315113442550153015341 0ustar ubuntuubuntu%PDF-1.4 %쏢 5 0 obj <> stream xŝ]ry~eOU<%AIlW"`cRC>-jW;YR;z%u?ӣ_Iܽ4^+փ:s՝1WoA)9?S]%5i?g gfGJ&9She6:C'}Hs:~>M<y'z䄃l]txd3/htȟI1Yl}./}~wpo^yߌuq,MỻCP:N^9Ô [^=S,'_rm,E2ɵ(XD`s$H<}rJE!Aoܬp9J-#ZX}o)ZI"2'{L0c;8U"no:MfT0>8Tj44)P@1՘gEL9j޸2_hxMfĖ]R>N6žKmu9Jt9j(eVڹ)^(b @'>fyy&;j9qr2Cw{{)f!r'`h@6[DLb3 tmЪlg5)a2([2+rt l,4ި1( jbo * RIA)}s #=UѢGtTӘ1MI/ {AW֋_])SYK"̍$Z_2+3$Y*E6I7 v //doxAf  ,- Ui^Qcx@dp&B]^ &Be: 44f/Ob xT.eKH<*=!f,Qͮ+עK4VBB!L Hs}:s|4'>L7/cӌ)-LƜP\\-w3k\eB!N !TBfJ8-dJض]-jm7O-GH5qF5';SM6SxT-7G=ш5UaױH݀E4bp_N6$"?-H@J"Q0un. }Q@Bn H[k8Px4:Iއ!;_!`2=Edz @ PV#0H[zk2J,iqF71(%h*Lyexǀ!!, ^LL,@qx\#4.,+ф}򓡾fmГO ' KX.eZ4`,XY9_2IBs4U\B,B $U*c\IEߜeb x1Z؋-=ݒHS~\tbzf~4zWcOi',- c#Oqk^ciPNh7[fu/Krr9f bJ3IDRlof%!~-,- ei[l&e-96T>r]Ҹ@lsIM7y1P'E-KN%(ϑ "DNnC2U~8Zk"I5>/ Y[! TRiN C6HԀ4h:BS|:*hE!gƅx&(y Bf]c Uғ{g}a3&(7Ζ;>*WƯ[?Md~0y<5G[7 g~WobskĖ$d;, __4',ŀc/W\pz થc 7Oa_1|짺ƨc?X^k_(`(Sh/Ig`0זEgc0l. Y~XHc 854HX.HF+gz bqvX4kŢH n~.Q]+q+7^XJ߷VCGRIgB ^.ɽl~,n$_ x1k7_XF\б5 Fpj<ѻ~g6{(F}G:{m]c6𩖎>&/4*B#mE)gq<[l[}ge@:Z!wAhy:&#YBlXfش 7ϴGSrQuvM+z̅ʦ!*?FV 2FoN?L8 SΜ qm[9z<>3/Y-@δ2qr_)N/ag!-Ҕ1UA~Yύ9rETZdQWmp*S Gɩr/+.yPl n I' z6uNJE_/W_9%/qe '4a.CkXYm4_9_x`5VwK3OIn`pB<$NL <LM(+!SvX]wXjZP,"r#pҽi>II9T7?Uެ40bYDܤ3P[tjDz -Y\m&$,Z?潛qtk傿P\ѪYhbr/b  Ӓ 4>w`(f."K|Шb ~۽z>V_'vK]:,zv yq('ZGnEy]_W rKCņ6dj.!=?7 Nf 0%xy'ONb+? n hB1g[H>eso>$|I) BePm 'B7$sC*EFj9RK/b[/&em,I ͽ3n3v e@=Eؑ"AilWu.AHISxTv2]9P-2=KGt5Sm];_JPSG%[gm e<Ύ$2\Й%jly:0t.A[@ŵk ߵ=%m3ܤmx5A)*'o&+rx1qċӓ$ū#jX-:9zQ4^}NjnI@tu?``"B886hHVǷ~r/ b 2 pcUmt6>MU1 b4-=^GvO54#_J)$8xxp):#Ômw4,s97$qQ"9ŋ3]8KQJy_vAUxy X,]fCMll ~zF:m}ҭY0nζ<ܻ> /Contents 5 0 R >> endobj 3 0 obj << /Type /Pages /Kids [ 4 0 R ] /Count 1 >> endobj 1 0 obj <> endobj 7 0 obj <>endobj 12 0 obj <> endobj 13 0 obj <> endobj 11 0 obj <> endobj 15 0 obj <> endobj 9 0 obj <> endobj 8 0 obj <> endobj 10 0 obj <> endobj 14 0 obj <>stream x{LSwWec7lF!@P̦Tā>R"]C^U Y$-tC|ĘlCMNߖeMr|\HA G>犳qvāmbZ @dtT6 QT !$dqL-U,^<_022ZA2FEj jV$2tަyOV5\mn2WXuVp9hc^&k8Ei3&3[32:փ `#HV`-Xf`0Rω9D9s%`@t,BAfnJI(K?TFǥirnXēp #`G.Ϧx3:{E G|_o;ʦѴG`ž>Mg6Myہ9-]哠T/(ѓnRO(xwbTiEltq/}]bŭ\9fl>|(e42xvu tT3Gjihl>nHY4$C:f&_#yHnG,7-NQDd!ocg; ]77lgAKX,!><:2&4,.1W"ns[=~y*%G9~Y2 2Y޶[xa,/}h+1m܂Yo~j 84>stream 2013-03-04T16:40:14Z 2013-03-04T16:40:14Z dvips()5.98 Copyright 2009 Radical Eye Software pins.dvi endstream endobj 2 0 obj <>endobj xref 0 17 0000000000 65535 f 0000005295 00000 n 0000009138 00000 n 0000005236 00000 n 0000005076 00000 n 0000000015 00000 n 0000005056 00000 n 0000005360 00000 n 0000005943 00000 n 0000005616 00000 n 0000006012 00000 n 0000005481 00000 n 0000005401 00000 n 0000005431 00000 n 0000006305 00000 n 0000005562 00000 n 0000007723 00000 n trailer << /Size 17 /Root 1 0 R /Info 2 0 R /ID [<6ECA4E15E91E2650FFA2CF17C0A2D4B8><6ECA4E15E91E2650FFA2CF17C0A2D4B8>] >> startxref 9340 %%EOF wiringpi-2.50/examples/0000775000175000017500000000000013442550153014540 5ustar ubuntuubuntuwiringpi-2.50/examples/ds1302.c0000664000175000017500000001302113442550153015615 0ustar ubuntuubuntu/* * ds1302.c: * Real Time clock * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include // Register defines #define RTC_SECS 0 #define RTC_MINS 1 #define RTC_HOURS 2 #define RTC_DATE 3 #define RTC_MONTH 4 #define RTC_DAY 5 #define RTC_YEAR 6 #define RTC_WP 7 #define RTC_TC 8 #define RTC_BM 31 static unsigned int masks [] = { 0x7F, 0x7F, 0x3F, 0x3F, 0x1F, 0x07, 0xFF } ; /* * bcdToD: dToBCD: * BCD decode/encode ********************************************************************************* */ static int bcdToD (unsigned int byte, unsigned int mask) { unsigned int b1, b2 ; byte &= mask ; b1 = byte & 0x0F ; b2 = ((byte >> 4) & 0x0F) * 10 ; return b1 + b2 ; } static unsigned int dToBcd (unsigned int byte) { return ((byte / 10) << 4) + (byte % 10) ; } /* * ramTest: * Simple test of the 31 bytes of RAM inside the DS1302 chip ********************************************************************************* */ static int ramTestValues [] = { 0x00, 0xFF, 0xAA, 0x55, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x00, 0xF0, 0x0F, -1 } ; static int ramTest (void) { int addr ; int got ; int i = 0 ; int errors = 0 ; int testVal ; printf ("DS1302 RAM TEST\n") ; testVal = ramTestValues [i] ; while (testVal != -1) { for (addr = 0 ; addr < 31 ; ++addr) ds1302ramWrite (addr, testVal) ; for (addr = 0 ; addr < 31 ; ++addr) if ((got = ds1302ramRead (addr)) != testVal) { printf ("DS1302 RAM Failure: Address: %2d, Expected: 0x%02X, Got: 0x%02X\n", addr, testVal, got) ; ++errors ; } testVal = ramTestValues [++i] ; } for (addr = 0 ; addr < 31 ; ++addr) ds1302ramWrite (addr, addr) ; for (addr = 0 ; addr < 31 ; ++addr) if ((got = ds1302ramRead (addr)) != addr) { printf ("DS1302 RAM Failure: Address: %2d, Expected: 0x%02X, Got: 0x%02X\n", addr, addr, got) ; ++errors ; } if (errors == 0) printf ("-- DS1302 RAM TEST: OK\n") ; else printf ("-- DS1302 RAM TEST FAILURE. %d errors.\n", errors) ; return 0 ; } /* * setLinuxClock: * Set the Linux clock from the hardware ********************************************************************************* */ static int setLinuxClock (void) { char dateTime [20] ; char command [64] ; int clock [8] ; printf ("Setting the Linux Clock from the DS1302... ") ; fflush (stdout) ; ds1302clockRead (clock) ; // [MMDDhhmm[[CC]YY][.ss]] sprintf (dateTime, "%02d%02d%02d%02d%02d%02d.%02d", bcdToD (clock [RTC_MONTH], masks [RTC_MONTH]), bcdToD (clock [RTC_DATE], masks [RTC_DATE]), bcdToD (clock [RTC_HOURS], masks [RTC_HOURS]), bcdToD (clock [RTC_MINS], masks [RTC_MINS]), 20, bcdToD (clock [RTC_YEAR], masks [RTC_YEAR]), bcdToD (clock [RTC_SECS], masks [RTC_SECS])) ; sprintf (command, "/bin/date %s", dateTime) ; system (command) ; return 0 ; } /* * setDSclock: * Set the DS1302 block from Linux time ********************************************************************************* */ static int setDSclock (void) { struct tm t ; time_t now ; int clock [8] ; printf ("Setting the clock in the DS1302 from Linux time... ") ; now = time (NULL) ; gmtime_r (&now, &t) ; clock [ 0] = dToBcd (t.tm_sec) ; // seconds clock [ 1] = dToBcd (t.tm_min) ; // mins clock [ 2] = dToBcd (t.tm_hour) ; // hours clock [ 3] = dToBcd (t.tm_mday) ; // date clock [ 4] = dToBcd (t.tm_mon + 1) ; // months 0-11 --> 1-12 clock [ 5] = dToBcd (t.tm_wday + 1) ; // weekdays (sun 0) clock [ 6] = dToBcd (t.tm_year - 100) ; // years clock [ 7] = 0 ; // W-Protect off ds1302clockWrite (clock) ; printf ("OK\n") ; return 0 ; } int main (int argc, char *argv []) { int i ; int clock [8] ; wiringPiSetup () ; ds1302setup (0, 1, 2) ; if (argc == 2) { /**/ if (strcmp (argv [1], "-slc") == 0) return setLinuxClock () ; else if (strcmp (argv [1], "-sdsc") == 0) return setDSclock () ; else if (strcmp (argv [1], "-rtest") == 0) return ramTest () ; else { printf ("Usage: ds1302 [-slc | -sdsc | -rtest]\n") ; return EXIT_FAILURE ; } } for (i = 0 ;; ++i) { printf ("%5d: ", i) ; ds1302clockRead (clock) ; printf (" %2d:%02d:%02d", bcdToD (clock [2], masks [2]), bcdToD (clock [1], masks [1]), bcdToD (clock [0], masks [0])) ; printf (" %2d/%02d/%04d", bcdToD (clock [3], masks [3]), bcdToD (clock [4], masks [4]), bcdToD (clock [6], masks [6]) + 2000) ; printf ("\n") ; delay (200) ; } return 0 ; } wiringpi-2.50/examples/blink-thread.c0000664000175000017500000000306613442550153017255 0ustar ubuntuubuntu/* * blink-thread.c: * Standard "blink" program in wiringPi. Blinks an LED connected * to the first GPIO pin. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include // LED Pin - wiringPi pin 0 is BCM_GPIO 17. #define LED 0 PI_THREAD (blinky) { for (;;) { digitalWrite (LED, HIGH) ; // On delay (500) ; // mS digitalWrite (LED, LOW) ; // Off delay (500) ; } } int main (void) { printf ("Raspberry Pi blink\n") ; wiringPiSetup () ; pinMode (LED, OUTPUT) ; piThreadCreate (blinky) ; for (;;) { printf ("Hello, world\n") ; delay (600) ; } return 0 ; } wiringpi-2.50/examples/blink12.c0000664000175000017500000000507613442550153016156 0ustar ubuntuubuntu/* * blink12.c: * Simple sequence over the first 12 GPIO pins - LEDs * Aimed at the Gertboard, but it's fairly generic. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include // Simple sequencer data // Triplets of LED, On/Off and delay int data [] = { 0, 1, 1, 1, 1, 1, 0, 0, 0, 2, 1, 1, 1, 0, 0, 3, 1, 1, 2, 0, 0, 4, 1, 1, 3, 0, 0, 5, 1, 1, 4, 0, 0, 6, 1, 1, 5, 0, 0, 7, 1, 1, 6, 0, 0, 11, 1, 1, 7, 0, 0, 10, 1, 1, 11, 0, 0, 13, 1, 1, 10, 0, 0, 12, 1, 1, 13, 0, 1, 12, 0, 1, 0, 0, 1, // Extra delay // Back again 12, 1, 1, 13, 1, 1, 12, 0, 0, 10, 1, 1, 13, 0, 0, 11, 1, 1, 10, 0, 0, 7, 1, 1, 11, 0, 0, 6, 1, 1, 7, 0, 0, 5, 1, 1, 6, 0, 0, 4, 1, 1, 5, 0, 0, 3, 1, 1, 4, 0, 0, 2, 1, 1, 3, 0, 0, 1, 1, 1, 2, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, // Extra delay 0, 9, 0, // End marker } ; int main (void) { int pin ; int dataPtr ; int l, s, d ; printf ("Raspberry Pi - 12-LED Sequence\n") ; printf ("==============================\n") ; printf ("\n") ; printf ("Connect LEDs up to the first 8 GPIO pins, then pins 11, 10, 13, 12 in\n") ; printf (" that order, then sit back and watch the show!\n") ; wiringPiSetup () ; for (pin = 0 ; pin < 14 ; ++pin) pinMode (pin, OUTPUT) ; dataPtr = 0 ; for (;;) { l = data [dataPtr++] ; // LED s = data [dataPtr++] ; // State d = data [dataPtr++] ; // Duration (10ths) if (s == 9) // 9 -> End Marker { dataPtr = 0 ; continue ; } digitalWrite (l, s) ; delay (d * 100) ; } return 0 ; } wiringpi-2.50/examples/blink.sh0000775000175000017500000000233513442550153016201 0ustar ubuntuubuntu#!/bin/sh -e # # blink.sh: # Standard "blink" program in wiringPi. Blinks an LED connected # to the first GPIO pin. # # Copyright (c) 2012-2013 Gordon Henderson. ####################################################################### # This file is part of wiringPi: # https://projects.drogon.net/raspberry-pi/wiringpi/ # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ####################################################################### # LED Pin - wiringPi pin 0 is BCM_GPIO 17. PIN=0 gpio mode $PIN out while true; do gpio write $PIN 1 sleep 0.5 gpio write $PIN 0 sleep 0.5 done wiringpi-2.50/examples/rht03.c0000664000175000017500000000423613442550153015651 0ustar ubuntuubuntu/* * rht03.c: * Driver for the MaxDetect series sensors * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #define RHT03_PIN 7 /* *********************************************************************** * The main program *********************************************************************** */ int main (void) { int result, temp, rh ; int minT, maxT, minRH, maxRH ; int numGood, numBad ; wiringPiSetup () ; piHiPri (55) ; minT = 1000 ; maxT = -1000 ; minRH = 1000 ; maxRH = -1000 ; numGood = numBad = 0 ; for (;;) { delay (100) ; result = readRHT03 (RHT03_PIN, &temp, &rh) ; if (!result) { printf (".") ; fflush (stdout) ; ++numBad ; continue ; } ++numGood ; if (temp < minT) minT = temp ; if (temp > maxT) maxT = temp ; if (rh < minRH) minRH = rh ; if (rh > maxRH) maxRH = rh ; printf ("\r%6d, %6d: ", numGood, numBad) ; printf ("Temp: %5.1f, RH: %5.1f%%", temp / 10.0, rh / 10.0) ; printf (" Max/Min Temp: %5.1f:%5.1f", maxT / 10.0, minT / 10.0) ; printf (" Max/Min RH: %5.1f:%5.1f", maxRH / 10.0, minRH / 10.0) ; printf ("\n") ; } return 0 ; } wiringpi-2.50/examples/Makefile0000664000175000017500000000755613442550153016215 0ustar ubuntuubuntu# # Makefile: # wiringPi - A "wiring" library for the Raspberry Pi # https://projects.drogon.net/wiring-pi # # Copyright (c) 2012-2015 Gordon Henderson ################################################################################# # This file is part of wiringPi: # Wiring Compatable library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# ifneq ($V,1) Q ?= @ endif #DEBUG = -g -O0 DEBUG = -O3 INCLUDE = -I/usr/local/include CFLAGS = $(DEBUG) -Wall $(INCLUDE) -Winline -pipe LDFLAGS = -L/usr/local/lib LDLIBS = -lwiringPi -lwiringPiDev -lpthread -lm -lcrypt -lrt # Should not alter anything below this line ############################################################################### SRC = blink.c blink8.c blink12.c \ blink12drcs.c \ pwm.c \ speed.c wfi.c isr.c isr-osc.c \ lcd.c lcd-adafruit.c clock.c \ nes.c \ softPwm.c softTone.c \ delayTest.c serialRead.c serialTest.c okLed.c ds1302.c \ lowPower.c \ max31855.c \ rht03.c OBJ = $(SRC:.c=.o) BINS = $(SRC:.c=) all: $Q cat README.TXT $Q echo " $(BINS)" | fmt $Q echo "" really-all: $(BINS) blink: blink.o $Q echo [link] $Q $(CC) -o $@ blink.o $(LDFLAGS) $(LDLIBS) blink8: blink8.o $Q echo [link] $Q $(CC) -o $@ blink8.o $(LDFLAGS) $(LDLIBS) blink12drcs: blink12drcs.o $Q echo [link] $Q $(CC) -o $@ blink12drcs.o $(LDFLAGS) $(LDLIBS) blink12: blink12.o $Q echo [link] $Q $(CC) -o $@ blink12.o $(LDFLAGS) $(LDLIBS) speed: speed.o $Q echo [link] $Q $(CC) -o $@ speed.o $(LDFLAGS) $(LDLIBS) lcd: lcd.o $Q echo [link] $Q $(CC) -o $@ lcd.o $(LDFLAGS) $(LDLIBS) lcd-adafruit: lcd-adafruit.o $Q echo [link] $Q $(CC) -o $@ lcd-adafruit.o $(LDFLAGS) $(LDLIBS) clock: clock.o $Q echo [link] $Q $(CC) -o $@ clock.o $(LDFLAGS) $(LDLIBS) wfi: wfi.o $Q echo [link] $Q $(CC) -o $@ wfi.o $(LDFLAGS) $(LDLIBS) isr: isr.o $Q echo [link] $Q $(CC) -o $@ isr.o $(LDFLAGS) $(LDLIBS) isr-osc: isr-osc.o $Q echo [link] $Q $(CC) -o $@ isr-osc.o $(LDFLAGS) $(LDLIBS) nes: nes.o $Q echo [link] $Q $(CC) -o $@ nes.o $(LDFLAGS) $(LDLIBS) rht03: rht03.o $Q echo [link] $Q $(CC) -o $@ rht03.o $(LDFLAGS) $(LDLIBS) pwm: pwm.o $Q echo [link] $Q $(CC) -o $@ pwm.o $(LDFLAGS) $(LDLIBS) softPwm: softPwm.o $Q echo [link] $Q $(CC) -o $@ softPwm.o $(LDFLAGS) $(LDLIBS) softTone: softTone.o $Q echo [link] $Q $(CC) -o $@ softTone.o $(LDFLAGS) $(LDLIBS) delayTest: delayTest.o $Q echo [link] $Q $(CC) -o $@ delayTest.o $(LDFLAGS) $(LDLIBS) serialRead: serialRead.o $Q echo [link] $Q $(CC) -o $@ serialRead.o $(LDFLAGS) $(LDLIBS) serialTest: serialTest.o $Q echo [link] $Q $(CC) -o $@ serialTest.o $(LDFLAGS) $(LDLIBS) okLed: okLed.o $Q echo [link] $Q $(CC) -o $@ okLed.o $(LDFLAGS) $(LDLIBS) tone: tone.o $Q echo [link] $Q $(CC) -o $@ tone.o $(LDFLAGS) $(LDLIBS) ds1302: ds1302.o $Q echo [link] $Q $(CC) -o $@ ds1302.o $(LDFLAGS) $(LDLIBS) max31855: max31855.o $Q echo [link] $Q $(CC) -o $@ max31855.o $(LDFLAGS) $(LDLIBS) .c.o: $Q echo [CC] $< $Q $(CC) -c $(CFLAGS) $< -o $@ clean: $Q echo "[Clean]" $Q rm -f $(OBJ) *~ core tags $(BINS) tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) depend: makedepend -Y $(SRC) # DO NOT DELETE wiringpi-2.50/examples/isr-osc.c0000664000175000017500000000633113442550153016266 0ustar ubuntuubuntu/* * isr-osc.c: * Wait for Interrupt test program - ISR method - interrupt oscillator * * How to test: * * IMPORTANT: To run this test we connect 2 GPIO pins together, but * before we do that YOU must make sure that they are both setup * the right way. If they are set to outputs and one is high and one low, * then you connect the wire, you'll create a short and that won't be good. * * Before making the connection, type: * gpio mode 0 output * gpio write 0 0 * gpio mode 1 input * then you can connect them together. * * Run the program, then: * gpio write 0 1 * gpio write 0 0 * * at which point it will trigger an interrupt and the program will * then do the up/down toggling for itself and run at full speed, and * it will report the number of interrupts recieved every second. * * Copyright (c) 2013 Gordon Henderson. projects@drogon.net *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include // What GPIO input are we using? // This is a wiringPi pin number #define OUT_PIN 0 #define IN_PIN 1 // globalCounter: // Global variable to count interrupts // Should be declared volatile to make sure the compiler doesn't cache it. static volatile int globalCounter = 0 ; /* * myInterrupt: ********************************************************************************* */ void myInterrupt (void) { digitalWrite (OUT_PIN, 1) ; ++globalCounter ; digitalWrite (OUT_PIN, 0) ; } /* ********************************************************************************* * main ********************************************************************************* */ int main (void) { int myCounter = 0 ; int lastCounter = 0 ; if (wiringPiSetup () < 0) { fprintf (stderr, "Unable to setup wiringPi: %s\n", strerror (errno)) ; return 1 ; } pinMode (OUT_PIN, OUTPUT) ; pinMode (IN_PIN, INPUT) ; if (wiringPiISR (IN_PIN, INT_EDGE_FALLING, &myInterrupt) < 0) { fprintf (stderr, "Unable to setup ISR: %s\n", strerror (errno)) ; return 1 ; } for (;;) { printf ("Waiting ... ") ; fflush (stdout) ; while (myCounter == globalCounter) delay (1000) ; printf (" Done. counter: %6d: %6d\n", globalCounter, myCounter - lastCounter) ; lastCounter = myCounter ; myCounter = globalCounter ; } return 0 ; } wiringpi-2.50/examples/blink.c0000664000175000017500000000266313442550153016012 0ustar ubuntuubuntu/* * blink.c: * Standard "blink" program in wiringPi. Blinks an LED connected * to the first GPIO pin. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include // LED Pin - wiringPi pin 0 is BCM_GPIO 17. #define LED 0 int main (void) { printf ("Raspberry Pi blink\n") ; wiringPiSetup () ; pinMode (LED, OUTPUT) ; for (;;) { digitalWrite (LED, HIGH) ; // On delay (500) ; // mS digitalWrite (LED, LOW) ; // Off delay (500) ; } return 0 ; } wiringpi-2.50/examples/wfi.c0000664000175000017500000000726213442550153015500 0ustar ubuntuubuntu/* * wfi.c: * Wait for Interrupt test program * * This program demonstrates the use of the waitForInterrupt() * function in wiringPi. It listens to a button input on * BCM_GPIO pin 17 (wiringPi pin 0) * * The biggest issue with this method is that it really only works * well in Sys mode. * * Jan 2013: This way of doing things is sort of deprecated now, see * the wiringPiISR() function instead and the isr.c test program here. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include // A 'key' which we can lock and unlock - values are 0 through 3 // This is interpreted internally as a pthread_mutex by wiringPi // which is hiding some of that to make life simple. #define COUNT_KEY 0 // What BCM_GPIO input are we using? #define BUTTON_PIN 17 // Debounce time in mS #define DEBOUNCE_TIME 100 // globalCounter: // Global variable to count interrupts // Should be declared volatile to make sure the compiler doesn't cache it. static volatile int globalCounter = 0 ; /* * waitForIt: * This is a thread created using the wiringPi simplified threading * mechanism. It will wait on an interrupt on the button and increment * a counter. ********************************************************************************* */ PI_THREAD (waitForIt) { int state = 0 ; int debounceTime = 0 ; (void)piHiPri (10) ; // Set this thread to be high priority for (;;) { if (waitForInterrupt (BUTTON_PIN, -1) > 0) // Got it { // Bouncing? if (millis () < debounceTime) { debounceTime = millis () + DEBOUNCE_TIME ; continue ; } // We have a valid one state ^= 1 ; piLock (COUNT_KEY) ; ++globalCounter ; piUnlock (COUNT_KEY) ; // Wait for key to be released while (digitalRead (BUTTON_PIN) == LOW) delay (1) ; debounceTime = millis () + DEBOUNCE_TIME ; } } } /* * setup: * Demo a crude but effective way to initialise the hardware ********************************************************************************* */ void setup (void) { // Use the gpio program to initialise the hardware // (This is the crude, but effective) system ("gpio edge 17 falling") ; // Setup wiringPi wiringPiSetupSys () ; // Fire off our interrupt handler piThreadCreate (waitForIt) ; } /* * main ********************************************************************************* */ int main (void) { int lastCounter = 0 ; int myCounter = 0 ; setup () ; for (;;) { printf ("Waiting ... ") ; fflush (stdout) ; while (myCounter == lastCounter) { piLock (COUNT_KEY) ; myCounter = globalCounter ; piUnlock (COUNT_KEY) ; delay (500) ; } printf (" Done. myCounter: %5d\n", myCounter) ; lastCounter = myCounter ; } return 0 ; } wiringpi-2.50/examples/PiFace/0000775000175000017500000000000013442550153015667 5ustar ubuntuubuntuwiringpi-2.50/examples/PiFace/motor.c0000664000175000017500000000616613442550153017204 0ustar ubuntuubuntu/* * motor.c: * Use the PiFace board to demonstrate an H bridge * circuit via the 2 relays. * Then add on an external transsitor to help with PWM. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include int outputs [2] = { 0,0 } ; #define PIFACE_BASE 200 #define PWM_OUT_PIN 204 #define PWM_UP 202 #define PWM_DOWN 203 void scanButton (int button) { if (digitalRead (PIFACE_BASE + button) == LOW) { outputs [button] ^= 1 ; digitalWrite (PIFACE_BASE + button, outputs [button]) ; printf ("Button %d pushed - output now: %s\n", button, (outputs [button] == 0) ? "Off" : "On") ; } while (digitalRead (PIFACE_BASE + button) == LOW) delay (1) ; } int main (void) { int pin, button ; int pwmValue = 0 ; printf ("Raspberry Pi PiFace - Motor control\n") ; printf ("==================================\n") ; printf ("\n") ; printf ( "This program is designed to be used with a motor connected to the relays\n" "in an H-Bridge type configuration with optional speeed control via PWM.\n" "\n" "Use the leftmost buttons to turn each relay on and off, and the rigthmost\n" "buttons to increase ot decrease the PWM output on the control pin (pin\n" "4)\n\n") ; wiringPiSetup () ; piFaceSetup (PIFACE_BASE) ; softPwmCreate (PWM_OUT_PIN, 100, 100) ; // Enable internal pull-ups & start with all off for (pin = 0 ; pin < 8 ; ++pin) { pullUpDnControl (PIFACE_BASE + pin, PUD_UP) ; digitalWrite (PIFACE_BASE + pin, 0) ; } for (;;) { for (button = 0 ; button < 2 ; ++button) scanButton (button) ; if (digitalRead (PWM_UP) == LOW) { pwmValue += 10 ; if (pwmValue > 100) pwmValue = 100 ; softPwmWrite (PWM_OUT_PIN, pwmValue) ; printf ("PWM -> %3d\n", pwmValue) ; while (digitalRead (PWM_UP) == LOW) delay (5) ; } if (digitalRead (PWM_DOWN) == LOW) { pwmValue -= 10 ; if (pwmValue < 0) pwmValue = 0 ; softPwmWrite (PWM_OUT_PIN, pwmValue) ; printf ("PWM -> %3d\n", pwmValue) ; while (digitalRead (PWM_DOWN) == LOW) delay (5) ; } delay (5) ; } return 0 ; } wiringpi-2.50/examples/PiFace/Makefile0000664000175000017500000000425613442550153017336 0ustar ubuntuubuntu# # Makefile: # wiringPi - A "wiring" library for the Raspberry Pi # https://projects.drogon.net/wiring-pi # # Copyright (c) 2012 Gordon Henderson ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# ifneq ($V,1) Q ?= @ endif #DEBUG = -g -O0 DEBUG = -O3 CC = gcc INCLUDE = -I/usr/local/include CFLAGS = $(DEBUG) -Wall $(INCLUDE) -Winline -pipe LDFLAGS = -L/usr/local/lib LDLIBS = -lwiringPi -lwiringPiDev -lpthread -lm # Should not alter anything below this line ############################################################################### SRC = blink.c buttons.c reaction.c ladder.c metro.c motor.c OBJ = $(SRC:.c=.o) BINS = $(SRC:.c=) all: $(BINS) blink: blink.o $Q echo [link] $Q $(CC) -o $@ blink.o $(LDFLAGS) $(LDLIBS) buttons: buttons.o $Q echo [link] $Q $(CC) -o $@ buttons.o $(LDFLAGS) $(LDLIBS) reaction: reaction.o $Q echo [link] $Q $(CC) -o $@ reaction.o $(LDFLAGS) $(LDLIBS) ladder: ladder.o $Q echo [link] $Q $(CC) -o $@ ladder.o $(LDFLAGS) $(LDLIBS) metro: metro.o $Q echo [link] $Q $(CC) -o $@ metro.o $(LDFLAGS) $(LDLIBS) motor: motor.o $Q echo [link] $Q $(CC) -o $@ motor.o $(LDFLAGS) $(LDLIBS) .c.o: $Q echo [CC] $< $Q $(CC) -c $(CFLAGS) $< -o $@ clean: $Q echo "[Clean]" $Q rm -f $(OBJ) *~ core tags $(BINS) tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) depend: makedepend -Y $(SRC) # DO NOT DELETE wiringpi-2.50/examples/PiFace/blink.c0000664000175000017500000000330713442550153017135 0ustar ubuntuubuntu/* * blink.c: * Simple "blink" test for the PiFace interface board. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include // Use 200 as the pin-base for the PiFace board, and pick a pin // for the LED that's not connected to a relay #define PIFACE 200 #define LED (PIFACE+2) int main (int argc, char *argv []) { printf ("Raspberry Pi PiFace Blink\n") ; printf ("=========================\n") ; // Always initialise wiringPi. Use wiringPiSys() if you don't need // (or want) to run as root wiringPiSetupSys () ; // Setup the PiFace board piFaceSetup (PIFACE) ; for (;;) { digitalWrite (LED, HIGH) ; // On delay (500) ; // mS digitalWrite (LED, LOW) ; // Off delay (500) ; } return 0 ; } wiringpi-2.50/examples/PiFace/metro.c0000664000175000017500000000516713442550153017172 0ustar ubuntuubuntu/* * metronome.c: * Simple test for the PiFace interface board. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #define PIFACE 200 /* * middleA: * Play middle A (on the relays - yea!) ********************************************************************************* */ static void middleA (void) { unsigned int next ; for (;;) { next = micros () + 1136 ; digitalWrite (PIFACE + 0, 0) ; digitalWrite (PIFACE + 1, 0) ; while (micros () < next) delayMicroseconds (1) ; next = micros () + 1137 ; digitalWrite (PIFACE + 0, 1) ; digitalWrite (PIFACE + 1, 1) ; while (micros () < next) delayMicroseconds (1) ; } } int main (int argc, char *argv []) { int bpm, msPerBeat, state = 0 ; unsigned int end ; printf ("Raspberry Pi PiFace Metronome\n") ; printf ("=============================\n") ; piHiPri (50) ; wiringPiSetupSys () ; // Needed for timing functions piFaceSetup (PIFACE) ; if (argc != 2) { printf ("Usage: %s \n", argv [0]) ; exit (1) ; } if (strcmp (argv [1], "a") == 0) middleA () ; bpm = atoi (argv [1]) ; if ((bpm < 40) || (bpm > 208)) { printf ("%s range is 40 through 208 beats per minute\n", argv [0]) ; exit (1) ; } msPerBeat = 60000 / bpm ; // Main loop: // Put some random LED pairs up for a few seconds, then blank ... for (;;) { end = millis () + msPerBeat ; digitalWrite (PIFACE + 0, state) ; digitalWrite (PIFACE + 1, state) ; while (millis () < end) delayMicroseconds (500) ; state ^= 1 ; } return 0 ; } wiringpi-2.50/examples/PiFace/reaction.c0000664000175000017500000000773113442550153017647 0ustar ubuntuubuntu/* * reaction.c: * Simple test for the PiFace interface board. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include int outputs [4] = { 0,0,0,0 } ; #define PIFACE 200 /* * light: * Light up the given LED - actually lights up a pair ********************************************************************************* */ void light (int led, int value) { led *= 2 ; digitalWrite (PIFACE + led + 0, value) ; digitalWrite (PIFACE + led + 1, value) ; } /* * lightAll: * All On or Off ********************************************************************************* */ void lightAll (int onoff) { light (0, onoff) ; light (1, onoff) ; light (2, onoff) ; light (3, onoff) ; } /* * waitForNoButtons: * Wait for all buttons to be released ********************************************************************************* */ void waitForNoButtons (void) { int i, button ; for (;;) { button = 0 ; for (i = 0 ; i < 4 ; ++i) button += digitalRead (PIFACE + i) ; if (button == 4) break ; } } void scanButton (int button) { if (digitalRead (PIFACE + button) == LOW) { outputs [button] ^= 1 ; digitalWrite (PIFACE + button, outputs [button]) ; } while (digitalRead (PIFACE + button) == LOW) delay (1) ; } int main (void) { int i, j ; int led, button ; unsigned int start, stop ; printf ("Raspberry Pi PiFace Reaction Timer\n") ; printf ("==================================\n") ; if (piFaceSetup (PIFACE) == -1) exit (1) ; // Enable internal pull-ups for (i = 0 ; i < 8 ; ++i) pullUpDnControl (PIFACE + i, PUD_UP) ; // Main game loop: // Put some random LED pairs up for a few seconds, then blank ... for (;;) { printf ("Press any button to start ... \n") ; fflush (stdout) ; for (;;) { led = rand () % 4 ; light (led, 1) ; delay (10) ; light (led, 0) ; button = 0 ; for (j = 0 ; j < 4 ; ++j) button += digitalRead (PIFACE + j) ; if (button != 4) break ; } waitForNoButtons () ; printf ("Wait for it ... ") ; fflush (stdout) ; led = rand () % 4 ; delay (rand () % 500 + 1000) ; light (led, 1) ; start = millis () ; for (button = -1 ; button == -1 ; ) { for (j = 0 ; j < 4 ; ++j) if (digitalRead (PIFACE + j) == 0) // Pushed { button = j ; break ; } } stop = millis () ; button = 3 - button ; // Correct for the buttons/LEDs reversed light (led, 0) ; waitForNoButtons () ; light (led, 1) ; if (button == led) { printf ("You got it in %3d mS\n", stop - start) ; } else { printf ("Missed: You pushed %d - LED was %d\n", button, led) ; for (;;) { light (button, 1) ; delay (100) ; light (button, 0) ; delay (100) ; i = 0 ; for (j = 0 ; j < 4 ; ++j) i += digitalRead (PIFACE + j) ; if (i != 4) break ; } waitForNoButtons () ; } light (led, 0) ; delay (4000) ; } return 0 ; } wiringpi-2.50/examples/PiFace/ladder.c0000775000175000017500000001431613442550153017276 0ustar ubuntuubuntu/* * ladder.c: * * Gordon Henderson, June 2012 *********************************************************************** */ #include #include #include #include #include #include #ifndef TRUE # define TRUE (1==1) # define FALSE (1==2) #endif #undef DEBUG #define NUM_LEDS 8 // Map the LEDs to the hardware pins // using PiFace pin numbers here #define PIFACE 200 const int ledMap [NUM_LEDS] = { // 0, 1, 2, 3, 4, 5, 6, 7, 8 200, 201, 202, 203, 204, 205, 206, 207 } ; // Some constants for our circuit simulation const double vBatt = 9.0 ; // Volts (ie. a PP3) const double capacitor = 0.001 ; // 1000uF const double rCharge = 2200.0 ; // ohms const double rDischarge = 68000.0 ; // ohms const double timeInc = 0.01 ; // Seconds double vCharge, vCap, vCapLast ; /* * setup: * Program the GPIO correctly and initialise the lamps *********************************************************************** */ void setup (void) { int i ; wiringPiSetupSys () ; if (piFaceSetup (200) == -1) exit (1) ; // Enable internal pull-ups for (i = 0 ; i < 8 ; ++i) pullUpDnControl (PIFACE + i, PUD_UP) ; // Calculate the actual charging voltage - standard calculation of // vCharge = r2 / (r1 + r2) * vBatt // // // -----+--- vBatt // | // R1 // | // +---+---- vCharge // | | // R2 C // | | // -----+---+----- vCharge = rDischarge / (rCharge + rDischarge) * vBatt ; // Start with no charge vCap = vCapLast = 0.0 ; } /* * introLeds * Put a little pattern on the LEDs to start with ********************************************************************************* */ void introLeds (void) { int i, j ; printf ("Pi Ladder\n") ; printf ("=========\n\n") ; printf (" vBatt: %6.2f volts\n", vBatt) ; printf (" rCharge: %6.0f ohms\n", rCharge) ; printf (" rDischarge: %6.0f ohms\n", rDischarge) ; printf (" vCharge: %6.2f volts\n", vCharge) ; printf (" capacitor: %6.0f uF\n", capacitor * 1000.0) ; // Flash 3 times: for (j = 0 ; j < 3 ; ++j) { for (i = 0 ; i < NUM_LEDS ; ++i) digitalWrite (ledMap [i], 1) ; delay (500) ; for (i = 0 ; i < NUM_LEDS ; ++i) digitalWrite (ledMap [i], 0) ; delay (100) ; } // All On for (i = 0 ; i < NUM_LEDS ; ++i) digitalWrite (ledMap [i], 1) ; delay (500) ; // Countdown... for (i = NUM_LEDS - 1 ; i >= 0 ; --i) { digitalWrite (ledMap [i], 0) ; delay (100) ; } delay (500) ; } /* * winningLeds * Put a little pattern on the LEDs to start with ********************************************************************************* */ void winningLeds (void) { int i, j ; // Flash 3 times: for (j = 0 ; j < 3 ; ++j) { for (i = 0 ; i < NUM_LEDS ; ++i) digitalWrite (ledMap [i], 1) ; delay (500) ; for (i = 0 ; i < NUM_LEDS ; ++i) digitalWrite (ledMap [i], 0) ; delay (100) ; } // All On for (i = 0 ; i < NUM_LEDS ; ++i) digitalWrite (ledMap [i], 1) ; delay (500) ; // Countup... for (i = 0 ; i < NUM_LEDS ; ++i) { digitalWrite (ledMap [i], 0) ; delay (100) ; } delay (500) ; } /* * chargeCapacitor: dischargeCapacitor: * Add or remove charge to the capacitor. * Standard capacitor formulae. ********************************************************************************* */ void chargeCapacitor (void) { vCap = (vCapLast - vCharge) * exp (- timeInc / (rCharge * capacitor)) + vCharge ; #ifdef DEBUG printf ("+vCap: %7.4f\n", vCap) ; #endif vCapLast = vCap ; } void dischargeCapacitor (void) { vCap = vCapLast * exp (- timeInc / (rDischarge * capacitor)) ; #ifdef DEBUG printf ("-vCap: %7.4f\n", vCap) ; #endif vCapLast = vCap ; } /* * ledBargraph: * Output the supplied number as a bargraph on the LEDs ********************************************************************************* */ void ledBargraph (double value, int topLedOn) { int topLed = (int)floor (value / vCharge * (double)NUM_LEDS) + 1 ; int i ; if (topLed > NUM_LEDS) topLed = NUM_LEDS ; if (!topLedOn) --topLed ; for (i = 0 ; i < topLed ; ++i) digitalWrite (ledMap [i], 1) ; for (i = topLed ; i < NUM_LEDS ; ++i) digitalWrite (ledMap [i], 0) ; } /* * ledOnAction: * Make sure the leading LED is on and check the button ********************************************************************************* */ void ledOnAction (void) { if (digitalRead (PIFACE) == LOW) { chargeCapacitor () ; ledBargraph (vCap, TRUE) ; } } /* * ledOffAction: * Make sure the leading LED is off and check the button ********************************************************************************* */ void ledOffAction (void) { dischargeCapacitor () ; // Are we still pushing the button? if (digitalRead (PIFACE) == LOW) { vCap = vCapLast = 0.0 ; ledBargraph (vCap, FALSE) ; // Wait until we release the button while (digitalRead (PIFACE) == LOW) delay (10) ; } } /* *********************************************************************** * The main program *********************************************************************** */ int main (void) { unsigned int then, ledOnTime, ledOffTime ; unsigned int ourDelay = (int)(1000.0 * timeInc) ; setup () ; introLeds () ; // Setup the LED times - TODO reduce the ON time as the game progresses ledOnTime = 1000 ; ledOffTime = 1000 ; // This is our Gate/Squarewave loop for (;;) { // LED ON: (void)ledBargraph (vCap, TRUE) ; then = millis () + ledOnTime ; while (millis () < then) { ledOnAction () ; delay (ourDelay) ; } // Have we won yet? // We need vCap to be in the top NUM_LEDS of the vCharge if (vCap > ((double)(NUM_LEDS - 1) / (double)NUM_LEDS * vCharge)) // Woo hoo! { winningLeds () ; while (digitalRead (PIFACE) == HIGH) delay (10) ; while (digitalRead (PIFACE) == LOW) delay (10) ; vCap = vCapLast = 0.0 ; } // LED OFF: (void)ledBargraph (vCap, FALSE) ; then = millis () + ledOffTime ; while (millis () < then) { ledOffAction () ; delay (ourDelay) ; } } return 0 ; } wiringpi-2.50/examples/PiFace/buttons.c0000664000175000017500000000537313442550153017541 0ustar ubuntuubuntu/* * buttons.c: * Simple test for the PiFace interface board. * * Read the buttons and output the same to the LEDs * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include int outputs [4] = { 0,0,0,0 } ; // Use 200 as the pin-base for the PiFace board #define PIFACE_BASE 200 /* * scanButton: * Read the guiven button - if it's pressed, then flip the state * of the correspoinding output pin ********************************************************************************* */ void scanButton (int button) { if (digitalRead (PIFACE_BASE + button) == LOW) { outputs [button] ^= 1 ; digitalWrite (PIFACE_BASE + button, outputs [button]) ; printf ("Button %d pushed - output now: %s\n", button, (outputs [button] == 0) ? "Off" : "On") ; } while (digitalRead (PIFACE_BASE + button) == LOW) delay (1) ; } /* * start here ********************************************************************************* */ int main (void) { int pin, button ; printf ("Raspberry Pi wiringPi + PiFace test program\n") ; printf ("===========================================\n") ; printf ("\n") ; printf ( "This program reads the buttons and uses them to toggle the first 4\n" "outputs. Push a button once to turn an output on, and push it again to\n" "turn it off again.\n\n") ; // Always initialise wiringPi. Use wiringPiSys() if you don't need // (or want) to run as root wiringPiSetupSys () ; piFaceSetup (PIFACE_BASE) ; // Enable internal pull-ups & start with all off for (pin = 0 ; pin < 8 ; ++pin) { pullUpDnControl (PIFACE_BASE + pin, PUD_UP) ; digitalWrite (PIFACE_BASE + pin, 0) ; } // Loop, scanning the buttons for (;;) { for (button = 0 ; button < 4 ; ++button) scanButton (button) ; delay (5) ; } return 0 ; } wiringpi-2.50/examples/okLed.c0000664000175000017500000000420513442550153015743 0ustar ubuntuubuntu/* * okLed.c: * Make the OK LED on the Pi Pulsate... * * Originally posted to the Raspberry Pi forums: * http://www.raspberrypi.org/phpBB3/viewtopic.php?p=162581#p162581 * * Compile this and store it somewhere, then kick it off at boot time * e.g. by putting it in /etc/rc.local and running it in the * background & * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include // The OK/Act LED is connected to BCM_GPIO pin 16 #define OK_LED 16 int main () { int fd, i ; wiringPiSetupGpio () ; // Change the trigger on the OK/Act LED to "none" if ((fd = open ("/sys/class/leds/led0/trigger", O_RDWR)) < 0) { fprintf (stderr, "Unable to change LED trigger: %s\n", strerror (errno)) ; return 1 ; } write (fd, "none\n", 5) ; close (fd) ; softPwmCreate (OK_LED, 0, 100) ; for (;;) { for (i = 0 ; i <= 100 ; ++i) { softPwmWrite (OK_LED, i) ; delay (10) ; } delay (50) ; for (i = 100 ; i >= 0 ; --i) { softPwmWrite (OK_LED, i) ; delay (10) ; } delay (10) ; } return 0 ; } wiringpi-2.50/examples/clock.c0000664000175000017500000001167113442550153016005 0ustar ubuntuubuntu/* * clock.c: * Demo of the 128x64 graphics based LCD driver. * This is designed to drive the parallel interface LCD drivers * based on the popular 12864H controller chip. * * This test program assumes the following: * (Which is currently hard-wired into the driver) * * GPIO 0-7 is connected to display data pins 0-7. * GPIO 10 is CS1 * GPIO 11 is CS2 * GPIO 12 is STROBE * GPIO 10 is RS * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include #ifndef TRUE # define TRUE (1==1) # define FALSE (1==2) #endif double clockRadius ; double thickness, barLen ; int maxX, maxY ; double rads (double degs) { return degs * M_PI / 180.0 ; } void drawClockHands (void) { time_t t ; struct tm *now ; double angle, p, x0, y0, x1, y1 ; int h24, h, m, s ; char text [20] ; time (&t) ; now = localtime (&t) ; h24 = now->tm_hour ; m = now->tm_min ; s = now->tm_sec ; h = h24 ; if (h > 12) h -= 12 ; // Hour hand angle = h * 30 + m * 0.5 ; x0 = sin (rads (angle)) * (clockRadius * 0.75) ; y0 = cos (rads (angle)) * (clockRadius * 0.75) ; for (p = -3.0 ; p <= 3.0 ; p += 0.2) { x1 = sin (rads (angle + p)) * (clockRadius * 0.7) ; y1 = cos (rads (angle + p)) * (clockRadius * 0.7) ; lcd128x64line (0, 0, x1, y1, 1) ; lcd128x64lineTo (x0, y0, 1) ; } // Minute hand angle = m * 6 ; x0 = sin (rads (angle)) * (clockRadius * 0.9) ; y0 = cos (rads (angle)) * (clockRadius * 0.9) ; for (p = -1.0 ; p <= 1.0 ; p += 0.2) { x1 = sin (rads (angle + p)) * (clockRadius * 0.85) ; y1 = cos (rads (angle + p)) * (clockRadius * 0.85) ; lcd128x64line (0, 0, x1, y1, 1) ; lcd128x64lineTo (x0, y0, 1) ; } // Second hand angle = s * 6 ; x0 = sin (rads (angle)) * (clockRadius * 0.2) ; y0 = cos (rads (angle)) * (clockRadius * 0.2) ; x1 = sin (rads (angle)) * (clockRadius * 0.95) ; y1 = cos (rads (angle)) * (clockRadius * 0.95) ; lcd128x64line (0 - x0, 0 - y0, x1, y1, 1) ; lcd128x64circle (0, 0, clockRadius * 0.1, 0, 1) ; lcd128x64circle (0, 0, clockRadius * 0.05, 1, 1) ; // Text: sprintf (text, "%02d:%02d:%02d", h24, m, s) ; lcd128x64puts (32, 24, text, 0, 1) ; sprintf (text, "%2d/%2d/%2d", now->tm_mday, now->tm_mon + 1, now->tm_year - 100) ; lcd128x64puts (32, -23, text, 0, 1) ; } void drawClockFace (void) { int m ; double d, px1, py1, px2, py2 ; lcd128x64clear (0) ; lcd128x64circle (0,0, clockRadius, 1, TRUE) ; lcd128x64circle (0,0, clockRadius - thickness, 0, TRUE) ; // The four big indicators for 12,15,30 and 45 lcd128x64rectangle (- 3, clockRadius - barLen, 3, clockRadius, 1, TRUE) ; // 12 lcd128x64rectangle (clockRadius - barLen, 3, clockRadius, -3, 1, TRUE) ; // 3 lcd128x64rectangle (- 3, -clockRadius + barLen, 3, -clockRadius, 1, TRUE) ; // 6 lcd128x64rectangle (-clockRadius + barLen, 3, -clockRadius, -3, 1, TRUE) ; // 9 // Smaller 5 and 1 minute ticks for (m = 0 ; m < 60 ; ++m) { px1 = sin (rads (m * 6)) * clockRadius ; py1 = cos (rads (m * 6)) * clockRadius ; if ((m % 5) == 0) d = barLen ; else d = barLen / 2.0 ; px2 = sin (rads (m * 6)) * (clockRadius - d) ; py2 = cos (rads (m * 6)) * (clockRadius - d) ; lcd128x64line (px1, py1, px2, py2, 1) ; } } void setup (void) { lcd128x64getScreenSize (&maxX, &maxY) ; clockRadius = maxY / 2 - 1 ; thickness = maxX / 48 ; barLen = thickness * 4 ; lcd128x64setOrigin (32, 32) ; } /* *********************************************************************** * The main program *********************************************************************** */ int main (int argc, char *argv []) { time_t now ; wiringPiSetup () ; lcd128x64setup () ; setup () ; for (;;) { drawClockFace () ; drawClockHands () ; lcd128x64update () ; now = time (NULL) ; while (time (NULL) == now) delay (10) ; } return 0 ; } wiringpi-2.50/examples/speed.c0000664000175000017500000000516113442550153016007 0ustar ubuntuubuntu/* * speed.c: * Simple program to measure the speed of the various GPIO * access mechanisms. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #define FAST_COUNT 10000000 #define SLOW_COUNT 1000000 #define PASSES 5 void speedTest (int pin, int maxCount) { int count, sum, perSec, i ; unsigned int start, end ; sum = 0 ; for (i = 0 ; i < PASSES ; ++i) { start = millis () ; for (count = 0 ; count < maxCount ; ++count) digitalWrite (pin, 1) ; end = millis () ; printf (" %6d", end - start) ; fflush (stdout) ; sum += (end - start) ; } digitalWrite (pin, 0) ; printf (". Av: %6dmS", sum / PASSES) ; perSec = (int)(double)maxCount / (double)((double)sum / (double)PASSES) * 1000.0 ; printf (": %7d/sec\n", perSec) ; } int main (void) { printf ("Raspberry Pi wiringPi GPIO speed test program\n") ; printf ("=============================================\n") ; // Start the standard way printf ("\nNative wiringPi method: (%8d iterations)\n", FAST_COUNT) ; wiringPiSetup () ; pinMode (0, OUTPUT) ; speedTest (0, FAST_COUNT) ; // GPIO printf ("\nNative GPIO method: (%8d iterations)\n", FAST_COUNT) ; wiringPiSetupGpio () ; pinMode (17, OUTPUT) ; speedTest (17, FAST_COUNT) ; // Phys printf ("\nPhysical pin GPIO method: (%8d iterations)\n", FAST_COUNT) ; wiringPiSetupPhys () ; pinMode (11, OUTPUT) ; speedTest (11, FAST_COUNT) ; // Switch to SYS mode: system ("/usr/local/bin/gpio export 17 out") ; printf ("\n/sys/class/gpio method: (%8d iterations)\n", SLOW_COUNT) ; wiringPiSetupSys () ; speedTest (17, SLOW_COUNT) ; return 0 ; } wiringpi-2.50/examples/spiSpeed.c0000664000175000017500000000651113442550153016463 0ustar ubuntuubuntu/* * spiSpeed.c: * Code to measure the SPI speed/latency. * Copyright (c) 2014 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include #include //#include //#include //#include #include #include #define TRUE (1==1) #define FALSE (!TRUE) #define SPI_CHAN 0 #define NUM_TIMES 100 #define MAX_SIZE (1024*1024) static int myFd ; void spiSetup (int speed) { if ((myFd = wiringPiSPISetup (SPI_CHAN, speed)) < 0) { fprintf (stderr, "Can't open the SPI bus: %s\n", strerror (errno)) ; exit (EXIT_FAILURE) ; } } int main (void) { int speed, times, size ; unsigned int start, end ; int spiFail ; unsigned char *myData ; double timePerTransaction, perfectTimePerTransaction, dataSpeed ; if ((myData = malloc (MAX_SIZE)) == NULL) { fprintf (stderr, "Unable to allocate buffer: %s\n", strerror (errno)) ; exit (EXIT_FAILURE) ; } wiringPiSetup () ; for (speed = 1 ; speed <= 32 ; speed *= 2) { printf ("+-------+--------+----------+----------+-----------+------------+\n") ; printf ("| MHz | Size | mS/Trans | TpS | Mb/Sec | Latency mS |\n") ; printf ("+-------+--------+----------+----------+-----------+------------+\n") ; spiFail = FALSE ; spiSetup (speed * 1000000) ; for (size = 1 ; size <= MAX_SIZE ; size *= 2) { printf ("| %5d | %6d ", speed, size) ; start = millis () ; for (times = 0 ; times < NUM_TIMES ; ++times) if (wiringPiSPIDataRW (SPI_CHAN, myData, size) == -1) { printf ("SPI failure: %s\n", strerror (errno)) ; spiFail = TRUE ; break ; } end = millis () ; if (spiFail) break ; timePerTransaction = ((double)(end - start) / (double)NUM_TIMES) / 1000.0 ; dataSpeed = (double)(size * 8) / (1024.0 * 1024.0) / timePerTransaction ; perfectTimePerTransaction = ((double)(size * 8)) / ((double)(speed * 1000000)) ; printf ("| %8.3f ", timePerTransaction * 1000.0) ; printf ("| %8.1f ", 1.0 / timePerTransaction) ; printf ("| %9.5f ", dataSpeed) ; printf ("| %8.5f ", (timePerTransaction - perfectTimePerTransaction) * 1000.0) ; printf ("|\n") ; } close (myFd) ; printf ("+-------+--------+----------+----------+-----------+------------+\n") ; printf ("\n") ; } return 0 ; } wiringpi-2.50/examples/header.h0000664000175000017500000000176313442550153016150 0ustar ubuntuubuntu/* * file.c: * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ wiringpi-2.50/examples/softPwm.c0000664000175000017500000000426513442550153016352 0ustar ubuntuubuntu/* * softPwm.c: * Test of the software PWM driver. Needs 8 LEDs connected * to the Pi - e.g. Ladder board. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #define RANGE 100 #define NUM_LEDS 8 int ledMap [NUM_LEDS] = { 0, 1, 2, 3, 4, 5, 6, 7 } ; int values [NUM_LEDS] = { 0, 25, 50, 75, 100, 75, 50, 25 } ; int main () { int i, j ; char buf [80] ; wiringPiSetup () ; for (i = 0 ; i < NUM_LEDS ; ++i) { softPwmCreate (ledMap [i], 0, RANGE) ; printf ("%3d, %3d, %3d\n", i, ledMap [i], values [i]) ; } fgets (buf, 80, stdin) ; // Bring all up one by one: for (i = 0 ; i < NUM_LEDS ; ++i) for (j = 0 ; j <= 100 ; ++j) { softPwmWrite (ledMap [i], j) ; delay (10) ; } fgets (buf, 80, stdin) ; // All Down for (i = 100 ; i > 0 ; --i) { for (j = 0 ; j < NUM_LEDS ; ++j) softPwmWrite (ledMap [j], i) ; delay (10) ; } fgets (buf, 80, stdin) ; for (;;) { for (i = 0 ; i < NUM_LEDS ; ++i) softPwmWrite (ledMap [i], values [i]) ; delay (50) ; i = values [0] ; for (j = 0 ; j < NUM_LEDS - 1 ; ++j) values [j] = values [j + 1] ; values [NUM_LEDS - 1] = i ; } } wiringpi-2.50/examples/blink12drcs.c0000664000175000017500000000607613442550153017033 0ustar ubuntuubuntu/* * blink12drcs.c: * Simple sequence over the first 12 GPIO pins - LEDs * Aimed at the Gertboard, but it's fairly generic. * This version uses DRC totalk to the ATmega on the Gertboard * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #define GERT_BASE 100 static int pinMap [] = { 0, 1, 2, 3, // Pi Native GERT_BASE + 2, GERT_BASE + 3, GERT_BASE + 4, GERT_BASE + 5, GERT_BASE + 6, GERT_BASE + 7, GERT_BASE + 8, GERT_BASE + 9, } ; // Simple sequencer data // Triplets of LED, On/Off and delay int data [] = { 0, 1, 1, 1, 1, 1, 0, 0, 0, 2, 1, 1, 1, 0, 0, 3, 1, 1, 2, 0, 0, 4, 1, 1, 3, 0, 0, 5, 1, 1, 4, 0, 0, 6, 1, 1, 5, 0, 0, 7, 1, 1, 6, 0, 0, 8, 1, 1, 7, 0, 0, 9, 1, 1, 8, 0, 0, 10, 1, 1, 9, 0, 0, 11, 1, 1, 10, 0, 1, 11, 0, 1, 0, 0, 1, // Extra delay // Back again 11, 1, 1, 10, 1, 1, 11, 0, 0, 9, 1, 1, 10, 0, 0, 8, 1, 1, 9, 0, 0, 7, 1, 1, 8, 0, 0, 6, 1, 1, 7, 0, 0, 5, 1, 1, 6, 0, 0, 4, 1, 1, 5, 0, 0, 3, 1, 1, 4, 0, 0, 2, 1, 1, 3, 0, 0, 1, 1, 1, 2, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, // Extra delay 0, 9, 0, // End marker } ; int main (void) { int pin ; int dataPtr ; int l, s, d ; printf ("Raspberry Pi - 12-LED Sequence\n") ; printf ("==============================\n") ; printf ("\n") ; printf ("Connect LEDs up to the first 4 Pi pins and 8 pins on the ATmega\n") ; printf (" from PD2 through PB1 in that order,\n") ; printf (" then sit back and watch the show!\n") ; wiringPiSetup () ; drcSetupSerial (GERT_BASE, 20, "/dev/ttyAMA0", 115200) ; for (pin = 0 ; pin < 12 ; ++pin) pinMode (pinMap [pin], OUTPUT) ; dataPtr = 0 ; for (;;) { l = data [dataPtr++] ; // LED s = data [dataPtr++] ; // State d = data [dataPtr++] ; // Duration (10ths) if (s == 9) // 9 -> End Marker { dataPtr = 0 ; continue ; } digitalWrite (pinMap [l], s) ; delay (d * analogRead (GERT_BASE) / 4) ; } return 0 ; } wiringpi-2.50/examples/isr.c0000664000175000017500000000637213442550153015511 0ustar ubuntuubuntu/* * isr.c: * Wait for Interrupt test program - ISR method * * How to test: * Use the SoC's pull-up and pull down resistors that are avalable * on input pins. So compile & run this program (via sudo), then * in another terminal: * gpio mode 0 up * gpio mode 0 down * at which point it should trigger an interrupt. Toggle the pin * up/down to generate more interrupts to test. * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include // globalCounter: // Global variable to count interrupts // Should be declared volatile to make sure the compiler doesn't cache it. static volatile int globalCounter [8] ; /* * myInterrupt: ********************************************************************************* */ void myInterrupt0 (void) { ++globalCounter [0] ; } void myInterrupt1 (void) { ++globalCounter [1] ; } void myInterrupt2 (void) { ++globalCounter [2] ; } void myInterrupt3 (void) { ++globalCounter [3] ; } void myInterrupt4 (void) { ++globalCounter [4] ; } void myInterrupt5 (void) { ++globalCounter [5] ; } void myInterrupt6 (void) { ++globalCounter [6] ; } void myInterrupt7 (void) { ++globalCounter [7] ; } /* ********************************************************************************* * main ********************************************************************************* */ int main (void) { int gotOne, pin ; int myCounter [8] ; for (pin = 0 ; pin < 8 ; ++pin) globalCounter [pin] = myCounter [pin] = 0 ; wiringPiSetup () ; wiringPiISR (0, INT_EDGE_FALLING, &myInterrupt0) ; wiringPiISR (1, INT_EDGE_FALLING, &myInterrupt1) ; wiringPiISR (2, INT_EDGE_FALLING, &myInterrupt2) ; wiringPiISR (3, INT_EDGE_FALLING, &myInterrupt3) ; wiringPiISR (4, INT_EDGE_FALLING, &myInterrupt4) ; wiringPiISR (5, INT_EDGE_FALLING, &myInterrupt5) ; wiringPiISR (6, INT_EDGE_FALLING, &myInterrupt6) ; wiringPiISR (7, INT_EDGE_FALLING, &myInterrupt7) ; for (;;) { gotOne = 0 ; printf ("Waiting ... ") ; fflush (stdout) ; for (;;) { for (pin = 0 ; pin < 8 ; ++pin) { if (globalCounter [pin] != myCounter [pin]) { printf (" Int on pin %d: Counter: %5d\n", pin, globalCounter [pin]) ; myCounter [pin] = globalCounter [pin] ; ++gotOne ; } } if (gotOne != 0) break ; } } return 0 ; } wiringpi-2.50/examples/pwm.c0000664000175000017500000000301613442550153015507 0ustar ubuntuubuntu/* * pwm.c: * This tests the hardware PWM channel. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include int main (void) { int bright ; printf ("Raspberry Pi wiringPi PWM test program\n") ; if (wiringPiSetup () == -1) exit (1) ; pinMode (1, PWM_OUTPUT) ; for (;;) { for (bright = 0 ; bright < 1024 ; ++bright) { pwmWrite (1, bright) ; delay (1) ; } for (bright = 1023 ; bright >= 0 ; --bright) { pwmWrite (1, bright) ; delay (1) ; } } return 0 ; } wiringpi-2.50/examples/Gertboard/0000775000175000017500000000000013442550153016451 5ustar ubuntuubuntuwiringpi-2.50/examples/Gertboard/Makefile0000664000175000017500000000273713442550153020122 0ustar ubuntuubuntu# # Makefile: # Gertboard - Examples using wiringPi # # Copyright (c) 2013 Gordon Henderson ################################################################################# ifneq ($V,1) Q ?= @ endif #DEBUG = -g -O0 DEBUG = -O3 CC = gcc INCLUDE = -I/usr/local/include CFLAGS = $(DEBUG) -Wall $(INCLUDE) -Winline -pipe LDFLAGS = -L/usr/local/lib LDLIBS = -lwiringPi -lwiringPiDev -lpthread -lm # Should not alter anything below this line ############################################################################### SRC = gertboard.c \ buttons.c 7segments.c \ voltmeter.c temperature.c vumeter.c \ record.c OBJ = $(SRC:.c=.o) BINS = $(SRC:.c=) all: $(BINS) gertboard: gertboard.o $Q echo [link] $Q $(CC) -o $@ gertboard.o $(LDFLAGS) $(LDLIBS) buttons: buttons.o $Q echo [link] $Q $(CC) -o $@ buttons.o $(LDFLAGS) $(LDLIBS) 7segments: 7segments.o $Q echo [link] $Q $(CC) -o $@ 7segments.o $(LDFLAGS) $(LDLIBS) voltmeter: voltmeter.o $Q echo [link] $Q $(CC) -o $@ voltmeter.o $(LDFLAGS) $(LDLIBS) temperature: temperature.o $Q echo [link] $Q $(CC) -o $@ temperature.o $(LDFLAGS) $(LDLIBS) vumeter: vumeter.o $Q echo [link] $Q $(CC) -o $@ vumeter.o $(LDFLAGS) $(LDLIBS) record: record.o $Q echo [link] $Q $(CC) -o $@ record.o $(LDFLAGS) $(LDLIBS) .c.o: $Q echo [CC] $< $Q $(CC) -c $(CFLAGS) $< -o $@ clean: $Q echo [Clean] $Q rm -f $(OBJ) *~ core tags $(BINS) tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) depend: makedepend -Y $(SRC) # DO NOT DELETE wiringpi-2.50/examples/Gertboard/voltmeter.c0000664000175000017500000000356513442550153020647 0ustar ubuntuubuntu/* * voltmeter.c: * Demonstrate use of the Gertboard A to D converter to make * a simple voltmeter. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include int main () { int x1, x2 ; double v1, v2 ; printf ("\n") ; printf ("Gertboard demo: Simple Voltmeters\n") ; printf ("=================================\n") ; // Always initialise wiringPi. Use wiringPiSys() if you don't need // (or want) to run as root wiringPiSetupSys () ; // Initialise the Gertboard analog hardware at pin 100 gertboardAnalogSetup (100) ; printf ("\n") ; printf ("| Channel 0 | Channel 1 |\n") ; for (;;) { // Read the 2 channels: x1 = analogRead (100) ; x2 = analogRead (101) ; // Convert to a voltage: v1 = (double)x1 / 1023.0 * 3.3 ; v2 = (double)x2 / 1023.0 * 3.3 ; // Print printf ("| %6.3f | %6.3f |\r", v1, v2) ; fflush (stdout) ; } return 0 ; } wiringpi-2.50/examples/Gertboard/temperature.c0000664000175000017500000000420013442550153021146 0ustar ubuntuubuntu/* * temperature.c: * Demonstrate use of the Gertboard A to D converter to make * a simple thermometer using the LM35. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include int main () { int x1, x2 ; double v1, v2 ; printf ("\n") ; printf ("Gertboard demo: Simple Thermemeter\n") ; printf ("==================================\n") ; // Always initialise wiringPi. Use wiringPiSys() if you don't need // (or want) to run as root wiringPiSetupSys () ; // Initialise the Gertboard analog hardware at pin 100 gertboardAnalogSetup (100) ; printf ("\n") ; printf ("| Channel 0 | Channel 1 | Temperature 1 | Temperature 2 |\n") ; for (;;) { // Read the 2 channels: x1 = analogRead (100) ; x2 = analogRead (101) ; // Convert to a voltage: v1 = (double)x1 / 1023.0 * 3.3 ; v2 = (double)x2 / 1023.0 * 3.3 ; // Print printf ("| %6.3f | %6.3f |", v1, v2) ; // Print Temperature of both channels by converting the LM35 reading // to a temperature. Fortunately these are easy: 0.01 volts per C. printf (" %4.1f | %4.1f |\r", v1 * 100.0, v2 * 100.0) ; fflush (stdout) ; } return 0 ; } wiringpi-2.50/examples/Gertboard/vumeter.c0000664000175000017500000000635613442550153020316 0ustar ubuntuubuntu/* * vumeter.c: * Simple VU meter * * Heres the theory: * We will sample at 4000 samples/sec and put the data into a * low-pass filter with a depth of 1000 samples. This will give * us 1/4 a second of lag on the signal, but I think it might * produce a more pleasing output. * * The input of the microphone should be at mid-pont with no * sound input, but we might have to sample that too, to get * our reference zero... * * Copyright (c) 2013 Gordon Henderson *********************************************************************** */ #include #include #include #include #include #ifndef TRUE #define TRUE (1==1) #define FALSE (!TRUE) #endif #define B_SIZE 1000 #define S_SIZE 128 static int buffer [B_SIZE] ; static int bPtr = 0 ; /* * ledPercent: * Output the given value as a percentage on the LEDs ********************************************************************************* */ static void ledPercent (int percent) { unsigned int output = 0 ; if (percent > 11) output |= 0x01 ; if (percent > 22) output |= 0x02 ; if (percent > 33) output |= 0x04 ; if (percent > 44) output |= 0x08 ; if (percent > 55) output |= 0x10 ; if (percent > 66) output |= 0x20 ; if (percent > 77) output |= 0x40 ; if (percent > 88) output |= 0x80 ; digitalWriteByte (output) ; } static unsigned int tPeriod, tNextSampleTime ; /* * sample: * Get a sample from the Gertboard. If not enough time has elapsed * since the last sample, then wait... ********************************************************************************* */ static void sample (void) { unsigned int tFuture ; // Calculate the future sample time tFuture = tPeriod + tNextSampleTime ; // Wait until the next sample time while (micros () < tNextSampleTime) ; buffer [bPtr] = gertboardAnalogRead (0) ; tNextSampleTime = tFuture ; } int main () { int quietLevel, min, max ; int i, sum ; unsigned int tStart, tEnd ; printf ("\n") ; printf ("Gertboard demo: VU Meter\n") ; printf ("========================\n") ; wiringPiSetup () ; gertboardSPISetup () ; ledPercent (0) ; for (i = 0 ; i < 8 ; ++i) pinMode (i, OUTPUT) ; for (bPtr = 0 ; bPtr < B_SIZE ; ++bPtr) buffer [bPtr] = 99 ; tPeriod = 1000000 / 1000 ; printf ("Shhhh.... ") ; fflush (stdout) ; delay (1000) ; printf ("Sampling quiet... ") ; fflush (stdout) ; tStart = micros () ; tNextSampleTime = micros () ; for (bPtr = 0 ; bPtr < B_SIZE ; ++bPtr) sample () ; tEnd = micros () ; quietLevel = 0 ; max = 0 ; min = 1024 ; for (i = 0 ; i < B_SIZE ; ++i) { quietLevel += buffer [i] ; if (buffer [i] > max) max = buffer [i] ; if (buffer [i] < min) min = buffer [i] ; } quietLevel /= B_SIZE ; printf ("Done. Quiet level is: %d [%d:%d] [%d:%d]\n", quietLevel, min, max, quietLevel - min, max - quietLevel) ; printf ("Time taken for %d reads: %duS\n", B_SIZE, tEnd - tStart) ; for (bPtr = 0 ;;) { sample () ; sum = 0 ; for (i = 0 ; i < S_SIZE ; ++i) sum += buffer [i] ; sum /= S_SIZE ; sum = abs (quietLevel - sum) ; sum = (sum * 1000) / quietLevel ; ledPercent (sum) ; if (++bPtr > S_SIZE) bPtr = 0 ; } return 0 ; } wiringpi-2.50/examples/Gertboard/record.c0000664000175000017500000000234613442550153020100 0ustar ubuntuubuntu/* * record.c: * Record some audio via the Gertboard * * Copyright (c) 2013 Gordon Henderson *********************************************************************** */ #include #include #include #include #define B_SIZE 40000 int main () { int i ; struct timeval tStart, tEnd, tTaken ; unsigned char buffer [B_SIZE] ; printf ("\n") ; printf ("Gertboard demo: Recorder\n") ; printf ("========================\n") ; // Always initialise wiringPi. Use wiringPiSys() if you don't need // (or want) to run as root wiringPiSetupSys () ; // Initialise the Gertboard analog hardware at pin 100 gertboardAnalogSetup (100) ; gettimeofday (&tStart, NULL) ; for (i = 0 ; i < B_SIZE ; ++i) buffer [i] = analogRead (100) >> 2 ; gettimeofday (&tEnd, NULL) ; timersub (&tEnd, &tStart, &tTaken) ; printf ("Time taken for %d reads: %ld.%ld\n", B_SIZE, tTaken.tv_sec, tTaken.tv_usec) ; gettimeofday (&tStart, NULL) ; for (i = 0 ; i < B_SIZE ; ++i) analogWrite (100, buffer [i]) ; gettimeofday (&tEnd, NULL) ; timersub (&tEnd, &tStart, &tTaken) ; printf ("Time taken for %d writes: %ld.%ld\n", B_SIZE, tTaken.tv_sec, tTaken.tv_usec) ; return 0 ; } wiringpi-2.50/examples/Gertboard/gertboard.c0000664000175000017500000000516213442550153020572 0ustar ubuntuubuntu/* * gertboard.c: * Simple test for the SPI bus on the Gertboard * * Hardware setup: * D/A port 0 jumpered to A/D port 0. * * We output a sine wave on D/A port 0 and sample A/D port 0. We then * plot the input value on the terminal as a sort of vertical scrolling * oscilloscipe. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include // Gertboard D to A is an 8-bit unit. #define B_SIZE 256 #include #include int main (void) { double angle ; int i, inputValue ; int buffer [B_SIZE] ; int cols ; struct winsize w ; printf ("Raspberry Pi Gertboard SPI test program\n") ; printf ("=======================================\n") ; ioctl (fileno (stdin), TIOCGWINSZ, &w); cols = w.ws_col - 2 ; // Always initialise wiringPi. Use wiringPiSys() if you don't need // (or want) to run as root wiringPiSetupSys () ; // Initialise the Gertboard analog hardware at pin 100 gertboardAnalogSetup (100) ; // Generate a Sine Wave and store in our buffer for (i = 0 ; i < B_SIZE ; ++i) { angle = ((double)i / (double)B_SIZE) * M_PI * 2.0 ; buffer [i] = (int)rint ((sin (angle)) * 127.0 + 128.0) ; } // Loop, output the sine wave on analog out port 0, read it into A-D port 0 // and display it on the screen for (;;) { for (i = 0 ; i < B_SIZE ; ++i) { analogWrite (100, buffer [i]) ; inputValue = analogRead (100) ; // We don't need to wory about the scale or sign - the analog hardware is // a 10-bit value, so 0-1023. Just scale this to our terminal printf ("%*s\n", (inputValue * cols) / 1023, "*") ; delay (2) ; } } return 0 ; } wiringpi-2.50/examples/Gertboard/buttons.c0000664000175000017500000000421313442550153020313 0ustar ubuntuubuntu/* * buttons.c: * Read the Gertboard buttons. Each one will act as an on/off * tiggle switch for 3 different LEDs * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include // Array to keep track of our LEDs int leds [] = { 0, 0, 0 } ; // scanButton: // See if a button is pushed, if so, then flip that LED and // wait for the button to be let-go void scanButton (int button) { if (digitalRead (button) == HIGH) // Low is pushed return ; leds [button] ^= 1 ; // Invert state digitalWrite (4 + button, leds [button]) ; while (digitalRead (button) == LOW) // Wait for release delay (10) ; } int main (void) { int i ; printf ("Raspberry Pi Gertboard Button Test\n") ; wiringPiSetup () ; // Setup the outputs: // Pins 3, 4, 5, 6 and 7 output: // We're not using 3 or 4, but make sure they're off anyway // (Using same hardware config as blink12.c) for (i = 3 ; i < 8 ; ++i) { pinMode (i, OUTPUT) ; digitalWrite (i, 0) ; } // Setup the inputs for (i = 0 ; i < 3 ; ++i) { pinMode (i, INPUT) ; pullUpDnControl (i, PUD_UP) ; leds [i] = 0 ; } for (;;) { for (i = 0 ; i < 3 ; ++i) scanButton (i) ; delay (1) ; } } wiringpi-2.50/examples/Gertboard/7segments.c0000664000175000017500000001043313442550153020532 0ustar ubuntuubuntu/* * 7segments.c: * Simple test program to see if we can drive a 7-segment LED * display using the GPIO and little else on the Raspberry Pi * * Copyright (c) 2013 Gordon Henderson *********************************************************************** */ #undef PHOTO_HACK #include #include #include #include #include /* * Segment mapping * * --a-- * | | * f b * | | * --g-- * | | * e c * | | * --d-- p */ // GPIO Pin Mapping static int digits [6] = { 7, 11, 10, 13, 12, 14 } ; static int segments [7] = { 6, 5, 4, 3, 2, 1, 0 } ; static const int segmentDigits [] = { // a b c d e f g Segments // 6 5 4 3 2 1 0, // wiringPi pin No. 1, 1, 1, 1, 1, 1, 0, // 0 0, 1, 1, 0, 0, 0, 0, // 1 1, 1, 0, 1, 1, 0, 1, // 2 1, 1, 1, 1, 0, 0, 1, // 3 0, 1, 1, 0, 0, 1, 1, // 4 1, 0, 1, 1, 0, 1, 1, // 5 1, 0, 1, 1, 1, 1, 1, // 6 1, 1, 1, 0, 0, 0, 0, // 7 1, 1, 1, 1, 1, 1, 1, // 8 1, 1, 1, 1, 0, 1, 1, // 9 1, 1, 1, 0, 1, 1, 1, // A 0, 0, 1, 1, 1, 1, 1, // b 1, 0, 0, 1, 1, 1, 0, // C 0, 1, 1, 1, 1, 0, 1, // d 1, 0, 0, 1, 1, 1, 1, // E 1, 0, 0, 0, 1, 1, 1, // F 0, 0, 0, 0, 0, 0, 0, // blank } ; // display: // A global variable which is written to by the main program and // read from by the thread that updates the display. Only the first // 6 characters are used. char display [8] ; /* * displayDigits: * This is our thread that's run concurrently with the main program. * Essentially sit in a loop, parsing and displaying the data held in * the "display" global. ********************************************************************************* */ PI_THREAD (displayDigits) { int digit, segment ; int index, d, segVal ; piHiPri (50) ; for (;;) { for (digit = 0 ; digit < 6 ; ++digit) { for (segment = 0 ; segment < 7 ; ++segment) { d = toupper (display [digit]) ; /**/ if ((d >= '0') && (d <= '9')) // Digit index = d - '0' ; else if ((d >= 'A') && (d <= 'F')) // Hex index = d - 'A' + 10 ; else index = 16 ; // Blank segVal = segmentDigits [index * 7 + segment] ; digitalWrite (segments [segment], segVal) ; } digitalWrite (digits [digit], 1) ; delay (2) ; digitalWrite (digits [digit], 0) ; } } } /* * setup: * Initialise the hardware and start the thread ********************************************************************************* */ void setup (void) { int i, c ; wiringPiSetup () ; // 7 segments for (i = 0 ; i < 7 ; ++i) { digitalWrite (segments [i], 0) ; pinMode (segments [i], OUTPUT) ; } // 6 digits for (i = 0 ; i < 6 ; ++i) { digitalWrite (digits [i], 0) ; pinMode (digits [i], OUTPUT) ; } strcpy (display, " ") ; piThreadCreate (displayDigits) ; delay (10) ; // Just to make sure it's started // Quick countdown LED test sort of thing c = 999999 ; for (i = 0 ; i < 10 ; ++i) { sprintf (display, "%06d", c) ; delay (400) ; c -= 111111 ; } strcpy (display, " ") ; delay (400) ; #ifdef PHOTO_HACK sprintf (display, "%s", "123456") ; for (;;) delay (1000) ; #endif } /* * teenager: * No explanation needed. (Nor one given!) ********************************************************************************* */ void teenager (void) { char *message = " feedbeef babe cafe b00b " ; int i ; for (i = 0 ; i < strlen (message) - 4 ; ++i) { strncpy (display, &message [i], 6) ; delay (200) ; } delay (1000) ; for (i = 0 ; i < 3 ; ++i) { strcpy (display, " ") ; delay (150) ; strcpy (display, " b00b ") ; delay (250) ; } delay (1000) ; strcpy (display, " ") ; delay (1000) ; } /* ********************************************************************************* * main: * Let the fun begin ********************************************************************************* */ int main (void) { struct tm *t ; time_t tim ; setup () ; teenager () ; tim = time (NULL) ; for (;;) { while (time (NULL) == tim) delay (5) ; tim = time (NULL) ; t = localtime (&tim) ; sprintf (display, "%02d%02d%02d", t->tm_hour, t->tm_min, t->tm_sec) ; delay (500) ; } return 0 ; } wiringpi-2.50/examples/servo.c0000664000175000017500000000316513442550153016047 0ustar ubuntuubuntu/* * servo.c: * Test of the softServo code. * Do not use this code - use the servoBlaster kernel module instead * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include int main () { if (wiringPiSetup () == -1) { fprintf (stdout, "oops: %s\n", strerror (errno)) ; return 1 ; } softServoSetup (0, 1, 2, 3, 4, 5, 6, 7) ; softServoWrite (0, 0) ; /* softServoWrite (1, 1000) ; softServoWrite (2, 1100) ; softServoWrite (3, 1200) ; softServoWrite (4, 1300) ; softServoWrite (5, 1400) ; softServoWrite (6, 1500) ; softServoWrite (7, 2200) ; */ for (;;) delay (10) ; } wiringpi-2.50/examples/PiGlow/0000775000175000017500000000000013442550153015741 5ustar ubuntuubuntuwiringpi-2.50/examples/PiGlow/Makefile0000664000175000017500000000415413442550153017405 0ustar ubuntuubuntu# # Makefile: # wiringPi - A "wiring" library for the Raspberry Pi # https://projects.drogon.net/wiring-pi # # Copyright (c) 2012-2015 Gordon Henderson ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# ifneq ($V,1) Q ?= @ endif #DEBUG = -g -O0 DEBUG = -O3 CC = gcc INCLUDE = -I/usr/local/include CFLAGS = $(DEBUG) -Wall $(INCLUDE) -Winline -pipe LDFLAGS = -L/usr/local/lib LDLIBS = -lwiringPi -lwiringPiDev -lpthread -lm # Should not alter anything below this line ############################################################################### SRC = piGlow0.c piGlow1.c piglow.c OBJ = $(SRC:.c=.o) BINS = $(SRC:.c=) all: $(BINS) piGlow0: piGlow0.o $Q echo [link] $Q $(CC) -o $@ piGlow0.o $(LDFLAGS) $(LDLIBS) piGlow1: piGlow1.o $Q echo [link] $Q $(CC) -o $@ piGlow1.o $(LDFLAGS) $(LDLIBS) piglow: piglow.o $Q echo [link] $Q $(CC) -o $@ piglow.o $(LDFLAGS) $(LDLIBS) .c.o: $Q echo [CC] $< $Q $(CC) -c $(CFLAGS) $< -o $@ clean: $Q echo "[Clean]" $Q rm -f $(OBJ) *~ core tags $(BINS) tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) install: piglow $Q echo Installing piglow into /usr/local/bin $Q cp -a piglow /usr/local/bin/piglow $Q chmod 755 /usr/local/bin/piglow $Q echo Done. Remember to load the I2C drivers! depend: makedepend -Y $(SRC) # DO NOT DELETE wiringpi-2.50/examples/PiGlow/piGlow0.c0000664000175000017500000000302713442550153017430 0ustar ubuntuubuntu/* * piglow.c: * Very simple demonstration of the PiGlow board. * This uses the SN3218 directly - soon there will be a new PiGlow * devLib device which will handle the PiGlow board on a more easy * to use manner... * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #define LED_BASE 533 int main (void) { int i, j ; wiringPiSetupSys () ; sn3218Setup (LED_BASE) ; for (;;) { for (i = 0 ; i < 256 ; ++i) for (j = 0 ; j < 18 ; ++j) analogWrite (LED_BASE + j, i) ; for (i = 255 ; i >= 0 ; --i) for (j = 0 ; j < 18 ; ++j) analogWrite (LED_BASE + j, i) ; } } wiringpi-2.50/examples/PiGlow/piglow.c0000664000175000017500000001113513442550153017407 0ustar ubuntuubuntu/* * piglow.c: * Very simple demonstration of the PiGlow board. * This uses the piGlow devLib. * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #ifndef TRUE # define TRUE (1==1) # define FALSE (!TRUE) #endif #include #include static void failUsage (void) { fprintf (stderr, "Usage examples:\n") ; fprintf (stderr, " piglow off # All off\n") ; fprintf (stderr, " piglow red 50 # Light the 3 red LEDs to 50%%\n") ; fprintf (stderr, " colours are: red, yellow, orange, green, blue and white\n") ; fprintf (stderr, " piglow all 75 # Light all to 75%%\n") ; fprintf (stderr, " piglow leg 0 25 # Light leg 0 to 25%%\n") ; fprintf (stderr, " piglow ring 3 100 # Light ring 3 to 100%%\n") ; fprintf (stderr, " piglow led 2 5 100 # Light the single LED on Leg 2, ring 5 to 100%%\n") ; exit (EXIT_FAILURE) ; } static int getPercent (char *typed) { int percent ; percent = atoi (typed) ; if ((percent < 0) || (percent > 100)) { fprintf (stderr, "piglow: percent value out of range\n") ; exit (EXIT_FAILURE) ; } return (percent * 255) / 100 ; } /* * main: * Our little demo prgoram ********************************************************************************* */ int main (int argc, char *argv []) { int percent ; int ring, leg ; // Always initialise wiringPi: // Use the Sys method if you don't need to run as root wiringPiSetupSys () ; // Initialise the piGlow devLib piGlowSetup (FALSE) ; if (argc == 1) failUsage () ; if ((argc == 2) && (strcasecmp (argv [1], "off") == 0)) { for (leg = 0 ; leg < 3 ; ++leg) piGlowLeg (leg, 0) ; return 0 ; } if (argc == 3) { percent = getPercent (argv [2]) ; /**/ if (strcasecmp (argv [1], "red") == 0) piGlowRing (PIGLOW_RED, percent) ; else if (strcasecmp (argv [1], "yellow") == 0) piGlowRing (PIGLOW_YELLOW, percent) ; else if (strcasecmp (argv [1], "orange") == 0) piGlowRing (PIGLOW_ORANGE, percent) ; else if (strcasecmp (argv [1], "green") == 0) piGlowRing (PIGLOW_GREEN, percent) ; else if (strcasecmp (argv [1], "blue") == 0) piGlowRing (PIGLOW_BLUE, percent) ; else if (strcasecmp (argv [1], "white") == 0) piGlowRing (PIGLOW_WHITE, percent) ; else if (strcasecmp (argv [1], "all") == 0) for (ring = 0 ; ring < 6 ; ++ring) piGlowRing (ring, percent) ; else { fprintf (stderr, "piglow: invalid colour\n") ; exit (EXIT_FAILURE) ; } return 0 ; } if (argc == 4) { /**/ if (strcasecmp (argv [1], "leg") == 0) { leg = atoi (argv [2]) ; if ((leg < 0) || (leg > 2)) { fprintf (stderr, "piglow: leg value out of range\n") ; exit (EXIT_FAILURE) ; } percent = getPercent (argv [3]) ; piGlowLeg (leg, percent) ; } else if (strcasecmp (argv [1], "ring") == 0) { ring = atoi (argv [2]) ; if ((ring < 0) || (ring > 5)) { fprintf (stderr, "piglow: ring value out of range\n") ; exit (EXIT_FAILURE) ; } percent = getPercent (argv [3]) ; piGlowRing (ring, percent) ; } return 0 ; } if (argc == 5) { if (strcasecmp (argv [1], "led") != 0) failUsage () ; leg = atoi (argv [2]) ; if ((leg < 0) || (leg > 2)) { fprintf (stderr, "piglow: leg value out of range\n") ; exit (EXIT_FAILURE) ; } ring = atoi (argv [3]) ; if ((ring < 0) || (ring > 5)) { fprintf (stderr, "piglow: ring value out of range\n") ; exit (EXIT_FAILURE) ; } percent = getPercent (argv [4]) ; piGlow1 (leg, ring, percent) ; return 0 ; } failUsage () ; return 0 ; } wiringpi-2.50/examples/PiGlow/piGlow1.c0000664000175000017500000001226513442550153017435 0ustar ubuntuubuntu/* * piGlow1.c: * Very simple demonstration of the PiGlow board. * This uses the piGlow devLib. * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #define PIGLOW_BASE 533 #ifndef TRUE # define TRUE (1==1) # define FALSE (!TRUE) #endif /* * keypressed: clearKeypressed: * Simple but effective ways to tell if the enter key has been pressed ********************************************************************************* */ static int keypressed (void) { struct pollfd polls ; polls.fd = fileno (stdin) ; polls.events = POLLIN ; return poll (&polls, 1, 0) != 0 ; } static void clearKeypressed (void) { while (keypressed ()) (void)getchar () ; } /* * pulseLed: * Pulses the LED at position leg, ring from off to a max. value, * then off again ********************************************************************************* */ static void pulseLed (int leg, int ring) { int i ; for (i = 0 ; i < 140 ; ++i) { piGlow1 (leg, ring, i) ; delay (1) ; } delay (10) ; for (i = 140 ; i >= 0 ; --i) { piGlow1 (leg, ring, i) ; delay (1) ; } } /* * pulseLeg: * Same as above, but a whole leg at a time ********************************************************************************* */ static void pulseLeg (int leg) { int i ; for (i = 0 ; i < 140 ; ++i) { piGlowLeg (leg, i) ; delay (1) ; } delay (10) ; for (i = 140 ; i >= 0 ; --i) { piGlowLeg (leg, i) ; delay (1) ; } } /* * pulse Ring: * Same as above, but a whole ring at a time ********************************************************************************* */ static void pulseRing (int ring) { int i ; for (i = 0 ; i < 140 ; ++i) { piGlowRing (ring, i) ; delay (1) ; } delay (10) ; for (i = 140 ; i >= 0 ; --i) { piGlowRing (ring, i) ; delay (1) ; } } #define LEG_STEPS 3 static int legSequence [] = { 4, 12, 99, 99, 4, 12, 12, 99, 4, } ; #define RING_STEPS 16 static int ringSequence [] = { 0, 0, 0, 0, 0, 64, 0, 0, 0, 0, 64, 64, 0, 0, 0, 64, 64, 0, 0, 0, 64, 64, 0, 0, 0, 64, 64, 0, 0, 0, 64, 64, 0, 0, 0, 0, 64, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 64, 0, 0, 0, 0, 0, 64, 64, 0, 0, 0, 0, 0, 64, 64, 0, 0, 0, 0, 0, 64, 64, 0, 0, 0, 0, 0, 64, 64, 0, 0, 0, 0, 0, 64, 64, 0, 0, 0, 0, 0, 64, 0, 0, 0, 0, 0, 0, } ; /* * main: * Our little demo prgoram ********************************************************************************* */ int main (void) { int i ; int step, ring, leg ; // Always initialise wiringPi: // Use the Sys method if you don't need to run as root wiringPiSetupSys () ; // Initialise the piGlow devLib with our chosen pin base piGlowSetup (1) ; // LEDs, one at a time printf ("LEDs, one at a time\n") ; for (; !keypressed () ;) for (leg = 0 ; leg < 3 ; ++leg) { for (ring = 0 ; ring < 6 ; ++ring) { pulseLed (leg, ring) ; if (keypressed ()) break ; } if (keypressed ()) break ; } clearKeypressed () ; // Rings, one at a time printf ("Rings, one at a time\n") ; for (; !keypressed () ;) for (ring = 0 ; ring < 6 ; ++ring) { pulseRing (ring) ; if (keypressed ()) break ; } clearKeypressed () ; // Legs, one at a time printf ("Legs, one at a time\n") ; for (; !keypressed () ;) for (leg = 0 ; leg < 3 ; ++leg) { pulseLeg (leg) ; if (keypressed ()) break ; } clearKeypressed () ; delay (1000) ; // Sequence - alternating rings, legs and random printf ("Sequence now\n") ; for (; !keypressed () ;) { for (i = 0 ; i < 20 ; ++i) for (step = 0 ; step < LEG_STEPS ; ++step) { for (leg = 0 ; leg < 3 ; ++leg) piGlowLeg (leg, legSequence [step * 3 + leg]) ; delay (80) ; } for (i = 0 ; i < 10 ; ++i) for (step = 0 ; step < RING_STEPS ; ++step) { for (ring = 0 ; ring < 6 ; ++ring) piGlowRing (ring, ringSequence [step * 6 + ring]) ; delay (80) ; } for (i = 0 ; i < 1000 ; ++i) { leg = random () % 3 ; ring = random () % 6 ; piGlow1 (leg, ring, random () % 256) ; delay (5) ; piGlow1 (leg, ring, 0) ; } } return 0 ; } wiringpi-2.50/examples/scrollPhat/0000775000175000017500000000000013442550153016653 5ustar ubuntuubuntuwiringpi-2.50/examples/scrollPhat/Makefile0000664000175000017500000000401613442550153020314 0ustar ubuntuubuntu# # Makefile: # wiringPi - A "wiring" library for the Raspberry Pi # https://projects.drogon.net/wiring-pi # # Copyright (c) 2012-2015 Gordon Henderson ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# ifneq ($V,1) Q ?= @ endif #DEBUG = -g -O0 DEBUG = -O3 CC = gcc INCLUDE = -I/usr/local/include CFLAGS = $(DEBUG) -Wall $(INCLUDE) -Winline -pipe LDFLAGS = -L/usr/local/lib LDLIBS = -lwiringPi -lwiringPiDev -lpthread -lm # Should not alter anything below this line ############################################################################### SRC = scphat.c test.c OBJ = $(SRC:.c=.o) BINS = $(SRC:.c=) all: $(BINS) test: test.o $Q echo [link] $Q $(CC) -o $@ test.o $(LDFLAGS) $(LDLIBS) scphat: scphat.o $Q echo [link] $Q $(CC) -o $@ scphat.o $(LDFLAGS) $(LDLIBS) .c.o: $Q echo [CC] $< $Q $(CC) -c $(CFLAGS) $< -o $@ clean: $Q echo "[Clean]" $Q rm -f $(OBJ) *~ core tags $(BINS) tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) install: scphat $Q echo Installing scphat into /usr/local/bin $Q cp -a scphat /usr/local/bin/scphat $Q chmod 755 /usr/local/bin/scphat $Q echo Done. Remember to load the I2C drivers if needed. depend: makedepend -Y $(SRC) # DO NOT DELETE wiringpi-2.50/examples/scrollPhat/scphat.c0000664000175000017500000001420013442550153020276 0ustar ubuntuubuntu/* * scphat.c: * Little program to allow use of the Pimoroni Sctoll Phat * from the command-line. * * Copyright (c) 2015-2016 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include static char *progName ; /* * checkArgs: * Count the arguments for each little function ********************************************************************************* */ static void checkArgs (char *command, int num, int arg, int argc) { if ((arg + num) < argc) return ; fprintf (stderr, "%s: Not enough data for %s command.\n", progName, command) ; exit (EXIT_FAILURE) ; } /* * doClear: * Clear the display ********************************************************************************* */ static int doClear (void) { scrollPhatClear () ; return 1 ; } /* * doBright ********************************************************************************* */ static int doBright (int arg, int argc, char *argv []) { checkArgs ("bright", 1, arg, argc) ; scrollPhatIntensity (atoi (argv [arg+1])) ; return 2 ; } /* * doPlot ********************************************************************************* */ static int doPlot (int arg, int argc, char *argv []) { checkArgs ("plot", 2, arg, argc) ; scrollPhatPoint (atoi (argv [arg+1]), atoi (argv [arg+2]), 1) ; scrollPhatUpdate () ; return 3 ; } /* * doLine ********************************************************************************* */ static int doLine (int arg, int argc, char *argv []) { checkArgs ("line", 4, arg, argc) ; scrollPhatLine (atoi (argv [arg+1]), atoi (argv [arg+2]), atoi (argv [arg+3]), atoi (argv [arg+4]), 1) ; scrollPhatUpdate () ; return 5 ; } /* * doLineTo ********************************************************************************* */ static int doLineTo (int arg, int argc, char *argv []) { checkArgs ("lineto", 2, arg, argc) ; scrollPhatLineTo (atoi (argv [arg+1]), atoi (argv [arg+2]), 1) ; scrollPhatUpdate () ; return 3 ; } /* * doWait ********************************************************************************* */ static int doWait (int arg, int argc, char *argv []) { checkArgs ("wait", 1, arg, argc) ; delay (atoi (argv [arg+1]) * 100) ; scrollPhatUpdate () ; return 2 ; } /* * doSpeed ********************************************************************************* */ static int doSpeed (int arg, int argc, char *argv []) { checkArgs ("speed", 1, arg, argc) ; scrollPhatPrintSpeed (atoi (argv [arg+1])) ; return 2 ; } /* * doScroll ********************************************************************************* */ static int doScroll (int arg, int argc, char *argv []) { checkArgs ("scroll", 1, arg, argc) ; scrollPhatPuts (argv [arg+1]) ; return 2 ; } static void failUsage (void) { fprintf (stderr, "Usage: %s command [paremters] ...\n", progName) ; fprintf (stderr, " commands:\n") ; fprintf (stderr, " clear/cls - Clear the display\n") ; fprintf (stderr, " bright N - Set display brightness; 1-100\n") ; fprintf (stderr, " plot X Y - Set a single pixel at location X Y; 0-10, 0-4\n") ; fprintf (stderr, " line X1 Y1 X2 Y2 - Draw a line from the 2 points\n") ; fprintf (stderr, " lineto X2 Y2 - Draw a line from the last point to the new one\n") ; fprintf (stderr, " wait/delay N - Wait for N 10ths seconds\n") ; fprintf (stderr, " speed N - Set scrolling speed (cps)\n") ; fprintf (stderr, " scroll S - Scroll the given string\n") ; fprintf (stderr, "\n") ; fprintf (stderr, " Example: %s plot 0 0 wait 50 scroll \" Hello \"\n", progName) ; exit (EXIT_FAILURE) ; } /* * the works ********************************************************************************* */ int main (int argc, char *argv []) { int arg = 1 ; char *command ; progName = argv [0] ; wiringPiSetupSys () ; if (scrollPhatSetup () != 0) { fprintf (stderr, "%s: Unable to initialise the scrollPhat: %s\n", progName, strerror (errno)) ; exit (EXIT_FAILURE) ; } progName = argv [0] ; if (argc < 2) { fprintf (stderr, "%s: Nothing to do...\n", argv [0]) ; failUsage () ; } while (arg != argc) { command = argv [arg] ; /**/ if (strcasecmp (command, "clear") == 0) arg += doClear () ; else if (strcasecmp (command, "cls") == 0) arg += doClear () ; else if (strcasecmp (command, "bright") == 0) arg += doBright (arg, argc, argv) ; else if (strcasecmp (command, "plot") == 0) arg += doPlot (arg, argc, argv) ; else if (strcasecmp (command, "line") == 0) arg += doLine (arg, argc, argv) ; else if (strcasecmp (command, "lineto") == 0) arg += doLineTo (arg, argc, argv) ; else if (strcasecmp (command, "wait") == 0) arg += doWait (arg, argc, argv) ; else if (strcasecmp (command, "delay") == 0) arg += doWait (arg, argc, argv) ; else if (strcasecmp (command, "speed") == 0) arg += doSpeed (arg, argc, argv) ; else if (strcasecmp (command, "scroll") == 0) arg += doScroll (arg, argc, argv) ; else { fprintf (stderr, "%s: Unknown command: %s.\n", argv [0], argv [arg]) ; failUsage () ; } } return 0 ; } wiringpi-2.50/examples/scrollPhat/test.c0000664000175000017500000000544013442550153020001 0ustar ubuntuubuntu/* * test.c: * Little test program forthe Pimoroni Scroll Phat. * * Copyright (c) 2015-2016 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include /* * prompt: * Simple prompt & wait ********************************************************************************* */ static void prompt (const char *p) { printf (" %s. Press ENTER: ", p) ; (void)getchar () ; } /* * the works ********************************************************************************* */ int main (void) { int x, y ; printf ("\n") ; printf ("Scroll Phat Test program\n") ; printf ("========================\n") ; if (scrollPhatSetup () != 0) { printf ("Unable to initialise the scrollPhat: %s\n", strerror (errno)) ; exit (1) ; } printf ("-> Scroll Phat initialised OK\n") ; printf ("... Basic display tests.\n\n") ; prompt ("Display ought to be blank") ; // Light all pixels using one point at a time for (y = 0 ; y < 5 ; ++y) for (x = 0 ; x < 12 ; ++x) scrollPhatPoint (x, y, 1) ; scrollPhatUpdate () ; prompt ("Display ought to be all lit-up") ; // Big rectangle scrollPhatClear () ; scrollPhatRectangle (0,0, 10, 4, 1, 0) ; scrollPhatUpdate () ; prompt ("There should now be a rectangle round the outside") ; scrollPhatLine (0,0, 10,4, 1) ; scrollPhatLine (0,4, 10,0, 1) ; scrollPhatUpdate () ; prompt ("Diagonal lines") ; scrollPhatIntensity (1) ; prompt ("Minimum brightness") ; scrollPhatIntensity (100) ; prompt ("Maximum brightness") ; scrollPhatIntensity (10) ; prompt ("Default brightness") ; scrollPhatClear () ; printf (" Message Test...Press Ctrl-C to exit: ") ; fflush (stdout) ; scrollPhatPrintSpeed (75) ; for (;;) scrollPhatPuts (" Welcome to the scroll phat from Pimoroni ") ; return 0 ; } wiringpi-2.50/examples/lowPower.c0000664000175000017500000000367513442550153016535 0ustar ubuntuubuntu/* * lowPower.c: * Check the Pi's LOW-Power signal. * * This is a demonstration program that could be turned into some sort * of logger via e.g. syslog - however it's also probably something * that might be better handled by a future kernel - who knows. * * Copyright (c) 2014 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #define LOW_POWER 35 /* * lowPower: * This is an ISR that waits for the low-power signal going low and * prints the result. ********************************************************************************* */ void lowPower (void) { time_t t ; time (&t) ; printf ("%s: LOW POWER DETECTED\n", ctime (&t)) ; } /* ********************************************************************************* * main ********************************************************************************* */ int main (void) { wiringPiSetupGpio () ; // GPIO mode as it's an internal pin wiringPiISR (LOW_POWER, INT_EDGE_FALLING, &lowPower) ; for (;;) delay (1000) ; return 0 ; } wiringpi-2.50/examples/blink6drcs.c0000664000175000017500000000555213442550153016754 0ustar ubuntuubuntu/* * blink6drcs.c: * Simple sequence over 6 pins on a remote DRC board. * Aimed at the Gertduino, but it's fairly generic. * This version uses DRC to talk to the ATmega on the Gertduino * * Copyright (c) 2012-2014 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #define GERT_BASE 100 static int pinMap [] = { GERT_BASE + 6, GERT_BASE + 5, GERT_BASE + 3, GERT_BASE + 10, GERT_BASE + 9, GERT_BASE + 13, } ; // Simple sequencer data // Triplets of LED, On/Off and delay int data [] = { 0, 1, 1, 1, 1, 1, 0, 0, 0, 2, 1, 1, 1, 0, 0, 3, 1, 1, 2, 0, 0, 4, 1, 1, 3, 0, 0, 5, 1, 1, 4, 0, 1, 5, 0, 1, 0, 0, 1, // Extra delay // Back again 5, 1, 1, 4, 1, 1, 5, 0, 0, 3, 1, 1, 4, 0, 0, 2, 1, 1, 3, 0, 0, 1, 1, 1, 2, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 1, 0, 0, 1, // Extra delay 0, 9, 0, // End marker } ; int main (void) { int pin ; int dataPtr ; int l, s, d ; printf ("Raspberry Pi - 6-LED Sequence\n") ; printf ("=============================\n") ; printf ("\n") ; printf (" Use the 2 buttons to temporarily speed up the sequence\n") ; wiringPiSetupSys () ; // Not using the Pi's GPIO here drcSetupSerial (GERT_BASE, 20, "/dev/ttyAMA0", 115200) ; for (pin = 0 ; pin < 6 ; ++pin) pinMode (pinMap [pin], OUTPUT) ; pinMode (GERT_BASE + 16, INPUT) ; // Buttons pinMode (GERT_BASE + 17, INPUT) ; pullUpDnControl (GERT_BASE + 16, PUD_UP) ; pullUpDnControl (GERT_BASE + 17, PUD_UP) ; dataPtr = 0 ; for (;;) { l = data [dataPtr++] ; // LED s = data [dataPtr++] ; // State d = data [dataPtr++] ; // Duration (10ths) if (s == 9) // 9 -> End Marker { dataPtr = 0 ; continue ; } digitalWrite (pinMap [l], s) ; delay (d * digitalRead (GERT_BASE + 16) * 15 + digitalRead (GERT_BASE + 17) * 20) ; } return 0 ; } wiringpi-2.50/examples/README.TXT0000664000175000017500000000054113442550153016076 0ustar ubuntuubuntu wiringPi Examples ================= There are now too many examples to compile them all in a sensible time, and you probably don't want to compile or run them all anyway, so they have been separated out. To compile an individual example, just type make exampleName To really compile everything: make really-all The individual tests are: wiringpi-2.50/examples/lcd-adafruit.c0000664000175000017500000001721613442550153017252 0ustar ubuntuubuntu/* * lcd-adafruit.c: * Text-based LCD driver test code * This is designed to drive the Adafruit RGB LCD Plate * with the additional 5 buttons for the Raspberry Pi * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #ifndef TRUE # define TRUE (1==1) # define FALSE (1==2) #endif // Defines for the Adafruit Pi LCD interface board #define AF_BASE 100 #define AF_RED (AF_BASE + 6) #define AF_GREEN (AF_BASE + 7) #define AF_BLUE (AF_BASE + 8) #define AF_E (AF_BASE + 13) #define AF_RW (AF_BASE + 14) #define AF_RS (AF_BASE + 15) #define AF_DB4 (AF_BASE + 12) #define AF_DB5 (AF_BASE + 11) #define AF_DB6 (AF_BASE + 10) #define AF_DB7 (AF_BASE + 9) #define AF_SELECT (AF_BASE + 0) #define AF_RIGHT (AF_BASE + 1) #define AF_DOWN (AF_BASE + 2) #define AF_UP (AF_BASE + 3) #define AF_LEFT (AF_BASE + 4) // User-Defined character test static unsigned char newChar [8] = { 0b00100, 0b00100, 0b00000, 0b00100, 0b01110, 0b11011, 0b11011, 0b10001, } ; // Global lcd handle: static int lcdHandle ; /* * usage: ********************************************************************************* */ int usage (const char *progName) { fprintf (stderr, "Usage: %s colour\n", progName) ; return EXIT_FAILURE ; } /* * scrollMessage: ********************************************************************************* */ static const char *message = " " "Wiring Pi by Gordon Henderson. HTTP://WIRINGPI.COM/" " " ; void scrollMessage (int line, int width) { char buf [32] ; static int position = 0 ; static int timer = 0 ; if (millis () < timer) return ; timer = millis () + 200 ; strncpy (buf, &message [position], width) ; buf [width] = 0 ; lcdPosition (lcdHandle, 0, line) ; lcdPuts (lcdHandle, buf) ; if (++position == (strlen (message) - width)) position = 0 ; } /* * setBacklightColour: * The colour outputs are inverted. ********************************************************************************* */ static void setBacklightColour (int colour) { colour &= 7 ; digitalWrite (AF_RED, !(colour & 1)) ; digitalWrite (AF_GREEN, !(colour & 2)) ; digitalWrite (AF_BLUE, !(colour & 4)) ; } /* * adafruitLCDSetup: * Setup the Adafruit board by making sure the additional pins are * set to the correct modes, etc. ********************************************************************************* */ static void adafruitLCDSetup (int colour) { int i ; // Backlight LEDs pinMode (AF_RED, OUTPUT) ; pinMode (AF_GREEN, OUTPUT) ; pinMode (AF_BLUE, OUTPUT) ; setBacklightColour (colour) ; // Input buttons for (i = 0 ; i <= 4 ; ++i) { pinMode (AF_BASE + i, INPUT) ; pullUpDnControl (AF_BASE + i, PUD_UP) ; // Enable pull-ups, switches close to 0v } // Control signals pinMode (AF_RW, OUTPUT) ; digitalWrite (AF_RW, LOW) ; // Not used with wiringPi - always in write mode // The other control pins are initialised with lcdInit () lcdHandle = lcdInit (2, 16, 4, AF_RS, AF_E, AF_DB4,AF_DB5,AF_DB6,AF_DB7, 0,0,0,0) ; if (lcdHandle < 0) { fprintf (stderr, "lcdInit failed\n") ; exit (EXIT_FAILURE) ; } } /* * waitForEnter: * On the Adafruit display, wait for the select button ********************************************************************************* */ static void waitForEnter (void) { printf ("Press SELECT to continue: ") ; fflush (stdout) ; while (digitalRead (AF_SELECT) == HIGH) // Wait for push delay (1) ; while (digitalRead (AF_SELECT) == LOW) // Wait for release delay (1) ; printf ("OK\n") ; } /* * speedTest: * Test the update speed of the display ********************************************************************************* */ static void speedTest (void) { unsigned int start, end, taken ; int times ; lcdClear (lcdHandle) ; start = millis () ; for (times = 0 ; times < 10 ; ++times) { lcdPuts (lcdHandle, "0123456789ABCDEF") ; lcdPuts (lcdHandle, "0123456789ABCDEF") ; } end = millis () ; taken = (end - start) / 10; lcdClear (lcdHandle) ; lcdPosition (lcdHandle, 0, 0) ; lcdPrintf (lcdHandle, "Speed: %dmS", taken) ; lcdPosition (lcdHandle, 0, 1) ; lcdPrintf (lcdHandle, "For full update") ; waitForEnter () ; lcdClear (lcdHandle) ; lcdPosition (lcdHandle, 0, 0) ; lcdPrintf (lcdHandle, "Time: %dmS", taken / 32) ; lcdPosition (lcdHandle, 0, 1) ; lcdPrintf (lcdHandle, "Per character") ; waitForEnter () ; lcdClear (lcdHandle) ; lcdPosition (lcdHandle, 0, 0) ; lcdPrintf (lcdHandle, "%d cps...", 32000 / taken) ; waitForEnter () ; } /* * The works ********************************************************************************* */ int main (int argc, char *argv[]) { int colour ; int cols = 16 ; int waitForRelease = FALSE ; struct tm *t ; time_t tim ; char buf [32] ; if (argc != 2) return usage (argv [0]) ; printf ("Raspberry Pi Adafruit LCD test\n") ; printf ("==============================\n") ; colour = atoi (argv [1]) ; wiringPiSetupSys () ; mcp23017Setup (AF_BASE, 0x20) ; adafruitLCDSetup (colour) ; lcdPosition (lcdHandle, 0, 0) ; lcdPuts (lcdHandle, "Gordon Henderson") ; lcdPosition (lcdHandle, 0, 1) ; lcdPuts (lcdHandle, " wiringpi.com ") ; waitForEnter () ; lcdPosition (lcdHandle, 0, 1) ; lcdPuts (lcdHandle, "Adafruit RGB LCD") ; waitForEnter () ; lcdCharDef (lcdHandle, 2, newChar) ; lcdClear (lcdHandle) ; lcdPosition (lcdHandle, 0, 0) ; lcdPuts (lcdHandle, "User Char: ") ; lcdPutchar (lcdHandle, 2) ; lcdCursor (lcdHandle, TRUE) ; lcdCursorBlink (lcdHandle, TRUE) ; waitForEnter () ; lcdCursor (lcdHandle, FALSE) ; lcdCursorBlink (lcdHandle, FALSE) ; speedTest () ; lcdClear (lcdHandle) ; for (;;) { scrollMessage (0, cols) ; tim = time (NULL) ; t = localtime (&tim) ; sprintf (buf, "%02d:%02d:%02d", t->tm_hour, t->tm_min, t->tm_sec) ; lcdPosition (lcdHandle, (cols - 8) / 2, 1) ; lcdPuts (lcdHandle, buf) ; // Check buttons to cycle colour // If Up or Down are still pushed, then skip if (waitForRelease) { if ((digitalRead (AF_UP) == LOW) || (digitalRead (AF_DOWN) == LOW)) continue ; else waitForRelease = FALSE ; } if (digitalRead (AF_UP) == LOW) // Pushed { colour = colour + 1 ; if (colour == 8) colour = 0 ; setBacklightColour (colour) ; waitForRelease = TRUE ; } if (digitalRead (AF_DOWN) == LOW) // Pushed { colour = colour - 1 ; if (colour == -1) colour = 7 ; setBacklightColour (colour) ; waitForRelease = TRUE ; } } return 0 ; } wiringpi-2.50/examples/nes.c0000664000175000017500000000430313442550153015471 0ustar ubuntuubuntu/* * nes.c: * Test program for an old NES controller connected to the Pi. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #define BLANK "| " int main () { int joystick ; unsigned int buttons ; if (wiringPiSetup () == -1) { fprintf (stdout, "oops: %s\n", strerror (errno)) ; return 1 ; } if ((joystick = setupNesJoystick (2, 1, 0)) == -1) { fprintf (stdout, "Unable to setup joystick\n") ; return 1 ; } for (;;) { buttons = readNesJoystick (joystick) ; if ((buttons & NES_UP) != 0) printf ("| UP " ) ; else printf (BLANK) ; if ((buttons & NES_DOWN) != 0) printf ("| DOWN " ) ; else printf (BLANK) ; if ((buttons & NES_LEFT) != 0) printf ("| LEFT " ) ; else printf (BLANK) ; if ((buttons & NES_RIGHT) != 0) printf ("|RIGHT " ) ; else printf (BLANK) ; if ((buttons & NES_SELECT) != 0) printf ("|SELECT" ) ; else printf (BLANK) ; if ((buttons & NES_START) != 0) printf ("|START " ) ; else printf (BLANK) ; if ((buttons & NES_A) != 0) printf ("| A " ) ; else printf (BLANK) ; if ((buttons & NES_B) != 0) printf ("| B " ) ; else printf (BLANK) ; printf ("|\n") ; } return 0 ; } wiringpi-2.50/examples/serialTest.c0000664000175000017500000000371313442550153017027 0ustar ubuntuubuntu/* * serialTest.c: * Very simple program to test the serial port. Expects * the port to be looped back to itself * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include int main () { int fd ; int count ; unsigned int nextTime ; if ((fd = serialOpen ("/dev/ttyAMA0", 115200)) < 0) { fprintf (stderr, "Unable to open serial device: %s\n", strerror (errno)) ; return 1 ; } if (wiringPiSetup () == -1) { fprintf (stdout, "Unable to start wiringPi: %s\n", strerror (errno)) ; return 1 ; } nextTime = millis () + 300 ; for (count = 0 ; count < 256 ; ) { if (millis () > nextTime) { printf ("\nOut: %3d: ", count) ; fflush (stdout) ; serialPutchar (fd, count) ; nextTime += 300 ; ++count ; } delay (3) ; while (serialDataAvail (fd)) { printf (" -> %3d", serialGetchar (fd)) ; fflush (stdout) ; } } printf ("\n") ; return 0 ; } wiringpi-2.50/examples/softTone.c0000664000175000017500000000276713442550153016521 0ustar ubuntuubuntu/* * softTone.c: * Test of the softTone module in wiringPi * Plays a scale out on pin 3 - connect pizeo disc to pin 3 & 0v * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #define PIN 3 int scale [8] = { 262, 294, 330, 349, 392, 440, 494, 525 } ; int main () { int i ; wiringPiSetup () ; softToneCreate (PIN) ; for (;;) { for (i = 0 ; i < 8 ; ++i) { printf ("%3d\n", i) ; softToneWrite (PIN, scale [i]) ; delay (500) ; } } } wiringpi-2.50/examples/lcd.c0000664000175000017500000001410713442550153015451 0ustar ubuntuubuntu/* * lcd.c: * Text-based LCD driver. * This is designed to drive the parallel interface LCD drivers * based in the Hitachi HD44780U controller and compatables. * * This test program assumes the following: * * 8-bit displays: * GPIO 0-7 is connected to display data pins 0-7. * GPIO 11 is the RS pin. * GPIO 10 is the Strobe/E pin. * * For 4-bit interface: * GPIO 4-7 is connected to display data pins 4-7. * GPIO 11 is the RS pin. * GPIO 10 is the Strobe/E pin. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #ifndef TRUE # define TRUE (1==1) # define FALSE (1==2) #endif static unsigned char newChar [8] = { 0b11111, 0b10001, 0b10001, 0b10101, 0b11111, 0b10001, 0b10001, 0b11111, } ; // Global lcd handle: static int lcdHandle ; /* * usage: ********************************************************************************* */ int usage (const char *progName) { fprintf (stderr, "Usage: %s bits cols rows\n", progName) ; return EXIT_FAILURE ; } /* * scrollMessage: ********************************************************************************* */ static const char *message = " " "Wiring Pi by Gordon Henderson. HTTP://WIRINGPI.COM/" " " ; void scrollMessage (int line, int width) { char buf [32] ; static int position = 0 ; static int timer = 0 ; if (millis () < timer) return ; timer = millis () + 200 ; strncpy (buf, &message [position], width) ; buf [width] = 0 ; lcdPosition (lcdHandle, 0, line) ; lcdPuts (lcdHandle, buf) ; if (++position == (strlen (message) - width)) position = 0 ; } /* * pingPong: * Bounce a character - only on 4-line displays ********************************************************************************* */ static void pingPong (int lcd, int cols) { static int position = 0 ; static int dir = 0 ; if (dir == 0) // Setup { dir = 1 ; lcdPosition (lcdHandle, 0, 3) ; lcdPutchar (lcdHandle, '*') ; return ; } lcdPosition (lcdHandle, position, 3) ; lcdPutchar (lcdHandle, ' ') ; position += dir ; if (position == cols) { dir = -1 ; --position ; } if (position < 0) { dir = 1 ; ++position ; } lcdPosition (lcdHandle, position, 3) ; lcdPutchar (lcdHandle, '#') ; } /* * waitForEnter: ********************************************************************************* */ static void waitForEnter (void) { printf ("Press ENTER to continue: ") ; (void)fgetc (stdin) ; } /* * The works ********************************************************************************* */ int main (int argc, char *argv[]) { int i ; int lcd ; int bits, rows, cols ; struct tm *t ; time_t tim ; char buf [32] ; if (argc != 4) return usage (argv [0]) ; printf ("Raspberry Pi LCD test\n") ; printf ("=====================\n") ; bits = atoi (argv [1]) ; cols = atoi (argv [2]) ; rows = atoi (argv [3]) ; if (!((rows == 1) || (rows == 2) || (rows == 4))) { fprintf (stderr, "%s: rows must be 1, 2 or 4\n", argv [0]) ; return EXIT_FAILURE ; } if (!((cols == 16) || (cols == 20))) { fprintf (stderr, "%s: cols must be 16 or 20\n", argv [0]) ; return EXIT_FAILURE ; } wiringPiSetup () ; if (bits == 4) lcdHandle = lcdInit (rows, cols, 4, 11,10, 4,5,6,7,0,0,0,0) ; else lcdHandle = lcdInit (rows, cols, 8, 11,10, 0,1,2,3,4,5,6,7) ; if (lcdHandle < 0) { fprintf (stderr, "%s: lcdInit failed\n", argv [0]) ; return -1 ; } lcdPosition (lcdHandle, 0, 0) ; lcdPuts (lcdHandle, "Gordon Henderson") ; lcdPosition (lcdHandle, 0, 1) ; lcdPuts (lcdHandle, " wiringpi.com ") ; waitForEnter () ; if (rows > 1) { lcdPosition (lcdHandle, 0, 1) ; lcdPuts (lcdHandle, " wiringpi.com ") ; if (rows == 4) { lcdPosition (lcdHandle, 0, 2) ; for (i = 0 ; i < ((cols - 1) / 2) ; ++i) lcdPuts (lcdHandle, "=-") ; lcdPuts (lcdHandle, "=3") ; lcdPosition (lcdHandle, 0, 3) ; for (i = 0 ; i < ((cols - 1) / 2) ; ++i) lcdPuts (lcdHandle, "-=") ; lcdPuts (lcdHandle, "-4") ; } } waitForEnter () ; lcdCharDef (lcdHandle, 2, newChar) ; lcdClear (lcdHandle) ; lcdPosition (lcdHandle, 0, 0) ; lcdPuts (lcdHandle, "User Char: ") ; lcdPutchar (lcdHandle, 2) ; lcdCursor (lcdHandle, TRUE) ; lcdCursorBlink (lcdHandle, TRUE) ; waitForEnter () ; lcdCursor (lcdHandle, FALSE) ; lcdCursorBlink (lcdHandle, FALSE) ; lcdClear (lcdHandle) ; for (;;) { scrollMessage (0, cols) ; if (rows == 1) continue ; tim = time (NULL) ; t = localtime (&tim) ; sprintf (buf, "%02d:%02d:%02d", t->tm_hour, t->tm_min, t->tm_sec) ; lcdPosition (lcdHandle, (cols - 8) / 2, 1) ; lcdPuts (lcdHandle, buf) ; if (rows == 2) continue ; sprintf (buf, "%02d/%02d/%04d", t->tm_mday, t->tm_mon + 1, t->tm_year+1900) ; lcdPosition (lcdHandle, (cols - 10) / 2, 2) ; lcdPuts (lcdHandle, buf) ; pingPong (lcd, cols) ; } return 0 ; } wiringpi-2.50/examples/q2w/0000775000175000017500000000000013442550153015251 5ustar ubuntuubuntuwiringpi-2.50/examples/q2w/blink.sh0000775000175000017500000000235113442550153016710 0ustar ubuntuubuntu#!/bin/sh -e # # blink.sh: # Standard "blink" program in wiringPi. Blinks an LED connected # to the LED on the Quick2Wire board # # Copyright (c) 2012-2013 Gordon Henderson. ####################################################################### # This file is part of wiringPi: # https://projects.drogon.net/raspberry-pi/wiringpi/ # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ####################################################################### # LED Pin - wiringPi pin 1 is BCM_GPIO 18. LED=1 gpio mode $LED out while true; do gpio write $LED 1 sleep 0.5 gpio write $LED 0 sleep 0.5 done wiringpi-2.50/examples/q2w/volts.c0000664000175000017500000000331113442550153016562 0ustar ubuntuubuntu/* * volts.c: * Read in all 4 analogs on the Q2W analog board. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #define LED 1 #define Q2W_ABASE 120 int main (void) { int value, pin ; // Enable the on-goard GPIO wiringPiSetup () ; pinMode (LED, OUTPUT) ; // On-board LED // Add in the pcf8591 on the q2w board pcf8591Setup (Q2W_ABASE, 0x48) ; printf ("Raspberry Pi - Quick2Wire Voltmeter\n") ; for (;;) { for (pin = 0 ; pin < 4 ; ++pin) { value = analogRead (Q2W_ABASE + pin) ; printf (" %5.2f", (double)value * 3.3 / 255.0) ; } printf ("\r") ; fflush (stdout) ; delay (100) ; digitalWrite (LED, !digitalRead (LED)) ; // Flicker the LED } return 0 ; } wiringpi-2.50/examples/q2w/Makefile0000664000175000017500000000405713442550153016717 0ustar ubuntuubuntu# # Makefile: # wiringPi - A "wiring" library for the Raspberry Pi # https://projects.drogon.net/wiring-pi # # Copyright (c) 2012-2013 Gordon Henderson ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# ifneq ($V,1) Q ?= @ endif #DEBUG = -g -O0 DEBUG = -O3 CC = gcc INCLUDE = -I/usr/local/include CFLAGS = $(DEBUG) -Wall $(INCLUDE) -Winline -pipe LDFLAGS = -L/usr/local/lib LDLIBS = -lwiringPi -lwiringPiDev -lpthread -lm ############################################################################### SRC = blink.c button.c blink-io.c volts.c bright.c OBJ = $(SRC:.c=.o) BINS = $(SRC:.c=) all: $(BINS) blink: blink.o $Q echo [link] $Q $(CC) -o $@ blink.o $(LDFLAGS) $(LDLIBS) blink-io: blink-io.o $Q echo [link] $Q $(CC) -o $@ blink-io.o $(LDFLAGS) $(LDLIBS) button: button.o $Q echo [link] $Q $(CC) -o $@ button.o $(LDFLAGS) $(LDLIBS) volts: volts.o $Q echo [link] $Q $(CC) -o $@ volts.o $(LDFLAGS) $(LDLIBS) bright: bright.o $Q echo [link] $Q $(CC) -o $@ bright.o $(LDFLAGS) $(LDLIBS) .c.o: $Q echo [CC] $< $Q $(CC) -c $(CFLAGS) $< -o $@ clean: $Q echo "[Clean]" $Q rm -f $(OBJ) *~ core tags $(BINS) tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) depend: makedepend -Y $(SRC) # DO NOT DELETE wiringpi-2.50/examples/q2w/blink.c0000664000175000017500000000262213442550153016516 0ustar ubuntuubuntu/* * blink.c: * Simple "blink" test for the Quick2Wire interface board. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #define LED 1 int main (void) { // Enable the on-goard GPIO wiringPiSetup () ; printf ("Raspberry Pi - Quick2Wire Mainboard LED Blink Test\n") ; pinMode (LED, OUTPUT) ; for (;;) { digitalWrite (LED, HIGH) ; delay (500) ; digitalWrite (LED, LOW) ; delay (500) ; } return 0 ; } wiringpi-2.50/examples/q2w/button.c0000664000175000017500000000340013442550153016725 0ustar ubuntuubuntu/* * button.c: * Simple button test for the Quick2Wire interface board. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #define BUTTON 0 #define LED1 1 #define LED2 7 int main (void) { // Enable the on-goard GPIO wiringPiSetup () ; printf ("Raspberry Pi - Quick2Wire Mainboard Button & LED Test\n") ; pinMode (BUTTON, INPUT) ; pinMode (LED1, OUTPUT) ; pinMode (LED2, OUTPUT) ; digitalWrite (LED1, HIGH) ; // On-board LED on digitalWrite (LED2, LOW) ; // 2nd LED off for (;;) { if (digitalRead (BUTTON) == HIGH) // Swap LED states { digitalWrite (LED1, LOW) ; digitalWrite (LED2, HIGH) ; while (digitalRead (BUTTON) == HIGH) delay (1) ; digitalWrite (LED1, HIGH) ; digitalWrite (LED2, LOW) ; } delay (1) ; } return 0 ; } wiringpi-2.50/examples/q2w/blink-io.c0000664000175000017500000000330713442550153017124 0ustar ubuntuubuntu/* * blink-io.c: * Simple "blink" test for the Quick2Wire 16-pin IO board. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #define LED 1 #define Q2W_BASE 100 int main (void) { // Enable the on-goard GPIO wiringPiSetup () ; // Add in the mcp23017 on the q2w board mcp23017Setup (Q2W_BASE, 0x20) ; printf ("Raspberry Pi - Quick2Wire MCP23017 Blink Test\n") ; // Blink the on-board LED as well as one on the mcp23017 pinMode (LED, OUTPUT) ; pinMode (Q2W_BASE + 0, OUTPUT) ; for (;;) { digitalWrite (LED, HIGH) ; digitalWrite (Q2W_BASE + 0, HIGH) ; delay (500) ; digitalWrite (LED, LOW) ; digitalWrite (Q2W_BASE + 0, LOW) ; delay (500) ; } return 0 ; } wiringpi-2.50/examples/q2w/binary.c0000664000175000017500000000414513442550153016705 0ustar ubuntuubuntu/* * binary.c: * Using the Quick 2 wire 16-bit GPIO expansion board to output * a binary counter. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #define Q2W_BASE 100 int main (void) { int i, bit ; // Enable the on-goard GPIO wiringPiSetup () ; // Add in the mcp23017 on the q2w board mcp23017Setup (Q2W_BASE, 0x20) ; printf ("Raspberry Pi - quite2Wire MCP23017 Test\n") ; // On-board button Input: pinMode (0, INPUT) ; // First 10 pins on q2w board as outputs: for (i = 0 ; i < 10 ; ++i) pinMode (Q2W_BASE + i, OUTPUT) ; // Last pin as an input with the internal pull-up enabled pinMode (Q2W_BASE + 15, INPUT) ; pullUpDnControl (Q2W_BASE + 15, PUD_UP) ; // Loop, outputting a binary number, // Go faster with the button, or stop if the // on-board button is pushed for (;;) { for (i = 0 ; i < 1024 ; ++i) { for (bit = 0 ; bit < 10 ; ++bit) digitalWrite (Q2W_BASE + bit, i & (1 << bit)) ; while (digitalRead (0) == HIGH) // While pushed delay (1) ; if (digitalRead (Q2W_BASE + 15) == HIGH) // Not Pushed delay (100) ; } } return 0 ; } wiringpi-2.50/examples/q2w/bright.c0000664000175000017500000000306413442550153016677 0ustar ubuntuubuntu/* * bright.c: * Vary the Q2W LED brightness with the analog card * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #define LED 1 #define Q2W_ABASE 120 int main (void) { int value ; // Enable the on-goard GPIO wiringPiSetup () ; // Add in the pcf8591 on the q2w board pcf8591Setup (Q2W_ABASE, 0x48) ; printf ("Raspberry Pi - Quick2Wire Analog Test\n") ; // Setup the LED pinMode (LED, PWM_OUTPUT) ; pwmWrite (LED, 0) ; for (;;) { value = analogRead (Q2W_ABASE + 0) ; pwmWrite (LED, value * 4) ; delay (10) ; } return 0 ; } wiringpi-2.50/examples/blink8.c0000664000175000017500000000321113442550153016070 0ustar ubuntuubuntu/* * blink8.c: * Simple sequence over the first 8 GPIO pins - LEDs * Aimed at the Gertboard, but it's fairly generic. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include int main (void) { int i, led ; printf ("Raspberry Pi - 8-LED Sequencer\n") ; printf ("==============================\n") ; printf ("\n") ; printf ("Connect LEDs to the first 8 GPIO pins and watch ...\n") ; wiringPiSetup () ; for (i = 0 ; i < 8 ; ++i) pinMode (i, OUTPUT) ; for (;;) { for (led = 0 ; led < 8 ; ++led) { digitalWrite (led, 1) ; delay (100) ; } for (led = 0 ; led < 8 ; ++led) { digitalWrite (led, 0) ; delay (100) ; } } } wiringpi-2.50/examples/blink.rtb0000664000175000017500000000224613442550153016354 0ustar ubuntuubuntu// blink.rtb: // Blink program in Return to Basic // // Copyright (c) 2012-2013 Gordon Henderson. //********************************************************************** // This file is part of wiringPi: // https://projects.drogon.net/raspberry-pi/wiringpi/ // // wiringPi is free software: you can redistribute it and/or modify // it under the terms of the GNU Lesser General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // wiringPi is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Lesser General Public License for more details. // // You should have received a copy of the GNU Lesser General Public License // along with wiringPi. If not, see . *********************************************************************** // PinMode (0, 1) // Output CYCLE DigitalWrite (0, 1) // Pin 0 ON WAIT (0.5) // 0.5 seconds DigitalWrite (0, 0) WAIT (0.5) REPEAT END wiringpi-2.50/examples/serialRead.c0000664000175000017500000000266013442550153016763 0ustar ubuntuubuntu/* * serial.c: * Example program to read bytes from the Serial line * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include int main () { int fd ; if ((fd = serialOpen ("/dev/ttyAMA0", 115200)) < 0) { fprintf (stderr, "Unable to open serial device: %s\n", strerror (errno)) ; return 1 ; } // Loop, getting and printing characters for (;;) { putchar (serialGetchar (fd)) ; fflush (stdout) ; } } wiringpi-2.50/examples/max31855.c0000664000175000017500000000352013442550153016077 0ustar ubuntuubuntu/* * max31855.c: * SPI Thermocouple interface chip * * Copyright (c) 2015 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include int main (int argc, char *argv []) { int i = 0 ; wiringPiSetup () ; max31855Setup (200, 0) ; max31855Setup (400, 1) ; for (;;) { if (i == 0) { printf ("+------+------+------+------++------+------+------+------+\n") ; printf ("| Raw | Err | C | F || Raw | Err | C | F |\n") ; printf ("+------+------+------+------++------+------+------+------+\n") ; } printf ("| %4d | %4d | %4d | %4d |", analogRead (200), analogRead (201), analogRead (202), analogRead (203)) ; printf ("| %4d | %4d | %4d | %4d |\n", analogRead (400), analogRead (401), analogRead (402), analogRead (403)) ; delay (500) ; if (++i == 10) i = 0 ; } } wiringpi-2.50/examples/delayTest.c0000664000175000017500000000473113442550153016647 0ustar ubuntuubuntu/* * delayTest.c: * Just a little test program I'm using to experiment with * various timings and latency, etc. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #define CYCLES 1000 int main() { int x ; struct timeval t1, t2, t3 ; int t ; int max, min ; int del ; int underRuns, overRuns, exactRuns, bogusRuns, total ; int descheds ; // Baseline test gettimeofday (&t1, NULL) ; gettimeofday (&t2, NULL) ; t = t2.tv_usec - t1.tv_usec ; printf ("Baseline test: %d\n", t); for (del = 1 ; del < 200 ; ++del) { underRuns = overRuns = exactRuns = total = 0 ; descheds = 0 ; max = 0 ; min = 999 ; for (x = 0 ; x < CYCLES ; ++x) { for (;;) // Repeat this if we get a delay over 999uS { // -> High probability Linux has deschedulled us gettimeofday (&t1, NULL) ; usleep (del) ; // delayMicroseconds (del) ; gettimeofday (&t2, NULL) ; timersub (&t2, &t1, &t3) ; t = t3.tv_usec ; if (t > 999) { ++descheds ; continue ; } else break ; } if (t == del) ++exactRuns ; else if (t < del) ++underRuns ; else if (t > del) ++overRuns ; if (t > max) max = t ; else if (t < min) min = t ; total += t ; } printf ("Delay: %3d. Min: %3d, Max: %3d, Unders: %3d, Overs: %3d, Exacts: %3d, Average: %3d, Descheds: %2d\n", del, min, max, underRuns, overRuns, exactRuns, total / CYCLES, descheds) ; fflush (stdout) ; usleep (1000) ; } return 0 ; } wiringpi-2.50/examples/COPYING.LESSER0000664000175000017500000001674313442550153016602 0ustar ubuntuubuntu GNU LESSER GENERAL PUBLIC LICENSE Version 3, 29 June 2007 Copyright (C) 2007 Free Software Foundation, Inc. Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below. 0. Additional Definitions. As used herein, "this License" refers to version 3 of the GNU Lesser General Public License, and the "GNU GPL" refers to version 3 of the GNU General Public License. "The Library" refers to a covered work governed by this License, other than an Application or a Combined Work as defined below. An "Application" is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library. A "Combined Work" is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the "Linked Version". The "Minimal Corresponding Source" for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version. The "Corresponding Application Code" for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work. 1. Exception to Section 3 of the GNU GPL. You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL. 2. Conveying Modified Versions. If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version: a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy. 3. Object Code Incorporating Material from Library Header Files. The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following: a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the object code with a copy of the GNU GPL and this license document. 4. Combined Works. You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following: a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the Combined Work with a copy of the GNU GPL and this license document. c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document. d) Do one of the following: 0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source. 1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version. e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.) 5. Combined Libraries. You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following: a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License. b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. 6. Revised Versions of the GNU Lesser General Public License. The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License "or any later version" applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation. If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library. wiringpi-2.50/examples/blink8-drcn.c0000664000175000017500000000343513442550153017024 0ustar ubuntuubuntu/* * blink8-drcn.c: * Simple sequence over the first 8 GPIO pins - LEDs * Aimed at the Ladder board, but it's fairly generic. * * Copyright (c) 2012-2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include int main (void) { int i, led ; printf ("Raspberry Pi - 8-LED Sequencer\n") ; printf ("==============================\n") ; printf ("\n") ; printf ("Connect LEDs to the first 8 GPIO pins and watch ...\n") ; int pinBase = 100 ; // wiringPiSetup () ; drcSetupNet (pinBase, 100, "192.168.254.21", "6124", "123456") ; for (i = 0 ; i < 8 ; ++i) pinMode (i + pinBase, OUTPUT) ; for (;;) { for (led = 0 ; led < 8 ; ++led) { digitalWrite (led + pinBase, 1) ; delay (10) ; } for (led = 0 ; led < 8 ; ++led) { digitalWrite (led + pinBase, 0) ; delay (10) ; } } } wiringpi-2.50/README.TXT0000664000175000017500000000113613442550153014261 0ustar ubuntuubuntu wiringPi README =============== Please note that the official way to get wiringPi is via git from git.drogon.net and not GitHub. ie. git clone git://git.drogon.net/wiringPi The version of wiringPi held on GitHub by "Gadgetoid" is used to build the wiringPython, Ruby, Perl, etc. wrappers for these other languages. This version may lag the official Drogon release. Pull requests may not be accepted to Github.... Please see http://wiringpi.com/ for the official documentation, etc. and the best way to submit bug reports, etc. is by sending an email to projects@drogon.net Thanks! -Gordon wiringpi-2.50/newVersion0000775000175000017500000000340313442550153015007 0ustar ubuntuubuntu#!/bin/sh -e # # newVersion: # Utility to create the version.h include file for the gpio command. # and the Debian package # # Copyright (c) 2012-2015 Gordon Henderson ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# echo Updating to version: `cat VERSION` rm -f version.h vMaj=`cut -d. -f1 VERSION` vMin=`cut -d. -f2 VERSION` echo "#define VERSION \"`cat VERSION`\"" > version.h echo "#define VERSION_MAJOR $vMaj" >> version.h echo "#define VERSION_MINOR $vMin" >> version.h rm -f debian-template/wiringPi/DEBIAN/control cat > debian-template/wiringPi/DEBIAN/control < Description: The wiringPi libraries, headers and gpio command Libraries to allow GPIO access on a Raspberry Pi from C and C++ and BASIC programs as well as from the command-line EOF wiringpi-2.50/People0000664000175000017500000000154113442550153014072 0ustar ubuntuubuntu Just a quick note to some people who've provided help, suggestions, bug-fixes, etc. along the way... Nick Lott: (And others) Hints about making it work with C++ Philipp Stefan Neininger: Minor bug in the Makefile to do with cross compiling Chris McSweeny Hints and tips about the use of arithmetic in gettimeofday() inside the dealyMicrosecondsHard() function. And spotting a couple of schoolboy errors in the (experimental) softServo code, prompting me to completely re-write it. Armin (Via projects website) Some pointers about the i2c-dev.h files. Arno Wagner Suggestions for the mmap calls in wiringPiSetup() CHARLES Thibaut: A small issue in softTone Xian Stannard Fixing some typos in the man page! Andre Crone Suggested the __WIRING_PI.H__ round wiringPi.h Rik Teerling Pointing out some silly mistooks in the I2C code... wiringpi-2.50/devLib/0000775000175000017500000000000013442550153014127 5ustar ubuntuubuntuwiringpi-2.50/devLib/ds1302.c0000664000175000017500000001335213442550153015213 0ustar ubuntuubuntu/* * ds1302.c: * Real Time clock * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include "ds1302.h" // Register defines #define RTC_SECS 0 #define RTC_MINS 1 #define RTC_HOURS 2 #define RTC_DATE 3 #define RTC_MONTH 4 #define RTC_DAY 5 #define RTC_YEAR 6 #define RTC_WP 7 #define RTC_TC 8 #define RTC_BM 31 // Locals static int dPin, cPin, sPin ; /* * dsShiftIn: * Shift a number in from the chip, LSB first. Note that the data is * sampled on the trailing edge of the last clock, so it's valid immediately. ********************************************************************************* */ static unsigned int dsShiftIn (void) { uint8_t value = 0 ; int i ; pinMode (dPin, INPUT) ; delayMicroseconds (1) ; for (i = 0 ; i < 8 ; ++i) { value |= (digitalRead (dPin) << i) ; digitalWrite (cPin, HIGH) ; delayMicroseconds (1) ; digitalWrite (cPin, LOW) ; delayMicroseconds (1) ; } return value; } /* * dsShiftOut: * A normal LSB-first shift-out, just slowed down a bit - the Pi is * a bit faster than the chip can handle. ********************************************************************************* */ static void dsShiftOut (unsigned int data) { int i ; pinMode (dPin, OUTPUT) ; for (i = 0 ; i < 8 ; ++i) { digitalWrite (dPin, data & (1 << i)) ; delayMicroseconds (1) ; digitalWrite (cPin, HIGH) ; delayMicroseconds (1) ; digitalWrite (cPin, LOW) ; delayMicroseconds (1) ; } } /* * ds1302regRead: ds1302regWrite: * Read/Write a value to an RTC Register or RAM location on the chip ********************************************************************************* */ static unsigned int ds1302regRead (const int reg) { unsigned int data ; digitalWrite (sPin, HIGH) ; delayMicroseconds (1) ; dsShiftOut (reg) ; data = dsShiftIn () ; digitalWrite (sPin, LOW) ; delayMicroseconds (1) ; return data ; } static void ds1302regWrite (const int reg, const unsigned int data) { digitalWrite (sPin, HIGH) ; delayMicroseconds (1) ; dsShiftOut (reg) ; dsShiftOut (data) ; digitalWrite (sPin, LOW) ; delayMicroseconds (1) ; } /* * ds1302rtcWrite: ds1302rtcRead: * Writes/Reads the data to/from the RTC register ********************************************************************************* */ unsigned int ds1302rtcRead (const int reg) { return ds1302regRead (0x81 | ((reg & 0x1F) << 1)) ; } void ds1302rtcWrite (int reg, unsigned int data) { ds1302regWrite (0x80 | ((reg & 0x1F) << 1), data) ; } /* * ds1302ramWrite: ds1302ramRead: * Writes/Reads the data to/from the RTC register ********************************************************************************* */ unsigned int ds1302ramRead (const int addr) { return ds1302regRead (0xC1 | ((addr & 0x1F) << 1)) ; } void ds1302ramWrite (const int addr, const unsigned int data) { ds1302regWrite ( 0xC0 | ((addr & 0x1F) << 1), data) ; } /* * ds1302clockRead: * Read all 8 bytes of the clock in a single operation ********************************************************************************* */ void ds1302clockRead (int clockData [8]) { int i ; unsigned int regVal = 0x81 | ((RTC_BM & 0x1F) << 1) ; digitalWrite (sPin, HIGH) ; delayMicroseconds (1) ; dsShiftOut (regVal) ; for (i = 0 ; i < 8 ; ++i) clockData [i] = dsShiftIn () ; digitalWrite (sPin, LOW) ; delayMicroseconds (1) ; } /* * ds1302clockWrite: * Write all 8 bytes of the clock in a single operation ********************************************************************************* */ void ds1302clockWrite (const int clockData [8]) { int i ; unsigned int regVal = 0x80 | ((RTC_BM & 0x1F) << 1) ; digitalWrite (sPin, HIGH) ; delayMicroseconds (1) ; dsShiftOut (regVal) ; for (i = 0 ; i < 8 ; ++i) dsShiftOut (clockData [i]) ; digitalWrite (sPin, LOW) ; delayMicroseconds (1) ; } /* * ds1302trickleCharge: * Set the bits on the trickle charger. * Probably best left alone... ********************************************************************************* */ void ds1302trickleCharge (const int diodes, const int resistors) { if (diodes + resistors == 0) ds1302rtcWrite (RTC_TC, 0x5C) ; // Disabled else ds1302rtcWrite (RTC_TC, 0xA0 | ((diodes & 3) << 2) | (resistors & 3)) ; } /* * ds1302setup: * Initialise the chip & remember the pins we're using ********************************************************************************* */ void ds1302setup (const int clockPin, const int dataPin, const int csPin) { dPin = dataPin ; cPin = clockPin ; sPin = csPin ; digitalWrite (dPin, LOW) ; digitalWrite (cPin, LOW) ; digitalWrite (sPin, LOW) ; pinMode (dPin, OUTPUT) ; pinMode (cPin, OUTPUT) ; pinMode (sPin, OUTPUT) ; ds1302rtcWrite (RTC_WP, 0) ; // Remove write-protect } wiringpi-2.50/devLib/piGlow.c0000664000175000017500000000564513442550153015546 0ustar ubuntuubuntu/* * piGlow.c: * Easy access to the Pimoroni PiGlow board. * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include "piGlow.h" #define PIGLOW_BASE 577 static int leg0 [6] = { 6, 7, 8, 5, 4, 9 } ; static int leg1 [6] = { 17, 16, 15, 13, 11, 10 } ; static int leg2 [6] = { 0, 1, 2, 3, 14, 12 } ; /* * piGlow1: * Light up an individual LED ********************************************************************************* */ void piGlow1 (const int leg, const int ring, const int intensity) { int *legLeds ; if ((leg < 0) || (leg > 2)) return ; if ((ring < 0) || (ring > 5)) return ; /**/ if (leg == 0) legLeds = leg0 ; else if (leg == 1) legLeds = leg1 ; else legLeds = leg2 ; analogWrite (PIGLOW_BASE + legLeds [ring], intensity) ; } /* * piGlowLeg: * Light up all 6 LEDs on a leg ********************************************************************************* */ void piGlowLeg (const int leg, const int intensity) { int i ; int *legLeds ; if ((leg < 0) || (leg > 2)) return ; /**/ if (leg == 0) legLeds = leg0 ; else if (leg == 1) legLeds = leg1 ; else legLeds = leg2 ; for (i = 0 ; i < 6 ; ++i) analogWrite (PIGLOW_BASE + legLeds [i], intensity) ; } /* * piGlowRing: * Light up 3 LEDs in a ring. Ring 0 is the outermost, 5 the innermost ********************************************************************************* */ void piGlowRing (const int ring, const int intensity) { if ((ring < 0) || (ring > 5)) return ; analogWrite (PIGLOW_BASE + leg0 [ring], intensity) ; analogWrite (PIGLOW_BASE + leg1 [ring], intensity) ; analogWrite (PIGLOW_BASE + leg2 [ring], intensity) ; } /* * piGlowSetup: * Initialise the board & remember the pins we're using ********************************************************************************* */ void piGlowSetup (int clear) { sn3218Setup (PIGLOW_BASE) ; if (clear) { piGlowLeg (0, 0) ; piGlowLeg (1, 0) ; piGlowLeg (2, 0) ; } } wiringpi-2.50/devLib/Makefile0000664000175000017500000001010613442550153015565 0ustar ubuntuubuntu# # Makefile: # wiringPi device - A "wiring" library for the Raspberry Pi # # Copyright (c) 2012-2016 Gordon Henderson ################################################################################# # This file is part of wiringPi: # https://projects.drogon.net/raspberry-pi/wiringpi/ # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# VERSION=$(shell cat ../VERSION) DESTDIR?=/usr PREFIX?=/local LDCONFIG?=ldconfig ifneq ($V,1) Q ?= @ endif STATIC=libwiringPiDev.a DYNAMIC=libwiringPiDev.so.$(VERSION) #DEBUG = -g -O0 DEBUG = -O2 INCLUDE = -I. DEFS = -D_GNU_SOURCE CFLAGS = $(DEBUG) $(DEFS) -Wformat=2 -Wall -Winline $(INCLUDE) -pipe -fPIC LIBS = ############################################################################### SRC = ds1302.c maxdetect.c piNes.c \ gertboard.c piFace.c \ lcd128x64.c lcd.c \ scrollPhat.c \ piGlow.c OBJ = $(SRC:.c=.o) HEADERS = ds1302.h gertboard.h lcd128x64.h lcd.h maxdetect.h piFace.h piGlow.h piNes.h\ scrollPhat.h all: $(DYNAMIC) static: $(STATIC) $(STATIC): $(OBJ) $Q echo "[Link (Static)]" $Q ar rcs $(STATIC) $(OBJ) $Q ranlib $(STATIC) # @size $(STATIC) $(DYNAMIC): $(OBJ) $Q echo "[Link (Dynamic)]" $Q $(CC) -shared -Wl,-soname,libwiringPiDev.so$(WIRINGPI_SONAME_SUFFIX) -o libwiringPiDev.so.$(VERSION) -lpthread $(OBJ) .c.o: $Q echo [Compile] $< $Q $(CC) -c $(CFLAGS) $< -o $@ .PHONY: clean clean: $Q echo "[Clean]" $Q rm -f $(OBJ) $(OBJ_I2C) *~ core tags Makefile.bak libwiringPiDev.* .PHONY: tags tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) .PHONY: install install: $(DYNAMIC) $Q echo "[Install Headers]" $Q install -m 0755 -d $(DESTDIR)$(PREFIX)/include $Q install -m 0644 $(HEADERS) $(DESTDIR)$(PREFIX)/include $Q echo "[Install Dynamic Lib]" $Q install -m 0755 -d $(DESTDIR)$(PREFIX)/lib $Q install -m 0755 libwiringPiDev.so.$(VERSION) $(DESTDIR)$(PREFIX)/lib/libwiringPiDev.so.$(VERSION) $Q ln -sf $(DESTDIR)$(PREFIX)/lib/libwiringPiDev.so.$(VERSION) $(DESTDIR)/lib/libwiringPiDev.so $Q $(LDCONFIG) .PHONY: install-static install-static: $(STATIC) $Q echo "[Install Headers]" $Q install -m 0755 -d $(DESTDIR)$(PREFIX)/include $Q install -m 0644 $(HEADERS) $(DESTDIR)$(PREFIX)/include $Q echo "[Install Static Lib]" $Q install -m 0755 -d $(DESTDIR)$(PREFIX)/lib $Q install -m 0755 libwiringPiDev.a $(DESTDIR)$(PREFIX)/lib .PHONY: install-deb install-deb: $(DYNAMIC) $Q echo "[Install Headers: deb]" $Q install -m 0755 -d ~/wiringPi/debian-template/wiringPi/usr/include $Q install -m 0644 $(HEADERS) ~/wiringPi/debian-template/wiringPi/usr/include $Q echo "[Install Dynamic Lib: deb]" install -m 0755 -d ~/wiringPi/debian-template/wiringPi/usr/lib install -m 0755 libwiringPiDev.so.$(VERSION) ~/wiringPi/debian-template/wiringPi/usr/lib/libwiringPiDev.so.$(VERSION) ln -sf ~/wiringPi/debian-template/wiringPi/usr/lib/libwiringPiDev.so.$(VERSION) ~/wiringPi/debian-template/wiringPi/usr/lib/libwiringPiDev.so .PHONY: uninstall uninstall: $Q echo "[UnInstall]" $Q cd $(DESTDIR)$(PREFIX)/include/ && rm -f $(HEADERS) $Q cd $(DESTDIR)$(PREFIX)/lib/ && rm -f libwiringPiDev.* $Q $(LDCONFIG) .PHONY: depend depend: makedepend -Y $(SRC) # DO NOT DELETE ds1302.o: ds1302.h maxdetect.o: maxdetect.h piNes.o: piNes.h gertboard.o: gertboard.h piFace.o: piFace.h lcd128x64.o: font.h lcd128x64.h lcd.o: lcd.h scrollPhat.o: scrollPhatFont.h scrollPhat.h piGlow.o: piGlow.h wiringpi-2.50/devLib/scrollPhat.c0000664000175000017500000002222413442550153016410 0ustar ubuntuubuntu/* * scrollPhat.c: * Simple driver for the Pimoroni Scroll Phat device * * Copyright (c) 2015 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include "scrollPhatFont.h" #include "scrollPhat.h" // Size #define SP_WIDTH 11 #define SP_HEIGHT 5 // I2C #define PHAT_I2C_ADDR 0x60 // Software copy of the framebuffer // it's 8-bit deep although the display itself is only 1-bit deep. static unsigned char frameBuffer [SP_WIDTH * SP_HEIGHT] ; static int lastX, lastY ; static int printDelayFactor ; static int scrollPhatFd ; static int putcharX ; #undef DEBUG /* * delay: * Wait for some number of milliseconds. * This taken from wiringPi as there is no-need to include the whole of * wiringPi just for the delay function. ********************************************************************************* */ static void delay (unsigned int howLong) { struct timespec sleeper, dummy ; sleeper.tv_sec = (time_t)(howLong / 1000) ; sleeper.tv_nsec = (long)(howLong % 1000) * 1000000 ; nanosleep (&sleeper, &dummy) ; } /* * scrollPhatUpdate: * Copy our software version to the real display ********************************************************************************* */ void scrollPhatUpdate (void) { register int x, y ; register unsigned char data, pixel ; unsigned char pixels [SP_WIDTH] ; #ifdef DEBUG printf ("+-----------+\n") ; for (y = 0 ; y < SP_HEIGHT ; ++y) { putchar ('|') ; for (x = 0 ; x < SP_WIDTH ; ++x) { pixel = frameBuffer [x + y * SP_WIDTH] ; putchar (pixel == 0 ? ' ' : '*') ; } printf ("|\n") ; } printf ("+-----------+\n") ; #endif for (x = 0 ; x < SP_WIDTH ; ++x) { data = 0 ; for (y = 0 ; y < SP_HEIGHT ; ++y) { pixel = frameBuffer [x + y * SP_WIDTH] ; data = (data << 1) | ((pixel == 0) ? 0 : 1) ; } pixels [x] = data ; } for (x = 0 ; x < SP_WIDTH ; ++x) wiringPiI2CWriteReg8 (scrollPhatFd, 1 + x, pixels [x]) ; wiringPiI2CWriteReg8 (scrollPhatFd, 0x0C, 0) ; } /* ********************************************************************************* * Standard Graphical Functions ********************************************************************************* */ /* * scrollPhatPoint: * Plot a pixel. Crude clipping - speed is not the essence here. ********************************************************************************* */ void scrollPhatPoint (int x, int y, int colour) { lastX = x ; lastY = y ; if ((x < 0) || (x >= SP_WIDTH) || (y < 0) || (y >= SP_HEIGHT)) return ; frameBuffer [x + y * SP_WIDTH] = colour ; } /* * scrollPhatLine: scrollPhatLineTo: * Classic Bressenham Line code - rely on the point function to do the * clipping for us here. ********************************************************************************* */ void scrollPhatLine (int x0, int y0, int x1, int y1, int colour) { int dx, dy ; int sx, sy ; int err, e2 ; lastX = x1 ; lastY = y1 ; dx = abs (x1 - x0) ; dy = abs (y1 - y0) ; sx = (x0 < x1) ? 1 : -1 ; sy = (y0 < y1) ? 1 : -1 ; err = dx - dy ; for (;;) { scrollPhatPoint (x0, y0, colour) ; if ((x0 == x1) && (y0 == y1)) break ; e2 = 2 * err ; if (e2 > -dy) { err -= dy ; x0 += sx ; } if (e2 < dx) { err += dx ; y0 += sy ; } } } void scrollPhatLineTo (int x, int y, int colour) { scrollPhatLine (lastX, lastY, x, y, colour) ; } /* * scrollPhatRectangle: * A rectangle is a spoilt days fishing ********************************************************************************* */ void scrollPhatRectangle (int x1, int y1, int x2, int y2, int colour, int filled) { register int x ; if (filled) { /**/ if (x1 == x2) scrollPhatLine (x1, y1, x2, y2, colour) ; else if (x1 < x2) for (x = x1 ; x <= x2 ; ++x) scrollPhatLine (x, y1, x, y2, colour) ; else for (x = x2 ; x <= x1 ; ++x) scrollPhatLine (x, y1, x, y2, colour) ; } else { scrollPhatLine (x1, y1, x2, y1, colour) ; scrollPhatLineTo (x2, y2, colour) ; scrollPhatLineTo (x1, y2, colour) ; scrollPhatLineTo (x1, y1, colour) ; } } /* * scrollPhatPutchar: * Print a single character to the screen then advance the pointer by an * appropriate ammount (variable width font). * We rely on the clipping done by the pixel plot function to keep us * out of trouble. * Return the width + space ********************************************************************************* */ int scrollPhatPutchar (int c) { register int x, y ; unsigned char line ; unsigned char *fontPtr ; unsigned char *p2 ; int lineWidth, width, mask ; // The font is printable characters, uppercase only... // and somewhat varaible width... c &= 0x7F ; if (c > 0x60) c -= 64 ; else c -= 32 ; fontPtr = scrollPhatFont + c * fontHeight ; // Work out width of this character // There probably is a more efficient way to do this, but... p2 = fontPtr ; width = 0 ; for (y = 0 ; y < fontHeight ; ++y) { mask = 0x80 ; for (lineWidth = 8 ; lineWidth > 0 ; --lineWidth) { if ((*p2 & mask) != 0) break ; mask >>= 1 ; } if (lineWidth > width) width = lineWidth ; ++p2 ; } if (width == 0) // Likely to be a blank or space character width = 3 ; for (y = fontHeight - 1 ; y >= 0 ; --y) { x = 0 ; line = *fontPtr++ ; for (mask = 1 << (width - 1) ; mask != 0 ; mask >>= 1) { scrollPhatPoint (putcharX + x, y, (line & mask)) ; ++x ; } } // make a line of space for (y = fontHeight - 1 ; y >= 0 ; --y) scrollPhatPoint (putcharX + width, y, 0) ; putcharX = putcharX + width + 1 ; return width + 1 ; } /* * scrollPhatPuts: * Send a string to the display - and scroll it across. * This is somewhat of a hack in that we print the entire string to the * display and let the point clipping take care of what's off-screen... ********************************************************************************* */ void scrollPhatPuts (const char *str) { int i ; int movingX = 0 ; const char *s ; int pixelLen ; // Print it once, then we know the width in pixels... putcharX = 0 ; s = str ; while (*s) scrollPhatPutchar (*s++) ; pixelLen = putcharX ; // Now scroll it by printing it and moving left one pixel movingX = 0 ; for (i = 0 ; i < pixelLen ; ++i) { putcharX = movingX ; s = str ; while (*s) scrollPhatPutchar (*s++) ; --movingX ; scrollPhatUpdate () ; delay (printDelayFactor) ; } } /* * scrollPhatPrintf: * Does what it says ********************************************************************************* */ void scrollPhatPrintf (const char *message, ...) { va_list argp ; char buffer [1024] ; va_start (argp, message) ; vsnprintf (buffer, 1023, message, argp) ; va_end (argp) ; scrollPhatPuts (buffer) ; } /* * scrollPhatPrintSpeed: * Change the print speed - mS per shift by 1 pixel ********************************************************************************* */ void scrollPhatPrintSpeed (const int pps) { if (pps < 0) printDelayFactor = 0 ; else printDelayFactor = pps ; } /* * scrollPhatClear: * Clear the display ********************************************************************************* */ void scrollPhatClear (void) { register int i ; register unsigned char *ptr = frameBuffer ; for (i = 0 ; i < (SP_WIDTH * SP_HEIGHT) ; ++i) *ptr++ = 0 ; scrollPhatUpdate () ; } /* * scrollPhatIntensity: * Set the display brightness - percentage ********************************************************************************* */ void scrollPhatIntensity (const int percent) { wiringPiI2CWriteReg8 (scrollPhatFd, 0x19, (127 * percent) / 100) ; } /* * scrollPhatSetup: * Initialise the Scroll Phat display ********************************************************************************* */ int scrollPhatSetup (void) { if ((scrollPhatFd = wiringPiI2CSetup (PHAT_I2C_ADDR)) < 0) return scrollPhatFd ; wiringPiI2CWriteReg8 (scrollPhatFd, 0x00, 0x03) ; // Enable display, set to 5x11 mode scrollPhatIntensity (10) ; scrollPhatClear () ; scrollPhatPrintSpeed (100) ; return 0 ; } wiringpi-2.50/devLib/piGlow.h0000664000175000017500000000271613442550153015547 0ustar ubuntuubuntu/* * piglow.h: * Easy access to the Pimoroni PiGlow board. * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #define PIGLOW_RED 0 #define PIGLOW_ORANGE 1 #define PIGLOW_YELLOW 2 #define PIGLOW_GREEN 3 #define PIGLOW_BLUE 4 #define PIGLOW_WHITE 5 #ifdef __cplusplus extern "C" { #endif extern void piGlow1 (const int leg, const int ring, const int intensity) ; extern void piGlowLeg (const int leg, const int intensity) ; extern void piGlowRing (const int ring, const int intensity) ; extern void piGlowSetup (int clear) ; #ifdef __cplusplus } #endif wiringpi-2.50/devLib/font.h0000664000175000017500000015440613442550153015260 0ustar ubuntuubuntu/**********************************************/ /* */ /* Font file generated by cpi2fnt */ /* ------------------------------ */ /* Combined with the alpha-numeric */ /* portion of Greg Harp's old PEARL */ /* font (from earlier versions of */ /* linux-m86k) by John Shifflett */ /* */ /**********************************************/ static const int fontHeight = 8 ; static const int fontWidth = 8 ; static unsigned char font [] = { /* 0 0x00 '^@' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 1 0x01 '^A' */ 0x7e, /* 01111110 */ 0x81, /* 10000001 */ 0xa5, /* 10100101 */ 0x81, /* 10000001 */ 0xbd, /* 10111101 */ 0x99, /* 10011001 */ 0x81, /* 10000001 */ 0x7e, /* 01111110 */ /* 2 0x02 '^B' */ 0x7e, /* 01111110 */ 0xff, /* 11111111 */ 0xdb, /* 11011011 */ 0xff, /* 11111111 */ 0xc3, /* 11000011 */ 0xe7, /* 11100111 */ 0xff, /* 11111111 */ 0x7e, /* 01111110 */ /* 3 0x03 '^C' */ 0x6c, /* 01101100 */ 0xfe, /* 11111110 */ 0xfe, /* 11111110 */ 0xfe, /* 11111110 */ 0x7c, /* 01111100 */ 0x38, /* 00111000 */ 0x10, /* 00010000 */ 0x00, /* 00000000 */ /* 4 0x04 '^D' */ 0x10, /* 00010000 */ 0x38, /* 00111000 */ 0x7c, /* 01111100 */ 0xfe, /* 11111110 */ 0x7c, /* 01111100 */ 0x38, /* 00111000 */ 0x10, /* 00010000 */ 0x00, /* 00000000 */ /* 5 0x05 '^E' */ 0x38, /* 00111000 */ 0x7c, /* 01111100 */ 0x38, /* 00111000 */ 0xfe, /* 11111110 */ 0xfe, /* 11111110 */ 0xd6, /* 11010110 */ 0x10, /* 00010000 */ 0x38, /* 00111000 */ /* 6 0x06 '^F' */ 0x10, /* 00010000 */ 0x38, /* 00111000 */ 0x7c, /* 01111100 */ 0xfe, /* 11111110 */ 0xfe, /* 11111110 */ 0x7c, /* 01111100 */ 0x10, /* 00010000 */ 0x38, /* 00111000 */ /* 7 0x07 '^G' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 8 0x08 '^H' */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xe7, /* 11100111 */ 0xc3, /* 11000011 */ 0xc3, /* 11000011 */ 0xe7, /* 11100111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ /* 9 0x09 '^I' */ 0x00, /* 00000000 */ 0x3c, /* 00111100 */ 0x66, /* 01100110 */ 0x42, /* 01000010 */ 0x42, /* 01000010 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x00, /* 00000000 */ /* 10 0x0a '^J' */ 0xff, /* 11111111 */ 0xc3, /* 11000011 */ 0x99, /* 10011001 */ 0xbd, /* 10111101 */ 0xbd, /* 10111101 */ 0x99, /* 10011001 */ 0xc3, /* 11000011 */ 0xff, /* 11111111 */ /* 11 0x0b '^K' */ 0x0f, /* 00001111 */ 0x07, /* 00000111 */ 0x0f, /* 00001111 */ 0x7d, /* 01111101 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0x78, /* 01111000 */ /* 12 0x0c '^L' */ 0x3c, /* 00111100 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ /* 13 0x0d '^M' */ 0x3f, /* 00111111 */ 0x33, /* 00110011 */ 0x3f, /* 00111111 */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x70, /* 01110000 */ 0xf0, /* 11110000 */ 0xe0, /* 11100000 */ /* 14 0x0e '^N' */ 0x7f, /* 01111111 */ 0x63, /* 01100011 */ 0x7f, /* 01111111 */ 0x63, /* 01100011 */ 0x63, /* 01100011 */ 0x67, /* 01100111 */ 0xe6, /* 11100110 */ 0xc0, /* 11000000 */ /* 15 0x0f '^O' */ 0x18, /* 00011000 */ 0xdb, /* 11011011 */ 0x3c, /* 00111100 */ 0xe7, /* 11100111 */ 0xe7, /* 11100111 */ 0x3c, /* 00111100 */ 0xdb, /* 11011011 */ 0x18, /* 00011000 */ /* 16 0x10 '^P' */ 0x80, /* 10000000 */ 0xe0, /* 11100000 */ 0xf8, /* 11111000 */ 0xfe, /* 11111110 */ 0xf8, /* 11111000 */ 0xe0, /* 11100000 */ 0x80, /* 10000000 */ 0x00, /* 00000000 */ /* 17 0x11 '^Q' */ 0x02, /* 00000010 */ 0x0e, /* 00001110 */ 0x3e, /* 00111110 */ 0xfe, /* 11111110 */ 0x3e, /* 00111110 */ 0x0e, /* 00001110 */ 0x02, /* 00000010 */ 0x00, /* 00000000 */ /* 18 0x12 '^R' */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ /* 19 0x13 '^S' */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x00, /* 00000000 */ 0x66, /* 01100110 */ 0x00, /* 00000000 */ /* 20 0x14 '^T' */ 0x7f, /* 01111111 */ 0xdb, /* 11011011 */ 0xdb, /* 11011011 */ 0x7b, /* 01111011 */ 0x1b, /* 00011011 */ 0x1b, /* 00011011 */ 0x1b, /* 00011011 */ 0x00, /* 00000000 */ /* 21 0x15 '^U' */ 0x3e, /* 00111110 */ 0x61, /* 01100001 */ 0x3c, /* 00111100 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x86, /* 10000110 */ 0x7c, /* 01111100 */ /* 22 0x16 '^V' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x7e, /* 01111110 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ /* 23 0x17 '^W' */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0xff, /* 11111111 */ /* 24 0x18 '^X' */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 25 0x19 '^Y' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 26 0x1a '^Z' */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0xfe, /* 11111110 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 27 0x1b '^[' */ 0x00, /* 00000000 */ 0x30, /* 00110000 */ 0x60, /* 01100000 */ 0xfe, /* 11111110 */ 0x60, /* 01100000 */ 0x30, /* 00110000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 28 0x1c '^\' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 29 0x1d '^]' */ 0x00, /* 00000000 */ 0x24, /* 00100100 */ 0x66, /* 01100110 */ 0xff, /* 11111111 */ 0x66, /* 01100110 */ 0x24, /* 00100100 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 30 0x1e '^^' */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x7e, /* 01111110 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 31 0x1f '^_' */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0x7e, /* 01111110 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 32 0x20 ' ' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 33 0x21 '!' */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x3c, /* 00111100 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 34 0x22 '"' */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 35 0x23 '#' */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0xfe, /* 11111110 */ 0x6c, /* 01101100 */ 0xfe, /* 11111110 */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0x00, /* 00000000 */ /* 36 0x24 '$' */ 0x18, /* 00011000 */ 0x3e, /* 00111110 */ 0x60, /* 01100000 */ 0x3c, /* 00111100 */ 0x06, /* 00000110 */ 0x7c, /* 01111100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 37 0x25 '%' */ 0x00, /* 00000000 */ 0xc6, /* 11000110 */ 0xcc, /* 11001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x66, /* 01100110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 38 0x26 '&' */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0x68, /* 01101000 */ 0x76, /* 01110110 */ 0xdc, /* 11011100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 39 0x27 ''' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 40 0x28 '(' */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0x00, /* 00000000 */ /* 41 0x29 ')' */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0x0c, /* 00001100 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x00, /* 00000000 */ /* 42 0x2a '*' */ 0x00, /* 00000000 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0xff, /* 11111111 */ 0x3c, /* 00111100 */ 0x66, /* 01100110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 43 0x2b '+' */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 44 0x2c ',' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ /* 45 0x2d '-' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 46 0x2e '.' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 47 0x2f '/' */ 0x03, /* 00000011 */ 0x06, /* 00000110 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x60, /* 01100000 */ 0xc0, /* 11000000 */ 0x00, /* 00000000 */ /* 48 0x30 '0' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xde, /* 11011110 */ 0xfe, /* 11111110 */ 0xf6, /* 11110110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 49 0x31 '1' */ 0x18, /* 00011000 */ 0x78, /* 01111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 50 0x32 '2' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x60, /* 01100000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ /* 51 0x33 '3' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0x06, /* 00000110 */ 0x1c, /* 00011100 */ 0x06, /* 00000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 52 0x34 '4' */ 0x1c, /* 00011100 */ 0x3c, /* 00111100 */ 0x6c, /* 01101100 */ 0xcc, /* 11001100 */ 0xfe, /* 11111110 */ 0x0c, /* 00001100 */ 0x0c, /* 00001100 */ 0x00, /* 00000000 */ /* 53 0x35 '5' */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0xfc, /* 11111100 */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 54 0x36 '6' */ 0x38, /* 00111000 */ 0x60, /* 01100000 */ 0xc0, /* 11000000 */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 55 0x37 '7' */ 0xfe, /* 11111110 */ 0x06, /* 00000110 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x60, /* 01100000 */ 0x60, /* 01100000 */ 0x00, /* 00000000 */ /* 56 0x38 '8' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 57 0x39 '9' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7e, /* 01111110 */ 0x06, /* 00000110 */ 0x0c, /* 00001100 */ 0x38, /* 00111000 */ 0x00, /* 00000000 */ /* 58 0x3a ':' */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 59 0x3b ';' */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ /* 60 0x3c '<' */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x60, /* 01100000 */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0x00, /* 00000000 */ /* 61 0x3d '=' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 62 0x3e '>' */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0x06, /* 00000110 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x00, /* 00000000 */ /* 63 0x3f '?' */ 0x3c, /* 00111100 */ 0x66, /* 01100110 */ 0x06, /* 00000110 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 64 0x40 '@' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xde, /* 11011110 */ 0xde, /* 11011110 */ 0xde, /* 11011110 */ 0xc0, /* 11000000 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 65 0x41 'A' */ 0x10, /* 00010000 */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 66 0x42 'B' */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xfc, /* 11111100 */ 0x00, /* 00000000 */ /* 67 0x43 'C' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 68 0x44 'D' */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xfc, /* 11111100 */ 0x00, /* 00000000 */ /* 69 0x45 'E' */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xf8, /* 11111000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ /* 70 0x46 'F' */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xf8, /* 11111000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0x00, /* 00000000 */ /* 71 0x47 'G' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc0, /* 11000000 */ 0xce, /* 11001110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 72 0x48 'H' */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 73 0x49 'I' */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ /* 74 0x4a 'J' */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 75 0x4b 'K' */ 0xc6, /* 11000110 */ 0xcc, /* 11001100 */ 0xd8, /* 11011000 */ 0xf0, /* 11110000 */ 0xd8, /* 11011000 */ 0xcc, /* 11001100 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 76 0x4c 'L' */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ /* 77 0x4d 'M' */ 0x82, /* 10000010 */ 0xc6, /* 11000110 */ 0xee, /* 11101110 */ 0xfe, /* 11111110 */ 0xd6, /* 11010110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 78 0x4e 'N' */ 0xc6, /* 11000110 */ 0xe6, /* 11100110 */ 0xf6, /* 11110110 */ 0xde, /* 11011110 */ 0xce, /* 11001110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 79 0x4f 'O' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 80 0x50 'P' */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xfc, /* 11111100 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0x00, /* 00000000 */ /* 81 0x51 'Q' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xf6, /* 11110110 */ 0xde, /* 11011110 */ 0x7c, /* 01111100 */ 0x06, /* 00000110 */ /* 82 0x52 'R' */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xfc, /* 11111100 */ 0xd8, /* 11011000 */ 0xcc, /* 11001100 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 83 0x53 'S' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0x60, /* 01100000 */ 0x38, /* 00111000 */ 0x0c, /* 00001100 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 84 0x54 'T' */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 85 0x55 'U' */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 86 0x56 'V' */ 0xc3, /* 11000011 */ 0xc3, /* 11000011 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 87 0x57 'W' */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xd6, /* 11010110 */ 0xfe, /* 11111110 */ 0xee, /* 11101110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 88 0x58 'X' */ 0xc3, /* 11000011 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x66, /* 01100110 */ 0xc3, /* 11000011 */ 0x00, /* 00000000 */ /* 89 0x59 'Y' */ 0xc3, /* 11000011 */ 0xc3, /* 11000011 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 90 0x5a 'Z' */ 0xfe, /* 11111110 */ 0x06, /* 00000110 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x60, /* 01100000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ /* 91 0x5b '[' */ 0x3c, /* 00111100 */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x3c, /* 00111100 */ 0x00, /* 00000000 */ /* 92 0x5c '\' */ 0xc0, /* 11000000 */ 0x60, /* 01100000 */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0x06, /* 00000110 */ 0x03, /* 00000011 */ 0x00, /* 00000000 */ /* 93 0x5d ']' */ 0x3c, /* 00111100 */ 0x0c, /* 00001100 */ 0x0c, /* 00001100 */ 0x0c, /* 00001100 */ 0x0c, /* 00001100 */ 0x0c, /* 00001100 */ 0x3c, /* 00111100 */ 0x00, /* 00000000 */ /* 94 0x5e '^' */ 0x10, /* 00010000 */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 95 0x5f '_' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ /* 96 0x60 '`' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 97 0x61 'a' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7c, /* 01111100 */ 0x06, /* 00000110 */ 0x7e, /* 01111110 */ 0xc6, /* 11000110 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ /* 98 0x62 'b' */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xfc, /* 11111100 */ 0x00, /* 00000000 */ /* 99 0x63 'c' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc0, /* 11000000 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 100 0x64 'd' */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ 0x7e, /* 01111110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ /* 101 0x65 'e' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 102 0x66 'f' */ 0x3c, /* 00111100 */ 0x66, /* 01100110 */ 0x60, /* 01100000 */ 0xf0, /* 11110000 */ 0x60, /* 01100000 */ 0x60, /* 01100000 */ 0x60, /* 01100000 */ 0x00, /* 00000000 */ /* 103 0x67 'g' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7e, /* 01111110 */ 0x06, /* 00000110 */ 0x7c, /* 01111100 */ /* 104 0x68 'h' */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 105 0x69 'i' */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x38, /* 00111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 106 0x6a 'j' */ 0x06, /* 00000110 */ 0x00, /* 00000000 */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ /* 107 0x6b 'k' */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xcc, /* 11001100 */ 0xd8, /* 11011000 */ 0xf0, /* 11110000 */ 0xd8, /* 11011000 */ 0xcc, /* 11001100 */ 0x00, /* 00000000 */ /* 108 0x6c 'l' */ 0x38, /* 00111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 109 0x6d 'm' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xec, /* 11101100 */ 0xfe, /* 11111110 */ 0xd6, /* 11010110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 110 0x6e 'n' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 111 0x6f 'o' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 112 0x70 'p' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xfc, /* 11111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xfc, /* 11111100 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ /* 113 0x71 'q' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7e, /* 01111110 */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ /* 114 0x72 'r' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xdc, /* 11011100 */ 0xe6, /* 11100110 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0x00, /* 00000000 */ /* 115 0x73 's' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0xc0, /* 11000000 */ 0x7c, /* 01111100 */ 0x06, /* 00000110 */ 0xfc, /* 11111100 */ 0x00, /* 00000000 */ /* 116 0x74 't' */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x7c, /* 01111100 */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x36, /* 00110110 */ 0x1c, /* 00011100 */ 0x00, /* 00000000 */ /* 117 0x75 'u' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 118 0x76 'v' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x6c, /* 01101100 */ 0x38, /* 00111000 */ 0x00, /* 00000000 */ /* 119 0x77 'w' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xd6, /* 11010110 */ 0xfe, /* 11111110 */ 0x6c, /* 01101100 */ 0x00, /* 00000000 */ /* 120 0x78 'x' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xc6, /* 11000110 */ 0x6c, /* 01101100 */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 121 0x79 'y' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xc3, /* 11000011 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x60, /* 01100000 */ /* 122 0x7a 'z' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ 0x0c, /* 00001100 */ 0x38, /* 00111000 */ 0x60, /* 01100000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ /* 123 0x7b '{' */ 0x0e, /* 00001110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x70, /* 01110000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x0e, /* 00001110 */ 0x00, /* 00000000 */ /* 124 0x7c '|' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 125 0x7d '}' */ 0x70, /* 01110000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x0e, /* 00001110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x70, /* 01110000 */ 0x00, /* 00000000 */ /* 126 0x7e '~' */ 0x72, /* 01110010 */ 0x9c, /* 10011100 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 127 0x7f '' */ 0x00, /* 00000000 */ 0x10, /* 00010000 */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ /* 128 0x80 '' */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x0c, /* 00001100 */ 0x78, /* 01111000 */ /* 129 0x81 '' */ 0xcc, /* 11001100 */ 0x00, /* 00000000 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 130 0x82 '' */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 131 0x83 '' */ 0x7c, /* 01111100 */ 0x82, /* 10000010 */ 0x78, /* 01111000 */ 0x0c, /* 00001100 */ 0x7c, /* 01111100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 132 0x84 '' */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ 0x78, /* 01111000 */ 0x0c, /* 00001100 */ 0x7c, /* 01111100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 133 0x85 '' */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x78, /* 01111000 */ 0x0c, /* 00001100 */ 0x7c, /* 01111100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 134 0x86 '' */ 0x30, /* 00110000 */ 0x30, /* 00110000 */ 0x78, /* 01111000 */ 0x0c, /* 00001100 */ 0x7c, /* 01111100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 135 0x87 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0x7e, /* 01111110 */ 0x0c, /* 00001100 */ 0x38, /* 00111000 */ /* 136 0x88 '' */ 0x7c, /* 01111100 */ 0x82, /* 10000010 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 137 0x89 '' */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 138 0x8a '' */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 139 0x8b '' */ 0x66, /* 01100110 */ 0x00, /* 00000000 */ 0x38, /* 00111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x00, /* 00000000 */ /* 140 0x8c '' */ 0x7c, /* 01111100 */ 0x82, /* 10000010 */ 0x38, /* 00111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x00, /* 00000000 */ /* 141 0x8d '' */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x38, /* 00111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x00, /* 00000000 */ /* 142 0x8e '' */ 0xc6, /* 11000110 */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 143 0x8f '' */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 144 0x90 '' */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0xf8, /* 11111000 */ 0xc0, /* 11000000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ /* 145 0x91 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0xd8, /* 11011000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ /* 146 0x92 '' */ 0x3e, /* 00111110 */ 0x6c, /* 01101100 */ 0xcc, /* 11001100 */ 0xfe, /* 11111110 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xce, /* 11001110 */ 0x00, /* 00000000 */ /* 147 0x93 '' */ 0x7c, /* 01111100 */ 0x82, /* 10000010 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 148 0x94 '' */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 149 0x95 '' */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 150 0x96 '' */ 0x78, /* 01111000 */ 0x84, /* 10000100 */ 0x00, /* 00000000 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 151 0x97 '' */ 0x60, /* 01100000 */ 0x30, /* 00110000 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 152 0x98 '' */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7e, /* 01111110 */ 0x06, /* 00000110 */ 0xfc, /* 11111100 */ /* 153 0x99 '' */ 0xc6, /* 11000110 */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x6c, /* 01101100 */ 0x38, /* 00111000 */ 0x00, /* 00000000 */ /* 154 0x9a '' */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 155 0x9b '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 156 0x9c '' */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0x64, /* 01100100 */ 0xf0, /* 11110000 */ 0x60, /* 01100000 */ 0x66, /* 01100110 */ 0xfc, /* 11111100 */ 0x00, /* 00000000 */ /* 157 0x9d '' */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 158 0x9e '' */ 0xf8, /* 11111000 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xfa, /* 11111010 */ 0xc6, /* 11000110 */ 0xcf, /* 11001111 */ 0xc6, /* 11000110 */ 0xc7, /* 11000111 */ /* 159 0x9f '' */ 0x0e, /* 00001110 */ 0x1b, /* 00011011 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0xd8, /* 11011000 */ 0x70, /* 01110000 */ 0x00, /* 00000000 */ /* 160 0xa0 '' */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x78, /* 01111000 */ 0x0c, /* 00001100 */ 0x7c, /* 01111100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 161 0xa1 '' */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x38, /* 00111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x00, /* 00000000 */ /* 162 0xa2 '' */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ /* 163 0xa3 '' */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 164 0xa4 '' */ 0x76, /* 01110110 */ 0xdc, /* 11011100 */ 0x00, /* 00000000 */ 0xdc, /* 11011100 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x00, /* 00000000 */ /* 165 0xa5 '' */ 0x76, /* 01110110 */ 0xdc, /* 11011100 */ 0x00, /* 00000000 */ 0xe6, /* 11100110 */ 0xf6, /* 11110110 */ 0xde, /* 11011110 */ 0xce, /* 11001110 */ 0x00, /* 00000000 */ /* 166 0xa6 '' */ 0x3c, /* 00111100 */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0x3e, /* 00111110 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 167 0xa7 '' */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0x38, /* 00111000 */ 0x00, /* 00000000 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 168 0xa8 '' */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x63, /* 01100011 */ 0x3e, /* 00111110 */ 0x00, /* 00000000 */ /* 169 0xa9 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 170 0xaa '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ 0x06, /* 00000110 */ 0x06, /* 00000110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 171 0xab '' */ 0x63, /* 01100011 */ 0xe6, /* 11100110 */ 0x6c, /* 01101100 */ 0x7e, /* 01111110 */ 0x33, /* 00110011 */ 0x66, /* 01100110 */ 0xcc, /* 11001100 */ 0x0f, /* 00001111 */ /* 172 0xac '' */ 0x63, /* 01100011 */ 0xe6, /* 11100110 */ 0x6c, /* 01101100 */ 0x7a, /* 01111010 */ 0x36, /* 00110110 */ 0x6a, /* 01101010 */ 0xdf, /* 11011111 */ 0x06, /* 00000110 */ /* 173 0xad '' */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 174 0xae '' */ 0x00, /* 00000000 */ 0x33, /* 00110011 */ 0x66, /* 01100110 */ 0xcc, /* 11001100 */ 0x66, /* 01100110 */ 0x33, /* 00110011 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 175 0xaf '' */ 0x00, /* 00000000 */ 0xcc, /* 11001100 */ 0x66, /* 01100110 */ 0x33, /* 00110011 */ 0x66, /* 01100110 */ 0xcc, /* 11001100 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 176 0xb0 '' */ 0x22, /* 00100010 */ 0x88, /* 10001000 */ 0x22, /* 00100010 */ 0x88, /* 10001000 */ 0x22, /* 00100010 */ 0x88, /* 10001000 */ 0x22, /* 00100010 */ 0x88, /* 10001000 */ /* 177 0xb1 '' */ 0x55, /* 01010101 */ 0xaa, /* 10101010 */ 0x55, /* 01010101 */ 0xaa, /* 10101010 */ 0x55, /* 01010101 */ 0xaa, /* 10101010 */ 0x55, /* 01010101 */ 0xaa, /* 10101010 */ /* 178 0xb2 '' */ 0x77, /* 01110111 */ 0xdd, /* 11011101 */ 0x77, /* 01110111 */ 0xdd, /* 11011101 */ 0x77, /* 01110111 */ 0xdd, /* 11011101 */ 0x77, /* 01110111 */ 0xdd, /* 11011101 */ /* 179 0xb3 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 180 0xb4 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0xf8, /* 11111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 181 0xb5 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0xf8, /* 11111000 */ 0x18, /* 00011000 */ 0xf8, /* 11111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 182 0xb6 '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0xf6, /* 11110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 183 0xb7 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 184 0xb8 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xf8, /* 11111000 */ 0x18, /* 00011000 */ 0xf8, /* 11111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 185 0xb9 '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0xf6, /* 11110110 */ 0x06, /* 00000110 */ 0xf6, /* 11110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 186 0xba '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 187 0xbb '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ 0x06, /* 00000110 */ 0xf6, /* 11110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 188 0xbc '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0xf6, /* 11110110 */ 0x06, /* 00000110 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 189 0xbd '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 190 0xbe '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0xf8, /* 11111000 */ 0x18, /* 00011000 */ 0xf8, /* 11111000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 191 0xbf '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xf8, /* 11111000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 192 0xc0 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x1f, /* 00011111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 193 0xc1 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 194 0xc2 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 195 0xc3 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x1f, /* 00011111 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 196 0xc4 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 197 0xc5 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0xff, /* 11111111 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 198 0xc6 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x1f, /* 00011111 */ 0x18, /* 00011000 */ 0x1f, /* 00011111 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 199 0xc7 '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x37, /* 00110111 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 200 0xc8 '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x37, /* 00110111 */ 0x30, /* 00110000 */ 0x3f, /* 00111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 201 0xc9 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x3f, /* 00111111 */ 0x30, /* 00110000 */ 0x37, /* 00110111 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 202 0xca '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0xf7, /* 11110111 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 203 0xcb '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0xf7, /* 11110111 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 204 0xcc '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x37, /* 00110111 */ 0x30, /* 00110000 */ 0x37, /* 00110111 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 205 0xcd '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 206 0xce '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0xf7, /* 11110111 */ 0x00, /* 00000000 */ 0xf7, /* 11110111 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 207 0xcf '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 208 0xd0 '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 209 0xd1 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 210 0xd2 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 211 0xd3 '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x3f, /* 00111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 212 0xd4 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x1f, /* 00011111 */ 0x18, /* 00011000 */ 0x1f, /* 00011111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 213 0xd5 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x1f, /* 00011111 */ 0x18, /* 00011000 */ 0x1f, /* 00011111 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 214 0xd6 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x3f, /* 00111111 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 215 0xd7 '' */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0xff, /* 11111111 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ /* 216 0xd8 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0xff, /* 11111111 */ 0x18, /* 00011000 */ 0xff, /* 11111111 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 217 0xd9 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0xf8, /* 11111000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 218 0xda '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x1f, /* 00011111 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 219 0xdb '' */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ /* 220 0xdc '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ /* 221 0xdd '' */ 0xf0, /* 11110000 */ 0xf0, /* 11110000 */ 0xf0, /* 11110000 */ 0xf0, /* 11110000 */ 0xf0, /* 11110000 */ 0xf0, /* 11110000 */ 0xf0, /* 11110000 */ 0xf0, /* 11110000 */ /* 222 0xde '' */ 0x0f, /* 00001111 */ 0x0f, /* 00001111 */ 0x0f, /* 00001111 */ 0x0f, /* 00001111 */ 0x0f, /* 00001111 */ 0x0f, /* 00001111 */ 0x0f, /* 00001111 */ 0x0f, /* 00001111 */ /* 223 0xdf '' */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0xff, /* 11111111 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 224 0xe0 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x76, /* 01110110 */ 0xdc, /* 11011100 */ 0xc8, /* 11001000 */ 0xdc, /* 11011100 */ 0x76, /* 01110110 */ 0x00, /* 00000000 */ /* 225 0xe1 '' */ 0x78, /* 01111000 */ 0xcc, /* 11001100 */ 0xcc, /* 11001100 */ 0xd8, /* 11011000 */ 0xcc, /* 11001100 */ 0xc6, /* 11000110 */ 0xcc, /* 11001100 */ 0x00, /* 00000000 */ /* 226 0xe2 '' */ 0xfe, /* 11111110 */ 0xc6, /* 11000110 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0xc0, /* 11000000 */ 0x00, /* 00000000 */ /* 227 0xe3 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0x00, /* 00000000 */ /* 228 0xe4 '' */ 0xfe, /* 11111110 */ 0xc6, /* 11000110 */ 0x60, /* 01100000 */ 0x30, /* 00110000 */ 0x60, /* 01100000 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ /* 229 0xe5 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0xd8, /* 11011000 */ 0xd8, /* 11011000 */ 0xd8, /* 11011000 */ 0x70, /* 01110000 */ 0x00, /* 00000000 */ /* 230 0xe6 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x7c, /* 01111100 */ 0xc0, /* 11000000 */ /* 231 0xe7 '' */ 0x00, /* 00000000 */ 0x76, /* 01110110 */ 0xdc, /* 11011100 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ /* 232 0xe8 '' */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x3c, /* 00111100 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ /* 233 0xe9 '' */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0xc6, /* 11000110 */ 0xfe, /* 11111110 */ 0xc6, /* 11000110 */ 0x6c, /* 01101100 */ 0x38, /* 00111000 */ 0x00, /* 00000000 */ /* 234 0xea '' */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0xee, /* 11101110 */ 0x00, /* 00000000 */ /* 235 0xeb '' */ 0x0e, /* 00001110 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0x3e, /* 00111110 */ 0x66, /* 01100110 */ 0x66, /* 01100110 */ 0x3c, /* 00111100 */ 0x00, /* 00000000 */ /* 236 0xec '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0xdb, /* 11011011 */ 0xdb, /* 11011011 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 237 0xed '' */ 0x06, /* 00000110 */ 0x0c, /* 00001100 */ 0x7e, /* 01111110 */ 0xdb, /* 11011011 */ 0xdb, /* 11011011 */ 0x7e, /* 01111110 */ 0x60, /* 01100000 */ 0xc0, /* 11000000 */ /* 238 0xee '' */ 0x1e, /* 00011110 */ 0x30, /* 00110000 */ 0x60, /* 01100000 */ 0x7e, /* 01111110 */ 0x60, /* 01100000 */ 0x30, /* 00110000 */ 0x1e, /* 00011110 */ 0x00, /* 00000000 */ /* 239 0xef '' */ 0x00, /* 00000000 */ 0x7c, /* 01111100 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0xc6, /* 11000110 */ 0x00, /* 00000000 */ /* 240 0xf0 '' */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ 0xfe, /* 11111110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 241 0xf1 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x7e, /* 01111110 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ /* 242 0xf2 '' */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ /* 243 0xf3 '' */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x18, /* 00011000 */ 0x0c, /* 00001100 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ /* 244 0xf4 '' */ 0x0e, /* 00001110 */ 0x1b, /* 00011011 */ 0x1b, /* 00011011 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ /* 245 0xf5 '' */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0xd8, /* 11011000 */ 0xd8, /* 11011000 */ 0x70, /* 01110000 */ /* 246 0xf6 '' */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x7e, /* 01111110 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 247 0xf7 '' */ 0x00, /* 00000000 */ 0x76, /* 01110110 */ 0xdc, /* 11011100 */ 0x00, /* 00000000 */ 0x76, /* 01110110 */ 0xdc, /* 11011100 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 248 0xf8 '' */ 0x38, /* 00111000 */ 0x6c, /* 01101100 */ 0x6c, /* 01101100 */ 0x38, /* 00111000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 249 0xf9 '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 250 0xfa '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x18, /* 00011000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 251 0xfb '' */ 0x0f, /* 00001111 */ 0x0c, /* 00001100 */ 0x0c, /* 00001100 */ 0x0c, /* 00001100 */ 0xec, /* 11101100 */ 0x6c, /* 01101100 */ 0x3c, /* 00111100 */ 0x1c, /* 00011100 */ /* 252 0xfc '' */ 0x6c, /* 01101100 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x36, /* 00110110 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 253 0xfd '' */ 0x78, /* 01111000 */ 0x0c, /* 00001100 */ 0x18, /* 00011000 */ 0x30, /* 00110000 */ 0x7c, /* 01111100 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 254 0xfe '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x3c, /* 00111100 */ 0x3c, /* 00111100 */ 0x3c, /* 00111100 */ 0x3c, /* 00111100 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ /* 255 0xff '' */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ 0x00, /* 00000000 */ }; wiringpi-2.50/devLib/gertboard.h0000664000175000017500000000271413442550153016255 0ustar ubuntuubuntu/* * gertboard.h: * Access routines for the SPI devices on the Gertboard * Copyright (c) 2012 Gordon Henderson * * The Gertboard has an MCP4802 dual-channel D to A convertor * connected to the SPI bus, selected via chip-select B. * *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif // Old routines extern void gertboardAnalogWrite (const int chan, const int value) ; extern int gertboardAnalogRead (const int chan) ; extern int gertboardSPISetup (void) ; // New extern int gertboardAnalogSetup (const int pinBase) ; #ifdef __cplusplus } #endif wiringpi-2.50/devLib/piNes.h0000664000175000017500000000264613442550153015366 0ustar ubuntuubuntu/* * piNes.h: * Driver for the NES Joystick controller on the Raspberry Pi * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #define MAX_NES_JOYSTICKS 8 #define NES_RIGHT 0x01 #define NES_LEFT 0x02 #define NES_DOWN 0x04 #define NES_UP 0x08 #define NES_START 0x10 #define NES_SELECT 0x20 #define NES_B 0x40 #define NES_A 0x80 #ifdef __cplusplus extern "C" { #endif extern int setupNesJoystick (int dPin, int cPin, int lPin) ; extern unsigned int readNesJoystick (int joystick) ; #ifdef __cplusplus } #endif wiringpi-2.50/devLib/piNes.c0000664000175000017500000000554313442550153015360 0ustar ubuntuubuntu/* * piNes.c: * Driver for the NES Joystick controller on the Raspberry Pi * Copyright (c) 2012 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include "piNes.h" #define MAX_NES_JOYSTICKS 8 #define NES_RIGHT 0x01 #define NES_LEFT 0x02 #define NES_DOWN 0x04 #define NES_UP 0x08 #define NES_START 0x10 #define NES_SELECT 0x20 #define NES_B 0x40 #define NES_A 0x80 #define PULSE_TIME 25 // Data to store the pins for each controller struct nesPinsStruct { unsigned int cPin, dPin, lPin ; } ; static struct nesPinsStruct nesPins [MAX_NES_JOYSTICKS] ; static int joysticks = 0 ; /* * setupNesJoystick: * Create a new NES joystick interface, program the pins, etc. ********************************************************************************* */ int setupNesJoystick (int dPin, int cPin, int lPin) { if (joysticks == MAX_NES_JOYSTICKS) return -1 ; nesPins [joysticks].dPin = dPin ; nesPins [joysticks].cPin = cPin ; nesPins [joysticks].lPin = lPin ; digitalWrite (lPin, LOW) ; digitalWrite (cPin, LOW) ; pinMode (lPin, OUTPUT) ; pinMode (cPin, OUTPUT) ; pinMode (dPin, INPUT) ; return joysticks++ ; } /* * readNesJoystick: * Do a single scan of the NES Joystick. ********************************************************************************* */ unsigned int readNesJoystick (int joystick) { unsigned int value = 0 ; int i ; struct nesPinsStruct *pins = &nesPins [joystick] ; // Toggle Latch - which presents the first bit digitalWrite (pins->lPin, HIGH) ; delayMicroseconds (PULSE_TIME) ; digitalWrite (pins->lPin, LOW) ; delayMicroseconds (PULSE_TIME) ; // Read first bit value = digitalRead (pins->dPin) ; // Now get the next 7 bits with the clock for (i = 0 ; i < 7 ; ++i) { digitalWrite (pins->cPin, HIGH) ; delayMicroseconds (PULSE_TIME) ; digitalWrite (pins->cPin, LOW) ; delayMicroseconds (PULSE_TIME) ; value = (value << 1) | digitalRead (pins->dPin) ; } return value ^ 0xFF ; } wiringpi-2.50/devLib/maxdetect.c0000775000175000017500000001303213442550153016253 0ustar ubuntuubuntu/* * maxdetect.c: * Driver for the MaxDetect series sensors * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include //#include //#include #include #include "maxdetect.h" #ifndef TRUE # define TRUE (1==1) # define FALSE (1==2) #endif /* * maxDetectLowHighWait: * Wait for a transition from low to high on the bus ********************************************************************************* */ static int maxDetectLowHighWait (const int pin) { struct timeval now, timeOut, timeUp ; // If already high then wait for pin to go low gettimeofday (&now, NULL) ; timerclear (&timeOut) ; timeOut.tv_usec = 1000 ; timeradd (&now, &timeOut, &timeUp) ; while (digitalRead (pin) == HIGH) { gettimeofday (&now, NULL) ; if (timercmp (&now, &timeUp, >)) return FALSE ; } // Wait for it to go HIGH gettimeofday (&now, NULL) ; timerclear (&timeOut) ; timeOut.tv_usec = 1000 ; timeradd (&now, &timeOut, &timeUp) ; while (digitalRead (pin) == LOW) { gettimeofday (&now, NULL) ; if (timercmp (&now, &timeUp, >)) return FALSE ; } return TRUE ; } /* * maxDetectClockByte: * Read in a single byte from the MaxDetect bus ********************************************************************************* */ static unsigned int maxDetectClockByte (const int pin) { unsigned int byte = 0 ; int bit ; for (bit = 0 ; bit < 8 ; ++bit) { if (!maxDetectLowHighWait (pin)) return 0 ; // bit starting now - we need to time it. delayMicroseconds (30) ; byte <<= 1 ; if (digitalRead (pin) == HIGH) // It's a 1 byte |= 1 ; } return byte ; } /* * maxDetectRead: * Read in and return the 4 data bytes from the MaxDetect sensor. * Return TRUE/FALSE depending on the checksum validity ********************************************************************************* */ int maxDetectRead (const int pin, unsigned char buffer [4]) { int i ; unsigned int checksum ; unsigned char localBuf [5] ; struct timeval now, then, took ; // See how long we took gettimeofday (&then, NULL) ; // Wake up the RHT03 by pulling the data line low, then high // Low for 10mS, high for 40uS. pinMode (pin, OUTPUT) ; digitalWrite (pin, 0) ; delay (10) ; digitalWrite (pin, 1) ; delayMicroseconds (40) ; pinMode (pin, INPUT) ; // Now wait for sensor to pull pin low if (!maxDetectLowHighWait (pin)) return FALSE ; // and read in 5 bytes (40 bits) for (i = 0 ; i < 5 ; ++i) localBuf [i] = maxDetectClockByte (pin) ; checksum = 0 ; for (i = 0 ; i < 4 ; ++i) { buffer [i] = localBuf [i] ; checksum += localBuf [i] ; } checksum &= 0xFF ; // See how long we took gettimeofday (&now, NULL) ; timersub (&now, &then, &took) ; // Total time to do this should be: // 10mS + 40µS - reset // + 80µS + 80µS - sensor doing its low -> high thing // + 40 * (50µS + 27µS (0) or 70µS (1) ) // = 15010µS // so if we take more than that, we've had a scheduling interruption and the // reading is probably bogus. if ((took.tv_sec != 0) || (took.tv_usec > 16000)) return FALSE ; return checksum == localBuf [4] ; } /* * readRHT03: * Read the Temperature & Humidity from an RHT03 sensor * Values returned are *10, so 123 is 12.3. ********************************************************************************* */ int readRHT03 (const int pin, int *temp, int *rh) { static struct timeval then ; // will initialise to zero static int lastTemp = 0 ; static int lastRh = 0 ; int result ; struct timeval now, timeOut ; unsigned char buffer [4] ; // The data sheets say to not read more than once every 2 seconds, so you // get the last good reading gettimeofday (&now, NULL) ; if (timercmp (&now, &then, <)) { *rh = lastRh ; *temp = lastTemp ; return TRUE ; } // Set timeout for next read gettimeofday (&now, NULL) ; timerclear (&timeOut) ; timeOut.tv_sec = 2 ; timeradd (&now, &timeOut, &then) ; // Read ... result = maxDetectRead (pin, buffer) ; if (!result) // Try again, but just once result = maxDetectRead (pin, buffer) ; if (!result) return FALSE ; *rh = (buffer [0] * 256 + buffer [1]) ; *temp = (buffer [2] * 256 + buffer [3]) ; if ((*temp & 0x8000) != 0) // Negative { *temp &= 0x7FFF ; *temp = -*temp ; } // Discard obviously bogus readings - the checksum can't detect a 2-bit error // (which does seem to happen - no realtime here) if ((*rh > 999) || (*temp > 800) || (*temp < -400)) return FALSE ; lastRh = *rh ; lastTemp = *temp ; return TRUE ; } wiringpi-2.50/devLib/ds1302.h0000664000175000017500000000321113442550153015211 0ustar ubuntuubuntu/* * ds1302.h: * Real Time clock * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern unsigned int ds1302rtcRead (const int reg) ; extern void ds1302rtcWrite (const int reg, const unsigned int data) ; extern unsigned int ds1302ramRead (const int addr) ; extern void ds1302ramWrite (const int addr, const unsigned int data) ; extern void ds1302clockRead (int clockData [8]) ; extern void ds1302clockWrite (const int clockData [8]) ; extern void ds1302trickleCharge (const int diodes, const int resistors) ; extern void ds1302setup (const int clockPin, const int dataPin, const int csPin) ; #ifdef __cplusplus } #endif wiringpi-2.50/devLib/piFace.c0000664000175000017500000000632613442550153015471 0ustar ubuntuubuntu/* * piFace.: * This file to interface with the PiFace peripheral device which * has an MCP23S17 GPIO device connected via the SPI bus. * * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include "piFace.h" /* * myDigitalWrite: * Perform the digitalWrite function on the PiFace board ********************************************************************************* */ void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { digitalWrite (pin + 16, value) ; } /* * myDigitalRead: * Perform the digitalRead function on the PiFace board * With a slight twist - if we read from base + 8, then we * read from the output latch... ********************************************************************************* */ int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { if ((pin - node->pinBase) >= 8) return digitalRead (pin + 8) ; else return digitalRead (pin + 16 + 8) ; } /* * myPullUpDnControl: * Perform the pullUpDnControl function on the PiFace board ********************************************************************************* */ void myPullUpDnControl (struct wiringPiNodeStruct *node, int pin, int pud) { pullUpDnControl (pin + 16 + 8, pud) ; } /* * piFaceSetup * We're going to create an instance of the mcp23s17 here, then * provide our own read/write routines on-top of it... * The supplied PiFace code (in Pithon) treats it as an 8-bit device * where you write the output ports and read the input port using the * same pin numbers, however I have had a request to be able to read * the output port, so reading 8..15 will read the output latch. ********************************************************************************* */ int piFaceSetup (const int pinBase) { int i ; struct wiringPiNodeStruct *node ; // Create an mcp23s17 instance: mcp23s17Setup (pinBase + 16, 0, 0) ; // Set the direction bits for (i = 0 ; i < 8 ; ++i) { pinMode (pinBase + 16 + i, OUTPUT) ; // Port A is the outputs pinMode (pinBase + 16 + 8 + i, INPUT) ; // Port B inputs. } node = wiringPiNewNode (pinBase, 16) ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; node->pullUpDnControl = myPullUpDnControl ; return 0 ; } wiringpi-2.50/devLib/scrollPhat.h0000664000175000017500000000336213442550153016417 0ustar ubuntuubuntu/* * scrollPhat.h: * Simple driver for the Pimoroni Scroll Phat device * * Copyright (c) 2015 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ extern void scrollPhatPoint (int x, int y, int colour) ; extern void scrollPhatLine (int x0, int y0, int x1, int y1, int colour) ; extern void scrollPhatLineTo (int x, int y, int colour) ; extern void scrollPhatRectangle (int x1, int y1, int x2, int y2, int colour, int filled) ; extern void scrollPhatUpdate (void) ; extern void scrollPhatClear (void) ; extern int scrollPhatPutchar (int c) ; //extern void scrollPhatPutchar (int c) ; extern void scrollPhatPuts (const char *str) ; extern void scrollPhatPrintf (const char *message, ...) ; extern void scrollPhatPrintSpeed (const int cps10) ; extern void scrollPhatIntensity (const int percent) ; extern int scrollPhatSetup (void) ; wiringpi-2.50/devLib/lcd128x64.c0000664000175000017500000003470413442550153015642 0ustar ubuntuubuntu/* * lcd128x64.c: * Graphics-based LCD driver. * This is designed to drive the parallel interface LCD drivers * based on the generic 12864H chips * * There are many variations on these chips, however they all mostly * seem to be similar. * This implementation has the Pins from the Pi hard-wired into it, * in particular wiringPi pins 0-7 so that we can use * digitalWriteByete() to speed things up somewhat. * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include "font.h" #include "lcd128x64.h" // Size #define LCD_WIDTH 128 #define LCD_HEIGHT 64 // Hardware Pins // Note pins 0-7 are the 8-bit data port #define CS1 10 #define CS2 11 #define STROBE 12 #define RS 13 // Software copy of the framebuffer // it's 8-bit deep although the display itself is only 1-bit deep. static unsigned char frameBuffer [LCD_WIDTH * LCD_HEIGHT] ; static int maxX, maxY ; static int lastX, lastY ; static int xOrigin, yOrigin ; static int lcdOrientation = 0 ; /* * strobe: * Toggle the strobe (Really the "E") pin to the device. * According to the docs, data is latched on the falling edge. ********************************************************************************* */ static void strobe (void) { digitalWrite (STROBE, 1) ; delayMicroseconds (1) ; digitalWrite (STROBE, 0) ; delayMicroseconds (5) ; } /* * sentData: * Send an data or command byte to the display. ********************************************************************************* */ static void sendData (const int data, const int chip) { digitalWrite (chip, 0) ; digitalWriteByte (data) ; strobe () ; digitalWrite (chip, 1) ; } /* * sendCommand: * Send a command byte to the display ********************************************************************************* */ static void sendCommand (const int command, const int chip) { digitalWrite (RS, 0) ; sendData (command, chip) ; digitalWrite (RS, 1) ; } /* * setCol: SetLine: * Set the column and line addresses ********************************************************************************* */ static void setCol (int col, const int chip) { sendCommand (0x40 | (col & 0x3F), chip) ; } static void setLine (int line, const int chip) { sendCommand (0xB8 | (line & 0x07), chip) ; } /* * lcd128x64update: * Copy our software version to the real display ********************************************************************************* */ void lcd128x64update (void) { int line, x, y, fbLoc ; unsigned char byte ; // Left side for (line = 0 ; line < 8 ; ++line) { setCol (0, CS1) ; setLine (line, CS1) ; for (x = 63 ; x >= 0 ; --x) { byte = 0 ; for (y = 0 ; y < 8 ; ++y) { fbLoc = x + (((7 - line) * 8) + (7 - y)) * LCD_WIDTH ; if (frameBuffer [fbLoc] != 0) byte |= (1 << y) ; } sendData (byte, CS1) ; } } // Right side for (line = 0 ; line < 8 ; ++line) { setCol (0, CS2) ; setLine (line, CS2) ; for (x = 127 ; x >= 64 ; --x) { byte = 0 ; for (y = 0 ; y < 8 ; ++y) { fbLoc = x + (((7 - line) * 8) + (7 - y)) * LCD_WIDTH ; if (frameBuffer [fbLoc] != 0) byte |= (1 << y) ; } sendData (byte, CS2) ; } } } /* * lcd128x64setOrigin: * Set the display offset origin ********************************************************************************* */ void lcd128x64setOrigin (int x, int y) { xOrigin = x ; yOrigin = y ; } /* * lcd128x64setOrientation: * Set the display orientation: * 0: Normal, the display is portrait mode, 0,0 is top left * 1: Landscape * 2: Portrait, flipped * 3: Landscape, flipped ********************************************************************************* */ void lcd128x64setOrientation (int orientation) { lcdOrientation = orientation & 3 ; lcd128x64setOrigin (0,0) ; switch (lcdOrientation) { case 0: maxX = LCD_WIDTH ; maxY = LCD_HEIGHT ; break ; case 1: maxX = LCD_HEIGHT ; maxY = LCD_WIDTH ; break ; case 2: maxX = LCD_WIDTH ; maxY = LCD_HEIGHT ; break ; case 3: maxX = LCD_HEIGHT ; maxY = LCD_WIDTH ; break ; } } /* * lcd128x64orientCoordinates: * Adjust the coordinates given to the display orientation ********************************************************************************* */ void lcd128x64orientCoordinates (int *x, int *y) { register int tmp ; *x += xOrigin ; *y += yOrigin ; *y = maxY - *y - 1 ; switch (lcdOrientation) { case 0: break; case 1: tmp = maxY - *y - 1 ; *y = *x ; *x = tmp ; break; case 2: *x = maxX - *x - 1 ; *y = maxY - *y - 1 ; break; case 3: *x = maxX - *x - 1 ; tmp = *y ; *y = *x ; *x = tmp ; break ; } } /* * lcd128x64getScreenSize: * Return the max X & Y screen sizes. Needs to be called again, if you * change screen orientation. ********************************************************************************* */ void lcd128x64getScreenSize (int *x, int *y) { *x = maxX ; *y = maxY ; } /* ********************************************************************************* * Standard Graphical Functions ********************************************************************************* */ /* * lcd128x64point: * Plot a pixel. ********************************************************************************* */ void lcd128x64point (int x, int y, int colour) { lastX = x ; lastY = y ; lcd128x64orientCoordinates (&x, &y) ; if ((x < 0) || (x >= LCD_WIDTH) || (y < 0) || (y >= LCD_HEIGHT)) return ; frameBuffer [x + y * LCD_WIDTH] = colour ; } /* * lcd128x64line: lcd128x64lineTo: * Classic Bressenham Line code ********************************************************************************* */ void lcd128x64line (int x0, int y0, int x1, int y1, int colour) { int dx, dy ; int sx, sy ; int err, e2 ; lastX = x1 ; lastY = y1 ; dx = abs (x1 - x0) ; dy = abs (y1 - y0) ; sx = (x0 < x1) ? 1 : -1 ; sy = (y0 < y1) ? 1 : -1 ; err = dx - dy ; for (;;) { lcd128x64point (x0, y0, colour) ; if ((x0 == x1) && (y0 == y1)) break ; e2 = 2 * err ; if (e2 > -dy) { err -= dy ; x0 += sx ; } if (e2 < dx) { err += dx ; y0 += sy ; } } } void lcd128x64lineTo (int x, int y, int colour) { lcd128x64line (lastX, lastY, x, y, colour) ; } /* * lcd128x64rectangle: * A rectangle is a spoilt days fishing ********************************************************************************* */ void lcd128x64rectangle (int x1, int y1, int x2, int y2, int colour, int filled) { register int x ; if (filled) { /**/ if (x1 == x2) lcd128x64line (x1, y1, x2, y2, colour) ; else if (x1 < x2) for (x = x1 ; x <= x2 ; ++x) lcd128x64line (x, y1, x, y2, colour) ; else for (x = x2 ; x <= x1 ; ++x) lcd128x64line (x, y1, x, y2, colour) ; } else { lcd128x64line (x1, y1, x2, y1, colour) ; lcd128x64lineTo (x2, y2, colour) ; lcd128x64lineTo (x1, y2, colour) ; lcd128x64lineTo (x1, y1, colour) ; } } /* * lcd128x64circle: * This is the midpoint circle algorithm. ********************************************************************************* */ void lcd128x64circle (int x, int y, int r, int colour, int filled) { int ddF_x = 1 ; int ddF_y = -2 * r ; int f = 1 - r ; int x1 = 0 ; int y1 = r ; if (filled) { lcd128x64line (x, y + r, x, y - r, colour) ; lcd128x64line (x + r, y, x - r, y, colour) ; } else { lcd128x64point (x, y + r, colour) ; lcd128x64point (x, y - r, colour) ; lcd128x64point (x + r, y, colour) ; lcd128x64point (x - r, y, colour) ; } while (x1 < y1) { if (f >= 0) { y1-- ; ddF_y += 2 ; f += ddF_y ; } x1++ ; ddF_x += 2 ; f += ddF_x ; if (filled) { lcd128x64line (x + x1, y + y1, x - x1, y + y1, colour) ; lcd128x64line (x + x1, y - y1, x - x1, y - y1, colour) ; lcd128x64line (x + y1, y + x1, x - y1, y + x1, colour) ; lcd128x64line (x + y1, y - x1, x - y1, y - x1, colour) ; } else { lcd128x64point (x + x1, y + y1, colour) ; lcd128x64point (x - x1, y + y1, colour) ; lcd128x64point (x + x1, y - y1, colour) ; lcd128x64point (x - x1, y - y1, colour) ; lcd128x64point (x + y1, y + x1, colour) ; lcd128x64point (x - y1, y + x1, colour) ; lcd128x64point (x + y1, y - x1, colour) ; lcd128x64point (x - y1, y - x1, colour) ; } } } /* * lcd128x64ellipse: * Fast ellipse drawing algorithm by * John Kennedy * Mathematics Department * Santa Monica College * 1900 Pico Blvd. * Santa Monica, CA 90405 * jrkennedy6@gmail.com * -Confirned in email this algorithm is in the public domain -GH- ********************************************************************************* */ static void plot4ellipsePoints (int cx, int cy, int x, int y, int colour, int filled) { if (filled) { lcd128x64line (cx + x, cy + y, cx - x, cy + y, colour) ; lcd128x64line (cx - x, cy - y, cx + x, cy - y, colour) ; } else { lcd128x64point (cx + x, cy + y, colour) ; lcd128x64point (cx - x, cy + y, colour) ; lcd128x64point (cx - x, cy - y, colour) ; lcd128x64point (cx + x, cy - y, colour) ; } } void lcd128x64ellipse (int cx, int cy, int xRadius, int yRadius, int colour, int filled) { int x, y ; int xChange, yChange, ellipseError ; int twoAsquare, twoBsquare ; int stoppingX, stoppingY ; twoAsquare = 2 * xRadius * xRadius ; twoBsquare = 2 * yRadius * yRadius ; x = xRadius ; y = 0 ; xChange = yRadius * yRadius * (1 - 2 * xRadius) ; yChange = xRadius * xRadius ; ellipseError = 0 ; stoppingX = twoBsquare * xRadius ; stoppingY = 0 ; while (stoppingX >= stoppingY) // 1st set of points { plot4ellipsePoints (cx, cy, x, y, colour, filled) ; ++y ; stoppingY += twoAsquare ; ellipseError += yChange ; yChange += twoAsquare ; if ((2 * ellipseError + xChange) > 0 ) { --x ; stoppingX -= twoBsquare ; ellipseError += xChange ; xChange += twoBsquare ; } } x = 0 ; y = yRadius ; xChange = yRadius * yRadius ; yChange = xRadius * xRadius * (1 - 2 * yRadius) ; ellipseError = 0 ; stoppingX = 0 ; stoppingY = twoAsquare * yRadius ; while (stoppingX <= stoppingY) //2nd set of points { plot4ellipsePoints (cx, cy, x, y, colour, filled) ; ++x ; stoppingX += twoBsquare ; ellipseError += xChange ; xChange += twoBsquare ; if ((2 * ellipseError + yChange) > 0 ) { --y ; stoppingY -= twoAsquare ; ellipseError += yChange ; yChange += twoAsquare ; } } } /* * lcd128x64putchar: * Print a single character to the screen ********************************************************************************* */ void lcd128x64putchar (int x, int y, int c, int bgCol, int fgCol) { int y1, y2 ; unsigned char line ; unsigned char *fontPtr ; // Can't print if we're offscreen //if ((x < 0) || (x >= (maxX - fontWidth)) || (y < 0) || (y >= (maxY - fontHeight))) // return ; fontPtr = font + c * fontHeight ; for (y1 = fontHeight - 1 ; y1 >= 0 ; --y1) { y2 = y + y1 ; line = *fontPtr++ ; lcd128x64point (x + 0, y2, (line & 0x80) == 0 ? bgCol : fgCol) ; lcd128x64point (x + 1, y2, (line & 0x40) == 0 ? bgCol : fgCol) ; lcd128x64point (x + 2, y2, (line & 0x20) == 0 ? bgCol : fgCol) ; lcd128x64point (x + 3, y2, (line & 0x10) == 0 ? bgCol : fgCol) ; lcd128x64point (x + 4, y2, (line & 0x08) == 0 ? bgCol : fgCol) ; lcd128x64point (x + 5, y2, (line & 0x04) == 0 ? bgCol : fgCol) ; lcd128x64point (x + 6, y2, (line & 0x02) == 0 ? bgCol : fgCol) ; lcd128x64point (x + 7, y2, (line & 0x01) == 0 ? bgCol : fgCol) ; } } /* * lcd128x64puts: * Send a string to the display. Obeys \n and \r formatting ********************************************************************************* */ void lcd128x64puts (int x, int y, const char *str, int bgCol, int fgCol) { int c, mx, my ; mx = x ; my = y ; while (*str) { c = *str++ ; if (c == '\r') { mx = x ; continue ; } if (c == '\n') { mx = x ; my -= fontHeight ; continue ; } lcd128x64putchar (mx, my, c, bgCol, fgCol) ; mx += fontWidth ; if (mx >= (maxX - fontWidth)) { mx = 0 ; my -= fontHeight ; } } } /* * lcd128x64clear: * Clear the display to the given colour. ********************************************************************************* */ void lcd128x64clear (int colour) { register int i ; register unsigned char *ptr = frameBuffer ; for (i = 0 ; i < (maxX * maxY) ; ++i) *ptr++ = colour ; } /* * lcd128x64setup: * Initialise the display and GPIO. ********************************************************************************* */ int lcd128x64setup (void) { int i ; for (i = 0 ; i < 8 ; ++i) pinMode (i, OUTPUT) ; digitalWrite (CS1, 1) ; digitalWrite (CS2, 1) ; digitalWrite (STROBE, 0) ; digitalWrite (RS, 1) ; pinMode (CS1, OUTPUT) ; pinMode (CS2, OUTPUT) ; pinMode (STROBE, OUTPUT) ; pinMode (RS, OUTPUT) ; sendCommand (0x3F, CS1) ; // Display ON sendCommand (0xC0, CS1) ; // Set display start line to 0 sendCommand (0x3F, CS2) ; // Display ON sendCommand (0xC0, CS2) ; // Set display start line to 0 lcd128x64clear (0) ; lcd128x64setOrientation (0) ; lcd128x64update () ; return 0 ; } wiringpi-2.50/devLib/maxdetect.h0000775000175000017500000000236213442550153016264 0ustar ubuntuubuntu/* * maxdetect.h: * Driver for the MaxDetect series sensors * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif // Main generic function int maxDetectRead (const int pin, unsigned char buffer [4]) ; // Individual sensors int readRHT03 (const int pin, int *temp, int *rh) ; #ifdef __cplusplus } #endif wiringpi-2.50/devLib/piFaceOld.c0000664000175000017500000001043213442550153016121 0ustar ubuntuubuntu/* * piFace.: * Copyright (c) 2012-2016 Gordon Henderson * * This file to interface with the PiFace peripheral device which * has an MCP23S17 GPIO device connected via the SPI bus. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include "../wiringPi/mcp23x0817.h" #include "piFace.h" #define PIFACE_SPEED 4000000 #define PIFACE_DEVNO 0 /* * writeByte: * Write a byte to a register on the MCP23S17 on the SPI bus. ********************************************************************************* */ static void writeByte (uint8_t reg, uint8_t data) { uint8_t spiData [4] ; spiData [0] = CMD_WRITE ; spiData [1] = reg ; spiData [2] = data ; wiringPiSPIDataRW (PIFACE_DEVNO, spiData, 3) ; } /* * readByte: * Read a byte from a register on the MCP23S17 on the SPI bus. ********************************************************************************* */ static uint8_t readByte (uint8_t reg) { uint8_t spiData [4] ; spiData [0] = CMD_READ ; spiData [1] = reg ; wiringPiSPIDataRW (PIFACE_DEVNO, spiData, 3) ; return spiData [2] ; } /* * myDigitalWrite: * Perform the digitalWrite function on the PiFace board ********************************************************************************* */ void myDigitalWrite (struct wiringPiNodeStruct *node, int pin, int value) { uint8_t mask, old ; pin -= node->pinBase ; mask = 1 << pin ; old = readByte (MCP23x17_GPIOA) ; if (value == 0) old &= (~mask) ; else old |= mask ; writeByte (MCP23x17_GPIOA, old) ; } /* * myDigitalRead: * Perform the digitalRead function on the PiFace board ********************************************************************************* */ int myDigitalRead (struct wiringPiNodeStruct *node, int pin) { uint8_t mask, reg ; mask = 1 << ((pin - node->pinBase) & 7) ; if (pin < 8) reg = MCP23x17_GPIOB ; // Input regsiter else reg = MCP23x17_OLATA ; // Output latch regsiter if ((readByte (reg) & mask) != 0) return HIGH ; else return LOW ; } /* * myPullUpDnControl: * Perform the pullUpDnControl function on the PiFace board ********************************************************************************* */ void myPullUpDnControl (struct wiringPiNodeStruct *node, int pin, int pud) { uint8_t mask, old ; mask = 1 << (pin - node->pinBase) ; old = readByte (MCP23x17_GPPUB) ; if (pud == 0) old &= (~mask) ; else old |= mask ; writeByte (MCP23x17_GPPUB, old) ; } /* * piFaceSetup * Setup the SPI interface and initialise the MCP23S17 chip * We create one node with 16 pins - each if the first 8 pins being read * and write - although the operations actually go to different * hardware ports. The top 8 let you read the state of the output register. ********************************************************************************* */ int piFaceSetup (const int pinBase) { int x ; struct wiringPiNodeStruct *node ; if ((x = wiringPiSPISetup (PIFACE_DEVNO, PIFACE_SPEED)) < 0) return x ; // Setup the MCP23S17 writeByte (MCP23x17_IOCON, IOCON_INIT) ; writeByte (MCP23x17_IODIRA, 0x00) ; // Port A -> Outputs writeByte (MCP23x17_IODIRB, 0xFF) ; // Port B -> Inputs node = wiringPiNewNode (pinBase, 16) ; node->digitalRead = myDigitalRead ; node->digitalWrite = myDigitalWrite ; node->pullUpDnControl = myPullUpDnControl ; return 0 ; } wiringpi-2.50/devLib/lcd.h0000664000175000017500000000405713442550153015050 0ustar ubuntuubuntu/* * lcd.h: * Text-based LCD driver. * This is designed to drive the parallel interface LCD drivers * based in the Hitachi HD44780U controller and compatables. * * Copyright (c) 2012 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #define MAX_LCDS 8 #ifdef __cplusplus extern "C" { #endif extern void lcdHome (const int fd) ; extern void lcdClear (const int fd) ; extern void lcdDisplay (const int fd, int state) ; extern void lcdCursor (const int fd, int state) ; extern void lcdCursorBlink (const int fd, int state) ; extern void lcdSendCommand (const int fd, unsigned char command) ; extern void lcdPosition (const int fd, int x, int y) ; extern void lcdCharDef (const int fd, int index, unsigned char data [8]) ; extern void lcdPutchar (const int fd, unsigned char data) ; extern void lcdPuts (const int fd, const char *string) ; extern void lcdPrintf (const int fd, const char *message, ...) ; extern int lcdInit (const int rows, const int cols, const int bits, const int rs, const int strb, const int d0, const int d1, const int d2, const int d3, const int d4, const int d5, const int d6, const int d7) ; #ifdef __cplusplus } #endif wiringpi-2.50/devLib/lcd.c0000664000175000017500000002643513442550153015047 0ustar ubuntuubuntu/* * lcd.c: * Text-based LCD driver. * This is designed to drive the parallel interface LCD drivers * based in the Hitachi HD44780U controller and compatables. * * Copyright (c) 2012 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include "lcd.h" #ifndef TRUE # define TRUE (1==1) # define FALSE (1==2) #endif // HD44780U Commands #define LCD_CLEAR 0x01 #define LCD_HOME 0x02 #define LCD_ENTRY 0x04 #define LCD_CTRL 0x08 #define LCD_CDSHIFT 0x10 #define LCD_FUNC 0x20 #define LCD_CGRAM 0x40 #define LCD_DGRAM 0x80 // Bits in the entry register #define LCD_ENTRY_SH 0x01 #define LCD_ENTRY_ID 0x02 // Bits in the control register #define LCD_BLINK_CTRL 0x01 #define LCD_CURSOR_CTRL 0x02 #define LCD_DISPLAY_CTRL 0x04 // Bits in the function register #define LCD_FUNC_F 0x04 #define LCD_FUNC_N 0x08 #define LCD_FUNC_DL 0x10 #define LCD_CDSHIFT_RL 0x04 struct lcdDataStruct { int bits, rows, cols ; int rsPin, strbPin ; int dataPins [8] ; int cx, cy ; } ; struct lcdDataStruct *lcds [MAX_LCDS] ; static int lcdControl ; // Row offsets static const int rowOff [4] = { 0x00, 0x40, 0x14, 0x54 } ; /* * strobe: * Toggle the strobe (Really the "E") pin to the device. * According to the docs, data is latched on the falling edge. ********************************************************************************* */ static void strobe (const struct lcdDataStruct *lcd) { // Note timing changes for new version of delayMicroseconds () digitalWrite (lcd->strbPin, 1) ; delayMicroseconds (50) ; digitalWrite (lcd->strbPin, 0) ; delayMicroseconds (50) ; } /* * sentDataCmd: * Send an data or command byte to the display. ********************************************************************************* */ static void sendDataCmd (const struct lcdDataStruct *lcd, unsigned char data) { register unsigned char myData = data ; unsigned char i, d4 ; if (lcd->bits == 4) { d4 = (myData >> 4) & 0x0F; for (i = 0 ; i < 4 ; ++i) { digitalWrite (lcd->dataPins [i], (d4 & 1)) ; d4 >>= 1 ; } strobe (lcd) ; d4 = myData & 0x0F ; for (i = 0 ; i < 4 ; ++i) { digitalWrite (lcd->dataPins [i], (d4 & 1)) ; d4 >>= 1 ; } } else { for (i = 0 ; i < 8 ; ++i) { digitalWrite (lcd->dataPins [i], (myData & 1)) ; myData >>= 1 ; } } strobe (lcd) ; } /* * putCommand: * Send a command byte to the display ********************************************************************************* */ static void putCommand (const struct lcdDataStruct *lcd, unsigned char command) { digitalWrite (lcd->rsPin, 0) ; sendDataCmd (lcd, command) ; delay (2) ; } static void put4Command (const struct lcdDataStruct *lcd, unsigned char command) { register unsigned char myCommand = command ; register unsigned char i ; digitalWrite (lcd->rsPin, 0) ; for (i = 0 ; i < 4 ; ++i) { digitalWrite (lcd->dataPins [i], (myCommand & 1)) ; myCommand >>= 1 ; } strobe (lcd) ; } /* ********************************************************************************* * User Callable code below here ********************************************************************************* */ /* * lcdHome: lcdClear: * Home the cursor or clear the screen. ********************************************************************************* */ void lcdHome (const int fd) { struct lcdDataStruct *lcd = lcds [fd] ; putCommand (lcd, LCD_HOME) ; lcd->cx = lcd->cy = 0 ; delay (5) ; } void lcdClear (const int fd) { struct lcdDataStruct *lcd = lcds [fd] ; putCommand (lcd, LCD_CLEAR) ; putCommand (lcd, LCD_HOME) ; lcd->cx = lcd->cy = 0 ; delay (5) ; } /* * lcdDisplay: lcdCursor: lcdCursorBlink: * Turn the display, cursor, cursor blinking on/off ********************************************************************************* */ void lcdDisplay (const int fd, int state) { struct lcdDataStruct *lcd = lcds [fd] ; if (state) lcdControl |= LCD_DISPLAY_CTRL ; else lcdControl &= ~LCD_DISPLAY_CTRL ; putCommand (lcd, LCD_CTRL | lcdControl) ; } void lcdCursor (const int fd, int state) { struct lcdDataStruct *lcd = lcds [fd] ; if (state) lcdControl |= LCD_CURSOR_CTRL ; else lcdControl &= ~LCD_CURSOR_CTRL ; putCommand (lcd, LCD_CTRL | lcdControl) ; } void lcdCursorBlink (const int fd, int state) { struct lcdDataStruct *lcd = lcds [fd] ; if (state) lcdControl |= LCD_BLINK_CTRL ; else lcdControl &= ~LCD_BLINK_CTRL ; putCommand (lcd, LCD_CTRL | lcdControl) ; } /* * lcdSendCommand: * Send any arbitary command to the display ********************************************************************************* */ void lcdSendCommand (const int fd, unsigned char command) { struct lcdDataStruct *lcd = lcds [fd] ; putCommand (lcd, command) ; } /* * lcdPosition: * Update the position of the cursor on the display. * Ignore invalid locations. ********************************************************************************* */ void lcdPosition (const int fd, int x, int y) { struct lcdDataStruct *lcd = lcds [fd] ; if ((x > lcd->cols) || (x < 0)) return ; if ((y > lcd->rows) || (y < 0)) return ; putCommand (lcd, x + (LCD_DGRAM | rowOff [y])) ; lcd->cx = x ; lcd->cy = y ; } /* * lcdCharDef: * Defines a new character in the CGRAM ********************************************************************************* */ void lcdCharDef (const int fd, int index, unsigned char data [8]) { struct lcdDataStruct *lcd = lcds [fd] ; int i ; putCommand (lcd, LCD_CGRAM | ((index & 7) << 3)) ; digitalWrite (lcd->rsPin, 1) ; for (i = 0 ; i < 8 ; ++i) sendDataCmd (lcd, data [i]) ; } /* * lcdPutchar: * Send a data byte to be displayed on the display. We implement a very * simple terminal here - with line wrapping, but no scrolling. Yet. ********************************************************************************* */ void lcdPutchar (const int fd, unsigned char data) { struct lcdDataStruct *lcd = lcds [fd] ; digitalWrite (lcd->rsPin, 1) ; sendDataCmd (lcd, data) ; if (++lcd->cx == lcd->cols) { lcd->cx = 0 ; if (++lcd->cy == lcd->rows) lcd->cy = 0 ; putCommand (lcd, lcd->cx + (LCD_DGRAM | rowOff [lcd->cy])) ; } } /* * lcdPuts: * Send a string to be displayed on the display ********************************************************************************* */ void lcdPuts (const int fd, const char *string) { while (*string) lcdPutchar (fd, *string++) ; } /* * lcdPrintf: * Printf to an LCD display ********************************************************************************* */ void lcdPrintf (const int fd, const char *message, ...) { va_list argp ; char buffer [1024] ; va_start (argp, message) ; vsnprintf (buffer, 1023, message, argp) ; va_end (argp) ; lcdPuts (fd, buffer) ; } /* * lcdInit: * Take a lot of parameters and initialise the LCD, and return a handle to * that LCD, or -1 if any error. ********************************************************************************* */ int lcdInit (const int rows, const int cols, const int bits, const int rs, const int strb, const int d0, const int d1, const int d2, const int d3, const int d4, const int d5, const int d6, const int d7) { static int initialised = 0 ; unsigned char func ; int i ; int lcdFd = -1 ; struct lcdDataStruct *lcd ; if (initialised == 0) { initialised = 1 ; for (i = 0 ; i < MAX_LCDS ; ++i) lcds [i] = NULL ; } // Simple sanity checks if (! ((bits == 4) || (bits == 8))) return -1 ; if ((rows < 0) || (rows > 20)) return -1 ; if ((cols < 0) || (cols > 20)) return -1 ; // Create a new LCD: for (i = 0 ; i < MAX_LCDS ; ++i) { if (lcds [i] == NULL) { lcdFd = i ; break ; } } if (lcdFd == -1) return -1 ; lcd = (struct lcdDataStruct *)malloc (sizeof (struct lcdDataStruct)) ; if (lcd == NULL) return -1 ; lcd->rsPin = rs ; lcd->strbPin = strb ; lcd->bits = 8 ; // For now - we'll set it properly later. lcd->rows = rows ; lcd->cols = cols ; lcd->cx = 0 ; lcd->cy = 0 ; lcd->dataPins [0] = d0 ; lcd->dataPins [1] = d1 ; lcd->dataPins [2] = d2 ; lcd->dataPins [3] = d3 ; lcd->dataPins [4] = d4 ; lcd->dataPins [5] = d5 ; lcd->dataPins [6] = d6 ; lcd->dataPins [7] = d7 ; lcds [lcdFd] = lcd ; digitalWrite (lcd->rsPin, 0) ; pinMode (lcd->rsPin, OUTPUT) ; digitalWrite (lcd->strbPin, 0) ; pinMode (lcd->strbPin, OUTPUT) ; for (i = 0 ; i < bits ; ++i) { digitalWrite (lcd->dataPins [i], 0) ; pinMode (lcd->dataPins [i], OUTPUT) ; } delay (35) ; // mS // 4-bit mode? // OK. This is a PIG and it's not at all obvious from the documentation I had, // so I guess some others have worked through either with better documentation // or more trial and error... Anyway here goes: // // It seems that the controller needs to see the FUNC command at least 3 times // consecutively - in 8-bit mode. If you're only using 8-bit mode, then it appears // that you can get away with one func-set, however I'd not rely on it... // // So to set 4-bit mode, you need to send the commands one nibble at a time, // the same three times, but send the command to set it into 8-bit mode those // three times, then send a final 4th command to set it into 4-bit mode, and only // then can you flip the switch for the rest of the library to work in 4-bit // mode which sends the commands as 2 x 4-bit values. if (bits == 4) { func = LCD_FUNC | LCD_FUNC_DL ; // Set 8-bit mode 3 times put4Command (lcd, func >> 4) ; delay (35) ; put4Command (lcd, func >> 4) ; delay (35) ; put4Command (lcd, func >> 4) ; delay (35) ; func = LCD_FUNC ; // 4th set: 4-bit mode put4Command (lcd, func >> 4) ; delay (35) ; lcd->bits = 4 ; } else { func = LCD_FUNC | LCD_FUNC_DL ; putCommand (lcd, func ) ; delay (35) ; putCommand (lcd, func ) ; delay (35) ; putCommand (lcd, func ) ; delay (35) ; } if (lcd->rows > 1) { func |= LCD_FUNC_N ; putCommand (lcd, func) ; delay (35) ; } // Rest of the initialisation sequence lcdDisplay (lcdFd, TRUE) ; lcdCursor (lcdFd, FALSE) ; lcdCursorBlink (lcdFd, FALSE) ; lcdClear (lcdFd) ; putCommand (lcd, LCD_ENTRY | LCD_ENTRY_ID) ; putCommand (lcd, LCD_CDSHIFT | LCD_CDSHIFT_RL) ; return lcdFd ; } wiringpi-2.50/devLib/gertboard.c0000664000175000017500000001002713442550153016244 0ustar ubuntuubuntu/* * gertboard.c: * Access routines for the SPI devices on the Gertboard * Copyright (c) 2012 Gordon Henderson * * The Gertboard has: * * An MCP3002 dual-channel A to D convertor connected * to the SPI bus, selected by chip-select A, and: * * An MCP4802 dual-channel D to A convertor connected * to the SPI bus, selected via chip-select B. * *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with wiringPi. * If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include "gertboard.h" // The A-D convertor won't run at more than 1MHz @ 3.3v #define SPI_ADC_SPEED 1000000 #define SPI_DAC_SPEED 1000000 #define SPI_A2D 0 #define SPI_D2A 1 /* * gertboardAnalogWrite: * Write an 8-bit data value to the MCP4802 Analog to digital * convertor on the Gertboard. ********************************************************************************* */ void gertboardAnalogWrite (const int chan, const int value) { uint8_t spiData [2] ; uint8_t chanBits, dataBits ; if (chan == 0) chanBits = 0x30 ; else chanBits = 0xB0 ; chanBits |= ((value >> 4) & 0x0F) ; dataBits = ((value << 4) & 0xF0) ; spiData [0] = chanBits ; spiData [1] = dataBits ; wiringPiSPIDataRW (SPI_D2A, spiData, 2) ; } /* * gertboardAnalogRead: * Return the analog value of the given channel (0/1). * The A/D is a 10-bit device ********************************************************************************* */ int gertboardAnalogRead (const int chan) { uint8_t spiData [2] ; uint8_t chanBits ; if (chan == 0) chanBits = 0b11010000 ; else chanBits = 0b11110000 ; spiData [0] = chanBits ; spiData [1] = 0 ; wiringPiSPIDataRW (SPI_A2D, spiData, 2) ; return ((spiData [0] << 8) | (spiData [1] >> 1)) & 0x3FF ; } /* * gertboardSPISetup: * Initialise the SPI bus, etc. ********************************************************************************* */ int gertboardSPISetup (void) { if (wiringPiSPISetup (SPI_A2D, SPI_ADC_SPEED) < 0) return -1 ; if (wiringPiSPISetup (SPI_D2A, SPI_DAC_SPEED) < 0) return -1 ; return 0 ; } /* * New wiringPi node extension methods. ********************************************************************************* */ static int myAnalogRead (struct wiringPiNodeStruct *node, const int chan) { return gertboardAnalogRead (chan - node->pinBase) ; } static void myAnalogWrite (struct wiringPiNodeStruct *node, const int chan, const int value) { gertboardAnalogWrite (chan - node->pinBase, value) ; } /* * gertboardAnalogSetup: * Create a new wiringPi device node for the analog devices on the * Gertboard. We create one node with 2 pins - each pin being read * and write - although the operations actually go to different * hardware devices. ********************************************************************************* */ int gertboardAnalogSetup (const int pinBase) { struct wiringPiNodeStruct *node ; int x ; if (( x = gertboardSPISetup ()) != 0) return x; node = wiringPiNewNode (pinBase, 2) ; node->analogRead = myAnalogRead ; node->analogWrite = myAnalogWrite ; return 0 ; } wiringpi-2.50/devLib/lcd128x64.h0000664000175000017500000000403513442550153015641 0ustar ubuntuubuntu/* * lcd128x64.h: * * Copyright (c) 2013 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ extern void lcd128x64setOrigin (int x, int y) ; extern void lcd128x64setOrientation (int orientation) ; extern void lcd128x64orientCoordinates (int *x, int *y) ; extern void lcd128x64getScreenSize (int *x, int *y) ; extern void lcd128x64point (int x, int y, int colour) ; extern void lcd128x64line (int x0, int y0, int x1, int y1, int colour) ; extern void lcd128x64lineTo (int x, int y, int colour) ; extern void lcd128x64rectangle (int x1, int y1, int x2, int y2, int colour, int filled) ; extern void lcd128x64circle (int x, int y, int r, int colour, int filled) ; extern void lcd128x64ellipse (int cx, int cy, int xRadius, int yRadius, int colour, int filled) ; extern void lcd128x64putchar (int x, int y, int c, int bgCol, int fgCol) ; extern void lcd128x64puts (int x, int y, const char *str, int bgCol, int fgCol) ; extern void lcd128x64update (void) ; extern void lcd128x64clear (int colour) ; extern int lcd128x64setup (void) ; wiringpi-2.50/devLib/piFace.h0000664000175000017500000000221113442550153015463 0ustar ubuntuubuntu/* * piFace.h: * Control the PiFace Interface board for the Raspberry Pi * Copyright (c) 2012-2013 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #ifdef __cplusplus extern "C" { #endif extern int piFaceSetup (const int pinBase) ; #ifdef __cplusplus } #endif wiringpi-2.50/devLib/scrollPhatFont.h0000664000175000017500000001612513442550153017247 0ustar ubuntuubuntu/* * scrollPhatFont.h: * Simple font for the Pimoroni Scroll Phat. * Note: this is a very much reduced font - 5 pixels high and * mostly 4 pixels wide - sometimes 5. Also only * printable characters from space to _ uppercase only. * * Copyright (c) 2015-2016 Gordon Henderson. *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ static const int fontHeight = 5 ; static unsigned char scrollPhatFont [] = { // 0x20, Space. Handeled as a special case in the code. 0x0, // .... 0x0, // .... 0x0, // .... 0x0, // .... 0x0, // .... // 0x21, ! 0x1, // * 0x1, // * 0x1, // * 0x0, // . 0x1, // * // 0x22, " 0x5, // *..* 0x5, // *..* 0x0, // .... 0x0, // .... 0x0, // .... // 0x23, # 0x9, // *..* 0xF, // **** 0x9, // *..* 0xF, // **** 0x9, // *..* // 0x24, $ 0x1, // ..*. 0x7, // .*** 0x2, // ..*. 0xE, // ***. 0x8, // ..*. // 0x25, % 0x9, // *..* 0x1, // ...* 0x6, // .**. 0x8, // *... 0x9, // *..* // 0x26, & 0x6, // .**. 0x8, // *... 0x4, // .*.. 0xA, // *.*. 0x5, // .*.* // 0x27, ' 0x1, // .* 0x2, // *. 0x0, // .. 0x0, // .. 0x0, // .. // 0x28, ( 0x3, // ..** 0x4, // .*.. 0x8, // *... 0x4, // .*.. 0x3, // ..** // 0x29, ) 0xC, // **.. 0x2, // ..*. 0x1, // ...* 0x2, // ..*. 0xC, // **.. // 0x2A, * 0x9, // *..* 0x6, // .**. 0xF, // **** 0x6, // .**. 0x9, // *..* // 0x2B, + 0x6, // .**. 0x6, // .**. 0xF, // **** 0x6, // .**. 0x6, // .**. // 0x2C, , 0x0, // .. 0x0, // .. 0x0, // .. 0x1, // .* 0x2, // *. // 0x2D, - 0x0, // .... 0x0, // .... 0xF, // **** 0x0, // .... 0x0, // .... // 0x2E, . 0x0, // . 0x0, // . 0x0, // . 0x0, // . 0x1, // * // 0x2F, / 0x1, // ...* 0x3, // ..** 0x4, // ..*. 0xC, // **.. 0x8, // *... // 0x30, 0 0x6, // .**. 0x9, // *..* 0x9, // *..* 0x9, // *..* 0x6, // .**. // 0x31, 1 0x2, // ..*. 0x6, // .**. 0x2, // ..*. 0x2, // ..*. 0x7, // .*** // 0x32, 2 0x6, // .**. 0x1, // ...* 0x6, // .**. 0x8, // *... 0xF, // **** // 0x33, 3 0xE, // ***. 0x1, // ...* 0xE, // ***. 0x1, // ...* 0xE, // ***. // 0x34, 4 0x6, // .**. 0xA, // *.*. 0xF, // **** 0x2, // ..*. 0x2, // ..*. // 0x35, 5 0xF, // **** 0x8, // *... 0xF, // **** 0x1, // ...* 0xE, // ***. // 0x36, 6 0x2, // ..*. 0x4, // .*.. 0xA, // *.*. 0x9, // *..* 0x6, // .**. // 0x37, 7 0xF, // **** 0x1, // ...* 0x2, // ..*. 0x4, // .*.. 0x8, // *... // 0x38, 8 0x6, // .**. 0x9, // *..* 0x6, // .**. 0x9, // *..* 0x6, // .**. // 0x39, 9 0x6, // .**. 0x9, // *..* 0x7, // .*.* 0x1, // ..*. 0x2, // .*.. // 0x3A, : 0x0, // . 0x1, // * 0x0, // . 0x1, // * 0x0, // . // 0x3B, ; 0x0, // .. 0x1, // .* 0x0, // .. 0x1, // .* 0x2, // *. // 0x3C, < 0x2, // ..*. 0x4, // .*.. 0x8, // *... 0x4, // .*.. 0x2, // ..*. // 0x3D, = 0x0, // .... 0xF, // **** 0x0, // .... 0xF, // **** 0x0, // .... // 0x3E, > 0x0, // .*.. 0x0, // ..*. 0x0, // ...* 0x0, // ..*. 0x0, // .*.. // 0x3F, ? 0x6, // .**. 0x1, // ...* 0x2, // ..*. 0x0, // .... 0x2, // ..*. // 0x40, @ 0x6, // .**. 0xD, // **.* 0x8, // *... 0x4, // .*.. 0x3, // ..** // 0x41, A 0x6, // .**. 0x9, // *..* 0xF, // **** 0x9, // *..* 0x9, // *..* // 0x42, B 0xE, // ***. 0x9, // *..* 0xE, // ***. 0x9, // *..* 0xE, // ***. // 0x43, C 0x6, // .**. 0x9, // *..* 0x8, // *... 0x9, // *..* 0x6, // .**. // 0x44, D 0xE, // ***. 0x9, // *..* 0x9, // *..* 0x9, // *..* 0xE, // ***. // 0x45, E 0xF, // **** 0x8, // *... 0xE, // ***. 0x8, // *... 0xF, // **** // 0x46, F 0xF, // **** 0x8, // *... 0xE, // ***. 0x8, // *... 0x8, // *... // 0x47, G 0x6, // .**. 0x9, // *..* 0x8, // *... 0xB, // *.** 0x6, // .**. // 0x48, H 0x9, // *..* 0x9, // *..* 0xF, // **** 0x9, // *..* 0x9, // *..* // 0x49, I 0x7, // *** 0x2, // .*. 0x2, // .*. 0x2, // .*. 0x7, // *** // 0x4A, J 0x7, // .*** 0x2, // ..*. 0x2, // ..*. 0xA, // *.*. 0x4, // .*.. // 0x4B, K 0x9, // *..* 0xA, // *.*. 0xC, // **.. 0xA, // *.*. 0x9, // *..* // 0x4C, L 0x4, // *.. 0x4, // *.. 0x4, // *.. 0x4, // *.. 0x7, // *** // 0x4D, M 0x11, // *...* 0x1B, // **.** 0x15, // *.*.* 0x11, // *...* 0x11, // *...* // 0x4E, N 0x9, // *..* 0xD, // **.* 0xB, // *.** 0x9, // *..* 0x9, // *..* // 0x4F, O 0x6, // .**. 0x9, // *..* 0x9, // *..* 0x9, // *..* 0x6, // .**. // 0x50, P 0xE, // ***. 0x9, // *..* 0xE, // ***. 0x8, // *... 0x8, // *... // 0x51, Q 0x6, // .**. 0x9, // *..* 0x9, // *..* 0xA, // *.*. 0x5, // .*.* // 0x52, R 0xE, // ***. 0x9, // *..* 0xF, // ***. 0xA, // *.*. 0x9, // *..* // 0x53, S 0x6, // .**. 0x8, // *... 0x6, // .**. 0x1, // ...* 0x6, // .**. // 0x54, T 0x7, // .*** 0x2, // ..*. 0x2, // ..*. 0x2, // ..*. 0x2, // ..*. // 0x55, U 0x9, // *..* 0x9, // *..* 0x9, // *..* 0x9, // *..* 0x6, // .**. // 0x56, V 0x11, // *...* 0x11, // *...* 0x11, // *...* 0x0A, // .*.*. 0x04, // ..*.. // 0x57, W 0x11, // *...* 0x11, // *...* 0x11, // *...* 0x15, // *.*.* 0x1B, // **.** // 0x58, X 0x9, // *..* 0x9, // *..* 0x6, // .**. 0x9, // *..* 0x9, // *..* // 0x59, Y 0x11, // *...* 0x0A, // .*.*. 0x04, // ..*.. 0x04, // ..*.. 0x04, // ..*.. // 0x5A, Z 0xF, // **** 0x1, // ...* 0x6, // .**. 0x8, // *... 0xF, // **** // 0x5B, [ 0xE, // ***. 0x8, // *... 0x8, // *... 0x8, // *... 0xE, // ***. // 0x5C, Backslash 0x8, // *... 0xC, // **.. 0x6, // .**. 0x3, // ..** 0x1, // ...* // 0x5D, ] 0x7, // .*** 0x1, // ...* 0x1, // ...* 0x1, // ...* 0x7, // .*** // 0x5E, ^ 0x6, // .**. 0x9, // *..* 0x0, // .... 0x0, // .... 0x0, // .... // 0x5F, _ 0x0, // .... 0x0, // .... 0x0, // .... 0x0, // .... 0xF, // **** } ; wiringpi-2.50/version.h0000664000175000017500000000011013442550153014550 0ustar ubuntuubuntu#define VERSION "2.50" #define VERSION_MAJOR 2 #define VERSION_MINOR 50 wiringpi-2.50/gpio/0000775000175000017500000000000013442550153013660 5ustar ubuntuubuntuwiringpi-2.50/gpio/readall.c0000664000175000017500000002525313442550153015437 0ustar ubuntuubuntu/* * readall.c: * The readall functions - getting a bit big, so split them out. * Copyright (c) 2012-2018 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include #include extern int wpMode ; #ifndef TRUE # define TRUE (1==1) # define FALSE (1==2) #endif /* * doReadallExternal: * A relatively crude way to read the pins on an external device. * We don't know the input/output mode of pins, but we can tell * if it's an analog pin or a digital one... ********************************************************************************* */ static void doReadallExternal (void) { int pin ; printf ("+------+---------+--------+\n") ; printf ("| Pin | Digital | Analog |\n") ; printf ("+------+---------+--------+\n") ; for (pin = wiringPiNodes->pinBase ; pin <= wiringPiNodes->pinMax ; ++pin) printf ("| %4d | %4d | %4d |\n", pin, digitalRead (pin), analogRead (pin)) ; printf ("+------+---------+--------+\n") ; } /* * doReadall: * Read all the GPIO pins * We also want to use this to read the state of pins on an externally * connected device, so we need to do some fiddling with the internal * wiringPi node structures - since the gpio command can only use * one external device at a time, we'll use that to our advantage... ********************************************************************************* */ static char *alts [] = { "IN", "OUT", "ALT5", "ALT4", "ALT0", "ALT1", "ALT2", "ALT3" } ; static int physToWpi [64] = { -1, // 0 -1, -1, // 1, 2 8, -1, 9, -1, 7, 15, -1, 16, 0, 1, 2, -1, 3, 4, -1, 5, 12, -1, 13, 6, 14, 10, -1, 11, // 25, 26 30, 31, // Actually I2C, but not used 21, -1, 22, 26, 23, -1, 24, 27, 25, 28, -1, 29, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 17, 18, 19, 20, -1, -1, -1, -1, -1, -1, -1, -1, -1 } ; static char *physNames [64] = { NULL, " 3.3v", "5v ", " SDA.1", "5v ", " SCL.1", "0v ", "GPIO. 7", "TxD ", " 0v", "RxD ", "GPIO. 0", "GPIO. 1", "GPIO. 2", "0v ", "GPIO. 3", "GPIO. 4", " 3.3v", "GPIO. 5", " MOSI", "0v ", " MISO", "GPIO. 6", " SCLK", "CE0 ", " 0v", "CE1 ", " SDA.0", "SCL.0 ", "GPIO.21", "0v ", "GPIO.22", "GPIO.26", "GPIO.23", "0v ", "GPIO.24", "GPIO.27", "GPIO.25", "GPIO.28", " 0v", "GPIO.29", NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, "GPIO.17", "GPIO.18", "GPIO.19", "GPIO.20", NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL, } ; /* * readallPhys: * Given a physical pin output the data on it and the next pin: *| BCM | wPi | Name | Mode | Val| Physical |Val | Mode | Name | wPi | BCM | ********************************************************************************* */ static void readallPhys (int physPin) { int pin ; if (physPinToGpio (physPin) == -1) printf (" | | ") ; else printf (" | %3d | %3d", physPinToGpio (physPin), physToWpi [physPin]) ; printf (" | %s", physNames [physPin]) ; if (physToWpi [physPin] == -1) printf (" | | ") ; else { /**/ if (wpMode == WPI_MODE_GPIO) pin = physPinToGpio (physPin) ; else if (wpMode == WPI_MODE_PHYS) pin = physPin ; else pin = physToWpi [physPin] ; printf (" | %4s", alts [getAlt (pin)]) ; printf (" | %d", digitalRead (pin)) ; } // Pin numbers: printf (" | %2d", physPin) ; ++physPin ; printf (" || %-2d", physPin) ; // Same, reversed if (physToWpi [physPin] == -1) printf (" | | ") ; else { /**/ if (wpMode == WPI_MODE_GPIO) pin = physPinToGpio (physPin) ; else if (wpMode == WPI_MODE_PHYS) pin = physPin ; else pin = physToWpi [physPin] ; printf (" | %d", digitalRead (pin)) ; printf (" | %-4s", alts [getAlt (pin)]) ; } printf (" | %-5s", physNames [physPin]) ; if (physToWpi [physPin] == -1) printf (" | | ") ; else printf (" | %-3d | %-3d", physToWpi [physPin], physPinToGpio (physPin)) ; printf (" |\n") ; } /* * allReadall: * Read all the pins regardless of the model. Primarily of use for * the compute module, but handy for other fiddling... ********************************************************************************* */ static void allReadall (void) { int pin ; printf ("+-----+------+-------+ +-----+------+-------+\n") ; printf ("| Pin | Mode | Value | | Pin | Mode | Value |\n") ; printf ("+-----+------+-------+ +-----+------+-------+\n") ; for (pin = 0 ; pin < 27 ; ++pin) { printf ("| %3d ", pin) ; printf ("| %-4s ", alts [getAlt (pin)]) ; printf ("| %s ", digitalRead (pin) == HIGH ? "High" : "Low ") ; printf ("| ") ; printf ("| %3d ", pin + 27) ; printf ("| %-4s ", alts [getAlt (pin + 27)]) ; printf ("| %s ", digitalRead (pin + 27) == HIGH ? "High" : "Low ") ; printf ("|\n") ; } printf ("+-----+------+-------+ +-----+------+-------+\n") ; } /* * abReadall: * Read all the pins on the model A or B. ********************************************************************************* */ void abReadall (int model, int rev) { int pin ; char *type ; if (model == PI_MODEL_A) type = " A" ; else if (rev == PI_VERSION_2) type = "B2" ; else type = "B1" ; printf (" +-----+-----+---------+------+---+-Model %s-+---+------+---------+-----+-----+\n", type) ; printf (" | BCM | wPi | Name | Mode | V | Physical | V | Mode | Name | wPi | BCM |\n") ; printf (" +-----+-----+---------+------+---+----++----+---+------+---------+-----+-----+\n") ; for (pin = 1 ; pin <= 26 ; pin += 2) readallPhys (pin) ; if (rev == PI_VERSION_2) // B version 2 { printf (" +-----+-----+---------+------+---+----++----+---+------+---------+-----+-----+\n") ; for (pin = 51 ; pin <= 54 ; pin += 2) readallPhys (pin) ; } printf (" +-----+-----+---------+------+---+----++----+---+------+---------+-----+-----+\n") ; printf (" | BCM | wPi | Name | Mode | V | Physical | V | Mode | Name | wPi | BCM |\n") ; printf (" +-----+-----+---------+------+---+-Model %s-+---+------+---------+-----+-----+\n", type) ; } /* * piPlusReadall: * Read all the pins on the model A+ or the B+ or actually, all 40-pin Pi's ********************************************************************************* */ static void plus2header (int model) { /**/ if (model == PI_MODEL_AP) printf (" +-----+-----+---------+------+---+---Pi A+--+---+------+---------+-----+-----+\n") ; else if (model == PI_MODEL_BP) printf (" +-----+-----+---------+------+---+---Pi B+--+---+------+---------+-----+-----+\n") ; else if (model == PI_MODEL_ZERO) printf (" +-----+-----+---------+------+---+-Pi Zero--+---+------+---------+-----+-----+\n") ; else if (model == PI_MODEL_ZERO_W) printf (" +-----+-----+---------+------+---+-Pi ZeroW-+---+------+---------+-----+-----+\n") ; else if (model == PI_MODEL_2) printf (" +-----+-----+---------+------+---+---Pi 2---+---+------+---------+-----+-----+\n") ; else if (model == PI_MODEL_3B) printf (" +-----+-----+---------+------+---+---Pi 3B--+---+------+---------+-----+-----+\n") ; else if (model == PI_MODEL_3BP) printf (" +-----+-----+---------+------+---+---Pi 3B+-+---+------+---------+-----+-----+\n") ; else if (model == PI_MODEL_3AP) printf (" +-----+-----+---------+------+---+---Pi 3A+-+---+------+---------+-----+-----+\n") ; else printf (" +-----+-----+---------+------+---+---Pi ?---+---+------+---------+-----+-----+\n") ; } static void piPlusReadall (int model) { int pin ; plus2header (model) ; printf (" | BCM | wPi | Name | Mode | V | Physical | V | Mode | Name | wPi | BCM |\n") ; printf (" +-----+-----+---------+------+---+----++----+---+------+---------+-----+-----+\n") ; for (pin = 1 ; pin <= 40 ; pin += 2) readallPhys (pin) ; printf (" +-----+-----+---------+------+---+----++----+---+------+---------+-----+-----+\n") ; printf (" | BCM | wPi | Name | Mode | V | Physical | V | Mode | Name | wPi | BCM |\n") ; plus2header (model) ; } /* * doReadall: * Generic read all pins called from main program. Works out the Pi type * and calls the appropriate function. ********************************************************************************* */ void doReadall (void) { int model, rev, mem, maker, overVolted ; if (wiringPiNodes != NULL) // External readall { doReadallExternal () ; return ; } piBoardId (&model, &rev, &mem, &maker, &overVolted) ; /**/ if ((model == PI_MODEL_A) || (model == PI_MODEL_B)) abReadall (model, rev) ; else if ((model == PI_MODEL_BP) || (model == PI_MODEL_AP) || (model == PI_MODEL_2) || (model == PI_MODEL_3AP) || (model == PI_MODEL_3B) || (model == PI_MODEL_3BP) || (model == PI_MODEL_ZERO) || (model == PI_MODEL_ZERO_W)) piPlusReadall (model) ; else if ((model == PI_MODEL_CM) || (model == PI_MODEL_CM3) || ((model == PI_MODEL_CM3P))) allReadall () ; else printf ("Oops - unable to determine board type... model: %d\n", model) ; } /* * doAllReadall: * Force reading of all pins regardless of Pi model ********************************************************************************* */ void doAllReadall (void) { allReadall () ; } /* * doQmode: * Query mode on a pin ********************************************************************************* */ void doQmode (int argc, char *argv []) { int pin ; if (argc != 3) { fprintf (stderr, "Usage: %s qmode pin\n", argv [0]) ; exit (EXIT_FAILURE) ; } pin = atoi (argv [2]) ; printf ("%s\n", alts [getAlt (pin)]) ; } wiringpi-2.50/gpio/test.sh0000775000175000017500000000234713442550153015204 0ustar ubuntuubuntu#!/bin/bash # # test.sh: # Simple test: Assumes LEDs on Pins 0-7 and lights them # in-turn. ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# # Simple test - assumes LEDs on Pins 0-7. for i in `seq 0 7`; do gpio mode $i out done while true; do for i in `seq 0 7`; do gpio write $i 1 sleep 0.1 done for i in `seq 0 7`; do gpio write $i 0 sleep 0.1 done done wiringpi-2.50/gpio/Makefile0000664000175000017500000000537513442550153015332 0ustar ubuntuubuntu# # Makefile: # The gpio command: # A swiss-army knige of GPIO shenanigans. # https://projects.drogon.net/wiring-pi # # Copyright (c) 2012-2016 Gordon Henderson ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# DESTDIR?=/usr PREFIX?=/local ifneq ($V,1) Q ?= @ endif #DEBUG = -g -O0 DEBUG = -O2 INCLUDE = -I$(DESTDIR)$(PREFIX)/include CFLAGS = $(DEBUG) -Wall -Wextra $(INCLUDE) -Winline -pipe LDFLAGS = -L$(DESTDIR)$(PREFIX)/lib LIBS = -lwiringPi -lwiringPiDev -lpthread -lrt -lm -lcrypt # May not need to alter anything below this line ############################################################################### SRC = gpio.c readall.c OBJ = $(SRC:.c=.o) all: gpio version.h: ../VERSION $Q echo Need to run newVersion above. gpio: $(OBJ) $Q echo [Link] $Q $(CC) -o $@ $(OBJ) $(LDFLAGS) $(LIBS) .c.o: $Q echo [Compile] $< $Q $(CC) -c $(CFLAGS) $< -o $@ .PHONY: clean clean: $Q echo "[Clean]" $Q rm -f $(OBJ) gpio *~ core tags *.bak .PHONY: tags tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) .PHONY: install install: gpio $Q echo "[Install]" $Q cp gpio $(DESTDIR)$(PREFIX)/bin ifneq ($(WIRINGPI_SUID),0) $Q chown root.root $(DESTDIR)$(PREFIX)/bin/gpio $Q chmod 4755 $(DESTDIR)$(PREFIX)/bin/gpio endif $Q mkdir -p $(DESTDIR)$(PREFIX)/share/man/man1 $Q cp gpio.1 $(DESTDIR)$(PREFIX)/share/man/man1 .PHONY: install-deb install-deb: gpio $Q echo "[Install: deb]" $Q install -m 0755 -d ~/wiringPi/debian-template/wiringPi/usr/bin $Q install -m 0755 gpio ~/wiringPi/debian-template/wiringPi/usr/bin $Q install -m 0755 -d ~/wiringPi/debian-template/wiringPi/usr/share/man/man1 $Q install -m 0644 gpio.1 ~/wiringPi/debian-template/wiringPi/usr/share/man/man1 .PHONY: uninstall uninstall: $Q echo "[UnInstall]" $Q rm -f $(DESTDIR)$(PREFIX)/bin/gpio $Q rm -f $(DESTDIR)$(PREFIX)/share/man/man1/gpio.1 .PHONY: depend depend: makedepend -Y $(SRC) # DO NOT DELETE gpio.o: ../version.h wiringpi-2.50/gpio/pintest0000775000175000017500000000775513442550153015312 0ustar ubuntuubuntu#!/bin/bash # # pintest # Test the Pi's GPIO port # Copyright (c) 2013-2015 Gordon Henderson ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# # logErr pin, expected got ################################################################################ logErr () { if [ $errs = 0 ]; then echo "" fi echo " --> Pin $1 failure. Expected $2, got $3" let errs+=1 } # printErrorCount ################################################################################ printErrCount() { if [ $errs = 0 ]; then echo "No faults detected." elif [ $errs = 1 ]; then echo "One fault detected." else echo "$errs faults detected" fi } # testPins start end ################################################################################ testPins() { start=$1 end=$2 errs=0 printf "%30s %2d:%2d: " "$3" $1 $2 # Set range to inputs for i in `seq $start $end`; do gpio mode $i in done # Enable internal pull-ups and expect to read high for i in `seq $start $end`; do gpio mode $i up if [ `gpio read $i` = 0 ]; then logErr $i 1 0 fi done # Enable internal pull-downs and expect to read low for i in `seq $start $end`; do gpio mode $i down if [ `gpio read $i` = 1 ]; then echo "Pin $i failure - expected 0, got 1" let errs+=1 fi done # Remove the internal pull up/downs for i in `seq $start $end`; do gpio mode $i tri done if [ $errs = 0 ]; then echo " OK" else printErrCount fi let totErrs+=errs } intro() { cat <. *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "../version.h" extern int wiringPiDebug ; // External functions I can't be bothered creating a separate .h file for: extern void doReadall (void) ; extern void doAllReadall (void) ; extern void doQmode (int argc, char *argv []) ; #ifndef TRUE # define TRUE (1==1) # define FALSE (1==2) #endif #define PI_USB_POWER_CONTROL 38 #define I2CDETECT "i2cdetect" #define MODPROBE "modprobe" #define RMMOD "rmmod" int wpMode ; char *usage = "Usage: gpio -v\n" " gpio -h\n" " gpio [-g|-1] ...\n" " gpio [-d] ...\n" " [-x extension:params] [[ -x ...]] ...\n" " gpio [-p] ...\n" " gpio ...\n" " gpio \n" " gpio readall\n" " gpio unexportall/exports\n" " gpio export/edge/unexport ...\n" " gpio wfi \n" " gpio drive \n" " gpio pwm-bal/pwm-ms \n" " gpio pwmr \n" " gpio pwmc \n" " gpio load spi/i2c\n" " gpio unload spi/i2c\n" " gpio i2cd/i2cdetect\n" " gpio rbx/rbd\n" " gpio wb \n" " gpio usbp high/low\n" " gpio gbr \n" " gpio gbw " ; // No trailing newline needed here. #ifdef NOT_FOR_NOW /* * decodePin: * Decode a pin "number" which can actually be a pin name to represent * one of the Pi's on-board pins. ********************************************************************************* */ static int decodePin (const char *str) { // The first case - see if it's a number: if (isdigit (str [0])) return atoi (str) ; return 0 ; } #endif /* * findExecutable: * Code to locate the path to the given executable. We have a fixed list * of locations to try which completely overrides any $PATH environment. * This may be detrimental, however it avoids the reliance on $PATH * which may be a security issue when this program is run a set-uid-root. ********************************************************************************* */ static const char *searchPath [] = { "/sbin", "/usr/sbin", "/bin", "/usr/bin", NULL, } ; static char *findExecutable (const char *progName) { static char *path = NULL ; int len = strlen (progName) ; int i = 0 ; struct stat statBuf ; for (i = 0 ; searchPath [i] != NULL ; ++i) { path = malloc (strlen (searchPath [i]) + len + 2) ; sprintf (path, "%s/%s", searchPath [i], progName) ; if (stat (path, &statBuf) == 0) return path ; free (path) ; } return NULL ; } /* * changeOwner: * Change the ownership of the file to the real userId of the calling * program so we can access it. ********************************************************************************* */ static void changeOwner (char *cmd, char *file) { uid_t uid = getuid () ; uid_t gid = getgid () ; if (chown (file, uid, gid) != 0) { // Removed (ignoring) the check for not existing as I'm fed-up with morons telling me that // the warning message is an error. if (errno != ENOENT) fprintf (stderr, "%s: Unable to change ownership of %s: %s\n", cmd, file, strerror (errno)) ; } } /* * moduleLoaded: * Return true/false if the supplied module is loaded ********************************************************************************* */ static int moduleLoaded (char *modName) { int len = strlen (modName) ; int found = FALSE ; FILE *fd = fopen ("/proc/modules", "r") ; char line [80] ; if (fd == NULL) { fprintf (stderr, "gpio: Unable to check /proc/modules: %s\n", strerror (errno)) ; exit (1) ; } while (fgets (line, 80, fd) != NULL) { if (strncmp (line, modName, len) != 0) continue ; found = TRUE ; break ; } fclose (fd) ; return found ; } /* * doLoad: * Load either the spi or i2c modules and change device ownerships, etc. ********************************************************************************* */ static void checkDevTree (char *argv []) { struct stat statBuf ; if (stat ("/proc/device-tree", &statBuf) == 0) // We're on a devtree system ... { fprintf (stderr, "%s: Unable to load/unload modules as this Pi has the device tree enabled.\n" " You need to run the raspi-config program (as root) and select the\n" " modules (SPI or I2C) that you wish to load/unload there and reboot.\n", argv [0]) ; exit (1) ; } } static void _doLoadUsage (char *argv []) { fprintf (stderr, "Usage: %s load [I2C baudrate in Kb/sec]\n", argv [0]) ; exit (1) ; } static void doLoad (int argc, char *argv []) { char *module1, *module2 ; char cmd [80] ; char *file1, *file2 ; char args1 [32], args2 [32] ; checkDevTree (argv) ; if (argc < 3) _doLoadUsage (argv) ; args1 [0] = args2 [0] = 0 ; /**/ if (strcasecmp (argv [2], "spi") == 0) { module1 = "spidev" ; module2 = "spi_bcm2708" ; file1 = "/dev/spidev0.0" ; file2 = "/dev/spidev0.1" ; if (argc == 4) { fprintf (stderr, "%s: Unable to set the buffer size now. Load aborted. Please see the man page.\n", argv [0]) ; exit (1) ; } else if (argc > 4) _doLoadUsage (argv) ; } else if (strcasecmp (argv [2], "i2c") == 0) { module1 = "i2c_dev" ; module2 = "i2c_bcm2708" ; file1 = "/dev/i2c-0" ; file2 = "/dev/i2c-1" ; if (argc == 4) sprintf (args2, " baudrate=%d", atoi (argv [3]) * 1000) ; else if (argc > 4) _doLoadUsage (argv) ; } else _doLoadUsage (argv) ; if (findExecutable ("modprobe") == NULL) printf ("No found\n") ; if (!moduleLoaded (module1)) { sprintf (cmd, "%s %s%s", findExecutable (MODPROBE), module1, args1) ; system (cmd) ; } if (!moduleLoaded (module2)) { sprintf (cmd, "%s %s%s", findExecutable (MODPROBE), module2, args2) ; system (cmd) ; } if (!moduleLoaded (module2)) { fprintf (stderr, "%s: Unable to load %s\n", argv [0], module2) ; exit (1) ; } sleep (1) ; // To let things get settled changeOwner (argv [0], file1) ; changeOwner (argv [0], file2) ; } /* * doUnLoad: * Un-Load either the spi or i2c modules and change device ownerships, etc. ********************************************************************************* */ static void _doUnLoadUsage (char *argv []) { fprintf (stderr, "Usage: %s unload \n", argv [0]) ; exit (1) ; } static void doUnLoad (int argc, char *argv []) { char *module1, *module2 ; char cmd [80] ; checkDevTree (argv) ; if (argc != 3) _doUnLoadUsage (argv) ; /**/ if (strcasecmp (argv [2], "spi") == 0) { module1 = "spidev" ; module2 = "spi_bcm2708" ; } else if (strcasecmp (argv [2], "i2c") == 0) { module1 = "i2c_dev" ; module2 = "i2c_bcm2708" ; } else _doUnLoadUsage (argv) ; if (moduleLoaded (module1)) { sprintf (cmd, "%s %s", findExecutable (RMMOD), module1) ; system (cmd) ; } if (moduleLoaded (module2)) { sprintf (cmd, "%s %s", findExecutable (RMMOD), module2) ; system (cmd) ; } } /* * doI2Cdetect: * Run the i2cdetect command with the right runes for this Pi revision ********************************************************************************* */ static void doI2Cdetect (UNU int argc, char *argv []) { int port = piGpioLayout () == 1 ? 0 : 1 ; char *c, *command ; if ((c = findExecutable (I2CDETECT)) == NULL) { fprintf (stderr, "%s: Unable to find i2cdetect command: %s\n", argv [0], strerror (errno)) ; return ; } if (!moduleLoaded ("i2c_dev")) { fprintf (stderr, "%s: The I2C kernel module(s) are not loaded.\n", argv [0]) ; return ; } command = malloc (strlen (c) + 16) ; sprintf (command, "%s -y %d", c, port) ; if (system (command) < 0) fprintf (stderr, "%s: Unable to run i2cdetect: %s\n", argv [0], strerror (errno)) ; } /* * doExports: * List all GPIO exports ********************************************************************************* */ static void doExports (UNU int argc, UNU char *argv []) { int fd ; int i, l, first ; char fName [128] ; char buf [16] ; for (first = 0, i = 0 ; i < 64 ; ++i) // Crude, but effective { // Try to read the direction sprintf (fName, "/sys/class/gpio/gpio%d/direction", i) ; if ((fd = open (fName, O_RDONLY)) == -1) continue ; if (first == 0) { ++first ; printf ("GPIO Pins exported:\n") ; } printf ("%4d: ", i) ; if ((l = read (fd, buf, 16)) == 0) sprintf (buf, "%s", "?") ; buf [l] = 0 ; if ((buf [strlen (buf) - 1]) == '\n') buf [strlen (buf) - 1] = 0 ; printf ("%-3s", buf) ; close (fd) ; // Try to Read the value sprintf (fName, "/sys/class/gpio/gpio%d/value", i) ; if ((fd = open (fName, O_RDONLY)) == -1) { printf ("No Value file (huh?)\n") ; continue ; } if ((l = read (fd, buf, 16)) == 0) sprintf (buf, "%s", "?") ; buf [l] = 0 ; if ((buf [strlen (buf) - 1]) == '\n') buf [strlen (buf) - 1] = 0 ; printf (" %s", buf) ; // Read any edge trigger file sprintf (fName, "/sys/class/gpio/gpio%d/edge", i) ; if ((fd = open (fName, O_RDONLY)) == -1) { printf ("\n") ; continue ; } if ((l = read (fd, buf, 16)) == 0) sprintf (buf, "%s", "?") ; buf [l] = 0 ; if ((buf [strlen (buf) - 1]) == '\n') buf [strlen (buf) - 1] = 0 ; printf (" %-8s\n", buf) ; close (fd) ; } } /* * doExport: * gpio export pin mode * This uses the /sys/class/gpio device interface. ********************************************************************************* */ void doExport (int argc, char *argv []) { FILE *fd ; int pin ; char *mode ; char fName [128] ; if (argc != 4) { fprintf (stderr, "Usage: %s export pin mode\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; mode = argv [3] ; if ((fd = fopen ("/sys/class/gpio/export", "w")) == NULL) { fprintf (stderr, "%s: Unable to open GPIO export interface: %s\n", argv [0], strerror (errno)) ; exit (1) ; } fprintf (fd, "%d\n", pin) ; fclose (fd) ; sprintf (fName, "/sys/class/gpio/gpio%d/direction", pin) ; if ((fd = fopen (fName, "w")) == NULL) { fprintf (stderr, "%s: Unable to open GPIO direction interface for pin %d: %s\n", argv [0], pin, strerror (errno)) ; exit (1) ; } /**/ if ((strcasecmp (mode, "in") == 0) || (strcasecmp (mode, "input") == 0)) fprintf (fd, "in\n") ; else if ((strcasecmp (mode, "out") == 0) || (strcasecmp (mode, "output") == 0)) fprintf (fd, "out\n") ; else if ((strcasecmp (mode, "high") == 0) || (strcasecmp (mode, "up") == 0)) fprintf (fd, "high\n") ; else if ((strcasecmp (mode, "low") == 0) || (strcasecmp (mode, "down") == 0)) fprintf (fd, "low\n") ; else { fprintf (stderr, "%s: Invalid mode: %s. Should be in, out, high or low\n", argv [1], mode) ; exit (1) ; } fclose (fd) ; // Change ownership so the current user can actually use it sprintf (fName, "/sys/class/gpio/gpio%d/value", pin) ; changeOwner (argv [0], fName) ; sprintf (fName, "/sys/class/gpio/gpio%d/edge", pin) ; changeOwner (argv [0], fName) ; } /* * doWfi: * gpio wfi pin mode * Wait for Interrupt on a given pin. * Slight cheat here - it's easier to actually use ISR now (which calls * gpio to set the pin modes!) then we simply sleep, and expect the thread * to exit the program. Crude but effective. ********************************************************************************* */ static void wfi (void) { exit (0) ; } void doWfi (int argc, char *argv []) { int pin, mode ; if (argc != 4) { fprintf (stderr, "Usage: %s wfi pin mode\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; /**/ if (strcasecmp (argv [3], "rising") == 0) mode = INT_EDGE_RISING ; else if (strcasecmp (argv [3], "falling") == 0) mode = INT_EDGE_FALLING ; else if (strcasecmp (argv [3], "both") == 0) mode = INT_EDGE_BOTH ; else { fprintf (stderr, "%s: wfi: Invalid mode: %s. Should be rising, falling or both\n", argv [1], argv [3]) ; exit (1) ; } if (wiringPiISR (pin, mode, &wfi) < 0) { fprintf (stderr, "%s: wfi: Unable to setup ISR: %s\n", argv [1], strerror (errno)) ; exit (1) ; } for (;;) delay (9999) ; } /* * doEdge: * gpio edge pin mode * Easy access to changing the edge trigger on a GPIO pin * This uses the /sys/class/gpio device interface. ********************************************************************************* */ void doEdge (int argc, char *argv []) { FILE *fd ; int pin ; char *mode ; char fName [128] ; if (argc != 4) { fprintf (stderr, "Usage: %s edge pin mode\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; mode = argv [3] ; // Export the pin and set direction to input if ((fd = fopen ("/sys/class/gpio/export", "w")) == NULL) { fprintf (stderr, "%s: Unable to open GPIO export interface: %s\n", argv [0], strerror (errno)) ; exit (1) ; } fprintf (fd, "%d\n", pin) ; fclose (fd) ; sprintf (fName, "/sys/class/gpio/gpio%d/direction", pin) ; if ((fd = fopen (fName, "w")) == NULL) { fprintf (stderr, "%s: Unable to open GPIO direction interface for pin %d: %s\n", argv [0], pin, strerror (errno)) ; exit (1) ; } fprintf (fd, "in\n") ; fclose (fd) ; sprintf (fName, "/sys/class/gpio/gpio%d/edge", pin) ; if ((fd = fopen (fName, "w")) == NULL) { fprintf (stderr, "%s: Unable to open GPIO edge interface for pin %d: %s\n", argv [0], pin, strerror (errno)) ; exit (1) ; } /**/ if (strcasecmp (mode, "none") == 0) fprintf (fd, "none\n") ; else if (strcasecmp (mode, "rising") == 0) fprintf (fd, "rising\n") ; else if (strcasecmp (mode, "falling") == 0) fprintf (fd, "falling\n") ; else if (strcasecmp (mode, "both") == 0) fprintf (fd, "both\n") ; else { fprintf (stderr, "%s: Invalid mode: %s. Should be none, rising, falling or both\n", argv [1], mode) ; exit (1) ; } // Change ownership of the value and edge files, so the current user can actually use it! sprintf (fName, "/sys/class/gpio/gpio%d/value", pin) ; changeOwner (argv [0], fName) ; sprintf (fName, "/sys/class/gpio/gpio%d/edge", pin) ; changeOwner (argv [0], fName) ; fclose (fd) ; } /* * doUnexport: * gpio unexport pin * This uses the /sys/class/gpio device interface. ********************************************************************************* */ void doUnexport (int argc, char *argv []) { FILE *fd ; int pin ; if (argc != 3) { fprintf (stderr, "Usage: %s unexport pin\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; if ((fd = fopen ("/sys/class/gpio/unexport", "w")) == NULL) { fprintf (stderr, "%s: Unable to open GPIO export interface\n", argv [0]) ; exit (1) ; } fprintf (fd, "%d\n", pin) ; fclose (fd) ; } /* * doUnexportAll: * gpio unexportall * Un-Export all the GPIO pins. * This uses the /sys/class/gpio device interface. ********************************************************************************* */ void doUnexportall (char *progName) { FILE *fd ; int pin ; for (pin = 0 ; pin < 63 ; ++pin) { if ((fd = fopen ("/sys/class/gpio/unexport", "w")) == NULL) { fprintf (stderr, "%s: Unable to open GPIO export interface\n", progName) ; exit (1) ; } fprintf (fd, "%d\n", pin) ; fclose (fd) ; } } /* * doReset: * Reset the GPIO pins - as much as we can do ********************************************************************************* */ static void doReset (UNU char *progName) { printf ("GPIO Reset is dangerous and has been removed from the gpio command.\n") ; printf (" - Please write a shell-script to reset the GPIO pins into the state\n") ; printf (" that you need them in for your applications.\n") ; } /* * doMode: * gpio mode pin mode ... ********************************************************************************* */ void doMode (int argc, char *argv []) { int pin ; char *mode ; if (argc != 4) { fprintf (stderr, "Usage: %s mode pin mode\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; mode = argv [3] ; /**/ if (strcasecmp (mode, "in") == 0) pinMode (pin, INPUT) ; else if (strcasecmp (mode, "input") == 0) pinMode (pin, INPUT) ; else if (strcasecmp (mode, "out") == 0) pinMode (pin, OUTPUT) ; else if (strcasecmp (mode, "output") == 0) pinMode (pin, OUTPUT) ; else if (strcasecmp (mode, "pwm") == 0) pinMode (pin, PWM_OUTPUT) ; else if (strcasecmp (mode, "pwmTone") == 0) pinMode (pin, PWM_TONE_OUTPUT) ; else if (strcasecmp (mode, "clock") == 0) pinMode (pin, GPIO_CLOCK) ; else if (strcasecmp (mode, "up") == 0) pullUpDnControl (pin, PUD_UP) ; else if (strcasecmp (mode, "down") == 0) pullUpDnControl (pin, PUD_DOWN) ; else if (strcasecmp (mode, "tri") == 0) pullUpDnControl (pin, PUD_OFF) ; else if (strcasecmp (mode, "off") == 0) pullUpDnControl (pin, PUD_OFF) ; else if (strcasecmp (mode, "alt0") == 0) pinModeAlt (pin, 0b100) ; else if (strcasecmp (mode, "alt1") == 0) pinModeAlt (pin, 0b101) ; else if (strcasecmp (mode, "alt2") == 0) pinModeAlt (pin, 0b110) ; else if (strcasecmp (mode, "alt3") == 0) pinModeAlt (pin, 0b111) ; else if (strcasecmp (mode, "alt4") == 0) pinModeAlt (pin, 0b011) ; else if (strcasecmp (mode, "alt5") == 0) pinModeAlt (pin, 0b010) ; else { fprintf (stderr, "%s: Invalid mode: %s. Should be in/out/pwm/clock/up/down/tri\n", argv [1], mode) ; exit (1) ; } } /* * doPadDrive: * gpio drive group value ********************************************************************************* */ static void doPadDrive (int argc, char *argv []) { int group, val ; if (argc != 4) { fprintf (stderr, "Usage: %s drive group value\n", argv [0]) ; exit (1) ; } group = atoi (argv [2]) ; val = atoi (argv [3]) ; if ((group < 0) || (group > 2)) { fprintf (stderr, "%s: drive group not 0, 1 or 2: %d\n", argv [0], group) ; exit (1) ; } if ((val < 0) || (val > 7)) { fprintf (stderr, "%s: drive value not 0-7: %d\n", argv [0], val) ; exit (1) ; } setPadDrive (group, val) ; } /* * doUsbP: * Control USB Power - High (1.2A) or Low (600mA) * gpio usbp high/low ********************************************************************************* */ static void doUsbP (int argc, char *argv []) { int model, rev, mem, maker, overVolted ; if (argc != 3) { fprintf (stderr, "Usage: %s usbp high|low\n", argv [0]) ; exit (1) ; } // Make sure we're on a B+ piBoardId (&model, &rev, &mem, &maker, &overVolted) ; if (!((model == PI_MODEL_BP) || (model == PI_MODEL_2))) { fprintf (stderr, "USB power contol is applicable to B+ and v2 boards only.\n") ; exit (1) ; } // Make sure we start in BCM_GPIO mode wiringPiSetupGpio () ; if ((strcasecmp (argv [2], "high") == 0) || (strcasecmp (argv [2], "hi") == 0)) { digitalWrite (PI_USB_POWER_CONTROL, 1) ; pinMode (PI_USB_POWER_CONTROL, OUTPUT) ; printf ("Switched to HIGH current USB (1.2A)\n") ; return ; } if ((strcasecmp (argv [2], "low") == 0) || (strcasecmp (argv [2], "lo") == 0)) { digitalWrite (PI_USB_POWER_CONTROL, 0) ; pinMode (PI_USB_POWER_CONTROL, OUTPUT) ; printf ("Switched to LOW current USB (600mA)\n") ; return ; } fprintf (stderr, "Usage: %s usbp high|low\n", argv [0]) ; exit (1) ; } /* * doGbw: * gpio gbw channel value * Gertboard Write - To the Analog output ********************************************************************************* */ static void doGbw (int argc, char *argv []) { int channel, value ; if (argc != 4) { fprintf (stderr, "Usage: %s gbw \n", argv [0]) ; exit (1) ; } channel = atoi (argv [2]) ; value = atoi (argv [3]) ; if ((channel < 0) || (channel > 1)) { fprintf (stderr, "%s: gbw: Channel number must be 0 or 1\n", argv [0]) ; exit (1) ; } if ((value < 0) || (value > 255)) { fprintf (stderr, "%s: gbw: Value must be from 0 to 255\n", argv [0]) ; exit (1) ; } if (gertboardAnalogSetup (64) < 0) { fprintf (stderr, "Unable to initialise the Gertboard SPI interface: %s\n", strerror (errno)) ; exit (1) ; } analogWrite (64 + channel, value) ; } /* * doGbr: * gpio gbr channel * From the analog input ********************************************************************************* */ static void doGbr (int argc, char *argv []) { int channel ; if (argc != 3) { fprintf (stderr, "Usage: %s gbr \n", argv [0]) ; exit (1) ; } channel = atoi (argv [2]) ; if ((channel < 0) || (channel > 1)) { fprintf (stderr, "%s: gbr: Channel number must be 0 or 1\n", argv [0]) ; exit (1) ; } if (gertboardAnalogSetup (64) < 0) { fprintf (stderr, "Unable to initialise the Gertboard SPI interface: %s\n", strerror (errno)) ; exit (1) ; } printf ("%d\n", analogRead (64 + channel)) ; } /* * doWrite: * gpio write pin value ********************************************************************************* */ static void doWrite (int argc, char *argv []) { int pin, val ; if (argc != 4) { fprintf (stderr, "Usage: %s write pin value\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; /**/ if ((strcasecmp (argv [3], "up") == 0) || (strcasecmp (argv [3], "on") == 0)) val = 1 ; else if ((strcasecmp (argv [3], "down") == 0) || (strcasecmp (argv [3], "off") == 0)) val = 0 ; else val = atoi (argv [3]) ; /**/ if (val == 0) digitalWrite (pin, LOW) ; else digitalWrite (pin, HIGH) ; } /* * doAwriterite: * gpio awrite pin value ********************************************************************************* */ static void doAwrite (int argc, char *argv []) { int pin, val ; if (argc != 4) { fprintf (stderr, "Usage: %s awrite pin value\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; val = atoi (argv [3]) ; analogWrite (pin, val) ; } /* * doWriteByte: * gpio wb value ********************************************************************************* */ static void doWriteByte (int argc, char *argv []) { int val ; if (argc != 3) { fprintf (stderr, "Usage: %s wb value\n", argv [0]) ; exit (1) ; } val = (int)strtol (argv [2], NULL, 0) ; digitalWriteByte (val) ; } /* * doReadByte: * gpio rbx|rbd value ********************************************************************************* */ static void doReadByte (int argc, char *argv [], int printHex) { int val ; if (argc != 2) { fprintf (stderr, "Usage: %s rbx|rbd\n", argv [0]) ; exit (1) ; } val = digitalReadByte () ; if (printHex) printf ("%02X\n", val) ; else printf ("%d\n", val) ; } /* * doRead: * Read a pin and return the value ********************************************************************************* */ void doRead (int argc, char *argv []) { int pin, val ; if (argc != 3) { fprintf (stderr, "Usage: %s read pin\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; val = digitalRead (pin) ; printf ("%s\n", val == 0 ? "0" : "1") ; } /* * doAread: * Read an analog pin and return the value ********************************************************************************* */ void doAread (int argc, char *argv []) { if (argc != 3) { fprintf (stderr, "Usage: %s aread pin\n", argv [0]) ; exit (1) ; } printf ("%d\n", analogRead (atoi (argv [2]))) ; } /* * doToggle: * Toggle an IO pin ********************************************************************************* */ void doToggle (int argc, char *argv []) { int pin ; if (argc != 3) { fprintf (stderr, "Usage: %s toggle pin\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; digitalWrite (pin, !digitalRead (pin)) ; } /* * doBlink: * Blink an IO pin ********************************************************************************* */ void doBlink (int argc, char *argv []) { int pin ; if (argc != 3) { fprintf (stderr, "Usage: %s blink pin\n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; pinMode (pin, OUTPUT) ; for (;;) { digitalWrite (pin, !digitalRead (pin)) ; delay (500) ; } } /* * doPwmTone: * Output a tone in a PWM pin ********************************************************************************* */ void doPwmTone (int argc, char *argv []) { int pin, freq ; if (argc != 4) { fprintf (stderr, "Usage: %s pwmTone \n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; freq = atoi (argv [3]) ; pwmToneWrite (pin, freq) ; } /* * doClock: * Output a clock on a pin ********************************************************************************* */ void doClock (int argc, char *argv []) { int pin, freq ; if (argc != 4) { fprintf (stderr, "Usage: %s clock \n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; freq = atoi (argv [3]) ; gpioClockSet (pin, freq) ; } /* * doPwm: * Output a PWM value on a pin ********************************************************************************* */ void doPwm (int argc, char *argv []) { int pin, val ; if (argc != 4) { fprintf (stderr, "Usage: %s pwm \n", argv [0]) ; exit (1) ; } pin = atoi (argv [2]) ; val = atoi (argv [3]) ; pwmWrite (pin, val) ; } /* * doPwmMode: doPwmRange: doPwmClock: * Change the PWM mode, range and clock divider values ********************************************************************************* */ static void doPwmMode (int mode) { pwmSetMode (mode) ; } static void doPwmRange (int argc, char *argv []) { unsigned int range ; if (argc != 3) { fprintf (stderr, "Usage: %s pwmr \n", argv [0]) ; exit (1) ; } range = (unsigned int)strtoul (argv [2], NULL, 10) ; if (range == 0) { fprintf (stderr, "%s: range must be > 0\n", argv [0]) ; exit (1) ; } pwmSetRange (range) ; } static void doPwmClock (int argc, char *argv []) { unsigned int clock ; if (argc != 3) { fprintf (stderr, "Usage: %s pwmc \n", argv [0]) ; exit (1) ; } clock = (unsigned int)strtoul (argv [2], NULL, 10) ; if ((clock < 1) || (clock > 4095)) { fprintf (stderr, "%s: clock must be between 0 and 4096\n", argv [0]) ; exit (1) ; } pwmSetClock (clock) ; } /* * doVersion: * Handle the ever more complicated version command and print out * some usefull information. ********************************************************************************* */ static void doVersion (char *argv []) { int model, rev, mem, maker, warranty ; struct stat statBuf ; char name [80] ; FILE *fd ; int vMaj, vMin ; wiringPiVersion (&vMaj, &vMin) ; printf ("gpio version: %d.%d\n", vMaj, vMin) ; printf ("Copyright (c) 2012-2018 Gordon Henderson\n") ; printf ("This is free software with ABSOLUTELY NO WARRANTY.\n") ; printf ("For details type: %s -warranty\n", argv [0]) ; printf ("\n") ; piBoardId (&model, &rev, &mem, &maker, &warranty) ; printf ("Raspberry Pi Details:\n") ; printf (" Type: %s, Revision: %s, Memory: %dMB, Maker: %s %s\n", piModelNames [model], piRevisionNames [rev], piMemorySize [mem], piMakerNames [maker], warranty ? "[Out of Warranty]" : "") ; // Check for device tree if (stat ("/proc/device-tree", &statBuf) == 0) // We're on a devtree system ... printf (" * Device tree is enabled.\n") ; if (stat ("/proc/device-tree/model", &statBuf) == 0) // Output Kernel idea of board type { if ((fd = fopen ("/proc/device-tree/model", "r")) != NULL) { fgets (name, 80, fd) ; fclose (fd) ; printf (" *--> %s\n", name) ; } } if (stat ("/dev/gpiomem", &statBuf) == 0) // User level GPIO is GO printf (" * This Raspberry Pi supports user-level GPIO access.\n") ; else printf (" * Root or sudo required for GPIO access.\n") ; } /* * main: * Start here ********************************************************************************* */ int main (int argc, char *argv []) { int i ; if (getenv ("WIRINGPI_DEBUG") != NULL) { printf ("gpio: wiringPi debug mode enabled\n") ; wiringPiDebug = TRUE ; } if (argc == 1) { fprintf (stderr, "%s: At your service!\n" " Type: gpio -h for full details and\n" " gpio readall for a quick printout of your connector details\n", argv [0]) ; exit (EXIT_FAILURE) ; } // Help if (strcasecmp (argv [1], "-h") == 0) { printf ("%s: %s\n", argv [0], usage) ; exit (EXIT_SUCCESS) ; } // Version & Warranty // Wish I could remember why I have both -R and -V ... if ((strcmp (argv [1], "-R") == 0) || (strcmp (argv [1], "-V") == 0)) { printf ("%d\n", piGpioLayout ()) ; exit (EXIT_SUCCESS) ; } // Version and information if (strcmp (argv [1], "-v") == 0) { doVersion (argv) ; exit (EXIT_SUCCESS) ; } if (strcasecmp (argv [1], "-warranty") == 0) { printf ("gpio version: %s\n", VERSION) ; printf ("Copyright (c) 2012-2018 Gordon Henderson\n") ; printf ("\n") ; printf (" This program is free software; you can redistribute it and/or modify\n") ; printf (" it under the terms of the GNU Leser General Public License as published\n") ; printf (" by the Free Software Foundation, either version 3 of the License, or\n") ; printf (" (at your option) any later version.\n") ; printf ("\n") ; printf (" This program is distributed in the hope that it will be useful,\n") ; printf (" but WITHOUT ANY WARRANTY; without even the implied warranty of\n") ; printf (" MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n") ; printf (" GNU Lesser General Public License for more details.\n") ; printf ("\n") ; printf (" You should have received a copy of the GNU Lesser General Public License\n") ; printf (" along with this program. If not, see .\n") ; printf ("\n") ; exit (EXIT_SUCCESS) ; } if (geteuid () != 0) { fprintf (stderr, "%s: Must be root to run. Program should be suid root. This is an error.\n", argv [0]) ; exit (EXIT_FAILURE) ; } // Initial test for /sys/class/gpio operations: /**/ if (strcasecmp (argv [1], "exports" ) == 0) { doExports (argc, argv) ; return 0 ; } else if (strcasecmp (argv [1], "export" ) == 0) { doExport (argc, argv) ; return 0 ; } else if (strcasecmp (argv [1], "edge" ) == 0) { doEdge (argc, argv) ; return 0 ; } else if (strcasecmp (argv [1], "unexport" ) == 0) { doUnexport (argc, argv) ; return 0 ; } else if (strcasecmp (argv [1], "unexportall") == 0) { doUnexportall (argv [0]) ; return 0 ; } // Check for load command: if (strcasecmp (argv [1], "load" ) == 0) { doLoad (argc, argv) ; return 0 ; } if (strcasecmp (argv [1], "unload" ) == 0) { doUnLoad (argc, argv) ; return 0 ; } // Check for usb power command if (strcasecmp (argv [1], "usbp" ) == 0) { doUsbP (argc, argv) ; return 0 ; } // Gertboard commands if (strcasecmp (argv [1], "gbr" ) == 0) { doGbr (argc, argv) ; return 0 ; } if (strcasecmp (argv [1], "gbw" ) == 0) { doGbw (argc, argv) ; return 0 ; } // Check for allreadall command, force Gpio mode if (strcasecmp (argv [1], "allreadall") == 0) { wiringPiSetupGpio () ; doAllReadall () ; return 0 ; } // Check for -g argument /**/ if (strcasecmp (argv [1], "-g") == 0) { wiringPiSetupGpio () ; for (i = 2 ; i < argc ; ++i) argv [i - 1] = argv [i] ; --argc ; wpMode = WPI_MODE_GPIO ; } // Check for -1 argument else if (strcasecmp (argv [1], "-1") == 0) { wiringPiSetupPhys () ; for (i = 2 ; i < argc ; ++i) argv [i - 1] = argv [i] ; --argc ; wpMode = WPI_MODE_PHYS ; } // Check for -p argument for PiFace else if (strcasecmp (argv [1], "-p") == 0) { piFaceSetup (200) ; for (i = 2 ; i < argc ; ++i) argv [i - 1] = argv [i] ; --argc ; wpMode = WPI_MODE_PIFACE ; } // Check for -z argument so we don't actually initialise wiringPi else if (strcasecmp (argv [1], "-z") == 0) { for (i = 2 ; i < argc ; ++i) argv [i - 1] = argv [i] ; --argc ; wpMode = WPI_MODE_UNINITIALISED ; } // Default to wiringPi mode else { wiringPiSetup () ; wpMode = WPI_MODE_PINS ; } // Check for -x argument to load in a new extension // -x extension:base:args // Can load many modules, but unless daemon mode we can only send one // command at a time. while (strcasecmp (argv [1], "-x") == 0) { if (argc < 3) { fprintf (stderr, "%s: -x missing extension command.\n", argv [0]) ; exit (EXIT_FAILURE) ; } if (!loadWPiExtension (argv [0], argv [2], TRUE)) { fprintf (stderr, "%s: Extension load failed: %s\n", argv [0], strerror (errno)) ; exit (EXIT_FAILURE) ; } // Shift args down by 2 for (i = 3 ; i < argc ; ++i) argv [i - 2] = argv [i] ; argc -= 2 ; } if (argc <= 1) { fprintf (stderr, "%s: no command given\n", argv [0]) ; exit (EXIT_FAILURE) ; } // Core wiringPi functions /**/ if (strcasecmp (argv [1], "mode" ) == 0) doMode (argc, argv) ; else if (strcasecmp (argv [1], "read" ) == 0) doRead (argc, argv) ; else if (strcasecmp (argv [1], "write" ) == 0) doWrite (argc, argv) ; else if (strcasecmp (argv [1], "pwm" ) == 0) doPwm (argc, argv) ; else if (strcasecmp (argv [1], "awrite" ) == 0) doAwrite (argc, argv) ; else if (strcasecmp (argv [1], "aread" ) == 0) doAread (argc, argv) ; // GPIO Nicies else if (strcasecmp (argv [1], "toggle" ) == 0) doToggle (argc, argv) ; else if (strcasecmp (argv [1], "blink" ) == 0) doBlink (argc, argv) ; // Pi Specifics else if (strcasecmp (argv [1], "pwm-bal" ) == 0) doPwmMode (PWM_MODE_BAL) ; else if (strcasecmp (argv [1], "pwm-ms" ) == 0) doPwmMode (PWM_MODE_MS) ; else if (strcasecmp (argv [1], "pwmr" ) == 0) doPwmRange (argc, argv) ; else if (strcasecmp (argv [1], "pwmc" ) == 0) doPwmClock (argc, argv) ; else if (strcasecmp (argv [1], "pwmTone" ) == 0) doPwmTone (argc, argv) ; else if (strcasecmp (argv [1], "drive" ) == 0) doPadDrive (argc, argv) ; else if (strcasecmp (argv [1], "readall" ) == 0) doReadall () ; else if (strcasecmp (argv [1], "nreadall" ) == 0) doReadall () ; else if (strcasecmp (argv [1], "pins" ) == 0) doReadall () ; else if (strcasecmp (argv [1], "qmode" ) == 0) doQmode (argc, argv) ; else if (strcasecmp (argv [1], "i2cdetect") == 0) doI2Cdetect (argc, argv) ; else if (strcasecmp (argv [1], "i2cd" ) == 0) doI2Cdetect (argc, argv) ; else if (strcasecmp (argv [1], "reset" ) == 0) doReset (argv [0]) ; else if (strcasecmp (argv [1], "wb" ) == 0) doWriteByte (argc, argv) ; else if (strcasecmp (argv [1], "rbx" ) == 0) doReadByte (argc, argv, TRUE) ; else if (strcasecmp (argv [1], "rbd" ) == 0) doReadByte (argc, argv, FALSE) ; else if (strcasecmp (argv [1], "clock" ) == 0) doClock (argc, argv) ; else if (strcasecmp (argv [1], "wfi" ) == 0) doWfi (argc, argv) ; else { fprintf (stderr, "%s: Unknown command: %s.\n", argv [0], argv [1]) ; exit (EXIT_FAILURE) ; } return 0 ; } wiringpi-2.50/gpio/COPYING.LESSER0000664000175000017500000001674313442550153015722 0ustar ubuntuubuntu GNU LESSER GENERAL PUBLIC LICENSE Version 3, 29 June 2007 Copyright (C) 2007 Free Software Foundation, Inc. Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below. 0. Additional Definitions. As used herein, "this License" refers to version 3 of the GNU Lesser General Public License, and the "GNU GPL" refers to version 3 of the GNU General Public License. "The Library" refers to a covered work governed by this License, other than an Application or a Combined Work as defined below. An "Application" is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library. A "Combined Work" is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the "Linked Version". The "Minimal Corresponding Source" for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version. The "Corresponding Application Code" for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work. 1. Exception to Section 3 of the GNU GPL. You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL. 2. Conveying Modified Versions. If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version: a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy. 3. Object Code Incorporating Material from Library Header Files. The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following: a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the object code with a copy of the GNU GPL and this license document. 4. Combined Works. You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following: a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the Combined Work with a copy of the GNU GPL and this license document. c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document. d) Do one of the following: 0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source. 1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version. e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.) 5. Combined Libraries. You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following: a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License. b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. 6. Revised Versions of the GNU Lesser General Public License. The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License "or any later version" applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation. If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library. wiringpi-2.50/gpio/gpio.10000664000175000017500000002230613442550153014703 0ustar ubuntuubuntu.TH GPIO 1 "March 2018" wiringPi "Command-Line access to Raspberry Pi's GPIO" .SH NAME gpio \- Command-line access to Raspberry Pi's GPIO .SH SYNOPSIS .B gpio .B \-v .PP .B gpio .B [ \-g | \-1 ] .B mode/read/write/aread/awrite/wb/pwm/pwnTone/clock/toggle/blink ... .PP .B gpio .B [ \-x extension:params ] .B mode/read/write/aread/awrite/pwm/toggle/blink ... .PP .B gpio .B [ \-p ] .B read/write/toggle/blink .B ... .PP .B gpio .B [ \-p ] .B pwnTone pin frequency .B ... .PP .B gpio .B readall .PP .B gpio .B unexportall/exports .PP .B gpio .B export/edge/unexport .B ... .PP .B gpio .B wfi .B ... .PP .B gpio .B drive group value .PP .B gpio .B usbp high | low .PP .B gpio .B pwm-bal/pwm-ms .PP .B gpio .B pwmr range .PP .B gpio .B load \ i2c/spi ... .PP .B gpio .B gbr channel .PP .B gpio .B gbw channel value .SH DESCRIPTION .B GPIO is a swiss army knife of a command line tool to allow the user easy access to the GPIO pins on the Raspberry Pi and the SPI A/D and D/A converters on the Gertboard. It's designed for simple testing and diagnostic purposes, but can be used in shell scripts for general if somewhat slow control of the GPIO pins. It can also control the IO's on the PiFace IO board and load the SPI and I2C kernel modules if required. Additionally, it can be used to set the exports in the \fI/sys/class/gpio\fR system directory to allow subsequent programs to use the \fR/sys/class/gpio\fR interface without needing to be run as root. .SH OPTIONS .TP .B \-v Output the current version including the board revision of the Raspberry Pi. .TP .B \-g Use the BCM_GPIO pins numbers rather than wiringPi pin numbers. \fINote:\fR The BCM_GPIO pin numbers are always used with the export and edge commands. .TP .B \-1 Use the physical pin numbers rather than wiringPi pin numbers. \fINote:\fR that this applies to the P1 connector only. It is not possible to use pins on the Revision 2 P5 connector this way, and as with \-g the BCM_GPIO pin numbers are always used with the export and edge commands. .TP .B \-x extension This causes the named extension to be initialised. Extensions comprise of a name (e.g. mcp23017) followed by a colon, then the pin-base, then more optional parameters depending on the extension type. See the web page on http://wiringpi.com/the-gpio-utility/ .TP .B \-p Use the PiFace interface board and its corresponding pin numbers. The PiFace will always appear at pin number 200 in the gpio command. You can assign any pin numbers you like in your own programs though. .TP .B read Read the digital value of the given pin and print 0 or 1 to represent the respective logic levels. .TP .B write Write the given value (0 or 1) to the pin. You need to set the pin to output mode first. .TP .B toggle Changes the state of a GPIO pin; 0 to 1, or 1 to 0. Note unlike the blink command, the pin must be in output mode first. .TP .B blink Blinks the given pin on/off. Press Control-C to exit. Note: This command explicitly sets the pin to output mode. .TP .B aread Read the analog value of the given pin. This needs to be used in conjunction with a -x flag to add in an extension that handles analog inputs. e.g. gpio -x mcp3002:200:0 aread 200 will read the first analog input on an mcp3002 SPI ADC chip. .TP .B awrite Write the analog value to the given pin. This needs to be used in conjunction with a -x flag to add in an extension that handles analog inputs. e.g. gpio -x mcp4802:200:0 awrite 200 128 will write the value 128 to the first DAC port on an mcp4802 chip on the Pi's SPI bus 0. .TP .B wb Write the given byte to the 8 main GPIO pins. You can prefix it with 0x to specify a hexadecimal number. You need to set pins to output mode first. .TP .B readall Output a table of all GPIO pins values. The values represent the actual values read if the pin is in input mode, or the last value written if the pin is in output mode. The readall command is usable with an extension module (via the -x parameter), but it's unable to determine pin modes or states, so will perform both a digital and analog read on each pin in-turn. .TP .B pwm Write a PWM value (0-1023) to the given pin. The pin needs to be put into PWM mode first. .TP .B clock Set the output frequency on the given pin. The pin needs to be put into clock mode first. .TP .B mode Set a pin into \fIinput\fR, \fIoutput\fR or \fIpwm\fR mode. Can also use the literals \fIup\fR, \fIdown\fR or \fItri\fR to set the internal pull-up, pull-down or tristate (off) controls. The ALT modes can also be set using \fIalt0\fR, \fIalt1\fR, ... \fIalt5\fR. .TP .B unexportall Un-Export all the GPIO pins in the /sys/class/gpio directory. .TP .B exports Print a list (if any) of all the exported GPIO pins and their current values. .TP .B export Export a GPIO pin in the \fI/sys/class/gpio\fR directory. Use like the mode command above however only \fIin\fR, \fIout\fR, \fIhigh\fR and \fRlow\fR are supported at this time. Note that the pin number is the \fBBCM_GPIO\fR number and not the wiringPi number. The \fIhigh\fR and \fIlow\fR commands pre-set the output value at the same time as the export to output mode. Once a GPIO pin has been exported, the \fBgpio\fR program changes the ownership of the \fI/sys/class/gpio/gpioX/value\fR and if present in later kernels, the \fI/sys/class/gpio/gpioX/edge\fR pseudo files to that of the user running the \fBgpio\fR program. This means that you can have a small script of gpio exports to setup the gpio pins as your program requires without the need to run anything as root, or with the sudo command. .TP .B edge This exports a GPIO pin in the \fI/sys/class/gpio\fR directory, set the direction to input and set the edge interrupt method to \fInone\fR, \fIrising\fR, \fIfalling\fR or \fIboth\fR. Use like the export command above and note that \fBBCM_GPIO\fR pin number is used not not wiringPi pin numbering. Like the export commands above, ownership is set to that of the calling user, allowing subsequent access from user programs without requiring root/sudo. .TP .B unexport Un-Export a GPIO pin in the /sys/class/gpio directory. .TP .B wfi This set the given pin to the supplied interrupt mode: rising, falling or both then waits for the interrupt to happen. It's a non-busy wait, so does not consume and CPU while it's waiting. .TP .B drive group value Change the pad driver value for the given pad group to the supplied drive value. Group is 0, 1 or 2 and value is 0-7. Do not use unless you are absolutely sure you know what you're doing. .TP .B usbp high | low Change the USB current limiter to high (1.2 amps) or low (the default, 600mA) This is only applicable to the Model B+ and the Model B, v2. .TP .B pwm-bal/pwm-ms Change the PWM mode to balanced (the default) or mark:space ratio (traditional) .TP .B pwmr Change the PWM range register. The default is 1024. .TP .B gbr channel This reads the analog to digital converter on the Gertboard on the given channel. The board jumpers need to be in-place to do this operation. .TP .B gbw channel value This writes the supplied value to the output channel on the Gertboards SPI digital to analogue converter. The board jumpers need to be in-place to do this operation. .SH "WiringPi vs. BCM_GPIO Pin numbering vs. Physical pin numbering" .PP The quickest way to get a list of the pin differences is to run the command .TP gpio readall .SH FILES .TP 2.2i .I gpio executable .SH EXAMPLES .TP 2.2i gpio mode 4 output # Set pin 4 to output .PP gpio -g mode 23 output # Set GPIO pin 23 to output (same as WiringPi pin 4) .PP gpio mode 1 pwm # Set pin 1 to PWM mode .PP gpio pwm 1 512 # Set pin 1 to PWM value 512 - half brightness .PP gpio export 17 out # Set GPIO Pin 17 to output .PP gpio export 0 in # Set GPIO Pin 0 (SDA0) to input. .PP gpio -g read 0 # Read GPIO Pin 0 (SDA0) .SH "NOTES" When using the \fIexport\fR, \fIedge\fR or \fIunexport\fR commands, the pin numbers are \fBalways\fR native BCM_GPIO numbers and never wiringPi pin numbers. As of kernels 4.1.7, a user-level GPIO access mechanism is available, however wiringPi will not use this by default - because at this time there appears to be issues when trying to program the PWM or clock output hardware. If you can live without PWM or GPIO clocks and you want to use the GPIO from a non-root program, then you need to make sure that the module \fIbcm2835_gpiomem\fR is loaded at boot time. This should happen automatically when you enable the device tree in raspi-config. You may also need some additional information in /etc/udev/rules.d/ to change the mode and ownership of the /dev/gpiomem file. Finally, you need to set the environment variable \fIWIRINGPI_GPIOMEM\fR. This will go-away in future releases once the /dev/gpiomem interface is fully operational. .SH "SEE ALSO" .LP WiringPi's home page .IP http://wiringpi.com/ .SH AUTHOR Gordon Henderson .SH "REPORTING BUGS" Please report bugs to .SH COPYRIGHT Copyright (c) 2012-2018 Gordon Henderson This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. .SH TRADEMARKS AND ACKNOWLEDGEMENTS Raspberry Pi is a trademark of the Raspberry Pi Foundation. See http://raspberrypi.org/ for full details. wiringpi-2.50/wiringPiD/0000775000175000017500000000000013442550153014616 5ustar ubuntuubuntuwiringpi-2.50/wiringPiD/wiringpid.c0000664000175000017500000002017613442550153016764 0ustar ubuntuubuntu/* * wiringPiD.c: * Copyright (c) 2012-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include #include #include #include "drcNetCmd.h" #include "network.h" #include "runRemote.h" #include "daemonise.h" #define PIDFILE "/var/run/wiringPiD.pid" // Globals static const char *usage = "[-h] [-d] [-g | -1 | -z] [[-x extension:pin:params] ...] password" ; static int doDaemon = FALSE ; // static void logMsg (const char *message, ...) { va_list argp ; char buffer [1024] ; va_start (argp, message) ; vsnprintf (buffer, 1023, message, argp) ; va_end (argp) ; if (doDaemon) syslog (LOG_DAEMON | LOG_INFO, "%s", buffer) ; else printf ("%s\n", buffer) ; } /* * sigHandler: * setupSigHandler: * Somehing has happened that would normally terminate the program so try * to close down nicely. ********************************************************************************* */ void sigHandler (int sig) { logMsg ("Exiting on signal %d: %s", sig, strsignal (sig)) ; (void)unlink (PIDFILE) ; exit (EXIT_FAILURE) ; } void setupSigHandler (void) { struct sigaction action ; sigemptyset (&action.sa_mask) ; action.sa_flags = 0 ; // Ignore what we can action.sa_handler = SIG_IGN ; sigaction (SIGHUP, &action, NULL) ; sigaction (SIGTTIN, &action, NULL) ; sigaction (SIGTTOU, &action, NULL) ; // Trap what we can to exit gracefully action.sa_handler = sigHandler ; sigaction (SIGINT, &action, NULL) ; sigaction (SIGQUIT, &action, NULL) ; sigaction (SIGILL, &action, NULL) ; sigaction (SIGABRT, &action, NULL) ; sigaction (SIGFPE, &action, NULL) ; sigaction (SIGSEGV, &action, NULL) ; sigaction (SIGPIPE, &action, NULL) ; sigaction (SIGALRM, &action, NULL) ; sigaction (SIGTERM, &action, NULL) ; sigaction (SIGUSR1, &action, NULL) ; sigaction (SIGUSR2, &action, NULL) ; sigaction (SIGCHLD, &action, NULL) ; sigaction (SIGTSTP, &action, NULL) ; sigaction (SIGBUS, &action, NULL) ; } /* * The works... ********************************************************************************* */ int main (int argc, char *argv []) { int clientFd ; char *p, *password ; int i ; int port = DEFAULT_SERVER_PORT ; int wpiSetup = 0 ; if (argc < 2) { fprintf (stderr, "Usage: %s %s\n", argv [0], usage) ; exit (EXIT_FAILURE) ; } // Help? if (strcasecmp (argv [1], "-h") == 0) { printf ("Usage: %s %s\n", argv [0], usage) ; return 0 ; } // Daemonize? // Must come before the other args as e.g. some extensions // open files which get closed on daemonise... if (strcasecmp (argv [1], "-d") == 0) { if (geteuid () != 0) { fprintf (stderr, "%s: Must be root to run as a daemon.\n", argv [0]) ; exit (EXIT_FAILURE) ; } doDaemon = TRUE ; daemonise (PIDFILE) ; for (i = 2 ; i < argc ; ++i) argv [i - 1] = argv [i] ; --argc ; } // Scan all other arguments while (*argv [1] == '-') { // Look for wiringPi setup arguments: // Same as the gpio command and rtb. // -g - bcm_gpio if (strcasecmp (argv [1], "-g") == 0) { if (wpiSetup == 0) { logMsg ("BCM_GPIO mode selected") ; wiringPiSetupGpio () ; } for (i = 2 ; i < argc ; ++i) argv [i - 1] = argv [i] ; --argc ; ++wpiSetup ; continue ; } // -1 - physical pins if (strcasecmp (argv [1], "-1") == 0) { if (wpiSetup == 0) { logMsg ("GPIO-PHYS mode selected") ; wiringPiSetupPhys () ; } for (i = 2 ; i < argc ; ++i) argv [i - 1] = argv [i] ; --argc ; ++wpiSetup ; continue ; } // -z - no wiringPi - blocks remotes accessing local pins if (strcasecmp (argv [1], "-z") == 0) { if (wpiSetup == 0) logMsg ("No GPIO mode selected") ; for (i = 2 ; i < argc ; ++i) argv [i - 1] = argv [i] ; --argc ; noLocalPins = TRUE ; ++wpiSetup ; continue ; } // -p to select the port if (strcasecmp (argv [1], "-p") == 0) { if (argc < 3) { logMsg ("-p missing extension port") ; exit (EXIT_FAILURE) ; } logMsg ("Setting port to: %s", argv [2]) ; port = atoi (argv [2]) ; if ((port < 1) || (port > 65535)) { logMsg ("Invalid server port: %d", port) ; exit (EXIT_FAILURE) ; } // Shift args down by 2 for (i = 3 ; i < argc ; ++i) argv [i - 2] = argv [i] ; argc -= 2 ; continue ; } // Check for -x argument to load in a new extension // -x extension:base:args // Can load many modules to extend the daemon. if (strcasecmp (argv [1], "-x") == 0) { if (argc < 3) { logMsg ("-x missing extension name:data:etc.") ; exit (EXIT_FAILURE) ; } logMsg ("Loading extension: %s", argv [2]) ; if (!loadWPiExtension (argv [0], argv [2], TRUE)) { logMsg ("Extension load failed: %s", strerror (errno)) ; exit (EXIT_FAILURE) ; } // Shift args down by 2 for (i = 3 ; i < argc ; ++i) argv [i - 2] = argv [i] ; argc -= 2 ; continue ; } logMsg ("Invalid parameter: %s", argv [1]) ; exit (EXIT_FAILURE) ; } // Default to wiringPi mode if (wpiSetup == 0) { logMsg ("WiringPi GPIO mode selected") ; wiringPiSetup () ; } // Finally, should just be one arg left - the password... if (argc != 2) { logMsg ("No password supplied") ; exit (EXIT_FAILURE) ; } if (strlen (argv [1]) < 6) { logMsg ("Password too short - at least 6 chars, not %d", strlen (argv [1])) ; exit (EXIT_FAILURE) ; } if ((password = malloc (strlen (argv [1]) + 1)) == NULL) { logMsg ("Out of memory") ; exit (EXIT_FAILURE) ; } strcpy (password, argv [1]) ; // Wipe out the password on the command-line in a vague attempt to try to // hide it from snoopers for (p = argv [1] ; *p ; ++p) *p = ' ' ; setupSigHandler () ; // Enter our big loop for (;;) { if (!doDaemon) printf ("-=-\nWaiting for a new connection...\n") ; if ((clientFd = setupServer (port)) < 0) { logMsg ("Unable to setup server: %s", strerror (errno)) ; exit (EXIT_FAILURE) ; } logMsg ("New connection from: %s.", getClientIP ()) ; if (!doDaemon) printf ("Sending Greeting.\n") ; if (sendGreeting (clientFd) < 0) { logMsg ("Unable to send greeting message: %s", strerror (errno)) ; closeServer (clientFd) ; continue ; } if (!doDaemon) printf ("Sending Challenge.\n") ; if (sendChallenge (clientFd) < 0) { logMsg ("Unable to send challenge message: %s", strerror (errno)) ; closeServer (clientFd) ; continue ; } if (!doDaemon) printf ("Waiting for response.\n") ; if (getResponse (clientFd) < 0) { logMsg ("Connection closed waiting for response: %s", strerror (errno)) ; closeServer (clientFd) ; continue ; } if (!passwordMatch (password)) { logMsg ("Password failure") ; closeServer (clientFd) ; continue ; } logMsg ("Password OK - Starting") ; runRemoteCommands (clientFd) ; closeServer (clientFd) ; } return 0 ; } wiringpi-2.50/wiringPiD/runRemote.c0000664000175000017500000000604113442550153016743 0ustar ubuntuubuntu/* * runRemote.c: * Run the remote commands passed over the network link. * * Copyright (c) 2012-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include //#include #include #include #include "drcNetCmd.h" #include "network.h" #include "runRemote.h" int noLocalPins = FALSE ; void runRemoteCommands (int fd) { register uint32_t pin ; int len ; struct drcNetComStruct cmd ; len = sizeof (struct drcNetComStruct) ; if (setsockopt (fd, SOL_SOCKET, SO_RCVLOWAT, (void *)&len, sizeof (len)) < 0) return ; for (;;) { if (recv (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) // Probably remote hangup return ; pin = cmd.pin ; if (noLocalPins && ((pin & PI_GPIO_MASK) == 0)) { if (send (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) return ; continue ; } switch (cmd.cmd) { case DRCN_PIN_MODE: pinMode (pin, cmd.data) ; if (send (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) return ; break ; case DRCN_PULL_UP_DN: pullUpDnControl (pin, cmd.data) ; break ; case DRCN_PWM_WRITE: pwmWrite (pin, cmd.data) ; if (send (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) return ; break ; case DRCN_DIGITAL_WRITE: digitalWrite (pin, cmd.data) ; if (send (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) return ; break ; case DRCN_DIGITAL_WRITE8: //digitalWrite8 (pin, cmd.data) ; if (send (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) return ; break ; case DRCN_DIGITAL_READ: cmd.data = digitalRead (pin) ; if (send (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) return ; break ; case DRCN_DIGITAL_READ8: //cmd.data = digitalRead8 (pin) ; if (send (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) return ; break ; case DRCN_ANALOG_WRITE: analogWrite (pin, cmd.data) ; if (send (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) return ; break ; case DRCN_ANALOG_READ: cmd.data = analogRead (pin) ; if (send (fd, &cmd, sizeof (cmd), 0) != sizeof (cmd)) return ; break ; } } } wiringpi-2.50/wiringPiD/network.h0000664000175000017500000000252313442550153016462 0ustar ubuntuubuntu/* * network.h: * Part of wiringPiD * Copyright (c) 2012-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ extern char *getClientIP (void) ; extern int getResponce (int clientFd) ; extern int setupServer (int serverPort) ; extern int sendGreeting (int clientFd) ; extern int sendChallenge (int clientFd) ; extern int getResponse (int clientFd) ; extern int passwordMatch (const char *password) ; extern void closeServer (int clientFd) ; wiringpi-2.50/wiringPiD/network.c0000664000175000017500000001745113442550153016463 0ustar ubuntuubuntu/* * network.c: * Part of wiringPiD * Copyright (c) 2012-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #include #include #include #include #include #include #include #include #include #include #include #include "network.h" #define TRUE (1==1) #define FALSE (!TRUE) // Local data #define SALT_LEN 16 static char salt [SALT_LEN + 1] ; static char *returnedHash = NULL ; static int serverFd = -1 ; // Union for the server Socket Address static union { struct sockaddr_in sin ; struct sockaddr_in6 sin6 ; } serverSockAddr ; // and client address static union { struct sockaddr_in sin ; struct sockaddr_in6 sin6 ; } clientSockAddr ; /* * getClientIP: * Returns a pointer to a static string containing the clients IP address ********************************************************************************* */ char *getClientIP (void) { char buf [INET6_ADDRSTRLEN] ; static char ipAddress [1024] ; if (clientSockAddr.sin.sin_family == AF_INET) // IPv4 { if (snprintf (ipAddress, 1024, "IPv4: %s", inet_ntop (clientSockAddr.sin.sin_family, (void *)&clientSockAddr.sin.sin_addr, buf, sizeof (buf))) == 1024) strcpy (ipAddress, "Too long") ; } else // IPv6 { if (clientSockAddr.sin.sin_family == AF_INET6 && IN6_IS_ADDR_V4MAPPED (&clientSockAddr.sin6.sin6_addr)) { if (snprintf (ipAddress, 1024, "IPv4in6: %s", inet_ntop (clientSockAddr.sin.sin_family, (char *)&clientSockAddr.sin6.sin6_addr, buf, sizeof(buf))) == 1024) strcpy (ipAddress, "Too long") ; } else { if (snprintf (ipAddress, 1024, "IPv6: %s", inet_ntop (clientSockAddr.sin.sin_family, (char *)&clientSockAddr.sin6.sin6_addr, buf, sizeof(buf))) == 1024) strcpy (ipAddress, "Too long") ; } } return ipAddress ; } /* * clientPstr: clientPrintf: * Print over a network socket ********************************************************************************* */ static int clientPstr (int fd, char *s) { int len = strlen (s) ; return (write (fd, s, len) == len) ? 0 : -1 ; } static int clientPrintf (const int fd, const char *message, ...) { va_list argp ; char buffer [1024] ; va_start (argp, message) ; vsnprintf (buffer, 1023, message, argp) ; va_end (argp) ; return clientPstr (fd, buffer) ; } /* * sendGreeting: * Send some text to the client device ********************************************************************************* */ int sendGreeting (int clientFd) { if (clientPrintf (clientFd, "200 Welcome to wiringPiD - http://wiringpi.com/\n") < 0) return -1 ; return clientPrintf (clientFd, "200 Connecting from: %s\n", getClientIP ()) ; } /* * getSalt: * Create a random 'salt' value for the password encryption process ********************************************************************************* */ static int getSalt (char drySalt []) { static const char *seaDog = "abcdefghijklmnopqrstuvwxyz" "ABCDEFGHIJKLMNOPQRSTUVWXYZ" "0123456789/." ; unsigned char wetSalt [SALT_LEN] ; int i, fd ; if ((fd = open ("/dev/urandom", O_RDONLY)) < 0) return fd ; if (read (fd, wetSalt, SALT_LEN) != SALT_LEN) return -1 ; close (fd) ; for (i = 0 ; i < SALT_LEN ; ++i) drySalt [i] = seaDog [wetSalt [i] & 63] ; drySalt [SALT_LEN] = 0 ; return 0 ; } /* * sendChallenge: * Create and send our salt (aka nonce) to the remote device ********************************************************************************* */ int sendChallenge (int clientFd) { if (getSalt (salt) < 0) return -1 ; return clientPrintf (clientFd, "Challenge %s\n", salt) ; } /* * getResponse: * Read the encrypted password from the remote device. ********************************************************************************* */ int getResponse (int clientFd) { char reply [1024] ; int len ; // Being sort of lazy about this. I'm expecting an SHA-512 hash back and these // are exactly 86 characters long, so no reason not to, I guess... len = 86 ; if (setsockopt (clientFd, SOL_SOCKET, SO_RCVLOWAT, (void *)&len, sizeof (len)) < 0) return -1 ; len = recv (clientFd, reply, 86, 0) ; if (len != 86) return -1 ; reply [len] = 0 ; if ((returnedHash = malloc (len + 1)) == NULL) return -1 ; strcpy (returnedHash, reply) ; return 0 ; } /* * passwordMatch: * See if there's a match. If not, we simply dump them. ********************************************************************************* */ int passwordMatch (const char *password) { char *encrypted ; char salted [1024] ; sprintf (salted, "$6$%s$", salt) ; encrypted = crypt (password, salted) ; // 20: $6$ then 16 characters of salt, then $ // 86 is the length of an SHA-512 hash return strncmp (encrypted + 20, returnedHash, 86) == 0 ; } /* * setupServer: * Do what's needed to create a local server socket instance that can listen * on both IPv4 and IPv6 interfaces. ********************************************************************************* */ int setupServer (int serverPort) { socklen_t clientSockAddrSize = sizeof (clientSockAddr) ; int on = 1 ; int family ; socklen_t serverSockAddrSize ; int clientFd ; // Try to create an IPv6 socket serverFd = socket (PF_INET6, SOCK_STREAM, 0) ; // If it didn't work, then fall-back to IPv4. if (serverFd < 0) { if ((serverFd = socket (PF_INET, SOCK_STREAM, 0)) < 0) return -1 ; family = AF_INET ; serverSockAddrSize = sizeof (struct sockaddr_in) ; } else // We got an IPv6 socket { family = AF_INET6 ; serverSockAddrSize = sizeof (struct sockaddr_in6) ; } if (setsockopt (serverFd, SOL_SOCKET, SO_REUSEADDR, &on, sizeof (on)) < 0) return -1 ; // Setup the servers socket address - cope with IPv4 and v6. memset (&serverSockAddr, 0, sizeof (serverSockAddr)) ; switch (family) { case AF_INET: serverSockAddr.sin.sin_family = AF_INET ; serverSockAddr.sin.sin_addr.s_addr = htonl (INADDR_ANY) ; serverSockAddr.sin.sin_port = htons (serverPort) ; break; case AF_INET6: serverSockAddr.sin6.sin6_family = AF_INET6 ; serverSockAddr.sin6.sin6_addr = in6addr_any ; serverSockAddr.sin6.sin6_port = htons (serverPort) ; } // Bind, listen and accept if (bind (serverFd, (struct sockaddr *)&serverSockAddr, serverSockAddrSize) < 0) return -1 ; if (listen (serverFd, 4) < 0) // Really only going to talk to one client at a time... return -1 ; if ((clientFd = accept (serverFd, (struct sockaddr *)&clientSockAddr, &clientSockAddrSize)) < 0) return -1 ; return clientFd ; } /* * closeServer: ********************************************************************************* */ void closeServer (int clientFd) { if (serverFd != -1) close (serverFd) ; if (clientFd != -1) close (clientFd) ; serverFd = clientFd = -1 ; } wiringpi-2.50/wiringPiD/Makefile0000664000175000017500000000543013442550153016260 0ustar ubuntuubuntu# # Makefile: # The wiringPiD utility: # https://projects.drogon.net/wiring-pi # # Copyright (c) 2012-2017 Gordon Henderson ################################################################################# # This file is part of wiringPi: # A "wiring" library for the Raspberry Pi # # wiringPi is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # wiringPi is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public License # along with wiringPi. If not, see . ################################################################################# DESTDIR?=/usr PREFIX?=/local ifneq ($V,1) Q ?= @ endif #DEBUG = -g -O0 DEBUG = -O2 INCLUDE = -I$(DESTDIR)$(PREFIX)/include CFLAGS = $(DEBUG) -Wall -Wextra $(INCLUDE) -Winline -pipe LDFLAGS = -L$(DESTDIR)$(PREFIX)/lib LIBS = -lwiringPi -lwiringPiDev -lpthread -lrt -lm -lcrypt # May not need to alter anything below this line ############################################################################### SRC = wiringpid.c network.c runRemote.c daemonise.c OBJ = $(SRC:.c=.o) all: wiringpid wiringpid: $(OBJ) $Q echo [Link] $Q $(CC) -o $@ $(OBJ) $(LDFLAGS) $(LIBS) .c.o: $Q echo [Compile] $< $Q $(CC) -c $(CFLAGS) $< -o $@ .PHONY: clean clean: $Q echo "[Clean]" $Q rm -f $(OBJ) wiringpid *~ core tags *.bak .PHONY: tags tags: $(SRC) $Q echo [ctags] $Q ctags $(SRC) .PHONY: install install: wiringpid $Q echo "[Install]" $Q mkdir -p $(DESTDIR)$(PREFIX)/sbin $Q cp wiringpid $(DESTDIR)$(PREFIX)/sbin $Q chown root.root $(DESTDIR)$(PREFIX)/sbin/wiringpid # $Q mkdir -p $(DESTDIR)$(PREFIX)/man/man8 # $Q cp gpio.1 $(DESTDIR)$(PREFIX)/man/man8 .PHONY: install-deb install-deb: gpio $Q echo "[Install: deb]" $Q install -m 0755 -d ~/wiringPi/debian-template/wiringPi/usr/bin $Q install -m 0755 gpio ~/wiringPi/debian-template/wiringPi/usr/bin $Q install -m 0755 -d ~/wiringPi/debian-template/wiringPi/man/man1 $Q install -m 0644 gpio.1 ~/wiringPi/debian-template/wiringPi/man/man1 .PHONY: uninstall uninstall: $Q echo "[UnInstall]" $Q rm -f $(DESTDIR)$(PREFIX)/sbin/wiringpid $Q rm -f $(DESTDIR)$(PREFIX)/man/man8/wiringpid.8 .PHONY: depend depend: makedepend -Y $(SRC) # DO NOT DELETE wiringpid.o: drcNetCmd.h network.h runRemote.h daemonise.h network.o: network.h runRemote.o: drcNetCmd.h network.h runRemote.h daemonise.o: daemonise.h wiringpi-2.50/wiringPiD/daemonise.c0000664000175000017500000000310713442550153016727 0ustar ubuntuubuntu/* * daemonise.c: * Fairly generic "Turn the current process into a daemon" code. * * Copyright (c) 2016-2017 Gordon Henderson. ********************************************************************************* */ #include #include #include #include #include #include #include "daemonise.h" void daemonise (const char *pidFile) { pid_t pid ; int i ; FILE *fd ; syslog (LOG_DAEMON | LOG_INFO, "Becoming daemon") ; // Fork from the parent if ((pid = fork ()) < 0) { syslog (LOG_DAEMON | LOG_ALERT, "Fork no. 1 failed: %m") ; exit (EXIT_FAILURE) ; } if (pid > 0) // Parent - terminate exit (EXIT_SUCCESS) ; // Now running on the child - become session leader if (setsid() < 0) { syslog (LOG_DAEMON | LOG_ALERT, "setsid failed: %m") ; exit (EXIT_FAILURE) ; } // Ignore a few signals signal (SIGCHLD, SIG_IGN) ; signal (SIGHUP, SIG_IGN) ; // Fork again if ((pid = fork ()) < 0) { syslog (LOG_DAEMON | LOG_ALERT, "Fork no. 2 failed: %m") ; exit (EXIT_FAILURE) ; } if (pid > 0) // parent - terminate exit (EXIT_SUCCESS) ; // Tidying up - reset umask, change to / and close all files umask (0) ; chdir ("/") ; for (i = 0 ; i < sysconf (_SC_OPEN_MAX) ; ++i) close (i) ; // Write PID into /var/run if (pidFile != NULL) { if ((fd = fopen (pidFile, "w")) == NULL) { syslog (LOG_DAEMON | LOG_ALERT, "Unable to write PID file: %m") ; exit (EXIT_FAILURE) ; } fprintf (fd, "%d\n", getpid ()) ; fclose (fd) ; } } wiringpi-2.50/wiringPiD/runRemote.h0000664000175000017500000000215113442550153016746 0ustar ubuntuubuntu/* * runRemote.h: * Run the remote commands passed over the network link. * * Copyright (c) 2012-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ // Globals extern int noLocalPins ; extern void runRemoteCommands (int fd) ; wiringpi-2.50/wiringPiD/drcNetCmd.h0000664000175000017500000000252613442550153016637 0ustar ubuntuubuntu/* * drcNetCmd.c: * Copyright (c) 2012-2017 Gordon Henderson *********************************************************************** * This file is part of wiringPi: * https://projects.drogon.net/raspberry-pi/wiringpi/ * * wiringPi is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * wiringPi is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with wiringPi. If not, see . *********************************************************************** */ #define DEFAULT_SERVER_PORT 6124 #define DRCN_PIN_MODE 1 #define DRCN_PULL_UP_DN 2 #define DRCN_DIGITAL_WRITE 3 #define DRCN_DIGITAL_WRITE8 4 #define DRCN_ANALOG_WRITE 5 #define DRCN_PWM_WRITE 6 #define DRCN_DIGITAL_READ 7 #define DRCN_DIGITAL_READ8 8 #define DRCN_ANALOG_READ 9 struct drcNetComStruct { uint32_t pin ; uint32_t cmd ; uint32_t data ; } comDat ; wiringpi-2.50/wiringPiD/daemonise.h0000664000175000017500000000041213442550153016730 0ustar ubuntuubuntu/* * daemonise.h: * Fairly generic "Turn the current process into a daemon" code. * * Copyright (c) 2016-2017 Gordon Henderson. ********************************************************************************* */ extern void daemonise (const char *pidFile) ; wiringpi-2.50/COPYING.LESSER0000664000175000017500000001674313442550153014764 0ustar ubuntuubuntu GNU LESSER GENERAL PUBLIC LICENSE Version 3, 29 June 2007 Copyright (C) 2007 Free Software Foundation, Inc. Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below. 0. Additional Definitions. As used herein, "this License" refers to version 3 of the GNU Lesser General Public License, and the "GNU GPL" refers to version 3 of the GNU General Public License. "The Library" refers to a covered work governed by this License, other than an Application or a Combined Work as defined below. An "Application" is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library. A "Combined Work" is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the "Linked Version". The "Minimal Corresponding Source" for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version. The "Corresponding Application Code" for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work. 1. Exception to Section 3 of the GNU GPL. You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL. 2. Conveying Modified Versions. If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version: a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy. 3. Object Code Incorporating Material from Library Header Files. The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following: a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the object code with a copy of the GNU GPL and this license document. 4. Combined Works. You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following: a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the Combined Work with a copy of the GNU GPL and this license document. c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document. d) Do one of the following: 0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source. 1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version. e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.) 5. Combined Libraries. You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following: a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License. b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. 6. Revised Versions of the GNU Lesser General Public License. The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License "or any later version" applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation. If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library.