2018-11-20 03:16:48 +00:00
|
|
|
/* mbed Microcontroller Library
|
2018-12-03 01:37:29 +00:00
|
|
|
* (C)Copyright TOSHIBA ELECTRONIC DEVICES & STORAGE CORPORATION 2018 All rights reserved
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
2018-11-20 03:16:48 +00:00
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
#include "mbed_assert.h"
|
|
|
|
#include "pinmap.h"
|
|
|
|
#include "gpio_include.h"
|
|
|
|
|
|
|
|
void pin_function(PinName pin, int function)
|
|
|
|
{
|
|
|
|
int port = 0;
|
|
|
|
uint8_t bit = 0;
|
|
|
|
uint8_t func = 0;
|
|
|
|
uint8_t dir = 0;
|
|
|
|
uint32_t port_base = 0;
|
|
|
|
uint32_t mode_base = 0;
|
|
|
|
|
|
|
|
/* Assert that pin is valid*/
|
|
|
|
MBED_ASSERT(pin != NC);
|
|
|
|
|
|
|
|
/* Calculate pin function and pin direction*/
|
|
|
|
func = PIN_FUNC(function);
|
|
|
|
dir = PIN_DIR(function);
|
|
|
|
|
|
|
|
/* Calculate port and pin position*/
|
|
|
|
port = PIN_PORT(pin);
|
|
|
|
bit = PIN_POS(pin);
|
|
|
|
|
|
|
|
port_base = BITBAND_PORT_BASE(port);
|
|
|
|
/* Initialization PxFR OFF */
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR1);
|
|
|
|
BITBAND_PORT_CLR(mode_base, bit);
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR2);
|
|
|
|
BITBAND_PORT_CLR(mode_base, bit);
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR3);
|
|
|
|
BITBAND_PORT_CLR(mode_base, bit);
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR4);
|
|
|
|
BITBAND_PORT_CLR(mode_base, bit);
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR5);
|
|
|
|
BITBAND_PORT_CLR(mode_base, bit);
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR6);
|
|
|
|
BITBAND_PORT_CLR(mode_base, bit);
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR7);
|
|
|
|
BITBAND_PORT_CLR(mode_base, bit);
|
|
|
|
|
|
|
|
/* Initialize Input */
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_CR);
|
|
|
|
BITBAND_PORT_CLR(mode_base, bit);
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_IE);
|
|
|
|
BITBAND_PORT_SET(mode_base, bit);
|
|
|
|
switch (func) {
|
2019-06-04 06:18:49 +00:00
|
|
|
case 0:
|
|
|
|
break;
|
|
|
|
case 1:
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR1);
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR2);
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR3);
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR4);
|
|
|
|
break;
|
|
|
|
case 5:
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR5);
|
|
|
|
break;
|
|
|
|
case 6:
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR6);
|
|
|
|
break;
|
|
|
|
case 7:
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_FR7);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
2018-11-20 03:16:48 +00:00
|
|
|
}
|
|
|
|
if (func != 0)
|
|
|
|
BITBAND_PORT_SET(mode_base, bit);
|
|
|
|
if(dir == PIN_OUTPUT) {
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_IE);
|
|
|
|
BITBAND_PORT_CLR(mode_base, bit);
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_CR);
|
|
|
|
BITBAND_PORT_SET(mode_base, bit);
|
|
|
|
} else if(dir == PIN_INOUT) {
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_IE);
|
|
|
|
BITBAND_PORT_SET(mode_base, bit);
|
|
|
|
mode_base = BITBAND_PORT_MODE_BASE(port_base, GPIO_Mode_CR);
|
|
|
|
BITBAND_PORT_SET(mode_base, bit);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void pin_mode(PinName pin, PinMode mode)
|
|
|
|
{
|
|
|
|
int port = 0;
|
|
|
|
uint8_t bit = 0;
|
|
|
|
uint8_t val = 0;
|
|
|
|
|
|
|
|
/* Assert that pin is valid*/
|
|
|
|
MBED_ASSERT(pin != NC);
|
|
|
|
|
|
|
|
/* Check if function is in range*/
|
|
|
|
if (mode > OpenDrain) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Calculate port and pin position*/
|
|
|
|
port = PIN_PORT(pin);
|
|
|
|
bit = PIN_POS(pin);
|
|
|
|
val = (1 << bit);
|
|
|
|
|
|
|
|
switch (port) {
|
2019-06-04 06:18:49 +00:00
|
|
|
case PortA:
|
|
|
|
if(mode == OpenDrain) TSB_PA->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PA->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PA->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortB:
|
|
|
|
if(mode == OpenDrain) TSB_PB->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PB->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PB->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortC:
|
|
|
|
if(mode == OpenDrain) TSB_PC->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PC->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PC->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortD:
|
|
|
|
if(mode == OpenDrain) TSB_PD->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PD->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PD->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortE:
|
|
|
|
if(mode == OpenDrain) TSB_PE->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PE->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PE->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortF:
|
|
|
|
if(mode == OpenDrain) TSB_PF->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PF->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PF->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortG:
|
|
|
|
if(mode == OpenDrain) TSB_PG->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PG->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PG->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortH:
|
|
|
|
if(mode == PullDown) TSB_PH->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortJ:
|
|
|
|
if(mode == OpenDrain) TSB_PJ->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PJ->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PJ->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortK:
|
|
|
|
if(mode == OpenDrain) TSB_PK->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PK->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PK->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortL:
|
|
|
|
if(mode == OpenDrain) TSB_PL->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PL->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PL->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortM:
|
|
|
|
if(mode == OpenDrain) TSB_PM->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PM->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PM->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortN:
|
|
|
|
if(mode == OpenDrain) TSB_PN->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PN->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PN->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortP:
|
|
|
|
if(mode == OpenDrain) TSB_PP->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PP->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PP->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortR:
|
|
|
|
if(mode == OpenDrain) TSB_PR->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PR->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PR->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortT:
|
|
|
|
if(mode == OpenDrain) TSB_PT->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PT->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PT->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortU:
|
|
|
|
if(mode == OpenDrain) TSB_PU->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PU->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PU->PDN |= val;
|
|
|
|
break;
|
|
|
|
case PortV:
|
|
|
|
if(mode == OpenDrain) TSB_PV->OD |= val;
|
|
|
|
else if(mode == PullUp) TSB_PV->PUP |= val;
|
|
|
|
else if(mode == PullDown || mode == PullDefault) TSB_PV->PDN |= val;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
2018-11-20 03:16:48 +00:00
|
|
|
}
|
|
|
|
}
|