From patchwork Sun Mar 2 09:38:32 2014 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Michael Scherer X-Patchwork-Id: 3749031 Return-Path: X-Original-To: patchwork-linux-nfs@patchwork.kernel.org Delivered-To: patchwork-parsemail@patchwork1.web.kernel.org Received: from mail.kernel.org (mail.kernel.org [198.145.19.201]) by patchwork1.web.kernel.org (Postfix) with ESMTP id 4DC9B9F35F for ; Sun, 2 Mar 2014 09:46:46 +0000 (UTC) Received: from mail.kernel.org (localhost [127.0.0.1]) by mail.kernel.org (Postfix) with ESMTP id 2A62820364 for ; Sun, 2 Mar 2014 09:46:45 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id D1620202E6 for ; Sun, 2 Mar 2014 09:46:43 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751622AbaCBJqm (ORCPT ); Sun, 2 Mar 2014 04:46:42 -0500 Received: from elspeth.ephaone.org ([88.191.186.164]:42196 "EHLO elspeth.ephaone.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751446AbaCBJql (ORCPT ); Sun, 2 Mar 2014 04:46:41 -0500 X-Greylist: delayed 484 seconds by postgrey-1.27 at vger.kernel.org; Sun, 02 Mar 2014 04:46:41 EST Received: from liliana.cdg.redhat.com (localhost [IPv6:::1]) by elspeth.ephaone.org (Postfix) with ESMTP id DF2B910020A; Sun, 2 Mar 2014 10:38:35 +0100 (CET) Received: by liliana.cdg.redhat.com (Postfix, from userid 500) id DB8B7240740; Sun, 2 Mar 2014 10:38:34 +0100 (CET) From: Michael Scherer To: linux-nfs@vger.kernel.org Cc: Michael Scherer Subject: [PATCH] nfsd: permit to use multiple time the -H option Date: Sun, 2 Mar 2014 10:38:32 +0100 Message-Id: <1393753112-14879-1-git-send-email-misc@zarb.org> X-Mailer: git-send-email 1.8.5.3 Sender: linux-nfs-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org X-Spam-Status: No, score=-6.9 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_HI, RP_MATCHES_RCVD, UNPARSEABLE_RELAY autolearn=ham version=3.3.1 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on mail.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP This permit to have 1 nfsd listening on more than 1 interface for multihomed systems, without having to listen on all interfaces and filtering later. --- utils/nfsd/nfsd.c | 51 +++++++++++++++++++++++++++++++++++---------------- utils/nfsd/nfsd.man | 3 ++- 2 files changed, 37 insertions(+), 17 deletions(-) diff --git a/utils/nfsd/nfsd.c b/utils/nfsd/nfsd.c index edeb621..7ab6fcf 100644 --- a/utils/nfsd/nfsd.c +++ b/utils/nfsd/nfsd.c @@ -95,9 +95,10 @@ nfsd_enable_protos(unsigned int *proto4, unsigned int *proto6) int main(int argc, char **argv) { - int count = NFSD_NPROC, c, error = 0, portnum = 0, fd, found_one; + int count = NFSD_NPROC, c, i, error = 0, portnum = 0, fd, found_one; char *p, *progname, *port; - char *haddr = NULL; + char **haddr = NULL; + unsigned int hcounter = 0; int socket_up = 0; unsigned int minorvers = 0; unsigned int minorversset = 0; @@ -118,6 +119,13 @@ main(int argc, char **argv) exit(1); } + haddr = malloc(sizeof(char*)); + if (!haddr) { + fprintf(stderr, "%s: unable to allocate memory.\n", progname); + exit(1); + } + haddr[0] = NULL; + xlog_syslog(0); xlog_stderr(1); @@ -127,17 +135,24 @@ main(int argc, char **argv) xlog_config(D_ALL, 1); break; case 'H': - /* - * for now, this only handles one -H option. Use the - * last one specified. - */ - free(haddr); - haddr = strdup(optarg); - if (!haddr) { + if (hcounter) { + haddr = realloc(haddr, sizeof(char*) * hcounter+1); + + if(!haddr) { + fprintf(stderr, "%s: unable to allocate " + "memory.\n", progname); + exit(1); + } + } + + haddr[hcounter] = strdup(optarg); + if (!haddr[hcounter]) { fprintf(stderr, "%s: unable to allocate " "memory.\n", progname); exit(1); } + + hcounter++; break; case 'P': /* XXX for nfs-server compatibility */ case 'p': @@ -286,16 +301,18 @@ main(int argc, char **argv) * interfaces, these are a no-op. */ nfssvc_setvers(versbits, minorvers, minorversset); - - error = nfssvc_set_sockets(AF_INET, proto4, haddr, port); - if (!error) - socket_up = 1; + + for(i=0; i <= hcounter; i++) { + error = nfssvc_set_sockets(AF_INET, proto4, haddr[i], port); + if (!error) + socket_up = 1; #ifdef IPV6_SUPPORTED - error = nfssvc_set_sockets(AF_INET6, proto6, haddr, port); - if (!error) - socket_up = 1; + error = nfssvc_set_sockets(AF_INET6, proto6, haddr[i], port); + if (!error) + socket_up = 1; #endif /* IPV6_SUPPORTED */ + } set_threads: /* don't start any threads if unable to hand off any sockets */ @@ -328,6 +345,8 @@ set_threads: xlog(L_ERROR, "error starting threads: errno %d (%m)", errno); out: free(port); + for(i=0; i <= hcounter; i++) + free(haddr[i]); free(haddr); free(progname); return (error != 0); diff --git a/utils/nfsd/nfsd.man b/utils/nfsd/nfsd.man index 7de0867..cdc14ba 100644 --- a/utils/nfsd/nfsd.man +++ b/utils/nfsd/nfsd.man @@ -35,7 +35,8 @@ Note that .B lockd (which performs file locking services for NFS) may still accept request on all known network addresses. This may change in future -releases of the Linux Kernel. +releases of the Linux Kernel. This option can be used multiple time +to listen to more than one interface. .TP .B \-p " or " \-\-port port specify a different port to listen on for NFS requests. By default,