5 * Bart De Schuymer <bdschuym@pandora.be>
10 #include <linux/module.h>
11 #include <linux/netfilter/x_tables.h>
12 #include <linux/netfilter_bridge/ebtables.h>
13 #include <linux/netfilter_bridge/ebt_mark_m.h>
16 ebt_mark_mt(const struct sk_buff
*skb
, const struct xt_match_param
*par
)
18 const struct ebt_mark_m_info
*info
= par
->matchinfo
;
20 if (info
->bitmask
& EBT_MARK_OR
)
21 return !!(skb
->mark
& info
->mask
) ^ info
->invert
;
22 return ((skb
->mark
& info
->mask
) == info
->mark
) ^ info
->invert
;
26 ebt_mark_mt_check(const char *table
, const void *e
,
27 const struct xt_match
*match
, void *data
,
28 unsigned int hook_mask
)
30 const struct ebt_mark_m_info
*info
= data
;
32 if (info
->bitmask
& ~EBT_MARK_MASK
)
34 if ((info
->bitmask
& EBT_MARK_OR
) && (info
->bitmask
& EBT_MARK_AND
))
41 static struct xt_match ebt_mark_mt_reg __read_mostly
= {
44 .family
= NFPROTO_BRIDGE
,
46 .checkentry
= ebt_mark_mt_check
,
47 .matchsize
= XT_ALIGN(sizeof(struct ebt_mark_m_info
)),
51 static int __init
ebt_mark_m_init(void)
53 return xt_register_match(&ebt_mark_mt_reg
);
56 static void __exit
ebt_mark_m_fini(void)
58 xt_unregister_match(&ebt_mark_mt_reg
);
61 module_init(ebt_mark_m_init
);
62 module_exit(ebt_mark_m_fini
);
63 MODULE_DESCRIPTION("Ebtables: Packet mark match");
64 MODULE_LICENSE("GPL");