2 * Copyright (C) 2015, 2016 "IoT.bzh"
3 * Author "Romain Forlot" <romain.forlot@iot.bzh>
4 * Author "Loic Collignon" <loic.collignon@iot.bzh>
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.apache.org/licenses/LICENSE-2.0
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
19 #include <linux/can.h>
20 #include <linux/can/raw.h>
22 #include <sys/timeb.h>
24 #include <afb/afb-binding.h>
26 #include "can-utils.hpp"
27 #include "can-decoder.hpp"
28 #include "openxc.pb.h"
37 void can_decode_message(can_bus_t &can_bus)
39 can_message_t can_message;
40 std:vector <CanSignal> signals;
41 std:vector <CanSignal>::iterator signals_i;
42 openxc_VehicleMessage vehicle_message;
43 openxc_DynamicField search_key, ret;
50 if(can_message = can_bus.next_can_message())
52 /* First we have to found which CanSignal is */
53 search_key = build_DynamicField(openxc_DynamicField_Type::openxc_DynamicField_Type_NUM, (double)can_message.get_id())
55 signals = find_can_signals(search_key);
57 /* Decoding the message ! Don't kill the messenger ! */
58 for(const auto& sig : signals)
60 subscribed_signals_i = subscribed_signals.find(sig);
62 if(subscribed_signals_i != subscribed_signals.end() &&
63 afb_event_is_valid(subscribed_signals_i->second))
65 ret = decoder.decodeSignal(sig, can_message, getSignals(), &send);
67 s_message = build_SimpleMessage(sig.genericName, ret);
69 vehicle_message = build_VehicleMessage_with_SimpleMessage(openxc_DynamicField_Type::openxc_DynamicField_Type_NUM, s_message);
70 vehicle_message_q.push(vehicle_message);
78 * Build a specific VehicleMessage containing a SimpleMessage.
80 openxc_VehicleMessage build_VehicleMessage_with_SimpleMessage(openxc_DynamicField_Type type,
81 const openxc_SimpleMessage& message)
84 long long int timestamp_msec;
86 openxc_VehicleMessage v = {0};
90 timestamp_msec = ((long long int) t_msec.time) * 1000ll +
91 (long long int) t_msec.millitm;
94 v.type = openxc_VehicleMessage_Type::openxc_VehicleMessage_Type_SIMPLE;
95 v.has_simple_message = true;
96 v.simple_message = message;
97 v.has_timestamp = true;
98 v.timestamp = timestamp_msec;
104 v.type = openxc_VehicleMessage_Type::openxc_VehicleMessage_Type_SIMPLE;
105 v.has_simple_message = true;
106 v.simple_message = message;
112 * Build an openxc_SimpleMessage associating a name to an openxc_DynamicField
114 openxc_SimpleMessage build_SimpleMessage(const std::string& name, const openxc_DynamicField& value)
117 openxc_SimpleMessage s = {0};
120 ::strncpy(s.name, name.c_str(), 100);
128 * Build an openxc_DynamicField depending what we pass as argument
130 openxc_DynamicField build_DynamicField(const std::string& value)
132 openxc_DynamicField d = {0}
134 d.type = openxc_DynamicField_Type_STRING;
136 d.has_string_value = true;
137 ::strncpy(d.string_value, value.c_tr(), 100);
143 * Build an openxc_DynamicField depending what we pass as argument
145 openxc_DynamicField build_DynamicField(double value)
147 openxc_DynamicField d = {0}
149 d.type = openxc_DynamicField_Type_NUM;
151 d.has_numeric_value = true;
152 d.numeric_value = field;
158 * Build an openxc_DynamicField depending what we pass as argument
160 openxc_DynamicField build_DynamicField(bool value)
162 openxc_DynamicField d = {0}
164 d.type = openxc_DynamicField_Type_BOOL;
166 d.has_boolean_value = true;
167 d.boolean_value = field;