Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp3944396iog; Tue, 21 Jun 2022 08:54:40 -0700 (PDT) X-Google-Smtp-Source: AGRyM1u92zcphuCIxOcbNlPGtxfb3t2iIninP4mUay9blybgm43teFOrU0fQaTPUdzKyEU8VkwKX X-Received: by 2002:a17:906:3f02:b0:718:bdf7:790d with SMTP id c2-20020a1709063f0200b00718bdf7790dmr26432661ejj.479.1655826880400; Tue, 21 Jun 2022 08:54:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655826880; cv=none; d=google.com; s=arc-20160816; b=UfXjQOhPgc2Kf3Jm+Vyo5r8p1qBM/n9zcrCN0QYSDjvDAEkKy/O4ej/jSAcNcVXncW 6WUixj5k/2n65isnimjUfOpdfaFp5H3DeBlTXr0NDlTBLCkiZ1NcU1nhRL/kWyIeCoZ1 IqnJ4kjpxfQntKbm6oZiwRUDkaHb2wqv66JiDMjD8jS+TwfG4T+AU99PhCzqG/8XX4oB dMkE7aAn7wg+nmlfEbfK6Pcvmkey8o1elmb/uvAgeIpyphwMDum6DfGElygfrqBIRqMp BABrlZUPL7nXlyVmD4R0nj3615cjgc3FdUoxvkMSEwIlTQrkyJDKqCgIzPRZqLOPOqfT hZVw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :dkim-signature; bh=1ObfmSGQW0ZwVE/c/9QlEVffnJCJ00dlQfzxaXeKDJ8=; b=Okdut9qO7CdtuvKhAgWtXag3Kid2yB8alWrLrbB36zgHIvEKxjSzkofcbg0wFht4we z7KYycPpOIIELI0XZloKDbqy/XIIFpNuu/NVpRjLYpGowb/TJoxwkNzDgKHmrfBYUFpq ZtQi/YHzOBHKGDav33Ea60YnXnJb8ympcWl4c6Z+Nar3ktTlSxQqLyuTl5AakDUIRjBX tWnHCRpt+oPETAGA90T+sudoni9GDQ6MZ4mRgfbmN2mM5GgGIx8HKj4Nq1ZLlVvCtluT 7gf1qfEi6vFyBuX2vG+4sFSSkowdBzSgjWXHef9WxmO2WVYHUDjuqYTAFn0X3Gpm1Meb Nx8Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=tP57ZQnJ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id hb44-20020a170907162c00b006feb0e0856dsi18799017ejc.653.2022.06.21.08.54.11; Tue, 21 Jun 2022 08:54:40 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=tP57ZQnJ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S1349156AbiFUPvf (ORCPT + 99 others); Tue, 21 Jun 2022 11:51:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33482 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232533AbiFUPve (ORCPT ); Tue, 21 Jun 2022 11:51:34 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E17F22BB18; Tue, 21 Jun 2022 08:51:32 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 7E93260DF0; Tue, 21 Jun 2022 15:51:32 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 45C18C3411C; Tue, 21 Jun 2022 15:51:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1655826691; bh=zmoo2ZRmvvNCyIQcE+Da2ZI2pDL/yDnS2nVNJbeGP6g=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=tP57ZQnJDy1t8hDt8nEzibw06dOdkIoIJcBAqfAZ/pZzgwDJksQ0hfGV9RLnDaSSq 7EYMzUqGrsFbEg9mnJlM//+At6FAlrJ+vI0n/CmBH02Rg3yo3WMvdX5GO2qNFdSOyP r29zKSmWlcSn+dqMuqjEW+IMczEA5sqIwwER70h+MWeKRCp5BLsA8fXg5CmEQTjiL0 1Wr3vMk7/ArqiUTSrI/c8f074q0rdeVcqxFkXX8jgiDrcNeYnHu+tR+j7o2PBmFvRl wmHnliM0FVXu4UNBNFKNIqpv3nm31sa6gRATqhMpeV70YWhFGT+DCQjTZEsbj7qYWM iarsmtGq78xJg== Date: Wed, 22 Jun 2022 00:51:24 +0900 From: Masami Hiramatsu (Google) To: Chuang W , Steven Rostedt Cc: stable@vger.kernel.org, "Naveen N. Rao" , Anil S Keshavamurthy , "David S. Miller" , Masami Hiramatsu , Ingo Molnar , Jessica Yu , linux-kernel@vger.kernel.org Subject: Re: [PATCH v2] kprobes: Rollback the aggrprobe post_handler on failed arm_kprobe() Message-Id: <20220622005124.4704eafa0e89c3fe31eef1f5@kernel.org> In-Reply-To: <20220619045028.50619-1-nashuiliang@gmail.com> References: <20220619045028.50619-1-nashuiliang@gmail.com> 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 X-Spam-Status: No, score=-7.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_HI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, 19 Jun 2022 12:50:27 +0800 Chuang W wrote: > In a scenario where livepatch and aggrprobe coexist on the same function > entry, and if this aggrprobe has a post_handler, arm_kprobe() always > fails as both livepatch and aggrprobe with post_handler will use > FTRACE_OPS_FL_IPMODIFY. > Since register_aggr_kprobe() doesn't roll back the post_handler on > failed arm_kprobe(), this aggrprobe will no longer be available even if > all kprobes on this aggrprobe don't have the post_handler. > > Fix to roll back the aggrprobe post_handler for this case. > With this patch, if a kprobe that has the post_handler is removed from > this aggrprobe (since arm_kprobe() failed), it will be available again. > This looks good to me. Acked-by: Masami Hiramatsu (Google) Thank you! > Fixes: 12310e343755 ("kprobes: Propagate error from arm_kprobe_ftrace()") > Signed-off-by: Chuang W > Cc: > --- > v1 -> v2: > - Add commit details > > kernel/kprobes.c | 5 +++++ > 1 file changed, 5 insertions(+) > > diff --git a/kernel/kprobes.c b/kernel/kprobes.c > index f214f8c088ed..0610b02a3a05 100644 > --- a/kernel/kprobes.c > +++ b/kernel/kprobes.c > @@ -1300,6 +1300,7 @@ static int register_aggr_kprobe(struct kprobe *orig_p, struct kprobe *p) > { > int ret = 0; > struct kprobe *ap = orig_p; > + kprobe_post_handler_t old_post_handler = NULL; > > cpus_read_lock(); > > @@ -1351,6 +1352,9 @@ static int register_aggr_kprobe(struct kprobe *orig_p, struct kprobe *p) > > /* Copy the insn slot of 'p' to 'ap'. */ > copy_kprobe(ap, p); > + > + /* save the old post_handler */ > + old_post_handler = ap->post_handler; > ret = add_new_kprobe(ap, p); > > out: > @@ -1365,6 +1369,7 @@ static int register_aggr_kprobe(struct kprobe *orig_p, struct kprobe *p) > ret = arm_kprobe(ap); > if (ret) { > ap->flags |= KPROBE_FLAG_DISABLED; > + ap->post_handler = old_post_handler; > list_del_rcu(&p->list); > synchronize_rcu(); > } > -- > 2.34.1 > -- Masami Hiramatsu (Google)