Return-Path: linux-nfs-owner@vger.kernel.org Received: from mail-ee0-f46.google.com ([74.125.83.46]:47271 "EHLO mail-ee0-f46.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752190Ab1LSMIY (ORCPT ); Mon, 19 Dec 2011 07:08:24 -0500 Received: by eekc4 with SMTP id c4so5365931eek.19 for ; Mon, 19 Dec 2011 04:08:23 -0800 (PST) Message-ID: <4EEF2933.8090405@tonian.com> Date: Mon, 19 Dec 2011 14:08:19 +0200 From: Benny Halevy MIME-Version: 1.0 To: Jeff Layton CC: linux-nfs@vger.kernel.org Subject: Re: [PATCH v2 4/5] nfsd: add a header describing upcall to nfsdcld References: <1323974606-16477-1-git-send-email-jlayton@redhat.com> <1323974606-16477-5-git-send-email-jlayton@redhat.com> In-Reply-To: <1323974606-16477-5-git-send-email-jlayton@redhat.com> Content-Type: text/plain; charset=ISO-8859-1 Sender: linux-nfs-owner@vger.kernel.org List-ID: On 2011-12-15 20:43, Jeff Layton wrote: > The daemon takes a versioned binary struct. Hopefully this should allow > us to revise the struct later if it becomes necessary. > > Signed-off-by: Jeff Layton > --- > include/linux/nfsd/cld.h | 57 ++++++++++++++++++++++++++++++++++++++++++++++ > 1 files changed, 57 insertions(+), 0 deletions(-) > create mode 100644 include/linux/nfsd/cld.h > > diff --git a/include/linux/nfsd/cld.h b/include/linux/nfsd/cld.h > new file mode 100644 > index 0000000..d64a7e7 > --- /dev/null > +++ b/include/linux/nfsd/cld.h > @@ -0,0 +1,57 @@ > +/* > + * fs/nfsd/cld.h - upcall description for nfsdcld communication > + * > + * Copyright (c) 2011 Red Hat, Inc. > + * Author(s): Jeff Layton > + * > + * This program is free software; you can redistribute it and/or modify > + * it under the terms of the GNU General Public License as published by > + * the Free Software Foundation; either version 2 of the License, or > + * (at your option) any later version. > + * > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + * > + * You should have received a copy of the GNU General Public License > + * along with this program; if not, write to the Free Software > + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. > + */ > + > +#ifndef _NFSD_CLD_H > +#define _NFSD_CLD_H > + > +/* latest upcall version available */ > +#define CLD_MAX_UPCALL_VERSION 1 > + > +/* defined by RFC3530 */ > +#define NFS4_OPAQUE_LIMIT 1024 > + > +enum cld_command { > + Cld_Create, /* create a record for this cm_id */ > + Cld_Expire, /* remove record for this cm_id */ > + Cld_Allow, /* is this cm_id allowed? */ > + Cld_GraceDone, /* grace period is complete */ > + Cld_NrToReclaim, /* how many client records need reclaim? */ > +}; > + > +/* representation of long-form NFSv4 client ID */ > +struct cld_name { > + uint16_t cn_len; /* length of cm_id */ > + unsigned char cn_id[NFS4_OPAQUE_LIMIT]; /* client-provided */ > +} __attribute__((packed)); > + > +/* message struct for communication with userspace */ > +struct cld_msg { > + uint8_t cm_vers; /* upcall version */ > + uint8_t cm_cmd; /* upcall command */ > + uint32_t cm_xid; /* transaction id */ > + int16_t cm_status; /* return code */ How about swapping the xid and status members so they'd align better? Benny > + union { > + int64_t cm_gracetime; /* grace period start time */ > + struct cld_name cm_name; > + } __attribute__((packed)) cm_u; > +} __attribute__((packed)); > + > +#endif /* !_NFSD_CLD_H */