From: Jason Wang <jasowang@redhat.com>
To: Yang Hongyang <yanghy@cn.fujitsu.com>, qemu-devel@nongnu.org
Cc: thuth@redhat.com, zhang.zhanghailiang@huawei.com,
lizhijian@cn.fujitsu.com, mrhines@linux.vnet.ibm.com,
stefanha@redhat.com
Subject: Re: [Qemu-devel] [PATCH v8 00/11] Add a netfilter object and netbuffer filter
Date: Thu, 27 Aug 2015 11:15:08 +0800 [thread overview]
Message-ID: <55DE80BC.4060305@redhat.com> (raw)
In-Reply-To: <1440583182-5828-1-git-send-email-yanghy@cn.fujitsu.com>
On 08/26/2015 05:59 PM, Yang Hongyang wrote:
> This patch add a new object netfilter, capture all network packets.
> Also implement a netbuffer based on this object.
> the "buffer" netfilter could be used by VM FT solutions like
> MicroCheckpointing, to buffer/release packets. Or to simulate
> packet delay.
>
> You can also get the series from:
> https://github.com/macrosheep/qemu/tree/netfilter-v8
>
> Usage:
> -netdev tap,id=bn0
> -netfilter buffer,id=f0,netdev=bn0,chain=in,interval=1000
> -device e1000,netdev=bn0
>
> dynamically add/remove netfilters:
> netfilter_add buffer,id=f0,netdev=bn0,chain=in,interval=1000
> netfilter_del f0
>
> NOTE:
> interval's scale is microsecond.
> chain is optional, and is one of in|out|all, default is "all".
> "in" means this filter will receive packets sent to the @netdev
> "out" means this filter will receive packets sent from the @netdev
> "all" means this filter will receive packets both sent to/from
> the @netdev
>
> TODO:
> - dump
>
> v8:
> - some minor fixes according to Thomas's comments
> - rebased to the latest master branch
>
> v7:
> - print filter info when execute 'info network'
> - addressed Jason's comments
>
> v6:
> - add multiqueue support, please see individual patch for detail
>
> v5:
> - add a sent_cb param to filter receive_iov api
> - squash the 4th patch into patch 3
> - remove dummy sent_cb (buffer filter)
> - addressed Jason's other comments, see individual patches for detail
>
> v4:
> - get rid of struct Filter
> - squash the 4th patch into patch 2
> - fix qemu_netfilter_pass_to_next_iov
> - get rid of bh (buffer filter)
> - release the packet to next filter instead of to receiver (buffer filter)
>
> v3:
> - add an api to pass the packet to next filter
> - remove netfilters when delete netdev
> - add qtest testcases for netfilter
> - addressed comments from Jason
>
> v2:
> - add a chain option to netfilter object
> - move the hook place earlier, before net_queue_send
> - drop the unused api in buffer filter
> - squash buffer filter patches into one
> - remove receive() api from netfilter, only receive_iov() is enough
> - addressed comments from Jason&Thomas
>
> v1:
> initial patch.
>
> Yang Hongyang (11):
> net: add a new object netfilter
> init/cleanup of netfilter object
> netfilter: add netfilter_{add|del} commands
> netfilter: hook packets before net queue send
> move out net queue structs define
> netfilter: add an API to pass the packet to next filter
> netfilter: print filter info associate with the netdev
> net/queue: export qemu_net_queue_append_iov
> netfilter: add a netbuffer filter
> filter/buffer: update command description and help
> tests: add test cases for netfilter object
>
> hmp-commands.hx | 30 +++++
> hmp.c | 29 +++++
> hmp.h | 4 +
> include/net/filter.h | 64 ++++++++++
> include/net/net.h | 1 +
> include/net/queue.h | 26 ++++
> include/qemu/typedefs.h | 1 +
> include/sysemu/sysemu.h | 1 +
> monitor.c | 33 +++++
> net/Makefile.objs | 2 +
> net/filter-buffer.c | 125 ++++++++++++++++++
> net/filter.c | 332 ++++++++++++++++++++++++++++++++++++++++++++++++
> net/filters.h | 17 +++
> net/net.c | 85 +++++++++++++
> net/queue.c | 31 +----
> qapi-schema.json | 100 +++++++++++++++
> qemu-options.hx | 17 +++
> qmp-commands.hx | 57 +++++++++
> tests/.gitignore | 1 +
> tests/Makefile | 2 +
> tests/test-netfilter.c | 194 ++++++++++++++++++++++++++++
> vl.c | 13 ++
> 22 files changed, 1140 insertions(+), 25 deletions(-)
> create mode 100644 include/net/filter.h
> create mode 100644 net/filter-buffer.c
> create mode 100644 net/filter.c
> create mode 100644 net/filters.h
> create mode 100644 tests/test-netfilter.c
>
Looks good to me. After addressing comments of interfaces, I think it
was pretty ready to be merged.
Thanks
next prev parent reply other threads:[~2015-08-27 3:15 UTC|newest]
Thread overview: 42+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-08-26 9:59 [Qemu-devel] [PATCH v8 00/11] Add a netfilter object and netbuffer filter Yang Hongyang
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 01/11] net: add a new object netfilter Yang Hongyang
2015-08-26 14:04 ` Markus Armbruster
2015-08-27 2:34 ` Yang Hongyang
2015-08-28 11:29 ` Markus Armbruster
2015-08-31 1:31 ` Yang Hongyang
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 02/11] init/cleanup of netfilter object Yang Hongyang
2015-08-26 13:13 ` Thomas Huth
2015-08-26 14:41 ` Markus Armbruster
2015-08-26 15:31 ` Eric Blake
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 03/11] netfilter: add netfilter_{add|del} commands Yang Hongyang
2015-08-26 15:17 ` Markus Armbruster
2015-08-26 15:37 ` Eric Blake
2015-08-28 11:37 ` Markus Armbruster
2015-08-31 1:36 ` Yang Hongyang
2015-08-31 7:08 ` Markus Armbruster
2015-08-31 9:01 ` Yang Hongyang
2015-08-31 14:53 ` Eric Blake
2015-09-01 1:24 ` Yang Hongyang
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 04/11] netfilter: hook packets before net queue send Yang Hongyang
2015-08-27 14:35 ` Thomas Huth
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 05/11] move out net queue structs define Yang Hongyang
2015-08-27 14:38 ` Thomas Huth
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 06/11] netfilter: add an API to pass the packet to next filter Yang Hongyang
2015-08-27 15:11 ` Thomas Huth
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 07/11] netfilter: print filter info associate with the netdev Yang Hongyang
2015-08-27 14:46 ` Thomas Huth
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 08/11] net/queue: export qemu_net_queue_append_iov Yang Hongyang
2015-08-27 15:05 ` Thomas Huth
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 09/11] netfilter: add a netbuffer filter Yang Hongyang
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 10/11] filter/buffer: update command description and help Yang Hongyang
2015-08-26 15:55 ` Markus Armbruster
2015-08-27 2:42 ` Yang Hongyang
2015-08-28 11:42 ` Markus Armbruster
2015-08-31 1:30 ` Yang Hongyang
2015-08-26 9:59 ` [Qemu-devel] [PATCH v8 11/11] tests: add test cases for netfilter object Yang Hongyang
2015-08-26 15:58 ` [Qemu-devel] [PATCH v8 00/11] Add a netfilter object and netbuffer filter Markus Armbruster
2015-08-27 2:25 ` Yang Hongyang
2015-08-27 1:05 ` Thomas Huth
2015-08-27 2:24 ` Yang Hongyang
2015-08-27 3:15 ` Jason Wang [this message]
2015-08-31 1:43 ` Yang Hongyang
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=55DE80BC.4060305@redhat.com \
--to=jasowang@redhat.com \
--cc=lizhijian@cn.fujitsu.com \
--cc=mrhines@linux.vnet.ibm.com \
--cc=qemu-devel@nongnu.org \
--cc=stefanha@redhat.com \
--cc=thuth@redhat.com \
--cc=yanghy@cn.fujitsu.com \
--cc=zhang.zhanghailiang@huawei.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.