Received: by 2002:ac0:a591:0:0:0:0:0 with SMTP id m17-v6csp94924imm; Fri, 6 Jul 2018 14:45:22 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfsL/HczTKCajLpaF37Uazl8qP6hRNShvqQg76gGchIqqq2o17hEz8su4ALa3px25crFbGS X-Received: by 2002:a17:902:6903:: with SMTP id j3-v6mr11556568plk.313.1530913522084; Fri, 06 Jul 2018 14:45:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530913522; cv=none; d=google.com; s=arc-20160816; b=tpUdJPSdxTr0mKByHFy1UKxHEWCfumb9CA5cTt+L2Orxj4ExjbIGcexN2IGfYv3sjf FFaXJZR/8OMFNLD+EQddct1XQ2vzELfETMFimWhQ2yhJaaTXyCfL+JFfkyrgQCru+XgV CbtFpwWpPY+66bOR9JGvX4YrTddcoJ7Al2VeCQoK53nU0todzYZecAP7LiuUdiv9cehK n3ochrBPqJNPCeOpKtBIjinUNcvQ41Y4FmLqkE3pY1t0Go7droZ2Q04K9HJksObNkZRw 0aso+AbidJUM8UW8nKU6mokpbyYZz1julSzetL2RxdnLzT1SKqlbZx4lCQ0c5x4ktS6j 8qEw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=KrIQAzZyjefIKFQ4uitl5ddkRz/kLtCH2yreZba173Y=; b=IX/+UTJfb6FRDguVNj+YU8WFsHnCwo05RT7b9ttI4z3kDn0AVZFzy+xeoL6RqZPle5 PCumpaOyFtwAXPDxUNClnVHLUPowp350KOjAYd3R77f5ZupndB1Pe/dWaCZ5BQk96iQA Xv91CftH5B1CJ3a9j4UL3F/IxopalGhiNkrJCckZWiFl3CpHlo0HRMb6b7WgvdsyTOev 9i2p+A9R+YLo/GPi+zn7HPgMbvnRDFdmYLWGWISm1K7V42HBZBWQxJl/1hRGK1GhW9uF Y9luyMYAnM7O4iUPdKDr9gvA3RYKzeLzen3rwl6QVgA8jKcCfl68jARkHzfAO+EaqdfT qsGA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b="P/ka28H6"; 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 89-v6si8738277plc.428.2018.07.06.14.45.06; Fri, 06 Jul 2018 14:45:22 -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=pass header.i=@joelfernandes.org header.s=google header.b="P/ka28H6"; 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 S932657AbeGFVo2 (ORCPT + 99 others); Fri, 6 Jul 2018 17:44:28 -0400 Received: from mail-pl0-f67.google.com ([209.85.160.67]:41037 "EHLO mail-pl0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932239AbeGFVo1 (ORCPT ); Fri, 6 Jul 2018 17:44:27 -0400 Received: by mail-pl0-f67.google.com with SMTP id w8-v6so3407489ply.8 for ; Fri, 06 Jul 2018 14:44:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=from:to:cc:subject:date:message-id; bh=KrIQAzZyjefIKFQ4uitl5ddkRz/kLtCH2yreZba173Y=; b=P/ka28H6AF24giTrfYp6TurGv4lxHlj6RxRHbcQcILBUw4McUHRo8WsgZqyOVG2Wrt cvE/I5gkiN+os13/GDL8xrlx2BCi4FzuKHxOz/SsL0eBqPArlwrug6Utmir91Ri1/w7h XIR+I4YoL0xXTZ6YxcTlPI0SyOJ4rTCzEfU7M= 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; bh=KrIQAzZyjefIKFQ4uitl5ddkRz/kLtCH2yreZba173Y=; b=WqXklTSN/8V2NpAAG6SLNTKGCBadH1ku6e4xnegEAyHwX5qmBq1j5Sd1s8SzYLwEDl RKqDxvN/qaRn1TCllUi1muyplz89R6Z1LDJPeHURXa/av4v5zA73/TZluA7KwAFdenxA A+Agvi66T0NHITlVa86jJLw6ra8Gtej5qmuxFUdgifUK1Q/UU6K1EitKsxJd3UYtAup+ WZ06f6BVRogbBacaUYMzeOpMd4g0oTRIEc0WRnRVrvI7zMExbY6oEauKZ9UfDnWcHXYC USFUrALJn/izoQd15ZVlJ+k54zgA7lQrI2+VrNc+cPBzvmadqM1f50T76mq/g3nKhGJ8 Jg2Q== X-Gm-Message-State: APt69E0PFO6Mu07xIdiQfVr5e9d3rak//RpnViENV1W+tBr4EG50mwFX w4Gyw8syZDMesmnlBZQ5qBjUOFpp9+w= X-Received: by 2002:a17:902:28ea:: with SMTP id f97-v6mr11357616plb.55.1530913466700; Fri, 06 Jul 2018 14:44:26 -0700 (PDT) Received: from joelaf.mtv.corp.google.com ([2620:0:1000:1600:3122:ea9c:d178:eb]) by smtp.gmail.com with ESMTPSA id c5-v6sm26967844pfe.169.2018.07.06.14.44.25 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 06 Jul 2018 14:44:25 -0700 (PDT) From: Joel Fernandes To: linux-kernel@vger.kernel.org Cc: kernel-team@android.com, Tobias Lindskog , Jeff Vander Stoep , Joel Fernandes , "Arve H" , devel@driverdev.osuosl.org, Greg Kroah-Hartman , Martijn Coenen , Todd Kjos Subject: [PATCH] ashmem: Shrink directly through shmem_fallocate Date: Fri, 6 Jul 2018 14:44:16 -0700 Message-Id: <20180706214416.184691-1-joel@joelfernandes.org> X-Mailer: git-send-email 2.18.0.203.gfac676dfb9-goog Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tobias Lindskog When ashmem_shrink is called from direct reclaim on a user thread, a call to do_fallocate will check for permissions against the security policy of that user thread. It can thus fail by chance if called on a thread that isn't permitted to modify the relevant ashmem areas. Because we know that we have a shmem file underneath, call the shmem implementation of fallocate directly instead of going through the user-space interface for fallocate. Bug: 21951515 Signed-off-by: Tobias Lindskog Signed-off-by: Jeff Vander Stoep Signed-off-by: Joel Fernandes (Google) --- drivers/staging/android/ashmem.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/staging/android/ashmem.c b/drivers/staging/android/ashmem.c index a1a0025b59e0..23ff9ee80386 100644 --- a/drivers/staging/android/ashmem.c +++ b/drivers/staging/android/ashmem.c @@ -444,9 +444,9 @@ ashmem_shrink_scan(struct shrinker *shrink, struct shrink_control *sc) loff_t start = range->pgstart * PAGE_SIZE; loff_t end = (range->pgend + 1) * PAGE_SIZE; - vfs_fallocate(range->asma->file, - FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE, - start, end - start); + range->asma->file->f_op->fallocate(range->asma->file, + FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE, + start, end - start); range->purged = ASHMEM_WAS_PURGED; lru_del(range); -- 2.18.0.203.gfac676dfb9-goog