Received: by 2002:a05:6358:53a8:b0:117:f937:c515 with SMTP id z40csp4144781rwe; Mon, 17 Apr 2023 08:32:11 -0700 (PDT) X-Google-Smtp-Source: AKy350Yi3E2p9uso1qSRJBUPQSpB5ntGAOZprsP1JDcgGw+CSedMAjx7blloe4N5XqP3LGhMcka2 X-Received: by 2002:a05:6a20:2896:b0:eb:bbd1:6d6c with SMTP id q22-20020a056a20289600b000ebbbd16d6cmr14632448pzf.21.1681745531289; Mon, 17 Apr 2023 08:32:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681745531; cv=none; d=google.com; s=arc-20160816; b=P1bsR/imLFpuzn9lh5FssP/8j0+jR/3ltREI7GBJOMX6/CkOTt+vrVFweSEnePottS wgFyLwp25xD8aH5DyNnBFYYzqBOi13fXmi6zt2wRZgA0F7WRfpYJg2ssgxH/ltSnUava Uj/AUePDRn9nZ1k7YDoG4JK3SLcSlbxU3ZcR6U8ZzOmhNZY6upm/QZsRB4vZWURAP4Zr Tl3rVRz0okCBGpzMYTS1k7jjpPbRTxLJ6vOOquwUFQ93DA/aqEFo2nhENvBuXO9guhiA e0mCAgZMzQaroa+DOieD3HF7ket9v+da3kYW2wl7erVG7F0DyMh30PvNTo09ff23vWn6 qiTQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=Dim/eRKwOshrQgrP39p6MYdsVDVSpbxAyUQgA3V2W3o=; b=TFC6P2m7ELH15GqZokGnIx2cGGIsJosOGEi8RTna5Mr38gj3esmjo4QFiV0W7xiNre DoHa8XJHjPWLxQ80qe+4ZSJEavsWsY8Wu10L+KLeKDEYbLV4SxQQiwUnKc4eDX6fekjI qK08o0GJDLScN2bQleMkq3ah3nDeQqCVJuP5MO4M17p/rtBcfuorWaSod+1moioWCixp 7OHWJ+0b0SB3MYklSUIXKQh3vEZlWPKOW9owZHJVDiC0ERRwAgfNrrOz+TlW/u7YjVL9 OytpVpt0BXcCiHpKI0RU9XzfHNQZrKlRIWb4nF1PMXu1meGYMMivd7Qw/RIXUlPRZCSV 239Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=Gb+003oP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id e11-20020a17090a9a8b00b00246f9ac052asi11549299pjp.89.2023.04.17.08.31.59; Mon, 17 Apr 2023 08:32:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=Gb+003oP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230349AbjDQP2A (ORCPT + 99 others); Mon, 17 Apr 2023 11:28:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53034 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229854AbjDQP17 (ORCPT ); Mon, 17 Apr 2023 11:27:59 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 78B4CC170; Mon, 17 Apr 2023 08:27:25 -0700 (PDT) Received: from pendragon.ideasonboard.com (133-32-181-51.west.xps.vectant.ne.jp [133.32.181.51]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id C3A04F95; Mon, 17 Apr 2023 17:27:15 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1681745236; bh=wthbCcSWIU8JnT/FLJdbW67i7ir9ec7QjMVQSyi39pc=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=Gb+003oPOYMGEOt6ITB4fiWdMUGOtBLfDNsiakYuu4dNmTBe3AZwHnLUkUYCQbuZa SoAgcezFEBlZqOtaeBnR0KpYjQMlFGqHDENsfbDwv1UluAR2j6Sq3UQgAsDt7ZVofs TTWClk4abQJZEaC1lrTvzrkCyszuQvmUCbqFBGuM= Date: Mon, 17 Apr 2023 18:27:31 +0300 From: Laurent Pinchart To: Geert Uytterhoeven Cc: Bin Liu , Mauro Carvalho Chehab , Mikhail Ulyanov , Andrzej Pietrasiewicz , Jacek Anaszewski , Sylwester Nawrocki , Matthias Brugger , AngeloGioacchino Del Regno , linux-media@vger.kernel.org, linux-renesas-soc@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org, kernel test robot Subject: Re: [PATCH] media: Add common header file with JPEG marker definitions Message-ID: <20230417152731.GC19964@pendragon.ideasonboard.com> References: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Geert, Thank you for the patch. On Mon, Apr 17, 2023 at 12:31:35PM +0200, Geert Uytterhoeven wrote: > When compile-testing on mips/RB532 with W=1: > > arch/mips/include/asm/mach-rc32434/rb.h:13: note: this is the location of the previous definition > 13 | #define RST (1 << 15) > | > drivers/media/platform/mediatek/jpeg/mtk_jpeg_dec_parse.c:15: warning: "RST" redefined > 15 | #define RST 0xd0 > | > drivers/media/platform/renesas/rcar_jpu.c:77: warning: "RST" redefined > 77 | #define RST 0xd0 > | > > "RST" is indeed a name too short to be conflict-free. > > Fix this by creating a common header file, containing > definitions for all JPEG markers used, prefixed by "JPEG_MARKER_", based > on the existing private definitions in the Samsung S5P JPEG driver, and > convert all affected drivers. > > Reported-by: kernel test robot > Link: https://lore.kernel.org/oe-kbuild-all/202304152346.hJOPxPRh-lkp@intel.com/ > Link: https://lore.kernel.org/oe-kbuild-all/202304150059.bHUyuriy-lkp@intel.com/ > Signed-off-by: Geert Uytterhoeven Reviewed-by: Laurent Pinchart > --- > No change in generated code before/after. > --- > .../mediatek/jpeg/mtk_jpeg_dec_parse.c | 17 ++---- > drivers/media/platform/renesas/rcar_jpu.c | 55 +++++++++---------- > .../platform/samsung/s5p-jpeg/jpeg-core.h | 12 +--- > include/media/jpeg.h | 20 +++++++ > 4 files changed, 52 insertions(+), 52 deletions(-) > create mode 100644 include/media/jpeg.h > > diff --git a/drivers/media/platform/mediatek/jpeg/mtk_jpeg_dec_parse.c b/drivers/media/platform/mediatek/jpeg/mtk_jpeg_dec_parse.c > index b95c45791c29edc5..bb9cdc9e0e90912b 100644 > --- a/drivers/media/platform/mediatek/jpeg/mtk_jpeg_dec_parse.c > +++ b/drivers/media/platform/mediatek/jpeg/mtk_jpeg_dec_parse.c > @@ -7,15 +7,10 @@ > > #include > #include > +#include > > #include "mtk_jpeg_dec_parse.h" > > -#define TEM 0x01 > -#define SOF0 0xc0 > -#define RST 0xd0 > -#define SOI 0xd8 > -#define EOI 0xd9 > - > struct mtk_jpeg_stream { > u8 *addr; > u32 size; > @@ -83,7 +78,7 @@ static bool mtk_jpeg_do_parse(struct mtk_jpeg_dec_param *param, u8 *src_addr_va, > > length = 0; > switch (byte) { > - case SOF0: > + case JPEG_MARKER_SOF0: > /* length */ > if (read_word_be(&stream, &word)) > break; > @@ -123,10 +118,10 @@ static bool mtk_jpeg_do_parse(struct mtk_jpeg_dec_param *param, u8 *src_addr_va, > > notfound = !(i == param->comp_num); > break; > - case RST ... RST + 7: > - case SOI: > - case EOI: > - case TEM: > + case JPEG_MARKER_RST ... JPEG_MARKER_RST + 7: > + case JPEG_MARKER_SOI: > + case JPEG_MARKER_EOI: > + case JPEG_MARKER_TEM: > break; > default: > if (read_word_be(&stream, &word)) > diff --git a/drivers/media/platform/renesas/rcar_jpu.c b/drivers/media/platform/renesas/rcar_jpu.c > index d1dda68bfb5e2087..25d3f0376d6709ba 100644 > --- a/drivers/media/platform/renesas/rcar_jpu.c > +++ b/drivers/media/platform/renesas/rcar_jpu.c > @@ -28,6 +28,7 @@ > #include > #include > #include > +#include > #include > #include > #include > @@ -71,19 +72,6 @@ > #define JPU_JPEG_DEFAULT_422_PIX_FMT V4L2_PIX_FMT_NV16M > #define JPU_JPEG_DEFAULT_420_PIX_FMT V4L2_PIX_FMT_NV12M > > -/* JPEG markers */ > -#define TEM 0x01 > -#define SOF0 0xc0 > -#define RST 0xd0 > -#define SOI 0xd8 > -#define EOI 0xd9 > -#define DHP 0xde > -#define DHT 0xc4 > -#define COM 0xfe > -#define DQT 0xdb > -#define DRI 0xdd > -#define APP0 0xe0 > - > #define JPU_RESET_TIMEOUT 100 /* ms */ > #define JPU_JOB_TIMEOUT 300 /* ms */ > #define JPU_MAX_QUALITY 4 > @@ -330,26 +318,32 @@ static const u8 zigzag[] = { > * Huffman tables; Padding with 0xff (33.3.27 R01UH0501EJ0100 Rev.1.00) > */ > #define JPU_JPEG_HDR_BLOB { \ > - 0xff, SOI, 0xff, DQT, 0x00, JPU_JPEG_QTBL_SIZE + 0x3, JPU_JPEG_LUM, \ > - [JPU_JPEG_QTBL_LUM_OFFSET ... \ > + 0xff, JPEG_MARKER_SOI, 0xff, JPEG_MARKER_DQT, 0x00, \ > + JPU_JPEG_QTBL_SIZE + 0x3, JPU_JPEG_LUM, \ > + [JPU_JPEG_QTBL_LUM_OFFSET ... \ > JPU_JPEG_QTBL_LUM_OFFSET + JPU_JPEG_QTBL_SIZE - 1] = 0x00, \ > - 0xff, DQT, 0x00, JPU_JPEG_QTBL_SIZE + 0x3, JPU_JPEG_CHR, \ > + 0xff, JPEG_MARKER_DQT, 0x00, JPU_JPEG_QTBL_SIZE + 0x3, JPU_JPEG_CHR, \ > [JPU_JPEG_QTBL_CHR_OFFSET ... JPU_JPEG_QTBL_CHR_OFFSET + \ > - JPU_JPEG_QTBL_SIZE - 1] = 0x00, 0xff, SOF0, 0x00, 0x11, 0x08, \ > + JPU_JPEG_QTBL_SIZE - 1] = 0x00, \ > + 0xff, JPEG_MARKER_SOF0, 0x00, 0x11, 0x08, \ > [JPU_JPEG_HEIGHT_OFFSET ... JPU_JPEG_HEIGHT_OFFSET + 1] = 0x00, \ > [JPU_JPEG_WIDTH_OFFSET ... JPU_JPEG_WIDTH_OFFSET + 1] = 0x00, \ > 0x03, 0x01, [JPU_JPEG_SUBS_OFFSET] = 0x00, JPU_JPEG_LUM, \ > 0x02, 0x11, JPU_JPEG_CHR, 0x03, 0x11, JPU_JPEG_CHR, \ > - 0xff, DHT, 0x00, JPU_JPEG_HDCTBL_SIZE + 0x3, JPU_JPEG_LUM|JPU_JPEG_DC, \ > + 0xff, JPEG_MARKER_DHT, 0x00, JPU_JPEG_HDCTBL_SIZE + 0x3, \ > + JPU_JPEG_LUM | JPU_JPEG_DC, \ > [JPU_JPEG_HDCTBL_LUM_OFFSET ... \ > JPU_JPEG_HDCTBL_LUM_OFFSET + JPU_JPEG_HDCTBL_SIZE - 1] = 0x00, \ > - 0xff, DHT, 0x00, JPU_JPEG_HACTBL_SIZE + 0x3, JPU_JPEG_LUM|JPU_JPEG_AC, \ > + 0xff, JPEG_MARKER_DHT, 0x00, JPU_JPEG_HACTBL_SIZE + 0x3, \ > + JPU_JPEG_LUM | JPU_JPEG_AC, \ > [JPU_JPEG_HACTBL_LUM_OFFSET ... \ > JPU_JPEG_HACTBL_LUM_OFFSET + JPU_JPEG_HACTBL_SIZE - 1] = 0x00, \ > - 0xff, DHT, 0x00, JPU_JPEG_HDCTBL_SIZE + 0x3, JPU_JPEG_CHR|JPU_JPEG_DC, \ > + 0xff, JPEG_MARKER_DHT, 0x00, JPU_JPEG_HDCTBL_SIZE + 0x3, \ > + JPU_JPEG_CHR | JPU_JPEG_DC, \ > [JPU_JPEG_HDCTBL_CHR_OFFSET ... \ > JPU_JPEG_HDCTBL_CHR_OFFSET + JPU_JPEG_HDCTBL_SIZE - 1] = 0x00, \ > - 0xff, DHT, 0x00, JPU_JPEG_HACTBL_SIZE + 0x3, JPU_JPEG_CHR|JPU_JPEG_AC, \ > + 0xff, JPEG_MARKER_DHT, 0x00, JPU_JPEG_HACTBL_SIZE + 0x3, \ > + JPU_JPEG_CHR | JPU_JPEG_AC, \ > [JPU_JPEG_HACTBL_CHR_OFFSET ... \ > JPU_JPEG_HACTBL_CHR_OFFSET + JPU_JPEG_HACTBL_SIZE - 1] = 0x00, \ > [JPU_JPEG_PADDING_OFFSET ... JPU_JPEG_HDR_SIZE - 1] = 0xff \ > @@ -613,7 +607,8 @@ static u8 jpu_parse_hdr(void *buffer, unsigned long size, unsigned int *width, > * basic size check and EOI - we don't want to let JPU cross > * buffer bounds in any case. Hope it's stopping by EOI. > */ > - if (size < JPU_JPEG_MIN_SIZE || *(u8 *)(buffer + size - 1) != EOI) > + if (size < JPU_JPEG_MIN_SIZE || > + *(u8 *)(buffer + size - 1) != JPEG_MARKER_EOI) > return 0; > > for (;;) { > @@ -624,14 +619,14 @@ static u8 jpu_parse_hdr(void *buffer, unsigned long size, unsigned int *width, > c = get_byte(&jpeg_buffer); > while (c == 0xff || c == 0); > > - if (!soi && c == SOI) { > + if (!soi && c == JPEG_MARKER_SOI) { > soi = true; > continue; > - } else if (soi != (c != SOI)) > + } else if (soi != (c != JPEG_MARKER_SOI)) > return 0; > > switch (c) { > - case SOF0: /* SOF0: baseline JPEG */ > + case JPEG_MARKER_SOF0: /* SOF0: baseline JPEG */ > skip(&jpeg_buffer, 3); /* segment length and bpp */ > if (get_word_be(&jpeg_buffer, height) || > get_word_be(&jpeg_buffer, width) || > @@ -640,11 +635,11 @@ static u8 jpu_parse_hdr(void *buffer, unsigned long size, unsigned int *width, > > skip(&jpeg_buffer, 1); > return get_byte(&jpeg_buffer); > - case DHT: > - case DQT: > - case COM: > - case DRI: > - case APP0 ... APP0 + 0x0f: > + case JPEG_MARKER_DHT: > + case JPEG_MARKER_DQT: > + case JPEG_MARKER_COM: > + case JPEG_MARKER_DRI: > + case JPEG_MARKER_APP0 ... JPEG_MARKER_APP0 + 0x0f: > if (get_word_be(&jpeg_buffer, &word)) > return 0; > skip(&jpeg_buffer, (long)word - 2); > diff --git a/drivers/media/platform/samsung/s5p-jpeg/jpeg-core.h b/drivers/media/platform/samsung/s5p-jpeg/jpeg-core.h > index 5570c79f122f5a09..4b665a3b630f8bf9 100644 > --- a/drivers/media/platform/samsung/s5p-jpeg/jpeg-core.h > +++ b/drivers/media/platform/samsung/s5p-jpeg/jpeg-core.h > @@ -11,6 +11,7 @@ > #define JPEG_CORE_H_ > > #include > +#include > #include > #include > #include > @@ -36,17 +37,6 @@ > > #define EXYNOS3250_IRQ_TIMEOUT 0x10000000 > > -/* a selection of JPEG markers */ > -#define JPEG_MARKER_TEM 0x01 > -#define JPEG_MARKER_SOF0 0xc0 > -#define JPEG_MARKER_DHT 0xc4 > -#define JPEG_MARKER_RST 0xd0 > -#define JPEG_MARKER_SOI 0xd8 > -#define JPEG_MARKER_EOI 0xd9 > -#define JPEG_MARKER_SOS 0xda > -#define JPEG_MARKER_DQT 0xdb > -#define JPEG_MARKER_DHP 0xde > - > /* Flags that indicate a format can be used for capture/output */ > #define SJPEG_FMT_FLAG_ENC_CAPTURE (1 << 0) > #define SJPEG_FMT_FLAG_ENC_OUTPUT (1 << 1) > diff --git a/include/media/jpeg.h b/include/media/jpeg.h > new file mode 100644 > index 0000000000000000..a01e142e99a7d001 > --- /dev/null > +++ b/include/media/jpeg.h > @@ -0,0 +1,20 @@ > +/* SPDX-License-Identifier: GPL-2.0-only */ > + > +#ifndef _MEDIA_JPEG_H_ > +#define _MEDIA_JPEG_H_ > + > +/* JPEG markers */ > +#define JPEG_MARKER_TEM 0x01 > +#define JPEG_MARKER_SOF0 0xc0 > +#define JPEG_MARKER_DHT 0xc4 > +#define JPEG_MARKER_RST 0xd0 > +#define JPEG_MARKER_SOI 0xd8 > +#define JPEG_MARKER_EOI 0xd9 > +#define JPEG_MARKER_SOS 0xda > +#define JPEG_MARKER_DQT 0xdb > +#define JPEG_MARKER_DRI 0xdd > +#define JPEG_MARKER_DHP 0xde > +#define JPEG_MARKER_APP0 0xe0 > +#define JPEG_MARKER_COM 0xfe > + > +#endif /* _MEDIA_JPEG_H_ */ -- Regards, Laurent Pinchart