diff options
author | Martin Liska <mliska@suse.cz> | 2015-01-15 10:53:55 +0100 |
---|---|---|
committer | Martin Liska <marxin@gcc.gnu.org> | 2015-01-15 09:53:55 +0000 |
commit | 5e306f6ed5549b3e4fee73ea4b25bb93b4f1d091 (patch) | |
tree | 2ae6536d21b88aa30134c4c533042320e3f1536c /gcc/optc-save-gen.awk | |
parent | d679e96bbecf5a59940c99dfec883d9dd5ba81ea (diff) | |
download | gcc-5e306f6ed5549b3e4fee73ea4b25bb93b4f1d091.zip gcc-5e306f6ed5549b3e4fee73ea4b25bb93b4f1d091.tar.gz gcc-5e306f6ed5549b3e4fee73ea4b25bb93b4f1d091.tar.bz2 |
Target optimization nodes: add support for arrays.
PR target/64377
* optc-save-gen.awk: Add support for array types.
From-SVN: r219636
Diffstat (limited to 'gcc/optc-save-gen.awk')
-rw-r--r-- | gcc/optc-save-gen.awk | 44 |
1 files changed, 42 insertions, 2 deletions
diff --git a/gcc/optc-save-gen.awk b/gcc/optc-save-gen.awk index c773213..add0949 100644 --- a/gcc/optc-save-gen.awk +++ b/gcc/optc-save-gen.awk @@ -580,6 +580,7 @@ print " struct cl_target_option const *ptr2 ATTRIBUTE_UNUSED print "{"; n_target_val = 0; n_target_str = 0; +n_target_array = 0; for (i = 0; i < n_target_save; i++) { var = target_save_decl[i]; @@ -591,8 +592,20 @@ for (i = 0; i < n_target_save; i++) { if (target_save_decl[i] ~ "^const char \\*+[_" alnum "]+$") var_target_str[n_target_str++] = name; else { - var_target_val_type[n_target_val] = type; - var_target_val[n_target_val++] = name; + if (target_save_decl[i] ~ " .*\\[.+\\]+$") { + size = name; + sub("[^\\[]+\\[", "", size); + sub("\\]$", "", size); + sub("\\[.+", "", name) + sub(" [^ ]+$", "", type) + var_target_array[n_target_array] = name + var_target_array_type[n_target_array] = type + var_target_array_size[n_target_array++] = size + } + else { + var_target_val_type[n_target_val] = type; + var_target_val[n_target_val++] = name; + } } } if (have_save) { @@ -627,6 +640,14 @@ for (i = 0; i < n_target_str; i++) { print " || strcmp (ptr1->" name", ptr2->" name ")))"; print " return false;"; } +for (i = 0; i < n_target_array; i++) { + name = var_target_array[i] + size = var_target_array_size[i] + type = var_target_array_type[i] + print " if (ptr1->" name" != ptr2->" name ""; + print " || memcmp (ptr1->" name ", ptr2->" name ", " size " * sizeof(" type ")))" + print " return false;"; +} for (i = 0; i < n_target_val; i++) { name = var_target_val[i] print " if (ptr1->" name" != ptr2->" name ")"; @@ -650,6 +671,13 @@ for (i = 0; i < n_target_str; i++) { print " else"; print " hstate.add_int (0);"; } +for (i = 0; i < n_target_array; i++) { + name= var_target_array[i] + size = var_target_array_size[i] + type = var_target_array_type[i] + print " hstate.add_int (" size ");"; + print " hstate.add (ptr->" name ", sizeof (" type ") * " size ");"; +} for (i = 0; i < n_target_val; i++) { name = var_target_val[i] print " hstate.add_wide_int (ptr->" name");"; @@ -668,6 +696,12 @@ for (i = 0; i < n_target_str; i++) { name = var_target_str[i] print " bp_pack_string (ob, bp, ptr->" name", true);"; } +for (i = 0; i < n_target_array; i++) { + name = var_target_array[i] + size = var_target_array_size[i] + print " for (unsigned i = 0; i < " size "; i++)" + print " bp_pack_value (bp, ptr->" name "[i], 64);"; +} for (i = 0; i < n_target_val; i++) { name = var_target_val[i] print " bp_pack_value (bp, ptr->" name", 64);"; @@ -687,6 +721,12 @@ for (i = 0; i < n_target_str; i++) { print " if (ptr->" name")"; print " ptr->" name" = xstrdup (ptr->" name");"; } +for (i = 0; i < n_target_array; i++) { + name = var_target_array[i] + size = var_target_array_size[i] + print " for (int i = " size " - 1; i >= 0; i--)" + print " ptr->" name "[i] = (" var_target_array_type[i] ") bp_unpack_value (bp, 64);"; +} for (i = 0; i < n_target_val; i++) { name = var_target_val[i] print " ptr->" name" = (" var_target_val_type[i] ") bp_unpack_value (bp, 64);"; |