2020-06-15 10:23:25 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* include/netpacket/can.h
|
|
|
|
* Definitions for use with AF_PACKET sockets
|
|
|
|
*
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership. The
|
|
|
|
* ASF licenses this file to you 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 __INCLUDE_NETPACKET_CAN_H
|
|
|
|
#define __INCLUDE_NETPACKET_CAN_H
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Included Files
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
* Pre-processor Definitions
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/* Special address description flags for the CAN_ID */
|
|
|
|
|
|
|
|
#define CAN_EFF_FLAG 0x80000000 /* EFF/SFF is set in the MSB */
|
|
|
|
#define CAN_RTR_FLAG 0x40000000 /* Remote transmission request */
|
|
|
|
#define CAN_ERR_FLAG 0x20000000 /* Error message frame */
|
|
|
|
|
|
|
|
/* Valid bits in CAN ID for frame formats */
|
|
|
|
|
|
|
|
#define CAN_SFF_MASK 0x000007ff /* Standard frame format (SFF) */
|
|
|
|
#define CAN_EFF_MASK 0x1fffffff /* Extended frame format (EFF) */
|
|
|
|
#define CAN_ERR_MASK 0x1fffffff /* Omit EFF, RTR, ERR flags */
|
|
|
|
|
2023-07-11 14:36:33 +02:00
|
|
|
#define CAN_MTU (sizeof(struct can_frame))
|
|
|
|
#define CANFD_MTU (sizeof(struct canfd_frame))
|
2020-06-15 10:23:25 +02:00
|
|
|
|
|
|
|
/* PF_CAN protocols */
|
|
|
|
|
|
|
|
#define CAN_RAW 1 /* RAW sockets */
|
|
|
|
#define CAN_BCM 2 /* Broadcast Manager */
|
|
|
|
#define CAN_TP16 3 /* VAG Transport Protocol v1.6 */
|
|
|
|
#define CAN_TP20 4 /* VAG Transport Protocol v2.0 */
|
|
|
|
#define CAN_MCNET 5 /* Bosch MCNet */
|
|
|
|
#define CAN_ISOTP 6 /* ISO 15765-2 Transport Protocol */
|
|
|
|
#define CAN_J1939 7 /* SAE J1939 */
|
|
|
|
#define CAN_NPROTO 8
|
|
|
|
|
2020-06-08 08:51:38 +02:00
|
|
|
#define SOL_CAN_BASE 100
|
|
|
|
|
|
|
|
#define SOL_CAN_RAW (SOL_CAN_BASE + CAN_RAW)
|
|
|
|
|
2020-06-15 10:23:25 +02:00
|
|
|
/* CAN_RAW socket options */
|
|
|
|
|
2020-10-24 03:40:33 +02:00
|
|
|
#define CAN_RAW_FILTER (__SO_PROTOCOL + 0)
|
2020-06-15 10:23:25 +02:00
|
|
|
/* set 0 .. n can_filter(s) */
|
2020-10-24 03:40:33 +02:00
|
|
|
#define CAN_RAW_ERR_FILTER (__SO_PROTOCOL + 1)
|
2020-06-15 10:23:25 +02:00
|
|
|
/* set filter for error frames */
|
2020-10-24 03:40:33 +02:00
|
|
|
#define CAN_RAW_LOOPBACK (__SO_PROTOCOL + 2)
|
2020-06-15 10:23:25 +02:00
|
|
|
/* local loopback (default:on) */
|
2020-10-24 03:40:33 +02:00
|
|
|
#define CAN_RAW_RECV_OWN_MSGS (__SO_PROTOCOL + 3)
|
2020-06-15 10:23:25 +02:00
|
|
|
/* receive my own msgs (default:off) */
|
2020-10-24 03:40:33 +02:00
|
|
|
#define CAN_RAW_FD_FRAMES (__SO_PROTOCOL + 4)
|
2020-06-15 10:23:25 +02:00
|
|
|
/* allow CAN FD frames (default:off) */
|
2020-10-24 03:40:33 +02:00
|
|
|
#define CAN_RAW_JOIN_FILTERS (__SO_PROTOCOL + 5)
|
2020-06-15 10:23:25 +02:00
|
|
|
/* all filters must match to trigger */
|
|
|
|
#define CAN_RAW_TX_DEADLINE (__SO_PROTOCOL + 6)
|
|
|
|
/* Abort frame when deadline passed */
|
|
|
|
|
2022-04-15 23:40:00 +02:00
|
|
|
/* CAN filter support (Hardware level filtering) ****************************/
|
|
|
|
|
|
|
|
/* Some CAN hardware supports a notion of prioritizing messages that match
|
|
|
|
* filters. Only two priority levels are currently supported and are encoded
|
|
|
|
* as defined below:
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define CAN_MSGPRIO_LOW 0
|
|
|
|
#define CAN_MSGPRIO_HIGH 1
|
|
|
|
|
|
|
|
/* Filter type. Not all CAN hardware will support all filter types. */
|
|
|
|
|
|
|
|
#define CAN_FILTER_MASK 0 /* Address match under a mask */
|
|
|
|
#define CAN_FILTER_DUAL 1 /* Dual address match */
|
|
|
|
#define CAN_FILTER_RANGE 2 /* Match a range of addresses */
|
|
|
|
|
2020-06-15 10:23:25 +02:00
|
|
|
/****************************************************************************
|
|
|
|
* Public Types
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/* Controller Area Network Identifier structure
|
|
|
|
*
|
|
|
|
* Bit 0-28: CAN identifier (11/29 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;
|
|
|
|
|
|
|
|
/* The sockaddr structure for CAN sockets
|
|
|
|
*
|
|
|
|
* can_family: Address family number AF_CAN.
|
|
|
|
* can_ifindex: CAN network interface index.
|
|
|
|
* can_addr: Protocol specific address information
|
|
|
|
*/
|
|
|
|
|
|
|
|
struct sockaddr_can
|
|
|
|
{
|
|
|
|
sa_family_t can_family;
|
|
|
|
int16_t can_ifindex;
|
|
|
|
union
|
|
|
|
{
|
|
|
|
/* Transport protocol class address information */
|
|
|
|
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
canid_t rx_id;
|
|
|
|
canid_t tx_id;
|
|
|
|
} tp;
|
|
|
|
|
|
|
|
/* J1939 address information */
|
|
|
|
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
/* 8 byte name when using dynamic addressing */
|
|
|
|
|
|
|
|
uint64_t name;
|
|
|
|
|
|
|
|
/* pgn:
|
|
|
|
* 8 bit: PS in PDU2 case, else 0
|
|
|
|
* 8 bit: PF
|
|
|
|
* 1 bit: DP
|
|
|
|
* 1 bit: reserved
|
|
|
|
*/
|
|
|
|
|
|
|
|
uint32_t pgn;
|
|
|
|
|
|
|
|
/* 1 byte address */
|
|
|
|
|
|
|
|
uint8_t addr;
|
|
|
|
} j1939;
|
|
|
|
} can_addr;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* __INCLUDE_NETPACKET_CAN_H */
|