Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp81626pxx; Mon, 26 Oct 2020 04:00:41 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzfMk/PxGFFwyjBK1reIYom/jRendV8Im268uWtdJdwmx575Me5I3ulKFdlBTayUSoXEki0 X-Received: by 2002:a17:906:ad5:: with SMTP id z21mr14393282ejf.461.1603710039957; Mon, 26 Oct 2020 04:00:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603710039; cv=none; d=google.com; s=arc-20160816; b=lAT8KbNsJM0ihEO9CwcAvnxdIUN7nOEFB6nRzjIBjySA5ZVOPJj6t9UX5kU2oQtF9Z T1GzXIjxgWOwyIEOMCqTSlNJ0LJg7Drxpwsa/ZoG6FfcsN8KDiDAiE1+3fyANtB2bTCp UxhPFzF7GgeS+OWhwkz/j72U4ynMw/BryELLopDuuiSHnqpGQIFKcijF0ylhwlGLMlh0 6QZSApGx4Bt4AsTHV3EdU9ee2DNIK/bMAFBTpSdS8sVAWvvkxAXJMxCN2Sd+6YEB3SPW Ypi6ixQAMA5vFa7imA3TqiIglOzsg5DKD6SQWFPxMLegMuWvCjntJEbARKaKTIDobFYN 2m3w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=kkmJ6ZmKgmcd6yJ6bv+WDWEfAJ+atBjrBRrq3Oi6xEA=; b=fo9rUvALzetXIxsoefouB/NmJrqtWRyFz00LMXVJkUmTUZVPT+YIXmP3nEPEn2kcyl Ie5nSqNd4nRllHqv0vTjnJHmjckHbntRJWwByz+ntMg0zQNw47XjuQyzoCOYT5FrbVH/ EO3waJQsJlrX65g3A/6wiFt+9vA13DPBML/2dTsc7SVpgy0FThdbCvTxCFxNkFAn3pUa AE2LSC6rApR0poFnDtIXz2yweKzkrPsNJH3VcRrEed9GGxXZw61Dn+aBVymERsWtaoeW og25zx8fF/wgEbJ0q5I0y15W746MnUYxRJbMP9oyQYslg0S9etFC7Fhzs7K7FMIUkfDl si1A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ffwll.ch header.s=google header.b=AyLC83NY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x16si6730015edq.176.2020.10.26.04.00.17; Mon, 26 Oct 2020 04:00:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@ffwll.ch header.s=google header.b=AyLC83NY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1772893AbgJZK7B (ORCPT + 99 others); Mon, 26 Oct 2020 06:59:01 -0400 Received: from mail-wm1-f66.google.com ([209.85.128.66]:38840 "EHLO mail-wm1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1772827AbgJZK6r (ORCPT ); Mon, 26 Oct 2020 06:58:47 -0400 Received: by mail-wm1-f66.google.com with SMTP id l15so11983911wmi.3 for ; Mon, 26 Oct 2020 03:58:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=kkmJ6ZmKgmcd6yJ6bv+WDWEfAJ+atBjrBRrq3Oi6xEA=; b=AyLC83NYGpnIvuLIFq1n+EYb5RD2pj+8NwDHlA6VA5HNxtYkzMI28Z+nvka4pfH0sh 7KSsyqM99nYdq6/YaTlJmbbjYh4uyOjgl1qj0NJ0XKlEnX0r9gulONO+zSqW5ASovylx roszmSmlQTJoMIlY94WrJZfxbZNLo6JFHhNE0= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=kkmJ6ZmKgmcd6yJ6bv+WDWEfAJ+atBjrBRrq3Oi6xEA=; b=svnSHTknBPrfwJ8t0ZPl5SNQWJNsTGgBbdeV0mJO4X7Zy75US7TosblROfzeacbi2M MDnA/mV2JxrtkyAd/DwQ/pAegMIt/LrdtGNrfOO3EutSJX5ylN5l5+t/6haV/FB1YALO Z1qqUGgAh50EXW1/TZSsbt8cZSQDYxwxbPjFU/2owsRdx8XyAGIEFBL3Azqi4c/0vciF jHb1WMlCZY3EG6Cz7s6SdUFDFFedZCT9sqk7zXeWaA0t/WV6VsktV/m9w0UvoIAnrpp9 nI1zvA3uTkXdthwJEmQArqFDm4kp+U/VLxM3TrjfMKugs5KdJkpxEAHPP7g5bzhJzt5D mvQQ== X-Gm-Message-State: AOAM530YPY17v8mR2orwZtUfdWRyfYL1JmFy1ZzgLgT1+WBHmDMD+e9a LYzQVLhbM9L7a7QuADWnkT/Vq1HZ/rTp+uZ9 X-Received: by 2002:a1c:4306:: with SMTP id q6mr16417557wma.189.1603709925752; Mon, 26 Oct 2020 03:58:45 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:57f4:0:efd0:b9e5:5ae6:c2fa]) by smtp.gmail.com with ESMTPSA id w83sm21165156wmg.48.2020.10.26.03.58.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 26 Oct 2020 03:58:45 -0700 (PDT) From: Daniel Vetter To: DRI Development , LKML Cc: kvm@vger.kernel.org, linux-mm@kvack.org, linux-arm-kernel@lists.infradead.org, linux-samsung-soc@vger.kernel.org, linux-media@vger.kernel.org, linux-s390@vger.kernel.org, Daniel Vetter , Greg Kroah-Hartman , Daniel Vetter , Jason Gunthorpe , Kees Cook , Dan Williams , Andrew Morton , John Hubbard , =?UTF-8?q?J=C3=A9r=C3=B4me=20Glisse?= , Jan Kara , Bjorn Helgaas , linux-pci@vger.kernel.org, "Rafael J. Wysocki" , Christian Brauner , "David S. Miller" , Michael Ellerman , Sourabh Jain , Mauro Carvalho Chehab , Nayna Jain Subject: [PATCH v4 14/15] sysfs: Support zapping of binary attr mmaps Date: Mon, 26 Oct 2020 11:58:17 +0100 Message-Id: <20201026105818.2585306-15-daniel.vetter@ffwll.ch> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20201026105818.2585306-1-daniel.vetter@ffwll.ch> References: <20201026105818.2585306-1-daniel.vetter@ffwll.ch> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We want to be able to revoke pci mmaps so that the same access rules applies as for /dev/kmem. Revoke support for devmem was added in 3234ac664a87 ("/dev/mem: Revoke mappings when a driver claims the region"). The simplest way to achieve this is by having the same filp->f_mapping for all mappings, so that unmap_mapping_range can find them all, no matter through which file they've been created. Since this must be set at open time we need sysfs support for this. Add an optional mapping parameter bin_attr, which is only consulted when there's also an mmap callback, since without mmap support allowing to adjust the ->f_mapping makes no sense. Reviewed-by: Greg Kroah-Hartman Signed-off-by: Daniel Vetter Cc: Jason Gunthorpe Cc: Kees Cook Cc: Dan Williams Cc: Andrew Morton Cc: John Hubbard Cc: Jérôme Glisse Cc: Jan Kara Cc: Dan Williams Cc: linux-mm@kvack.org Cc: linux-arm-kernel@lists.infradead.org Cc: linux-samsung-soc@vger.kernel.org Cc: linux-media@vger.kernel.org Cc: Bjorn Helgaas Cc: linux-pci@vger.kernel.org Cc: Greg Kroah-Hartman Cc: "Rafael J. Wysocki" Cc: Christian Brauner Cc: "David S. Miller" Cc: Michael Ellerman Cc: Sourabh Jain Cc: Daniel Vetter Cc: Mauro Carvalho Chehab Cc: Nayna Jain Signed-off-by: Daniel Vetter --- fs/sysfs/file.c | 11 +++++++++++ include/linux/sysfs.h | 2 ++ 2 files changed, 13 insertions(+) diff --git a/fs/sysfs/file.c b/fs/sysfs/file.c index eb6897ab78e7..9d8ccdb000e3 100644 --- a/fs/sysfs/file.c +++ b/fs/sysfs/file.c @@ -169,6 +169,16 @@ static int sysfs_kf_bin_mmap(struct kernfs_open_file *of, return battr->mmap(of->file, kobj, battr, vma); } +static int sysfs_kf_bin_open(struct kernfs_open_file *of) +{ + struct bin_attribute *battr = of->kn->priv; + + if (battr->mapping) + of->file->f_mapping = battr->mapping; + + return 0; +} + void sysfs_notify(struct kobject *kobj, const char *dir, const char *attr) { struct kernfs_node *kn = kobj->sd, *tmp; @@ -240,6 +250,7 @@ static const struct kernfs_ops sysfs_bin_kfops_mmap = { .read = sysfs_kf_bin_read, .write = sysfs_kf_bin_write, .mmap = sysfs_kf_bin_mmap, + .open = sysfs_kf_bin_open, }; int sysfs_add_file_mode_ns(struct kernfs_node *parent, diff --git a/include/linux/sysfs.h b/include/linux/sysfs.h index 34e84122f635..a17a474d1601 100644 --- a/include/linux/sysfs.h +++ b/include/linux/sysfs.h @@ -164,11 +164,13 @@ __ATTRIBUTE_GROUPS(_name) struct file; struct vm_area_struct; +struct address_space; struct bin_attribute { struct attribute attr; size_t size; void *private; + struct address_space *mapping; ssize_t (*read)(struct file *, struct kobject *, struct bin_attribute *, char *, loff_t, size_t); ssize_t (*write)(struct file *, struct kobject *, struct bin_attribute *, -- 2.28.0