13 #include <netlink-private/netlink.h> 14 #include <netlink/netfilter/nfnl.h> 15 #include <netlink/netfilter/netfilter.h> 16 #include <netlink/netfilter/queue_msg.h> 17 #include <linux/netfilter.h> 20 #define QUEUE_MSG_ATTR_GROUP (1UL << 0) 21 #define QUEUE_MSG_ATTR_FAMILY (1UL << 1) 22 #define QUEUE_MSG_ATTR_PACKETID (1UL << 2) 23 #define QUEUE_MSG_ATTR_HWPROTO (1UL << 3) 24 #define QUEUE_MSG_ATTR_HOOK (1UL << 4) 25 #define QUEUE_MSG_ATTR_MARK (1UL << 5) 26 #define QUEUE_MSG_ATTR_TIMESTAMP (1UL << 6) 27 #define QUEUE_MSG_ATTR_INDEV (1UL << 7) 28 #define QUEUE_MSG_ATTR_OUTDEV (1UL << 8) 29 #define QUEUE_MSG_ATTR_PHYSINDEV (1UL << 9) 30 #define QUEUE_MSG_ATTR_PHYSOUTDEV (1UL << 10) 31 #define QUEUE_MSG_ATTR_HWADDR (1UL << 11) 32 #define QUEUE_MSG_ATTR_PAYLOAD (1UL << 12) 33 #define QUEUE_MSG_ATTR_VERDICT (1UL << 13) 36 static void nfnl_queue_msg_free_data(
struct nl_object *c)
38 struct nfnl_queue_msg *msg = (
struct nfnl_queue_msg *) c;
43 free(msg->queue_msg_payload);
46 static int nfnl_queue_msg_clone(
struct nl_object *_dst,
struct nl_object *_src)
48 struct nfnl_queue_msg *dst = (
struct nfnl_queue_msg *) _dst;
49 struct nfnl_queue_msg *src = (
struct nfnl_queue_msg *) _src;
52 if (src->queue_msg_payload) {
53 err = nfnl_queue_msg_set_payload(dst, src->queue_msg_payload,
54 src->queue_msg_payload_len);
64 static void nfnl_queue_msg_dump(
struct nl_object *a,
struct nl_dump_params *p)
66 struct nfnl_queue_msg *msg = (
struct nfnl_queue_msg *) a;
67 struct nl_cache *link_cache;
74 if (msg->ce_mask & QUEUE_MSG_ATTR_GROUP)
75 nl_dump(p,
"GROUP=%u ", msg->queue_msg_group);
77 if (msg->ce_mask & QUEUE_MSG_ATTR_INDEV) {
84 nl_dump(p,
"IN=%d ", msg->queue_msg_indev);
87 if (msg->ce_mask & QUEUE_MSG_ATTR_PHYSINDEV) {
91 msg->queue_msg_physindev,
94 nl_dump(p,
"IN=%d ", msg->queue_msg_physindev);
97 if (msg->ce_mask & QUEUE_MSG_ATTR_OUTDEV) {
101 msg->queue_msg_outdev,
104 nl_dump(p,
"OUT=%d ", msg->queue_msg_outdev);
107 if (msg->ce_mask & QUEUE_MSG_ATTR_PHYSOUTDEV) {
111 msg->queue_msg_physoutdev,
114 nl_dump(p,
"PHYSOUT=%d ", msg->queue_msg_physoutdev);
117 if (msg->ce_mask & QUEUE_MSG_ATTR_HWADDR) {
121 for (i = 0; i < msg->queue_msg_hwaddr_len; i++)
122 nl_dump(p,
"%c%02x", i?
':':
'=',
123 msg->queue_msg_hwaddr[i]);
127 if (msg->ce_mask & QUEUE_MSG_ATTR_FAMILY)
129 nl_af2str(msg->queue_msg_family, buf,
sizeof(buf)));
131 if (msg->ce_mask & QUEUE_MSG_ATTR_HWPROTO)
133 nl_ether_proto2str(ntohs(msg->queue_msg_hwproto),
136 if (msg->ce_mask & QUEUE_MSG_ATTR_HOOK)
138 nfnl_inet_hook2str(msg->queue_msg_hook,
141 if (msg->ce_mask & QUEUE_MSG_ATTR_MARK)
142 nl_dump(p,
"MARK=%d ", msg->queue_msg_mark);
144 if (msg->ce_mask & QUEUE_MSG_ATTR_PAYLOAD)
145 nl_dump(p,
"PAYLOADLEN=%d ", msg->queue_msg_payload_len);
147 if (msg->ce_mask & QUEUE_MSG_ATTR_PACKETID)
148 nl_dump(p,
"PACKETID=%u ", msg->queue_msg_packetid);
150 if (msg->ce_mask & QUEUE_MSG_ATTR_VERDICT)
152 nfnl_verdict2str(msg->queue_msg_verdict,
158 nl_cache_put(link_cache);
166 struct nfnl_queue_msg *nfnl_queue_msg_alloc(
void)
171 void nfnl_queue_msg_get(
struct nfnl_queue_msg *msg)
176 void nfnl_queue_msg_put(
struct nfnl_queue_msg *msg)
188 void nfnl_queue_msg_set_group(
struct nfnl_queue_msg *msg, uint16_t group)
190 msg->queue_msg_group = group;
191 msg->ce_mask |= QUEUE_MSG_ATTR_GROUP;
194 int nfnl_queue_msg_test_group(
const struct nfnl_queue_msg *msg)
196 return !!(msg->ce_mask & QUEUE_MSG_ATTR_GROUP);
199 uint16_t nfnl_queue_msg_get_group(
const struct nfnl_queue_msg *msg)
201 return msg->queue_msg_group;
209 void nfnl_queue_msg_set_family(
struct nfnl_queue_msg *msg, uint8_t family)
211 msg->queue_msg_family = family;
212 msg->ce_mask |= QUEUE_MSG_ATTR_FAMILY;
215 int nfnl_queue_msg_test_family(
const struct nfnl_queue_msg *msg)
217 return !!(msg->ce_mask & QUEUE_MSG_ATTR_FAMILY);
220 uint8_t nfnl_queue_msg_get_family(
const struct nfnl_queue_msg *msg)
222 if (msg->ce_mask & QUEUE_MSG_ATTR_FAMILY)
223 return msg->queue_msg_family;
228 void nfnl_queue_msg_set_packetid(
struct nfnl_queue_msg *msg, uint32_t packetid)
230 msg->queue_msg_packetid = packetid;
231 msg->ce_mask |= QUEUE_MSG_ATTR_PACKETID;
234 int nfnl_queue_msg_test_packetid(
const struct nfnl_queue_msg *msg)
236 return !!(msg->ce_mask & QUEUE_MSG_ATTR_PACKETID);
239 uint32_t nfnl_queue_msg_get_packetid(
const struct nfnl_queue_msg *msg)
241 return msg->queue_msg_packetid;
244 void nfnl_queue_msg_set_hwproto(
struct nfnl_queue_msg *msg, uint16_t hwproto)
246 msg->queue_msg_hwproto = hwproto;
247 msg->ce_mask |= QUEUE_MSG_ATTR_HWPROTO;
250 int nfnl_queue_msg_test_hwproto(
const struct nfnl_queue_msg *msg)
252 return !!(msg->ce_mask & QUEUE_MSG_ATTR_HWPROTO);
255 uint16_t nfnl_queue_msg_get_hwproto(
const struct nfnl_queue_msg *msg)
257 return msg->queue_msg_hwproto;
260 void nfnl_queue_msg_set_hook(
struct nfnl_queue_msg *msg, uint8_t hook)
262 msg->queue_msg_hook = hook;
263 msg->ce_mask |= QUEUE_MSG_ATTR_HOOK;
266 int nfnl_queue_msg_test_hook(
const struct nfnl_queue_msg *msg)
268 return !!(msg->ce_mask & QUEUE_MSG_ATTR_HOOK);
271 uint8_t nfnl_queue_msg_get_hook(
const struct nfnl_queue_msg *msg)
273 return msg->queue_msg_hook;
276 void nfnl_queue_msg_set_mark(
struct nfnl_queue_msg *msg, uint32_t mark)
278 msg->queue_msg_mark = mark;
279 msg->ce_mask |= QUEUE_MSG_ATTR_MARK;
282 int nfnl_queue_msg_test_mark(
const struct nfnl_queue_msg *msg)
284 return !!(msg->ce_mask & QUEUE_MSG_ATTR_MARK);
287 uint32_t nfnl_queue_msg_get_mark(
const struct nfnl_queue_msg *msg)
289 return msg->queue_msg_mark;
292 void nfnl_queue_msg_set_timestamp(
struct nfnl_queue_msg *msg,
295 msg->queue_msg_timestamp.tv_sec = tv->tv_sec;
296 msg->queue_msg_timestamp.tv_usec = tv->tv_usec;
297 msg->ce_mask |= QUEUE_MSG_ATTR_TIMESTAMP;
300 int nfnl_queue_msg_test_timestamp(
const struct nfnl_queue_msg *msg)
302 return !!(msg->ce_mask & QUEUE_MSG_ATTR_TIMESTAMP);
305 const struct timeval *nfnl_queue_msg_get_timestamp(
const struct nfnl_queue_msg *msg)
307 if (!(msg->ce_mask & QUEUE_MSG_ATTR_TIMESTAMP))
309 return &msg->queue_msg_timestamp;
312 void nfnl_queue_msg_set_indev(
struct nfnl_queue_msg *msg, uint32_t indev)
314 msg->queue_msg_indev = indev;
315 msg->ce_mask |= QUEUE_MSG_ATTR_INDEV;
318 int nfnl_queue_msg_test_indev(
const struct nfnl_queue_msg *msg)
320 return !!(msg->ce_mask & QUEUE_MSG_ATTR_INDEV);
323 uint32_t nfnl_queue_msg_get_indev(
const struct nfnl_queue_msg *msg)
325 return msg->queue_msg_indev;
328 void nfnl_queue_msg_set_outdev(
struct nfnl_queue_msg *msg, uint32_t outdev)
330 msg->queue_msg_outdev = outdev;
331 msg->ce_mask |= QUEUE_MSG_ATTR_OUTDEV;
334 int nfnl_queue_msg_test_outdev(
const struct nfnl_queue_msg *msg)
336 return !!(msg->ce_mask & QUEUE_MSG_ATTR_OUTDEV);
339 uint32_t nfnl_queue_msg_get_outdev(
const struct nfnl_queue_msg *msg)
341 return msg->queue_msg_outdev;
344 void nfnl_queue_msg_set_physindev(
struct nfnl_queue_msg *msg,
347 msg->queue_msg_physindev = physindev;
348 msg->ce_mask |= QUEUE_MSG_ATTR_PHYSINDEV;
351 int nfnl_queue_msg_test_physindev(
const struct nfnl_queue_msg *msg)
353 return !!(msg->ce_mask & QUEUE_MSG_ATTR_PHYSINDEV);
356 uint32_t nfnl_queue_msg_get_physindev(
const struct nfnl_queue_msg *msg)
358 return msg->queue_msg_physindev;
361 void nfnl_queue_msg_set_physoutdev(
struct nfnl_queue_msg *msg,
364 msg->queue_msg_physoutdev = physoutdev;
365 msg->ce_mask |= QUEUE_MSG_ATTR_PHYSOUTDEV;
368 int nfnl_queue_msg_test_physoutdev(
const struct nfnl_queue_msg *msg)
370 return !!(msg->ce_mask & QUEUE_MSG_ATTR_PHYSOUTDEV);
373 uint32_t nfnl_queue_msg_get_physoutdev(
const struct nfnl_queue_msg *msg)
375 return msg->queue_msg_physoutdev;
378 void nfnl_queue_msg_set_hwaddr(
struct nfnl_queue_msg *msg, uint8_t *hwaddr,
381 if (len >
sizeof(msg->queue_msg_hwaddr))
382 len =
sizeof(msg->queue_msg_hwaddr);
384 msg->queue_msg_hwaddr_len = len;
385 memcpy(msg->queue_msg_hwaddr, hwaddr, len);
386 msg->ce_mask |= QUEUE_MSG_ATTR_HWADDR;
389 int nfnl_queue_msg_test_hwaddr(
const struct nfnl_queue_msg *msg)
391 return !!(msg->ce_mask & QUEUE_MSG_ATTR_HWADDR);
394 const uint8_t *nfnl_queue_msg_get_hwaddr(
const struct nfnl_queue_msg *msg,
397 if (!(msg->ce_mask & QUEUE_MSG_ATTR_HWADDR)) {
402 *len = msg->queue_msg_hwaddr_len;
403 return msg->queue_msg_hwaddr;
406 int nfnl_queue_msg_set_payload(
struct nfnl_queue_msg *msg, uint8_t *payload,
409 void *new_payload = malloc(len);
411 if (new_payload == NULL)
413 memcpy(new_payload, payload, len);
415 free(msg->queue_msg_payload);
417 msg->queue_msg_payload = new_payload;
418 msg->queue_msg_payload_len = len;
419 msg->ce_mask |= QUEUE_MSG_ATTR_PAYLOAD;
423 int nfnl_queue_msg_test_payload(
const struct nfnl_queue_msg *msg)
425 return !!(msg->ce_mask & QUEUE_MSG_ATTR_PAYLOAD);
428 const void *nfnl_queue_msg_get_payload(
const struct nfnl_queue_msg *msg,
int *len)
430 if (!(msg->ce_mask & QUEUE_MSG_ATTR_PAYLOAD)) {
435 *len = msg->queue_msg_payload_len;
436 return msg->queue_msg_payload;
444 void nfnl_queue_msg_set_verdict(
struct nfnl_queue_msg *msg,
445 unsigned int verdict)
447 msg->queue_msg_verdict = verdict;
448 msg->ce_mask |= QUEUE_MSG_ATTR_VERDICT;
451 int nfnl_queue_msg_test_verdict(
const struct nfnl_queue_msg *msg)
453 return !!(msg->ce_mask & QUEUE_MSG_ATTR_VERDICT);
456 unsigned int nfnl_queue_msg_get_verdict(
const struct nfnl_queue_msg *msg)
458 return msg->queue_msg_verdict;
461 static const struct trans_tbl nfnl_queue_msg_attrs[] = {
462 __ADD(QUEUE_MSG_ATTR_GROUP, group),
463 __ADD(QUEUE_MSG_ATTR_FAMILY, family),
464 __ADD(QUEUE_MSG_ATTR_PACKETID, packetid),
465 __ADD(QUEUE_MSG_ATTR_HWPROTO, hwproto),
466 __ADD(QUEUE_MSG_ATTR_HOOK, hook),
467 __ADD(QUEUE_MSG_ATTR_MARK, mark),
468 __ADD(QUEUE_MSG_ATTR_TIMESTAMP, timestamp),
469 __ADD(QUEUE_MSG_ATTR_INDEV, indev),
470 __ADD(QUEUE_MSG_ATTR_OUTDEV, outdev),
471 __ADD(QUEUE_MSG_ATTR_PHYSINDEV, physindev),
472 __ADD(QUEUE_MSG_ATTR_PHYSOUTDEV, physoutdev),
473 __ADD(QUEUE_MSG_ATTR_HWADDR, hwaddr),
474 __ADD(QUEUE_MSG_ATTR_PAYLOAD, payload),
475 __ADD(QUEUE_MSG_ATTR_VERDICT, verdict),
478 static char *nfnl_queue_msg_attrs2str(
int attrs,
char *buf,
size_t len)
480 return __flags2str(attrs, buf, len, nfnl_queue_msg_attrs,
481 ARRAY_SIZE(nfnl_queue_msg_attrs));
486 struct nl_object_ops queue_msg_obj_ops = {
487 .oo_name =
"netfilter/queuemsg",
488 .oo_size =
sizeof(
struct nfnl_queue_msg),
489 .oo_free_data = nfnl_queue_msg_free_data,
490 .oo_clone = nfnl_queue_msg_clone,
496 .oo_attrs2str = nfnl_queue_msg_attrs2str,
Dump object briefly on one line.
void nl_new_line(struct nl_dump_params *params)
Handle a new line while dumping.
struct nl_object * nl_object_alloc(struct nl_object_ops *ops)
Allocate a new object of kind specified by the operations handle.
struct nl_cache * nl_cache_mngt_require_safe(const char *name)
Return cache previously provided via nl_cache_mngt_provide()
void nl_object_get(struct nl_object *obj)
Acquire a reference on a object.
Dump all attributes but no statistics.
void nl_object_put(struct nl_object *obj)
Release a reference from an object.
char * rtnl_link_i2name(struct nl_cache *cache, int ifindex, char *dst, size_t len)
Translate interface index to corresponding link name.
void nl_dump(struct nl_dump_params *params, const char *fmt,...)
Dump a formatted character string.
Dump all attributes including statistics.