Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp613249ybl; Fri, 24 Jan 2020 06:27:11 -0800 (PST) X-Google-Smtp-Source: APXvYqyrbxNsekpEeAgboNYP+g+3ai7Eg9jT2bu8Dl2FdcOgdqPibKKDMPjhovjX06qItNVQcvNh X-Received: by 2002:a9d:6acd:: with SMTP id m13mr2824212otq.313.1579876031264; Fri, 24 Jan 2020 06:27:11 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579876031; cv=none; d=google.com; s=arc-20160816; b=Kep/6g7LLbpMws1euimSRWbo1VeMtxuCs4E3vDF1QJdh/+dm8pyDAzsOxREDUBFg/Q KMDx9wNgf7/7+EaRlbf6zoJ8PvzV5Xh0ZUpxPYFZU/Iu49H17DfPTQZW2Psabww9iJYG lDDYhQwakRYPxH/OFw4uKYLdvfCZhRROUWE2eyEddBQCyjf4zZvyFTd5L7Uv+1V16PAL thCDiT4IPuWiL80785M865wfnBLwt31bmAwYFgXOiGXz//1XbBOlD1S6j5uPRmbIaM8D bQFaNRR+yBtahf4X/NuZXEJx0r/aot4ZJOzrNx4c0MjMov8pHweHjqWVkp4Jf9WU3LHS oSeg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=/KMywolRDWh4Kkf+yU3h/O/xGfeUUJXkQZO/Z5weCHk=; b=q0/tDLTj4mHSu5Z+e1NlBn6ISgkvyj3wSqGhIexS/ZlwAH4NWMrrf2NiVgCGI/RjqD aJ9KyqnokrFAqkAnwZMrCnRfm3VkjzDvad7Hcn9dCQ2b2nuCyEhFDIUNnG2eJG39I3v4 xjr7Ut/Rf83HBqaOZYSLmBJZSORwkqUB7k3tYbyYIBdW+ljWSL86gZjHLD1qn4LJQHyO SHlrcgvKEalvNhOc3+gar5T6TRS/Ze5rFLmmBd6WkkzR/KZ5WEi6kjI/CfNsaJzWqwtH PqHqheGb+YOlpJ9pecLhkw4jjGtHml0DogvOtGp2B0RT3MfYpase77OtKtxLr1F9xq0p qqjA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=UTF8j8BA; 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 w20si530312oic.103.2020.01.24.06.26.59; Fri, 24 Jan 2020 06:27:11 -0800 (PST) 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=@kernel.org header.s=default header.b=UTF8j8BA; 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 S2390490AbgAXLRW (ORCPT + 99 others); Fri, 24 Jan 2020 06:17:22 -0500 Received: from mail.kernel.org ([198.145.29.99]:54244 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388431AbgAXLRV (ORCPT ); Fri, 24 Jan 2020 06:17:21 -0500 Received: from localhost (ip-213-127-102-57.ip.prioritytelecom.net [213.127.102.57]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id DE50B20708; Fri, 24 Jan 2020 11:17:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579864640; bh=8jsDoSQQObdWl/23S5S/Ie1KvLjzvlQpwUHF6wjzK/o=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=UTF8j8BAP1RnHnouY8jRkmQoHR1KyYbC9iELHWCUVrOljsj6bISyjvXKHy45VqPM+ FHCQnHszcQn5L/evywsC78f/0X2Yj602oEeS2wmydlXSZHrzafu+4CmUM+TgbgwM9v qo6xLjIcu6y0u39R0YijKr72CAb1mpxXNgGrK8xM= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Adrian Hunter , Alexander Shishkin , "Peter Zijlstra (Intel)" , Arnaldo Carvalho de Melo , Jiri Olsa , Linus Torvalds , Stephane Eranian , Thomas Gleixner , Vince Weaver , Ingo Molnar , Sasha Levin Subject: [PATCH 4.19 310/639] perf/core: Fix the address filtering fix Date: Fri, 24 Jan 2020 10:28:00 +0100 Message-Id: <20200124093125.759202603@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200124093047.008739095@linuxfoundation.org> References: <20200124093047.008739095@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Alexander Shishkin [ Upstream commit 52a44f83fc2d64a5e74d5d685fad2fecc7b7a321 ] The following recent commit: c60f83b813e5 ("perf, pt, coresight: Fix address filters for vmas with non-zero offset") changes the address filtering logic to communicate filter ranges to the PMU driver via a single address range object, instead of having the driver do the final bit of math. That change forgets to take into account kernel filters, which are not calculated the same way as DSO based filters. Fix that by passing the kernel filters the same way as file-based filters. This doesn't require any additional changes in the drivers. Reported-by: Adrian Hunter Signed-off-by: Alexander Shishkin Signed-off-by: Peter Zijlstra (Intel) Cc: Arnaldo Carvalho de Melo Cc: Jiri Olsa Cc: Linus Torvalds Cc: Peter Zijlstra Cc: Stephane Eranian Cc: Thomas Gleixner Cc: Vince Weaver Fixes: c60f83b813e5 ("perf, pt, coresight: Fix address filters for vmas with non-zero offset") Link: https://lkml.kernel.org/r/20190329091212.29870-1-alexander.shishkin@linux.intel.com Signed-off-by: Ingo Molnar Signed-off-by: Sasha Levin --- kernel/events/core.c | 37 +++++++++++++++++++++---------------- 1 file changed, 21 insertions(+), 16 deletions(-) diff --git a/kernel/events/core.c b/kernel/events/core.c index 4eef2d42d05c4..751888cbed5c0 100644 --- a/kernel/events/core.c +++ b/kernel/events/core.c @@ -8861,26 +8861,29 @@ static void perf_event_addr_filters_apply(struct perf_event *event) if (task == TASK_TOMBSTONE) return; - if (!ifh->nr_file_filters) - return; - - mm = get_task_mm(event->ctx->task); - if (!mm) - goto restart; + if (ifh->nr_file_filters) { + mm = get_task_mm(event->ctx->task); + if (!mm) + goto restart; - down_read(&mm->mmap_sem); + down_read(&mm->mmap_sem); + } raw_spin_lock_irqsave(&ifh->lock, flags); list_for_each_entry(filter, &ifh->list, entry) { - event->addr_filter_ranges[count].start = 0; - event->addr_filter_ranges[count].size = 0; + if (filter->path.dentry) { + /* + * Adjust base offset if the filter is associated to a + * binary that needs to be mapped: + */ + event->addr_filter_ranges[count].start = 0; + event->addr_filter_ranges[count].size = 0; - /* - * Adjust base offset if the filter is associated to a binary - * that needs to be mapped: - */ - if (filter->path.dentry) perf_addr_filter_apply(filter, mm, &event->addr_filter_ranges[count]); + } else { + event->addr_filter_ranges[count].start = filter->offset; + event->addr_filter_ranges[count].size = filter->size; + } count++; } @@ -8888,9 +8891,11 @@ static void perf_event_addr_filters_apply(struct perf_event *event) event->addr_filters_gen++; raw_spin_unlock_irqrestore(&ifh->lock, flags); - up_read(&mm->mmap_sem); + if (ifh->nr_file_filters) { + up_read(&mm->mmap_sem); - mmput(mm); + mmput(mm); + } restart: perf_event_stop(event, 1); -- 2.20.1