Received: by 10.192.165.148 with SMTP id m20csp943946imm; Wed, 2 May 2018 11:18:08 -0700 (PDT) X-Google-Smtp-Source: AB8JxZo/jzcSQrKDGP7Ve8mfSeFl2hQqfp6UnG+yc50dcr1F5H13iDMfdGhsS9Pt9snxENyMB6bh X-Received: by 2002:a63:6706:: with SMTP id b6-v6mr16897546pgc.214.1525285088788; Wed, 02 May 2018 11:18:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525285088; cv=none; d=google.com; s=arc-20160816; b=BAjywsqIckv1tXBC44/KLLzEVvitesFwzc8Dko7+I+GoBkJz9KenojL2/ekEnNQTEf UP3Ni1FPBbYAKGLmuuyqBU0eZ4Cvi1e6tAiOowlT5R5uSw6X3WIkoN96VRVjf8QJQkQn 2tLJ7WfnL+kj8mwxErvyzvHj/rWycJoDwxlJY8lYwOPnduM/yK0f9Y9Cr5l+kCyGr/ok YgJBXElhJ+mol5q+TNELGzP3nJGBRQHt1YYvlufer1z/7Cuy7B5yXmUrYUhIu2pxaVs1 M0Xn5COmPC7Kcg0O5iDO3kk+xH0V84OgewUAYh+3CSDwF2w7NJGx6ka02uv+ChcQF+Jc 1pyA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:user-agent:references :message-id:in-reply-to:subject:cc:to:from:date:dkim-signature :arc-authentication-results; bh=AUu3epC5xw8fncCrKkacavX48fvUm0ItWR3iyLadTtM=; b=XX0yxcTVv3wpbazjIAx2vI5H8lrhaoXrsMilGckVR2JIXVIkDBE7QErz/N87h/SbN2 gXJ8p80UZvIba65lQgTECOL5IDgn4RiX1U1HgzLtyY24zWKDBmCYbbMoU0p5d++6kEJ+ 3FVH79EIMkBLCvaFnxXYt8fjDF8D9egwGsDHSrjCiR7qW8500W8CjcgAMAp3WwgSUE5A o0pDEotDZpfVQ94mGwZ13YWWuZHpFMU9LTOTkhwAOtaoHIHz7MtrqMthaaW5kQVEF45E w/Bt1hR+kXmoAxgYpxetEMRC16rFXQiT0i74M/1UbEaQxnFzq1Cxsb2ho/QbGnvgY5R1 +8TQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=casper.20170209 header.b=shV2oxj2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q22si12112674pfi.282.2018.05.02.11.17.24; Wed, 02 May 2018 11:18:08 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@infradead.org header.s=casper.20170209 header.b=shV2oxj2; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751455AbeEBSMo (ORCPT + 99 others); Wed, 2 May 2018 14:12:44 -0400 Received: from casper.infradead.org ([85.118.1.10]:46998 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751181AbeEBSMl (ORCPT ); Wed, 2 May 2018 14:12:41 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=Content-Type:MIME-Version:References: Message-ID:In-Reply-To:Subject:cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=AUu3epC5xw8fncCrKkacavX48fvUm0ItWR3iyLadTtM=; b=shV2oxj2xHRLE7ZQiL/EyV4sV kv+1Rj9WMFY2lJV3CGxudHwGu4KKwd4u/cjxmM0AiVt5C36+BtIxFEp1TKnXSsk5LWJU9N9DrM/uE jJCSTy4DVrECAeFZeZ5IlwUJHAXr1KSG3/mKQ7piKGJP7GtbvTV2icnPnUF2NWZ/e2NuBmogPYVM8 tC2+tTHIpdVSeID/8LotG8AU8kw4iKJ6iy9CgxvKsyxmCgJ8nrvxu5uuh+1fBRoXzd4uo0a3e4dns ezoQE6gebfY8iy6ml4pS990RX5lFDh9y/Nsew29SGzqv2CGo7es+35LHDj/8+JXuPmMVp1z1qpnoa XnU5DLMfw==; Received: from jsimmons (helo=localhost) by casper.infradead.org with local-esmtp (Exim 4.90_1 #2 (Red Hat Linux)) id 1fDwF1-0000Mi-6u; Wed, 02 May 2018 18:12:36 +0000 Date: Wed, 2 May 2018 19:12:35 +0100 (BST) From: James Simmons To: NeilBrown cc: Oleg Drokin , Greg Kroah-Hartman , Andreas Dilger , Linux Kernel Mailing List , Lustre Development List Subject: Re: [PATCH 08/10] staging: lustre: move misc-device registration closer to related code. In-Reply-To: <152514675910.17843.16005951911891583421.stgit@noble> Message-ID: References: <152514658325.17843.11455067361317157487.stgit@noble> <152514675910.17843.16005951911891583421.stgit@noble> User-Agent: Alpine 2.21 (LFD 202 2017-01-01) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20180502_191235_243593_AB287995 X-CRM114-Status: GOOD ( 18.65 ) X-Spam-Score: -0.0 (/) X-Spam-Report: SpamAssassin version 3.4.1 on casper.infradead.org summary: Content analysis details: (-0.0 points, 5.0 required) pts rule name description ---- ---------------------- -------------------------------------------------- -0.0 NO_RELAYS Informational: message was not relayed via SMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org > The ioctl handler for the misc device is in lnet/libcfs/module.c > but is it registered in lnet/libcfs/linux/linux-module.c. > > Keeping related code together make maintenance easier, so move the > code. > > Signed-off-by: NeilBrown Reviewed-by: James Simmons > --- > .../staging/lustre/include/linux/libcfs/libcfs.h | 2 - > .../lustre/lnet/libcfs/linux/linux-module.c | 28 ------------------ > drivers/staging/lustre/lnet/libcfs/module.c | 31 +++++++++++++++++++- > 3 files changed, 30 insertions(+), 31 deletions(-) > > diff --git a/drivers/staging/lustre/include/linux/libcfs/libcfs.h b/drivers/staging/lustre/include/linux/libcfs/libcfs.h > index 6e7754b2f296..9263e151451b 100644 > --- a/drivers/staging/lustre/include/linux/libcfs/libcfs.h > +++ b/drivers/staging/lustre/include/linux/libcfs/libcfs.h > @@ -141,11 +141,9 @@ int libcfs_deregister_ioctl(struct libcfs_ioctl_handler *hand); > int libcfs_ioctl_getdata(struct libcfs_ioctl_hdr **hdr_pp, > const struct libcfs_ioctl_hdr __user *uparam); > int libcfs_ioctl_data_adjust(struct libcfs_ioctl_data *data); > -int libcfs_ioctl(unsigned long cmd, void __user *arg); > > #define _LIBCFS_H > > -extern struct miscdevice libcfs_dev; > /** > * The path of debug log dump upcall script. > */ > diff --git a/drivers/staging/lustre/lnet/libcfs/linux/linux-module.c b/drivers/staging/lustre/lnet/libcfs/linux/linux-module.c > index c8908e816c4c..954b681f9db7 100644 > --- a/drivers/staging/lustre/lnet/libcfs/linux/linux-module.c > +++ b/drivers/staging/lustre/lnet/libcfs/linux/linux-module.c > @@ -166,31 +166,3 @@ int libcfs_ioctl_getdata(struct libcfs_ioctl_hdr **hdr_pp, > kvfree(*hdr_pp); > return err; > } > - > -static long > -libcfs_psdev_ioctl(struct file *file, unsigned int cmd, unsigned long arg) > -{ > - if (!capable(CAP_SYS_ADMIN)) > - return -EACCES; > - > - if (_IOC_TYPE(cmd) != IOC_LIBCFS_TYPE || > - _IOC_NR(cmd) < IOC_LIBCFS_MIN_NR || > - _IOC_NR(cmd) > IOC_LIBCFS_MAX_NR) { > - CDEBUG(D_IOCTL, "invalid ioctl ( type %d, nr %d, size %d )\n", > - _IOC_TYPE(cmd), _IOC_NR(cmd), _IOC_SIZE(cmd)); > - return -EINVAL; > - } > - > - return libcfs_ioctl(cmd, (void __user *)arg); > -} > - > -static const struct file_operations libcfs_fops = { > - .owner = THIS_MODULE, > - .unlocked_ioctl = libcfs_psdev_ioctl, > -}; > - > -struct miscdevice libcfs_dev = { > - .minor = MISC_DYNAMIC_MINOR, > - .name = "lnet", > - .fops = &libcfs_fops, > -}; > diff --git a/drivers/staging/lustre/lnet/libcfs/module.c b/drivers/staging/lustre/lnet/libcfs/module.c > index 4b9acd7bc5cf..3fb150a57f49 100644 > --- a/drivers/staging/lustre/lnet/libcfs/module.c > +++ b/drivers/staging/lustre/lnet/libcfs/module.c > @@ -95,7 +95,7 @@ int libcfs_deregister_ioctl(struct libcfs_ioctl_handler *hand) > } > EXPORT_SYMBOL(libcfs_deregister_ioctl); > > -int libcfs_ioctl(unsigned long cmd, void __user *uparam) > +static int libcfs_ioctl(unsigned long cmd, void __user *uparam) > { > struct libcfs_ioctl_data *data = NULL; > struct libcfs_ioctl_hdr *hdr; > @@ -161,6 +161,35 @@ int libcfs_ioctl(unsigned long cmd, void __user *uparam) > return err; > } > > + > +static long > +libcfs_psdev_ioctl(struct file *file, unsigned int cmd, unsigned long arg) > +{ > + if (!capable(CAP_SYS_ADMIN)) > + return -EACCES; > + > + if (_IOC_TYPE(cmd) != IOC_LIBCFS_TYPE || > + _IOC_NR(cmd) < IOC_LIBCFS_MIN_NR || > + _IOC_NR(cmd) > IOC_LIBCFS_MAX_NR) { > + CDEBUG(D_IOCTL, "invalid ioctl ( type %d, nr %d, size %d )\n", > + _IOC_TYPE(cmd), _IOC_NR(cmd), _IOC_SIZE(cmd)); > + return -EINVAL; > + } > + > + return libcfs_ioctl(cmd, (void __user *)arg); > +} > + > +static const struct file_operations libcfs_fops = { > + .owner = THIS_MODULE, > + .unlocked_ioctl = libcfs_psdev_ioctl, > +}; > + > +struct miscdevice libcfs_dev = { > + .minor = MISC_DYNAMIC_MINOR, > + .name = "lnet", > + .fops = &libcfs_fops, > +}; > + > int lprocfs_call_handler(void *data, int write, loff_t *ppos, > void __user *buffer, size_t *lenp, > int (*handler)(void *data, int write, loff_t pos, > > >