Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

wiringPi.h 8.3 KiB

12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
9 meses atrás
9 meses atrás
6 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
9 meses atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
12 anos atrás
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. /*
  2. * wiringPi.h:
  3. * Arduino like Wiring library for the Raspberry Pi.
  4. * Copyright (c) 2012-2017 Gordon Henderson
  5. ***********************************************************************
  6. * This file is part of wiringPi:
  7. * https://github.com/WiringPi/WiringPi/
  8. *
  9. * wiringPi is free software: you can redistribute it and/or modify
  10. * it under the terms of the GNU Lesser General Public License as published by
  11. * the Free Software Foundation, either version 3 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * wiringPi is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU Lesser General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU Lesser General Public License
  20. * along with wiringPi. If not, see <http://www.gnu.org/licenses/>.
  21. ***********************************************************************
  22. */
  23. #ifndef __WIRING_PI_H__
  24. #define __WIRING_PI_H__
  25. // C doesn't have true/false by default and I can never remember which
  26. // way round they are, so ...
  27. // (and yes, I know about stdbool.h but I like capitals for these and I'm old)
  28. #ifndef TRUE
  29. # define TRUE (1==1)
  30. # define FALSE (!TRUE)
  31. #endif
  32. // GCC warning suppressor
  33. #define UNU __attribute__((unused))
  34. // Mask for the bottom 64 pins which belong to the Raspberry Pi
  35. // The others are available for the other devices
  36. #define PI_GPIO_MASK (0xFFFFFFC0)
  37. // Handy defines
  38. // wiringPi modes
  39. #define WPI_MODE_PINS 0
  40. #define WPI_MODE_GPIO 1
  41. #define WPI_MODE_GPIO_SYS 2
  42. #define WPI_MODE_PHYS 3
  43. #define WPI_MODE_PIFACE 4
  44. #define WPI_MODE_UNINITIALISED -1
  45. // Pin modes
  46. #define INPUT 0
  47. #define OUTPUT 1
  48. #define PWM_OUTPUT 2
  49. #define GPIO_CLOCK 3
  50. #define SOFT_PWM_OUTPUT 4
  51. #define SOFT_TONE_OUTPUT 5
  52. #define PWM_TONE_OUTPUT 6
  53. #define LOW 0
  54. #define HIGH 1
  55. // Pull up/down/none
  56. #define PUD_OFF 0
  57. #define PUD_DOWN 1
  58. #define PUD_UP 2
  59. // PWM
  60. #define PWM_MODE_MS 0
  61. #define PWM_MODE_BAL 1
  62. // Interrupt levels
  63. #define INT_EDGE_SETUP 0
  64. #define INT_EDGE_FALLING 1
  65. #define INT_EDGE_RISING 2
  66. #define INT_EDGE_BOTH 3
  67. // Pi model types and version numbers
  68. // Intended for the GPIO program Use at your own risk.
  69. // https://www.raspberrypi.com/documentation/computers/raspberry-pi.html#new-style-revision-codes
  70. #define PI_MODEL_A 0
  71. #define PI_MODEL_B 1
  72. #define PI_MODEL_AP 2
  73. #define PI_MODEL_BP 3
  74. #define PI_MODEL_2 4
  75. #define PI_ALPHA 5
  76. #define PI_MODEL_CM 6
  77. #define PI_MODEL_07 7
  78. #define PI_MODEL_3B 8
  79. #define PI_MODEL_ZERO 9
  80. #define PI_MODEL_CM3 10
  81. #define PI_MODEL_ZERO_W 12
  82. #define PI_MODEL_3BP 13
  83. #define PI_MODEL_3AP 14
  84. #define PI_MODEL_CM3P 16
  85. #define PI_MODEL_4B 17
  86. #define PI_MODEL_ZERO_2W 18
  87. #define PI_MODEL_400 19
  88. #define PI_MODEL_CM4 20
  89. #define PI_MODEL_CM4S 21
  90. #define PI_MODEL_5 23
  91. #define PI_VERSION_1 0
  92. #define PI_VERSION_1_1 1
  93. #define PI_VERSION_1_2 2
  94. #define PI_VERSION_2 3
  95. #define PI_MAKER_SONY 0
  96. #define PI_MAKER_EGOMAN 1
  97. #define PI_MAKER_EMBEST 2
  98. #define PI_MAKER_UNKNOWN 3
  99. extern const char *piModelNames [24] ;
  100. extern const char *piProcessor [ 5] ;
  101. extern const char *piRevisionNames [16] ;
  102. extern const char *piMakerNames [16] ;
  103. extern const int piMemorySize [ 8] ;
  104. // Intended for the GPIO program Use at your own risk.
  105. // Threads
  106. #define PI_THREAD(X) void *X (UNU void *dummy)
  107. // Failure modes
  108. #define WPI_FATAL (1==1)
  109. #define WPI_ALMOST (1==2)
  110. // wiringPiNodeStruct:
  111. // This describes additional device nodes in the extended wiringPi
  112. // 2.0 scheme of things.
  113. // It's a simple linked list for now, but will hopefully migrate to
  114. // a binary tree for efficiency reasons - but then again, the chances
  115. // of more than 1 or 2 devices being added are fairly slim, so who
  116. // knows....
  117. struct wiringPiNodeStruct
  118. {
  119. int pinBase ;
  120. int pinMax ;
  121. int fd ; // Node specific
  122. unsigned int data0 ; // ditto
  123. unsigned int data1 ; // ditto
  124. unsigned int data2 ; // ditto
  125. unsigned int data3 ; // ditto
  126. void (*pinMode) (struct wiringPiNodeStruct *node, int pin, int mode) ;
  127. void (*pullUpDnControl) (struct wiringPiNodeStruct *node, int pin, int mode) ;
  128. int (*digitalRead) (struct wiringPiNodeStruct *node, int pin) ;
  129. //unsigned int (*digitalRead8) (struct wiringPiNodeStruct *node, int pin) ;
  130. void (*digitalWrite) (struct wiringPiNodeStruct *node, int pin, int value) ;
  131. // void (*digitalWrite8) (struct wiringPiNodeStruct *node, int pin, int value) ;
  132. void (*pwmWrite) (struct wiringPiNodeStruct *node, int pin, int value) ;
  133. int (*analogRead) (struct wiringPiNodeStruct *node, int pin) ;
  134. void (*analogWrite) (struct wiringPiNodeStruct *node, int pin, int value) ;
  135. struct wiringPiNodeStruct *next ;
  136. } ;
  137. extern struct wiringPiNodeStruct *wiringPiNodes ;
  138. // Export variables for the hardware pointers
  139. extern volatile unsigned int *_wiringPiGpio ;
  140. extern volatile unsigned int *_wiringPiPwm ;
  141. extern volatile unsigned int *_wiringPiClk ;
  142. extern volatile unsigned int *_wiringPiPads ;
  143. extern volatile unsigned int *_wiringPiTimer ;
  144. extern volatile unsigned int *_wiringPiTimerIrqRaw ;
  145. // Function prototypes
  146. // c++ wrappers thanks to a comment by Nick Lott
  147. // (and others on the Raspberry Pi forums)
  148. #ifdef __cplusplus
  149. extern "C" {
  150. #endif
  151. // Data
  152. // Internal
  153. extern int wiringPiFailure (int fatal, const char *message, ...) ;
  154. // Core wiringPi functions
  155. extern struct wiringPiNodeStruct *wiringPiFindNode (int pin) ;
  156. extern struct wiringPiNodeStruct *wiringPiNewNode (int pinBase, int numPins) ;
  157. extern int GPIOToSysFS(const int pin) ;
  158. extern void wiringPiVersion (int *major, int *minor) ;
  159. extern int wiringPiSetup (void) ;
  160. extern int wiringPiSetupSys (void) ;
  161. extern int wiringPiSetupGpio (void) ;
  162. extern int wiringPiSetupPhys (void) ;
  163. extern void pinModeAlt (int pin, int mode) ;
  164. extern void pinMode (int pin, int mode) ;
  165. extern void pullUpDnControl (int pin, int pud) ;
  166. extern int digitalRead (int pin) ;
  167. extern void digitalWrite (int pin, int value) ;
  168. extern unsigned int digitalRead8 (int pin) ;
  169. extern void digitalWrite8 (int pin, int value) ;
  170. extern void pwmWrite (int pin, int value) ;
  171. extern int analogRead (int pin) ;
  172. extern void analogWrite (int pin, int value) ;
  173. // PiFace specifics
  174. // (Deprecated)
  175. extern int wiringPiSetupPiFace (void) ;
  176. extern int wiringPiSetupPiFaceForGpioProg (void) ; // Don't use this - for gpio program only
  177. // On-Board Raspberry Pi hardware specific stuff
  178. extern int piGpioLayout (void) ;
  179. extern int piBoardRev (void) ; // Deprecated
  180. extern void piBoardId (int *model, int *rev, int *mem, int *maker, int *overVolted) ;
  181. extern int wpiPinToGpio (int wpiPin) ;
  182. extern int physPinToGpio (int physPin) ;
  183. extern void setPadDrive (int group, int value) ;
  184. extern int getAlt (int pin) ;
  185. extern void pwmToneWrite (int pin, int freq) ;
  186. extern void pwmSetMode (int mode) ;
  187. extern void pwmSetRange (unsigned int range) ;
  188. extern void pwmSetClock (int divisor) ;
  189. extern void gpioClockSet (int pin, int freq) ;
  190. extern unsigned int digitalReadByte (void) ;
  191. extern unsigned int digitalReadByte2 (void) ;
  192. extern void digitalWriteByte (int value) ;
  193. extern void digitalWriteByte2 (int value) ;
  194. // Interrupts
  195. // (Also Pi hardware specific)
  196. extern int waitForInterrupt (int pin, int mS) ;
  197. extern int wiringPiISR (int pin, int mode, void (*function)(void)) ;
  198. // Threads
  199. extern int piThreadCreate (void *(*fn)(void *)) ;
  200. extern void piLock (int key) ;
  201. extern void piUnlock (int key) ;
  202. // Schedulling priority
  203. extern int piHiPri (const int pri) ;
  204. // Extras from arduino land
  205. extern void delay (unsigned int howLong) ;
  206. extern void delayMicroseconds (unsigned int howLong) ;
  207. extern unsigned int millis (void) ;
  208. extern unsigned int micros (void) ;
  209. #ifdef __cplusplus
  210. }
  211. #endif
  212. #endif