blob: 6cd2feb3e9b364aa4ec75c538fe954e581fbd84e [file] [log] [blame]
Alexei Starovoitova8085782014-12-01 15:06:38 -08001#include <stdio.h>
2#include <assert.h>
3#include <linux/bpf.h>
4#include "libbpf.h"
5#include "bpf_load.h"
Joe Stringer98996942016-12-08 18:46:20 -08006#include "sock_example.h"
Alexei Starovoitova8085782014-12-01 15:06:38 -08007#include <unistd.h>
8#include <arpa/inet.h>
9
10int main(int ac, char **argv)
11{
12 char filename[256];
13 FILE *f;
14 int i, sock;
15
16 snprintf(filename, sizeof(filename), "%s_kern.o", argv[0]);
17
18 if (load_bpf_file(filename)) {
19 printf("%s", bpf_log_buf);
20 return 1;
21 }
22
23 sock = open_raw_sock("lo");
24
25 assert(setsockopt(sock, SOL_SOCKET, SO_ATTACH_BPF, prog_fd,
26 sizeof(prog_fd[0])) == 0);
27
28 f = popen("ping -c5 localhost", "r");
29 (void) f;
30
31 for (i = 0; i < 5; i++) {
32 long long tcp_cnt, udp_cnt, icmp_cnt;
33 int key;
34
35 key = IPPROTO_TCP;
Joe Stringerd40fc182016-12-14 14:43:38 -080036 assert(bpf_map_lookup_elem(map_fd[0], &key, &tcp_cnt) == 0);
Alexei Starovoitova8085782014-12-01 15:06:38 -080037
38 key = IPPROTO_UDP;
Joe Stringerd40fc182016-12-14 14:43:38 -080039 assert(bpf_map_lookup_elem(map_fd[0], &key, &udp_cnt) == 0);
Alexei Starovoitova8085782014-12-01 15:06:38 -080040
41 key = IPPROTO_ICMP;
Joe Stringerd40fc182016-12-14 14:43:38 -080042 assert(bpf_map_lookup_elem(map_fd[0], &key, &icmp_cnt) == 0);
Alexei Starovoitova8085782014-12-01 15:06:38 -080043
Alexei Starovoitov614cd3b2015-03-13 11:57:43 -070044 printf("TCP %lld UDP %lld ICMP %lld bytes\n",
Alexei Starovoitova8085782014-12-01 15:06:38 -080045 tcp_cnt, udp_cnt, icmp_cnt);
46 sleep(1);
47 }
48
49 return 0;
50}