xref: /btstack/port/msp432p401lp-cc256x/ti/devices/msp432p4xx/driverlib/pmap.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/debug.h>
33*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/pmap.h>
34*5fd0122aSMatthias Ringwald 
35*5fd0122aSMatthias Ringwald 
PMAP_configurePorts(const uint8_t * portMapping,uint8_t pxMAPy,uint8_t numberOfPorts,uint8_t portMapReconfigure)36*5fd0122aSMatthias Ringwald void PMAP_configurePorts(const uint8_t *portMapping, uint8_t pxMAPy,
37*5fd0122aSMatthias Ringwald         uint8_t numberOfPorts, uint8_t portMapReconfigure)
38*5fd0122aSMatthias Ringwald {
39*5fd0122aSMatthias Ringwald     uint_fast16_t i;
40*5fd0122aSMatthias Ringwald 
41*5fd0122aSMatthias Ringwald     ASSERT(
42*5fd0122aSMatthias Ringwald             (portMapReconfigure == PMAP_ENABLE_RECONFIGURATION)
43*5fd0122aSMatthias Ringwald                     || (portMapReconfigure == PMAP_DISABLE_RECONFIGURATION));
44*5fd0122aSMatthias Ringwald 
45*5fd0122aSMatthias Ringwald     //Get write-access to port mapping registers:
46*5fd0122aSMatthias Ringwald     PMAP->KEYID = PMAP_KEYID_VAL;
47*5fd0122aSMatthias Ringwald 
48*5fd0122aSMatthias Ringwald     //Enable/Disable reconfiguration during runtime
49*5fd0122aSMatthias Ringwald     PMAP->CTL = (PMAP->CTL & ~PMAP_CTL_PRECFG) | portMapReconfigure;
50*5fd0122aSMatthias Ringwald 
51*5fd0122aSMatthias Ringwald     //Configure Port Mapping:
52*5fd0122aSMatthias Ringwald 
53*5fd0122aSMatthias Ringwald     for (i = 0; i < numberOfPorts * 8; i++)
54*5fd0122aSMatthias Ringwald     {
55*5fd0122aSMatthias Ringwald         HWREG8(PMAP_BASE + i + pxMAPy) = portMapping[i];
56*5fd0122aSMatthias Ringwald     }
57*5fd0122aSMatthias Ringwald 
58*5fd0122aSMatthias Ringwald     //Disable write-access to port mapping registers:
59*5fd0122aSMatthias Ringwald     PMAP->KEYID = 0;
60*5fd0122aSMatthias Ringwald }
61*5fd0122aSMatthias Ringwald 
62