1 /*
2 * Copyright (c) 2015, Freescale Semiconductor, Inc.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without modification,
6 * are permitted provided that the following conditions are met:
7 *
8 * o Redistributions of source code must retain the above copyright notice, this list
9 * of conditions and the following disclaimer.
10 *
11 * o Redistributions in binary form must reproduce the above copyright notice, this
12 * list of conditions and the following disclaimer in the documentation and/or
13 * other materials provided with the distribution.
14 *
15 * o Neither the name of Freescale Semiconductor, Inc. nor the names of its
16 * contributors may be used to endorse or promote products derived from this
17 * software without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
21 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
22 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
23 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
24 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
26 * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
28 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 */
30
31 #include "epit.h"
32
33 /*******************************************************************************
34 * Code
35 ******************************************************************************/
36
37 /*FUNCTION**********************************************************************
38 *
39 * Function Name : EPIT_Init
40 * Description : Initializes the EPIT module according to the specified
41 * parameters in the initConfig.
42 *
43 *END**************************************************************************/
EPIT_Init(EPIT_Type * base,const epit_init_config_t * initConfig)44 void EPIT_Init(EPIT_Type* base, const epit_init_config_t* initConfig)
45 {
46 assert(initConfig);
47
48 EPIT_CR_REG(base) = 0;
49
50 EPIT_SoftReset(base);
51
52 EPIT_CR_REG(base) = (initConfig->freeRun ? EPIT_CR_RLD_MASK : 0) |
53 (initConfig->waitEnable ? EPIT_CR_WAITEN_MASK : 0) |
54 (initConfig->stopEnable ? EPIT_CR_STOPEN_MASK : 0) |
55 (initConfig->dbgEnable ? EPIT_CR_DBGEN_MASK : 0) |
56 (initConfig->enableMode ? EPIT_CR_ENMOD_MASK : 0);
57 }
58
59 /*FUNCTION**********************************************************************
60 *
61 * Function Name : EPIT_SetOverwriteCounter
62 * Description : Enable or disable EPIT overwrite counter immediately.
63 *
64 *END**************************************************************************/
EPIT_SetOverwriteCounter(EPIT_Type * base,bool enable)65 void EPIT_SetOverwriteCounter(EPIT_Type* base, bool enable)
66 {
67 if(enable)
68 EPIT_CR_REG(base) |= EPIT_CR_IOVW_MASK;
69 else
70 EPIT_CR_REG(base) &= ~EPIT_CR_IOVW_MASK;
71 }
72
73 /*FUNCTION**********************************************************************
74 *
75 * Function Name : EPIT_SetIntCmd
76 * Description : Enable or disable EPIT interrupt.
77 *
78 *END**************************************************************************/
EPIT_SetIntCmd(EPIT_Type * base,bool enable)79 void EPIT_SetIntCmd(EPIT_Type* base, bool enable)
80 {
81 if (enable)
82 EPIT_CR_REG(base) |= EPIT_CR_OCIEN_MASK;
83 else
84 EPIT_CR_REG(base) &= ~EPIT_CR_OCIEN_MASK;
85 }
86
87 /*******************************************************************************
88 * EOF
89 ******************************************************************************/
90