79 lines
2.5 KiB
C++
79 lines
2.5 KiB
C++
/*
|
||
* eth_rx_dma.hpp
|
||
*
|
||
* Created on: 6 <20><><EFBFBD>. 2023 <20>.
|
||
* Author: sychev
|
||
*/
|
||
|
||
#ifndef FREE_RTOS_ETHERNET_ETH_RX_DMA_HPP_
|
||
#define FREE_RTOS_ETHERNET_ETH_RX_DMA_HPP_
|
||
|
||
#include <cstdint>
|
||
#include <networking/enet/core/include/dma/udma/enet_udma.h>
|
||
#include <networking/enet/core/include/core/enet_dma.h>
|
||
#include <networking/enet/core/include/core/enet_queue.h>
|
||
|
||
#include "free_rtos/handler_store/handler_store.hpp"
|
||
#include "free_rtos/semaphore/semaphore.hpp"
|
||
#include "free_rtos/task/task.hpp"
|
||
#include "free_rtos/profiler/quick_profiler_static.hpp"
|
||
|
||
#include "free_rtos/ethernet/eth_task_settings.hpp"
|
||
#include "free_rtos/ethernet/eth_frame.h"
|
||
#include "free_rtos/ethernet_ip/eth_stack_iface.hpp"
|
||
|
||
namespace free_rtos {
|
||
|
||
class EthRxFlow {
|
||
public:
|
||
EthRxFlow(TEthFrameMacAddr& mac_addr, EthStackIface& eth_stack);
|
||
|
||
bool open(uint32_t id, int32_t enetDmaRxChId, UBaseType_t task_priority, UBaseType_t task_stack_size);
|
||
|
||
bool is_open() {return open_;}
|
||
|
||
void set_passive() { passive_mode_ = true; }
|
||
|
||
private:
|
||
|
||
friend void rxIsrHandler(void *appData); /// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
|
||
friend void rxTaskHandler(void *appData); ///<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
|
||
void initRxFreePktQ(void * appPriv, EnetDma_PktQ * p_packet_queue, uint32_t qCount);
|
||
void submitFreeRxPkts(uint32_t qCount);
|
||
|
||
void rxProcessPktTask(); ///<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
|
||
private:
|
||
enum SignalsId {
|
||
e_signalRxPkt, /// <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
e_signalTotal
|
||
};
|
||
|
||
uint32_t id_; /// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
bool open_; /// <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>, <20><><EFBFBD> dma <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
|
||
Semaphore sem_[e_signalTotal]; /// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
|
||
Task rx_task; /// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
|
||
TEthFrameMacAddr& mac_addr_; /// mac <20><><EFBFBD><EFBFBD><EFBFBD>
|
||
|
||
EthStackIface& eth_stack_;
|
||
|
||
uint32_t rx_start_flow_idx_;
|
||
uint32_t rx_flow_idx_;
|
||
EnetDma_RxChHandle dma_handle_;
|
||
EnetDma_PktQ rx_free_pktq_;
|
||
|
||
bool passive_mode_; /// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <20><> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
};
|
||
|
||
|
||
}
|
||
|
||
|
||
|
||
#endif /* FREE_RTOS_ETHERNET_ETH_RX_DMA_HPP_ */
|