diff options
author | Romain Forlot <romain.forlot@iot.bzh> | 2018-09-28 17:12:18 +0200 |
---|---|---|
committer | Romain Forlot <romain.forlot@iot.bzh> | 2018-12-14 08:58:56 +0000 |
commit | ea35eabeadce57e4f5015797fea530c5bb219fff (patch) | |
tree | 69fbb0f4e4d5528500873d122bc35b3423d7ca96 /low-can-binding/binding/application-generated.cpp | |
parent | b049485873e1692cc9e7857e91e017f86dd91218 (diff) |
CAN FD implementation
Add a flag to CAN message definitions which set the message as using FD
protocol if true.
Use a new generated file with the new FD flag field on the message
definitions.
Change BCM socket "struct" using an union to store the CAN frames either
using the FD struct or the classic non FD struct. A BCM socket can only
one frame type once configured.
Use as much as possible the "struct canfd_frame" in the binding and only
make a difference before writing or reading the socket. From a memory
point of view both struct are identical and only the last member differ
and could hold more data with messages of 64 bytes long. So the
canfd_frame is compatible with the can_frame and can be differentiated
by a flag set in the can_id member.
Remove now unused code processing can_frame.
Keep the diagnostic manager using the classic CAN frame.
Set the maximum number of frames that a BCM socket can handle to 257.
Bug-AGL: SPEC-1980
Change-Id: Ifcc041281ea6745fc25cbd384743761f4446f489
Signed-off-by: Romain Forlot <romain.forlot@iot.bzh>
Diffstat (limited to 'low-can-binding/binding/application-generated.cpp')
-rw-r--r-- | low-can-binding/binding/application-generated.cpp | 48 |
1 files changed, 42 insertions, 6 deletions
diff --git a/low-can-binding/binding/application-generated.cpp b/low-can-binding/binding/application-generated.cpp index 5a67d86e..1b0a3506 100644 --- a/low-can-binding/binding/application-generated.cpp +++ b/low-can-binding/binding/application-generated.cpp @@ -7,7 +7,13 @@ application_t::application_t() , can_message_set_{ {std::make_shared<can_message_set_t>(can_message_set_t{0,"AGL Virtual Car", { // beginning can_message_definition_ vector - {std::make_shared<can_message_definition_t>(can_message_definition_t{"ls",0x30,can_message_format_t::STANDARD,frequency_clock_t(5.00000f),true, + {std::make_shared<can_message_definition_t>(can_message_definition_t{ + "ls", + 0x30, + false, + can_message_format_t::EXTENDED, + frequency_clock_t(5.00000f), + true, { // beginning can_signals vector {std::make_shared<can_signal_t> (can_signal_t{ "hvac.fan.speed", @@ -83,7 +89,13 @@ application_t::application_t() })} } // end can_signals vector })} // end can_message_definition entry -, {std::make_shared<can_message_definition_t>(can_message_definition_t{"hs",0x3D9,can_message_format_t::STANDARD,frequency_clock_t(5.00000f),true, +, {std::make_shared<can_message_definition_t>(can_message_definition_t{ + "hs", + 0x3D9, + true, + can_message_format_t::STANDARD, + frequency_clock_t(5.00000f), + true, { // beginning can_signals vector {std::make_shared<can_signal_t> (can_signal_t{ "engine.speed", @@ -141,7 +153,13 @@ application_t::application_t() })} } // end can_signals vector })} // end can_message_definition entry -, {std::make_shared<can_message_definition_t>(can_message_definition_t{"hs",0x3E9,can_message_format_t::STANDARD,frequency_clock_t(5.00000f),true, +, {std::make_shared<can_message_definition_t>(can_message_definition_t{ + "hs", + 0x3E9, + false, + can_message_format_t::EXTENDED, + frequency_clock_t(5.00000f), + true, { // beginning can_signals vector {std::make_shared<can_signal_t> (can_signal_t{ "vehicle.average.speed", @@ -163,7 +181,13 @@ application_t::application_t() })} } // end can_signals vector })} // end can_message_definition entry -, {std::make_shared<can_message_definition_t>(can_message_definition_t{"hs",0x4D1,can_message_format_t::STANDARD,frequency_clock_t(5.00000f),true, +, {std::make_shared<can_message_definition_t>(can_message_definition_t{ + "hs", + 0x4D1, + false, + can_message_format_t::STANDARD, + frequency_clock_t(5.00000f), + true, { // beginning can_signals vector {std::make_shared<can_signal_t> (can_signal_t{ "engine.oil.temp", @@ -203,7 +227,13 @@ application_t::application_t() })} } // end can_signals vector })} // end can_message_definition entry -, {std::make_shared<can_message_definition_t>(can_message_definition_t{"hs",0x620,can_message_format_t::STANDARD,frequency_clock_t(5.00000f),true, +, {std::make_shared<can_message_definition_t>(can_message_definition_t{ + "hs", + 0x620, + false, + can_message_format_t::STANDARD, + frequency_clock_t(5.00000f), + true, { // beginning can_signals vector {std::make_shared<can_signal_t> (can_signal_t{ "doors.boot.open", @@ -297,7 +327,13 @@ application_t::application_t() })} } // end can_signals vector })} // end can_message_definition entry -, {std::make_shared<can_message_definition_t>(can_message_definition_t{"hs",0x799,can_message_format_t::STANDARD,frequency_clock_t(5.00000f),true, +, {std::make_shared<can_message_definition_t>(can_message_definition_t{ + "hs", + 0x799, + false, + can_message_format_t::STANDARD, + frequency_clock_t(5.00000f), + true, { // beginning can_signals vector {std::make_shared<can_signal_t> (can_signal_t{ "windows.front_left.open", |