4 * Definitions for CAN Broadcast Manager (BCM)
6 * Author: Oliver Hartkopp <oliver.hartkopp@volkswagen.de>
7 * Copyright (c) 2002-2007 Volkswagen Group Electronic Research
10 * Send feedback to <socketcan-users@lists.berlios.de>
18 * struct bcm_msg_head - head of messages to/from the broadcast manager
19 * @opcode: opcode, see enum below.
20 * @flags: special flags, see below.
21 * @count: number of frames to send before changing interval.
22 * @ival1: interval for the first @count frames.
23 * @ival2: interval for the following frames.
24 * @can_id: CAN ID of frames to be sent or received.
25 * @nframes: number of frames appended to the message head.
26 * @frames: array of CAN frames.
32 struct timeval ival1, ival2;
35 struct can_frame frames[0];
39 TX_SETUP = 1, /* create (cyclic) transmission task */
40 TX_DELETE, /* remove (cyclic) transmission task */
41 TX_READ, /* read properties of (cyclic) transmission task */
42 TX_SEND, /* send one CAN frame */
43 RX_SETUP, /* create RX content filter subscription */
44 RX_DELETE, /* remove RX content filter subscription */
45 RX_READ, /* read properties of RX content filter subscription */
46 TX_STATUS, /* reply to TX_READ request */
47 TX_EXPIRED, /* notification on performed transmissions (count=0) */
48 RX_STATUS, /* reply to RX_READ request */
49 RX_TIMEOUT, /* cyclic message is absent */
50 RX_CHANGED /* updated CAN frame (detected content change) */
53 #define SETTIMER 0x0001
54 #define STARTTIMER 0x0002
55 #define TX_COUNTEVT 0x0004
56 #define TX_ANNOUNCE 0x0008
57 #define TX_CP_CAN_ID 0x0010
58 #define RX_FILTER_ID 0x0020
59 #define RX_CHECK_DLC 0x0040
60 #define RX_NO_AUTOTIMER 0x0080
61 #define RX_ANNOUNCE_RESUME 0x0100
62 #define TX_RESET_MULTI_IDX 0x0200
63 #define RX_RTR_FRAME 0x0400
65 #endif /* CAN_BCM_H */