Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp5609142ybi; Wed, 31 Jul 2019 00:16:58 -0700 (PDT) X-Google-Smtp-Source: APXvYqxoDKwYLtKvule/yDZQ14rsUMSNFfRNyz8iUGeHtbdgDZHUsAvmoDB+g4o4xi3YUyEkPHXE X-Received: by 2002:a17:90a:710c:: with SMTP id h12mr1417385pjk.36.1564557418859; Wed, 31 Jul 2019 00:16:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564557418; cv=none; d=google.com; s=arc-20160816; b=gAzr0yTX8eiC3e0cIGXJMMR8wqQ0E2h6iviMw/KvLbHpVX1VESyHz00xJCh3KmmBpX G6i7qbccBE4XCDO6IKT/L4gLShOJsV85gc6gKM/nb9YLdQc69COXLx11uESYMxgjWZer mdbeZOHOdvGhkSDjFe4lESVcrwIkTmYlbcgsNP0OGxbAWPvNVNswIZmygW7L20O7fqK+ MXlZoQ3IPOk+Tzjrny9u3neos2ZeJ4duYkASfJXXQbKVJrfmfWue7Iak0VoLIrWbVojn ztdvwdUnFie6w1Rypsz5D5qkH1cnYLagYUNsAyb3WjUNRMiA29o3DDKxvJAoWZIFrjXQ bS9g== 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 :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id; bh=0RyyX9F0sbArKkxfoewIbVym3iMCTG0j8SK3a5kMJZk=; b=CTvUmKCVo/hN/S8pbx2unweVl51JIF29qde3JY8YBCRUH+Eo+jEW9X4HUvHxQXKLUd JQ6CYo6ogJD8S+Bgi2ucRHUOPlwq3ZUr3aJ5IRiO8inrDmGghFPwGkTpsPUcSPya8Yup 2QE1nIalIckUzZWw+KJCTXzS9LoDGZY73lDucUblN23YvOj7oF2wQGUhngCfI6bW2FKy Z3tvJQRZ+aVzmMJ6SQgqQRbt68iVTgxHiMAuqkIzbhWb8+eZ/+YC38bDhivpu/s3D+yA HV5HdQZ8ZZHd/gUqUND8xDqGps1XX9ookZoTMTm59G7FvdwK8w1ujQrDfBrz2Z+Xb1JK zcGg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m128si30114214pfm.97.2019.07.31.00.16.43; Wed, 31 Jul 2019 00:16:58 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727467AbfGaG0h (ORCPT + 99 others); Wed, 31 Jul 2019 02:26:37 -0400 Received: from smtprelay0019.hostedemail.com ([216.40.44.19]:48876 "EHLO smtprelay.hostedemail.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726652AbfGaG0h (ORCPT ); Wed, 31 Jul 2019 02:26:37 -0400 Received: from filter.hostedemail.com (clb03-v110.bra.tucows.net [216.40.38.60]) by smtprelay02.hostedemail.com (Postfix) with ESMTP id D38943811; Wed, 31 Jul 2019 06:26:35 +0000 (UTC) X-Session-Marker: 6A6F6540706572636865732E636F6D X-Spam-Summary: 2,0,0,,d41d8cd98f00b204,joe@perches.com,:::::::::::::::,RULES_HIT:41:355:379:599:800:960:967:973:988:989:1260:1277:1311:1313:1314:1345:1359:1437:1515:1516:1518:1534:1541:1593:1594:1711:1730:1747:1777:1792:2393:2525:2553:2559:2563:2682:2685:2828:2859:2902:2904:2911:2933:2937:2939:2942:2945:2947:2951:2954:3022:3138:3139:3140:3141:3142:3353:3622:3865:3867:3868:3870:3871:3934:3936:3938:3941:3944:3947:3950:3953:3956:3959:4250:4321:4425:4605:5007:6119:7514:7875:7903:9025:10004:10400:10848:11026:11232:11658:11914:12043:12296:12297:12438:12555:12740:12760:12895:13069:13311:13357:13439:14181:14659:14721:21080:21433:21451:21627:30054:30090:30091,0,RBL:error,CacheIP:none,Bayesian:0.5,0.5,0.5,Netcheck:none,DomainCache:0,MSF:not bulk,SPF:fn,MSBL:0,DNSBL:neutral,Custom_rules:0:0:0,LFtime:25,LUA_SUMMARY:none X-HE-Tag: error57_395f5308c0426 X-Filterd-Recvd-Size: 2802 Received: from XPS-9350.home (cpe-23-242-196-136.socal.res.rr.com [23.242.196.136]) (Authenticated sender: joe@perches.com) by omf07.hostedemail.com (Postfix) with ESMTPA; Wed, 31 Jul 2019 06:26:34 +0000 (UTC) Message-ID: <29b3741ca8a9e94d64dba213059abb2296c30936.camel@perches.com> Subject: Re: [PATCH v2] drm: use trace_printk rather than printk in drm_dbg. From: Joe Perches To: Fuqian Huang Cc: Maarten Lankhorst , Maxime Ripard , Sean Paul , David Airlie , Daniel Vetter , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Date: Tue, 30 Jul 2019 23:26:32 -0700 In-Reply-To: <20190731062416.26238-1-huangfq.daxian@gmail.com> References: <20190731062416.26238-1-huangfq.daxian@gmail.com> Content-Type: text/plain; charset="ISO-8859-1" User-Agent: Evolution 3.30.5-0ubuntu0.18.10.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 2019-07-31 at 14:24 +0800, Fuqian Huang wrote: > In drivers/gpu/drm/amd/amdgpu/amdgpu_ih.c, > amdgpu_ih_process calls DRM_DEBUG which calls drm_dbg and > finally calls printk. > As amdgpu_ih_process is called from an interrupt handler, > and interrupt handler should be short as possible. > > As printk may lead to bogging down the system or can even > create a live lock. printk should not be used in IRQ context. > Instead, trace_printk is recommended in IRQ context. > Link: https://lwn.net/Articles/365835 > > Reviewed-by: Joe Perches I made a suggestion. I did not review this. Please do not add signatures like this if not specifically given by someone. > Signed-off-by: Fuqian Huang > --- > Changes in v2: > - Only make the interrupt uses the trace_printk to avoid > all 4000+ drm_dbg/DRM_DEBUG uses emitting a trace_printk. > > drivers/gpu/drm/drm_print.c | 10 +++++++--- > 1 file changed, 7 insertions(+), 3 deletions(-) > > diff --git a/drivers/gpu/drm/drm_print.c b/drivers/gpu/drm/drm_print.c > index a17c8a14dba4..747835d16fa6 100644 > --- a/drivers/gpu/drm/drm_print.c > +++ b/drivers/gpu/drm/drm_print.c > @@ -236,9 +236,13 @@ void drm_dbg(unsigned int category, const char *format, ...) > vaf.fmt = format; > vaf.va = &args; > > - printk(KERN_DEBUG "[" DRM_NAME ":%ps] %pV", > - __builtin_return_address(0), &vaf); > - > + if (in_interrupt()) { > + trace_printk(KERN_DEBUG "[" DRM_NAME ":%ps] %pV", > + __builtin_return_address(0), &vaf); > + } else { > + printk(KERN_DEBUG "[" DRM_NAME ":%ps] %pV", > + __builtin_return_address(0), &vaf); > + } > va_end(args); > } > EXPORT_SYMBOL(drm_dbg);