aboutsummaryrefslogtreecommitdiff
path: root/gcc/optabs.c
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2007-09-05 12:51:34 +0200
committerJan Hubicka <hubicka@gcc.gnu.org>2007-09-05 10:51:34 +0000
commita48b501cb5f9255780d5570c32a2823d9097f36b (patch)
tree28398b07d9c542a0222a47acedca2b72e7519999 /gcc/optabs.c
parent330618621be1e450c58f13fcc9bd29a355494afb (diff)
downloadgcc-a48b501cb5f9255780d5570c32a2823d9097f36b.zip
gcc-a48b501cb5f9255780d5570c32a2823d9097f36b.tar.gz
gcc-a48b501cb5f9255780d5570c32a2823d9097f36b.tar.bz2
optabs.c (libfunc_entry): Change optab to integer.
* optabs.c (libfunc_entry): Change optab to integer. (hash_libfunc, convert_optab_libfunc, optab_libfunc, set_optab_libfunc, set_conv_libfunc): Use optable indexes instead of pointers for hashing. From-SVN: r128128
Diffstat (limited to 'gcc/optabs.c')
-rw-r--r--gcc/optabs.c16
1 files changed, 8 insertions, 8 deletions
diff --git a/gcc/optabs.c b/gcc/optabs.c
index 2501ce6..32f397c 100644
--- a/gcc/optabs.c
+++ b/gcc/optabs.c
@@ -123,7 +123,7 @@ void debug_optab_libfuncs (void);
optab. In the first case mode2 is unused. */
struct libfunc_entry GTY(())
{
- void * GTY((skip)) optab;
+ size_t optab;
enum machine_mode mode1, mode2;
rtx libfunc;
};
@@ -139,7 +139,7 @@ hash_libfunc (const void *p)
const struct libfunc_entry *const e = (const struct libfunc_entry *) p;
return (((int) e->mode1 + (int) e->mode2 * NUM_MACHINE_MODES)
- ^ htab_hash_pointer (e->optab));
+ ^ e->optab);
}
/* Used for optab_hash. */
@@ -165,7 +165,7 @@ convert_optab_libfunc (convert_optab optab, enum machine_mode mode1,
struct libfunc_entry e;
struct libfunc_entry **slot;
- e.optab = optab;
+ e.optab = (size_t) (convert_optab_table[0] - optab);
e.mode1 = mode1;
e.mode2 = mode2;
slot = (struct libfunc_entry **) htab_find_slot (libfunc_hash, &e, NO_INSERT);
@@ -194,7 +194,7 @@ optab_libfunc (optab optab, enum machine_mode mode)
struct libfunc_entry e;
struct libfunc_entry **slot;
- e.optab = optab;
+ e.optab = (size_t) (optab_table[0] - optab);
e.mode1 = mode;
e.mode2 = VOIDmode;
slot = (struct libfunc_entry **) htab_find_slot (libfunc_hash, &e, NO_INSERT);
@@ -5938,7 +5938,7 @@ set_optab_libfunc (optab optable, enum machine_mode mode, const char *name)
rtx val;
struct libfunc_entry e;
struct libfunc_entry **slot;
- e.optab = optable;
+ e.optab = (size_t) (optab_table[0] - optable);
e.mode1 = mode;
e.mode2 = VOIDmode;
@@ -5949,7 +5949,7 @@ set_optab_libfunc (optab optable, enum machine_mode mode, const char *name)
slot = (struct libfunc_entry **) htab_find_slot (libfunc_hash, &e, INSERT);
if (*slot == NULL)
*slot = ggc_alloc (sizeof (struct libfunc_entry));
- (*slot)->optab = optable;
+ (*slot)->optab = (size_t) (optab_table[0] - optable);
(*slot)->mode1 = mode;
(*slot)->mode2 = VOIDmode;
(*slot)->libfunc = val;
@@ -5965,7 +5965,7 @@ set_conv_libfunc (convert_optab optable, enum machine_mode tmode,
rtx val;
struct libfunc_entry e;
struct libfunc_entry **slot;
- e.optab = optable;
+ e.optab = (size_t) (convert_optab_table[0] - optable);
e.mode1 = tmode;
e.mode2 = fmode;
@@ -5976,7 +5976,7 @@ set_conv_libfunc (convert_optab optable, enum machine_mode tmode,
slot = (struct libfunc_entry **) htab_find_slot (libfunc_hash, &e, INSERT);
if (*slot == NULL)
*slot = ggc_alloc (sizeof (struct libfunc_entry));
- (*slot)->optab = optable;
+ (*slot)->optab = (size_t) (convert_optab_table[0] - optable);
(*slot)->mode1 = tmode;
(*slot)->mode2 = fmode;
(*slot)->libfunc = val;