From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 1725) id AF024385781C; Thu, 1 Apr 2021 19:48:39 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org AF024385781C Content-Type: text/plain; charset="us-ascii" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit From: William Schmidt To: gcc-cvs@gcc.gnu.org Subject: [gcc(refs/users/wschmidt/heads/builtins10)] rs6000: Write static initializations for built-in table X-Act-Checkin: gcc X-Git-Author: Bill Schmidt X-Git-Refname: refs/users/wschmidt/heads/builtins10 X-Git-Oldrev: f1350178f61c886a29971e5a426ecb4611a3779e X-Git-Newrev: 25330a68c1114afeea7d7d3a83b64751e25ca1be Message-Id: <20210401194839.AF024385781C@sourceware.org> Date: Thu, 1 Apr 2021 19:48:39 +0000 (GMT) X-BeenThere: gcc-cvs@gcc.gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Gcc-cvs mailing list List-Unsubscribe: , List-Archive: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 01 Apr 2021 19:48:39 -0000 https://gcc.gnu.org/g:25330a68c1114afeea7d7d3a83b64751e25ca1be commit 25330a68c1114afeea7d7d3a83b64751e25ca1be Author: Bill Schmidt Date: Wed Mar 24 14:14:09 2021 -0500 rs6000: Write static initializations for built-in table 2021-03-24 Bill Schmidt gcc/ * config/rs6000/rs6000-gen-builtins.c (write_bif_static_init): New function. (write_init_file): Call write_bif_static_init. Diff: --- gcc/config/rs6000/rs6000-gen-builtins.c | 104 ++++++++++++++++++++++++++++++++ 1 file changed, 104 insertions(+) diff --git a/gcc/config/rs6000/rs6000-gen-builtins.c b/gcc/config/rs6000/rs6000-gen-builtins.c index be9774a65ac..58892d015b0 100644 --- a/gcc/config/rs6000/rs6000-gen-builtins.c +++ b/gcc/config/rs6000/rs6000-gen-builtins.c @@ -2440,6 +2440,108 @@ write_header_file () return 1; } +/* Write the decl and initializer for rs6000_builtin_info_x[]. */ +static void +write_bif_static_init () +{ + const char *res[3]; + fprintf (init_file, "bifdata rs6000_builtin_info_x[RS6000_BIF_MAX] =\n"); + fprintf (init_file, " {\n"); + fprintf (init_file, " { /* RS6000_BIF_NONE: */\n"); + fprintf (init_file, " \"\", ENB_ALWAYS, 0, CODE_FOR_nothing, 0,\n"); + fprintf (init_file, " 0, {0, 0, 0}, {RES_NONE, RES_NONE, RES_NONE},\n"); + fprintf (init_file, " {0, 0, 0}, {0, 0, 0}, \"\", RS6000_BIF_NONE\n"); + fprintf (init_file, " },\n"); + for (int i = 0; i <= curr_bif; i++) + { + bifdata *bifp = &bifs[bif_order[i]]; + fprintf (init_file, " { /* RS6000_BIF_%s: */\n", bifp->idname); + fprintf (init_file, " /* bifname */\t\"%s\",\n", + bifp->proto.bifname); + fprintf (init_file, " /* enable*/\t%s,\n", + enable_string[bifp->stanza]); + /* Type must be instantiated at run time. */ + fprintf (init_file, " /* fntype */\t0,\n"); + fprintf (init_file, " /* icode */\tCODE_FOR_%s,\n", + bifp->patname); + fprintf (init_file, " /* nargs */\t%d,\n", + bifp->proto.nargs); + fprintf (init_file, " /* bifattrs */\t0"); + if (bifp->attrs.isinit) + fprintf (init_file, " | bif_init_bit"); + if (bifp->attrs.isset) + fprintf (init_file, " | bif_set_bit"); + if (bifp->attrs.isextract) + fprintf (init_file, " | bif_extract_bit"); + if (bifp->attrs.isnosoft) + fprintf (init_file, " | bif_nosoft_bit"); + if (bifp->attrs.isldvec) + fprintf (init_file, " | bif_ldvec_bit"); + if (bifp->attrs.isstvec) + fprintf (init_file, " | bif_stvec_bit"); + if (bifp->attrs.isreve) + fprintf (init_file, " | bif_reve_bit"); + if (bifp->attrs.ispred) + fprintf (init_file, " | bif_pred_bit"); + if (bifp->attrs.ishtm) + fprintf (init_file, " | bif_htm_bit"); + if (bifp->attrs.ishtmspr) + fprintf (init_file, " | bif_htmspr_bit"); + if (bifp->attrs.ishtmcr) + fprintf (init_file, " | bif_htmcr_bit"); + if (bifp->attrs.ismma) + fprintf (init_file, " | bif_mma_bit"); + if (bifp->attrs.isquad) + fprintf (init_file, " | bif_quad_bit"); + if (bifp->attrs.ispair) + fprintf (init_file, " | bif_pair_bit"); + if (bifp->attrs.isno32bit) + fprintf (init_file, " | bif_no32bit_bit"); + if (bifp->attrs.is32bit) + fprintf (init_file, " | bif_32bit_bit"); + if (bifp->attrs.iscpu) + fprintf (init_file, " | bif_cpu_bit"); + if (bifp->attrs.isldstmask) + fprintf (init_file, " | bif_ldstmask_bit"); + if (bifp->attrs.islxvrse) + fprintf (init_file, " | bif_lxvrse_bit"); + if (bifp->attrs.islxvrze) + fprintf (init_file, " | bif_lxvrze_bit"); + if (bifp->attrs.isendian) + fprintf (init_file, " | bif_endian_bit"); + fprintf (init_file, ",\n"); + fprintf (init_file, " /* restr_opnd */\t{%d, %d, %d},\n", + bifp->proto.restr_opnd[0], bifp->proto.restr_opnd[1], + bifp->proto.restr_opnd[2]); + for (int j = 0; j < 3; j++) + res[j] = (bifp->proto.restr_opnd[j] == 0 ? "RES_NONE" + : (bifp->proto.restr[j] == RES_BITS ? "RES_BITS" + : (bifp->proto.restr[j] == RES_RANGE ? "RES_RANGE" + : (bifp->proto.restr[j] == RES_VALUES ? "RES_VALUES" + : (bifp->proto.restr[j] == RES_VAR_RANGE + ? "RES_VAR_RANGE" : "ERROR"))))); + fprintf (init_file, " /* restr */\t{%s, %s, %s},\n", + res[0], res[1], res[2]); + fprintf (init_file, " /* restr_val1 */\t{%d, %d, %d},\n", + bifp->proto.restr_val1[0], bifp->proto.restr_val1[1], + bifp->proto.restr_val1[2]); + fprintf (init_file, " /* restr_val2 */\t{%d, %d, %d},\n", + bifp->proto.restr_val2[0], bifp->proto.restr_val2[1], + bifp->proto.restr_val2[2]); + fprintf (init_file, " /* attr_string */\t\"%s\",\n", + (bifp->kind == FNK_CONST ? "= const" + : (bifp->kind == FNK_PURE ? "= pure" + : (bifp->kind == FNK_FPMATH ? "= fp, const" + : "")))); + bool no_icode = !strcmp (bifp->patname, "nothing"); + fprintf (init_file, " /* assoc_bif */\tRS6000_BIF_%s%s\n", + bifp->attrs.ismma && no_icode ? bifp->idname : "NONE", + bifp->attrs.ismma && no_icode ? "_INTERNAL" : ""); + fprintf (init_file, " },\n"); + } + fprintf (init_file, " };\n\n"); +} + /* Write code to initialize the built-in function table. */ static void write_init_bif_table () @@ -2607,6 +2709,8 @@ write_init_file () fprintf (init_file, "tree rs6000_builtin_decls_x[RS6000_OVLD_MAX];\n\n"); + write_bif_static_init (); + rbt_inorder_callback (&fntype_rbt, fntype_rbt.rbt_root, write_fntype); fprintf (init_file, "\n");