[Spice-devel] [spice-server v1 2/3] clang: Fix possible wrong computation

Victor Toso victortoso at redhat.com
Thu Dec 21 14:54:35 UTC 2017


Hi,

On Thu, Dec 21, 2017 at 09:48:10AM -0500, Frediano Ziglio wrote:
> > 
> > From: Victor Toso <me at victortoso.com>
> > 
> > Clang's warning about absolute value below is not entirely correct as
> > the difference between the two bitrate values could be negative but
> > using abs() could be wrong.
> > 
> > Wrapping between MAX() - MIN() is the simplest option.
> > 
> > > gstreamer-encoder.c:513:17: error: taking the absolute value of unsigned
> > > type 'unsigned long' has no effect
> > >     } else  if (abs(bit_rate - encoder->video_bit_rate) >
> > >     encoder->video_bit_rate * SPICE_GST_VIDEO_BITRATE_MARGIN) {
> > >                 ^
> > > gstreamer-encoder.c:513:17: note: remove the call to 'abs' since unsigned
> > > values cannot be negative
> > >     } else  if (abs(bit_rate - encoder->video_bit_rate) >
> > >     encoder->video_bit_rate * SPICE_GST_VIDEO_BITRATE_MARGIN) {
> > >                 ^~~
> >                                         1
> > Signed-off-by: Victor Toso <victortoso at redhat.com>
> > ---
> >  server/gstreamer-encoder.c | 7 ++++++-
> >  1 file changed, 6 insertions(+), 1 deletion(-)
> > 
> > diff --git a/server/gstreamer-encoder.c b/server/gstreamer-encoder.c
> > index 04f0c02f..869acf11 100644
> > --- a/server/gstreamer-encoder.c
> > +++ b/server/gstreamer-encoder.c
> > @@ -505,12 +505,17 @@ static void set_gstenc_bitrate(SpiceGstEncoder
> > *encoder);
> >  
> >  static void set_video_bit_rate(SpiceGstEncoder *encoder, uint64_t bit_rate)
> >  {
> > +    uint64_t diff_rate;
> > +
> >      if (encoder->video_bit_rate != bit_rate &&
> >          encoder->gstenc_bitrate_is_dynamic) {
> >          encoder->video_bit_rate = bit_rate;
> >          set_gstenc_bitrate(encoder);
> > +        return;
> > +    }
> >  
> > -    } else  if (abs(bit_rate - encoder->video_bit_rate) >
> > encoder->video_bit_rate * SPICE_GST_VIDEO_BITRATE_MARGIN) {
> > +    diff_rate = MAX(bit_rate, encoder->video_bit_rate) - MIN(bit_rate,
> > encoder->video_bit_rate);
> > +    if (diff_rate > encoder->video_bit_rate *
> > SPICE_GST_VIDEO_BITRATE_MARGIN) {
> 
> Why not abs((int64_t) bit_rate - (int64_t) encoder->video_bit_rate) ?

Hmm, should be okay too. I'll send a v2.

Cheers,
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: not available
URL: <https://lists.freedesktop.org/archives/spice-devel/attachments/20171221/45ee7bf2/attachment.sig>


More information about the Spice-devel mailing list