Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp1808303ybe; Tue, 3 Sep 2019 03:55:53 -0700 (PDT) X-Google-Smtp-Source: APXvYqwb+mQ+phON1GvQHu2By6GJWra235/Fefp4FPQuly4CXZOnd0Dz5k9a+yGYzEjv/VoSllGd X-Received: by 2002:a17:902:b605:: with SMTP id b5mr5500479pls.103.1567508153397; Tue, 03 Sep 2019 03:55:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567508153; cv=none; d=google.com; s=arc-20160816; b=OZJyiydltmHEpQb+e9Zg8Vco+4WSfxNPhpQ1v7TEjdaaHt8a7xUxT9v//TQwQDyL+b o/J2wCxg4ON9VB5t3xup/syetjgR7vPv+rbZih7c0w3gRd8/ed/GSKUdlq7kKOwwQtyC qYQi90FrK6cgohLgfsqpAQqkQuuWKhRf4KqvkXM3dk7q6K6ipN3KnWivn3llU2FeGQMw omk2a6KeHbLfwWCZRckhUoc7hsQ7rur3sdnZTdS6irbZn1Bw+hVnmPvoRXkzeJlL8hFZ BY+wNpKYfa1BFvIqbWuhUI6mCqp5d1D3i1hA82m3TXP6rgfw/SsA8HEgS2bPkOCvxiGF pqgQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:mail-followup-to :message-id:subject:cc:to:from:date:dkim-signature; bh=LfolOzk1BxHRrQFKBBtT+6uQRmEmOb3P6qDOK43OCow=; b=zyvtQiyOQYYmyRUvT+ytZhb5t2y1IRT73haelEzKzzxRxxOPXAe6im19T7oKzcvfyd iChbt5WzEo/XbWLOOo7n6DC7J99FhgI9Wxw8bNi7O0rXHOfUQYUSl1FovPMKQJd3HSm4 6o29xWSGA6rsN+yapKgGleceuXCb3Tr7HY0nakPt1LK3ilyJEt2G02lIz5uV3v6vMqBN Izb6UfQDTpRnnLYfEG7UqB42Zz+PvORuK72p12Yv793ExCAbcrul6hcvfibOpevuydft cUQLC5KPlDqkowdCyz2Z+uhs5yE1o9Fi5Z/NEjxoueKTKVnfTj3CRnVp5qaeYwcy7z0e +jTA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ffwll.ch header.s=google header.b="aX3gEPe/"; 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 n24si14719075pjq.85.2019.09.03.03.55.37; Tue, 03 Sep 2019 03:55:53 -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; dkim=fail header.i=@ffwll.ch header.s=google header.b="aX3gEPe/"; 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 S1728700AbfICKyl (ORCPT + 99 others); Tue, 3 Sep 2019 06:54:41 -0400 Received: from mail-ed1-f67.google.com ([209.85.208.67]:41721 "EHLO mail-ed1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728571AbfICKyl (ORCPT ); Tue, 3 Sep 2019 06:54:41 -0400 Received: by mail-ed1-f67.google.com with SMTP id z9so12843363edq.8 for ; Tue, 03 Sep 2019 03:54:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=sender:date:from:to:cc:subject:message-id:mail-followup-to :references:mime-version:content-disposition:in-reply-to:user-agent; bh=LfolOzk1BxHRrQFKBBtT+6uQRmEmOb3P6qDOK43OCow=; b=aX3gEPe/z4TuMjilqqC8NAae5WbmK/CindbAF5loLBCRbttVeiajRY2Xs+DOm7OrLF n79DhqQjif/rkDQbW0w8cLEFGNSwV6/UtLlFBj9ACTBU52tywKKzmrxgi2aJCUzEw22w SyjbC+XrsnGLmTuOdKIJBMmPYQ/9NzPExDptE= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :mail-followup-to:references:mime-version:content-disposition :in-reply-to:user-agent; bh=LfolOzk1BxHRrQFKBBtT+6uQRmEmOb3P6qDOK43OCow=; b=bPMApD15F9FMvvDXX3ZHnJvaONBz9h7w8WuR0qrQ3uRg6AvGAGymhCvKDxqmd0s2uF Lf5thkt5ZXRFXwkMAKJCdQ7siEjAWveXiMxjlPmtU40C3orgR+ivd4wA6yfw8Tj0OCv8 +nUioCQclPgH0xMEAzRO8uWLWRAPL78th2foGKdbrD9EyAgBTKg9RlxAv5PlMdxWTrOv cOkdxoJ+NxoDkCQFABR3MJOqhfII0uM1MAH0PeDPth/lHzSKGQvpZX6iiUT56csHVt1K JPCotfhRpu9eldC9awe1NyGMxr019cVa4rLVLra7gaYHXd7AZMbw+LVDcn+aiTlUgWCw EiDA== X-Gm-Message-State: APjAAAXmHvxFV85fAlC0u02CiNmkoaN5JdNeZVFT9yh6CldmwLM302f+ MxTzFAZjSs83PFcHKYBUyWI7dA== X-Received: by 2002:a17:906:a957:: with SMTP id hh23mr19832335ejb.82.1567508079238; Tue, 03 Sep 2019 03:54:39 -0700 (PDT) Received: from phenom.ffwll.local (212-51-149-96.fiber7.init7.net. [212.51.149.96]) by smtp.gmail.com with ESMTPSA id u14sm3435231edy.55.2019.09.03.03.54.37 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 Sep 2019 03:54:38 -0700 (PDT) Date: Tue, 3 Sep 2019 12:54:36 +0200 From: Daniel Vetter To: Gerd Hoffmann Cc: dri-devel@lists.freedesktop.org, Maarten Lankhorst , Maxime Ripard , Sean Paul , David Airlie , Daniel Vetter , open list Subject: Re: [PATCH v2 1/6] drm: add drm_print_bits Message-ID: <20190903105436.GU2112@phenom.ffwll.local> Mail-Followup-To: Gerd Hoffmann , dri-devel@lists.freedesktop.org, Maarten Lankhorst , Maxime Ripard , Sean Paul , David Airlie , open list References: <20190903101248.12879-1-kraxel@redhat.com> <20190903101248.12879-2-kraxel@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190903101248.12879-2-kraxel@redhat.com> X-Operating-System: Linux phenom 5.2.0-2-amd64 User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Sep 03, 2019 at 12:12:43PM +0200, Gerd Hoffmann wrote: > New helper to print named bits of some value (think flags fields). > > Signed-off-by: Gerd Hoffmann > --- > include/drm/drm_print.h | 3 +++ > drivers/gpu/drm/drm_print.c | 36 ++++++++++++++++++++++++++++++++++++ > 2 files changed, 39 insertions(+) > > diff --git a/include/drm/drm_print.h b/include/drm/drm_print.h > index a5d6f2f3e430..8658c1da1c7d 100644 > --- a/include/drm/drm_print.h > +++ b/include/drm/drm_print.h > @@ -88,6 +88,9 @@ __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); > +void drm_print_bits(struct drm_printer *p, unsigned int indent, > + const char *label, unsigned int value, > + const char *bits[], unsigned int nbits); > > __printf(2, 0) > /** > diff --git a/drivers/gpu/drm/drm_print.c b/drivers/gpu/drm/drm_print.c > index a17c8a14dba4..7f7aba920f51 100644 > --- a/drivers/gpu/drm/drm_print.c > +++ b/drivers/gpu/drm/drm_print.c > @@ -179,6 +179,42 @@ void drm_printf(struct drm_printer *p, const char *f, ...) > } > EXPORT_SYMBOL(drm_printf); > > +/** > + * drm_print_bits - print bits to a &drm_printer stream > + * > + * Print bits (in flag fields for example) in human readable form. > + * > + * @p: the &drm_printer > + * @indent: Tab indentation level (max 5) > + * @label: field label. > + * @value: field value. > + * @bits: Array with bit names. > + * @nbits: bit name array size. > + */ > +void drm_print_bits(struct drm_printer *p, unsigned int indent, > + const char *label, unsigned int value, > + const char *bits[], unsigned int nbits) > +{ > + bool first = true; > + unsigned int i; > + > + for (i = 0; i < nbits; i++) { > + if (!(value & (1 << i))) > + continue; > + if (!bits[i]) I think this should be a WARN_ON, indicates a programming error? > + continue; > + if (first) { > + first = false; > + drm_printf_indent(p, indent, "%s=%s", > + label, bits[i]); Hm, to make this a bit more flexible to use I'd drop the label= printing ... > + } else > + drm_printf(p, ",%s", bits[i]); > + } > + if (!first) > + drm_printf(p, "\n"); ... and also the newline. Then you could also use this for bit-fields which just a few bits. Also, should we print anything if no bit is set? If you prefer the label= + \n then pls add that to the kerneldoc, that it prints this as a line of its own. -Daniel > +} > +EXPORT_SYMBOL(drm_print_bits); > + > void drm_dev_printk(const struct device *dev, const char *level, > const char *format, ...) > { > -- > 2.18.1 > -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch