can_decoder : Move frame swap to only do it one time 60/23460/3
authorArthur Guyader <arthur.guyader@iot.bzh>
Mon, 16 Dec 2019 18:19:50 +0000 (19:19 +0100)
committerRomain Forlot <romain.forlot@iot.bzh>
Thu, 9 Jan 2020 15:25:36 +0000 (16:25 +0100)
This commit allows to swap only one time a data message.

Change-Id: I566c6ad72e266cd59a4397ab1a5ef423d752cf75
Signed-off-by: Arthur Guyader <arthur.guyader@iot.bzh>
Signed-off-by: Romain Forlot <romain.forlot@iot.bzh>
low-can-binding/binding/low-can-hat.cpp
low-can-binding/can/can-decoder.cpp

index 7e0d94a..7258074 100644 (file)
@@ -74,7 +74,11 @@ int read_message(sd_event_source *event_source, int fd, uint32_t revents, void *
                                if (message->get_id() &&
                                    message->get_length() &&
                                    ! (message->get_flags() & INVALID_FLAG) )
+                               {
+                                       if(can_subscription->get_signal() != nullptr && can_subscription->get_signal()->get_message()->get_flags() & BYTE_FRAME_IS_BIG_ENDIAN)
+                                               message->frame_swap();
                                        push_n_notify(message);
+                               }
                        }
                }
        }
index 160a22b..7221d71 100644 (file)
@@ -104,17 +104,6 @@ float decoder_t::parse_signal_bitfield(signal_t& signal, std::shared_ptr<message
        uint8_t new_start_bit = 0;
        uint8_t new_end_bit = 0;
 
-       if(signal.get_message()->get_flags() & CONTINENTAL_BIT_POSITION)
-               bit_position = converter_t::continental_bit_position_mess(message->get_length(),
-                                                             signal.get_bit_position(),
-                                                             bit_size);
-       if(signal.get_message()->get_flags() & BIT_POSITION_REVERSED)
-               bit_position = converter_t::bit_position_swap(message->get_length(),
-                                                             signal.get_bit_position(),
-                                                             bit_size);
-       if(signal.get_message()->get_flags() & BYTE_FRAME_IS_BIG_ENDIAN)
-               message->frame_swap();
-
        data = message->get_data_vector();
        converter_t::signal_to_bits_bytes(bit_position, bit_size, new_start_byte, new_end_byte, new_start_bit, new_end_bit);
 
@@ -409,6 +398,17 @@ openxc_DynamicField decoder_t::translate_signal(signal_t& signal, std::shared_pt
 ///
 openxc_DynamicField decoder_t::decode_signal( signal_t& signal, std::shared_ptr<message_t> message, bool* send)
 {
+
+
+       if(signal.get_message()->get_flags() & CONTINENTAL_BIT_POSITION)
+               signal.set_bit_position(converter_t::continental_bit_position_mess(message->get_length(),
+                                                             signal.get_bit_position(),
+                                                             signal.get_bit_size()));
+       if(signal.get_message()->get_flags() & BIT_POSITION_REVERSED)
+               signal.set_bit_position(converter_t::bit_position_swap(message->get_length(),
+                                                             signal.get_bit_position(),
+                                                             signal.get_bit_size()));
+
        signal_decoder decoder = signal.get_decoder() == nullptr ?
                                                        decode_noop : signal.get_decoder();