chiark / gitweb /
Debian build: ./newVersion updates debian/changelog too.
[wiringPi.git] / wiringPi / wiringPi.h
1 /*
2  * wiringPi:
3  *      Arduino compatable (ish) Wiring library for the Raspberry Pi
4  *      Copyright (c) 2012 Gordon Henderson
5  ***********************************************************************
6  * This file is part of wiringPi:
7  *      https://projects.drogon.net/raspberry-pi/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
24 #ifndef __WIRING_PI_H__
25 #define __WIRING_PI_H__
26
27 // Handy defines
28
29 // Deprecated
30 #define NUM_PINS        17
31
32 #define WPI_MODE_PINS            0
33 #define WPI_MODE_GPIO            1
34 #define WPI_MODE_GPIO_SYS        2
35 #define WPI_MODE_PHYS            3
36 #define WPI_MODE_PIFACE          4
37 #define WPI_MODE_UNINITIALISED  -1
38
39 // Pin modes
40
41 #define INPUT                    0
42 #define OUTPUT                   1
43 #define PWM_OUTPUT               2
44 #define GPIO_CLOCK               3
45 #define SOFT_PWM_OUTPUT          4
46 #define SOFT_TONE_OUTPUT         5
47 #define PWM_TONE_OUTPUT          6
48
49 #define LOW                      0
50 #define HIGH                     1
51
52 // Pull up/down/none
53
54 #define PUD_OFF                  0
55 #define PUD_DOWN                 1
56 #define PUD_UP                   2
57
58 // PWM
59
60 #define PWM_MODE_MS             0
61 #define PWM_MODE_BAL            1
62
63 // Interrupt levels
64
65 #define INT_EDGE_SETUP          0
66 #define INT_EDGE_FALLING        1
67 #define INT_EDGE_RISING         2
68 #define INT_EDGE_BOTH           3
69
70 // Pi model types and version numbers
71 //      Intended for the GPIO program Use at your own risk.
72
73 #define PI_MODEL_UNKNOWN        0
74 #define PI_MODEL_A              1
75 #define PI_MODEL_B              2
76 #define PI_MODEL_BP             3
77 #define PI_MODEL_CM             4
78 #define PI_MODEL_AP             5
79 #define PI_MODEL_2              6
80
81 #define PI_VERSION_UNKNOWN      0
82 #define PI_VERSION_1            1
83 #define PI_VERSION_1_1          2
84 #define PI_VERSION_1_2          3
85 #define PI_VERSION_2            4
86
87 #define PI_MAKER_UNKNOWN        0
88 #define PI_MAKER_EGOMAN         1
89 #define PI_MAKER_SONY           2
90 #define PI_MAKER_QISDA          3
91 #define PI_MAKER_MBEST          4
92
93 extern const char *piModelNames    [7] ;
94 extern const char *piRevisionNames [5] ;
95 extern const char *piMakerNames    [5] ;
96
97
98 //      Intended for the GPIO program Use at your own risk.
99
100 // Threads
101
102 #define PI_THREAD(X)    void *X (void *dummy)
103
104 // Failure modes
105
106 #define WPI_FATAL       (1==1)
107 #define WPI_ALMOST      (1==2)
108
109
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
118 struct wiringPiNodeStruct
119 {
120   int     pinBase ;
121   int     pinMax ;
122
123   int          fd ;     // Node specific
124   unsigned int data0 ;  //  ditto
125   unsigned int data1 ;  //  ditto
126   unsigned int data2 ;  //  ditto
127   unsigned int data3 ;  //  ditto
128
129   void   (*pinMode)         (struct wiringPiNodeStruct *node, int pin, int mode) ;
130   void   (*pullUpDnControl) (struct wiringPiNodeStruct *node, int pin, int mode) ;
131   int    (*digitalRead)     (struct wiringPiNodeStruct *node, int pin) ;
132   void   (*digitalWrite)    (struct wiringPiNodeStruct *node, int pin, int value) ;
133   void   (*pwmWrite)        (struct wiringPiNodeStruct *node, int pin, int value) ;
134   int    (*analogRead)      (struct wiringPiNodeStruct *node, int pin) ;
135   void   (*analogWrite)     (struct wiringPiNodeStruct *node, int pin, int value) ;
136
137   struct wiringPiNodeStruct *next ;
138 } ;
139
140 extern struct wiringPiNodeStruct *wiringPiNodes ;
141
142
143 // Function prototypes
144 //      c++ wrappers thanks to a comment by Nick Lott
145 //      (and others on the Raspberry Pi forums)
146
147 #ifdef __cplusplus
148 extern "C" {
149 #endif
150
151 // Data
152
153 // Internal
154
155 extern int wiringPiFailure (int fatal, const char *message, ...) ;
156
157 // Core wiringPi functions
158
159 extern struct wiringPiNodeStruct *wiringPiFindNode (int pin) ;
160 extern struct wiringPiNodeStruct *wiringPiNewNode  (int pinBase, int numPins) ;
161
162 extern int  wiringPiSetup       (void) ;
163 extern int  wiringPiSetupSys    (void) ;
164 extern int  wiringPiSetupGpio   (void) ;
165 extern int  wiringPiSetupPhys   (void) ;
166
167 extern void pinModeAlt          (int pin, int mode) ;
168 extern void pinMode             (int pin, int mode) ;
169 extern void pullUpDnControl     (int pin, int pud) ;
170 extern int  digitalRead         (int pin) ;
171 extern void digitalWrite        (int pin, int value) ;
172 extern void pwmWrite            (int pin, int value) ;
173 extern int  analogRead          (int pin) ;
174 extern void analogWrite         (int pin, int value) ;
175
176 // PiFace specifics 
177 //      (Deprecated)
178
179 extern int  wiringPiSetupPiFace (void) ;
180 extern int  wiringPiSetupPiFaceForGpioProg (void) ;     // Don't use this - for gpio program only
181
182 // On-Board Raspberry Pi hardware specific stuff
183
184 extern int  piBoardRev          (void) ;
185 extern void piBoardId           (int *model, int *rev, int *mem, int *maker, int *overVolted) ;
186 extern int  wpiPinToGpio        (int wpiPin) ;
187 extern int  physPinToGpio       (int physPin) ;
188 extern void setPadDrive         (int group, int value) ;
189 extern int  getAlt              (int pin) ;
190 extern void pwmToneWrite        (int pin, int freq) ;
191 extern void digitalWriteByte    (int value) ;
192 extern void pwmSetMode          (int mode) ;
193 extern void pwmSetRange         (unsigned int range) ;
194 extern void pwmSetClock         (int divisor) ;
195 extern void gpioClockSet        (int pin, int freq) ;
196
197 // Interrupts
198 //      (Also Pi hardware specific)
199
200 extern int  waitForInterrupt    (int pin, int mS) ;
201 extern int  wiringPiISR         (int pin, int mode, void (*function)(void)) ;
202
203 // Threads
204
205 extern int  piThreadCreate      (void *(*fn)(void *)) ;
206 extern void piLock              (int key) ;
207 extern void piUnlock            (int key) ;
208
209 // Schedulling priority
210
211 extern int piHiPri (const int pri) ;
212
213 // Extras from arduino land
214
215 extern void         delay             (unsigned int howLong) ;
216 extern void         delayMicroseconds (unsigned int howLong) ;
217 extern unsigned int millis            (void) ;
218 extern unsigned int micros            (void) ;
219
220 #ifdef __cplusplus
221 }
222 #endif
223
224 #endif