hc
2024-03-26 e0728245c89800c2038c23308f2d88969d5b41c8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
// SPDX-License-Identifier: GPL-2.0
#define _GNU_SOURCE
#include <sys/uio.h>
#include <errno.h>
#include <stdio.h>
#include <sys/socket.h>
#include <fcntl.h>
#include <unistd.h>
#include "../../include/uapi/linux/bpf.h"
#include <asm/unistd.h>
#include "msgfmt.h"
 
FILE *debug_f;
 
static int handle_get_cmd(struct mbox_request *cmd)
{
   switch (cmd->cmd) {
   case 0:
       return 0;
   default:
       break;
   }
   return -ENOPROTOOPT;
}
 
static int handle_set_cmd(struct mbox_request *cmd)
{
   return -ENOPROTOOPT;
}
 
static void loop(void)
{
   while (1) {
       struct mbox_request req;
       struct mbox_reply reply;
       int n;
 
       n = read(0, &req, sizeof(req));
       if (n != sizeof(req)) {
           fprintf(debug_f, "invalid request %d\n", n);
           return;
       }
 
       reply.status = req.is_set ?
           handle_set_cmd(&req) :
           handle_get_cmd(&req);
 
       n = write(1, &reply, sizeof(reply));
       if (n != sizeof(reply)) {
           fprintf(debug_f, "reply failed %d\n", n);
           return;
       }
   }
}
 
int main(void)
{
   debug_f = fopen("/dev/kmsg", "w");
   setvbuf(debug_f, 0, _IOLBF, 0);
   fprintf(debug_f, "<5>Started bpfilter\n");
   loop();
   fclose(debug_f);
   return 0;
}