Hi @PetrS ,
Thanks for the quick response.
Replacing while in place of if condition didn't work.
Please find the code of init, read and write functions.
Is there any code for implementing UDS over CAN in S32K148?
void Gen_FLEXCAN0_init(void)
{
#define MSG_BUF_SIZE 4 /* Msg Buffer Size. (CAN 2.0AB: 2 hdr + 2 data= 4 words) */
uint32_t i=0;
IP_PCC->PCCn[PCC_FlexCAN0_INDEX] |= PCC_PCCn_CGC_MASK; /* CGC=1: enable clock to FlexCAN0 */
IP_FLEXCAN0->MCR |= FLEXCAN_MCR_MDIS_MASK; /* MDIS=1: Disable module before selecting clock */
IP_FLEXCAN0->CTRL1 &= ~FLEXCAN_CTRL1_CLKSRC_MASK; /* CLKsrc=0: Clock Source = SOSCDIV2 */
IP_FLEXCAN0->MCR &= ~FLEXCAN_MCR_MDIS_MASK; /* MDIS=0; Enable module config. (Sets FRZ, HALT) */
//CAN0->MCR |= CAN_MCR_FRZ_MASK | CAN_MCR_HALT_MASK;
while (!((IP_FLEXCAN0->MCR & FLEXCAN_MCR_FRZACK_MASK) >> FLEXCAN_MCR_FRZACK_SHIFT)) {}
/*!
* Good practice:
* ===================================================
* wait for FRZACK=1 on freeze mode entry/exit
*/
IP_FLEXCAN0->CTRL1 = 0
#if defined(S32K11x_SERIES)
|CAN_CTRL1_PRESDIV(4) /* PRESDIV=4: Sclock=PEclock/(PRESDIV+1) = 40MHz/5 = 8MHz */
#endif
|FLEXCAN_CTRL1_PSEG2(3) /* Configure for 500 KHz bit time */
|FLEXCAN_CTRL1_PSEG1(3) /* Time quanta freq = 16 time quanta x 500 KHz bit time= 8MHz */
|FLEXCAN_CTRL1_PROPSEG(6) /* PRESDIV+1 = Fclksrc/Ftq = 8 MHz/8 MHz = 1 */
|FLEXCAN_CTRL1_RJW(3) /* so PRESDIV = 0 */
|FLEXCAN_CTRL1_SMP(1);
//|CAN_CTRL1_ERRMSK(1) ; /* Enaable error interrupt mask in CTRL1 register */
/* PSEG2 = Phase_Seg2 - 1 = 4 - 1 = 3 */
/* PSEG1 = PSEG2 = 3 */
/* PROPSEG= Prop_Seg - 1 = 7 - 1 = 6 */
/* RJW: since Phase_Seg2 >=4, RJW+1=4 so RJW=3. */
/* SMP = 1: use 3 bits per CAN sample */
/* CLKsrc=0 (unchanged): Fcanclk= Fosc= 8 MHz */
for(i=0; i<128; i++ )
{ /* IP_FLEXCAN0: clear 32 msg bufs x 4 words/msg buf = 128 words */
IP_FLEXCAN0->RAMn[i] = 0; /* Clear msg buf word */
}
for(i=0; i<16; i++ )
{ /* In FRZ mode, init IP_FLEXCAN0 16 msg buf filters */
IP_FLEXCAN0->RXIMR[i] = 0xFFFFFFFF; /* Check all ID bits for incoming messages */
}
// IP_FLEXCAN0->RXMGMASK = 0x1FFFFFFF; /* Global acceptance mask: check all ID bits */
IP_FLEXCAN0->RXMGMASK = 0x00;
IP_FLEXCAN0->RAMn[ 4*MSG_BUF_SIZE + 0] = 0x04000000; /* Msg Buf 4, word 0: Enable for reception */
/* EDL,BRS,ESI=0: CANFD not used */
/* CODE=4: MB set to RX inactive */
/* IDE=0: Standard ID */
/* SRR, RTR, TIME STAMP = 0: not applicable */
/*0x04000000*/
#ifdef NODE_A /* Node A receives msg with std ID 0x511 */
//IP_FLEXCAN0->RAMn[ 4*MSG_BUF_SIZE + 1] = 0x14440000; /* Msg Buf 4, word 1: Standard ID = 0x111 */
for(i=4;i<7;i++)
{
IP_FLEXCAN0->RAMn[ i*MSG_BUF_SIZE + 0] = 0x04 << 24;
}
#else /* Node B to receive msg with std ID 0x555 */
IP_FLEXCAN0->RAMn[ 4*MSG_BUF_SIZE + 1] = 0x15540000; /* Msg Buf 4, word 1: Standard ID = 0x555 */
#endif
/* PRIO = 0: CANFD not used */
IP_FLEXCAN0->MCR = 0x0000041F; /* Negate FlexCAN 1 halt state for 32 MBs */
while ((IP_FLEXCAN0->MCR && FLEXCAN_MCR_FRZACK_MASK) >> FLEXCAN_MCR_FRZACK_SHIFT) {}
/* Good practice: wait for FRZACK to clear (not in freeze mode) */
while ((IP_FLEXCAN0->MCR && FLEXCAN_MCR_NOTRDY_MASK) >> FLEXCAN_MCR_NOTRDY_SHIFT) {}
/* Good practice: wait for NOTRDY to clear (module ready) */
}
void Gen_FLEXCAN0_transmit_msg(void)
{
/*! Assumption:
* =================================
* Message buffer CODE is INACTIVE
*/
IP_FLEXCAN0->IFLAG1 = 0x00000001; /* Clear CAN 0 MB 0 flag without clearing others*/
IP_FLEXCAN0->RAMn[ 0*MSG_BUF_SIZE + 2] = 0xA5112233; /* MB0 word 2: data word 0 */
IP_FLEXCAN0->RAMn[ 0*MSG_BUF_SIZE + 3] = 0x44556677; /* MB0 word 3: data word 1 */
#ifdef NODE_A
IP_FLEXCAN0->RAMn[ 0*MSG_BUF_SIZE + 1] = 0x15540000; /* MB0 word 1: Tx msg with STD ID 0x555 */
#else
IP_FLEXCAN0->RAMn[ 0*MSG_BUF_SIZE + 1] = 0x14440000; /* MB0 word 1: Tx msg with STD ID 0x511 */
#endif
IP_FLEXCAN0->RAMn[ 0*MSG_BUF_SIZE + 0] = 0x0C400000 | 8 << FLEXCAN_WMBn_CS_DLC_SHIFT;
/* MB0 word 0: */
/* EDL,BRS,ESI=0: CANFD not used */
/* CODE=0xC: Activate msg buf to transmit */
/* IDE=0: Standard ID */
/* SRR=1 Tx frame (not req'd for std ID) */
/* RTR = 0: data, not remote tx request frame */
/* DLC = 8 bytes */
}
void Gen_FLEXCAN0_receive_msg(void)
{
/*! Receive msg from ID 0x556 using msg buffer 4
* =============================================
*/
uint8_t j;
uint32_t dummy;
RxCODE = (IP_FLEXCAN0->RAMn[ 4*MSG_BUF_SIZE + 0] & 0x07000000) >> 24; /* Read CODE field */
RxID = (IP_FLEXCAN0->RAMn[ 4*MSG_BUF_SIZE + 1] & FLEXCAN_WMBn_ID_ID_MASK) >> FLEXCAN_WMBn_ID_ID_SHIFT; /* Read ID */
RxLENGTH = (IP_FLEXCAN0->RAMn[ 4*MSG_BUF_SIZE + 0] & FLEXCAN_WMBn_CS_DLC_MASK) >> FLEXCAN_WMBn_CS_DLC_SHIFT; /* Read Message Length */
for (j=0; j<2; j++)
{ /* Read two words of data (8 bytes) */
RxDATA[j] = IP_FLEXCAN0->RAMn[ 4*MSG_BUF_SIZE + 2 + j];
}
RxTIMESTAMP = (IP_FLEXCAN0->RAMn[ 0*MSG_BUF_SIZE + 0] & 0x000FFFF);
dummy = IP_FLEXCAN0->TIMER; /* Read TIMER to unlock message buffers */
IP_FLEXCAN0->IFLAG1 = 0x00000010; /* Clear CAN 0 MB 4 flag without clearing others*/
}
Thanks