-
Notifications
You must be signed in to change notification settings - Fork 88
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
XDP packets are sent with 2 seconds delays #110
Comments
Just as few questions.
|
Thank you for the reply!
$ ~ sudo ethtool -i enp1s0
|
Just to see if there is a problem with batching, could you send a packet every 200 ms instead and see if you get 10 packets every 2 seconds or 20 packets every 4 seconds? Do you have another NIC you could try with, to see if you get the same behavior? |
With one packet sent every 200ms I get 10 packets every 2 seconds. Unfortunately, for the moment I don't have access to another NIC which supports XDP. |
Everything works as expected now, only after I enabled the XDP_COPY flag. |
Good to know. Then I would guess it is a bug in the i225 zero-copy driver, since it is not used when you use the XDP_COPY flag. We do have a test in our test suite that makes sure that sending a single packet works and is received quickly. Though I have never run it on an i225 since I do not have one in my lab. I would try reporting this to the person that has implemented this support. commit 9acf59a752d4c686739117d3b3129e60af1ba5c1
|
Can you check something for me please? Send one packet every 1 ms and see what you get. Just so I can pinpoint the problem better. |
Sorry for the late reply. With XDP_ZEROCOPY it sends only 1015 packets every 2 seconds when one packet is sent every 1ms. It also sends only 1015 packets every 2 seconds when the packets are sent every 0.1ms (100 us). With XDP_COPY the packets are sent correctly for both sending intervals. |
Weird. It is like the NIC driver in zero-copy mode has a 2 second timer that fires and then sends the packets. |
I wrote a very simple function which sends XDP packets, based on https://github.com/xdp-project/bpf-examples/blob/master/AF_XDP-example/xdpsock.c#L1535. There should be one packet sent once every 100ms. The problem is that all the packets are sent in ~10us after every 2 seconds ( I attached a Whireshark screenshot ). Any ideea why and how to fix this?
This is the function:
static int send_xdp_packet(struct xsk_socket_info* xsk, uint32_t* frame_nb, int batch_size)
{
uint32_t idx, idx_tx, tv_sec, tv_usec;
unsigned int i, rcvd;
}
static void kick_tx(struct xsk_socket_info* xsk)
{
int ret = sendto(xsk_socket__fd(xsk->xsk), NULL, 0, MSG_DONTWAIT, NULL, 0);
if (ret < 0) {
perror("kick_tx");
close(xsk_socket__fd(xsk->xsk));
exit(EXIT_FAILURE);
}
else if ((errno == ENOBUFS) || (errno == EAGAIN) || (errno == EBUSY) || (errno == ENETDOWN)) {
printf("WARNING kick_tx() sendto() returned error: %d\n", errno);
}
}
int main() {
/* ... */
xdp_mode = XDP_FLAGS_DRV_MODE;
xsks = xsk_configure_socket(umem, rx, tx, ifName, xdp_mode);
sockfd = xsk_socket__fd(xsks->xsk);
uint32_t frame_nb = 0;
}
The text was updated successfully, but these errors were encountered: