forked from Imagelibrary/binutils-gdb
gas: Fix memory leaks in ginsn.c
Free buffer memory after use in ginsn.c. * ginsn.c (ginsn_dst_print): Free buffer after use. (ginsn_print): Likewise.
This commit is contained in:
14
gas/ginsn.c
14
gas/ginsn.c
@@ -507,6 +507,7 @@ ginsn_dst_print (struct ginsn_dst *dst)
|
|||||||
char *buf = XNEWVEC (char, 32);
|
char *buf = XNEWVEC (char, 32);
|
||||||
sprintf (buf, "%%r%d", ginsn_get_dst_reg (dst));
|
sprintf (buf, "%%r%d", ginsn_get_dst_reg (dst));
|
||||||
strcat (dst_str, buf);
|
strcat (dst_str, buf);
|
||||||
|
free (buf);
|
||||||
}
|
}
|
||||||
else if (dst->type == GINSN_DST_INDIRECT)
|
else if (dst->type == GINSN_DST_INDIRECT)
|
||||||
{
|
{
|
||||||
@@ -514,6 +515,7 @@ ginsn_dst_print (struct ginsn_dst *dst)
|
|||||||
sprintf (buf, "[%%r%d+%lld]", ginsn_get_dst_reg (dst),
|
sprintf (buf, "[%%r%d+%lld]", ginsn_get_dst_reg (dst),
|
||||||
(long long int) ginsn_get_dst_disp (dst));
|
(long long int) ginsn_get_dst_disp (dst));
|
||||||
strcat (dst_str, buf);
|
strcat (dst_str, buf);
|
||||||
|
free (buf);
|
||||||
}
|
}
|
||||||
|
|
||||||
gas_assert (strlen (dst_str) < GINSN_LISTING_OPND_LEN);
|
gas_assert (strlen (dst_str) < GINSN_LISTING_OPND_LEN);
|
||||||
@@ -570,20 +572,26 @@ ginsn_print (ginsnS *ginsn)
|
|||||||
|
|
||||||
/* src 1. */
|
/* src 1. */
|
||||||
src = ginsn_get_src1 (ginsn);
|
src = ginsn_get_src1 (ginsn);
|
||||||
|
char *src_buf = ginsn_src_print (src);
|
||||||
str_size += snprintf (ginsn_str + str_size, GINSN_LISTING_LEN - str_size,
|
str_size += snprintf (ginsn_str + str_size, GINSN_LISTING_LEN - str_size,
|
||||||
" %s", ginsn_src_print (src));
|
" %s", src_buf);
|
||||||
|
free (src_buf);
|
||||||
gas_assert (str_size >= 0 && str_size < GINSN_LISTING_LEN);
|
gas_assert (str_size >= 0 && str_size < GINSN_LISTING_LEN);
|
||||||
|
|
||||||
/* src 2. */
|
/* src 2. */
|
||||||
src = ginsn_get_src2 (ginsn);
|
src = ginsn_get_src2 (ginsn);
|
||||||
|
src_buf = ginsn_src_print (src);
|
||||||
str_size += snprintf (ginsn_str + str_size, GINSN_LISTING_LEN - str_size,
|
str_size += snprintf (ginsn_str + str_size, GINSN_LISTING_LEN - str_size,
|
||||||
"%s", ginsn_src_print (src));
|
"%s", src_buf);
|
||||||
|
free (src_buf);
|
||||||
gas_assert (str_size >= 0 && str_size < GINSN_LISTING_LEN);
|
gas_assert (str_size >= 0 && str_size < GINSN_LISTING_LEN);
|
||||||
|
|
||||||
/* dst. */
|
/* dst. */
|
||||||
dst = ginsn_get_dst (ginsn);
|
dst = ginsn_get_dst (ginsn);
|
||||||
|
char *dst_buf = ginsn_dst_print (dst);
|
||||||
str_size += snprintf (ginsn_str + str_size, GINSN_LISTING_LEN - str_size,
|
str_size += snprintf (ginsn_str + str_size, GINSN_LISTING_LEN - str_size,
|
||||||
"%s", ginsn_dst_print (dst));
|
"%s", dst_buf);
|
||||||
|
free (dst_buf);
|
||||||
|
|
||||||
end:
|
end:
|
||||||
gas_assert (str_size >= 0 && str_size < GINSN_LISTING_LEN);
|
gas_assert (str_size >= 0 && str_size < GINSN_LISTING_LEN);
|
||||||
|
|||||||
Reference in New Issue
Block a user