diff options
-rw-r--r-- | hints/unicos.sh | 17 | ||||
-rw-r--r-- | lib/Math/Complex.pm | 5 |
2 files changed, 14 insertions, 8 deletions
diff --git a/hints/unicos.sh b/hints/unicos.sh index 5d29754586..43045ff6f9 100644 --- a/hints/unicos.sh +++ b/hints/unicos.sh @@ -2,15 +2,15 @@ case `uname -r` in 6.1*) shellflags="-m+65536" ;; esac case "$optimize" in -'') optimize="-h nofastmd" ;; # fastmd: integer values limited to 46 bits +# if we used fastmd (the default) integer values would be limited to 43 bits +# --Mark P. Lutz +'') optimize="-h nofastmd" ;; esac -case `uname -r` in -10.*) pp_ctl_cflags='optimize="$optimize -h scalar 0 -h vector 0"' ;; -esac -d_setregid='undef' -d_setreuid='undef' +# Avoid an optimizer bug where a volatile variables +# isn't correctly saved and restored --Mark P. Lutz +pp_ctl_cflags='ccflags="$ccflags -h scalar0 -h vector0"' case "$usemymalloc" in -'') # The perl malloc.c SHOULD work in Unicos (ILP64) says Ilya. +'') # The perl malloc.c SHOULD work says Ilya. # But for the time being (5.004_68), alas, it doesn't. --jhi # usemymalloc='y' # ccflags="$ccflags -DNO_RCHECK" @@ -19,3 +19,6 @@ case "$usemymalloc" in esac # Configure gets fooled for some reason. There is no getpgid(). d_getpgid='undef' +# These exist but do not really work. +d_setregid='undef' +d_setreuid='undef' diff --git a/lib/Math/Complex.pm b/lib/Math/Complex.pm index b13ab77f7a..514935522e 100644 --- a/lib/Math/Complex.pm +++ b/lib/Math/Complex.pm @@ -72,7 +72,10 @@ my %DISPLAY_FORMAT = ('style' => 'cartesian', 'polar_pretty_print' => 1); my $eps = 1e-14; # Epsilon -my $Inf = CORE::exp(CORE::exp(30)); +my $Inf; +unless ($^O eq 'unicos') { # Unicos gets a fatal runtime error + $Inf = CORE::exp(CORE::exp(30)); +} $Inf = "Inf" if !defined $Inf || !$Inf > 0; # |