我正在使用一个嵌入式计算机,它必须能够使用UDP与传统计算机通信。当盒子发送大的UDP消息(需要分段)时,每个片段都包含一个UDP报头。因此,如果我想发送一个大的数据报,它将像这样被分成碎片:
[eth hdr][ip hdr][udp hdr][ data 1 ] /* first fragment */
[eth hdr][ip hdr][udp hdr][ data 2 ] /* second fragment */
[eth hdr][ip hdr][udp hdr][ data 3 ] /* last fragment */
我知道这不是惯例,因为udp报头通常只包含在分段消息的第一个ip数据包中。然而,这对于与我需要对话的其他机器进行通信是非常有效的(例如。使用recvfrom),所以我没有理由深入研究并尝试更改它。
然而,我的问题在于阅读消息。盒子似乎期望以同样的方式向其发送零碎的udp数据报。我的意思是,它希望每个ipv4片段都有一个udp报头。在尝试改变这一点之前(这是一个相当特殊和复杂的平台),我想知道是否有任何方法可以配置sendto()或任何其他这样的函数来以这种格式发送udp消息。在监控流量时,我发现那些udp报头不存在。
非常感谢你的帮助。
发布于 2015-02-07 15:09:51
不是的。套接字不是这样工作的。只需编写您自己的sendto包装器,在您选择的任何缓冲区大小边界上手动分割多个UDP数据包中的帧即可。这将会达到你想要的效果。
示例代码如下:
ssize_t fragmented_sendto(int sockfd, const void *buf, size_t len, int flags,
const struct sockaddr *dest_addr, socklen_t addrlen, size_t MAX_PACKET_SIZE)
{
unsigned char* ptr = (unsigned char*) buf;
size_t total = 0;
while (total <= len)
{
size_t newsize = len - total;
if (newsize > MAX_PACKET_SIZE)
{
newsize = MAX_PACKET_SIZE;
}
ssize_t result = sendto(sockfd, ptr, newsize, flags, dest_addr, addrlen);
if (result < 0)
{
// handle error
return -1;
}
else
{
total += result;
ptr += result;
}
}
return (ssize_t)total;
}
https://stackoverflow.com/questions/28374957
复制相似问题