ToB企服应用市场:ToB评测及商务社交产业平台

标题: 简析XDP的重定向机制 [打印本页]

作者: 温锦文欧普厨电及净水器总代理    时间: 2022-9-16 17:27
标题: 简析XDP的重定向机制
一. XDP Socket示例解析

源码参见:https://github.com/xdp-project/xdp-tutorial/tree/master/advanced03-AF_XDP
该示例演示了如何通过BPF将网络数据包从XDP Hook点旁路到用户态的XDP Socket,解析过程中为突出重点,将只关注重点代码段,一些函数会被精简,比如:错误处理等
二. BPF 程序 af_xdp_kern.c

BPF程序是运行在内核态的一段代码,如下:
  1. struct bpf_map_def SEC("maps") xsks_map = {
  2.     .type = BPF_MAP_TYPE_XSKMAP,
  3.     .key_size = sizeof(int),
  4.     .value_size = sizeof(int),
  5.     .max_entries = 64,  /* Assume netdev has no more than 64 queues */
  6. };
  7. SEC("xdp_sock")
  8. int xdp_sock_prog(struct xdp_md *ctx)
  9. {
  10.     int index = ctx->rx_queue_index;
  11.     if (bpf_map_lookup_elem(&xsks_map, &index))
  12.         return bpf_redirect_map(&xsks_map, index, 0);
  13.    
  14.     return XDP_PASS;
  15. }
复制代码
综合以上,该bpf程序实现的功能就是:将收到的数据包重定向到xsks_map中指定的XDP Socket
三. 用户态程序 af_xdp_user.c

该程序实现bpf加载到网卡,创建XDP Scoket并绑定到网卡的指定队列,并通过XDP Scoket收发数据,这里仅分析xXDP Scoket相关部分
  1. int main(int argc, char **argv)
  2. {
  3.     ...
  4.     bpf_obj = load_bpf_and_xdp_attach(&cfg);
  5.     map = bpf_object__find_map_by_name(bpf_obj, "xsks_map");
  6.     ...
  7.     xsks_map_fd = bpf_map__fd(map);
  8.     ...
  9.     umem = configure_xsk_umem(packet_buffer, packet_buffer_size);
  10.     ...
  11.     xsk_socket = xsk_configure_socket(&cfg, umem);
  12.     ...
  13.     rx_and_process(&cfg, xsk_socket);
  14.     ...
  15. }
  16. static struct xsk_socket_info *xsk_configure_socket(struct config *cfg,
  17.                             struct xsk_umem_info *umem)
  18. {
  19.     ...
  20.     ret = xsk_socket__create(&xsk_info->xsk, cfg->ifname,
  21.                  cfg->xsk_if_queue, umem->umem, &xsk_info->rx,
  22.                  &xsk_info->tx, &xsk_cfg);
  23.     ...
  24. }
复制代码
  1. static void rx_and_process(struct config *cfg,
  2.                struct xsk_socket_info *xsk_socket)
  3. {
  4.     struct pollfd fds[2];
  5.     int ret, nfds = 1;
  6.     memset(fds, 0, sizeof(fds));
  7.     fds[0].fd = xsk_socket__fd(xsk_socket->xsk);
  8.     fds[0].events = POLLIN;
  9.    
  10.     while(!global_exit) {
  11.         if (cfg->xsk_poll_mode) {
  12.             ret = poll(fds, nfds, -1);
  13.             if (ret <= 0 || ret > 1)
  14.                 continue;
  15.         }
  16.         handle_receive_packets(xsk_socket);
  17.     }
  18. }
复制代码
四. 总结


Enjoy GreatSQL
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4