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/ref_a.h>
33*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/debug.h>
34*5fd0122aSMatthias Ringwald
REF_A_setReferenceVoltage(uint_fast8_t referenceVoltageSelect)35*5fd0122aSMatthias Ringwald void REF_A_setReferenceVoltage(uint_fast8_t referenceVoltageSelect)
36*5fd0122aSMatthias Ringwald {
37*5fd0122aSMatthias Ringwald ASSERT(referenceVoltageSelect <= REF_A_VREF2_5V);
38*5fd0122aSMatthias Ringwald
39*5fd0122aSMatthias Ringwald REF_A->CTL0 = (REF_A->CTL0 & ~REF_A_CTL0_VSEL_3) | referenceVoltageSelect;
40*5fd0122aSMatthias Ringwald }
41*5fd0122aSMatthias Ringwald
REF_A_disableTempSensor(void)42*5fd0122aSMatthias Ringwald void REF_A_disableTempSensor(void)
43*5fd0122aSMatthias Ringwald {
44*5fd0122aSMatthias Ringwald BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_TCOFF_OFS) = 1;
45*5fd0122aSMatthias Ringwald }
46*5fd0122aSMatthias Ringwald
REF_A_enableTempSensor(void)47*5fd0122aSMatthias Ringwald void REF_A_enableTempSensor(void)
48*5fd0122aSMatthias Ringwald {
49*5fd0122aSMatthias Ringwald BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_TCOFF_OFS) = 0;
50*5fd0122aSMatthias Ringwald }
51*5fd0122aSMatthias Ringwald
REF_A_enableReferenceVoltageOutput(void)52*5fd0122aSMatthias Ringwald void REF_A_enableReferenceVoltageOutput(void)
53*5fd0122aSMatthias Ringwald {
54*5fd0122aSMatthias Ringwald BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_OUT_OFS) = 1;
55*5fd0122aSMatthias Ringwald }
56*5fd0122aSMatthias Ringwald
REF_A_disableReferenceVoltageOutput(void)57*5fd0122aSMatthias Ringwald void REF_A_disableReferenceVoltageOutput(void)
58*5fd0122aSMatthias Ringwald {
59*5fd0122aSMatthias Ringwald BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_OUT_OFS) = 0;
60*5fd0122aSMatthias Ringwald }
61*5fd0122aSMatthias Ringwald
REF_A_enableReferenceVoltage(void)62*5fd0122aSMatthias Ringwald void REF_A_enableReferenceVoltage(void)
63*5fd0122aSMatthias Ringwald {
64*5fd0122aSMatthias Ringwald BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_ON_OFS) = 1;
65*5fd0122aSMatthias Ringwald }
66*5fd0122aSMatthias Ringwald
REF_A_disableReferenceVoltage(void)67*5fd0122aSMatthias Ringwald void REF_A_disableReferenceVoltage(void)
68*5fd0122aSMatthias Ringwald {
69*5fd0122aSMatthias Ringwald BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_ON_OFS) = 0;
70*5fd0122aSMatthias Ringwald }
71*5fd0122aSMatthias Ringwald
REF_A_getBandgapMode(void)72*5fd0122aSMatthias Ringwald uint_fast8_t REF_A_getBandgapMode(void)
73*5fd0122aSMatthias Ringwald {
74*5fd0122aSMatthias Ringwald return (REF_A->CTL0 & REF_A_CTL0_BGMODE);
75*5fd0122aSMatthias Ringwald }
76*5fd0122aSMatthias Ringwald
REF_A_isBandgapActive(void)77*5fd0122aSMatthias Ringwald bool REF_A_isBandgapActive(void)
78*5fd0122aSMatthias Ringwald {
79*5fd0122aSMatthias Ringwald return BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_BGACT_OFS);
80*5fd0122aSMatthias Ringwald }
81*5fd0122aSMatthias Ringwald
REF_A_isRefGenBusy(void)82*5fd0122aSMatthias Ringwald bool REF_A_isRefGenBusy(void)
83*5fd0122aSMatthias Ringwald {
84*5fd0122aSMatthias Ringwald return BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_GENBUSY_OFS);
85*5fd0122aSMatthias Ringwald }
86*5fd0122aSMatthias Ringwald
REF_A_isRefGenActive(void)87*5fd0122aSMatthias Ringwald bool REF_A_isRefGenActive(void)
88*5fd0122aSMatthias Ringwald {
89*5fd0122aSMatthias Ringwald return BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_GENACT_OFS);
90*5fd0122aSMatthias Ringwald }
91*5fd0122aSMatthias Ringwald
REF_A_getBufferedBandgapVoltageStatus(void)92*5fd0122aSMatthias Ringwald bool REF_A_getBufferedBandgapVoltageStatus(void)
93*5fd0122aSMatthias Ringwald {
94*5fd0122aSMatthias Ringwald return BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_BGRDY_OFS);
95*5fd0122aSMatthias Ringwald }
96*5fd0122aSMatthias Ringwald
REF_A_getVariableReferenceVoltageStatus(void)97*5fd0122aSMatthias Ringwald bool REF_A_getVariableReferenceVoltageStatus(void)
98*5fd0122aSMatthias Ringwald {
99*5fd0122aSMatthias Ringwald return BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_GENRDY_OFS);
100*5fd0122aSMatthias Ringwald }
101*5fd0122aSMatthias Ringwald
REF_A_setReferenceVoltageOneTimeTrigger(void)102*5fd0122aSMatthias Ringwald void REF_A_setReferenceVoltageOneTimeTrigger(void)
103*5fd0122aSMatthias Ringwald {
104*5fd0122aSMatthias Ringwald BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_GENOT_OFS) = 1;
105*5fd0122aSMatthias Ringwald }
106*5fd0122aSMatthias Ringwald
REF_A_setBufferedBandgapVoltageOneTimeTrigger(void)107*5fd0122aSMatthias Ringwald void REF_A_setBufferedBandgapVoltageOneTimeTrigger(void)
108*5fd0122aSMatthias Ringwald {
109*5fd0122aSMatthias Ringwald BITBAND_PERI(REF_A->CTL0,REF_A_CTL0_BGOT_OFS) = 1;
110*5fd0122aSMatthias Ringwald }
111*5fd0122aSMatthias Ringwald
112