Hi Takashi, Yes, it is redundant to delete plug->rate_converter. The patch has been fixed and submitted. Regards, Mounesh -----Original Message----- From: Takashi Iwai [mailto:tiwai@xxxxxxx] Sent: 17 February 2017 23:15 To: sutar.mounesh@xxxxxxxxx Cc: alsa-devel@xxxxxxxxxxxxxxxx; Sutar, Mounesh <Mounesh_Sutar@xxxxxxxxxx>; Andreas Pape <apape@xxxxxxxxxxxxxx> Subject: Re: [PATCH 6/6] pcm:plug: save converter config On Fri, 17 Feb 2017 08:18:02 +0100, sutar.mounesh@xxxxxxxxx wrote: > > From: Andreas Pape <apape@xxxxxxxxxxxxxx> > > Passed config is freed after call to open, thus it is invalid when > trying to extract the converter name. So config entry is saved for > later usage. > > Signed-off-by: Andreas Pape <apape@xxxxxxxxxxxxxx> > Signed-off-by: Mounesh Sutar <sutar.mounesh@xxxxxxxxx> > > diff --git a/src/pcm/pcm_plug.c b/src/pcm/pcm_plug.c index > 266707b..6d0c03d 100644 > --- a/src/pcm/pcm_plug.c > +++ b/src/pcm/pcm_plug.c > @@ -64,6 +64,8 @@ static int snd_pcm_plug_close(snd_pcm_t *pcm) > snd_pcm_plug_t *plug = pcm->private_data; > int err, result = 0; > free(plug->ttable); > + if (plug->rate_converter) > + snd_config_delete((snd_config_t*)plug->rate_converter); > assert(plug->gen.slave == plug->req_slave); > if (plug->gen.close_slave) { > snd_pcm_unlink_hw_ptr(pcm, plug->req_slave); @@ -1108,7 +1110,15 @@ > int snd_pcm_plug_open(snd_pcm_t **pcmp, > plug->sformat = sformat; > plug->schannels = schannels; > plug->srate = srate; > - plug->rate_converter = rate_converter; > + if (rate_converter) { > + if ((err = snd_config_copy((snd_config_t**)&plug->rate_converter, > + (snd_config_t *)rate_converter)) < 0) > + free(plug); > + return err; > + } > + else > + snd_config_delete((snd_config_t*)plug->rate_converter); Why do we need to delete plug->rate_converter here...? It's nowhere assigned after the patch? thanks, Takashi _______________________________________________ Alsa-devel mailing list Alsa-devel@xxxxxxxxxxxxxxxx http://mailman.alsa-project.org/mailman/listinfo/alsa-devel