mirror of
https://github.com/bminor/binutils-gdb.git
synced 2025-12-05 15:15:42 +00:00
libctf: fix libctf/testsuite/libctf-lookup/multidim-array on older arches
This patch inverts the ordering of nelems on multidimensional arrays on versions of gcc without the CTF_F_ARRNELEMS flag. This allows those systems which run older gcc to pass the test without modification to the multidim-array.lk file. libctf/ChangeLog: * testsuite/libctf-lookup/multidim-array.c: Test fixes.
This commit is contained in:
committed by
Nick Alcock
parent
72cb13430c
commit
a2a9b6487d
@@ -1,3 +1,2 @@
|
|||||||
int a[3][5][9];
|
int a[3][5][9];
|
||||||
int b[1][2];
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,8 +1,23 @@
|
|||||||
|
#include "config.h"
|
||||||
#include <ctf-api.h>
|
#include <ctf-api.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
static char *
|
||||||
|
insert_dimension (char *old_str, int num)
|
||||||
|
{
|
||||||
|
char *bracket_ptr = strchr (old_str, '[');
|
||||||
|
if (!bracket_ptr)
|
||||||
|
{
|
||||||
|
if (asprintf (&old_str, "int [%d]", num) < 0)
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
else if (asprintf (&old_str, "int [%d]%s", num, bracket_ptr) < 0)
|
||||||
|
return NULL;
|
||||||
|
return old_str;
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc, char *argv[])
|
main (int argc, char *argv[])
|
||||||
{
|
{
|
||||||
@@ -14,6 +29,7 @@ main (int argc, char *argv[])
|
|||||||
ctf_next_t *it = NULL;
|
ctf_next_t *it = NULL;
|
||||||
ctf_id_t type;
|
ctf_id_t type;
|
||||||
int flagged = 0;
|
int flagged = 0;
|
||||||
|
const char *name = NULL;
|
||||||
|
|
||||||
if ((ctf = ctf_open (argv[1], NULL, &err)) == NULL)
|
if ((ctf = ctf_open (argv[1], NULL, &err)) == NULL)
|
||||||
goto open_err;
|
goto open_err;
|
||||||
@@ -23,8 +39,8 @@ main (int argc, char *argv[])
|
|||||||
/* First, check for signs that the compiler is fixed but not emitting the
|
/* First, check for signs that the compiler is fixed but not emitting the
|
||||||
relevant flag yet. This combination is not expected to work right. */
|
relevant flag yet. This combination is not expected to work right. */
|
||||||
|
|
||||||
while ((dumpstr = ctf_dump (fp, &dump_state, CTF_SECT_HEADER,
|
while ((dumpstr = ctf_dump (fp, &dump_state, CTF_SECT_HEADER, NULL, NULL))
|
||||||
NULL, NULL)) != NULL)
|
!= NULL)
|
||||||
{
|
{
|
||||||
if (strstr (dumpstr, "CTF_F_ARRNELEMS") != NULL)
|
if (strstr (dumpstr, "CTF_F_ARRNELEMS") != NULL)
|
||||||
flagged = 1;
|
flagged = 1;
|
||||||
@@ -44,28 +60,49 @@ main (int argc, char *argv[])
|
|||||||
if (ar.ctr_nelems == 3)
|
if (ar.ctr_nelems == 3)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "UNSUPPORTED: compiler has GCC PR114186 fixed but "
|
fprintf (stderr, "UNSUPPORTED: compiler has GCC PR114186 fixed but "
|
||||||
"no indicative flag\n");
|
"no indicative flag\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Now check for the actual bug. */
|
/* Now check for the actual bug. */
|
||||||
|
if (flagged)
|
||||||
|
{
|
||||||
|
while ((type = ctf_type_next (fp, &it, NULL, 1)) != -1)
|
||||||
|
if (ctf_type_kind (fp, type) == CTF_K_ARRAY)
|
||||||
|
printf ("%s\n", ctf_type_aname (fp, type));
|
||||||
|
}
|
||||||
|
|
||||||
while ((type = ctf_type_next (fp, &it, NULL, 1)) != -1)
|
else
|
||||||
printf ("%s\n", ctf_type_aname (fp, type));
|
{
|
||||||
|
while ((type = ctf_symbol_next (fp, &it, &name, 0)) != CTF_ERR)
|
||||||
|
{
|
||||||
|
char *outstr = strdup ("int ");
|
||||||
|
while (ctf_type_kind (fp, type) == CTF_K_ARRAY)
|
||||||
|
{
|
||||||
|
ctf_arinfo_t ar;
|
||||||
|
if (ctf_array_info (fp, type, &ar) < 0)
|
||||||
|
goto unexpected;
|
||||||
|
outstr = insert_dimension (outstr, ar.ctr_nelems);
|
||||||
|
printf ("%s\n", outstr);
|
||||||
|
type = ar.ctr_contents;
|
||||||
|
}
|
||||||
|
free (outstr);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ctf_dict_close (fp);
|
ctf_dict_close (fp);
|
||||||
ctf_close (ctf);
|
ctf_close (ctf);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
open_err:
|
open_err:
|
||||||
fprintf (stderr, "%s: cannot open: %s\n", argv[0], ctf_errmsg (err));
|
fprintf (stderr, "%s: cannot open: %s\n", argv[0], ctf_errmsg (err));
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
unexpected:
|
unexpected:
|
||||||
fprintf (stderr, "Cannot look up symbol to determine compiler bugginess: %s\n",
|
fprintf (stderr,
|
||||||
|
"Cannot look up symbol to determine compiler bugginess: %s\n",
|
||||||
ctf_errmsg (ctf_errno (fp)));
|
ctf_errmsg (ctf_errno (fp)));
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,9 +1,5 @@
|
|||||||
# source: multidim-array-ctf.c
|
# source: multidim-array-ctf.c
|
||||||
int
|
|
||||||
(long )?unsigned int
|
|
||||||
int \[9\]
|
int \[9\]
|
||||||
int \[5\]\[9\]
|
int \[5\]\[9\]
|
||||||
int \[3\]\[5\]\[9\]
|
int \[3\]\[5\]\[9\]
|
||||||
int \[2\]
|
|
||||||
int \[1\]\[2\]
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user