Blame SOURCES/gcc48-rh1469697-6.patch

4dd737
commit dd9992d1b96b5811873c98a208c029bebb0c3577
4dd737
Author: law <law@138bc75d-0d04-0410-961f-82ee72b054a4>
4dd737
Date:   Wed Sep 20 05:35:07 2017 +0000
4dd737
4dd737
            * config/i386/i386.c (ix86_adjust_stack_and_probe_stack_clash): New.
4dd737
            (ix86_expand_prologue): Dump stack clash info as needed.
4dd737
            Call ix86_adjust_stack_and_probe_stack_clash as needed.
4dd737
    
4dd737
            * gcc.dg/stack-check-4.c: New test.
4dd737
            * gcc.dg/stack-check-5.c: New test.
4dd737
            * gcc.dg/stack-check-6.c: New test.
4dd737
            * gcc.dg/stack-check-6a.c: New test.
4dd737
            * gcc.dg/stack-check-7.c: New test.
4dd737
            * gcc.dg/stack-check-8.c: New test.
4dd737
            * gcc.dg/stack-check-9.c: New test.
4dd737
            * gcc.dg/stack-check-10.c: New test.
4dd737
            * lib/target-supports.exp
4dd737
            (check_effective_target_supports_stack_clash_protection): Enable for
4dd737
            x86 and x86_64 targets.
4dd737
    
4dd737
    git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@252998 138bc75d-0d04-0410-961f-82ee72b054a4
4dd737
4dd737
diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c
4dd737
index d996fd160e8..a555b0774c0 100644
4dd737
--- a/gcc/config/i386/i386.c
4dd737
+++ b/gcc/config/i386/i386.c
4dd737
@@ -9839,6 +9839,147 @@ release_scratch_register_on_entry (struct scratch_reg *sr)
4dd737
 
4dd737
 #define PROBE_INTERVAL (1 << STACK_CHECK_PROBE_INTERVAL_EXP)
4dd737
 
4dd737
+/* Emit code to adjust the stack pointer by SIZE bytes while probing it.
4dd737
+
4dd737
+   This differs from the next routine in that it tries hard to prevent
4dd737
+   attacks that jump the stack guard.  Thus it is never allowed to allocate
4dd737
+   more than PROBE_INTERVAL bytes of stack space without a suitable
4dd737
+   probe.  */
4dd737
+
4dd737
+static void
4dd737
+ix86_adjust_stack_and_probe_stack_clash (const HOST_WIDE_INT size)
4dd737
+{
4dd737
+  struct machine_function *m = cfun->machine;
4dd737
+
4dd737
+  /* If this function does not statically allocate stack space, then
4dd737
+     no probes are needed.  */
4dd737
+  if (!size)
4dd737
+    {
4dd737
+      dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false);
4dd737
+      return;
4dd737
+    }
4dd737
+
4dd737
+  /* If we are a noreturn function, then we have to consider the
4dd737
+     possibility that we're called via a jump rather than a call.
4dd737
+
4dd737
+     Thus we don't have the implicit probe generated by saving the
4dd737
+     return address into the stack at the call.  Thus, the stack
4dd737
+     pointer could be anywhere in the guard page.  The safe thing
4dd737
+     to do is emit a probe now.
4dd737
+
4dd737
+     ?!? This should be revamped to work like aarch64 and s390 where
4dd737
+     we track the offset from the most recent probe.  Normally that
4dd737
+     offset would be zero.  For a non-return function we would reset
4dd737
+     it to PROBE_INTERVAL - (STACK_BOUNDARY / BITS_PER_UNIT).   Then
4dd737
+     we just probe when we cross PROBE_INTERVAL.  */
4dd737
+  if (TREE_THIS_VOLATILE (cfun->decl))
4dd737
+    {
4dd737
+      emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx,
4dd737
+				       -GET_MODE_SIZE (word_mode)));
4dd737
+      emit_insn (gen_blockage ());
4dd737
+    }
4dd737
+
4dd737
+  /* If we allocate less than the size of the guard statically,
4dd737
+     then no probing is necessary, but we do need to allocate
4dd737
+     the stack.  */
4dd737
+  if (size < (1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE)))
4dd737
+    {
4dd737
+      pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx,
4dd737
+			         GEN_INT (-size), -1,
4dd737
+			         m->fs.cfa_reg == stack_pointer_rtx);
4dd737
+      dump_stack_clash_frame_info (NO_PROBE_SMALL_FRAME, true);
4dd737
+      return;
4dd737
+    }
4dd737
+
4dd737
+  /* We're allocating a large enough stack frame that we need to
4dd737
+     emit probes.  Either emit them inline or in a loop depending
4dd737
+     on the size.  */
4dd737
+  HOST_WIDE_INT probe_interval
4dd737
+    = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL);
4dd737
+  if (size <= 4 * probe_interval)
4dd737
+    {
4dd737
+      HOST_WIDE_INT i;
4dd737
+      for (i = probe_interval; i <= size; i += probe_interval)
4dd737
+	{
4dd737
+	  /* Allocate PROBE_INTERVAL bytes.  */
4dd737
+	  pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx,
4dd737
+				     GEN_INT (-probe_interval), -1,
4dd737
+				     m->fs.cfa_reg == stack_pointer_rtx);
4dd737
+
4dd737
+	  /* And probe at *sp.  */
4dd737
+	  emit_stack_probe (stack_pointer_rtx);
4dd737
+	  emit_insn (gen_blockage ());
4dd737
+	}
4dd737
+
4dd737
+      /* We need to allocate space for the residual, but we do not need
4dd737
+	 to probe the residual.  */
4dd737
+      HOST_WIDE_INT residual = (i - probe_interval - size);
4dd737
+      if (residual)
4dd737
+	pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx,
4dd737
+				   GEN_INT (residual), -1,
4dd737
+				   m->fs.cfa_reg == stack_pointer_rtx);
4dd737
+      dump_stack_clash_frame_info (PROBE_INLINE, residual != 0);
4dd737
+    }
4dd737
+  else
4dd737
+    {
4dd737
+      struct scratch_reg sr;
4dd737
+      get_scratch_register_on_entry (&sr);
4dd737
+
4dd737
+      /* Step 1: round SIZE down to a multiple of the interval.  */
4dd737
+      HOST_WIDE_INT rounded_size = size & -probe_interval;
4dd737
+
4dd737
+      /* Step 2: compute final value of the loop counter.  Use lea if
4dd737
+	 possible.  */
4dd737
+      rtx addr = plus_constant (Pmode, stack_pointer_rtx, -rounded_size);
4dd737
+      rtx insn;
4dd737
+      if (address_operand (addr, Pmode))
4dd737
+	insn = emit_insn (gen_rtx_SET (VOIDmode, sr.reg, addr));
4dd737
+      else
4dd737
+	{
4dd737
+	  emit_move_insn (sr.reg, GEN_INT (-rounded_size));
4dd737
+	  insn = emit_insn (gen_rtx_SET (VOIDmode, sr.reg,
4dd737
+					 gen_rtx_PLUS (Pmode, sr.reg,
4dd737
+						       stack_pointer_rtx)));
4dd737
+	}
4dd737
+      if (m->fs.cfa_reg == stack_pointer_rtx)
4dd737
+	{
4dd737
+	  add_reg_note (insn, REG_CFA_DEF_CFA,
4dd737
+			plus_constant (Pmode, sr.reg,
4dd737
+				       m->fs.cfa_offset + rounded_size));
4dd737
+	  RTX_FRAME_RELATED_P (insn) = 1;
4dd737
+        }
4dd737
+
4dd737
+      /* Step 3: the loop.  */
4dd737
+      rtx size_rtx = GEN_INT (rounded_size);
4dd737
+      insn = emit_insn (ix86_gen_adjust_stack_and_probe (sr.reg, sr.reg,
4dd737
+							 size_rtx));
4dd737
+      if (m->fs.cfa_reg == stack_pointer_rtx)
4dd737
+	{
4dd737
+	  m->fs.cfa_offset += rounded_size;
4dd737
+	  add_reg_note (insn, REG_CFA_DEF_CFA,
4dd737
+			plus_constant (Pmode, stack_pointer_rtx,
4dd737
+				       m->fs.cfa_offset));
4dd737
+	  RTX_FRAME_RELATED_P (insn) = 1;
4dd737
+        }
4dd737
+      m->fs.sp_offset += rounded_size;
4dd737
+      emit_insn (gen_blockage ());
4dd737
+
4dd737
+      /* Step 4: adjust SP if we cannot assert at compile-time that SIZE
4dd737
+	 is equal to ROUNDED_SIZE.  */
4dd737
+
4dd737
+      if (size != rounded_size)
4dd737
+	pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx,
4dd737
+				   GEN_INT (rounded_size - size), -1,
4dd737
+				   m->fs.cfa_reg == stack_pointer_rtx);
4dd737
+      dump_stack_clash_frame_info (PROBE_LOOP, size != rounded_size);
4dd737
+
4dd737
+      release_scratch_register_on_entry (&sr);
4dd737
+    }
4dd737
+
4dd737
+  /* Make sure nothing is scheduled before we are done.  */
4dd737
+  emit_insn (gen_blockage ());
4dd737
+}
4dd737
+
4dd737
 /* Emit code to adjust the stack pointer by SIZE bytes while probing it.  */
4dd737
 
4dd737
 static void
4dd737
@@ -10529,12 +10670,19 @@ ix86_expand_prologue (void)
4dd737
 
4dd737
   /* The stack has already been decremented by the instruction calling us
4dd737
      so probe if the size is non-negative to preserve the protection area.  */
4dd737
-  if (allocate >= 0 && flag_stack_check == STATIC_BUILTIN_STACK_CHECK)
4dd737
+  if (allocate >= 0
4dd737
+      && (flag_stack_check == STATIC_BUILTIN_STACK_CHECK
4dd737
+	  || flag_stack_clash_protection))
4dd737
     {
4dd737
       /* We expect the registers to be saved when probes are used.  */
4dd737
       gcc_assert (int_registers_saved);
4dd737
 
4dd737
-      if (STACK_CHECK_MOVING_SP)
4dd737
+      if (flag_stack_clash_protection)
4dd737
+	{
4dd737
+	  ix86_adjust_stack_and_probe_stack_clash (allocate);
4dd737
+	  allocate = 0;
4dd737
+	}
4dd737
+      else if (STACK_CHECK_MOVING_SP)
4dd737
 	{
4dd737
 	  ix86_adjust_stack_and_probe (allocate);
4dd737
 	  allocate = 0;
4dd737
diff --git a/gcc/testsuite/gcc.dg/stack-check-10.c b/gcc/testsuite/gcc.dg/stack-check-10.c
4dd737
new file mode 100644
4dd737
index 00000000000..a86956ad692
4dd737
--- /dev/null
4dd737
+++ b/gcc/testsuite/gcc.dg/stack-check-10.c
4dd737
@@ -0,0 +1,41 @@
4dd737
+/* { dg-do compile } */
4dd737
+/* { dg-options "-O2 -fstack-clash-protection -fdump-rtl-pro_and_epilogue -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=12" } */
4dd737
+/* { dg-require-effective-target supports_stack_clash_protection } */
4dd737
+
4dd737
+int f (int *);
4dd737
+
4dd737
+int
4dd737
+g (int a)
4dd737
+{
4dd737
+  return f (&a);
4dd737
+}
4dd737
+
4dd737
+int f1 (void);
4dd737
+int f2 (int);
4dd737
+
4dd737
+int
4dd737
+f3 (void)
4dd737
+{
4dd737
+  return f2 (f1 ());
4dd737
+}
4dd737
+
4dd737
+
4dd737
+/* If we have caller implicit probes, then we should not need probes in either callee.
4dd737
+   Else callees may need probes, particularly if non-leaf functions require a
4dd737
+   frame/frame pointer.  */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no probe" 2 "pro_and_epilogue" { target caller_implicit_probes } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash inline probe" 1 "pro_and_epilogue" { target { ! caller_implicit_probes } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no probe" 1 "pro_and_epilogue" { target { ! caller_implicit_probes } } } } */
4dd737
+
4dd737
+/* Neither of these functions are a nonreturn function.  */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 2 "pro_and_epilogue" } } */
4dd737
+
4dd737
+/* If the callee realigns the stack or has a mandatory frame, then both functions
4dd737
+   have a residual allocation.  Else just g() has a residual allocation.  */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 2 "pro_and_epilogue" } } */
4dd737
+
4dd737
+
4dd737
+/* If the target has frame pointers for non-leafs, then both functions will
4dd737
+   need a frame pointer.  Otherwise neither should.  */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 2 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */
4dd737
diff --git a/gcc/testsuite/gcc.dg/stack-check-3.c b/gcc/testsuite/gcc.dg/stack-check-3.c
4dd737
index 58fb65649ee..f0bf7c71a5b 100644
4dd737
--- a/gcc/testsuite/gcc.dg/stack-check-3.c
4dd737
+++ b/gcc/testsuite/gcc.dg/stack-check-3.c
4dd737
@@ -7,7 +7,7 @@
4dd737
    residual allocation + probe for f?.  */
4dd737
 
4dd737
 /* { dg-do compile } */
4dd737
-/* { dg-options "-O2 -fstack-clash-protection -fdump-rtl-expand -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=4096 --param stack-clash-protection-guard-size=4096" } */
4dd737
+/* { dg-options "-O2 -fstack-clash-protection -fdump-rtl-expand -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=12" } */
4dd737
 /* { dg-require-effective-target supports_stack_clash_protection } */
4dd737
 
4dd737
 __attribute__((noinline, noclone)) void
4dd737
diff --git a/gcc/testsuite/gcc.dg/stack-check-4.c b/gcc/testsuite/gcc.dg/stack-check-4.c
4dd737
new file mode 100644
4dd737
index 00000000000..b0c5c61972f
4dd737
--- /dev/null
4dd737
+++ b/gcc/testsuite/gcc.dg/stack-check-4.c
4dd737
@@ -0,0 +1,42 @@
4dd737
+/* On targets where the call instruction is an implicit probe of *sp, we
4dd737
+   elide stack probes as long as the size of the local stack is less than
4dd737
+   PROBE_INTERVAL.
4dd737
+
4dd737
+   But if the caller were to transform a tail call into a direct jump
4dd737
+   we do not have that implicit probe.  This normally isn't a problem as
4dd737
+   the caller must not have a local frame for that optimization to apply.
4dd737
+
4dd737
+   However, a sufficiently smart compiler could realize that the caller's
4dd737
+   local stack need not be torn down and thus could transform a call into
4dd737
+   a jump if the target is a noreturn function, even if the caller has
4dd737
+   a local frame.
4dd737
+
4dd737
+   To guard against that, targets that depend on *sp being probed by the
4dd737
+   call itself must emit a probe if the target function is a noreturn
4dd737
+   function, even if they just allocate a small amount of stack space.
4dd737
+
4dd737
+   Rather than try to parse RTL or assembly code, we instead require the
4dd737
+   prologue code to emit information into the dump file that we can
4dd737
+   scan for.   We scan for both the positive and negative cases.  */
4dd737
+
4dd737
+/* { dg-do compile } */
4dd737
+/* { dg-options "-O2 -fstack-clash-protection -fdump-rtl-pro_and_epilogue -fno-optimize-sibling-calls" } */
4dd737
+/* { dg-require-effective-target supports_stack_clash_protection } */
4dd737
+
4dd737
+extern void arf (char *);
4dd737
+
4dd737
+__attribute__ ((noreturn)) void foo1 ()
4dd737
+{
4dd737
+  char x[10];
4dd737
+  while (1)
4dd737
+    arf (x);
4dd737
+}
4dd737
+
4dd737
+void foo2 ()
4dd737
+{
4dd737
+  char x[10];
4dd737
+  arf (x);
4dd737
+}
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash noreturn" 1 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 1 "pro_and_epilogue" } } */
4dd737
+
4dd737
diff --git a/gcc/testsuite/gcc.dg/stack-check-5.c b/gcc/testsuite/gcc.dg/stack-check-5.c
4dd737
new file mode 100644
4dd737
index 00000000000..2171d9b6c23
4dd737
--- /dev/null
4dd737
+++ b/gcc/testsuite/gcc.dg/stack-check-5.c
4dd737
@@ -0,0 +1,74 @@
4dd737
+/* { dg-do compile } */
4dd737
+/* { dg-options "-O2 -fstack-clash-protection -fdump-rtl-pro_and_epilogue -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=12" } */
4dd737
+/* { dg-require-effective-target supports_stack_clash_protection } */
4dd737
+
4dd737
+
4dd737
+extern void foo (char *);
4dd737
+extern void bar (void);
4dd737
+
4dd737
+/* This function allocates no local stack and is a leaf.  It should have no
4dd737
+   probes on any target and should not require a frame pointer.  */
4dd737
+int
4dd737
+f0 (int x, int y)
4dd737
+{
4dd737
+  asm volatile ("" : : : "memory");  
4dd737
+  return x + y;
4dd737
+}
4dd737
+
4dd737
+/* This function allocates no local stack, but is not a leaf.  Ideally it
4dd737
+   should not need probing and no frame pointer.  */
4dd737
+int
4dd737
+f1 (int x, int y)
4dd737
+{
4dd737
+  asm volatile ("" : : : "memory");  
4dd737
+  bar ();
4dd737
+}
4dd737
+
4dd737
+/* This is a leaf with a small frame.  On targets with implicit probes in
4dd737
+   the caller, this should not need probing.  On targets with no implicit
4dd737
+   probes in the caller, it may require probes.  Ideally it should need no
4dd737
+   frame pointer.  */
4dd737
+void
4dd737
+f2 (void)
4dd737
+{
4dd737
+  char buf[512];
4dd737
+  asm volatile ("" : : "g" (&buf) : "memory");
4dd737
+}
4dd737
+
4dd737
+/* This is a non-leaf with a small frame.  On targets with implicit probes in
4dd737
+   the caller, this should not need probing.  On targets with no implicit
4dd737
+   probes in the caller, it may require probes.  It should need no frame
4dd737
+   pointer.  */
4dd737
+void
4dd737
+f3 (void)
4dd737
+{
4dd737
+  char buf[512];
4dd737
+  foo (buf);
4dd737
+}
4dd737
+
4dd737
+/* If we have caller implicit probes, then we should not need probes.
4dd737
+   Else callees may need probes, particularly if non-leaf functions require a
4dd737
+   frame/frame pointer.  */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no probe" 4 "pro_and_epilogue" { target caller_implicit_probes } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no probe" 2 "pro_and_epilogue" { target { ! caller_implicit_probes } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash inline probes " 2 "pro_and_epilogue" { target { ! caller_implicit_probes } } } } */
4dd737
+
4dd737
+/* None of these functions are marked with the noreturn attribute.  */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 4 "pro_and_epilogue" } } */
4dd737
+
4dd737
+/* Two functions are leafs, two are not.  Verify the target identified them
4dd737
+   appropriately.  */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 4 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */
4dd737
+
4dd737
+
4dd737
+/* We have selected the size of the array in f2/f3 to be large enough
4dd737
+   to not live in the red zone on targets that support it.
4dd737
+
4dd737
+   That allows simplification of this test considerably.
4dd737
+   f1() should not require any allocations, thus no residuals.
4dd737
+   All the rest of the functions require some kind of allocation,
4dd737
+   either for the saved fp/rp or the array.  */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no residual allocation in prologue" 1 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 3 "pro_and_epilogue" } } */
4dd737
diff --git a/gcc/testsuite/gcc.dg/stack-check-6.c b/gcc/testsuite/gcc.dg/stack-check-6.c
4dd737
new file mode 100644
4dd737
index 00000000000..ad2021c9037
4dd737
--- /dev/null
4dd737
+++ b/gcc/testsuite/gcc.dg/stack-check-6.c
4dd737
@@ -0,0 +1,55 @@
4dd737
+/* { dg-do compile } */
4dd737
+/* { dg-options "-O2 -fstack-clash-protection -fdump-rtl-pro_and_epilogue -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=12" } */
4dd737
+/* { dg-require-effective-target supports_stack_clash_protection } */
4dd737
+
4dd737
+
4dd737
+extern void foo (char *);
4dd737
+extern void bar (void);
4dd737
+
4dd737
+
4dd737
+/* This is a leaf with a frame that is large enough to require probing with
4dd737
+   a residual allocation, but small enough to probe inline.  */
4dd737
+void
4dd737
+f4 (void)
4dd737
+{
4dd737
+  char buf[4096 + 512];
4dd737
+  asm volatile ("" : : "g" (&buf) : "memory");
4dd737
+}
4dd737
+
4dd737
+
4dd737
+/* This is a non-leaf with a frame large enough to require probing and
4dd737
+   a residual allocation, but small enough to probe inline.  */
4dd737
+void
4dd737
+f5 (void)
4dd737
+{
4dd737
+  char buf[4096 + 512];
4dd737
+  foo (buf);
4dd737
+}
4dd737
+
4dd737
+/* This is a leaf with a frame that is large enough to require probing with
4dd737
+   a loop plus a residual allocation.  */
4dd737
+void
4dd737
+f6 (void)
4dd737
+{
4dd737
+  char buf[4096 * 10 + 512];
4dd737
+  asm volatile ("" : : "g" (&buf) : "memory");
4dd737
+}
4dd737
+
4dd737
+
4dd737
+/* This is a non-leaf with a frame large enough to require probing with
4dd737
+   a loop plus a residual allocation.  */
4dd737
+void
4dd737
+f7 (void)
4dd737
+{
4dd737
+  char buf[4096 * 10 + 512];
4dd737
+  foo (buf);
4dd737
+}
4dd737
+
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash inline probes" 2 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash probe loop" 2 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 4 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 4 "pro_and_epilogue" } } */
4dd737
+
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 4 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */
4dd737
diff --git a/gcc/testsuite/gcc.dg/stack-check-6a.c b/gcc/testsuite/gcc.dg/stack-check-6a.c
4dd737
new file mode 100644
4dd737
index 00000000000..6f8e7128921
4dd737
--- /dev/null
4dd737
+++ b/gcc/testsuite/gcc.dg/stack-check-6a.c
4dd737
@@ -0,0 +1,17 @@
4dd737
+/* The goal here is to verify that increasing the size of the guard allows
4dd737
+   elimination of all probing on the relevant targets.  */
4dd737
+   
4dd737
+/* { dg-do compile  } */
4dd737
+/* { dg-options "-O2 -fstack-clash-protection -fdump-rtl-pro_and_epilogue -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=16" } */
4dd737
+/* { dg-require-effective-target supports_stack_clash_protection  } */
4dd737
+
4dd737
+#include "stack-check-6.c"
4dd737
+
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash inline probes" 0 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash probe loop" 0 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 4 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 4 "pro_and_epilogue" } } */
4dd737
+
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 4 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */
4dd737
diff --git a/gcc/testsuite/gcc.dg/stack-check-7.c b/gcc/testsuite/gcc.dg/stack-check-7.c
4dd737
new file mode 100644
4dd737
index 00000000000..b963a2881dc
4dd737
--- /dev/null
4dd737
+++ b/gcc/testsuite/gcc.dg/stack-check-7.c
4dd737
@@ -0,0 +1,36 @@
4dd737
+/* { dg-do run } */
4dd737
+/* { dg-options "-O2 -fstack-clash-protection -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=12" } */
4dd737
+/* { dg-require-effective-target supports_stack_clash_protection } */
4dd737
+
4dd737
+/* For further testing, this can be run under valgrind where it's crashed
4dd737
+   on aarch64 and ppc64le with -fstack-check=specific.  */
4dd737
+
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+foo (char *p)
4dd737
+{
4dd737
+  asm volatile ("" : : "r" (p) : "memory");
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+bar (void)
4dd737
+{
4dd737
+  char buf[131072];
4dd737
+  foo (buf);
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+baz (void)
4dd737
+{
4dd737
+  char buf[12000];
4dd737
+  foo (buf);
4dd737
+}
4dd737
+
4dd737
+int
4dd737
+main ()
4dd737
+{
4dd737
+  bar ();
4dd737
+  baz ();
4dd737
+  return 0;
4dd737
+}
4dd737
+
4dd737
diff --git a/gcc/testsuite/gcc.dg/stack-check-8.c b/gcc/testsuite/gcc.dg/stack-check-8.c
4dd737
new file mode 100644
4dd737
index 00000000000..0ccec8b532a
4dd737
--- /dev/null
4dd737
+++ b/gcc/testsuite/gcc.dg/stack-check-8.c
4dd737
@@ -0,0 +1,139 @@
4dd737
+/* { dg-do run } */
4dd737
+/* { dg-options "-O2 -w -fstack-clash-protection -Wno-psabi -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=12" } */
4dd737
+/* { dg-require-effective-target supports_stack_clash_protection } */
4dd737
+
4dd737
+
4dd737
+typedef float V __attribute__((vector_size (32)));
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+foo (char *p)
4dd737
+{
4dd737
+  asm volatile ("" : : "r" (p) : "memory");
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) int
4dd737
+f0 (int x, int y)
4dd737
+{
4dd737
+  asm volatile ("" : : : "memory");  
4dd737
+  return x + y;
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f1 (void)
4dd737
+{
4dd737
+  char buf[64];
4dd737
+  foo (buf);
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f2 (void)
4dd737
+{
4dd737
+  char buf[12000];
4dd737
+  foo (buf);
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f3 (void)
4dd737
+{
4dd737
+  char buf[131072];
4dd737
+  foo (buf);
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f4 (int x)
4dd737
+{
4dd737
+  char vla[x];
4dd737
+  foo (vla);
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f5 (int x)
4dd737
+{
4dd737
+  char buf[12000];
4dd737
+  foo (buf);
4dd737
+  {
4dd737
+    char vla[x];
4dd737
+    foo (vla);
4dd737
+  }
4dd737
+  {
4dd737
+    char vla[x];
4dd737
+    foo (vla);
4dd737
+  }
4dd737
+}
4dd737
+
4dd737
+V v;
4dd737
+
4dd737
+__attribute__((noinline, noclone)) int
4dd737
+f6 (int x, int y, V a, V b, V c)
4dd737
+{
4dd737
+  asm volatile ("" : : : "memory");  
4dd737
+  v = a + b + c;
4dd737
+  return x + y;
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f7 (V a, V b, V c)
4dd737
+{
4dd737
+  char buf[64];
4dd737
+  foo (buf);
4dd737
+  v = a + b + c;
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f8 (V a, V b, V c)
4dd737
+{
4dd737
+  char buf[12000];
4dd737
+  foo (buf);
4dd737
+  v = a + b + c;
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f9 (V a, V b, V c)
4dd737
+{
4dd737
+  char buf[131072];
4dd737
+  foo (buf);
4dd737
+  v = a + b + c;
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f10 (int x, V a, V b, V c)
4dd737
+{
4dd737
+  char vla[x];
4dd737
+  foo (vla);
4dd737
+  v = a + b + c;
4dd737
+}
4dd737
+
4dd737
+__attribute__((noinline, noclone)) void
4dd737
+f11 (int x, V a, V b, V c)
4dd737
+{
4dd737
+  char buf[12000];
4dd737
+  foo (buf);
4dd737
+  v = a + b + c;
4dd737
+  {
4dd737
+    char vla[x];
4dd737
+    foo (vla);
4dd737
+  }
4dd737
+  {
4dd737
+    char vla[x];
4dd737
+    foo (vla);
4dd737
+  }
4dd737
+}
4dd737
+
4dd737
+int
4dd737
+main ()
4dd737
+{
4dd737
+  f0 (2, 3);
4dd737
+  f1 ();
4dd737
+  f2 ();
4dd737
+  f3 ();
4dd737
+  f4 (12000);
4dd737
+  f5 (12000);
4dd737
+  f6 (2, 3, v, v, v);
4dd737
+  f7 (v, v, v);
4dd737
+  f8 (v, v, v);
4dd737
+  f9 (v, v, v);
4dd737
+  f10 (12000, v, v, v);
4dd737
+  f11 (12000, v, v, v);
4dd737
+  return 0;
4dd737
+}
4dd737
+
4dd737
diff --git a/gcc/testsuite/gcc.dg/stack-check-9.c b/gcc/testsuite/gcc.dg/stack-check-9.c
4dd737
new file mode 100644
4dd737
index 00000000000..b84075b9b43
4dd737
--- /dev/null
4dd737
+++ b/gcc/testsuite/gcc.dg/stack-check-9.c
4dd737
@@ -0,0 +1,2022 @@
4dd737
+/* { dg-do compile } */
4dd737
+/* { dg-options "-O2 -fstack-clash-protection -fdump-rtl-pro_and_epilogue -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=12" } */
4dd737
+/* { dg-require-effective-target supports_stack_clash_protection } */
4dd737
+
4dd737
+double f1 (void);
4dd737
+double f2 (double, double);
4dd737
+
4dd737
+double
4dd737
+f3 (void)
4dd737
+{
4dd737
+  double d000 = f1 ();
4dd737
+  double d001 = f1 ();
4dd737
+  double d002 = f1 ();
4dd737
+  double d003 = f1 ();
4dd737
+  double d004 = f1 ();
4dd737
+  double d005 = f1 ();
4dd737
+  double d006 = f1 ();
4dd737
+  double d007 = f1 ();
4dd737
+  double d008 = f1 ();
4dd737
+  double d009 = f1 ();
4dd737
+  double d010 = f1 ();
4dd737
+  double d011 = f1 ();
4dd737
+  double d012 = f1 ();
4dd737
+  double d013 = f1 ();
4dd737
+  double d014 = f1 ();
4dd737
+  double d015 = f1 ();
4dd737
+  double d016 = f1 ();
4dd737
+  double d017 = f1 ();
4dd737
+  double d018 = f1 ();
4dd737
+  double d019 = f1 ();
4dd737
+  double d020 = f1 ();
4dd737
+  double d021 = f1 ();
4dd737
+  double d022 = f1 ();
4dd737
+  double d023 = f1 ();
4dd737
+  double d024 = f1 ();
4dd737
+  double d025 = f1 ();
4dd737
+  double d026 = f1 ();
4dd737
+  double d027 = f1 ();
4dd737
+  double d028 = f1 ();
4dd737
+  double d029 = f1 ();
4dd737
+  double d030 = f1 ();
4dd737
+  double d031 = f1 ();
4dd737
+  double d032 = f1 ();
4dd737
+  double d033 = f1 ();
4dd737
+  double d034 = f1 ();
4dd737
+  double d035 = f1 ();
4dd737
+  double d036 = f1 ();
4dd737
+  double d037 = f1 ();
4dd737
+  double d038 = f1 ();
4dd737
+  double d039 = f1 ();
4dd737
+  double d040 = f1 ();
4dd737
+  double d041 = f1 ();
4dd737
+  double d042 = f1 ();
4dd737
+  double d043 = f1 ();
4dd737
+  double d044 = f1 ();
4dd737
+  double d045 = f1 ();
4dd737
+  double d046 = f1 ();
4dd737
+  double d047 = f1 ();
4dd737
+  double d048 = f1 ();
4dd737
+  double d049 = f1 ();
4dd737
+  double d050 = f1 ();
4dd737
+  double d051 = f1 ();
4dd737
+  double d052 = f1 ();
4dd737
+  double d053 = f1 ();
4dd737
+  double d054 = f1 ();
4dd737
+  double d055 = f1 ();
4dd737
+  double d056 = f1 ();
4dd737
+  double d057 = f1 ();
4dd737
+  double d058 = f1 ();
4dd737
+  double d059 = f1 ();
4dd737
+  double d060 = f1 ();
4dd737
+  double d061 = f1 ();
4dd737
+  double d062 = f1 ();
4dd737
+  double d063 = f1 ();
4dd737
+  double d064 = f1 ();
4dd737
+  double d065 = f1 ();
4dd737
+  double d066 = f1 ();
4dd737
+  double d067 = f1 ();
4dd737
+  double d068 = f1 ();
4dd737
+  double d069 = f1 ();
4dd737
+  double d070 = f1 ();
4dd737
+  double d071 = f1 ();
4dd737
+  double d072 = f1 ();
4dd737
+  double d073 = f1 ();
4dd737
+  double d074 = f1 ();
4dd737
+  double d075 = f1 ();
4dd737
+  double d076 = f1 ();
4dd737
+  double d077 = f1 ();
4dd737
+  double d078 = f1 ();
4dd737
+  double d079 = f1 ();
4dd737
+  double d080 = f1 ();
4dd737
+  double d081 = f1 ();
4dd737
+  double d082 = f1 ();
4dd737
+  double d083 = f1 ();
4dd737
+  double d084 = f1 ();
4dd737
+  double d085 = f1 ();
4dd737
+  double d086 = f1 ();
4dd737
+  double d087 = f1 ();
4dd737
+  double d088 = f1 ();
4dd737
+  double d089 = f1 ();
4dd737
+  double d090 = f1 ();
4dd737
+  double d091 = f1 ();
4dd737
+  double d092 = f1 ();
4dd737
+  double d093 = f1 ();
4dd737
+  double d094 = f1 ();
4dd737
+  double d095 = f1 ();
4dd737
+  double d096 = f1 ();
4dd737
+  double d097 = f1 ();
4dd737
+  double d098 = f1 ();
4dd737
+  double d099 = f1 ();
4dd737
+  double d100 = f1 ();
4dd737
+  double d101 = f1 ();
4dd737
+  double d102 = f1 ();
4dd737
+  double d103 = f1 ();
4dd737
+  double d104 = f1 ();
4dd737
+  double d105 = f1 ();
4dd737
+  double d106 = f1 ();
4dd737
+  double d107 = f1 ();
4dd737
+  double d108 = f1 ();
4dd737
+  double d109 = f1 ();
4dd737
+  double d110 = f1 ();
4dd737
+  double d111 = f1 ();
4dd737
+  double d112 = f1 ();
4dd737
+  double d113 = f1 ();
4dd737
+  double d114 = f1 ();
4dd737
+  double d115 = f1 ();
4dd737
+  double d116 = f1 ();
4dd737
+  double d117 = f1 ();
4dd737
+  double d118 = f1 ();
4dd737
+  double d119 = f1 ();
4dd737
+  double d120 = f1 ();
4dd737
+  double d121 = f1 ();
4dd737
+  double d122 = f1 ();
4dd737
+  double d123 = f1 ();
4dd737
+  double d124 = f1 ();
4dd737
+  double d125 = f1 ();
4dd737
+  double d126 = f1 ();
4dd737
+  double d127 = f1 ();
4dd737
+  double d128 = f1 ();
4dd737
+  double d129 = f1 ();
4dd737
+  double d130 = f1 ();
4dd737
+  double d131 = f1 ();
4dd737
+  double d132 = f1 ();
4dd737
+  double d133 = f1 ();
4dd737
+  double d134 = f1 ();
4dd737
+  double d135 = f1 ();
4dd737
+  double d136 = f1 ();
4dd737
+  double d137 = f1 ();
4dd737
+  double d138 = f1 ();
4dd737
+  double d139 = f1 ();
4dd737
+  double d140 = f1 ();
4dd737
+  double d141 = f1 ();
4dd737
+  double d142 = f1 ();
4dd737
+  double d143 = f1 ();
4dd737
+  double d144 = f1 ();
4dd737
+  double d145 = f1 ();
4dd737
+  double d146 = f1 ();
4dd737
+  double d147 = f1 ();
4dd737
+  double d148 = f1 ();
4dd737
+  double d149 = f1 ();
4dd737
+  double d150 = f1 ();
4dd737
+  double d151 = f1 ();
4dd737
+  double d152 = f1 ();
4dd737
+  double d153 = f1 ();
4dd737
+  double d154 = f1 ();
4dd737
+  double d155 = f1 ();
4dd737
+  double d156 = f1 ();
4dd737
+  double d157 = f1 ();
4dd737
+  double d158 = f1 ();
4dd737
+  double d159 = f1 ();
4dd737
+  double d160 = f1 ();
4dd737
+  double d161 = f1 ();
4dd737
+  double d162 = f1 ();
4dd737
+  double d163 = f1 ();
4dd737
+  double d164 = f1 ();
4dd737
+  double d165 = f1 ();
4dd737
+  double d166 = f1 ();
4dd737
+  double d167 = f1 ();
4dd737
+  double d168 = f1 ();
4dd737
+  double d169 = f1 ();
4dd737
+  double d170 = f1 ();
4dd737
+  double d171 = f1 ();
4dd737
+  double d172 = f1 ();
4dd737
+  double d173 = f1 ();
4dd737
+  double d174 = f1 ();
4dd737
+  double d175 = f1 ();
4dd737
+  double d176 = f1 ();
4dd737
+  double d177 = f1 ();
4dd737
+  double d178 = f1 ();
4dd737
+  double d179 = f1 ();
4dd737
+  double d180 = f1 ();
4dd737
+  double d181 = f1 ();
4dd737
+  double d182 = f1 ();
4dd737
+  double d183 = f1 ();
4dd737
+  double d184 = f1 ();
4dd737
+  double d185 = f1 ();
4dd737
+  double d186 = f1 ();
4dd737
+  double d187 = f1 ();
4dd737
+  double d188 = f1 ();
4dd737
+  double d189 = f1 ();
4dd737
+  double d190 = f1 ();
4dd737
+  double d191 = f1 ();
4dd737
+  double d192 = f1 ();
4dd737
+  double d193 = f1 ();
4dd737
+  double d194 = f1 ();
4dd737
+  double d195 = f1 ();
4dd737
+  double d196 = f1 ();
4dd737
+  double d197 = f1 ();
4dd737
+  double d198 = f1 ();
4dd737
+  double d199 = f1 ();
4dd737
+  double d200 = f1 ();
4dd737
+  double d201 = f1 ();
4dd737
+  double d202 = f1 ();
4dd737
+  double d203 = f1 ();
4dd737
+  double d204 = f1 ();
4dd737
+  double d205 = f1 ();
4dd737
+  double d206 = f1 ();
4dd737
+  double d207 = f1 ();
4dd737
+  double d208 = f1 ();
4dd737
+  double d209 = f1 ();
4dd737
+  double d210 = f1 ();
4dd737
+  double d211 = f1 ();
4dd737
+  double d212 = f1 ();
4dd737
+  double d213 = f1 ();
4dd737
+  double d214 = f1 ();
4dd737
+  double d215 = f1 ();
4dd737
+  double d216 = f1 ();
4dd737
+  double d217 = f1 ();
4dd737
+  double d218 = f1 ();
4dd737
+  double d219 = f1 ();
4dd737
+  double d220 = f1 ();
4dd737
+  double d221 = f1 ();
4dd737
+  double d222 = f1 ();
4dd737
+  double d223 = f1 ();
4dd737
+  double d224 = f1 ();
4dd737
+  double d225 = f1 ();
4dd737
+  double d226 = f1 ();
4dd737
+  double d227 = f1 ();
4dd737
+  double d228 = f1 ();
4dd737
+  double d229 = f1 ();
4dd737
+  double d230 = f1 ();
4dd737
+  double d231 = f1 ();
4dd737
+  double d232 = f1 ();
4dd737
+  double d233 = f1 ();
4dd737
+  double d234 = f1 ();
4dd737
+  double d235 = f1 ();
4dd737
+  double d236 = f1 ();
4dd737
+  double d237 = f1 ();
4dd737
+  double d238 = f1 ();
4dd737
+  double d239 = f1 ();
4dd737
+  double d240 = f1 ();
4dd737
+  double d241 = f1 ();
4dd737
+  double d242 = f1 ();
4dd737
+  double d243 = f1 ();
4dd737
+  double d244 = f1 ();
4dd737
+  double d245 = f1 ();
4dd737
+  double d246 = f1 ();
4dd737
+  double d247 = f1 ();
4dd737
+  double d248 = f1 ();
4dd737
+  double d249 = f1 ();
4dd737
+  double d250 = f1 ();
4dd737
+  double d251 = f1 ();
4dd737
+  double d252 = f1 ();
4dd737
+  double d253 = f1 ();
4dd737
+  double d254 = f1 ();
4dd737
+  double d255 = f1 ();
4dd737
+  double d256 = f1 ();
4dd737
+  double d257 = f1 ();
4dd737
+  double d258 = f1 ();
4dd737
+  double d259 = f1 ();
4dd737
+  double d260 = f1 ();
4dd737
+  double d261 = f1 ();
4dd737
+  double d262 = f1 ();
4dd737
+  double d263 = f1 ();
4dd737
+  double d264 = f1 ();
4dd737
+  double d265 = f1 ();
4dd737
+  double d266 = f1 ();
4dd737
+  double d267 = f1 ();
4dd737
+  double d268 = f1 ();
4dd737
+  double d269 = f1 ();
4dd737
+  double d270 = f1 ();
4dd737
+  double d271 = f1 ();
4dd737
+  double d272 = f1 ();
4dd737
+  double d273 = f1 ();
4dd737
+  double d274 = f1 ();
4dd737
+  double d275 = f1 ();
4dd737
+  double d276 = f1 ();
4dd737
+  double d277 = f1 ();
4dd737
+  double d278 = f1 ();
4dd737
+  double d279 = f1 ();
4dd737
+  double d280 = f1 ();
4dd737
+  double d281 = f1 ();
4dd737
+  double d282 = f1 ();
4dd737
+  double d283 = f1 ();
4dd737
+  double d284 = f1 ();
4dd737
+  double d285 = f1 ();
4dd737
+  double d286 = f1 ();
4dd737
+  double d287 = f1 ();
4dd737
+  double d288 = f1 ();
4dd737
+  double d289 = f1 ();
4dd737
+  double d290 = f1 ();
4dd737
+  double d291 = f1 ();
4dd737
+  double d292 = f1 ();
4dd737
+  double d293 = f1 ();
4dd737
+  double d294 = f1 ();
4dd737
+  double d295 = f1 ();
4dd737
+  double d296 = f1 ();
4dd737
+  double d297 = f1 ();
4dd737
+  double d298 = f1 ();
4dd737
+  double d299 = f1 ();
4dd737
+  double d300 = f1 ();
4dd737
+  double d301 = f1 ();
4dd737
+  double d302 = f1 ();
4dd737
+  double d303 = f1 ();
4dd737
+  double d304 = f1 ();
4dd737
+  double d305 = f1 ();
4dd737
+  double d306 = f1 ();
4dd737
+  double d307 = f1 ();
4dd737
+  double d308 = f1 ();
4dd737
+  double d309 = f1 ();
4dd737
+  double d310 = f1 ();
4dd737
+  double d311 = f1 ();
4dd737
+  double d312 = f1 ();
4dd737
+  double d313 = f1 ();
4dd737
+  double d314 = f1 ();
4dd737
+  double d315 = f1 ();
4dd737
+  double d316 = f1 ();
4dd737
+  double d317 = f1 ();
4dd737
+  double d318 = f1 ();
4dd737
+  double d319 = f1 ();
4dd737
+  double d320 = f1 ();
4dd737
+  double d321 = f1 ();
4dd737
+  double d322 = f1 ();
4dd737
+  double d323 = f1 ();
4dd737
+  double d324 = f1 ();
4dd737
+  double d325 = f1 ();
4dd737
+  double d326 = f1 ();
4dd737
+  double d327 = f1 ();
4dd737
+  double d328 = f1 ();
4dd737
+  double d329 = f1 ();
4dd737
+  double d330 = f1 ();
4dd737
+  double d331 = f1 ();
4dd737
+  double d332 = f1 ();
4dd737
+  double d333 = f1 ();
4dd737
+  double d334 = f1 ();
4dd737
+  double d335 = f1 ();
4dd737
+  double d336 = f1 ();
4dd737
+  double d337 = f1 ();
4dd737
+  double d338 = f1 ();
4dd737
+  double d339 = f1 ();
4dd737
+  double d340 = f1 ();
4dd737
+  double d341 = f1 ();
4dd737
+  double d342 = f1 ();
4dd737
+  double d343 = f1 ();
4dd737
+  double d344 = f1 ();
4dd737
+  double d345 = f1 ();
4dd737
+  double d346 = f1 ();
4dd737
+  double d347 = f1 ();
4dd737
+  double d348 = f1 ();
4dd737
+  double d349 = f1 ();
4dd737
+  double d350 = f1 ();
4dd737
+  double d351 = f1 ();
4dd737
+  double d352 = f1 ();
4dd737
+  double d353 = f1 ();
4dd737
+  double d354 = f1 ();
4dd737
+  double d355 = f1 ();
4dd737
+  double d356 = f1 ();
4dd737
+  double d357 = f1 ();
4dd737
+  double d358 = f1 ();
4dd737
+  double d359 = f1 ();
4dd737
+  double d360 = f1 ();
4dd737
+  double d361 = f1 ();
4dd737
+  double d362 = f1 ();
4dd737
+  double d363 = f1 ();
4dd737
+  double d364 = f1 ();
4dd737
+  double d365 = f1 ();
4dd737
+  double d366 = f1 ();
4dd737
+  double d367 = f1 ();
4dd737
+  double d368 = f1 ();
4dd737
+  double d369 = f1 ();
4dd737
+  double d370 = f1 ();
4dd737
+  double d371 = f1 ();
4dd737
+  double d372 = f1 ();
4dd737
+  double d373 = f1 ();
4dd737
+  double d374 = f1 ();
4dd737
+  double d375 = f1 ();
4dd737
+  double d376 = f1 ();
4dd737
+  double d377 = f1 ();
4dd737
+  double d378 = f1 ();
4dd737
+  double d379 = f1 ();
4dd737
+  double d380 = f1 ();
4dd737
+  double d381 = f1 ();
4dd737
+  double d382 = f1 ();
4dd737
+  double d383 = f1 ();
4dd737
+  double d384 = f1 ();
4dd737
+  double d385 = f1 ();
4dd737
+  double d386 = f1 ();
4dd737
+  double d387 = f1 ();
4dd737
+  double d388 = f1 ();
4dd737
+  double d389 = f1 ();
4dd737
+  double d390 = f1 ();
4dd737
+  double d391 = f1 ();
4dd737
+  double d392 = f1 ();
4dd737
+  double d393 = f1 ();
4dd737
+  double d394 = f1 ();
4dd737
+  double d395 = f1 ();
4dd737
+  double d396 = f1 ();
4dd737
+  double d397 = f1 ();
4dd737
+  double d398 = f1 ();
4dd737
+  double d399 = f1 ();
4dd737
+  double d400 = f1 ();
4dd737
+  double d401 = f1 ();
4dd737
+  double d402 = f1 ();
4dd737
+  double d403 = f1 ();
4dd737
+  double d404 = f1 ();
4dd737
+  double d405 = f1 ();
4dd737
+  double d406 = f1 ();
4dd737
+  double d407 = f1 ();
4dd737
+  double d408 = f1 ();
4dd737
+  double d409 = f1 ();
4dd737
+  double d410 = f1 ();
4dd737
+  double d411 = f1 ();
4dd737
+  double d412 = f1 ();
4dd737
+  double d413 = f1 ();
4dd737
+  double d414 = f1 ();
4dd737
+  double d415 = f1 ();
4dd737
+  double d416 = f1 ();
4dd737
+  double d417 = f1 ();
4dd737
+  double d418 = f1 ();
4dd737
+  double d419 = f1 ();
4dd737
+  double d420 = f1 ();
4dd737
+  double d421 = f1 ();
4dd737
+  double d422 = f1 ();
4dd737
+  double d423 = f1 ();
4dd737
+  double d424 = f1 ();
4dd737
+  double d425 = f1 ();
4dd737
+  double d426 = f1 ();
4dd737
+  double d427 = f1 ();
4dd737
+  double d428 = f1 ();
4dd737
+  double d429 = f1 ();
4dd737
+  double d430 = f1 ();
4dd737
+  double d431 = f1 ();
4dd737
+  double d432 = f1 ();
4dd737
+  double d433 = f1 ();
4dd737
+  double d434 = f1 ();
4dd737
+  double d435 = f1 ();
4dd737
+  double d436 = f1 ();
4dd737
+  double d437 = f1 ();
4dd737
+  double d438 = f1 ();
4dd737
+  double d439 = f1 ();
4dd737
+  double d440 = f1 ();
4dd737
+  double d441 = f1 ();
4dd737
+  double d442 = f1 ();
4dd737
+  double d443 = f1 ();
4dd737
+  double d444 = f1 ();
4dd737
+  double d445 = f1 ();
4dd737
+  double d446 = f1 ();
4dd737
+  double d447 = f1 ();
4dd737
+  double d448 = f1 ();
4dd737
+  double d449 = f1 ();
4dd737
+  double d450 = f1 ();
4dd737
+  double d451 = f1 ();
4dd737
+  double d452 = f1 ();
4dd737
+  double d453 = f1 ();
4dd737
+  double d454 = f1 ();
4dd737
+  double d455 = f1 ();
4dd737
+  double d456 = f1 ();
4dd737
+  double d457 = f1 ();
4dd737
+  double d458 = f1 ();
4dd737
+  double d459 = f1 ();
4dd737
+  double d460 = f1 ();
4dd737
+  double d461 = f1 ();
4dd737
+  double d462 = f1 ();
4dd737
+  double d463 = f1 ();
4dd737
+  double d464 = f1 ();
4dd737
+  double d465 = f1 ();
4dd737
+  double d466 = f1 ();
4dd737
+  double d467 = f1 ();
4dd737
+  double d468 = f1 ();
4dd737
+  double d469 = f1 ();
4dd737
+  double d470 = f1 ();
4dd737
+  double d471 = f1 ();
4dd737
+  double d472 = f1 ();
4dd737
+  double d473 = f1 ();
4dd737
+  double d474 = f1 ();
4dd737
+  double d475 = f1 ();
4dd737
+  double d476 = f1 ();
4dd737
+  double d477 = f1 ();
4dd737
+  double d478 = f1 ();
4dd737
+  double d479 = f1 ();
4dd737
+  double d480 = f1 ();
4dd737
+  double d481 = f1 ();
4dd737
+  double d482 = f1 ();
4dd737
+  double d483 = f1 ();
4dd737
+  double d484 = f1 ();
4dd737
+  double d485 = f1 ();
4dd737
+  double d486 = f1 ();
4dd737
+  double d487 = f1 ();
4dd737
+  double d488 = f1 ();
4dd737
+  double d489 = f1 ();
4dd737
+  double d490 = f1 ();
4dd737
+  double d491 = f1 ();
4dd737
+  double d492 = f1 ();
4dd737
+  double d493 = f1 ();
4dd737
+  double d494 = f1 ();
4dd737
+  double d495 = f1 ();
4dd737
+  double d496 = f1 ();
4dd737
+  double d497 = f1 ();
4dd737
+  double d498 = f1 ();
4dd737
+  double d499 = f1 ();
4dd737
+  double d500 = f1 ();
4dd737
+  double d501 = f1 ();
4dd737
+  double d502 = f1 ();
4dd737
+  double d503 = f1 ();
4dd737
+  double d504 = f1 ();
4dd737
+  double d505 = f1 ();
4dd737
+  double d506 = f1 ();
4dd737
+  double d507 = f1 ();
4dd737
+  double d508 = f1 ();
4dd737
+  double d509 = f1 ();
4dd737
+  double d510 = f1 ();
4dd737
+  double d511 = f1 ();
4dd737
+  double d512 = f1 ();
4dd737
+  double d513 = f1 ();
4dd737
+  double d514 = f1 ();
4dd737
+  double d515 = f1 ();
4dd737
+  double d516 = f1 ();
4dd737
+  double d517 = f1 ();
4dd737
+  double d518 = f1 ();
4dd737
+  double d519 = f1 ();
4dd737
+  double d520 = f1 ();
4dd737
+  double d521 = f1 ();
4dd737
+  double d522 = f1 ();
4dd737
+  double d523 = f1 ();
4dd737
+  double d524 = f1 ();
4dd737
+  double d525 = f1 ();
4dd737
+  double d526 = f1 ();
4dd737
+  double d527 = f1 ();
4dd737
+  double d528 = f1 ();
4dd737
+  double d529 = f1 ();
4dd737
+  double d530 = f1 ();
4dd737
+  double d531 = f1 ();
4dd737
+  double d532 = f1 ();
4dd737
+  double d533 = f1 ();
4dd737
+  double d534 = f1 ();
4dd737
+  double d535 = f1 ();
4dd737
+  double d536 = f1 ();
4dd737
+  double d537 = f1 ();
4dd737
+  double d538 = f1 ();
4dd737
+  double d539 = f1 ();
4dd737
+  double d540 = f1 ();
4dd737
+  double d541 = f1 ();
4dd737
+  double d542 = f1 ();
4dd737
+  double d543 = f1 ();
4dd737
+  double d544 = f1 ();
4dd737
+  double d545 = f1 ();
4dd737
+  double d546 = f1 ();
4dd737
+  double d547 = f1 ();
4dd737
+  double d548 = f1 ();
4dd737
+  double d549 = f1 ();
4dd737
+  double d550 = f1 ();
4dd737
+  double d551 = f1 ();
4dd737
+  double d552 = f1 ();
4dd737
+  double d553 = f1 ();
4dd737
+  double d554 = f1 ();
4dd737
+  double d555 = f1 ();
4dd737
+  double d556 = f1 ();
4dd737
+  double d557 = f1 ();
4dd737
+  double d558 = f1 ();
4dd737
+  double d559 = f1 ();
4dd737
+  double d560 = f1 ();
4dd737
+  double d561 = f1 ();
4dd737
+  double d562 = f1 ();
4dd737
+  double d563 = f1 ();
4dd737
+  double d564 = f1 ();
4dd737
+  double d565 = f1 ();
4dd737
+  double d566 = f1 ();
4dd737
+  double d567 = f1 ();
4dd737
+  double d568 = f1 ();
4dd737
+  double d569 = f1 ();
4dd737
+  double d570 = f1 ();
4dd737
+  double d571 = f1 ();
4dd737
+  double d572 = f1 ();
4dd737
+  double d573 = f1 ();
4dd737
+  double d574 = f1 ();
4dd737
+  double d575 = f1 ();
4dd737
+  double d576 = f1 ();
4dd737
+  double d577 = f1 ();
4dd737
+  double d578 = f1 ();
4dd737
+  double d579 = f1 ();
4dd737
+  double d580 = f1 ();
4dd737
+  double d581 = f1 ();
4dd737
+  double d582 = f1 ();
4dd737
+  double d583 = f1 ();
4dd737
+  double d584 = f1 ();
4dd737
+  double d585 = f1 ();
4dd737
+  double d586 = f1 ();
4dd737
+  double d587 = f1 ();
4dd737
+  double d588 = f1 ();
4dd737
+  double d589 = f1 ();
4dd737
+  double d590 = f1 ();
4dd737
+  double d591 = f1 ();
4dd737
+  double d592 = f1 ();
4dd737
+  double d593 = f1 ();
4dd737
+  double d594 = f1 ();
4dd737
+  double d595 = f1 ();
4dd737
+  double d596 = f1 ();
4dd737
+  double d597 = f1 ();
4dd737
+  double d598 = f1 ();
4dd737
+  double d599 = f1 ();
4dd737
+  double d600 = f1 ();
4dd737
+  double d601 = f1 ();
4dd737
+  double d602 = f1 ();
4dd737
+  double d603 = f1 ();
4dd737
+  double d604 = f1 ();
4dd737
+  double d605 = f1 ();
4dd737
+  double d606 = f1 ();
4dd737
+  double d607 = f1 ();
4dd737
+  double d608 = f1 ();
4dd737
+  double d609 = f1 ();
4dd737
+  double d610 = f1 ();
4dd737
+  double d611 = f1 ();
4dd737
+  double d612 = f1 ();
4dd737
+  double d613 = f1 ();
4dd737
+  double d614 = f1 ();
4dd737
+  double d615 = f1 ();
4dd737
+  double d616 = f1 ();
4dd737
+  double d617 = f1 ();
4dd737
+  double d618 = f1 ();
4dd737
+  double d619 = f1 ();
4dd737
+  double d620 = f1 ();
4dd737
+  double d621 = f1 ();
4dd737
+  double d622 = f1 ();
4dd737
+  double d623 = f1 ();
4dd737
+  double d624 = f1 ();
4dd737
+  double d625 = f1 ();
4dd737
+  double d626 = f1 ();
4dd737
+  double d627 = f1 ();
4dd737
+  double d628 = f1 ();
4dd737
+  double d629 = f1 ();
4dd737
+  double d630 = f1 ();
4dd737
+  double d631 = f1 ();
4dd737
+  double d632 = f1 ();
4dd737
+  double d633 = f1 ();
4dd737
+  double d634 = f1 ();
4dd737
+  double d635 = f1 ();
4dd737
+  double d636 = f1 ();
4dd737
+  double d637 = f1 ();
4dd737
+  double d638 = f1 ();
4dd737
+  double d639 = f1 ();
4dd737
+  double d640 = f1 ();
4dd737
+  double d641 = f1 ();
4dd737
+  double d642 = f1 ();
4dd737
+  double d643 = f1 ();
4dd737
+  double d644 = f1 ();
4dd737
+  double d645 = f1 ();
4dd737
+  double d646 = f1 ();
4dd737
+  double d647 = f1 ();
4dd737
+  double d648 = f1 ();
4dd737
+  double d649 = f1 ();
4dd737
+  double d650 = f1 ();
4dd737
+  double d651 = f1 ();
4dd737
+  double d652 = f1 ();
4dd737
+  double d653 = f1 ();
4dd737
+  double d654 = f1 ();
4dd737
+  double d655 = f1 ();
4dd737
+  double d656 = f1 ();
4dd737
+  double d657 = f1 ();
4dd737
+  double d658 = f1 ();
4dd737
+  double d659 = f1 ();
4dd737
+  double d660 = f1 ();
4dd737
+  double d661 = f1 ();
4dd737
+  double d662 = f1 ();
4dd737
+  double d663 = f1 ();
4dd737
+  double d664 = f1 ();
4dd737
+  double d665 = f1 ();
4dd737
+  double d666 = f1 ();
4dd737
+  double d667 = f1 ();
4dd737
+  double d668 = f1 ();
4dd737
+  double d669 = f1 ();
4dd737
+  double d670 = f1 ();
4dd737
+  double d671 = f1 ();
4dd737
+  double d672 = f1 ();
4dd737
+  double d673 = f1 ();
4dd737
+  double d674 = f1 ();
4dd737
+  double d675 = f1 ();
4dd737
+  double d676 = f1 ();
4dd737
+  double d677 = f1 ();
4dd737
+  double d678 = f1 ();
4dd737
+  double d679 = f1 ();
4dd737
+  double d680 = f1 ();
4dd737
+  double d681 = f1 ();
4dd737
+  double d682 = f1 ();
4dd737
+  double d683 = f1 ();
4dd737
+  double d684 = f1 ();
4dd737
+  double d685 = f1 ();
4dd737
+  double d686 = f1 ();
4dd737
+  double d687 = f1 ();
4dd737
+  double d688 = f1 ();
4dd737
+  double d689 = f1 ();
4dd737
+  double d690 = f1 ();
4dd737
+  double d691 = f1 ();
4dd737
+  double d692 = f1 ();
4dd737
+  double d693 = f1 ();
4dd737
+  double d694 = f1 ();
4dd737
+  double d695 = f1 ();
4dd737
+  double d696 = f1 ();
4dd737
+  double d697 = f1 ();
4dd737
+  double d698 = f1 ();
4dd737
+  double d699 = f1 ();
4dd737
+  double d700 = f1 ();
4dd737
+  double d701 = f1 ();
4dd737
+  double d702 = f1 ();
4dd737
+  double d703 = f1 ();
4dd737
+  double d704 = f1 ();
4dd737
+  double d705 = f1 ();
4dd737
+  double d706 = f1 ();
4dd737
+  double d707 = f1 ();
4dd737
+  double d708 = f1 ();
4dd737
+  double d709 = f1 ();
4dd737
+  double d710 = f1 ();
4dd737
+  double d711 = f1 ();
4dd737
+  double d712 = f1 ();
4dd737
+  double d713 = f1 ();
4dd737
+  double d714 = f1 ();
4dd737
+  double d715 = f1 ();
4dd737
+  double d716 = f1 ();
4dd737
+  double d717 = f1 ();
4dd737
+  double d718 = f1 ();
4dd737
+  double d719 = f1 ();
4dd737
+  double d720 = f1 ();
4dd737
+  double d721 = f1 ();
4dd737
+  double d722 = f1 ();
4dd737
+  double d723 = f1 ();
4dd737
+  double d724 = f1 ();
4dd737
+  double d725 = f1 ();
4dd737
+  double d726 = f1 ();
4dd737
+  double d727 = f1 ();
4dd737
+  double d728 = f1 ();
4dd737
+  double d729 = f1 ();
4dd737
+  double d730 = f1 ();
4dd737
+  double d731 = f1 ();
4dd737
+  double d732 = f1 ();
4dd737
+  double d733 = f1 ();
4dd737
+  double d734 = f1 ();
4dd737
+  double d735 = f1 ();
4dd737
+  double d736 = f1 ();
4dd737
+  double d737 = f1 ();
4dd737
+  double d738 = f1 ();
4dd737
+  double d739 = f1 ();
4dd737
+  double d740 = f1 ();
4dd737
+  double d741 = f1 ();
4dd737
+  double d742 = f1 ();
4dd737
+  double d743 = f1 ();
4dd737
+  double d744 = f1 ();
4dd737
+  double d745 = f1 ();
4dd737
+  double d746 = f1 ();
4dd737
+  double d747 = f1 ();
4dd737
+  double d748 = f1 ();
4dd737
+  double d749 = f1 ();
4dd737
+  double d750 = f1 ();
4dd737
+  double d751 = f1 ();
4dd737
+  double d752 = f1 ();
4dd737
+  double d753 = f1 ();
4dd737
+  double d754 = f1 ();
4dd737
+  double d755 = f1 ();
4dd737
+  double d756 = f1 ();
4dd737
+  double d757 = f1 ();
4dd737
+  double d758 = f1 ();
4dd737
+  double d759 = f1 ();
4dd737
+  double d760 = f1 ();
4dd737
+  double d761 = f1 ();
4dd737
+  double d762 = f1 ();
4dd737
+  double d763 = f1 ();
4dd737
+  double d764 = f1 ();
4dd737
+  double d765 = f1 ();
4dd737
+  double d766 = f1 ();
4dd737
+  double d767 = f1 ();
4dd737
+  double d768 = f1 ();
4dd737
+  double d769 = f1 ();
4dd737
+  double d770 = f1 ();
4dd737
+  double d771 = f1 ();
4dd737
+  double d772 = f1 ();
4dd737
+  double d773 = f1 ();
4dd737
+  double d774 = f1 ();
4dd737
+  double d775 = f1 ();
4dd737
+  double d776 = f1 ();
4dd737
+  double d777 = f1 ();
4dd737
+  double d778 = f1 ();
4dd737
+  double d779 = f1 ();
4dd737
+  double d780 = f1 ();
4dd737
+  double d781 = f1 ();
4dd737
+  double d782 = f1 ();
4dd737
+  double d783 = f1 ();
4dd737
+  double d784 = f1 ();
4dd737
+  double d785 = f1 ();
4dd737
+  double d786 = f1 ();
4dd737
+  double d787 = f1 ();
4dd737
+  double d788 = f1 ();
4dd737
+  double d789 = f1 ();
4dd737
+  double d790 = f1 ();
4dd737
+  double d791 = f1 ();
4dd737
+  double d792 = f1 ();
4dd737
+  double d793 = f1 ();
4dd737
+  double d794 = f1 ();
4dd737
+  double d795 = f1 ();
4dd737
+  double d796 = f1 ();
4dd737
+  double d797 = f1 ();
4dd737
+  double d798 = f1 ();
4dd737
+  double d799 = f1 ();
4dd737
+  double d800 = f1 ();
4dd737
+  double d801 = f1 ();
4dd737
+  double d802 = f1 ();
4dd737
+  double d803 = f1 ();
4dd737
+  double d804 = f1 ();
4dd737
+  double d805 = f1 ();
4dd737
+  double d806 = f1 ();
4dd737
+  double d807 = f1 ();
4dd737
+  double d808 = f1 ();
4dd737
+  double d809 = f1 ();
4dd737
+  double d810 = f1 ();
4dd737
+  double d811 = f1 ();
4dd737
+  double d812 = f1 ();
4dd737
+  double d813 = f1 ();
4dd737
+  double d814 = f1 ();
4dd737
+  double d815 = f1 ();
4dd737
+  double d816 = f1 ();
4dd737
+  double d817 = f1 ();
4dd737
+  double d818 = f1 ();
4dd737
+  double d819 = f1 ();
4dd737
+  double d820 = f1 ();
4dd737
+  double d821 = f1 ();
4dd737
+  double d822 = f1 ();
4dd737
+  double d823 = f1 ();
4dd737
+  double d824 = f1 ();
4dd737
+  double d825 = f1 ();
4dd737
+  double d826 = f1 ();
4dd737
+  double d827 = f1 ();
4dd737
+  double d828 = f1 ();
4dd737
+  double d829 = f1 ();
4dd737
+  double d830 = f1 ();
4dd737
+  double d831 = f1 ();
4dd737
+  double d832 = f1 ();
4dd737
+  double d833 = f1 ();
4dd737
+  double d834 = f1 ();
4dd737
+  double d835 = f1 ();
4dd737
+  double d836 = f1 ();
4dd737
+  double d837 = f1 ();
4dd737
+  double d838 = f1 ();
4dd737
+  double d839 = f1 ();
4dd737
+  double d840 = f1 ();
4dd737
+  double d841 = f1 ();
4dd737
+  double d842 = f1 ();
4dd737
+  double d843 = f1 ();
4dd737
+  double d844 = f1 ();
4dd737
+  double d845 = f1 ();
4dd737
+  double d846 = f1 ();
4dd737
+  double d847 = f1 ();
4dd737
+  double d848 = f1 ();
4dd737
+  double d849 = f1 ();
4dd737
+  double d850 = f1 ();
4dd737
+  double d851 = f1 ();
4dd737
+  double d852 = f1 ();
4dd737
+  double d853 = f1 ();
4dd737
+  double d854 = f1 ();
4dd737
+  double d855 = f1 ();
4dd737
+  double d856 = f1 ();
4dd737
+  double d857 = f1 ();
4dd737
+  double d858 = f1 ();
4dd737
+  double d859 = f1 ();
4dd737
+  double d860 = f1 ();
4dd737
+  double d861 = f1 ();
4dd737
+  double d862 = f1 ();
4dd737
+  double d863 = f1 ();
4dd737
+  double d864 = f1 ();
4dd737
+  double d865 = f1 ();
4dd737
+  double d866 = f1 ();
4dd737
+  double d867 = f1 ();
4dd737
+  double d868 = f1 ();
4dd737
+  double d869 = f1 ();
4dd737
+  double d870 = f1 ();
4dd737
+  double d871 = f1 ();
4dd737
+  double d872 = f1 ();
4dd737
+  double d873 = f1 ();
4dd737
+  double d874 = f1 ();
4dd737
+  double d875 = f1 ();
4dd737
+  double d876 = f1 ();
4dd737
+  double d877 = f1 ();
4dd737
+  double d878 = f1 ();
4dd737
+  double d879 = f1 ();
4dd737
+  double d880 = f1 ();
4dd737
+  double d881 = f1 ();
4dd737
+  double d882 = f1 ();
4dd737
+  double d883 = f1 ();
4dd737
+  double d884 = f1 ();
4dd737
+  double d885 = f1 ();
4dd737
+  double d886 = f1 ();
4dd737
+  double d887 = f1 ();
4dd737
+  double d888 = f1 ();
4dd737
+  double d889 = f1 ();
4dd737
+  double d890 = f1 ();
4dd737
+  double d891 = f1 ();
4dd737
+  double d892 = f1 ();
4dd737
+  double d893 = f1 ();
4dd737
+  double d894 = f1 ();
4dd737
+  double d895 = f1 ();
4dd737
+  double d896 = f1 ();
4dd737
+  double d897 = f1 ();
4dd737
+  double d898 = f1 ();
4dd737
+  double d899 = f1 ();
4dd737
+  double d900 = f1 ();
4dd737
+  double d901 = f1 ();
4dd737
+  double d902 = f1 ();
4dd737
+  double d903 = f1 ();
4dd737
+  double d904 = f1 ();
4dd737
+  double d905 = f1 ();
4dd737
+  double d906 = f1 ();
4dd737
+  double d907 = f1 ();
4dd737
+  double d908 = f1 ();
4dd737
+  double d909 = f1 ();
4dd737
+  double d910 = f1 ();
4dd737
+  double d911 = f1 ();
4dd737
+  double d912 = f1 ();
4dd737
+  double d913 = f1 ();
4dd737
+  double d914 = f1 ();
4dd737
+  double d915 = f1 ();
4dd737
+  double d916 = f1 ();
4dd737
+  double d917 = f1 ();
4dd737
+  double d918 = f1 ();
4dd737
+  double d919 = f1 ();
4dd737
+  double d920 = f1 ();
4dd737
+  double d921 = f1 ();
4dd737
+  double d922 = f1 ();
4dd737
+  double d923 = f1 ();
4dd737
+  double d924 = f1 ();
4dd737
+  double d925 = f1 ();
4dd737
+  double d926 = f1 ();
4dd737
+  double d927 = f1 ();
4dd737
+  double d928 = f1 ();
4dd737
+  double d929 = f1 ();
4dd737
+  double d930 = f1 ();
4dd737
+  double d931 = f1 ();
4dd737
+  double d932 = f1 ();
4dd737
+  double d933 = f1 ();
4dd737
+  double d934 = f1 ();
4dd737
+  double d935 = f1 ();
4dd737
+  double d936 = f1 ();
4dd737
+  double d937 = f1 ();
4dd737
+  double d938 = f1 ();
4dd737
+  double d939 = f1 ();
4dd737
+  double d940 = f1 ();
4dd737
+  double d941 = f1 ();
4dd737
+  double d942 = f1 ();
4dd737
+  double d943 = f1 ();
4dd737
+  double d944 = f1 ();
4dd737
+  double d945 = f1 ();
4dd737
+  double d946 = f1 ();
4dd737
+  double d947 = f1 ();
4dd737
+  double d948 = f1 ();
4dd737
+  double d949 = f1 ();
4dd737
+  double d950 = f1 ();
4dd737
+  double d951 = f1 ();
4dd737
+  double d952 = f1 ();
4dd737
+  double d953 = f1 ();
4dd737
+  double d954 = f1 ();
4dd737
+  double d955 = f1 ();
4dd737
+  double d956 = f1 ();
4dd737
+  double d957 = f1 ();
4dd737
+  double d958 = f1 ();
4dd737
+  double d959 = f1 ();
4dd737
+  double d960 = f1 ();
4dd737
+  double d961 = f1 ();
4dd737
+  double d962 = f1 ();
4dd737
+  double d963 = f1 ();
4dd737
+  double d964 = f1 ();
4dd737
+  double d965 = f1 ();
4dd737
+  double d966 = f1 ();
4dd737
+  double d967 = f1 ();
4dd737
+  double d968 = f1 ();
4dd737
+  double d969 = f1 ();
4dd737
+  double d970 = f1 ();
4dd737
+  double d971 = f1 ();
4dd737
+  double d972 = f1 ();
4dd737
+  double d973 = f1 ();
4dd737
+  double d974 = f1 ();
4dd737
+  double d975 = f1 ();
4dd737
+  double d976 = f1 ();
4dd737
+  double d977 = f1 ();
4dd737
+  double d978 = f1 ();
4dd737
+  double d979 = f1 ();
4dd737
+  double d980 = f1 ();
4dd737
+  double d981 = f1 ();
4dd737
+  double d982 = f1 ();
4dd737
+  double d983 = f1 ();
4dd737
+  double d984 = f1 ();
4dd737
+  double d985 = f1 ();
4dd737
+  double d986 = f1 ();
4dd737
+  double d987 = f1 ();
4dd737
+  double d988 = f1 ();
4dd737
+  double d989 = f1 ();
4dd737
+  double d990 = f1 ();
4dd737
+  double d991 = f1 ();
4dd737
+  double d992 = f1 ();
4dd737
+  double d993 = f1 ();
4dd737
+  double d994 = f1 ();
4dd737
+  double d995 = f1 ();
4dd737
+  double d996 = f1 ();
4dd737
+  double d997 = f1 ();
4dd737
+  double d998 = f1 ();
4dd737
+  double d999 = f1 ();
4dd737
+
4dd737
+  double x = 0;
4dd737
+  x = f2 (x, d000);
4dd737
+  x = f2 (x, d001);
4dd737
+  x = f2 (x, d002);
4dd737
+  x = f2 (x, d003);
4dd737
+  x = f2 (x, d004);
4dd737
+  x = f2 (x, d005);
4dd737
+  x = f2 (x, d006);
4dd737
+  x = f2 (x, d007);
4dd737
+  x = f2 (x, d008);
4dd737
+  x = f2 (x, d009);
4dd737
+  x = f2 (x, d010);
4dd737
+  x = f2 (x, d011);
4dd737
+  x = f2 (x, d012);
4dd737
+  x = f2 (x, d013);
4dd737
+  x = f2 (x, d014);
4dd737
+  x = f2 (x, d015);
4dd737
+  x = f2 (x, d016);
4dd737
+  x = f2 (x, d017);
4dd737
+  x = f2 (x, d018);
4dd737
+  x = f2 (x, d019);
4dd737
+  x = f2 (x, d020);
4dd737
+  x = f2 (x, d021);
4dd737
+  x = f2 (x, d022);
4dd737
+  x = f2 (x, d023);
4dd737
+  x = f2 (x, d024);
4dd737
+  x = f2 (x, d025);
4dd737
+  x = f2 (x, d026);
4dd737
+  x = f2 (x, d027);
4dd737
+  x = f2 (x, d028);
4dd737
+  x = f2 (x, d029);
4dd737
+  x = f2 (x, d030);
4dd737
+  x = f2 (x, d031);
4dd737
+  x = f2 (x, d032);
4dd737
+  x = f2 (x, d033);
4dd737
+  x = f2 (x, d034);
4dd737
+  x = f2 (x, d035);
4dd737
+  x = f2 (x, d036);
4dd737
+  x = f2 (x, d037);
4dd737
+  x = f2 (x, d038);
4dd737
+  x = f2 (x, d039);
4dd737
+  x = f2 (x, d040);
4dd737
+  x = f2 (x, d041);
4dd737
+  x = f2 (x, d042);
4dd737
+  x = f2 (x, d043);
4dd737
+  x = f2 (x, d044);
4dd737
+  x = f2 (x, d045);
4dd737
+  x = f2 (x, d046);
4dd737
+  x = f2 (x, d047);
4dd737
+  x = f2 (x, d048);
4dd737
+  x = f2 (x, d049);
4dd737
+  x = f2 (x, d050);
4dd737
+  x = f2 (x, d051);
4dd737
+  x = f2 (x, d052);
4dd737
+  x = f2 (x, d053);
4dd737
+  x = f2 (x, d054);
4dd737
+  x = f2 (x, d055);
4dd737
+  x = f2 (x, d056);
4dd737
+  x = f2 (x, d057);
4dd737
+  x = f2 (x, d058);
4dd737
+  x = f2 (x, d059);
4dd737
+  x = f2 (x, d060);
4dd737
+  x = f2 (x, d061);
4dd737
+  x = f2 (x, d062);
4dd737
+  x = f2 (x, d063);
4dd737
+  x = f2 (x, d064);
4dd737
+  x = f2 (x, d065);
4dd737
+  x = f2 (x, d066);
4dd737
+  x = f2 (x, d067);
4dd737
+  x = f2 (x, d068);
4dd737
+  x = f2 (x, d069);
4dd737
+  x = f2 (x, d070);
4dd737
+  x = f2 (x, d071);
4dd737
+  x = f2 (x, d072);
4dd737
+  x = f2 (x, d073);
4dd737
+  x = f2 (x, d074);
4dd737
+  x = f2 (x, d075);
4dd737
+  x = f2 (x, d076);
4dd737
+  x = f2 (x, d077);
4dd737
+  x = f2 (x, d078);
4dd737
+  x = f2 (x, d079);
4dd737
+  x = f2 (x, d080);
4dd737
+  x = f2 (x, d081);
4dd737
+  x = f2 (x, d082);
4dd737
+  x = f2 (x, d083);
4dd737
+  x = f2 (x, d084);
4dd737
+  x = f2 (x, d085);
4dd737
+  x = f2 (x, d086);
4dd737
+  x = f2 (x, d087);
4dd737
+  x = f2 (x, d088);
4dd737
+  x = f2 (x, d089);
4dd737
+  x = f2 (x, d090);
4dd737
+  x = f2 (x, d091);
4dd737
+  x = f2 (x, d092);
4dd737
+  x = f2 (x, d093);
4dd737
+  x = f2 (x, d094);
4dd737
+  x = f2 (x, d095);
4dd737
+  x = f2 (x, d096);
4dd737
+  x = f2 (x, d097);
4dd737
+  x = f2 (x, d098);
4dd737
+  x = f2 (x, d099);
4dd737
+  x = f2 (x, d100);
4dd737
+  x = f2 (x, d101);
4dd737
+  x = f2 (x, d102);
4dd737
+  x = f2 (x, d103);
4dd737
+  x = f2 (x, d104);
4dd737
+  x = f2 (x, d105);
4dd737
+  x = f2 (x, d106);
4dd737
+  x = f2 (x, d107);
4dd737
+  x = f2 (x, d108);
4dd737
+  x = f2 (x, d109);
4dd737
+  x = f2 (x, d110);
4dd737
+  x = f2 (x, d111);
4dd737
+  x = f2 (x, d112);
4dd737
+  x = f2 (x, d113);
4dd737
+  x = f2 (x, d114);
4dd737
+  x = f2 (x, d115);
4dd737
+  x = f2 (x, d116);
4dd737
+  x = f2 (x, d117);
4dd737
+  x = f2 (x, d118);
4dd737
+  x = f2 (x, d119);
4dd737
+  x = f2 (x, d120);
4dd737
+  x = f2 (x, d121);
4dd737
+  x = f2 (x, d122);
4dd737
+  x = f2 (x, d123);
4dd737
+  x = f2 (x, d124);
4dd737
+  x = f2 (x, d125);
4dd737
+  x = f2 (x, d126);
4dd737
+  x = f2 (x, d127);
4dd737
+  x = f2 (x, d128);
4dd737
+  x = f2 (x, d129);
4dd737
+  x = f2 (x, d130);
4dd737
+  x = f2 (x, d131);
4dd737
+  x = f2 (x, d132);
4dd737
+  x = f2 (x, d133);
4dd737
+  x = f2 (x, d134);
4dd737
+  x = f2 (x, d135);
4dd737
+  x = f2 (x, d136);
4dd737
+  x = f2 (x, d137);
4dd737
+  x = f2 (x, d138);
4dd737
+  x = f2 (x, d139);
4dd737
+  x = f2 (x, d140);
4dd737
+  x = f2 (x, d141);
4dd737
+  x = f2 (x, d142);
4dd737
+  x = f2 (x, d143);
4dd737
+  x = f2 (x, d144);
4dd737
+  x = f2 (x, d145);
4dd737
+  x = f2 (x, d146);
4dd737
+  x = f2 (x, d147);
4dd737
+  x = f2 (x, d148);
4dd737
+  x = f2 (x, d149);
4dd737
+  x = f2 (x, d150);
4dd737
+  x = f2 (x, d151);
4dd737
+  x = f2 (x, d152);
4dd737
+  x = f2 (x, d153);
4dd737
+  x = f2 (x, d154);
4dd737
+  x = f2 (x, d155);
4dd737
+  x = f2 (x, d156);
4dd737
+  x = f2 (x, d157);
4dd737
+  x = f2 (x, d158);
4dd737
+  x = f2 (x, d159);
4dd737
+  x = f2 (x, d160);
4dd737
+  x = f2 (x, d161);
4dd737
+  x = f2 (x, d162);
4dd737
+  x = f2 (x, d163);
4dd737
+  x = f2 (x, d164);
4dd737
+  x = f2 (x, d165);
4dd737
+  x = f2 (x, d166);
4dd737
+  x = f2 (x, d167);
4dd737
+  x = f2 (x, d168);
4dd737
+  x = f2 (x, d169);
4dd737
+  x = f2 (x, d170);
4dd737
+  x = f2 (x, d171);
4dd737
+  x = f2 (x, d172);
4dd737
+  x = f2 (x, d173);
4dd737
+  x = f2 (x, d174);
4dd737
+  x = f2 (x, d175);
4dd737
+  x = f2 (x, d176);
4dd737
+  x = f2 (x, d177);
4dd737
+  x = f2 (x, d178);
4dd737
+  x = f2 (x, d179);
4dd737
+  x = f2 (x, d180);
4dd737
+  x = f2 (x, d181);
4dd737
+  x = f2 (x, d182);
4dd737
+  x = f2 (x, d183);
4dd737
+  x = f2 (x, d184);
4dd737
+  x = f2 (x, d185);
4dd737
+  x = f2 (x, d186);
4dd737
+  x = f2 (x, d187);
4dd737
+  x = f2 (x, d188);
4dd737
+  x = f2 (x, d189);
4dd737
+  x = f2 (x, d190);
4dd737
+  x = f2 (x, d191);
4dd737
+  x = f2 (x, d192);
4dd737
+  x = f2 (x, d193);
4dd737
+  x = f2 (x, d194);
4dd737
+  x = f2 (x, d195);
4dd737
+  x = f2 (x, d196);
4dd737
+  x = f2 (x, d197);
4dd737
+  x = f2 (x, d198);
4dd737
+  x = f2 (x, d199);
4dd737
+  x = f2 (x, d200);
4dd737
+  x = f2 (x, d201);
4dd737
+  x = f2 (x, d202);
4dd737
+  x = f2 (x, d203);
4dd737
+  x = f2 (x, d204);
4dd737
+  x = f2 (x, d205);
4dd737
+  x = f2 (x, d206);
4dd737
+  x = f2 (x, d207);
4dd737
+  x = f2 (x, d208);
4dd737
+  x = f2 (x, d209);
4dd737
+  x = f2 (x, d210);
4dd737
+  x = f2 (x, d211);
4dd737
+  x = f2 (x, d212);
4dd737
+  x = f2 (x, d213);
4dd737
+  x = f2 (x, d214);
4dd737
+  x = f2 (x, d215);
4dd737
+  x = f2 (x, d216);
4dd737
+  x = f2 (x, d217);
4dd737
+  x = f2 (x, d218);
4dd737
+  x = f2 (x, d219);
4dd737
+  x = f2 (x, d220);
4dd737
+  x = f2 (x, d221);
4dd737
+  x = f2 (x, d222);
4dd737
+  x = f2 (x, d223);
4dd737
+  x = f2 (x, d224);
4dd737
+  x = f2 (x, d225);
4dd737
+  x = f2 (x, d226);
4dd737
+  x = f2 (x, d227);
4dd737
+  x = f2 (x, d228);
4dd737
+  x = f2 (x, d229);
4dd737
+  x = f2 (x, d230);
4dd737
+  x = f2 (x, d231);
4dd737
+  x = f2 (x, d232);
4dd737
+  x = f2 (x, d233);
4dd737
+  x = f2 (x, d234);
4dd737
+  x = f2 (x, d235);
4dd737
+  x = f2 (x, d236);
4dd737
+  x = f2 (x, d237);
4dd737
+  x = f2 (x, d238);
4dd737
+  x = f2 (x, d239);
4dd737
+  x = f2 (x, d240);
4dd737
+  x = f2 (x, d241);
4dd737
+  x = f2 (x, d242);
4dd737
+  x = f2 (x, d243);
4dd737
+  x = f2 (x, d244);
4dd737
+  x = f2 (x, d245);
4dd737
+  x = f2 (x, d246);
4dd737
+  x = f2 (x, d247);
4dd737
+  x = f2 (x, d248);
4dd737
+  x = f2 (x, d249);
4dd737
+  x = f2 (x, d250);
4dd737
+  x = f2 (x, d251);
4dd737
+  x = f2 (x, d252);
4dd737
+  x = f2 (x, d253);
4dd737
+  x = f2 (x, d254);
4dd737
+  x = f2 (x, d255);
4dd737
+  x = f2 (x, d256);
4dd737
+  x = f2 (x, d257);
4dd737
+  x = f2 (x, d258);
4dd737
+  x = f2 (x, d259);
4dd737
+  x = f2 (x, d260);
4dd737
+  x = f2 (x, d261);
4dd737
+  x = f2 (x, d262);
4dd737
+  x = f2 (x, d263);
4dd737
+  x = f2 (x, d264);
4dd737
+  x = f2 (x, d265);
4dd737
+  x = f2 (x, d266);
4dd737
+  x = f2 (x, d267);
4dd737
+  x = f2 (x, d268);
4dd737
+  x = f2 (x, d269);
4dd737
+  x = f2 (x, d270);
4dd737
+  x = f2 (x, d271);
4dd737
+  x = f2 (x, d272);
4dd737
+  x = f2 (x, d273);
4dd737
+  x = f2 (x, d274);
4dd737
+  x = f2 (x, d275);
4dd737
+  x = f2 (x, d276);
4dd737
+  x = f2 (x, d277);
4dd737
+  x = f2 (x, d278);
4dd737
+  x = f2 (x, d279);
4dd737
+  x = f2 (x, d280);
4dd737
+  x = f2 (x, d281);
4dd737
+  x = f2 (x, d282);
4dd737
+  x = f2 (x, d283);
4dd737
+  x = f2 (x, d284);
4dd737
+  x = f2 (x, d285);
4dd737
+  x = f2 (x, d286);
4dd737
+  x = f2 (x, d287);
4dd737
+  x = f2 (x, d288);
4dd737
+  x = f2 (x, d289);
4dd737
+  x = f2 (x, d290);
4dd737
+  x = f2 (x, d291);
4dd737
+  x = f2 (x, d292);
4dd737
+  x = f2 (x, d293);
4dd737
+  x = f2 (x, d294);
4dd737
+  x = f2 (x, d295);
4dd737
+  x = f2 (x, d296);
4dd737
+  x = f2 (x, d297);
4dd737
+  x = f2 (x, d298);
4dd737
+  x = f2 (x, d299);
4dd737
+  x = f2 (x, d300);
4dd737
+  x = f2 (x, d301);
4dd737
+  x = f2 (x, d302);
4dd737
+  x = f2 (x, d303);
4dd737
+  x = f2 (x, d304);
4dd737
+  x = f2 (x, d305);
4dd737
+  x = f2 (x, d306);
4dd737
+  x = f2 (x, d307);
4dd737
+  x = f2 (x, d308);
4dd737
+  x = f2 (x, d309);
4dd737
+  x = f2 (x, d310);
4dd737
+  x = f2 (x, d311);
4dd737
+  x = f2 (x, d312);
4dd737
+  x = f2 (x, d313);
4dd737
+  x = f2 (x, d314);
4dd737
+  x = f2 (x, d315);
4dd737
+  x = f2 (x, d316);
4dd737
+  x = f2 (x, d317);
4dd737
+  x = f2 (x, d318);
4dd737
+  x = f2 (x, d319);
4dd737
+  x = f2 (x, d320);
4dd737
+  x = f2 (x, d321);
4dd737
+  x = f2 (x, d322);
4dd737
+  x = f2 (x, d323);
4dd737
+  x = f2 (x, d324);
4dd737
+  x = f2 (x, d325);
4dd737
+  x = f2 (x, d326);
4dd737
+  x = f2 (x, d327);
4dd737
+  x = f2 (x, d328);
4dd737
+  x = f2 (x, d329);
4dd737
+  x = f2 (x, d330);
4dd737
+  x = f2 (x, d331);
4dd737
+  x = f2 (x, d332);
4dd737
+  x = f2 (x, d333);
4dd737
+  x = f2 (x, d334);
4dd737
+  x = f2 (x, d335);
4dd737
+  x = f2 (x, d336);
4dd737
+  x = f2 (x, d337);
4dd737
+  x = f2 (x, d338);
4dd737
+  x = f2 (x, d339);
4dd737
+  x = f2 (x, d340);
4dd737
+  x = f2 (x, d341);
4dd737
+  x = f2 (x, d342);
4dd737
+  x = f2 (x, d343);
4dd737
+  x = f2 (x, d344);
4dd737
+  x = f2 (x, d345);
4dd737
+  x = f2 (x, d346);
4dd737
+  x = f2 (x, d347);
4dd737
+  x = f2 (x, d348);
4dd737
+  x = f2 (x, d349);
4dd737
+  x = f2 (x, d350);
4dd737
+  x = f2 (x, d351);
4dd737
+  x = f2 (x, d352);
4dd737
+  x = f2 (x, d353);
4dd737
+  x = f2 (x, d354);
4dd737
+  x = f2 (x, d355);
4dd737
+  x = f2 (x, d356);
4dd737
+  x = f2 (x, d357);
4dd737
+  x = f2 (x, d358);
4dd737
+  x = f2 (x, d359);
4dd737
+  x = f2 (x, d360);
4dd737
+  x = f2 (x, d361);
4dd737
+  x = f2 (x, d362);
4dd737
+  x = f2 (x, d363);
4dd737
+  x = f2 (x, d364);
4dd737
+  x = f2 (x, d365);
4dd737
+  x = f2 (x, d366);
4dd737
+  x = f2 (x, d367);
4dd737
+  x = f2 (x, d368);
4dd737
+  x = f2 (x, d369);
4dd737
+  x = f2 (x, d370);
4dd737
+  x = f2 (x, d371);
4dd737
+  x = f2 (x, d372);
4dd737
+  x = f2 (x, d373);
4dd737
+  x = f2 (x, d374);
4dd737
+  x = f2 (x, d375);
4dd737
+  x = f2 (x, d376);
4dd737
+  x = f2 (x, d377);
4dd737
+  x = f2 (x, d378);
4dd737
+  x = f2 (x, d379);
4dd737
+  x = f2 (x, d380);
4dd737
+  x = f2 (x, d381);
4dd737
+  x = f2 (x, d382);
4dd737
+  x = f2 (x, d383);
4dd737
+  x = f2 (x, d384);
4dd737
+  x = f2 (x, d385);
4dd737
+  x = f2 (x, d386);
4dd737
+  x = f2 (x, d387);
4dd737
+  x = f2 (x, d388);
4dd737
+  x = f2 (x, d389);
4dd737
+  x = f2 (x, d390);
4dd737
+  x = f2 (x, d391);
4dd737
+  x = f2 (x, d392);
4dd737
+  x = f2 (x, d393);
4dd737
+  x = f2 (x, d394);
4dd737
+  x = f2 (x, d395);
4dd737
+  x = f2 (x, d396);
4dd737
+  x = f2 (x, d397);
4dd737
+  x = f2 (x, d398);
4dd737
+  x = f2 (x, d399);
4dd737
+  x = f2 (x, d400);
4dd737
+  x = f2 (x, d401);
4dd737
+  x = f2 (x, d402);
4dd737
+  x = f2 (x, d403);
4dd737
+  x = f2 (x, d404);
4dd737
+  x = f2 (x, d405);
4dd737
+  x = f2 (x, d406);
4dd737
+  x = f2 (x, d407);
4dd737
+  x = f2 (x, d408);
4dd737
+  x = f2 (x, d409);
4dd737
+  x = f2 (x, d410);
4dd737
+  x = f2 (x, d411);
4dd737
+  x = f2 (x, d412);
4dd737
+  x = f2 (x, d413);
4dd737
+  x = f2 (x, d414);
4dd737
+  x = f2 (x, d415);
4dd737
+  x = f2 (x, d416);
4dd737
+  x = f2 (x, d417);
4dd737
+  x = f2 (x, d418);
4dd737
+  x = f2 (x, d419);
4dd737
+  x = f2 (x, d420);
4dd737
+  x = f2 (x, d421);
4dd737
+  x = f2 (x, d422);
4dd737
+  x = f2 (x, d423);
4dd737
+  x = f2 (x, d424);
4dd737
+  x = f2 (x, d425);
4dd737
+  x = f2 (x, d426);
4dd737
+  x = f2 (x, d427);
4dd737
+  x = f2 (x, d428);
4dd737
+  x = f2 (x, d429);
4dd737
+  x = f2 (x, d430);
4dd737
+  x = f2 (x, d431);
4dd737
+  x = f2 (x, d432);
4dd737
+  x = f2 (x, d433);
4dd737
+  x = f2 (x, d434);
4dd737
+  x = f2 (x, d435);
4dd737
+  x = f2 (x, d436);
4dd737
+  x = f2 (x, d437);
4dd737
+  x = f2 (x, d438);
4dd737
+  x = f2 (x, d439);
4dd737
+  x = f2 (x, d440);
4dd737
+  x = f2 (x, d441);
4dd737
+  x = f2 (x, d442);
4dd737
+  x = f2 (x, d443);
4dd737
+  x = f2 (x, d444);
4dd737
+  x = f2 (x, d445);
4dd737
+  x = f2 (x, d446);
4dd737
+  x = f2 (x, d447);
4dd737
+  x = f2 (x, d448);
4dd737
+  x = f2 (x, d449);
4dd737
+  x = f2 (x, d450);
4dd737
+  x = f2 (x, d451);
4dd737
+  x = f2 (x, d452);
4dd737
+  x = f2 (x, d453);
4dd737
+  x = f2 (x, d454);
4dd737
+  x = f2 (x, d455);
4dd737
+  x = f2 (x, d456);
4dd737
+  x = f2 (x, d457);
4dd737
+  x = f2 (x, d458);
4dd737
+  x = f2 (x, d459);
4dd737
+  x = f2 (x, d460);
4dd737
+  x = f2 (x, d461);
4dd737
+  x = f2 (x, d462);
4dd737
+  x = f2 (x, d463);
4dd737
+  x = f2 (x, d464);
4dd737
+  x = f2 (x, d465);
4dd737
+  x = f2 (x, d466);
4dd737
+  x = f2 (x, d467);
4dd737
+  x = f2 (x, d468);
4dd737
+  x = f2 (x, d469);
4dd737
+  x = f2 (x, d470);
4dd737
+  x = f2 (x, d471);
4dd737
+  x = f2 (x, d472);
4dd737
+  x = f2 (x, d473);
4dd737
+  x = f2 (x, d474);
4dd737
+  x = f2 (x, d475);
4dd737
+  x = f2 (x, d476);
4dd737
+  x = f2 (x, d477);
4dd737
+  x = f2 (x, d478);
4dd737
+  x = f2 (x, d479);
4dd737
+  x = f2 (x, d480);
4dd737
+  x = f2 (x, d481);
4dd737
+  x = f2 (x, d482);
4dd737
+  x = f2 (x, d483);
4dd737
+  x = f2 (x, d484);
4dd737
+  x = f2 (x, d485);
4dd737
+  x = f2 (x, d486);
4dd737
+  x = f2 (x, d487);
4dd737
+  x = f2 (x, d488);
4dd737
+  x = f2 (x, d489);
4dd737
+  x = f2 (x, d490);
4dd737
+  x = f2 (x, d491);
4dd737
+  x = f2 (x, d492);
4dd737
+  x = f2 (x, d493);
4dd737
+  x = f2 (x, d494);
4dd737
+  x = f2 (x, d495);
4dd737
+  x = f2 (x, d496);
4dd737
+  x = f2 (x, d497);
4dd737
+  x = f2 (x, d498);
4dd737
+  x = f2 (x, d499);
4dd737
+  x = f2 (x, d500);
4dd737
+  x = f2 (x, d501);
4dd737
+  x = f2 (x, d502);
4dd737
+  x = f2 (x, d503);
4dd737
+  x = f2 (x, d504);
4dd737
+  x = f2 (x, d505);
4dd737
+  x = f2 (x, d506);
4dd737
+  x = f2 (x, d507);
4dd737
+  x = f2 (x, d508);
4dd737
+  x = f2 (x, d509);
4dd737
+  x = f2 (x, d510);
4dd737
+  x = f2 (x, d511);
4dd737
+  x = f2 (x, d512);
4dd737
+  x = f2 (x, d513);
4dd737
+  x = f2 (x, d514);
4dd737
+  x = f2 (x, d515);
4dd737
+  x = f2 (x, d516);
4dd737
+  x = f2 (x, d517);
4dd737
+  x = f2 (x, d518);
4dd737
+  x = f2 (x, d519);
4dd737
+  x = f2 (x, d520);
4dd737
+  x = f2 (x, d521);
4dd737
+  x = f2 (x, d522);
4dd737
+  x = f2 (x, d523);
4dd737
+  x = f2 (x, d524);
4dd737
+  x = f2 (x, d525);
4dd737
+  x = f2 (x, d526);
4dd737
+  x = f2 (x, d527);
4dd737
+  x = f2 (x, d528);
4dd737
+  x = f2 (x, d529);
4dd737
+  x = f2 (x, d530);
4dd737
+  x = f2 (x, d531);
4dd737
+  x = f2 (x, d532);
4dd737
+  x = f2 (x, d533);
4dd737
+  x = f2 (x, d534);
4dd737
+  x = f2 (x, d535);
4dd737
+  x = f2 (x, d536);
4dd737
+  x = f2 (x, d537);
4dd737
+  x = f2 (x, d538);
4dd737
+  x = f2 (x, d539);
4dd737
+  x = f2 (x, d540);
4dd737
+  x = f2 (x, d541);
4dd737
+  x = f2 (x, d542);
4dd737
+  x = f2 (x, d543);
4dd737
+  x = f2 (x, d544);
4dd737
+  x = f2 (x, d545);
4dd737
+  x = f2 (x, d546);
4dd737
+  x = f2 (x, d547);
4dd737
+  x = f2 (x, d548);
4dd737
+  x = f2 (x, d549);
4dd737
+  x = f2 (x, d550);
4dd737
+  x = f2 (x, d551);
4dd737
+  x = f2 (x, d552);
4dd737
+  x = f2 (x, d553);
4dd737
+  x = f2 (x, d554);
4dd737
+  x = f2 (x, d555);
4dd737
+  x = f2 (x, d556);
4dd737
+  x = f2 (x, d557);
4dd737
+  x = f2 (x, d558);
4dd737
+  x = f2 (x, d559);
4dd737
+  x = f2 (x, d560);
4dd737
+  x = f2 (x, d561);
4dd737
+  x = f2 (x, d562);
4dd737
+  x = f2 (x, d563);
4dd737
+  x = f2 (x, d564);
4dd737
+  x = f2 (x, d565);
4dd737
+  x = f2 (x, d566);
4dd737
+  x = f2 (x, d567);
4dd737
+  x = f2 (x, d568);
4dd737
+  x = f2 (x, d569);
4dd737
+  x = f2 (x, d570);
4dd737
+  x = f2 (x, d571);
4dd737
+  x = f2 (x, d572);
4dd737
+  x = f2 (x, d573);
4dd737
+  x = f2 (x, d574);
4dd737
+  x = f2 (x, d575);
4dd737
+  x = f2 (x, d576);
4dd737
+  x = f2 (x, d577);
4dd737
+  x = f2 (x, d578);
4dd737
+  x = f2 (x, d579);
4dd737
+  x = f2 (x, d580);
4dd737
+  x = f2 (x, d581);
4dd737
+  x = f2 (x, d582);
4dd737
+  x = f2 (x, d583);
4dd737
+  x = f2 (x, d584);
4dd737
+  x = f2 (x, d585);
4dd737
+  x = f2 (x, d586);
4dd737
+  x = f2 (x, d587);
4dd737
+  x = f2 (x, d588);
4dd737
+  x = f2 (x, d589);
4dd737
+  x = f2 (x, d590);
4dd737
+  x = f2 (x, d591);
4dd737
+  x = f2 (x, d592);
4dd737
+  x = f2 (x, d593);
4dd737
+  x = f2 (x, d594);
4dd737
+  x = f2 (x, d595);
4dd737
+  x = f2 (x, d596);
4dd737
+  x = f2 (x, d597);
4dd737
+  x = f2 (x, d598);
4dd737
+  x = f2 (x, d599);
4dd737
+  x = f2 (x, d600);
4dd737
+  x = f2 (x, d601);
4dd737
+  x = f2 (x, d602);
4dd737
+  x = f2 (x, d603);
4dd737
+  x = f2 (x, d604);
4dd737
+  x = f2 (x, d605);
4dd737
+  x = f2 (x, d606);
4dd737
+  x = f2 (x, d607);
4dd737
+  x = f2 (x, d608);
4dd737
+  x = f2 (x, d609);
4dd737
+  x = f2 (x, d610);
4dd737
+  x = f2 (x, d611);
4dd737
+  x = f2 (x, d612);
4dd737
+  x = f2 (x, d613);
4dd737
+  x = f2 (x, d614);
4dd737
+  x = f2 (x, d615);
4dd737
+  x = f2 (x, d616);
4dd737
+  x = f2 (x, d617);
4dd737
+  x = f2 (x, d618);
4dd737
+  x = f2 (x, d619);
4dd737
+  x = f2 (x, d620);
4dd737
+  x = f2 (x, d621);
4dd737
+  x = f2 (x, d622);
4dd737
+  x = f2 (x, d623);
4dd737
+  x = f2 (x, d624);
4dd737
+  x = f2 (x, d625);
4dd737
+  x = f2 (x, d626);
4dd737
+  x = f2 (x, d627);
4dd737
+  x = f2 (x, d628);
4dd737
+  x = f2 (x, d629);
4dd737
+  x = f2 (x, d630);
4dd737
+  x = f2 (x, d631);
4dd737
+  x = f2 (x, d632);
4dd737
+  x = f2 (x, d633);
4dd737
+  x = f2 (x, d634);
4dd737
+  x = f2 (x, d635);
4dd737
+  x = f2 (x, d636);
4dd737
+  x = f2 (x, d637);
4dd737
+  x = f2 (x, d638);
4dd737
+  x = f2 (x, d639);
4dd737
+  x = f2 (x, d640);
4dd737
+  x = f2 (x, d641);
4dd737
+  x = f2 (x, d642);
4dd737
+  x = f2 (x, d643);
4dd737
+  x = f2 (x, d644);
4dd737
+  x = f2 (x, d645);
4dd737
+  x = f2 (x, d646);
4dd737
+  x = f2 (x, d647);
4dd737
+  x = f2 (x, d648);
4dd737
+  x = f2 (x, d649);
4dd737
+  x = f2 (x, d650);
4dd737
+  x = f2 (x, d651);
4dd737
+  x = f2 (x, d652);
4dd737
+  x = f2 (x, d653);
4dd737
+  x = f2 (x, d654);
4dd737
+  x = f2 (x, d655);
4dd737
+  x = f2 (x, d656);
4dd737
+  x = f2 (x, d657);
4dd737
+  x = f2 (x, d658);
4dd737
+  x = f2 (x, d659);
4dd737
+  x = f2 (x, d660);
4dd737
+  x = f2 (x, d661);
4dd737
+  x = f2 (x, d662);
4dd737
+  x = f2 (x, d663);
4dd737
+  x = f2 (x, d664);
4dd737
+  x = f2 (x, d665);
4dd737
+  x = f2 (x, d666);
4dd737
+  x = f2 (x, d667);
4dd737
+  x = f2 (x, d668);
4dd737
+  x = f2 (x, d669);
4dd737
+  x = f2 (x, d670);
4dd737
+  x = f2 (x, d671);
4dd737
+  x = f2 (x, d672);
4dd737
+  x = f2 (x, d673);
4dd737
+  x = f2 (x, d674);
4dd737
+  x = f2 (x, d675);
4dd737
+  x = f2 (x, d676);
4dd737
+  x = f2 (x, d677);
4dd737
+  x = f2 (x, d678);
4dd737
+  x = f2 (x, d679);
4dd737
+  x = f2 (x, d680);
4dd737
+  x = f2 (x, d681);
4dd737
+  x = f2 (x, d682);
4dd737
+  x = f2 (x, d683);
4dd737
+  x = f2 (x, d684);
4dd737
+  x = f2 (x, d685);
4dd737
+  x = f2 (x, d686);
4dd737
+  x = f2 (x, d687);
4dd737
+  x = f2 (x, d688);
4dd737
+  x = f2 (x, d689);
4dd737
+  x = f2 (x, d690);
4dd737
+  x = f2 (x, d691);
4dd737
+  x = f2 (x, d692);
4dd737
+  x = f2 (x, d693);
4dd737
+  x = f2 (x, d694);
4dd737
+  x = f2 (x, d695);
4dd737
+  x = f2 (x, d696);
4dd737
+  x = f2 (x, d697);
4dd737
+  x = f2 (x, d698);
4dd737
+  x = f2 (x, d699);
4dd737
+  x = f2 (x, d700);
4dd737
+  x = f2 (x, d701);
4dd737
+  x = f2 (x, d702);
4dd737
+  x = f2 (x, d703);
4dd737
+  x = f2 (x, d704);
4dd737
+  x = f2 (x, d705);
4dd737
+  x = f2 (x, d706);
4dd737
+  x = f2 (x, d707);
4dd737
+  x = f2 (x, d708);
4dd737
+  x = f2 (x, d709);
4dd737
+  x = f2 (x, d710);
4dd737
+  x = f2 (x, d711);
4dd737
+  x = f2 (x, d712);
4dd737
+  x = f2 (x, d713);
4dd737
+  x = f2 (x, d714);
4dd737
+  x = f2 (x, d715);
4dd737
+  x = f2 (x, d716);
4dd737
+  x = f2 (x, d717);
4dd737
+  x = f2 (x, d718);
4dd737
+  x = f2 (x, d719);
4dd737
+  x = f2 (x, d720);
4dd737
+  x = f2 (x, d721);
4dd737
+  x = f2 (x, d722);
4dd737
+  x = f2 (x, d723);
4dd737
+  x = f2 (x, d724);
4dd737
+  x = f2 (x, d725);
4dd737
+  x = f2 (x, d726);
4dd737
+  x = f2 (x, d727);
4dd737
+  x = f2 (x, d728);
4dd737
+  x = f2 (x, d729);
4dd737
+  x = f2 (x, d730);
4dd737
+  x = f2 (x, d731);
4dd737
+  x = f2 (x, d732);
4dd737
+  x = f2 (x, d733);
4dd737
+  x = f2 (x, d734);
4dd737
+  x = f2 (x, d735);
4dd737
+  x = f2 (x, d736);
4dd737
+  x = f2 (x, d737);
4dd737
+  x = f2 (x, d738);
4dd737
+  x = f2 (x, d739);
4dd737
+  x = f2 (x, d740);
4dd737
+  x = f2 (x, d741);
4dd737
+  x = f2 (x, d742);
4dd737
+  x = f2 (x, d743);
4dd737
+  x = f2 (x, d744);
4dd737
+  x = f2 (x, d745);
4dd737
+  x = f2 (x, d746);
4dd737
+  x = f2 (x, d747);
4dd737
+  x = f2 (x, d748);
4dd737
+  x = f2 (x, d749);
4dd737
+  x = f2 (x, d750);
4dd737
+  x = f2 (x, d751);
4dd737
+  x = f2 (x, d752);
4dd737
+  x = f2 (x, d753);
4dd737
+  x = f2 (x, d754);
4dd737
+  x = f2 (x, d755);
4dd737
+  x = f2 (x, d756);
4dd737
+  x = f2 (x, d757);
4dd737
+  x = f2 (x, d758);
4dd737
+  x = f2 (x, d759);
4dd737
+  x = f2 (x, d760);
4dd737
+  x = f2 (x, d761);
4dd737
+  x = f2 (x, d762);
4dd737
+  x = f2 (x, d763);
4dd737
+  x = f2 (x, d764);
4dd737
+  x = f2 (x, d765);
4dd737
+  x = f2 (x, d766);
4dd737
+  x = f2 (x, d767);
4dd737
+  x = f2 (x, d768);
4dd737
+  x = f2 (x, d769);
4dd737
+  x = f2 (x, d770);
4dd737
+  x = f2 (x, d771);
4dd737
+  x = f2 (x, d772);
4dd737
+  x = f2 (x, d773);
4dd737
+  x = f2 (x, d774);
4dd737
+  x = f2 (x, d775);
4dd737
+  x = f2 (x, d776);
4dd737
+  x = f2 (x, d777);
4dd737
+  x = f2 (x, d778);
4dd737
+  x = f2 (x, d779);
4dd737
+  x = f2 (x, d780);
4dd737
+  x = f2 (x, d781);
4dd737
+  x = f2 (x, d782);
4dd737
+  x = f2 (x, d783);
4dd737
+  x = f2 (x, d784);
4dd737
+  x = f2 (x, d785);
4dd737
+  x = f2 (x, d786);
4dd737
+  x = f2 (x, d787);
4dd737
+  x = f2 (x, d788);
4dd737
+  x = f2 (x, d789);
4dd737
+  x = f2 (x, d790);
4dd737
+  x = f2 (x, d791);
4dd737
+  x = f2 (x, d792);
4dd737
+  x = f2 (x, d793);
4dd737
+  x = f2 (x, d794);
4dd737
+  x = f2 (x, d795);
4dd737
+  x = f2 (x, d796);
4dd737
+  x = f2 (x, d797);
4dd737
+  x = f2 (x, d798);
4dd737
+  x = f2 (x, d799);
4dd737
+  x = f2 (x, d800);
4dd737
+  x = f2 (x, d801);
4dd737
+  x = f2 (x, d802);
4dd737
+  x = f2 (x, d803);
4dd737
+  x = f2 (x, d804);
4dd737
+  x = f2 (x, d805);
4dd737
+  x = f2 (x, d806);
4dd737
+  x = f2 (x, d807);
4dd737
+  x = f2 (x, d808);
4dd737
+  x = f2 (x, d809);
4dd737
+  x = f2 (x, d810);
4dd737
+  x = f2 (x, d811);
4dd737
+  x = f2 (x, d812);
4dd737
+  x = f2 (x, d813);
4dd737
+  x = f2 (x, d814);
4dd737
+  x = f2 (x, d815);
4dd737
+  x = f2 (x, d816);
4dd737
+  x = f2 (x, d817);
4dd737
+  x = f2 (x, d818);
4dd737
+  x = f2 (x, d819);
4dd737
+  x = f2 (x, d820);
4dd737
+  x = f2 (x, d821);
4dd737
+  x = f2 (x, d822);
4dd737
+  x = f2 (x, d823);
4dd737
+  x = f2 (x, d824);
4dd737
+  x = f2 (x, d825);
4dd737
+  x = f2 (x, d826);
4dd737
+  x = f2 (x, d827);
4dd737
+  x = f2 (x, d828);
4dd737
+  x = f2 (x, d829);
4dd737
+  x = f2 (x, d830);
4dd737
+  x = f2 (x, d831);
4dd737
+  x = f2 (x, d832);
4dd737
+  x = f2 (x, d833);
4dd737
+  x = f2 (x, d834);
4dd737
+  x = f2 (x, d835);
4dd737
+  x = f2 (x, d836);
4dd737
+  x = f2 (x, d837);
4dd737
+  x = f2 (x, d838);
4dd737
+  x = f2 (x, d839);
4dd737
+  x = f2 (x, d840);
4dd737
+  x = f2 (x, d841);
4dd737
+  x = f2 (x, d842);
4dd737
+  x = f2 (x, d843);
4dd737
+  x = f2 (x, d844);
4dd737
+  x = f2 (x, d845);
4dd737
+  x = f2 (x, d846);
4dd737
+  x = f2 (x, d847);
4dd737
+  x = f2 (x, d848);
4dd737
+  x = f2 (x, d849);
4dd737
+  x = f2 (x, d850);
4dd737
+  x = f2 (x, d851);
4dd737
+  x = f2 (x, d852);
4dd737
+  x = f2 (x, d853);
4dd737
+  x = f2 (x, d854);
4dd737
+  x = f2 (x, d855);
4dd737
+  x = f2 (x, d856);
4dd737
+  x = f2 (x, d857);
4dd737
+  x = f2 (x, d858);
4dd737
+  x = f2 (x, d859);
4dd737
+  x = f2 (x, d860);
4dd737
+  x = f2 (x, d861);
4dd737
+  x = f2 (x, d862);
4dd737
+  x = f2 (x, d863);
4dd737
+  x = f2 (x, d864);
4dd737
+  x = f2 (x, d865);
4dd737
+  x = f2 (x, d866);
4dd737
+  x = f2 (x, d867);
4dd737
+  x = f2 (x, d868);
4dd737
+  x = f2 (x, d869);
4dd737
+  x = f2 (x, d870);
4dd737
+  x = f2 (x, d871);
4dd737
+  x = f2 (x, d872);
4dd737
+  x = f2 (x, d873);
4dd737
+  x = f2 (x, d874);
4dd737
+  x = f2 (x, d875);
4dd737
+  x = f2 (x, d876);
4dd737
+  x = f2 (x, d877);
4dd737
+  x = f2 (x, d878);
4dd737
+  x = f2 (x, d879);
4dd737
+  x = f2 (x, d880);
4dd737
+  x = f2 (x, d881);
4dd737
+  x = f2 (x, d882);
4dd737
+  x = f2 (x, d883);
4dd737
+  x = f2 (x, d884);
4dd737
+  x = f2 (x, d885);
4dd737
+  x = f2 (x, d886);
4dd737
+  x = f2 (x, d887);
4dd737
+  x = f2 (x, d888);
4dd737
+  x = f2 (x, d889);
4dd737
+  x = f2 (x, d890);
4dd737
+  x = f2 (x, d891);
4dd737
+  x = f2 (x, d892);
4dd737
+  x = f2 (x, d893);
4dd737
+  x = f2 (x, d894);
4dd737
+  x = f2 (x, d895);
4dd737
+  x = f2 (x, d896);
4dd737
+  x = f2 (x, d897);
4dd737
+  x = f2 (x, d898);
4dd737
+  x = f2 (x, d899);
4dd737
+  x = f2 (x, d900);
4dd737
+  x = f2 (x, d901);
4dd737
+  x = f2 (x, d902);
4dd737
+  x = f2 (x, d903);
4dd737
+  x = f2 (x, d904);
4dd737
+  x = f2 (x, d905);
4dd737
+  x = f2 (x, d906);
4dd737
+  x = f2 (x, d907);
4dd737
+  x = f2 (x, d908);
4dd737
+  x = f2 (x, d909);
4dd737
+  x = f2 (x, d910);
4dd737
+  x = f2 (x, d911);
4dd737
+  x = f2 (x, d912);
4dd737
+  x = f2 (x, d913);
4dd737
+  x = f2 (x, d914);
4dd737
+  x = f2 (x, d915);
4dd737
+  x = f2 (x, d916);
4dd737
+  x = f2 (x, d917);
4dd737
+  x = f2 (x, d918);
4dd737
+  x = f2 (x, d919);
4dd737
+  x = f2 (x, d920);
4dd737
+  x = f2 (x, d921);
4dd737
+  x = f2 (x, d922);
4dd737
+  x = f2 (x, d923);
4dd737
+  x = f2 (x, d924);
4dd737
+  x = f2 (x, d925);
4dd737
+  x = f2 (x, d926);
4dd737
+  x = f2 (x, d927);
4dd737
+  x = f2 (x, d928);
4dd737
+  x = f2 (x, d929);
4dd737
+  x = f2 (x, d930);
4dd737
+  x = f2 (x, d931);
4dd737
+  x = f2 (x, d932);
4dd737
+  x = f2 (x, d933);
4dd737
+  x = f2 (x, d934);
4dd737
+  x = f2 (x, d935);
4dd737
+  x = f2 (x, d936);
4dd737
+  x = f2 (x, d937);
4dd737
+  x = f2 (x, d938);
4dd737
+  x = f2 (x, d939);
4dd737
+  x = f2 (x, d940);
4dd737
+  x = f2 (x, d941);
4dd737
+  x = f2 (x, d942);
4dd737
+  x = f2 (x, d943);
4dd737
+  x = f2 (x, d944);
4dd737
+  x = f2 (x, d945);
4dd737
+  x = f2 (x, d946);
4dd737
+  x = f2 (x, d947);
4dd737
+  x = f2 (x, d948);
4dd737
+  x = f2 (x, d949);
4dd737
+  x = f2 (x, d950);
4dd737
+  x = f2 (x, d951);
4dd737
+  x = f2 (x, d952);
4dd737
+  x = f2 (x, d953);
4dd737
+  x = f2 (x, d954);
4dd737
+  x = f2 (x, d955);
4dd737
+  x = f2 (x, d956);
4dd737
+  x = f2 (x, d957);
4dd737
+  x = f2 (x, d958);
4dd737
+  x = f2 (x, d959);
4dd737
+  x = f2 (x, d960);
4dd737
+  x = f2 (x, d961);
4dd737
+  x = f2 (x, d962);
4dd737
+  x = f2 (x, d963);
4dd737
+  x = f2 (x, d964);
4dd737
+  x = f2 (x, d965);
4dd737
+  x = f2 (x, d966);
4dd737
+  x = f2 (x, d967);
4dd737
+  x = f2 (x, d968);
4dd737
+  x = f2 (x, d969);
4dd737
+  x = f2 (x, d970);
4dd737
+  x = f2 (x, d971);
4dd737
+  x = f2 (x, d972);
4dd737
+  x = f2 (x, d973);
4dd737
+  x = f2 (x, d974);
4dd737
+  x = f2 (x, d975);
4dd737
+  x = f2 (x, d976);
4dd737
+  x = f2 (x, d977);
4dd737
+  x = f2 (x, d978);
4dd737
+  x = f2 (x, d979);
4dd737
+  x = f2 (x, d980);
4dd737
+  x = f2 (x, d981);
4dd737
+  x = f2 (x, d982);
4dd737
+  x = f2 (x, d983);
4dd737
+  x = f2 (x, d984);
4dd737
+  x = f2 (x, d985);
4dd737
+  x = f2 (x, d986);
4dd737
+  x = f2 (x, d987);
4dd737
+  x = f2 (x, d988);
4dd737
+  x = f2 (x, d989);
4dd737
+  x = f2 (x, d990);
4dd737
+  x = f2 (x, d991);
4dd737
+  x = f2 (x, d992);
4dd737
+  x = f2 (x, d993);
4dd737
+  x = f2 (x, d994);
4dd737
+  x = f2 (x, d995);
4dd737
+  x = f2 (x, d996);
4dd737
+  x = f2 (x, d997);
4dd737
+  x = f2 (x, d998);
4dd737
+  x = f2 (x, d999);
4dd737
+  return x;
4dd737
+}
4dd737
+
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash inline probes" 1 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 1 "pro_and_epilogue" } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 1 "pro_and_epilogue" } } */
4dd737
+
4dd737
+/* f3 is not a leaf
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 1 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */
4dd737
+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 1 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */
4dd737
diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp
4dd737
index 821cea9cb33..2c669a9822f 100644
4dd737
--- a/gcc/testsuite/lib/target-supports.exp
4dd737
+++ b/gcc/testsuite/lib/target-supports.exp
4dd737
@@ -5421,11 +5421,15 @@ proc check_effective_target_autoincdec { } {
4dd737
 proc check_effective_target_supports_stack_clash_protection { } {
4dd737
 
4dd737
    # Temporary until the target bits are fully ACK'd.
4dd737
-#  if { [istarget aarch*-*-*] || [istarget x86_64-*-*]
4dd737
-#       || [istarget i?86-*-*] || [istarget s390*-*-*]
4dd737
+#  if { [istarget aarch*-*-*]
4dd737
+#       || [istarget s390*-*-*]
4dd737
 #       || [istarget powerpc*-*-*] || [istarget rs6000*-*-*] } {
4dd737
 #	return 1
4dd737
 #  }
4dd737
+
4dd737
+    if { [istarget x86_64-*-*] || [istarget i?86-*-*] } {
4dd737
+	return 1
4dd737
+    }
4dd737
   return 0
4dd737
 }
4dd737