The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

mbed 2

This is the mbed 2 library. If you'd like to learn about Mbed OS please see the mbed-os docs.

Committer:
AnnaBridge
Date:
Wed Feb 20 20:53:29 2019 +0000
Revision:
172:65be27845400
Parent:
171:3a7713b1edbc
mbed library release version 165

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 171:3a7713b1edbc 1 /* mbed Microcontroller Library
AnnaBridge 171:3a7713b1edbc 2 * Copyright (c) 2006-2013 ARM Limited
AnnaBridge 171:3a7713b1edbc 3 *
AnnaBridge 171:3a7713b1edbc 4 * Licensed under the Apache License, Version 2.0 (the "License");
AnnaBridge 171:3a7713b1edbc 5 * you may not use this file except in compliance with the License.
AnnaBridge 171:3a7713b1edbc 6 * You may obtain a copy of the License at
AnnaBridge 171:3a7713b1edbc 7 *
AnnaBridge 171:3a7713b1edbc 8 * http://www.apache.org/licenses/LICENSE-2.0
AnnaBridge 171:3a7713b1edbc 9 *
AnnaBridge 171:3a7713b1edbc 10 * Unless required by applicable law or agreed to in writing, software
AnnaBridge 171:3a7713b1edbc 11 * distributed under the License is distributed on an "AS IS" BASIS,
AnnaBridge 171:3a7713b1edbc 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
AnnaBridge 171:3a7713b1edbc 13 * See the License for the specific language governing permissions and
AnnaBridge 171:3a7713b1edbc 14 * limitations under the License.
AnnaBridge 171:3a7713b1edbc 15 */
AnnaBridge 171:3a7713b1edbc 16 #ifndef MBED_PERIPHERALNAMES_H
AnnaBridge 171:3a7713b1edbc 17 #define MBED_PERIPHERALNAMES_H
AnnaBridge 171:3a7713b1edbc 18
AnnaBridge 171:3a7713b1edbc 19 #include "cmsis.h"
AnnaBridge 171:3a7713b1edbc 20
AnnaBridge 171:3a7713b1edbc 21 #ifdef __cplusplus
AnnaBridge 171:3a7713b1edbc 22 extern "C" {
AnnaBridge 171:3a7713b1edbc 23 #endif
AnnaBridge 171:3a7713b1edbc 24
AnnaBridge 171:3a7713b1edbc 25 typedef enum {
AnnaBridge 171:3a7713b1edbc 26 OSC32KCLK = 0,
AnnaBridge 171:3a7713b1edbc 27 } RTCName;
AnnaBridge 171:3a7713b1edbc 28
AnnaBridge 171:3a7713b1edbc 29 typedef enum {
AnnaBridge 171:3a7713b1edbc 30 LPUART_0 = 0,
AnnaBridge 171:3a7713b1edbc 31 LPUART_1 = 1,
AnnaBridge 171:3a7713b1edbc 32 LPUART_2 = 2,
AnnaBridge 171:3a7713b1edbc 33 LPUART_3 = 3,
AnnaBridge 171:3a7713b1edbc 34 LPUART_4 = 4,
AnnaBridge 171:3a7713b1edbc 35 } UARTName;
AnnaBridge 171:3a7713b1edbc 36
AnnaBridge 171:3a7713b1edbc 37 #define STDIO_UART_TX USBTX
AnnaBridge 171:3a7713b1edbc 38 #define STDIO_UART_RX USBRX
AnnaBridge 171:3a7713b1edbc 39 #define STDIO_UART LPUART_4
AnnaBridge 171:3a7713b1edbc 40
AnnaBridge 171:3a7713b1edbc 41 /* LPTMR interrupt is defined differently in K82F */
AnnaBridge 171:3a7713b1edbc 42 #define LPTMR0_IRQn LPTMR0_LPTMR1_IRQn
AnnaBridge 171:3a7713b1edbc 43
AnnaBridge 171:3a7713b1edbc 44 typedef enum {
AnnaBridge 171:3a7713b1edbc 45 I2C_0 = 0,
AnnaBridge 171:3a7713b1edbc 46 I2C_1 = 1,
AnnaBridge 171:3a7713b1edbc 47 I2C_2 = 2,
AnnaBridge 171:3a7713b1edbc 48 I2C_3 = 3,
AnnaBridge 171:3a7713b1edbc 49 } I2CName;
AnnaBridge 171:3a7713b1edbc 50
AnnaBridge 171:3a7713b1edbc 51 #define TPM_SHIFT 8
AnnaBridge 171:3a7713b1edbc 52 typedef enum {
AnnaBridge 171:3a7713b1edbc 53 PWM_1 = (0 << TPM_SHIFT) | (0), // FTM0 CH0
AnnaBridge 171:3a7713b1edbc 54 PWM_2 = (0 << TPM_SHIFT) | (1), // FTM0 CH1
AnnaBridge 171:3a7713b1edbc 55 PWM_3 = (0 << TPM_SHIFT) | (2), // FTM0 CH2
AnnaBridge 171:3a7713b1edbc 56 PWM_4 = (0 << TPM_SHIFT) | (3), // FTM0 CH3
AnnaBridge 171:3a7713b1edbc 57 PWM_5 = (0 << TPM_SHIFT) | (4), // FTM0 CH4
AnnaBridge 171:3a7713b1edbc 58 PWM_6 = (0 << TPM_SHIFT) | (5), // FTM0 CH5
AnnaBridge 171:3a7713b1edbc 59 PWM_7 = (0 << TPM_SHIFT) | (6), // FTM0 CH6
AnnaBridge 171:3a7713b1edbc 60 PWM_8 = (0 << TPM_SHIFT) | (7), // FTM0 CH7
AnnaBridge 171:3a7713b1edbc 61 PWM_9 = (1 << TPM_SHIFT) | (0), // FTM1 CH0
AnnaBridge 171:3a7713b1edbc 62 PWM_10 = (1 << TPM_SHIFT) | (1), // FTM1 CH1
AnnaBridge 171:3a7713b1edbc 63 PWM_11 = (2 << TPM_SHIFT) | (0), // FTM2 CH0
AnnaBridge 171:3a7713b1edbc 64 PWM_12 = (2 << TPM_SHIFT) | (1), // FTM2 CH1
AnnaBridge 171:3a7713b1edbc 65 PWM_13 = (3 << TPM_SHIFT) | (0), // FTM3 CH0
AnnaBridge 171:3a7713b1edbc 66 PWM_14 = (3 << TPM_SHIFT) | (1), // FTM3 CH1
AnnaBridge 171:3a7713b1edbc 67 PWM_15 = (3 << TPM_SHIFT) | (2), // FTM3 CH2
AnnaBridge 171:3a7713b1edbc 68 PWM_16 = (3 << TPM_SHIFT) | (3), // FTM3 CH3
AnnaBridge 171:3a7713b1edbc 69 PWM_17 = (3 << TPM_SHIFT) | (4), // FTM3 CH4
AnnaBridge 171:3a7713b1edbc 70 PWM_18 = (3 << TPM_SHIFT) | (5), // FTM3 CH5
AnnaBridge 171:3a7713b1edbc 71 PWM_19 = (3 << TPM_SHIFT) | (6), // FTM3 CH6
AnnaBridge 171:3a7713b1edbc 72 PWM_20 = (3 << TPM_SHIFT) | (7), // FTM3 CH7
AnnaBridge 171:3a7713b1edbc 73 } PWMName;
AnnaBridge 171:3a7713b1edbc 74
AnnaBridge 171:3a7713b1edbc 75 #define ADC_INSTANCE_SHIFT 8
AnnaBridge 171:3a7713b1edbc 76 #define ADC_B_CHANNEL_SHIFT 5
AnnaBridge 171:3a7713b1edbc 77 typedef enum {
AnnaBridge 171:3a7713b1edbc 78 ADC0_SE4a = (0 << ADC_INSTANCE_SHIFT) | 4,
AnnaBridge 171:3a7713b1edbc 79 ADC0_SE4b = (0 << ADC_INSTANCE_SHIFT) | (1 << ADC_B_CHANNEL_SHIFT) | 4,
AnnaBridge 171:3a7713b1edbc 80 ADC0_SE5a = (0 << ADC_INSTANCE_SHIFT) | 5,
AnnaBridge 171:3a7713b1edbc 81 ADC0_SE5b = (0 << ADC_INSTANCE_SHIFT) | (1 << ADC_B_CHANNEL_SHIFT) | 5,
AnnaBridge 171:3a7713b1edbc 82 ADC0_SE6a = (0 << ADC_INSTANCE_SHIFT) | 6,
AnnaBridge 171:3a7713b1edbc 83 ADC0_SE6b = (0 << ADC_INSTANCE_SHIFT) | (1 << ADC_B_CHANNEL_SHIFT) | 6,
AnnaBridge 171:3a7713b1edbc 84 ADC0_SE7a = (0 << ADC_INSTANCE_SHIFT) | 7,
AnnaBridge 171:3a7713b1edbc 85 ADC0_SE7b = (0 << ADC_INSTANCE_SHIFT) | (1 << ADC_B_CHANNEL_SHIFT) | 7,
AnnaBridge 171:3a7713b1edbc 86 ADC0_SE8 = (0 << ADC_INSTANCE_SHIFT) | 8,
AnnaBridge 171:3a7713b1edbc 87 ADC0_SE9 = (0 << ADC_INSTANCE_SHIFT) | 9,
AnnaBridge 171:3a7713b1edbc 88 ADC0_SE10 = (0 << ADC_INSTANCE_SHIFT) | 10,
AnnaBridge 171:3a7713b1edbc 89 ADC0_SE11 = (0 << ADC_INSTANCE_SHIFT) | 11,
AnnaBridge 171:3a7713b1edbc 90 ADC0_SE12 = (0 << ADC_INSTANCE_SHIFT) | 12,
AnnaBridge 171:3a7713b1edbc 91 ADC0_SE13 = (0 << ADC_INSTANCE_SHIFT) | 13,
AnnaBridge 171:3a7713b1edbc 92 ADC0_SE14 = (0 << ADC_INSTANCE_SHIFT) | 14,
AnnaBridge 171:3a7713b1edbc 93 ADC0_SE15 = (0 << ADC_INSTANCE_SHIFT) | 15,
AnnaBridge 171:3a7713b1edbc 94 ADC0_SE22 = (0 << ADC_INSTANCE_SHIFT) | 22,
AnnaBridge 171:3a7713b1edbc 95 ADC0_SE23 = (0 << ADC_INSTANCE_SHIFT) | 23,
AnnaBridge 171:3a7713b1edbc 96 } ADCName;
AnnaBridge 171:3a7713b1edbc 97
AnnaBridge 171:3a7713b1edbc 98 typedef enum {
AnnaBridge 171:3a7713b1edbc 99 DAC_0 = 0
AnnaBridge 171:3a7713b1edbc 100 } DACName;
AnnaBridge 171:3a7713b1edbc 101
AnnaBridge 171:3a7713b1edbc 102
AnnaBridge 171:3a7713b1edbc 103 typedef enum {
AnnaBridge 171:3a7713b1edbc 104 SPI_0 = 0,
AnnaBridge 171:3a7713b1edbc 105 SPI_1 = 1,
AnnaBridge 171:3a7713b1edbc 106 SPI_2 = 2,
AnnaBridge 171:3a7713b1edbc 107 } SPIName;
AnnaBridge 171:3a7713b1edbc 108
AnnaBridge 171:3a7713b1edbc 109 typedef enum {
AnnaBridge 171:3a7713b1edbc 110 QSPI_0 = 0
AnnaBridge 171:3a7713b1edbc 111 } QSPIName;
AnnaBridge 171:3a7713b1edbc 112
AnnaBridge 171:3a7713b1edbc 113 #ifdef __cplusplus
AnnaBridge 171:3a7713b1edbc 114 }
AnnaBridge 171:3a7713b1edbc 115 #endif
AnnaBridge 171:3a7713b1edbc 116
AnnaBridge 171:3a7713b1edbc 117 #endif