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/reset.h>
33*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/debug.h>
34*5fd0122aSMatthias Ringwald
ResetCtl_initiateSoftReset(void)35*5fd0122aSMatthias Ringwald void ResetCtl_initiateSoftReset(void)
36*5fd0122aSMatthias Ringwald {
37*5fd0122aSMatthias Ringwald RSTCTL->RESET_REQ |= (RESET_KEY | RESET_SOFT_RESET);
38*5fd0122aSMatthias Ringwald }
39*5fd0122aSMatthias Ringwald
ResetCtl_initiateSoftResetWithSource(uint32_t source)40*5fd0122aSMatthias Ringwald void ResetCtl_initiateSoftResetWithSource(uint32_t source)
41*5fd0122aSMatthias Ringwald {
42*5fd0122aSMatthias Ringwald RSTCTL->SOFTRESET_SET |= (source);
43*5fd0122aSMatthias Ringwald }
44*5fd0122aSMatthias Ringwald
ResetCtl_getSoftResetSource(void)45*5fd0122aSMatthias Ringwald uint32_t ResetCtl_getSoftResetSource(void)
46*5fd0122aSMatthias Ringwald {
47*5fd0122aSMatthias Ringwald return RSTCTL->SOFTRESET_STAT;
48*5fd0122aSMatthias Ringwald }
49*5fd0122aSMatthias Ringwald
ResetCtl_clearSoftResetSource(uint32_t mask)50*5fd0122aSMatthias Ringwald void ResetCtl_clearSoftResetSource(uint32_t mask)
51*5fd0122aSMatthias Ringwald {
52*5fd0122aSMatthias Ringwald RSTCTL->SOFTRESET_CLR |= mask;
53*5fd0122aSMatthias Ringwald }
54*5fd0122aSMatthias Ringwald
ResetCtl_initiateHardReset(void)55*5fd0122aSMatthias Ringwald void ResetCtl_initiateHardReset(void)
56*5fd0122aSMatthias Ringwald {
57*5fd0122aSMatthias Ringwald RSTCTL->RESET_REQ |= (RESET_KEY | RESET_HARD_RESET);
58*5fd0122aSMatthias Ringwald }
59*5fd0122aSMatthias Ringwald
ResetCtl_initiateHardResetWithSource(uint32_t source)60*5fd0122aSMatthias Ringwald void ResetCtl_initiateHardResetWithSource(uint32_t source)
61*5fd0122aSMatthias Ringwald {
62*5fd0122aSMatthias Ringwald RSTCTL->HARDRESET_SET |= (source);
63*5fd0122aSMatthias Ringwald }
64*5fd0122aSMatthias Ringwald
ResetCtl_getHardResetSource(void)65*5fd0122aSMatthias Ringwald uint32_t ResetCtl_getHardResetSource(void)
66*5fd0122aSMatthias Ringwald {
67*5fd0122aSMatthias Ringwald return RSTCTL->HARDRESET_STAT;
68*5fd0122aSMatthias Ringwald }
69*5fd0122aSMatthias Ringwald
ResetCtl_clearHardResetSource(uint32_t mask)70*5fd0122aSMatthias Ringwald void ResetCtl_clearHardResetSource(uint32_t mask)
71*5fd0122aSMatthias Ringwald {
72*5fd0122aSMatthias Ringwald RSTCTL->HARDRESET_CLR |= mask;
73*5fd0122aSMatthias Ringwald }
74*5fd0122aSMatthias Ringwald
ResetCtl_getPSSSource(void)75*5fd0122aSMatthias Ringwald uint32_t ResetCtl_getPSSSource(void)
76*5fd0122aSMatthias Ringwald {
77*5fd0122aSMatthias Ringwald return RSTCTL->PSSRESET_STAT;
78*5fd0122aSMatthias Ringwald }
79*5fd0122aSMatthias Ringwald
ResetCtl_clearPSSFlags(void)80*5fd0122aSMatthias Ringwald void ResetCtl_clearPSSFlags(void)
81*5fd0122aSMatthias Ringwald {
82*5fd0122aSMatthias Ringwald RSTCTL->PSSRESET_CLR |= RSTCTL_PSSRESET_CLR_CLR;
83*5fd0122aSMatthias Ringwald }
84*5fd0122aSMatthias Ringwald
ResetCtl_getPCMSource(void)85*5fd0122aSMatthias Ringwald uint32_t ResetCtl_getPCMSource(void)
86*5fd0122aSMatthias Ringwald {
87*5fd0122aSMatthias Ringwald return RSTCTL->PCMRESET_STAT;
88*5fd0122aSMatthias Ringwald }
89*5fd0122aSMatthias Ringwald
ResetCtl_clearPCMFlags(void)90*5fd0122aSMatthias Ringwald void ResetCtl_clearPCMFlags(void)
91*5fd0122aSMatthias Ringwald {
92*5fd0122aSMatthias Ringwald RSTCTL->PCMRESET_CLR |= RSTCTL_PCMRESET_CLR_CLR;
93*5fd0122aSMatthias Ringwald }
94*5fd0122aSMatthias Ringwald
95