2015-10-07 05:52:14 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2015 FUJITSU LIMITED
|
|
|
|
* Author: Yang Hongyang <yanghy@cn.fujitsu.com>
|
|
|
|
*
|
|
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or
|
|
|
|
* later. See the COPYING file in the top-level directory.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef QEMU_NET_FILTER_H
|
|
|
|
#define QEMU_NET_FILTER_H
|
|
|
|
|
2018-02-11 10:36:01 +01:00
|
|
|
#include "qapi/qapi-types-net.h"
|
2015-10-07 05:52:14 +02:00
|
|
|
#include "qom/object.h"
|
|
|
|
#include "qemu-common.h"
|
|
|
|
#include "net/queue.h"
|
|
|
|
|
|
|
|
#define TYPE_NETFILTER "netfilter"
|
|
|
|
#define NETFILTER(obj) \
|
|
|
|
OBJECT_CHECK(NetFilterState, (obj), TYPE_NETFILTER)
|
|
|
|
#define NETFILTER_GET_CLASS(obj) \
|
|
|
|
OBJECT_GET_CLASS(NetFilterClass, (obj), TYPE_NETFILTER)
|
|
|
|
#define NETFILTER_CLASS(klass) \
|
|
|
|
OBJECT_CLASS_CHECK(NetFilterClass, (klass), TYPE_NETFILTER)
|
|
|
|
|
|
|
|
typedef void (FilterSetup) (NetFilterState *nf, Error **errp);
|
|
|
|
typedef void (FilterCleanup) (NetFilterState *nf);
|
|
|
|
/*
|
|
|
|
* Return:
|
|
|
|
* 0: finished handling the packet, we should continue
|
|
|
|
* size: filter stolen this packet, we stop pass this packet further
|
|
|
|
*/
|
|
|
|
typedef ssize_t (FilterReceiveIOV)(NetFilterState *nc,
|
|
|
|
NetClientState *sender,
|
|
|
|
unsigned flags,
|
|
|
|
const struct iovec *iov,
|
|
|
|
int iovcnt,
|
|
|
|
NetPacketSent *sent_cb);
|
|
|
|
|
2016-03-01 06:37:02 +01:00
|
|
|
typedef void (FilterStatusChanged) (NetFilterState *nf, Error **errp);
|
|
|
|
|
2018-09-03 06:38:56 +02:00
|
|
|
typedef void (FilterHandleEvent) (NetFilterState *nf, int event, Error **errp);
|
|
|
|
|
2015-10-07 05:52:14 +02:00
|
|
|
typedef struct NetFilterClass {
|
|
|
|
ObjectClass parent_class;
|
|
|
|
|
|
|
|
/* optional */
|
|
|
|
FilterSetup *setup;
|
|
|
|
FilterCleanup *cleanup;
|
2016-03-01 06:37:02 +01:00
|
|
|
FilterStatusChanged *status_changed;
|
2018-09-03 06:38:56 +02:00
|
|
|
FilterHandleEvent *handle_event;
|
2015-10-07 05:52:14 +02:00
|
|
|
/* mandatory */
|
|
|
|
FilterReceiveIOV *receive_iov;
|
|
|
|
} NetFilterClass;
|
|
|
|
|
|
|
|
|
|
|
|
struct NetFilterState {
|
|
|
|
/* private */
|
|
|
|
Object parent;
|
|
|
|
|
|
|
|
/* protected */
|
|
|
|
char *netdev_id;
|
|
|
|
NetClientState *netdev;
|
|
|
|
NetFilterDirection direction;
|
2016-03-01 06:37:02 +01:00
|
|
|
bool on;
|
2015-10-07 05:52:14 +02:00
|
|
|
QTAILQ_ENTRY(NetFilterState) next;
|
|
|
|
};
|
|
|
|
|
2015-10-07 05:52:15 +02:00
|
|
|
ssize_t qemu_netfilter_receive(NetFilterState *nf,
|
|
|
|
NetFilterDirection direction,
|
|
|
|
NetClientState *sender,
|
|
|
|
unsigned flags,
|
|
|
|
const struct iovec *iov,
|
|
|
|
int iovcnt,
|
|
|
|
NetPacketSent *sent_cb);
|
|
|
|
|
2015-10-07 05:52:18 +02:00
|
|
|
/* pass the packet to the next filter */
|
|
|
|
ssize_t qemu_netfilter_pass_to_next(NetClientState *sender,
|
|
|
|
unsigned flags,
|
|
|
|
const struct iovec *iov,
|
|
|
|
int iovcnt,
|
|
|
|
void *opaque);
|
|
|
|
|
2018-09-03 06:38:56 +02:00
|
|
|
void colo_notify_filters_event(int event, Error **errp);
|
|
|
|
|
2015-10-07 05:52:14 +02:00
|
|
|
#endif /* QEMU_NET_FILTER_H */
|