Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp4539918rwb; Wed, 17 Aug 2022 01:34:25 -0700 (PDT) X-Google-Smtp-Source: AA6agR4G3VjlNR8L/daQWJqknG/TwzcMB0Cj+TVXdfwjv+AzmnzQZa8qApe55VAiIWoDlPsRN6a9 X-Received: by 2002:a05:6402:1681:b0:43d:2e92:63d with SMTP id a1-20020a056402168100b0043d2e92063dmr22455699edv.253.1660725265290; Wed, 17 Aug 2022 01:34:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660725265; cv=none; d=google.com; s=arc-20160816; b=liISwHlOAKpFTY3Kd44qooWuPccIbTFFj9mqsrFbmimLfYCgV4HU5CDyj6/Ml0Kjx+ Tmz4+w9tfpGJoT3B8Gk4sD7fwgRbVQRbUPVo0Dcfv9se6DAs2KiN9XUgelojCpgLAKgK Lc1EhjmcvZ963+lDm/xjhtw/bEQr3jfIB9K+W4FzmEwk5VZX/tHo4wiTGELU2UnRIYGe X7BWjCQ2+dupvU7woqUvdBPOtnmevDtWj/7P52AfOC3vzTtEzLMwdWwjEW5FCfDTY5vs eh7yPoibLrRBEhnIJwYq0MCbstwWYoIinHvpNed7tXdyKM36GR67jQHOP9Ah0otHoyNr pgzg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :to:subject; bh=8k3m8sYlhWg4CVrL7W4s6s5cubHMAEA/xU3S5CzQsbQ=; b=ck7gHbus6FS+aE3rvqOSyKbmjoBu34APwQD6L3z/ROg/WOVRiJAQxclwruF/Cq2VqU knHDJf4o2bWsx21N708BXArcbhYC+F2SYmKJVOiAnb2bUEE5P2HSOvql3MvAtH8eyicA g3XFzbmTtgi696zAE0d7BqeRTZ4Y2kvibDeJY2SSausOw5aJFqIUvegyu/4HxO/mxVHY T9queHCkH99uVZaOJW9w2lxY+qC7eikUkxP3M6a+WbwCg1zV+1p+VV+lwn657AzJ+M0L pxk3yxhLPs3lTh7RPf1Az8r6C7sjuuzGS2TxQPYTGc8qb3eJbpJ7ih+ouLR9iqsdi4DP myUg== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h15-20020a05640250cf00b0043bee43477csi12314260edb.576.2022.08.17.01.33.59; Wed, 17 Aug 2022 01:34:25 -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; 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=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235005AbiHQIUA (ORCPT + 99 others); Wed, 17 Aug 2022 04:20:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48758 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229764AbiHQIT7 (ORCPT ); Wed, 17 Aug 2022 04:19:59 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0D8E0242 for ; Wed, 17 Aug 2022 01:19:56 -0700 (PDT) Received: from dggemv711-chm.china.huawei.com (unknown [172.30.72.57]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4M716k3w5szXdVW; Wed, 17 Aug 2022 16:15:42 +0800 (CST) Received: from kwepemm600003.china.huawei.com (7.193.23.202) by dggemv711-chm.china.huawei.com (10.1.198.66) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Wed, 17 Aug 2022 16:19:54 +0800 Received: from [10.67.111.205] (10.67.111.205) by kwepemm600003.china.huawei.com (7.193.23.202) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Wed, 17 Aug 2022 16:19:53 +0800 Subject: Re: [PATCH] ftrace: Fix NULL pointer dereference in is_ftrace_trampoline when ftrace is dead To: , , References: <20220804021610.209791-1-yangjihong1@huawei.com> From: Yang Jihong Message-ID: <7cab66d9-3f41-0a8b-9906-b56f88dd6603@huawei.com> Date: Wed, 17 Aug 2022 16:19:53 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.6.1 MIME-Version: 1.0 In-Reply-To: <20220804021610.209791-1-yangjihong1@huawei.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.67.111.205] X-ClientProxiedBy: dggems701-chm.china.huawei.com (10.3.19.178) To kwepemm600003.china.huawei.com (7.193.23.202) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE, URIBL_BLOCKED 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 Hello, PING. Regards, Yang . On 2022/8/4 10:16, Yang Jihong wrote: > ftrace_startup does not remove ops from ftrace_ops_list when > ftrace_startup_enable fails: > > register_ftrace_function > ftrace_startup > __register_ftrace_function > ... > add_ftrace_ops(&ftrace_ops_list, ops) > ... > ... > ftrace_startup_enable // if ftrace failed to modify, ftrace_disabled is set to 1 > ... > return 0 // ops is in the ftrace_ops_list. > > When ftrace_disabled = 1, unregister_ftrace_function simply returns without doing anything: > unregister_ftrace_function > ftrace_shutdown > if (unlikely(ftrace_disabled)) > return -ENODEV; // return here, __unregister_ftrace_function is not executed, > // as a result, ops is still in the ftrace_ops_list > __unregister_ftrace_function > ... > > If ops is dynamically allocated, it will be free later, in this case, > is_ftrace_trampoline accesses NULL pointer: > > is_ftrace_trampoline > ftrace_ops_trampoline > do_for_each_ftrace_op(op, ftrace_ops_list) // OOPS! op may be NULL! > > Syzkaller reports as follows: > [ 1203.506103] BUG: kernel NULL pointer dereference, address: 000000000000010b > [ 1203.508039] #PF: supervisor read access in kernel mode > [ 1203.508798] #PF: error_code(0x0000) - not-present page > [ 1203.509558] PGD 800000011660b067 P4D 800000011660b067 PUD 130fb8067 PMD 0 > [ 1203.510560] Oops: 0000 [#1] SMP KASAN PTI > [ 1203.511189] CPU: 6 PID: 29532 Comm: syz-executor.2 Tainted: G B W 5.10.0 #8 > [ 1203.512324] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS rel-1.14.0-0-g155821a1990b-prebuilt.qemu.org 04/01/2014 > [ 1203.513895] RIP: 0010:is_ftrace_trampoline+0x26/0xb0 > [ 1203.514644] Code: ff eb d3 90 41 55 41 54 49 89 fc 55 53 e8 f2 00 fd ff 48 8b 1d 3b 35 5d 03 e8 e6 00 fd ff 48 8d bb 90 00 00 00 e8 2a 81 26 00 <48> 8b ab 90 00 00 00 48 85 ed 74 1d e8 c9 00 fd ff 48 8d bb 98 00 > [ 1203.518838] RSP: 0018:ffffc900012cf960 EFLAGS: 00010246 > [ 1203.520092] RAX: 0000000000000000 RBX: 000000000000007b RCX: ffffffff8a331866 > [ 1203.521469] RDX: 0000000000000000 RSI: 0000000000000008 RDI: 000000000000010b > [ 1203.522583] RBP: 0000000000000000 R08: 0000000000000000 R09: ffffffff8df18b07 > [ 1203.523550] R10: fffffbfff1be3160 R11: 0000000000000001 R12: 0000000000478399 > [ 1203.524596] R13: 0000000000000000 R14: ffff888145088000 R15: 0000000000000008 > [ 1203.525634] FS: 00007f429f5f4700(0000) GS:ffff8881daf00000(0000) knlGS:0000000000000000 > [ 1203.526801] CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 > [ 1203.527626] CR2: 000000000000010b CR3: 0000000170e1e001 CR4: 00000000003706e0 > [ 1203.528611] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000 > [ 1203.529605] DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400 > > Therefore, when ftrace_startup_enable fails, we need to rollback registration > process and remove ops from ftrace_ops_list. > > Signed-off-by: Yang Jihong > --- > kernel/trace/ftrace.c | 30 +++++++++++++++++++++--------- > 1 file changed, 21 insertions(+), 9 deletions(-) > > diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c > index 601ccf1b2f09..63bf7b67ab2e 100644 > --- a/kernel/trace/ftrace.c > +++ b/kernel/trace/ftrace.c > @@ -2922,24 +2922,36 @@ int ftrace_startup(struct ftrace_ops *ops, int command) > ops->flags |= FTRACE_OPS_FL_ENABLED | FTRACE_OPS_FL_ADDING; > > ret = ftrace_hash_ipmodify_enable(ops); > - if (ret < 0) { > - /* Rollback registration process */ > - __unregister_ftrace_function(ops); > - ftrace_start_up--; > - ops->flags &= ~FTRACE_OPS_FL_ENABLED; > - if (ops->flags & FTRACE_OPS_FL_DYNAMIC) > - ftrace_trampoline_free(ops); > - return ret; > - } > + if (ret < 0) > + goto out_rollback_registration; > > if (ftrace_hash_rec_enable(ops, 1)) > command |= FTRACE_UPDATE_CALLS; > > ftrace_startup_enable(command); > > + /* > + * If ftrace_startup_enable fails, > + * we need to rollback registration process. > + */ > + if (unlikely(ftrace_disabled)) { > + ret = -ENODEV; > + goto out_rollback_registration; > + } > + > ops->flags &= ~FTRACE_OPS_FL_ADDING; > > return 0; > + > +out_rollback_registration: > + /* Rollback registration process */ > + __unregister_ftrace_function(ops); > + ftrace_start_up--; > + ops->flags &= ~FTRACE_OPS_FL_ENABLED; > + if (ops->flags & FTRACE_OPS_FL_DYNAMIC) > + ftrace_trampoline_free(ops); > + > + return ret; > } > > int ftrace_shutdown(struct ftrace_ops *ops, int command) >