Thanks for review.My bad I forgot to change the remaining frees.Going to
send another patch

On Mon, Oct 16, 2023 at 6:49 PM Peter Maydell <peter.mayd...@linaro.org>
wrote:

> On Tue, 3 Oct 2023 at 18:23, ~h0lyalg0rithm <h0lyalg0ri...@git.sr.ht>
> wrote:
> >
> > From: Suraj Shirvankar <surajshirvan...@gmail.com>
> >
> > Signed-off-by: Suraj Shirvankar <surajshirvan...@gmail.com>
>
> Hi; thanks for this patch. Mostly it looks good, but I
> have a couple of review comments; details below.
>
> > ---
> >  contrib/elf2dmp/addrspace.c | 4 ++--
> >  contrib/elf2dmp/main.c      | 4 ++--
> >  contrib/elf2dmp/pdb.c       | 4 ++--
> >  contrib/elf2dmp/qemu_elf.c  | 4 ++--
> >  4 files changed, 8 insertions(+), 8 deletions(-)
> >
> > diff --git a/contrib/elf2dmp/addrspace.c b/contrib/elf2dmp/addrspace.c
> > index 64b5d680ad..3bfbb5093c 100644
> > --- a/contrib/elf2dmp/addrspace.c
> > +++ b/contrib/elf2dmp/addrspace.c
> > @@ -72,7 +72,7 @@ int pa_space_create(struct pa_space *ps, QEMU_Elf
> *qemu_elf)
> >          }
> >      }
> >
> > -    ps->block = malloc(sizeof(*ps->block) * ps->block_nr);
> > +    ps->block = g_new(struct pa_block, ps->block_nr);
> >      if (!ps->block) {
> >          return 1;
> >      }
>
> Unlike malloc(), g_new() can never fail. So the error check
> for NULL becomes redundant, and we can remove it. Similarly
> in the other cases below (including the g_malloc() call).
>
> > @@ -97,7 +97,7 @@ int pa_space_create(struct pa_space *ps, QEMU_Elf
> *qemu_elf)
> >  void pa_space_destroy(struct pa_space *ps)
> >  {
> >      ps->block_nr = 0;
> > -    free(ps->block);
> > +    g_free(ps->block);
> >  }
> >
> >  void va_space_set_dtb(struct va_space *vs, uint64_t dtb)
> > diff --git a/contrib/elf2dmp/main.c b/contrib/elf2dmp/main.c
> > index 5db163bdbe..97baf0c0c1 100644
> > --- a/contrib/elf2dmp/main.c
> > +++ b/contrib/elf2dmp/main.c
> > @@ -120,14 +120,14 @@ static KDDEBUGGER_DATA64 *get_kdbg(uint64_t
> KernBase, struct pdb_reader *pdb,
> >          }
> >      }
> >
> > -    kdbg = malloc(kdbg_hdr.Size);
> > +    kdbg = g_malloc(kdbg_hdr.Size);
> >      if (!kdbg) {
> >          return NULL;
> >      }
> >
> >      if (va_space_rw(vs, KdDebuggerDataBlock, kdbg, kdbg_hdr.Size, 0)) {
> >          eprintf("Failed to extract entire KDBG\n");
> > -        free(kdbg);
> > +        g_free(kdbg);
> >          return NULL;
> >      }
>
> This isn't the only place where we free the memory we
> allocate here. The other place is the "free(kdbg)" at the
> bottom of the main() function. So for consistency we should
> change that also to g_free().
>
> > diff --git a/contrib/elf2dmp/pdb.c b/contrib/elf2dmp/pdb.c
> > index 6ca5086f02..625001d1cf 100644
> > --- a/contrib/elf2dmp/pdb.c
> > +++ b/contrib/elf2dmp/pdb.c
> > @@ -116,7 +116,7 @@ static void *pdb_ds_read(const PDB_DS_HEADER *header,
> >
> >      nBlocks = (size + header->block_size - 1) / header->block_size;
> >
> > -    buffer = malloc(nBlocks * header->block_size);
> > +    buffer = g_malloc(nBlocks * header->block_size);
> >      if (!buffer) {
> >          return NULL;
> >      }
>
> Similarly here the buffer we allocated is usually returned
> from this function, assigned to some struct field, and then
> free()d much later on. So we should also switch all the other
> free() calls in this file to g_free().
>
> We should end up with no calls to free() left at all in
> the contrib/elf2dmp/ source files, I think.
>
> > @@ -201,7 +201,7 @@ static int pdb_init_symbols(struct pdb_reader *r)
> >      return 0;
> >
> >  out_symbols:
> > -    free(symbols);
> > +    g_free(symbols);
> >
> >      return err;
> >  }
> > diff --git a/contrib/elf2dmp/qemu_elf.c b/contrib/elf2dmp/qemu_elf.c
> > index de6ad744c6..9aa8715108 100644
> > --- a/contrib/elf2dmp/qemu_elf.c
> > +++ b/contrib/elf2dmp/qemu_elf.c
> > @@ -94,7 +94,7 @@ static int init_states(QEMU_Elf *qe)
> >
> >      printf("%zu CPU states has been found\n", cpu_nr);
> >
> > -    qe->state = malloc(sizeof(*qe->state) * cpu_nr);
> > +    qe->state = g_new(QEMUCPUState*, cpu_nr);
> >      if (!qe->state) {
> >          return 1;
> >      }
> > @@ -115,7 +115,7 @@ static int init_states(QEMU_Elf *qe)
> >
> >  static void exit_states(QEMU_Elf *qe)
> >  {
> > -    free(qe->state);
> > +    g_free(qe->state);
> >  }
> >
> >  static bool check_ehdr(QEMU_Elf *qe)
> > --
> > 2.38.5
>
> thanks
> -- PMM
>

Reply via email to