Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp338408pxb; Tue, 9 Feb 2021 01:28:40 -0800 (PST) X-Google-Smtp-Source: ABdhPJxhQuROzEOSLQXF2OBxl9Utre/WrsFdto2ykgKAMNz8QJSbJk0iouHMazXfVCPRkCHTm/2v X-Received: by 2002:a17:906:2747:: with SMTP id a7mr22088340ejd.250.1612862919990; Tue, 09 Feb 2021 01:28:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612862919; cv=none; d=google.com; s=arc-20160816; b=AyUjLwqEVa4ZWvVUFPnZvVeqyJAL0QRK+feOgewJA+lIDiz6GJ1jLE5SfSuKwtc3b0 bj6GKuIE6fP+VBHYSNSkRJfaj1gp+iGUADvKiv7Lyu5nKSoG7QLO98ZvAVxfn1+IYHeP prs6zr1IrxfpWnO5naw3URvDGPoxFUhbsrKG3y2e2z46DaR5d2lNm9M6wNFRrsRFZAjT /zgwkyVQtuzCZVlKLdj7A4pj/0d1FYzcjtPd9TT1sritedZ1I7BM3nLtNH3pFdbcv3HN bV/CpsFn2dKdODxDdXsi++QbCXBEFiCteNantGBQniHk9oFA9QIOeqVtuD2RZNSb959L wkuQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :ironport-sdr:ironport-sdr; bh=P8jD+7iZG+xzkQi0WNQENdGR1+PCFdKEPwW1i9DTM7Q=; b=nAn34dl354LyvwlRTz4Ca/FL3VK/0/K9I21jlQPX8fS0eKc4OAX9szGpgEaTfJ4OXK 339DIWc2OMX//CK8eg1KYw4YNVumjjyuQ/EEaIVZST0sUPXyDJWPsP7rehddvsSzFjmW jZTAT/IHLbCe0u9thiVOBr1KJo7TkEy+PyKJ99K7loQApYy6kLK+yVDIqXdjuZJOOZ7E h60VDAcRsKfFgI09MyVG9J2zVznU3F3B1SETJs0Ugp+XupEPUphz9+XgXkYvo6FDBIx2 c4YjqFjMvg1zS0jNUfO2GYwHpiKZF6YiDX13+uQFOBVF7LS5R/47sqaw1XaavIpBk39d F/SA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a9si3381472edv.308.2021.02.09.01.28.15; Tue, 09 Feb 2021 01:28:39 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229734AbhBIJZJ (ORCPT + 99 others); Tue, 9 Feb 2021 04:25:09 -0500 Received: from mga18.intel.com ([134.134.136.126]:48813 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230013AbhBIJWf (ORCPT ); Tue, 9 Feb 2021 04:22:35 -0500 IronPort-SDR: 6/oFOG9Dgrt5PvG3R1M5VPXNqJhNlR8spaJ9GS5pOOlsj4VbQ8LK9sv/K1TMvqq42oa8Y+e5A3 FJzlYSM94ANQ== X-IronPort-AV: E=McAfee;i="6000,8403,9889"; a="169533833" X-IronPort-AV: E=Sophos;i="5.81,164,1610438400"; d="scan'208";a="169533833" Received: from fmsmga007.fm.intel.com ([10.253.24.52]) by orsmga106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 09 Feb 2021 01:20:38 -0800 IronPort-SDR: +Z/5X24YSvj/nQVhkOlB08Xo4zq6U6D4CCsGwSc7d2XzQVC+10oR8jwhB2k54f/Kjo7zZeTa+9 UgZVBYxFb1Sw== X-IronPort-AV: E=Sophos;i="5.81,164,1610438400"; d="scan'208";a="360442487" Received: from paasikivi.fi.intel.com ([10.237.72.42]) by fmsmga007-auth.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 09 Feb 2021 01:20:34 -0800 Received: by paasikivi.fi.intel.com (Postfix, from userid 1000) id 70B12206D0; Tue, 9 Feb 2021 11:20:32 +0200 (EET) Date: Tue, 9 Feb 2021 11:20:32 +0200 From: Sakari Ailus To: Andy Shevchenko Cc: Linux Kernel Mailing List , Linux Media Mailing List , Andy Shevchenko , Petr Mladek , Dave Stevenson , dri-devel , Hans Verkuil , Laurent Pinchart , Mauro Carvalho Chehab , Sergey Senozhatsky , Steven Rostedt , Joe Perches , Jani Nikula , Rasmus Villemoes Subject: Re: [PATCH v6 1/3] lib/vsprintf: Add support for printing V4L2 and DRM fourccs Message-ID: <20210209092032.GC32460@paasikivi.fi.intel.com> References: <20210208200903.28084-1-sakari.ailus@linux.intel.com> <20210208200903.28084-2-sakari.ailus@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Andy, On Mon, Feb 08, 2021 at 10:43:30PM +0200, Andy Shevchenko wrote: > On Mon, Feb 8, 2021 at 10:11 PM Sakari Ailus > wrote: > > > > Add a printk modifier %p4cc (for pixel format) for printing V4L2 and DRM > > pixel formats denoted by fourccs. The fourcc encoding is the same for both > > so the same implementation can be used. > > Thank you for an update with the examples how current users will be > converted. Below review is based on the users I had seen so far and > assumptions made in this code. I see that it's tagged by maintainers, > but I can't help to comment again on this. In any case the decision is > up to them. > > ... > > > +V4L2 and DRM FourCC code (pixel format) > > +--------------------------------------- > > + > > +:: > > + > > + %p4cc > > + > > +Print a FourCC code used by V4L2 or DRM, including format endianness and > > +its numerical value as hexadecimal. > > + > > +Passed by reference. > > + > > +Examples:: > > + > > + %p4cc BG12 little-endian (0x32314742) > > This misses examples of the (strange) escaping cases and wiped > whitespaces to make sure everybody understands that 'D 12' will be the > same as 'D1 2' (side note: which I disagree on, perhaps something > should be added into documentation why). The spaces are expected to be at the end only. I can add such example if you like. There are no fourcc codes with spaces in the middle in neither V4L2 nor DRM, and I don't think the expectation is to have them either. > > ... > > > +static noinline_for_stack > > +char *fourcc_string(char *buf, char *end, const u32 *fourcc, > > + struct printf_spec spec, const char *fmt) > > +{ > > > + char output[sizeof("(xx)(xx)(xx)(xx) little-endian (0x01234567)")]; > > Do we have any evidence / document / standard that the above format is > what people would find good? From existing practices (I consider other > printings elsewhere and users in this series) I find '(xx)' form for > hex numbers is weird. The standard practice is to use \xHH (without > parentheses). Earlier in the review it was proposed that special handling of codes below 32 should be added, which I did. Using the parentheses is apparently an existing practice elsewhere. Note that neither DRM nor V4L2 currently has such fourcc codes currently. > > > + char *p = output; > > + unsigned int i; > > + u32 val; > > + > > + if (fmt[1] != 'c' || fmt[2] != 'c') > > + return error_string(buf, end, "(%p4?)", spec); > > + > > + if (check_pointer(&buf, end, fourcc, spec)) > > + return buf; > > + > > + val = *fourcc & ~BIT(31); > > + > > + for (i = 0; i < sizeof(*fourcc); i++) { > > + unsigned char c = val >> (i * 8); > > ... > > > + /* Weed out spaces */ > > + if (c == ' ') > > + continue; > > None of the existing users does that. Why? The existing instances of printing fourcc codes in V4L2 are scattered around with priority on implementation simplicity. As we have a single simplementation here, I'm not really worried about that. > > > + /* Print non-control ASCII characters as-is */ > > + if (isascii(c) && isprint(c)) { > > + *p++ = c; > > + continue; > > + } > > + > > + *p++ = '('; > > + p = hex_byte_pack(p, c); > > + *p++ = ')'; > > + } > > + > > + strcpy(p, *fourcc & BIT(31) ? " big-endian" : " little-endian"); > > + p += strlen(p); > > + > > + *p++ = ' '; > > + *p++ = '('; > > > + p = special_hex_number(p, output + sizeof(output) - 2, *fourcc, > > + sizeof(u32)); > > This is perfectly one line (in this file we have even longer lines). Sure, you can do that, and I can then review your patch and point to the coding style documentation. :-) > > > + *p++ = ')'; > > + *p = '\0'; > > + > > + return string(buf, end, output, spec); > > +} > -- Kind regards, Sakari Ailus