2023-05-03 14:01:32 +03:00
|
|
|
|
/*
|
2023-06-06 10:27:01 +03:00
|
|
|
|
* eth_ecat_telegram.cpp
|
2023-05-03 14:01:32 +03:00
|
|
|
|
*
|
2023-06-06 10:27:01 +03:00
|
|
|
|
* Created on: Jun 5, 2023
|
2023-05-03 14:01:32 +03:00
|
|
|
|
* Author: algin
|
|
|
|
|
*/
|
|
|
|
|
|
2023-06-26 18:58:31 +03:00
|
|
|
|
#include "ethernet_industry/eth_ecat_telegram.hpp"
|
2023-05-03 14:01:32 +03:00
|
|
|
|
|
|
|
|
|
namespace free_rtos {
|
|
|
|
|
|
2023-06-06 10:27:01 +03:00
|
|
|
|
namespace telegram {
|
2023-05-03 14:01:32 +03:00
|
|
|
|
|
|
|
|
|
int32_t EcatTelegram::Process(uint8_t *p_data, uint32_t len) {
|
2023-06-09 13:57:20 +03:00
|
|
|
|
// TODO: Не забывать вычитать из указателя sizeof(TEthFrameHeader) !
|
|
|
|
|
unpack(p_data - sizeof(TEthFrameHeader));
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
DebugP_log((char*)"Process started\r\n");
|
|
|
|
|
|
|
|
|
|
for(uint8_t *data = p_data; data < p_data + len; data++) {
|
|
|
|
|
DebugP_log((char*)"0x%01x ", *data);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DebugP_log((char*)"\r\n");
|
|
|
|
|
*/
|
2023-05-26 11:06:54 +03:00
|
|
|
|
|
2023-05-03 14:01:32 +03:00
|
|
|
|
rx_sem_.post();
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-08 12:27:49 +03:00
|
|
|
|
uint32_t EcatTelegram::Sender(uint8_t *p_data, size_t scatter_segment) {
|
|
|
|
|
uint8_t *raw = pack(p_data);
|
|
|
|
|
|
2023-06-09 13:57:20 +03:00
|
|
|
|
//DebugP_log((char*)"Sender started\r\n");
|
|
|
|
|
|
2023-06-08 12:27:49 +03:00
|
|
|
|
return raw - p_data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
uint8_t* EcatTelegram::pack(uint8_t *raw) {
|
|
|
|
|
TEthFrameHeader *p_eth_hdr = new(raw) TEthFrameHeader{ {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF},
|
|
|
|
|
{0x01, 0x01, 0x01, 0x01, 0x01, 0x01},
|
|
|
|
|
ETH_PROT_ECAT_LE };
|
2023-06-26 18:58:31 +03:00
|
|
|
|
TEcatFrameHeader *p_hdr = new(raw + sizeof(TEthFrameHeader)) TEcatFrameHeader{ .bits{ .length = 0,
|
2023-06-08 12:27:49 +03:00
|
|
|
|
.type = static_cast<uint16_t>(ec_network::PROTOCOL_TYPE) } };
|
|
|
|
|
uint8_t *p_datagram_first = raw + sizeof(TEthFrameHeader) + sizeof(TEcatFrameHeader);
|
2023-05-03 14:01:32 +03:00
|
|
|
|
uint8_t *p_datagram_last = p_datagram_first;
|
|
|
|
|
|
2023-05-10 15:10:01 +03:00
|
|
|
|
(void)p_eth_hdr;
|
|
|
|
|
(void)p_hdr;
|
|
|
|
|
|
2023-06-16 13:01:24 +03:00
|
|
|
|
auto queue = datagram_queue_; // Копия очереди
|
2023-06-15 15:16:51 +03:00
|
|
|
|
auto next = queue.dequeue();
|
|
|
|
|
|
2023-05-03 14:01:32 +03:00
|
|
|
|
while(next != nullptr) {
|
2023-06-16 10:18:13 +03:00
|
|
|
|
//DebugP_log((char*)"Packet packed\r\n");
|
|
|
|
|
|
2023-06-08 12:27:49 +03:00
|
|
|
|
p_datagram_last = next->pack(p_datagram_last);
|
2023-06-15 15:16:51 +03:00
|
|
|
|
next = queue.dequeue();
|
2023-05-03 14:01:32 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
p_hdr->bits.length = p_datagram_last - p_datagram_first;
|
2023-06-08 12:27:49 +03:00
|
|
|
|
|
|
|
|
|
return p_datagram_last;
|
2023-05-03 14:01:32 +03:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-08 12:27:49 +03:00
|
|
|
|
uint8_t* EcatTelegram::unpack(uint8_t *raw) {
|
2023-05-26 11:06:54 +03:00
|
|
|
|
TEthFrameHeader *p_eth_hdr = reinterpret_cast<TEthFrameHeader*>(raw);
|
|
|
|
|
TEcatFrameHeader *p_hdr = reinterpret_cast<TEcatFrameHeader*>(raw + sizeof(TEthFrameHeader));
|
|
|
|
|
uint8_t *p_datagram_first = raw + sizeof(TEthFrameHeader) + sizeof(TEcatFrameHeader);
|
2023-05-03 14:01:32 +03:00
|
|
|
|
uint8_t *p_datagram_last = p_datagram_first;
|
|
|
|
|
|
2023-06-13 12:37:00 +03:00
|
|
|
|
if(p_eth_hdr->prot_id != ETH_PROT_ECAT_LE) {
|
|
|
|
|
DebugP_log((char*)"Error: wrong protocol ID\r\n");
|
|
|
|
|
|
|
|
|
|
return raw;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if(p_hdr->bits.type != static_cast<uint16_t>(ec_network::PROTOCOL_TYPE)) {
|
|
|
|
|
DebugP_log((char*)"Error: wrong ethercat protocol type\r\n");
|
|
|
|
|
|
|
|
|
|
return raw;
|
|
|
|
|
}
|
2023-05-10 15:10:01 +03:00
|
|
|
|
|
2023-06-16 13:01:24 +03:00
|
|
|
|
auto queue = datagram_queue_; // Копия очереди
|
2023-06-15 15:16:51 +03:00
|
|
|
|
auto next = queue.dequeue();
|
|
|
|
|
|
2023-05-03 14:01:32 +03:00
|
|
|
|
while(next != nullptr) {
|
2023-06-16 10:18:13 +03:00
|
|
|
|
//DebugP_log((char*)"Packet unpacked\r\n");
|
|
|
|
|
|
2023-06-08 12:27:49 +03:00
|
|
|
|
p_datagram_last = next->unpack(p_datagram_last);
|
2023-06-15 15:16:51 +03:00
|
|
|
|
next = queue.dequeue();
|
2023-05-03 14:01:32 +03:00
|
|
|
|
}
|
2023-06-08 12:27:49 +03:00
|
|
|
|
|
|
|
|
|
return p_datagram_last;
|
2023-05-03 14:01:32 +03:00
|
|
|
|
}
|
|
|
|
|
|
2023-06-16 13:01:24 +03:00
|
|
|
|
void EcatTelegram::transfer() {
|
2023-06-08 12:27:49 +03:00
|
|
|
|
bool stat = eth_stack_.send_pkt(port_id_, ETH_PROT_ECAT_LE, 1);
|
2023-05-03 14:01:32 +03:00
|
|
|
|
|
|
|
|
|
if(stat == false) {
|
2023-06-09 13:57:20 +03:00
|
|
|
|
DebugP_log((char*)"telegram transfer error !\r\n");
|
|
|
|
|
|
2023-05-03 14:01:32 +03:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
rx_sem_.pend();
|
2023-06-08 12:27:49 +03:00
|
|
|
|
|
2023-06-15 15:16:51 +03:00
|
|
|
|
datagram_queue_.clear();
|
2023-05-03 14:01:32 +03:00
|
|
|
|
}
|
2023-06-15 15:16:51 +03:00
|
|
|
|
|
2023-06-16 13:01:24 +03:00
|
|
|
|
void EcatTelegram::transfer(datagram::IEcatDatagram& next) {
|
|
|
|
|
datagram_queue_ + next;
|
2023-05-03 14:01:32 +03:00
|
|
|
|
|
2023-06-16 13:01:24 +03:00
|
|
|
|
transfer();
|
|
|
|
|
}
|
2023-06-15 15:16:51 +03:00
|
|
|
|
|
2023-06-16 13:01:24 +03:00
|
|
|
|
void EcatTelegram::transfer(queue::Queue<datagram::IEcatDatagram>& next) {
|
|
|
|
|
datagram_queue_ + next;
|
2023-06-15 15:16:51 +03:00
|
|
|
|
|
2023-06-16 13:01:24 +03:00
|
|
|
|
transfer();
|
2023-06-15 15:16:51 +03:00
|
|
|
|
}
|
2023-06-16 13:01:24 +03:00
|
|
|
|
|
2023-05-03 14:01:32 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|