Message ID | 6b3c166a8d5827a1f6f2a33d85feae1c1633a45d.1607332046.git.yuleixzhang@tencent.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show
Return-Path: <SRS0=nodF=FL=kvack.org=owner-linux-mm@kernel.org> X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-13.5 required=3.0 tests=BAYES_00, DKIM_ADSP_CUSTOM_MED,DKIM_INVALID,DKIM_SIGNED,FREEMAIL_FORGED_FROMDOMAIN, FREEMAIL_FROM,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 76FB5C0018C for <linux-mm@archiver.kernel.org>; Mon, 7 Dec 2020 11:34:36 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 105CA233A0 for <linux-mm@archiver.kernel.org>; Mon, 7 Dec 2020 11:34:35 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 105CA233A0 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=gmail.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 7123F8D0013; Mon, 7 Dec 2020 06:34:35 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id 6C1FF8D0001; Mon, 7 Dec 2020 06:34:35 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 5D8BF8D0013; Mon, 7 Dec 2020 06:34:35 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0040.hostedemail.com [216.40.44.40]) by kanga.kvack.org (Postfix) with ESMTP id 4586F8D0001 for <linux-mm@kvack.org>; Mon, 7 Dec 2020 06:34:35 -0500 (EST) Received: from smtpin14.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay05.hostedemail.com (Postfix) with ESMTP id 092F1181AEF1F for <linux-mm@kvack.org>; Mon, 7 Dec 2020 11:34:35 +0000 (UTC) X-FDA: 77566278510.14.thing20_2b0595a273de Received: from filter.hostedemail.com (10.5.16.251.rfc1918.com [10.5.16.251]) by smtpin14.hostedemail.com (Postfix) with ESMTP id E07741822987B for <linux-mm@kvack.org>; Mon, 7 Dec 2020 11:34:34 +0000 (UTC) X-HE-Tag: thing20_2b0595a273de X-Filterd-Recvd-Size: 4510 Received: from mail-pf1-f196.google.com (mail-pf1-f196.google.com [209.85.210.196]) by imf33.hostedemail.com (Postfix) with ESMTP for <linux-mm@kvack.org>; Mon, 7 Dec 2020 11:34:34 +0000 (UTC) Received: by mail-pf1-f196.google.com with SMTP id d2so5721753pfq.5 for <linux-mm@kvack.org>; Mon, 07 Dec 2020 03:34:34 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=TR3cC+AByvGn3JshaPXKc+3rxof2L0xMPbaiJBaNE0A=; b=PwcAOe4heCxF7XTuomjeUtwKezkdJmM0HmTX1yw4AeADa+3Z5jYH2gnncSNx6tF/dK nqc3OY3XklNb6fsWrMNV9SLhYauoxenHh7jF/LUEVNXitOpU59OZoN9JC+QCR46jU/Ns sBCj+XDvRx916ayOQcnxhHqZ/yh9ih/c9sVknDZkZs/LBEO/v5jpO2wZ1oEm3FfjX0hE TbWTBt9N8W/HGCkWK2IvBBhkklXYtf5Ke1t4gjU8zkkB1O5YL8vGHwUoJwXrPE3CU4Q8 1EfVWBeVZsU6g44z81Jf/b0p33RSG/Hwm+qr6c5NqBuzkeVYX26s7OBZzLc31WX/Gbiy jVjg== 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=TR3cC+AByvGn3JshaPXKc+3rxof2L0xMPbaiJBaNE0A=; b=uTlN5dpBDL0lRpZUCWXib6aebQA04sxBBLkwMJe+Jc5twQUFkZW5JBVfRJQRdNxZRv xtpn0fJsyKMDi2a19AD4ZfHMUOfkfT56Sq0uFLzVoI0kyJBRdXi+CgdX/RStoZgcP0+I 73rzE/f5f0ysAg+CUFz8CRcQiDpy5Gpe7CMxzWIReqCtpuQBg3ygRjp65+JiRWG3Tpc3 dcXmWp7NUQ+iluei/oCMH2zGsFmGyxBiTOOMelIMfAFh0GNofCibd/1FKqh+0Vqmsmh4 VfO2Vl/cNZ5zf4ZLeVq0mQct1gy97wFCV4Bhzf+1ZMHIz7mJ3qU2zSUPMemWAr1GwD5w BDLg== X-Gm-Message-State: AOAM5305UPRc8d0qW/5dgzf/YBETzZlCw6dusbwPTiWpHbNBVtoiLlZN DjRO4+rZdsSww+fzwV6TmyBjva0O6RM= X-Google-Smtp-Source: ABdhPJwrnzftH6wwtqZGjpZb2mr88aLorhMPJcvx0VqVsyAFRqovNa0wPGz47Osa45K8P+P4zlb4ww== X-Received: by 2002:a63:e20:: with SMTP id d32mr18339042pgl.94.1607340873505; Mon, 07 Dec 2020 03:34:33 -0800 (PST) Received: from localhost.localdomain ([203.205.141.39]) by smtp.gmail.com with ESMTPSA id d4sm14219822pfo.127.2020.12.07.03.34.30 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Mon, 07 Dec 2020 03:34:32 -0800 (PST) From: yulei.kernel@gmail.com X-Google-Original-From: yuleixzhang@tencent.com To: linux-mm@kvack.org, akpm@linux-foundation.org, linux-fsdevel@vger.kernel.org, kvm@vger.kernel.org, linux-kernel@vger.kernel.org, naoya.horiguchi@nec.com, viro@zeniv.linux.org.uk, pbonzini@redhat.com Cc: joao.m.martins@oracle.com, rdunlap@infradead.org, sean.j.christopherson@intel.com, xiaoguangrong.eric@gmail.com, kernellwp@gmail.com, lihaiwei.kernel@gmail.com, Yulei Zhang <yuleixzhang@tencent.com>, Chen Zhuo <sagazchen@tencent.com> Subject: [RFC V2 16/37] dmemfs: introduce ->split() to dmemfs_vm_ops Date: Mon, 7 Dec 2020 19:31:09 +0800 Message-Id: <6b3c166a8d5827a1f6f2a33d85feae1c1633a45d.1607332046.git.yuleixzhang@tencent.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <cover.1607332046.git.yuleixzhang@tencent.com> References: <cover.1607332046.git.yuleixzhang@tencent.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: <linux-mm.kvack.org> |
Series |
Enhance memory utilization with DMEMFS
|
expand
|
diff --git a/fs/dmemfs/inode.c b/fs/dmemfs/inode.c index 443f2e1..ab6a492 100644 --- a/fs/dmemfs/inode.c +++ b/fs/dmemfs/inode.c @@ -450,6 +450,13 @@ static bool check_vma_access(struct vm_area_struct *vma, int write) return len; } +static int dmemfs_split(struct vm_area_struct *vma, unsigned long addr) +{ + if (addr & (dmem_page_size(file_inode(vma->vm_file)) - 1)) + return -EINVAL; + return 0; +} + static vm_fault_t dmemfs_fault(struct vm_fault *vmf) { struct vm_area_struct *vma = vmf->vma; @@ -484,6 +491,7 @@ static unsigned long dmemfs_pagesize(struct vm_area_struct *vma) } static const struct vm_operations_struct dmemfs_vm_ops = { + .split = dmemfs_split, .fault = dmemfs_fault, .pagesize = dmemfs_pagesize, .access = dmemfs_access_dmem,