mbed library sources. Supersedes mbed-src.

Dependents:   Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more

Committer:
AnnaBridge
Date:
Wed Feb 20 22:31:08 2019 +0000
Revision:
189:f392fc9709a3
Parent:
188:bcfe06ba3d64
mbed library release version 165

Who changed what in which revision?

UserRevisionLine numberNew contents of line
<> 144:ef7eb2e8f9f7 1 /* mbed Microcontroller Library
<> 144:ef7eb2e8f9f7 2 * Copyright (c) 2015-2016 Nuvoton
<> 144:ef7eb2e8f9f7 3 *
<> 144:ef7eb2e8f9f7 4 * Licensed under the Apache License, Version 2.0 (the "License");
<> 144:ef7eb2e8f9f7 5 * you may not use this file except in compliance with the License.
<> 144:ef7eb2e8f9f7 6 * You may obtain a copy of the License at
<> 144:ef7eb2e8f9f7 7 *
<> 144:ef7eb2e8f9f7 8 * http://www.apache.org/licenses/LICENSE-2.0
<> 144:ef7eb2e8f9f7 9 *
<> 144:ef7eb2e8f9f7 10 * Unless required by applicable law or agreed to in writing, software
<> 144:ef7eb2e8f9f7 11 * distributed under the License is distributed on an "AS IS" BASIS,
<> 144:ef7eb2e8f9f7 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
<> 144:ef7eb2e8f9f7 13 * See the License for the specific language governing permissions and
<> 144:ef7eb2e8f9f7 14 * limitations under the License.
<> 144:ef7eb2e8f9f7 15 */
<> 144:ef7eb2e8f9f7 16
<> 144:ef7eb2e8f9f7 17 #include "gpio_api.h"
<> 144:ef7eb2e8f9f7 18 #include "mbed_assert.h"
<> 144:ef7eb2e8f9f7 19 #include "pinmap.h"
<> 144:ef7eb2e8f9f7 20 #include "mbed_error.h"
<> 144:ef7eb2e8f9f7 21 #include "PeripheralPins.h"
<> 144:ef7eb2e8f9f7 22
<> 144:ef7eb2e8f9f7 23 uint32_t gpio_set(PinName pin)
<> 144:ef7eb2e8f9f7 24 {
<> 144:ef7eb2e8f9f7 25 if (pin == (PinName) NC) {
<> 144:ef7eb2e8f9f7 26 return 0;
<> 144:ef7eb2e8f9f7 27 }
<> 144:ef7eb2e8f9f7 28
<> 144:ef7eb2e8f9f7 29 uint32_t pin_index = NU_PINNAME_TO_PIN(pin);
<> 144:ef7eb2e8f9f7 30
<> 144:ef7eb2e8f9f7 31 #if 1
<> 144:ef7eb2e8f9f7 32 pin_function(pin, 0 << NU_MFP_POS(pin_index));
<> 144:ef7eb2e8f9f7 33 #else
<> 144:ef7eb2e8f9f7 34 pinmap_pinout(pin, PinMap_GPIO);
<> 144:ef7eb2e8f9f7 35 #endif
<> 144:ef7eb2e8f9f7 36
<> 144:ef7eb2e8f9f7 37 return (uint32_t)(1 << pin_index); // Return the pin mask
<> 144:ef7eb2e8f9f7 38 }
<> 144:ef7eb2e8f9f7 39
AnnaBridge 181:57724642e740 40 int gpio_is_connected(const gpio_t *obj)
AnnaBridge 181:57724642e740 41 {
AnnaBridge 181:57724642e740 42 return (obj->pin != (PinName) NC);
AnnaBridge 181:57724642e740 43 }
AnnaBridge 181:57724642e740 44
<> 144:ef7eb2e8f9f7 45 void gpio_init(gpio_t *obj, PinName pin)
<> 144:ef7eb2e8f9f7 46 {
<> 144:ef7eb2e8f9f7 47 obj->pin = pin;
<> 144:ef7eb2e8f9f7 48
<> 144:ef7eb2e8f9f7 49 if (obj->pin == (PinName) NC) {
<> 144:ef7eb2e8f9f7 50 return;
<> 144:ef7eb2e8f9f7 51 }
<> 144:ef7eb2e8f9f7 52
<> 144:ef7eb2e8f9f7 53 obj->mask = gpio_set(pin);
AnnaBridge 188:bcfe06ba3d64 54 /* Default mode/direction */
AnnaBridge 188:bcfe06ba3d64 55 obj->mode = PullUp;
AnnaBridge 188:bcfe06ba3d64 56 obj->direction = PIN_INPUT;
<> 144:ef7eb2e8f9f7 57 }
<> 144:ef7eb2e8f9f7 58
<> 144:ef7eb2e8f9f7 59 void gpio_mode(gpio_t *obj, PinMode mode)
<> 144:ef7eb2e8f9f7 60 {
<> 144:ef7eb2e8f9f7 61 if (obj->pin == (PinName) NC) {
<> 144:ef7eb2e8f9f7 62 return;
<> 144:ef7eb2e8f9f7 63 }
AnnaBridge 188:bcfe06ba3d64 64
AnnaBridge 188:bcfe06ba3d64 65 switch (mode) {
AnnaBridge 188:bcfe06ba3d64 66 case PullNone:
AnnaBridge 188:bcfe06ba3d64 67 case PullDown:
AnnaBridge 188:bcfe06ba3d64 68 case PullUp:
AnnaBridge 188:bcfe06ba3d64 69 /* H/W doesn't support separate configuration for input pull mode/direction.
AnnaBridge 188:bcfe06ba3d64 70 * We translate to input-only/push-pull output I/O mode dependent on direction. */
AnnaBridge 188:bcfe06ba3d64 71 obj->mode = (obj->direction == PIN_INPUT) ? InputOnly : PushPullOutput;
AnnaBridge 188:bcfe06ba3d64 72 break;
AnnaBridge 188:bcfe06ba3d64 73
AnnaBridge 188:bcfe06ba3d64 74 case QuasiBidirectional:
AnnaBridge 188:bcfe06ba3d64 75 /* With quasi-bidirectional I/O mode, before digital input function is performed,
AnnaBridge 188:bcfe06ba3d64 76 * the corresponding bit in GPIOx_DOUT must be set to 1. */
AnnaBridge 188:bcfe06ba3d64 77 obj->mode = QuasiBidirectional;
AnnaBridge 188:bcfe06ba3d64 78 if (obj->direction == PIN_INPUT) {
AnnaBridge 188:bcfe06ba3d64 79 gpio_write(obj, 1);
AnnaBridge 188:bcfe06ba3d64 80 }
AnnaBridge 188:bcfe06ba3d64 81 break;
AnnaBridge 188:bcfe06ba3d64 82
AnnaBridge 188:bcfe06ba3d64 83 case InputOnly:
AnnaBridge 188:bcfe06ba3d64 84 case PushPullOutput:
AnnaBridge 188:bcfe06ba3d64 85 /* We may meet contradictory I/O mode/direction configuration. Favor I/O mode
AnnaBridge 188:bcfe06ba3d64 86 * in the gpio_mode call here. */
AnnaBridge 188:bcfe06ba3d64 87 if (mode == InputOnly) {
AnnaBridge 188:bcfe06ba3d64 88 obj->direction = PIN_INPUT;
AnnaBridge 188:bcfe06ba3d64 89 obj->mode = InputOnly;
AnnaBridge 188:bcfe06ba3d64 90 } else {
AnnaBridge 188:bcfe06ba3d64 91 obj->direction = PIN_OUTPUT;
AnnaBridge 188:bcfe06ba3d64 92 obj->mode = PushPullOutput;
AnnaBridge 188:bcfe06ba3d64 93 }
AnnaBridge 188:bcfe06ba3d64 94 break;
AnnaBridge 188:bcfe06ba3d64 95
AnnaBridge 188:bcfe06ba3d64 96 default:
AnnaBridge 188:bcfe06ba3d64 97 /* Allow for configuring other I/O modes directly */
AnnaBridge 188:bcfe06ba3d64 98 obj->mode = mode;
AnnaBridge 188:bcfe06ba3d64 99 break;
AnnaBridge 188:bcfe06ba3d64 100 }
AnnaBridge 188:bcfe06ba3d64 101
AnnaBridge 188:bcfe06ba3d64 102 pin_mode(obj->pin, obj->mode);
<> 144:ef7eb2e8f9f7 103 }
<> 144:ef7eb2e8f9f7 104
<> 144:ef7eb2e8f9f7 105 void gpio_dir(gpio_t *obj, PinDirection direction)
<> 144:ef7eb2e8f9f7 106 {
<> 144:ef7eb2e8f9f7 107 if (obj->pin == (PinName) NC) {
<> 144:ef7eb2e8f9f7 108 return;
<> 144:ef7eb2e8f9f7 109 }
AnnaBridge 188:bcfe06ba3d64 110
AnnaBridge 188:bcfe06ba3d64 111 obj->direction = direction;
AnnaBridge 188:bcfe06ba3d64 112
AnnaBridge 188:bcfe06ba3d64 113 switch (obj->mode) {
AnnaBridge 188:bcfe06ba3d64 114 case PullNone:
AnnaBridge 188:bcfe06ba3d64 115 case PullDown:
AnnaBridge 188:bcfe06ba3d64 116 case PullUp:
AnnaBridge 188:bcfe06ba3d64 117 /* H/W doesn't support separate configuration for input pull mode/direction.
AnnaBridge 188:bcfe06ba3d64 118 * We translate to input-only/push-pull output I/O mode dependent on direction. */
AnnaBridge 188:bcfe06ba3d64 119 obj->mode = (obj->direction == PIN_INPUT) ? InputOnly : PushPullOutput;
<> 144:ef7eb2e8f9f7 120 break;
<> 144:ef7eb2e8f9f7 121
AnnaBridge 188:bcfe06ba3d64 122 case QuasiBidirectional:
AnnaBridge 188:bcfe06ba3d64 123 /* With quasi-bidirectional I/O mode, before digital input function is performed,
AnnaBridge 188:bcfe06ba3d64 124 * the corresponding bit in GPIOx_DOUT must be set to 1. */
AnnaBridge 188:bcfe06ba3d64 125 if (obj->direction == PIN_INPUT) {
AnnaBridge 188:bcfe06ba3d64 126 gpio_write(obj, 1);
AnnaBridge 188:bcfe06ba3d64 127 }
AnnaBridge 188:bcfe06ba3d64 128 break;
AnnaBridge 188:bcfe06ba3d64 129
AnnaBridge 188:bcfe06ba3d64 130 case InputOnly:
AnnaBridge 188:bcfe06ba3d64 131 case PushPullOutput:
AnnaBridge 188:bcfe06ba3d64 132 /* We may meet contradictory I/O mode/direction configuration. Favor direction
AnnaBridge 188:bcfe06ba3d64 133 * in the gpio_dir call here. */
AnnaBridge 188:bcfe06ba3d64 134 obj->mode = (obj->direction == PIN_INPUT) ? InputOnly : PushPullOutput;
AnnaBridge 188:bcfe06ba3d64 135 break;
AnnaBridge 188:bcfe06ba3d64 136
<> 144:ef7eb2e8f9f7 137 default:
AnnaBridge 188:bcfe06ba3d64 138 break;
<> 144:ef7eb2e8f9f7 139 }
AnnaBridge 188:bcfe06ba3d64 140
AnnaBridge 188:bcfe06ba3d64 141 pin_mode(obj->pin, obj->mode);
<> 144:ef7eb2e8f9f7 142 }