Skip to content

Commit

Permalink
[example] Add CAN example for SAMV71-XPLAINED board
Browse files Browse the repository at this point in the history
  • Loading branch information
rleh committed Feb 9, 2023
1 parent 04e3cb1 commit 464615e
Show file tree
Hide file tree
Showing 2 changed files with 78 additions and 0 deletions.
69 changes: 69 additions & 0 deletions examples/samv71_xplained_ultra/can/main.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
/*
* Copyright (c) 2023, Raphael Lehmann
*
* This file is part of the modm project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*/

#include <modm/board.hpp>
#include <modm/debug/logger.hpp>
#include <modm/board.hpp>

using namespace modm::literals;
using namespace modm::platform;
using namespace Board;

// Set the log level
#undef MODM_LOG_LEVEL
#define MODM_LOG_LEVEL modm::log::INFO

int
main()
{
Board::initialize();

MODM_LOG_INFO << "CAN Test Program" << modm::endl;

MODM_LOG_INFO << "Mcan1: Initializing with 125kbps for boards CAN transceiver (PC12/PC14)." << modm::endl;
// Mcan1 is connted in Board::initialize(); CAN transceiver on the dev board
Mcan1::initialize<Board::SystemClock, 125_kbps, 1_pct>(12);

MODM_LOG_INFO << "Mcan1: Setting up Filter to receive every message." << modm::endl;
Mcan1::setExtendedFilter(0, Mcan1::FilterConfig::Fifo0,
modm::can::ExtendedIdentifier(0),
modm::can::ExtendedMask(0));
Mcan1::setStandardFilter(0, Mcan1::FilterConfig::Fifo0,
modm::can::StandardIdentifier(0),
modm::can::StandardMask(0));

uint32_t counter{0};

while (true)
{
MODM_LOG_INFO << "loop: " << counter++ << modm::endl;

modm::can::Message txMsg{1, 1};
txMsg.setExtended(true);
txMsg.data[0] = counter;
MODM_LOG_INFO << "Mcan1: Sending message... " << txMsg << modm::endl;
Mcan1::sendMessage(txMsg);

if (Mcan1::isMessageAvailable())
{
MODM_LOG_INFO << "Mcan1: Message is available... ";
modm::can::Message rxMsg;
if (Mcan1::getMessage(rxMsg))
MODM_LOG_INFO << rxMsg << modm::endl;
else
MODM_LOG_INFO << " but getting message FAILED" << modm::endl;
}

Led0::toggle();
modm::delay(500ms);
}

return 0;
}
9 changes: 9 additions & 0 deletions examples/samv71_xplained_ultra/can/project.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
<library>
<extends>modm:samv71-xplained-ultra</extends>
<options>
<option name="modm:build:build.path">../../../build/samv71_xplained_ultra/can</option>
</options>
<modules>
<module>modm:build:scons</module>
</modules>
</library>

0 comments on commit 464615e

Please sign in to comment.