36 #include "../include/sobel.hpp"
37 #include "../include/xf_sobel_config.h"
38 #include "../include/sobel_network_library.hpp"
39 #include "../include/sobel_hw_common.hpp"
40 #include "../include/sobel_processing.hpp"
58 stream<NetworkWord> &siSHL_This_Data,
59 stream<NetworkWord> &soTHIS_Shl_Data,
60 stream<NetworkMetaStream> &siNrc_meta,
61 stream<NetworkMetaStream> &soNrc_meta,
62 ap_uint<32> *po_rx_ports
74 stream<DmCmd> &soMemWrCmdP0,
75 stream<DmSts> &siMemWrStsP0,
88 #pragma HLS INTERFACE axis register both port=siSHL_This_Data
89 #pragma HLS INTERFACE axis register both port=soTHIS_Shl_Data
91 #pragma HLS INTERFACE axis register both port=siNrc_meta
92 #pragma HLS INTERFACE axis register both port=soNrc_meta
94 #pragma HLS INTERFACE ap_ovld register port=po_rx_ports name=poROL_NRC_Rx_ports
96 #if HLS_VERSION < 20211
97 #pragma HLS INTERFACE ap_stable register port=pi_rank name=piFMC_ROL_rank
98 #pragma HLS INTERFACE ap_stable register port=pi_size name=piFMC_ROL_size
99 #elif HLS_VERSION >= 20211
100 #pragma HLS stable variable=pi_rank
101 #pragma HLS stable variable=pi_size
103 printf(
"ERROR: Invalid HLS_VERSION=%s\n", HLS_VERSION);
110 #pragma HLS INTERFACE axis register both port=soMemWrCmdP0
111 #pragma HLS INTERFACE axis register both port=siMemWrStsP0
112 #pragma HLS INTERFACE axis register both port=soMemWriteP0
114 #if HLS_VERSION <= 20201
115 #pragma HLS DATA_PACK variable=soMemWrCmdP0 instance=soMemWrCmdP0
116 #pragma HLS DATA_PACK variable=siMemWrStsP0 instance=siMemWrStsP0
117 #elif HLS_VERSION >= 20211
118 #pragma HLS aggregate variable=soMemWrCmdP0 compact=bit
119 #pragma HLS aggregate variable=siMemWrStsP0 compact=bit
121 printf(
"ERROR: Invalid HLS_VERSION=%s\n", HLS_VERSION);
131 const unsigned int max_axi_rw_burst_length = 64;
134 #pragma HLS INTERFACE m_axi depth=ddr_mem_depth port=lcl_mem0 bundle=moMEM_Mp1\
135 max_read_burst_length=max_axi_rw_burst_length max_write_burst_length=max_axi_rw_burst_length offset=direct \
136 num_read_outstanding=16 num_write_outstanding=16 latency=ddr_latency
139 #pragma HLS INTERFACE m_axi depth=ddr_mem_depth port=lcl_mem1 bundle=moMEM_Mp1 \
140 max_read_burst_length=max_axi_rw_burst_length max_write_burst_length=max_axi_rw_burst_length offset=direct \
141 num_read_outstanding=16 num_write_outstanding=16 latency=ddr_latency
149 static stream<NetworkWord> sRxpToTxp_Data(
"sRxpToTxP_Data");
150 static stream<NetworkMetaStream> sRxtoTx_Meta(
"sRxtoTx_Meta");
151 static unsigned int processed_word_rx;
152 static unsigned int processed_bytes_rx;
153 static unsigned int processed_word_tx = 0;
154 static stream<bool> sImageLoaded(
"sImageLoaded");
155 static bool skip_read;
156 static bool write_chunk_to_ddr_pending;
157 static bool ready_to_accept_new_data;
158 static bool signal_init;
161 static stream<ap_uint<MEMDW_512>> img_in_axi_stream (
"img_in_axi_stream");
163 static stream<bool> sMemBurstRx(
"sMemBurstRx");
168 static stream<ap_uint<INPUT_PTR_WIDTH>> img_in_axi_stream (
"img_in_axi_stream");
169 static stream<ap_uint<OUTPUT_PTR_WIDTH>> img_out_axi_stream (
"img_out_axi_stream");
171 static stream<NodeId> sDstNode_sig(
"sDstNode_sig");
175 #pragma HLS stream variable=sRxtoTx_Meta depth=tot_transfers
176 #pragma HLS reset variable=processed_word_rx
177 #pragma HLS reset variable=processed_word_tx
178 #pragma HLS reset variable=processed_bytes_rx
180 #pragma HLS stream variable=sImageLoaded depth=1
181 #pragma HLS reset variable=skip_read
182 #pragma HLS reset variable=write_chunk_to_ddr_pending
184 #pragma HLS reset variable=ready_to_accept_new_data
185 #pragma HLS reset variable=signal_init
186 #pragma HLS STREAM variable=sDstNode_sig depth=1
189 #pragma HLS stream variable=img_in_axi_stream depth=img_in_axi_stream_depth
190 #pragma HLS stream variable=sProcessed_bytes_rx depth=img_in_axi_stream_depth
192 #pragma HLS stream variable=img_in_axi_stream depth=img_in_axi_stream_depth
193 #pragma HLS stream variable=img_out_axi_stream depth=img_out_axi_stream_depth
#define TRANSFERS_PER_CHUNK
void pProcPath(stream< NetworkWord > &sRxpToTxp_Data, stream< NetworkMetaStream > &sRxtoTx_Meta, NetworkMetaStream meta_tmp, varin *instruct, double *out, unsigned int *processed_word_rx, unsigned int *processed_word_proc, unsigned int *struct_loaded)
Processing Path - Main processing FSM for Vitis kernels.
void pPortAndDestionation(ap_uint< 32 > *pi_rank, ap_uint< 32 > *pi_size, stream< NodeId > &sDstNode_sig, ap_uint< 32 > *po_rx_ports)
pPortAndDestionation - Setup the port and the destination rank.
void pRXPath(stream< NetworkWord > &siSHL_This_Data, stream< NetworkMetaStream > &siNrc_meta, stream< NetworkMetaStream > &sRxtoProc_Meta, stream< NetworkWord > &sRxpToProcp_Data, NetworkMetaStream meta_tmp, bool *start_stop, unsigned int *processed_word_rx, unsigned int *processed_bytes_rx)
Receive Path - From SHELL to THIS.
void pTXPath(stream< NetworkWord > &soTHIS_Shl_Data, stream< NetworkMetaStream > &soNrc_meta, stream< NetworkWord > &sProcpToTxp_Data, stream< NetworkMetaStream > &sRxtoTx_Meta, stream< NodeId > &sDstNode_sig, unsigned int *processed_word_tx, ap_uint< 32 > *pi_rank)
Transmit Path - From THIS to SHELL.
void sobel(ap_uint< 32 > *pi_rank, ap_uint< 32 > *pi_size, stream< NetworkWord > &siSHL_This_Data, stream< NetworkWord > &soTHIS_Shl_Data, stream< NetworkMetaStream > &siNrc_meta, stream< NetworkMetaStream > &soNrc_meta, ap_uint< 32 > *po_rx_ports, stream< DmCmd > &soMemWrCmdP0, stream< DmSts > &siMemWrStsP0, stream< Axis< 512 > > &soMemWriteP0, membus_t *lcl_mem0, membus_t *lcl_mem1)
Main process of the Sobel Application directives.