1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/sys/include/can/can.h
Vincent Dupont 5469ba1d49 can: add CAN stack
The CAN stack support only raw CAN at this time.
It contains a device interface (drivers/include/can/candev.h) and the data link
layer, build around can/device.c can/pkt.c and can/router.c. can/dll.c contains
the upper level and lower level interface to send and receive CAN frames.
Upper layer interface is located in include/can/raw.h
2017-06-19 15:35:26 +02:00

150 lines
4.4 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 can
* @defgroup can_dll Data Link Layer
* @brief CAN Data Link Layer
*
* The Data Link Layer is composed of the device, router, pkt and dll files.
* It can be used to send and receive raw CAN frames through multiple CAN controllers.
*
* @{
*
*
* @file
* @brief Definitions high-level CAN interface
*
* @author Vincent Dupont <vincent@otakeys.com>
* @author Toon Stegen <toon.stegen@altran.com>
*/
#ifndef CAN_CAN_H
#define CAN_CAN_H
#ifdef __cplusplus
extern "C" {
#endif
#include <stdint.h>
#if defined(__linux__)
#include <linux/can.h>
#include <libsocketcan.h>
#else
/**
* @brief Max data length for a CAN frame
*/
#define CAN_MAX_DLEN (8)
/**
* @name CAN_ID flags and masks
* @{
*/
/* special address description flags for the CAN_ID */
#define CAN_EFF_FLAG (0x80000000U) /**< EFF/SFF is set in the MSB */
#define CAN_RTR_FLAG (0x40000000U) /**< remote transmission request */
#define CAN_ERR_FLAG (0x20000000U) /**< error message frame */
/* valid bits in CAN ID for frame formats */
#define CAN_SFF_MASK (0x000007FFU) /**< standard frame format (SFF) */
#define CAN_EFF_MASK (0x1FFFFFFFU) /**< extended frame format (EFF) */
#define CAN_ERR_MASK (0x1FFFFFFFU) /**< omit EFF, RTR, ERR flags */
/** @} */
/**
* @brief CAN operational and error states
*/
enum can_state {
CAN_STATE_ERROR_ACTIVE = 0, /**< RX/TX error count < 96 */
CAN_STATE_ERROR_WARNING, /**< RX/TX error count < 128 */
CAN_STATE_ERROR_PASSIVE, /**< RX/TX error count < 256 */
CAN_STATE_BUS_OFF, /**< RX/TX error count >= 256 */
CAN_STATE_STOPPED, /**< Device is stopped */
CAN_STATE_SLEEPING, /**< Device is sleeping */
CAN_STATE_MAX
};
/**
* @brief Controller Area Network Identifier structure
*
* bit 0-28 : CAN identifier (11/29 bit) right aligned for 11 bit
* bit 29 : error message frame flag (0 = data frame, 1 = error message)
* bit 30 : remote transmission request flag (1 = rtr frame)
* bit 31 : frame format flag (0 = standard 11 bit, 1 = extended 29 bit)
*/
typedef uint32_t canid_t;
/**
* @brief Controller Area Network frame
*/
struct can_frame {
canid_t can_id; /**< 32 bit CAN_ID + EFF/RTR/ERR flags */
uint8_t can_dlc; /**< frame payload length in byte (0 .. CAN_MAX_DLEN) */
uint8_t __pad; /**< padding */
uint8_t __res0; /**< reserved / padding */
uint8_t __res1; /**< reserved / padding */
/** Frame data */
uint8_t data[CAN_MAX_DLEN] __attribute__((aligned(8)));
};
/**
* @brief Controller Area Network filter
*/
struct can_filter {
canid_t can_id; /**< CAN ID */
canid_t can_mask; /**< Mask */
};
/**
* @brief CAN bit-timing parameters
*
* For further information, please read chapter "8 BIT TIMING
* REQUIREMENTS" of the "Bosch CAN Specification version 2.0"
* at http://www.semiconductors.bosch.de/pdf/can2spec.pdf.
*/
struct can_bittiming {
uint32_t bitrate; /**< Bit-rate in bits/second */
uint32_t sample_point; /**< Sample point in one-tenth of a percent */
uint32_t tq; /**< Time quanta (TQ) in nanoseconds */
uint32_t prop_seg; /**< Propagation segment in TQs */
uint32_t phase_seg1; /**< Phase buffer segment 1 in TQs */
uint32_t phase_seg2; /**< Phase buffer segment 2 in TQs */
uint32_t sjw; /**< Synchronisation jump width in TQs */
uint32_t brp; /**< Bit-rate prescaler */
};
/**
* @brief CAN hardware-dependent bit-timing constant
*
* Used for calculating and checking bit-timing parameters
*/
struct can_bittiming_const {
uint32_t tseg1_min; /**< Time segment 1 = prop_seg + phase_seg1, min value */
uint32_t tseg1_max; /**< Time segment 1, max value */
uint32_t tseg2_min; /**< Time segment 2 = phase_seg2, min value */
uint32_t tseg2_max; /**< Time segment 2, max value */
uint32_t sjw_max; /**< Synchronisation jump width */
uint32_t brp_min; /**< Bit-rate prescaler, min value */
uint32_t brp_max; /**< Bit-rate prescaler, max value */
uint32_t brp_inc; /**< Bit-rate prescaler, increment */
};
#endif /* defined(__linux__) */
#ifdef __cplusplus
}
#endif
#endif /* CAN_CAN_H */
/** @} */