summaryrefslogtreecommitdiff
path: root/gcc/insn-addr.h
diff options
context:
space:
mode:
authorkazu <kazu@138bc75d-0d04-0410-961f-82ee72b054a4>2006-12-23 22:10:10 +0000
committerkazu <kazu@138bc75d-0d04-0410-961f-82ee72b054a4>2006-12-23 22:10:10 +0000
commite56df1a96bbf45aff92f0062388bfd1083a1a1d8 (patch)
tree46e966a10c5cfd38bdcd802c2fcdba4bc35d4581 /gcc/insn-addr.h
parent52c842b7286039b4cb2f8a43c6b7e21b7a44f9e5 (diff)
downloadgcc-e56df1a96bbf45aff92f0062388bfd1083a1a1d8.tar.gz
* Makefile.in (final.o): Depend on vecprim.h.
* final.c: Include vecprim.h. (insn_addresses_): Change the type to VEC(int,heap)*. * insn-addr.h (INSN_ADDRESSES_DEFN): Remove. (INSN_ADDRESSES, INSN_ADDRESSES_ALLOC, INSN_ADDRESSES_SIZE, INSN_ADDRESSES_NEW): Use VEC instead of VARRAY. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@120177 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/insn-addr.h')
-rw-r--r--gcc/insn-addr.h60
1 files changed, 38 insertions, 22 deletions
diff --git a/gcc/insn-addr.h b/gcc/insn-addr.h
index 457980e44fe..baa3cdadcae 100644
--- a/gcc/insn-addr.h
+++ b/gcc/insn-addr.h
@@ -19,32 +19,48 @@ Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301, USA. */
#ifndef GCC_INSN_ADDR_H
-#define GCC_INSN_ADDR_H
+#define GCC_INSN_ADDR_H
-#include "varray.h"
+#include "vecprim.h"
-extern GTY(()) varray_type insn_addresses_;
+extern VEC(int,heap) *insn_addresses_;
extern int insn_current_address;
-#define INSN_ADDRESSES_DEFN() varray_type insn_addresses_
-#define INSN_ADDRESSES(id) VARRAY_INT (insn_addresses_, (id))
-#define INSN_ADDRESSES_ALLOC(size) \
- VARRAY_INT_INIT (insn_addresses_, (size), "insn_addresses")
-#define INSN_ADDRESSES_FREE() (insn_addresses_ = 0)
+#define INSN_ADDRESSES(id) (*&(VEC_address (int, insn_addresses_) [id]))
+#define INSN_ADDRESSES_ALLOC(size) \
+ do \
+ { \
+ insn_addresses_ = VEC_alloc (int, heap, size); \
+ VEC_safe_grow (int, heap, insn_addresses_, size); \
+ memset (VEC_address (int, insn_addresses_), \
+ 0, sizeof (int) * size); \
+ } \
+ while (0)
+#define INSN_ADDRESSES_FREE() (VEC_free (int, heap, insn_addresses_))
#define INSN_ADDRESSES_SET_P() (insn_addresses_ != 0)
-#define INSN_ADDRESSES_SIZE() VARRAY_SIZE (insn_addresses_)
-#define INSN_ADDRESSES_NEW(insn, addr) do \
- { \
- unsigned insn_uid__ = INSN_UID ((insn)); \
- int insn_addr__ = (addr); \
- \
- if (INSN_ADDRESSES_SET_P ()) \
- { \
- if (INSN_ADDRESSES_SIZE () <= insn_uid__) \
- VARRAY_GROW (insn_addresses_, insn_uid__ + 1); \
- INSN_ADDRESSES (insn_uid__) = insn_addr__; \
- } \
- } \
-while (0)
+#define INSN_ADDRESSES_SIZE() (VEC_length (int, insn_addresses_))
+
+static inline void
+insn_addresses_new (rtx insn, int insn_addr)
+{
+ unsigned insn_uid = INSN_UID ((insn));
+
+ if (INSN_ADDRESSES_SET_P ())
+ {
+ size_t size = INSN_ADDRESSES_SIZE ();
+ if (size <= insn_uid)
+ {
+ int *p;
+ VEC_safe_grow (int, heap, insn_addresses_, insn_uid + 1);
+ p = VEC_address (int, insn_addresses_);
+ memset (&p[size],
+ 0, sizeof (int) * (insn_uid + 1 - size));
+ }
+ INSN_ADDRESSES (insn_uid) = insn_addr;
+ }
+}
+
+#define INSN_ADDRESSES_NEW(insn, addr) \
+ (insn_addresses_new (insn, addr))
#endif /* ! GCC_INSN_ADDR_H */