genconfig.c 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. /* Generate from machine description:
  2. - some #define configuration flags.
  3. Copyright (C) 1987 Free Software Foundation, Inc.
  4. This file is part of GNU CC.
  5. GNU CC is distributed in the hope that it will be useful,
  6. but WITHOUT ANY WARRANTY. No author or distributor
  7. accepts responsibility to anyone for the consequences of using it
  8. or for whether it serves any particular purpose or works at all,
  9. unless he says so in writing. Refer to the GNU CC General Public
  10. License for full details.
  11. Everyone is granted permission to copy, modify and redistribute
  12. GNU CC, but only under the conditions described in the
  13. GNU CC General Public License. A copy of this license is
  14. supposed to have been given to you along with GNU CC so you
  15. can know your rights and responsibilities. It should be in a
  16. file named COPYING. Among other things, the copyright notice
  17. and this notice must be preserved on all copies. */
  18. #include <stdio.h>
  19. #include "rtl.h"
  20. #include <obstack.h>
  21. struct obstack obstack;
  22. struct obstack *current_obstack = &obstack;
  23. #define obstack_chunk_alloc xmalloc
  24. #define obstack_chunk_free free
  25. extern int xmalloc ();
  26. extern void free ();
  27. /* flags to determine output of machine description dependent #define's. */
  28. int max_recog_operands_flag;
  29. int max_dup_operands_flag;
  30. int max_sets_per_insn_flag;
  31. int register_constraint_flag;
  32. int sets_seen_this_insn;
  33. int dup_operands_seen_this_insn;
  34. void fatal ();
  35. void
  36. walk_insn_part (part)
  37. rtx part;
  38. {
  39. register int i, j;
  40. register RTX_CODE code = GET_CODE (part);
  41. register char *format_ptr;
  42. switch (code)
  43. {
  44. case SET:
  45. sets_seen_this_insn++;
  46. break;
  47. case MATCH_OPERAND:
  48. if (XINT (part, 0) > max_recog_operands_flag)
  49. max_recog_operands_flag = XINT (part, 0);
  50. if (XSTR (part, 2) && *XSTR (part, 2))
  51. register_constraint_flag = 1;
  52. return;
  53. case MATCH_DUP:
  54. ++dup_operands_seen_this_insn;
  55. case REG: case CONST_INT: case SYMBOL_REF:
  56. case LABEL_REF: case PC: case CC0:
  57. return;
  58. }
  59. format_ptr = GET_RTX_FORMAT (GET_CODE (part));
  60. for (i = 0; i < GET_RTX_LENGTH (GET_CODE (part)); i++)
  61. switch (*format_ptr++)
  62. {
  63. case 'e':
  64. walk_insn_part (XEXP (part, i));
  65. break;
  66. case 'E':
  67. if (XVEC (part, i) != NULL)
  68. for (j = 0; j < XVECLEN (part, i); j++)
  69. walk_insn_part (XVECEXP (part, i, j));
  70. break;
  71. }
  72. }
  73. void
  74. gen_insn (insn)
  75. rtx insn;
  76. {
  77. int i;
  78. /* Walk the insn pattern to gather the #define's status. */
  79. sets_seen_this_insn = 0;
  80. dup_operands_seen_this_insn = 0;
  81. for (i = 0; i < XVECLEN (insn, 1); i++) {
  82. walk_insn_part (XVECEXP (insn, 1, i));
  83. }
  84. if (sets_seen_this_insn > max_sets_per_insn_flag)
  85. max_sets_per_insn_flag = sets_seen_this_insn;
  86. if (dup_operands_seen_this_insn > max_dup_operands_flag)
  87. max_dup_operands_flag = dup_operands_seen_this_insn;
  88. }
  89. xmalloc (size)
  90. {
  91. register int val = malloc (size);
  92. if (val == 0)
  93. abort ();
  94. return val;
  95. }
  96. int
  97. xrealloc (ptr, size)
  98. char *ptr;
  99. int size;
  100. {
  101. int result = realloc (ptr, size);
  102. if (!result)
  103. abort ();
  104. return result;
  105. }
  106. void
  107. fatal (s, a1, a2)
  108. {
  109. fprintf (stderr, "genflags: ");
  110. fprintf (stderr, s, a1, a2);
  111. fprintf (stderr, "\n");
  112. exit (1);
  113. }
  114. main (argc, argv)
  115. int argc;
  116. char **argv;
  117. {
  118. rtx desc;
  119. FILE *infile;
  120. extern rtx read_rtx ();
  121. register int c;
  122. obstack_begin (current_obstack, 4060);
  123. if (argc <= 1)
  124. fatal ("No input file name.");
  125. infile = fopen (argv[1], "r");
  126. if (infile == 0)
  127. {
  128. perror (argv[1]);
  129. exit (1);
  130. }
  131. init_rtl ();
  132. printf ("/* Generated automatically by the program `genconfig'\n\
  133. from the machine description file `md'. */\n\n");
  134. /* Read the machine description. */
  135. while (1)
  136. {
  137. c = read_skip_spaces (infile);
  138. if (c == EOF)
  139. break;
  140. ungetc (c, infile);
  141. desc = read_rtx (infile);
  142. gen_insn (desc);
  143. }
  144. printf ("\n#define MAX_RECOG_OPERANDS %d\n", max_recog_operands_flag + 1);
  145. printf ("\n#define MAX_DUP_OPERANDS %d\n", max_dup_operands_flag);
  146. printf ("#define MAX_SETS_PER_INSN %d\n", max_sets_per_insn_flag);
  147. if (register_constraint_flag)
  148. printf ("#define REGISTER_CONSTRAINTS\n");
  149. return 0;
  150. }