From: Hailiang Zhang <zhang.zhanghailiang@huawei.com>
To: Jason Wang <jasowang@redhat.com>, qemu-devel@nongnu.org
Cc: peter.huangpeng@huawei.com, zhangchen.fnst@cn.fujitsu.com,
hongyang.yang@easystack.cn
Subject: Re: [Qemu-devel] [PATCH RFC 2/7] net/filter: Add a 'status' property for filter object
Date: Mon, 25 Jan 2016 14:00:39 +0800 [thread overview]
Message-ID: <56A5BA07.8060408@huawei.com> (raw)
In-Reply-To: <56A5AD13.4030401@redhat.com>
On 2016/1/25 13:05, Jason Wang wrote:
>
>
> On 01/22/2016 04:36 PM, zhanghailiang wrote:
>> With this property, users can control if this filter is 'enable'
>> or 'disable'. The default behavior for filter is enabled.
>>
>> Signed-off-by: zhanghailiang <zhang.zhanghailiang@huawei.com>
>
> Let's squash patch 3 into this for a complete implementation of 'status'.
>
OK, will do that, thanks.
>> ---
>> include/net/filter.h | 1 +
>> net/filter.c | 36 ++++++++++++++++++++++++++++++++++++
>> 2 files changed, 37 insertions(+)
>>
>> diff --git a/include/net/filter.h b/include/net/filter.h
>> index 8a20138..9ed5ec6 100644
>> --- a/include/net/filter.h
>> +++ b/include/net/filter.h
>> @@ -55,6 +55,7 @@ struct NetFilterState {
>> char *netdev_id;
>> NetClientState *netdev;
>> NetFilterDirection direction;
>> + bool enabled;
>> QTAILQ_ENTRY(NetFilterState) next;
>> };
>>
>> diff --git a/net/filter.c b/net/filter.c
>> index 40254bd..f4933cc 100644
>> --- a/net/filter.c
>> +++ b/net/filter.c
>> @@ -117,8 +117,41 @@ static void netfilter_set_direction(Object *obj, int direction, Error **errp)
>> nf->direction = direction;
>> }
>>
>> +static char *netfilter_get_status(Object *obj, Error **errp)
>> +{
>> + NetFilterState *nf = NETFILTER(obj);
>> +
>> + if (nf->enabled) {
>> + return g_strdup("enable");
>> + } else {
>> + return g_strdup("disable");
>> + }
>> +}
>> +
>> +static void netfilter_set_status(Object *obj, const char *str, Error **errp)
>> +{
>> + NetFilterState *nf = NETFILTER(obj);
>> +
>> + if (!strcmp(str, "enable")) {
>> + nf->enabled = true;
>> + } else if (!strcmp(str, "disable")) {
>> + nf->enabled = false;
>> + } else {
>> + error_setg(errp, "Invalid value for netfilter status, "
>> + "should be 'enable' or 'disable'");
>> + }
>> +}
>> +
>> static void netfilter_init(Object *obj)
>> {
>> + NetFilterState *nf = NETFILTER(obj);
>> +
>> + /*
>> + * If not configured with 'status' property, the default status
>> + * for netfilter will be enabled.
>> + */
>> + nf->enabled = true;
>> +
>> object_property_add_str(obj, "netdev",
>> netfilter_get_netdev_id, netfilter_set_netdev_id,
>> NULL);
>> @@ -126,6 +159,9 @@ static void netfilter_init(Object *obj)
>> NetFilterDirection_lookup,
>> netfilter_get_direction, netfilter_set_direction,
>> NULL);
>> + object_property_add_str(obj, "status",
>> + netfilter_get_status, netfilter_set_status,
>> + NULL);
>> }
>>
>> void netfilter_print_info(NetFilterState *nf, char *output_str, int size)
>
>
> .
>
next prev parent reply other threads:[~2016-01-25 6:00 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-01-22 8:36 [Qemu-devel] [PATCH RFC 0/7] Netfilter: Add each netdev a default filter zhanghailiang
2016-01-22 8:36 ` [Qemu-devel] [PATCH RFC 1/7] net/filter: Fix the output information for command 'info network' zhanghailiang
2016-01-25 5:01 ` Jason Wang
2016-01-25 5:58 ` Hailiang Zhang
2016-01-26 3:05 ` Jason Wang
2016-01-26 3:34 ` Hailiang Zhang
2016-01-22 8:36 ` [Qemu-devel] [PATCH RFC 2/7] net/filter: Add a 'status' property for filter object zhanghailiang
2016-01-25 5:05 ` Jason Wang
2016-01-25 6:00 ` Hailiang Zhang [this message]
2016-01-22 8:36 ` [Qemu-devel] [PATCH RFC 3/7] net/filter: Skip the disabled filter when delivering packets zhanghailiang
2016-01-22 9:32 ` Wen Congyang
2016-01-25 5:04 ` Jason Wang
2016-01-25 5:59 ` Hailiang Zhang
2016-01-22 8:36 ` [Qemu-devel] [PATCH RFC 4/7] net/filter: Introduce a helper to add a filter to the netdev zhanghailiang
2016-01-25 5:20 ` Jason Wang
2016-01-25 7:42 ` Hailiang Zhang
2016-01-22 8:36 ` [Qemu-devel] [PATCH RFC 5/7] filter-buffer: Accept zero interval zhanghailiang
2016-01-25 5:19 ` Jason Wang
2016-01-25 7:41 ` Hailiang Zhang
2016-01-22 8:36 ` [Qemu-devel] [PATCH RFC 6/7] net/filter: Add a default filter to each netdev zhanghailiang
2016-01-25 5:18 ` Jason Wang
2016-01-25 7:22 ` Hailiang Zhang
2016-01-25 11:19 ` Hailiang Zhang
2016-01-27 3:29 ` Jason Wang
2016-01-26 3:18 ` Jason Wang
2016-01-26 3:39 ` Hailiang Zhang
2016-01-27 0:37 ` Hailiang Zhang
2016-01-27 5:59 ` Jason Wang
2016-01-27 6:41 ` Hailiang Zhang
2016-01-22 8:36 ` [Qemu-devel] [PATCH RFC 7/7] net/filter: prevent the default filter to be deleted zhanghailiang
2016-01-25 5:25 ` Jason Wang
2016-01-25 7:43 ` Hailiang Zhang
2016-01-22 8:53 ` [Qemu-devel] [PATCH RFC 0/7] Netfilter: Add each netdev a default filter Hailiang Zhang
2016-01-22 10:07 ` Daniel P. Berrange
2016-01-22 10:35 ` Hailiang Zhang
2016-01-22 10:38 ` Daniel P. Berrange
2016-01-25 1:59 ` Hailiang Zhang
2016-01-25 5:24 ` Hailiang Zhang
2016-01-25 3:32 ` Jason Wang
2016-01-25 5:49 ` Hailiang Zhang
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=56A5BA07.8060408@huawei.com \
--to=zhang.zhanghailiang@huawei.com \
--cc=hongyang.yang@easystack.cn \
--cc=jasowang@redhat.com \
--cc=peter.huangpeng@huawei.com \
--cc=qemu-devel@nongnu.org \
--cc=zhangchen.fnst@cn.fujitsu.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.