Received: by 2002:ac0:a594:0:0:0:0:0 with SMTP id m20-v6csp1553568imm; Tue, 15 May 2018 22:49:47 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqoWTZ8kpY3Yv05m7wMOIhRrop4KdQhofoeZ51EpfOOie2s9to2VgYa5nGBbj4nwt9CIA9b X-Received: by 2002:a63:4004:: with SMTP id n4-v6mr11544846pga.248.1526449787596; Tue, 15 May 2018 22:49:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1526449787; cv=none; d=google.com; s=arc-20160816; b=TFITIuQDZW6Bm3fjAV7xZep9Ch9MjGQoop3A1pgtz0M9+AYz37qM1J9W4PkfuA9FAT chTmjv74pxcsAi5qb/fmYUUAVxSu/8CSI3guSK+Gp9LVbawGS7YPAKWnnBt4IEw01xNZ lsbRFwI16ikIda2Q3ADADJLso/qSfSiDpJo3gWpgUavD9g+dMrEpyP9/L1m1BZGlHW0t FQzMI6wYD8yPDoNyRMNfCK9aOhg7CFzIc35MvNSeWbKHjSmYNhZA9d6GHqp82BbVcLE5 0UtLE1bf50O9lzu8v9h3Agde0xCT7I8dl8BRQ2e8QfI08DOhCbtLI5IGyW1ANMxhXbGj tbsg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=SheFcqGfvk/YxMRUbgKBwrFwjOkmf851m/OvKfa2+sA=; b=fXY+CuqemacORhZ9PutkUj/jyiz2EhOQDJhjUxVz+bXrljS/1y0KAEHnbIMwYKQNfn f7GAdQ8TxGN8d+D2gUzugS1JkLip5kLF/QhvyG4VxgNP1lJZgTA33gXT5rvVM+Zu+gTL BSpZle5kHHMLF1lv/WpwCNE3y8Pl/fSgdH0GanCgxtjxjLOBz6jpwnMux9qQk/CPuvp+ OqMRgeDIssu3yZJOdP45Krbu9nUbabfQGuga6KR6D9K7hY4+JHJXGaQlWTmilFS4IhFY 9rD4yAfTTo3wRt32LUNdkZAfv/mhf3/6n8nDOQMS3/XiIw+x2lLjdtGy6bpmj+EJpRU5 3S/A== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=Qs4iInHn; 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 95-v6si1871403plc.383.2018.05.15.22.49.33; Tue, 15 May 2018 22:49:47 -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=bombadil.20170209 header.b=Qs4iInHn; 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 S1752824AbeEPFrl (ORCPT + 99 others); Wed, 16 May 2018 01:47:41 -0400 Received: from bombadil.infradead.org ([198.137.202.133]:58082 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751389AbeEPFox (ORCPT ); Wed, 16 May 2018 01:44:53 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=References:In-Reply-To:Message-Id: Date:Subject:Cc:To:From:Sender:Reply-To:MIME-Version:Content-Type: 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=SheFcqGfvk/YxMRUbgKBwrFwjOkmf851m/OvKfa2+sA=; b=Qs4iInHnKeEVYR/LHZA5u+aTV xikTmEBnkb6U688POi0VgJ6mcqM0oCbXFf/7E2IpxE+7sE1u6elFViVCtWXNzWg3HbjWLfccZC3RW bqKbo/Ptw7rPQ8CNFyP2QX+VwrjSFLMd5F4EIS/YNVNLnE+3olJzq5JtRQ3TGTz8n2uTxuhSvwbES s86tqE+Fc6pBVOClU09ssu7R9xV5/AIHJQhjc7itOOGhuIYjRIf/V0AyBV7nfyEfMOArMX3bCWhWW zfhlhvSsgKUjs+LyaKKHB92qxIlTEEFvyAGcWV3VYgFIk4tD6qcmYPHdDFpJpfQ+kR8BCrdR3VrfV SVI0qfp/Q==; Received: from [93.83.86.253] (helo=localhost) by bombadil.infradead.org with esmtpsa (Exim 4.90_1 #2 (Red Hat Linux)) id 1fIpEf-0008Bu-UZ; Wed, 16 May 2018 05:44:26 +0000 From: Christoph Hellwig To: Souptick Joarder , Matthew Wilcox Cc: linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org, devel@lists.orangefs.org, ceph-devel@vger.kernel.org, linux-btrfs@vger.kernel.org, linux-ext4@vger.kernel.org, ocfs2-devel@oss.oracle.com, linux-mtd@lists.infradead.org, dri-devel@lists.freedesktop.org, lustre-devel@lists.lustre.org, linux-arm-kernel@lists.infradead.org, linux-s390@vger.kernel.org Subject: [PATCH 10/14] vgem: separate errno from VM_FAULT_* values Date: Wed, 16 May 2018 07:43:44 +0200 Message-Id: <20180516054348.15950-11-hch@lst.de> X-Mailer: git-send-email 2.17.0 In-Reply-To: <20180516054348.15950-1-hch@lst.de> References: <20180516054348.15950-1-hch@lst.de> X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org. See http://www.infradead.org/rpr.html Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org And streamline the code in vgem_fault with early returns so that it is a little bit more readable. Signed-off-by: Christoph Hellwig --- drivers/gpu/drm/vgem/vgem_drv.c | 51 +++++++++++++++------------------ 1 file changed, 23 insertions(+), 28 deletions(-) diff --git a/drivers/gpu/drm/vgem/vgem_drv.c b/drivers/gpu/drm/vgem/vgem_drv.c index 2524ff116f00..a261e0aab83a 100644 --- a/drivers/gpu/drm/vgem/vgem_drv.c +++ b/drivers/gpu/drm/vgem/vgem_drv.c @@ -61,12 +61,13 @@ static void vgem_gem_free_object(struct drm_gem_object *obj) kfree(vgem_obj); } -static int vgem_gem_fault(struct vm_fault *vmf) +static vm_fault_t vgem_gem_fault(struct vm_fault *vmf) { struct vm_area_struct *vma = vmf->vma; struct drm_vgem_gem_object *obj = vma->vm_private_data; /* We don't use vmf->pgoff since that has the fake offset */ unsigned long vaddr = vmf->address; + struct page *page; int ret; loff_t num_pages; pgoff_t page_offset; @@ -85,35 +86,29 @@ static int vgem_gem_fault(struct vm_fault *vmf) ret = 0; } mutex_unlock(&obj->pages_lock); - if (ret) { - struct page *page; - - page = shmem_read_mapping_page( - file_inode(obj->base.filp)->i_mapping, - page_offset); - if (!IS_ERR(page)) { - vmf->page = page; - ret = 0; - } else switch (PTR_ERR(page)) { - case -ENOSPC: - case -ENOMEM: - ret = VM_FAULT_OOM; - break; - case -EBUSY: - ret = VM_FAULT_RETRY; - break; - case -EFAULT: - case -EINVAL: - ret = VM_FAULT_SIGBUS; - break; - default: - WARN_ON(PTR_ERR(page)); - ret = VM_FAULT_SIGBUS; - break; - } + if (!ret) + return 0; + + page = shmem_read_mapping_page(file_inode(obj->base.filp)->i_mapping, + page_offset); + if (!IS_ERR(page)) { + vmf->page = page; + return 0; + } + switch (PTR_ERR(page)) { + case -ENOSPC: + case -ENOMEM: + return VM_FAULT_OOM; + case -EBUSY: + return VM_FAULT_RETRY; + case -EFAULT: + case -EINVAL: + return VM_FAULT_SIGBUS; + default: + WARN_ON(PTR_ERR(page)); + return VM_FAULT_SIGBUS; } - return ret; } static const struct vm_operations_struct vgem_gem_vm_ops = { -- 2.17.0