mirror of https://github.com/ARMmbed/mbed-os.git
Adding Laird BL654 as a new MTB target
parent
a6651b868b
commit
6f720e86a1
|
@ -0,0 +1,315 @@
|
|||
/*
|
||||
* Copyright (c) 2016 Nordic Semiconductor ASA
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice, this list
|
||||
* of conditions and the following disclaimer.
|
||||
*
|
||||
* 2. Redistributions in binary form, except as embedded into a Nordic Semiconductor ASA
|
||||
* integrated circuit in a product or a software update for such product, must reproduce
|
||||
* the above copyright notice, this list of conditions and the following disclaimer in
|
||||
* the documentation and/or other materials provided with the distribution.
|
||||
*
|
||||
* 3. Neither the name of Nordic Semiconductor ASA nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific prior
|
||||
* written permission.
|
||||
*
|
||||
* 4. This software, with or without modification, must only be used with a
|
||||
* Nordic Semiconductor ASA integrated circuit.
|
||||
*
|
||||
* 5. Any software provided in binary or object form under this license must not be reverse
|
||||
* engineered, decompiled, modified and/or disassembled.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
||||
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
||||
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef MBED_PINNAMES_H
|
||||
#define MBED_PINNAMES_H
|
||||
|
||||
#include "cmsis.h"
|
||||
#include "nrf_gpio.h"
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
typedef enum {
|
||||
PIN_INPUT,
|
||||
PIN_OUTPUT
|
||||
} PinDirection;
|
||||
|
||||
#define PORT_SHIFT 3
|
||||
|
||||
///> define macro producing for example Px_y = NRF_GPIO_PIN_MAP(x, y)
|
||||
#define PinDef(port_num, pin_num) P##port_num##_##pin_num = NRF_GPIO_PIN_MAP(port_num, pin_num)
|
||||
|
||||
|
||||
typedef enum {
|
||||
PinDef(0 , 0), // P0_0 = 0...
|
||||
PinDef(0 , 1),
|
||||
PinDef(0 , 2),
|
||||
PinDef(0 , 3),
|
||||
PinDef(0 , 4),
|
||||
PinDef(0 , 5),
|
||||
PinDef(0 , 6),
|
||||
PinDef(0 , 7),
|
||||
PinDef(0 , 8),
|
||||
PinDef(0 , 9),
|
||||
PinDef(0 , 10),
|
||||
PinDef(0 , 11),
|
||||
PinDef(0 , 12),
|
||||
PinDef(0 , 13),
|
||||
PinDef(0 , 14),
|
||||
PinDef(0 , 15),
|
||||
PinDef(0 , 16),
|
||||
PinDef(0 , 17),
|
||||
PinDef(0 , 18),
|
||||
PinDef(0 , 19),
|
||||
PinDef(0 , 20),
|
||||
PinDef(0 , 21),
|
||||
PinDef(0 , 22),
|
||||
PinDef(0 , 23),
|
||||
PinDef(0 , 24),
|
||||
PinDef(0 , 25),
|
||||
PinDef(0 , 26),
|
||||
PinDef(0 , 27),
|
||||
PinDef(0 , 28),
|
||||
PinDef(0 , 29),
|
||||
PinDef(0 , 30),
|
||||
PinDef(0 , 31),
|
||||
|
||||
PinDef(1 , 0), //P1_1 = 32...
|
||||
PinDef(1 , 1),
|
||||
PinDef(1 , 2),
|
||||
PinDef(1 , 3),
|
||||
PinDef(1 , 4),
|
||||
PinDef(1 , 5),
|
||||
PinDef(1 , 6),
|
||||
PinDef(1 , 7),
|
||||
PinDef(1 , 8),
|
||||
PinDef(1 , 9),
|
||||
PinDef(1 , 10),
|
||||
PinDef(1 , 11),
|
||||
PinDef(1 , 12),
|
||||
PinDef(1 , 13),
|
||||
PinDef(1 , 14),
|
||||
PinDef(1 , 15),
|
||||
|
||||
// Port0
|
||||
p0 = P0_0,
|
||||
p1 = P0_1,
|
||||
p2 = P0_2,
|
||||
p3 = P0_3,
|
||||
p4 = P0_4,
|
||||
p5 = P0_5,
|
||||
p6 = P0_6,
|
||||
p7 = P0_7,
|
||||
|
||||
p8 = P0_8,
|
||||
p9 = P0_9,
|
||||
p10 = P0_10,
|
||||
p11 = P0_11,
|
||||
p12 = P0_12,
|
||||
p13 = P0_13,
|
||||
p14 = P0_14,
|
||||
p15 = P0_15,
|
||||
|
||||
p16 = P0_16,
|
||||
p17 = P0_17,
|
||||
p18 = P0_18,
|
||||
p19 = P0_19,
|
||||
p20 = P0_20,
|
||||
p21 = P0_21,
|
||||
p22 = P0_22,
|
||||
p23 = P0_23,
|
||||
|
||||
p24 = P0_24,
|
||||
p25 = P0_25,
|
||||
p26 = P0_26,
|
||||
p27 = P0_27,
|
||||
p28 = P0_28,
|
||||
p29 = P0_29,
|
||||
p30 = P0_30,
|
||||
p31 = P0_31,
|
||||
|
||||
// Port1
|
||||
p32 = P1_0,
|
||||
p33 = P1_1,
|
||||
p34 = P1_2,
|
||||
p35 = P1_3,
|
||||
p36 = P1_4,
|
||||
p37 = P1_5,
|
||||
p38 = P1_6,
|
||||
p39 = P1_7,
|
||||
|
||||
p40 = P1_8,
|
||||
p41 = P1_9,
|
||||
p42 = P1_10,
|
||||
p43 = P1_11,
|
||||
p44 = P1_12,
|
||||
p45 = P1_13,
|
||||
p46 = P1_14,
|
||||
p47 = P1_15,
|
||||
|
||||
// Not connected
|
||||
NC = (int)0xFFFFFFFF,
|
||||
|
||||
SIO_0 = P0_0,
|
||||
SIO_1 = P0_1,
|
||||
SIO_2 = P0_2,
|
||||
SIO_3 = P0_3,
|
||||
SIO_4 = P0_4,
|
||||
SIO_5 = P0_5,
|
||||
SIO_6 = P0_6,
|
||||
SIO_7 = P0_7,
|
||||
SIO_8 = P0_8,
|
||||
SIO_9 = P0_9, //NFC1
|
||||
SIO_10 = P0_10, //NFC2
|
||||
SIO_11 = P0_11,
|
||||
SIO_12 = P0_12,
|
||||
SIO_13 = P0_13,
|
||||
SIO_14 = P0_14,
|
||||
SIO_15 = P0_15,
|
||||
|
||||
SIO_16 = P0_16,
|
||||
SIO_17 = P0_17,
|
||||
SIO_18 = NC,
|
||||
SIO_19 = P0_19,
|
||||
SIO_20 = P0_20,
|
||||
SIO_21 = P0_21,
|
||||
SIO_22 = P0_22,
|
||||
SIO_23 = P0_23,
|
||||
SIO_24 = P0_24,
|
||||
SIO_25 = P0_25,
|
||||
SIO_26 = P0_26,
|
||||
SIO_27 = P0_27,
|
||||
SIO_28 = P0_28,
|
||||
SIO_29 = P0_29,
|
||||
SIO_30 = P0_30,
|
||||
SIO_31 = P0_31,
|
||||
|
||||
SIO_32 = P1_0,
|
||||
SIO_33 = P1_1,
|
||||
SIO_34 = P1_2,
|
||||
SIO_35 = P1_3,
|
||||
SIO_36 = P1_4,
|
||||
SIO_37 = P1_5,
|
||||
SIO_38 = P1_6,
|
||||
SIO_39 = P1_7,
|
||||
SIO_40 = P1_8,
|
||||
SIO_41 = P1_9,
|
||||
SIO_42 = P1_10,
|
||||
SIO_43 = P1_11,
|
||||
SIO_44 = P1_12,
|
||||
SIO_45 = P1_13,
|
||||
SIO_46 = P1_14,
|
||||
SIO_47 = P1_15,
|
||||
|
||||
LED1 = SIO_38,
|
||||
LED2 = SIO_39,
|
||||
LED3 = SIO_37,
|
||||
LED_RED = LED1,
|
||||
LED_GREEN = LED3,
|
||||
LED_BLUE = LED2,
|
||||
|
||||
BUTTON1 = SIO_33,
|
||||
USER_BUTTON = BUTTON1,
|
||||
|
||||
//Nordic SDK pin names
|
||||
RX_PIN_NUMBER = SIO_8,
|
||||
TX_PIN_NUMBER = SIO_6,
|
||||
CTS_PIN_NUMBER = SIO_7,
|
||||
RTS_PIN_NUMBER = SIO_5,
|
||||
|
||||
// mBed interface Pins
|
||||
USBTX = TX_PIN_NUMBER,
|
||||
USBRX = RX_PIN_NUMBER,
|
||||
STDIO_UART_TX = TX_PIN_NUMBER,
|
||||
STDIO_UART_RX = RX_PIN_NUMBER,
|
||||
STDIO_UART_CTS = CTS_PIN_NUMBER,
|
||||
STDIO_UART_RTS = RTS_PIN_NUMBER,
|
||||
|
||||
SPI_PSELMOSI0 = SIO_45,
|
||||
SPI_PSELMISO0 = SIO_46,
|
||||
SPI_PSELSS0 = SIO_42, //CS for SD card on MTB
|
||||
SPI_PSELSCK0 = SIO_47,
|
||||
|
||||
SPI_PSELMOSI1 = SIO_30,
|
||||
SPI_PSELMISO1 = SIO_29,
|
||||
SPI_PSELSS1 = SIO_41, //CS for LCD on MTB
|
||||
SPI_PSELSCK1 = SIO_44,
|
||||
|
||||
//Default SPI
|
||||
SPI_MOSI = SPI_PSELMOSI0,
|
||||
SPI_MISO = SPI_PSELMISO0,
|
||||
SPI_SCK = SPI_PSELSCK0,
|
||||
SPI_CS = SPI_PSELSS0,
|
||||
|
||||
/*
|
||||
SPIS_PSELMOSI = P1_2,
|
||||
SPIS_PSELMISO = P1_3,
|
||||
SPIS_PSELSS = P1_1,
|
||||
SPIS_PSELSCK = P1_4,
|
||||
*/
|
||||
|
||||
I2C_SDA0 = SIO_26,
|
||||
I2C_SCL0 = SIO_27,
|
||||
|
||||
I2C_SDA1 = SIO_25,
|
||||
I2C_SCL1 = SIO_28,
|
||||
|
||||
//Default I2C
|
||||
I2C_SCL = I2C_SCL0,
|
||||
I2C_SDA = I2C_SDA0,
|
||||
|
||||
UART_TX1 = SIO_16,
|
||||
UART_RX1 = SIO_15,
|
||||
|
||||
UART_TX2 = SIO_21,
|
||||
UART_RX2 = SIO_24,
|
||||
|
||||
//Default UART
|
||||
UART_TX = UART_TX1,
|
||||
UART_RX = UART_RX1,
|
||||
|
||||
//MTB aliases
|
||||
GP0 = SIO_33,
|
||||
GP1 = SIO_34,
|
||||
AIN0 = SIO_2,
|
||||
AIN1 = SIO_3,
|
||||
AIN2 = SIO_4,
|
||||
GP2 = SIO_42,
|
||||
GP3 = SIO_43,
|
||||
GP4 = SIO_19,
|
||||
GP5 = SIO_17, //A0 for LCD on MTB
|
||||
GP6 = SIO_40, //RESET for LCD on MTB
|
||||
GP7 = SIO_41,
|
||||
GP8 = SIO_12,
|
||||
|
||||
} PinName;
|
||||
|
||||
typedef enum {
|
||||
PullNone = 0,
|
||||
PullDown = 1,
|
||||
PullUp = 3,
|
||||
PullDefault = PullUp
|
||||
} PinMode;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
|
@ -0,0 +1,24 @@
|
|||
// The 'features' section in 'target.json' is now used to create the device's hardware preprocessor switches.
|
||||
// Check the 'features' section of the target description in 'targets.json' for more details.
|
||||
/* mbed Microcontroller Library
|
||||
* Copyright (c) 2006-2013 ARM Limited
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
#ifndef MBED_DEVICE_H
|
||||
#define MBED_DEVICE_H
|
||||
|
||||
|
||||
#include "objects.h"
|
||||
|
||||
#endif
|
|
@ -188,6 +188,14 @@
|
|||
"NRF52_ERRATA_20"
|
||||
],
|
||||
"target.console-uart-flow-control": "RTSCTS"
|
||||
},
|
||||
"MTB_LAIRD_BL654": {
|
||||
"target.macros_add": [
|
||||
"CONFIG_GPIO_AS_PINRESET",
|
||||
"NRF52_ERRATA_20"
|
||||
],
|
||||
"target.lf_clock_src": "NRF_LF_SRC_RC",
|
||||
"target.console-uart-flow-control": null
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -3977,6 +3977,17 @@
|
|||
"release_versions": ["5"],
|
||||
"device_name": "nRF52840_xxAA"
|
||||
},
|
||||
"MTB_LAIRD_BL654": {
|
||||
"inherits": ["MCU_NRF52840"],
|
||||
"release_versions": ["5"],
|
||||
"device_name": "nRF52840_xxAA",
|
||||
"detect_code": ["0465"],
|
||||
"features_remove": ["CRYPTOCELL310"],
|
||||
"macros_remove": ["MBEDTLS_CONFIG_HW_SUPPORT"],
|
||||
"overrides": {
|
||||
"lf_clock_src": "NRF_LF_SRC_RC"
|
||||
}
|
||||
},
|
||||
"BLUEPILL_F103C8": {
|
||||
"inherits": ["FAMILY_STM32"],
|
||||
"core": "Cortex-M3",
|
||||
|
|
Loading…
Reference in New Issue