Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp816919ybz; Wed, 29 Apr 2020 09:54:38 -0700 (PDT) X-Google-Smtp-Source: APiQypKOadVFlo/A0gmiHHF+36cvajB+1vcat159Va7Zx81TRY/DghznTzowxofTeEcfyiZcdvYE X-Received: by 2002:a17:906:a38f:: with SMTP id k15mr3588478ejz.181.1588179278289; Wed, 29 Apr 2020 09:54:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588179278; cv=none; d=google.com; s=arc-20160816; b=K7kNSN8RFDYzNhSpcXpconcEiGHjcLRjXA70UA9JzsRgUKvNlSc7tDYwUI4zXnnSTO lTU4YtYJa3kGlWUeoufgwt9dGwRC4JIv+Ku5yJuq8VXbzhT5ZA+OPkCMp83Z9pLB/bcu QSfyZLJx2Fy01P6D92JdyFREMpdrUzpKD8iAKlpd9ZNcW2QJk4G1hPEhtLiLrou8du3u WsgZttR2/jSxWY6rk1lZrDBNPoKF3jUe5mQzwBQJXNmLzuRnGpXjuupjl5SBPWLYTipr x7I+Ynqo9BiDY9eLcorB7yrIJ54aBTEy7djWAWLediHGh+HrIQgdauklUKbH/58zNK5K AjPw== 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 :references:in-reply-to:message-id:subject:cc:to:from:date; bh=DkYrJ0AjosC/QnYzlP3keK/eGKvPseo/I8ygHOl2mOM=; b=hthyXWmkdR4nib/7mcrguZhv5JA9MWYVqnvr7SjxPzyKYUcH+AzuiukfXbO122rTNj 3bjNLuCBKLS3yonaB0g65iXAw9FYBsfcvka8Wpyom/MGZoLQK7JI+3tCvZY74wLh+44m X74j7wt6cO2YTsfA35e7LsmccZGoKNS0D/cqPcqhxNOmdz189VU3d/nDQc0eStothSF0 YnGuamzjOjewPBwXeVxAztpNmfozZ6gzFKzv7V+LVJX0hw+3RKI3k55wrIA+nLCs8Y1z sw0r7VgtC2svxLbPIxDofdNM/CZiRUbldoboCh4W4nW2x4SwfWBz9e69LOS07fiYoMoP M4ig== 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 cw6si3640796edb.552.2020.04.29.09.54.14; Wed, 29 Apr 2020 09:54:38 -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 S1726743AbgD2Qws (ORCPT + 99 others); Wed, 29 Apr 2020 12:52:48 -0400 Received: from mail.kernel.org ([198.145.29.99]:60790 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726423AbgD2Qws (ORCPT ); Wed, 29 Apr 2020 12:52:48 -0400 Received: from gandalf.local.home (cpe-66-24-58-225.stny.res.rr.com [66.24.58.225]) (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 E08C3208FE; Wed, 29 Apr 2020 16:52:46 +0000 (UTC) Date: Wed, 29 Apr 2020 12:52:45 -0400 From: Steven Rostedt To: Joerg Roedel 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: <20200429125245.5a804f62@gandalf.local.home> In-Reply-To: <20200429162026.GT30814@suse.de> References: <20200429054857.66e8e333@oasis.local.home> <20200429105941.GQ30814@suse.de> <20200429082854.6e1796b5@oasis.local.home> <20200429100731.201312a9@gandalf.local.home> <20200429161747.GS30814@suse.de> <20200429162026.GT30814@suse.de> X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 29 Apr 2020 18:20:26 +0200 Joerg Roedel wrote: > On Wed, Apr 29, 2020 at 06:17:47PM +0200, Joerg Roedel wrote: > > On Wed, Apr 29, 2020 at 10:07:31AM -0400, Steven Rostedt wrote: > > > Talking with Mathieu about this on IRC, he pointed out that my code does > > > have a vzalloc() that is called: > > > > > > in trace_pid_write() > > > > > > pid_list->pids = vzalloc((pid_list->pid_max + 7) >> 3); > > > > > > This is done when -P1,2 is on the trace-cmd command line. > > > > And that buffer is written to at any function entry? > > What I meant to say, is it possible that the page-fault handler does not > complete because at its beginning it calls into trace-code and faults > again on the same address? > It should be read only at sched_switch. Basically, it's a big bitmask, where each bit represents a possible process id (can be 2 gigs if we allow all positive ints!). Then, it is only written when setting it up. Bits 1 and 2 are set here (-P1,2). At context switch, next->pid is checked against this bitmask, and if it is set, it means we should allow this process to be traced. This mask should only be accessed at sched_switch time, not at other times. And it may read any possible page in that mask depending on the process id of the next task to be scheduled in. -- Steve