Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp4280771rwn; Sun, 11 Sep 2022 08:39:33 -0700 (PDT) X-Google-Smtp-Source: AA6agR6HgW7jtEtXF5BOnKL5qM84tobsZcuaC4lTT7ZhMg48H9YUwVy/a6hQj1BT2l0I3F4sGUIT X-Received: by 2002:a05:6402:2499:b0:440:942a:40c2 with SMTP id q25-20020a056402249900b00440942a40c2mr19547139eda.37.1662910772961; Sun, 11 Sep 2022 08:39:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662910772; cv=none; d=google.com; s=arc-20160816; b=Qa86OXA5NwQiGNvyrmZAw5RPOngEjAAPdWtQlzEwNrUS7Bk35XqxRDPCCuD8UQFaUy CV0fOatM+eu8jr/hrs3sYV7IHDCPkhyou1wrSsoqoszGuAvfUSA1NRK05E5ihPo8KS5w yJGAMPIL+xsCkgTnCn932VbEfYE2j0g/aqsRIaM5HSaIn7s+w5H1GdPkuRDWxP8/+pXB zsLToXLGouR+W/XGhRoGtBkgvW3iaUmeF8q7pcTAiHBWoAtHFsVWQEJ2CPbdJ1vnUhHx HhZqhqMP6wjk5/V3dIwIaO4Nf7rtfUS/Z7UgiBHI8162UT74U+oOeauAWUAmmlqQOprk LxjQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=0vIafAUmfHKEkRBn1BJs65Ura+eUXhwSJOGqHqTk/x4=; b=aONCpBtfQcrHT9MtuYAiiTzH8ZZM+V8fpLIDGCMbrSfNhm70PCirf88FxlaOh4VuEM HB/rphPtsJS7Pt/7ewKR09OTzcVhE+H7WYWL4iKyB4yWxrME9tg094df9+U/93au0FY0 cQSDCiQNu9hpRrziKeOIP45G4u0VObqvkdwDklu4D4f1R8fBD7SYvs3cS3wmFYbxXCa/ dVf9rq6aoYmkz0tYHhB2MIdk/hQVa5YIR1EtPsm3O9MW6qHjoFVpRqn0+lGyiQoEdyN9 Pxc5rGL4+aeZCaxhUgtYswQID6Eb7hXvs+pTFHI1wS0j5oW9vk//84S4TFeIR3fSI5I8 UjFw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=NJS4McPg; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z12-20020a056402274c00b0043df9ca3ff8si6198577edd.50.2022.09.11.08.39.07; Sun, 11 Sep 2022 08:39:32 -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 header.i=@gmail.com header.s=20210112 header.b=NJS4McPg; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229544AbiIKOpN (ORCPT + 99 others); Sun, 11 Sep 2022 10:45:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46604 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229529AbiIKOpL (ORCPT ); Sun, 11 Sep 2022 10:45:11 -0400 Received: from mail-oo1-xc29.google.com (mail-oo1-xc29.google.com [IPv6:2607:f8b0:4864:20::c29]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 94D2524087 for ; Sun, 11 Sep 2022 07:45:09 -0700 (PDT) Received: by mail-oo1-xc29.google.com with SMTP id a1-20020a4ab101000000b0044acf001f83so1038467ooo.10 for ; Sun, 11 Sep 2022 07:45:09 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date; bh=0vIafAUmfHKEkRBn1BJs65Ura+eUXhwSJOGqHqTk/x4=; b=NJS4McPgY7YVVhIfIV57csmvoqjvrU55j9D6Wc9iSqTEgRFy8j3qEAE1UjmXRz1U79 4Htu424fqVQ7e9nJFgPrjdvwIRvzDt18q56G+QHX3nOlCO8JvI/Od8GOYQOIslX4yv5B A78rCHbCUulyAHTjhUZE1pqtbLRoxRdAeL26HmfT1WPX7bzaHTMqCNlLBsIOtfPP15hC uakI/GSkfR32eNOJOdjotsE2h3knKfnewnV6Yae/BSug5LUVoHMWkEpR0LCCBCVbnxk+ NCX6uUAlnYzvhpOoOdp3HuPBUZY1DS22UOUG+J+oka0wiwItja82WIKmvLUZt96wRNY/ 3j5w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date; bh=0vIafAUmfHKEkRBn1BJs65Ura+eUXhwSJOGqHqTk/x4=; b=bHAQLKpD/eirZ5re5lXyQFvyZmfhU2mzlw4aOTXDBNSSLTyKqMGgJiLLcGetzklw8v kp4Nv6FY4WeNMg/UD0jzxc+qvNQz7yhuiCzhwz/TpvJ8+M03g/zvBskLM/FMZQKl64Fn zNA/Ggnuby1ZjHaAdqGQliR4mG2JsUftPSvUJ13gPMDVhMfoA2kPFnwGTZ0hEV7rHB99 HX8tFEWn6gp/08JlJxmBgBuLQ/HEt4C8hibXcsjq/QyrbRfpcBSROXbPppN2Uq46YJDG 9DrZqI5/yTjHWsroOvHpePm3sXuVpI1pWsaYbiGMPnT/PT0XgajD5duQZTQnJR/4kL9F nn3w== X-Gm-Message-State: ACgBeo10AriPwagK1hpfwKjU7WOwiBymSKkQdfieLcYthPjfI2FQzhQr t5y2sBE8GVrdMTOuJYnjXng= X-Received: by 2002:a05:6820:1a0d:b0:44b:f59:8354 with SMTP id bq13-20020a0568201a0d00b0044b0f598354mr7856325oob.92.1662907508924; Sun, 11 Sep 2022 07:45:08 -0700 (PDT) Received: from ?IPV6:2804:431:c7f5:f684:ee06:25a5:3122:5cd3? ([2804:431:c7f5:f684:ee06:25a5:3122:5cd3]) by smtp.gmail.com with ESMTPSA id t6-20020a4a8246000000b0044b491ccf97sm2750663oog.25.2022.09.11.07.45.06 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Sun, 11 Sep 2022 07:45:08 -0700 (PDT) Message-ID: <5f6089e5-146a-78c7-6590-4ef0ec1ea043@gmail.com> Date: Sun, 11 Sep 2022 11:45:05 -0300 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.13.0 Subject: Re: [PATCH v2] drm/vkms: fix 32bit compilation error by replacing macros Content-Language: en-US To: Melissa Wen , rodrigosiqueiramelo@gmail.com, melissa.srw@gmail.com, airlied@linux.ie, daniel@ffwll.ch Cc: Sudip Mukherjee , Alex Deucher , Alex Deucher , kernel test robot , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20220910190303.682897-1-mwen@igalia.com> From: Igor Matheus Andrade Torrente In-Reply-To: <20220910190303.682897-1-mwen@igalia.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-6.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,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 Reviewed-by: Igor Torrente On 9/10/22 16:03, Melissa Wen wrote: > Replace vkms_formats macro for fixed-point operations with functions > from drm/drm_fixed.h to do the same job and fix 32-bit compilation > errors. > > v2: > - don't cast results to s32 (Igor) > - add missing drm_fixp2int conversion (Igor) > > Fixes: a19c2ac9858 ("drm: vkms: Add support to the RGB565 format") > Tested-by: Sudip Mukherjee (v1) > Reviewed-by: Alex Deucher (v1) > Reported-by: Sudip Mukherjee > Reported-by: kernel test robot > Signed-off-by: Melissa Wen > --- > drivers/gpu/drm/vkms/vkms_formats.c | 53 +++++++++++------------------ > 1 file changed, 19 insertions(+), 34 deletions(-) > > diff --git a/drivers/gpu/drm/vkms/vkms_formats.c b/drivers/gpu/drm/vkms/vkms_formats.c > index 300abb4d1dfe..d4950688b3f1 100644 > --- a/drivers/gpu/drm/vkms/vkms_formats.c > +++ b/drivers/gpu/drm/vkms/vkms_formats.c > @@ -1,27 +1,12 @@ > // SPDX-License-Identifier: GPL-2.0+ > > -#include > +#include > #include > +#include > +#include > > #include "vkms_formats.h" > > -/* The following macros help doing fixed point arithmetic. */ > -/* > - * With Fixed-Point scale 15 we have 17 and 15 bits of integer and fractional > - * parts respectively. > - * | 0000 0000 0000 0000 0.000 0000 0000 0000 | > - * 31 0 > - */ > -#define SHIFT 15 > - > -#define INT_TO_FIXED(a) ((a) << SHIFT) > -#define FIXED_MUL(a, b) ((s32)(((s64)(a) * (b)) >> SHIFT)) > -#define FIXED_DIV(a, b) ((s32)(((s64)(a) << SHIFT) / (b))) > -/* This macro converts a fixed point number to int, and round half up it */ > -#define FIXED_TO_INT_ROUND(a) (((a) + (1 << (SHIFT - 1))) >> SHIFT) > -#define INT_TO_FIXED_DIV(a, b) (FIXED_DIV(INT_TO_FIXED(a), INT_TO_FIXED(b))) > -#define INT_TO_FIXED_DIV(a, b) (FIXED_DIV(INT_TO_FIXED(a), INT_TO_FIXED(b))) > - > static size_t pixel_offset(const struct vkms_frame_info *frame_info, int x, int y) > { > return frame_info->offset + (y * frame_info->pitch) > @@ -137,19 +122,19 @@ static void RGB565_to_argb_u16(struct line_buffer *stage_buffer, > int x_limit = min_t(size_t, drm_rect_width(&frame_info->dst), > stage_buffer->n_pixels); > > - s32 fp_rb_ratio = INT_TO_FIXED_DIV(65535, 31); > - s32 fp_g_ratio = INT_TO_FIXED_DIV(65535, 63); > + s64 fp_rb_ratio = drm_fixp_div(drm_int2fixp(65535), drm_int2fixp(31)); > + s64 fp_g_ratio = drm_fixp_div(drm_int2fixp(65535), drm_int2fixp(63)); > > for (size_t x = 0; x < x_limit; x++, src_pixels++) { > u16 rgb_565 = le16_to_cpu(*src_pixels); > - s32 fp_r = INT_TO_FIXED((rgb_565 >> 11) & 0x1f); > - s32 fp_g = INT_TO_FIXED((rgb_565 >> 5) & 0x3f); > - s32 fp_b = INT_TO_FIXED(rgb_565 & 0x1f); > + s64 fp_r = drm_int2fixp((rgb_565 >> 11) & 0x1f); > + s64 fp_g = drm_int2fixp((rgb_565 >> 5) & 0x3f); > + s64 fp_b = drm_int2fixp(rgb_565 & 0x1f); > > out_pixels[x].a = (u16)0xffff; > - out_pixels[x].r = FIXED_TO_INT_ROUND(FIXED_MUL(fp_r, fp_rb_ratio)); > - out_pixels[x].g = FIXED_TO_INT_ROUND(FIXED_MUL(fp_g, fp_g_ratio)); > - out_pixels[x].b = FIXED_TO_INT_ROUND(FIXED_MUL(fp_b, fp_rb_ratio)); > + out_pixels[x].r = drm_fixp2int(drm_fixp_mul(fp_r, fp_rb_ratio)); > + out_pixels[x].g = drm_fixp2int(drm_fixp_mul(fp_g, fp_g_ratio)); > + out_pixels[x].b = drm_fixp2int(drm_fixp_mul(fp_b, fp_rb_ratio)); > } > } > > @@ -248,17 +233,17 @@ static void argb_u16_to_RGB565(struct vkms_frame_info *frame_info, > int x_limit = min_t(size_t, drm_rect_width(&frame_info->dst), > src_buffer->n_pixels); > > - s32 fp_rb_ratio = INT_TO_FIXED_DIV(65535, 31); > - s32 fp_g_ratio = INT_TO_FIXED_DIV(65535, 63); > + s64 fp_rb_ratio = drm_fixp_div(drm_int2fixp(65535), drm_int2fixp(31)); > + s64 fp_g_ratio = drm_fixp_div(drm_int2fixp(65535), drm_int2fixp(63)); > > for (size_t x = 0; x < x_limit; x++, dst_pixels++) { > - s32 fp_r = INT_TO_FIXED(in_pixels[x].r); > - s32 fp_g = INT_TO_FIXED(in_pixels[x].g); > - s32 fp_b = INT_TO_FIXED(in_pixels[x].b); > + s64 fp_r = drm_int2fixp(in_pixels[x].r); > + s64 fp_g = drm_int2fixp(in_pixels[x].g); > + s64 fp_b = drm_int2fixp(in_pixels[x].b); > > - u16 r = FIXED_TO_INT_ROUND(FIXED_DIV(fp_r, fp_rb_ratio)); > - u16 g = FIXED_TO_INT_ROUND(FIXED_DIV(fp_g, fp_g_ratio)); > - u16 b = FIXED_TO_INT_ROUND(FIXED_DIV(fp_b, fp_rb_ratio)); > + u16 r = drm_fixp2int(drm_fixp_div(fp_r, fp_rb_ratio)); > + u16 g = drm_fixp2int(drm_fixp_div(fp_g, fp_g_ratio)); > + u16 b = drm_fixp2int(drm_fixp_div(fp_b, fp_rb_ratio)); > > *dst_pixels = cpu_to_le16(r << 11 | g << 5 | b); > }