X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=CAN-binder%2Flow-can-binding%2Fcan%2Fcan-decoder.cpp;h=61bfe753d1b289a666e9bc8b1d75e51ab11ea7fb;hb=2a35b45d6bdef8b634de36103e0a33490922dd4e;hp=e01e43bb8a46812c389ff0660eb810230c539eca;hpb=3102ec9ce009d0f28355c5b7df9c5bd5013e6e75;p=apps%2Fagl-service-can-low-level.git diff --git a/CAN-binder/low-can-binding/can/can-decoder.cpp b/CAN-binder/low-can-binding/can/can-decoder.cpp index e01e43bb..61bfe753 100644 --- a/CAN-binder/low-can-binding/can/can-decoder.cpp +++ b/CAN-binder/low-can-binding/can/can-decoder.cpp @@ -19,8 +19,8 @@ #include "canutil/read.h" #include "../utils/openxc-utils.hpp" - -#include "../low-can-binding.hpp" +#include "can-message-definition.hpp" +#include "../binding/low-can-hat.hpp" /// @brief Parse the signal's bitfield from the given data and return the raw /// value. @@ -54,7 +54,7 @@ float decoder_t::parseSignalBitfield(can_signal_t& signal, const can_message_t& /// always succeeds. /// openxc_DynamicField decoder_t::noopDecoder(can_signal_t& signal, - const std::vector& signals, float value, bool* send) + const std::vector >& signals, float value, bool* send) { openxc_DynamicField decoded_value = build_DynamicField(value); @@ -76,7 +76,7 @@ openxc_DynamicField decoder_t::noopDecoder(can_signal_t& signal, /// decoder always succeeds. /// openxc_DynamicField decoder_t::booleanDecoder(can_signal_t& signal, - const std::vector& signals, float value, bool* send) + const std::vector >& signals, float value, bool* send) { openxc_DynamicField decoded_value = build_DynamicField(value == 0.0 ? false : true); @@ -98,7 +98,7 @@ openxc_DynamicField decoder_t::booleanDecoder(can_signal_t& signal, /// @return Return value is undefined. /// openxc_DynamicField decoder_t::ignoreDecoder(can_signal_t& signal, - const std::vector& signals, float value, bool* send) + const std::vector >& signals, float value, bool* send) { if(send) *send = false; @@ -125,14 +125,14 @@ openxc_DynamicField decoder_t::ignoreDecoder(can_signal_t& signal, /// return value is undefined. /// openxc_DynamicField decoder_t::stateDecoder(can_signal_t& signal, - const std::vector& signals, float value, bool* send) + const std::vector >& signals, float value, bool* send) { const std::string signal_state = signal.get_states((uint8_t)value); openxc_DynamicField decoded_value = build_DynamicField(signal_state); if(signal_state.size() <= 0) { *send = false; - ERROR(binder_interface, "%s: No state found with index: %d", __FUNCTION__, (int)value); + ERROR("No state found with index: %d", (int)value); } return decoded_value; } @@ -153,11 +153,11 @@ openxc_DynamicField decoder_t::stateDecoder(can_signal_t& signal, /// The decoder returns an openxc_DynamicField, which may contain a number, /// string or boolean. /// -openxc_DynamicField decoder_t::translateSignal(can_signal_t& signal, can_message_t& message, - const std::vector& signals, bool* send) +openxc_DynamicField decoder_t::translateSignal(can_signal_t& signal, const can_message_t& message, + const std::vector >& signals, bool* send) { float value = decoder_t::parseSignalBitfield(signal, message); - DEBUG(binder_interface, "%s: Decoded message from parseSignalBitfield: %f", __FUNCTION__, value); + DEBUG("Decoded message from parseSignalBitfield: %f", value); // Must call the decoders every time, regardless of if we are going to // decide to send the signal or not. @@ -167,11 +167,13 @@ openxc_DynamicField decoder_t::translateSignal(can_signal_t& signal, can_message signal.set_received(true); // Don't send if they is no changes - if ((signal.get_last_value() == value && !signal.get_send_same()) || !send ) + if ((signal.get_last_value() == value && !signal.get_send_same()) || !*send ) { *send = false; } signal.set_last_value(value); + signal.set_timestamp(message.get_timestamp()); + signal.get_message()->set_last_value(message); return decoded_value; } @@ -191,7 +193,7 @@ openxc_DynamicField decoder_t::translateSignal(can_signal_t& signal, can_message /// string or boolean. If 'send' is false, the return value is undefined. /// openxc_DynamicField decoder_t::decodeSignal( can_signal_t& signal, - float value, const std::vector& signals, bool* send) + float value, const std::vector >& signals, bool* send) { SignalDecoder decoder = signal.get_decoder() == nullptr ? noopDecoder : signal.get_decoder(); @@ -214,7 +216,7 @@ openxc_DynamicField decoder_t::decodeSignal( can_signal_t& signal, /// not be decoded. /// openxc_DynamicField decoder_t::decodeSignal( can_signal_t& signal, - const can_message_t& message, const std::vector& signals, bool* send) + const can_message_t& message, const std::vector >& signals, bool* send) { float value = parseSignalBitfield(signal, message); return decodeSignal(signal, value, signals, send);