Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp3491054pxa; Wed, 26 Aug 2020 01:35:35 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwBoJv1ARE+rYhguyilQI/Uwk/NqBBclc/70/VBfJ6+X68vCiqncAaoQaWukLJmt3gMc5Y4 X-Received: by 2002:a17:906:5902:: with SMTP id h2mr15319003ejq.423.1598430935775; Wed, 26 Aug 2020 01:35:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598430935; cv=none; d=google.com; s=arc-20160816; b=rkzRd5h6t1N0k4DybELM0gkplflUOzy1B5Kb9KNI/7zoBMHtOpENMlxfm7IIybACQH 5EUdvs4vJyLMC/szRvbdDtqC//4gpPdwe76vans/AnJin6K1XcCGQLtVScWWwDlwaYje /hby4PZ8pijCRl+59RdHsNpYo0HK85rU5xG867uT3LXRkbHz3/lKnvbcG07L8nZj1YjU jccVNxlYxuY42w9Elmv8mjDnjGEfAzCgO2MeZpOrKxfXdg8OiIMkcnEcMfBK5dk73Cx8 ssfm8g45hOAnwBZ++HGv7cP8tAZg3iV4K76kw6CkQHQXe7JE6dQF06T65EiiIoHyt/Uy 7CCw== 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 :dkim-signature; bh=Gd09w0wUwMYxXxm0ZkW27tnwYfaxFXD38xynIkzx79A=; b=gzFu3ePqEjhKkglXWNW572CwTx2k4ArISEl85CzbF5mk2zMbkYuD5W0vMH0LqtuuHX uoFeiilora41JXd67BRrQmYqPzxR1olCH9FotR5+WJ7QTNohiMC15VqQdb2suZ73KS1q BBlKConNbfi5wOptjn0IG8CfxfgxhkViMh7t7iQp/Ld4hEOfJp4+3ZiPGzR0CpeNeBgg Na12qtUuo2FZ3LLH31Kgongobo6OoCLiHVC5Gp9HAOKryAjQXwUZ9tbk278DjpbYm1eU D3splBbsNG5/XbL0aznvG/IxqykB/YShlX/8nKvAxl9mVucGKYQBz5wIe8SZp7tztshB uuhQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=eHNvNWFO; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p4si1241727edi.81.2020.08.26.01.35.11; Wed, 26 Aug 2020 01:35:35 -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; dkim=pass header.i=@kernel.org header.s=default header.b=eHNvNWFO; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726999AbgHZIcD (ORCPT + 99 others); Wed, 26 Aug 2020 04:32:03 -0400 Received: from mail.kernel.org ([198.145.29.99]:49634 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726884AbgHZIcC (ORCPT ); Wed, 26 Aug 2020 04:32:02 -0400 Received: from devnote2 (NE2965lan1.rev.em-net.ne.jp [210.141.244.193]) (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 6328F20707; Wed, 26 Aug 2020 08:32:00 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1598430722; bh=+zgvqau40KD6zoirbrmJVE9a/bFPfvd4D/v0f4gdpg0=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=eHNvNWFO+gU8BFaCL0EtG2rT/AVfXwkqWtRtCRSY59S9Sz/5O1xW+6E138Fj1pyOa F8gswCtGY64ln7vX1d1Q9rUXCdgacbqatvlhfTfqJmwxLEhyrlOLNXLR5EeoXXDps3 jfUAbaiG0OQXxHBXg1qXgy3Tn1g+CFIff66n92Mg= Date: Wed, 26 Aug 2020 17:31:58 +0900 From: Masami Hiramatsu To: peterz@infradead.org Cc: "Eddy_Wu@trendmicro.com" , "linux-kernel@vger.kernel.org" , "x86@kernel.org" , "David S. Miller" Subject: Re: x86/kprobes: kretprobe fails to triggered if kprobe at function entry is not optimized (trigger by int3 breakpoint) Message-Id: <20200826173158.19bc6f5c3b05fbb3f6d0aa3e@kernel.org> In-Reply-To: <20200825120911.GX1362448@hirez.programming.kicks-ass.net> References: <8816bdbbc55c4d2397e0b02aad2825d3@trendmicro.com> <20200825005426.f592075d13be740cb3c9aa77@kernel.org> <7396e7b2079644a6aafd9670a111232b@trendmicro.com> <20200825151538.f856d701a34f4e0561a64932@kernel.org> <20200825120911.GX1362448@hirez.programming.kicks-ass.net> X-Mailer: Sylpheed 3.7.0 (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 Hi Peter, On Tue, 25 Aug 2020 14:09:11 +0200 peterz@infradead.org wrote: > > @@ -1934,50 +1884,28 @@ unsigned long __weak arch_deref_entry_point(void *entry) > static int pre_handler_kretprobe(struct kprobe *p, struct pt_regs *regs) > { > struct kretprobe *rp = container_of(p, struct kretprobe, kp); > - unsigned long hash, flags = 0; > struct kretprobe_instance *ri; > + struct llist_node *llist; > > - /* > - * To avoid deadlocks, prohibit return probing in NMI contexts, > - * just skip the probe and increase the (inexact) 'nmissed' > - * statistical counter, so that the user is informed that > - * something happened: > - */ > - if (unlikely(in_nmi())) { > + llist = llist_del_first(&rp->free_instances); > + if (!llist) { > rp->nmissed++; > return 0; > } Would we need a lock around llist_del_first(&rp->free_instance) here? linux/llist.h said, * Cases where locking is not needed: * If there are multiple producers and multiple consumers, llist_add can be * used in producers and llist_del_all can be used in consumers simultaneously * without locking. Also a single consumer can use llist_del_first while ^^^^^^^^^^^^^^^^^^^^^^^ * multiple producers simultaneously use llist_add, without any locking. * * Cases where locking is needed: * If we have multiple consumers with llist_del_first used in one consumer, and ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ * llist_del_first or llist_del_all used in other consumers, then a lock is * needed. pre_handler_kretprobe() can be invoked simultaneously on the different CPUs if those are calling the same probed function. Thank you, -- Masami Hiramatsu