[Spice-devel] [PATCH spice-server v2 02/23] mjpeg: Use GLib memory functions

Frediano Ziglio fziglio at redhat.com
Mon Sep 25 07:56:48 UTC 2017


> 
> On Wed, 2017-09-20 at 08:50 +0100, Frediano Ziglio wrote:
> > Signed-off-by: Frediano Ziglio <fziglio at redhat.com>
> > ---
> >  server/mjpeg-encoder.c | 28 ++++++++++++++--------------
> >  1 file changed, 14 insertions(+), 14 deletions(-)
> > 
> > diff --git a/server/mjpeg-encoder.c b/server/mjpeg-encoder.c
> > index 07ca69c20..cb70ab1b5 100644
> > --- a/server/mjpeg-encoder.c
> > +++ b/server/mjpeg-encoder.c
> > @@ -191,18 +191,18 @@ static uint32_t
> > get_min_required_playback_delay(uint64_t frame_enc_size,
> >  static void mjpeg_video_buffer_free(VideoBuffer *video_buffer)
> >  {
> >      MJpegVideoBuffer *buffer = (MJpegVideoBuffer*)video_buffer;
> > -    free(buffer->base.data);
> > -    free(buffer);
> > +    g_free(buffer->base.data);
> > +    g_free(buffer);
> >  }
> >  
> >  static MJpegVideoBuffer* create_mjpeg_video_buffer(void)
> >  {
> > -    MJpegVideoBuffer *buffer = spice_new0(MJpegVideoBuffer, 1);
> > +    MJpegVideoBuffer *buffer = g_new0(MJpegVideoBuffer, 1);
> >      buffer->base.free = mjpeg_video_buffer_free;
> >      buffer->maxsize = MJPEG_INITIAL_BUFFER_SIZE;
> > -    buffer->base.data = malloc(buffer->maxsize);
> > +    buffer->base.data = g_try_malloc(buffer->maxsize);
> >      if (!buffer->base.data) {
> > -        free(buffer);
> > +        g_free(buffer);
> >          buffer = NULL;
> >      }
> >      return buffer;
> > @@ -211,10 +211,10 @@ static MJpegVideoBuffer*
> > create_mjpeg_video_buffer(void)
> >  static void mjpeg_encoder_destroy(VideoEncoder *video_encoder)
> >  {
> >      MJpegEncoder *encoder = (MJpegEncoder*)video_encoder;
> > -    free(encoder->cinfo.dest);
> > +    g_free(encoder->cinfo.dest);
> >      jpeg_destroy_compress(&encoder->cinfo);
> > -    free(encoder->row);
> > -    free(encoder);
> > +    g_free(encoder->row);
> > +    g_free(encoder);
> >  }
> >  
> >  static uint8_t mjpeg_encoder_get_bytes_per_pixel(MJpegEncoder
> > *encoder)
> > @@ -278,7 +278,7 @@ static boolean
> > empty_mem_output_buffer(j_compress_ptr cinfo)
> >  
> >    /* Try to allocate new buffer with double size */
> >    nextsize = dest->bufsize * 2;
> > -  nextbuffer = realloc(dest->buffer, nextsize);
> > +  nextbuffer = g_try_realloc(dest->buffer, nextsize);
> >  
> >    if (nextbuffer == NULL)
> >      ERREXIT1(cinfo, JERR_OUT_OF_MEMORY, 10);
> > @@ -304,7 +304,7 @@ static void term_mem_destination(j_compress_ptr
> > cinfo)
> >   * Prepare for output to a memory buffer.
> >   * The caller must supply its own initial buffer and size.
> >   * When the actual data output exceeds the given size, the library
> > - * will adapt the buffer size as necessary using the malloc()/free()
> > + * will adapt the buffer size as necessary using the
> > g_malloc()/g_free()
> >   * functions. The buffer is available to the application after the
> >   * compression and the application is then responsible for freeing
> > it.
> >   */
> > @@ -323,7 +323,7 @@ spice_jpeg_mem_dest(j_compress_ptr cinfo,
> >     * can be written to the same buffer without re-executing
> > jpeg_mem_dest.
> >     */
> >    if (cinfo->dest == NULL) { /* first time for this JPEG object? */
> > -    cinfo->dest = spice_malloc(sizeof(mem_destination_mgr));
> > +    cinfo->dest = g_malloc(sizeof(mem_destination_mgr));
> 
> I'd be tempted to change this to g_new() or g_new0(), but maybe that's
> just me.
> 

However dest is not mem_destination_mgr so would be something like

  cinfo->dest = &(g_new(mem_destination_mgr, 1))->pub;

or

  cinfo->dest = (jpeg_destination_msg *) g_new(mem_destination_mgr, 1);

> Acked-by: Jonathon Jongsma <jjongsma at redhat.com>
> 
> >    }
> >  
> >    dest = (mem_destination_mgr *) cinfo->dest;
> > @@ -700,7 +700,7 @@ static void mjpeg_encoder_adjust_fps(MJpegEncoder
> > *encoder, uint64_t now)
> >  }
> >  
> >  /*
> > - * dest must be either NULL or allocated by malloc, since it might
> > be freed
> > + * dest must be either NULL or allocated by g_malloc, since it might
> > be freed
> >   * during the encoding, if its size is too small.
> >   *
> >   * return:
> > @@ -790,7 +790,7 @@ static int mjpeg_encoder_start_frame(MJpegEncoder
> > *encoder,
> >              return VIDEO_ENCODER_FRAME_UNSUPPORTED;
> >          }
> >          if (encoder->row_size < stride) {
> > -            encoder->row = spice_realloc(encoder->row, stride);
> > +            encoder->row = g_realloc(encoder->row, stride);
> >              encoder->row_size = stride;
> >          }
> >      }
> > @@ -1357,7 +1357,7 @@ VideoEncoder
> > *mjpeg_encoder_new(SpiceVideoCodecType codec_type,
> >  
> >      spice_return_val_if_fail(codec_type ==
> > SPICE_VIDEO_CODEC_TYPE_MJPEG, NULL);
> >  
> > -    encoder = spice_new0(MJpegEncoder, 1);
> > +    encoder = g_new0(MJpegEncoder, 1);
> >      encoder->base.destroy = mjpeg_encoder_destroy;
> >      encoder->base.encode_frame = mjpeg_encoder_encode_frame;
> >      encoder->base.client_stream_report =
> > mjpeg_encoder_client_stream_report;
> 


More information about the Spice-devel mailing list