mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 11:12:44 +01:00
a38cd1477e
cpu/stm32: Add CAN support for f722ze board f722ze board has ONLY 1 CAN interface, fix compiling error which treats f722xx has more than 1 CAN.
152 lines
3.5 KiB
C
152 lines
3.5 KiB
C
/*
|
|
* Copyright (C) 2016 OTA keys S.A.
|
|
*
|
|
* 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 candev_stm32
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief STM32 CAN controller driver (bxCAN) default parameters
|
|
*
|
|
* @author Vincent Dupont <vincent@otakeys.com>
|
|
* @}
|
|
*/
|
|
|
|
#ifndef CAN_PARAMS_H
|
|
#define CAN_PARAMS_H
|
|
|
|
#include "can/device.h"
|
|
#include "periph/can.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/** Default STM32 CAN devices config */
|
|
static const can_conf_t candev_conf[] = {
|
|
{
|
|
#if defined(CPU_FAM_STM32F0)
|
|
.can = CAN,
|
|
.rcc_mask = RCC_APB1ENR_CANEN,
|
|
.rx_pin = GPIO_PIN(PORT_A, 11),
|
|
.tx_pin = GPIO_PIN(PORT_A, 12),
|
|
.af = GPIO_AF4,
|
|
.irqn = CEC_CAN_IRQn,
|
|
#else
|
|
.can = CAN1,
|
|
#if defined(CPU_FAM_STM32L4)
|
|
.rcc_mask = RCC_APB1ENR1_CAN1EN,
|
|
#else
|
|
.rcc_mask = RCC_APB1ENR_CAN1EN,
|
|
#if CANDEV_STM32_CHAN_NUMOF > 1
|
|
.can_master = CAN1,
|
|
.master_rcc_mask = RCC_APB1ENR_CAN1EN,
|
|
.first_filter = 0,
|
|
.nb_filters = 14,
|
|
#endif
|
|
#endif
|
|
#if defined(CPU_FAM_STM32F1)
|
|
.rx_pin = GPIO_PIN(PORT_A, 11),
|
|
.tx_pin = GPIO_PIN(PORT_A, 12),
|
|
#elif defined(CPU_FAM_STM32L4) || defined(CPU_FAM_STM32F4)
|
|
.rx_pin = GPIO_PIN(PORT_B, 8),
|
|
.tx_pin = GPIO_PIN(PORT_B, 9),
|
|
.af = GPIO_AF9,
|
|
#else
|
|
.rx_pin = GPIO_PIN(PORT_D, 0),
|
|
.tx_pin = GPIO_PIN(PORT_D, 1),
|
|
.af = GPIO_AF9,
|
|
#endif
|
|
.tx_irqn = CAN1_TX_IRQn,
|
|
.rx0_irqn = CAN1_RX0_IRQn,
|
|
.rx1_irqn = CAN1_RX1_IRQn,
|
|
.sce_irqn = CAN1_SCE_IRQn,
|
|
#endif
|
|
.en_deep_sleep_wake_up = true,
|
|
.ttcm = 0,
|
|
.abom = 1,
|
|
.awum = 1,
|
|
.nart = 0,
|
|
.rflm = 0,
|
|
.txfp = 0,
|
|
},
|
|
#if (CANDEV_STM32_CHAN_NUMOF >= 2) && (CAN_DLL_NUMOF >= 2)
|
|
{
|
|
.can = CAN2,
|
|
.rcc_mask = RCC_APB1ENR_CAN2EN,
|
|
.can_master = CAN1,
|
|
.master_rcc_mask = RCC_APB1ENR_CAN1EN,
|
|
.first_filter = 14,
|
|
.nb_filters = 14,
|
|
.rx_pin = GPIO_PIN(PORT_B, 5),
|
|
.tx_pin = GPIO_PIN(PORT_B, 6),
|
|
#ifndef CPU_FAM_STM32F1
|
|
.af = GPIO_AF9,
|
|
#endif
|
|
.en_deep_sleep_wake_up = true,
|
|
.tx_irqn = CAN2_TX_IRQn,
|
|
.rx0_irqn = CAN2_RX0_IRQn,
|
|
.rx1_irqn = CAN2_RX1_IRQn,
|
|
.sce_irqn = CAN2_SCE_IRQn,
|
|
.ttcm = 0,
|
|
.abom = 1,
|
|
.awum = 1,
|
|
.nart = 0,
|
|
.rflm = 0,
|
|
.txfp = 0,
|
|
},
|
|
#endif
|
|
#if (CANDEV_STM32_CHAN_NUMOF >= 3) && (CAN_DLL_NUMOF >= 3)
|
|
{
|
|
.can = CAN3,
|
|
.rcc_mask = RCC_APB1ENR_CAN3EN,
|
|
.can_master = CAN3,
|
|
.master_rcc_mask = RCC_APB1ENR_CAN3EN,
|
|
.first_filter = 0,
|
|
.nb_filters = 14,
|
|
.rx_pin = GPIO_PIN(PORT_B, 3),
|
|
.tx_pin = GPIO_PIN(PORT_B, 4),
|
|
.af = GPIO_AF11,
|
|
.en_deep_sleep_wake_up = true,
|
|
.tx_irqn = CAN3_TX_IRQn,
|
|
.rx0_irqn = CAN3_RX0_IRQn,
|
|
.rx1_irqn = CAN3_RX1_IRQn,
|
|
.sce_irqn = CAN3_SCE_IRQn,
|
|
.ttcm = 0,
|
|
.abom = 1,
|
|
.awum = 1,
|
|
.nart = 0,
|
|
.rflm = 0,
|
|
.txfp = 0,
|
|
},
|
|
#endif
|
|
};
|
|
|
|
/** Default STM32 CAN devices parameters */
|
|
static const candev_params_t candev_params[] = {
|
|
{
|
|
.name = "can_stm32_0",
|
|
},
|
|
#if (CANDEV_STM32_CHAN_NUMOF >= 2) && (CAN_DLL_NUMOF >= 2)
|
|
{
|
|
.name = "can_stm32_1",
|
|
},
|
|
#endif
|
|
#if (CANDEV_STM32_CHAN_NUMOF >= 3) && (CAN_DLL_NUMOF >= 3)
|
|
{
|
|
.name = "can_stm32_2",
|
|
},
|
|
#endif
|
|
};
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* CAN_PARAMS_H */
|