xref: /btstack/port/msp432p401lp-cc256x/ti/devices/msp432p4xx/driverlib/gpio.c (revision 5fd0122a3e19d95e11e1f3eb8a08a2b2acb2557e)
1*5fd0122aSMatthias Ringwald /* --COPYRIGHT--,BSD
2*5fd0122aSMatthias Ringwald  * Copyright (c) 2017, Texas Instruments Incorporated
3*5fd0122aSMatthias Ringwald  * All rights reserved.
4*5fd0122aSMatthias Ringwald  *
5*5fd0122aSMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
6*5fd0122aSMatthias Ringwald  * modification, are permitted provided that the following conditions
7*5fd0122aSMatthias Ringwald  * are met:
8*5fd0122aSMatthias Ringwald  *
9*5fd0122aSMatthias Ringwald  * *  Redistributions of source code must retain the above copyright
10*5fd0122aSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
11*5fd0122aSMatthias Ringwald  *
12*5fd0122aSMatthias Ringwald  * *  Redistributions in binary form must reproduce the above copyright
13*5fd0122aSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
14*5fd0122aSMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
15*5fd0122aSMatthias Ringwald  *
16*5fd0122aSMatthias Ringwald  * *  Neither the name of Texas Instruments Incorporated nor the names of
17*5fd0122aSMatthias Ringwald  *    its contributors may be used to endorse or promote products derived
18*5fd0122aSMatthias Ringwald  *    from this software without specific prior written permission.
19*5fd0122aSMatthias Ringwald  *
20*5fd0122aSMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21*5fd0122aSMatthias Ringwald  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
22*5fd0122aSMatthias Ringwald  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23*5fd0122aSMatthias Ringwald  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
24*5fd0122aSMatthias Ringwald  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25*5fd0122aSMatthias Ringwald  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26*5fd0122aSMatthias Ringwald  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
27*5fd0122aSMatthias Ringwald  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
28*5fd0122aSMatthias Ringwald  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29*5fd0122aSMatthias Ringwald  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30*5fd0122aSMatthias Ringwald  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31*5fd0122aSMatthias Ringwald  * --/COPYRIGHT--*/
32*5fd0122aSMatthias Ringwald /* Standard Includes */
33*5fd0122aSMatthias Ringwald #include <stdint.h>
34*5fd0122aSMatthias Ringwald 
35*5fd0122aSMatthias Ringwald /* DriverLib Includes */
36*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/gpio.h>
37*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/debug.h>
38*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/interrupt.h>
39*5fd0122aSMatthias Ringwald 
40*5fd0122aSMatthias Ringwald 
41*5fd0122aSMatthias Ringwald static const uint32_t GPIO_PORT_TO_INT[] =
42*5fd0122aSMatthias Ringwald { 0x00,
43*5fd0122aSMatthias Ringwald INT_PORT1,
44*5fd0122aSMatthias Ringwald INT_PORT2,
45*5fd0122aSMatthias Ringwald INT_PORT3,
46*5fd0122aSMatthias Ringwald INT_PORT4,
47*5fd0122aSMatthias Ringwald INT_PORT5,
48*5fd0122aSMatthias Ringwald INT_PORT6 };
49*5fd0122aSMatthias Ringwald 
50*5fd0122aSMatthias Ringwald static const uint32_t GPIO_PORT_TO_BASE[] =
51*5fd0122aSMatthias Ringwald {   0x00,
52*5fd0122aSMatthias Ringwald     (uint32_t)P1,
53*5fd0122aSMatthias Ringwald     (uint32_t)P1+1,
54*5fd0122aSMatthias Ringwald     (uint32_t)P3,
55*5fd0122aSMatthias Ringwald     (uint32_t)P3+1,
56*5fd0122aSMatthias Ringwald     (uint32_t)P5,
57*5fd0122aSMatthias Ringwald     (uint32_t)P5+1,
58*5fd0122aSMatthias Ringwald     (uint32_t)P7,
59*5fd0122aSMatthias Ringwald     (uint32_t)P7+1,
60*5fd0122aSMatthias Ringwald     (uint32_t)P9,
61*5fd0122aSMatthias Ringwald     (uint32_t)P9+1,
62*5fd0122aSMatthias Ringwald     (uint32_t)PJ
63*5fd0122aSMatthias Ringwald };
64*5fd0122aSMatthias Ringwald 
GPIO_setAsOutputPin(uint_fast8_t selectedPort,uint_fast16_t selectedPins)65*5fd0122aSMatthias Ringwald void GPIO_setAsOutputPin(uint_fast8_t selectedPort, uint_fast16_t selectedPins)
66*5fd0122aSMatthias Ringwald {
67*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
68*5fd0122aSMatthias Ringwald 
69*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PASEL0) &= ~selectedPins;
70*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PASEL1) &= ~selectedPins;
71*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PADIR) |= selectedPins;
72*5fd0122aSMatthias Ringwald }
73*5fd0122aSMatthias Ringwald 
74*5fd0122aSMatthias Ringwald 
GPIO_setAsInputPin(uint_fast8_t selectedPort,uint_fast16_t selectedPins)75*5fd0122aSMatthias Ringwald void GPIO_setAsInputPin(uint_fast8_t selectedPort, uint_fast16_t selectedPins)
76*5fd0122aSMatthias Ringwald {
77*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
78*5fd0122aSMatthias Ringwald 
79*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PASEL0) &= ~selectedPins;
80*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PASEL1) &= ~selectedPins;
81*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PADIR) &= ~selectedPins;
82*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAREN) &= ~selectedPins;
83*5fd0122aSMatthias Ringwald }
84*5fd0122aSMatthias Ringwald 
85*5fd0122aSMatthias Ringwald 
GPIO_setAsPeripheralModuleFunctionOutputPin(uint_fast8_t selectedPort,uint_fast16_t selectedPins,uint_fast8_t mode)86*5fd0122aSMatthias Ringwald void GPIO_setAsPeripheralModuleFunctionOutputPin(uint_fast8_t selectedPort,
87*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins, uint_fast8_t mode)
88*5fd0122aSMatthias Ringwald {
89*5fd0122aSMatthias Ringwald 
90*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
91*5fd0122aSMatthias Ringwald 
92*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PADIR) |= selectedPins;
93*5fd0122aSMatthias Ringwald     switch (mode)
94*5fd0122aSMatthias Ringwald     {
95*5fd0122aSMatthias Ringwald     case GPIO_PRIMARY_MODULE_FUNCTION:
96*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL0) |= selectedPins;
97*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL1) &= ~selectedPins;
98*5fd0122aSMatthias Ringwald         break;
99*5fd0122aSMatthias Ringwald     case GPIO_SECONDARY_MODULE_FUNCTION:
100*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL0) &= ~selectedPins;
101*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL1) |= selectedPins;
102*5fd0122aSMatthias Ringwald         break;
103*5fd0122aSMatthias Ringwald     case GPIO_TERTIARY_MODULE_FUNCTION:
104*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL0) |= selectedPins;
105*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL1) |= selectedPins;
106*5fd0122aSMatthias Ringwald         break;
107*5fd0122aSMatthias Ringwald     }
108*5fd0122aSMatthias Ringwald }
109*5fd0122aSMatthias Ringwald 
110*5fd0122aSMatthias Ringwald 
GPIO_setAsPeripheralModuleFunctionInputPin(uint_fast8_t selectedPort,uint_fast16_t selectedPins,uint_fast8_t mode)111*5fd0122aSMatthias Ringwald void GPIO_setAsPeripheralModuleFunctionInputPin(uint_fast8_t selectedPort,
112*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins, uint_fast8_t mode)
113*5fd0122aSMatthias Ringwald {
114*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
115*5fd0122aSMatthias Ringwald 
116*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PADIR) &= ~selectedPins;
117*5fd0122aSMatthias Ringwald     switch (mode)
118*5fd0122aSMatthias Ringwald     {
119*5fd0122aSMatthias Ringwald     case GPIO_PRIMARY_MODULE_FUNCTION:
120*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL0) |= selectedPins;
121*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL1) &= ~selectedPins;
122*5fd0122aSMatthias Ringwald         break;
123*5fd0122aSMatthias Ringwald     case GPIO_SECONDARY_MODULE_FUNCTION:
124*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL0) &= ~selectedPins;
125*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL1) |= selectedPins;
126*5fd0122aSMatthias Ringwald         break;
127*5fd0122aSMatthias Ringwald     case GPIO_TERTIARY_MODULE_FUNCTION:
128*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL0) |= selectedPins;
129*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PASEL1) |= selectedPins;
130*5fd0122aSMatthias Ringwald         break;
131*5fd0122aSMatthias Ringwald     }
132*5fd0122aSMatthias Ringwald }
133*5fd0122aSMatthias Ringwald 
134*5fd0122aSMatthias Ringwald 
GPIO_setOutputHighOnPin(uint_fast8_t selectedPort,uint_fast16_t selectedPins)135*5fd0122aSMatthias Ringwald void GPIO_setOutputHighOnPin(uint_fast8_t selectedPort,
136*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins)
137*5fd0122aSMatthias Ringwald {
138*5fd0122aSMatthias Ringwald 
139*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
140*5fd0122aSMatthias Ringwald 
141*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAOUT) |= selectedPins;
142*5fd0122aSMatthias Ringwald }
143*5fd0122aSMatthias Ringwald 
144*5fd0122aSMatthias Ringwald 
GPIO_setOutputLowOnPin(uint_fast8_t selectedPort,uint_fast16_t selectedPins)145*5fd0122aSMatthias Ringwald void GPIO_setOutputLowOnPin(uint_fast8_t selectedPort,
146*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins)
147*5fd0122aSMatthias Ringwald {
148*5fd0122aSMatthias Ringwald 
149*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
150*5fd0122aSMatthias Ringwald 
151*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAOUT) &= ~selectedPins;
152*5fd0122aSMatthias Ringwald }
153*5fd0122aSMatthias Ringwald 
154*5fd0122aSMatthias Ringwald 
GPIO_toggleOutputOnPin(uint_fast8_t selectedPort,uint_fast16_t selectedPins)155*5fd0122aSMatthias Ringwald void GPIO_toggleOutputOnPin(uint_fast8_t selectedPort,
156*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins)
157*5fd0122aSMatthias Ringwald {
158*5fd0122aSMatthias Ringwald 
159*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
160*5fd0122aSMatthias Ringwald 
161*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAOUT) ^= selectedPins;
162*5fd0122aSMatthias Ringwald }
163*5fd0122aSMatthias Ringwald 
164*5fd0122aSMatthias Ringwald 
GPIO_setAsInputPinWithPullDownResistor(uint_fast8_t selectedPort,uint_fast16_t selectedPins)165*5fd0122aSMatthias Ringwald void GPIO_setAsInputPinWithPullDownResistor(uint_fast8_t selectedPort,
166*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins)
167*5fd0122aSMatthias Ringwald {
168*5fd0122aSMatthias Ringwald 
169*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
170*5fd0122aSMatthias Ringwald 
171*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PASEL0) &= ~selectedPins;
172*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PASEL1) &= ~selectedPins;
173*5fd0122aSMatthias Ringwald 
174*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PADIR) &= ~selectedPins;
175*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAREN) |= selectedPins;
176*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAOUT) &= ~selectedPins;
177*5fd0122aSMatthias Ringwald }
178*5fd0122aSMatthias Ringwald 
179*5fd0122aSMatthias Ringwald 
GPIO_setAsInputPinWithPullUpResistor(uint_fast8_t selectedPort,uint_fast16_t selectedPins)180*5fd0122aSMatthias Ringwald void GPIO_setAsInputPinWithPullUpResistor(uint_fast8_t selectedPort,
181*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins)
182*5fd0122aSMatthias Ringwald {
183*5fd0122aSMatthias Ringwald 
184*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
185*5fd0122aSMatthias Ringwald 
186*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PASEL0) &= ~selectedPins;
187*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PASEL1) &= ~selectedPins;
188*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PADIR) &= ~selectedPins;
189*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAREN) |= selectedPins;
190*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAOUT) |= selectedPins;
191*5fd0122aSMatthias Ringwald }
192*5fd0122aSMatthias Ringwald 
193*5fd0122aSMatthias Ringwald 
GPIO_getInputPinValue(uint_fast8_t selectedPort,uint_fast16_t selectedPins)194*5fd0122aSMatthias Ringwald uint8_t GPIO_getInputPinValue(uint_fast8_t selectedPort,
195*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins)
196*5fd0122aSMatthias Ringwald {
197*5fd0122aSMatthias Ringwald     uint_fast16_t inputPinValue;
198*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
199*5fd0122aSMatthias Ringwald 
200*5fd0122aSMatthias Ringwald     inputPinValue = HWREG16(baseAddress + OFS_LIB_PAIN) & (selectedPins);
201*5fd0122aSMatthias Ringwald 
202*5fd0122aSMatthias Ringwald     if (inputPinValue > 0)
203*5fd0122aSMatthias Ringwald         return GPIO_INPUT_PIN_HIGH;
204*5fd0122aSMatthias Ringwald     return GPIO_INPUT_PIN_LOW;
205*5fd0122aSMatthias Ringwald }
206*5fd0122aSMatthias Ringwald 
207*5fd0122aSMatthias Ringwald 
GPIO_enableInterrupt(uint_fast8_t selectedPort,uint_fast16_t selectedPins)208*5fd0122aSMatthias Ringwald void GPIO_enableInterrupt(uint_fast8_t selectedPort, uint_fast16_t selectedPins)
209*5fd0122aSMatthias Ringwald {
210*5fd0122aSMatthias Ringwald 
211*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
212*5fd0122aSMatthias Ringwald 
213*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAIE) |= selectedPins;
214*5fd0122aSMatthias Ringwald }
215*5fd0122aSMatthias Ringwald 
216*5fd0122aSMatthias Ringwald 
GPIO_disableInterrupt(uint_fast8_t selectedPort,uint_fast16_t selectedPins)217*5fd0122aSMatthias Ringwald void GPIO_disableInterrupt(uint_fast8_t selectedPort,
218*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins)
219*5fd0122aSMatthias Ringwald {
220*5fd0122aSMatthias Ringwald 
221*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
222*5fd0122aSMatthias Ringwald 
223*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAIE) &= ~selectedPins;
224*5fd0122aSMatthias Ringwald }
225*5fd0122aSMatthias Ringwald 
226*5fd0122aSMatthias Ringwald 
GPIO_getInterruptStatus(uint_fast8_t selectedPort,uint_fast16_t selectedPins)227*5fd0122aSMatthias Ringwald uint_fast16_t GPIO_getInterruptStatus(uint_fast8_t selectedPort,
228*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins)
229*5fd0122aSMatthias Ringwald {
230*5fd0122aSMatthias Ringwald 
231*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
232*5fd0122aSMatthias Ringwald 
233*5fd0122aSMatthias Ringwald     return HWREG16(baseAddress + OFS_LIB_PAIFG) & selectedPins;
234*5fd0122aSMatthias Ringwald }
235*5fd0122aSMatthias Ringwald 
236*5fd0122aSMatthias Ringwald 
GPIO_clearInterruptFlag(uint_fast8_t selectedPort,uint_fast16_t selectedPins)237*5fd0122aSMatthias Ringwald void GPIO_clearInterruptFlag(uint_fast8_t selectedPort,
238*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins)
239*5fd0122aSMatthias Ringwald {
240*5fd0122aSMatthias Ringwald 
241*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
242*5fd0122aSMatthias Ringwald 
243*5fd0122aSMatthias Ringwald 
244*5fd0122aSMatthias Ringwald     HWREG16(baseAddress + OFS_LIB_PAIFG) &= ~selectedPins;
245*5fd0122aSMatthias Ringwald }
246*5fd0122aSMatthias Ringwald 
247*5fd0122aSMatthias Ringwald 
GPIO_interruptEdgeSelect(uint_fast8_t selectedPort,uint_fast16_t selectedPins,uint_fast8_t edgeSelect)248*5fd0122aSMatthias Ringwald void GPIO_interruptEdgeSelect(uint_fast8_t selectedPort,
249*5fd0122aSMatthias Ringwald         uint_fast16_t selectedPins, uint_fast8_t edgeSelect)
250*5fd0122aSMatthias Ringwald {
251*5fd0122aSMatthias Ringwald 
252*5fd0122aSMatthias Ringwald     uint32_t baseAddress = GPIO_PORT_TO_BASE[selectedPort];
253*5fd0122aSMatthias Ringwald 
254*5fd0122aSMatthias Ringwald 
255*5fd0122aSMatthias Ringwald     if (GPIO_LOW_TO_HIGH_TRANSITION == edgeSelect)
256*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PAIES) &= ~selectedPins;
257*5fd0122aSMatthias Ringwald     else
258*5fd0122aSMatthias Ringwald         HWREG16(baseAddress + OFS_LIB_PAIES) |= selectedPins;
259*5fd0122aSMatthias Ringwald }
260*5fd0122aSMatthias Ringwald 
GPIO_getEnabledInterruptStatus(uint_fast8_t selectedPort)261*5fd0122aSMatthias Ringwald uint_fast16_t GPIO_getEnabledInterruptStatus(uint_fast8_t selectedPort)
262*5fd0122aSMatthias Ringwald {
263*5fd0122aSMatthias Ringwald     uint_fast16_t pendingInts;
264*5fd0122aSMatthias Ringwald     uint32_t baseAddr;
265*5fd0122aSMatthias Ringwald 
266*5fd0122aSMatthias Ringwald     pendingInts = GPIO_getInterruptStatus(selectedPort, 0xFFFF);
267*5fd0122aSMatthias Ringwald     baseAddr = GPIO_PORT_TO_BASE[selectedPort];
268*5fd0122aSMatthias Ringwald 
269*5fd0122aSMatthias Ringwald     ASSERT(baseAddr != 0xFFFF);
270*5fd0122aSMatthias Ringwald 
271*5fd0122aSMatthias Ringwald     switch (selectedPort)
272*5fd0122aSMatthias Ringwald     {
273*5fd0122aSMatthias Ringwald     case GPIO_PORT_P1:
274*5fd0122aSMatthias Ringwald     case GPIO_PORT_P3:
275*5fd0122aSMatthias Ringwald     case GPIO_PORT_P5:
276*5fd0122aSMatthias Ringwald     case GPIO_PORT_P7:
277*5fd0122aSMatthias Ringwald     case GPIO_PORT_P9:
278*5fd0122aSMatthias Ringwald         return (HWREG8(baseAddr + OFS_LIB_P1IE) & pendingInts);
279*5fd0122aSMatthias Ringwald     case GPIO_PORT_P2:
280*5fd0122aSMatthias Ringwald     case GPIO_PORT_P4:
281*5fd0122aSMatthias Ringwald     case GPIO_PORT_P6:
282*5fd0122aSMatthias Ringwald     case GPIO_PORT_P8:
283*5fd0122aSMatthias Ringwald     case GPIO_PORT_P10:
284*5fd0122aSMatthias Ringwald         return (HWREG8(baseAddr + OFS_LIB_P2IE) & pendingInts);
285*5fd0122aSMatthias Ringwald     case GPIO_PORT_PJ:
286*5fd0122aSMatthias Ringwald         return (HWREG16(baseAddr + OFS_LIB_PAIE) & pendingInts);
287*5fd0122aSMatthias Ringwald     default:
288*5fd0122aSMatthias Ringwald         return 0;
289*5fd0122aSMatthias Ringwald     }
290*5fd0122aSMatthias Ringwald }
291*5fd0122aSMatthias Ringwald 
292*5fd0122aSMatthias Ringwald 
GPIO_setDriveStrengthHigh(uint_fast8_t selectedPort,uint_fast8_t selectedPins)293*5fd0122aSMatthias Ringwald void GPIO_setDriveStrengthHigh(uint_fast8_t selectedPort,
294*5fd0122aSMatthias Ringwald         uint_fast8_t selectedPins)
295*5fd0122aSMatthias Ringwald {
296*5fd0122aSMatthias Ringwald     uint32_t baseAddr;
297*5fd0122aSMatthias Ringwald 
298*5fd0122aSMatthias Ringwald     baseAddr = GPIO_PORT_TO_BASE[selectedPort];
299*5fd0122aSMatthias Ringwald 
300*5fd0122aSMatthias Ringwald     HWREG8(baseAddr + OFS_LIB_PADS) |= selectedPins;
301*5fd0122aSMatthias Ringwald 
302*5fd0122aSMatthias Ringwald }
303*5fd0122aSMatthias Ringwald 
GPIO_setDriveStrengthLow(uint_fast8_t selectedPort,uint_fast8_t selectedPins)304*5fd0122aSMatthias Ringwald void GPIO_setDriveStrengthLow(uint_fast8_t selectedPort,
305*5fd0122aSMatthias Ringwald         uint_fast8_t selectedPins)
306*5fd0122aSMatthias Ringwald {
307*5fd0122aSMatthias Ringwald     uint32_t baseAddr;
308*5fd0122aSMatthias Ringwald 
309*5fd0122aSMatthias Ringwald     baseAddr = GPIO_PORT_TO_BASE[selectedPort];
310*5fd0122aSMatthias Ringwald 
311*5fd0122aSMatthias Ringwald     HWREG8(baseAddr + OFS_LIB_PADS) &= ~selectedPins;
312*5fd0122aSMatthias Ringwald 
313*5fd0122aSMatthias Ringwald }
314*5fd0122aSMatthias Ringwald 
GPIO_registerInterrupt(uint_fast8_t selectedPort,void (* intHandler)(void))315*5fd0122aSMatthias Ringwald void GPIO_registerInterrupt(uint_fast8_t selectedPort, void (*intHandler)(void))
316*5fd0122aSMatthias Ringwald {
317*5fd0122aSMatthias Ringwald     uint32_t wPortInt;
318*5fd0122aSMatthias Ringwald 
319*5fd0122aSMatthias Ringwald     wPortInt = GPIO_PORT_TO_INT[selectedPort];
320*5fd0122aSMatthias Ringwald 
321*5fd0122aSMatthias Ringwald     //
322*5fd0122aSMatthias Ringwald     // Register the interrupt handler, returning an error if an error occurs.
323*5fd0122aSMatthias Ringwald     //
324*5fd0122aSMatthias Ringwald     Interrupt_registerInterrupt(wPortInt, intHandler);
325*5fd0122aSMatthias Ringwald 
326*5fd0122aSMatthias Ringwald     //
327*5fd0122aSMatthias Ringwald     // Enable the system control interrupt.
328*5fd0122aSMatthias Ringwald     //
329*5fd0122aSMatthias Ringwald     Interrupt_enableInterrupt(wPortInt);
330*5fd0122aSMatthias Ringwald }
331*5fd0122aSMatthias Ringwald 
332*5fd0122aSMatthias Ringwald 
GPIO_unregisterInterrupt(uint_fast8_t selectedPort)333*5fd0122aSMatthias Ringwald void GPIO_unregisterInterrupt(uint_fast8_t selectedPort)
334*5fd0122aSMatthias Ringwald {
335*5fd0122aSMatthias Ringwald     uint32_t wPortInt;
336*5fd0122aSMatthias Ringwald 
337*5fd0122aSMatthias Ringwald     wPortInt = GPIO_PORT_TO_INT[selectedPort];
338*5fd0122aSMatthias Ringwald 
339*5fd0122aSMatthias Ringwald     //
340*5fd0122aSMatthias Ringwald     // Disable the interrupt.
341*5fd0122aSMatthias Ringwald     //
342*5fd0122aSMatthias Ringwald     Interrupt_disableInterrupt(wPortInt);
343*5fd0122aSMatthias Ringwald 
344*5fd0122aSMatthias Ringwald     //
345*5fd0122aSMatthias Ringwald     // Unregister the interrupt handler.
346*5fd0122aSMatthias Ringwald     //
347*5fd0122aSMatthias Ringwald     Interrupt_unregisterInterrupt(wPortInt);
348*5fd0122aSMatthias Ringwald }
349*5fd0122aSMatthias Ringwald 
350*5fd0122aSMatthias Ringwald 
351