Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp540648img; Fri, 22 Mar 2019 03:33:07 -0700 (PDT) X-Google-Smtp-Source: APXvYqz/6Xc83gEG2UsW0MVrpNlcMUJ5lljFMa3zu91F7mJLF09HYMAQky3HpgOztkAy5rb71GpE X-Received: by 2002:a63:4616:: with SMTP id t22mr7488430pga.217.1553250787443; Fri, 22 Mar 2019 03:33:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553250787; cv=none; d=google.com; s=arc-20160816; b=FqJ1wQJMDY0GZlq5Sl/nwQniaUeWjLUilegIqi9ej4cdSg20mubZS0yZpclwixzkSE 9/XN6hPjy483acmaD4oBuYd3KG/ailnr/vvWd13Do5Q0dIMLxw1J7ZLu3wxQ1ZI28+2R 0trytb0M8FSXjII+6B5gZ8PMctEzLHdHHEHUIZXF59Ns5Vd5VS8y0fSNmGy+VUGb6ho9 cSPFIizKOxKmqc+f2flMvB5lHhGVmnkWrz8Vf5n1sWqts0J4Du6ySDz2ztK+tj7w0hcy j6Tlk8uJHI4M7aOvNDll0nD2w7tHqP3o1uh9InU9HzcXdaBQ1fy4xO/1c93mJ5z7ToJY c32A== 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:organization:references:in-reply-to:date:cc:to:from :subject:message-id; bh=AC0SOs1XMor9dZWhfkoPgQ1Rxm2qfQUStJ2iOkOILKE=; b=LyK3dknvvtUSVGNMzJAubtBh5w4wvdDH4UBLiwIPFmVP2FB/yXdoKMgk5d9W4n4RB0 7O62+XVSJHD1l2VrTAorqGie36khy3XiLkZHPNNWRY2QGOI3cNdMeh46jhXZCWNuVelK Ky3YYmDbrO6f7d9w91akAYSyWakoC1PX68rai/WDJhYmAHSZrBZEyGNKe0W7c3JoLMjW UTmtaJXDa8tcO+s0xPrCz/5rD8PCgplz3+9OtRzfwwxBut8B4JcPb3/xuWbMh+RjZwmd 9Q99BrCGQl7dT2hxpzYWVjiT4TiK29QqRUN3AZBVhBei0Fx6sMoAzi6gQxyUya/iUpxO 5SQw== 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 l65si6778583plb.338.2019.03.22.03.32.52; Fri, 22 Mar 2019 03:33:07 -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 S1727988AbfCVKa6 (ORCPT + 99 others); Fri, 22 Mar 2019 06:30:58 -0400 Received: from relay7-d.mail.gandi.net ([217.70.183.200]:51911 "EHLO relay7-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726667AbfCVKa5 (ORCPT ); Fri, 22 Mar 2019 06:30:57 -0400 X-Originating-IP: 90.88.33.153 Received: from aptenodytes (aaubervilliers-681-1-92-153.w90-88.abo.wanadoo.fr [90.88.33.153]) (Authenticated sender: paul.kocialkowski@bootlin.com) by relay7-d.mail.gandi.net (Postfix) with ESMTPSA id 5EB5520008; Fri, 22 Mar 2019 10:30:54 +0000 (UTC) Message-ID: <14f34f5ce32ca4943aec42e32878d6dcc7ea5524.camel@bootlin.com> Subject: Re: [PATCH 1/7] drm: Add a helper function for printing a debugfs_regset32. From: Paul Kocialkowski To: Eric Anholt , dri-devel@lists.freedesktop.org Cc: linux-kernel@vger.kernel.org, Maxime Ripard Date: Fri, 22 Mar 2019 11:30:53 +0100 In-Reply-To: <20190220210343.28157-1-eric@anholt.net> References: <20190220210343.28157-1-eric@anholt.net> Organization: Bootlin Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.32.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, Le mercredi 20 février 2019 à 13:03 -0800, Eric Anholt a écrit : > The debugfs_regset32 is nice to use for reducing boilerplate in > dumping a bunch of regs in debugfs, but we also want to be able to > print to dmesg them at runtime for driver debugging. drm_printer lets > us format debugfs and the printk the same way. Looks good to me! Reviewed-by: Paul Kocialkowski Cheers, Paul > Signed-off-by: Eric Anholt > --- > drivers/gpu/drm/drm_print.c | 16 ++++++++++++++++ > include/drm/drm_print.h | 2 ++ > 2 files changed, 18 insertions(+) > > diff --git a/drivers/gpu/drm/drm_print.c b/drivers/gpu/drm/drm_print.c > index 0e7fc3e7dfb4..5ecc0f04cd0c 100644 > --- a/drivers/gpu/drm/drm_print.c > +++ b/drivers/gpu/drm/drm_print.c > @@ -253,3 +253,19 @@ void drm_err(const char *format, ...) > va_end(args); > } > EXPORT_SYMBOL(drm_err); > + > +void drm_print_regset32(struct drm_printer *p, struct debugfs_regset32 *regset) > +{ > + int namelen = 0; > + int i; > + > + for (i = 0; i < regset->nregs; i++) > + namelen = max(namelen, (int)strlen(regset->regs[i].name)); > + > + for (i = 0; i < regset->nregs; i++) { > + drm_printf(p, "%*s = 0x%08x\n", > + namelen, regset->regs[i].name, > + readl(regset->base + regset->regs[i].offset)); > + } > +} > +EXPORT_SYMBOL(drm_print_regset32); > diff --git a/include/drm/drm_print.h b/include/drm/drm_print.h > index afbc3beef089..3a4247319e63 100644 > --- a/include/drm/drm_print.h > +++ b/include/drm/drm_print.h > @@ -30,6 +30,7 @@ > #include > #include > #include > +#include > > /** > * DOC: print > @@ -84,6 +85,7 @@ void __drm_printfn_debug(struct drm_printer *p, struct va_format *vaf); > __printf(2, 3) > void drm_printf(struct drm_printer *p, const char *f, ...); > void drm_puts(struct drm_printer *p, const char *str); > +void drm_print_regset32(struct drm_printer *p, struct debugfs_regset32 *regset); > > __printf(2, 0) > /** -- Paul Kocialkowski, Bootlin Embedded Linux and kernel engineering https://bootlin.com