Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp452408rwd; Wed, 14 Jun 2023 19:17:32 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ6NXN0I6+ZmprytlLq7Hl07TLkkUogrr12vYwfbANyovRTAMb5BYveTeYiymNHv5KZsLwnZ X-Received: by 2002:a17:907:8a09:b0:961:be96:b0e7 with SMTP id sc9-20020a1709078a0900b00961be96b0e7mr19754319ejc.48.1686795452116; Wed, 14 Jun 2023 19:17:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686795452; cv=none; d=google.com; s=arc-20160816; b=TK/uJN9c3LenuVSwp49S5apxB4lVVMUN0f90iS7bFbwmEVDwY4hWQjOGR1V3/o7Ts3 ww0X80VnnBKmUkG/zvXA5K05TbJ7SS5/xrUMQ7PTAWnPwQFNzyrDb8SKh5EVQ+SXrI7l PMIWRCxbUa9r40uJGexWz4ScndRjfBcIFGcKMWbkiq5XdNkgg0E+5+VQZ+TWyQzShgAx G1IVST89yPfYhLhAzRrB5a59wCf4CT/gk8U0XRf7ESp3X2Aka4LQOZFczPfLTkc0JIK5 g8ZJAJ49OGzuvlPLT4ZMv38YwR1LenTOQnpI2QIioVCDwAur2gP7qiXCO+qg5oei6K62 5QSw== 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 :cc:to:subject; bh=I/sJbp9PVIwh9Tot0JlaSwh8hff2tGIrI9WFkmp2XhI=; b=nH8Yhj5PnlP7OoR+ynH5We1ksz+GK/fc8z7Y93VcL9OCCffeB4F7hZwVHUljZghOxp fzLBzBCqu0mQBkZKSAyH8LiYoL6Ot3T3qHTTqSYFgFHVG6xvt4Hg5B++cXvO+J1hxZhr Y/nOD2Q3tMuQUnWhNR25uvvVAT0wAu9pFJAP9rOV59tdOyp7ThtIXtK/Q6f+mNcknF4k 7l0/Bsh/3iHwgnG2W7b8m85C40IRC9KaJK4MIbaxlslxCQNmaaeEhGhRBYqWIbJekau4 I2iiUmxhgHcyGh038AkhKo9mI4bKtxCTc2XZZdZeb+jSn/RPSo/IBU4qbck3N/dI82C4 pxQg== 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 u6-20020a1709063b8600b009745d6d4f99si8879217ejf.311.2023.06.14.19.17.07; Wed, 14 Jun 2023 19:17:32 -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 S233529AbjFOBzA (ORCPT + 99 others); Wed, 14 Jun 2023 21:55:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50478 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240276AbjFOByy (ORCPT ); Wed, 14 Jun 2023 21:54:54 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3A39BA6; Wed, 14 Jun 2023 18:54:53 -0700 (PDT) Received: from kwepemm600003.china.huawei.com (unknown [172.30.72.56]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4QhQG81z38zqTx4; Thu, 15 Jun 2023 09:49:52 +0800 (CST) 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.2507.23; Thu, 15 Jun 2023 09:54:50 +0800 Subject: Re: [PATCH] perf top & record: Fix segfault when default cycles event is not supported To: Ian Rogers CC: , , , , , , , , , , References: <20230614151625.2077-1-yangjihong1@huawei.com> From: Yang Jihong Message-ID: <668a6159-b7a8-ed25-d8fa-5584a4c04d37@huawei.com> Date: Thu, 15 Jun 2023 09:54:49 +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: Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-Originating-IP: [10.67.111.205] X-ClientProxiedBy: dggems702-chm.china.huawei.com (10.3.19.179) To kwepemm600003.china.huawei.com (7.193.23.202) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,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 Hello, On 2023/6/15 6:03, Ian Rogers wrote: > On Wed, Jun 14, 2023 at 9:18 AM Ian Rogers wrote: >> >> On Wed, Jun 14, 2023 at 8:18 AM Yang Jihong wrote: >>> >>> The perf-record and perf-top call parse_event() to add a cycles event to >>> an empty evlist. For the system that does not support hardware cycles >>> event, such as QEMU, the evlist is empty due to the following code process: >>> >>> parse_event(evlist, "cycles:P" or ""cycles:Pu") >>> parse_events(evlist, "cycles:P") >>> __parse_events >>> ... >>> ret = parse_events__scanner(str, &parse_state); >>> // ret = 0 >>> ... >>> ret2 = parse_events__sort_events_and_fix_groups() >>> if (ret2 < 0) >>> return ret; >>> // The cycles event is not supported, here ret2 = -EINVAL, >>> // Here return 0. >>> ... >>> evlist__splice_list_tail(evlist) >>> // The code here does not execute to, so the evlist is still empty. >>> >>> A null pointer occurs when the content in the evlist is accessed later. >>> >>> Before: >>> >>> # perf list hw >>> >>> List of pre-defined events (to be used in -e or -M): >>> >>> # perf record true >>> libperf: Miscounted nr_mmaps 0 vs 1 >>> WARNING: No sample_id_all support, falling back to unordered processing >>> perf: Segmentation fault >>> Obtained 1 stack frames. >>> [0xc5beff] >>> Segmentation fault >>> >>> Solution: >>> If cycles event is not supported, try to fall back to cpu-clock event. >>> >>> After: >>> # perf record true >>> [ perf record: Woken up 1 times to write data ] >>> [ perf record: Captured and wrote 0.006 MB perf.data ] >>> # >>> >>> Fixes: 7b100989b4f6 ("perf evlist: Remove __evlist__add_default") >>> Signed-off-by: Yang Jihong >> >> Thanks, useful addition. The cpu-clock fall back wasn't present before >> 7b100989b4f6 so is the fixes tag correct? > > Hmm... it should be coming from evsel__fallback: > https://git.kernel.org/pub/scm/linux/kernel/git/acme/linux.git/tree/tools/perf/util/evsel.c?h=tmp.perf-tools-next#n2840 > so we shouldn't duplicate that logic. The question is why we're not > doing the fallback. > Yes, it's a bit of the same logic as evsel__fallback, or we can call evlist__add_default() as before, simply create an evsel of hardware cycles and add it directly to evlist. Please confirm whether this solution is feasible. If it is feasible, I will send a v2 version. Thanks, Yang