From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:53162) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1ZWmmL-0005qN-Jy for qemu-devel@nongnu.org; Tue, 01 Sep 2015 10:43:18 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1ZWmmH-0008My-KT for qemu-devel@nongnu.org; Tue, 01 Sep 2015 10:43:17 -0400 Received: from mx1.redhat.com ([209.132.183.28]:54586) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1ZWmmH-0008Mr-G2 for qemu-devel@nongnu.org; Tue, 01 Sep 2015 10:43:13 -0400 Date: Tue, 1 Sep 2015 15:43:08 +0100 From: Stefan Hajnoczi Message-ID: <20150901144308.GE2407@stefanha-thinkpad.redhat.com> References: <1441098383-22585-1-git-send-email-yanghy@cn.fujitsu.com> <1441098383-22585-6-git-send-email-yanghy@cn.fujitsu.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1441098383-22585-6-git-send-email-yanghy@cn.fujitsu.com> Subject: Re: [Qemu-devel] [PATCH v9 05/10] move out net queue structs define List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Yang Hongyang Cc: thuth@redhat.com, zhang.zhanghailiang@huawei.com, lizhijian@cn.fujitsu.com, jasowang@redhat.com, qemu-devel@nongnu.org, mrhines@linux.vnet.ibm.com, armbru@redhat.com On Tue, Sep 01, 2015 at 05:06:18PM +0800, Yang Hongyang wrote: > This will be used by the next patch in this series. > > Signed-off-by: Yang Hongyang > Reviewed-by: Thomas Huth > --- > include/net/queue.h | 19 +++++++++++++++++++ > net/queue.c | 19 ------------------- > 2 files changed, 19 insertions(+), 19 deletions(-) > > diff --git a/include/net/queue.h b/include/net/queue.h > index fc02b33..1d65e47 100644 > --- a/include/net/queue.h > +++ b/include/net/queue.h > @@ -31,6 +31,25 @@ typedef struct NetQueue NetQueue; > > typedef void (NetPacketSent) (NetClientState *sender, ssize_t ret); > > +struct NetPacket { > + QTAILQ_ENTRY(NetPacket) entry; > + NetClientState *sender; > + unsigned flags; > + int size; > + NetPacketSent *sent_cb; > + uint8_t data[0]; > +}; > + > +struct NetQueue { > + void *opaque; > + uint32_t nq_maxlen; > + uint32_t nq_count; > + > + QTAILQ_HEAD(packets, NetPacket) packets; > + > + unsigned delivering:1; > +}; > + Why is it necessary to expose both structs? Normally functions would be added to maintain the abstraction. Instead, you have chosen to access the fields directly - this is probably a bad idea.