xref: /btstack/port/msp432p401lp-cc256x/ti/devices/msp432p4xx/driverlib/timer32.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/timer32.h>
33*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/interrupt.h>
34*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/debug.h>
35*5fd0122aSMatthias Ringwald 
Timer32_initModule(uint32_t timer,uint32_t preScaler,uint32_t resolution,uint32_t mode)36*5fd0122aSMatthias Ringwald void Timer32_initModule(uint32_t timer, uint32_t preScaler, uint32_t resolution,
37*5fd0122aSMatthias Ringwald         uint32_t mode)
38*5fd0122aSMatthias Ringwald {
39*5fd0122aSMatthias Ringwald     /* Setting up one shot or continuous mode */
40*5fd0122aSMatthias Ringwald     if (mode == TIMER32_PERIODIC_MODE)
41*5fd0122aSMatthias Ringwald         BITBAND_PERI(TIMER32_CMSIS(timer)->CONTROL, TIMER32_CONTROL_MODE_OFS)
42*5fd0122aSMatthias Ringwald                     = 1;
43*5fd0122aSMatthias Ringwald     else if (mode == TIMER32_FREE_RUN_MODE)
44*5fd0122aSMatthias Ringwald         BITBAND_PERI(TIMER32_CMSIS(timer)->CONTROL, TIMER32_CONTROL_MODE_OFS)
45*5fd0122aSMatthias Ringwald                     = 0;
46*5fd0122aSMatthias Ringwald     else
47*5fd0122aSMatthias Ringwald         ASSERT(false);
48*5fd0122aSMatthias Ringwald 
49*5fd0122aSMatthias Ringwald     /* Setting the resolution of the timer */
50*5fd0122aSMatthias Ringwald     if (resolution == TIMER32_16BIT)
51*5fd0122aSMatthias Ringwald         BITBAND_PERI(TIMER32_CMSIS(timer)->CONTROL, TIMER32_CONTROL_SIZE_OFS)
52*5fd0122aSMatthias Ringwald                     = 0;
53*5fd0122aSMatthias Ringwald     else if (resolution == TIMER32_32BIT)
54*5fd0122aSMatthias Ringwald         BITBAND_PERI(TIMER32_CMSIS(timer)->CONTROL, TIMER32_CONTROL_SIZE_OFS)
55*5fd0122aSMatthias Ringwald                     = 1;
56*5fd0122aSMatthias Ringwald     else
57*5fd0122aSMatthias Ringwald         ASSERT(false);
58*5fd0122aSMatthias Ringwald 
59*5fd0122aSMatthias Ringwald     /* Setting the PreScaler */
60*5fd0122aSMatthias Ringwald     ASSERT(
61*5fd0122aSMatthias Ringwald             resolution == TIMER32_PRESCALER_1
62*5fd0122aSMatthias Ringwald             || resolution == TIMER32_PRESCALER_16
63*5fd0122aSMatthias Ringwald             || resolution == TIMER32_PRESCALER_256);
64*5fd0122aSMatthias Ringwald 
65*5fd0122aSMatthias Ringwald     TIMER32_CMSIS(timer)->CONTROL = (TIMER32_CMSIS(timer)->CONTROL
66*5fd0122aSMatthias Ringwald             & (~TIMER32_CONTROL_PRESCALE_MASK)) | preScaler;
67*5fd0122aSMatthias Ringwald 
68*5fd0122aSMatthias Ringwald }
69*5fd0122aSMatthias Ringwald 
Timer32_setCount(uint32_t timer,uint32_t count)70*5fd0122aSMatthias Ringwald void Timer32_setCount(uint32_t timer, uint32_t count)
71*5fd0122aSMatthias Ringwald {
72*5fd0122aSMatthias Ringwald     if (!BITBAND_PERI(TIMER32_CMSIS(timer)->CONTROL, TIMER32_CONTROL_SIZE_OFS)
73*5fd0122aSMatthias Ringwald             && (count > UINT16_MAX))
74*5fd0122aSMatthias Ringwald         TIMER32_CMSIS(timer)->LOAD = UINT16_MAX;
75*5fd0122aSMatthias Ringwald     else
76*5fd0122aSMatthias Ringwald         TIMER32_CMSIS(timer)->LOAD = count;
77*5fd0122aSMatthias Ringwald }
78*5fd0122aSMatthias Ringwald 
Timer32_setCountInBackground(uint32_t timer,uint32_t count)79*5fd0122aSMatthias Ringwald void Timer32_setCountInBackground(uint32_t timer, uint32_t count)
80*5fd0122aSMatthias Ringwald {
81*5fd0122aSMatthias Ringwald     if (!BITBAND_PERI(TIMER32_CMSIS(timer)->CONTROL, TIMER32_CONTROL_SIZE_OFS)
82*5fd0122aSMatthias Ringwald             && (count > UINT16_MAX))
83*5fd0122aSMatthias Ringwald         TIMER32_CMSIS(timer)->BGLOAD = UINT16_MAX;
84*5fd0122aSMatthias Ringwald     else
85*5fd0122aSMatthias Ringwald         TIMER32_CMSIS(timer)->BGLOAD = count;
86*5fd0122aSMatthias Ringwald }
87*5fd0122aSMatthias Ringwald 
Timer32_getValue(uint32_t timer)88*5fd0122aSMatthias Ringwald uint32_t Timer32_getValue(uint32_t timer)
89*5fd0122aSMatthias Ringwald {
90*5fd0122aSMatthias Ringwald     return TIMER32_CMSIS(timer)->VALUE;
91*5fd0122aSMatthias Ringwald }
92*5fd0122aSMatthias Ringwald 
Timer32_startTimer(uint32_t timer,bool oneShot)93*5fd0122aSMatthias Ringwald void Timer32_startTimer(uint32_t timer, bool oneShot)
94*5fd0122aSMatthias Ringwald {
95*5fd0122aSMatthias Ringwald     ASSERT(timer == TIMER32_0_BASE || timer == TIMER32_1_BASE);
96*5fd0122aSMatthias Ringwald 
97*5fd0122aSMatthias Ringwald     if (oneShot)
98*5fd0122aSMatthias Ringwald         BITBAND_PERI(TIMER32_CMSIS(timer)->CONTROL, TIMER32_CONTROL_ONESHOT_OFS)
99*5fd0122aSMatthias Ringwald                     = 1;
100*5fd0122aSMatthias Ringwald     else
101*5fd0122aSMatthias Ringwald         BITBAND_PERI(TIMER32_CMSIS(timer)->CONTROL, TIMER32_CONTROL_ONESHOT_OFS)
102*5fd0122aSMatthias Ringwald                     = 0;
103*5fd0122aSMatthias Ringwald 
104*5fd0122aSMatthias Ringwald     TIMER32_CMSIS(timer)->CONTROL |= TIMER32_CONTROL_ENABLE;
105*5fd0122aSMatthias Ringwald }
106*5fd0122aSMatthias Ringwald 
Timer32_haltTimer(uint32_t timer)107*5fd0122aSMatthias Ringwald void Timer32_haltTimer(uint32_t timer)
108*5fd0122aSMatthias Ringwald {
109*5fd0122aSMatthias Ringwald     ASSERT(timer == TIMER32_0_BASE || timer == TIMER32_1_BASE);
110*5fd0122aSMatthias Ringwald 
111*5fd0122aSMatthias Ringwald     TIMER32_CMSIS(timer)->CONTROL &= ~TIMER32_CONTROL_ENABLE;
112*5fd0122aSMatthias Ringwald }
113*5fd0122aSMatthias Ringwald 
Timer32_enableInterrupt(uint32_t timer)114*5fd0122aSMatthias Ringwald void Timer32_enableInterrupt(uint32_t timer)
115*5fd0122aSMatthias Ringwald {
116*5fd0122aSMatthias Ringwald     TIMER32_CMSIS(timer)->CONTROL |= TIMER32_CONTROL_IE;
117*5fd0122aSMatthias Ringwald }
118*5fd0122aSMatthias Ringwald 
Timer32_disableInterrupt(uint32_t timer)119*5fd0122aSMatthias Ringwald void Timer32_disableInterrupt(uint32_t timer)
120*5fd0122aSMatthias Ringwald {
121*5fd0122aSMatthias Ringwald     TIMER32_CMSIS(timer)->CONTROL &= ~TIMER32_CONTROL_IE;
122*5fd0122aSMatthias Ringwald }
123*5fd0122aSMatthias Ringwald 
Timer32_clearInterruptFlag(uint32_t timer)124*5fd0122aSMatthias Ringwald void Timer32_clearInterruptFlag(uint32_t timer)
125*5fd0122aSMatthias Ringwald {
126*5fd0122aSMatthias Ringwald     TIMER32_CMSIS(timer)->INTCLR |= 0x01;
127*5fd0122aSMatthias Ringwald }
128*5fd0122aSMatthias Ringwald 
Timer32_getInterruptStatus(uint32_t timer)129*5fd0122aSMatthias Ringwald uint32_t Timer32_getInterruptStatus(uint32_t timer)
130*5fd0122aSMatthias Ringwald {
131*5fd0122aSMatthias Ringwald     return TIMER32_CMSIS(timer)->MIS;
132*5fd0122aSMatthias Ringwald }
133*5fd0122aSMatthias Ringwald 
Timer32_registerInterrupt(uint32_t timerInterrupt,void (* intHandler)(void))134*5fd0122aSMatthias Ringwald void Timer32_registerInterrupt(uint32_t timerInterrupt,
135*5fd0122aSMatthias Ringwald         void (*intHandler)(void))
136*5fd0122aSMatthias Ringwald {
137*5fd0122aSMatthias Ringwald     Interrupt_registerInterrupt(timerInterrupt, intHandler);
138*5fd0122aSMatthias Ringwald     Interrupt_enableInterrupt(timerInterrupt);
139*5fd0122aSMatthias Ringwald }
140*5fd0122aSMatthias Ringwald 
Timer32_unregisterInterrupt(uint32_t timerInterrupt)141*5fd0122aSMatthias Ringwald void Timer32_unregisterInterrupt(uint32_t timerInterrupt)
142*5fd0122aSMatthias Ringwald {
143*5fd0122aSMatthias Ringwald     Interrupt_disableInterrupt(timerInterrupt);
144*5fd0122aSMatthias Ringwald     Interrupt_unregisterInterrupt(timerInterrupt);
145*5fd0122aSMatthias Ringwald }
146*5fd0122aSMatthias Ringwald 
147