Index: firmware/source/can.c =================================================================== diff -u -rc4434389fe6c3314c2bba98dc2f4cf737551f637 -r439894cb0508e69af3ece09ae57a62feac09e3f2 --- firmware/source/can.c (.../can.c) (revision c4434389fe6c3314c2bba98dc2f4cf737551f637) +++ firmware/source/can.c (.../can.c) (revision 439894cb0508e69af3ece09ae57a62feac09e3f2) @@ -373,6 +373,25 @@ canREG1->IF2CMD = (uint8) 0xF8U; canREG1->IF2NO = 10U; + /** - Initialize message 11 + * - Wait until IF1 is ready for use + * - Set message mask + * - Set message control word + * - Set message arbitration + * - Set IF1 control byte + * - Set IF1 message number + */ + /*SAFETYMCUSW 28 D MR:NA "Potentially infinite loop found - Hardware Status check for execution sequence" */ + while ((canREG1->IF1STAT & 0x80U) ==0x80U) + { + } /* Wait */ + + canREG1->IF1MSK = 0xC0000000U | (uint32)((uint32)((uint32)0x000007FFU & (uint32)0x000007FFU) << (uint32)18U); + canREG1->IF1ARB = (uint32)0x80000000U | (uint32)0x00000000U | (uint32)0x20000000U | (uint32)((uint32)((uint32)0x070U & (uint32)0x000007FFU) << (uint32)18U); + canREG1->IF1MCTL = 0x00001000U | (uint32)0x00000800U | (uint32)0x00000000U | (uint32)0x00000080U | (uint32)8U; + canREG1->IF1CMD = (uint8) 0xF8U; + canREG1->IF1NO = 11U; + /** - Setup IF1 for data transmission * - Wait until IF1 is ready for use * - Set IF1 control byte