24void Canbus::send_data(uint32_t can_id,
bool use_extended_id,
bool remote_transmission_request,
25 const std::vector<uint8_t> &data) {
28 uint8_t size =
static_cast<uint8_t
>(data.size());
29 if (use_extended_id) {
30 ESP_LOGD(TAG,
"send extended id=0x%08" PRIx32
" rtr=%s size=%d", can_id, TRUEFALSE(remote_transmission_request),
33 ESP_LOGD(TAG,
"send standard id=0x%03" PRIx32
" rtr=%s size=%d", can_id, TRUEFALSE(remote_transmission_request),
36 if (size > CAN_MAX_DATA_LENGTH)
37 size = CAN_MAX_DATA_LENGTH;
39 can_message.
can_id = can_id;
43 for (
int i = 0; i < size; i++) {
44 can_message.data[i] = data[i];
45 ESP_LOGVV(TAG,
" data[%d]=%02x", i, can_message.data[i]);
49 if (use_extended_id) {
50 ESP_LOGW(TAG,
"send to extended id=0x%08" PRIx32
" failed!", can_id);
52 ESP_LOGW(TAG,
"send to standard id=0x%03" PRIx32
" failed!", can_id);
69 int message_counter = 0;
73 ESP_LOGD(TAG,
"received can message (#%d) extended can_id=0x%" PRIx32
" size=%d", message_counter,
76 ESP_LOGD(TAG,
"received can message (#%d) std can_id=0x%" PRIx32
" size=%d", message_counter, can_message.
can_id,
80 std::vector<uint8_t> data;
84 ESP_LOGV(TAG,
" can_message.data[%d]=%02x", i, can_message.data[i]);
85 data.push_back(can_message.data[i]);
93 if ((trigger->can_id_ == (can_message.
can_id & trigger->can_id_mask_)) &&
95 (!trigger->remote_transmission_request_.has_value() ||