Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp2179178ybz; Thu, 30 Apr 2020 12:16:37 -0700 (PDT) X-Google-Smtp-Source: APiQypJlQcH5Ye0g5nQCk8PS8yJHVcjRjyM2pKPaeUxYhfpkcOk3rADSP+sxqVo6C8PO3NBeRcpg X-Received: by 2002:a17:906:d926:: with SMTP id rn6mr4092220ejb.169.1588274197484; Thu, 30 Apr 2020 12:16:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588274197; cv=none; d=google.com; s=arc-20160816; b=ph5qpUbB+ZAfqXSir87+e+iIrKFf9q97lkCykV39Ha4b9dEb7ep0mWd61tOnDmQweI iY7GxhDtzVvIcxzQN5YK5CjBmyepTUdGGDoP6itmd2J8sXlCsMnNZpDBIyInOH6R6iKb NcmQRGnSDQrN/cFjKxLPRc/DEpwtjxRAfeJ3Ai942tyo4xt6fVE9MN/moVWsNGuMCNvY JO/OosE6mKrWiz8d7atdl5HFFtpUwGuauQ4av1nKOk7/JVUnBlZNcitYV8bwDZxPSh9G IaTkyP/do4hWY+iMyEx3lBnOHaoQUAAB+t+szBC0zUGnbLFPR/20YWkvMzMrJj8TwHmA qxug== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=8FWj8o+JQSbaDaHtJyCGwJBboqEAgrLgGm47tTLZxJ4=; b=dfb1Z9G4ekJMG0+gPA3wEPieqlAiIMCDZXMkjF9HosW8sW9PCM0vTMYIxLwUJ/moGi gXXN0Rg8pTIRHcyO1oSwRgS8qdsh/cCnhm7HUKL+pS2VvoIWZ2iljdz2LMryvEGQAHbu nb/4MyTnjSFjfpEAtrR/47v2Tldu+VfSCW1VwU8ecXaYID93m3gBnq9DlRwupMdljgMv jzzcaSkkrc+jUGvQ38Oro564MCtz5GdkDB9187o16wAMMRatTc3qIOH0z05X3YXB2aAc CoTzMBz99WOR0xkIewtKrtiU3iN4oG4ODxOJAP/c9fziMxAsKgchbUZVN04wMYI3gAhM Fypw== ARC-Authentication-Results: i=1; mx.google.com; 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 x17si386245ejn.21.2020.04.30.12.16.13; Thu, 30 Apr 2020 12:16:37 -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; 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 S1726579AbgD3TOj (ORCPT + 99 others); Thu, 30 Apr 2020 15:14:39 -0400 Received: from mx2.suse.de ([195.135.220.15]:43872 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726272AbgD3TOi (ORCPT ); Thu, 30 Apr 2020 15:14:38 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id B3C4DABC2; Thu, 30 Apr 2020 19:14:36 +0000 (UTC) Date: Thu, 30 Apr 2020 21:14:34 +0200 From: Joerg Roedel To: Steven Rostedt Cc: LKML , Ingo Molnar , Thomas Gleixner , Peter Zijlstra , Borislav Petkov , Andrew Morton , Shile Zhang , Andy Lutomirski , "Rafael J. Wysocki" , Dave Hansen , Tzvetomir Stoyanov , Mathieu Desnoyers Subject: Re: [RFC][PATCH] x86/mm: Sync all vmalloc mappings before text_poke() Message-ID: <20200430191434.GC8135@suse.de> References: <20200429054857.66e8e333@oasis.local.home> <20200429105941.GQ30814@suse.de> <20200429082854.6e1796b5@oasis.local.home> <20200429100731.201312a9@gandalf.local.home> <20200430141120.GA8135@suse.de> <20200430121136.6d7aeb22@gandalf.local.home> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200430121136.6d7aeb22@gandalf.local.home> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Apr 30, 2020 at 12:11:36PM -0400, Steven Rostedt wrote: > bool trace_event_ignore_this_pid(struct trace_event_file *trace_file) > { > struct trace_array *tr = trace_file->tr; > struct trace_array_cpu *data; > struct trace_pid_list *no_pid_list; > struct trace_pid_list *pid_list; > > pid_list = rcu_dereference_raw(tr->filtered_pids); > no_pid_list = rcu_dereference_raw(tr->filtered_no_pids); > > if (!pid_list && !no_pid_list) > return false; > > data = this_cpu_ptr(tr->array_buffer.data); > > return data->ignore_pid; > } > > [...] > > tl;dr; It's not an issue with the vmalloc, it's an issue with per_cpu > allocations! Yes, looks like you are right, it faults on the return statement, so the data-pointer seems not to be mapped. I looked at another instance: The trapping instruction is: movzbl 0x7c(%rax),%eax Which is a pointer-dereference, with %rax=0xffffe8ffffccc870. The 'data' pointer is allocated with alloc_percpu(). And alloc_percpu() calls down into pcpu_alloc(), which allocates new percpu chunks using vmalloc() on x86. And there we are again in the vmalloc area. Regards, Joerg