00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #include "config.h"
00023 #include "system.h"
00024 #include "ggc.h"
00025 #include "vec.h"
00026 #include "errors.h"
00027 #include "coretypes.h"
00028 #include "tree.h"
00029
00030 struct vec_prefix
00031 {
00032 unsigned num;
00033 unsigned alloc;
00034 void *vec[1];
00035 };
00036
00037
00038
00039
00040
00041 void *
00042 vec_gc_p_reserve (void *vec, int reserve MEM_STAT_DECL)
00043 {
00044 return vec_gc_o_reserve (vec, reserve,
00045 offsetof (struct vec_prefix, vec), sizeof (void *)
00046 PASS_MEM_STAT);
00047 }
00048
00049
00050
00051
00052
00053
00054
00055 void *
00056 vec_gc_o_reserve (void *vec, int reserve, size_t vec_offset, size_t elt_size
00057 MEM_STAT_DECL)
00058 {
00059 struct vec_prefix *pfx = vec;
00060 unsigned alloc = pfx ? pfx->num : 0;
00061
00062 if (reserve >= 0)
00063 alloc += reserve;
00064 else if (alloc)
00065 alloc *= 2;
00066 else
00067 alloc = 4;
00068
00069 if (pfx && pfx->alloc >= alloc)
00070 abort ();
00071
00072 vec = ggc_realloc_stat (vec, vec_offset + alloc * elt_size PASS_MEM_STAT);
00073 ((struct vec_prefix *)vec)->alloc = alloc;
00074 if (!pfx)
00075 ((struct vec_prefix *)vec)->num = 0;
00076
00077 return vec;
00078 }
00079
00080
00081
00082 void
00083 vec_gc_free (void *vec)
00084 {
00085 ggc_free (vec);
00086 }
00087
00088
00089
00090
00091
00092 void *
00093 vec_heap_p_reserve (void *vec, int reserve MEM_STAT_DECL)
00094 {
00095 return vec_heap_o_reserve (vec, reserve,
00096 offsetof (struct vec_prefix, vec), sizeof (void *)
00097 PASS_MEM_STAT);
00098 }
00099
00100
00101
00102
00103
00104
00105
00106 void *
00107 vec_heap_o_reserve (void *vec, int reserve, size_t vec_offset, size_t elt_size
00108 MEM_STAT_DECL)
00109 {
00110 struct vec_prefix *pfx = vec;
00111 unsigned alloc = pfx ? pfx->num : 0;
00112
00113 if (reserve >= 0)
00114 alloc += reserve;
00115 else if (alloc)
00116 alloc *= 2;
00117 else
00118 alloc = 4;
00119
00120 if (pfx && pfx->alloc >= alloc)
00121 abort ();
00122
00123 vec = xrealloc (vec, vec_offset + alloc * elt_size);
00124 ((struct vec_prefix *)vec)->alloc = alloc;
00125 if (!pfx)
00126 ((struct vec_prefix *)vec)->num = 0;
00127
00128 return vec;
00129 }
00130
00131
00132
00133 void
00134 vec_heap_free (void *vec)
00135 {
00136 free (vec);
00137 }
00138
00139 #if ENABLE_CHECKING
00140
00141
00142 void
00143 vec_assert_fail (const char *op, const char *struct_name,
00144 const char *file, unsigned int line, const char *function)
00145 {
00146 internal_error ("vector %s %s domain error, in %s at %s:%u",
00147 struct_name, op, function, trim_filename (file), line);
00148 }
00149 #endif