Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp286032ybb; Fri, 3 Apr 2020 02:42:01 -0700 (PDT) X-Google-Smtp-Source: APiQypJDz3F469Y0rrhw8D6VVl5A2fGwaS9I3KLfGNUuC5E2nbg5oGZto9o+kCYje5gPMebkuf+u X-Received: by 2002:a9d:7a45:: with SMTP id z5mr5468767otm.181.1585906921061; Fri, 03 Apr 2020 02:42:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585906921; cv=none; d=google.com; s=arc-20160816; b=C/r/szCTuB2T/mQYq4cVrE2OS5bydZ1TFBN7au6j40YTj2eVhSfTIyIayFmT2MSNKm 5O+X+EyMFSVgGB+lNOSPRZB4eOUDXLSEcf/I2mE/fuKHxB2H0bp/bG+3P/xM2lQyiSdr cZc84eAPWI7266+bbLFy5JG7BAiYFnfO1H2b2SDFnNtMou4svshiIJ/OFzmIXx2/DhnG HZN5dFbfGDjl3zXiPdnyIZxt5sUXF41iYJnY2bv9QKhwQx9/fVckv7mZWsq+u8Qnw7F9 gUUdZ5Z92DoA8lqqkntYlyrh96+QPXcjsSO9cXgH1DDfbGnNw4Y9SSp5Q+eAjaBurNHG wdVQ== 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:message-id:subject:cc :to:from:date:ironport-sdr:ironport-sdr; bh=KW9iWuhCztJU4BIeHeuCfHvwvz9XOnL13/aOnDgrsmU=; b=nROzhEcuemFOpI2LHm3cA0mtSfcp64gho6QyfZmvPbJKBYSlKfzKYiAAFIUfX/3tp4 CeWw2ok9xM/vi/gyPU23lNUpqViobS5OrNSLHaI3FChhY2Y5q4VTAJ9phGCE1kbFcnSF SG0v88lMTE+X+XECnnW4hiiBMbAuhbGVTHxpl59Cdkey6P5UDnWbUldLrqKK2r3sjnc5 HkTtJCDgP57k9PzuWB1w8Qq5KLuJNNbfBwyDv/zs/X8aaw6zRET00H8kB+OJOSFrjSM8 ErtgI872MOYVgCpMGJXnNRzQJoFO2HZsIXfYvSYAPNpK1Pb9KFWhtEaB529NsJtghfBC /v5g== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h145si3413589oib.210.2020.04.03.02.41.48; Fri, 03 Apr 2020 02:42:01 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390693AbgDCJj5 (ORCPT + 99 others); Fri, 3 Apr 2020 05:39:57 -0400 Received: from mga01.intel.com ([192.55.52.88]:26488 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390660AbgDCJj4 (ORCPT ); Fri, 3 Apr 2020 05:39:56 -0400 IronPort-SDR: GgMkbqAjlXj6Kj5UAAIlHGvbBBOldu6VzORqlDGN7fEQn1IcKDGHXvLtYKpNK5QZYG5lZ+5DwK a8yGyErHQ6qQ== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by fmsmga101.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 03 Apr 2020 02:39:26 -0700 IronPort-SDR: mrfzUyQhdnAbx6mzKGKFsTZVO2V/SsCPoTEyp8okqq/FlyrMWR9/Xl6C1QvBColw/C4o0d4tcH M/aQK3AzdKQA== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.72,339,1580803200"; d="scan'208";a="451242657" Received: from seemahan-mobl.ger.corp.intel.com (HELO kekkonen.fi.intel.com) ([10.249.38.56]) by fmsmga006.fm.intel.com with ESMTP; 03 Apr 2020 02:39:22 -0700 Received: by kekkonen.fi.intel.com (Postfix, from userid 1000) id 6354521F19; Fri, 3 Apr 2020 12:39:17 +0300 (EEST) Date: Fri, 3 Apr 2020 12:39:16 +0300 From: Sakari Ailus To: Andy Shevchenko Cc: Petr Mladek , linux-media@vger.kernel.org, Dave Stevenson , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, hverkuil@xs4all.nl, laurent.pinchart@ideasonboard.com, mchehab@kernel.org, Sergey Senozhatsky , Steven Rostedt , Joe Perches , Jani Nikula Subject: Re: [PATCH v2 1/1] lib/vsprintf: Add support for printing V4L2 and DRM fourccs Message-ID: <20200403093916.GA3172@kekkonen.localdomain> References: <20200403091156.7814-1-sakari.ailus@linux.intel.com> <20200403093103.GI1922688@smile.fi.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200403093103.GI1922688@smile.fi.intel.com> 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 Hi Andy, Thanks for the comments. On Fri, Apr 03, 2020 at 12:31:03PM +0300, Andy Shevchenko wrote: > On Fri, Apr 03, 2020 at 12:11:56PM +0300, Sakari Ailus wrote: > > Add a printk modifier %ppf (for pixel format) for printing V4L2 and DRM > > pixel formats denoted by 4ccs. The 4cc encoding is the same for both so > > the same implementation can be used. > > ... > > > +static noinline_for_stack > > +char *fourcc_string(char *buf, char *end, const u32 *fourcc, > > + struct printf_spec spec, const char *fmt) > > +{ > > > +#define FOURCC_STRING_BE "-BE" > > + char s[sizeof(*fourcc) + sizeof(FOURCC_STRING_BE)] = { 0 }; > > I guess it makes it too complicated. The above also clearly binds the size to the data that is expected to contain there. I'd prefer keeping it as-is. And yes, 8 would be correct, too. > > char s[8]; > > > + if (check_pointer(&buf, end, fourcc, spec)) > > + return buf; > > + > > + if (fmt[1] != 'c' || fmt[2] != 'c') > > + return error_string(buf, end, "(%p4?)", spec); > > + > > > + put_unaligned_le32(*fourcc & ~BIT(31), s); > > Can you elaborate what the difference in output with this bit set over cleared? > I.o.w. why don't we need to put it as BE and for LE case addd "-LE"? The established practice is that big endian formats have "-BE" suffix whereas the little endian ones have nothing. (At least when it comes to V4L2.) > > > + if (*fourcc & BIT(31)) > > + strscpy(s + sizeof(*fourcc), FOURCC_STRING_BE, > > + sizeof(FOURCC_STRING_BE)); > > We know the size, and we may put '\0' as well > if (*fourcc & BIT(31)) > strscpy(&s[4], "-BE", sizeof("-BE")); > else > strscpy(&s[4], "", sizeof("")); The rest of the struct memory has already been set to zero in variable declaration. -- Kind regards, Sakari Ailus