xref: /btstack/port/msp432p401lp-cc256x/ti/devices/msp432p4xx/driverlib/comp_e.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 #include <ti/devices/msp432p4xx/driverlib/comp_e.h>
33*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/interrupt.h>
34*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/debug.h>
35*5fd0122aSMatthias Ringwald 
__getRegisterSettingForInput(uint32_t input)36*5fd0122aSMatthias Ringwald static uint16_t __getRegisterSettingForInput(uint32_t input)
37*5fd0122aSMatthias Ringwald {
38*5fd0122aSMatthias Ringwald     switch (input)
39*5fd0122aSMatthias Ringwald     {
40*5fd0122aSMatthias Ringwald     case COMP_E_INPUT0:
41*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_0;
42*5fd0122aSMatthias Ringwald     case COMP_E_INPUT1:
43*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_1;
44*5fd0122aSMatthias Ringwald     case COMP_E_INPUT2:
45*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_2;
46*5fd0122aSMatthias Ringwald     case COMP_E_INPUT3:
47*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_3;
48*5fd0122aSMatthias Ringwald     case COMP_E_INPUT4:
49*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_4;
50*5fd0122aSMatthias Ringwald     case COMP_E_INPUT5:
51*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_5;
52*5fd0122aSMatthias Ringwald     case COMP_E_INPUT6:
53*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_6;
54*5fd0122aSMatthias Ringwald     case COMP_E_INPUT7:
55*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_7;
56*5fd0122aSMatthias Ringwald     case COMP_E_INPUT8:
57*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_8;
58*5fd0122aSMatthias Ringwald     case COMP_E_INPUT9:
59*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_9;
60*5fd0122aSMatthias Ringwald     case COMP_E_INPUT10:
61*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_10;
62*5fd0122aSMatthias Ringwald     case COMP_E_INPUT11:
63*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_11;
64*5fd0122aSMatthias Ringwald     case COMP_E_INPUT12:
65*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_12;
66*5fd0122aSMatthias Ringwald     case COMP_E_INPUT13:
67*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_13;
68*5fd0122aSMatthias Ringwald     case COMP_E_INPUT14:
69*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_14;
70*5fd0122aSMatthias Ringwald     case COMP_E_INPUT15:
71*5fd0122aSMatthias Ringwald         return COMP_E_CTL0_IPSEL_15;
72*5fd0122aSMatthias Ringwald     case COMP_E_VREF:
73*5fd0122aSMatthias Ringwald         return COMP_E_VREF;
74*5fd0122aSMatthias Ringwald     default:
75*5fd0122aSMatthias Ringwald         ASSERT(false);
76*5fd0122aSMatthias Ringwald         return 0x11;
77*5fd0122aSMatthias Ringwald     }
78*5fd0122aSMatthias Ringwald 
79*5fd0122aSMatthias Ringwald }
80*5fd0122aSMatthias Ringwald 
COMP_E_initModule(uint32_t comparator,const COMP_E_Config * config)81*5fd0122aSMatthias Ringwald bool COMP_E_initModule(uint32_t comparator, const COMP_E_Config *config)
82*5fd0122aSMatthias Ringwald {
83*5fd0122aSMatthias Ringwald     uint_fast8_t positiveTerminalInput = __getRegisterSettingForInput(
84*5fd0122aSMatthias Ringwald             config->positiveTerminalInput);
85*5fd0122aSMatthias Ringwald     uint_fast8_t negativeTerminalInput = __getRegisterSettingForInput(
86*5fd0122aSMatthias Ringwald             config->negativeTerminalInput);
87*5fd0122aSMatthias Ringwald     bool retVal = true;
88*5fd0122aSMatthias Ringwald 
89*5fd0122aSMatthias Ringwald     ASSERT(positiveTerminalInput < 0x10); ASSERT(negativeTerminalInput < 0x10);
90*5fd0122aSMatthias Ringwald     ASSERT(positiveTerminalInput != negativeTerminalInput);
91*5fd0122aSMatthias Ringwald     ASSERT(
92*5fd0122aSMatthias Ringwald             config->outputFilterEnableAndDelayLevel
93*5fd0122aSMatthias Ringwald             <= COMP_E_FILTEROUTPUT_DLYLVL4);
94*5fd0122aSMatthias Ringwald 
95*5fd0122aSMatthias Ringwald     /* Reset COMPE Control 1 & Interrupt Registers for initialization */
96*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->CTL0 = 0;
97*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->INT = 0;
98*5fd0122aSMatthias Ringwald 
99*5fd0122aSMatthias Ringwald     // Set the Positive Terminal
100*5fd0122aSMatthias Ringwald     if (COMP_E_VREF != positiveTerminalInput)
101*5fd0122aSMatthias Ringwald     {
102*5fd0122aSMatthias Ringwald         // Enable Positive Terminal Input Mux and Set to the appropriate input
103*5fd0122aSMatthias Ringwald         COMP_E_CMSIS(comparator)->CTL0 |= COMP_E_CTL0_IPEN
104*5fd0122aSMatthias Ringwald                 + positiveTerminalInput;
105*5fd0122aSMatthias Ringwald 
106*5fd0122aSMatthias Ringwald         // Disable the input buffer
107*5fd0122aSMatthias Ringwald         COMP_E_CMSIS(comparator)->CTL3 |= (1 << positiveTerminalInput);
108*5fd0122aSMatthias Ringwald     } else
109*5fd0122aSMatthias Ringwald     {
110*5fd0122aSMatthias Ringwald         //  Reset and Set COMPE Control 2 Register
111*5fd0122aSMatthias Ringwald         BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL2,COMP_E_CTL2_RSEL_OFS) = 0;
112*5fd0122aSMatthias Ringwald     }
113*5fd0122aSMatthias Ringwald 
114*5fd0122aSMatthias Ringwald     // Set the Negative Terminal
115*5fd0122aSMatthias Ringwald     if (COMP_E_VREF != negativeTerminalInput)
116*5fd0122aSMatthias Ringwald     {
117*5fd0122aSMatthias Ringwald         // Enable Negative Terminal Input Mux and Set  to the appropriate input
118*5fd0122aSMatthias Ringwald         COMP_E_CMSIS(comparator)->CTL0 |= COMP_E_CTL0_IMEN
119*5fd0122aSMatthias Ringwald                 + (negativeTerminalInput << 8);
120*5fd0122aSMatthias Ringwald 
121*5fd0122aSMatthias Ringwald         // Disable the input buffer
122*5fd0122aSMatthias Ringwald         COMP_E_CMSIS(comparator)->CTL3 |= (1 << negativeTerminalInput);
123*5fd0122aSMatthias Ringwald     } else
124*5fd0122aSMatthias Ringwald     {
125*5fd0122aSMatthias Ringwald         // Reset and Set COMPE Control 2 Register
126*5fd0122aSMatthias Ringwald         BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL2, COMP_E_CTL2_RSEL_OFS) = 1;
127*5fd0122aSMatthias Ringwald     }
128*5fd0122aSMatthias Ringwald 
129*5fd0122aSMatthias Ringwald     // Reset and Set COMPE Control 1 Register
130*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->CTL1 = config->powerMode
131*5fd0122aSMatthias Ringwald             + config->outputFilterEnableAndDelayLevel
132*5fd0122aSMatthias Ringwald             + config->invertedOutputPolarity;
133*5fd0122aSMatthias Ringwald 
134*5fd0122aSMatthias Ringwald     return retVal;
135*5fd0122aSMatthias Ringwald }
136*5fd0122aSMatthias Ringwald 
COMP_E_setReferenceVoltage(uint32_t comparator,uint_fast16_t supplyVoltageReferenceBase,uint_fast16_t lowerLimitSupplyVoltageFractionOf32,uint_fast16_t upperLimitSupplyVoltageFractionOf32)137*5fd0122aSMatthias Ringwald void COMP_E_setReferenceVoltage(uint32_t comparator,
138*5fd0122aSMatthias Ringwald         uint_fast16_t supplyVoltageReferenceBase,
139*5fd0122aSMatthias Ringwald         uint_fast16_t lowerLimitSupplyVoltageFractionOf32,
140*5fd0122aSMatthias Ringwald         uint_fast16_t upperLimitSupplyVoltageFractionOf32)
141*5fd0122aSMatthias Ringwald {
142*5fd0122aSMatthias Ringwald     ASSERT(supplyVoltageReferenceBase <= COMP_E_VREFBASE2_5V);
143*5fd0122aSMatthias Ringwald     ASSERT(upperLimitSupplyVoltageFractionOf32 <= 32);
144*5fd0122aSMatthias Ringwald     ASSERT(lowerLimitSupplyVoltageFractionOf32 <= 32);
145*5fd0122aSMatthias Ringwald     ASSERT(upperLimitSupplyVoltageFractionOf32
146*5fd0122aSMatthias Ringwald             >= lowerLimitSupplyVoltageFractionOf32);
147*5fd0122aSMatthias Ringwald 
148*5fd0122aSMatthias Ringwald     BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL1, COMP_E_CTL1_MRVS_OFS) = 0;
149*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->CTL2 &= COMP_E_CTL2_RSEL;
150*5fd0122aSMatthias Ringwald 
151*5fd0122aSMatthias Ringwald     // Set Voltage Source(Vcc | Vref, resistor ladder or not)
152*5fd0122aSMatthias Ringwald     if (COMP_E_REFERENCE_AMPLIFIER_DISABLED == supplyVoltageReferenceBase)
153*5fd0122aSMatthias Ringwald     {
154*5fd0122aSMatthias Ringwald         COMP_E_CMSIS(comparator)->CTL2 |= COMP_E_CTL2_RS_1;
155*5fd0122aSMatthias Ringwald     } else if (lowerLimitSupplyVoltageFractionOf32 == 32)
156*5fd0122aSMatthias Ringwald     {
157*5fd0122aSMatthias Ringwald         COMP_E_CMSIS(comparator)->CTL2 |= COMP_E_CTL2_RS_3;
158*5fd0122aSMatthias Ringwald     } else
159*5fd0122aSMatthias Ringwald     {
160*5fd0122aSMatthias Ringwald         COMP_E_CMSIS(comparator)->CTL2 |= COMP_E_CTL2_RS_2;
161*5fd0122aSMatthias Ringwald     }
162*5fd0122aSMatthias Ringwald 
163*5fd0122aSMatthias Ringwald     // Set COMPE Control 2 Register
164*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->CTL2 |= supplyVoltageReferenceBase
165*5fd0122aSMatthias Ringwald             + ((upperLimitSupplyVoltageFractionOf32 - 1) << 8)
166*5fd0122aSMatthias Ringwald             + (lowerLimitSupplyVoltageFractionOf32 - 1);
167*5fd0122aSMatthias Ringwald }
168*5fd0122aSMatthias Ringwald 
COMP_E_setReferenceAccuracy(uint32_t comparator,uint_fast16_t referenceAccuracy)169*5fd0122aSMatthias Ringwald void COMP_E_setReferenceAccuracy(uint32_t comparator,
170*5fd0122aSMatthias Ringwald         uint_fast16_t referenceAccuracy)
171*5fd0122aSMatthias Ringwald {
172*5fd0122aSMatthias Ringwald     ASSERT(
173*5fd0122aSMatthias Ringwald             (referenceAccuracy == COMP_E_ACCURACY_STATIC)
174*5fd0122aSMatthias Ringwald             || (referenceAccuracy == COMP_E_ACCURACY_CLOCKED));
175*5fd0122aSMatthias Ringwald 
176*5fd0122aSMatthias Ringwald     if (referenceAccuracy)
177*5fd0122aSMatthias Ringwald         BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL2, COMP_E_CTL2_REFACC_OFS) = 1;
178*5fd0122aSMatthias Ringwald     else
179*5fd0122aSMatthias Ringwald         BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL2, COMP_E_CTL2_REFACC_OFS) = 0;
180*5fd0122aSMatthias Ringwald 
181*5fd0122aSMatthias Ringwald }
182*5fd0122aSMatthias Ringwald 
COMP_E_setPowerMode(uint32_t comparator,uint_fast16_t powerMode)183*5fd0122aSMatthias Ringwald void COMP_E_setPowerMode(uint32_t comparator, uint_fast16_t powerMode)
184*5fd0122aSMatthias Ringwald {
185*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->CTL1 = (COMP_E_CMSIS(comparator)->CTL1
186*5fd0122aSMatthias Ringwald             & ~(COMP_E_CTL1_PWRMD_MASK)) | powerMode;
187*5fd0122aSMatthias Ringwald }
188*5fd0122aSMatthias Ringwald 
COMP_E_enableModule(uint32_t comparator)189*5fd0122aSMatthias Ringwald void COMP_E_enableModule(uint32_t comparator)
190*5fd0122aSMatthias Ringwald {
191*5fd0122aSMatthias Ringwald     BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL1, COMP_E_CTL1_ON_OFS) = 1;
192*5fd0122aSMatthias Ringwald }
193*5fd0122aSMatthias Ringwald 
COMP_E_disableModule(uint32_t comparator)194*5fd0122aSMatthias Ringwald void COMP_E_disableModule(uint32_t comparator)
195*5fd0122aSMatthias Ringwald {
196*5fd0122aSMatthias Ringwald     BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL1, COMP_E_CTL1_ON_OFS) = 0;
197*5fd0122aSMatthias Ringwald }
198*5fd0122aSMatthias Ringwald 
COMP_E_shortInputs(uint32_t comparator)199*5fd0122aSMatthias Ringwald void COMP_E_shortInputs(uint32_t comparator)
200*5fd0122aSMatthias Ringwald {
201*5fd0122aSMatthias Ringwald     BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL1, COMP_E_CTL1_SHORT_OFS) = 1;
202*5fd0122aSMatthias Ringwald }
203*5fd0122aSMatthias Ringwald 
COMP_E_unshortInputs(uint32_t comparator)204*5fd0122aSMatthias Ringwald void COMP_E_unshortInputs(uint32_t comparator)
205*5fd0122aSMatthias Ringwald {
206*5fd0122aSMatthias Ringwald     BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL1, COMP_E_CTL1_SHORT_OFS) = 0;
207*5fd0122aSMatthias Ringwald }
208*5fd0122aSMatthias Ringwald 
COMP_E_disableInputBuffer(uint32_t comparator,uint_fast16_t inputPort)209*5fd0122aSMatthias Ringwald void COMP_E_disableInputBuffer(uint32_t comparator, uint_fast16_t inputPort)
210*5fd0122aSMatthias Ringwald {
211*5fd0122aSMatthias Ringwald     ASSERT(inputPort <= COMP_E_INPUT15);
212*5fd0122aSMatthias Ringwald 
213*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->CTL3 |= (inputPort);
214*5fd0122aSMatthias Ringwald }
215*5fd0122aSMatthias Ringwald 
COMP_E_enableInputBuffer(uint32_t comparator,uint_fast16_t inputPort)216*5fd0122aSMatthias Ringwald void COMP_E_enableInputBuffer(uint32_t comparator, uint_fast16_t inputPort)
217*5fd0122aSMatthias Ringwald {
218*5fd0122aSMatthias Ringwald     ASSERT(inputPort <= COMP_E_INPUT15);
219*5fd0122aSMatthias Ringwald 
220*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->CTL3 &= ~(inputPort);
221*5fd0122aSMatthias Ringwald }
222*5fd0122aSMatthias Ringwald 
COMP_E_swapIO(uint32_t comparator)223*5fd0122aSMatthias Ringwald void COMP_E_swapIO(uint32_t comparator)
224*5fd0122aSMatthias Ringwald {
225*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->CTL1 ^= COMP_E_CTL1_EX; // Toggle CEEX bit
226*5fd0122aSMatthias Ringwald }
227*5fd0122aSMatthias Ringwald 
COMP_E_outputValue(uint32_t comparator)228*5fd0122aSMatthias Ringwald uint8_t COMP_E_outputValue(uint32_t comparator)
229*5fd0122aSMatthias Ringwald {
230*5fd0122aSMatthias Ringwald     return COMP_E_CMSIS(comparator)->CTL1 & COMP_E_CTL1_OUT;
231*5fd0122aSMatthias Ringwald }
232*5fd0122aSMatthias Ringwald 
COMP_E_enableInterrupt(uint32_t comparator,uint_fast16_t mask)233*5fd0122aSMatthias Ringwald void COMP_E_enableInterrupt(uint32_t comparator, uint_fast16_t mask)
234*5fd0122aSMatthias Ringwald {
235*5fd0122aSMatthias Ringwald     // Set the Interrupt enable bit
236*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->INT |= mask;
237*5fd0122aSMatthias Ringwald }
238*5fd0122aSMatthias Ringwald 
COMP_E_getEnabledInterruptStatus(uint32_t comparator)239*5fd0122aSMatthias Ringwald uint_fast16_t COMP_E_getEnabledInterruptStatus(uint32_t comparator)
240*5fd0122aSMatthias Ringwald {
241*5fd0122aSMatthias Ringwald     return COMP_E_getInterruptStatus(comparator) &
242*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->INT;
243*5fd0122aSMatthias Ringwald }
244*5fd0122aSMatthias Ringwald 
COMP_E_disableInterrupt(uint32_t comparator,uint_fast16_t mask)245*5fd0122aSMatthias Ringwald void COMP_E_disableInterrupt(uint32_t comparator, uint_fast16_t mask)
246*5fd0122aSMatthias Ringwald {
247*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->INT &= ~(mask);
248*5fd0122aSMatthias Ringwald }
249*5fd0122aSMatthias Ringwald 
COMP_E_clearInterruptFlag(uint32_t comparator,uint_fast16_t mask)250*5fd0122aSMatthias Ringwald void COMP_E_clearInterruptFlag(uint32_t comparator, uint_fast16_t mask)
251*5fd0122aSMatthias Ringwald {
252*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->INT &= ~(mask);
253*5fd0122aSMatthias Ringwald }
254*5fd0122aSMatthias Ringwald 
COMP_E_getInterruptStatus(uint32_t comparator)255*5fd0122aSMatthias Ringwald uint_fast16_t COMP_E_getInterruptStatus(uint32_t comparator)
256*5fd0122aSMatthias Ringwald {
257*5fd0122aSMatthias Ringwald     return (COMP_E_CMSIS(comparator)->INT & (COMP_E_OUTPUT_INTERRUPT_FLAG |
258*5fd0122aSMatthias Ringwald     COMP_E_INTERRUPT_FLAG_INVERTED_POLARITY |
259*5fd0122aSMatthias Ringwald     COMP_E_INTERRUPT_FLAG_READY));
260*5fd0122aSMatthias Ringwald }
261*5fd0122aSMatthias Ringwald 
COMP_E_setInterruptEdgeDirection(uint32_t comparator,uint_fast8_t edgeDirection)262*5fd0122aSMatthias Ringwald void COMP_E_setInterruptEdgeDirection(uint32_t comparator,
263*5fd0122aSMatthias Ringwald         uint_fast8_t edgeDirection)
264*5fd0122aSMatthias Ringwald {
265*5fd0122aSMatthias Ringwald     ASSERT(edgeDirection <= COMP_E_RISINGEDGE);
266*5fd0122aSMatthias Ringwald 
267*5fd0122aSMatthias Ringwald     // Set the edge direction that will trigger an interrupt
268*5fd0122aSMatthias Ringwald     if (COMP_E_RISINGEDGE == edgeDirection)
269*5fd0122aSMatthias Ringwald         BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL1, COMP_E_CTL1_IES_OFS) = 0;
270*5fd0122aSMatthias Ringwald     else if (COMP_E_FALLINGEDGE == edgeDirection)
271*5fd0122aSMatthias Ringwald         BITBAND_PERI(COMP_E_CMSIS(comparator)->CTL1, COMP_E_CTL1_IES_OFS) = 1;
272*5fd0122aSMatthias Ringwald }
273*5fd0122aSMatthias Ringwald 
COMP_E_toggleInterruptEdgeDirection(uint32_t comparator)274*5fd0122aSMatthias Ringwald void COMP_E_toggleInterruptEdgeDirection(uint32_t comparator)
275*5fd0122aSMatthias Ringwald {
276*5fd0122aSMatthias Ringwald     COMP_E_CMSIS(comparator)->CTL1 ^= COMP_E_CTL1_IES;
277*5fd0122aSMatthias Ringwald }
278*5fd0122aSMatthias Ringwald 
COMP_E_registerInterrupt(uint32_t comparator,void (* intHandler)(void))279*5fd0122aSMatthias Ringwald void COMP_E_registerInterrupt(uint32_t comparator, void (*intHandler)(void))
280*5fd0122aSMatthias Ringwald {
281*5fd0122aSMatthias Ringwald     switch (comparator)
282*5fd0122aSMatthias Ringwald     {
283*5fd0122aSMatthias Ringwald     case COMP_E0_BASE:
284*5fd0122aSMatthias Ringwald         Interrupt_registerInterrupt(INT_COMP_E0, intHandler);
285*5fd0122aSMatthias Ringwald         Interrupt_enableInterrupt(INT_COMP_E0);
286*5fd0122aSMatthias Ringwald         break;
287*5fd0122aSMatthias Ringwald     case COMP_E1_BASE:
288*5fd0122aSMatthias Ringwald         Interrupt_registerInterrupt(INT_COMP_E1, intHandler);
289*5fd0122aSMatthias Ringwald         Interrupt_enableInterrupt(INT_COMP_E1);
290*5fd0122aSMatthias Ringwald         break;
291*5fd0122aSMatthias Ringwald     default:
292*5fd0122aSMatthias Ringwald         ASSERT(false);
293*5fd0122aSMatthias Ringwald     }
294*5fd0122aSMatthias Ringwald }
295*5fd0122aSMatthias Ringwald 
COMP_E_unregisterInterrupt(uint32_t comparator)296*5fd0122aSMatthias Ringwald void COMP_E_unregisterInterrupt(uint32_t comparator)
297*5fd0122aSMatthias Ringwald {
298*5fd0122aSMatthias Ringwald     switch (comparator)
299*5fd0122aSMatthias Ringwald     {
300*5fd0122aSMatthias Ringwald     case COMP_E0_BASE:
301*5fd0122aSMatthias Ringwald         Interrupt_disableInterrupt(INT_COMP_E0);
302*5fd0122aSMatthias Ringwald         Interrupt_unregisterInterrupt(INT_COMP_E0);
303*5fd0122aSMatthias Ringwald         break;
304*5fd0122aSMatthias Ringwald     case COMP_E1_BASE:
305*5fd0122aSMatthias Ringwald         Interrupt_disableInterrupt(INT_COMP_E1);
306*5fd0122aSMatthias Ringwald         Interrupt_unregisterInterrupt(INT_COMP_E1);
307*5fd0122aSMatthias Ringwald         break;
308*5fd0122aSMatthias Ringwald     default:
309*5fd0122aSMatthias Ringwald         ASSERT(false);
310*5fd0122aSMatthias Ringwald     }
311*5fd0122aSMatthias Ringwald }
312*5fd0122aSMatthias Ringwald 
313