summaryrefslogtreecommitdiff
path: root/contrib/paranoia.cc
diff options
context:
space:
mode:
authorrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2002-10-22 00:09:41 +0000
committerrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2002-10-22 00:09:41 +0000
commit351130341f970634630dda2538d64556875ea402 (patch)
tree89ed00a5d9c2cef42696dffda1d771baa825c5b3 /contrib/paranoia.cc
parent6b9d1b54d202b59edb25b4c3001dd0d52379ce42 (diff)
downloadgcc-351130341f970634630dda2538d64556875ea402.tar.gz
* paranoia.cc (real_c_float::image): Accomodate size of
real_internal format. (main): Unbuffer stdio. Add real_internal format. (floor_log2_wide): New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@58395 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'contrib/paranoia.cc')
-rw-r--r--contrib/paranoia.cc19
1 files changed, 18 insertions, 1 deletions
diff --git a/contrib/paranoia.cc b/contrib/paranoia.cc
index fafb92b708f..694d3d4509b 100644
--- a/contrib/paranoia.cc
+++ b/contrib/paranoia.cc
@@ -195,7 +195,10 @@ class real_c_float
static const enum machine_mode MODE = SFmode;
private:
- long image[128 / 32];
+ static const int external_max = 128 / 32;
+ static const int internal_max
+ = (sizeof (REAL_VALUE_TYPE) + sizeof (long) + 1) / sizeof (long);
+ long image[external_max < internal_max ? internal_max : external_max];
void from_long(long);
void from_str(const char *);
@@ -2607,6 +2610,9 @@ Paranoia<FLOAT>::notify (const char *s)
int main(int ac, char **av)
{
+ setbuf(stdout, NULL);
+ setbuf(stderr, NULL);
+
while (1)
switch (getopt (ac, av, "pvg:fdl"))
{
@@ -2639,6 +2645,7 @@ int main(int ac, char **av)
F(i370_double),
F(c4x_single),
F(c4x_extended),
+ F(real_internal),
#undef F
};
@@ -2697,3 +2704,13 @@ fancy_abort ()
}
int target_flags = 0;
+
+extern "C" int
+floor_log2_wide (unsigned HOST_WIDE_INT x)
+{
+ int log = -1;
+ while (x != 0)
+ log++,
+ x >>= 1;
+ return log;
+}