我们正在开发一个基于Cyclone V的定制板,它是一个运行嵌入式FPGA+ARM内核3.10-ltsi的Linux。我们的目标应用程序是通过TCP千兆位以太网将驻留在内存中的大小为50-400MB的原始海量数据发送到运行在Windows7上的Java客户端。iperf显示我们的主板的TCP吞吐量在6xxMBit/s的范围内。问题:1.我们有一个要求,我们需要在一定的时间间隔内发送原始内存数据。
int total_sent = 0, bytes_sent = 0;
gettimeofday(&t0, 0);
for (total_sent = 0; total_sent < data_size;) {
bytes_sent = write(conn_fd, buf + total_sent, data_size - total_sent);
if (bytes_sent == -1)
break;
total_sent += bytes_sent;
}
gettimeofday(&t1, 0);
unsigned long elapsed_us = (t1.tv_sec - t0.tv_sec) * 1000000 + t1.tv_usec - t0.tv_usec;
double elapsed_s = (double)elapsed_us / 1000000;
printf("Throughput: %f Mbit/s\n", img_size * 8 / elapsed_s / 1000000);
printf("Total bytes sent: %d\n", total_sent);这是测量吞吐量的正确方法吗?
3.在我们的案例中,增加吞吐量的最佳方法是什么?我们希望达到的最大吞吐量是1024MBit/s。
发布于 2014-12-18 15:32:10
如果你坚持使用TCP,也许你可以使用vmsplice() (参见:vmsplice() and TCP)。
祝好运
https://stackoverflow.com/questions/27540014
复制相似问题