Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of Can_sniffer_BMS4 by
main.cpp
- Committer:
- hudakz
- Date:
- 2016-07-23
- Revision:
- 12:e91e44924194
- Parent:
- 11:07d927da1a94
- Child:
- 13:e741def3e4ff
File content as of revision 12:e91e44924194:
/* * An example showing how to use the CANnucleo library: * * Two affordable (less than $4 on ebay) STM32F103C8T6 boards (20kB SRAM, 64kB Flash), * compatible with the NUCLEO-F103RB platform (20kB SRAM, 128kB Flash), * are connected to the same CAN bus via transceivers (MCP2551 or TJA1040, or etc.). * CAN transceivers are not part of NUCLEO boards, therefore must be added by you. * Remember also that CAN bus (even a short one) must be terminated with 120 Ohm resitors at both ends. * * For more details see the wiki page <https://developer.mbed.org/users/hudakz/code/CANnucleo_Hello/> * * NOTE: If you'd like to use the official NUCLEO boards comment out line 25 * * The same code is used for both NUCLEO boards, but: * For board #1 compile the example without any change. * For board #2 comment out line 26 before compiling * * Once the binaries have been downloaded to the boards reset board #1. * */ #include "mbed.h" #include "CANnucleo.h" //#define TARGET_STM32F103C8T6 1 // comment out this line when using official NUCLEO boards! #define BOARD1 1 // comment out this line when compiling for board #2 #if defined(TARGET_STM32F103C8T6) #define LED_PIN PC_13 const int OFF = 1; const int ON = 0; #else #define LED_PIN LED1 const int OFF = 0; const int ON = 1; #endif #if defined(BOARD1) const unsigned int RX_ID = 0x100; const unsigned int TX_ID = 0x101; #else const unsigned int RX_ID = 0x101; const unsigned int TX_ID = 0x100; #endif DigitalOut led(LED_PIN); int ledState; Timer timer; CAN can(PA_11, PA_12); // CAN Rx pin name, CAN Tx pin name CANMessage rxMsg; CANMessage txMsg; int counter = 0; volatile bool msgAvailable = false; /** * @brief 'CAN receive-complete' interrup handler. * @note Called on arrival of new CAN message. * Keep it as short as possible. * @param * @retval */ void onMsgReceived() { msgAvailable = true; } /** * @brief Main * @note * @param * @retval */ int main() { can.frequency(1000000); // set bit rate to 1Mbps can.attach(&onMsgReceived); // attach 'CAN receive-complete' interrupt handler #if defined(BOARD1) led = ON; // turn LED on timer.start(); // start timer #else led = OFF; // turn LED off #endif while(1) { if(timer.read() >= 1.0) { // check for timeout timer.stop(); // stop timer timer.reset(); // reset timer counter++; // increment counter ledState = led.read(); // get led state txMsg.clear(); // clear Tx message storage txMsg.id = TX_ID; // set ID txMsg << counter; // append first data item txMsg << ledState; // append second data item (total data lenght must be <= 8 bytes!) led = OFF; // turn LED off if(can.write(txMsg)) // transmit message printf("CAN message sent\r\n"); else printf("Transmission error\r\n"); } if(msgAvailable) { msgAvailable = false; // reset flag for next use can.read(rxMsg); // read message into Rx message storage printf("CAN message received:\r\n"); printf(" ID = %#x\r\n", rxMsg.id); printf(" Type = %d\r\n", rxMsg.type); printf(" Format = %d\r\n", rxMsg.format); printf(" Length = %d\r\n", rxMsg.len); printf(" Data ="); for(int i = 0; i < rxMsg.len; i++) printf(" %x", rxMsg.data[i]); printf("\r\n"); // Filtering performed by software: if(rxMsg.id == RX_ID) { // See comments in CAN.cpp for filtering performed by hardware rxMsg >> counter; // extract first data item rxMsg >> ledState; // extract second data item printf("counter = %d\r\n", counter); led = ledState; // set LED timer.start(); // transmission lag } } } }