Re: [hatari-devel] undefined behaviour fixes |
[ Thread Index |
Date Index
| More lists.tuxfamily.org/hatari-devel Archives
]
- To: hatari-devel@xxxxxxxxxxxxxxxxxxx
- Subject: Re: [hatari-devel] undefined behaviour fixes
- From: David Savinkoff <dsavnkff@xxxxxxxxx>
- Date: Wed, 15 Jan 2025 15:40:07 -0800
- Dkim-signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=telus.net; s=google; t=1736984415; x=1737589215; darn=lists.tuxfamily.org; h=content-transfer-encoding:to:subject:message-id:date:from :in-reply-to:references:mime-version:from:to:cc:subject:date :message-id:reply-to; bh=BA7Z2Rv94C/0kqumsYzKd5SYEkO6NgD9qtRCVbXhEHU=; b=JVTErJl6N20vuKNj4lfn5JYfX4Pj/8gjoVCvioHv26oGYXo9x9FahnqBZUTR52Wayx y1Jq3yxCONvoTJQo36RvBpfZGmIGbG0CX2yn9WOaWZL6ys9DwWoDq0EeHc7PCXCgVT7P 6X1lXjG3S43NIiFgffzE/Zjg0M9E0CtL1/l7zJHvBuYbx76IBeVW0V4b8/dYo/Y/2htk VtaZY6QbHWLVq7RfFz/T1PNplju9d9Y4JA3XHmI7Lbw7mdpf8PJ+0WiSvTP9gxkpD3hd sO83lRw2j2TgFn8Wky2V1NZOOS9YClaVZ/unRnxN5FL3prKSoDyumUJ5LaCPtztliJVK wz5g==
On Sun, Jan 12, 2025 at 5:34 AM Nicolas Pomarède <npomarede@xxxxxxxxxxxx> wrote:
>
> Le 12/01/2025 à 13:56, Thomas Huth a écrit :
> > Am Sat, 11 Jan 2025 13:10:51 -0800
> > schrieb David Savinkoff <dsavnkff@xxxxxxxxx>:
> >
> >> Hi,
> >> This filter's function call is passed an int16_t and returns an int16_t.
> >> The filter calculates using int32_t so that there is no possibility of
> >> shifting too much.
> >
> > This is not about shifting too much, it's about shifting signed (negative)
> > values which is undefined behavior in C.
> >
> >> This is why there is no warning.
> >
> > There is a warning when compiling with "-fsanitize=undefined".
> >
> >> I love the 1 clock cycle barrel shifter in non-legacy CPUs.
> >
> > I think modern C compilers are smart enough to convert multiplications by
> > 32768 into the corresponding shift assembly instruction.
> >
>
> Hi
>
> After reading several specs / use cases here and there, it seems indeed
> a better way to not use shift operators when the involved variable is
> negative.
>
> C specs warns about several "undefined" behaviour that we can't handle
> in our code, but on the other hand any modern C compiler should know
> when a multiplication / division is a power of 2 and adjust the
> resulting asm code to use arithmetic shift if the variable is signed.
>
> So, I'm also in favor of dropping << / >> in sound.c ; it will certainly
> be optimised to "ASR/ASL" equivalent by the compiler, and even if not,
> this part in sound.c is rather small performance-wise compared to the
> whole cpu and video emulation, so I'm not even sure loss of performance
> here would be visible in the end.
>
> Nicolas
>
Hi,
Using signed multiplies in this code allows this code to work with
one's complement, and signed magnitude CPUs. I thought Hatari
is small endian / big endian, and two's complement only.
Note that signed integer, arithmetic left/right shifting of negative
numbers is fully supported with two's complement math.
>
> >
> >> On Fri, Jan 10, 2025 at 11:37 PM Thomas Huth <th.huth@xxxxxxxxx> wrote:
> >>>
> >>> Am Sat, 11 Jan 2025 07:30:35 +0000
> >>> schrieb Thomas Huth <th.huth@xxxxxxxxx>:
> >>> ...
> >>>>
> >>>>> Because I still think it is bad coding style to shift negative values and similar in my opinion we should only set -fwrapv where really necessary. So we should probably only do that in the CPU core, like in my previous patch. As I said previously, the parts of Hatari that are used in Previous including the DSP do not trigger any warning. So Hatari is aside from the CPU core likely to be clean and should stay like that.
> >>>>
> >>>> It's not. There is at least one more spot in the sound code:
> >>>>
> >>>> src/sound.c:389:18: runtime error: left shift of negative value -893
> >>>>
> >>>> Maybe Nicolas could have a look at it? ... those filters
> >>>> are not really my turf.
> >>>
> >>> I guess the fix would be as easy as:
> >>>
> >>> diff --git a/src/sound.c b/src/sound.c
> >>> --- a/src/sound.c
> >>> +++ b/src/sound.c
> >>> @@ -386,8 +386,8 @@ ymsample Subsonic_IIR_HPF_Left(ymsample x0)
> >>> if ( YM2149_HPF_Filter == YM2149_HPF_FILTER_NONE )
> >>> return x0;
> >>>
> >>> - y1 += ((x0 - x1)<<15) - (y0<<6); /* 64*y0 */
> >>> - y0 = y1>>15;
> >>> + y1 += ((x0 - x1) * 32768) - (y0 * 64); /* 64*y0 */
> >>> + y0 = y1 / 32768;
> >>> x1 = x0;
> >>>
> >>> return y0;
> >>>
> >>> ?
> >>>
> >>> Thomas
> >>>
> >>>
> >>
> >>
> >
> >
>
>
>