Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp1850705pxu; Fri, 9 Oct 2020 01:03:00 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxSjy+cL2U+F89trz9giVOoZzfQgYpT98fBXExP8R94c6tvNI7s5f1ijmK4Q9CYl9vMtWYd X-Received: by 2002:aa7:c491:: with SMTP id m17mr12883967edq.299.1602230579941; Fri, 09 Oct 2020 01:02:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1602230579; cv=none; d=google.com; s=arc-20160816; b=GWC2nzT9BB7SlzBnjxBDX9XwGxXzHag87r8Wb/aiO0DjaZ7ptJJmDTCKWa3SVx+LAl nm7j5ZfZ6zqojpf/B8wFxDuZ0EVD5dZ4JO0xWHwTSMSEM2bCEs7CsuLggIqpxjt0azQH eb/2IgAHhKYF2RlRcEmCEAGg2CIfyHpmJq3AGf85PkYdE3QnMX9d4Fyc1JEYk/ps8bqh iUGezgA16bdH20ED/QKbhcAn8skUjeYzmv4yqoKiPSYVXtY2+x1p4K8YxcQsEC7r+ieT B0X7SC2kOOzi7E4xihHUdRXIBelxW9Q5W4K7wEZRNcYaJt2SC7NWlxSG3LVn7tLys4wP A9Sg== 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=DPr3++TkgD7opBHxWri6P050gTocJAeikYQ/tt45kKI=; b=NcpGE6i2T3yDg/sBGlJAbkPBCE6TZMP07MiK94yb7T3O5u5hM+mxNSjZ+7q4jmfEJa dmDd7nkuC/TwkQYDtB8RZ5sV90KXVRSwIakwHUuhB1OXGac22WFxJrcgZ099JoZKkvt3 v5H9gZpnVVs9tswpwczY/IHni2+m/mqWat1VybVH6aZmojCbCLCzDehMF0qST0YyAw/c JL80PwLCDfPBs14Og1XVKQnROWYNXIpuN8hrEz1I351K1IysIGmmUT8qi8jnMfNun+i0 OXen9Z6V/CxOHH6ccXhfbvFrsDeL+jhsHBFsv1lcO/HC2Pyg6szsdOKPiDALciKFOO5x VmKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ffwll.ch header.s=google header.b=DVC+VHNw; 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 dh21si5224792edb.255.2020.10.09.01.02.36; Fri, 09 Oct 2020 01:02:59 -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=DVC+VHNw; 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 S1732858AbgJIIAz (ORCPT + 99 others); Fri, 9 Oct 2020 04:00:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49556 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732759AbgJIIAP (ORCPT ); Fri, 9 Oct 2020 04:00:15 -0400 Received: from mail-wr1-x443.google.com (mail-wr1-x443.google.com [IPv6:2a00:1450:4864:20::443]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1C545C0613D5 for ; Fri, 9 Oct 2020 01:00:15 -0700 (PDT) Received: by mail-wr1-x443.google.com with SMTP id e17so9219774wru.12 for ; Fri, 09 Oct 2020 01:00:15 -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=DPr3++TkgD7opBHxWri6P050gTocJAeikYQ/tt45kKI=; b=DVC+VHNwYKVtqSii5lIVeaydDB6BLYuTeAJ5rwW+S55nTxLLBIyrPBVsS/L9PHMkF1 q3uw+XyygTSKEzljnhrtd+uqW+UWrHLzIjTm4/9nOxCepU5EL5HwS+mIoRk0TD6zsvng eZRy5dYaQjR4QunmQxA3SCZhsE7Sk5d3j+0PQ= 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=DPr3++TkgD7opBHxWri6P050gTocJAeikYQ/tt45kKI=; b=Mdo9sm2UYvEtVhJV235dFrb8EXj99S4aI/MDcg2qlTDJ6KhShOALNAT10nEllnMTNb 8G0uFtXWEPA6be5qNlObiqenjnhBQwZ7tRE8mNj0afAZOV2uINmD3WUKJx6ccpxyrJ9l g1iqG5akwaxmthVZfJB3vHUXen3o8e/bjl1+2A07IvYPRpcH5Qd1cXX0KSR0fOJ1sYKP TmJnA63w1+Kn3dG8CLxsGnO+Uu+twQTdeBGxTHpu2mjiCxPNScIBguZb3VRPsyq6SWaC 3nsmQkMpRHA3pA3wftrxuxAYufglfUnKHaupTTpjOct8S41v+aA1mdyG2h+j+R3LpOgu GOlQ== X-Gm-Message-State: AOAM531Qszrg6ZlwOSD/FdHz5TsSKnR1wD/IreCDWnuRRoYJwWsNtHN2 8/cRa/D5vYBYOohp4J9w7budtw== X-Received: by 2002:adf:f50e:: with SMTP id q14mr6435975wro.56.1602230413759; Fri, 09 Oct 2020 01:00:13 -0700 (PDT) Received: from phenom.ffwll.local ([2a02:168:57f4:0:efd0:b9e5:5ae6:c2fa]) by smtp.gmail.com with ESMTPSA id u17sm11634118wri.45.2020.10.09.01.00.12 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 09 Oct 2020 01:00:13 -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 , 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, Greg Kroah-Hartman , "Rafael J. Wysocki" , Christian Brauner , "David S. Miller" , Michael Ellerman , Sourabh Jain , Mauro Carvalho Chehab , Nayna Jain Subject: [PATCH v2 15/17] sysfs: Support zapping of binary attr mmaps Date: Fri, 9 Oct 2020 09:59:32 +0200 Message-Id: <20201009075934.3509076-16-daniel.vetter@ffwll.ch> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20201009075934.3509076-1-daniel.vetter@ffwll.ch> References: <20201009075934.3509076-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. 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 --- 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