Received: by 10.213.65.68 with SMTP id h4csp1668124imn; Thu, 15 Mar 2018 06:23:50 -0700 (PDT) X-Google-Smtp-Source: AG47ELszu27ZQu/gsJQPK1fiimh6r4cmPr2C/Ny4DoqGYWBKzwcBvNTeNWZ9B1QqlMU+4A//8jlq X-Received: by 2002:a17:902:64cf:: with SMTP id y15-v6mr8235240pli.49.1521120230245; Thu, 15 Mar 2018 06:23:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521120230; cv=none; d=google.com; s=arc-20160816; b=OBV9UqpDoufjlTJkYc4EiGPII0gF3S0gvIWiBg20g4rJM08fW9I9T3lbtC2EKqnzUC CpXnhTBgSiAWp902AZNCFTh6AkQVLp83sK2D40aAeI1XYgWMZmbZHPX4Y6rGrl8o90wb /iAkqprCk1zWyNKaRDHbAxrI9dujvUWoXZu2Cflp9aDu7L2r1pF9kgwEWDY5ElhHy2Sh Kz7J8SW9Qe8RtcxRPz7q9ud5cXZSEucW5MdC3Sa5LiGgBUflPqSGDS9wkjI8Qzssz23Q y61mCl8O5NSEbkyIRzYXCZF+j0t8TJXGuMyjh0ZZlEC9Az1PNLd79baofvlQGbYtUd9N Fgeg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=NNC6Dq2dP1lM6sRN0vqshRwxTz5PTajv3MEkskhw8jQ=; b=pyKuq4BqUldCe6qPLuTnJAd1txPvF6EfLF2ipkdtizcKunxjP+4rBrESmAhVdO9+RT XPi0E5eRELWdhEIcNdl8fgntAVHaRXhijkxaW+gzJVtAyUdl6apYPw3lYijNrSL3/ngY kuFV6/dFEWM4a3vAjwu3skvQCM4pIiU6Cv3O0WE2SdtN9Br0b+tzsBn/8TGO6IScT5d9 35QcVTAx+x+onpixPDCI1e0KZCKs0U+rwMVvXO7QRPVxMs3Z3MzDGzKzJxDSL7MfqaIr hEV7yU1CVxBgRFA9Km/zQqD3525OwkkfJeok1NAfBrxZ1lCINMEwc1exdZkMCLvoCKfq qdiw== 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 q87si3783345pfa.385.2018.03.15.06.23.35; Thu, 15 Mar 2018 06:23:50 -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 S1751985AbeCONWj (ORCPT + 99 others); Thu, 15 Mar 2018 09:22:39 -0400 Received: from mga05.intel.com ([192.55.52.43]:14294 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751833AbeCONWh (ORCPT ); Thu, 15 Mar 2018 09:22:37 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by fmsmga105.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 15 Mar 2018 06:22:37 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.48,310,1517904000"; d="scan'208";a="211588067" Received: from ashleylh-mobl1.ger.corp.intel.com (HELO [10.249.35.19]) ([10.249.35.19]) by fmsmga006.fm.intel.com with ESMTP; 15 Mar 2018 06:22:34 -0700 Subject: Re: [PATCH] drm: Reduce object size of DRM_ERROR and DRM_DEBUG uses To: Joe Perches , Gustavo Padovan , Sean Paul , David Airlie , Jani Nikula , Joonas Lahtinen , Rodrigo Vivi Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, intel-gfx@lists.freedesktop.org References: <016b5cb84cede20fd0f91ed6965421d99fd5f2ce.1520978414.git.joe@perches.com> From: Maarten Lankhorst Message-ID: <7dac9dbd-b57b-6e37-c1bb-9ab6c2711613@linux.intel.com> Date: Thu, 15 Mar 2018 14:22:33 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 MIME-Version: 1.0 In-Reply-To: <016b5cb84cede20fd0f91ed6965421d99fd5f2ce.1520978414.git.joe@perches.com> Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Op 13-03-18 om 23:02 schreef Joe Perches: > drm_printk is used for both DRM_ERROR and DRM_DEBUG with unnecessary > arguments that can be removed by creating separate functins. > > Create specific functions for these calls to reduce x86/64 defconfig > size by ~20k. > > Modify the existing macros to use the specific calls. > > new: > $ size -t drivers/gpu/drm/built-in.a | tail -1 > 1876562 44542 995 1922099 1d5433 (TOTALS) > > old: > $ size -t drivers/gpu/drm/built-in.a | tail -1 > 1897565 44542 995 1943102 1da63e (TOTALS) > > Miscellanea: > > o intel_display requires a change to use the specific calls. > > Signed-off-by: Joe Perches > --- I guess this adds up. Nice reduction. :) > drivers/gpu/drm/drm_print.c | 28 +++++++++++++++++++++------- > drivers/gpu/drm/i915/intel_display.c | 15 ++++----------- > include/drm/drm_print.h | 27 ++++++++++++++------------- > 3 files changed, 39 insertions(+), 31 deletions(-) > > diff --git a/drivers/gpu/drm/drm_print.c b/drivers/gpu/drm/drm_print.c > index 781518fd88e3..79abf6d5b4db 100644 > --- a/drivers/gpu/drm/drm_print.c > +++ b/drivers/gpu/drm/drm_print.c > @@ -89,23 +89,37 @@ void drm_dev_printk(const struct device *dev, const char *level, > } > EXPORT_SYMBOL(drm_dev_printk); > > -void drm_printk(const char *level, unsigned int category, > - const char *format, ...) > +void drm_dbg(unsigned int category, const char *format, ...) > { > struct va_format vaf; > va_list args; > > - if (category != DRM_UT_NONE && !(drm_debug & category)) > + if (!(drm_debug & category)) > return; > > va_start(args, format); > vaf.fmt = format; > vaf.va = &args; > > - printk("%s" "[" DRM_NAME ":%ps]%s %pV", > - level, __builtin_return_address(0), > - strcmp(level, KERN_ERR) == 0 ? " *ERROR*" : "", &vaf); > + printk(KERN_DEBUG "[" DRM_NAME ":%ps] %pV", > + __builtin_return_address(0), &vaf); > + > + va_end(args); > +} > +EXPORT_SYMBOL(drm_dbg); > + > +void drm_err(const char *format, ...) > +{ > + struct va_format vaf; > + va_list args; > + > + va_start(args, format); > + vaf.fmt = format; > + vaf.va = &args; > + > + printk(KERN_ERR "[" DRM_NAME ":%ps] *ERROR* %pV", > + __builtin_return_address(0), &vaf); > > va_end(args); > } > -EXPORT_SYMBOL(drm_printk); > +EXPORT_SYMBOL(drm_err); > diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c > index 2933ad38094f..d8e522e3cd39 100644 > --- a/drivers/gpu/drm/i915/intel_display.c > +++ b/drivers/gpu/drm/i915/intel_display.c > @@ -11059,24 +11059,17 @@ intel_compare_link_m_n(const struct intel_link_m_n *m_n, > static void __printf(3, 4) > pipe_config_err(bool adjust, const char *name, const char *format, ...) > { > - char *level; > - unsigned int category; > struct va_format vaf; > va_list args; > > - if (adjust) { > - level = KERN_DEBUG; > - category = DRM_UT_KMS; > - } else { > - level = KERN_ERR; > - category = DRM_UT_NONE; > - } > - > va_start(args, format); > vaf.fmt = format; > vaf.va = &args; > > - drm_printk(level, category, "mismatch in %s %pV", name, &vaf); > + if (adjust) > + drm_dbg(DRM_UT_KMS, "mismatch in %s %pV", name, &vaf); > + else > + drm_err("mismatch in %s %pV", name, &vaf); Could this use DRM_DEBUG_KMS/DRM_ERROR? Rest looks good, so I can fix up if you want. ~Maarten