This file is indexed.

/usr/src/xtables-addons-2.3/ip6table_rawpost.c is in xtables-addons-dkms 2.3-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
/*
 *	rawpost table for ip6_tables
 *	written by Jan Engelhardt, 2008 - 2009
 *	placed in the Public Domain
 */
#include <linux/module.h>
#include <linux/netfilter_ipv6/ip6_tables.h>
#include <net/ip.h>
#include "compat_xtables.h"
#include "compat_rawpost.h"

enum {
	RAWPOST_VALID_HOOKS = 1 << NF_INET_POST_ROUTING,
};

static struct {
	struct ip6t_replace repl;
	struct ip6t_standard entries[1];
	struct ip6t_error term;
} rawpost6_initial __initdata = {
	.repl = {
		.name        = "rawpost",
		.valid_hooks = RAWPOST_VALID_HOOKS,
		.num_entries = 2,
		.size        = sizeof(struct ip6t_standard) +
		               sizeof(struct ip6t_error),
		.hook_entry  = {
			[NF_INET_POST_ROUTING] = 0,
		},
		.underflow = {
			[NF_INET_POST_ROUTING] = 0,
		},
	},
	.entries = {
		IP6T_STANDARD_INIT(NF_ACCEPT),	/* POST_ROUTING */
	},
	.term = IP6T_ERROR_INIT,		/* ERROR */
};

static struct xt_table *rawpost6_ptable;

static struct xt_table rawpost6_itable = {
	.name        = "rawpost",
	.af          = NFPROTO_IPV6,
	.valid_hooks = RAWPOST_VALID_HOOKS,
	.me          = THIS_MODULE,
};

static unsigned int rawpost6_hook_fn(unsigned int hook, sk_buff_t *skb,
    const struct net_device *in, const struct net_device *out,
    int (*okfn)(struct sk_buff *))
{
	return ip6t_do_table(skb, hook, in, out, rawpost6_ptable);
}

static struct nf_hook_ops rawpost6_hook_ops __read_mostly = {
	.hook     = rawpost6_hook_fn,
	.pf       = NFPROTO_IPV6,
	.hooknum  = NF_INET_POST_ROUTING,
	.priority = NF_IP6_PRI_LAST,
	.owner    = THIS_MODULE,
};

static int __init rawpost6_table_init(void)
{
	int ret;

	rawpost6_ptable = ip6t_register_table(&init_net, &rawpost6_itable,
	                  &rawpost6_initial.repl);
	if (IS_ERR(rawpost6_ptable))
		return PTR_ERR(rawpost6_ptable);

	ret = nf_register_hook(&rawpost6_hook_ops);
	if (ret < 0)
		goto out;

	return ret;

 out:
	ip6t_unregister_table(rawpost6_ptable);
	return ret;
}

static void __exit rawpost6_table_exit(void)
{
	nf_unregister_hook(&rawpost6_hook_ops);
	ip6t_unregister_table(rawpost6_ptable);
}

module_init(rawpost6_table_init);
module_exit(rawpost6_table_exit);
MODULE_AUTHOR("Jan Engelhardt ");
MODULE_LICENSE("GPL");