[PATCH] video: Add parentheses around VNBYTES() macro
Simon Glass
sjg at chromium.org
Tue Sep 19 03:04:41 CEST 2023
Hi Tom, Dan,
On Tue, 8 Aug 2023 at 19:39, Tom Rini <trini at konsulko.com> wrote:
>
> On Wed, Jul 26, 2023 at 09:54:08AM +0300, Dan Carpenter wrote:
>
> > The VNBYTES() macro needs to have parentheses to prevent some (harmless)
> > macro expansion bugs. The VNBYTES() macro is used like this:
> >
> > VID_TO_PIXEL(x) * VNBYTES(vid_priv->bpix)
> >
> > The * operation is done before the / operation. It still ends up with
> > the same results, but it's not ideal.
> >
> > Signed-off-by: Dan Carpenter <dan.carpenter at linaro.org>
> > Reviewed-by: Simon Glass <sjg at chromium.org>
>
> In that this seems correct:
>
> Applied to u-boot/next, thanks!
>
> But I want to note that with gcc-13.1 (and binutils 2.40) or more
> specifically the kernel.org arm/aarch64/etc toolchains, this causes the
> generated code to change:
> aarch64: (for 1/1 boards) all +8.0 text +8.0
> bananapi-m5 : all +8 text +8
> u-boot: add: 0/0, grow: 1/0 bytes: 8/0 (8)
> function old new delta
> video_post_probe 248 256 +8
>
> So I don't know that this was a harmless bug.
Hmm I should have read the comment directly above...
"Note we omit the outer brackets to allow multiplication by fractional pixels."
Having said that, it doesn't seem to matter getting (if indeed we do)
a less accurate result.
Regards,
Simon
More information about the U-Boot
mailing list