i have composed the program which i want 2 dsp(tms320 f 28035) to communicate each other.
when i run it, then the one in the master always gets into trip ( while(ECanaRegs.CANTA.all != 0x0000FFFF ) ) to wait the CANTA
register changing to 1. always~~~(of course, i did wire the transceiver for ECAN, numbered SN65HVD230 )
i have tried masive times, i am nearly dying.
this problem really drives me crazy~~
can any kind rescurer help me to correct the program which Refers to attachment?
please~~~
below file's Filename Extension should be exchanged .txt into .c
#include "DSP28x_Project.h" // Device Headerfile and Examples Include File void main(void) { Uint16 j; struct ECAN_REGS ECanaShadow; InitSysCtrl(); { EALLOW; GpioCtrlRegs.GPAPUD.bit.GPIO30 = 0; // Enable pull-up for GPIO30 (CANRXA) GpioCtrlRegs.GPAPUD.bit.GPIO31 = 0; // Enable pull-up for GPIO31 (CANTXA) GpioCtrlRegs.GPAQSEL2.bit.GPIO30 = 3; // Asynch qual for GPIO30 (CANRXA) GpioCtrlRegs.GPAMUX2.bit.GPIO30 = 1; // Configure GPIO30 for CANRXA operation GpioCtrlRegs.GPAMUX2.bit.GPIO31 = 1; // Configure GPIO31 for CANTXA operation EDIS; } DINT; InitPieCtrl(); IER = 0x0000; IFR = 0x0000; InitPieVectTable(); caninit(); // Initialize eCAN-A module // Write to the mailbox RAM field of MBOX0 - 15 ECanaMboxes.MBOX0.MDL.all = 0x12345678; ECanaMboxes.MBOX0.MDH.all = 0x13579ace; ECanaMboxes.MBOX1.MDL.all = 0x11111111; ECanaMboxes.MBOX1.MDH.all = 0x11111111; ECanaMboxes.MBOX2.MDL.all = 0x22222222; ECanaMboxes.MBOX2.MDH.all = 0x22222222; ECanaMboxes.MBOX3.MDL.all = 0x33333333; ECanaMboxes.MBOX3.MDH.all = 0x33333333; ECanaMboxes.MBOX4.MDL.all = 0x44444444; ECanaMboxes.MBOX4.MDH.all = 0x44444444; ECanaMboxes.MBOX5.MDL.all = 0x55555555; ECanaMboxes.MBOX5.MDH.all = 0x55555555; ECanaMboxes.MBOX6.MDL.all = 0x66666666; ECanaMboxes.MBOX6.MDH.all = 0x66666666; ECanaMboxes.MBOX7.MDL.all = 0x77777777; ECanaMboxes.MBOX7.MDH.all = 0x77777777; ECanaMboxes.MBOX8.MDL.all = 0x88888888; ECanaMboxes.MBOX8.MDH.all = 0x88888888; ECanaMboxes.MBOX9.MDL.all = 0x99999999; ECanaMboxes.MBOX9.MDH.all = 0x99999999; ECanaMboxes.MBOX10.MDL.all = 0xaaaaaaaa; ECanaMboxes.MBOX10.MDH.all = 0xaaaaaaaa; ECanaMboxes.MBOX11.MDL.all = 0xbbbbbbbb; ECanaMboxes.MBOX11.MDH.all = 0xbbbbbbbb; ECanaMboxes.MBOX12.MDL.all = 0xcccccccc; ECanaMboxes.MBOX12.MDH.all = 0xcccccccc; ECanaMboxes.MBOX13.MDL.all = 0xdddddddd; ECanaMboxes.MBOX13.MDH.all = 0xdddddddd; ECanaMboxes.MBOX14.MDL.all = 0xeeeeeeee; ECanaMboxes.MBOX14.MDH.all = 0xeeeeeeee; ECanaMboxes.MBOX15.MDL.all = 0xffffffff; ECanaMboxes.MBOX15.MDH.all = 0xffffffff; // Since this write is to the entire register (instead of a bit // field) a shadow register is not required. /// EALLOW; /// ECanaRegs.CANMIM.all = 0xFFFFFFFF; // Configure the eCAN for self test mode // Enable the enhanced features of the eCAN. /// EALLOW; /// ECanaShadow.CANMC.all = ECanaRegs.CANMC.all; /// ECanaShadow.CANMC.bit.STM = 1; // Configure CAN for self-test mode /// ECanaRegs.CANMC.all = ECanaShadow.CANMC.all; /// EDIS; // Begin transmitting for(;;) { ECanaRegs.CANTRS.all = 0x0000FFFF; // Set TRS for all transmit mailboxes while(ECanaRegs.CANTA.all != 0x0000FFFF ) {} // Wait for all TAn bits to be set.. ECanaRegs.CANTA.all = 0x0000FFFF; // Clear all TAn while(ECanaRegs.CANTA.all != 0x00000000 ) {} } } //=========================================================================== // No more. //===========================================================================
#include "DSP2803x_Device.h" // DSP28 Headerfile Include File #include "DSP2803x_Examples.h" // DSP28 Examples Include File void caninit(void) // Initialize eCAN-A module { struct ECAN_REGS ECanaShadow; EALLOW; // EALLOW enables access to protected bits ECanaShadow.CANTIOC.all = ECanaRegs.CANTIOC.all; ECanaShadow.CANTIOC.bit.TXFUNC = 1; ECanaRegs.CANTIOC.all = ECanaShadow.CANTIOC.all; ECanaShadow.CANRIOC.all = ECanaRegs.CANRIOC.all; ECanaShadow.CANRIOC.bit.RXFUNC = 1; ECanaRegs.CANRIOC.all = ECanaShadow.CANRIOC.all; ECanaShadow.CANMC.all = ECanaRegs.CANMC.all; ECanaShadow.CANMC.bit.SCB = 1; ECanaRegs.CANMC.all = ECanaShadow.CANMC.all; /* Configure bit timing parameters for eCANA*/ ECanaShadow.CANMC.all = ECanaRegs.CANMC.all; ECanaShadow.CANMC.bit.CCR = 1 ; // Set CCR = 1 ECanaRegs.CANMC.all = ECanaShadow.CANMC.all; // Wait until the CPU has been granted permission to change the configuration registers do { ECanaShadow.CANES.all = ECanaRegs.CANES.all; } while(ECanaShadow.CANES.bit.CCE != 1 ); // Wait for CCE bit to be set.. ECanaShadow.CANBTC.all = 0; /* The following block is only for 60 MHz SYSCLKOUT. (30 MHz CAN module clock Bit rate = 1 Mbps See Note at end of file. */ ECanaShadow.CANBTC.bit.BRPREG = 2; ECanaShadow.CANBTC.bit.TSEG2REG = 1; ECanaShadow.CANBTC.bit.TSEG1REG = 6; ECanaShadow.CANBTC.bit.SAM = 1; ECanaRegs.CANBTC.all = ECanaShadow.CANBTC.all; ECanaMboxes.MBOX0.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX1.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX2.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX3.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX4.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX5.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX6.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX7.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX8.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX9.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX10.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX11.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX12.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX13.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX14.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX15.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX16.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX17.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX18.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX19.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX20.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX21.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX22.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX23.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX24.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX25.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX26.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX27.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX28.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX29.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX30.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX31.MSGCTRL.all = 0x00000000; ECanaShadow.CANMC.all = ECanaRegs.CANMC.all; ECanaShadow.CANMC.bit.CCR = 0 ; // Set CCR = 0 ECanaRegs.CANMC.all = ECanaShadow.CANMC.all; // Wait until the CPU no longer has permission to change the configuration registers do { ECanaShadow.CANES.all = ECanaRegs.CANES.all; } while(ECanaShadow.CANES.bit.CCE != 0 ); // Wait for CCE bit to be cleared.. // TAn, RMPn, GIFn bits are all zero upon reset and are cleared again // as a matter of precaution. ECanaRegs.CANTRR.all=0xffffffff; do { ECanaShadow.CANTRS.all = ECanaRegs.CANTRS.all; } while(ECanaShadow.CANTRS.all != 0 ); ECanaRegs.CANTA.all = 0xFFFFFFFF; /* Clear all TAn bits */ ECanaRegs.CANRMP.all = 0xFFFFFFFF; /* Clear all RMPn bits */ ECanaRegs.CANGIF0.all = 0xFFFFFFFF; /* Clear all interrupt flag bits */ ECanaRegs.CANGIF1.all = 0xFFFFFFFF; /* Disable all Mailboxes */ ECanaRegs.CANME.all = 0; // Required before writing the MSGIDs // Mailboxs can be written to 16-bits or 32-bits at a time // Write to the MSGID field of TRANSMIT mailboxes MBOX0 - 15 ECanaMboxes.MBOX0.MSGID.all = 0x80000000; ECanaMboxes.MBOX1.MSGID.all = 0x80000001; ECanaMboxes.MBOX2.MSGID.all = 0x80000002; ECanaMboxes.MBOX3.MSGID.all = 0x80000003; ECanaMboxes.MBOX4.MSGID.all = 0x80000004; ECanaMboxes.MBOX5.MSGID.all = 0x80000005; ECanaMboxes.MBOX6.MSGID.all = 0x80000006; ECanaMboxes.MBOX7.MSGID.all = 0x80000007; ECanaMboxes.MBOX8.MSGID.all = 0x80000008; ECanaMboxes.MBOX9.MSGID.all = 0x80000009; ECanaMboxes.MBOX10.MSGID.all = 0x8000000A; ECanaMboxes.MBOX11.MSGID.all = 0x8000000B; ECanaMboxes.MBOX12.MSGID.all = 0x8000000C; ECanaMboxes.MBOX13.MSGID.all = 0x8000000D; ECanaMboxes.MBOX14.MSGID.all = 0x8000000E; ECanaMboxes.MBOX15.MSGID.all = 0x8000000F; // Write to the MSGID field of RECEIVE mailboxes MBOX16 - 31 ECanaMboxes.MBOX16.MSGID.all = 0x81111110; ECanaMboxes.MBOX17.MSGID.all = 0x81111111; ECanaMboxes.MBOX18.MSGID.all = 0x81111112; ECanaMboxes.MBOX19.MSGID.all = 0x81111113; ECanaMboxes.MBOX20.MSGID.all = 0x81111114; ECanaMboxes.MBOX21.MSGID.all = 0x81111115; ECanaMboxes.MBOX22.MSGID.all = 0x81111116; ECanaMboxes.MBOX23.MSGID.all = 0x81111117; ECanaMboxes.MBOX24.MSGID.all = 0x81111118; ECanaMboxes.MBOX25.MSGID.all = 0x81111119; ECanaMboxes.MBOX26.MSGID.all = 0x8111111A; ECanaMboxes.MBOX27.MSGID.all = 0x8111111B; ECanaMboxes.MBOX28.MSGID.all = 0x8111111C; ECanaMboxes.MBOX29.MSGID.all = 0x8111111D; ECanaMboxes.MBOX30.MSGID.all = 0x8111111E; ECanaMboxes.MBOX31.MSGID.all = 0x8111111F; // Specify that 8 bits will be sent/received ECanaMboxes.MBOX0.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX1.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX2.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX3.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX4.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX5.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX6.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX7.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX8.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX9.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX10.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX11.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX12.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX13.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX14.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX15.MSGCTRL.bit.DLC = 8; // Configure Mailboxes 0-15 as Tx, 16-31 as Rx // Since this write is to the entire register (instead of a bit // field) a shadow register is not required. ECanaRegs.CANMD.all = 0xFFFF0000; // Enable all Mailboxes */ // Since this write is to the entire register (instead of a bit // field) a shadow register is not required. ECanaRegs.CANME.all = 0xFFFFFFFF; // EDIS; } //--------------------------------------------------------------------------- // Example: InitECanGpio: //--------------------------------------------------------------------------- // This function initializes GPIO pins to function as eCAN pins // // Each GPIO pin can be configured as a GPIO pin or up to 3 different // peripheral functional pins. By default all pins come up as GPIO // inputs after reset. // // Caution: // Only one GPIO pin should be enabled for CANTXA operation. // Only one GPIO pin shoudl be enabled for CANRXA operation. // Comment out other unwanted lines. /* Note: Bit timing parameters must be chosen based on the network parameters such as the sampling point desired and the propagation delay of the network. The propagation delay is a function of length of the cable, delay introduced by the transceivers and opto/galvanic-isolators (if any). The parameters used in this file must be changed taking into account the above mentioned factors in order to arrive at the bit-timing parameters suitable for a network. */ //=========================================================================== // End of file. //===========================================================================
#include "DSP28x_Project.h" // Device Headerfile and Examples Include File long ffff[16]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; void main(void) { struct ECAN_REGS ECanaShadow; InitSysCtrl(); { EALLOW; GpioCtrlRegs.GPAPUD.bit.GPIO30 = 0; // Enable pull-up for GPIO30 (CANRXA) GpioCtrlRegs.GPAPUD.bit.GPIO31 = 0; // Enable pull-up for GPIO31 (CANTXA) GpioCtrlRegs.GPAQSEL2.bit.GPIO30 = 3; // Asynch qual for GPIO30 (CANRXA) GpioCtrlRegs.GPAMUX2.bit.GPIO30 = 1; // Configure GPIO30 for CANRXA operation GpioCtrlRegs.GPAMUX2.bit.GPIO31 = 1; // Configure GPIO31 for CANTXA operation EDIS; } DINT; InitPieCtrl(); IER = 0x0000; IFR = 0x0000; InitPieVectTable(); caninitsalve(); // Initialize eCAN-A module // Configure the eCAN for self test mode // Enable the enhanced features of the eCAN. /// EALLOW; /// ECanaShadow.CANMC.all = ECanaRegs.CANMC.all; /// ECanaShadow.CANMC.bit.STM = 1; // Configure CAN for self-test mode /// ECanaRegs.CANMC.all = ECanaShadow.CANMC.all; /// EDIS; // Begin waiting for(;;) { ffff[0] = ECanaMboxes.MBOX0.MDL.all; ffff[1] = ECanaMboxes.MBOX1.MDL.all; ffff[2] = ECanaMboxes.MBOX2.MDL.all; ffff[3] = ECanaMboxes.MBOX3.MDL.all; ffff[4] = ECanaMboxes.MBOX4.MDL.all; ffff[5] = ECanaMboxes.MBOX5.MDL.all; ffff[6] = ECanaMboxes.MBOX6.MDL.all; ffff[7] = ECanaMboxes.MBOX7.MDL.all; ffff[8] = ECanaMboxes.MBOX8.MDL.all; ffff[9] = ECanaMboxes.MBOX9.MDL.all; ffff[10] = ECanaMboxes.MBOX10.MDL.all; ffff[11] = ECanaMboxes.MBOX11.MDL.all; ffff[12] = ECanaMboxes.MBOX12.MDL.all; ffff[13] = ECanaMboxes.MBOX13.MDL.all; ffff[14] = ECanaMboxes.MBOX14.MDL.all; ffff[15] = ECanaMboxes.MBOX15.MDL.all; } } //=========================================================================== // No more. //===========================================================================
#include "DSP2803x_Device.h" // DSP28 Headerfile Include File #include "DSP2803x_Examples.h" // DSP28 Examples Include File //--------------------------------------------------------------------------- // InitECan: //--------------------------------------------------------------------------- // This function initializes the eCAN module to a known state. // void caninitsalve(void) // Initialize eCAN-A module { struct ECAN_REGS ECanaShadow; EALLOW; // EALLOW enables access to protected bits ECanaShadow.CANTIOC.all = ECanaRegs.CANTIOC.all; ECanaShadow.CANTIOC.bit.TXFUNC = 1; ECanaRegs.CANTIOC.all = ECanaShadow.CANTIOC.all; ECanaShadow.CANRIOC.all = ECanaRegs.CANRIOC.all; ECanaShadow.CANRIOC.bit.RXFUNC = 1; ECanaRegs.CANRIOC.all = ECanaShadow.CANRIOC.all; ECanaShadow.CANMC.all = ECanaRegs.CANMC.all; ECanaShadow.CANMC.bit.SCB = 1; ECanaRegs.CANMC.all = ECanaShadow.CANMC.all; /* Configure bit timing parameters for eCANA*/ ECanaShadow.CANMC.all = ECanaRegs.CANMC.all; ECanaShadow.CANMC.bit.CCR = 1 ; // Set CCR = 1 ECanaRegs.CANMC.all = ECanaShadow.CANMC.all; // Wait until the CPU has been granted permission to change the configuration registers do { ECanaShadow.CANES.all = ECanaRegs.CANES.all; } while(ECanaShadow.CANES.bit.CCE != 1 ); // Wait for CCE bit to be set.. ECanaShadow.CANBTC.all = 0; /* The following block is only for 60 MHz SYSCLKOUT. (30 MHz CAN module clock Bit rate = 1 Mbps See Note at end of file. */ ECanaShadow.CANBTC.bit.BRPREG = 2; ECanaShadow.CANBTC.bit.TSEG2REG = 1; ECanaShadow.CANBTC.bit.TSEG1REG = 6; ECanaShadow.CANBTC.bit.SAM = 1; ECanaRegs.CANBTC.all = ECanaShadow.CANBTC.all; ECanaMboxes.MBOX0.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX1.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX2.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX3.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX4.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX5.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX6.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX7.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX8.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX9.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX10.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX11.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX12.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX13.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX14.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX15.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX16.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX17.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX18.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX19.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX20.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX21.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX22.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX23.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX24.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX25.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX26.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX27.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX28.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX29.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX30.MSGCTRL.all = 0x00000000; ECanaMboxes.MBOX31.MSGCTRL.all = 0x00000000; ECanaShadow.CANMC.all = ECanaRegs.CANMC.all; ECanaShadow.CANMC.bit.CCR = 0 ; // Set CCR = 0 ECanaRegs.CANMC.all = ECanaShadow.CANMC.all; // Wait until the CPU no longer has permission to change the configuration registers do { ECanaShadow.CANES.all = ECanaRegs.CANES.all; } while(ECanaShadow.CANES.bit.CCE != 0 ); // Wait for CCE bit to be cleared.. //`,',`,',`,',`,',`,',`,',`,',`,',`,',`,',`,',`,',`,',`,',`,',`,', // TAn, RMPn, GIFn bits are all zero upon reset and are cleared again // as a matter of precaution. /// ECanaRegs.CANTRR.all=0xffffffff; /// do /// { /// ECanaShadow.CANTRS.all = ECanaRegs.CANTRS.all; /// } while(ECanaShadow.CANTRS.all != 0 ); ECanaRegs.CANTA.all = 0xFFFFFFFF; /* Clear all TAn bits */ ECanaRegs.CANRMP.all = 0xFFFFFFFF; /* Clear all RMPn bits */ ECanaRegs.CANGIF0.all = 0xFFFFFFFF; /* Clear all interrupt flag bits */ ECanaRegs.CANGIF1.all = 0xFFFFFFFF; /* Disable all Mailboxes */ ECanaRegs.CANME.all = 0; // Required before writing the MSGIDs // Mailboxs can be written to 16-bits or 32-bits at a time // Write to the MSGID field of TRANSMIT mailboxes MBOX0 - 15 ECanaMboxes.MBOX0.MSGID.all = 0x81111110; ECanaMboxes.MBOX1.MSGID.all = 0x81111111; ECanaMboxes.MBOX2.MSGID.all = 0x81111112; ECanaMboxes.MBOX3.MSGID.all = 0x81111113; ECanaMboxes.MBOX4.MSGID.all = 0x81111114; ECanaMboxes.MBOX5.MSGID.all = 0x81111115; ECanaMboxes.MBOX6.MSGID.all = 0x81111116; ECanaMboxes.MBOX7.MSGID.all = 0x81111117; ECanaMboxes.MBOX8.MSGID.all = 0x81111118; ECanaMboxes.MBOX9.MSGID.all = 0x81111119; ECanaMboxes.MBOX10.MSGID.all = 0x8111111A; ECanaMboxes.MBOX11.MSGID.all = 0x8111111B; ECanaMboxes.MBOX12.MSGID.all = 0x8111111C; ECanaMboxes.MBOX13.MSGID.all = 0x8111111D; ECanaMboxes.MBOX14.MSGID.all = 0x8111111E; ECanaMboxes.MBOX15.MSGID.all = 0x8111111F; // Write to the MSGID field of RECEIVE mailboxes MBOX16 - 31 ECanaMboxes.MBOX16.MSGID.all = 0x80000000; ECanaMboxes.MBOX17.MSGID.all = 0x80000001; ECanaMboxes.MBOX18.MSGID.all = 0x80000002; ECanaMboxes.MBOX19.MSGID.all = 0x80000003; ECanaMboxes.MBOX20.MSGID.all = 0x80000004; ECanaMboxes.MBOX21.MSGID.all = 0x80000005; ECanaMboxes.MBOX22.MSGID.all = 0x80000006; ECanaMboxes.MBOX23.MSGID.all = 0x80000007; ECanaMboxes.MBOX24.MSGID.all = 0x80000008; ECanaMboxes.MBOX25.MSGID.all = 0x80000009; ECanaMboxes.MBOX26.MSGID.all = 0x8000000A; ECanaMboxes.MBOX27.MSGID.all = 0x8000000B; ECanaMboxes.MBOX28.MSGID.all = 0x8000000C; ECanaMboxes.MBOX29.MSGID.all = 0x8000000D; ECanaMboxes.MBOX30.MSGID.all = 0x8000000E; ECanaMboxes.MBOX31.MSGID.all = 0x8000000F; // Specify that 8 bits will be sent/received ECanaMboxes.MBOX0.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX1.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX2.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX3.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX4.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX5.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX6.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX7.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX8.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX9.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX10.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX11.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX12.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX13.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX14.MSGCTRL.bit.DLC = 8; ECanaMboxes.MBOX15.MSGCTRL.bit.DLC = 8; // Configure Mailboxes 0-15 as Tx, 16-31 as Rx // Since this write is to the entire register (instead of a bit // field) a shadow register is not required. ECanaRegs.CANMD.all = 0x0000FFFF; // Enable all Mailboxes */ // Since this write is to the entire register (instead of a bit // field) a shadow register is not required. ECanaRegs.CANME.all = 0xFFFFFFFF; // EDIS; } //--------------------------------------------------------------------------- // Example: InitECanGpio: //--------------------------------------------------------------------------- // This function initializes GPIO pins to function as eCAN pins // // Each GPIO pin can be configured as a GPIO pin or up to 3 different // peripheral functional pins. By default all pins come up as GPIO // inputs after reset. // // Caution: // Only one GPIO pin should be enabled for CANTXA operation. // Only one GPIO pin shoudl be enabled for CANRXA operation. // Comment out other unwanted lines. /* Note: Bit timing parameters must be chosen based on the network parameters such as the sampling point desired and the propagation delay of the network. The propagation delay is a function of length of the cable, delay introduced by the transceivers and opto/galvanic-isolators (if any). The parameters used in this file must be changed taking into account the above mentioned factors in order to arrive at the bit-timing parameters suitable for a network. */ //=========================================================================== // End of file. //===========================================================================