Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp4207150rwl; Wed, 28 Dec 2022 00:29:35 -0800 (PST) X-Google-Smtp-Source: AMrXdXsCeK82onBqFRtUU598hmDdLPDRF1U/QfpH1VoLlFPJlh/t8BoaEji/iti4f7myuq3ci4Ri X-Received: by 2002:a17:906:9693:b0:7c1:2980:7fd8 with SMTP id w19-20020a170906969300b007c129807fd8mr16720801ejx.17.1672216175433; Wed, 28 Dec 2022 00:29:35 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1672216175; cv=none; d=google.com; s=arc-20160816; b=wwjis9HX9VTXXtfJfaPWtiTtw9ssUnnv7QBYPlMPgFti3QernzF/5aq58z3r79xR8F zdr8P4Th1qOR9qXXwVcwyPz991XY6cobChJoND0vIMtFJ2qwS890Uv/4klxglPLqnSZ1 bRA4MMWC7A+JmTeWm1icRn6xVPUwl16BWMVcvM04FRs4rlbPPuB2HfuSXNEmyeFDi8mK K4Lvzc6U5SsXpT2GNb/D8Ai7jjO9Cy+HWADPYOqRg9HiNCEMk+ZH68S1TXd5UiITmctb kWPSe9h4hTBfPPg/piQlwAmsOZR0d6BKxxX/NSNuTNMmADV82Xr4h8Qke5BEE759aTBV /X5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=CJPimVnxorRg2kzRc2DAU24mx1aUehs3rtYnka4deQA=; b=07o7FZO1PA4DJULdkls0p8VFeJvmzncSYHNSf4VEQJT5YT/lbkyRwDup7hJMsuScsZ vUigu2ZfFHvu0J54+grvDhSo0Cv1VS6OJfJ7jmufgRcGkB8DFMSdhUOVSCiGy478miFx EJZQ+/15m93PIGJ3ZPehQWnHixTTe8Svdc7wg5hVV22HHhq6IM7l20vjuVh0AaC6QGEj fEEBZ3A8hChiPHDPaQA8GvMYeDDDBfPVfqkPPRI8f9RJLUcTR76oG0gSTxHHZ7iciyyo azcG+jcTR9P7wk1xafCA87WXAyXHr6Lwflh2XlAcdFBdIiSw2wRjTcEqrVC67aYMCs8F LmoQ== 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 c13-20020a170906340d00b007c10ac8f9afsi9583122ejb.807.2022.12.28.00.29.20; Wed, 28 Dec 2022 00:29:35 -0800 (PST) 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 S230133AbiL1IRk (ORCPT + 64 others); Wed, 28 Dec 2022 03:17:40 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39544 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229526AbiL1IRi (ORCPT ); Wed, 28 Dec 2022 03:17:38 -0500 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 203E3F43 for ; Wed, 28 Dec 2022 00:17:36 -0800 (PST) Received: from dggpemm500017.china.huawei.com (unknown [172.30.72.57]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4Nhkqz6sm9zmWMm; Wed, 28 Dec 2022 16:16:15 +0800 (CST) Received: from [10.174.178.220] (10.174.178.220) by dggpemm500017.china.huawei.com (7.185.36.178) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.34; Wed, 28 Dec 2022 16:17:32 +0800 Message-ID: <5cb83ada-a1a4-b52f-3254-0e6536ab4315@huawei.com> Date: Wed, 28 Dec 2022 16:17:32 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.8.0 Subject: Re: [PATCH] cma:tracing: Print alloc result in trace_cma_alloc_finish Content-Language: en-US To: "Masami Hiramatsu (Google)" CC: Steven Rostedt , Andrew Morton , , , , References: <20221208142130.1501195-1-haowenchao@huawei.com> <20221218102030.94b44e62608f20fd9decf9a0@kernel.org> From: Wenchao Hao In-Reply-To: <20221218102030.94b44e62608f20fd9decf9a0@kernel.org> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [10.174.178.220] X-ClientProxiedBy: dggpeml100018.china.huawei.com (7.185.36.133) To dggpemm500017.china.huawei.com (7.185.36.178) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-5.3 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS 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 2022/12/18 9:20, Masami Hiramatsu (Google) wrote: > On Thu, 8 Dec 2022 22:21:30 +0800 > Wenchao Hao wrote: > >> The result of allocation is not printed in trace_cma_alloc_finish >> now, while it's important to do it so we can set filters to catch >> specific error on allocation or trigger some operations on specific >> error. >> >> Although we have printed the result in log, but the log is >> conditional and could not be filtered by tracing event. >> >> What's more, it introduce little overhead to print this result. >> The result of allocation is named as errorno in trace. > > This looks good to me. BTW, with this change, cma_alloc_class has only > one event - cma_alloc_busy_retry. If so, can we remove the cma_alloc_class? > > Thank you, > Sorry, I got COVID-19 and just recovered, so did not response your email in time. The cma_alloc_class should be removed. Since Andrew has applied this patch, I would send another one to remove it. >> >> Signed-off-by: Wenchao Hao >> --- >> include/trace/events/cma.h | 32 +++++++++++++++++++++++++++++--- >> mm/cma.c | 2 +- >> 2 files changed, 30 insertions(+), 4 deletions(-) >> >> diff --git a/include/trace/events/cma.h b/include/trace/events/cma.h >> index 3d708dae1542..ef75ea606ab2 100644 >> --- a/include/trace/events/cma.h >> +++ b/include/trace/events/cma.h >> @@ -91,12 +91,38 @@ TRACE_EVENT(cma_alloc_start, >> __entry->align) >> ); >> >> -DEFINE_EVENT(cma_alloc_class, cma_alloc_finish, >> +TRACE_EVENT(cma_alloc_finish, >> >> TP_PROTO(const char *name, unsigned long pfn, const struct page *page, >> - unsigned long count, unsigned int align), >> + unsigned long count, unsigned int align, int errorno), >> >> - TP_ARGS(name, pfn, page, count, align) >> + TP_ARGS(name, pfn, page, count, align, errorno), >> + >> + TP_STRUCT__entry( >> + __string(name, name) >> + __field(unsigned long, pfn) >> + __field(const struct page *, page) >> + __field(unsigned long, count) >> + __field(unsigned int, align) >> + __field(int, errorno) >> + ), >> + >> + TP_fast_assign( >> + __assign_str(name, name); >> + __entry->pfn = pfn; >> + __entry->page = page; >> + __entry->count = count; >> + __entry->align = align; >> + __entry->errorno = errorno; >> + ), >> + >> + TP_printk("name=%s pfn=0x%lx page=%p count=%lu align=%u errorno=%d", >> + __get_str(name), >> + __entry->pfn, >> + __entry->page, >> + __entry->count, >> + __entry->align, >> + __entry->errorno) >> ); >> >> DEFINE_EVENT(cma_alloc_class, cma_alloc_busy_retry, >> diff --git a/mm/cma.c b/mm/cma.c >> index 4a978e09547a..a75b17b03b66 100644 >> --- a/mm/cma.c >> +++ b/mm/cma.c >> @@ -491,7 +491,7 @@ struct page *cma_alloc(struct cma *cma, unsigned long count, >> start = bitmap_no + mask + 1; >> } >> >> - trace_cma_alloc_finish(cma->name, pfn, page, count, align); >> + trace_cma_alloc_finish(cma->name, pfn, page, count, align, ret); >> >> /* >> * CMA can allocate multiple page blocks, which results in different >> -- >> 2.32.0 >> > >