annotate libiberty/testsuite/demangler-fuzzer.c @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Demangler fuzzer.
kono
parents:
diff changeset
2
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
3 Copyright (C) 2014-2020 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 This file is part of GNU libiberty.
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 This program is free software; you can redistribute it and/or modify
kono
parents:
diff changeset
8 it under the terms of the GNU General Public License as published by
kono
parents:
diff changeset
9 the Free Software Foundation; either version 3 of the License, or
kono
parents:
diff changeset
10 (at your option) any later version.
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 This program is distributed in the hope that it will be useful,
kono
parents:
diff changeset
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
kono
parents:
diff changeset
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
kono
parents:
diff changeset
15 GNU General Public License for more details.
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 #include <stdio.h>
kono
parents:
diff changeset
21 #include <stdlib.h>
kono
parents:
diff changeset
22 #include <unistd.h>
kono
parents:
diff changeset
23 #include <time.h>
kono
parents:
diff changeset
24 #include "demangle.h"
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 #define MAXLEN 253
kono
parents:
diff changeset
27 #define ALPMIN 33
kono
parents:
diff changeset
28 #define ALPMAX 127
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 static char *program_name;
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 #define DEFAULT_MAXCOUNT 7500000
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 static void
kono
parents:
diff changeset
35 print_usage (FILE *fp, int exit_value)
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 fprintf (fp, "Usage: %s [OPTION]...\n", program_name);
kono
parents:
diff changeset
38 fprintf (fp, "Options:\n");
kono
parents:
diff changeset
39 fprintf (fp, " -h Display this message.\n");
kono
parents:
diff changeset
40 fprintf (fp, " -s SEED Select the random seed to be used.\n");
kono
parents:
diff changeset
41 fprintf (fp, " The default is to base one on the");
kono
parents:
diff changeset
42 fprintf (fp, " current time.\n");
kono
parents:
diff changeset
43 fprintf (fp, " -m MAXCOUNT Exit after MAXCOUNT symbols.\n");
kono
parents:
diff changeset
44 fprintf (fp, " The default is %d.", DEFAULT_MAXCOUNT);
kono
parents:
diff changeset
45 fprintf (fp, " Set to `-1' for no limit.\n");
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 exit (exit_value);
kono
parents:
diff changeset
48 }
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 int
kono
parents:
diff changeset
51 main (int argc, char *argv[])
kono
parents:
diff changeset
52 {
kono
parents:
diff changeset
53 char symbol[2 + MAXLEN + 1] = "_Z";
kono
parents:
diff changeset
54 int seed = -1, seed_set = 0;
kono
parents:
diff changeset
55 int count = 0, maxcount = DEFAULT_MAXCOUNT;
kono
parents:
diff changeset
56 int optchr;
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 program_name = argv[0];
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 do
kono
parents:
diff changeset
61 {
kono
parents:
diff changeset
62 optchr = getopt (argc, argv, "hs:m:t:");
kono
parents:
diff changeset
63 switch (optchr)
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 case '?': /* Unrecognized option. */
kono
parents:
diff changeset
66 print_usage (stderr, 1);
kono
parents:
diff changeset
67 break;
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 case 'h':
kono
parents:
diff changeset
70 print_usage (stdout, 0);
kono
parents:
diff changeset
71 break;
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 case 's':
kono
parents:
diff changeset
74 seed = atoi (optarg);
kono
parents:
diff changeset
75 seed_set = 1;
kono
parents:
diff changeset
76 break;
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 case 'm':
kono
parents:
diff changeset
79 maxcount = atoi (optarg);
kono
parents:
diff changeset
80 break;
kono
parents:
diff changeset
81 }
kono
parents:
diff changeset
82 }
kono
parents:
diff changeset
83 while (optchr != -1);
kono
parents:
diff changeset
84
kono
parents:
diff changeset
85 if (!seed_set)
kono
parents:
diff changeset
86 seed = time (NULL);
kono
parents:
diff changeset
87 srand (seed);
kono
parents:
diff changeset
88 printf ("%s: seed = %d\n", program_name, seed);
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 while (maxcount < 0 || count < maxcount)
kono
parents:
diff changeset
91 {
kono
parents:
diff changeset
92 char *buffer = symbol + 2;
kono
parents:
diff changeset
93 int length, i;
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95 length = rand () % MAXLEN;
kono
parents:
diff changeset
96 for (i = 0; i < length; i++)
kono
parents:
diff changeset
97 *buffer++ = (rand () % (ALPMAX - ALPMIN)) + ALPMIN;
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 *buffer++ = '\0';
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 cplus_demangle (symbol, DMGL_AUTO | DMGL_ANSI | DMGL_PARAMS);
kono
parents:
diff changeset
102
kono
parents:
diff changeset
103 count++;
kono
parents:
diff changeset
104 }
kono
parents:
diff changeset
105
kono
parents:
diff changeset
106 printf ("%s: successfully demangled %d symbols\n", program_name, count);
kono
parents:
diff changeset
107 exit (0);
kono
parents:
diff changeset
108 }