35#ifndef LIBBSP_MSCAN_BASE_H
36#define LIBBSP_MSCAN_BASE_H
40#include <bsp/mpc5200.h>
50#define MSCAN_BIT_RATE_MIN 10000
52#define MSCAN_BIT_RATE_MAX 1000000
54#define MSCAN_BIT_RATE_DEFAULT 125000
56#define MSCAN_FILTER_NUMBER_MIN 0
58#define MSCAN_FILTER_NUMBER_2 2
60#define MSCAN_FILTER_NUMBER_4 4
62#define MSCAN_FILTER_NUMBER_MAX 8
64#define MSCAN_FILTER_ID_DEFAULT 0U
66#define MSCAN_FILTER_MASK_DEFAULT 0xffffffffU
68#define MSCAN_TRANSMIT_BUFFER_NUMBER 3
76#define CTL0_RXFRM (1 << 7)
77#define CTL0_RXACT (1 << 6)
78#define CTL0_CSWAI (1 << 5)
79#define CTL0_SYNCH (1 << 4)
80#define CTL0_TIME (1 << 3)
81#define CTL0_WUPE (1 << 2)
82#define CTL0_SLPRQ (1 << 1)
83#define CTL0_INITRQ (1 << 0)
93#define CTL1_CANE (1 << 7)
94#define CTL1_CLKSRC (1 << 6)
95#define CTL1_LOOPB (1 << 5)
96#define CTL1_LISTEN (1 << 4)
97#define CTL1_WUPM (1 << 2)
98#define CTL1_SLPAK (1 << 1)
99#define CTL1_INITAK (1 << 0)
109#define BTR0_SJW_MASK 0xc0
110#define BTR0_BRP_MASK 0x3f
112#define BTR0_SJW( btr0) ((btr0) << 6)
113#define BTR0_BRP( btr0) ((btr0) << 0)
115#define BTR0_GET_SJW( btr0) (((btr0) & BTR0_SJW_MASK) >> 6)
116#define BTR0_GET_BRP( btr0) (((btr0) & BTR0_BRP_MASK) >> 0)
126#define BTR1_SAMP_MASK 0x80
127#define BTR1_TSEG1_MASK 0x0f
128#define BTR1_TSEG2_MASK 0x70
130#define BTR1_SAMP (1 << 7)
131#define BTR1_TSEG1( btr1) ((btr1) << 0)
132#define BTR1_TSEG2( btr1) ((btr1) << 4)
134#define BTR1_GET_TSEG1( btr0) (((btr0) & BTR1_TSEG1_MASK) >> 0)
135#define BTR1_GET_TSEG2( btr0) (((btr0) & BTR1_TSEG2_MASK) >> 4)
145#define RFLG_WUPIF (1 << 7)
146#define RFLG_CSCIF (1 << 6)
147#define RFLG_RSTAT_MASK (3 << 4)
148#define RFLG_RSTAT_OK (0 << 4)
149#define RFLG_RSTAT_WRN (1 << 4)
150#define RFLG_RSTAT_ERR (2 << 4)
151#define RFLG_RSTAT_OFF (3 << 4)
152#define RFLG_TSTAT_MASK (3 << 2)
153#define RFLG_TSTAT_OK (0 << 2)
154#define RFLG_TSTAT_WRN (1 << 2)
155#define RFLG_TSTAT_ERR (2 << 2)
156#define RFLG_TSTAT_OFF (3 << 2)
157#define RFLG_OVRIF (1 << 1)
158#define RFLG_RXF (1 << 0)
159#define RFLG_GET_RX_STATE(rflg) (((rflg) >> 4) & 0x03)
160#define RFLG_GET_TX_STATE(rflg) (((rflg) >> 2) & 0x03)
170#define RIER_WUPIE (1 << 7)
171#define RIER_CSCIE (1 << 6)
172#define RIER_RSTAT(rier) ((rier) << 4)
173#define RIER_TSTAT(rier) ((rier) << 2)
174#define RIER_OVRIE (1 << 1)
175#define RIER_RXFIE (1 << 0)
185#define TFLG_TXE2 (1 << 2)
186#define TFLG_TXE1 (1 << 1)
187#define TFLG_TXE0 (1 << 0)
197#define TIER_TXEI2 (1 << 2)
198#define TIER_TXEI1 (1 << 1)
199#define TIER_TXEI0 (1 << 0)
209#define TARQ_ABTRQ2 (1 << 2)
210#define TARQ_ABTRQ1 (1 << 1)
211#define TARQ_ABTRQ0 (1 << 0)
221#define TAAK_ABTRQ2 (1 << 2)
222#define TAAK_ABTRQ1 (1 << 1)
223#define TAAK_ABTRQ0 (1 << 0)
233#define BSEL_TX2 (1 << 2)
234#define BSEL_TX1 (1 << 1)
235#define BSEL_TX0 (1 << 0)
245#define IDAC_IDAM1 (1 << 5)
246#define IDAC_IDAM0 (1 << 4)
247#define IDAC_IDAM (IDAC_IDAM1 | IDAC_IDAM0)
248#define IDAC_IDHIT( idac) ((idac) & 0x7)
void mscan_get_error_counters(volatile mscan *m, unsigned *rec, unsigned *tec)
Returns the receiver and transmitter error counter values in rec and tec of MSCAN module m.
Definition: mscan-base.c:549
void mscan_sleep_mode_leave(volatile mscan *m)
Leave sleep mode for the MSCAN module m.
Definition: mscan-base.c:284
void mscan_initialization_mode_leave(volatile mscan *m, const mscan_context *context)
Leave initialization mode for the MSCAN module m.
Definition: mscan-base.c:253
volatile uint8_t * mscan_id_acceptance_register(volatile mscan *m, unsigned i)
Returns the address of the CANIDAR register with index i of the MSCAN module m.
Definition: mscan-base.c:448
void mscan_initialization_mode_enter(volatile mscan *m, mscan_context *context)
Enter initialization mode for the MSCAN module m.
Definition: mscan-base.c:232
bool mscan_enable(volatile mscan *m, unsigned bit_rate)
Enables and initializes the MSCAN module m.
Definition: mscan-base.c:300
volatile uint8_t * mscan_id_mask_register(volatile mscan *m, unsigned i)
Returns the address of the CANIDMR register with index i of the MSCAN module m.
Definition: mscan-base.c:470
bool mscan_set_bit_rate(volatile mscan *m, unsigned bit_rate)
Sets the bit rate for the MSCAN module m to can_bit_rate in [bits/s].
Definition: mscan-base.c:156
bool mscan_set_filter_number(volatile mscan *m, unsigned number)
Sets the number of active filters of the MSCAN module m to number and returns true if number is valid...
Definition: mscan-base.c:409
struct mpc5200_mscan mscan
MSCAN registers.
Definition: mscan-base.h:255
void mscan_interrupts_disable(volatile mscan *m)
Disables all interrupts for the MSCAN module m.
Definition: mscan-base.c:221
void mscan_sleep_mode_enter(volatile mscan *m)
Enter sleep mode for the MSCAN module m.
Definition: mscan-base.c:275
void mscan_disable(volatile mscan *m)
Disables the MSCAN module m.
Definition: mscan-base.c:333
unsigned mscan_filter_number(volatile mscan *m)
Returns the number of active filters of the MSCAN module m.
Definition: mscan-base.c:386
void mscan_filter_clear(volatile mscan *m)
Sets the filter ID and mask registers of the MSCAN module m to default values.
Definition: mscan-base.c:351
bool mscan_filter_operation(volatile mscan *m, bool set, unsigned index, uint32_t *id, uint32_t *mask)
Sets or gets the filter ID and mask in id and mask depending on set of MSCAN module m....
Definition: mscan-base.c:493
rtems_termios_device_context * context
Definition: console-config.c:62
MSCAN context that has to be saved throughout the initialization mode.
Definition: mscan-base.h:261