| Oliver Hartkopp | ffd980f | 2007-11-16 15:53:52 -0800 | [diff] [blame] | 1 | /* | 
 | 2 |  * linux/can/bcm.h | 
 | 3 |  * | 
 | 4 |  * Definitions for CAN Broadcast Manager (BCM) | 
 | 5 |  * | 
 | 6 |  * Author: Oliver Hartkopp <oliver.hartkopp@volkswagen.de> | 
 | 7 |  * Copyright (c) 2002-2007 Volkswagen Group Electronic Research | 
 | 8 |  * All rights reserved. | 
 | 9 |  * | 
 | 10 |  * Send feedback to <socketcan-users@lists.berlios.de> | 
 | 11 |  * | 
 | 12 |  */ | 
 | 13 |  | 
 | 14 | #ifndef CAN_BCM_H | 
 | 15 | #define CAN_BCM_H | 
 | 16 |  | 
| Jaswinder Singh Rajput | 9d6aa4c | 2009-01-30 19:50:25 +0530 | [diff] [blame] | 17 | #include <linux/types.h> | 
 | 18 |  | 
| Oliver Hartkopp | ffd980f | 2007-11-16 15:53:52 -0800 | [diff] [blame] | 19 | /** | 
 | 20 |  * struct bcm_msg_head - head of messages to/from the broadcast manager | 
 | 21 |  * @opcode:    opcode, see enum below. | 
 | 22 |  * @flags:     special flags, see below. | 
 | 23 |  * @count:     number of frames to send before changing interval. | 
 | 24 |  * @ival1:     interval for the first @count frames. | 
 | 25 |  * @ival2:     interval for the following frames. | 
 | 26 |  * @can_id:    CAN ID of frames to be sent or received. | 
 | 27 |  * @nframes:   number of frames appended to the message head. | 
 | 28 |  * @frames:    array of CAN frames. | 
 | 29 |  */ | 
 | 30 | struct bcm_msg_head { | 
| Oliver Hartkopp | 4195e31 | 2007-12-27 16:50:06 -0800 | [diff] [blame] | 31 | 	__u32 opcode; | 
 | 32 | 	__u32 flags; | 
 | 33 | 	__u32 count; | 
| Oliver Hartkopp | ffd980f | 2007-11-16 15:53:52 -0800 | [diff] [blame] | 34 | 	struct timeval ival1, ival2; | 
 | 35 | 	canid_t can_id; | 
| Oliver Hartkopp | 4195e31 | 2007-12-27 16:50:06 -0800 | [diff] [blame] | 36 | 	__u32 nframes; | 
| Oliver Hartkopp | ffd980f | 2007-11-16 15:53:52 -0800 | [diff] [blame] | 37 | 	struct can_frame frames[0]; | 
 | 38 | }; | 
 | 39 |  | 
 | 40 | enum { | 
 | 41 | 	TX_SETUP = 1,	/* create (cyclic) transmission task */ | 
 | 42 | 	TX_DELETE,	/* remove (cyclic) transmission task */ | 
 | 43 | 	TX_READ,	/* read properties of (cyclic) transmission task */ | 
 | 44 | 	TX_SEND,	/* send one CAN frame */ | 
 | 45 | 	RX_SETUP,	/* create RX content filter subscription */ | 
 | 46 | 	RX_DELETE,	/* remove RX content filter subscription */ | 
 | 47 | 	RX_READ,	/* read properties of RX content filter subscription */ | 
 | 48 | 	TX_STATUS,	/* reply to TX_READ request */ | 
 | 49 | 	TX_EXPIRED,	/* notification on performed transmissions (count=0) */ | 
 | 50 | 	RX_STATUS,	/* reply to RX_READ request */ | 
 | 51 | 	RX_TIMEOUT,	/* cyclic message is absent */ | 
 | 52 | 	RX_CHANGED	/* updated CAN frame (detected content change) */ | 
 | 53 | }; | 
 | 54 |  | 
 | 55 | #define SETTIMER            0x0001 | 
 | 56 | #define STARTTIMER          0x0002 | 
 | 57 | #define TX_COUNTEVT         0x0004 | 
 | 58 | #define TX_ANNOUNCE         0x0008 | 
 | 59 | #define TX_CP_CAN_ID        0x0010 | 
 | 60 | #define RX_FILTER_ID        0x0020 | 
 | 61 | #define RX_CHECK_DLC        0x0040 | 
 | 62 | #define RX_NO_AUTOTIMER     0x0080 | 
 | 63 | #define RX_ANNOUNCE_RESUME  0x0100 | 
 | 64 | #define TX_RESET_MULTI_IDX  0x0200 | 
 | 65 | #define RX_RTR_FRAME        0x0400 | 
 | 66 |  | 
 | 67 | #endif /* CAN_BCM_H */ |