2015-07-04 09:37:54 +02:00
|
|
|
/*
|
2015-07-16 02:56:33 +02:00
|
|
|
* Copyright (C) 2015 Rakendra Thapa <rakendrathapa@gmail.com>
|
2015-07-04 09:37:54 +02:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup boards_ek-lm4f120xl
|
|
|
|
* @{
|
|
|
|
*
|
2015-07-21 18:08:56 +02:00
|
|
|
* @file
|
2015-07-04 09:37:54 +02:00
|
|
|
* @name Peripheral MCU configuration for the ek-lm4f120xl board
|
|
|
|
*
|
|
|
|
* @author Rakendra Thapa <rakendrathapa@gmail.com>
|
|
|
|
*/
|
|
|
|
|
2015-07-16 02:56:33 +02:00
|
|
|
#ifndef PERIPH_CONF_H
|
|
|
|
#define PERIPH_CONF_H
|
2015-07-04 09:37:54 +02:00
|
|
|
|
2016-05-03 13:53:20 +02:00
|
|
|
#include "periph_cpu.h"
|
2020-09-08 14:33:28 +02:00
|
|
|
#include "macros/units.h"
|
2016-05-03 13:53:20 +02:00
|
|
|
|
2015-07-04 09:37:54 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-07-18 03:16:46 +02:00
|
|
|
/**
|
|
|
|
* @name Define the nominal CPU core clock in this board
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define CLK80 1
|
|
|
|
#define CLK50 2
|
|
|
|
#define CLK40 3
|
|
|
|
#define CLK16 4
|
|
|
|
#define CLK1 5
|
2015-07-21 18:08:56 +02:00
|
|
|
#define CLOCK_SOURCE CLK40
|
2020-09-08 14:33:28 +02:00
|
|
|
#define CLOCK_CORECLOCK MHZ(80)
|
2015-07-18 03:16:46 +02:00
|
|
|
/** @} */
|
|
|
|
|
2015-07-04 09:37:54 +02:00
|
|
|
/**
|
2020-09-09 14:35:29 +02:00
|
|
|
* @name Timer configuration
|
2015-07-04 09:37:54 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2020-09-09 14:35:29 +02:00
|
|
|
static const timer_conf_t timer_config[] = {
|
|
|
|
{
|
|
|
|
.dev = WTIMER0_BASE,
|
|
|
|
.max = 0xffffffff,
|
|
|
|
.irqn = Timer0A_IRQn,
|
|
|
|
.sysctl = SYSCTL_PERIPH_WTIMER0,
|
|
|
|
.intbase = INT_WTIMER0A,
|
|
|
|
.channels = 1
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.dev = WTIMER1_BASE,
|
|
|
|
.max = 0xffffffff,
|
|
|
|
.irqn = Timer1A_IRQn,
|
|
|
|
.sysctl = SYSCTL_PERIPH_WTIMER1,
|
|
|
|
.intbase = INT_WTIMER1A,
|
|
|
|
.channels = 1
|
|
|
|
},
|
|
|
|
};
|
2015-07-04 09:37:54 +02:00
|
|
|
|
2020-09-09 14:35:29 +02:00
|
|
|
#define TIMER_NUMOF ARRAY_SIZE(timer_config)
|
2015-10-05 21:12:10 +02:00
|
|
|
|
2020-09-09 14:35:29 +02:00
|
|
|
#define TIMER_0_ISR isr_wtimer0a
|
2015-07-18 09:28:16 +02:00
|
|
|
#define TIMER_1_ISR isr_wtimer1a
|
2022-08-11 16:24:37 +02:00
|
|
|
/** @} */
|
2015-07-04 09:37:54 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @name UART configuration
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define UART_NUMOF (1U)
|
|
|
|
#define UART_IRQ_PRIO 1
|
2020-08-31 13:34:15 +02:00
|
|
|
/* UART clock runs with 40MHz */
|
|
|
|
#define UART_CLK ROM_SysCtlClockGet()
|
2015-07-04 09:37:54 +02:00
|
|
|
/* UART 0 device configuration */
|
|
|
|
#define UART_0_DEV UART0_BASE
|
2015-07-16 02:56:33 +02:00
|
|
|
#define UART_0_CLK (40000000)
|
2015-07-04 09:37:54 +02:00
|
|
|
#define UART_0_IRQ_CHAN UART0_IRQn
|
2015-07-18 09:28:16 +02:00
|
|
|
#define UART_0_ISR isr_uart0
|
2015-07-04 09:37:54 +02:00
|
|
|
/* UART 0 pin configuration */
|
|
|
|
#define UART_0_PORT GPIOA
|
|
|
|
#define UART_0_TX_PIN UART_PA1_U0TX
|
|
|
|
#define UART_0_RX_PIN UART_PA0_U0RX
|
|
|
|
/** @} */
|
|
|
|
|
2015-12-03 13:10:12 +01:00
|
|
|
/**
|
2017-01-26 18:14:32 +01:00
|
|
|
* @name ADC configuration
|
2015-12-03 13:10:12 +01:00
|
|
|
* @{
|
|
|
|
*/
|
2016-03-14 11:30:53 +01:00
|
|
|
#define ADC_NUMOF (12)
|
|
|
|
/** @} */
|
2015-12-03 13:10:12 +01:00
|
|
|
|
2016-05-03 13:53:20 +02:00
|
|
|
/**
|
|
|
|
* @name SPI configuration
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
static const spi_conf_t spi_confs[] = {
|
|
|
|
{
|
|
|
|
.ssi_sysctl = SYSCTL_PERIPH_SSI0,
|
|
|
|
.ssi_base = SSI0_BASE,
|
|
|
|
.gpio_sysctl = SYSCTL_PERIPH_GPIOA,
|
|
|
|
.gpio_port = GPIO_PORTA_BASE,
|
|
|
|
.pins = {
|
|
|
|
.clk = GPIO_PA2_SSI0CLK,
|
|
|
|
.fss = GPIO_PA3_SSI0FSS,
|
|
|
|
.rx = GPIO_PA4_SSI0RX,
|
|
|
|
.tx = GPIO_PA5_SSI0TX,
|
|
|
|
.mask = GPIO_PIN_2 | GPIO_PIN_3 | GPIO_PIN_4 | GPIO_PIN_5
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.ssi_sysctl = SYSCTL_PERIPH_SSI1,
|
|
|
|
.ssi_base = SSI1_BASE,
|
|
|
|
.gpio_sysctl = SYSCTL_PERIPH_GPIOF,
|
|
|
|
.gpio_port = GPIO_PORTF_BASE,
|
|
|
|
.pins = {
|
|
|
|
.clk = GPIO_PF2_SSI1CLK,
|
|
|
|
.fss = GPIO_PF3_SSI1FSS,
|
|
|
|
.rx = GPIO_PF0_SSI1RX,
|
|
|
|
.tx = GPIO_PF1_SSI1TX,
|
|
|
|
.mask = GPIO_PIN_0 | GPIO_PIN_1 | GPIO_PIN_2 | GPIO_PIN_3
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.ssi_sysctl = SYSCTL_PERIPH_SSI2,
|
|
|
|
.ssi_base = SSI2_BASE,
|
|
|
|
.gpio_sysctl = SYSCTL_PERIPH_GPIOB,
|
|
|
|
.gpio_port = GPIO_PORTB_BASE,
|
|
|
|
.pins = {
|
|
|
|
.clk = GPIO_PB4_SSI2CLK,
|
|
|
|
.fss = GPIO_PB5_SSI2FSS,
|
|
|
|
.rx = GPIO_PB6_SSI2RX,
|
|
|
|
.tx = GPIO_PB7_SSI2TX,
|
|
|
|
.mask = GPIO_PIN_4 | GPIO_PIN_5 | GPIO_PIN_6 | GPIO_PIN_7
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
.ssi_sysctl = SYSCTL_PERIPH_SSI3,
|
|
|
|
.ssi_base = SSI3_BASE,
|
|
|
|
.gpio_sysctl = SYSCTL_PERIPH_GPIOD,
|
|
|
|
.gpio_port = GPIO_PORTD_BASE,
|
|
|
|
.pins = {
|
|
|
|
.clk = GPIO_PD0_SSI3CLK,
|
|
|
|
.fss = GPIO_PD1_SSI3FSS,
|
|
|
|
.rx = GPIO_PD2_SSI3RX,
|
|
|
|
.tx = GPIO_PD3_SSI3TX,
|
|
|
|
.mask = GPIO_PIN_0 | GPIO_PIN_1 | GPIO_PIN_2 | GPIO_PIN_3
|
|
|
|
}
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2019-07-18 15:14:29 +02:00
|
|
|
#define SPI_NUMOF ARRAY_SIZE(spi_confs)
|
2016-05-03 13:53:20 +02:00
|
|
|
/** @} */
|
|
|
|
|
2015-07-04 09:37:54 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2015-07-16 02:56:33 +02:00
|
|
|
#endif /* PERIPH_CONF_H */
|
2015-07-04 09:37:54 +02:00
|
|
|
/** @} */
|