From 402f1e92045a5180c0578056952eda9e4d7a278d Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Jan 04 2018 17:21:06 +0000 Subject: 7.2.1-6 --- diff --git a/.gitignore b/.gitignore index 7190c49..3fabea3 100644 --- a/.gitignore +++ b/.gitignore @@ -25,3 +25,4 @@ /gcc-7.2.1-20170829.tar.bz2 /gcc-7.2.1-20170915.tar.bz2 /gcc-7.2.1-20180101.tar.bz2 +/gcc-7.2.1-20180104.tar.bz2 diff --git a/gcc.spec b/gcc.spec index 7f5b055..c481430 100644 --- a/gcc.spec +++ b/gcc.spec @@ -1,10 +1,10 @@ -%global DATE 20180101 -%global SVNREV 256064 +%global DATE 20180104 +%global SVNREV 256255 %global gcc_version 7.2.1 %global gcc_major 7 # Note, gcc_release must be integer, if you want to add suffixes to # %{release}, append them after %{gcc_release} on Release: line. -%global gcc_release 5 +%global gcc_release 6 %global nvptx_tools_gitrev c28050f60193b3b95a18866a96f03334e874e78f %global nvptx_newlib_gitrev aadc8eb0ec43b7cd0dd2dfb484bae63c8b05ef24 %global _unpackaged_files_terminate_build 0 @@ -235,30 +235,13 @@ Patch8: gcc7-no-add-needed.patch Patch9: gcc7-aarch64-async-unw-tables.patch Patch10: gcc7-foffload-default.patch Patch11: gcc7-Wno-format-security.patch -Patch12: gcc7-pr83556.patch -Patch13: gcc7-aarch64-sanitizer-fix.patch +Patch12: gcc7-aarch64-sanitizer-fix.patch +Patch13: gcc7-rh1512529-aarch64.patch Patch1000: nvptx-tools-no-ptxas.patch Patch1001: nvptx-tools-build.patch Patch1002: nvptx-tools-glibc.patch -Patch2001: gcc7-rh1512529-1.patch -Patch2002: gcc7-rh1512529-2.patch -Patch2003: gcc7-rh1512529-3.patch -Patch2004: gcc7-rh1512529-4.patch -Patch2005: gcc7-rh1512529-5.patch -Patch2006: gcc7-rh1512529-6.patch -Patch2007: gcc7-rh1512529-7.patch -Patch2008: gcc7-rh1512529-8.patch -Patch2009: gcc7-rh1512529-9.patch -Patch2010: gcc7-rh1512529-10.patch -Patch2011: gcc7-rh1512529-11.patch -Patch2012: gcc7-rh1512529-12.patch -Patch2013: gcc7-rh1512529-13.patch -Patch2014: gcc7-rh1512529-14.patch -Patch2015: gcc7-rh1512529-15.patch -Patch2016: gcc7-rh1512529-16.patch -Patch2017: gcc7-rh1512529-17.patch # On ARM EABI systems, we do want -gnueabi to be part of the # target triple. @@ -843,10 +826,10 @@ package or when debugging this package. %patch9 -p0 -b .aarch64-async-unw-tables~ %patch10 -p0 -b .foffload-default~ %patch11 -p0 -b .Wno-format-security~ -%patch12 -p0 -b .pr83556~ %if 0%{?fedora} > 27 -%patch13 -p0 -b .aarch64-sanitizer-fix~ +%patch12 -p0 -b .aarch64-sanitizer-fix~ %endif +%patch13 -p0 -b .rh1512529-aarch64~ cd nvptx-tools-%{nvptx_tools_gitrev} %patch1000 -p1 -b .nvptx-tools-no-ptxas~ @@ -854,24 +837,6 @@ cd nvptx-tools-%{nvptx_tools_gitrev} %patch1002 -p1 -b .nvptx-tools-glibc~ cd .. -%patch2001 -p1 -%patch2002 -p1 -%patch2003 -p1 -%patch2004 -p1 -%patch2005 -p1 -%patch2006 -p1 -%patch2007 -p1 -%patch2008 -p1 -%patch2009 -p1 -%patch2010 -p1 -%patch2011 -p1 -%patch2012 -p1 -%patch2013 -p1 -%patch2014 -p1 -%patch2015 -p1 -%patch2016 -p1 -%patch2017 -p1 - %if 0%{?_enable_debug_packages} mkdir dwz-wrapper if [ -f /usr/bin/dwz ]; then @@ -3282,6 +3247,14 @@ fi %endif %changelog +* Thu Jan 4 2018 Jakub Jelinek 7.2.1-6 +- update from the 7 branch + - PRs c++/83556, fortran/83650, libgfortran/83649 +- backport fixes for two -fstack-clash-protection bugs from the trunk + (PRs middle-end/83654, target/83641) +- commit -fstack-clash-protection patches except aarch64 to + redhat/gcc-7-branch instead of applying them as patches in the spec file + * Mon Jan 1 2018 Jakub Jelinek 7.2.1-5 - update from the 7 branch - PRs ada/82393, bootstrap/83439, c++/70029, c++/79650, c++/80259, diff --git a/gcc7-pr83556.patch b/gcc7-pr83556.patch deleted file mode 100644 index c4ff5c4..0000000 --- a/gcc7-pr83556.patch +++ /dev/null @@ -1,84 +0,0 @@ -2017-12-23 Jakub Jelinek - - PR c++/83556 - * tree.c (replace_placeholders_r): Pass NULL as last argument to - cp_walk_tree instead of d->pset. If non-TREE_CONSTANT and - non-PLACEHOLDER_EXPR tree has been seen already, set *walk_subtrees - to false and return. - (replace_placeholders): Pass NULL instead of &pset as last argument - to cp_walk_tree. - - * g++.dg/cpp0x/pr83556.C: New test. - ---- gcc/cp/tree.c.jj 2017-12-15 16:10:37.000000000 +0100 -+++ gcc/cp/tree.c 2017-12-22 23:24:16.720428548 +0100 -@@ -3106,6 +3106,11 @@ replace_placeholders_r (tree* t, int* wa - { - constructor_elt *ce; - vec *v = CONSTRUCTOR_ELTS (*t); -+ if (d->pset->add (*t)) -+ { -+ *walk_subtrees = false; -+ return NULL_TREE; -+ } - for (unsigned i = 0; vec_safe_iterate (v, i, &ce); ++i) - { - tree *valp = &ce->value; -@@ -3125,7 +3130,7 @@ replace_placeholders_r (tree* t, int* wa - valp = &TARGET_EXPR_INITIAL (*valp); - } - d->obj = subob; -- cp_walk_tree (valp, replace_placeholders_r, data_, d->pset); -+ cp_walk_tree (valp, replace_placeholders_r, data_, NULL); - d->obj = obj; - } - *walk_subtrees = false; -@@ -3133,6 +3138,8 @@ replace_placeholders_r (tree* t, int* wa - } - - default: -+ if (d->pset->add (*t)) -+ *walk_subtrees = false; - break; - } - -@@ -3161,7 +3168,7 @@ replace_placeholders (tree exp, tree obj - replace_placeholders_t data = { obj, false, &pset }; - if (TREE_CODE (exp) == TARGET_EXPR) - tp = &TARGET_EXPR_INITIAL (exp); -- cp_walk_tree (tp, replace_placeholders_r, &data, &pset); -+ cp_walk_tree (tp, replace_placeholders_r, &data, NULL); - if (seen_p) - *seen_p = data.seen; - return exp; ---- gcc/testsuite/g++.dg/cpp0x/pr83556.C.jj 2017-12-22 23:30:10.771126002 +0100 -+++ gcc/testsuite/g++.dg/cpp0x/pr83556.C 2017-12-22 23:29:21.000000000 +0100 -@@ -0,0 +1,28 @@ -+// PR c++/83556 -+// { dg-do run { target c++11 } } -+ -+int -+foo () -+{ -+ return 1; -+} -+ -+struct A -+{ -+ int a = foo (); -+ int b = 1; -+ int c = a ? 1 * b : 2 * b; -+}; -+ -+struct B -+{ -+ A d {}; -+}; -+ -+int -+main () -+{ -+ B e {}; -+ if (e.d.c != 1) -+ __builtin_abort (); -+} diff --git a/gcc7-rh1512529-1.patch b/gcc7-rh1512529-1.patch deleted file mode 100644 index 7b3e763..0000000 --- a/gcc7-rh1512529-1.patch +++ /dev/null @@ -1,340 +0,0 @@ -commit cc3586c7f4704acbbd3f2f99de5b82bcc8f6fe36 -Author: law -Date: Wed Sep 20 04:56:54 2017 +0000 - - * common.opt (-fstack-clash-protection): New option. - * flag-types.h (enum stack_check_type): Note difference between - -fstack-check= and -fstack-clash-protection. - * params.def (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE): New PARAM. - (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL): Likewise. - * toplev.c (process_options): Issue warnings/errors for cases - not handled with -fstack-clash-protection. - * doc/invoke.texi (-fstack-clash-protection): Document new option. - (-fstack-check): Note additional problem with -fstack-check=generic. - Note that -fstack-check is primarily for Ada and refer users - to -fstack-clash-protection for stack-clash-protection. - Document new params for stack clash protection. - - * gcc.dg/stack-check-2.c: New test. - * lib/target-supports.exp - (check_effective_target_supports_stack_clash_protection): New function. - (check_effective_target_frame_pointer_for_non_leaf): Likewise. - (check_effective_target_caller_implicit_probes): Likewise. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@252994 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/common.opt b/gcc/common.opt -index 592bbd15309..bcaea91c130 100644 ---- a/gcc/common.opt -+++ b/gcc/common.opt -@@ -2291,13 +2291,18 @@ Common Report Var(flag_variable_expansion_in_unroller) Optimization - Apply variable expansion when loops are unrolled. - - fstack-check= --Common Report RejectNegative Joined -+Common Report RejectNegative Joined Optimization - -fstack-check=[no|generic|specific] Insert stack checking code into the program. - - fstack-check - Common Alias(fstack-check=, specific, no) - Insert stack checking code into the program. Same as -fstack-check=specific. - -+fstack-clash-protection -+Common Report Var(flag_stack_clash_protection) Optimization -+Insert code to probe each page of stack space as it is allocated to protect -+from stack-clash style attacks. -+ - fstack-limit - Common Var(common_deferred_options) Defer - -diff --git a/gcc/doc/invoke.texi b/gcc/doc/invoke.texi -index a0fb09eb9e1..f77035571a1 100644 ---- a/gcc/doc/invoke.texi -+++ b/gcc/doc/invoke.texi -@@ -10026,6 +10026,21 @@ compilation without. The value for compilation with profile feedback - needs to be more conservative (higher) in order to make tracer - effective. - -+@item stack-clash-protection-guard-size -+Specify the size of the operating system provided stack guard as -+2 raised to @var{num} bytes. The default value is 12 (4096 bytes). -+Acceptable values are between 12 and 30. Higher values may reduce the -+number of explicit probes, but a value larger than the operating system -+provided guard will leave code vulnerable to stack clash style attacks. -+ -+@item stack-clash-protection-probe-interval -+Stack clash protection involves probing stack space as it is allocated. This -+param controls the maximum distance between probes into the stack as 2 raised -+to @var{num} bytes. Acceptable values are between 10 and 16 and defaults to -+12. Higher values may reduce the number of explicit probes, but a value -+larger than the operating system provided guard will leave code vulnerable to -+stack clash style attacks. -+ - @item max-cse-path-length - - The maximum number of basic blocks on path that CSE considers. -@@ -11218,7 +11233,8 @@ target support in the compiler but comes with the following drawbacks: - @enumerate - @item - Modified allocation strategy for large objects: they are always --allocated dynamically if their size exceeds a fixed threshold. -+allocated dynamically if their size exceeds a fixed threshold. Note this -+may change the semantics of some code. - - @item - Fixed limit on the size of the static frame of functions: when it is -@@ -11233,6 +11249,25 @@ generic implementation, code performance is hampered. - Note that old-style stack checking is also the fallback method for - @samp{specific} if no target support has been added in the compiler. - -+@samp{-fstack-check=} is designed for Ada's needs to detect infinite recursion -+and stack overflows. @samp{specific} is an excellent choice when compiling -+Ada code. It is not generally sufficient to protect against stack-clash -+attacks. To protect against those you want @samp{-fstack-clash-protection}. -+ -+@item -fstack-clash-protection -+@opindex fstack-clash-protection -+Generate code to prevent stack clash style attacks. When this option is -+enabled, the compiler will only allocate one page of stack space at a time -+and each page is accessed immediately after allocation. Thus, it prevents -+allocations from jumping over any stack guard page provided by the -+operating system. -+ -+Most targets do not fully support stack clash protection. However, on -+those targets @option{-fstack-clash-protection} will protect dynamic stack -+allocations. @option{-fstack-clash-protection} may also provide limited -+protection for static stack allocations if the target supports -+@option{-fstack-check=specific}. -+ - @item -fstack-limit-register=@var{reg} - @itemx -fstack-limit-symbol=@var{sym} - @itemx -fno-stack-limit -diff --git a/gcc/flag-types.h b/gcc/flag-types.h -index 27a38efdc8e..4e5a4e58119 100644 ---- a/gcc/flag-types.h -+++ b/gcc/flag-types.h -@@ -166,7 +166,14 @@ enum permitted_flt_eval_methods - PERMITTED_FLT_EVAL_METHODS_C11 - }; - --/* Type of stack check. */ -+/* Type of stack check. -+ -+ Stack checking is designed to detect infinite recursion and stack -+ overflows for Ada programs. Furthermore stack checking tries to ensure -+ in that scenario that enough stack space is left to run a signal handler. -+ -+ -fstack-check= does not prevent stack-clash style attacks. For that -+ you want -fstack-clash-protection. */ - enum stack_check_type - { - /* Do not check the stack. */ -diff --git a/gcc/params.def b/gcc/params.def -index 6b07518a34b..ce66e393eb1 100644 ---- a/gcc/params.def -+++ b/gcc/params.def -@@ -213,6 +213,16 @@ DEFPARAM(PARAM_STACK_FRAME_GROWTH, - "Maximal stack frame growth due to inlining (in percent).", - 1000, 0, 0) - -+DEFPARAM(PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE, -+ "stack-clash-protection-guard-size", -+ "Size of the stack guard expressed as a power of two.", -+ 12, 12, 30) -+ -+DEFPARAM(PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL, -+ "stack-clash-protection-probe-interval", -+ "Interval in which to probe the stack expressed as a power of two.", -+ 12, 10, 16) -+ - /* The GCSE optimization will be disabled if it would require - significantly more memory than this value. */ - DEFPARAM(PARAM_MAX_GCSE_MEMORY, -diff --git a/gcc/testsuite/gcc.dg/stack-check-2.c b/gcc/testsuite/gcc.dg/stack-check-2.c -new file mode 100644 -index 00000000000..196c4bbfbdd ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-2.c -@@ -0,0 +1,66 @@ -+/* The goal here is to ensure that we never consider a call to a noreturn -+ function as a potential tail call. -+ -+ Right now GCC discovers potential tail calls by looking at the -+ predecessors of the exit block. A call to a non-return function -+ has no successors and thus can never match that first filter. -+ -+ But that could change one day and we want to catch it. The problem -+ is the compiler could potentially optimize a tail call to a nonreturn -+ function, even if the caller has a frame. That breaks the assumption -+ that calls probe *sp when saving the return address that some targets -+ depend on to elide stack probes. */ -+ -+/* { dg-do compile } */ -+/* { dg-options "-O2 -fstack-clash-protection -fdump-tree-tailc -fdump-tree-optimized" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+extern void foo (void) __attribute__ ((__noreturn__)); -+ -+ -+void -+test_direct_1 (void) -+{ -+ foo (); -+} -+ -+void -+test_direct_2 (void) -+{ -+ return foo (); -+} -+ -+void (*indirect)(void)__attribute__ ((noreturn)); -+ -+ -+void -+test_indirect_1 () -+{ -+ (*indirect)(); -+} -+ -+void -+test_indirect_2 (void) -+{ -+ return (*indirect)();; -+} -+ -+ -+typedef void (*pvfn)() __attribute__ ((noreturn)); -+ -+void (*indirect_casted)(void); -+ -+void -+test_indirect_casted_1 () -+{ -+ (*(pvfn)indirect_casted)(); -+} -+ -+void -+test_indirect_casted_2 (void) -+{ -+ return (*(pvfn)indirect_casted)(); -+} -+/* { dg-final { scan-tree-dump-not "tail call" "tailc" } } */ -+/* { dg-final { scan-tree-dump-not "tail call" "optimized" } } */ -+ -diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp -index 57caec74836..1000f15358b 100644 ---- a/gcc/testsuite/lib/target-supports.exp -+++ b/gcc/testsuite/lib/target-supports.exp -@@ -8371,3 +8371,80 @@ proc check_effective_target_arm_coproc4_ok { } { - return [check_cached_effective_target arm_coproc4_ok \ - check_effective_target_arm_coproc4_ok_nocache] - } -+ -+# Return 1 if the target has support for stack probing designed -+# to avoid stack-clash style attacks. -+# -+# This is used to restrict the stack-clash mitigation tests to -+# just those targets that have been explicitly supported. -+# -+# In addition to the prologue work on those targets, each target's -+# properties should be described in the functions below so that -+# tests do not become a mess of unreadable target conditions. -+# -+proc check_effective_target_supports_stack_clash_protection { } { -+ -+ # Temporary until the target bits are fully ACK'd. -+# if { [istarget aarch*-*-*] || [istarget x86_64-*-*] -+# || [istarget i?86-*-*] || [istarget s390*-*-*] -+# || [istarget powerpc*-*-*] || [istarget rs6000*-*-*] } { -+# return 1 -+# } -+ return 0 -+} -+ -+# Return 1 if the target creates a frame pointer for non-leaf functions -+# Note we ignore cases where we apply tail call optimization here. -+proc check_effective_target_frame_pointer_for_non_leaf { } { -+ if { [istarget aarch*-*-*] } { -+ return 1 -+ } -+ return 0 -+} -+ -+# Return 1 if the target's calling sequence or its ABI -+# create implicit stack probes at or prior to function entry. -+proc check_effective_target_caller_implicit_probes { } { -+ -+ # On x86/x86_64 the call instruction itself pushes the return -+ # address onto the stack. That is an implicit probe of *sp. -+ if { [istarget x86_64-*-*] || [istarget i?86-*-*] } { -+ return 1 -+ } -+ -+ # On PPC, the ABI mandates that the address of the outer -+ # frame be stored at *sp. Thus each allocation of stack -+ # space is itself an implicit probe of *sp. -+ if { [istarget powerpc*-*-*] || [istarget rs6000*-*-*] } { -+ return 1 -+ } -+ -+ # s390's ABI has a register save area allocated by the -+ # caller for use by the callee. The mere existence does -+ # not constitute a probe by the caller, but when the slots -+ # used by the callee those stores are implicit probes. -+ if { [istarget s390*-*-*] } { -+ return 1 -+ } -+ -+ # Not strictly true on aarch64, but we have agreed that we will -+ # consider any function that pushes SP more than 3kbytes into -+ # the guard page as broken. This essentially means that we can -+ # consider the aarch64 as having a caller implicit probe at -+ # *(sp + 1k). -+ if { [istarget aarch64*-*-*] } { -+ return 1; -+ } -+ -+ return 0 -+} -+ -+# Targets that potentially realign the stack pointer often cause residual -+# stack allocations and make it difficult to elimination loops or residual -+# allocations for dynamic stack allocations -+proc check_effective_target_callee_realigns_stack { } { -+ if { [istarget x86_64-*-*] || [istarget i?86-*-*] } { -+ return 1 -+ } -+ return 0 -+} -diff --git a/gcc/toplev.c b/gcc/toplev.c -index e7a5d487313..a7da7964fbb 100644 ---- a/gcc/toplev.c -+++ b/gcc/toplev.c -@@ -1574,6 +1574,26 @@ process_options (void) - flag_associative_math = 0; - } - -+ /* -fstack-clash-protection is not currently supported on targets -+ where the stack grows up. */ -+ if (flag_stack_clash_protection && !STACK_GROWS_DOWNWARD) -+ { -+ warning_at (UNKNOWN_LOCATION, 0, -+ "%<-fstack-clash-protection%> is not supported on targets " -+ "where the stack grows from lower to higher addresses"); -+ flag_stack_clash_protection = 0; -+ } -+ -+ /* We can not support -fstack-check= and -fstack-clash-protection at -+ the same time. */ -+ if (flag_stack_check != NO_STACK_CHECK && flag_stack_clash_protection) -+ { -+ warning_at (UNKNOWN_LOCATION, 0, -+ "%<-fstack-check=%> and %<-fstack-clash_protection%> are " -+ "mutually exclusive. Disabling %<-fstack-check=%>"); -+ flag_stack_check = NO_STACK_CHECK; -+ } -+ - /* With -fcx-limited-range, we do cheap and quick complex arithmetic. */ - if (flag_cx_limited_range) - flag_complex_method = 0; diff --git a/gcc7-rh1512529-10.patch b/gcc7-rh1512529-10.patch deleted file mode 100644 index 26ccbf4..0000000 --- a/gcc7-rh1512529-10.patch +++ /dev/null @@ -1,605 +0,0 @@ -commit b552ddab57a34fe1acb8d714b5f556082600b9e0 -Author: law -Date: Mon Sep 25 23:13:55 2017 +0000 - - * config/rs6000/rs6000-protos.h (output_probe_stack_range): Update - prototype for new argument. - * config/rs6000/rs6000.c (rs6000_emit_allocate_stack_1): New function, - mostly extracted from rs6000_emit_allocate_stack. - (rs6000_emit_probe_stack_range_stack_clash): New function. - (rs6000_emit_allocate_stack): Call - rs6000_emit_probe_stack_range_stack_clash as needed. - (rs6000_emit_probe_stack_range): Add additional argument - to call to gen_probe_stack_range{si,di}. - (output_probe_stack_range): New. - (output_probe_stack_range_1): Renamed from output_probe_stack_range. - (output_probe_stack_range_stack_clash): New. - (rs6000_emit_prologue): Emit notes into dump file as requested. - * rs6000.md (allocate_stack): Handle -fstack-clash-protection. - (probe_stack_range): Operand 0 is now early-clobbered. - Add additional operand and pass it to output_probe_stack_range. - - * lib/target-supports.exp - (check_effective_target_supports_stack_clash_protection): Enable for - rs6000 and powerpc targets. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@253179 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/config/rs6000/rs6000-protos.h b/gcc/config/rs6000/rs6000-protos.h -index 74ad733d1b9..d48aa88f4b1 100644 ---- a/gcc/config/rs6000/rs6000-protos.h -+++ b/gcc/config/rs6000/rs6000-protos.h -@@ -134,7 +134,7 @@ extern void rs6000_emit_sCOND (machine_mode, rtx[]); - extern void rs6000_emit_cbranch (machine_mode, rtx[]); - extern char * output_cbranch (rtx, const char *, int, rtx_insn *); - extern char * output_e500_flip_gt_bit (rtx, rtx); --extern const char * output_probe_stack_range (rtx, rtx); -+extern const char * output_probe_stack_range (rtx, rtx, rtx); - extern bool rs6000_emit_set_const (rtx, rtx); - extern int rs6000_emit_cmove (rtx, rtx, rtx, rtx); - extern int rs6000_emit_vector_cond_expr (rtx, rtx, rtx, rtx, rtx, rtx); -diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c -index 1836e1d147d..8235bff2469 100644 ---- a/gcc/config/rs6000/rs6000.c -+++ b/gcc/config/rs6000/rs6000.c -@@ -28133,6 +28133,221 @@ rs6000_emit_stack_tie (rtx fp, bool hard_frame_needed) - emit_insn (gen_stack_tie (gen_rtx_PARALLEL (VOIDmode, p))); - } - -+/* Allocate SIZE_INT bytes on the stack using a store with update style insn -+ and set the appropriate attributes for the generated insn. Return the -+ first insn which adjusts the stack pointer or the last insn before -+ the stack adjustment loop. -+ -+ SIZE_INT is used to create the CFI note for the allocation. -+ -+ SIZE_RTX is an rtx containing the size of the adjustment. Note that -+ since stacks grow to lower addresses its runtime value is -SIZE_INT. -+ -+ ORIG_SP contains the backchain value that must be stored at *sp. */ -+ -+static rtx_insn * -+rs6000_emit_allocate_stack_1 (HOST_WIDE_INT size_int, rtx orig_sp) -+{ -+ rtx_insn *insn; -+ -+ rtx size_rtx = GEN_INT (-size_int); -+ if (size_int > 32767) -+ { -+ rtx tmp_reg = gen_rtx_REG (Pmode, 0); -+ /* Need a note here so that try_split doesn't get confused. */ -+ if (get_last_insn () == NULL_RTX) -+ emit_note (NOTE_INSN_DELETED); -+ insn = emit_move_insn (tmp_reg, size_rtx); -+ try_split (PATTERN (insn), insn, 0); -+ size_rtx = tmp_reg; -+ } -+ -+ if (Pmode == SImode) -+ insn = emit_insn (gen_movsi_update_stack (stack_pointer_rtx, -+ stack_pointer_rtx, -+ size_rtx, -+ orig_sp)); -+ else -+ insn = emit_insn (gen_movdi_di_update_stack (stack_pointer_rtx, -+ stack_pointer_rtx, -+ size_rtx, -+ orig_sp)); -+ rtx par = PATTERN (insn); -+ gcc_assert (GET_CODE (par) == PARALLEL); -+ rtx set = XVECEXP (par, 0, 0); -+ gcc_assert (GET_CODE (set) == SET); -+ rtx mem = SET_DEST (set); -+ gcc_assert (MEM_P (mem)); -+ MEM_NOTRAP_P (mem) = 1; -+ set_mem_alias_set (mem, get_frame_alias_set ()); -+ -+ RTX_FRAME_RELATED_P (insn) = 1; -+ add_reg_note (insn, REG_FRAME_RELATED_EXPR, -+ gen_rtx_SET (stack_pointer_rtx, -+ gen_rtx_PLUS (Pmode, -+ stack_pointer_rtx, -+ GEN_INT (-size_int)))); -+ -+ /* Emit a blockage to ensure the allocation/probing insns are -+ not optimized, combined, removed, etc. Add REG_STACK_CHECK -+ note for similar reasons. */ -+ if (flag_stack_clash_protection) -+ { -+ add_reg_note (insn, REG_STACK_CHECK, const0_rtx); -+ emit_insn (gen_blockage ()); -+ } -+ -+ return insn; -+} -+ -+static HOST_WIDE_INT -+get_stack_clash_protection_probe_interval (void) -+{ -+ return (HOST_WIDE_INT_1U -+ << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL)); -+} -+ -+static HOST_WIDE_INT -+get_stack_clash_protection_guard_size (void) -+{ -+ return (HOST_WIDE_INT_1U -+ << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE)); -+} -+ -+/* Allocate ORIG_SIZE bytes on the stack and probe the newly -+ allocated space every STACK_CLASH_PROTECTION_PROBE_INTERVAL bytes. -+ -+ COPY_REG, if non-null, should contain a copy of the original -+ stack pointer at exit from this function. -+ -+ This is subtly different than the Ada probing in that it tries hard to -+ prevent attacks that jump the stack guard. Thus it is never allowed to -+ allocate more than STACK_CLASH_PROTECTION_PROBE_INTERVAL bytes of stack -+ space without a suitable probe. */ -+static rtx_insn * -+rs6000_emit_probe_stack_range_stack_clash (HOST_WIDE_INT orig_size, -+ rtx copy_reg) -+{ -+ rtx orig_sp = copy_reg; -+ -+ HOST_WIDE_INT probe_interval = get_stack_clash_protection_probe_interval (); -+ -+ /* Round the size down to a multiple of PROBE_INTERVAL. */ -+ HOST_WIDE_INT rounded_size = ROUND_DOWN (orig_size, probe_interval); -+ -+ /* If explicitly requested, -+ or the rounded size is not the same as the original size -+ or the the rounded size is greater than a page, -+ then we will need a copy of the original stack pointer. */ -+ if (rounded_size != orig_size -+ || rounded_size > probe_interval -+ || copy_reg) -+ { -+ /* If the caller did not request a copy of the incoming stack -+ pointer, then we use r0 to hold the copy. */ -+ if (!copy_reg) -+ orig_sp = gen_rtx_REG (Pmode, 0); -+ emit_move_insn (orig_sp, stack_pointer_rtx); -+ } -+ -+ /* There's three cases here. -+ -+ One is a single probe which is the most common and most efficiently -+ implemented as it does not have to have a copy of the original -+ stack pointer if there are no residuals. -+ -+ Second is unrolled allocation/probes which we use if there's just -+ a few of them. It needs to save the original stack pointer into a -+ temporary for use as a source register in the allocation/probe. -+ -+ Last is a loop. This is the most uncommon case and least efficient. */ -+ rtx_insn *retval = NULL; -+ if (rounded_size == probe_interval) -+ { -+ retval = rs6000_emit_allocate_stack_1 (probe_interval, stack_pointer_rtx); -+ -+ dump_stack_clash_frame_info (PROBE_INLINE, rounded_size != orig_size); -+ } -+ else if (rounded_size <= 8 * probe_interval) -+ { -+ /* The ABI requires using the store with update insns to allocate -+ space and store the backchain into the stack -+ -+ So we save the current stack pointer into a temporary, then -+ emit the store-with-update insns to store the saved stack pointer -+ into the right location in each new page. */ -+ for (int i = 0; i < rounded_size; i += probe_interval) -+ { -+ rtx_insn *insn -+ = rs6000_emit_allocate_stack_1 (probe_interval, orig_sp); -+ -+ /* Save the first stack adjustment in RETVAL. */ -+ if (i == 0) -+ retval = insn; -+ } -+ -+ dump_stack_clash_frame_info (PROBE_INLINE, rounded_size != orig_size); -+ } -+ else -+ { -+ /* Compute the ending address. */ -+ rtx end_addr -+ = copy_reg ? gen_rtx_REG (Pmode, 0) : gen_rtx_REG (Pmode, 12); -+ rtx rs = GEN_INT (-rounded_size); -+ rtx_insn *insn; -+ if (add_operand (rs, Pmode)) -+ insn = emit_insn (gen_add3_insn (end_addr, stack_pointer_rtx, rs)); -+ else -+ { -+ emit_move_insn (end_addr, GEN_INT (-rounded_size)); -+ insn = emit_insn (gen_add3_insn (end_addr, end_addr, -+ stack_pointer_rtx)); -+ /* Describe the effect of INSN to the CFI engine. */ -+ add_reg_note (insn, REG_FRAME_RELATED_EXPR, -+ gen_rtx_SET (end_addr, -+ gen_rtx_PLUS (Pmode, stack_pointer_rtx, -+ rs))); -+ } -+ RTX_FRAME_RELATED_P (insn) = 1; -+ -+ /* Emit the loop. */ -+ if (TARGET_64BIT) -+ retval = emit_insn (gen_probe_stack_rangedi (stack_pointer_rtx, -+ stack_pointer_rtx, orig_sp, -+ end_addr)); -+ else -+ retval = emit_insn (gen_probe_stack_rangesi (stack_pointer_rtx, -+ stack_pointer_rtx, orig_sp, -+ end_addr)); -+ RTX_FRAME_RELATED_P (retval) = 1; -+ /* Describe the effect of INSN to the CFI engine. */ -+ add_reg_note (retval, REG_FRAME_RELATED_EXPR, -+ gen_rtx_SET (stack_pointer_rtx, end_addr)); -+ -+ /* Emit a blockage to ensure the allocation/probing insns are -+ not optimized, combined, removed, etc. Other cases handle this -+ within their call to rs6000_emit_allocate_stack_1. */ -+ emit_insn (gen_blockage ()); -+ -+ dump_stack_clash_frame_info (PROBE_LOOP, rounded_size != orig_size); -+ } -+ -+ if (orig_size != rounded_size) -+ { -+ /* Allocate (and implicitly probe) any residual space. */ -+ HOST_WIDE_INT residual = orig_size - rounded_size; -+ -+ rtx_insn *insn = rs6000_emit_allocate_stack_1 (residual, orig_sp); -+ -+ /* If the residual was the only allocation, then we can return the -+ allocating insn. */ -+ if (!retval) -+ retval = insn; -+ } -+ -+ return retval; -+} -+ - /* Emit the correct code for allocating stack space, as insns. - If COPY_REG, make sure a copy of the old frame is left there. - The generated code may use hard register 0 as a temporary. */ -@@ -28144,7 +28359,6 @@ rs6000_emit_allocate_stack (HOST_WIDE_INT size, rtx copy_reg, int copy_off) - rtx stack_reg = gen_rtx_REG (Pmode, STACK_POINTER_REGNUM); - rtx tmp_reg = gen_rtx_REG (Pmode, 0); - rtx todec = gen_int_mode (-size, Pmode); -- rtx par, set, mem; - - if (INTVAL (todec) != -size) - { -@@ -28184,6 +28398,23 @@ rs6000_emit_allocate_stack (HOST_WIDE_INT size, rtx copy_reg, int copy_off) - warning (0, "stack limit expression is not supported"); - } - -+ if (flag_stack_clash_protection) -+ { -+ if (size < get_stack_clash_protection_guard_size ()) -+ dump_stack_clash_frame_info (NO_PROBE_SMALL_FRAME, true); -+ else -+ { -+ rtx_insn *insn = rs6000_emit_probe_stack_range_stack_clash (size, -+ copy_reg); -+ -+ /* If we asked for a copy with an offset, then we still need add in -+ the offset. */ -+ if (copy_reg && copy_off) -+ emit_insn (gen_add3_insn (copy_reg, copy_reg, GEN_INT (copy_off))); -+ return insn; -+ } -+ } -+ - if (copy_reg) - { - if (copy_off != 0) -@@ -28192,38 +28423,11 @@ rs6000_emit_allocate_stack (HOST_WIDE_INT size, rtx copy_reg, int copy_off) - emit_move_insn (copy_reg, stack_reg); - } - -- if (size > 32767) -- { -- /* Need a note here so that try_split doesn't get confused. */ -- if (get_last_insn () == NULL_RTX) -- emit_note (NOTE_INSN_DELETED); -- insn = emit_move_insn (tmp_reg, todec); -- try_split (PATTERN (insn), insn, 0); -- todec = tmp_reg; -- } -- -- insn = emit_insn (TARGET_32BIT -- ? gen_movsi_update_stack (stack_reg, stack_reg, -- todec, stack_reg) -- : gen_movdi_di_update_stack (stack_reg, stack_reg, -- todec, stack_reg)); - /* Since we didn't use gen_frame_mem to generate the MEM, grab - it now and set the alias set/attributes. The above gen_*_update - calls will generate a PARALLEL with the MEM set being the first - operation. */ -- par = PATTERN (insn); -- gcc_assert (GET_CODE (par) == PARALLEL); -- set = XVECEXP (par, 0, 0); -- gcc_assert (GET_CODE (set) == SET); -- mem = SET_DEST (set); -- gcc_assert (MEM_P (mem)); -- MEM_NOTRAP_P (mem) = 1; -- set_mem_alias_set (mem, get_frame_alias_set ()); -- -- RTX_FRAME_RELATED_P (insn) = 1; -- add_reg_note (insn, REG_FRAME_RELATED_EXPR, -- gen_rtx_SET (stack_reg, gen_rtx_PLUS (Pmode, stack_reg, -- GEN_INT (-size)))); -+ insn = rs6000_emit_allocate_stack_1 (size, stack_reg); - return insn; - } - -@@ -28305,9 +28509,9 @@ rs6000_emit_probe_stack_range (HOST_WIDE_INT first, HOST_WIDE_INT size) - until it is equal to ROUNDED_SIZE. */ - - if (TARGET_64BIT) -- emit_insn (gen_probe_stack_rangedi (r12, r12, r0)); -+ emit_insn (gen_probe_stack_rangedi (r12, r12, stack_pointer_rtx, r0)); - else -- emit_insn (gen_probe_stack_rangesi (r12, r12, r0)); -+ emit_insn (gen_probe_stack_rangesi (r12, r12, stack_pointer_rtx, r0)); - - - /* Step 4: probe at FIRST + SIZE if we cannot assert at compile-time -@@ -28319,10 +28523,10 @@ rs6000_emit_probe_stack_range (HOST_WIDE_INT first, HOST_WIDE_INT size) - } - - /* Probe a range of stack addresses from REG1 to REG2 inclusive. These are -- absolute addresses. */ -+ addresses, not offsets. */ - --const char * --output_probe_stack_range (rtx reg1, rtx reg2) -+static const char * -+output_probe_stack_range_1 (rtx reg1, rtx reg2) - { - static int labelno = 0; - char loop_lab[32]; -@@ -28357,6 +28561,95 @@ output_probe_stack_range (rtx reg1, rtx reg2) - return ""; - } - -+/* This function is called when rs6000_frame_related is processing -+ SETs within a PARALLEL, and returns whether the REGNO save ought to -+ be marked RTX_FRAME_RELATED_P. The PARALLELs involved are those -+ for out-of-line register save functions, store multiple, and the -+ Darwin world_save. They may contain registers that don't really -+ need saving. */ -+ -+static bool -+interesting_frame_related_regno (unsigned int regno) -+{ -+ /* Saves apparently of r0 are actually saving LR. It doesn't make -+ sense to substitute the regno here to test save_reg_p (LR_REGNO). -+ We *know* LR needs saving, and dwarf2cfi.c is able to deduce that -+ (set (mem) (r0)) is saving LR from a prior (set (r0) (lr)) marked -+ as frame related. */ -+ if (regno == 0) -+ return true; -+ /* If we see CR2 then we are here on a Darwin world save. Saves of -+ CR2 signify the whole CR is being saved. This is a long-standing -+ ABI wart fixed by ELFv2. As for r0/lr there is no need to check -+ that CR needs to be saved. */ -+ if (regno == CR2_REGNO) -+ return true; -+ /* Omit frame info for any user-defined global regs. If frame info -+ is supplied for them, frame unwinding will restore a user reg. -+ Also omit frame info for any reg we don't need to save, as that -+ bloats frame info and can cause problems with shrink wrapping. -+ Since global regs won't be seen as needing to be saved, both of -+ these conditions are covered by save_reg_p. */ -+ return save_reg_p (regno); -+} -+ -+/* Probe a range of stack addresses from REG1 to REG3 inclusive. These are -+ addresses, not offsets. -+ -+ REG2 contains the backchain that must be stored into *sp at each allocation. -+ -+ This is subtly different than the Ada probing above in that it tries hard -+ to prevent attacks that jump the stack guard. Thus, it is never allowed -+ to allocate more than PROBE_INTERVAL bytes of stack space without a -+ suitable probe. */ -+ -+static const char * -+output_probe_stack_range_stack_clash (rtx reg1, rtx reg2, rtx reg3) -+{ -+ static int labelno = 0; -+ char loop_lab[32]; -+ rtx xops[3]; -+ -+ HOST_WIDE_INT probe_interval = get_stack_clash_protection_probe_interval (); -+ -+ ASM_GENERATE_INTERNAL_LABEL (loop_lab, "LPSRL", labelno++); -+ -+ ASM_OUTPUT_INTERNAL_LABEL (asm_out_file, loop_lab); -+ -+ /* This allocates and probes. */ -+ xops[0] = reg1; -+ xops[1] = reg2; -+ xops[2] = GEN_INT (-probe_interval); -+ if (TARGET_64BIT) -+ output_asm_insn ("stdu %1,%2(%0)", xops); -+ else -+ output_asm_insn ("stwu %1,%2(%0)", xops); -+ -+ /* Jump to LOOP_LAB if TEST_ADDR != LAST_ADDR. */ -+ xops[0] = reg1; -+ xops[1] = reg3; -+ if (TARGET_64BIT) -+ output_asm_insn ("cmpd 0,%0,%1", xops); -+ else -+ output_asm_insn ("cmpw 0,%0,%1", xops); -+ -+ fputs ("\tbne 0,", asm_out_file); -+ assemble_name_raw (asm_out_file, loop_lab); -+ fputc ('\n', asm_out_file); -+ -+ return ""; -+} -+ -+/* Wrapper around the output_probe_stack_range routines. */ -+const char * -+output_probe_stack_range (rtx reg1, rtx reg2, rtx reg3) -+{ -+ if (flag_stack_clash_protection) -+ return output_probe_stack_range_stack_clash (reg1, reg2, reg3); -+ else -+ return output_probe_stack_range_1 (reg1, reg3); -+} -+ - /* Add to 'insn' a note which is PATTERN (INSN) but with REG replaced - with (plus:P (reg 1) VAL), and with REG2 replaced with REPL2 if REG2 - is not NULL. It would be nice if dwarf2out_frame_debug_expr could -@@ -29951,6 +30244,13 @@ rs6000_emit_prologue (void) - } - } - -+ /* If we are emitting stack probes, but allocate no stack, then -+ just note that in the dump file. */ -+ if (flag_stack_clash_protection -+ && dump_file -+ && !info->push_p) -+ dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false); -+ - /* Update stack and set back pointer unless this is V.4, - for which it was done previously. */ - if (!WORLD_SAVE_P (info) && info->push_p -diff --git a/gcc/config/rs6000/rs6000.md b/gcc/config/rs6000/rs6000.md -index 3323976a35d..843148e9703 100644 ---- a/gcc/config/rs6000/rs6000.md -+++ b/gcc/config/rs6000/rs6000.md -@@ -10386,10 +10386,20 @@ - ;; - ;; First, an insn to allocate new stack space for dynamic use (e.g., alloca). - ;; We move the back-chain and decrement the stack pointer. -- -+;; -+;; Operand1 is more naturally reg_or_short_operand. However, for a large -+;; constant alloca, using that predicate will force the generic code to put -+;; the constant size into a register before calling the expander. -+;; -+;; As a result the expander would not have the constant size information -+;; in those cases and would have to generate less efficient code. -+;; -+;; Thus we allow reg_or_cint_operand instead so that the expander can see -+;; the constant size. The value is forced into a register if necessary. -+;; - (define_expand "allocate_stack" - [(set (match_operand 0 "gpc_reg_operand" "") -- (minus (reg 1) (match_operand 1 "reg_or_short_operand" ""))) -+ (minus (reg 1) (match_operand 1 "reg_or_cint_operand" ""))) - (set (reg 1) - (minus (reg 1) (match_dup 1)))] - "" -@@ -10399,6 +10409,15 @@ - rtx neg_op0; - rtx insn, par, set, mem; - -+ /* By allowing reg_or_cint_operand as the predicate we can get -+ better code for stack-clash-protection because we do not lose -+ size information. But the rest of the code expects the operand -+ to be reg_or_short_operand. If it isn't, then force it into -+ a register. */ -+ rtx orig_op1 = operands[1]; -+ if (!reg_or_short_operand (operands[1], Pmode)) -+ operands[1] = force_reg (Pmode, operands[1]); -+ - emit_move_insn (chain, stack_bot); - - /* Check stack bounds if necessary. */ -@@ -10411,6 +10430,51 @@ - emit_insn (gen_cond_trap (LTU, available, operands[1], const0_rtx)); - } - -+ /* Allocate and probe if requested. -+ This may look similar to the loop we use for prologue allocations, -+ but it is critically different. For the former we know the loop -+ will iterate, but do not know that generally here. The former -+ uses that knowledge to rotate the loop. Combining them would be -+ possible with some performance cost. */ -+ if (flag_stack_clash_protection) -+ { -+ rtx rounded_size, last_addr, residual; -+ HOST_WIDE_INT probe_interval; -+ compute_stack_clash_protection_loop_data (&rounded_size, &last_addr, -+ &residual, &probe_interval, -+ orig_op1); -+ -+ /* We do occasionally get in here with constant sizes, we might -+ as well do a reasonable job when we obviously can. */ -+ if (rounded_size != const0_rtx) -+ { -+ rtx loop_lab, end_loop; -+ bool rotated = CONST_INT_P (rounded_size); -+ -+ emit_stack_clash_protection_probe_loop_start (&loop_lab, &end_loop, -+ last_addr, rotated); -+ -+ if (Pmode == SImode) -+ emit_insn (gen_movsi_update_stack (stack_pointer_rtx, -+ stack_pointer_rtx, -+ GEN_INT (-probe_interval), -+ chain)); -+ else -+ emit_insn (gen_movdi_di_update_stack (stack_pointer_rtx, -+ stack_pointer_rtx, -+ GEN_INT (-probe_interval), -+ chain)); -+ emit_stack_clash_protection_probe_loop_end (loop_lab, end_loop, -+ last_addr, rotated); -+ } -+ -+ /* Now handle residuals. We just have to set operands[1] correctly -+ and let the rest of the expander run. */ -+ operands[1] = residual; -+ if (!CONST_INT_P (residual)) -+ operands[1] = force_reg (Pmode, operands[1]); -+ } -+ - if (GET_CODE (operands[1]) != CONST_INT - || INTVAL (operands[1]) < -32767 - || INTVAL (operands[1]) > 32768) -@@ -11549,12 +11613,13 @@ - (set_attr "length" "4")]) - - (define_insn "probe_stack_range" -- [(set (match_operand:P 0 "register_operand" "=r") -+ [(set (match_operand:P 0 "register_operand" "=&r") - (unspec_volatile:P [(match_operand:P 1 "register_operand" "0") -- (match_operand:P 2 "register_operand" "r")] -+ (match_operand:P 2 "register_operand" "r") -+ (match_operand:P 3 "register_operand" "r")] - UNSPECV_PROBE_STACK_RANGE))] - "" -- "* return output_probe_stack_range (operands[0], operands[2]);" -+ "* return output_probe_stack_range (operands[0], operands[2], operands[3]);" - [(set_attr "type" "three")]) - - ;; Compare insns are next. Note that the RS/6000 has two types of compares, -diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp -index cb58a2be35f..02eb2066393 100644 ---- a/gcc/testsuite/lib/target-supports.exp -+++ b/gcc/testsuite/lib/target-supports.exp -@@ -8385,12 +8385,12 @@ proc check_effective_target_arm_coproc4_ok { } { - proc check_effective_target_supports_stack_clash_protection { } { - - # Temporary until the target bits are fully ACK'd. --# if { [istarget aarch*-*-*] --# || [istarget powerpc*-*-*] || [istarget rs6000*-*-*] } { -+# if { [istarget aarch*-*-*] } { - # return 1 - # } - - if { [istarget x86_64-*-*] || [istarget i?86-*-*] -+ || [istarget powerpc*-*-*] || [istarget rs6000*-*-*] - || [istarget s390*-*-*] } { - return 1 - } diff --git a/gcc7-rh1512529-11.patch b/gcc7-rh1512529-11.patch deleted file mode 100644 index 4d9c746..0000000 --- a/gcc7-rh1512529-11.patch +++ /dev/null @@ -1,28 +0,0 @@ -commit eecbe7ada9a8ab913e779a27c0e90ec736eedc78 -Author: law -Date: Fri Nov 3 17:14:23 2017 +0000 - - * config/i386/i386.c (ix86_expand_prologue): Tighten assert - for int_registers_saved. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@254386 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c -index 086848b2c73..fd74f1f6c0c 100644 ---- a/gcc/config/i386/i386.c -+++ b/gcc/config/i386/i386.c -@@ -14172,8 +14172,12 @@ ix86_expand_prologue (void) - && (flag_stack_check == STATIC_BUILTIN_STACK_CHECK - || flag_stack_clash_protection)) - { -- /* We expect the registers to be saved when probes are used. */ -- gcc_assert (int_registers_saved); -+ /* This assert wants to verify that integer registers were saved -+ prior to probing. This is necessary when probing may be implemented -+ as a function call (Windows). It is not necessary for stack clash -+ protection probing. */ -+ if (!flag_stack_clash_protection) -+ gcc_assert (int_registers_saved); - - if (flag_stack_clash_protection) - { diff --git a/gcc7-rh1512529-12.patch b/gcc7-rh1512529-12.patch deleted file mode 100644 index 3f2786e..0000000 --- a/gcc7-rh1512529-12.patch +++ /dev/null @@ -1,81 +0,0 @@ -commit 75179275ecc35724a058676199188e0d13e65054 -Author: law -Date: Fri Nov 3 20:30:53 2017 +0000 - - * config/i386/i386.c (ix86_emit_restore_reg_using_pop): Prototype. - (ix86_adjust_stack_and_probe_stack_clash): Use a push/pop sequence - to probe at the start of a noreturn function. - - * gcc.target/i386/stack-check-12.c: New test. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@254396 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c -index fd74f1f6c0c..3c828ba492d 100644 ---- a/gcc/config/i386/i386.c -+++ b/gcc/config/i386/i386.c -@@ -96,6 +96,7 @@ static rtx legitimize_dllimport_symbol (rtx, bool); - static rtx legitimize_pe_coff_extern_decl (rtx, bool); - static rtx legitimize_pe_coff_symbol (rtx, bool); - static void ix86_print_operand_address_as (FILE *, rtx, addr_space_t, bool); -+static void ix86_emit_restore_reg_using_pop (rtx); - - #ifndef CHECK_STACK_LIMIT - #define CHECK_STACK_LIMIT (-1) -@@ -13287,10 +13288,13 @@ ix86_adjust_stack_and_probe_stack_clash (const HOST_WIDE_INT size) - no probes are needed. */ - if (!size) - { -+ struct ix86_frame frame; -+ ix86_compute_frame_layout (&frame); -+ - /* However, the allocation of space via pushes for register - saves could be viewed as allocating space, but without the - need to probe. */ -- if (m->frame.nregs || m->frame.nsseregs || frame_pointer_needed) -+ if (frame.nregs || frame.nsseregs || frame_pointer_needed) - dump_stack_clash_frame_info (NO_PROBE_SMALL_FRAME, true); - else - dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false); -@@ -13312,8 +13316,14 @@ ix86_adjust_stack_and_probe_stack_clash (const HOST_WIDE_INT size) - we just probe when we cross PROBE_INTERVAL. */ - if (TREE_THIS_VOLATILE (cfun->decl)) - { -- emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, -- -GET_MODE_SIZE (word_mode))); -+ /* We can safely use any register here since we're just going to push -+ its value and immediately pop it back. But we do try and avoid -+ argument passing registers so as not to introduce dependencies in -+ the pipeline. For 32 bit we use %esi and for 64 bit we use %rax. */ -+ rtx dummy_reg = gen_rtx_REG (word_mode, TARGET_64BIT ? AX_REG : SI_REG); -+ rtx_insn *insn = emit_insn (gen_push (dummy_reg)); -+ RTX_FRAME_RELATED_P (insn) = 1; -+ ix86_emit_restore_reg_using_pop (dummy_reg); - emit_insn (gen_blockage ()); - } - -diff --git a/gcc/testsuite/gcc.target/i386/stack-check-12.c b/gcc/testsuite/gcc.target/i386/stack-check-12.c -new file mode 100644 -index 00000000000..cb69bb08086 ---- /dev/null -+++ b/gcc/testsuite/gcc.target/i386/stack-check-12.c -@@ -0,0 +1,19 @@ -+/* { dg-do compile } */ -+/* { dg-options "-O2 -fstack-clash-protection -mtune=generic" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+__attribute__ ((noreturn)) void exit (int); -+ -+__attribute__ ((noreturn)) void -+f (void) -+{ -+ asm volatile ("nop" ::: "edi"); -+ exit (1); -+} -+ -+/* { dg-final { scan-assembler-not "or\[ql\]" } } */ -+/* { dg-final { scan-assembler "pushl %esi" { target ia32 } } } */ -+/* { dg-final { scan-assembler "popl %esi" { target ia32 } } }*/ -+/* { dg-final { scan-assembler "pushq %rax" { target { ! ia32 } } } } */ -+/* { dg-final { scan-assembler "popq %rax" { target { ! ia32 } } } }*/ -+ diff --git a/gcc7-rh1512529-13.patch b/gcc7-rh1512529-13.patch deleted file mode 100644 index 8221622..0000000 --- a/gcc7-rh1512529-13.patch +++ /dev/null @@ -1,228 +0,0 @@ -commit 2f97a7844f2211bbd4fd869c18e26801bb795aa9 -Author: law -Date: Mon Nov 6 15:51:16 2017 +0000 - - PR target/82788 - * config/i386/i386.c (PROBE_INTERVAL): Remove. - (get_probe_interval): New functions. - (ix86_adjust_stack_and_probe_stack_clash): Use get_probe_interval. - (ix86_adjust_stack_and_probe): Likewise. - (output_adjust_stack_and_probe): Likewise. - (ix86_emit_probe_stack_range): Likewise. - (ix86_expand_prologue): Likewise. - - PR target/82788 - * gcc.dg/pr82788.c: New test. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@254456 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c -index acd192a98c5..a904afe828d 100644 ---- a/gcc/config/i386/i386.c -+++ b/gcc/config/i386/i386.c -@@ -13270,7 +13270,17 @@ release_scratch_register_on_entry (struct scratch_reg *sr) - } - } - --#define PROBE_INTERVAL (1 << STACK_CHECK_PROBE_INTERVAL_EXP) -+/* Return the probing interval for -fstack-clash-protection. */ -+ -+static HOST_WIDE_INT -+get_probe_interval (void) -+{ -+ if (flag_stack_clash_protection) -+ return (HOST_WIDE_INT_1U -+ << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL)); -+ else -+ return (HOST_WIDE_INT_1U << STACK_CHECK_PROBE_INTERVAL_EXP); -+} - - /* Emit code to adjust the stack pointer by SIZE bytes while probing it. - -@@ -13339,8 +13349,7 @@ ix86_adjust_stack_and_probe_stack_clash (const HOST_WIDE_INT size) - /* We're allocating a large enough stack frame that we need to - emit probes. Either emit them inline or in a loop depending - on the size. */ -- HOST_WIDE_INT probe_interval -- = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL); -+ HOST_WIDE_INT probe_interval = get_probe_interval (); - if (size <= 4 * probe_interval) - { - HOST_WIDE_INT i; -@@ -13349,7 +13358,7 @@ ix86_adjust_stack_and_probe_stack_clash (const HOST_WIDE_INT size) - /* Allocate PROBE_INTERVAL bytes. */ - rtx insn - = pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx, -- GEN_INT (-PROBE_INTERVAL), -1, -+ GEN_INT (-probe_interval), -1, - m->fs.cfa_reg == stack_pointer_rtx); - add_reg_note (insn, REG_STACK_CHECK, const0_rtx); - -@@ -13442,7 +13451,7 @@ ix86_adjust_stack_and_probe (const HOST_WIDE_INT size) - that's the easy case. The run-time loop is made up of 9 insns in the - generic case while the compile-time loop is made up of 3+2*(n-1) insns - for n # of intervals. */ -- if (size <= 4 * PROBE_INTERVAL) -+ if (size <= 4 * get_probe_interval ()) - { - HOST_WIDE_INT i, adjust; - bool first_probe = true; -@@ -13451,15 +13460,15 @@ ix86_adjust_stack_and_probe (const HOST_WIDE_INT size) - values of N from 1 until it exceeds SIZE. If only one probe is - needed, this will not generate any code. Then adjust and probe - to PROBE_INTERVAL + SIZE. */ -- for (i = PROBE_INTERVAL; i < size; i += PROBE_INTERVAL) -+ for (i = get_probe_interval (); i < size; i += get_probe_interval ()) - { - if (first_probe) - { -- adjust = 2 * PROBE_INTERVAL + dope; -+ adjust = 2 * get_probe_interval () + dope; - first_probe = false; - } - else -- adjust = PROBE_INTERVAL; -+ adjust = get_probe_interval (); - - emit_insn (gen_rtx_SET (stack_pointer_rtx, - plus_constant (Pmode, stack_pointer_rtx, -@@ -13468,9 +13477,9 @@ ix86_adjust_stack_and_probe (const HOST_WIDE_INT size) - } - - if (first_probe) -- adjust = size + PROBE_INTERVAL + dope; -+ adjust = size + get_probe_interval () + dope; - else -- adjust = size + PROBE_INTERVAL - i; -+ adjust = size + get_probe_interval () - i; - - emit_insn (gen_rtx_SET (stack_pointer_rtx, - plus_constant (Pmode, stack_pointer_rtx, -@@ -13480,7 +13489,8 @@ ix86_adjust_stack_and_probe (const HOST_WIDE_INT size) - /* Adjust back to account for the additional first interval. */ - last = emit_insn (gen_rtx_SET (stack_pointer_rtx, - plus_constant (Pmode, stack_pointer_rtx, -- PROBE_INTERVAL + dope))); -+ (get_probe_interval () -+ + dope)))); - } - - /* Otherwise, do the same as above, but in a loop. Note that we must be -@@ -13498,7 +13508,7 @@ ix86_adjust_stack_and_probe (const HOST_WIDE_INT size) - - /* Step 1: round SIZE to the previous multiple of the interval. */ - -- rounded_size = ROUND_DOWN (size, PROBE_INTERVAL); -+ rounded_size = ROUND_DOWN (size, get_probe_interval ()); - - - /* Step 2: compute initial and final value of the loop counter. */ -@@ -13506,7 +13516,7 @@ ix86_adjust_stack_and_probe (const HOST_WIDE_INT size) - /* SP = SP_0 + PROBE_INTERVAL. */ - emit_insn (gen_rtx_SET (stack_pointer_rtx, - plus_constant (Pmode, stack_pointer_rtx, -- - (PROBE_INTERVAL + dope)))); -+ - (get_probe_interval () + dope)))); - - /* LAST_ADDR = SP_0 + PROBE_INTERVAL + ROUNDED_SIZE. */ - if (rounded_size <= (HOST_WIDE_INT_1 << 31)) -@@ -13551,7 +13561,8 @@ ix86_adjust_stack_and_probe (const HOST_WIDE_INT size) - /* Adjust back to account for the additional first interval. */ - last = emit_insn (gen_rtx_SET (stack_pointer_rtx, - plus_constant (Pmode, stack_pointer_rtx, -- PROBE_INTERVAL + dope))); -+ (get_probe_interval () -+ + dope)))); - - release_scratch_register_on_entry (&sr); - } -@@ -13568,7 +13579,7 @@ ix86_adjust_stack_and_probe (const HOST_WIDE_INT size) - XVECEXP (expr, 0, 1) - = gen_rtx_SET (stack_pointer_rtx, - plus_constant (Pmode, stack_pointer_rtx, -- PROBE_INTERVAL + dope + size)); -+ get_probe_interval () + dope + size)); - add_reg_note (last, REG_FRAME_RELATED_EXPR, expr); - RTX_FRAME_RELATED_P (last) = 1; - -@@ -13595,7 +13606,7 @@ output_adjust_stack_and_probe (rtx reg) - - /* SP = SP + PROBE_INTERVAL. */ - xops[0] = stack_pointer_rtx; -- xops[1] = GEN_INT (PROBE_INTERVAL); -+ xops[1] = GEN_INT (get_probe_interval ()); - output_asm_insn ("sub%z0\t{%1, %0|%0, %1}", xops); - - /* Probe at SP. */ -@@ -13625,14 +13636,14 @@ ix86_emit_probe_stack_range (HOST_WIDE_INT first, HOST_WIDE_INT size) - that's the easy case. The run-time loop is made up of 6 insns in the - generic case while the compile-time loop is made up of n insns for n # - of intervals. */ -- if (size <= 6 * PROBE_INTERVAL) -+ if (size <= 6 * get_probe_interval ()) - { - HOST_WIDE_INT i; - - /* Probe at FIRST + N * PROBE_INTERVAL for values of N from 1 until - it exceeds SIZE. If only one probe is needed, this will not - generate any code. Then probe at FIRST + SIZE. */ -- for (i = PROBE_INTERVAL; i < size; i += PROBE_INTERVAL) -+ for (i = get_probe_interval (); i < size; i += get_probe_interval ()) - emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, - -(first + i))); - -@@ -13655,7 +13666,7 @@ ix86_emit_probe_stack_range (HOST_WIDE_INT first, HOST_WIDE_INT size) - - /* Step 1: round SIZE to the previous multiple of the interval. */ - -- rounded_size = ROUND_DOWN (size, PROBE_INTERVAL); -+ rounded_size = ROUND_DOWN (size, get_probe_interval ()); - - - /* Step 2: compute initial and final value of the loop counter. */ -@@ -13716,7 +13727,7 @@ output_probe_stack_range (rtx reg, rtx end) - - /* TEST_ADDR = TEST_ADDR + PROBE_INTERVAL. */ - xops[0] = reg; -- xops[1] = GEN_INT (PROBE_INTERVAL); -+ xops[1] = GEN_INT (get_probe_interval ()); - output_asm_insn ("sub%z0\t{%1, %0|%0, %1}", xops); - - /* Probe at TEST_ADDR. */ -@@ -14194,7 +14205,7 @@ ix86_expand_prologue (void) - else if (STACK_CHECK_MOVING_SP) - { - if (!(crtl->is_leaf && !cfun->calls_alloca -- && allocate <= PROBE_INTERVAL)) -+ && allocate <= get_probe_interval ())) - { - ix86_adjust_stack_and_probe (allocate); - allocate = 0; -@@ -14211,7 +14222,7 @@ ix86_expand_prologue (void) - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (size > PROBE_INTERVAL) -+ if (size > get_probe_interval ()) - ix86_emit_probe_stack_range (0, size); - } - else -@@ -14222,7 +14233,7 @@ ix86_expand_prologue (void) - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (size > PROBE_INTERVAL -+ if (size > get_probe_interval () - && size > get_stack_check_protect ()) - ix86_emit_probe_stack_range (get_stack_check_protect (), - size - get_stack_check_protect ()); -diff --git a/gcc/testsuite/gcc.dg/pr82788.c b/gcc/testsuite/gcc.dg/pr82788.c -new file mode 100644 -index 00000000000..a8f628fd7f6 ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/pr82788.c -@@ -0,0 +1,4 @@ -+/* { dg-do run } */ -+/* { dg-options "-O2 -fstack-clash-protection --param stack-clash-protection-probe-interval=10 --param stack-clash-protection-guard-size=12" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+int main() { int a[1442]; return 0;} diff --git a/gcc7-rh1512529-14.patch b/gcc7-rh1512529-14.patch deleted file mode 100644 index b79edf8..0000000 --- a/gcc7-rh1512529-14.patch +++ /dev/null @@ -1,43 +0,0 @@ -commit 799fb6fee433891510ab613a024450c926cdb4b3 -Author: law -Date: Wed Nov 15 06:30:31 2017 +0000 - - * explow.c (anti_adjust_stack_and_probe_stack_clash): Avoid probing - the red zone for stack_clash_protection_final_dynamic_probe targets - when the total dynamic stack size is zero bytes. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@254753 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/explow.c b/gcc/explow.c -index 6af6355fe30..53c4a6d7db9 100644 ---- a/gcc/explow.c -+++ b/gcc/explow.c -@@ -1978,6 +1978,13 @@ anti_adjust_stack_and_probe_stack_clash (rtx size) - if (size != CONST0_RTX (Pmode) - && targetm.stack_clash_protection_final_dynamic_probe (residual)) - { -+ /* SIZE could be zero at runtime and in that case *sp could hold -+ live data. Furthermore, we don't want to probe into the red -+ zone. -+ -+ Go ahead and just guard a probe at *sp on SIZE != 0 at runtime -+ if SIZE is not a compile time constant. */ -+ - /* Ideally we would just probe at *sp. However, if SIZE is not - a compile-time constant, but is zero at runtime, then *sp - might hold live data. So probe at *sp if we know that -@@ -1990,9 +1997,12 @@ anti_adjust_stack_and_probe_stack_clash (rtx size) - } - else - { -- emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, -- -GET_MODE_SIZE (word_mode))); -+ rtx label = gen_label_rtx (); -+ emit_cmp_and_jump_insns (size, CONST0_RTX (GET_MODE (size)), -+ EQ, NULL_RTX, Pmode, 1, label); -+ emit_stack_probe (stack_pointer_rtx); - emit_insn (gen_blockage ()); -+ emit_label (label); - } - } - } diff --git a/gcc7-rh1512529-15.patch b/gcc7-rh1512529-15.patch deleted file mode 100644 index 90f7afd..0000000 --- a/gcc7-rh1512529-15.patch +++ /dev/null @@ -1,46 +0,0 @@ -commit df7f99d5297f3c592401d7312c481578a8a62991 -Author: Jeff Law -Date: Wed Nov 22 11:55:10 2017 -0700 - - * gcc.dg/stack-check-5.c: Skip with -fstack-protector. - * gcc.dg/stack-check-6.c: Likewise. - * gcc.dg/stack-check-6a.c: Likewise. - -diff --git a/gcc/testsuite/gcc.dg/stack-check-5.c b/gcc/testsuite/gcc.dg/stack-check-5.c -index 3178f5d8ce5..dd9f8dbf607 100644 ---- a/gcc/testsuite/gcc.dg/stack-check-5.c -+++ b/gcc/testsuite/gcc.dg/stack-check-5.c -@@ -1,6 +1,8 @@ - /* { dg-do compile } */ - /* { 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" } */ - /* { dg-require-effective-target supports_stack_clash_protection } */ -+/* { dg-skip-if "" { *-*-* } { "-fstack-protector" } { "" } } */ -+ - - - /* Otherwise the S/390 back-end might save the stack pointer in f2 () -diff --git a/gcc/testsuite/gcc.dg/stack-check-6.c b/gcc/testsuite/gcc.dg/stack-check-6.c -index ad2021c9037..83559c5533c 100644 ---- a/gcc/testsuite/gcc.dg/stack-check-6.c -+++ b/gcc/testsuite/gcc.dg/stack-check-6.c -@@ -1,6 +1,8 @@ - /* { dg-do compile } */ - /* { 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" } */ - /* { dg-require-effective-target supports_stack_clash_protection } */ -+/* { dg-skip-if "" { *-*-* } { "-fstack-protector" } { "" } } */ -+ - - - extern void foo (char *); -diff --git a/gcc/testsuite/gcc.dg/stack-check-6a.c b/gcc/testsuite/gcc.dg/stack-check-6a.c -index 6f8e7128921..a1a2acbd6bd 100644 ---- a/gcc/testsuite/gcc.dg/stack-check-6a.c -+++ b/gcc/testsuite/gcc.dg/stack-check-6a.c -@@ -4,6 +4,7 @@ - /* { dg-do compile } */ - /* { 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" } */ - /* { dg-require-effective-target supports_stack_clash_protection } */ -+/* { dg-skip-if "" { *-*-* } { "-fstack-protector" } { "" } } */ - - #include "stack-check-6.c" - diff --git a/gcc7-rh1512529-16.patch b/gcc7-rh1512529-16.patch deleted file mode 100644 index 0211044..0000000 --- a/gcc7-rh1512529-16.patch +++ /dev/null @@ -1,2498 +0,0 @@ -commit 3dfd5ffd7ce1f940e474a0e7718d968b00a2a7c8 -Author: Jeff Law -Date: Wed Nov 22 12:01:56 2017 -0700 - - aarch64 support - -diff --git a/gcc/config/aarch64/aarch64.c b/gcc/config/aarch64/aarch64.c -index 75c12f1de65..31fa4148c3f 100644 ---- a/gcc/config/aarch64/aarch64.c -+++ b/gcc/config/aarch64/aarch64.c -@@ -2747,7 +2747,14 @@ aarch64_output_probe_stack_range (rtx reg1, rtx reg2) - output_asm_insn ("sub\t%0, %0, %1", xops); - - /* Probe at TEST_ADDR. */ -- output_asm_insn ("str\txzr, [%0]", xops); -+ if (flag_stack_clash_protection) -+ { -+ gcc_assert (xops[0] == stack_pointer_rtx); -+ xops[1] = GEN_INT (PROBE_INTERVAL - 8); -+ output_asm_insn ("str\txzr, [%0, %1]", xops); -+ } -+ else -+ output_asm_insn ("str\txzr, [%0]", xops); - - /* Test if TEST_ADDR == LAST_ADDR. */ - xops[1] = reg2; -@@ -3511,6 +3518,127 @@ aarch64_set_handled_components (sbitmap components) - cfun->machine->reg_is_wrapped_separately[regno] = true; - } - -+/* Allocate SIZE bytes of stack space using SCRATCH_REG as a scratch -+ register. */ -+ -+static void -+aarch64_allocate_and_probe_stack_space (int scratchreg, HOST_WIDE_INT size, -+ bool frame_related_p) -+{ -+ HOST_WIDE_INT probe_interval -+ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL); -+ HOST_WIDE_INT guard_size -+ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE); -+ HOST_WIDE_INT guard_used_by_caller = 1024; -+ -+ /* SIZE should be large enough to require probing here. ie, it -+ must be larger than GUARD_SIZE - GUARD_USED_BY_CALLER. -+ -+ We can allocate GUARD_SIZE - GUARD_USED_BY_CALLER as a single chunk -+ without any probing. */ -+ gcc_assert (size >= guard_size - guard_used_by_caller); -+ aarch64_sub_sp (scratchreg, guard_size - guard_used_by_caller, -+ frame_related_p); -+ HOST_WIDE_INT orig_size = size; -+ size -= (guard_size - guard_used_by_caller); -+ -+ HOST_WIDE_INT rounded_size = size & -probe_interval; -+ HOST_WIDE_INT residual = size - rounded_size; -+ -+ /* We can handle a small number of allocations/probes inline. Otherwise -+ punt to a loop. */ -+ if (rounded_size && rounded_size <= 4 * probe_interval) -+ { -+ /* We don't use aarch64_sub_sp here because we don't want to -+ repeatedly load SCRATCHREG. */ -+ rtx scratch_rtx = gen_rtx_REG (Pmode, scratchreg); -+ if (probe_interval > ARITH_FACTOR) -+ emit_move_insn (scratch_rtx, GEN_INT (-probe_interval)); -+ else -+ scratch_rtx = GEN_INT (-probe_interval); -+ -+ for (HOST_WIDE_INT i = 0; i < rounded_size; i += probe_interval) -+ { -+ rtx_insn *insn = emit_insn (gen_add2_insn (stack_pointer_rtx, -+ scratch_rtx)); -+ add_reg_note (insn, REG_STACK_CHECK, const0_rtx); -+ -+ if (probe_interval > ARITH_FACTOR) -+ { -+ RTX_FRAME_RELATED_P (insn) = 1; -+ rtx adj = plus_constant (Pmode, stack_pointer_rtx, -probe_interval); -+ add_reg_note (insn, REG_CFA_ADJUST_CFA, -+ gen_rtx_SET (stack_pointer_rtx, adj)); -+ } -+ -+ emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, -+ (probe_interval -+ - GET_MODE_SIZE (word_mode)))); -+ emit_insn (gen_blockage ()); -+ } -+ dump_stack_clash_frame_info (PROBE_INLINE, size != rounded_size); -+ } -+ else if (rounded_size) -+ { -+ /* Compute the ending address. */ -+ rtx temp = gen_rtx_REG (word_mode, scratchreg); -+ emit_move_insn (temp, GEN_INT (-rounded_size)); -+ rtx_insn *insn -+ = emit_insn (gen_add3_insn (temp, stack_pointer_rtx, temp)); -+ -+ /* For the initial allocation, we don't have a frame pointer -+ set up, so we always need CFI notes. If we're doing the -+ final allocation, then we may have a frame pointer, in which -+ case it is the CFA, otherwise we need CFI notes. -+ -+ We can determine which allocation we are doing by looking at -+ the temporary register. IP0 is the initial allocation, IP1 -+ is the final allocation. */ -+ if (scratchreg == IP0_REGNUM || !frame_pointer_needed) -+ { -+ /* We want the CFA independent of the stack pointer for the -+ duration of the loop. */ -+ add_reg_note (insn, REG_CFA_DEF_CFA, -+ plus_constant (Pmode, temp, -+ (rounded_size + (orig_size - size)))); -+ RTX_FRAME_RELATED_P (insn) = 1; -+ } -+ -+ /* This allocates and probes the stack. -+ -+ It also probes at a 4k interval regardless of the value of -+ PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL. */ -+ insn = emit_insn (gen_probe_stack_range (stack_pointer_rtx, -+ stack_pointer_rtx, temp)); -+ -+ /* Now reset the CFA register if needed. */ -+ if (scratchreg == IP0_REGNUM || !frame_pointer_needed) -+ { -+ add_reg_note (insn, REG_CFA_DEF_CFA, -+ plus_constant (Pmode, stack_pointer_rtx, -+ (rounded_size + (orig_size - size)))); -+ RTX_FRAME_RELATED_P (insn) = 1; -+ } -+ -+ emit_insn (gen_blockage ()); -+ dump_stack_clash_frame_info (PROBE_LOOP, size != rounded_size); -+ } -+ else -+ dump_stack_clash_frame_info (PROBE_INLINE, size != rounded_size); -+ -+ /* Handle any residuals. -+ Note that any residual must be probed. */ -+ if (residual) -+ { -+ aarch64_sub_sp (scratchreg, residual, frame_related_p); -+ add_reg_note (get_last_insn (), REG_STACK_CHECK, const0_rtx); -+ emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, -+ (residual - GET_MODE_SIZE (word_mode)))); -+ emit_insn (gen_blockage ()); -+ } -+ return; -+} -+ - /* AArch64 stack frames generated by this compiler look like: - - +-------------------------------+ -@@ -3592,7 +3720,54 @@ aarch64_expand_prologue (void) - aarch64_emit_probe_stack_range (get_stack_check_protect (), frame_size); - } - -- aarch64_sub_sp (IP0_REGNUM, initial_adjust, true); -+ /* We do not fully protect aarch64 against stack clash style attacks -+ as doing so would be prohibitively expensive with less utility over -+ time as newer compilers are deployed. -+ -+ We assume the guard is at least 64k. Furthermore, we assume that -+ the caller has not pushed the stack pointer more than 1k into -+ the guard. A caller that pushes the stack pointer than 1k into -+ the guard is considered invalid. -+ -+ Note that the caller's ability to push the stack pointer into the -+ guard is a function of the number and size of outgoing arguments and/or -+ dynamic stack allocations due to the mandatory save of the link register -+ in the caller's frame. -+ -+ With those assumptions the callee can allocate up to 63k of stack -+ space without probing. -+ -+ When probing is needed, we emit a probe at the start of the prologue -+ and every PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL bytes thereafter. -+ -+ We have to track how much space has been allocated, but we do not -+ track stores into the stack as implicit probes except for the -+ fp/lr store. */ -+ HOST_WIDE_INT guard_size -+ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE); -+ HOST_WIDE_INT guard_used_by_caller = 1024; -+ if (flag_stack_clash_protection) -+ { -+ if (frame_size == 0) -+ dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false); -+ else if (initial_adjust < guard_size - guard_used_by_caller -+ && final_adjust < guard_size - guard_used_by_caller) -+ dump_stack_clash_frame_info (NO_PROBE_SMALL_FRAME, true); -+ } -+ -+ /* In theory we should never have both an initial adjustment -+ and a callee save adjustment. Verify that is the case since the -+ code below does not handle it for -fstack-clash-protection. */ -+ gcc_assert (initial_adjust == 0 || callee_adjust == 0); -+ -+ /* Only probe if the initial adjustment is larger than the guard -+ less the amount of the guard reserved for use by the caller's -+ outgoing args. */ -+ if (flag_stack_clash_protection -+ && initial_adjust >= guard_size - guard_used_by_caller) -+ aarch64_allocate_and_probe_stack_space (IP0_REGNUM, initial_adjust, true); -+ else -+ aarch64_sub_sp (IP0_REGNUM, initial_adjust, true); - - if (callee_adjust != 0) - aarch64_push_regs (reg1, reg2, callee_adjust); -@@ -3613,7 +3788,30 @@ aarch64_expand_prologue (void) - callee_adjust != 0 || frame_pointer_needed); - aarch64_save_callee_saves (DFmode, callee_offset, V0_REGNUM, V31_REGNUM, - callee_adjust != 0 || frame_pointer_needed); -- aarch64_sub_sp (IP1_REGNUM, final_adjust, !frame_pointer_needed); -+ -+ /* We may need to probe the final adjustment as well. */ -+ if (flag_stack_clash_protection && final_adjust != 0) -+ { -+ /* First probe if the final adjustment is larger than the guard size -+ less the amount of the guard reserved for use by the caller's -+ outgoing args. */ -+ if (final_adjust >= guard_size - guard_used_by_caller) -+ aarch64_allocate_and_probe_stack_space (IP1_REGNUM, final_adjust, !frame_pointer_needed); -+ else -+ aarch64_sub_sp (IP1_REGNUM, final_adjust, !frame_pointer_needed); -+ -+ /* We must also probe if the final adjustment is larger than the guard -+ that is assumed used by the caller. This may be sub-optimal. */ -+ if (final_adjust >= guard_used_by_caller) -+ { -+ if (dump_file) -+ fprintf (dump_file, -+ "Stack clash aarch64 large outgoing arg, probing\n"); -+ emit_stack_probe (stack_pointer_rtx); -+ } -+ } -+ else -+ aarch64_sub_sp (IP1_REGNUM, final_adjust, !frame_pointer_needed); - } - - /* Return TRUE if we can use a simple_return insn. -@@ -3679,7 +3877,11 @@ aarch64_expand_epilogue (bool for_sibcall) - RTX_FRAME_RELATED_P (insn) = callee_adjust == 0; - } - else -- aarch64_add_sp (IP1_REGNUM, final_adjust, df_regs_ever_live_p (IP1_REGNUM)); -+ aarch64_add_sp (IP1_REGNUM, final_adjust, -+ /* A stack clash protection prologue may not have -+ left IP1_REGNUM in a usable state. */ -+ (flag_stack_clash_protection -+ || df_regs_ever_live_p (IP1_REGNUM))); - - aarch64_restore_callee_saves (DImode, callee_offset, R0_REGNUM, R30_REGNUM, - callee_adjust != 0, &cfi_ops); -@@ -3702,7 +3904,11 @@ aarch64_expand_epilogue (bool for_sibcall) - cfi_ops = NULL; - } - -- aarch64_add_sp (IP0_REGNUM, initial_adjust, df_regs_ever_live_p (IP0_REGNUM)); -+ /* A stack clash protection prologue may not have left IP0_REGNUM -+ in a usable state. */ -+ aarch64_add_sp (IP0_REGNUM, initial_adjust, -+ (flag_stack_clash_protection -+ || df_regs_ever_live_p (IP0_REGNUM))); - - if (cfi_ops) - { -@@ -8696,6 +8902,12 @@ aarch64_override_options_internal (struct gcc_options *opts) - opts->x_param_values, - global_options_set.x_param_values); - -+ /* We assume the guard page is 64k. */ -+ maybe_set_param_value (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE, -+ 16, -+ opts->x_param_values, -+ global_options_set.x_param_values); -+ - aarch64_override_options_after_change_1 (opts); - } - -@@ -14726,6 +14938,28 @@ aarch64_sched_can_speculate_insn (rtx_insn *insn) - } - } - -+/* It has been decided that to allow up to 1kb of outgoing argument -+ space to be allocated w/o probing. If more than 1kb of outgoing -+ argment space is allocated, then it must be probed and the last -+ probe must occur no more than 1kbyte away from the end of the -+ allocated space. -+ -+ This implies that the residual part of an alloca allocation may -+ need probing in cases where the generic code might not otherwise -+ think a probe is needed. -+ -+ This target hook returns TRUE when allocating RESIDUAL bytes of -+ alloca space requires an additional probe, otherwise FALSE is -+ returned. */ -+ -+static bool -+aarch64_stack_clash_protection_final_dynamic_probe (rtx residual) -+{ -+ return (residual == CONST0_RTX (Pmode) -+ || GET_CODE (residual) != CONST_INT -+ || INTVAL (residual) >= 1024); -+} -+ - /* Target-specific selftests. */ - - #if CHECKING_P -@@ -15154,6 +15388,10 @@ aarch64_libgcc_floating_mode_supported_p - #undef TARGET_CUSTOM_FUNCTION_DESCRIPTORS - #define TARGET_CUSTOM_FUNCTION_DESCRIPTORS 4 - -+#undef TARGET_STACK_CLASH_PROTECTION_FINAL_DYNAMIC_PROBE -+#define TARGET_STACK_CLASH_PROTECTION_FINAL_DYNAMIC_PROBE \ -+ aarch64_stack_clash_protection_final_dynamic_probe -+ - #if CHECKING_P - #undef TARGET_RUN_TARGET_SELFTESTS - #define TARGET_RUN_TARGET_SELFTESTS selftest::aarch64_run_selftests -diff --git a/gcc/config/aarch64/aarch64.md b/gcc/config/aarch64/aarch64.md -index 51368e29f2d..09b353d7470 100644 ---- a/gcc/config/aarch64/aarch64.md -+++ b/gcc/config/aarch64/aarch64.md -@@ -5413,7 +5413,7 @@ - ) - - (define_insn "probe_stack_range" -- [(set (match_operand:DI 0 "register_operand" "=r") -+ [(set (match_operand:DI 0 "register_operand" "=rk") - (unspec_volatile:DI [(match_operand:DI 1 "register_operand" "0") - (match_operand:DI 2 "register_operand" "r")] - UNSPECV_PROBE_STACK_RANGE))] -diff --git a/gcc/testsuite/gcc.dg/stack-check-16.c b/gcc/testsuite/gcc.dg/stack-check-16.c -new file mode 100644 -index 00000000000..0b9728532e8 ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-16.c -@@ -0,0 +1,2017 @@ -+/* { dg-do compile } */ -+/* { dg-options "-fstack-clash-protection -w" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+int printf (const char *, ...); -+void blah (char *space) { } -+ -+__attribute__ ((optimize ("-O0"))) -+int do_test (void) -+{ -+ blah (alloca (10)); -+ mtrace (); -+ printf ( -+"%1$s" "%2$s" "%3$s" "%4$s" "%5$s" "%6$s" "%7$s" "%8$s" "%9$s" "%10$s" -+"%11$s" "%12$s" "%13$s" "%14$s" "%15$s" "%16$s" "%17$s" "%18$s" "%19$s" "%20$s" -+"%21$s" "%22$s" "%23$s" "%24$s" "%25$s" "%26$s" "%27$s" "%28$s" "%29$s" "%30$s" -+"%31$s" "%32$s" "%33$s" "%34$s" "%35$s" "%36$s" "%37$s" "%38$s" "%39$s" "%40$s" -+"%41$s" "%42$s" "%43$s" "%44$s" "%45$s" "%46$s" "%47$s" "%48$s" "%49$s" "%50$s" -+"%51$s" "%52$s" "%53$s" "%54$s" "%55$s" "%56$s" "%57$s" "%58$s" "%59$s" "%60$s" -+"%61$s" "%62$s" "%63$s" "%64$s" "%65$s" "%66$s" "%67$s" "%68$s" "%69$s" "%70$s" -+"%71$s" "%72$s" "%73$s" "%74$s" "%75$s" "%76$s" "%77$s" "%78$s" "%79$s" "%80$s" -+"%81$s" "%82$s" "%83$s" "%84$s" "%85$s" "%86$s" "%87$s" "%88$s" "%89$s" "%90$s" -+"%91$s" "%92$s" "%93$s" "%94$s" "%95$s" "%96$s" "%97$s" "%98$s" "%99$s" "%100$s" -+"%101$s" "%102$s" "%103$s" "%104$s" "%105$s" "%106$s" "%107$s" "%108$s" "%109$s" "%110$s" -+"%111$s" "%112$s" "%113$s" "%114$s" "%115$s" "%116$s" "%117$s" "%118$s" "%119$s" "%120$s" -+"%121$s" "%122$s" "%123$s" "%124$s" "%125$s" "%126$s" "%127$s" "%128$s" "%129$s" "%130$s" -+"%131$s" "%132$s" "%133$s" "%134$s" "%135$s" "%136$s" "%137$s" "%138$s" "%139$s" "%140$s" -+"%141$s" "%142$s" "%143$s" "%144$s" "%145$s" "%146$s" "%147$s" "%148$s" "%149$s" "%150$s" -+"%151$s" "%152$s" "%153$s" "%154$s" "%155$s" "%156$s" "%157$s" "%158$s" "%159$s" "%160$s" -+"%161$s" "%162$s" "%163$s" "%164$s" "%165$s" "%166$s" "%167$s" "%168$s" "%169$s" "%170$s" -+"%171$s" "%172$s" "%173$s" "%174$s" "%175$s" "%176$s" "%177$s" "%178$s" "%179$s" "%180$s" -+"%181$s" "%182$s" "%183$s" "%184$s" "%185$s" "%186$s" "%187$s" "%188$s" "%189$s" "%190$s" -+"%191$s" "%192$s" "%193$s" "%194$s" "%195$s" "%196$s" "%197$s" "%198$s" "%199$s" "%200$s" -+"%201$s" "%202$s" "%203$s" "%204$s" "%205$s" "%206$s" "%207$s" "%208$s" "%209$s" "%210$s" -+"%211$s" "%212$s" "%213$s" "%214$s" "%215$s" "%216$s" "%217$s" "%218$s" "%219$s" "%220$s" -+"%221$s" "%222$s" "%223$s" "%224$s" "%225$s" "%226$s" "%227$s" "%228$s" "%229$s" "%230$s" -+"%231$s" "%232$s" "%233$s" "%234$s" "%235$s" "%236$s" "%237$s" "%238$s" "%239$s" "%240$s" -+"%241$s" "%242$s" "%243$s" "%244$s" "%245$s" "%246$s" "%247$s" "%248$s" "%249$s" "%250$s" -+"%251$s" "%252$s" "%253$s" "%254$s" "%255$s" "%256$s" "%257$s" "%258$s" "%259$s" "%260$s" -+"%261$s" "%262$s" "%263$s" "%264$s" "%265$s" "%266$s" "%267$s" "%268$s" "%269$s" "%270$s" -+"%271$s" "%272$s" "%273$s" "%274$s" "%275$s" "%276$s" "%277$s" "%278$s" "%279$s" "%280$s" -+"%281$s" "%282$s" "%283$s" "%284$s" "%285$s" "%286$s" "%287$s" "%288$s" "%289$s" "%290$s" -+"%291$s" "%292$s" "%293$s" "%294$s" "%295$s" "%296$s" "%297$s" "%298$s" "%299$s" "%300$s" -+"%301$s" "%302$s" "%303$s" "%304$s" "%305$s" "%306$s" "%307$s" "%308$s" "%309$s" "%310$s" -+"%311$s" "%312$s" "%313$s" "%314$s" "%315$s" "%316$s" "%317$s" "%318$s" "%319$s" "%320$s" -+"%321$s" "%322$s" "%323$s" "%324$s" "%325$s" "%326$s" "%327$s" "%328$s" "%329$s" "%330$s" -+"%331$s" "%332$s" "%333$s" "%334$s" "%335$s" "%336$s" "%337$s" "%338$s" "%339$s" "%340$s" -+"%341$s" "%342$s" "%343$s" "%344$s" "%345$s" "%346$s" "%347$s" "%348$s" "%349$s" "%350$s" -+"%351$s" "%352$s" "%353$s" "%354$s" "%355$s" "%356$s" "%357$s" "%358$s" "%359$s" "%360$s" -+"%361$s" "%362$s" "%363$s" "%364$s" "%365$s" "%366$s" "%367$s" "%368$s" "%369$s" "%370$s" -+"%371$s" "%372$s" "%373$s" "%374$s" "%375$s" "%376$s" "%377$s" "%378$s" "%379$s" "%380$s" -+"%381$s" "%382$s" "%383$s" "%384$s" "%385$s" "%386$s" "%387$s" "%388$s" "%389$s" "%390$s" -+"%391$s" "%392$s" "%393$s" "%394$s" "%395$s" "%396$s" "%397$s" "%398$s" "%399$s" "%400$s" -+"%401$s" "%402$s" "%403$s" "%404$s" "%405$s" "%406$s" "%407$s" "%408$s" "%409$s" "%410$s" -+"%411$s" "%412$s" "%413$s" "%414$s" "%415$s" "%416$s" "%417$s" "%418$s" "%419$s" "%420$s" -+"%421$s" "%422$s" "%423$s" "%424$s" "%425$s" "%426$s" "%427$s" "%428$s" "%429$s" "%430$s" -+"%431$s" "%432$s" "%433$s" "%434$s" "%435$s" "%436$s" "%437$s" "%438$s" "%439$s" "%440$s" -+"%441$s" "%442$s" "%443$s" "%444$s" "%445$s" "%446$s" "%447$s" "%448$s" "%449$s" "%450$s" -+"%451$s" "%452$s" "%453$s" "%454$s" "%455$s" "%456$s" "%457$s" "%458$s" "%459$s" "%460$s" -+"%461$s" "%462$s" "%463$s" "%464$s" "%465$s" "%466$s" "%467$s" "%468$s" "%469$s" "%470$s" -+"%471$s" "%472$s" "%473$s" "%474$s" "%475$s" "%476$s" "%477$s" "%478$s" "%479$s" "%480$s" -+"%481$s" "%482$s" "%483$s" "%484$s" "%485$s" "%486$s" "%487$s" "%488$s" "%489$s" "%490$s" -+"%491$s" "%492$s" "%493$s" "%494$s" "%495$s" "%496$s" "%497$s" "%498$s" "%499$s" "%500$s" -+"%501$s" "%502$s" "%503$s" "%504$s" "%505$s" "%506$s" "%507$s" "%508$s" "%509$s" "%510$s" -+"%511$s" "%512$s" "%513$s" "%514$s" "%515$s" "%516$s" "%517$s" "%518$s" "%519$s" "%520$s" -+"%521$s" "%522$s" "%523$s" "%524$s" "%525$s" "%526$s" "%527$s" "%528$s" "%529$s" "%530$s" -+"%531$s" "%532$s" "%533$s" "%534$s" "%535$s" "%536$s" "%537$s" "%538$s" "%539$s" "%540$s" -+"%541$s" "%542$s" "%543$s" "%544$s" "%545$s" "%546$s" "%547$s" "%548$s" "%549$s" "%550$s" -+"%551$s" "%552$s" "%553$s" "%554$s" "%555$s" "%556$s" "%557$s" "%558$s" "%559$s" "%560$s" -+"%561$s" "%562$s" "%563$s" "%564$s" "%565$s" "%566$s" "%567$s" "%568$s" "%569$s" "%570$s" -+"%571$s" "%572$s" "%573$s" "%574$s" "%575$s" "%576$s" "%577$s" "%578$s" "%579$s" "%580$s" -+"%581$s" "%582$s" "%583$s" "%584$s" "%585$s" "%586$s" "%587$s" "%588$s" "%589$s" "%590$s" -+"%591$s" "%592$s" "%593$s" "%594$s" "%595$s" "%596$s" "%597$s" "%598$s" "%599$s" "%600$s" -+"%601$s" "%602$s" "%603$s" "%604$s" "%605$s" "%606$s" "%607$s" "%608$s" "%609$s" "%610$s" -+"%611$s" "%612$s" "%613$s" "%614$s" "%615$s" "%616$s" "%617$s" "%618$s" "%619$s" "%620$s" -+"%621$s" "%622$s" "%623$s" "%624$s" "%625$s" "%626$s" "%627$s" "%628$s" "%629$s" "%630$s" -+"%631$s" "%632$s" "%633$s" "%634$s" "%635$s" "%636$s" "%637$s" "%638$s" "%639$s" "%640$s" -+"%641$s" "%642$s" "%643$s" "%644$s" "%645$s" "%646$s" "%647$s" "%648$s" "%649$s" "%650$s" -+"%651$s" "%652$s" "%653$s" "%654$s" "%655$s" "%656$s" "%657$s" "%658$s" "%659$s" "%660$s" -+"%661$s" "%662$s" "%663$s" "%664$s" "%665$s" "%666$s" "%667$s" "%668$s" "%669$s" "%670$s" -+"%671$s" "%672$s" "%673$s" "%674$s" "%675$s" "%676$s" "%677$s" "%678$s" "%679$s" "%680$s" -+"%681$s" "%682$s" "%683$s" "%684$s" "%685$s" "%686$s" "%687$s" "%688$s" "%689$s" "%690$s" -+"%691$s" "%692$s" "%693$s" "%694$s" "%695$s" "%696$s" "%697$s" "%698$s" "%699$s" "%700$s" -+"%701$s" "%702$s" "%703$s" "%704$s" "%705$s" "%706$s" "%707$s" "%708$s" "%709$s" "%710$s" -+"%711$s" "%712$s" "%713$s" "%714$s" "%715$s" "%716$s" "%717$s" "%718$s" "%719$s" "%720$s" -+"%721$s" "%722$s" "%723$s" "%724$s" "%725$s" "%726$s" "%727$s" "%728$s" "%729$s" "%730$s" -+"%731$s" "%732$s" "%733$s" "%734$s" "%735$s" "%736$s" "%737$s" "%738$s" "%739$s" "%740$s" -+"%741$s" "%742$s" "%743$s" "%744$s" "%745$s" "%746$s" "%747$s" "%748$s" "%749$s" "%750$s" -+"%751$s" "%752$s" "%753$s" "%754$s" "%755$s" "%756$s" "%757$s" "%758$s" "%759$s" "%760$s" -+"%761$s" "%762$s" "%763$s" "%764$s" "%765$s" "%766$s" "%767$s" "%768$s" "%769$s" "%770$s" -+"%771$s" "%772$s" "%773$s" "%774$s" "%775$s" "%776$s" "%777$s" "%778$s" "%779$s" "%780$s" -+"%781$s" "%782$s" "%783$s" "%784$s" "%785$s" "%786$s" "%787$s" "%788$s" "%789$s" "%790$s" -+"%791$s" "%792$s" "%793$s" "%794$s" "%795$s" "%796$s" "%797$s" "%798$s" "%799$s" "%800$s" -+"%801$s" "%802$s" "%803$s" "%804$s" "%805$s" "%806$s" "%807$s" "%808$s" "%809$s" "%810$s" -+"%811$s" "%812$s" "%813$s" "%814$s" "%815$s" "%816$s" "%817$s" "%818$s" "%819$s" "%820$s" -+"%821$s" "%822$s" "%823$s" "%824$s" "%825$s" "%826$s" "%827$s" "%828$s" "%829$s" "%830$s" -+"%831$s" "%832$s" "%833$s" "%834$s" "%835$s" "%836$s" "%837$s" "%838$s" "%839$s" "%840$s" -+"%841$s" "%842$s" "%843$s" "%844$s" "%845$s" "%846$s" "%847$s" "%848$s" "%849$s" "%850$s" -+"%851$s" "%852$s" "%853$s" "%854$s" "%855$s" "%856$s" "%857$s" "%858$s" "%859$s" "%860$s" -+"%861$s" "%862$s" "%863$s" "%864$s" "%865$s" "%866$s" "%867$s" "%868$s" "%869$s" "%870$s" -+"%871$s" "%872$s" "%873$s" "%874$s" "%875$s" "%876$s" "%877$s" "%878$s" "%879$s" "%880$s" -+"%881$s" "%882$s" "%883$s" "%884$s" "%885$s" "%886$s" "%887$s" "%888$s" "%889$s" "%890$s" -+"%891$s" "%892$s" "%893$s" "%894$s" "%895$s" "%896$s" "%897$s" "%898$s" "%899$s" "%900$s" -+"%901$s" "%902$s" "%903$s" "%904$s" "%905$s" "%906$s" "%907$s" "%908$s" "%909$s" "%910$s" -+"%911$s" "%912$s" "%913$s" "%914$s" "%915$s" "%916$s" "%917$s" "%918$s" "%919$s" "%920$s" -+"%921$s" "%922$s" "%923$s" "%924$s" "%925$s" "%926$s" "%927$s" "%928$s" "%929$s" "%930$s" -+"%931$s" "%932$s" "%933$s" "%934$s" "%935$s" "%936$s" "%937$s" "%938$s" "%939$s" "%940$s" -+"%941$s" "%942$s" "%943$s" "%944$s" "%945$s" "%946$s" "%947$s" "%948$s" "%949$s" "%950$s" -+"%951$s" "%952$s" "%953$s" "%954$s" "%955$s" "%956$s" "%957$s" "%958$s" "%959$s" "%960$s" -+"%961$s" "%962$s" "%963$s" "%964$s" "%965$s" "%966$s" "%967$s" "%968$s" "%969$s" "%970$s" -+"%971$s" "%972$s" "%973$s" "%974$s" "%975$s" "%976$s" "%977$s" "%978$s" "%979$s" "%980$s" -+"%981$s" "%982$s" "%983$s" "%984$s" "%985$s" "%986$s" "%987$s" "%988$s" "%989$s" "%990$s" -+"%991$s" "%992$s" "%993$s" "%994$s" "%995$s" "%996$s" "%997$s" "%998$s" "%999$s" "%1000$s" -+"%1001$s" "%1002$s" "%1003$s" "%1004$s" "%1005$s" "%1006$s" "%1007$s" "%1008$s" "%1009$s" "%1010$s" -+"%1011$s" "%1012$s" "%1013$s" "%1014$s" "%1015$s" "%1016$s" "%1017$s" "%1018$s" "%1019$s" "%1020$s" -+"%1021$s" "%1022$s" "%1023$s" "%1024$s" "%1025$s" "%1026$s" "%1027$s" "%1028$s" "%1029$s" "%1030$s" -+"%1031$s" "%1032$s" "%1033$s" "%1034$s" "%1035$s" "%1036$s" "%1037$s" "%1038$s" "%1039$s" "%1040$s" -+"%1041$s" "%1042$s" "%1043$s" "%1044$s" "%1045$s" "%1046$s" "%1047$s" "%1048$s" "%1049$s" "%1050$s" -+"%1051$s" "%1052$s" "%1053$s" "%1054$s" "%1055$s" "%1056$s" "%1057$s" "%1058$s" "%1059$s" "%1060$s" -+"%1061$s" "%1062$s" "%1063$s" "%1064$s" "%1065$s" "%1066$s" "%1067$s" "%1068$s" "%1069$s" "%1070$s" -+"%1071$s" "%1072$s" "%1073$s" "%1074$s" "%1075$s" "%1076$s" "%1077$s" "%1078$s" "%1079$s" "%1080$s" -+"%1081$s" "%1082$s" "%1083$s" "%1084$s" "%1085$s" "%1086$s" "%1087$s" "%1088$s" "%1089$s" "%1090$s" -+"%1091$s" "%1092$s" "%1093$s" "%1094$s" "%1095$s" "%1096$s" "%1097$s" "%1098$s" "%1099$s" "%1100$s" -+"%1101$s" "%1102$s" "%1103$s" "%1104$s" "%1105$s" "%1106$s" "%1107$s" "%1108$s" "%1109$s" "%1110$s" -+"%1111$s" "%1112$s" "%1113$s" "%1114$s" "%1115$s" "%1116$s" "%1117$s" "%1118$s" "%1119$s" "%1120$s" -+"%1121$s" "%1122$s" "%1123$s" "%1124$s" "%1125$s" "%1126$s" "%1127$s" "%1128$s" "%1129$s" "%1130$s" -+"%1131$s" "%1132$s" "%1133$s" "%1134$s" "%1135$s" "%1136$s" "%1137$s" "%1138$s" "%1139$s" "%1140$s" -+"%1141$s" "%1142$s" "%1143$s" "%1144$s" "%1145$s" "%1146$s" "%1147$s" "%1148$s" "%1149$s" "%1150$s" -+"%1151$s" "%1152$s" "%1153$s" "%1154$s" "%1155$s" "%1156$s" "%1157$s" "%1158$s" "%1159$s" "%1160$s" -+"%1161$s" "%1162$s" "%1163$s" "%1164$s" "%1165$s" "%1166$s" "%1167$s" "%1168$s" "%1169$s" "%1170$s" -+"%1171$s" "%1172$s" "%1173$s" "%1174$s" "%1175$s" "%1176$s" "%1177$s" "%1178$s" "%1179$s" "%1180$s" -+"%1181$s" "%1182$s" "%1183$s" "%1184$s" "%1185$s" "%1186$s" "%1187$s" "%1188$s" "%1189$s" "%1190$s" -+"%1191$s" "%1192$s" "%1193$s" "%1194$s" "%1195$s" "%1196$s" "%1197$s" "%1198$s" "%1199$s" "%1200$s" -+"%1201$s" "%1202$s" "%1203$s" "%1204$s" "%1205$s" "%1206$s" "%1207$s" "%1208$s" "%1209$s" "%1210$s" -+"%1211$s" "%1212$s" "%1213$s" "%1214$s" "%1215$s" "%1216$s" "%1217$s" "%1218$s" "%1219$s" "%1220$s" -+"%1221$s" "%1222$s" "%1223$s" "%1224$s" "%1225$s" "%1226$s" "%1227$s" "%1228$s" "%1229$s" "%1230$s" -+"%1231$s" "%1232$s" "%1233$s" "%1234$s" "%1235$s" "%1236$s" "%1237$s" "%1238$s" "%1239$s" "%1240$s" -+"%1241$s" "%1242$s" "%1243$s" "%1244$s" "%1245$s" "%1246$s" "%1247$s" "%1248$s" "%1249$s" "%1250$s" -+"%1251$s" "%1252$s" "%1253$s" "%1254$s" "%1255$s" "%1256$s" "%1257$s" "%1258$s" "%1259$s" "%1260$s" -+"%1261$s" "%1262$s" "%1263$s" "%1264$s" "%1265$s" "%1266$s" "%1267$s" "%1268$s" "%1269$s" "%1270$s" -+"%1271$s" "%1272$s" "%1273$s" "%1274$s" "%1275$s" "%1276$s" "%1277$s" "%1278$s" "%1279$s" "%1280$s" -+"%1281$s" "%1282$s" "%1283$s" "%1284$s" "%1285$s" "%1286$s" "%1287$s" "%1288$s" "%1289$s" "%1290$s" -+"%1291$s" "%1292$s" "%1293$s" "%1294$s" "%1295$s" "%1296$s" "%1297$s" "%1298$s" "%1299$s" "%1300$s" -+"%1301$s" "%1302$s" "%1303$s" "%1304$s" "%1305$s" "%1306$s" "%1307$s" "%1308$s" "%1309$s" "%1310$s" -+"%1311$s" "%1312$s" "%1313$s" "%1314$s" "%1315$s" "%1316$s" "%1317$s" "%1318$s" "%1319$s" "%1320$s" -+"%1321$s" "%1322$s" "%1323$s" "%1324$s" "%1325$s" "%1326$s" "%1327$s" "%1328$s" "%1329$s" "%1330$s" -+"%1331$s" "%1332$s" "%1333$s" "%1334$s" "%1335$s" "%1336$s" "%1337$s" "%1338$s" "%1339$s" "%1340$s" -+"%1341$s" "%1342$s" "%1343$s" "%1344$s" "%1345$s" "%1346$s" "%1347$s" "%1348$s" "%1349$s" "%1350$s" -+"%1351$s" "%1352$s" "%1353$s" "%1354$s" "%1355$s" "%1356$s" "%1357$s" "%1358$s" "%1359$s" "%1360$s" -+"%1361$s" "%1362$s" "%1363$s" "%1364$s" "%1365$s" "%1366$s" "%1367$s" "%1368$s" "%1369$s" "%1370$s" -+"%1371$s" "%1372$s" "%1373$s" "%1374$s" "%1375$s" "%1376$s" "%1377$s" "%1378$s" "%1379$s" "%1380$s" -+"%1381$s" "%1382$s" "%1383$s" "%1384$s" "%1385$s" "%1386$s" "%1387$s" "%1388$s" "%1389$s" "%1390$s" -+"%1391$s" "%1392$s" "%1393$s" "%1394$s" "%1395$s" "%1396$s" "%1397$s" "%1398$s" "%1399$s" "%1400$s" -+"%1401$s" "%1402$s" "%1403$s" "%1404$s" "%1405$s" "%1406$s" "%1407$s" "%1408$s" "%1409$s" "%1410$s" -+"%1411$s" "%1412$s" "%1413$s" "%1414$s" "%1415$s" "%1416$s" "%1417$s" "%1418$s" "%1419$s" "%1420$s" -+"%1421$s" "%1422$s" "%1423$s" "%1424$s" "%1425$s" "%1426$s" "%1427$s" "%1428$s" "%1429$s" "%1430$s" -+"%1431$s" "%1432$s" "%1433$s" "%1434$s" "%1435$s" "%1436$s" "%1437$s" "%1438$s" "%1439$s" "%1440$s" -+"%1441$s" "%1442$s" "%1443$s" "%1444$s" "%1445$s" "%1446$s" "%1447$s" "%1448$s" "%1449$s" "%1450$s" -+"%1451$s" "%1452$s" "%1453$s" "%1454$s" "%1455$s" "%1456$s" "%1457$s" "%1458$s" "%1459$s" "%1460$s" -+"%1461$s" "%1462$s" "%1463$s" "%1464$s" "%1465$s" "%1466$s" "%1467$s" "%1468$s" "%1469$s" "%1470$s" -+"%1471$s" "%1472$s" "%1473$s" "%1474$s" "%1475$s" "%1476$s" "%1477$s" "%1478$s" "%1479$s" "%1480$s" -+"%1481$s" "%1482$s" "%1483$s" "%1484$s" "%1485$s" "%1486$s" "%1487$s" "%1488$s" "%1489$s" "%1490$s" -+"%1491$s" "%1492$s" "%1493$s" "%1494$s" "%1495$s" "%1496$s" "%1497$s" "%1498$s" "%1499$s" "%1500$s" -+"%1501$s" "%1502$s" "%1503$s" "%1504$s" "%1505$s" "%1506$s" "%1507$s" "%1508$s" "%1509$s" "%1510$s" -+"%1511$s" "%1512$s" "%1513$s" "%1514$s" "%1515$s" "%1516$s" "%1517$s" "%1518$s" "%1519$s" "%1520$s" -+"%1521$s" "%1522$s" "%1523$s" "%1524$s" "%1525$s" "%1526$s" "%1527$s" "%1528$s" "%1529$s" "%1530$s" -+"%1531$s" "%1532$s" "%1533$s" "%1534$s" "%1535$s" "%1536$s" "%1537$s" "%1538$s" "%1539$s" "%1540$s" -+"%1541$s" "%1542$s" "%1543$s" "%1544$s" "%1545$s" "%1546$s" "%1547$s" "%1548$s" "%1549$s" "%1550$s" -+"%1551$s" "%1552$s" "%1553$s" "%1554$s" "%1555$s" "%1556$s" "%1557$s" "%1558$s" "%1559$s" "%1560$s" -+"%1561$s" "%1562$s" "%1563$s" "%1564$s" "%1565$s" "%1566$s" "%1567$s" "%1568$s" "%1569$s" "%1570$s" -+"%1571$s" "%1572$s" "%1573$s" "%1574$s" "%1575$s" "%1576$s" "%1577$s" "%1578$s" "%1579$s" "%1580$s" -+"%1581$s" "%1582$s" "%1583$s" "%1584$s" "%1585$s" "%1586$s" "%1587$s" "%1588$s" "%1589$s" "%1590$s" -+"%1591$s" "%1592$s" "%1593$s" "%1594$s" "%1595$s" "%1596$s" "%1597$s" "%1598$s" "%1599$s" "%1600$s" -+"%1601$s" "%1602$s" "%1603$s" "%1604$s" "%1605$s" "%1606$s" "%1607$s" "%1608$s" "%1609$s" "%1610$s" -+"%1611$s" "%1612$s" "%1613$s" "%1614$s" "%1615$s" "%1616$s" "%1617$s" "%1618$s" "%1619$s" "%1620$s" -+"%1621$s" "%1622$s" "%1623$s" "%1624$s" "%1625$s" "%1626$s" "%1627$s" "%1628$s" "%1629$s" "%1630$s" -+"%1631$s" "%1632$s" "%1633$s" "%1634$s" "%1635$s" "%1636$s" "%1637$s" "%1638$s" "%1639$s" "%1640$s" -+"%1641$s" "%1642$s" "%1643$s" "%1644$s" "%1645$s" "%1646$s" "%1647$s" "%1648$s" "%1649$s" "%1650$s" -+"%1651$s" "%1652$s" "%1653$s" "%1654$s" "%1655$s" "%1656$s" "%1657$s" "%1658$s" "%1659$s" "%1660$s" -+"%1661$s" "%1662$s" "%1663$s" "%1664$s" "%1665$s" "%1666$s" "%1667$s" "%1668$s" "%1669$s" "%1670$s" -+"%1671$s" "%1672$s" "%1673$s" "%1674$s" "%1675$s" "%1676$s" "%1677$s" "%1678$s" "%1679$s" "%1680$s" -+"%1681$s" "%1682$s" "%1683$s" "%1684$s" "%1685$s" "%1686$s" "%1687$s" "%1688$s" "%1689$s" "%1690$s" -+"%1691$s" "%1692$s" "%1693$s" "%1694$s" "%1695$s" "%1696$s" "%1697$s" "%1698$s" "%1699$s" "%1700$s" -+"%1701$s" "%1702$s" "%1703$s" "%1704$s" "%1705$s" "%1706$s" "%1707$s" "%1708$s" "%1709$s" "%1710$s" -+"%1711$s" "%1712$s" "%1713$s" "%1714$s" "%1715$s" "%1716$s" "%1717$s" "%1718$s" "%1719$s" "%1720$s" -+"%1721$s" "%1722$s" "%1723$s" "%1724$s" "%1725$s" "%1726$s" "%1727$s" "%1728$s" "%1729$s" "%1730$s" -+"%1731$s" "%1732$s" "%1733$s" "%1734$s" "%1735$s" "%1736$s" "%1737$s" "%1738$s" "%1739$s" "%1740$s" -+"%1741$s" "%1742$s" "%1743$s" "%1744$s" "%1745$s" "%1746$s" "%1747$s" "%1748$s" "%1749$s" "%1750$s" -+"%1751$s" "%1752$s" "%1753$s" "%1754$s" "%1755$s" "%1756$s" "%1757$s" "%1758$s" "%1759$s" "%1760$s" -+"%1761$s" "%1762$s" "%1763$s" "%1764$s" "%1765$s" "%1766$s" "%1767$s" "%1768$s" "%1769$s" "%1770$s" -+"%1771$s" "%1772$s" "%1773$s" "%1774$s" "%1775$s" "%1776$s" "%1777$s" "%1778$s" "%1779$s" "%1780$s" -+"%1781$s" "%1782$s" "%1783$s" "%1784$s" "%1785$s" "%1786$s" "%1787$s" "%1788$s" "%1789$s" "%1790$s" -+"%1791$s" "%1792$s" "%1793$s" "%1794$s" "%1795$s" "%1796$s" "%1797$s" "%1798$s" "%1799$s" "%1800$s" -+"%1801$s" "%1802$s" "%1803$s" "%1804$s" "%1805$s" "%1806$s" "%1807$s" "%1808$s" "%1809$s" "%1810$s" -+"%1811$s" "%1812$s" "%1813$s" "%1814$s" "%1815$s" "%1816$s" "%1817$s" "%1818$s" "%1819$s" "%1820$s" -+"%1821$s" "%1822$s" "%1823$s" "%1824$s" "%1825$s" "%1826$s" "%1827$s" "%1828$s" "%1829$s" "%1830$s" -+"%1831$s" "%1832$s" "%1833$s" "%1834$s" "%1835$s" "%1836$s" "%1837$s" "%1838$s" "%1839$s" "%1840$s" -+"%1841$s" "%1842$s" "%1843$s" "%1844$s" "%1845$s" "%1846$s" "%1847$s" "%1848$s" "%1849$s" "%1850$s" -+"%1851$s" "%1852$s" "%1853$s" "%1854$s" "%1855$s" "%1856$s" "%1857$s" "%1858$s" "%1859$s" "%1860$s" -+"%1861$s" "%1862$s" "%1863$s" "%1864$s" "%1865$s" "%1866$s" "%1867$s" "%1868$s" "%1869$s" "%1870$s" -+"%1871$s" "%1872$s" "%1873$s" "%1874$s" "%1875$s" "%1876$s" "%1877$s" "%1878$s" "%1879$s" "%1880$s" -+"%1881$s" "%1882$s" "%1883$s" "%1884$s" "%1885$s" "%1886$s" "%1887$s" "%1888$s" "%1889$s" "%1890$s" -+"%1891$s" "%1892$s" "%1893$s" "%1894$s" "%1895$s" "%1896$s" "%1897$s" "%1898$s" "%1899$s" "%1900$s" -+"%1901$s" "%1902$s" "%1903$s" "%1904$s" "%1905$s" "%1906$s" "%1907$s" "%1908$s" "%1909$s" "%1910$s" -+"%1911$s" "%1912$s" "%1913$s" "%1914$s" "%1915$s" "%1916$s" "%1917$s" "%1918$s" "%1919$s" "%1920$s" -+"%1921$s" "%1922$s" "%1923$s" "%1924$s" "%1925$s" "%1926$s" "%1927$s" "%1928$s" "%1929$s" "%1930$s" -+"%1931$s" "%1932$s" "%1933$s" "%1934$s" "%1935$s" "%1936$s" "%1937$s" "%1938$s" "%1939$s" "%1940$s" -+"%1941$s" "%1942$s" "%1943$s" "%1944$s" "%1945$s" "%1946$s" "%1947$s" "%1948$s" "%1949$s" "%1950$s" -+"%1951$s" "%1952$s" "%1953$s" "%1954$s" "%1955$s" "%1956$s" "%1957$s" "%1958$s" "%1959$s" "%1960$s" -+"%1961$s" "%1962$s" "%1963$s" "%1964$s" "%1965$s" "%1966$s" "%1967$s" "%1968$s" "%1969$s" "%1970$s" -+"%1971$s" "%1972$s" "%1973$s" "%1974$s" "%1975$s" "%1976$s" "%1977$s" "%1978$s" "%1979$s" "%1980$s" -+"%1981$s" "%1982$s" "%1983$s" "%1984$s" "%1985$s" "%1986$s" "%1987$s" "%1988$s" "%1989$s" "%1990$s" -+"%1991$s" "%1992$s" "%1993$s" "%1994$s" "%1995$s" "%1996$s" "%1997$s" "%1998$s" "%1999$s" "%2000$s" -+"%2001$s" "%2002$s" "%2003$s" "%2004$s" "%2005$s" "%2006$s" "%2007$s" "%2008$s" "%2009$s" "%2010$s" -+"%2011$s" "%2012$s" "%2013$s" "%2014$s" "%2015$s" "%2016$s" "%2017$s" "%2018$s" "%2019$s" "%2020$s" -+"%2021$s" "%2022$s" "%2023$s" "%2024$s" "%2025$s" "%2026$s" "%2027$s" "%2028$s" "%2029$s" "%2030$s" -+"%2031$s" "%2032$s" "%2033$s" "%2034$s" "%2035$s" "%2036$s" "%2037$s" "%2038$s" "%2039$s" "%2040$s" -+"%2041$s" "%2042$s" "%2043$s" "%2044$s" "%2045$s" "%2046$s" "%2047$s" "%2048$s" "%2049$s" "%2050$s" -+"%2051$s" "%2052$s" "%2053$s" "%2054$s" "%2055$s" "%2056$s" "%2057$s" "%2058$s" "%2059$s" "%2060$s" -+"%2061$s" "%2062$s" "%2063$s" "%2064$s" "%2065$s" "%2066$s" "%2067$s" "%2068$s" "%2069$s" "%2070$s" -+"%2071$s" "%2072$s" "%2073$s" "%2074$s" "%2075$s" "%2076$s" "%2077$s" "%2078$s" "%2079$s" "%2080$s" -+"%2081$s" "%2082$s" "%2083$s" "%2084$s" "%2085$s" "%2086$s" "%2087$s" "%2088$s" "%2089$s" "%2090$s" -+"%2091$s" "%2092$s" "%2093$s" "%2094$s" "%2095$s" "%2096$s" "%2097$s" "%2098$s" "%2099$s" "%2100$s" -+"%2101$s" "%2102$s" "%2103$s" "%2104$s" "%2105$s" "%2106$s" "%2107$s" "%2108$s" "%2109$s" "%2110$s" -+"%2111$s" "%2112$s" "%2113$s" "%2114$s" "%2115$s" "%2116$s" "%2117$s" "%2118$s" "%2119$s" "%2120$s" -+"%2121$s" "%2122$s" "%2123$s" "%2124$s" "%2125$s" "%2126$s" "%2127$s" "%2128$s" "%2129$s" "%2130$s" -+"%2131$s" "%2132$s" "%2133$s" "%2134$s" "%2135$s" "%2136$s" "%2137$s" "%2138$s" "%2139$s" "%2140$s" -+"%2141$s" "%2142$s" "%2143$s" "%2144$s" "%2145$s" "%2146$s" "%2147$s" "%2148$s" "%2149$s" "%2150$s" -+"%2151$s" "%2152$s" "%2153$s" "%2154$s" "%2155$s" "%2156$s" "%2157$s" "%2158$s" "%2159$s" "%2160$s" -+"%2161$s" "%2162$s" "%2163$s" "%2164$s" "%2165$s" "%2166$s" "%2167$s" "%2168$s" "%2169$s" "%2170$s" -+"%2171$s" "%2172$s" "%2173$s" "%2174$s" "%2175$s" "%2176$s" "%2177$s" "%2178$s" "%2179$s" "%2180$s" -+"%2181$s" "%2182$s" "%2183$s" "%2184$s" "%2185$s" "%2186$s" "%2187$s" "%2188$s" "%2189$s" "%2190$s" -+"%2191$s" "%2192$s" "%2193$s" "%2194$s" "%2195$s" "%2196$s" "%2197$s" "%2198$s" "%2199$s" "%2200$s" -+"%2201$s" "%2202$s" "%2203$s" "%2204$s" "%2205$s" "%2206$s" "%2207$s" "%2208$s" "%2209$s" "%2210$s" -+"%2211$s" "%2212$s" "%2213$s" "%2214$s" "%2215$s" "%2216$s" "%2217$s" "%2218$s" "%2219$s" "%2220$s" -+"%2221$s" "%2222$s" "%2223$s" "%2224$s" "%2225$s" "%2226$s" "%2227$s" "%2228$s" "%2229$s" "%2230$s" -+"%2231$s" "%2232$s" "%2233$s" "%2234$s" "%2235$s" "%2236$s" "%2237$s" "%2238$s" "%2239$s" "%2240$s" -+"%2241$s" "%2242$s" "%2243$s" "%2244$s" "%2245$s" "%2246$s" "%2247$s" "%2248$s" "%2249$s" "%2250$s" -+"%2251$s" "%2252$s" "%2253$s" "%2254$s" "%2255$s" "%2256$s" "%2257$s" "%2258$s" "%2259$s" "%2260$s" -+"%2261$s" "%2262$s" "%2263$s" "%2264$s" "%2265$s" "%2266$s" "%2267$s" "%2268$s" "%2269$s" "%2270$s" -+"%2271$s" "%2272$s" "%2273$s" "%2274$s" "%2275$s" "%2276$s" "%2277$s" "%2278$s" "%2279$s" "%2280$s" -+"%2281$s" "%2282$s" "%2283$s" "%2284$s" "%2285$s" "%2286$s" "%2287$s" "%2288$s" "%2289$s" "%2290$s" -+"%2291$s" "%2292$s" "%2293$s" "%2294$s" "%2295$s" "%2296$s" "%2297$s" "%2298$s" "%2299$s" "%2300$s" -+"%2301$s" "%2302$s" "%2303$s" "%2304$s" "%2305$s" "%2306$s" "%2307$s" "%2308$s" "%2309$s" "%2310$s" -+"%2311$s" "%2312$s" "%2313$s" "%2314$s" "%2315$s" "%2316$s" "%2317$s" "%2318$s" "%2319$s" "%2320$s" -+"%2321$s" "%2322$s" "%2323$s" "%2324$s" "%2325$s" "%2326$s" "%2327$s" "%2328$s" "%2329$s" "%2330$s" -+"%2331$s" "%2332$s" "%2333$s" "%2334$s" "%2335$s" "%2336$s" "%2337$s" "%2338$s" "%2339$s" "%2340$s" -+"%2341$s" "%2342$s" "%2343$s" "%2344$s" "%2345$s" "%2346$s" "%2347$s" "%2348$s" "%2349$s" "%2350$s" -+"%2351$s" "%2352$s" "%2353$s" "%2354$s" "%2355$s" "%2356$s" "%2357$s" "%2358$s" "%2359$s" "%2360$s" -+"%2361$s" "%2362$s" "%2363$s" "%2364$s" "%2365$s" "%2366$s" "%2367$s" "%2368$s" "%2369$s" "%2370$s" -+"%2371$s" "%2372$s" "%2373$s" "%2374$s" "%2375$s" "%2376$s" "%2377$s" "%2378$s" "%2379$s" "%2380$s" -+"%2381$s" "%2382$s" "%2383$s" "%2384$s" "%2385$s" "%2386$s" "%2387$s" "%2388$s" "%2389$s" "%2390$s" -+"%2391$s" "%2392$s" "%2393$s" "%2394$s" "%2395$s" "%2396$s" "%2397$s" "%2398$s" "%2399$s" "%2400$s" -+"%2401$s" "%2402$s" "%2403$s" "%2404$s" "%2405$s" "%2406$s" "%2407$s" "%2408$s" "%2409$s" "%2410$s" -+"%2411$s" "%2412$s" "%2413$s" "%2414$s" "%2415$s" "%2416$s" "%2417$s" "%2418$s" "%2419$s" "%2420$s" -+"%2421$s" "%2422$s" "%2423$s" "%2424$s" "%2425$s" "%2426$s" "%2427$s" "%2428$s" "%2429$s" "%2430$s" -+"%2431$s" "%2432$s" "%2433$s" "%2434$s" "%2435$s" "%2436$s" "%2437$s" "%2438$s" "%2439$s" "%2440$s" -+"%2441$s" "%2442$s" "%2443$s" "%2444$s" "%2445$s" "%2446$s" "%2447$s" "%2448$s" "%2449$s" "%2450$s" -+"%2451$s" "%2452$s" "%2453$s" "%2454$s" "%2455$s" "%2456$s" "%2457$s" "%2458$s" "%2459$s" "%2460$s" -+"%2461$s" "%2462$s" "%2463$s" "%2464$s" "%2465$s" "%2466$s" "%2467$s" "%2468$s" "%2469$s" "%2470$s" -+"%2471$s" "%2472$s" "%2473$s" "%2474$s" "%2475$s" "%2476$s" "%2477$s" "%2478$s" "%2479$s" "%2480$s" -+"%2481$s" "%2482$s" "%2483$s" "%2484$s" "%2485$s" "%2486$s" "%2487$s" "%2488$s" "%2489$s" "%2490$s" -+"%2491$s" "%2492$s" "%2493$s" "%2494$s" "%2495$s" "%2496$s" "%2497$s" "%2498$s" "%2499$s" "%2500$s" -+"%2501$s" "%2502$s" "%2503$s" "%2504$s" "%2505$s" "%2506$s" "%2507$s" "%2508$s" "%2509$s" "%2510$s" -+"%2511$s" "%2512$s" "%2513$s" "%2514$s" "%2515$s" "%2516$s" "%2517$s" "%2518$s" "%2519$s" "%2520$s" -+"%2521$s" "%2522$s" "%2523$s" "%2524$s" "%2525$s" "%2526$s" "%2527$s" "%2528$s" "%2529$s" "%2530$s" -+"%2531$s" "%2532$s" "%2533$s" "%2534$s" "%2535$s" "%2536$s" "%2537$s" "%2538$s" "%2539$s" "%2540$s" -+"%2541$s" "%2542$s" "%2543$s" "%2544$s" "%2545$s" "%2546$s" "%2547$s" "%2548$s" "%2549$s" "%2550$s" -+"%2551$s" "%2552$s" "%2553$s" "%2554$s" "%2555$s" "%2556$s" "%2557$s" "%2558$s" "%2559$s" "%2560$s" -+"%2561$s" "%2562$s" "%2563$s" "%2564$s" "%2565$s" "%2566$s" "%2567$s" "%2568$s" "%2569$s" "%2570$s" -+"%2571$s" "%2572$s" "%2573$s" "%2574$s" "%2575$s" "%2576$s" "%2577$s" "%2578$s" "%2579$s" "%2580$s" -+"%2581$s" "%2582$s" "%2583$s" "%2584$s" "%2585$s" "%2586$s" "%2587$s" "%2588$s" "%2589$s" "%2590$s" -+"%2591$s" "%2592$s" "%2593$s" "%2594$s" "%2595$s" "%2596$s" "%2597$s" "%2598$s" "%2599$s" "%2600$s" -+"%2601$s" "%2602$s" "%2603$s" "%2604$s" "%2605$s" "%2606$s" "%2607$s" "%2608$s" "%2609$s" "%2610$s" -+"%2611$s" "%2612$s" "%2613$s" "%2614$s" "%2615$s" "%2616$s" "%2617$s" "%2618$s" "%2619$s" "%2620$s" -+"%2621$s" "%2622$s" "%2623$s" "%2624$s" "%2625$s" "%2626$s" "%2627$s" "%2628$s" "%2629$s" "%2630$s" -+"%2631$s" "%2632$s" "%2633$s" "%2634$s" "%2635$s" "%2636$s" "%2637$s" "%2638$s" "%2639$s" "%2640$s" -+"%2641$s" "%2642$s" "%2643$s" "%2644$s" "%2645$s" "%2646$s" "%2647$s" "%2648$s" "%2649$s" "%2650$s" -+"%2651$s" "%2652$s" "%2653$s" "%2654$s" "%2655$s" "%2656$s" "%2657$s" "%2658$s" "%2659$s" "%2660$s" -+"%2661$s" "%2662$s" "%2663$s" "%2664$s" "%2665$s" "%2666$s" "%2667$s" "%2668$s" "%2669$s" "%2670$s" -+"%2671$s" "%2672$s" "%2673$s" "%2674$s" "%2675$s" "%2676$s" "%2677$s" "%2678$s" "%2679$s" "%2680$s" -+"%2681$s" "%2682$s" "%2683$s" "%2684$s" "%2685$s" "%2686$s" "%2687$s" "%2688$s" "%2689$s" "%2690$s" -+"%2691$s" "%2692$s" "%2693$s" "%2694$s" "%2695$s" "%2696$s" "%2697$s" "%2698$s" "%2699$s" "%2700$s" -+"%2701$s" "%2702$s" "%2703$s" "%2704$s" "%2705$s" "%2706$s" "%2707$s" "%2708$s" "%2709$s" "%2710$s" -+"%2711$s" "%2712$s" "%2713$s" "%2714$s" "%2715$s" "%2716$s" "%2717$s" "%2718$s" "%2719$s" "%2720$s" -+"%2721$s" "%2722$s" "%2723$s" "%2724$s" "%2725$s" "%2726$s" "%2727$s" "%2728$s" "%2729$s" "%2730$s" -+"%2731$s" "%2732$s" "%2733$s" "%2734$s" "%2735$s" "%2736$s" "%2737$s" "%2738$s" "%2739$s" "%2740$s" -+"%2741$s" "%2742$s" "%2743$s" "%2744$s" "%2745$s" "%2746$s" "%2747$s" "%2748$s" "%2749$s" "%2750$s" -+"%2751$s" "%2752$s" "%2753$s" "%2754$s" "%2755$s" "%2756$s" "%2757$s" "%2758$s" "%2759$s" "%2760$s" -+"%2761$s" "%2762$s" "%2763$s" "%2764$s" "%2765$s" "%2766$s" "%2767$s" "%2768$s" "%2769$s" "%2770$s" -+"%2771$s" "%2772$s" "%2773$s" "%2774$s" "%2775$s" "%2776$s" "%2777$s" "%2778$s" "%2779$s" "%2780$s" -+"%2781$s" "%2782$s" "%2783$s" "%2784$s" "%2785$s" "%2786$s" "%2787$s" "%2788$s" "%2789$s" "%2790$s" -+"%2791$s" "%2792$s" "%2793$s" "%2794$s" "%2795$s" "%2796$s" "%2797$s" "%2798$s" "%2799$s" "%2800$s" -+"%2801$s" "%2802$s" "%2803$s" "%2804$s" "%2805$s" "%2806$s" "%2807$s" "%2808$s" "%2809$s" "%2810$s" -+"%2811$s" "%2812$s" "%2813$s" "%2814$s" "%2815$s" "%2816$s" "%2817$s" "%2818$s" "%2819$s" "%2820$s" -+"%2821$s" "%2822$s" "%2823$s" "%2824$s" "%2825$s" "%2826$s" "%2827$s" "%2828$s" "%2829$s" "%2830$s" -+"%2831$s" "%2832$s" "%2833$s" "%2834$s" "%2835$s" "%2836$s" "%2837$s" "%2838$s" "%2839$s" "%2840$s" -+"%2841$s" "%2842$s" "%2843$s" "%2844$s" "%2845$s" "%2846$s" "%2847$s" "%2848$s" "%2849$s" "%2850$s" -+"%2851$s" "%2852$s" "%2853$s" "%2854$s" "%2855$s" "%2856$s" "%2857$s" "%2858$s" "%2859$s" "%2860$s" -+"%2861$s" "%2862$s" "%2863$s" "%2864$s" "%2865$s" "%2866$s" "%2867$s" "%2868$s" "%2869$s" "%2870$s" -+"%2871$s" "%2872$s" "%2873$s" "%2874$s" "%2875$s" "%2876$s" "%2877$s" "%2878$s" "%2879$s" "%2880$s" -+"%2881$s" "%2882$s" "%2883$s" "%2884$s" "%2885$s" "%2886$s" "%2887$s" "%2888$s" "%2889$s" "%2890$s" -+"%2891$s" "%2892$s" "%2893$s" "%2894$s" "%2895$s" "%2896$s" "%2897$s" "%2898$s" "%2899$s" "%2900$s" -+"%2901$s" "%2902$s" "%2903$s" "%2904$s" "%2905$s" "%2906$s" "%2907$s" "%2908$s" "%2909$s" "%2910$s" -+"%2911$s" "%2912$s" "%2913$s" "%2914$s" "%2915$s" "%2916$s" "%2917$s" "%2918$s" "%2919$s" "%2920$s" -+"%2921$s" "%2922$s" "%2923$s" "%2924$s" "%2925$s" "%2926$s" "%2927$s" "%2928$s" "%2929$s" "%2930$s" -+"%2931$s" "%2932$s" "%2933$s" "%2934$s" "%2935$s" "%2936$s" "%2937$s" "%2938$s" "%2939$s" "%2940$s" -+"%2941$s" "%2942$s" "%2943$s" "%2944$s" "%2945$s" "%2946$s" "%2947$s" "%2948$s" "%2949$s" "%2950$s" -+"%2951$s" "%2952$s" "%2953$s" "%2954$s" "%2955$s" "%2956$s" "%2957$s" "%2958$s" "%2959$s" "%2960$s" -+"%2961$s" "%2962$s" "%2963$s" "%2964$s" "%2965$s" "%2966$s" "%2967$s" "%2968$s" "%2969$s" "%2970$s" -+"%2971$s" "%2972$s" "%2973$s" "%2974$s" "%2975$s" "%2976$s" "%2977$s" "%2978$s" "%2979$s" "%2980$s" -+"%2981$s" "%2982$s" "%2983$s" "%2984$s" "%2985$s" "%2986$s" "%2987$s" "%2988$s" "%2989$s" "%2990$s" -+"%2991$s" "%2992$s" "%2993$s" "%2994$s" "%2995$s" "%2996$s" "%2997$s" "%2998$s" "%2999$s" "%3000$s" -+"%3001$s" "%3002$s" "%3003$s" "%3004$s" "%3005$s" "%3006$s" "%3007$s" "%3008$s" "%3009$s" "%3010$s" -+"%3011$s" "%3012$s" "%3013$s" "%3014$s" "%3015$s" "%3016$s" "%3017$s" "%3018$s" "%3019$s" "%3020$s" -+"%3021$s" "%3022$s" "%3023$s" "%3024$s" "%3025$s" "%3026$s" "%3027$s" "%3028$s" "%3029$s" "%3030$s" -+"%3031$s" "%3032$s" "%3033$s" "%3034$s" "%3035$s" "%3036$s" "%3037$s" "%3038$s" "%3039$s" "%3040$s" -+"%3041$s" "%3042$s" "%3043$s" "%3044$s" "%3045$s" "%3046$s" "%3047$s" "%3048$s" "%3049$s" "%3050$s" -+"%3051$s" "%3052$s" "%3053$s" "%3054$s" "%3055$s" "%3056$s" "%3057$s" "%3058$s" "%3059$s" "%3060$s" -+"%3061$s" "%3062$s" "%3063$s" "%3064$s" "%3065$s" "%3066$s" "%3067$s" "%3068$s" "%3069$s" "%3070$s" -+"%3071$s" "%3072$s" "%3073$s" "%3074$s" "%3075$s" "%3076$s" "%3077$s" "%3078$s" "%3079$s" "%3080$s" -+"%3081$s" "%3082$s" "%3083$s" "%3084$s" "%3085$s" "%3086$s" "%3087$s" "%3088$s" "%3089$s" "%3090$s" -+"%3091$s" "%3092$s" "%3093$s" "%3094$s" "%3095$s" "%3096$s" "%3097$s" "%3098$s" "%3099$s" "%3100$s" -+"%3101$s" "%3102$s" "%3103$s" "%3104$s" "%3105$s" "%3106$s" "%3107$s" "%3108$s" "%3109$s" "%3110$s" -+"%3111$s" "%3112$s" "%3113$s" "%3114$s" "%3115$s" "%3116$s" "%3117$s" "%3118$s" "%3119$s" "%3120$s" -+"%3121$s" "%3122$s" "%3123$s" "%3124$s" "%3125$s" "%3126$s" "%3127$s" "%3128$s" "%3129$s" "%3130$s" -+"%3131$s" "%3132$s" "%3133$s" "%3134$s" "%3135$s" "%3136$s" "%3137$s" "%3138$s" "%3139$s" "%3140$s" -+"%3141$s" "%3142$s" "%3143$s" "%3144$s" "%3145$s" "%3146$s" "%3147$s" "%3148$s" "%3149$s" "%3150$s" -+"%3151$s" "%3152$s" "%3153$s" "%3154$s" "%3155$s" "%3156$s" "%3157$s" "%3158$s" "%3159$s" "%3160$s" -+"%3161$s" "%3162$s" "%3163$s" "%3164$s" "%3165$s" "%3166$s" "%3167$s" "%3168$s" "%3169$s" "%3170$s" -+"%3171$s" "%3172$s" "%3173$s" "%3174$s" "%3175$s" "%3176$s" "%3177$s" "%3178$s" "%3179$s" "%3180$s" -+"%3181$s" "%3182$s" "%3183$s" "%3184$s" "%3185$s" "%3186$s" "%3187$s" "%3188$s" "%3189$s" "%3190$s" -+"%3191$s" "%3192$s" "%3193$s" "%3194$s" "%3195$s" "%3196$s" "%3197$s" "%3198$s" "%3199$s" "%3200$s" -+"%3201$s" "%3202$s" "%3203$s" "%3204$s" "%3205$s" "%3206$s" "%3207$s" "%3208$s" "%3209$s" "%3210$s" -+"%3211$s" "%3212$s" "%3213$s" "%3214$s" "%3215$s" "%3216$s" "%3217$s" "%3218$s" "%3219$s" "%3220$s" -+"%3221$s" "%3222$s" "%3223$s" "%3224$s" "%3225$s" "%3226$s" "%3227$s" "%3228$s" "%3229$s" "%3230$s" -+"%3231$s" "%3232$s" "%3233$s" "%3234$s" "%3235$s" "%3236$s" "%3237$s" "%3238$s" "%3239$s" "%3240$s" -+"%3241$s" "%3242$s" "%3243$s" "%3244$s" "%3245$s" "%3246$s" "%3247$s" "%3248$s" "%3249$s" "%3250$s" -+"%3251$s" "%3252$s" "%3253$s" "%3254$s" "%3255$s" "%3256$s" "%3257$s" "%3258$s" "%3259$s" "%3260$s" -+"%3261$s" "%3262$s" "%3263$s" "%3264$s" "%3265$s" "%3266$s" "%3267$s" "%3268$s" "%3269$s" "%3270$s" -+"%3271$s" "%3272$s" "%3273$s" "%3274$s" "%3275$s" "%3276$s" "%3277$s" "%3278$s" "%3279$s" "%3280$s" -+"%3281$s" "%3282$s" "%3283$s" "%3284$s" "%3285$s" "%3286$s" "%3287$s" "%3288$s" "%3289$s" "%3290$s" -+"%3291$s" "%3292$s" "%3293$s" "%3294$s" "%3295$s" "%3296$s" "%3297$s" "%3298$s" "%3299$s" "%3300$s" -+"%3301$s" "%3302$s" "%3303$s" "%3304$s" "%3305$s" "%3306$s" "%3307$s" "%3308$s" "%3309$s" "%3310$s" -+"%3311$s" "%3312$s" "%3313$s" "%3314$s" "%3315$s" "%3316$s" "%3317$s" "%3318$s" "%3319$s" "%3320$s" -+"%3321$s" "%3322$s" "%3323$s" "%3324$s" "%3325$s" "%3326$s" "%3327$s" "%3328$s" "%3329$s" "%3330$s" -+"%3331$s" "%3332$s" "%3333$s" "%3334$s" "%3335$s" "%3336$s" "%3337$s" "%3338$s" "%3339$s" "%3340$s" -+"%3341$s" "%3342$s" "%3343$s" "%3344$s" "%3345$s" "%3346$s" "%3347$s" "%3348$s" "%3349$s" "%3350$s" -+"%3351$s" "%3352$s" "%3353$s" "%3354$s" "%3355$s" "%3356$s" "%3357$s" "%3358$s" "%3359$s" "%3360$s" -+"%3361$s" "%3362$s" "%3363$s" "%3364$s" "%3365$s" "%3366$s" "%3367$s" "%3368$s" "%3369$s" "%3370$s" -+"%3371$s" "%3372$s" "%3373$s" "%3374$s" "%3375$s" "%3376$s" "%3377$s" "%3378$s" "%3379$s" "%3380$s" -+"%3381$s" "%3382$s" "%3383$s" "%3384$s" "%3385$s" "%3386$s" "%3387$s" "%3388$s" "%3389$s" "%3390$s" -+"%3391$s" "%3392$s" "%3393$s" "%3394$s" "%3395$s" "%3396$s" "%3397$s" "%3398$s" "%3399$s" "%3400$s" -+"%3401$s" "%3402$s" "%3403$s" "%3404$s" "%3405$s" "%3406$s" "%3407$s" "%3408$s" "%3409$s" "%3410$s" -+"%3411$s" "%3412$s" "%3413$s" "%3414$s" "%3415$s" "%3416$s" "%3417$s" "%3418$s" "%3419$s" "%3420$s" -+"%3421$s" "%3422$s" "%3423$s" "%3424$s" "%3425$s" "%3426$s" "%3427$s" "%3428$s" "%3429$s" "%3430$s" -+"%3431$s" "%3432$s" "%3433$s" "%3434$s" "%3435$s" "%3436$s" "%3437$s" "%3438$s" "%3439$s" "%3440$s" -+"%3441$s" "%3442$s" "%3443$s" "%3444$s" "%3445$s" "%3446$s" "%3447$s" "%3448$s" "%3449$s" "%3450$s" -+"%3451$s" "%3452$s" "%3453$s" "%3454$s" "%3455$s" "%3456$s" "%3457$s" "%3458$s" "%3459$s" "%3460$s" -+"%3461$s" "%3462$s" "%3463$s" "%3464$s" "%3465$s" "%3466$s" "%3467$s" "%3468$s" "%3469$s" "%3470$s" -+"%3471$s" "%3472$s" "%3473$s" "%3474$s" "%3475$s" "%3476$s" "%3477$s" "%3478$s" "%3479$s" "%3480$s" -+"%3481$s" "%3482$s" "%3483$s" "%3484$s" "%3485$s" "%3486$s" "%3487$s" "%3488$s" "%3489$s" "%3490$s" -+"%3491$s" "%3492$s" "%3493$s" "%3494$s" "%3495$s" "%3496$s" "%3497$s" "%3498$s" "%3499$s" "%3500$s" -+"%3501$s" "%3502$s" "%3503$s" "%3504$s" "%3505$s" "%3506$s" "%3507$s" "%3508$s" "%3509$s" "%3510$s" -+"%3511$s" "%3512$s" "%3513$s" "%3514$s" "%3515$s" "%3516$s" "%3517$s" "%3518$s" "%3519$s" "%3520$s" -+"%3521$s" "%3522$s" "%3523$s" "%3524$s" "%3525$s" "%3526$s" "%3527$s" "%3528$s" "%3529$s" "%3530$s" -+"%3531$s" "%3532$s" "%3533$s" "%3534$s" "%3535$s" "%3536$s" "%3537$s" "%3538$s" "%3539$s" "%3540$s" -+"%3541$s" "%3542$s" "%3543$s" "%3544$s" "%3545$s" "%3546$s" "%3547$s" "%3548$s" "%3549$s" "%3550$s" -+"%3551$s" "%3552$s" "%3553$s" "%3554$s" "%3555$s" "%3556$s" "%3557$s" "%3558$s" "%3559$s" "%3560$s" -+"%3561$s" "%3562$s" "%3563$s" "%3564$s" "%3565$s" "%3566$s" "%3567$s" "%3568$s" "%3569$s" "%3570$s" -+"%3571$s" "%3572$s" "%3573$s" "%3574$s" "%3575$s" "%3576$s" "%3577$s" "%3578$s" "%3579$s" "%3580$s" -+"%3581$s" "%3582$s" "%3583$s" "%3584$s" "%3585$s" "%3586$s" "%3587$s" "%3588$s" "%3589$s" "%3590$s" -+"%3591$s" "%3592$s" "%3593$s" "%3594$s" "%3595$s" "%3596$s" "%3597$s" "%3598$s" "%3599$s" "%3600$s" -+"%3601$s" "%3602$s" "%3603$s" "%3604$s" "%3605$s" "%3606$s" "%3607$s" "%3608$s" "%3609$s" "%3610$s" -+"%3611$s" "%3612$s" "%3613$s" "%3614$s" "%3615$s" "%3616$s" "%3617$s" "%3618$s" "%3619$s" "%3620$s" -+"%3621$s" "%3622$s" "%3623$s" "%3624$s" "%3625$s" "%3626$s" "%3627$s" "%3628$s" "%3629$s" "%3630$s" -+"%3631$s" "%3632$s" "%3633$s" "%3634$s" "%3635$s" "%3636$s" "%3637$s" "%3638$s" "%3639$s" "%3640$s" -+"%3641$s" "%3642$s" "%3643$s" "%3644$s" "%3645$s" "%3646$s" "%3647$s" "%3648$s" "%3649$s" "%3650$s" -+"%3651$s" "%3652$s" "%3653$s" "%3654$s" "%3655$s" "%3656$s" "%3657$s" "%3658$s" "%3659$s" "%3660$s" -+"%3661$s" "%3662$s" "%3663$s" "%3664$s" "%3665$s" "%3666$s" "%3667$s" "%3668$s" "%3669$s" "%3670$s" -+"%3671$s" "%3672$s" "%3673$s" "%3674$s" "%3675$s" "%3676$s" "%3677$s" "%3678$s" "%3679$s" "%3680$s" -+"%3681$s" "%3682$s" "%3683$s" "%3684$s" "%3685$s" "%3686$s" "%3687$s" "%3688$s" "%3689$s" "%3690$s" -+"%3691$s" "%3692$s" "%3693$s" "%3694$s" "%3695$s" "%3696$s" "%3697$s" "%3698$s" "%3699$s" "%3700$s" -+"%3701$s" "%3702$s" "%3703$s" "%3704$s" "%3705$s" "%3706$s" "%3707$s" "%3708$s" "%3709$s" "%3710$s" -+"%3711$s" "%3712$s" "%3713$s" "%3714$s" "%3715$s" "%3716$s" "%3717$s" "%3718$s" "%3719$s" "%3720$s" -+"%3721$s" "%3722$s" "%3723$s" "%3724$s" "%3725$s" "%3726$s" "%3727$s" "%3728$s" "%3729$s" "%3730$s" -+"%3731$s" "%3732$s" "%3733$s" "%3734$s" "%3735$s" "%3736$s" "%3737$s" "%3738$s" "%3739$s" "%3740$s" -+"%3741$s" "%3742$s" "%3743$s" "%3744$s" "%3745$s" "%3746$s" "%3747$s" "%3748$s" "%3749$s" "%3750$s" -+"%3751$s" "%3752$s" "%3753$s" "%3754$s" "%3755$s" "%3756$s" "%3757$s" "%3758$s" "%3759$s" "%3760$s" -+"%3761$s" "%3762$s" "%3763$s" "%3764$s" "%3765$s" "%3766$s" "%3767$s" "%3768$s" "%3769$s" "%3770$s" -+"%3771$s" "%3772$s" "%3773$s" "%3774$s" "%3775$s" "%3776$s" "%3777$s" "%3778$s" "%3779$s" "%3780$s" -+"%3781$s" "%3782$s" "%3783$s" "%3784$s" "%3785$s" "%3786$s" "%3787$s" "%3788$s" "%3789$s" "%3790$s" -+"%3791$s" "%3792$s" "%3793$s" "%3794$s" "%3795$s" "%3796$s" "%3797$s" "%3798$s" "%3799$s" "%3800$s" -+"%3801$s" "%3802$s" "%3803$s" "%3804$s" "%3805$s" "%3806$s" "%3807$s" "%3808$s" "%3809$s" "%3810$s" -+"%3811$s" "%3812$s" "%3813$s" "%3814$s" "%3815$s" "%3816$s" "%3817$s" "%3818$s" "%3819$s" "%3820$s" -+"%3821$s" "%3822$s" "%3823$s" "%3824$s" "%3825$s" "%3826$s" "%3827$s" "%3828$s" "%3829$s" "%3830$s" -+"%3831$s" "%3832$s" "%3833$s" "%3834$s" "%3835$s" "%3836$s" "%3837$s" "%3838$s" "%3839$s" "%3840$s" -+"%3841$s" "%3842$s" "%3843$s" "%3844$s" "%3845$s" "%3846$s" "%3847$s" "%3848$s" "%3849$s" "%3850$s" -+"%3851$s" "%3852$s" "%3853$s" "%3854$s" "%3855$s" "%3856$s" "%3857$s" "%3858$s" "%3859$s" "%3860$s" -+"%3861$s" "%3862$s" "%3863$s" "%3864$s" "%3865$s" "%3866$s" "%3867$s" "%3868$s" "%3869$s" "%3870$s" -+"%3871$s" "%3872$s" "%3873$s" "%3874$s" "%3875$s" "%3876$s" "%3877$s" "%3878$s" "%3879$s" "%3880$s" -+"%3881$s" "%3882$s" "%3883$s" "%3884$s" "%3885$s" "%3886$s" "%3887$s" "%3888$s" "%3889$s" "%3890$s" -+"%3891$s" "%3892$s" "%3893$s" "%3894$s" "%3895$s" "%3896$s" "%3897$s" "%3898$s" "%3899$s" "%3900$s" -+"%3901$s" "%3902$s" "%3903$s" "%3904$s" "%3905$s" "%3906$s" "%3907$s" "%3908$s" "%3909$s" "%3910$s" -+"%3911$s" "%3912$s" "%3913$s" "%3914$s" "%3915$s" "%3916$s" "%3917$s" "%3918$s" "%3919$s" "%3920$s" -+"%3921$s" "%3922$s" "%3923$s" "%3924$s" "%3925$s" "%3926$s" "%3927$s" "%3928$s" "%3929$s" "%3930$s" -+"%3931$s" "%3932$s" "%3933$s" "%3934$s" "%3935$s" "%3936$s" "%3937$s" "%3938$s" "%3939$s" "%3940$s" -+"%3941$s" "%3942$s" "%3943$s" "%3944$s" "%3945$s" "%3946$s" "%3947$s" "%3948$s" "%3949$s" "%3950$s" -+"%3951$s" "%3952$s" "%3953$s" "%3954$s" "%3955$s" "%3956$s" "%3957$s" "%3958$s" "%3959$s" "%3960$s" -+"%3961$s" "%3962$s" "%3963$s" "%3964$s" "%3965$s" "%3966$s" "%3967$s" "%3968$s" "%3969$s" "%3970$s" -+"%3971$s" "%3972$s" "%3973$s" "%3974$s" "%3975$s" "%3976$s" "%3977$s" "%3978$s" "%3979$s" "%3980$s" -+"%3981$s" "%3982$s" "%3983$s" "%3984$s" "%3985$s" "%3986$s" "%3987$s" "%3988$s" "%3989$s" "%3990$s" -+"%3991$s" "%3992$s" "%3993$s" "%3994$s" "%3995$s" "%3996$s" "%3997$s" "%3998$s" "%3999$s" "%4000$s" -+"%4001$s" "%4002$s" "%4003$s" "%4004$s" "%4005$s" "%4006$s" "%4007$s" "%4008$s" "%4009$s" "%4010$s" -+"%4011$s" "%4012$s" "%4013$s" "%4014$s" "%4015$s" "%4016$s" "%4017$s" "%4018$s" "%4019$s" "%4020$s" -+"%4021$s" "%4022$s" "%4023$s" "%4024$s" "%4025$s" "%4026$s" "%4027$s" "%4028$s" "%4029$s" "%4030$s" -+"%4031$s" "%4032$s" "%4033$s" "%4034$s" "%4035$s" "%4036$s" "%4037$s" "%4038$s" "%4039$s" "%4040$s" -+"%4041$s" "%4042$s" "%4043$s" "%4044$s" "%4045$s" "%4046$s" "%4047$s" "%4048$s" "%4049$s" "%4050$s" -+"%4051$s" "%4052$s" "%4053$s" "%4054$s" "%4055$s" "%4056$s" "%4057$s" "%4058$s" "%4059$s" "%4060$s" -+"%4061$s" "%4062$s" "%4063$s" "%4064$s" "%4065$s" "%4066$s" "%4067$s" "%4068$s" "%4069$s" "%4070$s" -+"%4071$s" "%4072$s" "%4073$s" "%4074$s" "%4075$s" "%4076$s" "%4077$s" "%4078$s" "%4079$s" "%4080$s" -+"%4081$s" "%4082$s" "%4083$s" "%4084$s" "%4085$s" "%4086$s" "%4087$s" "%4088$s" "%4089$s" "%4090$s" -+"%4091$s" "%4092$s" "%4093$s" "%4094$s" "%4095$s" "%4096$s" "%4097$s" "%4098$s" "%4099$s" "%4100$s" -+"%4101$s" "%4102$s" "%4103$s" "%4104$s" "%4105$s" "%4106$s" "%4107$s" "%4108$s" "%4109$s" "%4110$s" -+"%4111$s" "%4112$s" "%4113$s" "%4114$s" "%4115$s" "%4116$s" "%4117$s" "%4118$s" "%4119$s" "%4120$s" -+"%4121$s" "%4122$s" "%4123$s" "%4124$s" "%4125$s" "%4126$s" "%4127$s" "%4128$s" "%4129$s" "%4130$s" -+"%4131$s" "%4132$s" "%4133$s" "%4134$s" "%4135$s" "%4136$s" "%4137$s" "%4138$s" "%4139$s" "%4140$s" -+"%4141$s" "%4142$s" "%4143$s" "%4144$s" "%4145$s" "%4146$s" "%4147$s" "%4148$s" "%4149$s" "%4150$s" -+"%4151$s" "%4152$s" "%4153$s" "%4154$s" "%4155$s" "%4156$s" "%4157$s" "%4158$s" "%4159$s" "%4160$s" -+"%4161$s" "%4162$s" "%4163$s" "%4164$s" "%4165$s" "%4166$s" "%4167$s" "%4168$s" "%4169$s" "%4170$s" -+"%4171$s" "%4172$s" "%4173$s" "%4174$s" "%4175$s" "%4176$s" "%4177$s" "%4178$s" "%4179$s" "%4180$s" -+"%4181$s" "%4182$s" "%4183$s" "%4184$s" "%4185$s" "%4186$s" "%4187$s" "%4188$s" "%4189$s" "%4190$s" -+"%4191$s" "%4192$s" "%4193$s" "%4194$s" "%4195$s" "%4196$s" "%4197$s" "%4198$s" "%4199$s" "%4200$s" -+"%4201$s" "%4202$s" "%4203$s" "%4204$s" "%4205$s" "%4206$s" "%4207$s" "%4208$s" "%4209$s" "%4210$s" -+"%4211$s" "%4212$s" "%4213$s" "%4214$s" "%4215$s" "%4216$s" "%4217$s" "%4218$s" "%4219$s" "%4220$s" -+"%4221$s" "%4222$s" "%4223$s" "%4224$s" "%4225$s" "%4226$s" "%4227$s" "%4228$s" "%4229$s" "%4230$s" -+"%4231$s" "%4232$s" "%4233$s" "%4234$s" "%4235$s" "%4236$s" "%4237$s" "%4238$s" "%4239$s" "%4240$s" -+"%4241$s" "%4242$s" "%4243$s" "%4244$s" "%4245$s" "%4246$s" "%4247$s" "%4248$s" "%4249$s" "%4250$s" -+"%4251$s" "%4252$s" "%4253$s" "%4254$s" "%4255$s" "%4256$s" "%4257$s" "%4258$s" "%4259$s" "%4260$s" -+"%4261$s" "%4262$s" "%4263$s" "%4264$s" "%4265$s" "%4266$s" "%4267$s" "%4268$s" "%4269$s" "%4270$s" -+"%4271$s" "%4272$s" "%4273$s" "%4274$s" "%4275$s" "%4276$s" "%4277$s" "%4278$s" "%4279$s" "%4280$s" -+"%4281$s" "%4282$s" "%4283$s" "%4284$s" "%4285$s" "%4286$s" "%4287$s" "%4288$s" "%4289$s" "%4290$s" -+"%4291$s" "%4292$s" "%4293$s" "%4294$s" "%4295$s" "%4296$s" "%4297$s" "%4298$s" "%4299$s" "%4300$s" -+"%4301$s" "%4302$s" "%4303$s" "%4304$s" "%4305$s" "%4306$s" "%4307$s" "%4308$s" "%4309$s" "%4310$s" -+"%4311$s" "%4312$s" "%4313$s" "%4314$s" "%4315$s" "%4316$s" "%4317$s" "%4318$s" "%4319$s" "%4320$s" -+"%4321$s" "%4322$s" "%4323$s" "%4324$s" "%4325$s" "%4326$s" "%4327$s" "%4328$s" "%4329$s" "%4330$s" -+"%4331$s" "%4332$s" "%4333$s" "%4334$s" "%4335$s" "%4336$s" "%4337$s" "%4338$s" "%4339$s" "%4340$s" -+"%4341$s" "%4342$s" "%4343$s" "%4344$s" "%4345$s" "%4346$s" "%4347$s" "%4348$s" "%4349$s" "%4350$s" -+"%4351$s" "%4352$s" "%4353$s" "%4354$s" "%4355$s" "%4356$s" "%4357$s" "%4358$s" "%4359$s" "%4360$s" -+"%4361$s" "%4362$s" "%4363$s" "%4364$s" "%4365$s" "%4366$s" "%4367$s" "%4368$s" "%4369$s" "%4370$s" -+"%4371$s" "%4372$s" "%4373$s" "%4374$s" "%4375$s" "%4376$s" "%4377$s" "%4378$s" "%4379$s" "%4380$s" -+"%4381$s" "%4382$s" "%4383$s" "%4384$s" "%4385$s" "%4386$s" "%4387$s" "%4388$s" "%4389$s" "%4390$s" -+"%4391$s" "%4392$s" "%4393$s" "%4394$s" "%4395$s" "%4396$s" "%4397$s" "%4398$s" "%4399$s" "%4400$s" -+"%4401$s" "%4402$s" "%4403$s" "%4404$s" "%4405$s" "%4406$s" "%4407$s" "%4408$s" "%4409$s" "%4410$s" -+"%4411$s" "%4412$s" "%4413$s" "%4414$s" "%4415$s" "%4416$s" "%4417$s" "%4418$s" "%4419$s" "%4420$s" -+"%4421$s" "%4422$s" "%4423$s" "%4424$s" "%4425$s" "%4426$s" "%4427$s" "%4428$s" "%4429$s" "%4430$s" -+"%4431$s" "%4432$s" "%4433$s" "%4434$s" "%4435$s" "%4436$s" "%4437$s" "%4438$s" "%4439$s" "%4440$s" -+"%4441$s" "%4442$s" "%4443$s" "%4444$s" "%4445$s" "%4446$s" "%4447$s" "%4448$s" "%4449$s" "%4450$s" -+"%4451$s" "%4452$s" "%4453$s" "%4454$s" "%4455$s" "%4456$s" "%4457$s" "%4458$s" "%4459$s" "%4460$s" -+"%4461$s" "%4462$s" "%4463$s" "%4464$s" "%4465$s" "%4466$s" "%4467$s" "%4468$s" "%4469$s" "%4470$s" -+"%4471$s" "%4472$s" "%4473$s" "%4474$s" "%4475$s" "%4476$s" "%4477$s" "%4478$s" "%4479$s" "%4480$s" -+"%4481$s" "%4482$s" "%4483$s" "%4484$s" "%4485$s" "%4486$s" "%4487$s" "%4488$s" "%4489$s" "%4490$s" -+"%4491$s" "%4492$s" "%4493$s" "%4494$s" "%4495$s" "%4496$s" "%4497$s" "%4498$s" "%4499$s" "%4500$s" -+"%4501$s" "%4502$s" "%4503$s" "%4504$s" "%4505$s" "%4506$s" "%4507$s" "%4508$s" "%4509$s" "%4510$s" -+"%4511$s" "%4512$s" "%4513$s" "%4514$s" "%4515$s" "%4516$s" "%4517$s" "%4518$s" "%4519$s" "%4520$s" -+"%4521$s" "%4522$s" "%4523$s" "%4524$s" "%4525$s" "%4526$s" "%4527$s" "%4528$s" "%4529$s" "%4530$s" -+"%4531$s" "%4532$s" "%4533$s" "%4534$s" "%4535$s" "%4536$s" "%4537$s" "%4538$s" "%4539$s" "%4540$s" -+"%4541$s" "%4542$s" "%4543$s" "%4544$s" "%4545$s" "%4546$s" "%4547$s" "%4548$s" "%4549$s" "%4550$s" -+"%4551$s" "%4552$s" "%4553$s" "%4554$s" "%4555$s" "%4556$s" "%4557$s" "%4558$s" "%4559$s" "%4560$s" -+"%4561$s" "%4562$s" "%4563$s" "%4564$s" "%4565$s" "%4566$s" "%4567$s" "%4568$s" "%4569$s" "%4570$s" -+"%4571$s" "%4572$s" "%4573$s" "%4574$s" "%4575$s" "%4576$s" "%4577$s" "%4578$s" "%4579$s" "%4580$s" -+"%4581$s" "%4582$s" "%4583$s" "%4584$s" "%4585$s" "%4586$s" "%4587$s" "%4588$s" "%4589$s" "%4590$s" -+"%4591$s" "%4592$s" "%4593$s" "%4594$s" "%4595$s" "%4596$s" "%4597$s" "%4598$s" "%4599$s" "%4600$s" -+"%4601$s" "%4602$s" "%4603$s" "%4604$s" "%4605$s" "%4606$s" "%4607$s" "%4608$s" "%4609$s" "%4610$s" -+"%4611$s" "%4612$s" "%4613$s" "%4614$s" "%4615$s" "%4616$s" "%4617$s" "%4618$s" "%4619$s" "%4620$s" -+"%4621$s" "%4622$s" "%4623$s" "%4624$s" "%4625$s" "%4626$s" "%4627$s" "%4628$s" "%4629$s" "%4630$s" -+"%4631$s" "%4632$s" "%4633$s" "%4634$s" "%4635$s" "%4636$s" "%4637$s" "%4638$s" "%4639$s" "%4640$s" -+"%4641$s" "%4642$s" "%4643$s" "%4644$s" "%4645$s" "%4646$s" "%4647$s" "%4648$s" "%4649$s" "%4650$s" -+"%4651$s" "%4652$s" "%4653$s" "%4654$s" "%4655$s" "%4656$s" "%4657$s" "%4658$s" "%4659$s" "%4660$s" -+"%4661$s" "%4662$s" "%4663$s" "%4664$s" "%4665$s" "%4666$s" "%4667$s" "%4668$s" "%4669$s" "%4670$s" -+"%4671$s" "%4672$s" "%4673$s" "%4674$s" "%4675$s" "%4676$s" "%4677$s" "%4678$s" "%4679$s" "%4680$s" -+"%4681$s" "%4682$s" "%4683$s" "%4684$s" "%4685$s" "%4686$s" "%4687$s" "%4688$s" "%4689$s" "%4690$s" -+"%4691$s" "%4692$s" "%4693$s" "%4694$s" "%4695$s" "%4696$s" "%4697$s" "%4698$s" "%4699$s" "%4700$s" -+"%4701$s" "%4702$s" "%4703$s" "%4704$s" "%4705$s" "%4706$s" "%4707$s" "%4708$s" "%4709$s" "%4710$s" -+"%4711$s" "%4712$s" "%4713$s" "%4714$s" "%4715$s" "%4716$s" "%4717$s" "%4718$s" "%4719$s" "%4720$s" -+"%4721$s" "%4722$s" "%4723$s" "%4724$s" "%4725$s" "%4726$s" "%4727$s" "%4728$s" "%4729$s" "%4730$s" -+"%4731$s" "%4732$s" "%4733$s" "%4734$s" "%4735$s" "%4736$s" "%4737$s" "%4738$s" "%4739$s" "%4740$s" -+"%4741$s" "%4742$s" "%4743$s" "%4744$s" "%4745$s" "%4746$s" "%4747$s" "%4748$s" "%4749$s" "%4750$s" -+"%4751$s" "%4752$s" "%4753$s" "%4754$s" "%4755$s" "%4756$s" "%4757$s" "%4758$s" "%4759$s" "%4760$s" -+"%4761$s" "%4762$s" "%4763$s" "%4764$s" "%4765$s" "%4766$s" "%4767$s" "%4768$s" "%4769$s" "%4770$s" -+"%4771$s" "%4772$s" "%4773$s" "%4774$s" "%4775$s" "%4776$s" "%4777$s" "%4778$s" "%4779$s" "%4780$s" -+"%4781$s" "%4782$s" "%4783$s" "%4784$s" "%4785$s" "%4786$s" "%4787$s" "%4788$s" "%4789$s" "%4790$s" -+"%4791$s" "%4792$s" "%4793$s" "%4794$s" "%4795$s" "%4796$s" "%4797$s" "%4798$s" "%4799$s" "%4800$s" -+"%4801$s" "%4802$s" "%4803$s" "%4804$s" "%4805$s" "%4806$s" "%4807$s" "%4808$s" "%4809$s" "%4810$s" -+"%4811$s" "%4812$s" "%4813$s" "%4814$s" "%4815$s" "%4816$s" "%4817$s" "%4818$s" "%4819$s" "%4820$s" -+"%4821$s" "%4822$s" "%4823$s" "%4824$s" "%4825$s" "%4826$s" "%4827$s" "%4828$s" "%4829$s" "%4830$s" -+"%4831$s" "%4832$s" "%4833$s" "%4834$s" "%4835$s" "%4836$s" "%4837$s" "%4838$s" "%4839$s" "%4840$s" -+"%4841$s" "%4842$s" "%4843$s" "%4844$s" "%4845$s" "%4846$s" "%4847$s" "%4848$s" "%4849$s" "%4850$s" -+"%4851$s" "%4852$s" "%4853$s" "%4854$s" "%4855$s" "%4856$s" "%4857$s" "%4858$s" "%4859$s" "%4860$s" -+"%4861$s" "%4862$s" "%4863$s" "%4864$s" "%4865$s" "%4866$s" "%4867$s" "%4868$s" "%4869$s" "%4870$s" -+"%4871$s" "%4872$s" "%4873$s" "%4874$s" "%4875$s" "%4876$s" "%4877$s" "%4878$s" "%4879$s" "%4880$s" -+"%4881$s" "%4882$s" "%4883$s" "%4884$s" "%4885$s" "%4886$s" "%4887$s" "%4888$s" "%4889$s" "%4890$s" -+"%4891$s" "%4892$s" "%4893$s" "%4894$s" "%4895$s" "%4896$s" "%4897$s" "%4898$s" "%4899$s" "%4900$s" -+"%4901$s" "%4902$s" "%4903$s" "%4904$s" "%4905$s" "%4906$s" "%4907$s" "%4908$s" "%4909$s" "%4910$s" -+"%4911$s" "%4912$s" "%4913$s" "%4914$s" "%4915$s" "%4916$s" "%4917$s" "%4918$s" "%4919$s" "%4920$s" -+"%4921$s" "%4922$s" "%4923$s" "%4924$s" "%4925$s" "%4926$s" "%4927$s" "%4928$s" "%4929$s" "%4930$s" -+"%4931$s" "%4932$s" "%4933$s" "%4934$s" "%4935$s" "%4936$s" "%4937$s" "%4938$s" "%4939$s" "%4940$s" -+"%4941$s" "%4942$s" "%4943$s" "%4944$s" "%4945$s" "%4946$s" "%4947$s" "%4948$s" "%4949$s" "%4950$s" -+"%4951$s" "%4952$s" "%4953$s" "%4954$s" "%4955$s" "%4956$s" "%4957$s" "%4958$s" "%4959$s" "%4960$s" -+"%4961$s" "%4962$s" "%4963$s" "%4964$s" "%4965$s" "%4966$s" "%4967$s" "%4968$s" "%4969$s" "%4970$s" -+"%4971$s" "%4972$s" "%4973$s" "%4974$s" "%4975$s" "%4976$s" "%4977$s" "%4978$s" "%4979$s" "%4980$s" -+"%4981$s" "%4982$s" "%4983$s" "%4984$s" "%4985$s" "%4986$s" "%4987$s" "%4988$s" "%4989$s" "%4990$s" -+"%4991$s" "%4992$s" "%4993$s" "%4994$s" "%4995$s" "%4996$s" "%4997$s" "%4998$s" "%4999$s" "%5000$s" -+"%5001$s" "%5002$s" "%5003$s" "%5004$s" "%5005$s" "%5006$s" "%5007$s" "%5008$s" "%5009$s" "%5010$s" -+"%5011$s" "%5012$s" "%5013$s" "%5014$s" "%5015$s" "%5016$s" "%5017$s" "%5018$s" "%5019$s" "%5020$s" -+"%5021$s" "%5022$s" "%5023$s" "%5024$s" "%5025$s" "%5026$s" "%5027$s" "%5028$s" "%5029$s" "%5030$s" -+"%5031$s" "%5032$s" "%5033$s" "%5034$s" "%5035$s" "%5036$s" "%5037$s" "%5038$s" "%5039$s" "%5040$s" -+"%5041$s" "%5042$s" "%5043$s" "%5044$s" "%5045$s" "%5046$s" "%5047$s" "%5048$s" "%5049$s" "%5050$s" -+"%5051$s" "%5052$s" "%5053$s" "%5054$s" "%5055$s" "%5056$s" "%5057$s" "%5058$s" "%5059$s" "%5060$s" -+"%5061$s" "%5062$s" "%5063$s" "%5064$s" "%5065$s" "%5066$s" "%5067$s" "%5068$s" "%5069$s" "%5070$s" -+"%5071$s" "%5072$s" "%5073$s" "%5074$s" "%5075$s" "%5076$s" "%5077$s" "%5078$s" "%5079$s" "%5080$s" -+"%5081$s" "%5082$s" "%5083$s" "%5084$s" "%5085$s" "%5086$s" "%5087$s" "%5088$s" "%5089$s" "%5090$s" -+"%5091$s" "%5092$s" "%5093$s" "%5094$s" "%5095$s" "%5096$s" "%5097$s" "%5098$s" "%5099$s" "%5100$s" -+"%5101$s" "%5102$s" "%5103$s" "%5104$s" "%5105$s" "%5106$s" "%5107$s" "%5108$s" "%5109$s" "%5110$s" -+"%5111$s" "%5112$s" "%5113$s" "%5114$s" "%5115$s" "%5116$s" "%5117$s" "%5118$s" "%5119$s" "%5120$s" -+"%5121$s" "%5122$s" "%5123$s" "%5124$s" "%5125$s" "%5126$s" "%5127$s" "%5128$s" "%5129$s" "%5130$s" -+"%5131$s" "%5132$s" "%5133$s" "%5134$s" "%5135$s" "%5136$s" "%5137$s" "%5138$s" "%5139$s" "%5140$s" -+"%5141$s" "%5142$s" "%5143$s" "%5144$s" "%5145$s" "%5146$s" "%5147$s" "%5148$s" "%5149$s" "%5150$s" -+"%5151$s" "%5152$s" "%5153$s" "%5154$s" "%5155$s" "%5156$s" "%5157$s" "%5158$s" "%5159$s" "%5160$s" -+"%5161$s" "%5162$s" "%5163$s" "%5164$s" "%5165$s" "%5166$s" "%5167$s" "%5168$s" "%5169$s" "%5170$s" -+"%5171$s" "%5172$s" "%5173$s" "%5174$s" "%5175$s" "%5176$s" "%5177$s" "%5178$s" "%5179$s" "%5180$s" -+"%5181$s" "%5182$s" "%5183$s" "%5184$s" "%5185$s" "%5186$s" "%5187$s" "%5188$s" "%5189$s" "%5190$s" -+"%5191$s" "%5192$s" "%5193$s" "%5194$s" "%5195$s" "%5196$s" "%5197$s" "%5198$s" "%5199$s" "%5200$s" -+"%5201$s" "%5202$s" "%5203$s" "%5204$s" "%5205$s" "%5206$s" "%5207$s" "%5208$s" "%5209$s" "%5210$s" -+"%5211$s" "%5212$s" "%5213$s" "%5214$s" "%5215$s" "%5216$s" "%5217$s" "%5218$s" "%5219$s" "%5220$s" -+"%5221$s" "%5222$s" "%5223$s" "%5224$s" "%5225$s" "%5226$s" "%5227$s" "%5228$s" "%5229$s" "%5230$s" -+"%5231$s" "%5232$s" "%5233$s" "%5234$s" "%5235$s" "%5236$s" "%5237$s" "%5238$s" "%5239$s" "%5240$s" -+"%5241$s" "%5242$s" "%5243$s" "%5244$s" "%5245$s" "%5246$s" "%5247$s" "%5248$s" "%5249$s" "%5250$s" -+"%5251$s" "%5252$s" "%5253$s" "%5254$s" "%5255$s" "%5256$s" "%5257$s" "%5258$s" "%5259$s" "%5260$s" -+"%5261$s" "%5262$s" "%5263$s" "%5264$s" "%5265$s" "%5266$s" "%5267$s" "%5268$s" "%5269$s" "%5270$s" -+"%5271$s" "%5272$s" "%5273$s" "%5274$s" "%5275$s" "%5276$s" "%5277$s" "%5278$s" "%5279$s" "%5280$s" -+"%5281$s" "%5282$s" "%5283$s" "%5284$s" "%5285$s" "%5286$s" "%5287$s" "%5288$s" "%5289$s" "%5290$s" -+"%5291$s" "%5292$s" "%5293$s" "%5294$s" "%5295$s" "%5296$s" "%5297$s" "%5298$s" "%5299$s" "%5300$s" -+"%5301$s" "%5302$s" "%5303$s" "%5304$s" "%5305$s" "%5306$s" "%5307$s" "%5308$s" "%5309$s" "%5310$s" -+"%5311$s" "%5312$s" "%5313$s" "%5314$s" "%5315$s" "%5316$s" "%5317$s" "%5318$s" "%5319$s" "%5320$s" -+"%5321$s" "%5322$s" "%5323$s" "%5324$s" "%5325$s" "%5326$s" "%5327$s" "%5328$s" "%5329$s" "%5330$s" -+"%5331$s" "%5332$s" "%5333$s" "%5334$s" "%5335$s" "%5336$s" "%5337$s" "%5338$s" "%5339$s" "%5340$s" -+"%5341$s" "%5342$s" "%5343$s" "%5344$s" "%5345$s" "%5346$s" "%5347$s" "%5348$s" "%5349$s" "%5350$s" -+"%5351$s" "%5352$s" "%5353$s" "%5354$s" "%5355$s" "%5356$s" "%5357$s" "%5358$s" "%5359$s" "%5360$s" -+"%5361$s" "%5362$s" "%5363$s" "%5364$s" "%5365$s" "%5366$s" "%5367$s" "%5368$s" "%5369$s" "%5370$s" -+"%5371$s" "%5372$s" "%5373$s" "%5374$s" "%5375$s" "%5376$s" "%5377$s" "%5378$s" "%5379$s" "%5380$s" -+"%5381$s" "%5382$s" "%5383$s" "%5384$s" "%5385$s" "%5386$s" "%5387$s" "%5388$s" "%5389$s" "%5390$s" -+"%5391$s" "%5392$s" "%5393$s" "%5394$s" "%5395$s" "%5396$s" "%5397$s" "%5398$s" "%5399$s" "%5400$s" -+"%5401$s" "%5402$s" "%5403$s" "%5404$s" "%5405$s" "%5406$s" "%5407$s" "%5408$s" "%5409$s" "%5410$s" -+"%5411$s" "%5412$s" "%5413$s" "%5414$s" "%5415$s" "%5416$s" "%5417$s" "%5418$s" "%5419$s" "%5420$s" -+"%5421$s" "%5422$s" "%5423$s" "%5424$s" "%5425$s" "%5426$s" "%5427$s" "%5428$s" "%5429$s" "%5430$s" -+"%5431$s" "%5432$s" "%5433$s" "%5434$s" "%5435$s" "%5436$s" "%5437$s" "%5438$s" "%5439$s" "%5440$s" -+"%5441$s" "%5442$s" "%5443$s" "%5444$s" "%5445$s" "%5446$s" "%5447$s" "%5448$s" "%5449$s" "%5450$s" -+"%5451$s" "%5452$s" "%5453$s" "%5454$s" "%5455$s" "%5456$s" "%5457$s" "%5458$s" "%5459$s" "%5460$s" -+"%5461$s" "%5462$s" "%5463$s" "%5464$s" "%5465$s" "%5466$s" "%5467$s" "%5468$s" "%5469$s" "%5470$s" -+"%5471$s" "%5472$s" "%5473$s" "%5474$s" "%5475$s" "%5476$s" "%5477$s" "%5478$s" "%5479$s" "%5480$s" -+"%5481$s" "%5482$s" "%5483$s" "%5484$s" "%5485$s" "%5486$s" "%5487$s" "%5488$s" "%5489$s" "%5490$s" -+"%5491$s" "%5492$s" "%5493$s" "%5494$s" "%5495$s" "%5496$s" "%5497$s" "%5498$s" "%5499$s" "%5500$s" -+"%5501$s" "%5502$s" "%5503$s" "%5504$s" "%5505$s" "%5506$s" "%5507$s" "%5508$s" "%5509$s" "%5510$s" -+"%5511$s" "%5512$s" "%5513$s" "%5514$s" "%5515$s" "%5516$s" "%5517$s" "%5518$s" "%5519$s" "%5520$s" -+"%5521$s" "%5522$s" "%5523$s" "%5524$s" "%5525$s" "%5526$s" "%5527$s" "%5528$s" "%5529$s" "%5530$s" -+"%5531$s" "%5532$s" "%5533$s" "%5534$s" "%5535$s" "%5536$s" "%5537$s" "%5538$s" "%5539$s" "%5540$s" -+"%5541$s" "%5542$s" "%5543$s" "%5544$s" "%5545$s" "%5546$s" "%5547$s" "%5548$s" "%5549$s" "%5550$s" -+"%5551$s" "%5552$s" "%5553$s" "%5554$s" "%5555$s" "%5556$s" "%5557$s" "%5558$s" "%5559$s" "%5560$s" -+"%5561$s" "%5562$s" "%5563$s" "%5564$s" "%5565$s" "%5566$s" "%5567$s" "%5568$s" "%5569$s" "%5570$s" -+"%5571$s" "%5572$s" "%5573$s" "%5574$s" "%5575$s" "%5576$s" "%5577$s" "%5578$s" "%5579$s" "%5580$s" -+"%5581$s" "%5582$s" "%5583$s" "%5584$s" "%5585$s" "%5586$s" "%5587$s" "%5588$s" "%5589$s" "%5590$s" -+"%5591$s" "%5592$s" "%5593$s" "%5594$s" "%5595$s" "%5596$s" "%5597$s" "%5598$s" "%5599$s" "%5600$s" -+"%5601$s" "%5602$s" "%5603$s" "%5604$s" "%5605$s" "%5606$s" "%5607$s" "%5608$s" "%5609$s" "%5610$s" -+"%5611$s" "%5612$s" "%5613$s" "%5614$s" "%5615$s" "%5616$s" "%5617$s" "%5618$s" "%5619$s" "%5620$s" -+"%5621$s" "%5622$s" "%5623$s" "%5624$s" "%5625$s" "%5626$s" "%5627$s" "%5628$s" "%5629$s" "%5630$s" -+"%5631$s" "%5632$s" "%5633$s" "%5634$s" "%5635$s" "%5636$s" "%5637$s" "%5638$s" "%5639$s" "%5640$s" -+"%5641$s" "%5642$s" "%5643$s" "%5644$s" "%5645$s" "%5646$s" "%5647$s" "%5648$s" "%5649$s" "%5650$s" -+"%5651$s" "%5652$s" "%5653$s" "%5654$s" "%5655$s" "%5656$s" "%5657$s" "%5658$s" "%5659$s" "%5660$s" -+"%5661$s" "%5662$s" "%5663$s" "%5664$s" "%5665$s" "%5666$s" "%5667$s" "%5668$s" "%5669$s" "%5670$s" -+"%5671$s" "%5672$s" "%5673$s" "%5674$s" "%5675$s" "%5676$s" "%5677$s" "%5678$s" "%5679$s" "%5680$s" -+"%5681$s" "%5682$s" "%5683$s" "%5684$s" "%5685$s" "%5686$s" "%5687$s" "%5688$s" "%5689$s" "%5690$s" -+"%5691$s" "%5692$s" "%5693$s" "%5694$s" "%5695$s" "%5696$s" "%5697$s" "%5698$s" "%5699$s" "%5700$s" -+"%5701$s" "%5702$s" "%5703$s" "%5704$s" "%5705$s" "%5706$s" "%5707$s" "%5708$s" "%5709$s" "%5710$s" -+"%5711$s" "%5712$s" "%5713$s" "%5714$s" "%5715$s" "%5716$s" "%5717$s" "%5718$s" "%5719$s" "%5720$s" -+"%5721$s" "%5722$s" "%5723$s" "%5724$s" "%5725$s" "%5726$s" "%5727$s" "%5728$s" "%5729$s" "%5730$s" -+"%5731$s" "%5732$s" "%5733$s" "%5734$s" "%5735$s" "%5736$s" "%5737$s" "%5738$s" "%5739$s" "%5740$s" -+"%5741$s" "%5742$s" "%5743$s" "%5744$s" "%5745$s" "%5746$s" "%5747$s" "%5748$s" "%5749$s" "%5750$s" -+"%5751$s" "%5752$s" "%5753$s" "%5754$s" "%5755$s" "%5756$s" "%5757$s" "%5758$s" "%5759$s" "%5760$s" -+"%5761$s" "%5762$s" "%5763$s" "%5764$s" "%5765$s" "%5766$s" "%5767$s" "%5768$s" "%5769$s" "%5770$s" -+"%5771$s" "%5772$s" "%5773$s" "%5774$s" "%5775$s" "%5776$s" "%5777$s" "%5778$s" "%5779$s" "%5780$s" -+"%5781$s" "%5782$s" "%5783$s" "%5784$s" "%5785$s" "%5786$s" "%5787$s" "%5788$s" "%5789$s" "%5790$s" -+"%5791$s" "%5792$s" "%5793$s" "%5794$s" "%5795$s" "%5796$s" "%5797$s" "%5798$s" "%5799$s" "%5800$s" -+"%5801$s" "%5802$s" "%5803$s" "%5804$s" "%5805$s" "%5806$s" "%5807$s" "%5808$s" "%5809$s" "%5810$s" -+"%5811$s" "%5812$s" "%5813$s" "%5814$s" "%5815$s" "%5816$s" "%5817$s" "%5818$s" "%5819$s" "%5820$s" -+"%5821$s" "%5822$s" "%5823$s" "%5824$s" "%5825$s" "%5826$s" "%5827$s" "%5828$s" "%5829$s" "%5830$s" -+"%5831$s" "%5832$s" "%5833$s" "%5834$s" "%5835$s" "%5836$s" "%5837$s" "%5838$s" "%5839$s" "%5840$s" -+"%5841$s" "%5842$s" "%5843$s" "%5844$s" "%5845$s" "%5846$s" "%5847$s" "%5848$s" "%5849$s" "%5850$s" -+"%5851$s" "%5852$s" "%5853$s" "%5854$s" "%5855$s" "%5856$s" "%5857$s" "%5858$s" "%5859$s" "%5860$s" -+"%5861$s" "%5862$s" "%5863$s" "%5864$s" "%5865$s" "%5866$s" "%5867$s" "%5868$s" "%5869$s" "%5870$s" -+"%5871$s" "%5872$s" "%5873$s" "%5874$s" "%5875$s" "%5876$s" "%5877$s" "%5878$s" "%5879$s" "%5880$s" -+"%5881$s" "%5882$s" "%5883$s" "%5884$s" "%5885$s" "%5886$s" "%5887$s" "%5888$s" "%5889$s" "%5890$s" -+"%5891$s" "%5892$s" "%5893$s" "%5894$s" "%5895$s" "%5896$s" "%5897$s" "%5898$s" "%5899$s" "%5900$s" -+"%5901$s" "%5902$s" "%5903$s" "%5904$s" "%5905$s" "%5906$s" "%5907$s" "%5908$s" "%5909$s" "%5910$s" -+"%5911$s" "%5912$s" "%5913$s" "%5914$s" "%5915$s" "%5916$s" "%5917$s" "%5918$s" "%5919$s" "%5920$s" -+"%5921$s" "%5922$s" "%5923$s" "%5924$s" "%5925$s" "%5926$s" "%5927$s" "%5928$s" "%5929$s" "%5930$s" -+"%5931$s" "%5932$s" "%5933$s" "%5934$s" "%5935$s" "%5936$s" "%5937$s" "%5938$s" "%5939$s" "%5940$s" -+"%5941$s" "%5942$s" "%5943$s" "%5944$s" "%5945$s" "%5946$s" "%5947$s" "%5948$s" "%5949$s" "%5950$s" -+"%5951$s" "%5952$s" "%5953$s" "%5954$s" "%5955$s" "%5956$s" "%5957$s" "%5958$s" "%5959$s" "%5960$s" -+"%5961$s" "%5962$s" "%5963$s" "%5964$s" "%5965$s" "%5966$s" "%5967$s" "%5968$s" "%5969$s" "%5970$s" -+"%5971$s" "%5972$s" "%5973$s" "%5974$s" "%5975$s" "%5976$s" "%5977$s" "%5978$s" "%5979$s" "%5980$s" -+"%5981$s" "%5982$s" "%5983$s" "%5984$s" "%5985$s" "%5986$s" "%5987$s" "%5988$s" "%5989$s" "%5990$s" -+"%5991$s" "%5992$s" "%5993$s" "%5994$s" "%5995$s" "%5996$s" "%5997$s" "%5998$s" "%5999$s" "%6000$s" -+"%6001$s" "%6002$s" "%6003$s" "%6004$s" "%6005$s" "%6006$s" "%6007$s" "%6008$s" "%6009$s" "%6010$s" -+"%6011$s" "%6012$s" "%6013$s" "%6014$s" "%6015$s" "%6016$s" "%6017$s" "%6018$s" "%6019$s" "%6020$s" -+"%6021$s" "%6022$s" "%6023$s" "%6024$s" "%6025$s" "%6026$s" "%6027$s" "%6028$s" "%6029$s" "%6030$s" -+"%6031$s" "%6032$s" "%6033$s" "%6034$s" "%6035$s" "%6036$s" "%6037$s" "%6038$s" "%6039$s" "%6040$s" -+"%6041$s" "%6042$s" "%6043$s" "%6044$s" "%6045$s" "%6046$s" "%6047$s" "%6048$s" "%6049$s" "%6050$s" -+"%6051$s" "%6052$s" "%6053$s" "%6054$s" "%6055$s" "%6056$s" "%6057$s" "%6058$s" "%6059$s" "%6060$s" -+"%6061$s" "%6062$s" "%6063$s" "%6064$s" "%6065$s" "%6066$s" "%6067$s" "%6068$s" "%6069$s" "%6070$s" -+"%6071$s" "%6072$s" "%6073$s" "%6074$s" "%6075$s" "%6076$s" "%6077$s" "%6078$s" "%6079$s" "%6080$s" -+"%6081$s" "%6082$s" "%6083$s" "%6084$s" "%6085$s" "%6086$s" "%6087$s" "%6088$s" "%6089$s" "%6090$s" -+"%6091$s" "%6092$s" "%6093$s" "%6094$s" "%6095$s" "%6096$s" "%6097$s" "%6098$s" "%6099$s" "%6100$s" -+"%6101$s" "%6102$s" "%6103$s" "%6104$s" "%6105$s" "%6106$s" "%6107$s" "%6108$s" "%6109$s" "%6110$s" -+"%6111$s" "%6112$s" "%6113$s" "%6114$s" "%6115$s" "%6116$s" "%6117$s" "%6118$s" "%6119$s" "%6120$s" -+"%6121$s" "%6122$s" "%6123$s" "%6124$s" "%6125$s" "%6126$s" "%6127$s" "%6128$s" "%6129$s" "%6130$s" -+"%6131$s" "%6132$s" "%6133$s" "%6134$s" "%6135$s" "%6136$s" "%6137$s" "%6138$s" "%6139$s" "%6140$s" -+"%6141$s" "%6142$s" "%6143$s" "%6144$s" "%6145$s" "%6146$s" "%6147$s" "%6148$s" "%6149$s" "%6150$s" -+"%6151$s" "%6152$s" "%6153$s" "%6154$s" "%6155$s" "%6156$s" "%6157$s" "%6158$s" "%6159$s" "%6160$s" -+"%6161$s" "%6162$s" "%6163$s" "%6164$s" "%6165$s" "%6166$s" "%6167$s" "%6168$s" "%6169$s" "%6170$s" -+"%6171$s" "%6172$s" "%6173$s" "%6174$s" "%6175$s" "%6176$s" "%6177$s" "%6178$s" "%6179$s" "%6180$s" -+"%6181$s" "%6182$s" "%6183$s" "%6184$s" "%6185$s" "%6186$s" "%6187$s" "%6188$s" "%6189$s" "%6190$s" -+"%6191$s" "%6192$s" "%6193$s" "%6194$s" "%6195$s" "%6196$s" "%6197$s" "%6198$s" "%6199$s" "%6200$s" -+"%6201$s" "%6202$s" "%6203$s" "%6204$s" "%6205$s" "%6206$s" "%6207$s" "%6208$s" "%6209$s" "%6210$s" -+"%6211$s" "%6212$s" "%6213$s" "%6214$s" "%6215$s" "%6216$s" "%6217$s" "%6218$s" "%6219$s" "%6220$s" -+"%6221$s" "%6222$s" "%6223$s" "%6224$s" "%6225$s" "%6226$s" "%6227$s" "%6228$s" "%6229$s" "%6230$s" -+"%6231$s" "%6232$s" "%6233$s" "%6234$s" "%6235$s" "%6236$s" "%6237$s" "%6238$s" "%6239$s" "%6240$s" -+"%6241$s" "%6242$s" "%6243$s" "%6244$s" "%6245$s" "%6246$s" "%6247$s" "%6248$s" "%6249$s" "%6250$s" -+"%6251$s" "%6252$s" "%6253$s" "%6254$s" "%6255$s" "%6256$s" "%6257$s" "%6258$s" "%6259$s" "%6260$s" -+"%6261$s" "%6262$s" "%6263$s" "%6264$s" "%6265$s" "%6266$s" "%6267$s" "%6268$s" "%6269$s" "%6270$s" -+"%6271$s" "%6272$s" "%6273$s" "%6274$s" "%6275$s" "%6276$s" "%6277$s" "%6278$s" "%6279$s" "%6280$s" -+"%6281$s" "%6282$s" "%6283$s" "%6284$s" "%6285$s" "%6286$s" "%6287$s" "%6288$s" "%6289$s" "%6290$s" -+"%6291$s" "%6292$s" "%6293$s" "%6294$s" "%6295$s" "%6296$s" "%6297$s" "%6298$s" "%6299$s" "%6300$s" -+"%6301$s" "%6302$s" "%6303$s" "%6304$s" "%6305$s" "%6306$s" "%6307$s" "%6308$s" "%6309$s" "%6310$s" -+"%6311$s" "%6312$s" "%6313$s" "%6314$s" "%6315$s" "%6316$s" "%6317$s" "%6318$s" "%6319$s" "%6320$s" -+"%6321$s" "%6322$s" "%6323$s" "%6324$s" "%6325$s" "%6326$s" "%6327$s" "%6328$s" "%6329$s" "%6330$s" -+"%6331$s" "%6332$s" "%6333$s" "%6334$s" "%6335$s" "%6336$s" "%6337$s" "%6338$s" "%6339$s" "%6340$s" -+"%6341$s" "%6342$s" "%6343$s" "%6344$s" "%6345$s" "%6346$s" "%6347$s" "%6348$s" "%6349$s" "%6350$s" -+"%6351$s" "%6352$s" "%6353$s" "%6354$s" "%6355$s" "%6356$s" "%6357$s" "%6358$s" "%6359$s" "%6360$s" -+"%6361$s" "%6362$s" "%6363$s" "%6364$s" "%6365$s" "%6366$s" "%6367$s" "%6368$s" "%6369$s" "%6370$s" -+"%6371$s" "%6372$s" "%6373$s" "%6374$s" "%6375$s" "%6376$s" "%6377$s" "%6378$s" "%6379$s" "%6380$s" -+"%6381$s" "%6382$s" "%6383$s" "%6384$s" "%6385$s" "%6386$s" "%6387$s" "%6388$s" "%6389$s" "%6390$s" -+"%6391$s" "%6392$s" "%6393$s" "%6394$s" "%6395$s" "%6396$s" "%6397$s" "%6398$s" "%6399$s" "%6400$s" -+"%6401$s" "%6402$s" "%6403$s" "%6404$s" "%6405$s" "%6406$s" "%6407$s" "%6408$s" "%6409$s" "%6410$s" -+"%6411$s" "%6412$s" "%6413$s" "%6414$s" "%6415$s" "%6416$s" "%6417$s" "%6418$s" "%6419$s" "%6420$s" -+"%6421$s" "%6422$s" "%6423$s" "%6424$s" "%6425$s" "%6426$s" "%6427$s" "%6428$s" "%6429$s" "%6430$s" -+"%6431$s" "%6432$s" "%6433$s" "%6434$s" "%6435$s" "%6436$s" "%6437$s" "%6438$s" "%6439$s" "%6440$s" -+"%6441$s" "%6442$s" "%6443$s" "%6444$s" "%6445$s" "%6446$s" "%6447$s" "%6448$s" "%6449$s" "%6450$s" -+"%6451$s" "%6452$s" "%6453$s" "%6454$s" "%6455$s" "%6456$s" "%6457$s" "%6458$s" "%6459$s" "%6460$s" -+"%6461$s" "%6462$s" "%6463$s" "%6464$s" "%6465$s" "%6466$s" "%6467$s" "%6468$s" "%6469$s" "%6470$s" -+"%6471$s" "%6472$s" "%6473$s" "%6474$s" "%6475$s" "%6476$s" "%6477$s" "%6478$s" "%6479$s" "%6480$s" -+"%6481$s" "%6482$s" "%6483$s" "%6484$s" "%6485$s" "%6486$s" "%6487$s" "%6488$s" "%6489$s" "%6490$s" -+"%6491$s" "%6492$s" "%6493$s" "%6494$s" "%6495$s" "%6496$s" "%6497$s" "%6498$s" "%6499$s" "%6500$s" -+"%6501$s" "%6502$s" "%6503$s" "%6504$s" "%6505$s" "%6506$s" "%6507$s" "%6508$s" "%6509$s" "%6510$s" -+"%6511$s" "%6512$s" "%6513$s" "%6514$s" "%6515$s" "%6516$s" "%6517$s" "%6518$s" "%6519$s" "%6520$s" -+"%6521$s" "%6522$s" "%6523$s" "%6524$s" "%6525$s" "%6526$s" "%6527$s" "%6528$s" "%6529$s" "%6530$s" -+"%6531$s" "%6532$s" "%6533$s" "%6534$s" "%6535$s" "%6536$s" "%6537$s" "%6538$s" "%6539$s" "%6540$s" -+"%6541$s" "%6542$s" "%6543$s" "%6544$s" "%6545$s" "%6546$s" "%6547$s" "%6548$s" "%6549$s" "%6550$s" -+"%6551$s" "%6552$s" "%6553$s" "%6554$s" "%6555$s" "%6556$s" "%6557$s" "%6558$s" "%6559$s" "%6560$s" -+"%6561$s" "%6562$s" "%6563$s" "%6564$s" "%6565$s" "%6566$s" "%6567$s" "%6568$s" "%6569$s" "%6570$s" -+"%6571$s" "%6572$s" "%6573$s" "%6574$s" "%6575$s" "%6576$s" "%6577$s" "%6578$s" "%6579$s" "%6580$s" -+"%6581$s" "%6582$s" "%6583$s" "%6584$s" "%6585$s" "%6586$s" "%6587$s" "%6588$s" "%6589$s" "%6590$s" -+"%6591$s" "%6592$s" "%6593$s" "%6594$s" "%6595$s" "%6596$s" "%6597$s" "%6598$s" "%6599$s" "%6600$s" -+"%6601$s" "%6602$s" "%6603$s" "%6604$s" "%6605$s" "%6606$s" "%6607$s" "%6608$s" "%6609$s" "%6610$s" -+"%6611$s" "%6612$s" "%6613$s" "%6614$s" "%6615$s" "%6616$s" "%6617$s" "%6618$s" "%6619$s" "%6620$s" -+"%6621$s" "%6622$s" "%6623$s" "%6624$s" "%6625$s" "%6626$s" "%6627$s" "%6628$s" "%6629$s" "%6630$s" -+"%6631$s" "%6632$s" "%6633$s" "%6634$s" "%6635$s" "%6636$s" "%6637$s" "%6638$s" "%6639$s" "%6640$s" -+"%6641$s" "%6642$s" "%6643$s" "%6644$s" "%6645$s" "%6646$s" "%6647$s" "%6648$s" "%6649$s" "%6650$s" -+"%6651$s" "%6652$s" "%6653$s" "%6654$s" "%6655$s" "%6656$s" "%6657$s" "%6658$s" "%6659$s" "%6660$s" -+"%6661$s" "%6662$s" "%6663$s" "%6664$s" "%6665$s" "%6666$s" "%6667$s" "%6668$s" "%6669$s" "%6670$s" -+"%6671$s" "%6672$s" "%6673$s" "%6674$s" "%6675$s" "%6676$s" "%6677$s" "%6678$s" "%6679$s" "%6680$s" -+"%6681$s" "%6682$s" "%6683$s" "%6684$s" "%6685$s" "%6686$s" "%6687$s" "%6688$s" "%6689$s" "%6690$s" -+"%6691$s" "%6692$s" "%6693$s" "%6694$s" "%6695$s" "%6696$s" "%6697$s" "%6698$s" "%6699$s" "%6700$s" -+"%6701$s" "%6702$s" "%6703$s" "%6704$s" "%6705$s" "%6706$s" "%6707$s" "%6708$s" "%6709$s" "%6710$s" -+"%6711$s" "%6712$s" "%6713$s" "%6714$s" "%6715$s" "%6716$s" "%6717$s" "%6718$s" "%6719$s" "%6720$s" -+"%6721$s" "%6722$s" "%6723$s" "%6724$s" "%6725$s" "%6726$s" "%6727$s" "%6728$s" "%6729$s" "%6730$s" -+"%6731$s" "%6732$s" "%6733$s" "%6734$s" "%6735$s" "%6736$s" "%6737$s" "%6738$s" "%6739$s" "%6740$s" -+"%6741$s" "%6742$s" "%6743$s" "%6744$s" "%6745$s" "%6746$s" "%6747$s" "%6748$s" "%6749$s" "%6750$s" -+"%6751$s" "%6752$s" "%6753$s" "%6754$s" "%6755$s" "%6756$s" "%6757$s" "%6758$s" "%6759$s" "%6760$s" -+"%6761$s" "%6762$s" "%6763$s" "%6764$s" "%6765$s" "%6766$s" "%6767$s" "%6768$s" "%6769$s" "%6770$s" -+"%6771$s" "%6772$s" "%6773$s" "%6774$s" "%6775$s" "%6776$s" "%6777$s" "%6778$s" "%6779$s" "%6780$s" -+"%6781$s" "%6782$s" "%6783$s" "%6784$s" "%6785$s" "%6786$s" "%6787$s" "%6788$s" "%6789$s" "%6790$s" -+"%6791$s" "%6792$s" "%6793$s" "%6794$s" "%6795$s" "%6796$s" "%6797$s" "%6798$s" "%6799$s" "%6800$s" -+"%6801$s" "%6802$s" "%6803$s" "%6804$s" "%6805$s" "%6806$s" "%6807$s" "%6808$s" "%6809$s" "%6810$s" -+"%6811$s" "%6812$s" "%6813$s" "%6814$s" "%6815$s" "%6816$s" "%6817$s" "%6818$s" "%6819$s" "%6820$s" -+"%6821$s" "%6822$s" "%6823$s" "%6824$s" "%6825$s" "%6826$s" "%6827$s" "%6828$s" "%6829$s" "%6830$s" -+"%6831$s" "%6832$s" "%6833$s" "%6834$s" "%6835$s" "%6836$s" "%6837$s" "%6838$s" "%6839$s" "%6840$s" -+"%6841$s" "%6842$s" "%6843$s" "%6844$s" "%6845$s" "%6846$s" "%6847$s" "%6848$s" "%6849$s" "%6850$s" -+"%6851$s" "%6852$s" "%6853$s" "%6854$s" "%6855$s" "%6856$s" "%6857$s" "%6858$s" "%6859$s" "%6860$s" -+"%6861$s" "%6862$s" "%6863$s" "%6864$s" "%6865$s" "%6866$s" "%6867$s" "%6868$s" "%6869$s" "%6870$s" -+"%6871$s" "%6872$s" "%6873$s" "%6874$s" "%6875$s" "%6876$s" "%6877$s" "%6878$s" "%6879$s" "%6880$s" -+"%6881$s" "%6882$s" "%6883$s" "%6884$s" "%6885$s" "%6886$s" "%6887$s" "%6888$s" "%6889$s" "%6890$s" -+"%6891$s" "%6892$s" "%6893$s" "%6894$s" "%6895$s" "%6896$s" "%6897$s" "%6898$s" "%6899$s" "%6900$s" -+"%6901$s" "%6902$s" "%6903$s" "%6904$s" "%6905$s" "%6906$s" "%6907$s" "%6908$s" "%6909$s" "%6910$s" -+"%6911$s" "%6912$s" "%6913$s" "%6914$s" "%6915$s" "%6916$s" "%6917$s" "%6918$s" "%6919$s" "%6920$s" -+"%6921$s" "%6922$s" "%6923$s" "%6924$s" "%6925$s" "%6926$s" "%6927$s" "%6928$s" "%6929$s" "%6930$s" -+"%6931$s" "%6932$s" "%6933$s" "%6934$s" "%6935$s" "%6936$s" "%6937$s" "%6938$s" "%6939$s" "%6940$s" -+"%6941$s" "%6942$s" "%6943$s" "%6944$s" "%6945$s" "%6946$s" "%6947$s" "%6948$s" "%6949$s" "%6950$s" -+"%6951$s" "%6952$s" "%6953$s" "%6954$s" "%6955$s" "%6956$s" "%6957$s" "%6958$s" "%6959$s" "%6960$s" -+"%6961$s" "%6962$s" "%6963$s" "%6964$s" "%6965$s" "%6966$s" "%6967$s" "%6968$s" "%6969$s" "%6970$s" -+"%6971$s" "%6972$s" "%6973$s" "%6974$s" "%6975$s" "%6976$s" "%6977$s" "%6978$s" "%6979$s" "%6980$s" -+"%6981$s" "%6982$s" "%6983$s" "%6984$s" "%6985$s" "%6986$s" "%6987$s" "%6988$s" "%6989$s" "%6990$s" -+"%6991$s" "%6992$s" "%6993$s" "%6994$s" "%6995$s" "%6996$s" "%6997$s" "%6998$s" "%6999$s" "%7000$s" -+"%7001$s" "%7002$s" "%7003$s" "%7004$s" "%7005$s" "%7006$s" "%7007$s" "%7008$s" "%7009$s" "%7010$s" -+"%7011$s" "%7012$s" "%7013$s" "%7014$s" "%7015$s" "%7016$s" "%7017$s" "%7018$s" "%7019$s" "%7020$s" -+"%7021$s" "%7022$s" "%7023$s" "%7024$s" "%7025$s" "%7026$s" "%7027$s" "%7028$s" "%7029$s" "%7030$s" -+"%7031$s" "%7032$s" "%7033$s" "%7034$s" "%7035$s" "%7036$s" "%7037$s" "%7038$s" "%7039$s" "%7040$s" -+"%7041$s" "%7042$s" "%7043$s" "%7044$s" "%7045$s" "%7046$s" "%7047$s" "%7048$s" "%7049$s" "%7050$s" -+"%7051$s" "%7052$s" "%7053$s" "%7054$s" "%7055$s" "%7056$s" "%7057$s" "%7058$s" "%7059$s" "%7060$s" -+"%7061$s" "%7062$s" "%7063$s" "%7064$s" "%7065$s" "%7066$s" "%7067$s" "%7068$s" "%7069$s" "%7070$s" -+"%7071$s" "%7072$s" "%7073$s" "%7074$s" "%7075$s" "%7076$s" "%7077$s" "%7078$s" "%7079$s" "%7080$s" -+"%7081$s" "%7082$s" "%7083$s" "%7084$s" "%7085$s" "%7086$s" "%7087$s" "%7088$s" "%7089$s" "%7090$s" -+"%7091$s" "%7092$s" "%7093$s" "%7094$s" "%7095$s" "%7096$s" "%7097$s" "%7098$s" "%7099$s" "%7100$s" -+"%7101$s" "%7102$s" "%7103$s" "%7104$s" "%7105$s" "%7106$s" "%7107$s" "%7108$s" "%7109$s" "%7110$s" -+"%7111$s" "%7112$s" "%7113$s" "%7114$s" "%7115$s" "%7116$s" "%7117$s" "%7118$s" "%7119$s" "%7120$s" -+"%7121$s" "%7122$s" "%7123$s" "%7124$s" "%7125$s" "%7126$s" "%7127$s" "%7128$s" "%7129$s" "%7130$s" -+"%7131$s" "%7132$s" "%7133$s" "%7134$s" "%7135$s" "%7136$s" "%7137$s" "%7138$s" "%7139$s" "%7140$s" -+"%7141$s" "%7142$s" "%7143$s" "%7144$s" "%7145$s" "%7146$s" "%7147$s" "%7148$s" "%7149$s" "%7150$s" -+"%7151$s" "%7152$s" "%7153$s" "%7154$s" "%7155$s" "%7156$s" "%7157$s" "%7158$s" "%7159$s" "%7160$s" -+"%7161$s" "%7162$s" "%7163$s" "%7164$s" "%7165$s" "%7166$s" "%7167$s" "%7168$s" "%7169$s" "%7170$s" -+"%7171$s" "%7172$s" "%7173$s" "%7174$s" "%7175$s" "%7176$s" "%7177$s" "%7178$s" "%7179$s" "%7180$s" -+"%7181$s" "%7182$s" "%7183$s" "%7184$s" "%7185$s" "%7186$s" "%7187$s" "%7188$s" "%7189$s" "%7190$s" -+"%7191$s" "%7192$s" "%7193$s" "%7194$s" "%7195$s" "%7196$s" "%7197$s" "%7198$s" "%7199$s" "%7200$s" -+"%7201$s" "%7202$s" "%7203$s" "%7204$s" "%7205$s" "%7206$s" "%7207$s" "%7208$s" "%7209$s" "%7210$s" -+"%7211$s" "%7212$s" "%7213$s" "%7214$s" "%7215$s" "%7216$s" "%7217$s" "%7218$s" "%7219$s" "%7220$s" -+"%7221$s" "%7222$s" "%7223$s" "%7224$s" "%7225$s" "%7226$s" "%7227$s" "%7228$s" "%7229$s" "%7230$s" -+"%7231$s" "%7232$s" "%7233$s" "%7234$s" "%7235$s" "%7236$s" "%7237$s" "%7238$s" "%7239$s" "%7240$s" -+"%7241$s" "%7242$s" "%7243$s" "%7244$s" "%7245$s" "%7246$s" "%7247$s" "%7248$s" "%7249$s" "%7250$s" -+"%7251$s" "%7252$s" "%7253$s" "%7254$s" "%7255$s" "%7256$s" "%7257$s" "%7258$s" "%7259$s" "%7260$s" -+"%7261$s" "%7262$s" "%7263$s" "%7264$s" "%7265$s" "%7266$s" "%7267$s" "%7268$s" "%7269$s" "%7270$s" -+"%7271$s" "%7272$s" "%7273$s" "%7274$s" "%7275$s" "%7276$s" "%7277$s" "%7278$s" "%7279$s" "%7280$s" -+"%7281$s" "%7282$s" "%7283$s" "%7284$s" "%7285$s" "%7286$s" "%7287$s" "%7288$s" "%7289$s" "%7290$s" -+"%7291$s" "%7292$s" "%7293$s" "%7294$s" "%7295$s" "%7296$s" "%7297$s" "%7298$s" "%7299$s" "%7300$s" -+"%7301$s" "%7302$s" "%7303$s" "%7304$s" "%7305$s" "%7306$s" "%7307$s" "%7308$s" "%7309$s" "%7310$s" -+"%7311$s" "%7312$s" "%7313$s" "%7314$s" "%7315$s" "%7316$s" "%7317$s" "%7318$s" "%7319$s" "%7320$s" -+"%7321$s" "%7322$s" "%7323$s" "%7324$s" "%7325$s" "%7326$s" "%7327$s" "%7328$s" "%7329$s" "%7330$s" -+"%7331$s" "%7332$s" "%7333$s" "%7334$s" "%7335$s" "%7336$s" "%7337$s" "%7338$s" "%7339$s" "%7340$s" -+"%7341$s" "%7342$s" "%7343$s" "%7344$s" "%7345$s" "%7346$s" "%7347$s" "%7348$s" "%7349$s" "%7350$s" -+"%7351$s" "%7352$s" "%7353$s" "%7354$s" "%7355$s" "%7356$s" "%7357$s" "%7358$s" "%7359$s" "%7360$s" -+"%7361$s" "%7362$s" "%7363$s" "%7364$s" "%7365$s" "%7366$s" "%7367$s" "%7368$s" "%7369$s" "%7370$s" -+"%7371$s" "%7372$s" "%7373$s" "%7374$s" "%7375$s" "%7376$s" "%7377$s" "%7378$s" "%7379$s" "%7380$s" -+"%7381$s" "%7382$s" "%7383$s" "%7384$s" "%7385$s" "%7386$s" "%7387$s" "%7388$s" "%7389$s" "%7390$s" -+"%7391$s" "%7392$s" "%7393$s" "%7394$s" "%7395$s" "%7396$s" "%7397$s" "%7398$s" "%7399$s" "%7400$s" -+"%7401$s" "%7402$s" "%7403$s" "%7404$s" "%7405$s" "%7406$s" "%7407$s" "%7408$s" "%7409$s" "%7410$s" -+"%7411$s" "%7412$s" "%7413$s" "%7414$s" "%7415$s" "%7416$s" "%7417$s" "%7418$s" "%7419$s" "%7420$s" -+"%7421$s" "%7422$s" "%7423$s" "%7424$s" "%7425$s" "%7426$s" "%7427$s" "%7428$s" "%7429$s" "%7430$s" -+"%7431$s" "%7432$s" "%7433$s" "%7434$s" "%7435$s" "%7436$s" "%7437$s" "%7438$s" "%7439$s" "%7440$s" -+"%7441$s" "%7442$s" "%7443$s" "%7444$s" "%7445$s" "%7446$s" "%7447$s" "%7448$s" "%7449$s" "%7450$s" -+"%7451$s" "%7452$s" "%7453$s" "%7454$s" "%7455$s" "%7456$s" "%7457$s" "%7458$s" "%7459$s" "%7460$s" -+"%7461$s" "%7462$s" "%7463$s" "%7464$s" "%7465$s" "%7466$s" "%7467$s" "%7468$s" "%7469$s" "%7470$s" -+"%7471$s" "%7472$s" "%7473$s" "%7474$s" "%7475$s" "%7476$s" "%7477$s" "%7478$s" "%7479$s" "%7480$s" -+"%7481$s" "%7482$s" "%7483$s" "%7484$s" "%7485$s" "%7486$s" "%7487$s" "%7488$s" "%7489$s" "%7490$s" -+"%7491$s" "%7492$s" "%7493$s" "%7494$s" "%7495$s" "%7496$s" "%7497$s" "%7498$s" "%7499$s" "%7500$s" -+"%7501$s" "%7502$s" "%7503$s" "%7504$s" "%7505$s" "%7506$s" "%7507$s" "%7508$s" "%7509$s" "%7510$s" -+"%7511$s" "%7512$s" "%7513$s" "%7514$s" "%7515$s" "%7516$s" "%7517$s" "%7518$s" "%7519$s" "%7520$s" -+"%7521$s" "%7522$s" "%7523$s" "%7524$s" "%7525$s" "%7526$s" "%7527$s" "%7528$s" "%7529$s" "%7530$s" -+"%7531$s" "%7532$s" "%7533$s" "%7534$s" "%7535$s" "%7536$s" "%7537$s" "%7538$s" "%7539$s" "%7540$s" -+"%7541$s" "%7542$s" "%7543$s" "%7544$s" "%7545$s" "%7546$s" "%7547$s" "%7548$s" "%7549$s" "%7550$s" -+"%7551$s" "%7552$s" "%7553$s" "%7554$s" "%7555$s" "%7556$s" "%7557$s" "%7558$s" "%7559$s" "%7560$s" -+"%7561$s" "%7562$s" "%7563$s" "%7564$s" "%7565$s" "%7566$s" "%7567$s" "%7568$s" "%7569$s" "%7570$s" -+"%7571$s" "%7572$s" "%7573$s" "%7574$s" "%7575$s" "%7576$s" "%7577$s" "%7578$s" "%7579$s" "%7580$s" -+"%7581$s" "%7582$s" "%7583$s" "%7584$s" "%7585$s" "%7586$s" "%7587$s" "%7588$s" "%7589$s" "%7590$s" -+"%7591$s" "%7592$s" "%7593$s" "%7594$s" "%7595$s" "%7596$s" "%7597$s" "%7598$s" "%7599$s" "%7600$s" -+"%7601$s" "%7602$s" "%7603$s" "%7604$s" "%7605$s" "%7606$s" "%7607$s" "%7608$s" "%7609$s" "%7610$s" -+"%7611$s" "%7612$s" "%7613$s" "%7614$s" "%7615$s" "%7616$s" "%7617$s" "%7618$s" "%7619$s" "%7620$s" -+"%7621$s" "%7622$s" "%7623$s" "%7624$s" "%7625$s" "%7626$s" "%7627$s" "%7628$s" "%7629$s" "%7630$s" -+"%7631$s" "%7632$s" "%7633$s" "%7634$s" "%7635$s" "%7636$s" "%7637$s" "%7638$s" "%7639$s" "%7640$s" -+"%7641$s" "%7642$s" "%7643$s" "%7644$s" "%7645$s" "%7646$s" "%7647$s" "%7648$s" "%7649$s" "%7650$s" -+"%7651$s" "%7652$s" "%7653$s" "%7654$s" "%7655$s" "%7656$s" "%7657$s" "%7658$s" "%7659$s" "%7660$s" -+"%7661$s" "%7662$s" "%7663$s" "%7664$s" "%7665$s" "%7666$s" "%7667$s" "%7668$s" "%7669$s" "%7670$s" -+"%7671$s" "%7672$s" "%7673$s" "%7674$s" "%7675$s" "%7676$s" "%7677$s" "%7678$s" "%7679$s" "%7680$s" -+"%7681$s" "%7682$s" "%7683$s" "%7684$s" "%7685$s" "%7686$s" "%7687$s" "%7688$s" "%7689$s" "%7690$s" -+"%7691$s" "%7692$s" "%7693$s" "%7694$s" "%7695$s" "%7696$s" "%7697$s" "%7698$s" "%7699$s" "%7700$s" -+"%7701$s" "%7702$s" "%7703$s" "%7704$s" "%7705$s" "%7706$s" "%7707$s" "%7708$s" "%7709$s" "%7710$s" -+"%7711$s" "%7712$s" "%7713$s" "%7714$s" "%7715$s" "%7716$s" "%7717$s" "%7718$s" "%7719$s" "%7720$s" -+"%7721$s" "%7722$s" "%7723$s" "%7724$s" "%7725$s" "%7726$s" "%7727$s" "%7728$s" "%7729$s" "%7730$s" -+"%7731$s" "%7732$s" "%7733$s" "%7734$s" "%7735$s" "%7736$s" "%7737$s" "%7738$s" "%7739$s" "%7740$s" -+"%7741$s" "%7742$s" "%7743$s" "%7744$s" "%7745$s" "%7746$s" "%7747$s" "%7748$s" "%7749$s" "%7750$s" -+"%7751$s" "%7752$s" "%7753$s" "%7754$s" "%7755$s" "%7756$s" "%7757$s" "%7758$s" "%7759$s" "%7760$s" -+"%7761$s" "%7762$s" "%7763$s" "%7764$s" "%7765$s" "%7766$s" "%7767$s" "%7768$s" "%7769$s" "%7770$s" -+"%7771$s" "%7772$s" "%7773$s" "%7774$s" "%7775$s" "%7776$s" "%7777$s" "%7778$s" "%7779$s" "%7780$s" -+"%7781$s" "%7782$s" "%7783$s" "%7784$s" "%7785$s" "%7786$s" "%7787$s" "%7788$s" "%7789$s" "%7790$s" -+"%7791$s" "%7792$s" "%7793$s" "%7794$s" "%7795$s" "%7796$s" "%7797$s" "%7798$s" "%7799$s" "%7800$s" -+"%7801$s" "%7802$s" "%7803$s" "%7804$s" "%7805$s" "%7806$s" "%7807$s" "%7808$s" "%7809$s" "%7810$s" -+"%7811$s" "%7812$s" "%7813$s" "%7814$s" "%7815$s" "%7816$s" "%7817$s" "%7818$s" "%7819$s" "%7820$s" -+"%7821$s" "%7822$s" "%7823$s" "%7824$s" "%7825$s" "%7826$s" "%7827$s" "%7828$s" "%7829$s" "%7830$s" -+"%7831$s" "%7832$s" "%7833$s" "%7834$s" "%7835$s" "%7836$s" "%7837$s" "%7838$s" "%7839$s" "%7840$s" -+"%7841$s" "%7842$s" "%7843$s" "%7844$s" "%7845$s" "%7846$s" "%7847$s" "%7848$s" "%7849$s" "%7850$s" -+"%7851$s" "%7852$s" "%7853$s" "%7854$s" "%7855$s" "%7856$s" "%7857$s" "%7858$s" "%7859$s" "%7860$s" -+"%7861$s" "%7862$s" "%7863$s" "%7864$s" "%7865$s" "%7866$s" "%7867$s" "%7868$s" "%7869$s" "%7870$s" -+"%7871$s" "%7872$s" "%7873$s" "%7874$s" "%7875$s" "%7876$s" "%7877$s" "%7878$s" "%7879$s" "%7880$s" -+"%7881$s" "%7882$s" "%7883$s" "%7884$s" "%7885$s" "%7886$s" "%7887$s" "%7888$s" "%7889$s" "%7890$s" -+"%7891$s" "%7892$s" "%7893$s" "%7894$s" "%7895$s" "%7896$s" "%7897$s" "%7898$s" "%7899$s" "%7900$s" -+"%7901$s" "%7902$s" "%7903$s" "%7904$s" "%7905$s" "%7906$s" "%7907$s" "%7908$s" "%7909$s" "%7910$s" -+"%7911$s" "%7912$s" "%7913$s" "%7914$s" "%7915$s" "%7916$s" "%7917$s" "%7918$s" "%7919$s" "%7920$s" -+"%7921$s" "%7922$s" "%7923$s" "%7924$s" "%7925$s" "%7926$s" "%7927$s" "%7928$s" "%7929$s" "%7930$s" -+"%7931$s" "%7932$s" "%7933$s" "%7934$s" "%7935$s" "%7936$s" "%7937$s" "%7938$s" "%7939$s" "%7940$s" -+"%7941$s" "%7942$s" "%7943$s" "%7944$s" "%7945$s" "%7946$s" "%7947$s" "%7948$s" "%7949$s" "%7950$s" -+"%7951$s" "%7952$s" "%7953$s" "%7954$s" "%7955$s" "%7956$s" "%7957$s" "%7958$s" "%7959$s" "%7960$s" -+"%7961$s" "%7962$s" "%7963$s" "%7964$s" "%7965$s" "%7966$s" "%7967$s" "%7968$s" "%7969$s" "%7970$s" -+"%7971$s" "%7972$s" "%7973$s" "%7974$s" "%7975$s" "%7976$s" "%7977$s" "%7978$s" "%7979$s" "%7980$s" -+"%7981$s" "%7982$s" "%7983$s" "%7984$s" "%7985$s" "%7986$s" "%7987$s" "%7988$s" "%7989$s" "%7990$s" -+"%7991$s" "%7992$s" "%7993$s" "%7994$s" "%7995$s" "%7996$s" "%7997$s" "%7998$s" "%7999$s" "%8000$s" -+"%8001$s" "%8002$s" "%8003$s" "%8004$s" "%8005$s" "%8006$s" "%8007$s" "%8008$s" "%8009$s" "%8010$s" -+"%8011$s" "%8012$s" "%8013$s" "%8014$s" "%8015$s" "%8016$s" "%8017$s" "%8018$s" "%8019$s" "%8020$s" -+"%8021$s" "%8022$s" "%8023$s" "%8024$s" "%8025$s" "%8026$s" "%8027$s" "%8028$s" "%8029$s" "%8030$s" -+"%8031$s" "%8032$s" "%8033$s" "%8034$s" "%8035$s" "%8036$s" "%8037$s" "%8038$s" "%8039$s" "%8040$s" -+"%8041$s" "%8042$s" "%8043$s" "%8044$s" "%8045$s" "%8046$s" "%8047$s" "%8048$s" "%8049$s" "%8050$s" -+"%8051$s" "%8052$s" "%8053$s" "%8054$s" "%8055$s" "%8056$s" "%8057$s" "%8058$s" "%8059$s" "%8060$s" -+"%8061$s" "%8062$s" "%8063$s" "%8064$s" "%8065$s" "%8066$s" "%8067$s" "%8068$s" "%8069$s" "%8070$s" -+"%8071$s" "%8072$s" "%8073$s" "%8074$s" "%8075$s" "%8076$s" "%8077$s" "%8078$s" "%8079$s" "%8080$s" -+"%8081$s" "%8082$s" "%8083$s" "%8084$s" "%8085$s" "%8086$s" "%8087$s" "%8088$s" "%8089$s" "%8090$s" -+"%8091$s" "%8092$s" "%8093$s" "%8094$s" "%8095$s" "%8096$s" "%8097$s" "%8098$s" "%8099$s" "%8100$s" -+"%8101$s" "%8102$s" "%8103$s" "%8104$s" "%8105$s" "%8106$s" "%8107$s" "%8108$s" "%8109$s" "%8110$s" -+"%8111$s" "%8112$s" "%8113$s" "%8114$s" "%8115$s" "%8116$s" "%8117$s" "%8118$s" "%8119$s" "%8120$s" -+"%8121$s" "%8122$s" "%8123$s" "%8124$s" "%8125$s" "%8126$s" "%8127$s" "%8128$s" "%8129$s" "%8130$s" -+"%8131$s" "%8132$s" "%8133$s" "%8134$s" "%8135$s" "%8136$s" "%8137$s" "%8138$s" "%8139$s" "%8140$s" -+"%8141$s" "%8142$s" "%8143$s" "%8144$s" "%8145$s" "%8146$s" "%8147$s" "%8148$s" "%8149$s" "%8150$s" -+"%8151$s" "%8152$s" "%8153$s" "%8154$s" "%8155$s" "%8156$s" "%8157$s" "%8158$s" "%8159$s" "%8160$s" -+"%8161$s" "%8162$s" "%8163$s" "%8164$s" "%8165$s" "%8166$s" "%8167$s" "%8168$s" "%8169$s" "%8170$s" -+"%8171$s" "%8172$s" "%8173$s" "%8174$s" "%8175$s" "%8176$s" "%8177$s" "%8178$s" "%8179$s" "%8180$s" -+"%8181$s" "%8182$s" "%8183$s" "%8184$s" "%8185$s" "%8186$s" "%8187$s" "%8188$s" "%8189$s" "%8190$s" -+"%8191$s" "%8192$s" "%8193$s" "%8194$s" "%8195$s" "%8196$s" "%8197$s" "%8198$s" "%8199$s" "%8200$s" -+"%8201$s" "%8202$s" "%8203$s" "%8204$s" "%8205$s" "%8206$s" "%8207$s" "%8208$s" "%8209$s" "%8210$s" -+"%8211$s" "%8212$s" "%8213$s" "%8214$s" "%8215$s" "%8216$s" "%8217$s" "%8218$s" "%8219$s" "%8220$s" -+"%8221$s" "%8222$s" "%8223$s" "%8224$s" "%8225$s" "%8226$s" "%8227$s" "%8228$s" "%8229$s" "%8230$s" -+"%8231$s" "%8232$s" "%8233$s" "%8234$s" "%8235$s" "%8236$s" "%8237$s" "%8238$s" "%8239$s" "%8240$s" -+"%8241$s" "%8242$s" "%8243$s" "%8244$s" "%8245$s" "%8246$s" "%8247$s" "%8248$s" "%8249$s" "%8250$s" -+"%8251$s" "%8252$s" "%8253$s" "%8254$s" "%8255$s" "%8256$s" "%8257$s" "%8258$s" "%8259$s" "%8260$s" -+"%8261$s" "%8262$s" "%8263$s" "%8264$s" "%8265$s" "%8266$s" "%8267$s" "%8268$s" "%8269$s" "%8270$s" -+"%8271$s" "%8272$s" "%8273$s" "%8274$s" "%8275$s" "%8276$s" "%8277$s" "%8278$s" "%8279$s" "%8280$s" -+"%8281$s" "%8282$s" "%8283$s" "%8284$s" "%8285$s" "%8286$s" "%8287$s" "%8288$s" "%8289$s" "%8290$s" -+"%8291$s" "%8292$s" "%8293$s" "%8294$s" "%8295$s" "%8296$s" "%8297$s" "%8298$s" "%8299$s" "%8300$s" -+"%8301$s" "%8302$s" "%8303$s" "%8304$s" "%8305$s" "%8306$s" "%8307$s" "%8308$s" "%8309$s" "%8310$s" -+"%8311$s" "%8312$s" "%8313$s" "%8314$s" "%8315$s" "%8316$s" "%8317$s" "%8318$s" "%8319$s" "%8320$s" -+"%8321$s" "%8322$s" "%8323$s" "%8324$s" "%8325$s" "%8326$s" "%8327$s" "%8328$s" "%8329$s" "%8330$s" -+"%8331$s" "%8332$s" "%8333$s" "%8334$s" "%8335$s" "%8336$s" "%8337$s" "%8338$s" "%8339$s" "%8340$s" -+"%8341$s" "%8342$s" "%8343$s" "%8344$s" "%8345$s" "%8346$s" "%8347$s" "%8348$s" "%8349$s" "%8350$s" -+"%8351$s" "%8352$s" "%8353$s" "%8354$s" "%8355$s" "%8356$s" "%8357$s" "%8358$s" "%8359$s" "%8360$s" -+"%8361$s" "%8362$s" "%8363$s" "%8364$s" "%8365$s" "%8366$s" "%8367$s" "%8368$s" "%8369$s" "%8370$s" -+"%8371$s" "%8372$s" "%8373$s" "%8374$s" "%8375$s" "%8376$s" "%8377$s" "%8378$s" "%8379$s" "%8380$s" -+"%8381$s" "%8382$s" "%8383$s" "%8384$s" "%8385$s" "%8386$s" "%8387$s" "%8388$s" "%8389$s" "%8390$s" -+"%8391$s" "%8392$s" "%8393$s" "%8394$s" "%8395$s" "%8396$s" "%8397$s" "%8398$s" "%8399$s" "%8400$s" -+"%8401$s" "%8402$s" "%8403$s" "%8404$s" "%8405$s" "%8406$s" "%8407$s" "%8408$s" "%8409$s" "%8410$s" -+"%8411$s" "%8412$s" "%8413$s" "%8414$s" "%8415$s" "%8416$s" "%8417$s" "%8418$s" "%8419$s" "%8420$s" -+"%8421$s" "%8422$s" "%8423$s" "%8424$s" "%8425$s" "%8426$s" "%8427$s" "%8428$s" "%8429$s" "%8430$s" -+"%8431$s" "%8432$s" "%8433$s" "%8434$s" "%8435$s" "%8436$s" "%8437$s" "%8438$s" "%8439$s" "%8440$s" -+"%8441$s" "%8442$s" "%8443$s" "%8444$s" "%8445$s" "%8446$s" "%8447$s" "%8448$s" "%8449$s" "%8450$s" -+"%8451$s" "%8452$s" "%8453$s" "%8454$s" "%8455$s" "%8456$s" "%8457$s" "%8458$s" "%8459$s" "%8460$s" -+"%8461$s" "%8462$s" "%8463$s" "%8464$s" "%8465$s" "%8466$s" "%8467$s" "%8468$s" "%8469$s" "%8470$s" -+"%8471$s" "%8472$s" "%8473$s" "%8474$s" "%8475$s" "%8476$s" "%8477$s" "%8478$s" "%8479$s" "%8480$s" -+"%8481$s" "%8482$s" "%8483$s" "%8484$s" "%8485$s" "%8486$s" "%8487$s" "%8488$s" "%8489$s" "%8490$s" -+"%8491$s" "%8492$s" "%8493$s" "%8494$s" "%8495$s" "%8496$s" "%8497$s" "%8498$s" "%8499$s" "%8500$s" -+"%8501$s" "%8502$s" "%8503$s" "%8504$s" "%8505$s" "%8506$s" "%8507$s" "%8508$s" "%8509$s" "%8510$s" -+"%8511$s" "%8512$s" "%8513$s" "%8514$s" "%8515$s" "%8516$s" "%8517$s" "%8518$s" "%8519$s" "%8520$s" -+"%8521$s" "%8522$s" "%8523$s" "%8524$s" "%8525$s" "%8526$s" "%8527$s" "%8528$s" "%8529$s" "%8530$s" -+"%8531$s" "%8532$s" "%8533$s" "%8534$s" "%8535$s" "%8536$s" "%8537$s" "%8538$s" "%8539$s" "%8540$s" -+"%8541$s" "%8542$s" "%8543$s" "%8544$s" "%8545$s" "%8546$s" "%8547$s" "%8548$s" "%8549$s" "%8550$s" -+"%8551$s" "%8552$s" "%8553$s" "%8554$s" "%8555$s" "%8556$s" "%8557$s" "%8558$s" "%8559$s" "%8560$s" -+"%8561$s" "%8562$s" "%8563$s" "%8564$s" "%8565$s" "%8566$s" "%8567$s" "%8568$s" "%8569$s" "%8570$s" -+"%8571$s" "%8572$s" "%8573$s" "%8574$s" "%8575$s" "%8576$s" "%8577$s" "%8578$s" "%8579$s" "%8580$s" -+"%8581$s" "%8582$s" "%8583$s" "%8584$s" "%8585$s" "%8586$s" "%8587$s" "%8588$s" "%8589$s" "%8590$s" -+"%8591$s" "%8592$s" "%8593$s" "%8594$s" "%8595$s" "%8596$s" "%8597$s" "%8598$s" "%8599$s" "%8600$s" -+"%8601$s" "%8602$s" "%8603$s" "%8604$s" "%8605$s" "%8606$s" "%8607$s" "%8608$s" "%8609$s" "%8610$s" -+"%8611$s" "%8612$s" "%8613$s" "%8614$s" "%8615$s" "%8616$s" "%8617$s" "%8618$s" "%8619$s" "%8620$s" -+"%8621$s" "%8622$s" "%8623$s" "%8624$s" "%8625$s" "%8626$s" "%8627$s" "%8628$s" "%8629$s" "%8630$s" -+"%8631$s" "%8632$s" "%8633$s" "%8634$s" "%8635$s" "%8636$s" "%8637$s" "%8638$s" "%8639$s" "%8640$s" -+"%8641$s" "%8642$s" "%8643$s" "%8644$s" "%8645$s" "%8646$s" "%8647$s" "%8648$s" "%8649$s" "%8650$s" -+"%8651$s" "%8652$s" "%8653$s" "%8654$s" "%8655$s" "%8656$s" "%8657$s" "%8658$s" "%8659$s" "%8660$s" -+"%8661$s" "%8662$s" "%8663$s" "%8664$s" "%8665$s" "%8666$s" "%8667$s" "%8668$s" "%8669$s" "%8670$s" -+"%8671$s" "%8672$s" "%8673$s" "%8674$s" "%8675$s" "%8676$s" "%8677$s" "%8678$s" "%8679$s" "%8680$s" -+"%8681$s" "%8682$s" "%8683$s" "%8684$s" "%8685$s" "%8686$s" "%8687$s" "%8688$s" "%8689$s" "%8690$s" -+"%8691$s" "%8692$s" "%8693$s" "%8694$s" "%8695$s" "%8696$s" "%8697$s" "%8698$s" "%8699$s" "%8700$s" -+"%8701$s" "%8702$s" "%8703$s" "%8704$s" "%8705$s" "%8706$s" "%8707$s" "%8708$s" "%8709$s" "%8710$s" -+"%8711$s" "%8712$s" "%8713$s" "%8714$s" "%8715$s" "%8716$s" "%8717$s" "%8718$s" "%8719$s" "%8720$s" -+"%8721$s" "%8722$s" "%8723$s" "%8724$s" "%8725$s" "%8726$s" "%8727$s" "%8728$s" "%8729$s" "%8730$s" -+"%8731$s" "%8732$s" "%8733$s" "%8734$s" "%8735$s" "%8736$s" "%8737$s" "%8738$s" "%8739$s" "%8740$s" -+"%8741$s" "%8742$s" "%8743$s" "%8744$s" "%8745$s" "%8746$s" "%8747$s" "%8748$s" "%8749$s" "%8750$s" -+"%8751$s" "%8752$s" "%8753$s" "%8754$s" "%8755$s" "%8756$s" "%8757$s" "%8758$s" "%8759$s" "%8760$s" -+"%8761$s" "%8762$s" "%8763$s" "%8764$s" "%8765$s" "%8766$s" "%8767$s" "%8768$s" "%8769$s" "%8770$s" -+"%8771$s" "%8772$s" "%8773$s" "%8774$s" "%8775$s" "%8776$s" "%8777$s" "%8778$s" "%8779$s" "%8780$s" -+"%8781$s" "%8782$s" "%8783$s" "%8784$s" "%8785$s" "%8786$s" "%8787$s" "%8788$s" "%8789$s" "%8790$s" -+"%8791$s" "%8792$s" "%8793$s" "%8794$s" "%8795$s" "%8796$s" "%8797$s" "%8798$s" "%8799$s" "%8800$s" -+"%8801$s" "%8802$s" "%8803$s" "%8804$s" "%8805$s" "%8806$s" "%8807$s" "%8808$s" "%8809$s" "%8810$s" -+"%8811$s" "%8812$s" "%8813$s" "%8814$s" "%8815$s" "%8816$s" "%8817$s" "%8818$s" "%8819$s" "%8820$s" -+"%8821$s" "%8822$s" "%8823$s" "%8824$s" "%8825$s" "%8826$s" "%8827$s" "%8828$s" "%8829$s" "%8830$s" -+"%8831$s" "%8832$s" "%8833$s" "%8834$s" "%8835$s" "%8836$s" "%8837$s" "%8838$s" "%8839$s" "%8840$s" -+"%8841$s" "%8842$s" "%8843$s" "%8844$s" "%8845$s" "%8846$s" "%8847$s" "%8848$s" "%8849$s" "%8850$s" -+"%8851$s" "%8852$s" "%8853$s" "%8854$s" "%8855$s" "%8856$s" "%8857$s" "%8858$s" "%8859$s" "%8860$s" -+"%8861$s" "%8862$s" "%8863$s" "%8864$s" "%8865$s" "%8866$s" "%8867$s" "%8868$s" "%8869$s" "%8870$s" -+"%8871$s" "%8872$s" "%8873$s" "%8874$s" "%8875$s" "%8876$s" "%8877$s" "%8878$s" "%8879$s" "%8880$s" -+"%8881$s" "%8882$s" "%8883$s" "%8884$s" "%8885$s" "%8886$s" "%8887$s" "%8888$s" "%8889$s" "%8890$s" -+"%8891$s" "%8892$s" "%8893$s" "%8894$s" "%8895$s" "%8896$s" "%8897$s" "%8898$s" "%8899$s" "%8900$s" -+"%8901$s" "%8902$s" "%8903$s" "%8904$s" "%8905$s" "%8906$s" "%8907$s" "%8908$s" "%8909$s" "%8910$s" -+"%8911$s" "%8912$s" "%8913$s" "%8914$s" "%8915$s" "%8916$s" "%8917$s" "%8918$s" "%8919$s" "%8920$s" -+"%8921$s" "%8922$s" "%8923$s" "%8924$s" "%8925$s" "%8926$s" "%8927$s" "%8928$s" "%8929$s" "%8930$s" -+"%8931$s" "%8932$s" "%8933$s" "%8934$s" "%8935$s" "%8936$s" "%8937$s" "%8938$s" "%8939$s" "%8940$s" -+"%8941$s" "%8942$s" "%8943$s" "%8944$s" "%8945$s" "%8946$s" "%8947$s" "%8948$s" "%8949$s" "%8950$s" -+"%8951$s" "%8952$s" "%8953$s" "%8954$s" "%8955$s" "%8956$s" "%8957$s" "%8958$s" "%8959$s" "%8960$s" -+"%8961$s" "%8962$s" "%8963$s" "%8964$s" "%8965$s" "%8966$s" "%8967$s" "%8968$s" "%8969$s" "%8970$s" -+"%8971$s" "%8972$s" "%8973$s" "%8974$s" "%8975$s" "%8976$s" "%8977$s" "%8978$s" "%8979$s" "%8980$s" -+"%8981$s" "%8982$s" "%8983$s" "%8984$s" "%8985$s" "%8986$s" "%8987$s" "%8988$s" "%8989$s" "%8990$s" -+"%8991$s" "%8992$s" "%8993$s" "%8994$s" "%8995$s" "%8996$s" "%8997$s" "%8998$s" "%8999$s" "%9000$s" -+"%9001$s" "%9002$s" "%9003$s" "%9004$s" "%9005$s" "%9006$s" "%9007$s" "%9008$s" "%9009$s" "%9010$s" -+"%9011$s" "%9012$s" "%9013$s" "%9014$s" "%9015$s" "%9016$s" "%9017$s" "%9018$s" "%9019$s" "%9020$s" -+"%9021$s" "%9022$s" "%9023$s" "%9024$s" "%9025$s" "%9026$s" "%9027$s" "%9028$s" "%9029$s" "%9030$s" -+"%9031$s" "%9032$s" "%9033$s" "%9034$s" "%9035$s" "%9036$s" "%9037$s" "%9038$s" "%9039$s" "%9040$s" -+"%9041$s" "%9042$s" "%9043$s" "%9044$s" "%9045$s" "%9046$s" "%9047$s" "%9048$s" "%9049$s" "%9050$s" -+"%9051$s" "%9052$s" "%9053$s" "%9054$s" "%9055$s" "%9056$s" "%9057$s" "%9058$s" "%9059$s" "%9060$s" -+"%9061$s" "%9062$s" "%9063$s" "%9064$s" "%9065$s" "%9066$s" "%9067$s" "%9068$s" "%9069$s" "%9070$s" -+"%9071$s" "%9072$s" "%9073$s" "%9074$s" "%9075$s" "%9076$s" "%9077$s" "%9078$s" "%9079$s" "%9080$s" -+"%9081$s" "%9082$s" "%9083$s" "%9084$s" "%9085$s" "%9086$s" "%9087$s" "%9088$s" "%9089$s" "%9090$s" -+"%9091$s" "%9092$s" "%9093$s" "%9094$s" "%9095$s" "%9096$s" "%9097$s" "%9098$s" "%9099$s" "%9100$s" -+"%9101$s" "%9102$s" "%9103$s" "%9104$s" "%9105$s" "%9106$s" "%9107$s" "%9108$s" "%9109$s" "%9110$s" -+"%9111$s" "%9112$s" "%9113$s" "%9114$s" "%9115$s" "%9116$s" "%9117$s" "%9118$s" "%9119$s" "%9120$s" -+"%9121$s" "%9122$s" "%9123$s" "%9124$s" "%9125$s" "%9126$s" "%9127$s" "%9128$s" "%9129$s" "%9130$s" -+"%9131$s" "%9132$s" "%9133$s" "%9134$s" "%9135$s" "%9136$s" "%9137$s" "%9138$s" "%9139$s" "%9140$s" -+"%9141$s" "%9142$s" "%9143$s" "%9144$s" "%9145$s" "%9146$s" "%9147$s" "%9148$s" "%9149$s" "%9150$s" -+"%9151$s" "%9152$s" "%9153$s" "%9154$s" "%9155$s" "%9156$s" "%9157$s" "%9158$s" "%9159$s" "%9160$s" -+"%9161$s" "%9162$s" "%9163$s" "%9164$s" "%9165$s" "%9166$s" "%9167$s" "%9168$s" "%9169$s" "%9170$s" -+"%9171$s" "%9172$s" "%9173$s" "%9174$s" "%9175$s" "%9176$s" "%9177$s" "%9178$s" "%9179$s" "%9180$s" -+"%9181$s" "%9182$s" "%9183$s" "%9184$s" "%9185$s" "%9186$s" "%9187$s" "%9188$s" "%9189$s" "%9190$s" -+"%9191$s" "%9192$s" "%9193$s" "%9194$s" "%9195$s" "%9196$s" "%9197$s" "%9198$s" "%9199$s" "%9200$s" -+"%9201$s" "%9202$s" "%9203$s" "%9204$s" "%9205$s" "%9206$s" "%9207$s" "%9208$s" "%9209$s" "%9210$s" -+"%9211$s" "%9212$s" "%9213$s" "%9214$s" "%9215$s" "%9216$s" "%9217$s" "%9218$s" "%9219$s" "%9220$s" -+"%9221$s" "%9222$s" "%9223$s" "%9224$s" "%9225$s" "%9226$s" "%9227$s" "%9228$s" "%9229$s" "%9230$s" -+"%9231$s" "%9232$s" "%9233$s" "%9234$s" "%9235$s" "%9236$s" "%9237$s" "%9238$s" "%9239$s" "%9240$s" -+"%9241$s" "%9242$s" "%9243$s" "%9244$s" "%9245$s" "%9246$s" "%9247$s" "%9248$s" "%9249$s" "%9250$s" -+"%9251$s" "%9252$s" "%9253$s" "%9254$s" "%9255$s" "%9256$s" "%9257$s" "%9258$s" "%9259$s" "%9260$s" -+"%9261$s" "%9262$s" "%9263$s" "%9264$s" "%9265$s" "%9266$s" "%9267$s" "%9268$s" "%9269$s" "%9270$s" -+"%9271$s" "%9272$s" "%9273$s" "%9274$s" "%9275$s" "%9276$s" "%9277$s" "%9278$s" "%9279$s" "%9280$s" -+"%9281$s" "%9282$s" "%9283$s" "%9284$s" "%9285$s" "%9286$s" "%9287$s" "%9288$s" "%9289$s" "%9290$s" -+"%9291$s" "%9292$s" "%9293$s" "%9294$s" "%9295$s" "%9296$s" "%9297$s" "%9298$s" "%9299$s" "%9300$s" -+"%9301$s" "%9302$s" "%9303$s" "%9304$s" "%9305$s" "%9306$s" "%9307$s" "%9308$s" "%9309$s" "%9310$s" -+"%9311$s" "%9312$s" "%9313$s" "%9314$s" "%9315$s" "%9316$s" "%9317$s" "%9318$s" "%9319$s" "%9320$s" -+"%9321$s" "%9322$s" "%9323$s" "%9324$s" "%9325$s" "%9326$s" "%9327$s" "%9328$s" "%9329$s" "%9330$s" -+"%9331$s" "%9332$s" "%9333$s" "%9334$s" "%9335$s" "%9336$s" "%9337$s" "%9338$s" "%9339$s" "%9340$s" -+"%9341$s" "%9342$s" "%9343$s" "%9344$s" "%9345$s" "%9346$s" "%9347$s" "%9348$s" "%9349$s" "%9350$s" -+"%9351$s" "%9352$s" "%9353$s" "%9354$s" "%9355$s" "%9356$s" "%9357$s" "%9358$s" "%9359$s" "%9360$s" -+"%9361$s" "%9362$s" "%9363$s" "%9364$s" "%9365$s" "%9366$s" "%9367$s" "%9368$s" "%9369$s" "%9370$s" -+"%9371$s" "%9372$s" "%9373$s" "%9374$s" "%9375$s" "%9376$s" "%9377$s" "%9378$s" "%9379$s" "%9380$s" -+"%9381$s" "%9382$s" "%9383$s" "%9384$s" "%9385$s" "%9386$s" "%9387$s" "%9388$s" "%9389$s" "%9390$s" -+"%9391$s" "%9392$s" "%9393$s" "%9394$s" "%9395$s" "%9396$s" "%9397$s" "%9398$s" "%9399$s" "%9400$s" -+"%9401$s" "%9402$s" "%9403$s" "%9404$s" "%9405$s" "%9406$s" "%9407$s" "%9408$s" "%9409$s" "%9410$s" -+"%9411$s" "%9412$s" "%9413$s" "%9414$s" "%9415$s" "%9416$s" "%9417$s" "%9418$s" "%9419$s" "%9420$s" -+"%9421$s" "%9422$s" "%9423$s" "%9424$s" "%9425$s" "%9426$s" "%9427$s" "%9428$s" "%9429$s" "%9430$s" -+"%9431$s" "%9432$s" "%9433$s" "%9434$s" "%9435$s" "%9436$s" "%9437$s" "%9438$s" "%9439$s" "%9440$s" -+"%9441$s" "%9442$s" "%9443$s" "%9444$s" "%9445$s" "%9446$s" "%9447$s" "%9448$s" "%9449$s" "%9450$s" -+"%9451$s" "%9452$s" "%9453$s" "%9454$s" "%9455$s" "%9456$s" "%9457$s" "%9458$s" "%9459$s" "%9460$s" -+"%9461$s" "%9462$s" "%9463$s" "%9464$s" "%9465$s" "%9466$s" "%9467$s" "%9468$s" "%9469$s" "%9470$s" -+"%9471$s" "%9472$s" "%9473$s" "%9474$s" "%9475$s" "%9476$s" "%9477$s" "%9478$s" "%9479$s" "%9480$s" -+"%9481$s" "%9482$s" "%9483$s" "%9484$s" "%9485$s" "%9486$s" "%9487$s" "%9488$s" "%9489$s" "%9490$s" -+"%9491$s" "%9492$s" "%9493$s" "%9494$s" "%9495$s" "%9496$s" "%9497$s" "%9498$s" "%9499$s" "%9500$s" -+"%9501$s" "%9502$s" "%9503$s" "%9504$s" "%9505$s" "%9506$s" "%9507$s" "%9508$s" "%9509$s" "%9510$s" -+"%9511$s" "%9512$s" "%9513$s" "%9514$s" "%9515$s" "%9516$s" "%9517$s" "%9518$s" "%9519$s" "%9520$s" -+"%9521$s" "%9522$s" "%9523$s" "%9524$s" "%9525$s" "%9526$s" "%9527$s" "%9528$s" "%9529$s" "%9530$s" -+"%9531$s" "%9532$s" "%9533$s" "%9534$s" "%9535$s" "%9536$s" "%9537$s" "%9538$s" "%9539$s" "%9540$s" -+"%9541$s" "%9542$s" "%9543$s" "%9544$s" "%9545$s" "%9546$s" "%9547$s" "%9548$s" "%9549$s" "%9550$s" -+"%9551$s" "%9552$s" "%9553$s" "%9554$s" "%9555$s" "%9556$s" "%9557$s" "%9558$s" "%9559$s" "%9560$s" -+"%9561$s" "%9562$s" "%9563$s" "%9564$s" "%9565$s" "%9566$s" "%9567$s" "%9568$s" "%9569$s" "%9570$s" -+"%9571$s" "%9572$s" "%9573$s" "%9574$s" "%9575$s" "%9576$s" "%9577$s" "%9578$s" "%9579$s" "%9580$s" -+"%9581$s" "%9582$s" "%9583$s" "%9584$s" "%9585$s" "%9586$s" "%9587$s" "%9588$s" "%9589$s" "%9590$s" -+"%9591$s" "%9592$s" "%9593$s" "%9594$s" "%9595$s" "%9596$s" "%9597$s" "%9598$s" "%9599$s" "%9600$s" -+"%9601$s" "%9602$s" "%9603$s" "%9604$s" "%9605$s" "%9606$s" "%9607$s" "%9608$s" "%9609$s" "%9610$s" -+"%9611$s" "%9612$s" "%9613$s" "%9614$s" "%9615$s" "%9616$s" "%9617$s" "%9618$s" "%9619$s" "%9620$s" -+"%9621$s" "%9622$s" "%9623$s" "%9624$s" "%9625$s" "%9626$s" "%9627$s" "%9628$s" "%9629$s" "%9630$s" -+"%9631$s" "%9632$s" "%9633$s" "%9634$s" "%9635$s" "%9636$s" "%9637$s" "%9638$s" "%9639$s" "%9640$s" -+"%9641$s" "%9642$s" "%9643$s" "%9644$s" "%9645$s" "%9646$s" "%9647$s" "%9648$s" "%9649$s" "%9650$s" -+"%9651$s" "%9652$s" "%9653$s" "%9654$s" "%9655$s" "%9656$s" "%9657$s" "%9658$s" "%9659$s" "%9660$s" -+"%9661$s" "%9662$s" "%9663$s" "%9664$s" "%9665$s" "%9666$s" "%9667$s" "%9668$s" "%9669$s" "%9670$s" -+"%9671$s" "%9672$s" "%9673$s" "%9674$s" "%9675$s" "%9676$s" "%9677$s" "%9678$s" "%9679$s" "%9680$s" -+"%9681$s" "%9682$s" "%9683$s" "%9684$s" "%9685$s" "%9686$s" "%9687$s" "%9688$s" "%9689$s" "%9690$s" -+"%9691$s" "%9692$s" "%9693$s" "%9694$s" "%9695$s" "%9696$s" "%9697$s" "%9698$s" "%9699$s" "%9700$s" -+"%9701$s" "%9702$s" "%9703$s" "%9704$s" "%9705$s" "%9706$s" "%9707$s" "%9708$s" "%9709$s" "%9710$s" -+"%9711$s" "%9712$s" "%9713$s" "%9714$s" "%9715$s" "%9716$s" "%9717$s" "%9718$s" "%9719$s" "%9720$s" -+"%9721$s" "%9722$s" "%9723$s" "%9724$s" "%9725$s" "%9726$s" "%9727$s" "%9728$s" "%9729$s" "%9730$s" -+"%9731$s" "%9732$s" "%9733$s" "%9734$s" "%9735$s" "%9736$s" "%9737$s" "%9738$s" "%9739$s" "%9740$s" -+"%9741$s" "%9742$s" "%9743$s" "%9744$s" "%9745$s" "%9746$s" "%9747$s" "%9748$s" "%9749$s" "%9750$s" -+"%9751$s" "%9752$s" "%9753$s" "%9754$s" "%9755$s" "%9756$s" "%9757$s" "%9758$s" "%9759$s" "%9760$s" -+"%9761$s" "%9762$s" "%9763$s" "%9764$s" "%9765$s" "%9766$s" "%9767$s" "%9768$s" "%9769$s" "%9770$s" -+"%9771$s" "%9772$s" "%9773$s" "%9774$s" "%9775$s" "%9776$s" "%9777$s" "%9778$s" "%9779$s" "%9780$s" -+"%9781$s" "%9782$s" "%9783$s" "%9784$s" "%9785$s" "%9786$s" "%9787$s" "%9788$s" "%9789$s" "%9790$s" -+"%9791$s" "%9792$s" "%9793$s" "%9794$s" "%9795$s" "%9796$s" "%9797$s" "%9798$s" "%9799$s" "%9800$s" -+"%9801$s" "%9802$s" "%9803$s" "%9804$s" "%9805$s" "%9806$s" "%9807$s" "%9808$s" "%9809$s" "%9810$s" -+"%9811$s" "%9812$s" "%9813$s" "%9814$s" "%9815$s" "%9816$s" "%9817$s" "%9818$s" "%9819$s" "%9820$s" -+"%9821$s" "%9822$s" "%9823$s" "%9824$s" "%9825$s" "%9826$s" "%9827$s" "%9828$s" "%9829$s" "%9830$s" -+"%9831$s" "%9832$s" "%9833$s" "%9834$s" "%9835$s" "%9836$s" "%9837$s" "%9838$s" "%9839$s" "%9840$s" -+"%9841$s" "%9842$s" "%9843$s" "%9844$s" "%9845$s" "%9846$s" "%9847$s" "%9848$s" "%9849$s" "%9850$s" -+"%9851$s" "%9852$s" "%9853$s" "%9854$s" "%9855$s" "%9856$s" "%9857$s" "%9858$s" "%9859$s" "%9860$s" -+"%9861$s" "%9862$s" "%9863$s" "%9864$s" "%9865$s" "%9866$s" "%9867$s" "%9868$s" "%9869$s" "%9870$s" -+"%9871$s" "%9872$s" "%9873$s" "%9874$s" "%9875$s" "%9876$s" "%9877$s" "%9878$s" "%9879$s" "%9880$s" -+"%9881$s" "%9882$s" "%9883$s" "%9884$s" "%9885$s" "%9886$s" "%9887$s" "%9888$s" "%9889$s" "%9890$s" -+"%9891$s" "%9892$s" "%9893$s" "%9894$s" "%9895$s" "%9896$s" "%9897$s" "%9898$s" "%9899$s" "%9900$s" -+"%9901$s" "%9902$s" "%9903$s" "%9904$s" "%9905$s" "%9906$s" "%9907$s" "%9908$s" "%9909$s" "%9910$s" -+"%9911$s" "%9912$s" "%9913$s" "%9914$s" "%9915$s" "%9916$s" "%9917$s" "%9918$s" "%9919$s" "%9920$s" -+"%9921$s" "%9922$s" "%9923$s" "%9924$s" "%9925$s" "%9926$s" "%9927$s" "%9928$s" "%9929$s" "%9930$s" -+"%9931$s" "%9932$s" "%9933$s" "%9934$s" "%9935$s" "%9936$s" "%9937$s" "%9938$s" "%9939$s" "%9940$s" -+"%9941$s" "%9942$s" "%9943$s" "%9944$s" "%9945$s" "%9946$s" "%9947$s" "%9948$s" "%9949$s" "%9950$s" -+"%9951$s" "%9952$s" "%9953$s" "%9954$s" "%9955$s" "%9956$s" "%9957$s" "%9958$s" "%9959$s" "%9960$s" -+"%9961$s" "%9962$s" "%9963$s" "%9964$s" "%9965$s" "%9966$s" "%9967$s" "%9968$s" "%9969$s" "%9970$s" -+"%9971$s" "%9972$s" "%9973$s" "%9974$s" "%9975$s" "%9976$s" "%9977$s" "%9978$s" "%9979$s" "%9980$s" -+"%9981$s" "%9982$s" "%9983$s" "%9984$s" "%9985$s" "%9986$s" "%9987$s" "%9988$s" "%9989$s" "%9990$s" -+"%9991$s" "%9992$s" "%9993$s" "%9994$s" "%9995$s" "%9996$s" "%9997$s" "%9998$s" "%9999$s" "%10000$s" -+"%10001$s", -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 10 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 20 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 30 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 40 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 50 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 60 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 70 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 80 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 90 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1000 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1010 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1020 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1030 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1040 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1050 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1060 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1070 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1080 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1090 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2000 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2010 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2020 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2030 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2040 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2050 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2060 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2070 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2080 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2090 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3000 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3010 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3020 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3030 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3040 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3050 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3060 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3070 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3080 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3090 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4000 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4010 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4020 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4030 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4040 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4050 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4060 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4070 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4080 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4090 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5000 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5010 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5020 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5030 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5040 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5050 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5060 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5070 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5080 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5090 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6000 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6010 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6020 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6030 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6040 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6050 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6060 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6070 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6080 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6090 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7000 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7010 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7020 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7030 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7040 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7050 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7060 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7070 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7080 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7090 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8000 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8010 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8020 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8030 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8040 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8050 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8060 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8070 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8080 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8090 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9000 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9010 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9020 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9030 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9040 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9050 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9060 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9070 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9080 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9090 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9100 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9110 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9120 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9130 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9140 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9150 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9160 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9170 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9180 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9190 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9200 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9210 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9220 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9230 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9240 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9250 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9260 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9270 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9280 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9290 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9300 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9310 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9320 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9330 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9340 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9350 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9360 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9370 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9380 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9390 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9400 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9410 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9420 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9430 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9440 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9450 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9460 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9470 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9480 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9490 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9500 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9510 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9520 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9530 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9540 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9550 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9560 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9570 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9580 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9590 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9600 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9610 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9620 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9630 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9640 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9650 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9660 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9670 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9680 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9690 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9700 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9710 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9720 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9730 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9740 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9750 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9760 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9770 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9780 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9790 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9800 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9810 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9820 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9830 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9840 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9850 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9860 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9870 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9880 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9890 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9900 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9910 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9920 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9930 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9940 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9950 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9960 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9970 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9980 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9990 */ -+"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 10000 */ -+"\n"); -+ return 0; -+} -diff --git a/gcc/testsuite/gcc.target/aarch64/stack-check-12.c b/gcc/testsuite/gcc.target/aarch64/stack-check-12.c -new file mode 100644 -index 00000000000..2ce38483b6b ---- /dev/null -+++ b/gcc/testsuite/gcc.target/aarch64/stack-check-12.c -@@ -0,0 +1,20 @@ -+/* { dg-do compile } */ -+/* { dg-options "-O2 -fstack-clash-protection --param stack-clash-protection-guard-size=12" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+extern void arf (unsigned long int *, unsigned long int *); -+void -+frob () -+{ -+ unsigned long int num[1000]; -+ unsigned long int den[1000]; -+ arf (den, num); -+} -+ -+/* This verifies that the scheduler did not break the dependencies -+ by adjusting the offsets within the probe and that the scheduler -+ did not reorder around the stack probes. */ -+/* { dg-final { scan-assembler-times "sub\\tsp, sp, #4096\\n\\tstr\\txzr, .sp, 4088." 3 } } */ -+ -+ -+ -diff --git a/gcc/testsuite/gcc.target/aarch64/stack-check-13.c b/gcc/testsuite/gcc.target/aarch64/stack-check-13.c -new file mode 100644 -index 00000000000..d8886835989 ---- /dev/null -+++ b/gcc/testsuite/gcc.target/aarch64/stack-check-13.c -@@ -0,0 +1,28 @@ -+/* { dg-do compile } */ -+/* { dg-options "-O2 -fstack-clash-protection --param stack-clash-protection-guard-size=12" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+#define ARG32(X) X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X -+#define ARG192(X) ARG32(X),ARG32(X),ARG32(X),ARG32(X),ARG32(X),ARG32(X) -+void out1(ARG192(__int128)); -+int t1(int); -+ -+int t3(int x) -+{ -+ if (x < 1000) -+ return t1 (x) + 1; -+ -+ out1 (ARG192(1)); -+ return 0; -+} -+ -+ -+ -+/* This test creates a large (> 1k) outgoing argument area that needs -+ to be probed. We don't test the exact size of the space or the -+ exact offset to make the test a little less sensitive to trivial -+ output changes. */ -+/* { dg-final { scan-assembler-times "sub\\tsp, sp, #....\\n\\tstr\\txzr, \\\[sp" 1 } } */ -+ -+ -+ -diff --git a/gcc/testsuite/gcc.target/aarch64/stack-check-14.c b/gcc/testsuite/gcc.target/aarch64/stack-check-14.c -new file mode 100644 -index 00000000000..59ffe01376d ---- /dev/null -+++ b/gcc/testsuite/gcc.target/aarch64/stack-check-14.c -@@ -0,0 +1,25 @@ -+/* { dg-do compile } */ -+/* { dg-options "-O2 -fstack-clash-protection --param stack-clash-protection-guard-size=12" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+int t1(int); -+ -+int t2(int x) -+{ -+ char *p = __builtin_alloca (4050); -+ x = t1 (x); -+ return p[x]; -+} -+ -+ -+/* This test has a constant sized alloca that is smaller than the -+ probe interval. But it actually requires two probes instead -+ of one because of the optimistic assumptions we made in the -+ aarch64 prologue code WRT probing state. -+ -+ The form can change quite a bit so we just check for two -+ probes without looking at the actual address. */ -+/* { dg-final { scan-assembler-times "str\\txzr," 2 } } */ -+ -+ -+ -diff --git a/gcc/testsuite/gcc.target/aarch64/stack-check-15.c b/gcc/testsuite/gcc.target/aarch64/stack-check-15.c -new file mode 100644 -index 00000000000..e06db6dc2f0 ---- /dev/null -+++ b/gcc/testsuite/gcc.target/aarch64/stack-check-15.c -@@ -0,0 +1,24 @@ -+/* { dg-do compile } */ -+/* { dg-options "-O2 -fstack-clash-protection --param stack-clash-protection-guard-size=12" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+int t1(int); -+ -+int t2(int x) -+{ -+ char *p = __builtin_alloca (x); -+ x = t1 (x); -+ return p[x]; -+} -+ -+ -+/* This test has a variable sized alloca. It requires 3 probes. -+ One in the loop, one for the residual and at the end of the -+ alloca area. -+ -+ The form can change quite a bit so we just check for two -+ probes without looking at the actual address. */ -+/* { dg-final { scan-assembler-times "str\\txzr," 3 } } */ -+ -+ -+ -diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp -index 02eb2066393..5431c236aa1 100644 ---- a/gcc/testsuite/lib/target-supports.exp -+++ b/gcc/testsuite/lib/target-supports.exp -@@ -8384,14 +8384,9 @@ proc check_effective_target_arm_coproc4_ok { } { - # - proc check_effective_target_supports_stack_clash_protection { } { - -- # Temporary until the target bits are fully ACK'd. --# if { [istarget aarch*-*-*] } { --# return 1 --# } -- - if { [istarget x86_64-*-*] || [istarget i?86-*-*] - || [istarget powerpc*-*-*] || [istarget rs6000*-*-*] -- || [istarget s390*-*-*] } { -+ || [istarget aarch64*-**] || [istarget s390*-*-*] } { - return 1 - } - return 0 diff --git a/gcc7-rh1512529-17.patch b/gcc7-rh1512529-17.patch deleted file mode 100644 index e3b813c..0000000 --- a/gcc7-rh1512529-17.patch +++ /dev/null @@ -1,40 +0,0 @@ -commit 5ed5d56d36fc50627edf537c75afa0fdf6ba4f5d -Author: Jeff Law -Date: Wed Nov 22 12:02:50 2017 -0700 - - 2017-10-31 Segher Boessenkool - - PR target/82674 - * config/rs6000/rs6000.md (allocate_stack): Force update interval - into a register if it does not fit into an immediate offset field. - -diff --git a/gcc/config/rs6000/rs6000.md b/gcc/config/rs6000/rs6000.md -index 843148e9703..4b9732a78ec 100644 ---- a/gcc/config/rs6000/rs6000.md -+++ b/gcc/config/rs6000/rs6000.md -@@ -10450,6 +10450,9 @@ - { - rtx loop_lab, end_loop; - bool rotated = CONST_INT_P (rounded_size); -+ rtx update = GEN_INT (-probe_interval); -+ if (probe_interval > 32768) -+ update = force_reg (Pmode, update); - - emit_stack_clash_protection_probe_loop_start (&loop_lab, &end_loop, - last_addr, rotated); -@@ -10457,13 +10460,11 @@ - if (Pmode == SImode) - emit_insn (gen_movsi_update_stack (stack_pointer_rtx, - stack_pointer_rtx, -- GEN_INT (-probe_interval), -- chain)); -+ update, chain)); - else - emit_insn (gen_movdi_di_update_stack (stack_pointer_rtx, - stack_pointer_rtx, -- GEN_INT (-probe_interval), -- chain)); -+ update, chain)); - emit_stack_clash_protection_probe_loop_end (loop_lab, end_loop, - last_addr, rotated); - } diff --git a/gcc7-rh1512529-2.patch b/gcc7-rh1512529-2.patch deleted file mode 100644 index e334b5c..0000000 --- a/gcc7-rh1512529-2.patch +++ /dev/null @@ -1,735 +0,0 @@ -commit bed27844b80e17ad786028a0a82c7d47990d15bb -Author: law -Date: Wed Sep 20 05:05:12 2017 +0000 - - 2017-09-18 Jeff Law - - * explow.c: Include "params.h". - (anti_adjust_stack_and_probe_stack_clash): New function. - (get_stack_check_protect): Likewise. - (compute_stack_clash_protection_loop_data): Likewise. - (emit_stack_clash_protection_loop_start): Likewise. - (emit_stack_clash_protection_loop_end): Likewise. - (allocate_dynamic_stack_space): Use get_stack_check_protect. - Use anti_adjust_stack_and_probe_stack_clash. - * explow.h (compute_stack_clash_protection_loop_data): Prototype. - (emit_stack_clash_protection_loop_start): Likewise. - (emit_stack_clash_protection_loop_end): Likewise. - * rtl.h (get_stack_check_protect): Prototype. - * target.def (stack_clash_protection_final_dynamic_probe): New hook. - * targhooks.c (default_stack_clash_protection_final_dynamic_probe): New. - * targhooks.h (default_stack_clash_protection_final_dynamic_probe): - Prototype. - * doc/tm.texi.in (TARGET_STACK_CLASH_PROTECTION_FINAL_DYNAMIC_PROBE): - Add @hook. - * doc/tm.texi: Rebuilt. - * config/aarch64/aarch64.c (aarch64_expand_prologue): Use - get_stack_check_protect. - * config/alpha/alpha.c (alpha_expand_prologue): Likewise. - * config/arm/arm.c (arm_expand_prologue): Likewise. - (arm_frame_pointer_required): Likewise. - * config/i386/i386.c (ix86_expand_prologue): Likewise. - * config/ia64/ia64.c (ia64_expand_prologue): Likewise. - * config/mips/mips.c (mips_expand_prologue): Likewise. - * config/powerpcspe/powerpcspe.c (rs6000_emit_prologue): Likewise. - * config/rs6000/rs6000.c (rs6000_emit_prologue): Likewise. - * config/sparc/sparc.c (sparc_expand_prologue): Likewise. - (sparc_flat_expand_prologue): Likewise. - - * gcc.dg/stack-check-3.c: New test. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@252995 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/config/aarch64/aarch64.c b/gcc/config/aarch64/aarch64.c -index 1bd010be756..75c12f1de65 100644 ---- a/gcc/config/aarch64/aarch64.c -+++ b/gcc/config/aarch64/aarch64.c -@@ -3582,12 +3582,14 @@ aarch64_expand_prologue (void) - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (frame_size > PROBE_INTERVAL && frame_size > STACK_CHECK_PROTECT) -- aarch64_emit_probe_stack_range (STACK_CHECK_PROTECT, -- frame_size - STACK_CHECK_PROTECT); -+ if (frame_size > PROBE_INTERVAL -+ && frame_size > get_stack_check_protect ()) -+ aarch64_emit_probe_stack_range (get_stack_check_protect (), -+ (frame_size -+ - get_stack_check_protect ())); - } - else if (frame_size > 0) -- aarch64_emit_probe_stack_range (STACK_CHECK_PROTECT, frame_size); -+ aarch64_emit_probe_stack_range (get_stack_check_protect (), frame_size); - } - - aarch64_sub_sp (IP0_REGNUM, initial_adjust, true); -diff --git a/gcc/config/alpha/alpha.c b/gcc/config/alpha/alpha.c -index 00a69c1a08d..91f3d7cfbeb 100644 ---- a/gcc/config/alpha/alpha.c -+++ b/gcc/config/alpha/alpha.c -@@ -7741,7 +7741,7 @@ alpha_expand_prologue (void) - - probed_size = frame_size; - if (flag_stack_check) -- probed_size += STACK_CHECK_PROTECT; -+ probed_size += get_stack_check_protect (); - - if (probed_size <= 32768) - { -diff --git a/gcc/config/arm/arm.c b/gcc/config/arm/arm.c -index 1ded0d2a17d..242d7c792fe 100644 ---- a/gcc/config/arm/arm.c -+++ b/gcc/config/arm/arm.c -@@ -21604,13 +21604,13 @@ arm_expand_prologue (void) - - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (size > PROBE_INTERVAL && size > STACK_CHECK_PROTECT) -- arm_emit_probe_stack_range (STACK_CHECK_PROTECT, -- size - STACK_CHECK_PROTECT, -+ if (size > PROBE_INTERVAL && size > get_stack_check_protect ()) -+ arm_emit_probe_stack_range (get_stack_check_protect (), -+ size - get_stack_check_protect (), - regno, live_regs_mask); - } - else if (size > 0) -- arm_emit_probe_stack_range (STACK_CHECK_PROTECT, size, -+ arm_emit_probe_stack_range (get_stack_check_protect (), size, - regno, live_regs_mask); - } - -@@ -27751,7 +27751,7 @@ arm_frame_pointer_required (void) - { - /* We don't have the final size of the frame so adjust. */ - size += 32 * UNITS_PER_WORD; -- if (size > PROBE_INTERVAL && size > STACK_CHECK_PROTECT) -+ if (size > PROBE_INTERVAL && size > get_stack_check_protect ()) - return true; - } - else -diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c -index 2d163797ba0..60bab9a26a6 100644 ---- a/gcc/config/i386/i386.c -+++ b/gcc/config/i386/i386.c -@@ -14037,7 +14037,7 @@ ix86_expand_prologue (void) - HOST_WIDE_INT size = allocate; - - if (TARGET_64BIT && size >= HOST_WIDE_INT_C (0x80000000)) -- size = 0x80000000 - STACK_CHECK_PROTECT - 1; -+ size = 0x80000000 - get_stack_check_protect () - 1; - - if (TARGET_STACK_PROBE) - { -@@ -14047,18 +14047,20 @@ ix86_expand_prologue (void) - ix86_emit_probe_stack_range (0, size); - } - else -- ix86_emit_probe_stack_range (0, size + STACK_CHECK_PROTECT); -+ ix86_emit_probe_stack_range (0, -+ size + get_stack_check_protect ()); - } - else - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (size > PROBE_INTERVAL && size > STACK_CHECK_PROTECT) -- ix86_emit_probe_stack_range (STACK_CHECK_PROTECT, -- size - STACK_CHECK_PROTECT); -+ if (size > PROBE_INTERVAL -+ && size > get_stack_check_protect ()) -+ ix86_emit_probe_stack_range (get_stack_check_protect (), -+ size - get_stack_check_protect ()); - } - else -- ix86_emit_probe_stack_range (STACK_CHECK_PROTECT, size); -+ ix86_emit_probe_stack_range (get_stack_check_protect (), size); - } - } - } -diff --git a/gcc/config/ia64/ia64.c b/gcc/config/ia64/ia64.c -index a9f479b6e5c..17d6b3318a6 100644 ---- a/gcc/config/ia64/ia64.c -+++ b/gcc/config/ia64/ia64.c -@@ -3476,15 +3476,16 @@ ia64_expand_prologue (void) - - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (size > PROBE_INTERVAL && size > STACK_CHECK_PROTECT) -- ia64_emit_probe_stack_range (STACK_CHECK_PROTECT, -- size - STACK_CHECK_PROTECT, -+ if (size > PROBE_INTERVAL && size > get_stack_check_protect ()) -+ ia64_emit_probe_stack_range (get_stack_check_protect (), -+ size - get_stack_check_protect (), - bs_size); -- else if (size + bs_size > STACK_CHECK_PROTECT) -- ia64_emit_probe_stack_range (STACK_CHECK_PROTECT, 0, bs_size); -+ else if (size + bs_size > get_stack_check_protect ()) -+ ia64_emit_probe_stack_range (get_stack_check_protect (), -+ 0, bs_size); - } - else if (size + bs_size > 0) -- ia64_emit_probe_stack_range (STACK_CHECK_PROTECT, size, bs_size); -+ ia64_emit_probe_stack_range (get_stack_check_protect (), size, bs_size); - } - - if (dump_file) -diff --git a/gcc/config/mips/mips.c b/gcc/config/mips/mips.c -index 6bfd86a07af..7d85ce7055a 100644 ---- a/gcc/config/mips/mips.c -+++ b/gcc/config/mips/mips.c -@@ -12081,12 +12081,12 @@ mips_expand_prologue (void) - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (size > PROBE_INTERVAL && size > STACK_CHECK_PROTECT) -- mips_emit_probe_stack_range (STACK_CHECK_PROTECT, -- size - STACK_CHECK_PROTECT); -+ if (size > PROBE_INTERVAL && size > get_stack_check_protect ()) -+ mips_emit_probe_stack_range (get_stack_check_protect (), -+ size - get_stack_check_protect ()); - } - else if (size > 0) -- mips_emit_probe_stack_range (STACK_CHECK_PROTECT, size); -+ mips_emit_probe_stack_range (get_stack_check_protect (), size); - } - - /* Save the registers. Allocate up to MIPS_MAX_FIRST_STACK_STEP -diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c -index 66496a1f80f..1836e1d147d 100644 ---- a/gcc/config/rs6000/rs6000.c -+++ b/gcc/config/rs6000/rs6000.c -@@ -29294,12 +29294,12 @@ rs6000_emit_prologue (void) - - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (size > PROBE_INTERVAL && size > STACK_CHECK_PROTECT) -- rs6000_emit_probe_stack_range (STACK_CHECK_PROTECT, -- size - STACK_CHECK_PROTECT); -+ if (size > PROBE_INTERVAL && size > get_stack_check_protect ()) -+ rs6000_emit_probe_stack_range (get_stack_check_protect (), -+ size - get_stack_check_protect ()); - } - else if (size > 0) -- rs6000_emit_probe_stack_range (STACK_CHECK_PROTECT, size); -+ rs6000_emit_probe_stack_range (get_stack_check_protect (), size); - } - - if (TARGET_FIX_AND_CONTINUE) -diff --git a/gcc/config/sparc/sparc.c b/gcc/config/sparc/sparc.c -index 83ca1dcc617..b32bb9859e1 100644 ---- a/gcc/config/sparc/sparc.c -+++ b/gcc/config/sparc/sparc.c -@@ -5695,12 +5695,12 @@ sparc_expand_prologue (void) - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (size > PROBE_INTERVAL && size > STACK_CHECK_PROTECT) -- sparc_emit_probe_stack_range (STACK_CHECK_PROTECT, -- size - STACK_CHECK_PROTECT); -+ if (size > PROBE_INTERVAL && size > get_stack_check_protect ()) -+ sparc_emit_probe_stack_range (get_stack_check_protect (), -+ size - get_stack_check_protect ()); - } - else if (size > 0) -- sparc_emit_probe_stack_range (STACK_CHECK_PROTECT, size); -+ sparc_emit_probe_stack_range (get_stack_check_protect (), size); - } - - if (size == 0) -@@ -5806,12 +5806,12 @@ sparc_flat_expand_prologue (void) - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -- if (size > PROBE_INTERVAL && size > STACK_CHECK_PROTECT) -- sparc_emit_probe_stack_range (STACK_CHECK_PROTECT, -- size - STACK_CHECK_PROTECT); -+ if (size > PROBE_INTERVAL && size > get_stack_check_protect ()) -+ sparc_emit_probe_stack_range (get_stack_check_protect (), -+ size - get_stack_check_protect ()); - } - else if (size > 0) -- sparc_emit_probe_stack_range (STACK_CHECK_PROTECT, size); -+ sparc_emit_probe_stack_range (get_stack_check_protect (), size); - } - - if (sparc_save_local_in_regs_p) -diff --git a/gcc/doc/tm.texi b/gcc/doc/tm.texi -index c4f2c893c8e..0ba2925a1bd 100644 ---- a/gcc/doc/tm.texi -+++ b/gcc/doc/tm.texi -@@ -3419,6 +3419,10 @@ GCC computed the default from the values of the above macros and you will - normally not need to override that default. - @end defmac - -+@deftypefn {Target Hook} bool TARGET_STACK_CLASH_PROTECTION_FINAL_DYNAMIC_PROBE (rtx @var{residual}) -+Some targets make optimistic assumptions about the state of stack probing when they emit their prologues. On such targets a probe into the end of any dynamically allocated space is likely required for safety against stack clash style attacks. Define this variable to return nonzero if such a probe is required or zero otherwise. You need not define this macro if it would always have the value zero. -+@end deftypefn -+ - @need 2000 - @node Frame Registers - @subsection Registers That Address the Stack Frame -diff --git a/gcc/doc/tm.texi.in b/gcc/doc/tm.texi.in -index 1c471d8da35..d31255e86cb 100644 ---- a/gcc/doc/tm.texi.in -+++ b/gcc/doc/tm.texi.in -@@ -2999,6 +2999,8 @@ GCC computed the default from the values of the above macros and you will - normally not need to override that default. - @end defmac - -+@hook TARGET_STACK_CLASH_PROTECTION_FINAL_DYNAMIC_PROBE -+ - @need 2000 - @node Frame Registers - @subsection Registers That Address the Stack Frame -diff --git a/gcc/explow.c b/gcc/explow.c -index 67cb6ff1513..e7db438b1ec 100644 ---- a/gcc/explow.c -+++ b/gcc/explow.c -@@ -39,8 +39,11 @@ along with GCC; see the file COPYING3. If not see - #include "expr.h" - #include "common/common-target.h" - #include "output.h" -+#include "params.h" -+#include "dumpfile.h" - - static rtx break_out_memory_refs (rtx); -+static void anti_adjust_stack_and_probe_stack_clash (rtx); - - - /* Truncate and perhaps sign-extend C as appropriate for MODE. */ -@@ -1271,6 +1274,29 @@ get_dynamic_stack_size (rtx *psize, unsigned size_align, - *psize = size; - } - -+/* Return the number of bytes to "protect" on the stack for -fstack-check. -+ -+ "protect" in the context of -fstack-check means how many bytes we -+ should always ensure are available on the stack. More importantly -+ this is how many bytes are skipped when probing the stack. -+ -+ On some targets we want to reuse the -fstack-check prologue support -+ to give a degree of protection against stack clashing style attacks. -+ -+ In that scenario we do not want to skip bytes before probing as that -+ would render the stack clash protections useless. -+ -+ So we never use STACK_CHECK_PROTECT directly. Instead we indirect though -+ this helper which allows us to provide different values for -+ -fstack-check and -fstack-clash-protection. */ -+HOST_WIDE_INT -+get_stack_check_protect (void) -+{ -+ if (flag_stack_clash_protection) -+ return 0; -+ return STACK_CHECK_PROTECT; -+} -+ - /* Return an rtx representing the address of an area of memory dynamically - pushed on the stack. - -@@ -1429,7 +1455,7 @@ allocate_dynamic_stack_space (rtx size, unsigned size_align, - probe_stack_range (STACK_OLD_CHECK_PROTECT + STACK_CHECK_MAX_FRAME_SIZE, - size); - else if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK) -- probe_stack_range (STACK_CHECK_PROTECT, size); -+ probe_stack_range (get_stack_check_protect (), size); - - /* Don't let anti_adjust_stack emit notes. */ - suppress_reg_args_size = true; -@@ -1482,6 +1508,8 @@ allocate_dynamic_stack_space (rtx size, unsigned size_align, - - if (flag_stack_check && STACK_CHECK_MOVING_SP) - anti_adjust_stack_and_probe (size, false); -+ else if (flag_stack_clash_protection) -+ anti_adjust_stack_and_probe_stack_clash (size); - else - anti_adjust_stack (size); - -@@ -1757,6 +1785,219 @@ probe_stack_range (HOST_WIDE_INT first, rtx size) - emit_insn (gen_blockage ()); - } - -+/* Compute parameters for stack clash probing a dynamic stack -+ allocation of SIZE bytes. -+ -+ We compute ROUNDED_SIZE, LAST_ADDR, RESIDUAL and PROBE_INTERVAL. -+ -+ Additionally we conditionally dump the type of probing that will -+ be needed given the values computed. */ -+ -+void -+compute_stack_clash_protection_loop_data (rtx *rounded_size, rtx *last_addr, -+ rtx *residual, -+ HOST_WIDE_INT *probe_interval, -+ rtx size) -+{ -+ /* Round SIZE down to STACK_CLASH_PROTECTION_PROBE_INTERVAL */ -+ *probe_interval -+ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL); -+ *rounded_size = simplify_gen_binary (AND, Pmode, size, -+ GEN_INT (-*probe_interval)); -+ -+ /* Compute the value of the stack pointer for the last iteration. -+ It's just SP + ROUNDED_SIZE. */ -+ rtx rounded_size_op = force_operand (*rounded_size, NULL_RTX); -+ *last_addr = force_operand (gen_rtx_fmt_ee (STACK_GROW_OP, Pmode, -+ stack_pointer_rtx, -+ rounded_size_op), -+ NULL_RTX); -+ -+ /* Compute any residuals not allocated by the loop above. Residuals -+ are just the ROUNDED_SIZE - SIZE. */ -+ *residual = simplify_gen_binary (MINUS, Pmode, size, *rounded_size); -+ -+ /* Dump key information to make writing tests easy. */ -+ if (dump_file) -+ { -+ if (*rounded_size == CONST0_RTX (Pmode)) -+ fprintf (dump_file, -+ "Stack clash skipped dynamic allocation and probing loop.\n"); -+ else if (GET_CODE (*rounded_size) == CONST_INT -+ && INTVAL (*rounded_size) <= 4 * *probe_interval) -+ fprintf (dump_file, -+ "Stack clash dynamic allocation and probing inline.\n"); -+ else if (GET_CODE (*rounded_size) == CONST_INT) -+ fprintf (dump_file, -+ "Stack clash dynamic allocation and probing in " -+ "rotated loop.\n"); -+ else -+ fprintf (dump_file, -+ "Stack clash dynamic allocation and probing in loop.\n"); -+ -+ if (*residual != CONST0_RTX (Pmode)) -+ fprintf (dump_file, -+ "Stack clash dynamic allocation and probing residuals.\n"); -+ else -+ fprintf (dump_file, -+ "Stack clash skipped dynamic allocation and " -+ "probing residuals.\n"); -+ } -+} -+ -+/* Emit the start of an allocate/probe loop for stack -+ clash protection. -+ -+ LOOP_LAB and END_LAB are returned for use when we emit the -+ end of the loop. -+ -+ LAST addr is the value for SP which stops the loop. */ -+void -+emit_stack_clash_protection_probe_loop_start (rtx *loop_lab, -+ rtx *end_lab, -+ rtx last_addr, -+ bool rotated) -+{ -+ /* Essentially we want to emit any setup code, the top of loop -+ label and the comparison at the top of the loop. */ -+ *loop_lab = gen_label_rtx (); -+ *end_lab = gen_label_rtx (); -+ -+ emit_label (*loop_lab); -+ if (!rotated) -+ emit_cmp_and_jump_insns (stack_pointer_rtx, last_addr, EQ, NULL_RTX, -+ Pmode, 1, *end_lab); -+} -+ -+/* Emit the end of a stack clash probing loop. -+ -+ This consists of just the jump back to LOOP_LAB and -+ emitting END_LOOP after the loop. */ -+ -+void -+emit_stack_clash_protection_probe_loop_end (rtx loop_lab, rtx end_loop, -+ rtx last_addr, bool rotated) -+{ -+ if (rotated) -+ emit_cmp_and_jump_insns (stack_pointer_rtx, last_addr, NE, NULL_RTX, -+ Pmode, 1, loop_lab); -+ else -+ emit_jump (loop_lab); -+ -+ emit_label (end_loop); -+ -+} -+ -+/* Adjust the stack pointer by minus SIZE (an rtx for a number of bytes) -+ while probing it. This pushes when SIZE is positive. SIZE need not -+ be constant. -+ -+ This is subtly different than anti_adjust_stack_and_probe to try and -+ prevent stack-clash attacks -+ -+ 1. It must assume no knowledge of the probing state, any allocation -+ must probe. -+ -+ Consider the case of a 1 byte alloca in a loop. If the sum of the -+ allocations is large, then this could be used to jump the guard if -+ probes were not emitted. -+ -+ 2. It never skips probes, whereas anti_adjust_stack_and_probe will -+ skip probes on the first couple PROBE_INTERVALs on the assumption -+ they're done elsewhere. -+ -+ 3. It only allocates and probes SIZE bytes, it does not need to -+ allocate/probe beyond that because this probing style does not -+ guarantee signal handling capability if the guard is hit. */ -+ -+static void -+anti_adjust_stack_and_probe_stack_clash (rtx size) -+{ -+ /* First ensure SIZE is Pmode. */ -+ if (GET_MODE (size) != VOIDmode && GET_MODE (size) != Pmode) -+ size = convert_to_mode (Pmode, size, 1); -+ -+ /* We can get here with a constant size on some targets. */ -+ rtx rounded_size, last_addr, residual; -+ HOST_WIDE_INT probe_interval; -+ compute_stack_clash_protection_loop_data (&rounded_size, &last_addr, -+ &residual, &probe_interval, size); -+ -+ if (rounded_size != CONST0_RTX (Pmode)) -+ { -+ if (INTVAL (rounded_size) <= 4 * probe_interval) -+ { -+ for (HOST_WIDE_INT i = 0; -+ i < INTVAL (rounded_size); -+ i += probe_interval) -+ { -+ anti_adjust_stack (GEN_INT (probe_interval)); -+ -+ /* The prologue does not probe residuals. Thus the offset -+ here to probe just beyond what the prologue had already -+ allocated. */ -+ emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, -+ (probe_interval -+ - GET_MODE_SIZE (word_mode)))); -+ emit_insn (gen_blockage ()); -+ } -+ } -+ else -+ { -+ rtx loop_lab, end_loop; -+ bool rotate_loop = GET_CODE (rounded_size) == CONST_INT; -+ emit_stack_clash_protection_probe_loop_start (&loop_lab, &end_loop, -+ last_addr, rotate_loop); -+ -+ anti_adjust_stack (GEN_INT (probe_interval)); -+ -+ /* The prologue does not probe residuals. Thus the offset here -+ to probe just beyond what the prologue had already allocated. */ -+ emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, -+ (probe_interval -+ - GET_MODE_SIZE (word_mode)))); -+ -+ emit_stack_clash_protection_probe_loop_end (loop_lab, end_loop, -+ last_addr, rotate_loop); -+ emit_insn (gen_blockage ()); -+ } -+ } -+ -+ if (residual != CONST0_RTX (Pmode)) -+ { -+ rtx x = force_reg (Pmode, plus_constant (Pmode, residual, -+ -GET_MODE_SIZE (word_mode))); -+ anti_adjust_stack (residual); -+ emit_stack_probe (gen_rtx_PLUS (Pmode, stack_pointer_rtx, x)); -+ emit_insn (gen_blockage ()); -+ } -+ -+ /* Some targets make optimistic assumptions in their prologues about -+ how the caller may have probed the stack. Make sure we honor -+ those assumptions when needed. */ -+ if (size != CONST0_RTX (Pmode) -+ && targetm.stack_clash_protection_final_dynamic_probe (residual)) -+ { -+ /* Ideally we would just probe at *sp. However, if SIZE is not -+ a compile-time constant, but is zero at runtime, then *sp -+ might hold live data. So probe at *sp if we know that -+ an allocation was made, otherwise probe into the red zone -+ which is obviously undesirable. */ -+ if (GET_CODE (size) == CONST_INT) -+ { -+ emit_stack_probe (stack_pointer_rtx); -+ emit_insn (gen_blockage ()); -+ } -+ else -+ { -+ emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, -+ -GET_MODE_SIZE (word_mode))); -+ emit_insn (gen_blockage ()); -+ } -+ } -+} -+ -+ - /* Adjust the stack pointer by minus SIZE (an rtx for a number of bytes) - while probing it. This pushes when SIZE is positive. SIZE need not - be constant. If ADJUST_BACK is true, adjust back the stack pointer -diff --git a/gcc/explow.h b/gcc/explow.h -index 217a3226adb..b85c051e8ce 100644 ---- a/gcc/explow.h -+++ b/gcc/explow.h -@@ -69,6 +69,15 @@ extern void anti_adjust_stack (rtx); - /* Add some bytes to the stack while probing it. An rtx says how many. */ - extern void anti_adjust_stack_and_probe (rtx, bool); - -+/* Support for building allocation/probing loops for stack-clash -+ protection of dyamically allocated stack space. */ -+extern void compute_stack_clash_protection_loop_data (rtx *, rtx *, rtx *, -+ HOST_WIDE_INT *, rtx); -+extern void emit_stack_clash_protection_probe_loop_start (rtx *, rtx *, -+ rtx, bool); -+extern void emit_stack_clash_protection_probe_loop_end (rtx, rtx, -+ rtx, bool); -+ - /* This enum is used for the following two functions. */ - enum save_level {SAVE_BLOCK, SAVE_FUNCTION, SAVE_NONLOCAL}; - -diff --git a/gcc/rtl.h b/gcc/rtl.h -index 93330425c00..98f993a95a5 100644 ---- a/gcc/rtl.h -+++ b/gcc/rtl.h -@@ -2707,6 +2707,7 @@ get_full_set_src_cost (rtx x, machine_mode mode, struct full_rtx_costs *c) - /* In explow.c */ - extern HOST_WIDE_INT trunc_int_for_mode (HOST_WIDE_INT, machine_mode); - extern rtx plus_constant (machine_mode, rtx, HOST_WIDE_INT, bool = false); -+extern HOST_WIDE_INT get_stack_check_protect (void); - - /* In rtl.c */ - extern rtx rtx_alloc_stat (RTX_CODE MEM_STAT_DECL); -diff --git a/gcc/target.def b/gcc/target.def -index 6bebfd5b9d6..8b8ad1f4938 100644 ---- a/gcc/target.def -+++ b/gcc/target.def -@@ -5473,6 +5473,13 @@ these registers when the target switches are opposed to them.)", - void, (void), - hook_void_void) - -+DEFHOOK -+(stack_clash_protection_final_dynamic_probe, -+ "Some targets make optimistic assumptions about the state of stack probing when they emit their prologues. On such targets a probe into the end of any dynamically allocated space is likely required for safety against stack clash style attacks. Define this variable to return nonzero if such a probe is required or zero otherwise. You need not define this macro if it would always have the value zero.", -+ bool, (rtx residual), -+ default_stack_clash_protection_final_dynamic_probe) -+ -+ - /* Functions specific to the C family of frontends. */ - #undef HOOK_PREFIX - #define HOOK_PREFIX "TARGET_C_" -diff --git a/gcc/targhooks.c b/gcc/targhooks.c -index 1cdec068ed8..225048e7518 100644 ---- a/gcc/targhooks.c -+++ b/gcc/targhooks.c -@@ -2107,4 +2107,10 @@ default_excess_precision (enum excess_precision_type ATTRIBUTE_UNUSED) - return FLT_EVAL_METHOD_PROMOTE_TO_FLOAT; - } - -+HOST_WIDE_INT -+default_stack_clash_protection_final_dynamic_probe (rtx residual ATTRIBUTE_UNUSED) -+{ -+ return 0; -+} -+ - #include "gt-targhooks.h" -diff --git a/gcc/targhooks.h b/gcc/targhooks.h -index 18070df7839..32ae9d88050 100644 ---- a/gcc/targhooks.h -+++ b/gcc/targhooks.h -@@ -263,5 +263,6 @@ extern unsigned int default_min_arithmetic_precision (void); - - extern enum flt_eval_method - default_excess_precision (enum excess_precision_type ATTRIBUTE_UNUSED); -+extern bool default_stack_clash_protection_final_dynamic_probe (rtx); - - #endif /* GCC_TARGHOOKS_H */ -diff --git a/gcc/testsuite/gcc.dg/stack-check-3.c b/gcc/testsuite/gcc.dg/stack-check-3.c -new file mode 100644 -index 00000000000..58fb65649ee ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-3.c -@@ -0,0 +1,86 @@ -+/* The goal here is to ensure that dynamic allocations via vlas or -+ alloca calls receive probing. -+ -+ Scanning the RTL or assembly code seems like insanity here as does -+ checking for particular allocation sizes and probe offsets. For -+ now we just verify that there's an allocation + probe loop and -+ residual allocation + probe for f?. */ -+ -+/* { dg-do compile } */ -+/* { 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" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+__attribute__((noinline, noclone)) void -+foo (char *p) -+{ -+ asm volatile ("" : : "r" (p) : "memory"); -+} -+ -+/* Simple VLA, no other locals. */ -+__attribute__((noinline, noclone)) void -+f0 (int x) -+{ -+ char vla[x]; -+ foo (vla); -+} -+ -+/* Simple VLA, small local frame. */ -+__attribute__((noinline, noclone)) void -+f1 (int x) -+{ -+ char locals[128]; -+ char vla[x]; -+ foo (vla); -+} -+ -+/* Small constant alloca, no other locals. */ -+__attribute__((noinline, noclone)) void -+f2 (int x) -+{ -+ char *vla = __builtin_alloca (128); -+ foo (vla); -+} -+ -+/* Big constant alloca, small local frame. */ -+__attribute__((noinline, noclone)) void -+f3 (int x) -+{ -+ char locals[128]; -+ char *vla = __builtin_alloca (16384); -+ foo (vla); -+} -+ -+/* Big constant alloca, small local frame. */ -+__attribute__((noinline, noclone)) void -+f3a (int x) -+{ -+ char locals[128]; -+ char *vla = __builtin_alloca (32768); -+ foo (vla); -+} -+ -+/* Nonconstant alloca, no other locals. */ -+__attribute__((noinline, noclone)) void -+f4 (int x) -+{ -+ char *vla = __builtin_alloca (x); -+ foo (vla); -+} -+ -+/* Nonconstant alloca, small local frame. */ -+__attribute__((noinline, noclone)) void -+f5 (int x) -+{ -+ char locals[128]; -+ char *vla = __builtin_alloca (x); -+ foo (vla); -+} -+ -+/* { dg-final { scan-rtl-dump-times "allocation and probing residuals" 7 "expand" } } */ -+ -+ -+/* { dg-final { scan-rtl-dump-times "allocation and probing in loop" 7 "expand" { target callee_realigns_stack } } } */ -+/* { dg-final { scan-rtl-dump-times "allocation and probing in loop" 4 "expand" { target { ! callee_realigns_stack } } } } */ -+/* { dg-final { scan-rtl-dump-times "allocation and probing in rotated loop" 1 "expand" { target { ! callee_realigns_stack } } } } */ -+/* { dg-final { scan-rtl-dump-times "allocation and probing inline" 1 "expand" { target { ! callee_realigns_stack } } } } */ -+/* { dg-final { scan-rtl-dump-times "skipped dynamic allocation and probing loop" 1 "expand" { target { ! callee_realigns_stack } } } } */ diff --git a/gcc7-rh1512529-3.patch b/gcc7-rh1512529-3.patch deleted file mode 100644 index 112cf25..0000000 --- a/gcc7-rh1512529-3.patch +++ /dev/null @@ -1,199 +0,0 @@ -commit 640ca5ef08a3ade8fe3f32d8c412008410de989c -Author: law -Date: Wed Sep 20 05:21:09 2017 +0000 - - * config/alpha/alpha.c (alpha_expand_prologue): Also check - flag_stack_clash_protection. - * config/arm/arm.c (arm_compute_static_chain_stack_bytes): Likewise. - (arm_expand_prologue, thumb1_expand_prologue): Likewise. - (arm_frame_pointer_required): Likewise. - * config/ia64/ia64.c (ia64_compute_frame_size): Likewise. - (ia64_expand_prologue): Likewise. - * config/mips/mips.c (mips_expand_prologue): Likewise. - * config/powerpcspe/powerpcspe.c (rs6000_expand_prologue): Likewise. - * config/sparc/sparc.c (sparc_expand_prologue): Likewise. - (sparc_flat_expand_prologue): Likewise. - * config/spu/spu.c (spu_expand_prologue): Likewise. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@252996 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/config/alpha/alpha.c b/gcc/config/alpha/alpha.c -index 91f3d7cfbeb..36e78a0caf7 100644 ---- a/gcc/config/alpha/alpha.c -+++ b/gcc/config/alpha/alpha.c -@@ -7740,7 +7740,7 @@ alpha_expand_prologue (void) - Note that we are only allowed to adjust sp once in the prologue. */ - - probed_size = frame_size; -- if (flag_stack_check) -+ if (flag_stack_check || flag_stack_clash_protection) - probed_size += get_stack_check_protect (); - - if (probed_size <= 32768) -@@ -7755,7 +7755,7 @@ alpha_expand_prologue (void) - /* We only have to do this probe if we aren't saving registers or - if we are probing beyond the frame because of -fstack-check. */ - if ((sa_size == 0 && probed_size > probed - 4096) -- || flag_stack_check) -+ || flag_stack_check || flag_stack_clash_protection) - emit_insn (gen_probe_stack (GEN_INT (-probed_size))); - } - -@@ -7785,7 +7785,8 @@ alpha_expand_prologue (void) - late in the compilation, generate the loop as a single insn. */ - emit_insn (gen_prologue_stack_probe_loop (count, ptr)); - -- if ((leftover > 4096 && sa_size == 0) || flag_stack_check) -+ if ((leftover > 4096 && sa_size == 0) -+ || flag_stack_check || flag_stack_clash_protection) - { - rtx last = gen_rtx_MEM (DImode, - plus_constant (Pmode, ptr, -leftover)); -@@ -7793,7 +7794,7 @@ alpha_expand_prologue (void) - emit_move_insn (last, const0_rtx); - } - -- if (flag_stack_check) -+ if (flag_stack_check || flag_stack_clash_protection) - { - /* If -fstack-check is specified we have to load the entire - constant into a register and subtract from the sp in one go, -diff --git a/gcc/config/arm/arm.c b/gcc/config/arm/arm.c -index 242d7c792fe..4f85a061753 100644 ---- a/gcc/config/arm/arm.c -+++ b/gcc/config/arm/arm.c -@@ -19083,7 +19083,8 @@ arm_compute_static_chain_stack_bytes (void) - /* See the defining assertion in arm_expand_prologue. */ - if (IS_NESTED (arm_current_func_type ()) - && ((TARGET_APCS_FRAME && frame_pointer_needed && TARGET_ARM) -- || (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || ((flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection) - && !df_regs_ever_live_p (LR_REGNUM))) - && arm_r3_live_at_start_p () - && crtl->args.pretend_args_size == 0) -@@ -21377,7 +21378,8 @@ arm_expand_prologue (void) - clobbered when creating the frame, we need to save and restore it. */ - clobber_ip = IS_NESTED (func_type) - && ((TARGET_APCS_FRAME && frame_pointer_needed && TARGET_ARM) -- || (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || ((flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection) - && !df_regs_ever_live_p (LR_REGNUM) - && arm_r3_live_at_start_p ())); - -@@ -21591,7 +21593,8 @@ arm_expand_prologue (void) - stack checking. We use IP as the first scratch register, except for the - non-APCS nested functions if LR or r3 are available (see clobber_ip). */ - if (!IS_INTERRUPT (func_type) -- && flag_stack_check == STATIC_BUILTIN_STACK_CHECK) -+ && (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection)) - { - unsigned int regno; - -@@ -24875,7 +24878,9 @@ thumb1_expand_prologue (void) - current_function_static_stack_size = size; - - /* If we have a frame, then do stack checking. FIXME: not implemented. */ -- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK && size) -+ if ((flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection) -+ && size) - sorry ("-fstack-check=specific for Thumb-1"); - - amount = offsets->outgoing_args - offsets->saved_regs; -@@ -27736,7 +27741,8 @@ arm_frame_pointer_required (void) - instruction prior to the stack adjustment and this requires a frame - pointer if we want to catch the exception using the EABI unwinder. */ - if (!IS_INTERRUPT (arm_current_func_type ()) -- && flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ && (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection) - && arm_except_unwind_info (&global_options) == UI_TARGET - && cfun->can_throw_non_call_exceptions) - { -diff --git a/gcc/config/ia64/ia64.c b/gcc/config/ia64/ia64.c -index 17d6b3318a6..8acb92fd32b 100644 ---- a/gcc/config/ia64/ia64.c -+++ b/gcc/config/ia64/ia64.c -@@ -2685,7 +2685,8 @@ ia64_compute_frame_size (HOST_WIDE_INT size) - mark_reg_gr_used_mask (cfun->machine->ia64_eh_epilogue_bsp, NULL); - - /* Static stack checking uses r2 and r3. */ -- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK) -+ if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection) - current_frame_info.gr_used_mask |= 0xc; - - /* Find the size of the register stack frame. We have only 80 local -@@ -3468,7 +3469,8 @@ ia64_expand_prologue (void) - if (flag_stack_usage_info) - current_function_static_stack_size = current_frame_info.total_size; - -- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK) -+ if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection) - { - HOST_WIDE_INT size = current_frame_info.total_size; - int bs_size = BACKING_STORE_SIZE (current_frame_info.n_input_regs -diff --git a/gcc/config/mips/mips.c b/gcc/config/mips/mips.c -index 7d85ce7055a..b2d3c737b34 100644 ---- a/gcc/config/mips/mips.c -+++ b/gcc/config/mips/mips.c -@@ -12077,7 +12077,8 @@ mips_expand_prologue (void) - if (flag_stack_usage_info) - current_function_static_stack_size = size; - -- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK) -+ if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection) - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -diff --git a/gcc/config/sparc/sparc.c b/gcc/config/sparc/sparc.c -index b32bb9859e1..498bd04f5c2 100644 ---- a/gcc/config/sparc/sparc.c -+++ b/gcc/config/sparc/sparc.c -@@ -5691,7 +5691,8 @@ sparc_expand_prologue (void) - if (flag_stack_usage_info) - current_function_static_stack_size = size; - -- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK) -+ if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection) - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -@@ -5802,7 +5803,8 @@ sparc_flat_expand_prologue (void) - if (flag_stack_usage_info) - current_function_static_stack_size = size; - -- if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK) -+ if (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection) - { - if (crtl->is_leaf && !cfun->calls_alloca) - { -diff --git a/gcc/config/spu/spu.c b/gcc/config/spu/spu.c -index fcb85c0ee16..22745fa32c3 100644 ---- a/gcc/config/spu/spu.c -+++ b/gcc/config/spu/spu.c -@@ -1760,7 +1760,7 @@ spu_expand_prologue (void) - - if (total_size > 0) - { -- if (flag_stack_check) -+ if (flag_stack_check || flag_stack_clash_protection) - { - /* We compare against total_size-1 because - ($sp >= total_size) <=> ($sp > total_size-1) */ -@@ -5364,7 +5364,7 @@ spu_allocate_stack (rtx op0, rtx op1) - emit_insn (gen_spu_convert (sp, stack_pointer_rtx)); - emit_insn (gen_subv4si3 (sp, sp, splatted)); - -- if (flag_stack_check) -+ if (flag_stack_check || flag_stack_clash_protection) - { - rtx avail = gen_reg_rtx(SImode); - rtx result = gen_reg_rtx(SImode); diff --git a/gcc7-rh1512529-4.patch b/gcc7-rh1512529-4.patch deleted file mode 100644 index 9c953ec..0000000 --- a/gcc7-rh1512529-4.patch +++ /dev/null @@ -1,92 +0,0 @@ -commit 7f0d332f992c3b51c8aff3ed79e2233ed2498863 -Author: law -Date: Wed Sep 20 05:23:51 2017 +0000 - - * function.c (dump_stack_clash_frame_info): New function. - * function.h (dump_stack_clash_frame_info): Prototype. - (enum stack_clash_probes): New enum. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@252997 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/function.c b/gcc/function.c -index 21eb586a8f7..6d0f462a262 100644 ---- a/gcc/function.c -+++ b/gcc/function.c -@@ -5695,6 +5695,58 @@ get_arg_pointer_save_area (void) - return ret; - } - -+ -+/* If debugging dumps are requested, dump information about how the -+ target handled -fstack-check=clash for the prologue. -+ -+ PROBES describes what if any probes were emitted. -+ -+ RESIDUALS indicates if the prologue had any residual allocation -+ (i.e. total allocation was not a multiple of PROBE_INTERVAL). */ -+ -+void -+dump_stack_clash_frame_info (enum stack_clash_probes probes, bool residuals) -+{ -+ if (!dump_file) -+ return; -+ -+ switch (probes) -+ { -+ case NO_PROBE_NO_FRAME: -+ fprintf (dump_file, -+ "Stack clash no probe no stack adjustment in prologue.\n"); -+ break; -+ case NO_PROBE_SMALL_FRAME: -+ fprintf (dump_file, -+ "Stack clash no probe small stack adjustment in prologue.\n"); -+ break; -+ case PROBE_INLINE: -+ fprintf (dump_file, "Stack clash inline probes in prologue.\n"); -+ break; -+ case PROBE_LOOP: -+ fprintf (dump_file, "Stack clash probe loop in prologue.\n"); -+ break; -+ } -+ -+ if (residuals) -+ fprintf (dump_file, "Stack clash residual allocation in prologue.\n"); -+ else -+ fprintf (dump_file, "Stack clash no residual allocation in prologue.\n"); -+ -+ if (frame_pointer_needed) -+ fprintf (dump_file, "Stack clash frame pointer needed.\n"); -+ else -+ fprintf (dump_file, "Stack clash no frame pointer needed.\n"); -+ -+ if (TREE_THIS_VOLATILE (cfun->decl)) -+ fprintf (dump_file, -+ "Stack clash noreturn prologue, assuming no implicit" -+ " probes in caller.\n"); -+ else -+ fprintf (dump_file, -+ "Stack clash not noreturn prologue.\n"); -+} -+ - /* Add a list of INSNS to the hash HASHP, possibly allocating HASHP - for the first time. */ - -diff --git a/gcc/function.h b/gcc/function.h -index 0f34bcd6123..87dac803622 100644 ---- a/gcc/function.h -+++ b/gcc/function.h -@@ -553,6 +553,14 @@ do { \ - ((TARGET_PTRMEMFUNC_VBIT_LOCATION == ptrmemfunc_vbit_in_pfn) \ - ? MAX (FUNCTION_BOUNDARY, 2 * BITS_PER_UNIT) : FUNCTION_BOUNDARY) - -+enum stack_clash_probes { -+ NO_PROBE_NO_FRAME, -+ NO_PROBE_SMALL_FRAME, -+ PROBE_INLINE, -+ PROBE_LOOP -+}; -+ -+extern void dump_stack_clash_frame_info (enum stack_clash_probes, bool); - - - extern void push_function_context (void); diff --git a/gcc7-rh1512529-5.patch b/gcc7-rh1512529-5.patch deleted file mode 100644 index 1b6d4ba..0000000 --- a/gcc7-rh1512529-5.patch +++ /dev/null @@ -1,2705 +0,0 @@ -commit ded495f992254176bd1d08d4f200a7b508a33b9a -Author: law -Date: Wed Sep 20 05:35:07 2017 +0000 - - * config/i386/i386.c (ix86_adjust_stack_and_probe_stack_clash): New. - (ix86_expand_prologue): Dump stack clash info as needed. - Call ix86_adjust_stack_and_probe_stack_clash as needed. - - * gcc.dg/stack-check-4.c: New test. - * gcc.dg/stack-check-5.c: New test. - * gcc.dg/stack-check-6.c: New test. - * gcc.dg/stack-check-6a.c: New test. - * gcc.dg/stack-check-7.c: New test. - * gcc.dg/stack-check-8.c: New test. - * gcc.dg/stack-check-9.c: New test. - * gcc.dg/stack-check-10.c: New test. - * lib/target-supports.exp - (check_effective_target_supports_stack_clash_protection): Enable for - x86 and x86_64 targets. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@252998 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c -index 60bab9a26a6..088dca2001f 100644 ---- a/gcc/config/i386/i386.c -+++ b/gcc/config/i386/i386.c -@@ -13270,6 +13270,147 @@ release_scratch_register_on_entry (struct scratch_reg *sr) - - #define PROBE_INTERVAL (1 << STACK_CHECK_PROBE_INTERVAL_EXP) - -+/* Emit code to adjust the stack pointer by SIZE bytes while probing it. -+ -+ This differs from the next routine in that it tries hard to prevent -+ attacks that jump the stack guard. Thus it is never allowed to allocate -+ more than PROBE_INTERVAL bytes of stack space without a suitable -+ probe. */ -+ -+static void -+ix86_adjust_stack_and_probe_stack_clash (const HOST_WIDE_INT size) -+{ -+ struct machine_function *m = cfun->machine; -+ -+ /* If this function does not statically allocate stack space, then -+ no probes are needed. */ -+ if (!size) -+ { -+ dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false); -+ return; -+ } -+ -+ /* If we are a noreturn function, then we have to consider the -+ possibility that we're called via a jump rather than a call. -+ -+ Thus we don't have the implicit probe generated by saving the -+ return address into the stack at the call. Thus, the stack -+ pointer could be anywhere in the guard page. The safe thing -+ to do is emit a probe now. -+ -+ ?!? This should be revamped to work like aarch64 and s390 where -+ we track the offset from the most recent probe. Normally that -+ offset would be zero. For a non-return function we would reset -+ it to PROBE_INTERVAL - (STACK_BOUNDARY / BITS_PER_UNIT). Then -+ we just probe when we cross PROBE_INTERVAL. */ -+ if (TREE_THIS_VOLATILE (cfun->decl)) -+ { -+ emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, -+ -GET_MODE_SIZE (word_mode))); -+ emit_insn (gen_blockage ()); -+ } -+ -+ /* If we allocate less than the size of the guard statically, -+ then no probing is necessary, but we do need to allocate -+ the stack. */ -+ if (size < (1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE))) -+ { -+ pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx, -+ GEN_INT (-size), -1, -+ m->fs.cfa_reg == stack_pointer_rtx); -+ dump_stack_clash_frame_info (NO_PROBE_SMALL_FRAME, true); -+ return; -+ } -+ -+ /* We're allocating a large enough stack frame that we need to -+ emit probes. Either emit them inline or in a loop depending -+ on the size. */ -+ HOST_WIDE_INT probe_interval -+ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL); -+ if (size <= 4 * probe_interval) -+ { -+ HOST_WIDE_INT i; -+ for (i = probe_interval; i <= size; i += probe_interval) -+ { -+ /* Allocate PROBE_INTERVAL bytes. */ -+ pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx, -+ GEN_INT (-probe_interval), -1, -+ m->fs.cfa_reg == stack_pointer_rtx); -+ -+ /* And probe at *sp. */ -+ emit_stack_probe (stack_pointer_rtx); -+ emit_insn (gen_blockage ()); -+ } -+ -+ /* We need to allocate space for the residual, but we do not need -+ to probe the residual. */ -+ HOST_WIDE_INT residual = (i - probe_interval - size); -+ if (residual) -+ pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx, -+ GEN_INT (residual), -1, -+ m->fs.cfa_reg == stack_pointer_rtx); -+ dump_stack_clash_frame_info (PROBE_INLINE, residual != 0); -+ } -+ else -+ { -+ struct scratch_reg sr; -+ get_scratch_register_on_entry (&sr); -+ -+ /* Step 1: round SIZE down to a multiple of the interval. */ -+ HOST_WIDE_INT rounded_size = size & -probe_interval; -+ -+ /* Step 2: compute final value of the loop counter. Use lea if -+ possible. */ -+ rtx addr = plus_constant (Pmode, stack_pointer_rtx, -rounded_size); -+ rtx insn; -+ if (address_no_seg_operand (addr, Pmode)) -+ insn = emit_insn (gen_rtx_SET (sr.reg, addr)); -+ else -+ { -+ emit_move_insn (sr.reg, GEN_INT (-rounded_size)); -+ insn = emit_insn (gen_rtx_SET (sr.reg, -+ gen_rtx_PLUS (Pmode, sr.reg, -+ stack_pointer_rtx))); -+ } -+ if (m->fs.cfa_reg == stack_pointer_rtx) -+ { -+ add_reg_note (insn, REG_CFA_DEF_CFA, -+ plus_constant (Pmode, sr.reg, -+ m->fs.cfa_offset + rounded_size)); -+ RTX_FRAME_RELATED_P (insn) = 1; -+ } -+ -+ /* Step 3: the loop. */ -+ rtx size_rtx = GEN_INT (rounded_size); -+ insn = emit_insn (ix86_gen_adjust_stack_and_probe (sr.reg, sr.reg, -+ size_rtx)); -+ if (m->fs.cfa_reg == stack_pointer_rtx) -+ { -+ m->fs.cfa_offset += rounded_size; -+ add_reg_note (insn, REG_CFA_DEF_CFA, -+ plus_constant (Pmode, stack_pointer_rtx, -+ m->fs.cfa_offset)); -+ RTX_FRAME_RELATED_P (insn) = 1; -+ } -+ m->fs.sp_offset += rounded_size; -+ emit_insn (gen_blockage ()); -+ -+ /* Step 4: adjust SP if we cannot assert at compile-time that SIZE -+ is equal to ROUNDED_SIZE. */ -+ -+ if (size != rounded_size) -+ pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx, -+ GEN_INT (rounded_size - size), -1, -+ m->fs.cfa_reg == stack_pointer_rtx); -+ dump_stack_clash_frame_info (PROBE_LOOP, size != rounded_size); -+ -+ release_scratch_register_on_entry (&sr); -+ } -+ -+ /* Make sure nothing is scheduled before we are done. */ -+ emit_insn (gen_blockage ()); -+} -+ - /* Emit code to adjust the stack pointer by SIZE bytes while probing it. */ - - static void -@@ -14018,12 +14159,19 @@ ix86_expand_prologue (void) - - /* The stack has already been decremented by the instruction calling us - so probe if the size is non-negative to preserve the protection area. */ -- if (allocate >= 0 && flag_stack_check == STATIC_BUILTIN_STACK_CHECK) -+ if (allocate >= 0 -+ && (flag_stack_check == STATIC_BUILTIN_STACK_CHECK -+ || flag_stack_clash_protection)) - { - /* We expect the registers to be saved when probes are used. */ - gcc_assert (int_registers_saved); - -- if (STACK_CHECK_MOVING_SP) -+ if (flag_stack_clash_protection) -+ { -+ ix86_adjust_stack_and_probe_stack_clash (allocate); -+ allocate = 0; -+ } -+ else if (STACK_CHECK_MOVING_SP) - { - if (!(crtl->is_leaf && !cfun->calls_alloca - && allocate <= PROBE_INTERVAL)) -diff --git a/gcc/testsuite/gcc.dg/stack-check-10.c b/gcc/testsuite/gcc.dg/stack-check-10.c -new file mode 100644 -index 00000000000..a86956ad692 ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-10.c -@@ -0,0 +1,41 @@ -+/* { dg-do compile } */ -+/* { 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" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+int f (int *); -+ -+int -+g (int a) -+{ -+ return f (&a); -+} -+ -+int f1 (void); -+int f2 (int); -+ -+int -+f3 (void) -+{ -+ return f2 (f1 ()); -+} -+ -+ -+/* If we have caller implicit probes, then we should not need probes in either callee. -+ Else callees may need probes, particularly if non-leaf functions require a -+ frame/frame pointer. */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no probe" 2 "pro_and_epilogue" { target caller_implicit_probes } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash inline probe" 1 "pro_and_epilogue" { target { ! caller_implicit_probes } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no probe" 1 "pro_and_epilogue" { target { ! caller_implicit_probes } } } } */ -+ -+/* Neither of these functions are a nonreturn function. */ -+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 2 "pro_and_epilogue" } } */ -+ -+/* If the callee realigns the stack or has a mandatory frame, then both functions -+ have a residual allocation. Else just g() has a residual allocation. */ -+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 2 "pro_and_epilogue" } } */ -+ -+ -+/* If the target has frame pointers for non-leafs, then both functions will -+ need a frame pointer. Otherwise neither should. */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 2 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */ -diff --git a/gcc/testsuite/gcc.dg/stack-check-3.c b/gcc/testsuite/gcc.dg/stack-check-3.c -index 58fb65649ee..f0bf7c71a5b 100644 ---- a/gcc/testsuite/gcc.dg/stack-check-3.c -+++ b/gcc/testsuite/gcc.dg/stack-check-3.c -@@ -7,7 +7,7 @@ - residual allocation + probe for f?. */ - - /* { dg-do compile } */ --/* { 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" } */ -+/* { 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" } */ - /* { dg-require-effective-target supports_stack_clash_protection } */ - - __attribute__((noinline, noclone)) void -diff --git a/gcc/testsuite/gcc.dg/stack-check-4.c b/gcc/testsuite/gcc.dg/stack-check-4.c -new file mode 100644 -index 00000000000..b0c5c61972f ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-4.c -@@ -0,0 +1,42 @@ -+/* On targets where the call instruction is an implicit probe of *sp, we -+ elide stack probes as long as the size of the local stack is less than -+ PROBE_INTERVAL. -+ -+ But if the caller were to transform a tail call into a direct jump -+ we do not have that implicit probe. This normally isn't a problem as -+ the caller must not have a local frame for that optimization to apply. -+ -+ However, a sufficiently smart compiler could realize that the caller's -+ local stack need not be torn down and thus could transform a call into -+ a jump if the target is a noreturn function, even if the caller has -+ a local frame. -+ -+ To guard against that, targets that depend on *sp being probed by the -+ call itself must emit a probe if the target function is a noreturn -+ function, even if they just allocate a small amount of stack space. -+ -+ Rather than try to parse RTL or assembly code, we instead require the -+ prologue code to emit information into the dump file that we can -+ scan for. We scan for both the positive and negative cases. */ -+ -+/* { dg-do compile } */ -+/* { dg-options "-O2 -fstack-clash-protection -fdump-rtl-pro_and_epilogue -fno-optimize-sibling-calls" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+extern void arf (char *); -+ -+__attribute__ ((noreturn)) void foo1 () -+{ -+ char x[10]; -+ while (1) -+ arf (x); -+} -+ -+void foo2 () -+{ -+ char x[10]; -+ arf (x); -+} -+/* { dg-final { scan-rtl-dump-times "Stack clash noreturn" 1 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 1 "pro_and_epilogue" } } */ -+ -diff --git a/gcc/testsuite/gcc.dg/stack-check-5.c b/gcc/testsuite/gcc.dg/stack-check-5.c -new file mode 100644 -index 00000000000..2171d9b6c23 ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-5.c -@@ -0,0 +1,74 @@ -+/* { dg-do compile } */ -+/* { 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" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+ -+extern void foo (char *); -+extern void bar (void); -+ -+/* This function allocates no local stack and is a leaf. It should have no -+ probes on any target and should not require a frame pointer. */ -+int -+f0 (int x, int y) -+{ -+ asm volatile ("" : : : "memory"); -+ return x + y; -+} -+ -+/* This function allocates no local stack, but is not a leaf. Ideally it -+ should not need probing and no frame pointer. */ -+int -+f1 (int x, int y) -+{ -+ asm volatile ("" : : : "memory"); -+ bar (); -+} -+ -+/* This is a leaf with a small frame. On targets with implicit probes in -+ the caller, this should not need probing. On targets with no implicit -+ probes in the caller, it may require probes. Ideally it should need no -+ frame pointer. */ -+void -+f2 (void) -+{ -+ char buf[512]; -+ asm volatile ("" : : "g" (&buf) : "memory"); -+} -+ -+/* This is a non-leaf with a small frame. On targets with implicit probes in -+ the caller, this should not need probing. On targets with no implicit -+ probes in the caller, it may require probes. It should need no frame -+ pointer. */ -+void -+f3 (void) -+{ -+ char buf[512]; -+ foo (buf); -+} -+ -+/* If we have caller implicit probes, then we should not need probes. -+ Else callees may need probes, particularly if non-leaf functions require a -+ frame/frame pointer. */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no probe" 4 "pro_and_epilogue" { target caller_implicit_probes } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no probe" 2 "pro_and_epilogue" { target { ! caller_implicit_probes } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash inline probes " 2 "pro_and_epilogue" { target { ! caller_implicit_probes } } } } */ -+ -+/* None of these functions are marked with the noreturn attribute. */ -+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 4 "pro_and_epilogue" } } */ -+ -+/* Two functions are leafs, two are not. Verify the target identified them -+ appropriately. */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 4 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */ -+ -+ -+/* We have selected the size of the array in f2/f3 to be large enough -+ to not live in the red zone on targets that support it. -+ -+ That allows simplification of this test considerably. -+ f1() should not require any allocations, thus no residuals. -+ All the rest of the functions require some kind of allocation, -+ either for the saved fp/rp or the array. */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no residual allocation in prologue" 1 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 3 "pro_and_epilogue" } } */ -diff --git a/gcc/testsuite/gcc.dg/stack-check-6.c b/gcc/testsuite/gcc.dg/stack-check-6.c -new file mode 100644 -index 00000000000..ad2021c9037 ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-6.c -@@ -0,0 +1,55 @@ -+/* { dg-do compile } */ -+/* { 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" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+ -+extern void foo (char *); -+extern void bar (void); -+ -+ -+/* This is a leaf with a frame that is large enough to require probing with -+ a residual allocation, but small enough to probe inline. */ -+void -+f4 (void) -+{ -+ char buf[4096 + 512]; -+ asm volatile ("" : : "g" (&buf) : "memory"); -+} -+ -+ -+/* This is a non-leaf with a frame large enough to require probing and -+ a residual allocation, but small enough to probe inline. */ -+void -+f5 (void) -+{ -+ char buf[4096 + 512]; -+ foo (buf); -+} -+ -+/* This is a leaf with a frame that is large enough to require probing with -+ a loop plus a residual allocation. */ -+void -+f6 (void) -+{ -+ char buf[4096 * 10 + 512]; -+ asm volatile ("" : : "g" (&buf) : "memory"); -+} -+ -+ -+/* This is a non-leaf with a frame large enough to require probing with -+ a loop plus a residual allocation. */ -+void -+f7 (void) -+{ -+ char buf[4096 * 10 + 512]; -+ foo (buf); -+} -+ -+/* { dg-final { scan-rtl-dump-times "Stack clash inline probes" 2 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash probe loop" 2 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 4 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 4 "pro_and_epilogue" } } */ -+ -+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 4 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */ -diff --git a/gcc/testsuite/gcc.dg/stack-check-6a.c b/gcc/testsuite/gcc.dg/stack-check-6a.c -new file mode 100644 -index 00000000000..6f8e7128921 ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-6a.c -@@ -0,0 +1,17 @@ -+/* The goal here is to verify that increasing the size of the guard allows -+ elimination of all probing on the relevant targets. */ -+ -+/* { dg-do compile } */ -+/* { 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" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+#include "stack-check-6.c" -+ -+/* { dg-final { scan-rtl-dump-times "Stack clash inline probes" 0 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash probe loop" 0 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 4 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 4 "pro_and_epilogue" } } */ -+ -+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 4 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 2 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */ -diff --git a/gcc/testsuite/gcc.dg/stack-check-7.c b/gcc/testsuite/gcc.dg/stack-check-7.c -new file mode 100644 -index 00000000000..b963a2881dc ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-7.c -@@ -0,0 +1,36 @@ -+/* { dg-do run } */ -+/* { dg-options "-O2 -fstack-clash-protection -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=12" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+/* For further testing, this can be run under valgrind where it's crashed -+ on aarch64 and ppc64le with -fstack-check=specific. */ -+ -+ -+__attribute__((noinline, noclone)) void -+foo (char *p) -+{ -+ asm volatile ("" : : "r" (p) : "memory"); -+} -+ -+__attribute__((noinline, noclone)) void -+bar (void) -+{ -+ char buf[131072]; -+ foo (buf); -+} -+ -+__attribute__((noinline, noclone)) void -+baz (void) -+{ -+ char buf[12000]; -+ foo (buf); -+} -+ -+int -+main () -+{ -+ bar (); -+ baz (); -+ return 0; -+} -+ -diff --git a/gcc/testsuite/gcc.dg/stack-check-8.c b/gcc/testsuite/gcc.dg/stack-check-8.c -new file mode 100644 -index 00000000000..84d5adef154 ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-8.c -@@ -0,0 +1,139 @@ -+/* { dg-do run } */ -+/* { dg-options "-O2 -fstack-clash-protection -Wno-psabi -fno-optimize-sibling-calls --param stack-clash-protection-probe-interval=12 --param stack-clash-protection-guard-size=12" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+ -+typedef float V __attribute__((vector_size (32))); -+ -+__attribute__((noinline, noclone)) void -+foo (char *p) -+{ -+ asm volatile ("" : : "r" (p) : "memory"); -+} -+ -+__attribute__((noinline, noclone)) int -+f0 (int x, int y) -+{ -+ asm volatile ("" : : : "memory"); -+ return x + y; -+} -+ -+__attribute__((noinline, noclone)) void -+f1 (void) -+{ -+ char buf[64]; -+ foo (buf); -+} -+ -+__attribute__((noinline, noclone)) void -+f2 (void) -+{ -+ char buf[12000]; -+ foo (buf); -+} -+ -+__attribute__((noinline, noclone)) void -+f3 (void) -+{ -+ char buf[131072]; -+ foo (buf); -+} -+ -+__attribute__((noinline, noclone)) void -+f4 (int x) -+{ -+ char vla[x]; -+ foo (vla); -+} -+ -+__attribute__((noinline, noclone)) void -+f5 (int x) -+{ -+ char buf[12000]; -+ foo (buf); -+ { -+ char vla[x]; -+ foo (vla); -+ } -+ { -+ char vla[x]; -+ foo (vla); -+ } -+} -+ -+V v; -+ -+__attribute__((noinline, noclone)) int -+f6 (int x, int y, V a, V b, V c) -+{ -+ asm volatile ("" : : : "memory"); -+ v = a + b + c; -+ return x + y; -+} -+ -+__attribute__((noinline, noclone)) void -+f7 (V a, V b, V c) -+{ -+ char buf[64]; -+ foo (buf); -+ v = a + b + c; -+} -+ -+__attribute__((noinline, noclone)) void -+f8 (V a, V b, V c) -+{ -+ char buf[12000]; -+ foo (buf); -+ v = a + b + c; -+} -+ -+__attribute__((noinline, noclone)) void -+f9 (V a, V b, V c) -+{ -+ char buf[131072]; -+ foo (buf); -+ v = a + b + c; -+} -+ -+__attribute__((noinline, noclone)) void -+f10 (int x, V a, V b, V c) -+{ -+ char vla[x]; -+ foo (vla); -+ v = a + b + c; -+} -+ -+__attribute__((noinline, noclone)) void -+f11 (int x, V a, V b, V c) -+{ -+ char buf[12000]; -+ foo (buf); -+ v = a + b + c; -+ { -+ char vla[x]; -+ foo (vla); -+ } -+ { -+ char vla[x]; -+ foo (vla); -+ } -+} -+ -+int -+main () -+{ -+ f0 (2, 3); -+ f1 (); -+ f2 (); -+ f3 (); -+ f4 (12000); -+ f5 (12000); -+ f6 (2, 3, v, v, v); -+ f7 (v, v, v); -+ f8 (v, v, v); -+ f9 (v, v, v); -+ f10 (12000, v, v, v); -+ f11 (12000, v, v, v); -+ return 0; -+} -+ -diff --git a/gcc/testsuite/gcc.dg/stack-check-9.c b/gcc/testsuite/gcc.dg/stack-check-9.c -new file mode 100644 -index 00000000000..b84075b9b43 ---- /dev/null -+++ b/gcc/testsuite/gcc.dg/stack-check-9.c -@@ -0,0 +1,2022 @@ -+/* { dg-do compile } */ -+/* { 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" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+double f1 (void); -+double f2 (double, double); -+ -+double -+f3 (void) -+{ -+ double d000 = f1 (); -+ double d001 = f1 (); -+ double d002 = f1 (); -+ double d003 = f1 (); -+ double d004 = f1 (); -+ double d005 = f1 (); -+ double d006 = f1 (); -+ double d007 = f1 (); -+ double d008 = f1 (); -+ double d009 = f1 (); -+ double d010 = f1 (); -+ double d011 = f1 (); -+ double d012 = f1 (); -+ double d013 = f1 (); -+ double d014 = f1 (); -+ double d015 = f1 (); -+ double d016 = f1 (); -+ double d017 = f1 (); -+ double d018 = f1 (); -+ double d019 = f1 (); -+ double d020 = f1 (); -+ double d021 = f1 (); -+ double d022 = f1 (); -+ double d023 = f1 (); -+ double d024 = f1 (); -+ double d025 = f1 (); -+ double d026 = f1 (); -+ double d027 = f1 (); -+ double d028 = f1 (); -+ double d029 = f1 (); -+ double d030 = f1 (); -+ double d031 = f1 (); -+ double d032 = f1 (); -+ double d033 = f1 (); -+ double d034 = f1 (); -+ double d035 = f1 (); -+ double d036 = f1 (); -+ double d037 = f1 (); -+ double d038 = f1 (); -+ double d039 = f1 (); -+ double d040 = f1 (); -+ double d041 = f1 (); -+ double d042 = f1 (); -+ double d043 = f1 (); -+ double d044 = f1 (); -+ double d045 = f1 (); -+ double d046 = f1 (); -+ double d047 = f1 (); -+ double d048 = f1 (); -+ double d049 = f1 (); -+ double d050 = f1 (); -+ double d051 = f1 (); -+ double d052 = f1 (); -+ double d053 = f1 (); -+ double d054 = f1 (); -+ double d055 = f1 (); -+ double d056 = f1 (); -+ double d057 = f1 (); -+ double d058 = f1 (); -+ double d059 = f1 (); -+ double d060 = f1 (); -+ double d061 = f1 (); -+ double d062 = f1 (); -+ double d063 = f1 (); -+ double d064 = f1 (); -+ double d065 = f1 (); -+ double d066 = f1 (); -+ double d067 = f1 (); -+ double d068 = f1 (); -+ double d069 = f1 (); -+ double d070 = f1 (); -+ double d071 = f1 (); -+ double d072 = f1 (); -+ double d073 = f1 (); -+ double d074 = f1 (); -+ double d075 = f1 (); -+ double d076 = f1 (); -+ double d077 = f1 (); -+ double d078 = f1 (); -+ double d079 = f1 (); -+ double d080 = f1 (); -+ double d081 = f1 (); -+ double d082 = f1 (); -+ double d083 = f1 (); -+ double d084 = f1 (); -+ double d085 = f1 (); -+ double d086 = f1 (); -+ double d087 = f1 (); -+ double d088 = f1 (); -+ double d089 = f1 (); -+ double d090 = f1 (); -+ double d091 = f1 (); -+ double d092 = f1 (); -+ double d093 = f1 (); -+ double d094 = f1 (); -+ double d095 = f1 (); -+ double d096 = f1 (); -+ double d097 = f1 (); -+ double d098 = f1 (); -+ double d099 = f1 (); -+ double d100 = f1 (); -+ double d101 = f1 (); -+ double d102 = f1 (); -+ double d103 = f1 (); -+ double d104 = f1 (); -+ double d105 = f1 (); -+ double d106 = f1 (); -+ double d107 = f1 (); -+ double d108 = f1 (); -+ double d109 = f1 (); -+ double d110 = f1 (); -+ double d111 = f1 (); -+ double d112 = f1 (); -+ double d113 = f1 (); -+ double d114 = f1 (); -+ double d115 = f1 (); -+ double d116 = f1 (); -+ double d117 = f1 (); -+ double d118 = f1 (); -+ double d119 = f1 (); -+ double d120 = f1 (); -+ double d121 = f1 (); -+ double d122 = f1 (); -+ double d123 = f1 (); -+ double d124 = f1 (); -+ double d125 = f1 (); -+ double d126 = f1 (); -+ double d127 = f1 (); -+ double d128 = f1 (); -+ double d129 = f1 (); -+ double d130 = f1 (); -+ double d131 = f1 (); -+ double d132 = f1 (); -+ double d133 = f1 (); -+ double d134 = f1 (); -+ double d135 = f1 (); -+ double d136 = f1 (); -+ double d137 = f1 (); -+ double d138 = f1 (); -+ double d139 = f1 (); -+ double d140 = f1 (); -+ double d141 = f1 (); -+ double d142 = f1 (); -+ double d143 = f1 (); -+ double d144 = f1 (); -+ double d145 = f1 (); -+ double d146 = f1 (); -+ double d147 = f1 (); -+ double d148 = f1 (); -+ double d149 = f1 (); -+ double d150 = f1 (); -+ double d151 = f1 (); -+ double d152 = f1 (); -+ double d153 = f1 (); -+ double d154 = f1 (); -+ double d155 = f1 (); -+ double d156 = f1 (); -+ double d157 = f1 (); -+ double d158 = f1 (); -+ double d159 = f1 (); -+ double d160 = f1 (); -+ double d161 = f1 (); -+ double d162 = f1 (); -+ double d163 = f1 (); -+ double d164 = f1 (); -+ double d165 = f1 (); -+ double d166 = f1 (); -+ double d167 = f1 (); -+ double d168 = f1 (); -+ double d169 = f1 (); -+ double d170 = f1 (); -+ double d171 = f1 (); -+ double d172 = f1 (); -+ double d173 = f1 (); -+ double d174 = f1 (); -+ double d175 = f1 (); -+ double d176 = f1 (); -+ double d177 = f1 (); -+ double d178 = f1 (); -+ double d179 = f1 (); -+ double d180 = f1 (); -+ double d181 = f1 (); -+ double d182 = f1 (); -+ double d183 = f1 (); -+ double d184 = f1 (); -+ double d185 = f1 (); -+ double d186 = f1 (); -+ double d187 = f1 (); -+ double d188 = f1 (); -+ double d189 = f1 (); -+ double d190 = f1 (); -+ double d191 = f1 (); -+ double d192 = f1 (); -+ double d193 = f1 (); -+ double d194 = f1 (); -+ double d195 = f1 (); -+ double d196 = f1 (); -+ double d197 = f1 (); -+ double d198 = f1 (); -+ double d199 = f1 (); -+ double d200 = f1 (); -+ double d201 = f1 (); -+ double d202 = f1 (); -+ double d203 = f1 (); -+ double d204 = f1 (); -+ double d205 = f1 (); -+ double d206 = f1 (); -+ double d207 = f1 (); -+ double d208 = f1 (); -+ double d209 = f1 (); -+ double d210 = f1 (); -+ double d211 = f1 (); -+ double d212 = f1 (); -+ double d213 = f1 (); -+ double d214 = f1 (); -+ double d215 = f1 (); -+ double d216 = f1 (); -+ double d217 = f1 (); -+ double d218 = f1 (); -+ double d219 = f1 (); -+ double d220 = f1 (); -+ double d221 = f1 (); -+ double d222 = f1 (); -+ double d223 = f1 (); -+ double d224 = f1 (); -+ double d225 = f1 (); -+ double d226 = f1 (); -+ double d227 = f1 (); -+ double d228 = f1 (); -+ double d229 = f1 (); -+ double d230 = f1 (); -+ double d231 = f1 (); -+ double d232 = f1 (); -+ double d233 = f1 (); -+ double d234 = f1 (); -+ double d235 = f1 (); -+ double d236 = f1 (); -+ double d237 = f1 (); -+ double d238 = f1 (); -+ double d239 = f1 (); -+ double d240 = f1 (); -+ double d241 = f1 (); -+ double d242 = f1 (); -+ double d243 = f1 (); -+ double d244 = f1 (); -+ double d245 = f1 (); -+ double d246 = f1 (); -+ double d247 = f1 (); -+ double d248 = f1 (); -+ double d249 = f1 (); -+ double d250 = f1 (); -+ double d251 = f1 (); -+ double d252 = f1 (); -+ double d253 = f1 (); -+ double d254 = f1 (); -+ double d255 = f1 (); -+ double d256 = f1 (); -+ double d257 = f1 (); -+ double d258 = f1 (); -+ double d259 = f1 (); -+ double d260 = f1 (); -+ double d261 = f1 (); -+ double d262 = f1 (); -+ double d263 = f1 (); -+ double d264 = f1 (); -+ double d265 = f1 (); -+ double d266 = f1 (); -+ double d267 = f1 (); -+ double d268 = f1 (); -+ double d269 = f1 (); -+ double d270 = f1 (); -+ double d271 = f1 (); -+ double d272 = f1 (); -+ double d273 = f1 (); -+ double d274 = f1 (); -+ double d275 = f1 (); -+ double d276 = f1 (); -+ double d277 = f1 (); -+ double d278 = f1 (); -+ double d279 = f1 (); -+ double d280 = f1 (); -+ double d281 = f1 (); -+ double d282 = f1 (); -+ double d283 = f1 (); -+ double d284 = f1 (); -+ double d285 = f1 (); -+ double d286 = f1 (); -+ double d287 = f1 (); -+ double d288 = f1 (); -+ double d289 = f1 (); -+ double d290 = f1 (); -+ double d291 = f1 (); -+ double d292 = f1 (); -+ double d293 = f1 (); -+ double d294 = f1 (); -+ double d295 = f1 (); -+ double d296 = f1 (); -+ double d297 = f1 (); -+ double d298 = f1 (); -+ double d299 = f1 (); -+ double d300 = f1 (); -+ double d301 = f1 (); -+ double d302 = f1 (); -+ double d303 = f1 (); -+ double d304 = f1 (); -+ double d305 = f1 (); -+ double d306 = f1 (); -+ double d307 = f1 (); -+ double d308 = f1 (); -+ double d309 = f1 (); -+ double d310 = f1 (); -+ double d311 = f1 (); -+ double d312 = f1 (); -+ double d313 = f1 (); -+ double d314 = f1 (); -+ double d315 = f1 (); -+ double d316 = f1 (); -+ double d317 = f1 (); -+ double d318 = f1 (); -+ double d319 = f1 (); -+ double d320 = f1 (); -+ double d321 = f1 (); -+ double d322 = f1 (); -+ double d323 = f1 (); -+ double d324 = f1 (); -+ double d325 = f1 (); -+ double d326 = f1 (); -+ double d327 = f1 (); -+ double d328 = f1 (); -+ double d329 = f1 (); -+ double d330 = f1 (); -+ double d331 = f1 (); -+ double d332 = f1 (); -+ double d333 = f1 (); -+ double d334 = f1 (); -+ double d335 = f1 (); -+ double d336 = f1 (); -+ double d337 = f1 (); -+ double d338 = f1 (); -+ double d339 = f1 (); -+ double d340 = f1 (); -+ double d341 = f1 (); -+ double d342 = f1 (); -+ double d343 = f1 (); -+ double d344 = f1 (); -+ double d345 = f1 (); -+ double d346 = f1 (); -+ double d347 = f1 (); -+ double d348 = f1 (); -+ double d349 = f1 (); -+ double d350 = f1 (); -+ double d351 = f1 (); -+ double d352 = f1 (); -+ double d353 = f1 (); -+ double d354 = f1 (); -+ double d355 = f1 (); -+ double d356 = f1 (); -+ double d357 = f1 (); -+ double d358 = f1 (); -+ double d359 = f1 (); -+ double d360 = f1 (); -+ double d361 = f1 (); -+ double d362 = f1 (); -+ double d363 = f1 (); -+ double d364 = f1 (); -+ double d365 = f1 (); -+ double d366 = f1 (); -+ double d367 = f1 (); -+ double d368 = f1 (); -+ double d369 = f1 (); -+ double d370 = f1 (); -+ double d371 = f1 (); -+ double d372 = f1 (); -+ double d373 = f1 (); -+ double d374 = f1 (); -+ double d375 = f1 (); -+ double d376 = f1 (); -+ double d377 = f1 (); -+ double d378 = f1 (); -+ double d379 = f1 (); -+ double d380 = f1 (); -+ double d381 = f1 (); -+ double d382 = f1 (); -+ double d383 = f1 (); -+ double d384 = f1 (); -+ double d385 = f1 (); -+ double d386 = f1 (); -+ double d387 = f1 (); -+ double d388 = f1 (); -+ double d389 = f1 (); -+ double d390 = f1 (); -+ double d391 = f1 (); -+ double d392 = f1 (); -+ double d393 = f1 (); -+ double d394 = f1 (); -+ double d395 = f1 (); -+ double d396 = f1 (); -+ double d397 = f1 (); -+ double d398 = f1 (); -+ double d399 = f1 (); -+ double d400 = f1 (); -+ double d401 = f1 (); -+ double d402 = f1 (); -+ double d403 = f1 (); -+ double d404 = f1 (); -+ double d405 = f1 (); -+ double d406 = f1 (); -+ double d407 = f1 (); -+ double d408 = f1 (); -+ double d409 = f1 (); -+ double d410 = f1 (); -+ double d411 = f1 (); -+ double d412 = f1 (); -+ double d413 = f1 (); -+ double d414 = f1 (); -+ double d415 = f1 (); -+ double d416 = f1 (); -+ double d417 = f1 (); -+ double d418 = f1 (); -+ double d419 = f1 (); -+ double d420 = f1 (); -+ double d421 = f1 (); -+ double d422 = f1 (); -+ double d423 = f1 (); -+ double d424 = f1 (); -+ double d425 = f1 (); -+ double d426 = f1 (); -+ double d427 = f1 (); -+ double d428 = f1 (); -+ double d429 = f1 (); -+ double d430 = f1 (); -+ double d431 = f1 (); -+ double d432 = f1 (); -+ double d433 = f1 (); -+ double d434 = f1 (); -+ double d435 = f1 (); -+ double d436 = f1 (); -+ double d437 = f1 (); -+ double d438 = f1 (); -+ double d439 = f1 (); -+ double d440 = f1 (); -+ double d441 = f1 (); -+ double d442 = f1 (); -+ double d443 = f1 (); -+ double d444 = f1 (); -+ double d445 = f1 (); -+ double d446 = f1 (); -+ double d447 = f1 (); -+ double d448 = f1 (); -+ double d449 = f1 (); -+ double d450 = f1 (); -+ double d451 = f1 (); -+ double d452 = f1 (); -+ double d453 = f1 (); -+ double d454 = f1 (); -+ double d455 = f1 (); -+ double d456 = f1 (); -+ double d457 = f1 (); -+ double d458 = f1 (); -+ double d459 = f1 (); -+ double d460 = f1 (); -+ double d461 = f1 (); -+ double d462 = f1 (); -+ double d463 = f1 (); -+ double d464 = f1 (); -+ double d465 = f1 (); -+ double d466 = f1 (); -+ double d467 = f1 (); -+ double d468 = f1 (); -+ double d469 = f1 (); -+ double d470 = f1 (); -+ double d471 = f1 (); -+ double d472 = f1 (); -+ double d473 = f1 (); -+ double d474 = f1 (); -+ double d475 = f1 (); -+ double d476 = f1 (); -+ double d477 = f1 (); -+ double d478 = f1 (); -+ double d479 = f1 (); -+ double d480 = f1 (); -+ double d481 = f1 (); -+ double d482 = f1 (); -+ double d483 = f1 (); -+ double d484 = f1 (); -+ double d485 = f1 (); -+ double d486 = f1 (); -+ double d487 = f1 (); -+ double d488 = f1 (); -+ double d489 = f1 (); -+ double d490 = f1 (); -+ double d491 = f1 (); -+ double d492 = f1 (); -+ double d493 = f1 (); -+ double d494 = f1 (); -+ double d495 = f1 (); -+ double d496 = f1 (); -+ double d497 = f1 (); -+ double d498 = f1 (); -+ double d499 = f1 (); -+ double d500 = f1 (); -+ double d501 = f1 (); -+ double d502 = f1 (); -+ double d503 = f1 (); -+ double d504 = f1 (); -+ double d505 = f1 (); -+ double d506 = f1 (); -+ double d507 = f1 (); -+ double d508 = f1 (); -+ double d509 = f1 (); -+ double d510 = f1 (); -+ double d511 = f1 (); -+ double d512 = f1 (); -+ double d513 = f1 (); -+ double d514 = f1 (); -+ double d515 = f1 (); -+ double d516 = f1 (); -+ double d517 = f1 (); -+ double d518 = f1 (); -+ double d519 = f1 (); -+ double d520 = f1 (); -+ double d521 = f1 (); -+ double d522 = f1 (); -+ double d523 = f1 (); -+ double d524 = f1 (); -+ double d525 = f1 (); -+ double d526 = f1 (); -+ double d527 = f1 (); -+ double d528 = f1 (); -+ double d529 = f1 (); -+ double d530 = f1 (); -+ double d531 = f1 (); -+ double d532 = f1 (); -+ double d533 = f1 (); -+ double d534 = f1 (); -+ double d535 = f1 (); -+ double d536 = f1 (); -+ double d537 = f1 (); -+ double d538 = f1 (); -+ double d539 = f1 (); -+ double d540 = f1 (); -+ double d541 = f1 (); -+ double d542 = f1 (); -+ double d543 = f1 (); -+ double d544 = f1 (); -+ double d545 = f1 (); -+ double d546 = f1 (); -+ double d547 = f1 (); -+ double d548 = f1 (); -+ double d549 = f1 (); -+ double d550 = f1 (); -+ double d551 = f1 (); -+ double d552 = f1 (); -+ double d553 = f1 (); -+ double d554 = f1 (); -+ double d555 = f1 (); -+ double d556 = f1 (); -+ double d557 = f1 (); -+ double d558 = f1 (); -+ double d559 = f1 (); -+ double d560 = f1 (); -+ double d561 = f1 (); -+ double d562 = f1 (); -+ double d563 = f1 (); -+ double d564 = f1 (); -+ double d565 = f1 (); -+ double d566 = f1 (); -+ double d567 = f1 (); -+ double d568 = f1 (); -+ double d569 = f1 (); -+ double d570 = f1 (); -+ double d571 = f1 (); -+ double d572 = f1 (); -+ double d573 = f1 (); -+ double d574 = f1 (); -+ double d575 = f1 (); -+ double d576 = f1 (); -+ double d577 = f1 (); -+ double d578 = f1 (); -+ double d579 = f1 (); -+ double d580 = f1 (); -+ double d581 = f1 (); -+ double d582 = f1 (); -+ double d583 = f1 (); -+ double d584 = f1 (); -+ double d585 = f1 (); -+ double d586 = f1 (); -+ double d587 = f1 (); -+ double d588 = f1 (); -+ double d589 = f1 (); -+ double d590 = f1 (); -+ double d591 = f1 (); -+ double d592 = f1 (); -+ double d593 = f1 (); -+ double d594 = f1 (); -+ double d595 = f1 (); -+ double d596 = f1 (); -+ double d597 = f1 (); -+ double d598 = f1 (); -+ double d599 = f1 (); -+ double d600 = f1 (); -+ double d601 = f1 (); -+ double d602 = f1 (); -+ double d603 = f1 (); -+ double d604 = f1 (); -+ double d605 = f1 (); -+ double d606 = f1 (); -+ double d607 = f1 (); -+ double d608 = f1 (); -+ double d609 = f1 (); -+ double d610 = f1 (); -+ double d611 = f1 (); -+ double d612 = f1 (); -+ double d613 = f1 (); -+ double d614 = f1 (); -+ double d615 = f1 (); -+ double d616 = f1 (); -+ double d617 = f1 (); -+ double d618 = f1 (); -+ double d619 = f1 (); -+ double d620 = f1 (); -+ double d621 = f1 (); -+ double d622 = f1 (); -+ double d623 = f1 (); -+ double d624 = f1 (); -+ double d625 = f1 (); -+ double d626 = f1 (); -+ double d627 = f1 (); -+ double d628 = f1 (); -+ double d629 = f1 (); -+ double d630 = f1 (); -+ double d631 = f1 (); -+ double d632 = f1 (); -+ double d633 = f1 (); -+ double d634 = f1 (); -+ double d635 = f1 (); -+ double d636 = f1 (); -+ double d637 = f1 (); -+ double d638 = f1 (); -+ double d639 = f1 (); -+ double d640 = f1 (); -+ double d641 = f1 (); -+ double d642 = f1 (); -+ double d643 = f1 (); -+ double d644 = f1 (); -+ double d645 = f1 (); -+ double d646 = f1 (); -+ double d647 = f1 (); -+ double d648 = f1 (); -+ double d649 = f1 (); -+ double d650 = f1 (); -+ double d651 = f1 (); -+ double d652 = f1 (); -+ double d653 = f1 (); -+ double d654 = f1 (); -+ double d655 = f1 (); -+ double d656 = f1 (); -+ double d657 = f1 (); -+ double d658 = f1 (); -+ double d659 = f1 (); -+ double d660 = f1 (); -+ double d661 = f1 (); -+ double d662 = f1 (); -+ double d663 = f1 (); -+ double d664 = f1 (); -+ double d665 = f1 (); -+ double d666 = f1 (); -+ double d667 = f1 (); -+ double d668 = f1 (); -+ double d669 = f1 (); -+ double d670 = f1 (); -+ double d671 = f1 (); -+ double d672 = f1 (); -+ double d673 = f1 (); -+ double d674 = f1 (); -+ double d675 = f1 (); -+ double d676 = f1 (); -+ double d677 = f1 (); -+ double d678 = f1 (); -+ double d679 = f1 (); -+ double d680 = f1 (); -+ double d681 = f1 (); -+ double d682 = f1 (); -+ double d683 = f1 (); -+ double d684 = f1 (); -+ double d685 = f1 (); -+ double d686 = f1 (); -+ double d687 = f1 (); -+ double d688 = f1 (); -+ double d689 = f1 (); -+ double d690 = f1 (); -+ double d691 = f1 (); -+ double d692 = f1 (); -+ double d693 = f1 (); -+ double d694 = f1 (); -+ double d695 = f1 (); -+ double d696 = f1 (); -+ double d697 = f1 (); -+ double d698 = f1 (); -+ double d699 = f1 (); -+ double d700 = f1 (); -+ double d701 = f1 (); -+ double d702 = f1 (); -+ double d703 = f1 (); -+ double d704 = f1 (); -+ double d705 = f1 (); -+ double d706 = f1 (); -+ double d707 = f1 (); -+ double d708 = f1 (); -+ double d709 = f1 (); -+ double d710 = f1 (); -+ double d711 = f1 (); -+ double d712 = f1 (); -+ double d713 = f1 (); -+ double d714 = f1 (); -+ double d715 = f1 (); -+ double d716 = f1 (); -+ double d717 = f1 (); -+ double d718 = f1 (); -+ double d719 = f1 (); -+ double d720 = f1 (); -+ double d721 = f1 (); -+ double d722 = f1 (); -+ double d723 = f1 (); -+ double d724 = f1 (); -+ double d725 = f1 (); -+ double d726 = f1 (); -+ double d727 = f1 (); -+ double d728 = f1 (); -+ double d729 = f1 (); -+ double d730 = f1 (); -+ double d731 = f1 (); -+ double d732 = f1 (); -+ double d733 = f1 (); -+ double d734 = f1 (); -+ double d735 = f1 (); -+ double d736 = f1 (); -+ double d737 = f1 (); -+ double d738 = f1 (); -+ double d739 = f1 (); -+ double d740 = f1 (); -+ double d741 = f1 (); -+ double d742 = f1 (); -+ double d743 = f1 (); -+ double d744 = f1 (); -+ double d745 = f1 (); -+ double d746 = f1 (); -+ double d747 = f1 (); -+ double d748 = f1 (); -+ double d749 = f1 (); -+ double d750 = f1 (); -+ double d751 = f1 (); -+ double d752 = f1 (); -+ double d753 = f1 (); -+ double d754 = f1 (); -+ double d755 = f1 (); -+ double d756 = f1 (); -+ double d757 = f1 (); -+ double d758 = f1 (); -+ double d759 = f1 (); -+ double d760 = f1 (); -+ double d761 = f1 (); -+ double d762 = f1 (); -+ double d763 = f1 (); -+ double d764 = f1 (); -+ double d765 = f1 (); -+ double d766 = f1 (); -+ double d767 = f1 (); -+ double d768 = f1 (); -+ double d769 = f1 (); -+ double d770 = f1 (); -+ double d771 = f1 (); -+ double d772 = f1 (); -+ double d773 = f1 (); -+ double d774 = f1 (); -+ double d775 = f1 (); -+ double d776 = f1 (); -+ double d777 = f1 (); -+ double d778 = f1 (); -+ double d779 = f1 (); -+ double d780 = f1 (); -+ double d781 = f1 (); -+ double d782 = f1 (); -+ double d783 = f1 (); -+ double d784 = f1 (); -+ double d785 = f1 (); -+ double d786 = f1 (); -+ double d787 = f1 (); -+ double d788 = f1 (); -+ double d789 = f1 (); -+ double d790 = f1 (); -+ double d791 = f1 (); -+ double d792 = f1 (); -+ double d793 = f1 (); -+ double d794 = f1 (); -+ double d795 = f1 (); -+ double d796 = f1 (); -+ double d797 = f1 (); -+ double d798 = f1 (); -+ double d799 = f1 (); -+ double d800 = f1 (); -+ double d801 = f1 (); -+ double d802 = f1 (); -+ double d803 = f1 (); -+ double d804 = f1 (); -+ double d805 = f1 (); -+ double d806 = f1 (); -+ double d807 = f1 (); -+ double d808 = f1 (); -+ double d809 = f1 (); -+ double d810 = f1 (); -+ double d811 = f1 (); -+ double d812 = f1 (); -+ double d813 = f1 (); -+ double d814 = f1 (); -+ double d815 = f1 (); -+ double d816 = f1 (); -+ double d817 = f1 (); -+ double d818 = f1 (); -+ double d819 = f1 (); -+ double d820 = f1 (); -+ double d821 = f1 (); -+ double d822 = f1 (); -+ double d823 = f1 (); -+ double d824 = f1 (); -+ double d825 = f1 (); -+ double d826 = f1 (); -+ double d827 = f1 (); -+ double d828 = f1 (); -+ double d829 = f1 (); -+ double d830 = f1 (); -+ double d831 = f1 (); -+ double d832 = f1 (); -+ double d833 = f1 (); -+ double d834 = f1 (); -+ double d835 = f1 (); -+ double d836 = f1 (); -+ double d837 = f1 (); -+ double d838 = f1 (); -+ double d839 = f1 (); -+ double d840 = f1 (); -+ double d841 = f1 (); -+ double d842 = f1 (); -+ double d843 = f1 (); -+ double d844 = f1 (); -+ double d845 = f1 (); -+ double d846 = f1 (); -+ double d847 = f1 (); -+ double d848 = f1 (); -+ double d849 = f1 (); -+ double d850 = f1 (); -+ double d851 = f1 (); -+ double d852 = f1 (); -+ double d853 = f1 (); -+ double d854 = f1 (); -+ double d855 = f1 (); -+ double d856 = f1 (); -+ double d857 = f1 (); -+ double d858 = f1 (); -+ double d859 = f1 (); -+ double d860 = f1 (); -+ double d861 = f1 (); -+ double d862 = f1 (); -+ double d863 = f1 (); -+ double d864 = f1 (); -+ double d865 = f1 (); -+ double d866 = f1 (); -+ double d867 = f1 (); -+ double d868 = f1 (); -+ double d869 = f1 (); -+ double d870 = f1 (); -+ double d871 = f1 (); -+ double d872 = f1 (); -+ double d873 = f1 (); -+ double d874 = f1 (); -+ double d875 = f1 (); -+ double d876 = f1 (); -+ double d877 = f1 (); -+ double d878 = f1 (); -+ double d879 = f1 (); -+ double d880 = f1 (); -+ double d881 = f1 (); -+ double d882 = f1 (); -+ double d883 = f1 (); -+ double d884 = f1 (); -+ double d885 = f1 (); -+ double d886 = f1 (); -+ double d887 = f1 (); -+ double d888 = f1 (); -+ double d889 = f1 (); -+ double d890 = f1 (); -+ double d891 = f1 (); -+ double d892 = f1 (); -+ double d893 = f1 (); -+ double d894 = f1 (); -+ double d895 = f1 (); -+ double d896 = f1 (); -+ double d897 = f1 (); -+ double d898 = f1 (); -+ double d899 = f1 (); -+ double d900 = f1 (); -+ double d901 = f1 (); -+ double d902 = f1 (); -+ double d903 = f1 (); -+ double d904 = f1 (); -+ double d905 = f1 (); -+ double d906 = f1 (); -+ double d907 = f1 (); -+ double d908 = f1 (); -+ double d909 = f1 (); -+ double d910 = f1 (); -+ double d911 = f1 (); -+ double d912 = f1 (); -+ double d913 = f1 (); -+ double d914 = f1 (); -+ double d915 = f1 (); -+ double d916 = f1 (); -+ double d917 = f1 (); -+ double d918 = f1 (); -+ double d919 = f1 (); -+ double d920 = f1 (); -+ double d921 = f1 (); -+ double d922 = f1 (); -+ double d923 = f1 (); -+ double d924 = f1 (); -+ double d925 = f1 (); -+ double d926 = f1 (); -+ double d927 = f1 (); -+ double d928 = f1 (); -+ double d929 = f1 (); -+ double d930 = f1 (); -+ double d931 = f1 (); -+ double d932 = f1 (); -+ double d933 = f1 (); -+ double d934 = f1 (); -+ double d935 = f1 (); -+ double d936 = f1 (); -+ double d937 = f1 (); -+ double d938 = f1 (); -+ double d939 = f1 (); -+ double d940 = f1 (); -+ double d941 = f1 (); -+ double d942 = f1 (); -+ double d943 = f1 (); -+ double d944 = f1 (); -+ double d945 = f1 (); -+ double d946 = f1 (); -+ double d947 = f1 (); -+ double d948 = f1 (); -+ double d949 = f1 (); -+ double d950 = f1 (); -+ double d951 = f1 (); -+ double d952 = f1 (); -+ double d953 = f1 (); -+ double d954 = f1 (); -+ double d955 = f1 (); -+ double d956 = f1 (); -+ double d957 = f1 (); -+ double d958 = f1 (); -+ double d959 = f1 (); -+ double d960 = f1 (); -+ double d961 = f1 (); -+ double d962 = f1 (); -+ double d963 = f1 (); -+ double d964 = f1 (); -+ double d965 = f1 (); -+ double d966 = f1 (); -+ double d967 = f1 (); -+ double d968 = f1 (); -+ double d969 = f1 (); -+ double d970 = f1 (); -+ double d971 = f1 (); -+ double d972 = f1 (); -+ double d973 = f1 (); -+ double d974 = f1 (); -+ double d975 = f1 (); -+ double d976 = f1 (); -+ double d977 = f1 (); -+ double d978 = f1 (); -+ double d979 = f1 (); -+ double d980 = f1 (); -+ double d981 = f1 (); -+ double d982 = f1 (); -+ double d983 = f1 (); -+ double d984 = f1 (); -+ double d985 = f1 (); -+ double d986 = f1 (); -+ double d987 = f1 (); -+ double d988 = f1 (); -+ double d989 = f1 (); -+ double d990 = f1 (); -+ double d991 = f1 (); -+ double d992 = f1 (); -+ double d993 = f1 (); -+ double d994 = f1 (); -+ double d995 = f1 (); -+ double d996 = f1 (); -+ double d997 = f1 (); -+ double d998 = f1 (); -+ double d999 = f1 (); -+ -+ double x = 0; -+ x = f2 (x, d000); -+ x = f2 (x, d001); -+ x = f2 (x, d002); -+ x = f2 (x, d003); -+ x = f2 (x, d004); -+ x = f2 (x, d005); -+ x = f2 (x, d006); -+ x = f2 (x, d007); -+ x = f2 (x, d008); -+ x = f2 (x, d009); -+ x = f2 (x, d010); -+ x = f2 (x, d011); -+ x = f2 (x, d012); -+ x = f2 (x, d013); -+ x = f2 (x, d014); -+ x = f2 (x, d015); -+ x = f2 (x, d016); -+ x = f2 (x, d017); -+ x = f2 (x, d018); -+ x = f2 (x, d019); -+ x = f2 (x, d020); -+ x = f2 (x, d021); -+ x = f2 (x, d022); -+ x = f2 (x, d023); -+ x = f2 (x, d024); -+ x = f2 (x, d025); -+ x = f2 (x, d026); -+ x = f2 (x, d027); -+ x = f2 (x, d028); -+ x = f2 (x, d029); -+ x = f2 (x, d030); -+ x = f2 (x, d031); -+ x = f2 (x, d032); -+ x = f2 (x, d033); -+ x = f2 (x, d034); -+ x = f2 (x, d035); -+ x = f2 (x, d036); -+ x = f2 (x, d037); -+ x = f2 (x, d038); -+ x = f2 (x, d039); -+ x = f2 (x, d040); -+ x = f2 (x, d041); -+ x = f2 (x, d042); -+ x = f2 (x, d043); -+ x = f2 (x, d044); -+ x = f2 (x, d045); -+ x = f2 (x, d046); -+ x = f2 (x, d047); -+ x = f2 (x, d048); -+ x = f2 (x, d049); -+ x = f2 (x, d050); -+ x = f2 (x, d051); -+ x = f2 (x, d052); -+ x = f2 (x, d053); -+ x = f2 (x, d054); -+ x = f2 (x, d055); -+ x = f2 (x, d056); -+ x = f2 (x, d057); -+ x = f2 (x, d058); -+ x = f2 (x, d059); -+ x = f2 (x, d060); -+ x = f2 (x, d061); -+ x = f2 (x, d062); -+ x = f2 (x, d063); -+ x = f2 (x, d064); -+ x = f2 (x, d065); -+ x = f2 (x, d066); -+ x = f2 (x, d067); -+ x = f2 (x, d068); -+ x = f2 (x, d069); -+ x = f2 (x, d070); -+ x = f2 (x, d071); -+ x = f2 (x, d072); -+ x = f2 (x, d073); -+ x = f2 (x, d074); -+ x = f2 (x, d075); -+ x = f2 (x, d076); -+ x = f2 (x, d077); -+ x = f2 (x, d078); -+ x = f2 (x, d079); -+ x = f2 (x, d080); -+ x = f2 (x, d081); -+ x = f2 (x, d082); -+ x = f2 (x, d083); -+ x = f2 (x, d084); -+ x = f2 (x, d085); -+ x = f2 (x, d086); -+ x = f2 (x, d087); -+ x = f2 (x, d088); -+ x = f2 (x, d089); -+ x = f2 (x, d090); -+ x = f2 (x, d091); -+ x = f2 (x, d092); -+ x = f2 (x, d093); -+ x = f2 (x, d094); -+ x = f2 (x, d095); -+ x = f2 (x, d096); -+ x = f2 (x, d097); -+ x = f2 (x, d098); -+ x = f2 (x, d099); -+ x = f2 (x, d100); -+ x = f2 (x, d101); -+ x = f2 (x, d102); -+ x = f2 (x, d103); -+ x = f2 (x, d104); -+ x = f2 (x, d105); -+ x = f2 (x, d106); -+ x = f2 (x, d107); -+ x = f2 (x, d108); -+ x = f2 (x, d109); -+ x = f2 (x, d110); -+ x = f2 (x, d111); -+ x = f2 (x, d112); -+ x = f2 (x, d113); -+ x = f2 (x, d114); -+ x = f2 (x, d115); -+ x = f2 (x, d116); -+ x = f2 (x, d117); -+ x = f2 (x, d118); -+ x = f2 (x, d119); -+ x = f2 (x, d120); -+ x = f2 (x, d121); -+ x = f2 (x, d122); -+ x = f2 (x, d123); -+ x = f2 (x, d124); -+ x = f2 (x, d125); -+ x = f2 (x, d126); -+ x = f2 (x, d127); -+ x = f2 (x, d128); -+ x = f2 (x, d129); -+ x = f2 (x, d130); -+ x = f2 (x, d131); -+ x = f2 (x, d132); -+ x = f2 (x, d133); -+ x = f2 (x, d134); -+ x = f2 (x, d135); -+ x = f2 (x, d136); -+ x = f2 (x, d137); -+ x = f2 (x, d138); -+ x = f2 (x, d139); -+ x = f2 (x, d140); -+ x = f2 (x, d141); -+ x = f2 (x, d142); -+ x = f2 (x, d143); -+ x = f2 (x, d144); -+ x = f2 (x, d145); -+ x = f2 (x, d146); -+ x = f2 (x, d147); -+ x = f2 (x, d148); -+ x = f2 (x, d149); -+ x = f2 (x, d150); -+ x = f2 (x, d151); -+ x = f2 (x, d152); -+ x = f2 (x, d153); -+ x = f2 (x, d154); -+ x = f2 (x, d155); -+ x = f2 (x, d156); -+ x = f2 (x, d157); -+ x = f2 (x, d158); -+ x = f2 (x, d159); -+ x = f2 (x, d160); -+ x = f2 (x, d161); -+ x = f2 (x, d162); -+ x = f2 (x, d163); -+ x = f2 (x, d164); -+ x = f2 (x, d165); -+ x = f2 (x, d166); -+ x = f2 (x, d167); -+ x = f2 (x, d168); -+ x = f2 (x, d169); -+ x = f2 (x, d170); -+ x = f2 (x, d171); -+ x = f2 (x, d172); -+ x = f2 (x, d173); -+ x = f2 (x, d174); -+ x = f2 (x, d175); -+ x = f2 (x, d176); -+ x = f2 (x, d177); -+ x = f2 (x, d178); -+ x = f2 (x, d179); -+ x = f2 (x, d180); -+ x = f2 (x, d181); -+ x = f2 (x, d182); -+ x = f2 (x, d183); -+ x = f2 (x, d184); -+ x = f2 (x, d185); -+ x = f2 (x, d186); -+ x = f2 (x, d187); -+ x = f2 (x, d188); -+ x = f2 (x, d189); -+ x = f2 (x, d190); -+ x = f2 (x, d191); -+ x = f2 (x, d192); -+ x = f2 (x, d193); -+ x = f2 (x, d194); -+ x = f2 (x, d195); -+ x = f2 (x, d196); -+ x = f2 (x, d197); -+ x = f2 (x, d198); -+ x = f2 (x, d199); -+ x = f2 (x, d200); -+ x = f2 (x, d201); -+ x = f2 (x, d202); -+ x = f2 (x, d203); -+ x = f2 (x, d204); -+ x = f2 (x, d205); -+ x = f2 (x, d206); -+ x = f2 (x, d207); -+ x = f2 (x, d208); -+ x = f2 (x, d209); -+ x = f2 (x, d210); -+ x = f2 (x, d211); -+ x = f2 (x, d212); -+ x = f2 (x, d213); -+ x = f2 (x, d214); -+ x = f2 (x, d215); -+ x = f2 (x, d216); -+ x = f2 (x, d217); -+ x = f2 (x, d218); -+ x = f2 (x, d219); -+ x = f2 (x, d220); -+ x = f2 (x, d221); -+ x = f2 (x, d222); -+ x = f2 (x, d223); -+ x = f2 (x, d224); -+ x = f2 (x, d225); -+ x = f2 (x, d226); -+ x = f2 (x, d227); -+ x = f2 (x, d228); -+ x = f2 (x, d229); -+ x = f2 (x, d230); -+ x = f2 (x, d231); -+ x = f2 (x, d232); -+ x = f2 (x, d233); -+ x = f2 (x, d234); -+ x = f2 (x, d235); -+ x = f2 (x, d236); -+ x = f2 (x, d237); -+ x = f2 (x, d238); -+ x = f2 (x, d239); -+ x = f2 (x, d240); -+ x = f2 (x, d241); -+ x = f2 (x, d242); -+ x = f2 (x, d243); -+ x = f2 (x, d244); -+ x = f2 (x, d245); -+ x = f2 (x, d246); -+ x = f2 (x, d247); -+ x = f2 (x, d248); -+ x = f2 (x, d249); -+ x = f2 (x, d250); -+ x = f2 (x, d251); -+ x = f2 (x, d252); -+ x = f2 (x, d253); -+ x = f2 (x, d254); -+ x = f2 (x, d255); -+ x = f2 (x, d256); -+ x = f2 (x, d257); -+ x = f2 (x, d258); -+ x = f2 (x, d259); -+ x = f2 (x, d260); -+ x = f2 (x, d261); -+ x = f2 (x, d262); -+ x = f2 (x, d263); -+ x = f2 (x, d264); -+ x = f2 (x, d265); -+ x = f2 (x, d266); -+ x = f2 (x, d267); -+ x = f2 (x, d268); -+ x = f2 (x, d269); -+ x = f2 (x, d270); -+ x = f2 (x, d271); -+ x = f2 (x, d272); -+ x = f2 (x, d273); -+ x = f2 (x, d274); -+ x = f2 (x, d275); -+ x = f2 (x, d276); -+ x = f2 (x, d277); -+ x = f2 (x, d278); -+ x = f2 (x, d279); -+ x = f2 (x, d280); -+ x = f2 (x, d281); -+ x = f2 (x, d282); -+ x = f2 (x, d283); -+ x = f2 (x, d284); -+ x = f2 (x, d285); -+ x = f2 (x, d286); -+ x = f2 (x, d287); -+ x = f2 (x, d288); -+ x = f2 (x, d289); -+ x = f2 (x, d290); -+ x = f2 (x, d291); -+ x = f2 (x, d292); -+ x = f2 (x, d293); -+ x = f2 (x, d294); -+ x = f2 (x, d295); -+ x = f2 (x, d296); -+ x = f2 (x, d297); -+ x = f2 (x, d298); -+ x = f2 (x, d299); -+ x = f2 (x, d300); -+ x = f2 (x, d301); -+ x = f2 (x, d302); -+ x = f2 (x, d303); -+ x = f2 (x, d304); -+ x = f2 (x, d305); -+ x = f2 (x, d306); -+ x = f2 (x, d307); -+ x = f2 (x, d308); -+ x = f2 (x, d309); -+ x = f2 (x, d310); -+ x = f2 (x, d311); -+ x = f2 (x, d312); -+ x = f2 (x, d313); -+ x = f2 (x, d314); -+ x = f2 (x, d315); -+ x = f2 (x, d316); -+ x = f2 (x, d317); -+ x = f2 (x, d318); -+ x = f2 (x, d319); -+ x = f2 (x, d320); -+ x = f2 (x, d321); -+ x = f2 (x, d322); -+ x = f2 (x, d323); -+ x = f2 (x, d324); -+ x = f2 (x, d325); -+ x = f2 (x, d326); -+ x = f2 (x, d327); -+ x = f2 (x, d328); -+ x = f2 (x, d329); -+ x = f2 (x, d330); -+ x = f2 (x, d331); -+ x = f2 (x, d332); -+ x = f2 (x, d333); -+ x = f2 (x, d334); -+ x = f2 (x, d335); -+ x = f2 (x, d336); -+ x = f2 (x, d337); -+ x = f2 (x, d338); -+ x = f2 (x, d339); -+ x = f2 (x, d340); -+ x = f2 (x, d341); -+ x = f2 (x, d342); -+ x = f2 (x, d343); -+ x = f2 (x, d344); -+ x = f2 (x, d345); -+ x = f2 (x, d346); -+ x = f2 (x, d347); -+ x = f2 (x, d348); -+ x = f2 (x, d349); -+ x = f2 (x, d350); -+ x = f2 (x, d351); -+ x = f2 (x, d352); -+ x = f2 (x, d353); -+ x = f2 (x, d354); -+ x = f2 (x, d355); -+ x = f2 (x, d356); -+ x = f2 (x, d357); -+ x = f2 (x, d358); -+ x = f2 (x, d359); -+ x = f2 (x, d360); -+ x = f2 (x, d361); -+ x = f2 (x, d362); -+ x = f2 (x, d363); -+ x = f2 (x, d364); -+ x = f2 (x, d365); -+ x = f2 (x, d366); -+ x = f2 (x, d367); -+ x = f2 (x, d368); -+ x = f2 (x, d369); -+ x = f2 (x, d370); -+ x = f2 (x, d371); -+ x = f2 (x, d372); -+ x = f2 (x, d373); -+ x = f2 (x, d374); -+ x = f2 (x, d375); -+ x = f2 (x, d376); -+ x = f2 (x, d377); -+ x = f2 (x, d378); -+ x = f2 (x, d379); -+ x = f2 (x, d380); -+ x = f2 (x, d381); -+ x = f2 (x, d382); -+ x = f2 (x, d383); -+ x = f2 (x, d384); -+ x = f2 (x, d385); -+ x = f2 (x, d386); -+ x = f2 (x, d387); -+ x = f2 (x, d388); -+ x = f2 (x, d389); -+ x = f2 (x, d390); -+ x = f2 (x, d391); -+ x = f2 (x, d392); -+ x = f2 (x, d393); -+ x = f2 (x, d394); -+ x = f2 (x, d395); -+ x = f2 (x, d396); -+ x = f2 (x, d397); -+ x = f2 (x, d398); -+ x = f2 (x, d399); -+ x = f2 (x, d400); -+ x = f2 (x, d401); -+ x = f2 (x, d402); -+ x = f2 (x, d403); -+ x = f2 (x, d404); -+ x = f2 (x, d405); -+ x = f2 (x, d406); -+ x = f2 (x, d407); -+ x = f2 (x, d408); -+ x = f2 (x, d409); -+ x = f2 (x, d410); -+ x = f2 (x, d411); -+ x = f2 (x, d412); -+ x = f2 (x, d413); -+ x = f2 (x, d414); -+ x = f2 (x, d415); -+ x = f2 (x, d416); -+ x = f2 (x, d417); -+ x = f2 (x, d418); -+ x = f2 (x, d419); -+ x = f2 (x, d420); -+ x = f2 (x, d421); -+ x = f2 (x, d422); -+ x = f2 (x, d423); -+ x = f2 (x, d424); -+ x = f2 (x, d425); -+ x = f2 (x, d426); -+ x = f2 (x, d427); -+ x = f2 (x, d428); -+ x = f2 (x, d429); -+ x = f2 (x, d430); -+ x = f2 (x, d431); -+ x = f2 (x, d432); -+ x = f2 (x, d433); -+ x = f2 (x, d434); -+ x = f2 (x, d435); -+ x = f2 (x, d436); -+ x = f2 (x, d437); -+ x = f2 (x, d438); -+ x = f2 (x, d439); -+ x = f2 (x, d440); -+ x = f2 (x, d441); -+ x = f2 (x, d442); -+ x = f2 (x, d443); -+ x = f2 (x, d444); -+ x = f2 (x, d445); -+ x = f2 (x, d446); -+ x = f2 (x, d447); -+ x = f2 (x, d448); -+ x = f2 (x, d449); -+ x = f2 (x, d450); -+ x = f2 (x, d451); -+ x = f2 (x, d452); -+ x = f2 (x, d453); -+ x = f2 (x, d454); -+ x = f2 (x, d455); -+ x = f2 (x, d456); -+ x = f2 (x, d457); -+ x = f2 (x, d458); -+ x = f2 (x, d459); -+ x = f2 (x, d460); -+ x = f2 (x, d461); -+ x = f2 (x, d462); -+ x = f2 (x, d463); -+ x = f2 (x, d464); -+ x = f2 (x, d465); -+ x = f2 (x, d466); -+ x = f2 (x, d467); -+ x = f2 (x, d468); -+ x = f2 (x, d469); -+ x = f2 (x, d470); -+ x = f2 (x, d471); -+ x = f2 (x, d472); -+ x = f2 (x, d473); -+ x = f2 (x, d474); -+ x = f2 (x, d475); -+ x = f2 (x, d476); -+ x = f2 (x, d477); -+ x = f2 (x, d478); -+ x = f2 (x, d479); -+ x = f2 (x, d480); -+ x = f2 (x, d481); -+ x = f2 (x, d482); -+ x = f2 (x, d483); -+ x = f2 (x, d484); -+ x = f2 (x, d485); -+ x = f2 (x, d486); -+ x = f2 (x, d487); -+ x = f2 (x, d488); -+ x = f2 (x, d489); -+ x = f2 (x, d490); -+ x = f2 (x, d491); -+ x = f2 (x, d492); -+ x = f2 (x, d493); -+ x = f2 (x, d494); -+ x = f2 (x, d495); -+ x = f2 (x, d496); -+ x = f2 (x, d497); -+ x = f2 (x, d498); -+ x = f2 (x, d499); -+ x = f2 (x, d500); -+ x = f2 (x, d501); -+ x = f2 (x, d502); -+ x = f2 (x, d503); -+ x = f2 (x, d504); -+ x = f2 (x, d505); -+ x = f2 (x, d506); -+ x = f2 (x, d507); -+ x = f2 (x, d508); -+ x = f2 (x, d509); -+ x = f2 (x, d510); -+ x = f2 (x, d511); -+ x = f2 (x, d512); -+ x = f2 (x, d513); -+ x = f2 (x, d514); -+ x = f2 (x, d515); -+ x = f2 (x, d516); -+ x = f2 (x, d517); -+ x = f2 (x, d518); -+ x = f2 (x, d519); -+ x = f2 (x, d520); -+ x = f2 (x, d521); -+ x = f2 (x, d522); -+ x = f2 (x, d523); -+ x = f2 (x, d524); -+ x = f2 (x, d525); -+ x = f2 (x, d526); -+ x = f2 (x, d527); -+ x = f2 (x, d528); -+ x = f2 (x, d529); -+ x = f2 (x, d530); -+ x = f2 (x, d531); -+ x = f2 (x, d532); -+ x = f2 (x, d533); -+ x = f2 (x, d534); -+ x = f2 (x, d535); -+ x = f2 (x, d536); -+ x = f2 (x, d537); -+ x = f2 (x, d538); -+ x = f2 (x, d539); -+ x = f2 (x, d540); -+ x = f2 (x, d541); -+ x = f2 (x, d542); -+ x = f2 (x, d543); -+ x = f2 (x, d544); -+ x = f2 (x, d545); -+ x = f2 (x, d546); -+ x = f2 (x, d547); -+ x = f2 (x, d548); -+ x = f2 (x, d549); -+ x = f2 (x, d550); -+ x = f2 (x, d551); -+ x = f2 (x, d552); -+ x = f2 (x, d553); -+ x = f2 (x, d554); -+ x = f2 (x, d555); -+ x = f2 (x, d556); -+ x = f2 (x, d557); -+ x = f2 (x, d558); -+ x = f2 (x, d559); -+ x = f2 (x, d560); -+ x = f2 (x, d561); -+ x = f2 (x, d562); -+ x = f2 (x, d563); -+ x = f2 (x, d564); -+ x = f2 (x, d565); -+ x = f2 (x, d566); -+ x = f2 (x, d567); -+ x = f2 (x, d568); -+ x = f2 (x, d569); -+ x = f2 (x, d570); -+ x = f2 (x, d571); -+ x = f2 (x, d572); -+ x = f2 (x, d573); -+ x = f2 (x, d574); -+ x = f2 (x, d575); -+ x = f2 (x, d576); -+ x = f2 (x, d577); -+ x = f2 (x, d578); -+ x = f2 (x, d579); -+ x = f2 (x, d580); -+ x = f2 (x, d581); -+ x = f2 (x, d582); -+ x = f2 (x, d583); -+ x = f2 (x, d584); -+ x = f2 (x, d585); -+ x = f2 (x, d586); -+ x = f2 (x, d587); -+ x = f2 (x, d588); -+ x = f2 (x, d589); -+ x = f2 (x, d590); -+ x = f2 (x, d591); -+ x = f2 (x, d592); -+ x = f2 (x, d593); -+ x = f2 (x, d594); -+ x = f2 (x, d595); -+ x = f2 (x, d596); -+ x = f2 (x, d597); -+ x = f2 (x, d598); -+ x = f2 (x, d599); -+ x = f2 (x, d600); -+ x = f2 (x, d601); -+ x = f2 (x, d602); -+ x = f2 (x, d603); -+ x = f2 (x, d604); -+ x = f2 (x, d605); -+ x = f2 (x, d606); -+ x = f2 (x, d607); -+ x = f2 (x, d608); -+ x = f2 (x, d609); -+ x = f2 (x, d610); -+ x = f2 (x, d611); -+ x = f2 (x, d612); -+ x = f2 (x, d613); -+ x = f2 (x, d614); -+ x = f2 (x, d615); -+ x = f2 (x, d616); -+ x = f2 (x, d617); -+ x = f2 (x, d618); -+ x = f2 (x, d619); -+ x = f2 (x, d620); -+ x = f2 (x, d621); -+ x = f2 (x, d622); -+ x = f2 (x, d623); -+ x = f2 (x, d624); -+ x = f2 (x, d625); -+ x = f2 (x, d626); -+ x = f2 (x, d627); -+ x = f2 (x, d628); -+ x = f2 (x, d629); -+ x = f2 (x, d630); -+ x = f2 (x, d631); -+ x = f2 (x, d632); -+ x = f2 (x, d633); -+ x = f2 (x, d634); -+ x = f2 (x, d635); -+ x = f2 (x, d636); -+ x = f2 (x, d637); -+ x = f2 (x, d638); -+ x = f2 (x, d639); -+ x = f2 (x, d640); -+ x = f2 (x, d641); -+ x = f2 (x, d642); -+ x = f2 (x, d643); -+ x = f2 (x, d644); -+ x = f2 (x, d645); -+ x = f2 (x, d646); -+ x = f2 (x, d647); -+ x = f2 (x, d648); -+ x = f2 (x, d649); -+ x = f2 (x, d650); -+ x = f2 (x, d651); -+ x = f2 (x, d652); -+ x = f2 (x, d653); -+ x = f2 (x, d654); -+ x = f2 (x, d655); -+ x = f2 (x, d656); -+ x = f2 (x, d657); -+ x = f2 (x, d658); -+ x = f2 (x, d659); -+ x = f2 (x, d660); -+ x = f2 (x, d661); -+ x = f2 (x, d662); -+ x = f2 (x, d663); -+ x = f2 (x, d664); -+ x = f2 (x, d665); -+ x = f2 (x, d666); -+ x = f2 (x, d667); -+ x = f2 (x, d668); -+ x = f2 (x, d669); -+ x = f2 (x, d670); -+ x = f2 (x, d671); -+ x = f2 (x, d672); -+ x = f2 (x, d673); -+ x = f2 (x, d674); -+ x = f2 (x, d675); -+ x = f2 (x, d676); -+ x = f2 (x, d677); -+ x = f2 (x, d678); -+ x = f2 (x, d679); -+ x = f2 (x, d680); -+ x = f2 (x, d681); -+ x = f2 (x, d682); -+ x = f2 (x, d683); -+ x = f2 (x, d684); -+ x = f2 (x, d685); -+ x = f2 (x, d686); -+ x = f2 (x, d687); -+ x = f2 (x, d688); -+ x = f2 (x, d689); -+ x = f2 (x, d690); -+ x = f2 (x, d691); -+ x = f2 (x, d692); -+ x = f2 (x, d693); -+ x = f2 (x, d694); -+ x = f2 (x, d695); -+ x = f2 (x, d696); -+ x = f2 (x, d697); -+ x = f2 (x, d698); -+ x = f2 (x, d699); -+ x = f2 (x, d700); -+ x = f2 (x, d701); -+ x = f2 (x, d702); -+ x = f2 (x, d703); -+ x = f2 (x, d704); -+ x = f2 (x, d705); -+ x = f2 (x, d706); -+ x = f2 (x, d707); -+ x = f2 (x, d708); -+ x = f2 (x, d709); -+ x = f2 (x, d710); -+ x = f2 (x, d711); -+ x = f2 (x, d712); -+ x = f2 (x, d713); -+ x = f2 (x, d714); -+ x = f2 (x, d715); -+ x = f2 (x, d716); -+ x = f2 (x, d717); -+ x = f2 (x, d718); -+ x = f2 (x, d719); -+ x = f2 (x, d720); -+ x = f2 (x, d721); -+ x = f2 (x, d722); -+ x = f2 (x, d723); -+ x = f2 (x, d724); -+ x = f2 (x, d725); -+ x = f2 (x, d726); -+ x = f2 (x, d727); -+ x = f2 (x, d728); -+ x = f2 (x, d729); -+ x = f2 (x, d730); -+ x = f2 (x, d731); -+ x = f2 (x, d732); -+ x = f2 (x, d733); -+ x = f2 (x, d734); -+ x = f2 (x, d735); -+ x = f2 (x, d736); -+ x = f2 (x, d737); -+ x = f2 (x, d738); -+ x = f2 (x, d739); -+ x = f2 (x, d740); -+ x = f2 (x, d741); -+ x = f2 (x, d742); -+ x = f2 (x, d743); -+ x = f2 (x, d744); -+ x = f2 (x, d745); -+ x = f2 (x, d746); -+ x = f2 (x, d747); -+ x = f2 (x, d748); -+ x = f2 (x, d749); -+ x = f2 (x, d750); -+ x = f2 (x, d751); -+ x = f2 (x, d752); -+ x = f2 (x, d753); -+ x = f2 (x, d754); -+ x = f2 (x, d755); -+ x = f2 (x, d756); -+ x = f2 (x, d757); -+ x = f2 (x, d758); -+ x = f2 (x, d759); -+ x = f2 (x, d760); -+ x = f2 (x, d761); -+ x = f2 (x, d762); -+ x = f2 (x, d763); -+ x = f2 (x, d764); -+ x = f2 (x, d765); -+ x = f2 (x, d766); -+ x = f2 (x, d767); -+ x = f2 (x, d768); -+ x = f2 (x, d769); -+ x = f2 (x, d770); -+ x = f2 (x, d771); -+ x = f2 (x, d772); -+ x = f2 (x, d773); -+ x = f2 (x, d774); -+ x = f2 (x, d775); -+ x = f2 (x, d776); -+ x = f2 (x, d777); -+ x = f2 (x, d778); -+ x = f2 (x, d779); -+ x = f2 (x, d780); -+ x = f2 (x, d781); -+ x = f2 (x, d782); -+ x = f2 (x, d783); -+ x = f2 (x, d784); -+ x = f2 (x, d785); -+ x = f2 (x, d786); -+ x = f2 (x, d787); -+ x = f2 (x, d788); -+ x = f2 (x, d789); -+ x = f2 (x, d790); -+ x = f2 (x, d791); -+ x = f2 (x, d792); -+ x = f2 (x, d793); -+ x = f2 (x, d794); -+ x = f2 (x, d795); -+ x = f2 (x, d796); -+ x = f2 (x, d797); -+ x = f2 (x, d798); -+ x = f2 (x, d799); -+ x = f2 (x, d800); -+ x = f2 (x, d801); -+ x = f2 (x, d802); -+ x = f2 (x, d803); -+ x = f2 (x, d804); -+ x = f2 (x, d805); -+ x = f2 (x, d806); -+ x = f2 (x, d807); -+ x = f2 (x, d808); -+ x = f2 (x, d809); -+ x = f2 (x, d810); -+ x = f2 (x, d811); -+ x = f2 (x, d812); -+ x = f2 (x, d813); -+ x = f2 (x, d814); -+ x = f2 (x, d815); -+ x = f2 (x, d816); -+ x = f2 (x, d817); -+ x = f2 (x, d818); -+ x = f2 (x, d819); -+ x = f2 (x, d820); -+ x = f2 (x, d821); -+ x = f2 (x, d822); -+ x = f2 (x, d823); -+ x = f2 (x, d824); -+ x = f2 (x, d825); -+ x = f2 (x, d826); -+ x = f2 (x, d827); -+ x = f2 (x, d828); -+ x = f2 (x, d829); -+ x = f2 (x, d830); -+ x = f2 (x, d831); -+ x = f2 (x, d832); -+ x = f2 (x, d833); -+ x = f2 (x, d834); -+ x = f2 (x, d835); -+ x = f2 (x, d836); -+ x = f2 (x, d837); -+ x = f2 (x, d838); -+ x = f2 (x, d839); -+ x = f2 (x, d840); -+ x = f2 (x, d841); -+ x = f2 (x, d842); -+ x = f2 (x, d843); -+ x = f2 (x, d844); -+ x = f2 (x, d845); -+ x = f2 (x, d846); -+ x = f2 (x, d847); -+ x = f2 (x, d848); -+ x = f2 (x, d849); -+ x = f2 (x, d850); -+ x = f2 (x, d851); -+ x = f2 (x, d852); -+ x = f2 (x, d853); -+ x = f2 (x, d854); -+ x = f2 (x, d855); -+ x = f2 (x, d856); -+ x = f2 (x, d857); -+ x = f2 (x, d858); -+ x = f2 (x, d859); -+ x = f2 (x, d860); -+ x = f2 (x, d861); -+ x = f2 (x, d862); -+ x = f2 (x, d863); -+ x = f2 (x, d864); -+ x = f2 (x, d865); -+ x = f2 (x, d866); -+ x = f2 (x, d867); -+ x = f2 (x, d868); -+ x = f2 (x, d869); -+ x = f2 (x, d870); -+ x = f2 (x, d871); -+ x = f2 (x, d872); -+ x = f2 (x, d873); -+ x = f2 (x, d874); -+ x = f2 (x, d875); -+ x = f2 (x, d876); -+ x = f2 (x, d877); -+ x = f2 (x, d878); -+ x = f2 (x, d879); -+ x = f2 (x, d880); -+ x = f2 (x, d881); -+ x = f2 (x, d882); -+ x = f2 (x, d883); -+ x = f2 (x, d884); -+ x = f2 (x, d885); -+ x = f2 (x, d886); -+ x = f2 (x, d887); -+ x = f2 (x, d888); -+ x = f2 (x, d889); -+ x = f2 (x, d890); -+ x = f2 (x, d891); -+ x = f2 (x, d892); -+ x = f2 (x, d893); -+ x = f2 (x, d894); -+ x = f2 (x, d895); -+ x = f2 (x, d896); -+ x = f2 (x, d897); -+ x = f2 (x, d898); -+ x = f2 (x, d899); -+ x = f2 (x, d900); -+ x = f2 (x, d901); -+ x = f2 (x, d902); -+ x = f2 (x, d903); -+ x = f2 (x, d904); -+ x = f2 (x, d905); -+ x = f2 (x, d906); -+ x = f2 (x, d907); -+ x = f2 (x, d908); -+ x = f2 (x, d909); -+ x = f2 (x, d910); -+ x = f2 (x, d911); -+ x = f2 (x, d912); -+ x = f2 (x, d913); -+ x = f2 (x, d914); -+ x = f2 (x, d915); -+ x = f2 (x, d916); -+ x = f2 (x, d917); -+ x = f2 (x, d918); -+ x = f2 (x, d919); -+ x = f2 (x, d920); -+ x = f2 (x, d921); -+ x = f2 (x, d922); -+ x = f2 (x, d923); -+ x = f2 (x, d924); -+ x = f2 (x, d925); -+ x = f2 (x, d926); -+ x = f2 (x, d927); -+ x = f2 (x, d928); -+ x = f2 (x, d929); -+ x = f2 (x, d930); -+ x = f2 (x, d931); -+ x = f2 (x, d932); -+ x = f2 (x, d933); -+ x = f2 (x, d934); -+ x = f2 (x, d935); -+ x = f2 (x, d936); -+ x = f2 (x, d937); -+ x = f2 (x, d938); -+ x = f2 (x, d939); -+ x = f2 (x, d940); -+ x = f2 (x, d941); -+ x = f2 (x, d942); -+ x = f2 (x, d943); -+ x = f2 (x, d944); -+ x = f2 (x, d945); -+ x = f2 (x, d946); -+ x = f2 (x, d947); -+ x = f2 (x, d948); -+ x = f2 (x, d949); -+ x = f2 (x, d950); -+ x = f2 (x, d951); -+ x = f2 (x, d952); -+ x = f2 (x, d953); -+ x = f2 (x, d954); -+ x = f2 (x, d955); -+ x = f2 (x, d956); -+ x = f2 (x, d957); -+ x = f2 (x, d958); -+ x = f2 (x, d959); -+ x = f2 (x, d960); -+ x = f2 (x, d961); -+ x = f2 (x, d962); -+ x = f2 (x, d963); -+ x = f2 (x, d964); -+ x = f2 (x, d965); -+ x = f2 (x, d966); -+ x = f2 (x, d967); -+ x = f2 (x, d968); -+ x = f2 (x, d969); -+ x = f2 (x, d970); -+ x = f2 (x, d971); -+ x = f2 (x, d972); -+ x = f2 (x, d973); -+ x = f2 (x, d974); -+ x = f2 (x, d975); -+ x = f2 (x, d976); -+ x = f2 (x, d977); -+ x = f2 (x, d978); -+ x = f2 (x, d979); -+ x = f2 (x, d980); -+ x = f2 (x, d981); -+ x = f2 (x, d982); -+ x = f2 (x, d983); -+ x = f2 (x, d984); -+ x = f2 (x, d985); -+ x = f2 (x, d986); -+ x = f2 (x, d987); -+ x = f2 (x, d988); -+ x = f2 (x, d989); -+ x = f2 (x, d990); -+ x = f2 (x, d991); -+ x = f2 (x, d992); -+ x = f2 (x, d993); -+ x = f2 (x, d994); -+ x = f2 (x, d995); -+ x = f2 (x, d996); -+ x = f2 (x, d997); -+ x = f2 (x, d998); -+ x = f2 (x, d999); -+ return x; -+} -+ -+/* { dg-final { scan-rtl-dump-times "Stack clash inline probes" 1 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash residual allocation in prologue" 1 "pro_and_epilogue" } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash not noreturn" 1 "pro_and_epilogue" } } */ -+ -+/* f3 is not a leaf -+/* { dg-final { scan-rtl-dump-times "Stack clash no frame pointer needed" 1 "pro_and_epilogue" { target { ! frame_pointer_for_non_leaf } } } } */ -+/* { dg-final { scan-rtl-dump-times "Stack clash frame pointer needed" 1 "pro_and_epilogue" { target { frame_pointer_for_non_leaf } } } } */ -diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp -index 1000f15358b..8dbec663b18 100644 ---- a/gcc/testsuite/lib/target-supports.exp -+++ b/gcc/testsuite/lib/target-supports.exp -@@ -8385,11 +8385,15 @@ proc check_effective_target_arm_coproc4_ok { } { - proc check_effective_target_supports_stack_clash_protection { } { - - # Temporary until the target bits are fully ACK'd. --# if { [istarget aarch*-*-*] || [istarget x86_64-*-*] --# || [istarget i?86-*-*] || [istarget s390*-*-*] -+# if { [istarget aarch*-*-*] -+# || [istarget s390*-*-*] - # || [istarget powerpc*-*-*] || [istarget rs6000*-*-*] } { - # return 1 - # } -+ -+ if { [istarget x86_64-*-*] || [istarget i?86-*-*] } { -+ return 1 -+ } - return 0 - } - diff --git a/gcc7-rh1512529-6.patch b/gcc7-rh1512529-6.patch deleted file mode 100644 index dd13635..0000000 --- a/gcc7-rh1512529-6.patch +++ /dev/null @@ -1,118 +0,0 @@ -commit e7519110827a59eb7275591db640bdbdfd31ba15 -Author: law -Date: Wed Sep 20 05:43:28 2017 +0000 - - * combine-stack-adj.c (combine_stack_adjustments_for_block): Do - nothing for stack adjustments with REG_STACK_CHECK. - * sched-deps.c (parse_add_or_inc): Reject insns with - REG_STACK_CHECK from dependency breaking. - * config/i386/i386.c (pro_epilogue_adjust_stack): Return insn. - (ix86_adjust_satck_and_probe_stack_clash): Add REG_STACK_NOTEs. - * reg-notes.def (STACK_CHECK): New note. - - * gcc.target/i386/stack-check-11.c: New test. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@252999 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/combine-stack-adj.c b/gcc/combine-stack-adj.c -index 9ec14a3e443..82d6dba856f 100644 ---- a/gcc/combine-stack-adj.c -+++ b/gcc/combine-stack-adj.c -@@ -508,6 +508,8 @@ combine_stack_adjustments_for_block (basic_block bb) - continue; - - set = single_set_for_csa (insn); -+ if (set && find_reg_note (insn, REG_STACK_CHECK, NULL_RTX)) -+ set = NULL_RTX; - if (set) - { - rtx dest = SET_DEST (set); -diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c -index 088dca2001f..5aff9b9d113 100644 ---- a/gcc/config/i386/i386.c -+++ b/gcc/config/i386/i386.c -@@ -12900,7 +12900,7 @@ ix86_add_queued_cfa_restore_notes (rtx insn) - zero if %r11 register is live and cannot be freely used and positive - otherwise. */ - --static void -+static rtx - pro_epilogue_adjust_stack (rtx dest, rtx src, rtx offset, - int style, bool set_cfa) - { -@@ -12987,6 +12987,7 @@ pro_epilogue_adjust_stack (rtx dest, rtx src, rtx offset, - m->fs.sp_offset = ooffset - INTVAL (offset); - m->fs.sp_valid = valid; - } -+ return insn; - } - - /* Find an available register to be used as dynamic realign argument -@@ -13333,9 +13334,11 @@ ix86_adjust_stack_and_probe_stack_clash (const HOST_WIDE_INT size) - for (i = probe_interval; i <= size; i += probe_interval) - { - /* Allocate PROBE_INTERVAL bytes. */ -- pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx, -- GEN_INT (-probe_interval), -1, -- m->fs.cfa_reg == stack_pointer_rtx); -+ rtx insn -+ = pro_epilogue_adjust_stack (stack_pointer_rtx, stack_pointer_rtx, -+ GEN_INT (-PROBE_INTERVAL), -1, -+ m->fs.cfa_reg == stack_pointer_rtx); -+ add_reg_note (insn, REG_STACK_CHECK, const0_rtx); - - /* And probe at *sp. */ - emit_stack_probe (stack_pointer_rtx); -diff --git a/gcc/reg-notes.def b/gcc/reg-notes.def -index 8734d26e5b4..18cf7e3cfc0 100644 ---- a/gcc/reg-notes.def -+++ b/gcc/reg-notes.def -@@ -223,6 +223,10 @@ REG_NOTE (ARGS_SIZE) - pseudo reg. */ - REG_NOTE (RETURNED) - -+/* Indicates the instruction is a stack check probe that should not -+ be combined with other stack adjustments. */ -+REG_NOTE (STACK_CHECK) -+ - /* Used to mark a call with the function decl called by the call. - The decl might not be available in the call due to splitting of the call - insn. This note is a SYMBOL_REF. */ -diff --git a/gcc/sched-deps.c b/gcc/sched-deps.c -index b2393bf28fb..564f3fb1559 100644 ---- a/gcc/sched-deps.c -+++ b/gcc/sched-deps.c -@@ -4717,6 +4717,11 @@ parse_add_or_inc (struct mem_inc_info *mii, rtx_insn *insn, bool before_mem) - if (RTX_FRAME_RELATED_P (insn) || !pat) - return false; - -+ /* Do not allow breaking data dependencies for insns that are marked -+ with REG_STACK_CHECK. */ -+ if (find_reg_note (insn, REG_STACK_CHECK, NULL)) -+ return false; -+ - /* Result must be single reg. */ - if (!REG_P (SET_DEST (pat))) - return false; -diff --git a/gcc/testsuite/gcc.target/i386/stack-check-11.c b/gcc/testsuite/gcc.target/i386/stack-check-11.c -new file mode 100644 -index 00000000000..183103f01e5 ---- /dev/null -+++ b/gcc/testsuite/gcc.target/i386/stack-check-11.c -@@ -0,0 +1,16 @@ -+/* { dg-do compile } */ -+/* { dg-options "-O2 -fstack-clash-protection" } */ -+/* { dg-require-effective-target supports_stack_clash_protection } */ -+ -+extern void arf (unsigned long int *, unsigned long int *); -+void -+frob () -+{ -+ unsigned long int num[859]; -+ unsigned long int den[859]; -+ arf (den, num); -+} -+ -+/* { dg-final { scan-assembler-times "subq" 4 } } */ -+/* { dg-final { scan-assembler-times "orq" 3 } } */ -+ diff --git a/gcc7-rh1512529-7.patch b/gcc7-rh1512529-7.patch deleted file mode 100644 index 0510dcd..0000000 --- a/gcc7-rh1512529-7.patch +++ /dev/null @@ -1,88 +0,0 @@ -commit 919262bedfe78b0d4f9fddbd980b85243a83bf28 -Author: law -Date: Wed Sep 20 21:59:50 2017 +0000 - - * explow.c (compute_stack_clash_protection_loop_data): Use - CONST_INT_P instead of explicit test. Verify object is a - CONST_INT_P before looking at INTVAL. - (anti_adjust_stack_and_probe_stack_clash): Use CONST_INT_P - instead of explicit test. - - * gcc.target/i386/stack-check-11.c: Update test and regexp - so that it works for both i?86 and x86_64. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@253034 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/explow.c b/gcc/explow.c -index 2a73414ab22..6af6355fe30 100644 ---- a/gcc/explow.c -+++ b/gcc/explow.c -@@ -1822,11 +1822,11 @@ compute_stack_clash_protection_loop_data (rtx *rounded_size, rtx *last_addr, - if (*rounded_size == CONST0_RTX (Pmode)) - fprintf (dump_file, - "Stack clash skipped dynamic allocation and probing loop.\n"); -- else if (GET_CODE (*rounded_size) == CONST_INT -+ else if (CONST_INT_P (*rounded_size) - && INTVAL (*rounded_size) <= 4 * *probe_interval) - fprintf (dump_file, - "Stack clash dynamic allocation and probing inline.\n"); -- else if (GET_CODE (*rounded_size) == CONST_INT) -+ else if (CONST_INT_P (*rounded_size)) - fprintf (dump_file, - "Stack clash dynamic allocation and probing in " - "rotated loop.\n"); -@@ -1924,7 +1924,8 @@ anti_adjust_stack_and_probe_stack_clash (rtx size) - - if (rounded_size != CONST0_RTX (Pmode)) - { -- if (INTVAL (rounded_size) <= 4 * probe_interval) -+ if (CONST_INT_P (rounded_size) -+ && INTVAL (rounded_size) <= 4 * probe_interval) - { - for (HOST_WIDE_INT i = 0; - i < INTVAL (rounded_size); -@@ -1944,7 +1945,7 @@ anti_adjust_stack_and_probe_stack_clash (rtx size) - else - { - rtx loop_lab, end_loop; -- bool rotate_loop = GET_CODE (rounded_size) == CONST_INT; -+ bool rotate_loop = CONST_INT_P (rounded_size); - emit_stack_clash_protection_probe_loop_start (&loop_lab, &end_loop, - last_addr, rotate_loop); - -@@ -1982,7 +1983,7 @@ anti_adjust_stack_and_probe_stack_clash (rtx size) - might hold live data. So probe at *sp if we know that - an allocation was made, otherwise probe into the red zone - which is obviously undesirable. */ -- if (GET_CODE (size) == CONST_INT) -+ if (CONST_INT_P (size)) - { - emit_stack_probe (stack_pointer_rtx); - emit_insn (gen_blockage ()); -diff --git a/gcc/testsuite/gcc.target/i386/stack-check-11.c b/gcc/testsuite/gcc.target/i386/stack-check-11.c -index 183103f01e5..fe5b2c2b844 100644 ---- a/gcc/testsuite/gcc.target/i386/stack-check-11.c -+++ b/gcc/testsuite/gcc.target/i386/stack-check-11.c -@@ -2,15 +2,17 @@ - /* { dg-options "-O2 -fstack-clash-protection" } */ - /* { dg-require-effective-target supports_stack_clash_protection } */ - --extern void arf (unsigned long int *, unsigned long int *); -+#include -+ -+extern void arf (uint64_t *, uint64_t *); - void - frob () - { -- unsigned long int num[859]; -- unsigned long int den[859]; -+ uint64_t num[859]; -+ uint64_t den[859]; - arf (den, num); - } - --/* { dg-final { scan-assembler-times "subq" 4 } } */ --/* { dg-final { scan-assembler-times "orq" 3 } } */ -+/* { dg-final { scan-assembler-times "sub\[ql\]" 4 } } */ -+/* { dg-final { scan-assembler-times "or\[ql\]" 3 } } */ - diff --git a/gcc7-rh1512529-8.patch b/gcc7-rh1512529-8.patch deleted file mode 100644 index a59a8ee..0000000 --- a/gcc7-rh1512529-8.patch +++ /dev/null @@ -1,388 +0,0 @@ -commit a63af926db1d6109011e4dd81c750ecf784ab6c1 -Author: law -Date: Thu Sep 21 04:30:16 2017 +0000 - - * config/s390/s390.c (MIN_UNROLL_PROBES): Define. - (allocate_stack_space): New function, partially extracted from - s390_emit_prologue. - (s390_emit_prologue): Track offset to most recent stack probe. - Code to allocate space moved into allocate_stack_space. - Dump actions when no stack is allocated. - (s390_prologue_plus_offset): New function. - (s390_emit_stack_probe): Likewise. - - * gcc.dg/stack-check-5.c: Add argument for s390. - * lib/target-supports.exp: - (check_effective_target_supports_stack_clash_protection): Enable for - s390/s390x targets. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@253049 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/config/s390/s390.c b/gcc/config/s390/s390.c -index c408d59efd2..c78f1456daa 100644 ---- a/gcc/config/s390/s390.c -+++ b/gcc/config/s390/s390.c -@@ -10974,6 +10974,183 @@ pass_s390_early_mach::execute (function *fun) - - } // anon namespace - -+/* Calculate TARGET = REG + OFFSET as s390_emit_prologue would do it. -+ - push too big immediates to the literal pool and annotate the refs -+ - emit frame related notes for stack pointer changes. */ -+ -+static rtx -+s390_prologue_plus_offset (rtx target, rtx reg, rtx offset, bool frame_related_p) -+{ -+ rtx insn; -+ rtx orig_offset = offset; -+ -+ gcc_assert (REG_P (target)); -+ gcc_assert (REG_P (reg)); -+ gcc_assert (CONST_INT_P (offset)); -+ -+ if (offset == const0_rtx) /* lr/lgr */ -+ { -+ insn = emit_move_insn (target, reg); -+ } -+ else if (DISP_IN_RANGE (INTVAL (offset))) /* la */ -+ { -+ insn = emit_move_insn (target, gen_rtx_PLUS (Pmode, reg, -+ offset)); -+ } -+ else -+ { -+ if (!satisfies_constraint_K (offset) /* ahi/aghi */ -+ && (!TARGET_EXTIMM -+ || (!satisfies_constraint_Op (offset) /* alfi/algfi */ -+ && !satisfies_constraint_On (offset)))) /* slfi/slgfi */ -+ offset = force_const_mem (Pmode, offset); -+ -+ if (target != reg) -+ { -+ insn = emit_move_insn (target, reg); -+ RTX_FRAME_RELATED_P (insn) = frame_related_p ? 1 : 0; -+ } -+ -+ insn = emit_insn (gen_add2_insn (target, offset)); -+ -+ if (!CONST_INT_P (offset)) -+ { -+ annotate_constant_pool_refs (&PATTERN (insn)); -+ -+ if (frame_related_p) -+ add_reg_note (insn, REG_FRAME_RELATED_EXPR, -+ gen_rtx_SET (target, -+ gen_rtx_PLUS (Pmode, target, -+ orig_offset))); -+ } -+ } -+ -+ RTX_FRAME_RELATED_P (insn) = frame_related_p ? 1 : 0; -+ -+ /* If this is a stack adjustment and we are generating a stack clash -+ prologue, then add a REG_STACK_CHECK note to signal that this insn -+ should be left alone. */ -+ if (flag_stack_clash_protection && target == stack_pointer_rtx) -+ add_reg_note (insn, REG_STACK_CHECK, const0_rtx); -+ -+ return insn; -+} -+ -+/* Emit a compare instruction with a volatile memory access as stack -+ probe. It does not waste store tags and does not clobber any -+ registers apart from the condition code. */ -+static void -+s390_emit_stack_probe (rtx addr) -+{ -+ rtx tmp = gen_rtx_MEM (Pmode, addr); -+ MEM_VOLATILE_P (tmp) = 1; -+ s390_emit_compare (EQ, gen_rtx_REG (Pmode, 0), tmp); -+ emit_insn (gen_blockage ()); -+} -+ -+/* Use a runtime loop if we have to emit more probes than this. */ -+#define MIN_UNROLL_PROBES 3 -+ -+/* Allocate SIZE bytes of stack space, using TEMP_REG as a temporary -+ if necessary. LAST_PROBE_OFFSET contains the offset of the closest -+ probe relative to the stack pointer. -+ -+ Note that SIZE is negative. -+ -+ The return value is true if TEMP_REG has been clobbered. */ -+static bool -+allocate_stack_space (rtx size, HOST_WIDE_INT last_probe_offset, -+ rtx temp_reg) -+{ -+ bool temp_reg_clobbered_p = false; -+ HOST_WIDE_INT probe_interval -+ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL); -+ HOST_WIDE_INT guard_size -+ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE); -+ -+ if (flag_stack_clash_protection) -+ { -+ if (last_probe_offset + -INTVAL (size) < guard_size) -+ dump_stack_clash_frame_info (NO_PROBE_SMALL_FRAME, true); -+ else -+ { -+ rtx offset = GEN_INT (probe_interval - UNITS_PER_LONG); -+ HOST_WIDE_INT rounded_size = -INTVAL (size) & -probe_interval; -+ HOST_WIDE_INT num_probes = rounded_size / probe_interval; -+ HOST_WIDE_INT residual = -INTVAL (size) - rounded_size; -+ -+ if (num_probes < MIN_UNROLL_PROBES) -+ { -+ /* Emit unrolled probe statements. */ -+ -+ for (unsigned int i = 0; i < num_probes; i++) -+ { -+ s390_prologue_plus_offset (stack_pointer_rtx, -+ stack_pointer_rtx, -+ GEN_INT (-probe_interval), true); -+ s390_emit_stack_probe (gen_rtx_PLUS (Pmode, -+ stack_pointer_rtx, -+ offset)); -+ } -+ dump_stack_clash_frame_info (PROBE_INLINE, residual != 0); -+ } -+ else -+ { -+ /* Emit a loop probing the pages. */ -+ -+ rtx_code_label *loop_start_label = gen_label_rtx (); -+ -+ /* From now on temp_reg will be the CFA register. */ -+ s390_prologue_plus_offset (temp_reg, stack_pointer_rtx, -+ GEN_INT (-rounded_size), true); -+ emit_label (loop_start_label); -+ -+ s390_prologue_plus_offset (stack_pointer_rtx, -+ stack_pointer_rtx, -+ GEN_INT (-probe_interval), false); -+ s390_emit_stack_probe (gen_rtx_PLUS (Pmode, -+ stack_pointer_rtx, -+ offset)); -+ emit_cmp_and_jump_insns (stack_pointer_rtx, temp_reg, -+ GT, NULL_RTX, -+ Pmode, 1, loop_start_label); -+ -+ /* Without this make_edges ICEes. */ -+ JUMP_LABEL (get_last_insn ()) = loop_start_label; -+ LABEL_NUSES (loop_start_label) = 1; -+ -+ /* That's going to be a NOP since stack pointer and -+ temp_reg are supposed to be the same here. We just -+ emit it to set the CFA reg back to r15. */ -+ s390_prologue_plus_offset (stack_pointer_rtx, temp_reg, -+ const0_rtx, true); -+ temp_reg_clobbered_p = true; -+ dump_stack_clash_frame_info (PROBE_LOOP, residual != 0); -+ } -+ -+ /* Handle any residual allocation request. */ -+ s390_prologue_plus_offset (stack_pointer_rtx, -+ stack_pointer_rtx, -+ GEN_INT (-residual), true); -+ last_probe_offset += residual; -+ if (last_probe_offset >= probe_interval) -+ s390_emit_stack_probe (gen_rtx_PLUS (Pmode, -+ stack_pointer_rtx, -+ GEN_INT (residual -+ - UNITS_PER_LONG))); -+ -+ return temp_reg_clobbered_p; -+ } -+ } -+ -+ /* Subtract frame size from stack pointer. */ -+ s390_prologue_plus_offset (stack_pointer_rtx, -+ stack_pointer_rtx, -+ size, true); -+ -+ return temp_reg_clobbered_p; -+} -+ - /* Expand the prologue into a bunch of separate insns. */ - - void -@@ -10998,6 +11175,19 @@ s390_emit_prologue (void) - else - temp_reg = gen_rtx_REG (Pmode, 1); - -+ /* When probing for stack-clash mitigation, we have to track the distance -+ between the stack pointer and closest known reference. -+ -+ Most of the time we have to make a worst cast assumption. The -+ only exception is when TARGET_BACKCHAIN is active, in which case -+ we know *sp (offset 0) was written. */ -+ HOST_WIDE_INT probe_interval -+ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL); -+ HOST_WIDE_INT last_probe_offset -+ = (TARGET_BACKCHAIN -+ ? (TARGET_PACKED_STACK ? STACK_POINTER_OFFSET - UNITS_PER_LONG : 0) -+ : probe_interval - (STACK_BOUNDARY / UNITS_PER_WORD)); -+ - s390_save_gprs_to_fprs (); - - /* Save call saved gprs. */ -@@ -11009,6 +11199,14 @@ s390_emit_prologue (void) - - cfun_frame_layout.first_save_gpr_slot), - cfun_frame_layout.first_save_gpr, - cfun_frame_layout.last_save_gpr); -+ -+ /* This is not 100% correct. If we have more than one register saved, -+ then LAST_PROBE_OFFSET can move even closer to sp. */ -+ last_probe_offset -+ = (cfun_frame_layout.gprs_offset + -+ UNITS_PER_LONG * (cfun_frame_layout.first_save_gpr -+ - cfun_frame_layout.first_save_gpr_slot)); -+ - emit_insn (insn); - } - -@@ -11025,6 +11223,8 @@ s390_emit_prologue (void) - if (cfun_fpr_save_p (i)) - { - save_fpr (stack_pointer_rtx, offset, i); -+ if (offset < last_probe_offset) -+ last_probe_offset = offset; - offset += 8; - } - else if (!TARGET_PACKED_STACK || cfun->stdarg) -@@ -11038,6 +11238,8 @@ s390_emit_prologue (void) - if (cfun_fpr_save_p (i)) - { - insn = save_fpr (stack_pointer_rtx, offset, i); -+ if (offset < last_probe_offset) -+ last_probe_offset = offset; - offset += 8; - - /* If f4 and f6 are call clobbered they are saved due to -@@ -11060,6 +11262,8 @@ s390_emit_prologue (void) - if (cfun_fpr_save_p (i)) - { - insn = save_fpr (stack_pointer_rtx, offset, i); -+ if (offset < last_probe_offset) -+ last_probe_offset = offset; - - RTX_FRAME_RELATED_P (insn) = 1; - offset -= 8; -@@ -11079,10 +11283,11 @@ s390_emit_prologue (void) - if (cfun_frame_layout.frame_size > 0) - { - rtx frame_off = GEN_INT (-cfun_frame_layout.frame_size); -- rtx real_frame_off; -+ rtx_insn *stack_pointer_backup_loc; -+ bool temp_reg_clobbered_p; - - if (s390_stack_size) -- { -+ { - HOST_WIDE_INT stack_guard; - - if (s390_stack_guard) -@@ -11148,35 +11353,36 @@ s390_emit_prologue (void) - if (s390_warn_dynamicstack_p && cfun->calls_alloca) - warning (0, "%qs uses dynamic stack allocation", current_function_name ()); - -- /* Save incoming stack pointer into temp reg. */ -- if (TARGET_BACKCHAIN || next_fpr) -- insn = emit_insn (gen_move_insn (temp_reg, stack_pointer_rtx)); -+ /* Save the location where we could backup the incoming stack -+ pointer. */ -+ stack_pointer_backup_loc = get_last_insn (); - -- /* Subtract frame size from stack pointer. */ -+ temp_reg_clobbered_p = allocate_stack_space (frame_off, last_probe_offset, -+ temp_reg); - -- if (DISP_IN_RANGE (INTVAL (frame_off))) -- { -- insn = gen_rtx_SET (stack_pointer_rtx, -- gen_rtx_PLUS (Pmode, stack_pointer_rtx, -- frame_off)); -- insn = emit_insn (insn); -- } -- else -+ if (TARGET_BACKCHAIN || next_fpr) - { -- if (!CONST_OK_FOR_K (INTVAL (frame_off))) -- frame_off = force_const_mem (Pmode, frame_off); -- -- insn = emit_insn (gen_add2_insn (stack_pointer_rtx, frame_off)); -- annotate_constant_pool_refs (&PATTERN (insn)); -+ if (temp_reg_clobbered_p) -+ { -+ /* allocate_stack_space had to make use of temp_reg and -+ we need it to hold a backup of the incoming stack -+ pointer. Calculate back that value from the current -+ stack pointer. */ -+ s390_prologue_plus_offset (temp_reg, stack_pointer_rtx, -+ GEN_INT (cfun_frame_layout.frame_size), -+ false); -+ } -+ else -+ { -+ /* allocate_stack_space didn't actually required -+ temp_reg. Insert the stack pointer backup insn -+ before the stack pointer decrement code - knowing now -+ that the value will survive. */ -+ emit_insn_after (gen_move_insn (temp_reg, stack_pointer_rtx), -+ stack_pointer_backup_loc); -+ } - } - -- RTX_FRAME_RELATED_P (insn) = 1; -- real_frame_off = GEN_INT (-cfun_frame_layout.frame_size); -- add_reg_note (insn, REG_FRAME_RELATED_EXPR, -- gen_rtx_SET (stack_pointer_rtx, -- gen_rtx_PLUS (Pmode, stack_pointer_rtx, -- real_frame_off))); -- - /* Set backchain. */ - - if (TARGET_BACKCHAIN) -@@ -11200,6 +11406,8 @@ s390_emit_prologue (void) - emit_clobber (addr); - } - } -+ else if (flag_stack_clash_protection) -+ dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false); - - /* Save fprs 8 - 15 (64 bit ABI). */ - -diff --git a/gcc/testsuite/gcc.dg/stack-check-5.c b/gcc/testsuite/gcc.dg/stack-check-5.c -index 2171d9b6c23..3178f5d8ce5 100644 ---- a/gcc/testsuite/gcc.dg/stack-check-5.c -+++ b/gcc/testsuite/gcc.dg/stack-check-5.c -@@ -3,6 +3,10 @@ - /* { dg-require-effective-target supports_stack_clash_protection } */ - - -+/* Otherwise the S/390 back-end might save the stack pointer in f2 () -+ into an FPR. */ -+/* { dg-additional-options "-msoft-float" { target { s390x-*-* } } } */ -+ - extern void foo (char *); - extern void bar (void); - -diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp -index 8dbec663b18..e9f03886ca6 100644 ---- a/gcc/testsuite/lib/target-supports.exp -+++ b/gcc/testsuite/lib/target-supports.exp -@@ -8386,12 +8386,12 @@ proc check_effective_target_supports_stack_clash_protection { } { - - # Temporary until the target bits are fully ACK'd. - # if { [istarget aarch*-*-*] --# || [istarget s390*-*-*] - # || [istarget powerpc*-*-*] || [istarget rs6000*-*-*] } { - # return 1 - # } - -- if { [istarget x86_64-*-*] || [istarget i?86-*-*] } { -+ if { [istarget x86_64-*-*] || [istarget i?86-*-*] -+ || [istarget s390*-*-*] } { - return 1 - } - return 0 diff --git a/gcc7-rh1512529-9.patch b/gcc7-rh1512529-9.patch deleted file mode 100644 index 9c1f260..0000000 --- a/gcc7-rh1512529-9.patch +++ /dev/null @@ -1,49 +0,0 @@ -commit 233a9def5cd0b70f1288ff57ce67d9d5d5d7f845 -Author: law -Date: Thu Sep 21 22:03:59 2017 +0000 - - * config/i386/i386.c (ix86_adjust_stack_and_probe_stack_clash): - Fix dump output if the only stack space is for pushed registers. - - * lib/target-supports.exp - (check_effective_target_frame_pointer_for_non_leaf): Add - case for x86 Solaris. - - git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@253082 138bc75d-0d04-0410-961f-82ee72b054a4 - -diff --git a/gcc/config/i386/i386.c b/gcc/config/i386/i386.c -index 5aff9b9d113..086848b2c73 100644 ---- a/gcc/config/i386/i386.c -+++ b/gcc/config/i386/i386.c -@@ -13287,7 +13287,13 @@ ix86_adjust_stack_and_probe_stack_clash (const HOST_WIDE_INT size) - no probes are needed. */ - if (!size) - { -- dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false); -+ /* However, the allocation of space via pushes for register -+ saves could be viewed as allocating space, but without the -+ need to probe. */ -+ if (m->frame.nregs || m->frame.nsseregs || frame_pointer_needed) -+ dump_stack_clash_frame_info (NO_PROBE_SMALL_FRAME, true); -+ else -+ dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false); - return; - } - -diff --git a/gcc/testsuite/lib/target-supports.exp b/gcc/testsuite/lib/target-supports.exp -index e9f03886ca6..cb58a2be35f 100644 ---- a/gcc/testsuite/lib/target-supports.exp -+++ b/gcc/testsuite/lib/target-supports.exp -@@ -8403,6 +8403,12 @@ proc check_effective_target_frame_pointer_for_non_leaf { } { - if { [istarget aarch*-*-*] } { - return 1 - } -+ -+ # Solaris/x86 defaults to -fno-omit-frame-pointer. -+ if { [istarget i?86-*-solaris*] || [istarget x86_64-*-solaris*] } { -+ return 1 -+ } -+ - return 0 - } - diff --git a/gcc7-rh1512529-aarch64.patch b/gcc7-rh1512529-aarch64.patch new file mode 100644 index 0000000..6148517 --- /dev/null +++ b/gcc7-rh1512529-aarch64.patch @@ -0,0 +1,2477 @@ +commit 3dfd5ffd7ce1f940e474a0e7718d968b00a2a7c8 +Author: Jeff Law +Date: Wed Nov 22 12:01:56 2017 -0700 + + aarch64 support + +--- gcc/config/aarch64/aarch64.c ++++ gcc/config/aarch64/aarch64.c +@@ -2747,7 +2747,14 @@ aarch64_output_probe_stack_range (rtx reg1, rtx reg2) + output_asm_insn ("sub\t%0, %0, %1", xops); + + /* Probe at TEST_ADDR. */ +- output_asm_insn ("str\txzr, [%0]", xops); ++ if (flag_stack_clash_protection) ++ { ++ gcc_assert (xops[0] == stack_pointer_rtx); ++ xops[1] = GEN_INT (PROBE_INTERVAL - 8); ++ output_asm_insn ("str\txzr, [%0, %1]", xops); ++ } ++ else ++ output_asm_insn ("str\txzr, [%0]", xops); + + /* Test if TEST_ADDR == LAST_ADDR. */ + xops[1] = reg2; +@@ -3511,6 +3518,127 @@ aarch64_set_handled_components (sbitmap components) + cfun->machine->reg_is_wrapped_separately[regno] = true; + } + ++/* Allocate SIZE bytes of stack space using SCRATCH_REG as a scratch ++ register. */ ++ ++static void ++aarch64_allocate_and_probe_stack_space (int scratchreg, HOST_WIDE_INT size, ++ bool frame_related_p) ++{ ++ HOST_WIDE_INT probe_interval ++ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL); ++ HOST_WIDE_INT guard_size ++ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE); ++ HOST_WIDE_INT guard_used_by_caller = 1024; ++ ++ /* SIZE should be large enough to require probing here. ie, it ++ must be larger than GUARD_SIZE - GUARD_USED_BY_CALLER. ++ ++ We can allocate GUARD_SIZE - GUARD_USED_BY_CALLER as a single chunk ++ without any probing. */ ++ gcc_assert (size >= guard_size - guard_used_by_caller); ++ aarch64_sub_sp (scratchreg, guard_size - guard_used_by_caller, ++ frame_related_p); ++ HOST_WIDE_INT orig_size = size; ++ size -= (guard_size - guard_used_by_caller); ++ ++ HOST_WIDE_INT rounded_size = size & -probe_interval; ++ HOST_WIDE_INT residual = size - rounded_size; ++ ++ /* We can handle a small number of allocations/probes inline. Otherwise ++ punt to a loop. */ ++ if (rounded_size && rounded_size <= 4 * probe_interval) ++ { ++ /* We don't use aarch64_sub_sp here because we don't want to ++ repeatedly load SCRATCHREG. */ ++ rtx scratch_rtx = gen_rtx_REG (Pmode, scratchreg); ++ if (probe_interval > ARITH_FACTOR) ++ emit_move_insn (scratch_rtx, GEN_INT (-probe_interval)); ++ else ++ scratch_rtx = GEN_INT (-probe_interval); ++ ++ for (HOST_WIDE_INT i = 0; i < rounded_size; i += probe_interval) ++ { ++ rtx_insn *insn = emit_insn (gen_add2_insn (stack_pointer_rtx, ++ scratch_rtx)); ++ add_reg_note (insn, REG_STACK_CHECK, const0_rtx); ++ ++ if (probe_interval > ARITH_FACTOR) ++ { ++ RTX_FRAME_RELATED_P (insn) = 1; ++ rtx adj = plus_constant (Pmode, stack_pointer_rtx, -probe_interval); ++ add_reg_note (insn, REG_CFA_ADJUST_CFA, ++ gen_rtx_SET (stack_pointer_rtx, adj)); ++ } ++ ++ emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, ++ (probe_interval ++ - GET_MODE_SIZE (word_mode)))); ++ emit_insn (gen_blockage ()); ++ } ++ dump_stack_clash_frame_info (PROBE_INLINE, size != rounded_size); ++ } ++ else if (rounded_size) ++ { ++ /* Compute the ending address. */ ++ rtx temp = gen_rtx_REG (word_mode, scratchreg); ++ emit_move_insn (temp, GEN_INT (-rounded_size)); ++ rtx_insn *insn ++ = emit_insn (gen_add3_insn (temp, stack_pointer_rtx, temp)); ++ ++ /* For the initial allocation, we don't have a frame pointer ++ set up, so we always need CFI notes. If we're doing the ++ final allocation, then we may have a frame pointer, in which ++ case it is the CFA, otherwise we need CFI notes. ++ ++ We can determine which allocation we are doing by looking at ++ the temporary register. IP0 is the initial allocation, IP1 ++ is the final allocation. */ ++ if (scratchreg == IP0_REGNUM || !frame_pointer_needed) ++ { ++ /* We want the CFA independent of the stack pointer for the ++ duration of the loop. */ ++ add_reg_note (insn, REG_CFA_DEF_CFA, ++ plus_constant (Pmode, temp, ++ (rounded_size + (orig_size - size)))); ++ RTX_FRAME_RELATED_P (insn) = 1; ++ } ++ ++ /* This allocates and probes the stack. ++ ++ It also probes at a 4k interval regardless of the value of ++ PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL. */ ++ insn = emit_insn (gen_probe_stack_range (stack_pointer_rtx, ++ stack_pointer_rtx, temp)); ++ ++ /* Now reset the CFA register if needed. */ ++ if (scratchreg == IP0_REGNUM || !frame_pointer_needed) ++ { ++ add_reg_note (insn, REG_CFA_DEF_CFA, ++ plus_constant (Pmode, stack_pointer_rtx, ++ (rounded_size + (orig_size - size)))); ++ RTX_FRAME_RELATED_P (insn) = 1; ++ } ++ ++ emit_insn (gen_blockage ()); ++ dump_stack_clash_frame_info (PROBE_LOOP, size != rounded_size); ++ } ++ else ++ dump_stack_clash_frame_info (PROBE_INLINE, size != rounded_size); ++ ++ /* Handle any residuals. ++ Note that any residual must be probed. */ ++ if (residual) ++ { ++ aarch64_sub_sp (scratchreg, residual, frame_related_p); ++ add_reg_note (get_last_insn (), REG_STACK_CHECK, const0_rtx); ++ emit_stack_probe (plus_constant (Pmode, stack_pointer_rtx, ++ (residual - GET_MODE_SIZE (word_mode)))); ++ emit_insn (gen_blockage ()); ++ } ++ return; ++} ++ + /* AArch64 stack frames generated by this compiler look like: + + +-------------------------------+ +@@ -3592,7 +3720,54 @@ aarch64_expand_prologue (void) + aarch64_emit_probe_stack_range (get_stack_check_protect (), frame_size); + } + +- aarch64_sub_sp (IP0_REGNUM, initial_adjust, true); ++ /* We do not fully protect aarch64 against stack clash style attacks ++ as doing so would be prohibitively expensive with less utility over ++ time as newer compilers are deployed. ++ ++ We assume the guard is at least 64k. Furthermore, we assume that ++ the caller has not pushed the stack pointer more than 1k into ++ the guard. A caller that pushes the stack pointer than 1k into ++ the guard is considered invalid. ++ ++ Note that the caller's ability to push the stack pointer into the ++ guard is a function of the number and size of outgoing arguments and/or ++ dynamic stack allocations due to the mandatory save of the link register ++ in the caller's frame. ++ ++ With those assumptions the callee can allocate up to 63k of stack ++ space without probing. ++ ++ When probing is needed, we emit a probe at the start of the prologue ++ and every PARAM_STACK_CLASH_PROTECTION_PROBE_INTERVAL bytes thereafter. ++ ++ We have to track how much space has been allocated, but we do not ++ track stores into the stack as implicit probes except for the ++ fp/lr store. */ ++ HOST_WIDE_INT guard_size ++ = 1 << PARAM_VALUE (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE); ++ HOST_WIDE_INT guard_used_by_caller = 1024; ++ if (flag_stack_clash_protection) ++ { ++ if (frame_size == 0) ++ dump_stack_clash_frame_info (NO_PROBE_NO_FRAME, false); ++ else if (initial_adjust < guard_size - guard_used_by_caller ++ && final_adjust < guard_size - guard_used_by_caller) ++ dump_stack_clash_frame_info (NO_PROBE_SMALL_FRAME, true); ++ } ++ ++ /* In theory we should never have both an initial adjustment ++ and a callee save adjustment. Verify that is the case since the ++ code below does not handle it for -fstack-clash-protection. */ ++ gcc_assert (initial_adjust == 0 || callee_adjust == 0); ++ ++ /* Only probe if the initial adjustment is larger than the guard ++ less the amount of the guard reserved for use by the caller's ++ outgoing args. */ ++ if (flag_stack_clash_protection ++ && initial_adjust >= guard_size - guard_used_by_caller) ++ aarch64_allocate_and_probe_stack_space (IP0_REGNUM, initial_adjust, true); ++ else ++ aarch64_sub_sp (IP0_REGNUM, initial_adjust, true); + + if (callee_adjust != 0) + aarch64_push_regs (reg1, reg2, callee_adjust); +@@ -3613,7 +3788,30 @@ aarch64_expand_prologue (void) + callee_adjust != 0 || frame_pointer_needed); + aarch64_save_callee_saves (DFmode, callee_offset, V0_REGNUM, V31_REGNUM, + callee_adjust != 0 || frame_pointer_needed); +- aarch64_sub_sp (IP1_REGNUM, final_adjust, !frame_pointer_needed); ++ ++ /* We may need to probe the final adjustment as well. */ ++ if (flag_stack_clash_protection && final_adjust != 0) ++ { ++ /* First probe if the final adjustment is larger than the guard size ++ less the amount of the guard reserved for use by the caller's ++ outgoing args. */ ++ if (final_adjust >= guard_size - guard_used_by_caller) ++ aarch64_allocate_and_probe_stack_space (IP1_REGNUM, final_adjust, !frame_pointer_needed); ++ else ++ aarch64_sub_sp (IP1_REGNUM, final_adjust, !frame_pointer_needed); ++ ++ /* We must also probe if the final adjustment is larger than the guard ++ that is assumed used by the caller. This may be sub-optimal. */ ++ if (final_adjust >= guard_used_by_caller) ++ { ++ if (dump_file) ++ fprintf (dump_file, ++ "Stack clash aarch64 large outgoing arg, probing\n"); ++ emit_stack_probe (stack_pointer_rtx); ++ } ++ } ++ else ++ aarch64_sub_sp (IP1_REGNUM, final_adjust, !frame_pointer_needed); + } + + /* Return TRUE if we can use a simple_return insn. +@@ -3679,7 +3877,11 @@ aarch64_expand_epilogue (bool for_sibcall) + RTX_FRAME_RELATED_P (insn) = callee_adjust == 0; + } + else +- aarch64_add_sp (IP1_REGNUM, final_adjust, df_regs_ever_live_p (IP1_REGNUM)); ++ aarch64_add_sp (IP1_REGNUM, final_adjust, ++ /* A stack clash protection prologue may not have ++ left IP1_REGNUM in a usable state. */ ++ (flag_stack_clash_protection ++ || df_regs_ever_live_p (IP1_REGNUM))); + + aarch64_restore_callee_saves (DImode, callee_offset, R0_REGNUM, R30_REGNUM, + callee_adjust != 0, &cfi_ops); +@@ -3702,7 +3904,11 @@ aarch64_expand_epilogue (bool for_sibcall) + cfi_ops = NULL; + } + +- aarch64_add_sp (IP0_REGNUM, initial_adjust, df_regs_ever_live_p (IP0_REGNUM)); ++ /* A stack clash protection prologue may not have left IP0_REGNUM ++ in a usable state. */ ++ aarch64_add_sp (IP0_REGNUM, initial_adjust, ++ (flag_stack_clash_protection ++ || df_regs_ever_live_p (IP0_REGNUM))); + + if (cfi_ops) + { +@@ -8696,6 +8902,12 @@ aarch64_override_options_internal (struct gcc_options *opts) + opts->x_param_values, + global_options_set.x_param_values); + ++ /* We assume the guard page is 64k. */ ++ maybe_set_param_value (PARAM_STACK_CLASH_PROTECTION_GUARD_SIZE, ++ 16, ++ opts->x_param_values, ++ global_options_set.x_param_values); ++ + aarch64_override_options_after_change_1 (opts); + } + +@@ -14726,6 +14938,28 @@ aarch64_sched_can_speculate_insn (rtx_insn *insn) + } + } + ++/* It has been decided that to allow up to 1kb of outgoing argument ++ space to be allocated w/o probing. If more than 1kb of outgoing ++ argment space is allocated, then it must be probed and the last ++ probe must occur no more than 1kbyte away from the end of the ++ allocated space. ++ ++ This implies that the residual part of an alloca allocation may ++ need probing in cases where the generic code might not otherwise ++ think a probe is needed. ++ ++ This target hook returns TRUE when allocating RESIDUAL bytes of ++ alloca space requires an additional probe, otherwise FALSE is ++ returned. */ ++ ++static bool ++aarch64_stack_clash_protection_final_dynamic_probe (rtx residual) ++{ ++ return (residual == CONST0_RTX (Pmode) ++ || GET_CODE (residual) != CONST_INT ++ || INTVAL (residual) >= 1024); ++} ++ + /* Target-specific selftests. */ + + #if CHECKING_P +@@ -15154,6 +15388,10 @@ aarch64_libgcc_floating_mode_supported_p + #undef TARGET_CUSTOM_FUNCTION_DESCRIPTORS + #define TARGET_CUSTOM_FUNCTION_DESCRIPTORS 4 + ++#undef TARGET_STACK_CLASH_PROTECTION_FINAL_DYNAMIC_PROBE ++#define TARGET_STACK_CLASH_PROTECTION_FINAL_DYNAMIC_PROBE \ ++ aarch64_stack_clash_protection_final_dynamic_probe ++ + #if CHECKING_P + #undef TARGET_RUN_TARGET_SELFTESTS + #define TARGET_RUN_TARGET_SELFTESTS selftest::aarch64_run_selftests +--- gcc/config/aarch64/aarch64.md ++++ gcc/config/aarch64/aarch64.md +@@ -5413,7 +5413,7 @@ + ) + + (define_insn "probe_stack_range" +- [(set (match_operand:DI 0 "register_operand" "=r") ++ [(set (match_operand:DI 0 "register_operand" "=rk") + (unspec_volatile:DI [(match_operand:DI 1 "register_operand" "0") + (match_operand:DI 2 "register_operand" "r")] + UNSPECV_PROBE_STACK_RANGE))] +--- gcc/testsuite/gcc.dg/stack-check-16.c ++++ gcc/testsuite/gcc.dg/stack-check-16.c +@@ -0,0 +1,2017 @@ ++/* { dg-do compile } */ ++/* { dg-options "-fstack-clash-protection -w" } */ ++/* { dg-require-effective-target supports_stack_clash_protection } */ ++ ++int printf (const char *, ...); ++void blah (char *space) { } ++ ++__attribute__ ((optimize ("-O0"))) ++int do_test (void) ++{ ++ blah (alloca (10)); ++ mtrace (); ++ printf ( ++"%1$s" "%2$s" "%3$s" "%4$s" "%5$s" "%6$s" "%7$s" "%8$s" "%9$s" "%10$s" ++"%11$s" "%12$s" "%13$s" "%14$s" "%15$s" "%16$s" "%17$s" "%18$s" "%19$s" "%20$s" ++"%21$s" "%22$s" "%23$s" "%24$s" "%25$s" "%26$s" "%27$s" "%28$s" "%29$s" "%30$s" ++"%31$s" "%32$s" "%33$s" "%34$s" "%35$s" "%36$s" "%37$s" "%38$s" "%39$s" "%40$s" ++"%41$s" "%42$s" "%43$s" "%44$s" "%45$s" "%46$s" "%47$s" "%48$s" "%49$s" "%50$s" ++"%51$s" "%52$s" "%53$s" "%54$s" "%55$s" "%56$s" "%57$s" "%58$s" "%59$s" "%60$s" ++"%61$s" "%62$s" "%63$s" "%64$s" "%65$s" "%66$s" "%67$s" "%68$s" "%69$s" "%70$s" ++"%71$s" "%72$s" "%73$s" "%74$s" "%75$s" "%76$s" "%77$s" "%78$s" "%79$s" "%80$s" ++"%81$s" "%82$s" "%83$s" "%84$s" "%85$s" "%86$s" "%87$s" "%88$s" "%89$s" "%90$s" ++"%91$s" "%92$s" "%93$s" "%94$s" "%95$s" "%96$s" "%97$s" "%98$s" "%99$s" "%100$s" ++"%101$s" "%102$s" "%103$s" "%104$s" "%105$s" "%106$s" "%107$s" "%108$s" "%109$s" "%110$s" ++"%111$s" "%112$s" "%113$s" "%114$s" "%115$s" "%116$s" "%117$s" "%118$s" "%119$s" "%120$s" ++"%121$s" "%122$s" "%123$s" "%124$s" "%125$s" "%126$s" "%127$s" "%128$s" "%129$s" "%130$s" ++"%131$s" "%132$s" "%133$s" "%134$s" "%135$s" "%136$s" "%137$s" "%138$s" "%139$s" "%140$s" ++"%141$s" "%142$s" "%143$s" "%144$s" "%145$s" "%146$s" "%147$s" "%148$s" "%149$s" "%150$s" ++"%151$s" "%152$s" "%153$s" "%154$s" "%155$s" "%156$s" "%157$s" "%158$s" "%159$s" "%160$s" ++"%161$s" "%162$s" "%163$s" "%164$s" "%165$s" "%166$s" "%167$s" "%168$s" "%169$s" "%170$s" ++"%171$s" "%172$s" "%173$s" "%174$s" "%175$s" "%176$s" "%177$s" "%178$s" "%179$s" "%180$s" ++"%181$s" "%182$s" "%183$s" "%184$s" "%185$s" "%186$s" "%187$s" "%188$s" "%189$s" "%190$s" ++"%191$s" "%192$s" "%193$s" "%194$s" "%195$s" "%196$s" "%197$s" "%198$s" "%199$s" "%200$s" ++"%201$s" "%202$s" "%203$s" "%204$s" "%205$s" "%206$s" "%207$s" "%208$s" "%209$s" "%210$s" ++"%211$s" "%212$s" "%213$s" "%214$s" "%215$s" "%216$s" "%217$s" "%218$s" "%219$s" "%220$s" ++"%221$s" "%222$s" "%223$s" "%224$s" "%225$s" "%226$s" "%227$s" "%228$s" "%229$s" "%230$s" ++"%231$s" "%232$s" "%233$s" "%234$s" "%235$s" "%236$s" "%237$s" "%238$s" "%239$s" "%240$s" ++"%241$s" "%242$s" "%243$s" "%244$s" "%245$s" "%246$s" "%247$s" "%248$s" "%249$s" "%250$s" ++"%251$s" "%252$s" "%253$s" "%254$s" "%255$s" "%256$s" "%257$s" "%258$s" "%259$s" "%260$s" ++"%261$s" "%262$s" "%263$s" "%264$s" "%265$s" "%266$s" "%267$s" "%268$s" "%269$s" "%270$s" ++"%271$s" "%272$s" "%273$s" "%274$s" "%275$s" "%276$s" "%277$s" "%278$s" "%279$s" "%280$s" ++"%281$s" "%282$s" "%283$s" "%284$s" "%285$s" "%286$s" "%287$s" "%288$s" "%289$s" "%290$s" ++"%291$s" "%292$s" "%293$s" "%294$s" "%295$s" "%296$s" "%297$s" "%298$s" "%299$s" "%300$s" ++"%301$s" "%302$s" "%303$s" "%304$s" "%305$s" "%306$s" "%307$s" "%308$s" "%309$s" "%310$s" ++"%311$s" "%312$s" "%313$s" "%314$s" "%315$s" "%316$s" "%317$s" "%318$s" "%319$s" "%320$s" ++"%321$s" "%322$s" "%323$s" "%324$s" "%325$s" "%326$s" "%327$s" "%328$s" "%329$s" "%330$s" ++"%331$s" "%332$s" "%333$s" "%334$s" "%335$s" "%336$s" "%337$s" "%338$s" "%339$s" "%340$s" ++"%341$s" "%342$s" "%343$s" "%344$s" "%345$s" "%346$s" "%347$s" "%348$s" "%349$s" "%350$s" ++"%351$s" "%352$s" "%353$s" "%354$s" "%355$s" "%356$s" "%357$s" "%358$s" "%359$s" "%360$s" ++"%361$s" "%362$s" "%363$s" "%364$s" "%365$s" "%366$s" "%367$s" "%368$s" "%369$s" "%370$s" ++"%371$s" "%372$s" "%373$s" "%374$s" "%375$s" "%376$s" "%377$s" "%378$s" "%379$s" "%380$s" ++"%381$s" "%382$s" "%383$s" "%384$s" "%385$s" "%386$s" "%387$s" "%388$s" "%389$s" "%390$s" ++"%391$s" "%392$s" "%393$s" "%394$s" "%395$s" "%396$s" "%397$s" "%398$s" "%399$s" "%400$s" ++"%401$s" "%402$s" "%403$s" "%404$s" "%405$s" "%406$s" "%407$s" "%408$s" "%409$s" "%410$s" ++"%411$s" "%412$s" "%413$s" "%414$s" "%415$s" "%416$s" "%417$s" "%418$s" "%419$s" "%420$s" ++"%421$s" "%422$s" "%423$s" "%424$s" "%425$s" "%426$s" "%427$s" "%428$s" "%429$s" "%430$s" ++"%431$s" "%432$s" "%433$s" "%434$s" "%435$s" "%436$s" "%437$s" "%438$s" "%439$s" "%440$s" ++"%441$s" "%442$s" "%443$s" "%444$s" "%445$s" "%446$s" "%447$s" "%448$s" "%449$s" "%450$s" ++"%451$s" "%452$s" "%453$s" "%454$s" "%455$s" "%456$s" "%457$s" "%458$s" "%459$s" "%460$s" ++"%461$s" "%462$s" "%463$s" "%464$s" "%465$s" "%466$s" "%467$s" "%468$s" "%469$s" "%470$s" ++"%471$s" "%472$s" "%473$s" "%474$s" "%475$s" "%476$s" "%477$s" "%478$s" "%479$s" "%480$s" ++"%481$s" "%482$s" "%483$s" "%484$s" "%485$s" "%486$s" "%487$s" "%488$s" "%489$s" "%490$s" ++"%491$s" "%492$s" "%493$s" "%494$s" "%495$s" "%496$s" "%497$s" "%498$s" "%499$s" "%500$s" ++"%501$s" "%502$s" "%503$s" "%504$s" "%505$s" "%506$s" "%507$s" "%508$s" "%509$s" "%510$s" ++"%511$s" "%512$s" "%513$s" "%514$s" "%515$s" "%516$s" "%517$s" "%518$s" "%519$s" "%520$s" ++"%521$s" "%522$s" "%523$s" "%524$s" "%525$s" "%526$s" "%527$s" "%528$s" "%529$s" "%530$s" ++"%531$s" "%532$s" "%533$s" "%534$s" "%535$s" "%536$s" "%537$s" "%538$s" "%539$s" "%540$s" ++"%541$s" "%542$s" "%543$s" "%544$s" "%545$s" "%546$s" "%547$s" "%548$s" "%549$s" "%550$s" ++"%551$s" "%552$s" "%553$s" "%554$s" "%555$s" "%556$s" "%557$s" "%558$s" "%559$s" "%560$s" ++"%561$s" "%562$s" "%563$s" "%564$s" "%565$s" "%566$s" "%567$s" "%568$s" "%569$s" "%570$s" ++"%571$s" "%572$s" "%573$s" "%574$s" "%575$s" "%576$s" "%577$s" "%578$s" "%579$s" "%580$s" ++"%581$s" "%582$s" "%583$s" "%584$s" "%585$s" "%586$s" "%587$s" "%588$s" "%589$s" "%590$s" ++"%591$s" "%592$s" "%593$s" "%594$s" "%595$s" "%596$s" "%597$s" "%598$s" "%599$s" "%600$s" ++"%601$s" "%602$s" "%603$s" "%604$s" "%605$s" "%606$s" "%607$s" "%608$s" "%609$s" "%610$s" ++"%611$s" "%612$s" "%613$s" "%614$s" "%615$s" "%616$s" "%617$s" "%618$s" "%619$s" "%620$s" ++"%621$s" "%622$s" "%623$s" "%624$s" "%625$s" "%626$s" "%627$s" "%628$s" "%629$s" "%630$s" ++"%631$s" "%632$s" "%633$s" "%634$s" "%635$s" "%636$s" "%637$s" "%638$s" "%639$s" "%640$s" ++"%641$s" "%642$s" "%643$s" "%644$s" "%645$s" "%646$s" "%647$s" "%648$s" "%649$s" "%650$s" ++"%651$s" "%652$s" "%653$s" "%654$s" "%655$s" "%656$s" "%657$s" "%658$s" "%659$s" "%660$s" ++"%661$s" "%662$s" "%663$s" "%664$s" "%665$s" "%666$s" "%667$s" "%668$s" "%669$s" "%670$s" ++"%671$s" "%672$s" "%673$s" "%674$s" "%675$s" "%676$s" "%677$s" "%678$s" "%679$s" "%680$s" ++"%681$s" "%682$s" "%683$s" "%684$s" "%685$s" "%686$s" "%687$s" "%688$s" "%689$s" "%690$s" ++"%691$s" "%692$s" "%693$s" "%694$s" "%695$s" "%696$s" "%697$s" "%698$s" "%699$s" "%700$s" ++"%701$s" "%702$s" "%703$s" "%704$s" "%705$s" "%706$s" "%707$s" "%708$s" "%709$s" "%710$s" ++"%711$s" "%712$s" "%713$s" "%714$s" "%715$s" "%716$s" "%717$s" "%718$s" "%719$s" "%720$s" ++"%721$s" "%722$s" "%723$s" "%724$s" "%725$s" "%726$s" "%727$s" "%728$s" "%729$s" "%730$s" ++"%731$s" "%732$s" "%733$s" "%734$s" "%735$s" "%736$s" "%737$s" "%738$s" "%739$s" "%740$s" ++"%741$s" "%742$s" "%743$s" "%744$s" "%745$s" "%746$s" "%747$s" "%748$s" "%749$s" "%750$s" ++"%751$s" "%752$s" "%753$s" "%754$s" "%755$s" "%756$s" "%757$s" "%758$s" "%759$s" "%760$s" ++"%761$s" "%762$s" "%763$s" "%764$s" "%765$s" "%766$s" "%767$s" "%768$s" "%769$s" "%770$s" ++"%771$s" "%772$s" "%773$s" "%774$s" "%775$s" "%776$s" "%777$s" "%778$s" "%779$s" "%780$s" ++"%781$s" "%782$s" "%783$s" "%784$s" "%785$s" "%786$s" "%787$s" "%788$s" "%789$s" "%790$s" ++"%791$s" "%792$s" "%793$s" "%794$s" "%795$s" "%796$s" "%797$s" "%798$s" "%799$s" "%800$s" ++"%801$s" "%802$s" "%803$s" "%804$s" "%805$s" "%806$s" "%807$s" "%808$s" "%809$s" "%810$s" ++"%811$s" "%812$s" "%813$s" "%814$s" "%815$s" "%816$s" "%817$s" "%818$s" "%819$s" "%820$s" ++"%821$s" "%822$s" "%823$s" "%824$s" "%825$s" "%826$s" "%827$s" "%828$s" "%829$s" "%830$s" ++"%831$s" "%832$s" "%833$s" "%834$s" "%835$s" "%836$s" "%837$s" "%838$s" "%839$s" "%840$s" ++"%841$s" "%842$s" "%843$s" "%844$s" "%845$s" "%846$s" "%847$s" "%848$s" "%849$s" "%850$s" ++"%851$s" "%852$s" "%853$s" "%854$s" "%855$s" "%856$s" "%857$s" "%858$s" "%859$s" "%860$s" ++"%861$s" "%862$s" "%863$s" "%864$s" "%865$s" "%866$s" "%867$s" "%868$s" "%869$s" "%870$s" ++"%871$s" "%872$s" "%873$s" "%874$s" "%875$s" "%876$s" "%877$s" "%878$s" "%879$s" "%880$s" ++"%881$s" "%882$s" "%883$s" "%884$s" "%885$s" "%886$s" "%887$s" "%888$s" "%889$s" "%890$s" ++"%891$s" "%892$s" "%893$s" "%894$s" "%895$s" "%896$s" "%897$s" "%898$s" "%899$s" "%900$s" ++"%901$s" "%902$s" "%903$s" "%904$s" "%905$s" "%906$s" "%907$s" "%908$s" "%909$s" "%910$s" ++"%911$s" "%912$s" "%913$s" "%914$s" "%915$s" "%916$s" "%917$s" "%918$s" "%919$s" "%920$s" ++"%921$s" "%922$s" "%923$s" "%924$s" "%925$s" "%926$s" "%927$s" "%928$s" "%929$s" "%930$s" ++"%931$s" "%932$s" "%933$s" "%934$s" "%935$s" "%936$s" "%937$s" "%938$s" "%939$s" "%940$s" ++"%941$s" "%942$s" "%943$s" "%944$s" "%945$s" "%946$s" "%947$s" "%948$s" "%949$s" "%950$s" ++"%951$s" "%952$s" "%953$s" "%954$s" "%955$s" "%956$s" "%957$s" "%958$s" "%959$s" "%960$s" ++"%961$s" "%962$s" "%963$s" "%964$s" "%965$s" "%966$s" "%967$s" "%968$s" "%969$s" "%970$s" ++"%971$s" "%972$s" "%973$s" "%974$s" "%975$s" "%976$s" "%977$s" "%978$s" "%979$s" "%980$s" ++"%981$s" "%982$s" "%983$s" "%984$s" "%985$s" "%986$s" "%987$s" "%988$s" "%989$s" "%990$s" ++"%991$s" "%992$s" "%993$s" "%994$s" "%995$s" "%996$s" "%997$s" "%998$s" "%999$s" "%1000$s" ++"%1001$s" "%1002$s" "%1003$s" "%1004$s" "%1005$s" "%1006$s" "%1007$s" "%1008$s" "%1009$s" "%1010$s" ++"%1011$s" "%1012$s" "%1013$s" "%1014$s" "%1015$s" "%1016$s" "%1017$s" "%1018$s" "%1019$s" "%1020$s" ++"%1021$s" "%1022$s" "%1023$s" "%1024$s" "%1025$s" "%1026$s" "%1027$s" "%1028$s" "%1029$s" "%1030$s" ++"%1031$s" "%1032$s" "%1033$s" "%1034$s" "%1035$s" "%1036$s" "%1037$s" "%1038$s" "%1039$s" "%1040$s" ++"%1041$s" "%1042$s" "%1043$s" "%1044$s" "%1045$s" "%1046$s" "%1047$s" "%1048$s" "%1049$s" "%1050$s" ++"%1051$s" "%1052$s" "%1053$s" "%1054$s" "%1055$s" "%1056$s" "%1057$s" "%1058$s" "%1059$s" "%1060$s" ++"%1061$s" "%1062$s" "%1063$s" "%1064$s" "%1065$s" "%1066$s" "%1067$s" "%1068$s" "%1069$s" "%1070$s" ++"%1071$s" "%1072$s" "%1073$s" "%1074$s" "%1075$s" "%1076$s" "%1077$s" "%1078$s" "%1079$s" "%1080$s" ++"%1081$s" "%1082$s" "%1083$s" "%1084$s" "%1085$s" "%1086$s" "%1087$s" "%1088$s" "%1089$s" "%1090$s" ++"%1091$s" "%1092$s" "%1093$s" "%1094$s" "%1095$s" "%1096$s" "%1097$s" "%1098$s" "%1099$s" "%1100$s" ++"%1101$s" "%1102$s" "%1103$s" "%1104$s" "%1105$s" "%1106$s" "%1107$s" "%1108$s" "%1109$s" "%1110$s" ++"%1111$s" "%1112$s" "%1113$s" "%1114$s" "%1115$s" "%1116$s" "%1117$s" "%1118$s" "%1119$s" "%1120$s" ++"%1121$s" "%1122$s" "%1123$s" "%1124$s" "%1125$s" "%1126$s" "%1127$s" "%1128$s" "%1129$s" "%1130$s" ++"%1131$s" "%1132$s" "%1133$s" "%1134$s" "%1135$s" "%1136$s" "%1137$s" "%1138$s" "%1139$s" "%1140$s" ++"%1141$s" "%1142$s" "%1143$s" "%1144$s" "%1145$s" "%1146$s" "%1147$s" "%1148$s" "%1149$s" "%1150$s" ++"%1151$s" "%1152$s" "%1153$s" "%1154$s" "%1155$s" "%1156$s" "%1157$s" "%1158$s" "%1159$s" "%1160$s" ++"%1161$s" "%1162$s" "%1163$s" "%1164$s" "%1165$s" "%1166$s" "%1167$s" "%1168$s" "%1169$s" "%1170$s" ++"%1171$s" "%1172$s" "%1173$s" "%1174$s" "%1175$s" "%1176$s" "%1177$s" "%1178$s" "%1179$s" "%1180$s" ++"%1181$s" "%1182$s" "%1183$s" "%1184$s" "%1185$s" "%1186$s" "%1187$s" "%1188$s" "%1189$s" "%1190$s" ++"%1191$s" "%1192$s" "%1193$s" "%1194$s" "%1195$s" "%1196$s" "%1197$s" "%1198$s" "%1199$s" "%1200$s" ++"%1201$s" "%1202$s" "%1203$s" "%1204$s" "%1205$s" "%1206$s" "%1207$s" "%1208$s" "%1209$s" "%1210$s" ++"%1211$s" "%1212$s" "%1213$s" "%1214$s" "%1215$s" "%1216$s" "%1217$s" "%1218$s" "%1219$s" "%1220$s" ++"%1221$s" "%1222$s" "%1223$s" "%1224$s" "%1225$s" "%1226$s" "%1227$s" "%1228$s" "%1229$s" "%1230$s" ++"%1231$s" "%1232$s" "%1233$s" "%1234$s" "%1235$s" "%1236$s" "%1237$s" "%1238$s" "%1239$s" "%1240$s" ++"%1241$s" "%1242$s" "%1243$s" "%1244$s" "%1245$s" "%1246$s" "%1247$s" "%1248$s" "%1249$s" "%1250$s" ++"%1251$s" "%1252$s" "%1253$s" "%1254$s" "%1255$s" "%1256$s" "%1257$s" "%1258$s" "%1259$s" "%1260$s" ++"%1261$s" "%1262$s" "%1263$s" "%1264$s" "%1265$s" "%1266$s" "%1267$s" "%1268$s" "%1269$s" "%1270$s" ++"%1271$s" "%1272$s" "%1273$s" "%1274$s" "%1275$s" "%1276$s" "%1277$s" "%1278$s" "%1279$s" "%1280$s" ++"%1281$s" "%1282$s" "%1283$s" "%1284$s" "%1285$s" "%1286$s" "%1287$s" "%1288$s" "%1289$s" "%1290$s" ++"%1291$s" "%1292$s" "%1293$s" "%1294$s" "%1295$s" "%1296$s" "%1297$s" "%1298$s" "%1299$s" "%1300$s" ++"%1301$s" "%1302$s" "%1303$s" "%1304$s" "%1305$s" "%1306$s" "%1307$s" "%1308$s" "%1309$s" "%1310$s" ++"%1311$s" "%1312$s" "%1313$s" "%1314$s" "%1315$s" "%1316$s" "%1317$s" "%1318$s" "%1319$s" "%1320$s" ++"%1321$s" "%1322$s" "%1323$s" "%1324$s" "%1325$s" "%1326$s" "%1327$s" "%1328$s" "%1329$s" "%1330$s" ++"%1331$s" "%1332$s" "%1333$s" "%1334$s" "%1335$s" "%1336$s" "%1337$s" "%1338$s" "%1339$s" "%1340$s" ++"%1341$s" "%1342$s" "%1343$s" "%1344$s" "%1345$s" "%1346$s" "%1347$s" "%1348$s" "%1349$s" "%1350$s" ++"%1351$s" "%1352$s" "%1353$s" "%1354$s" "%1355$s" "%1356$s" "%1357$s" "%1358$s" "%1359$s" "%1360$s" ++"%1361$s" "%1362$s" "%1363$s" "%1364$s" "%1365$s" "%1366$s" "%1367$s" "%1368$s" "%1369$s" "%1370$s" ++"%1371$s" "%1372$s" "%1373$s" "%1374$s" "%1375$s" "%1376$s" "%1377$s" "%1378$s" "%1379$s" "%1380$s" ++"%1381$s" "%1382$s" "%1383$s" "%1384$s" "%1385$s" "%1386$s" "%1387$s" "%1388$s" "%1389$s" "%1390$s" ++"%1391$s" "%1392$s" "%1393$s" "%1394$s" "%1395$s" "%1396$s" "%1397$s" "%1398$s" "%1399$s" "%1400$s" ++"%1401$s" "%1402$s" "%1403$s" "%1404$s" "%1405$s" "%1406$s" "%1407$s" "%1408$s" "%1409$s" "%1410$s" ++"%1411$s" "%1412$s" "%1413$s" "%1414$s" "%1415$s" "%1416$s" "%1417$s" "%1418$s" "%1419$s" "%1420$s" ++"%1421$s" "%1422$s" "%1423$s" "%1424$s" "%1425$s" "%1426$s" "%1427$s" "%1428$s" "%1429$s" "%1430$s" ++"%1431$s" "%1432$s" "%1433$s" "%1434$s" "%1435$s" "%1436$s" "%1437$s" "%1438$s" "%1439$s" "%1440$s" ++"%1441$s" "%1442$s" "%1443$s" "%1444$s" "%1445$s" "%1446$s" "%1447$s" "%1448$s" "%1449$s" "%1450$s" ++"%1451$s" "%1452$s" "%1453$s" "%1454$s" "%1455$s" "%1456$s" "%1457$s" "%1458$s" "%1459$s" "%1460$s" ++"%1461$s" "%1462$s" "%1463$s" "%1464$s" "%1465$s" "%1466$s" "%1467$s" "%1468$s" "%1469$s" "%1470$s" ++"%1471$s" "%1472$s" "%1473$s" "%1474$s" "%1475$s" "%1476$s" "%1477$s" "%1478$s" "%1479$s" "%1480$s" ++"%1481$s" "%1482$s" "%1483$s" "%1484$s" "%1485$s" "%1486$s" "%1487$s" "%1488$s" "%1489$s" "%1490$s" ++"%1491$s" "%1492$s" "%1493$s" "%1494$s" "%1495$s" "%1496$s" "%1497$s" "%1498$s" "%1499$s" "%1500$s" ++"%1501$s" "%1502$s" "%1503$s" "%1504$s" "%1505$s" "%1506$s" "%1507$s" "%1508$s" "%1509$s" "%1510$s" ++"%1511$s" "%1512$s" "%1513$s" "%1514$s" "%1515$s" "%1516$s" "%1517$s" "%1518$s" "%1519$s" "%1520$s" ++"%1521$s" "%1522$s" "%1523$s" "%1524$s" "%1525$s" "%1526$s" "%1527$s" "%1528$s" "%1529$s" "%1530$s" ++"%1531$s" "%1532$s" "%1533$s" "%1534$s" "%1535$s" "%1536$s" "%1537$s" "%1538$s" "%1539$s" "%1540$s" ++"%1541$s" "%1542$s" "%1543$s" "%1544$s" "%1545$s" "%1546$s" "%1547$s" "%1548$s" "%1549$s" "%1550$s" ++"%1551$s" "%1552$s" "%1553$s" "%1554$s" "%1555$s" "%1556$s" "%1557$s" "%1558$s" "%1559$s" "%1560$s" ++"%1561$s" "%1562$s" "%1563$s" "%1564$s" "%1565$s" "%1566$s" "%1567$s" "%1568$s" "%1569$s" "%1570$s" ++"%1571$s" "%1572$s" "%1573$s" "%1574$s" "%1575$s" "%1576$s" "%1577$s" "%1578$s" "%1579$s" "%1580$s" ++"%1581$s" "%1582$s" "%1583$s" "%1584$s" "%1585$s" "%1586$s" "%1587$s" "%1588$s" "%1589$s" "%1590$s" ++"%1591$s" "%1592$s" "%1593$s" "%1594$s" "%1595$s" "%1596$s" "%1597$s" "%1598$s" "%1599$s" "%1600$s" ++"%1601$s" "%1602$s" "%1603$s" "%1604$s" "%1605$s" "%1606$s" "%1607$s" "%1608$s" "%1609$s" "%1610$s" ++"%1611$s" "%1612$s" "%1613$s" "%1614$s" "%1615$s" "%1616$s" "%1617$s" "%1618$s" "%1619$s" "%1620$s" ++"%1621$s" "%1622$s" "%1623$s" "%1624$s" "%1625$s" "%1626$s" "%1627$s" "%1628$s" "%1629$s" "%1630$s" ++"%1631$s" "%1632$s" "%1633$s" "%1634$s" "%1635$s" "%1636$s" "%1637$s" "%1638$s" "%1639$s" "%1640$s" ++"%1641$s" "%1642$s" "%1643$s" "%1644$s" "%1645$s" "%1646$s" "%1647$s" "%1648$s" "%1649$s" "%1650$s" ++"%1651$s" "%1652$s" "%1653$s" "%1654$s" "%1655$s" "%1656$s" "%1657$s" "%1658$s" "%1659$s" "%1660$s" ++"%1661$s" "%1662$s" "%1663$s" "%1664$s" "%1665$s" "%1666$s" "%1667$s" "%1668$s" "%1669$s" "%1670$s" ++"%1671$s" "%1672$s" "%1673$s" "%1674$s" "%1675$s" "%1676$s" "%1677$s" "%1678$s" "%1679$s" "%1680$s" ++"%1681$s" "%1682$s" "%1683$s" "%1684$s" "%1685$s" "%1686$s" "%1687$s" "%1688$s" "%1689$s" "%1690$s" ++"%1691$s" "%1692$s" "%1693$s" "%1694$s" "%1695$s" "%1696$s" "%1697$s" "%1698$s" "%1699$s" "%1700$s" ++"%1701$s" "%1702$s" "%1703$s" "%1704$s" "%1705$s" "%1706$s" "%1707$s" "%1708$s" "%1709$s" "%1710$s" ++"%1711$s" "%1712$s" "%1713$s" "%1714$s" "%1715$s" "%1716$s" "%1717$s" "%1718$s" "%1719$s" "%1720$s" ++"%1721$s" "%1722$s" "%1723$s" "%1724$s" "%1725$s" "%1726$s" "%1727$s" "%1728$s" "%1729$s" "%1730$s" ++"%1731$s" "%1732$s" "%1733$s" "%1734$s" "%1735$s" "%1736$s" "%1737$s" "%1738$s" "%1739$s" "%1740$s" ++"%1741$s" "%1742$s" "%1743$s" "%1744$s" "%1745$s" "%1746$s" "%1747$s" "%1748$s" "%1749$s" "%1750$s" ++"%1751$s" "%1752$s" "%1753$s" "%1754$s" "%1755$s" "%1756$s" "%1757$s" "%1758$s" "%1759$s" "%1760$s" ++"%1761$s" "%1762$s" "%1763$s" "%1764$s" "%1765$s" "%1766$s" "%1767$s" "%1768$s" "%1769$s" "%1770$s" ++"%1771$s" "%1772$s" "%1773$s" "%1774$s" "%1775$s" "%1776$s" "%1777$s" "%1778$s" "%1779$s" "%1780$s" ++"%1781$s" "%1782$s" "%1783$s" "%1784$s" "%1785$s" "%1786$s" "%1787$s" "%1788$s" "%1789$s" "%1790$s" ++"%1791$s" "%1792$s" "%1793$s" "%1794$s" "%1795$s" "%1796$s" "%1797$s" "%1798$s" "%1799$s" "%1800$s" ++"%1801$s" "%1802$s" "%1803$s" "%1804$s" "%1805$s" "%1806$s" "%1807$s" "%1808$s" "%1809$s" "%1810$s" ++"%1811$s" "%1812$s" "%1813$s" "%1814$s" "%1815$s" "%1816$s" "%1817$s" "%1818$s" "%1819$s" "%1820$s" ++"%1821$s" "%1822$s" "%1823$s" "%1824$s" "%1825$s" "%1826$s" "%1827$s" "%1828$s" "%1829$s" "%1830$s" ++"%1831$s" "%1832$s" "%1833$s" "%1834$s" "%1835$s" "%1836$s" "%1837$s" "%1838$s" "%1839$s" "%1840$s" ++"%1841$s" "%1842$s" "%1843$s" "%1844$s" "%1845$s" "%1846$s" "%1847$s" "%1848$s" "%1849$s" "%1850$s" ++"%1851$s" "%1852$s" "%1853$s" "%1854$s" "%1855$s" "%1856$s" "%1857$s" "%1858$s" "%1859$s" "%1860$s" ++"%1861$s" "%1862$s" "%1863$s" "%1864$s" "%1865$s" "%1866$s" "%1867$s" "%1868$s" "%1869$s" "%1870$s" ++"%1871$s" "%1872$s" "%1873$s" "%1874$s" "%1875$s" "%1876$s" "%1877$s" "%1878$s" "%1879$s" "%1880$s" ++"%1881$s" "%1882$s" "%1883$s" "%1884$s" "%1885$s" "%1886$s" "%1887$s" "%1888$s" "%1889$s" "%1890$s" ++"%1891$s" "%1892$s" "%1893$s" "%1894$s" "%1895$s" "%1896$s" "%1897$s" "%1898$s" "%1899$s" "%1900$s" ++"%1901$s" "%1902$s" "%1903$s" "%1904$s" "%1905$s" "%1906$s" "%1907$s" "%1908$s" "%1909$s" "%1910$s" ++"%1911$s" "%1912$s" "%1913$s" "%1914$s" "%1915$s" "%1916$s" "%1917$s" "%1918$s" "%1919$s" "%1920$s" ++"%1921$s" "%1922$s" "%1923$s" "%1924$s" "%1925$s" "%1926$s" "%1927$s" "%1928$s" "%1929$s" "%1930$s" ++"%1931$s" "%1932$s" "%1933$s" "%1934$s" "%1935$s" "%1936$s" "%1937$s" "%1938$s" "%1939$s" "%1940$s" ++"%1941$s" "%1942$s" "%1943$s" "%1944$s" "%1945$s" "%1946$s" "%1947$s" "%1948$s" "%1949$s" "%1950$s" ++"%1951$s" "%1952$s" "%1953$s" "%1954$s" "%1955$s" "%1956$s" "%1957$s" "%1958$s" "%1959$s" "%1960$s" ++"%1961$s" "%1962$s" "%1963$s" "%1964$s" "%1965$s" "%1966$s" "%1967$s" "%1968$s" "%1969$s" "%1970$s" ++"%1971$s" "%1972$s" "%1973$s" "%1974$s" "%1975$s" "%1976$s" "%1977$s" "%1978$s" "%1979$s" "%1980$s" ++"%1981$s" "%1982$s" "%1983$s" "%1984$s" "%1985$s" "%1986$s" "%1987$s" "%1988$s" "%1989$s" "%1990$s" ++"%1991$s" "%1992$s" "%1993$s" "%1994$s" "%1995$s" "%1996$s" "%1997$s" "%1998$s" "%1999$s" "%2000$s" ++"%2001$s" "%2002$s" "%2003$s" "%2004$s" "%2005$s" "%2006$s" "%2007$s" "%2008$s" "%2009$s" "%2010$s" ++"%2011$s" "%2012$s" "%2013$s" "%2014$s" "%2015$s" "%2016$s" "%2017$s" "%2018$s" "%2019$s" "%2020$s" ++"%2021$s" "%2022$s" "%2023$s" "%2024$s" "%2025$s" "%2026$s" "%2027$s" "%2028$s" "%2029$s" "%2030$s" ++"%2031$s" "%2032$s" "%2033$s" "%2034$s" "%2035$s" "%2036$s" "%2037$s" "%2038$s" "%2039$s" "%2040$s" ++"%2041$s" "%2042$s" "%2043$s" "%2044$s" "%2045$s" "%2046$s" "%2047$s" "%2048$s" "%2049$s" "%2050$s" ++"%2051$s" "%2052$s" "%2053$s" "%2054$s" "%2055$s" "%2056$s" "%2057$s" "%2058$s" "%2059$s" "%2060$s" ++"%2061$s" "%2062$s" "%2063$s" "%2064$s" "%2065$s" "%2066$s" "%2067$s" "%2068$s" "%2069$s" "%2070$s" ++"%2071$s" "%2072$s" "%2073$s" "%2074$s" "%2075$s" "%2076$s" "%2077$s" "%2078$s" "%2079$s" "%2080$s" ++"%2081$s" "%2082$s" "%2083$s" "%2084$s" "%2085$s" "%2086$s" "%2087$s" "%2088$s" "%2089$s" "%2090$s" ++"%2091$s" "%2092$s" "%2093$s" "%2094$s" "%2095$s" "%2096$s" "%2097$s" "%2098$s" "%2099$s" "%2100$s" ++"%2101$s" "%2102$s" "%2103$s" "%2104$s" "%2105$s" "%2106$s" "%2107$s" "%2108$s" "%2109$s" "%2110$s" ++"%2111$s" "%2112$s" "%2113$s" "%2114$s" "%2115$s" "%2116$s" "%2117$s" "%2118$s" "%2119$s" "%2120$s" ++"%2121$s" "%2122$s" "%2123$s" "%2124$s" "%2125$s" "%2126$s" "%2127$s" "%2128$s" "%2129$s" "%2130$s" ++"%2131$s" "%2132$s" "%2133$s" "%2134$s" "%2135$s" "%2136$s" "%2137$s" "%2138$s" "%2139$s" "%2140$s" ++"%2141$s" "%2142$s" "%2143$s" "%2144$s" "%2145$s" "%2146$s" "%2147$s" "%2148$s" "%2149$s" "%2150$s" ++"%2151$s" "%2152$s" "%2153$s" "%2154$s" "%2155$s" "%2156$s" "%2157$s" "%2158$s" "%2159$s" "%2160$s" ++"%2161$s" "%2162$s" "%2163$s" "%2164$s" "%2165$s" "%2166$s" "%2167$s" "%2168$s" "%2169$s" "%2170$s" ++"%2171$s" "%2172$s" "%2173$s" "%2174$s" "%2175$s" "%2176$s" "%2177$s" "%2178$s" "%2179$s" "%2180$s" ++"%2181$s" "%2182$s" "%2183$s" "%2184$s" "%2185$s" "%2186$s" "%2187$s" "%2188$s" "%2189$s" "%2190$s" ++"%2191$s" "%2192$s" "%2193$s" "%2194$s" "%2195$s" "%2196$s" "%2197$s" "%2198$s" "%2199$s" "%2200$s" ++"%2201$s" "%2202$s" "%2203$s" "%2204$s" "%2205$s" "%2206$s" "%2207$s" "%2208$s" "%2209$s" "%2210$s" ++"%2211$s" "%2212$s" "%2213$s" "%2214$s" "%2215$s" "%2216$s" "%2217$s" "%2218$s" "%2219$s" "%2220$s" ++"%2221$s" "%2222$s" "%2223$s" "%2224$s" "%2225$s" "%2226$s" "%2227$s" "%2228$s" "%2229$s" "%2230$s" ++"%2231$s" "%2232$s" "%2233$s" "%2234$s" "%2235$s" "%2236$s" "%2237$s" "%2238$s" "%2239$s" "%2240$s" ++"%2241$s" "%2242$s" "%2243$s" "%2244$s" "%2245$s" "%2246$s" "%2247$s" "%2248$s" "%2249$s" "%2250$s" ++"%2251$s" "%2252$s" "%2253$s" "%2254$s" "%2255$s" "%2256$s" "%2257$s" "%2258$s" "%2259$s" "%2260$s" ++"%2261$s" "%2262$s" "%2263$s" "%2264$s" "%2265$s" "%2266$s" "%2267$s" "%2268$s" "%2269$s" "%2270$s" ++"%2271$s" "%2272$s" "%2273$s" "%2274$s" "%2275$s" "%2276$s" "%2277$s" "%2278$s" "%2279$s" "%2280$s" ++"%2281$s" "%2282$s" "%2283$s" "%2284$s" "%2285$s" "%2286$s" "%2287$s" "%2288$s" "%2289$s" "%2290$s" ++"%2291$s" "%2292$s" "%2293$s" "%2294$s" "%2295$s" "%2296$s" "%2297$s" "%2298$s" "%2299$s" "%2300$s" ++"%2301$s" "%2302$s" "%2303$s" "%2304$s" "%2305$s" "%2306$s" "%2307$s" "%2308$s" "%2309$s" "%2310$s" ++"%2311$s" "%2312$s" "%2313$s" "%2314$s" "%2315$s" "%2316$s" "%2317$s" "%2318$s" "%2319$s" "%2320$s" ++"%2321$s" "%2322$s" "%2323$s" "%2324$s" "%2325$s" "%2326$s" "%2327$s" "%2328$s" "%2329$s" "%2330$s" ++"%2331$s" "%2332$s" "%2333$s" "%2334$s" "%2335$s" "%2336$s" "%2337$s" "%2338$s" "%2339$s" "%2340$s" ++"%2341$s" "%2342$s" "%2343$s" "%2344$s" "%2345$s" "%2346$s" "%2347$s" "%2348$s" "%2349$s" "%2350$s" ++"%2351$s" "%2352$s" "%2353$s" "%2354$s" "%2355$s" "%2356$s" "%2357$s" "%2358$s" "%2359$s" "%2360$s" ++"%2361$s" "%2362$s" "%2363$s" "%2364$s" "%2365$s" "%2366$s" "%2367$s" "%2368$s" "%2369$s" "%2370$s" ++"%2371$s" "%2372$s" "%2373$s" "%2374$s" "%2375$s" "%2376$s" "%2377$s" "%2378$s" "%2379$s" "%2380$s" ++"%2381$s" "%2382$s" "%2383$s" "%2384$s" "%2385$s" "%2386$s" "%2387$s" "%2388$s" "%2389$s" "%2390$s" ++"%2391$s" "%2392$s" "%2393$s" "%2394$s" "%2395$s" "%2396$s" "%2397$s" "%2398$s" "%2399$s" "%2400$s" ++"%2401$s" "%2402$s" "%2403$s" "%2404$s" "%2405$s" "%2406$s" "%2407$s" "%2408$s" "%2409$s" "%2410$s" ++"%2411$s" "%2412$s" "%2413$s" "%2414$s" "%2415$s" "%2416$s" "%2417$s" "%2418$s" "%2419$s" "%2420$s" ++"%2421$s" "%2422$s" "%2423$s" "%2424$s" "%2425$s" "%2426$s" "%2427$s" "%2428$s" "%2429$s" "%2430$s" ++"%2431$s" "%2432$s" "%2433$s" "%2434$s" "%2435$s" "%2436$s" "%2437$s" "%2438$s" "%2439$s" "%2440$s" ++"%2441$s" "%2442$s" "%2443$s" "%2444$s" "%2445$s" "%2446$s" "%2447$s" "%2448$s" "%2449$s" "%2450$s" ++"%2451$s" "%2452$s" "%2453$s" "%2454$s" "%2455$s" "%2456$s" "%2457$s" "%2458$s" "%2459$s" "%2460$s" ++"%2461$s" "%2462$s" "%2463$s" "%2464$s" "%2465$s" "%2466$s" "%2467$s" "%2468$s" "%2469$s" "%2470$s" ++"%2471$s" "%2472$s" "%2473$s" "%2474$s" "%2475$s" "%2476$s" "%2477$s" "%2478$s" "%2479$s" "%2480$s" ++"%2481$s" "%2482$s" "%2483$s" "%2484$s" "%2485$s" "%2486$s" "%2487$s" "%2488$s" "%2489$s" "%2490$s" ++"%2491$s" "%2492$s" "%2493$s" "%2494$s" "%2495$s" "%2496$s" "%2497$s" "%2498$s" "%2499$s" "%2500$s" ++"%2501$s" "%2502$s" "%2503$s" "%2504$s" "%2505$s" "%2506$s" "%2507$s" "%2508$s" "%2509$s" "%2510$s" ++"%2511$s" "%2512$s" "%2513$s" "%2514$s" "%2515$s" "%2516$s" "%2517$s" "%2518$s" "%2519$s" "%2520$s" ++"%2521$s" "%2522$s" "%2523$s" "%2524$s" "%2525$s" "%2526$s" "%2527$s" "%2528$s" "%2529$s" "%2530$s" ++"%2531$s" "%2532$s" "%2533$s" "%2534$s" "%2535$s" "%2536$s" "%2537$s" "%2538$s" "%2539$s" "%2540$s" ++"%2541$s" "%2542$s" "%2543$s" "%2544$s" "%2545$s" "%2546$s" "%2547$s" "%2548$s" "%2549$s" "%2550$s" ++"%2551$s" "%2552$s" "%2553$s" "%2554$s" "%2555$s" "%2556$s" "%2557$s" "%2558$s" "%2559$s" "%2560$s" ++"%2561$s" "%2562$s" "%2563$s" "%2564$s" "%2565$s" "%2566$s" "%2567$s" "%2568$s" "%2569$s" "%2570$s" ++"%2571$s" "%2572$s" "%2573$s" "%2574$s" "%2575$s" "%2576$s" "%2577$s" "%2578$s" "%2579$s" "%2580$s" ++"%2581$s" "%2582$s" "%2583$s" "%2584$s" "%2585$s" "%2586$s" "%2587$s" "%2588$s" "%2589$s" "%2590$s" ++"%2591$s" "%2592$s" "%2593$s" "%2594$s" "%2595$s" "%2596$s" "%2597$s" "%2598$s" "%2599$s" "%2600$s" ++"%2601$s" "%2602$s" "%2603$s" "%2604$s" "%2605$s" "%2606$s" "%2607$s" "%2608$s" "%2609$s" "%2610$s" ++"%2611$s" "%2612$s" "%2613$s" "%2614$s" "%2615$s" "%2616$s" "%2617$s" "%2618$s" "%2619$s" "%2620$s" ++"%2621$s" "%2622$s" "%2623$s" "%2624$s" "%2625$s" "%2626$s" "%2627$s" "%2628$s" "%2629$s" "%2630$s" ++"%2631$s" "%2632$s" "%2633$s" "%2634$s" "%2635$s" "%2636$s" "%2637$s" "%2638$s" "%2639$s" "%2640$s" ++"%2641$s" "%2642$s" "%2643$s" "%2644$s" "%2645$s" "%2646$s" "%2647$s" "%2648$s" "%2649$s" "%2650$s" ++"%2651$s" "%2652$s" "%2653$s" "%2654$s" "%2655$s" "%2656$s" "%2657$s" "%2658$s" "%2659$s" "%2660$s" ++"%2661$s" "%2662$s" "%2663$s" "%2664$s" "%2665$s" "%2666$s" "%2667$s" "%2668$s" "%2669$s" "%2670$s" ++"%2671$s" "%2672$s" "%2673$s" "%2674$s" "%2675$s" "%2676$s" "%2677$s" "%2678$s" "%2679$s" "%2680$s" ++"%2681$s" "%2682$s" "%2683$s" "%2684$s" "%2685$s" "%2686$s" "%2687$s" "%2688$s" "%2689$s" "%2690$s" ++"%2691$s" "%2692$s" "%2693$s" "%2694$s" "%2695$s" "%2696$s" "%2697$s" "%2698$s" "%2699$s" "%2700$s" ++"%2701$s" "%2702$s" "%2703$s" "%2704$s" "%2705$s" "%2706$s" "%2707$s" "%2708$s" "%2709$s" "%2710$s" ++"%2711$s" "%2712$s" "%2713$s" "%2714$s" "%2715$s" "%2716$s" "%2717$s" "%2718$s" "%2719$s" "%2720$s" ++"%2721$s" "%2722$s" "%2723$s" "%2724$s" "%2725$s" "%2726$s" "%2727$s" "%2728$s" "%2729$s" "%2730$s" ++"%2731$s" "%2732$s" "%2733$s" "%2734$s" "%2735$s" "%2736$s" "%2737$s" "%2738$s" "%2739$s" "%2740$s" ++"%2741$s" "%2742$s" "%2743$s" "%2744$s" "%2745$s" "%2746$s" "%2747$s" "%2748$s" "%2749$s" "%2750$s" ++"%2751$s" "%2752$s" "%2753$s" "%2754$s" "%2755$s" "%2756$s" "%2757$s" "%2758$s" "%2759$s" "%2760$s" ++"%2761$s" "%2762$s" "%2763$s" "%2764$s" "%2765$s" "%2766$s" "%2767$s" "%2768$s" "%2769$s" "%2770$s" ++"%2771$s" "%2772$s" "%2773$s" "%2774$s" "%2775$s" "%2776$s" "%2777$s" "%2778$s" "%2779$s" "%2780$s" ++"%2781$s" "%2782$s" "%2783$s" "%2784$s" "%2785$s" "%2786$s" "%2787$s" "%2788$s" "%2789$s" "%2790$s" ++"%2791$s" "%2792$s" "%2793$s" "%2794$s" "%2795$s" "%2796$s" "%2797$s" "%2798$s" "%2799$s" "%2800$s" ++"%2801$s" "%2802$s" "%2803$s" "%2804$s" "%2805$s" "%2806$s" "%2807$s" "%2808$s" "%2809$s" "%2810$s" ++"%2811$s" "%2812$s" "%2813$s" "%2814$s" "%2815$s" "%2816$s" "%2817$s" "%2818$s" "%2819$s" "%2820$s" ++"%2821$s" "%2822$s" "%2823$s" "%2824$s" "%2825$s" "%2826$s" "%2827$s" "%2828$s" "%2829$s" "%2830$s" ++"%2831$s" "%2832$s" "%2833$s" "%2834$s" "%2835$s" "%2836$s" "%2837$s" "%2838$s" "%2839$s" "%2840$s" ++"%2841$s" "%2842$s" "%2843$s" "%2844$s" "%2845$s" "%2846$s" "%2847$s" "%2848$s" "%2849$s" "%2850$s" ++"%2851$s" "%2852$s" "%2853$s" "%2854$s" "%2855$s" "%2856$s" "%2857$s" "%2858$s" "%2859$s" "%2860$s" ++"%2861$s" "%2862$s" "%2863$s" "%2864$s" "%2865$s" "%2866$s" "%2867$s" "%2868$s" "%2869$s" "%2870$s" ++"%2871$s" "%2872$s" "%2873$s" "%2874$s" "%2875$s" "%2876$s" "%2877$s" "%2878$s" "%2879$s" "%2880$s" ++"%2881$s" "%2882$s" "%2883$s" "%2884$s" "%2885$s" "%2886$s" "%2887$s" "%2888$s" "%2889$s" "%2890$s" ++"%2891$s" "%2892$s" "%2893$s" "%2894$s" "%2895$s" "%2896$s" "%2897$s" "%2898$s" "%2899$s" "%2900$s" ++"%2901$s" "%2902$s" "%2903$s" "%2904$s" "%2905$s" "%2906$s" "%2907$s" "%2908$s" "%2909$s" "%2910$s" ++"%2911$s" "%2912$s" "%2913$s" "%2914$s" "%2915$s" "%2916$s" "%2917$s" "%2918$s" "%2919$s" "%2920$s" ++"%2921$s" "%2922$s" "%2923$s" "%2924$s" "%2925$s" "%2926$s" "%2927$s" "%2928$s" "%2929$s" "%2930$s" ++"%2931$s" "%2932$s" "%2933$s" "%2934$s" "%2935$s" "%2936$s" "%2937$s" "%2938$s" "%2939$s" "%2940$s" ++"%2941$s" "%2942$s" "%2943$s" "%2944$s" "%2945$s" "%2946$s" "%2947$s" "%2948$s" "%2949$s" "%2950$s" ++"%2951$s" "%2952$s" "%2953$s" "%2954$s" "%2955$s" "%2956$s" "%2957$s" "%2958$s" "%2959$s" "%2960$s" ++"%2961$s" "%2962$s" "%2963$s" "%2964$s" "%2965$s" "%2966$s" "%2967$s" "%2968$s" "%2969$s" "%2970$s" ++"%2971$s" "%2972$s" "%2973$s" "%2974$s" "%2975$s" "%2976$s" "%2977$s" "%2978$s" "%2979$s" "%2980$s" ++"%2981$s" "%2982$s" "%2983$s" "%2984$s" "%2985$s" "%2986$s" "%2987$s" "%2988$s" "%2989$s" "%2990$s" ++"%2991$s" "%2992$s" "%2993$s" "%2994$s" "%2995$s" "%2996$s" "%2997$s" "%2998$s" "%2999$s" "%3000$s" ++"%3001$s" "%3002$s" "%3003$s" "%3004$s" "%3005$s" "%3006$s" "%3007$s" "%3008$s" "%3009$s" "%3010$s" ++"%3011$s" "%3012$s" "%3013$s" "%3014$s" "%3015$s" "%3016$s" "%3017$s" "%3018$s" "%3019$s" "%3020$s" ++"%3021$s" "%3022$s" "%3023$s" "%3024$s" "%3025$s" "%3026$s" "%3027$s" "%3028$s" "%3029$s" "%3030$s" ++"%3031$s" "%3032$s" "%3033$s" "%3034$s" "%3035$s" "%3036$s" "%3037$s" "%3038$s" "%3039$s" "%3040$s" ++"%3041$s" "%3042$s" "%3043$s" "%3044$s" "%3045$s" "%3046$s" "%3047$s" "%3048$s" "%3049$s" "%3050$s" ++"%3051$s" "%3052$s" "%3053$s" "%3054$s" "%3055$s" "%3056$s" "%3057$s" "%3058$s" "%3059$s" "%3060$s" ++"%3061$s" "%3062$s" "%3063$s" "%3064$s" "%3065$s" "%3066$s" "%3067$s" "%3068$s" "%3069$s" "%3070$s" ++"%3071$s" "%3072$s" "%3073$s" "%3074$s" "%3075$s" "%3076$s" "%3077$s" "%3078$s" "%3079$s" "%3080$s" ++"%3081$s" "%3082$s" "%3083$s" "%3084$s" "%3085$s" "%3086$s" "%3087$s" "%3088$s" "%3089$s" "%3090$s" ++"%3091$s" "%3092$s" "%3093$s" "%3094$s" "%3095$s" "%3096$s" "%3097$s" "%3098$s" "%3099$s" "%3100$s" ++"%3101$s" "%3102$s" "%3103$s" "%3104$s" "%3105$s" "%3106$s" "%3107$s" "%3108$s" "%3109$s" "%3110$s" ++"%3111$s" "%3112$s" "%3113$s" "%3114$s" "%3115$s" "%3116$s" "%3117$s" "%3118$s" "%3119$s" "%3120$s" ++"%3121$s" "%3122$s" "%3123$s" "%3124$s" "%3125$s" "%3126$s" "%3127$s" "%3128$s" "%3129$s" "%3130$s" ++"%3131$s" "%3132$s" "%3133$s" "%3134$s" "%3135$s" "%3136$s" "%3137$s" "%3138$s" "%3139$s" "%3140$s" ++"%3141$s" "%3142$s" "%3143$s" "%3144$s" "%3145$s" "%3146$s" "%3147$s" "%3148$s" "%3149$s" "%3150$s" ++"%3151$s" "%3152$s" "%3153$s" "%3154$s" "%3155$s" "%3156$s" "%3157$s" "%3158$s" "%3159$s" "%3160$s" ++"%3161$s" "%3162$s" "%3163$s" "%3164$s" "%3165$s" "%3166$s" "%3167$s" "%3168$s" "%3169$s" "%3170$s" ++"%3171$s" "%3172$s" "%3173$s" "%3174$s" "%3175$s" "%3176$s" "%3177$s" "%3178$s" "%3179$s" "%3180$s" ++"%3181$s" "%3182$s" "%3183$s" "%3184$s" "%3185$s" "%3186$s" "%3187$s" "%3188$s" "%3189$s" "%3190$s" ++"%3191$s" "%3192$s" "%3193$s" "%3194$s" "%3195$s" "%3196$s" "%3197$s" "%3198$s" "%3199$s" "%3200$s" ++"%3201$s" "%3202$s" "%3203$s" "%3204$s" "%3205$s" "%3206$s" "%3207$s" "%3208$s" "%3209$s" "%3210$s" ++"%3211$s" "%3212$s" "%3213$s" "%3214$s" "%3215$s" "%3216$s" "%3217$s" "%3218$s" "%3219$s" "%3220$s" ++"%3221$s" "%3222$s" "%3223$s" "%3224$s" "%3225$s" "%3226$s" "%3227$s" "%3228$s" "%3229$s" "%3230$s" ++"%3231$s" "%3232$s" "%3233$s" "%3234$s" "%3235$s" "%3236$s" "%3237$s" "%3238$s" "%3239$s" "%3240$s" ++"%3241$s" "%3242$s" "%3243$s" "%3244$s" "%3245$s" "%3246$s" "%3247$s" "%3248$s" "%3249$s" "%3250$s" ++"%3251$s" "%3252$s" "%3253$s" "%3254$s" "%3255$s" "%3256$s" "%3257$s" "%3258$s" "%3259$s" "%3260$s" ++"%3261$s" "%3262$s" "%3263$s" "%3264$s" "%3265$s" "%3266$s" "%3267$s" "%3268$s" "%3269$s" "%3270$s" ++"%3271$s" "%3272$s" "%3273$s" "%3274$s" "%3275$s" "%3276$s" "%3277$s" "%3278$s" "%3279$s" "%3280$s" ++"%3281$s" "%3282$s" "%3283$s" "%3284$s" "%3285$s" "%3286$s" "%3287$s" "%3288$s" "%3289$s" "%3290$s" ++"%3291$s" "%3292$s" "%3293$s" "%3294$s" "%3295$s" "%3296$s" "%3297$s" "%3298$s" "%3299$s" "%3300$s" ++"%3301$s" "%3302$s" "%3303$s" "%3304$s" "%3305$s" "%3306$s" "%3307$s" "%3308$s" "%3309$s" "%3310$s" ++"%3311$s" "%3312$s" "%3313$s" "%3314$s" "%3315$s" "%3316$s" "%3317$s" "%3318$s" "%3319$s" "%3320$s" ++"%3321$s" "%3322$s" "%3323$s" "%3324$s" "%3325$s" "%3326$s" "%3327$s" "%3328$s" "%3329$s" "%3330$s" ++"%3331$s" "%3332$s" "%3333$s" "%3334$s" "%3335$s" "%3336$s" "%3337$s" "%3338$s" "%3339$s" "%3340$s" ++"%3341$s" "%3342$s" "%3343$s" "%3344$s" "%3345$s" "%3346$s" "%3347$s" "%3348$s" "%3349$s" "%3350$s" ++"%3351$s" "%3352$s" "%3353$s" "%3354$s" "%3355$s" "%3356$s" "%3357$s" "%3358$s" "%3359$s" "%3360$s" ++"%3361$s" "%3362$s" "%3363$s" "%3364$s" "%3365$s" "%3366$s" "%3367$s" "%3368$s" "%3369$s" "%3370$s" ++"%3371$s" "%3372$s" "%3373$s" "%3374$s" "%3375$s" "%3376$s" "%3377$s" "%3378$s" "%3379$s" "%3380$s" ++"%3381$s" "%3382$s" "%3383$s" "%3384$s" "%3385$s" "%3386$s" "%3387$s" "%3388$s" "%3389$s" "%3390$s" ++"%3391$s" "%3392$s" "%3393$s" "%3394$s" "%3395$s" "%3396$s" "%3397$s" "%3398$s" "%3399$s" "%3400$s" ++"%3401$s" "%3402$s" "%3403$s" "%3404$s" "%3405$s" "%3406$s" "%3407$s" "%3408$s" "%3409$s" "%3410$s" ++"%3411$s" "%3412$s" "%3413$s" "%3414$s" "%3415$s" "%3416$s" "%3417$s" "%3418$s" "%3419$s" "%3420$s" ++"%3421$s" "%3422$s" "%3423$s" "%3424$s" "%3425$s" "%3426$s" "%3427$s" "%3428$s" "%3429$s" "%3430$s" ++"%3431$s" "%3432$s" "%3433$s" "%3434$s" "%3435$s" "%3436$s" "%3437$s" "%3438$s" "%3439$s" "%3440$s" ++"%3441$s" "%3442$s" "%3443$s" "%3444$s" "%3445$s" "%3446$s" "%3447$s" "%3448$s" "%3449$s" "%3450$s" ++"%3451$s" "%3452$s" "%3453$s" "%3454$s" "%3455$s" "%3456$s" "%3457$s" "%3458$s" "%3459$s" "%3460$s" ++"%3461$s" "%3462$s" "%3463$s" "%3464$s" "%3465$s" "%3466$s" "%3467$s" "%3468$s" "%3469$s" "%3470$s" ++"%3471$s" "%3472$s" "%3473$s" "%3474$s" "%3475$s" "%3476$s" "%3477$s" "%3478$s" "%3479$s" "%3480$s" ++"%3481$s" "%3482$s" "%3483$s" "%3484$s" "%3485$s" "%3486$s" "%3487$s" "%3488$s" "%3489$s" "%3490$s" ++"%3491$s" "%3492$s" "%3493$s" "%3494$s" "%3495$s" "%3496$s" "%3497$s" "%3498$s" "%3499$s" "%3500$s" ++"%3501$s" "%3502$s" "%3503$s" "%3504$s" "%3505$s" "%3506$s" "%3507$s" "%3508$s" "%3509$s" "%3510$s" ++"%3511$s" "%3512$s" "%3513$s" "%3514$s" "%3515$s" "%3516$s" "%3517$s" "%3518$s" "%3519$s" "%3520$s" ++"%3521$s" "%3522$s" "%3523$s" "%3524$s" "%3525$s" "%3526$s" "%3527$s" "%3528$s" "%3529$s" "%3530$s" ++"%3531$s" "%3532$s" "%3533$s" "%3534$s" "%3535$s" "%3536$s" "%3537$s" "%3538$s" "%3539$s" "%3540$s" ++"%3541$s" "%3542$s" "%3543$s" "%3544$s" "%3545$s" "%3546$s" "%3547$s" "%3548$s" "%3549$s" "%3550$s" ++"%3551$s" "%3552$s" "%3553$s" "%3554$s" "%3555$s" "%3556$s" "%3557$s" "%3558$s" "%3559$s" "%3560$s" ++"%3561$s" "%3562$s" "%3563$s" "%3564$s" "%3565$s" "%3566$s" "%3567$s" "%3568$s" "%3569$s" "%3570$s" ++"%3571$s" "%3572$s" "%3573$s" "%3574$s" "%3575$s" "%3576$s" "%3577$s" "%3578$s" "%3579$s" "%3580$s" ++"%3581$s" "%3582$s" "%3583$s" "%3584$s" "%3585$s" "%3586$s" "%3587$s" "%3588$s" "%3589$s" "%3590$s" ++"%3591$s" "%3592$s" "%3593$s" "%3594$s" "%3595$s" "%3596$s" "%3597$s" "%3598$s" "%3599$s" "%3600$s" ++"%3601$s" "%3602$s" "%3603$s" "%3604$s" "%3605$s" "%3606$s" "%3607$s" "%3608$s" "%3609$s" "%3610$s" ++"%3611$s" "%3612$s" "%3613$s" "%3614$s" "%3615$s" "%3616$s" "%3617$s" "%3618$s" "%3619$s" "%3620$s" ++"%3621$s" "%3622$s" "%3623$s" "%3624$s" "%3625$s" "%3626$s" "%3627$s" "%3628$s" "%3629$s" "%3630$s" ++"%3631$s" "%3632$s" "%3633$s" "%3634$s" "%3635$s" "%3636$s" "%3637$s" "%3638$s" "%3639$s" "%3640$s" ++"%3641$s" "%3642$s" "%3643$s" "%3644$s" "%3645$s" "%3646$s" "%3647$s" "%3648$s" "%3649$s" "%3650$s" ++"%3651$s" "%3652$s" "%3653$s" "%3654$s" "%3655$s" "%3656$s" "%3657$s" "%3658$s" "%3659$s" "%3660$s" ++"%3661$s" "%3662$s" "%3663$s" "%3664$s" "%3665$s" "%3666$s" "%3667$s" "%3668$s" "%3669$s" "%3670$s" ++"%3671$s" "%3672$s" "%3673$s" "%3674$s" "%3675$s" "%3676$s" "%3677$s" "%3678$s" "%3679$s" "%3680$s" ++"%3681$s" "%3682$s" "%3683$s" "%3684$s" "%3685$s" "%3686$s" "%3687$s" "%3688$s" "%3689$s" "%3690$s" ++"%3691$s" "%3692$s" "%3693$s" "%3694$s" "%3695$s" "%3696$s" "%3697$s" "%3698$s" "%3699$s" "%3700$s" ++"%3701$s" "%3702$s" "%3703$s" "%3704$s" "%3705$s" "%3706$s" "%3707$s" "%3708$s" "%3709$s" "%3710$s" ++"%3711$s" "%3712$s" "%3713$s" "%3714$s" "%3715$s" "%3716$s" "%3717$s" "%3718$s" "%3719$s" "%3720$s" ++"%3721$s" "%3722$s" "%3723$s" "%3724$s" "%3725$s" "%3726$s" "%3727$s" "%3728$s" "%3729$s" "%3730$s" ++"%3731$s" "%3732$s" "%3733$s" "%3734$s" "%3735$s" "%3736$s" "%3737$s" "%3738$s" "%3739$s" "%3740$s" ++"%3741$s" "%3742$s" "%3743$s" "%3744$s" "%3745$s" "%3746$s" "%3747$s" "%3748$s" "%3749$s" "%3750$s" ++"%3751$s" "%3752$s" "%3753$s" "%3754$s" "%3755$s" "%3756$s" "%3757$s" "%3758$s" "%3759$s" "%3760$s" ++"%3761$s" "%3762$s" "%3763$s" "%3764$s" "%3765$s" "%3766$s" "%3767$s" "%3768$s" "%3769$s" "%3770$s" ++"%3771$s" "%3772$s" "%3773$s" "%3774$s" "%3775$s" "%3776$s" "%3777$s" "%3778$s" "%3779$s" "%3780$s" ++"%3781$s" "%3782$s" "%3783$s" "%3784$s" "%3785$s" "%3786$s" "%3787$s" "%3788$s" "%3789$s" "%3790$s" ++"%3791$s" "%3792$s" "%3793$s" "%3794$s" "%3795$s" "%3796$s" "%3797$s" "%3798$s" "%3799$s" "%3800$s" ++"%3801$s" "%3802$s" "%3803$s" "%3804$s" "%3805$s" "%3806$s" "%3807$s" "%3808$s" "%3809$s" "%3810$s" ++"%3811$s" "%3812$s" "%3813$s" "%3814$s" "%3815$s" "%3816$s" "%3817$s" "%3818$s" "%3819$s" "%3820$s" ++"%3821$s" "%3822$s" "%3823$s" "%3824$s" "%3825$s" "%3826$s" "%3827$s" "%3828$s" "%3829$s" "%3830$s" ++"%3831$s" "%3832$s" "%3833$s" "%3834$s" "%3835$s" "%3836$s" "%3837$s" "%3838$s" "%3839$s" "%3840$s" ++"%3841$s" "%3842$s" "%3843$s" "%3844$s" "%3845$s" "%3846$s" "%3847$s" "%3848$s" "%3849$s" "%3850$s" ++"%3851$s" "%3852$s" "%3853$s" "%3854$s" "%3855$s" "%3856$s" "%3857$s" "%3858$s" "%3859$s" "%3860$s" ++"%3861$s" "%3862$s" "%3863$s" "%3864$s" "%3865$s" "%3866$s" "%3867$s" "%3868$s" "%3869$s" "%3870$s" ++"%3871$s" "%3872$s" "%3873$s" "%3874$s" "%3875$s" "%3876$s" "%3877$s" "%3878$s" "%3879$s" "%3880$s" ++"%3881$s" "%3882$s" "%3883$s" "%3884$s" "%3885$s" "%3886$s" "%3887$s" "%3888$s" "%3889$s" "%3890$s" ++"%3891$s" "%3892$s" "%3893$s" "%3894$s" "%3895$s" "%3896$s" "%3897$s" "%3898$s" "%3899$s" "%3900$s" ++"%3901$s" "%3902$s" "%3903$s" "%3904$s" "%3905$s" "%3906$s" "%3907$s" "%3908$s" "%3909$s" "%3910$s" ++"%3911$s" "%3912$s" "%3913$s" "%3914$s" "%3915$s" "%3916$s" "%3917$s" "%3918$s" "%3919$s" "%3920$s" ++"%3921$s" "%3922$s" "%3923$s" "%3924$s" "%3925$s" "%3926$s" "%3927$s" "%3928$s" "%3929$s" "%3930$s" ++"%3931$s" "%3932$s" "%3933$s" "%3934$s" "%3935$s" "%3936$s" "%3937$s" "%3938$s" "%3939$s" "%3940$s" ++"%3941$s" "%3942$s" "%3943$s" "%3944$s" "%3945$s" "%3946$s" "%3947$s" "%3948$s" "%3949$s" "%3950$s" ++"%3951$s" "%3952$s" "%3953$s" "%3954$s" "%3955$s" "%3956$s" "%3957$s" "%3958$s" "%3959$s" "%3960$s" ++"%3961$s" "%3962$s" "%3963$s" "%3964$s" "%3965$s" "%3966$s" "%3967$s" "%3968$s" "%3969$s" "%3970$s" ++"%3971$s" "%3972$s" "%3973$s" "%3974$s" "%3975$s" "%3976$s" "%3977$s" "%3978$s" "%3979$s" "%3980$s" ++"%3981$s" "%3982$s" "%3983$s" "%3984$s" "%3985$s" "%3986$s" "%3987$s" "%3988$s" "%3989$s" "%3990$s" ++"%3991$s" "%3992$s" "%3993$s" "%3994$s" "%3995$s" "%3996$s" "%3997$s" "%3998$s" "%3999$s" "%4000$s" ++"%4001$s" "%4002$s" "%4003$s" "%4004$s" "%4005$s" "%4006$s" "%4007$s" "%4008$s" "%4009$s" "%4010$s" ++"%4011$s" "%4012$s" "%4013$s" "%4014$s" "%4015$s" "%4016$s" "%4017$s" "%4018$s" "%4019$s" "%4020$s" ++"%4021$s" "%4022$s" "%4023$s" "%4024$s" "%4025$s" "%4026$s" "%4027$s" "%4028$s" "%4029$s" "%4030$s" ++"%4031$s" "%4032$s" "%4033$s" "%4034$s" "%4035$s" "%4036$s" "%4037$s" "%4038$s" "%4039$s" "%4040$s" ++"%4041$s" "%4042$s" "%4043$s" "%4044$s" "%4045$s" "%4046$s" "%4047$s" "%4048$s" "%4049$s" "%4050$s" ++"%4051$s" "%4052$s" "%4053$s" "%4054$s" "%4055$s" "%4056$s" "%4057$s" "%4058$s" "%4059$s" "%4060$s" ++"%4061$s" "%4062$s" "%4063$s" "%4064$s" "%4065$s" "%4066$s" "%4067$s" "%4068$s" "%4069$s" "%4070$s" ++"%4071$s" "%4072$s" "%4073$s" "%4074$s" "%4075$s" "%4076$s" "%4077$s" "%4078$s" "%4079$s" "%4080$s" ++"%4081$s" "%4082$s" "%4083$s" "%4084$s" "%4085$s" "%4086$s" "%4087$s" "%4088$s" "%4089$s" "%4090$s" ++"%4091$s" "%4092$s" "%4093$s" "%4094$s" "%4095$s" "%4096$s" "%4097$s" "%4098$s" "%4099$s" "%4100$s" ++"%4101$s" "%4102$s" "%4103$s" "%4104$s" "%4105$s" "%4106$s" "%4107$s" "%4108$s" "%4109$s" "%4110$s" ++"%4111$s" "%4112$s" "%4113$s" "%4114$s" "%4115$s" "%4116$s" "%4117$s" "%4118$s" "%4119$s" "%4120$s" ++"%4121$s" "%4122$s" "%4123$s" "%4124$s" "%4125$s" "%4126$s" "%4127$s" "%4128$s" "%4129$s" "%4130$s" ++"%4131$s" "%4132$s" "%4133$s" "%4134$s" "%4135$s" "%4136$s" "%4137$s" "%4138$s" "%4139$s" "%4140$s" ++"%4141$s" "%4142$s" "%4143$s" "%4144$s" "%4145$s" "%4146$s" "%4147$s" "%4148$s" "%4149$s" "%4150$s" ++"%4151$s" "%4152$s" "%4153$s" "%4154$s" "%4155$s" "%4156$s" "%4157$s" "%4158$s" "%4159$s" "%4160$s" ++"%4161$s" "%4162$s" "%4163$s" "%4164$s" "%4165$s" "%4166$s" "%4167$s" "%4168$s" "%4169$s" "%4170$s" ++"%4171$s" "%4172$s" "%4173$s" "%4174$s" "%4175$s" "%4176$s" "%4177$s" "%4178$s" "%4179$s" "%4180$s" ++"%4181$s" "%4182$s" "%4183$s" "%4184$s" "%4185$s" "%4186$s" "%4187$s" "%4188$s" "%4189$s" "%4190$s" ++"%4191$s" "%4192$s" "%4193$s" "%4194$s" "%4195$s" "%4196$s" "%4197$s" "%4198$s" "%4199$s" "%4200$s" ++"%4201$s" "%4202$s" "%4203$s" "%4204$s" "%4205$s" "%4206$s" "%4207$s" "%4208$s" "%4209$s" "%4210$s" ++"%4211$s" "%4212$s" "%4213$s" "%4214$s" "%4215$s" "%4216$s" "%4217$s" "%4218$s" "%4219$s" "%4220$s" ++"%4221$s" "%4222$s" "%4223$s" "%4224$s" "%4225$s" "%4226$s" "%4227$s" "%4228$s" "%4229$s" "%4230$s" ++"%4231$s" "%4232$s" "%4233$s" "%4234$s" "%4235$s" "%4236$s" "%4237$s" "%4238$s" "%4239$s" "%4240$s" ++"%4241$s" "%4242$s" "%4243$s" "%4244$s" "%4245$s" "%4246$s" "%4247$s" "%4248$s" "%4249$s" "%4250$s" ++"%4251$s" "%4252$s" "%4253$s" "%4254$s" "%4255$s" "%4256$s" "%4257$s" "%4258$s" "%4259$s" "%4260$s" ++"%4261$s" "%4262$s" "%4263$s" "%4264$s" "%4265$s" "%4266$s" "%4267$s" "%4268$s" "%4269$s" "%4270$s" ++"%4271$s" "%4272$s" "%4273$s" "%4274$s" "%4275$s" "%4276$s" "%4277$s" "%4278$s" "%4279$s" "%4280$s" ++"%4281$s" "%4282$s" "%4283$s" "%4284$s" "%4285$s" "%4286$s" "%4287$s" "%4288$s" "%4289$s" "%4290$s" ++"%4291$s" "%4292$s" "%4293$s" "%4294$s" "%4295$s" "%4296$s" "%4297$s" "%4298$s" "%4299$s" "%4300$s" ++"%4301$s" "%4302$s" "%4303$s" "%4304$s" "%4305$s" "%4306$s" "%4307$s" "%4308$s" "%4309$s" "%4310$s" ++"%4311$s" "%4312$s" "%4313$s" "%4314$s" "%4315$s" "%4316$s" "%4317$s" "%4318$s" "%4319$s" "%4320$s" ++"%4321$s" "%4322$s" "%4323$s" "%4324$s" "%4325$s" "%4326$s" "%4327$s" "%4328$s" "%4329$s" "%4330$s" ++"%4331$s" "%4332$s" "%4333$s" "%4334$s" "%4335$s" "%4336$s" "%4337$s" "%4338$s" "%4339$s" "%4340$s" ++"%4341$s" "%4342$s" "%4343$s" "%4344$s" "%4345$s" "%4346$s" "%4347$s" "%4348$s" "%4349$s" "%4350$s" ++"%4351$s" "%4352$s" "%4353$s" "%4354$s" "%4355$s" "%4356$s" "%4357$s" "%4358$s" "%4359$s" "%4360$s" ++"%4361$s" "%4362$s" "%4363$s" "%4364$s" "%4365$s" "%4366$s" "%4367$s" "%4368$s" "%4369$s" "%4370$s" ++"%4371$s" "%4372$s" "%4373$s" "%4374$s" "%4375$s" "%4376$s" "%4377$s" "%4378$s" "%4379$s" "%4380$s" ++"%4381$s" "%4382$s" "%4383$s" "%4384$s" "%4385$s" "%4386$s" "%4387$s" "%4388$s" "%4389$s" "%4390$s" ++"%4391$s" "%4392$s" "%4393$s" "%4394$s" "%4395$s" "%4396$s" "%4397$s" "%4398$s" "%4399$s" "%4400$s" ++"%4401$s" "%4402$s" "%4403$s" "%4404$s" "%4405$s" "%4406$s" "%4407$s" "%4408$s" "%4409$s" "%4410$s" ++"%4411$s" "%4412$s" "%4413$s" "%4414$s" "%4415$s" "%4416$s" "%4417$s" "%4418$s" "%4419$s" "%4420$s" ++"%4421$s" "%4422$s" "%4423$s" "%4424$s" "%4425$s" "%4426$s" "%4427$s" "%4428$s" "%4429$s" "%4430$s" ++"%4431$s" "%4432$s" "%4433$s" "%4434$s" "%4435$s" "%4436$s" "%4437$s" "%4438$s" "%4439$s" "%4440$s" ++"%4441$s" "%4442$s" "%4443$s" "%4444$s" "%4445$s" "%4446$s" "%4447$s" "%4448$s" "%4449$s" "%4450$s" ++"%4451$s" "%4452$s" "%4453$s" "%4454$s" "%4455$s" "%4456$s" "%4457$s" "%4458$s" "%4459$s" "%4460$s" ++"%4461$s" "%4462$s" "%4463$s" "%4464$s" "%4465$s" "%4466$s" "%4467$s" "%4468$s" "%4469$s" "%4470$s" ++"%4471$s" "%4472$s" "%4473$s" "%4474$s" "%4475$s" "%4476$s" "%4477$s" "%4478$s" "%4479$s" "%4480$s" ++"%4481$s" "%4482$s" "%4483$s" "%4484$s" "%4485$s" "%4486$s" "%4487$s" "%4488$s" "%4489$s" "%4490$s" ++"%4491$s" "%4492$s" "%4493$s" "%4494$s" "%4495$s" "%4496$s" "%4497$s" "%4498$s" "%4499$s" "%4500$s" ++"%4501$s" "%4502$s" "%4503$s" "%4504$s" "%4505$s" "%4506$s" "%4507$s" "%4508$s" "%4509$s" "%4510$s" ++"%4511$s" "%4512$s" "%4513$s" "%4514$s" "%4515$s" "%4516$s" "%4517$s" "%4518$s" "%4519$s" "%4520$s" ++"%4521$s" "%4522$s" "%4523$s" "%4524$s" "%4525$s" "%4526$s" "%4527$s" "%4528$s" "%4529$s" "%4530$s" ++"%4531$s" "%4532$s" "%4533$s" "%4534$s" "%4535$s" "%4536$s" "%4537$s" "%4538$s" "%4539$s" "%4540$s" ++"%4541$s" "%4542$s" "%4543$s" "%4544$s" "%4545$s" "%4546$s" "%4547$s" "%4548$s" "%4549$s" "%4550$s" ++"%4551$s" "%4552$s" "%4553$s" "%4554$s" "%4555$s" "%4556$s" "%4557$s" "%4558$s" "%4559$s" "%4560$s" ++"%4561$s" "%4562$s" "%4563$s" "%4564$s" "%4565$s" "%4566$s" "%4567$s" "%4568$s" "%4569$s" "%4570$s" ++"%4571$s" "%4572$s" "%4573$s" "%4574$s" "%4575$s" "%4576$s" "%4577$s" "%4578$s" "%4579$s" "%4580$s" ++"%4581$s" "%4582$s" "%4583$s" "%4584$s" "%4585$s" "%4586$s" "%4587$s" "%4588$s" "%4589$s" "%4590$s" ++"%4591$s" "%4592$s" "%4593$s" "%4594$s" "%4595$s" "%4596$s" "%4597$s" "%4598$s" "%4599$s" "%4600$s" ++"%4601$s" "%4602$s" "%4603$s" "%4604$s" "%4605$s" "%4606$s" "%4607$s" "%4608$s" "%4609$s" "%4610$s" ++"%4611$s" "%4612$s" "%4613$s" "%4614$s" "%4615$s" "%4616$s" "%4617$s" "%4618$s" "%4619$s" "%4620$s" ++"%4621$s" "%4622$s" "%4623$s" "%4624$s" "%4625$s" "%4626$s" "%4627$s" "%4628$s" "%4629$s" "%4630$s" ++"%4631$s" "%4632$s" "%4633$s" "%4634$s" "%4635$s" "%4636$s" "%4637$s" "%4638$s" "%4639$s" "%4640$s" ++"%4641$s" "%4642$s" "%4643$s" "%4644$s" "%4645$s" "%4646$s" "%4647$s" "%4648$s" "%4649$s" "%4650$s" ++"%4651$s" "%4652$s" "%4653$s" "%4654$s" "%4655$s" "%4656$s" "%4657$s" "%4658$s" "%4659$s" "%4660$s" ++"%4661$s" "%4662$s" "%4663$s" "%4664$s" "%4665$s" "%4666$s" "%4667$s" "%4668$s" "%4669$s" "%4670$s" ++"%4671$s" "%4672$s" "%4673$s" "%4674$s" "%4675$s" "%4676$s" "%4677$s" "%4678$s" "%4679$s" "%4680$s" ++"%4681$s" "%4682$s" "%4683$s" "%4684$s" "%4685$s" "%4686$s" "%4687$s" "%4688$s" "%4689$s" "%4690$s" ++"%4691$s" "%4692$s" "%4693$s" "%4694$s" "%4695$s" "%4696$s" "%4697$s" "%4698$s" "%4699$s" "%4700$s" ++"%4701$s" "%4702$s" "%4703$s" "%4704$s" "%4705$s" "%4706$s" "%4707$s" "%4708$s" "%4709$s" "%4710$s" ++"%4711$s" "%4712$s" "%4713$s" "%4714$s" "%4715$s" "%4716$s" "%4717$s" "%4718$s" "%4719$s" "%4720$s" ++"%4721$s" "%4722$s" "%4723$s" "%4724$s" "%4725$s" "%4726$s" "%4727$s" "%4728$s" "%4729$s" "%4730$s" ++"%4731$s" "%4732$s" "%4733$s" "%4734$s" "%4735$s" "%4736$s" "%4737$s" "%4738$s" "%4739$s" "%4740$s" ++"%4741$s" "%4742$s" "%4743$s" "%4744$s" "%4745$s" "%4746$s" "%4747$s" "%4748$s" "%4749$s" "%4750$s" ++"%4751$s" "%4752$s" "%4753$s" "%4754$s" "%4755$s" "%4756$s" "%4757$s" "%4758$s" "%4759$s" "%4760$s" ++"%4761$s" "%4762$s" "%4763$s" "%4764$s" "%4765$s" "%4766$s" "%4767$s" "%4768$s" "%4769$s" "%4770$s" ++"%4771$s" "%4772$s" "%4773$s" "%4774$s" "%4775$s" "%4776$s" "%4777$s" "%4778$s" "%4779$s" "%4780$s" ++"%4781$s" "%4782$s" "%4783$s" "%4784$s" "%4785$s" "%4786$s" "%4787$s" "%4788$s" "%4789$s" "%4790$s" ++"%4791$s" "%4792$s" "%4793$s" "%4794$s" "%4795$s" "%4796$s" "%4797$s" "%4798$s" "%4799$s" "%4800$s" ++"%4801$s" "%4802$s" "%4803$s" "%4804$s" "%4805$s" "%4806$s" "%4807$s" "%4808$s" "%4809$s" "%4810$s" ++"%4811$s" "%4812$s" "%4813$s" "%4814$s" "%4815$s" "%4816$s" "%4817$s" "%4818$s" "%4819$s" "%4820$s" ++"%4821$s" "%4822$s" "%4823$s" "%4824$s" "%4825$s" "%4826$s" "%4827$s" "%4828$s" "%4829$s" "%4830$s" ++"%4831$s" "%4832$s" "%4833$s" "%4834$s" "%4835$s" "%4836$s" "%4837$s" "%4838$s" "%4839$s" "%4840$s" ++"%4841$s" "%4842$s" "%4843$s" "%4844$s" "%4845$s" "%4846$s" "%4847$s" "%4848$s" "%4849$s" "%4850$s" ++"%4851$s" "%4852$s" "%4853$s" "%4854$s" "%4855$s" "%4856$s" "%4857$s" "%4858$s" "%4859$s" "%4860$s" ++"%4861$s" "%4862$s" "%4863$s" "%4864$s" "%4865$s" "%4866$s" "%4867$s" "%4868$s" "%4869$s" "%4870$s" ++"%4871$s" "%4872$s" "%4873$s" "%4874$s" "%4875$s" "%4876$s" "%4877$s" "%4878$s" "%4879$s" "%4880$s" ++"%4881$s" "%4882$s" "%4883$s" "%4884$s" "%4885$s" "%4886$s" "%4887$s" "%4888$s" "%4889$s" "%4890$s" ++"%4891$s" "%4892$s" "%4893$s" "%4894$s" "%4895$s" "%4896$s" "%4897$s" "%4898$s" "%4899$s" "%4900$s" ++"%4901$s" "%4902$s" "%4903$s" "%4904$s" "%4905$s" "%4906$s" "%4907$s" "%4908$s" "%4909$s" "%4910$s" ++"%4911$s" "%4912$s" "%4913$s" "%4914$s" "%4915$s" "%4916$s" "%4917$s" "%4918$s" "%4919$s" "%4920$s" ++"%4921$s" "%4922$s" "%4923$s" "%4924$s" "%4925$s" "%4926$s" "%4927$s" "%4928$s" "%4929$s" "%4930$s" ++"%4931$s" "%4932$s" "%4933$s" "%4934$s" "%4935$s" "%4936$s" "%4937$s" "%4938$s" "%4939$s" "%4940$s" ++"%4941$s" "%4942$s" "%4943$s" "%4944$s" "%4945$s" "%4946$s" "%4947$s" "%4948$s" "%4949$s" "%4950$s" ++"%4951$s" "%4952$s" "%4953$s" "%4954$s" "%4955$s" "%4956$s" "%4957$s" "%4958$s" "%4959$s" "%4960$s" ++"%4961$s" "%4962$s" "%4963$s" "%4964$s" "%4965$s" "%4966$s" "%4967$s" "%4968$s" "%4969$s" "%4970$s" ++"%4971$s" "%4972$s" "%4973$s" "%4974$s" "%4975$s" "%4976$s" "%4977$s" "%4978$s" "%4979$s" "%4980$s" ++"%4981$s" "%4982$s" "%4983$s" "%4984$s" "%4985$s" "%4986$s" "%4987$s" "%4988$s" "%4989$s" "%4990$s" ++"%4991$s" "%4992$s" "%4993$s" "%4994$s" "%4995$s" "%4996$s" "%4997$s" "%4998$s" "%4999$s" "%5000$s" ++"%5001$s" "%5002$s" "%5003$s" "%5004$s" "%5005$s" "%5006$s" "%5007$s" "%5008$s" "%5009$s" "%5010$s" ++"%5011$s" "%5012$s" "%5013$s" "%5014$s" "%5015$s" "%5016$s" "%5017$s" "%5018$s" "%5019$s" "%5020$s" ++"%5021$s" "%5022$s" "%5023$s" "%5024$s" "%5025$s" "%5026$s" "%5027$s" "%5028$s" "%5029$s" "%5030$s" ++"%5031$s" "%5032$s" "%5033$s" "%5034$s" "%5035$s" "%5036$s" "%5037$s" "%5038$s" "%5039$s" "%5040$s" ++"%5041$s" "%5042$s" "%5043$s" "%5044$s" "%5045$s" "%5046$s" "%5047$s" "%5048$s" "%5049$s" "%5050$s" ++"%5051$s" "%5052$s" "%5053$s" "%5054$s" "%5055$s" "%5056$s" "%5057$s" "%5058$s" "%5059$s" "%5060$s" ++"%5061$s" "%5062$s" "%5063$s" "%5064$s" "%5065$s" "%5066$s" "%5067$s" "%5068$s" "%5069$s" "%5070$s" ++"%5071$s" "%5072$s" "%5073$s" "%5074$s" "%5075$s" "%5076$s" "%5077$s" "%5078$s" "%5079$s" "%5080$s" ++"%5081$s" "%5082$s" "%5083$s" "%5084$s" "%5085$s" "%5086$s" "%5087$s" "%5088$s" "%5089$s" "%5090$s" ++"%5091$s" "%5092$s" "%5093$s" "%5094$s" "%5095$s" "%5096$s" "%5097$s" "%5098$s" "%5099$s" "%5100$s" ++"%5101$s" "%5102$s" "%5103$s" "%5104$s" "%5105$s" "%5106$s" "%5107$s" "%5108$s" "%5109$s" "%5110$s" ++"%5111$s" "%5112$s" "%5113$s" "%5114$s" "%5115$s" "%5116$s" "%5117$s" "%5118$s" "%5119$s" "%5120$s" ++"%5121$s" "%5122$s" "%5123$s" "%5124$s" "%5125$s" "%5126$s" "%5127$s" "%5128$s" "%5129$s" "%5130$s" ++"%5131$s" "%5132$s" "%5133$s" "%5134$s" "%5135$s" "%5136$s" "%5137$s" "%5138$s" "%5139$s" "%5140$s" ++"%5141$s" "%5142$s" "%5143$s" "%5144$s" "%5145$s" "%5146$s" "%5147$s" "%5148$s" "%5149$s" "%5150$s" ++"%5151$s" "%5152$s" "%5153$s" "%5154$s" "%5155$s" "%5156$s" "%5157$s" "%5158$s" "%5159$s" "%5160$s" ++"%5161$s" "%5162$s" "%5163$s" "%5164$s" "%5165$s" "%5166$s" "%5167$s" "%5168$s" "%5169$s" "%5170$s" ++"%5171$s" "%5172$s" "%5173$s" "%5174$s" "%5175$s" "%5176$s" "%5177$s" "%5178$s" "%5179$s" "%5180$s" ++"%5181$s" "%5182$s" "%5183$s" "%5184$s" "%5185$s" "%5186$s" "%5187$s" "%5188$s" "%5189$s" "%5190$s" ++"%5191$s" "%5192$s" "%5193$s" "%5194$s" "%5195$s" "%5196$s" "%5197$s" "%5198$s" "%5199$s" "%5200$s" ++"%5201$s" "%5202$s" "%5203$s" "%5204$s" "%5205$s" "%5206$s" "%5207$s" "%5208$s" "%5209$s" "%5210$s" ++"%5211$s" "%5212$s" "%5213$s" "%5214$s" "%5215$s" "%5216$s" "%5217$s" "%5218$s" "%5219$s" "%5220$s" ++"%5221$s" "%5222$s" "%5223$s" "%5224$s" "%5225$s" "%5226$s" "%5227$s" "%5228$s" "%5229$s" "%5230$s" ++"%5231$s" "%5232$s" "%5233$s" "%5234$s" "%5235$s" "%5236$s" "%5237$s" "%5238$s" "%5239$s" "%5240$s" ++"%5241$s" "%5242$s" "%5243$s" "%5244$s" "%5245$s" "%5246$s" "%5247$s" "%5248$s" "%5249$s" "%5250$s" ++"%5251$s" "%5252$s" "%5253$s" "%5254$s" "%5255$s" "%5256$s" "%5257$s" "%5258$s" "%5259$s" "%5260$s" ++"%5261$s" "%5262$s" "%5263$s" "%5264$s" "%5265$s" "%5266$s" "%5267$s" "%5268$s" "%5269$s" "%5270$s" ++"%5271$s" "%5272$s" "%5273$s" "%5274$s" "%5275$s" "%5276$s" "%5277$s" "%5278$s" "%5279$s" "%5280$s" ++"%5281$s" "%5282$s" "%5283$s" "%5284$s" "%5285$s" "%5286$s" "%5287$s" "%5288$s" "%5289$s" "%5290$s" ++"%5291$s" "%5292$s" "%5293$s" "%5294$s" "%5295$s" "%5296$s" "%5297$s" "%5298$s" "%5299$s" "%5300$s" ++"%5301$s" "%5302$s" "%5303$s" "%5304$s" "%5305$s" "%5306$s" "%5307$s" "%5308$s" "%5309$s" "%5310$s" ++"%5311$s" "%5312$s" "%5313$s" "%5314$s" "%5315$s" "%5316$s" "%5317$s" "%5318$s" "%5319$s" "%5320$s" ++"%5321$s" "%5322$s" "%5323$s" "%5324$s" "%5325$s" "%5326$s" "%5327$s" "%5328$s" "%5329$s" "%5330$s" ++"%5331$s" "%5332$s" "%5333$s" "%5334$s" "%5335$s" "%5336$s" "%5337$s" "%5338$s" "%5339$s" "%5340$s" ++"%5341$s" "%5342$s" "%5343$s" "%5344$s" "%5345$s" "%5346$s" "%5347$s" "%5348$s" "%5349$s" "%5350$s" ++"%5351$s" "%5352$s" "%5353$s" "%5354$s" "%5355$s" "%5356$s" "%5357$s" "%5358$s" "%5359$s" "%5360$s" ++"%5361$s" "%5362$s" "%5363$s" "%5364$s" "%5365$s" "%5366$s" "%5367$s" "%5368$s" "%5369$s" "%5370$s" ++"%5371$s" "%5372$s" "%5373$s" "%5374$s" "%5375$s" "%5376$s" "%5377$s" "%5378$s" "%5379$s" "%5380$s" ++"%5381$s" "%5382$s" "%5383$s" "%5384$s" "%5385$s" "%5386$s" "%5387$s" "%5388$s" "%5389$s" "%5390$s" ++"%5391$s" "%5392$s" "%5393$s" "%5394$s" "%5395$s" "%5396$s" "%5397$s" "%5398$s" "%5399$s" "%5400$s" ++"%5401$s" "%5402$s" "%5403$s" "%5404$s" "%5405$s" "%5406$s" "%5407$s" "%5408$s" "%5409$s" "%5410$s" ++"%5411$s" "%5412$s" "%5413$s" "%5414$s" "%5415$s" "%5416$s" "%5417$s" "%5418$s" "%5419$s" "%5420$s" ++"%5421$s" "%5422$s" "%5423$s" "%5424$s" "%5425$s" "%5426$s" "%5427$s" "%5428$s" "%5429$s" "%5430$s" ++"%5431$s" "%5432$s" "%5433$s" "%5434$s" "%5435$s" "%5436$s" "%5437$s" "%5438$s" "%5439$s" "%5440$s" ++"%5441$s" "%5442$s" "%5443$s" "%5444$s" "%5445$s" "%5446$s" "%5447$s" "%5448$s" "%5449$s" "%5450$s" ++"%5451$s" "%5452$s" "%5453$s" "%5454$s" "%5455$s" "%5456$s" "%5457$s" "%5458$s" "%5459$s" "%5460$s" ++"%5461$s" "%5462$s" "%5463$s" "%5464$s" "%5465$s" "%5466$s" "%5467$s" "%5468$s" "%5469$s" "%5470$s" ++"%5471$s" "%5472$s" "%5473$s" "%5474$s" "%5475$s" "%5476$s" "%5477$s" "%5478$s" "%5479$s" "%5480$s" ++"%5481$s" "%5482$s" "%5483$s" "%5484$s" "%5485$s" "%5486$s" "%5487$s" "%5488$s" "%5489$s" "%5490$s" ++"%5491$s" "%5492$s" "%5493$s" "%5494$s" "%5495$s" "%5496$s" "%5497$s" "%5498$s" "%5499$s" "%5500$s" ++"%5501$s" "%5502$s" "%5503$s" "%5504$s" "%5505$s" "%5506$s" "%5507$s" "%5508$s" "%5509$s" "%5510$s" ++"%5511$s" "%5512$s" "%5513$s" "%5514$s" "%5515$s" "%5516$s" "%5517$s" "%5518$s" "%5519$s" "%5520$s" ++"%5521$s" "%5522$s" "%5523$s" "%5524$s" "%5525$s" "%5526$s" "%5527$s" "%5528$s" "%5529$s" "%5530$s" ++"%5531$s" "%5532$s" "%5533$s" "%5534$s" "%5535$s" "%5536$s" "%5537$s" "%5538$s" "%5539$s" "%5540$s" ++"%5541$s" "%5542$s" "%5543$s" "%5544$s" "%5545$s" "%5546$s" "%5547$s" "%5548$s" "%5549$s" "%5550$s" ++"%5551$s" "%5552$s" "%5553$s" "%5554$s" "%5555$s" "%5556$s" "%5557$s" "%5558$s" "%5559$s" "%5560$s" ++"%5561$s" "%5562$s" "%5563$s" "%5564$s" "%5565$s" "%5566$s" "%5567$s" "%5568$s" "%5569$s" "%5570$s" ++"%5571$s" "%5572$s" "%5573$s" "%5574$s" "%5575$s" "%5576$s" "%5577$s" "%5578$s" "%5579$s" "%5580$s" ++"%5581$s" "%5582$s" "%5583$s" "%5584$s" "%5585$s" "%5586$s" "%5587$s" "%5588$s" "%5589$s" "%5590$s" ++"%5591$s" "%5592$s" "%5593$s" "%5594$s" "%5595$s" "%5596$s" "%5597$s" "%5598$s" "%5599$s" "%5600$s" ++"%5601$s" "%5602$s" "%5603$s" "%5604$s" "%5605$s" "%5606$s" "%5607$s" "%5608$s" "%5609$s" "%5610$s" ++"%5611$s" "%5612$s" "%5613$s" "%5614$s" "%5615$s" "%5616$s" "%5617$s" "%5618$s" "%5619$s" "%5620$s" ++"%5621$s" "%5622$s" "%5623$s" "%5624$s" "%5625$s" "%5626$s" "%5627$s" "%5628$s" "%5629$s" "%5630$s" ++"%5631$s" "%5632$s" "%5633$s" "%5634$s" "%5635$s" "%5636$s" "%5637$s" "%5638$s" "%5639$s" "%5640$s" ++"%5641$s" "%5642$s" "%5643$s" "%5644$s" "%5645$s" "%5646$s" "%5647$s" "%5648$s" "%5649$s" "%5650$s" ++"%5651$s" "%5652$s" "%5653$s" "%5654$s" "%5655$s" "%5656$s" "%5657$s" "%5658$s" "%5659$s" "%5660$s" ++"%5661$s" "%5662$s" "%5663$s" "%5664$s" "%5665$s" "%5666$s" "%5667$s" "%5668$s" "%5669$s" "%5670$s" ++"%5671$s" "%5672$s" "%5673$s" "%5674$s" "%5675$s" "%5676$s" "%5677$s" "%5678$s" "%5679$s" "%5680$s" ++"%5681$s" "%5682$s" "%5683$s" "%5684$s" "%5685$s" "%5686$s" "%5687$s" "%5688$s" "%5689$s" "%5690$s" ++"%5691$s" "%5692$s" "%5693$s" "%5694$s" "%5695$s" "%5696$s" "%5697$s" "%5698$s" "%5699$s" "%5700$s" ++"%5701$s" "%5702$s" "%5703$s" "%5704$s" "%5705$s" "%5706$s" "%5707$s" "%5708$s" "%5709$s" "%5710$s" ++"%5711$s" "%5712$s" "%5713$s" "%5714$s" "%5715$s" "%5716$s" "%5717$s" "%5718$s" "%5719$s" "%5720$s" ++"%5721$s" "%5722$s" "%5723$s" "%5724$s" "%5725$s" "%5726$s" "%5727$s" "%5728$s" "%5729$s" "%5730$s" ++"%5731$s" "%5732$s" "%5733$s" "%5734$s" "%5735$s" "%5736$s" "%5737$s" "%5738$s" "%5739$s" "%5740$s" ++"%5741$s" "%5742$s" "%5743$s" "%5744$s" "%5745$s" "%5746$s" "%5747$s" "%5748$s" "%5749$s" "%5750$s" ++"%5751$s" "%5752$s" "%5753$s" "%5754$s" "%5755$s" "%5756$s" "%5757$s" "%5758$s" "%5759$s" "%5760$s" ++"%5761$s" "%5762$s" "%5763$s" "%5764$s" "%5765$s" "%5766$s" "%5767$s" "%5768$s" "%5769$s" "%5770$s" ++"%5771$s" "%5772$s" "%5773$s" "%5774$s" "%5775$s" "%5776$s" "%5777$s" "%5778$s" "%5779$s" "%5780$s" ++"%5781$s" "%5782$s" "%5783$s" "%5784$s" "%5785$s" "%5786$s" "%5787$s" "%5788$s" "%5789$s" "%5790$s" ++"%5791$s" "%5792$s" "%5793$s" "%5794$s" "%5795$s" "%5796$s" "%5797$s" "%5798$s" "%5799$s" "%5800$s" ++"%5801$s" "%5802$s" "%5803$s" "%5804$s" "%5805$s" "%5806$s" "%5807$s" "%5808$s" "%5809$s" "%5810$s" ++"%5811$s" "%5812$s" "%5813$s" "%5814$s" "%5815$s" "%5816$s" "%5817$s" "%5818$s" "%5819$s" "%5820$s" ++"%5821$s" "%5822$s" "%5823$s" "%5824$s" "%5825$s" "%5826$s" "%5827$s" "%5828$s" "%5829$s" "%5830$s" ++"%5831$s" "%5832$s" "%5833$s" "%5834$s" "%5835$s" "%5836$s" "%5837$s" "%5838$s" "%5839$s" "%5840$s" ++"%5841$s" "%5842$s" "%5843$s" "%5844$s" "%5845$s" "%5846$s" "%5847$s" "%5848$s" "%5849$s" "%5850$s" ++"%5851$s" "%5852$s" "%5853$s" "%5854$s" "%5855$s" "%5856$s" "%5857$s" "%5858$s" "%5859$s" "%5860$s" ++"%5861$s" "%5862$s" "%5863$s" "%5864$s" "%5865$s" "%5866$s" "%5867$s" "%5868$s" "%5869$s" "%5870$s" ++"%5871$s" "%5872$s" "%5873$s" "%5874$s" "%5875$s" "%5876$s" "%5877$s" "%5878$s" "%5879$s" "%5880$s" ++"%5881$s" "%5882$s" "%5883$s" "%5884$s" "%5885$s" "%5886$s" "%5887$s" "%5888$s" "%5889$s" "%5890$s" ++"%5891$s" "%5892$s" "%5893$s" "%5894$s" "%5895$s" "%5896$s" "%5897$s" "%5898$s" "%5899$s" "%5900$s" ++"%5901$s" "%5902$s" "%5903$s" "%5904$s" "%5905$s" "%5906$s" "%5907$s" "%5908$s" "%5909$s" "%5910$s" ++"%5911$s" "%5912$s" "%5913$s" "%5914$s" "%5915$s" "%5916$s" "%5917$s" "%5918$s" "%5919$s" "%5920$s" ++"%5921$s" "%5922$s" "%5923$s" "%5924$s" "%5925$s" "%5926$s" "%5927$s" "%5928$s" "%5929$s" "%5930$s" ++"%5931$s" "%5932$s" "%5933$s" "%5934$s" "%5935$s" "%5936$s" "%5937$s" "%5938$s" "%5939$s" "%5940$s" ++"%5941$s" "%5942$s" "%5943$s" "%5944$s" "%5945$s" "%5946$s" "%5947$s" "%5948$s" "%5949$s" "%5950$s" ++"%5951$s" "%5952$s" "%5953$s" "%5954$s" "%5955$s" "%5956$s" "%5957$s" "%5958$s" "%5959$s" "%5960$s" ++"%5961$s" "%5962$s" "%5963$s" "%5964$s" "%5965$s" "%5966$s" "%5967$s" "%5968$s" "%5969$s" "%5970$s" ++"%5971$s" "%5972$s" "%5973$s" "%5974$s" "%5975$s" "%5976$s" "%5977$s" "%5978$s" "%5979$s" "%5980$s" ++"%5981$s" "%5982$s" "%5983$s" "%5984$s" "%5985$s" "%5986$s" "%5987$s" "%5988$s" "%5989$s" "%5990$s" ++"%5991$s" "%5992$s" "%5993$s" "%5994$s" "%5995$s" "%5996$s" "%5997$s" "%5998$s" "%5999$s" "%6000$s" ++"%6001$s" "%6002$s" "%6003$s" "%6004$s" "%6005$s" "%6006$s" "%6007$s" "%6008$s" "%6009$s" "%6010$s" ++"%6011$s" "%6012$s" "%6013$s" "%6014$s" "%6015$s" "%6016$s" "%6017$s" "%6018$s" "%6019$s" "%6020$s" ++"%6021$s" "%6022$s" "%6023$s" "%6024$s" "%6025$s" "%6026$s" "%6027$s" "%6028$s" "%6029$s" "%6030$s" ++"%6031$s" "%6032$s" "%6033$s" "%6034$s" "%6035$s" "%6036$s" "%6037$s" "%6038$s" "%6039$s" "%6040$s" ++"%6041$s" "%6042$s" "%6043$s" "%6044$s" "%6045$s" "%6046$s" "%6047$s" "%6048$s" "%6049$s" "%6050$s" ++"%6051$s" "%6052$s" "%6053$s" "%6054$s" "%6055$s" "%6056$s" "%6057$s" "%6058$s" "%6059$s" "%6060$s" ++"%6061$s" "%6062$s" "%6063$s" "%6064$s" "%6065$s" "%6066$s" "%6067$s" "%6068$s" "%6069$s" "%6070$s" ++"%6071$s" "%6072$s" "%6073$s" "%6074$s" "%6075$s" "%6076$s" "%6077$s" "%6078$s" "%6079$s" "%6080$s" ++"%6081$s" "%6082$s" "%6083$s" "%6084$s" "%6085$s" "%6086$s" "%6087$s" "%6088$s" "%6089$s" "%6090$s" ++"%6091$s" "%6092$s" "%6093$s" "%6094$s" "%6095$s" "%6096$s" "%6097$s" "%6098$s" "%6099$s" "%6100$s" ++"%6101$s" "%6102$s" "%6103$s" "%6104$s" "%6105$s" "%6106$s" "%6107$s" "%6108$s" "%6109$s" "%6110$s" ++"%6111$s" "%6112$s" "%6113$s" "%6114$s" "%6115$s" "%6116$s" "%6117$s" "%6118$s" "%6119$s" "%6120$s" ++"%6121$s" "%6122$s" "%6123$s" "%6124$s" "%6125$s" "%6126$s" "%6127$s" "%6128$s" "%6129$s" "%6130$s" ++"%6131$s" "%6132$s" "%6133$s" "%6134$s" "%6135$s" "%6136$s" "%6137$s" "%6138$s" "%6139$s" "%6140$s" ++"%6141$s" "%6142$s" "%6143$s" "%6144$s" "%6145$s" "%6146$s" "%6147$s" "%6148$s" "%6149$s" "%6150$s" ++"%6151$s" "%6152$s" "%6153$s" "%6154$s" "%6155$s" "%6156$s" "%6157$s" "%6158$s" "%6159$s" "%6160$s" ++"%6161$s" "%6162$s" "%6163$s" "%6164$s" "%6165$s" "%6166$s" "%6167$s" "%6168$s" "%6169$s" "%6170$s" ++"%6171$s" "%6172$s" "%6173$s" "%6174$s" "%6175$s" "%6176$s" "%6177$s" "%6178$s" "%6179$s" "%6180$s" ++"%6181$s" "%6182$s" "%6183$s" "%6184$s" "%6185$s" "%6186$s" "%6187$s" "%6188$s" "%6189$s" "%6190$s" ++"%6191$s" "%6192$s" "%6193$s" "%6194$s" "%6195$s" "%6196$s" "%6197$s" "%6198$s" "%6199$s" "%6200$s" ++"%6201$s" "%6202$s" "%6203$s" "%6204$s" "%6205$s" "%6206$s" "%6207$s" "%6208$s" "%6209$s" "%6210$s" ++"%6211$s" "%6212$s" "%6213$s" "%6214$s" "%6215$s" "%6216$s" "%6217$s" "%6218$s" "%6219$s" "%6220$s" ++"%6221$s" "%6222$s" "%6223$s" "%6224$s" "%6225$s" "%6226$s" "%6227$s" "%6228$s" "%6229$s" "%6230$s" ++"%6231$s" "%6232$s" "%6233$s" "%6234$s" "%6235$s" "%6236$s" "%6237$s" "%6238$s" "%6239$s" "%6240$s" ++"%6241$s" "%6242$s" "%6243$s" "%6244$s" "%6245$s" "%6246$s" "%6247$s" "%6248$s" "%6249$s" "%6250$s" ++"%6251$s" "%6252$s" "%6253$s" "%6254$s" "%6255$s" "%6256$s" "%6257$s" "%6258$s" "%6259$s" "%6260$s" ++"%6261$s" "%6262$s" "%6263$s" "%6264$s" "%6265$s" "%6266$s" "%6267$s" "%6268$s" "%6269$s" "%6270$s" ++"%6271$s" "%6272$s" "%6273$s" "%6274$s" "%6275$s" "%6276$s" "%6277$s" "%6278$s" "%6279$s" "%6280$s" ++"%6281$s" "%6282$s" "%6283$s" "%6284$s" "%6285$s" "%6286$s" "%6287$s" "%6288$s" "%6289$s" "%6290$s" ++"%6291$s" "%6292$s" "%6293$s" "%6294$s" "%6295$s" "%6296$s" "%6297$s" "%6298$s" "%6299$s" "%6300$s" ++"%6301$s" "%6302$s" "%6303$s" "%6304$s" "%6305$s" "%6306$s" "%6307$s" "%6308$s" "%6309$s" "%6310$s" ++"%6311$s" "%6312$s" "%6313$s" "%6314$s" "%6315$s" "%6316$s" "%6317$s" "%6318$s" "%6319$s" "%6320$s" ++"%6321$s" "%6322$s" "%6323$s" "%6324$s" "%6325$s" "%6326$s" "%6327$s" "%6328$s" "%6329$s" "%6330$s" ++"%6331$s" "%6332$s" "%6333$s" "%6334$s" "%6335$s" "%6336$s" "%6337$s" "%6338$s" "%6339$s" "%6340$s" ++"%6341$s" "%6342$s" "%6343$s" "%6344$s" "%6345$s" "%6346$s" "%6347$s" "%6348$s" "%6349$s" "%6350$s" ++"%6351$s" "%6352$s" "%6353$s" "%6354$s" "%6355$s" "%6356$s" "%6357$s" "%6358$s" "%6359$s" "%6360$s" ++"%6361$s" "%6362$s" "%6363$s" "%6364$s" "%6365$s" "%6366$s" "%6367$s" "%6368$s" "%6369$s" "%6370$s" ++"%6371$s" "%6372$s" "%6373$s" "%6374$s" "%6375$s" "%6376$s" "%6377$s" "%6378$s" "%6379$s" "%6380$s" ++"%6381$s" "%6382$s" "%6383$s" "%6384$s" "%6385$s" "%6386$s" "%6387$s" "%6388$s" "%6389$s" "%6390$s" ++"%6391$s" "%6392$s" "%6393$s" "%6394$s" "%6395$s" "%6396$s" "%6397$s" "%6398$s" "%6399$s" "%6400$s" ++"%6401$s" "%6402$s" "%6403$s" "%6404$s" "%6405$s" "%6406$s" "%6407$s" "%6408$s" "%6409$s" "%6410$s" ++"%6411$s" "%6412$s" "%6413$s" "%6414$s" "%6415$s" "%6416$s" "%6417$s" "%6418$s" "%6419$s" "%6420$s" ++"%6421$s" "%6422$s" "%6423$s" "%6424$s" "%6425$s" "%6426$s" "%6427$s" "%6428$s" "%6429$s" "%6430$s" ++"%6431$s" "%6432$s" "%6433$s" "%6434$s" "%6435$s" "%6436$s" "%6437$s" "%6438$s" "%6439$s" "%6440$s" ++"%6441$s" "%6442$s" "%6443$s" "%6444$s" "%6445$s" "%6446$s" "%6447$s" "%6448$s" "%6449$s" "%6450$s" ++"%6451$s" "%6452$s" "%6453$s" "%6454$s" "%6455$s" "%6456$s" "%6457$s" "%6458$s" "%6459$s" "%6460$s" ++"%6461$s" "%6462$s" "%6463$s" "%6464$s" "%6465$s" "%6466$s" "%6467$s" "%6468$s" "%6469$s" "%6470$s" ++"%6471$s" "%6472$s" "%6473$s" "%6474$s" "%6475$s" "%6476$s" "%6477$s" "%6478$s" "%6479$s" "%6480$s" ++"%6481$s" "%6482$s" "%6483$s" "%6484$s" "%6485$s" "%6486$s" "%6487$s" "%6488$s" "%6489$s" "%6490$s" ++"%6491$s" "%6492$s" "%6493$s" "%6494$s" "%6495$s" "%6496$s" "%6497$s" "%6498$s" "%6499$s" "%6500$s" ++"%6501$s" "%6502$s" "%6503$s" "%6504$s" "%6505$s" "%6506$s" "%6507$s" "%6508$s" "%6509$s" "%6510$s" ++"%6511$s" "%6512$s" "%6513$s" "%6514$s" "%6515$s" "%6516$s" "%6517$s" "%6518$s" "%6519$s" "%6520$s" ++"%6521$s" "%6522$s" "%6523$s" "%6524$s" "%6525$s" "%6526$s" "%6527$s" "%6528$s" "%6529$s" "%6530$s" ++"%6531$s" "%6532$s" "%6533$s" "%6534$s" "%6535$s" "%6536$s" "%6537$s" "%6538$s" "%6539$s" "%6540$s" ++"%6541$s" "%6542$s" "%6543$s" "%6544$s" "%6545$s" "%6546$s" "%6547$s" "%6548$s" "%6549$s" "%6550$s" ++"%6551$s" "%6552$s" "%6553$s" "%6554$s" "%6555$s" "%6556$s" "%6557$s" "%6558$s" "%6559$s" "%6560$s" ++"%6561$s" "%6562$s" "%6563$s" "%6564$s" "%6565$s" "%6566$s" "%6567$s" "%6568$s" "%6569$s" "%6570$s" ++"%6571$s" "%6572$s" "%6573$s" "%6574$s" "%6575$s" "%6576$s" "%6577$s" "%6578$s" "%6579$s" "%6580$s" ++"%6581$s" "%6582$s" "%6583$s" "%6584$s" "%6585$s" "%6586$s" "%6587$s" "%6588$s" "%6589$s" "%6590$s" ++"%6591$s" "%6592$s" "%6593$s" "%6594$s" "%6595$s" "%6596$s" "%6597$s" "%6598$s" "%6599$s" "%6600$s" ++"%6601$s" "%6602$s" "%6603$s" "%6604$s" "%6605$s" "%6606$s" "%6607$s" "%6608$s" "%6609$s" "%6610$s" ++"%6611$s" "%6612$s" "%6613$s" "%6614$s" "%6615$s" "%6616$s" "%6617$s" "%6618$s" "%6619$s" "%6620$s" ++"%6621$s" "%6622$s" "%6623$s" "%6624$s" "%6625$s" "%6626$s" "%6627$s" "%6628$s" "%6629$s" "%6630$s" ++"%6631$s" "%6632$s" "%6633$s" "%6634$s" "%6635$s" "%6636$s" "%6637$s" "%6638$s" "%6639$s" "%6640$s" ++"%6641$s" "%6642$s" "%6643$s" "%6644$s" "%6645$s" "%6646$s" "%6647$s" "%6648$s" "%6649$s" "%6650$s" ++"%6651$s" "%6652$s" "%6653$s" "%6654$s" "%6655$s" "%6656$s" "%6657$s" "%6658$s" "%6659$s" "%6660$s" ++"%6661$s" "%6662$s" "%6663$s" "%6664$s" "%6665$s" "%6666$s" "%6667$s" "%6668$s" "%6669$s" "%6670$s" ++"%6671$s" "%6672$s" "%6673$s" "%6674$s" "%6675$s" "%6676$s" "%6677$s" "%6678$s" "%6679$s" "%6680$s" ++"%6681$s" "%6682$s" "%6683$s" "%6684$s" "%6685$s" "%6686$s" "%6687$s" "%6688$s" "%6689$s" "%6690$s" ++"%6691$s" "%6692$s" "%6693$s" "%6694$s" "%6695$s" "%6696$s" "%6697$s" "%6698$s" "%6699$s" "%6700$s" ++"%6701$s" "%6702$s" "%6703$s" "%6704$s" "%6705$s" "%6706$s" "%6707$s" "%6708$s" "%6709$s" "%6710$s" ++"%6711$s" "%6712$s" "%6713$s" "%6714$s" "%6715$s" "%6716$s" "%6717$s" "%6718$s" "%6719$s" "%6720$s" ++"%6721$s" "%6722$s" "%6723$s" "%6724$s" "%6725$s" "%6726$s" "%6727$s" "%6728$s" "%6729$s" "%6730$s" ++"%6731$s" "%6732$s" "%6733$s" "%6734$s" "%6735$s" "%6736$s" "%6737$s" "%6738$s" "%6739$s" "%6740$s" ++"%6741$s" "%6742$s" "%6743$s" "%6744$s" "%6745$s" "%6746$s" "%6747$s" "%6748$s" "%6749$s" "%6750$s" ++"%6751$s" "%6752$s" "%6753$s" "%6754$s" "%6755$s" "%6756$s" "%6757$s" "%6758$s" "%6759$s" "%6760$s" ++"%6761$s" "%6762$s" "%6763$s" "%6764$s" "%6765$s" "%6766$s" "%6767$s" "%6768$s" "%6769$s" "%6770$s" ++"%6771$s" "%6772$s" "%6773$s" "%6774$s" "%6775$s" "%6776$s" "%6777$s" "%6778$s" "%6779$s" "%6780$s" ++"%6781$s" "%6782$s" "%6783$s" "%6784$s" "%6785$s" "%6786$s" "%6787$s" "%6788$s" "%6789$s" "%6790$s" ++"%6791$s" "%6792$s" "%6793$s" "%6794$s" "%6795$s" "%6796$s" "%6797$s" "%6798$s" "%6799$s" "%6800$s" ++"%6801$s" "%6802$s" "%6803$s" "%6804$s" "%6805$s" "%6806$s" "%6807$s" "%6808$s" "%6809$s" "%6810$s" ++"%6811$s" "%6812$s" "%6813$s" "%6814$s" "%6815$s" "%6816$s" "%6817$s" "%6818$s" "%6819$s" "%6820$s" ++"%6821$s" "%6822$s" "%6823$s" "%6824$s" "%6825$s" "%6826$s" "%6827$s" "%6828$s" "%6829$s" "%6830$s" ++"%6831$s" "%6832$s" "%6833$s" "%6834$s" "%6835$s" "%6836$s" "%6837$s" "%6838$s" "%6839$s" "%6840$s" ++"%6841$s" "%6842$s" "%6843$s" "%6844$s" "%6845$s" "%6846$s" "%6847$s" "%6848$s" "%6849$s" "%6850$s" ++"%6851$s" "%6852$s" "%6853$s" "%6854$s" "%6855$s" "%6856$s" "%6857$s" "%6858$s" "%6859$s" "%6860$s" ++"%6861$s" "%6862$s" "%6863$s" "%6864$s" "%6865$s" "%6866$s" "%6867$s" "%6868$s" "%6869$s" "%6870$s" ++"%6871$s" "%6872$s" "%6873$s" "%6874$s" "%6875$s" "%6876$s" "%6877$s" "%6878$s" "%6879$s" "%6880$s" ++"%6881$s" "%6882$s" "%6883$s" "%6884$s" "%6885$s" "%6886$s" "%6887$s" "%6888$s" "%6889$s" "%6890$s" ++"%6891$s" "%6892$s" "%6893$s" "%6894$s" "%6895$s" "%6896$s" "%6897$s" "%6898$s" "%6899$s" "%6900$s" ++"%6901$s" "%6902$s" "%6903$s" "%6904$s" "%6905$s" "%6906$s" "%6907$s" "%6908$s" "%6909$s" "%6910$s" ++"%6911$s" "%6912$s" "%6913$s" "%6914$s" "%6915$s" "%6916$s" "%6917$s" "%6918$s" "%6919$s" "%6920$s" ++"%6921$s" "%6922$s" "%6923$s" "%6924$s" "%6925$s" "%6926$s" "%6927$s" "%6928$s" "%6929$s" "%6930$s" ++"%6931$s" "%6932$s" "%6933$s" "%6934$s" "%6935$s" "%6936$s" "%6937$s" "%6938$s" "%6939$s" "%6940$s" ++"%6941$s" "%6942$s" "%6943$s" "%6944$s" "%6945$s" "%6946$s" "%6947$s" "%6948$s" "%6949$s" "%6950$s" ++"%6951$s" "%6952$s" "%6953$s" "%6954$s" "%6955$s" "%6956$s" "%6957$s" "%6958$s" "%6959$s" "%6960$s" ++"%6961$s" "%6962$s" "%6963$s" "%6964$s" "%6965$s" "%6966$s" "%6967$s" "%6968$s" "%6969$s" "%6970$s" ++"%6971$s" "%6972$s" "%6973$s" "%6974$s" "%6975$s" "%6976$s" "%6977$s" "%6978$s" "%6979$s" "%6980$s" ++"%6981$s" "%6982$s" "%6983$s" "%6984$s" "%6985$s" "%6986$s" "%6987$s" "%6988$s" "%6989$s" "%6990$s" ++"%6991$s" "%6992$s" "%6993$s" "%6994$s" "%6995$s" "%6996$s" "%6997$s" "%6998$s" "%6999$s" "%7000$s" ++"%7001$s" "%7002$s" "%7003$s" "%7004$s" "%7005$s" "%7006$s" "%7007$s" "%7008$s" "%7009$s" "%7010$s" ++"%7011$s" "%7012$s" "%7013$s" "%7014$s" "%7015$s" "%7016$s" "%7017$s" "%7018$s" "%7019$s" "%7020$s" ++"%7021$s" "%7022$s" "%7023$s" "%7024$s" "%7025$s" "%7026$s" "%7027$s" "%7028$s" "%7029$s" "%7030$s" ++"%7031$s" "%7032$s" "%7033$s" "%7034$s" "%7035$s" "%7036$s" "%7037$s" "%7038$s" "%7039$s" "%7040$s" ++"%7041$s" "%7042$s" "%7043$s" "%7044$s" "%7045$s" "%7046$s" "%7047$s" "%7048$s" "%7049$s" "%7050$s" ++"%7051$s" "%7052$s" "%7053$s" "%7054$s" "%7055$s" "%7056$s" "%7057$s" "%7058$s" "%7059$s" "%7060$s" ++"%7061$s" "%7062$s" "%7063$s" "%7064$s" "%7065$s" "%7066$s" "%7067$s" "%7068$s" "%7069$s" "%7070$s" ++"%7071$s" "%7072$s" "%7073$s" "%7074$s" "%7075$s" "%7076$s" "%7077$s" "%7078$s" "%7079$s" "%7080$s" ++"%7081$s" "%7082$s" "%7083$s" "%7084$s" "%7085$s" "%7086$s" "%7087$s" "%7088$s" "%7089$s" "%7090$s" ++"%7091$s" "%7092$s" "%7093$s" "%7094$s" "%7095$s" "%7096$s" "%7097$s" "%7098$s" "%7099$s" "%7100$s" ++"%7101$s" "%7102$s" "%7103$s" "%7104$s" "%7105$s" "%7106$s" "%7107$s" "%7108$s" "%7109$s" "%7110$s" ++"%7111$s" "%7112$s" "%7113$s" "%7114$s" "%7115$s" "%7116$s" "%7117$s" "%7118$s" "%7119$s" "%7120$s" ++"%7121$s" "%7122$s" "%7123$s" "%7124$s" "%7125$s" "%7126$s" "%7127$s" "%7128$s" "%7129$s" "%7130$s" ++"%7131$s" "%7132$s" "%7133$s" "%7134$s" "%7135$s" "%7136$s" "%7137$s" "%7138$s" "%7139$s" "%7140$s" ++"%7141$s" "%7142$s" "%7143$s" "%7144$s" "%7145$s" "%7146$s" "%7147$s" "%7148$s" "%7149$s" "%7150$s" ++"%7151$s" "%7152$s" "%7153$s" "%7154$s" "%7155$s" "%7156$s" "%7157$s" "%7158$s" "%7159$s" "%7160$s" ++"%7161$s" "%7162$s" "%7163$s" "%7164$s" "%7165$s" "%7166$s" "%7167$s" "%7168$s" "%7169$s" "%7170$s" ++"%7171$s" "%7172$s" "%7173$s" "%7174$s" "%7175$s" "%7176$s" "%7177$s" "%7178$s" "%7179$s" "%7180$s" ++"%7181$s" "%7182$s" "%7183$s" "%7184$s" "%7185$s" "%7186$s" "%7187$s" "%7188$s" "%7189$s" "%7190$s" ++"%7191$s" "%7192$s" "%7193$s" "%7194$s" "%7195$s" "%7196$s" "%7197$s" "%7198$s" "%7199$s" "%7200$s" ++"%7201$s" "%7202$s" "%7203$s" "%7204$s" "%7205$s" "%7206$s" "%7207$s" "%7208$s" "%7209$s" "%7210$s" ++"%7211$s" "%7212$s" "%7213$s" "%7214$s" "%7215$s" "%7216$s" "%7217$s" "%7218$s" "%7219$s" "%7220$s" ++"%7221$s" "%7222$s" "%7223$s" "%7224$s" "%7225$s" "%7226$s" "%7227$s" "%7228$s" "%7229$s" "%7230$s" ++"%7231$s" "%7232$s" "%7233$s" "%7234$s" "%7235$s" "%7236$s" "%7237$s" "%7238$s" "%7239$s" "%7240$s" ++"%7241$s" "%7242$s" "%7243$s" "%7244$s" "%7245$s" "%7246$s" "%7247$s" "%7248$s" "%7249$s" "%7250$s" ++"%7251$s" "%7252$s" "%7253$s" "%7254$s" "%7255$s" "%7256$s" "%7257$s" "%7258$s" "%7259$s" "%7260$s" ++"%7261$s" "%7262$s" "%7263$s" "%7264$s" "%7265$s" "%7266$s" "%7267$s" "%7268$s" "%7269$s" "%7270$s" ++"%7271$s" "%7272$s" "%7273$s" "%7274$s" "%7275$s" "%7276$s" "%7277$s" "%7278$s" "%7279$s" "%7280$s" ++"%7281$s" "%7282$s" "%7283$s" "%7284$s" "%7285$s" "%7286$s" "%7287$s" "%7288$s" "%7289$s" "%7290$s" ++"%7291$s" "%7292$s" "%7293$s" "%7294$s" "%7295$s" "%7296$s" "%7297$s" "%7298$s" "%7299$s" "%7300$s" ++"%7301$s" "%7302$s" "%7303$s" "%7304$s" "%7305$s" "%7306$s" "%7307$s" "%7308$s" "%7309$s" "%7310$s" ++"%7311$s" "%7312$s" "%7313$s" "%7314$s" "%7315$s" "%7316$s" "%7317$s" "%7318$s" "%7319$s" "%7320$s" ++"%7321$s" "%7322$s" "%7323$s" "%7324$s" "%7325$s" "%7326$s" "%7327$s" "%7328$s" "%7329$s" "%7330$s" ++"%7331$s" "%7332$s" "%7333$s" "%7334$s" "%7335$s" "%7336$s" "%7337$s" "%7338$s" "%7339$s" "%7340$s" ++"%7341$s" "%7342$s" "%7343$s" "%7344$s" "%7345$s" "%7346$s" "%7347$s" "%7348$s" "%7349$s" "%7350$s" ++"%7351$s" "%7352$s" "%7353$s" "%7354$s" "%7355$s" "%7356$s" "%7357$s" "%7358$s" "%7359$s" "%7360$s" ++"%7361$s" "%7362$s" "%7363$s" "%7364$s" "%7365$s" "%7366$s" "%7367$s" "%7368$s" "%7369$s" "%7370$s" ++"%7371$s" "%7372$s" "%7373$s" "%7374$s" "%7375$s" "%7376$s" "%7377$s" "%7378$s" "%7379$s" "%7380$s" ++"%7381$s" "%7382$s" "%7383$s" "%7384$s" "%7385$s" "%7386$s" "%7387$s" "%7388$s" "%7389$s" "%7390$s" ++"%7391$s" "%7392$s" "%7393$s" "%7394$s" "%7395$s" "%7396$s" "%7397$s" "%7398$s" "%7399$s" "%7400$s" ++"%7401$s" "%7402$s" "%7403$s" "%7404$s" "%7405$s" "%7406$s" "%7407$s" "%7408$s" "%7409$s" "%7410$s" ++"%7411$s" "%7412$s" "%7413$s" "%7414$s" "%7415$s" "%7416$s" "%7417$s" "%7418$s" "%7419$s" "%7420$s" ++"%7421$s" "%7422$s" "%7423$s" "%7424$s" "%7425$s" "%7426$s" "%7427$s" "%7428$s" "%7429$s" "%7430$s" ++"%7431$s" "%7432$s" "%7433$s" "%7434$s" "%7435$s" "%7436$s" "%7437$s" "%7438$s" "%7439$s" "%7440$s" ++"%7441$s" "%7442$s" "%7443$s" "%7444$s" "%7445$s" "%7446$s" "%7447$s" "%7448$s" "%7449$s" "%7450$s" ++"%7451$s" "%7452$s" "%7453$s" "%7454$s" "%7455$s" "%7456$s" "%7457$s" "%7458$s" "%7459$s" "%7460$s" ++"%7461$s" "%7462$s" "%7463$s" "%7464$s" "%7465$s" "%7466$s" "%7467$s" "%7468$s" "%7469$s" "%7470$s" ++"%7471$s" "%7472$s" "%7473$s" "%7474$s" "%7475$s" "%7476$s" "%7477$s" "%7478$s" "%7479$s" "%7480$s" ++"%7481$s" "%7482$s" "%7483$s" "%7484$s" "%7485$s" "%7486$s" "%7487$s" "%7488$s" "%7489$s" "%7490$s" ++"%7491$s" "%7492$s" "%7493$s" "%7494$s" "%7495$s" "%7496$s" "%7497$s" "%7498$s" "%7499$s" "%7500$s" ++"%7501$s" "%7502$s" "%7503$s" "%7504$s" "%7505$s" "%7506$s" "%7507$s" "%7508$s" "%7509$s" "%7510$s" ++"%7511$s" "%7512$s" "%7513$s" "%7514$s" "%7515$s" "%7516$s" "%7517$s" "%7518$s" "%7519$s" "%7520$s" ++"%7521$s" "%7522$s" "%7523$s" "%7524$s" "%7525$s" "%7526$s" "%7527$s" "%7528$s" "%7529$s" "%7530$s" ++"%7531$s" "%7532$s" "%7533$s" "%7534$s" "%7535$s" "%7536$s" "%7537$s" "%7538$s" "%7539$s" "%7540$s" ++"%7541$s" "%7542$s" "%7543$s" "%7544$s" "%7545$s" "%7546$s" "%7547$s" "%7548$s" "%7549$s" "%7550$s" ++"%7551$s" "%7552$s" "%7553$s" "%7554$s" "%7555$s" "%7556$s" "%7557$s" "%7558$s" "%7559$s" "%7560$s" ++"%7561$s" "%7562$s" "%7563$s" "%7564$s" "%7565$s" "%7566$s" "%7567$s" "%7568$s" "%7569$s" "%7570$s" ++"%7571$s" "%7572$s" "%7573$s" "%7574$s" "%7575$s" "%7576$s" "%7577$s" "%7578$s" "%7579$s" "%7580$s" ++"%7581$s" "%7582$s" "%7583$s" "%7584$s" "%7585$s" "%7586$s" "%7587$s" "%7588$s" "%7589$s" "%7590$s" ++"%7591$s" "%7592$s" "%7593$s" "%7594$s" "%7595$s" "%7596$s" "%7597$s" "%7598$s" "%7599$s" "%7600$s" ++"%7601$s" "%7602$s" "%7603$s" "%7604$s" "%7605$s" "%7606$s" "%7607$s" "%7608$s" "%7609$s" "%7610$s" ++"%7611$s" "%7612$s" "%7613$s" "%7614$s" "%7615$s" "%7616$s" "%7617$s" "%7618$s" "%7619$s" "%7620$s" ++"%7621$s" "%7622$s" "%7623$s" "%7624$s" "%7625$s" "%7626$s" "%7627$s" "%7628$s" "%7629$s" "%7630$s" ++"%7631$s" "%7632$s" "%7633$s" "%7634$s" "%7635$s" "%7636$s" "%7637$s" "%7638$s" "%7639$s" "%7640$s" ++"%7641$s" "%7642$s" "%7643$s" "%7644$s" "%7645$s" "%7646$s" "%7647$s" "%7648$s" "%7649$s" "%7650$s" ++"%7651$s" "%7652$s" "%7653$s" "%7654$s" "%7655$s" "%7656$s" "%7657$s" "%7658$s" "%7659$s" "%7660$s" ++"%7661$s" "%7662$s" "%7663$s" "%7664$s" "%7665$s" "%7666$s" "%7667$s" "%7668$s" "%7669$s" "%7670$s" ++"%7671$s" "%7672$s" "%7673$s" "%7674$s" "%7675$s" "%7676$s" "%7677$s" "%7678$s" "%7679$s" "%7680$s" ++"%7681$s" "%7682$s" "%7683$s" "%7684$s" "%7685$s" "%7686$s" "%7687$s" "%7688$s" "%7689$s" "%7690$s" ++"%7691$s" "%7692$s" "%7693$s" "%7694$s" "%7695$s" "%7696$s" "%7697$s" "%7698$s" "%7699$s" "%7700$s" ++"%7701$s" "%7702$s" "%7703$s" "%7704$s" "%7705$s" "%7706$s" "%7707$s" "%7708$s" "%7709$s" "%7710$s" ++"%7711$s" "%7712$s" "%7713$s" "%7714$s" "%7715$s" "%7716$s" "%7717$s" "%7718$s" "%7719$s" "%7720$s" ++"%7721$s" "%7722$s" "%7723$s" "%7724$s" "%7725$s" "%7726$s" "%7727$s" "%7728$s" "%7729$s" "%7730$s" ++"%7731$s" "%7732$s" "%7733$s" "%7734$s" "%7735$s" "%7736$s" "%7737$s" "%7738$s" "%7739$s" "%7740$s" ++"%7741$s" "%7742$s" "%7743$s" "%7744$s" "%7745$s" "%7746$s" "%7747$s" "%7748$s" "%7749$s" "%7750$s" ++"%7751$s" "%7752$s" "%7753$s" "%7754$s" "%7755$s" "%7756$s" "%7757$s" "%7758$s" "%7759$s" "%7760$s" ++"%7761$s" "%7762$s" "%7763$s" "%7764$s" "%7765$s" "%7766$s" "%7767$s" "%7768$s" "%7769$s" "%7770$s" ++"%7771$s" "%7772$s" "%7773$s" "%7774$s" "%7775$s" "%7776$s" "%7777$s" "%7778$s" "%7779$s" "%7780$s" ++"%7781$s" "%7782$s" "%7783$s" "%7784$s" "%7785$s" "%7786$s" "%7787$s" "%7788$s" "%7789$s" "%7790$s" ++"%7791$s" "%7792$s" "%7793$s" "%7794$s" "%7795$s" "%7796$s" "%7797$s" "%7798$s" "%7799$s" "%7800$s" ++"%7801$s" "%7802$s" "%7803$s" "%7804$s" "%7805$s" "%7806$s" "%7807$s" "%7808$s" "%7809$s" "%7810$s" ++"%7811$s" "%7812$s" "%7813$s" "%7814$s" "%7815$s" "%7816$s" "%7817$s" "%7818$s" "%7819$s" "%7820$s" ++"%7821$s" "%7822$s" "%7823$s" "%7824$s" "%7825$s" "%7826$s" "%7827$s" "%7828$s" "%7829$s" "%7830$s" ++"%7831$s" "%7832$s" "%7833$s" "%7834$s" "%7835$s" "%7836$s" "%7837$s" "%7838$s" "%7839$s" "%7840$s" ++"%7841$s" "%7842$s" "%7843$s" "%7844$s" "%7845$s" "%7846$s" "%7847$s" "%7848$s" "%7849$s" "%7850$s" ++"%7851$s" "%7852$s" "%7853$s" "%7854$s" "%7855$s" "%7856$s" "%7857$s" "%7858$s" "%7859$s" "%7860$s" ++"%7861$s" "%7862$s" "%7863$s" "%7864$s" "%7865$s" "%7866$s" "%7867$s" "%7868$s" "%7869$s" "%7870$s" ++"%7871$s" "%7872$s" "%7873$s" "%7874$s" "%7875$s" "%7876$s" "%7877$s" "%7878$s" "%7879$s" "%7880$s" ++"%7881$s" "%7882$s" "%7883$s" "%7884$s" "%7885$s" "%7886$s" "%7887$s" "%7888$s" "%7889$s" "%7890$s" ++"%7891$s" "%7892$s" "%7893$s" "%7894$s" "%7895$s" "%7896$s" "%7897$s" "%7898$s" "%7899$s" "%7900$s" ++"%7901$s" "%7902$s" "%7903$s" "%7904$s" "%7905$s" "%7906$s" "%7907$s" "%7908$s" "%7909$s" "%7910$s" ++"%7911$s" "%7912$s" "%7913$s" "%7914$s" "%7915$s" "%7916$s" "%7917$s" "%7918$s" "%7919$s" "%7920$s" ++"%7921$s" "%7922$s" "%7923$s" "%7924$s" "%7925$s" "%7926$s" "%7927$s" "%7928$s" "%7929$s" "%7930$s" ++"%7931$s" "%7932$s" "%7933$s" "%7934$s" "%7935$s" "%7936$s" "%7937$s" "%7938$s" "%7939$s" "%7940$s" ++"%7941$s" "%7942$s" "%7943$s" "%7944$s" "%7945$s" "%7946$s" "%7947$s" "%7948$s" "%7949$s" "%7950$s" ++"%7951$s" "%7952$s" "%7953$s" "%7954$s" "%7955$s" "%7956$s" "%7957$s" "%7958$s" "%7959$s" "%7960$s" ++"%7961$s" "%7962$s" "%7963$s" "%7964$s" "%7965$s" "%7966$s" "%7967$s" "%7968$s" "%7969$s" "%7970$s" ++"%7971$s" "%7972$s" "%7973$s" "%7974$s" "%7975$s" "%7976$s" "%7977$s" "%7978$s" "%7979$s" "%7980$s" ++"%7981$s" "%7982$s" "%7983$s" "%7984$s" "%7985$s" "%7986$s" "%7987$s" "%7988$s" "%7989$s" "%7990$s" ++"%7991$s" "%7992$s" "%7993$s" "%7994$s" "%7995$s" "%7996$s" "%7997$s" "%7998$s" "%7999$s" "%8000$s" ++"%8001$s" "%8002$s" "%8003$s" "%8004$s" "%8005$s" "%8006$s" "%8007$s" "%8008$s" "%8009$s" "%8010$s" ++"%8011$s" "%8012$s" "%8013$s" "%8014$s" "%8015$s" "%8016$s" "%8017$s" "%8018$s" "%8019$s" "%8020$s" ++"%8021$s" "%8022$s" "%8023$s" "%8024$s" "%8025$s" "%8026$s" "%8027$s" "%8028$s" "%8029$s" "%8030$s" ++"%8031$s" "%8032$s" "%8033$s" "%8034$s" "%8035$s" "%8036$s" "%8037$s" "%8038$s" "%8039$s" "%8040$s" ++"%8041$s" "%8042$s" "%8043$s" "%8044$s" "%8045$s" "%8046$s" "%8047$s" "%8048$s" "%8049$s" "%8050$s" ++"%8051$s" "%8052$s" "%8053$s" "%8054$s" "%8055$s" "%8056$s" "%8057$s" "%8058$s" "%8059$s" "%8060$s" ++"%8061$s" "%8062$s" "%8063$s" "%8064$s" "%8065$s" "%8066$s" "%8067$s" "%8068$s" "%8069$s" "%8070$s" ++"%8071$s" "%8072$s" "%8073$s" "%8074$s" "%8075$s" "%8076$s" "%8077$s" "%8078$s" "%8079$s" "%8080$s" ++"%8081$s" "%8082$s" "%8083$s" "%8084$s" "%8085$s" "%8086$s" "%8087$s" "%8088$s" "%8089$s" "%8090$s" ++"%8091$s" "%8092$s" "%8093$s" "%8094$s" "%8095$s" "%8096$s" "%8097$s" "%8098$s" "%8099$s" "%8100$s" ++"%8101$s" "%8102$s" "%8103$s" "%8104$s" "%8105$s" "%8106$s" "%8107$s" "%8108$s" "%8109$s" "%8110$s" ++"%8111$s" "%8112$s" "%8113$s" "%8114$s" "%8115$s" "%8116$s" "%8117$s" "%8118$s" "%8119$s" "%8120$s" ++"%8121$s" "%8122$s" "%8123$s" "%8124$s" "%8125$s" "%8126$s" "%8127$s" "%8128$s" "%8129$s" "%8130$s" ++"%8131$s" "%8132$s" "%8133$s" "%8134$s" "%8135$s" "%8136$s" "%8137$s" "%8138$s" "%8139$s" "%8140$s" ++"%8141$s" "%8142$s" "%8143$s" "%8144$s" "%8145$s" "%8146$s" "%8147$s" "%8148$s" "%8149$s" "%8150$s" ++"%8151$s" "%8152$s" "%8153$s" "%8154$s" "%8155$s" "%8156$s" "%8157$s" "%8158$s" "%8159$s" "%8160$s" ++"%8161$s" "%8162$s" "%8163$s" "%8164$s" "%8165$s" "%8166$s" "%8167$s" "%8168$s" "%8169$s" "%8170$s" ++"%8171$s" "%8172$s" "%8173$s" "%8174$s" "%8175$s" "%8176$s" "%8177$s" "%8178$s" "%8179$s" "%8180$s" ++"%8181$s" "%8182$s" "%8183$s" "%8184$s" "%8185$s" "%8186$s" "%8187$s" "%8188$s" "%8189$s" "%8190$s" ++"%8191$s" "%8192$s" "%8193$s" "%8194$s" "%8195$s" "%8196$s" "%8197$s" "%8198$s" "%8199$s" "%8200$s" ++"%8201$s" "%8202$s" "%8203$s" "%8204$s" "%8205$s" "%8206$s" "%8207$s" "%8208$s" "%8209$s" "%8210$s" ++"%8211$s" "%8212$s" "%8213$s" "%8214$s" "%8215$s" "%8216$s" "%8217$s" "%8218$s" "%8219$s" "%8220$s" ++"%8221$s" "%8222$s" "%8223$s" "%8224$s" "%8225$s" "%8226$s" "%8227$s" "%8228$s" "%8229$s" "%8230$s" ++"%8231$s" "%8232$s" "%8233$s" "%8234$s" "%8235$s" "%8236$s" "%8237$s" "%8238$s" "%8239$s" "%8240$s" ++"%8241$s" "%8242$s" "%8243$s" "%8244$s" "%8245$s" "%8246$s" "%8247$s" "%8248$s" "%8249$s" "%8250$s" ++"%8251$s" "%8252$s" "%8253$s" "%8254$s" "%8255$s" "%8256$s" "%8257$s" "%8258$s" "%8259$s" "%8260$s" ++"%8261$s" "%8262$s" "%8263$s" "%8264$s" "%8265$s" "%8266$s" "%8267$s" "%8268$s" "%8269$s" "%8270$s" ++"%8271$s" "%8272$s" "%8273$s" "%8274$s" "%8275$s" "%8276$s" "%8277$s" "%8278$s" "%8279$s" "%8280$s" ++"%8281$s" "%8282$s" "%8283$s" "%8284$s" "%8285$s" "%8286$s" "%8287$s" "%8288$s" "%8289$s" "%8290$s" ++"%8291$s" "%8292$s" "%8293$s" "%8294$s" "%8295$s" "%8296$s" "%8297$s" "%8298$s" "%8299$s" "%8300$s" ++"%8301$s" "%8302$s" "%8303$s" "%8304$s" "%8305$s" "%8306$s" "%8307$s" "%8308$s" "%8309$s" "%8310$s" ++"%8311$s" "%8312$s" "%8313$s" "%8314$s" "%8315$s" "%8316$s" "%8317$s" "%8318$s" "%8319$s" "%8320$s" ++"%8321$s" "%8322$s" "%8323$s" "%8324$s" "%8325$s" "%8326$s" "%8327$s" "%8328$s" "%8329$s" "%8330$s" ++"%8331$s" "%8332$s" "%8333$s" "%8334$s" "%8335$s" "%8336$s" "%8337$s" "%8338$s" "%8339$s" "%8340$s" ++"%8341$s" "%8342$s" "%8343$s" "%8344$s" "%8345$s" "%8346$s" "%8347$s" "%8348$s" "%8349$s" "%8350$s" ++"%8351$s" "%8352$s" "%8353$s" "%8354$s" "%8355$s" "%8356$s" "%8357$s" "%8358$s" "%8359$s" "%8360$s" ++"%8361$s" "%8362$s" "%8363$s" "%8364$s" "%8365$s" "%8366$s" "%8367$s" "%8368$s" "%8369$s" "%8370$s" ++"%8371$s" "%8372$s" "%8373$s" "%8374$s" "%8375$s" "%8376$s" "%8377$s" "%8378$s" "%8379$s" "%8380$s" ++"%8381$s" "%8382$s" "%8383$s" "%8384$s" "%8385$s" "%8386$s" "%8387$s" "%8388$s" "%8389$s" "%8390$s" ++"%8391$s" "%8392$s" "%8393$s" "%8394$s" "%8395$s" "%8396$s" "%8397$s" "%8398$s" "%8399$s" "%8400$s" ++"%8401$s" "%8402$s" "%8403$s" "%8404$s" "%8405$s" "%8406$s" "%8407$s" "%8408$s" "%8409$s" "%8410$s" ++"%8411$s" "%8412$s" "%8413$s" "%8414$s" "%8415$s" "%8416$s" "%8417$s" "%8418$s" "%8419$s" "%8420$s" ++"%8421$s" "%8422$s" "%8423$s" "%8424$s" "%8425$s" "%8426$s" "%8427$s" "%8428$s" "%8429$s" "%8430$s" ++"%8431$s" "%8432$s" "%8433$s" "%8434$s" "%8435$s" "%8436$s" "%8437$s" "%8438$s" "%8439$s" "%8440$s" ++"%8441$s" "%8442$s" "%8443$s" "%8444$s" "%8445$s" "%8446$s" "%8447$s" "%8448$s" "%8449$s" "%8450$s" ++"%8451$s" "%8452$s" "%8453$s" "%8454$s" "%8455$s" "%8456$s" "%8457$s" "%8458$s" "%8459$s" "%8460$s" ++"%8461$s" "%8462$s" "%8463$s" "%8464$s" "%8465$s" "%8466$s" "%8467$s" "%8468$s" "%8469$s" "%8470$s" ++"%8471$s" "%8472$s" "%8473$s" "%8474$s" "%8475$s" "%8476$s" "%8477$s" "%8478$s" "%8479$s" "%8480$s" ++"%8481$s" "%8482$s" "%8483$s" "%8484$s" "%8485$s" "%8486$s" "%8487$s" "%8488$s" "%8489$s" "%8490$s" ++"%8491$s" "%8492$s" "%8493$s" "%8494$s" "%8495$s" "%8496$s" "%8497$s" "%8498$s" "%8499$s" "%8500$s" ++"%8501$s" "%8502$s" "%8503$s" "%8504$s" "%8505$s" "%8506$s" "%8507$s" "%8508$s" "%8509$s" "%8510$s" ++"%8511$s" "%8512$s" "%8513$s" "%8514$s" "%8515$s" "%8516$s" "%8517$s" "%8518$s" "%8519$s" "%8520$s" ++"%8521$s" "%8522$s" "%8523$s" "%8524$s" "%8525$s" "%8526$s" "%8527$s" "%8528$s" "%8529$s" "%8530$s" ++"%8531$s" "%8532$s" "%8533$s" "%8534$s" "%8535$s" "%8536$s" "%8537$s" "%8538$s" "%8539$s" "%8540$s" ++"%8541$s" "%8542$s" "%8543$s" "%8544$s" "%8545$s" "%8546$s" "%8547$s" "%8548$s" "%8549$s" "%8550$s" ++"%8551$s" "%8552$s" "%8553$s" "%8554$s" "%8555$s" "%8556$s" "%8557$s" "%8558$s" "%8559$s" "%8560$s" ++"%8561$s" "%8562$s" "%8563$s" "%8564$s" "%8565$s" "%8566$s" "%8567$s" "%8568$s" "%8569$s" "%8570$s" ++"%8571$s" "%8572$s" "%8573$s" "%8574$s" "%8575$s" "%8576$s" "%8577$s" "%8578$s" "%8579$s" "%8580$s" ++"%8581$s" "%8582$s" "%8583$s" "%8584$s" "%8585$s" "%8586$s" "%8587$s" "%8588$s" "%8589$s" "%8590$s" ++"%8591$s" "%8592$s" "%8593$s" "%8594$s" "%8595$s" "%8596$s" "%8597$s" "%8598$s" "%8599$s" "%8600$s" ++"%8601$s" "%8602$s" "%8603$s" "%8604$s" "%8605$s" "%8606$s" "%8607$s" "%8608$s" "%8609$s" "%8610$s" ++"%8611$s" "%8612$s" "%8613$s" "%8614$s" "%8615$s" "%8616$s" "%8617$s" "%8618$s" "%8619$s" "%8620$s" ++"%8621$s" "%8622$s" "%8623$s" "%8624$s" "%8625$s" "%8626$s" "%8627$s" "%8628$s" "%8629$s" "%8630$s" ++"%8631$s" "%8632$s" "%8633$s" "%8634$s" "%8635$s" "%8636$s" "%8637$s" "%8638$s" "%8639$s" "%8640$s" ++"%8641$s" "%8642$s" "%8643$s" "%8644$s" "%8645$s" "%8646$s" "%8647$s" "%8648$s" "%8649$s" "%8650$s" ++"%8651$s" "%8652$s" "%8653$s" "%8654$s" "%8655$s" "%8656$s" "%8657$s" "%8658$s" "%8659$s" "%8660$s" ++"%8661$s" "%8662$s" "%8663$s" "%8664$s" "%8665$s" "%8666$s" "%8667$s" "%8668$s" "%8669$s" "%8670$s" ++"%8671$s" "%8672$s" "%8673$s" "%8674$s" "%8675$s" "%8676$s" "%8677$s" "%8678$s" "%8679$s" "%8680$s" ++"%8681$s" "%8682$s" "%8683$s" "%8684$s" "%8685$s" "%8686$s" "%8687$s" "%8688$s" "%8689$s" "%8690$s" ++"%8691$s" "%8692$s" "%8693$s" "%8694$s" "%8695$s" "%8696$s" "%8697$s" "%8698$s" "%8699$s" "%8700$s" ++"%8701$s" "%8702$s" "%8703$s" "%8704$s" "%8705$s" "%8706$s" "%8707$s" "%8708$s" "%8709$s" "%8710$s" ++"%8711$s" "%8712$s" "%8713$s" "%8714$s" "%8715$s" "%8716$s" "%8717$s" "%8718$s" "%8719$s" "%8720$s" ++"%8721$s" "%8722$s" "%8723$s" "%8724$s" "%8725$s" "%8726$s" "%8727$s" "%8728$s" "%8729$s" "%8730$s" ++"%8731$s" "%8732$s" "%8733$s" "%8734$s" "%8735$s" "%8736$s" "%8737$s" "%8738$s" "%8739$s" "%8740$s" ++"%8741$s" "%8742$s" "%8743$s" "%8744$s" "%8745$s" "%8746$s" "%8747$s" "%8748$s" "%8749$s" "%8750$s" ++"%8751$s" "%8752$s" "%8753$s" "%8754$s" "%8755$s" "%8756$s" "%8757$s" "%8758$s" "%8759$s" "%8760$s" ++"%8761$s" "%8762$s" "%8763$s" "%8764$s" "%8765$s" "%8766$s" "%8767$s" "%8768$s" "%8769$s" "%8770$s" ++"%8771$s" "%8772$s" "%8773$s" "%8774$s" "%8775$s" "%8776$s" "%8777$s" "%8778$s" "%8779$s" "%8780$s" ++"%8781$s" "%8782$s" "%8783$s" "%8784$s" "%8785$s" "%8786$s" "%8787$s" "%8788$s" "%8789$s" "%8790$s" ++"%8791$s" "%8792$s" "%8793$s" "%8794$s" "%8795$s" "%8796$s" "%8797$s" "%8798$s" "%8799$s" "%8800$s" ++"%8801$s" "%8802$s" "%8803$s" "%8804$s" "%8805$s" "%8806$s" "%8807$s" "%8808$s" "%8809$s" "%8810$s" ++"%8811$s" "%8812$s" "%8813$s" "%8814$s" "%8815$s" "%8816$s" "%8817$s" "%8818$s" "%8819$s" "%8820$s" ++"%8821$s" "%8822$s" "%8823$s" "%8824$s" "%8825$s" "%8826$s" "%8827$s" "%8828$s" "%8829$s" "%8830$s" ++"%8831$s" "%8832$s" "%8833$s" "%8834$s" "%8835$s" "%8836$s" "%8837$s" "%8838$s" "%8839$s" "%8840$s" ++"%8841$s" "%8842$s" "%8843$s" "%8844$s" "%8845$s" "%8846$s" "%8847$s" "%8848$s" "%8849$s" "%8850$s" ++"%8851$s" "%8852$s" "%8853$s" "%8854$s" "%8855$s" "%8856$s" "%8857$s" "%8858$s" "%8859$s" "%8860$s" ++"%8861$s" "%8862$s" "%8863$s" "%8864$s" "%8865$s" "%8866$s" "%8867$s" "%8868$s" "%8869$s" "%8870$s" ++"%8871$s" "%8872$s" "%8873$s" "%8874$s" "%8875$s" "%8876$s" "%8877$s" "%8878$s" "%8879$s" "%8880$s" ++"%8881$s" "%8882$s" "%8883$s" "%8884$s" "%8885$s" "%8886$s" "%8887$s" "%8888$s" "%8889$s" "%8890$s" ++"%8891$s" "%8892$s" "%8893$s" "%8894$s" "%8895$s" "%8896$s" "%8897$s" "%8898$s" "%8899$s" "%8900$s" ++"%8901$s" "%8902$s" "%8903$s" "%8904$s" "%8905$s" "%8906$s" "%8907$s" "%8908$s" "%8909$s" "%8910$s" ++"%8911$s" "%8912$s" "%8913$s" "%8914$s" "%8915$s" "%8916$s" "%8917$s" "%8918$s" "%8919$s" "%8920$s" ++"%8921$s" "%8922$s" "%8923$s" "%8924$s" "%8925$s" "%8926$s" "%8927$s" "%8928$s" "%8929$s" "%8930$s" ++"%8931$s" "%8932$s" "%8933$s" "%8934$s" "%8935$s" "%8936$s" "%8937$s" "%8938$s" "%8939$s" "%8940$s" ++"%8941$s" "%8942$s" "%8943$s" "%8944$s" "%8945$s" "%8946$s" "%8947$s" "%8948$s" "%8949$s" "%8950$s" ++"%8951$s" "%8952$s" "%8953$s" "%8954$s" "%8955$s" "%8956$s" "%8957$s" "%8958$s" "%8959$s" "%8960$s" ++"%8961$s" "%8962$s" "%8963$s" "%8964$s" "%8965$s" "%8966$s" "%8967$s" "%8968$s" "%8969$s" "%8970$s" ++"%8971$s" "%8972$s" "%8973$s" "%8974$s" "%8975$s" "%8976$s" "%8977$s" "%8978$s" "%8979$s" "%8980$s" ++"%8981$s" "%8982$s" "%8983$s" "%8984$s" "%8985$s" "%8986$s" "%8987$s" "%8988$s" "%8989$s" "%8990$s" ++"%8991$s" "%8992$s" "%8993$s" "%8994$s" "%8995$s" "%8996$s" "%8997$s" "%8998$s" "%8999$s" "%9000$s" ++"%9001$s" "%9002$s" "%9003$s" "%9004$s" "%9005$s" "%9006$s" "%9007$s" "%9008$s" "%9009$s" "%9010$s" ++"%9011$s" "%9012$s" "%9013$s" "%9014$s" "%9015$s" "%9016$s" "%9017$s" "%9018$s" "%9019$s" "%9020$s" ++"%9021$s" "%9022$s" "%9023$s" "%9024$s" "%9025$s" "%9026$s" "%9027$s" "%9028$s" "%9029$s" "%9030$s" ++"%9031$s" "%9032$s" "%9033$s" "%9034$s" "%9035$s" "%9036$s" "%9037$s" "%9038$s" "%9039$s" "%9040$s" ++"%9041$s" "%9042$s" "%9043$s" "%9044$s" "%9045$s" "%9046$s" "%9047$s" "%9048$s" "%9049$s" "%9050$s" ++"%9051$s" "%9052$s" "%9053$s" "%9054$s" "%9055$s" "%9056$s" "%9057$s" "%9058$s" "%9059$s" "%9060$s" ++"%9061$s" "%9062$s" "%9063$s" "%9064$s" "%9065$s" "%9066$s" "%9067$s" "%9068$s" "%9069$s" "%9070$s" ++"%9071$s" "%9072$s" "%9073$s" "%9074$s" "%9075$s" "%9076$s" "%9077$s" "%9078$s" "%9079$s" "%9080$s" ++"%9081$s" "%9082$s" "%9083$s" "%9084$s" "%9085$s" "%9086$s" "%9087$s" "%9088$s" "%9089$s" "%9090$s" ++"%9091$s" "%9092$s" "%9093$s" "%9094$s" "%9095$s" "%9096$s" "%9097$s" "%9098$s" "%9099$s" "%9100$s" ++"%9101$s" "%9102$s" "%9103$s" "%9104$s" "%9105$s" "%9106$s" "%9107$s" "%9108$s" "%9109$s" "%9110$s" ++"%9111$s" "%9112$s" "%9113$s" "%9114$s" "%9115$s" "%9116$s" "%9117$s" "%9118$s" "%9119$s" "%9120$s" ++"%9121$s" "%9122$s" "%9123$s" "%9124$s" "%9125$s" "%9126$s" "%9127$s" "%9128$s" "%9129$s" "%9130$s" ++"%9131$s" "%9132$s" "%9133$s" "%9134$s" "%9135$s" "%9136$s" "%9137$s" "%9138$s" "%9139$s" "%9140$s" ++"%9141$s" "%9142$s" "%9143$s" "%9144$s" "%9145$s" "%9146$s" "%9147$s" "%9148$s" "%9149$s" "%9150$s" ++"%9151$s" "%9152$s" "%9153$s" "%9154$s" "%9155$s" "%9156$s" "%9157$s" "%9158$s" "%9159$s" "%9160$s" ++"%9161$s" "%9162$s" "%9163$s" "%9164$s" "%9165$s" "%9166$s" "%9167$s" "%9168$s" "%9169$s" "%9170$s" ++"%9171$s" "%9172$s" "%9173$s" "%9174$s" "%9175$s" "%9176$s" "%9177$s" "%9178$s" "%9179$s" "%9180$s" ++"%9181$s" "%9182$s" "%9183$s" "%9184$s" "%9185$s" "%9186$s" "%9187$s" "%9188$s" "%9189$s" "%9190$s" ++"%9191$s" "%9192$s" "%9193$s" "%9194$s" "%9195$s" "%9196$s" "%9197$s" "%9198$s" "%9199$s" "%9200$s" ++"%9201$s" "%9202$s" "%9203$s" "%9204$s" "%9205$s" "%9206$s" "%9207$s" "%9208$s" "%9209$s" "%9210$s" ++"%9211$s" "%9212$s" "%9213$s" "%9214$s" "%9215$s" "%9216$s" "%9217$s" "%9218$s" "%9219$s" "%9220$s" ++"%9221$s" "%9222$s" "%9223$s" "%9224$s" "%9225$s" "%9226$s" "%9227$s" "%9228$s" "%9229$s" "%9230$s" ++"%9231$s" "%9232$s" "%9233$s" "%9234$s" "%9235$s" "%9236$s" "%9237$s" "%9238$s" "%9239$s" "%9240$s" ++"%9241$s" "%9242$s" "%9243$s" "%9244$s" "%9245$s" "%9246$s" "%9247$s" "%9248$s" "%9249$s" "%9250$s" ++"%9251$s" "%9252$s" "%9253$s" "%9254$s" "%9255$s" "%9256$s" "%9257$s" "%9258$s" "%9259$s" "%9260$s" ++"%9261$s" "%9262$s" "%9263$s" "%9264$s" "%9265$s" "%9266$s" "%9267$s" "%9268$s" "%9269$s" "%9270$s" ++"%9271$s" "%9272$s" "%9273$s" "%9274$s" "%9275$s" "%9276$s" "%9277$s" "%9278$s" "%9279$s" "%9280$s" ++"%9281$s" "%9282$s" "%9283$s" "%9284$s" "%9285$s" "%9286$s" "%9287$s" "%9288$s" "%9289$s" "%9290$s" ++"%9291$s" "%9292$s" "%9293$s" "%9294$s" "%9295$s" "%9296$s" "%9297$s" "%9298$s" "%9299$s" "%9300$s" ++"%9301$s" "%9302$s" "%9303$s" "%9304$s" "%9305$s" "%9306$s" "%9307$s" "%9308$s" "%9309$s" "%9310$s" ++"%9311$s" "%9312$s" "%9313$s" "%9314$s" "%9315$s" "%9316$s" "%9317$s" "%9318$s" "%9319$s" "%9320$s" ++"%9321$s" "%9322$s" "%9323$s" "%9324$s" "%9325$s" "%9326$s" "%9327$s" "%9328$s" "%9329$s" "%9330$s" ++"%9331$s" "%9332$s" "%9333$s" "%9334$s" "%9335$s" "%9336$s" "%9337$s" "%9338$s" "%9339$s" "%9340$s" ++"%9341$s" "%9342$s" "%9343$s" "%9344$s" "%9345$s" "%9346$s" "%9347$s" "%9348$s" "%9349$s" "%9350$s" ++"%9351$s" "%9352$s" "%9353$s" "%9354$s" "%9355$s" "%9356$s" "%9357$s" "%9358$s" "%9359$s" "%9360$s" ++"%9361$s" "%9362$s" "%9363$s" "%9364$s" "%9365$s" "%9366$s" "%9367$s" "%9368$s" "%9369$s" "%9370$s" ++"%9371$s" "%9372$s" "%9373$s" "%9374$s" "%9375$s" "%9376$s" "%9377$s" "%9378$s" "%9379$s" "%9380$s" ++"%9381$s" "%9382$s" "%9383$s" "%9384$s" "%9385$s" "%9386$s" "%9387$s" "%9388$s" "%9389$s" "%9390$s" ++"%9391$s" "%9392$s" "%9393$s" "%9394$s" "%9395$s" "%9396$s" "%9397$s" "%9398$s" "%9399$s" "%9400$s" ++"%9401$s" "%9402$s" "%9403$s" "%9404$s" "%9405$s" "%9406$s" "%9407$s" "%9408$s" "%9409$s" "%9410$s" ++"%9411$s" "%9412$s" "%9413$s" "%9414$s" "%9415$s" "%9416$s" "%9417$s" "%9418$s" "%9419$s" "%9420$s" ++"%9421$s" "%9422$s" "%9423$s" "%9424$s" "%9425$s" "%9426$s" "%9427$s" "%9428$s" "%9429$s" "%9430$s" ++"%9431$s" "%9432$s" "%9433$s" "%9434$s" "%9435$s" "%9436$s" "%9437$s" "%9438$s" "%9439$s" "%9440$s" ++"%9441$s" "%9442$s" "%9443$s" "%9444$s" "%9445$s" "%9446$s" "%9447$s" "%9448$s" "%9449$s" "%9450$s" ++"%9451$s" "%9452$s" "%9453$s" "%9454$s" "%9455$s" "%9456$s" "%9457$s" "%9458$s" "%9459$s" "%9460$s" ++"%9461$s" "%9462$s" "%9463$s" "%9464$s" "%9465$s" "%9466$s" "%9467$s" "%9468$s" "%9469$s" "%9470$s" ++"%9471$s" "%9472$s" "%9473$s" "%9474$s" "%9475$s" "%9476$s" "%9477$s" "%9478$s" "%9479$s" "%9480$s" ++"%9481$s" "%9482$s" "%9483$s" "%9484$s" "%9485$s" "%9486$s" "%9487$s" "%9488$s" "%9489$s" "%9490$s" ++"%9491$s" "%9492$s" "%9493$s" "%9494$s" "%9495$s" "%9496$s" "%9497$s" "%9498$s" "%9499$s" "%9500$s" ++"%9501$s" "%9502$s" "%9503$s" "%9504$s" "%9505$s" "%9506$s" "%9507$s" "%9508$s" "%9509$s" "%9510$s" ++"%9511$s" "%9512$s" "%9513$s" "%9514$s" "%9515$s" "%9516$s" "%9517$s" "%9518$s" "%9519$s" "%9520$s" ++"%9521$s" "%9522$s" "%9523$s" "%9524$s" "%9525$s" "%9526$s" "%9527$s" "%9528$s" "%9529$s" "%9530$s" ++"%9531$s" "%9532$s" "%9533$s" "%9534$s" "%9535$s" "%9536$s" "%9537$s" "%9538$s" "%9539$s" "%9540$s" ++"%9541$s" "%9542$s" "%9543$s" "%9544$s" "%9545$s" "%9546$s" "%9547$s" "%9548$s" "%9549$s" "%9550$s" ++"%9551$s" "%9552$s" "%9553$s" "%9554$s" "%9555$s" "%9556$s" "%9557$s" "%9558$s" "%9559$s" "%9560$s" ++"%9561$s" "%9562$s" "%9563$s" "%9564$s" "%9565$s" "%9566$s" "%9567$s" "%9568$s" "%9569$s" "%9570$s" ++"%9571$s" "%9572$s" "%9573$s" "%9574$s" "%9575$s" "%9576$s" "%9577$s" "%9578$s" "%9579$s" "%9580$s" ++"%9581$s" "%9582$s" "%9583$s" "%9584$s" "%9585$s" "%9586$s" "%9587$s" "%9588$s" "%9589$s" "%9590$s" ++"%9591$s" "%9592$s" "%9593$s" "%9594$s" "%9595$s" "%9596$s" "%9597$s" "%9598$s" "%9599$s" "%9600$s" ++"%9601$s" "%9602$s" "%9603$s" "%9604$s" "%9605$s" "%9606$s" "%9607$s" "%9608$s" "%9609$s" "%9610$s" ++"%9611$s" "%9612$s" "%9613$s" "%9614$s" "%9615$s" "%9616$s" "%9617$s" "%9618$s" "%9619$s" "%9620$s" ++"%9621$s" "%9622$s" "%9623$s" "%9624$s" "%9625$s" "%9626$s" "%9627$s" "%9628$s" "%9629$s" "%9630$s" ++"%9631$s" "%9632$s" "%9633$s" "%9634$s" "%9635$s" "%9636$s" "%9637$s" "%9638$s" "%9639$s" "%9640$s" ++"%9641$s" "%9642$s" "%9643$s" "%9644$s" "%9645$s" "%9646$s" "%9647$s" "%9648$s" "%9649$s" "%9650$s" ++"%9651$s" "%9652$s" "%9653$s" "%9654$s" "%9655$s" "%9656$s" "%9657$s" "%9658$s" "%9659$s" "%9660$s" ++"%9661$s" "%9662$s" "%9663$s" "%9664$s" "%9665$s" "%9666$s" "%9667$s" "%9668$s" "%9669$s" "%9670$s" ++"%9671$s" "%9672$s" "%9673$s" "%9674$s" "%9675$s" "%9676$s" "%9677$s" "%9678$s" "%9679$s" "%9680$s" ++"%9681$s" "%9682$s" "%9683$s" "%9684$s" "%9685$s" "%9686$s" "%9687$s" "%9688$s" "%9689$s" "%9690$s" ++"%9691$s" "%9692$s" "%9693$s" "%9694$s" "%9695$s" "%9696$s" "%9697$s" "%9698$s" "%9699$s" "%9700$s" ++"%9701$s" "%9702$s" "%9703$s" "%9704$s" "%9705$s" "%9706$s" "%9707$s" "%9708$s" "%9709$s" "%9710$s" ++"%9711$s" "%9712$s" "%9713$s" "%9714$s" "%9715$s" "%9716$s" "%9717$s" "%9718$s" "%9719$s" "%9720$s" ++"%9721$s" "%9722$s" "%9723$s" "%9724$s" "%9725$s" "%9726$s" "%9727$s" "%9728$s" "%9729$s" "%9730$s" ++"%9731$s" "%9732$s" "%9733$s" "%9734$s" "%9735$s" "%9736$s" "%9737$s" "%9738$s" "%9739$s" "%9740$s" ++"%9741$s" "%9742$s" "%9743$s" "%9744$s" "%9745$s" "%9746$s" "%9747$s" "%9748$s" "%9749$s" "%9750$s" ++"%9751$s" "%9752$s" "%9753$s" "%9754$s" "%9755$s" "%9756$s" "%9757$s" "%9758$s" "%9759$s" "%9760$s" ++"%9761$s" "%9762$s" "%9763$s" "%9764$s" "%9765$s" "%9766$s" "%9767$s" "%9768$s" "%9769$s" "%9770$s" ++"%9771$s" "%9772$s" "%9773$s" "%9774$s" "%9775$s" "%9776$s" "%9777$s" "%9778$s" "%9779$s" "%9780$s" ++"%9781$s" "%9782$s" "%9783$s" "%9784$s" "%9785$s" "%9786$s" "%9787$s" "%9788$s" "%9789$s" "%9790$s" ++"%9791$s" "%9792$s" "%9793$s" "%9794$s" "%9795$s" "%9796$s" "%9797$s" "%9798$s" "%9799$s" "%9800$s" ++"%9801$s" "%9802$s" "%9803$s" "%9804$s" "%9805$s" "%9806$s" "%9807$s" "%9808$s" "%9809$s" "%9810$s" ++"%9811$s" "%9812$s" "%9813$s" "%9814$s" "%9815$s" "%9816$s" "%9817$s" "%9818$s" "%9819$s" "%9820$s" ++"%9821$s" "%9822$s" "%9823$s" "%9824$s" "%9825$s" "%9826$s" "%9827$s" "%9828$s" "%9829$s" "%9830$s" ++"%9831$s" "%9832$s" "%9833$s" "%9834$s" "%9835$s" "%9836$s" "%9837$s" "%9838$s" "%9839$s" "%9840$s" ++"%9841$s" "%9842$s" "%9843$s" "%9844$s" "%9845$s" "%9846$s" "%9847$s" "%9848$s" "%9849$s" "%9850$s" ++"%9851$s" "%9852$s" "%9853$s" "%9854$s" "%9855$s" "%9856$s" "%9857$s" "%9858$s" "%9859$s" "%9860$s" ++"%9861$s" "%9862$s" "%9863$s" "%9864$s" "%9865$s" "%9866$s" "%9867$s" "%9868$s" "%9869$s" "%9870$s" ++"%9871$s" "%9872$s" "%9873$s" "%9874$s" "%9875$s" "%9876$s" "%9877$s" "%9878$s" "%9879$s" "%9880$s" ++"%9881$s" "%9882$s" "%9883$s" "%9884$s" "%9885$s" "%9886$s" "%9887$s" "%9888$s" "%9889$s" "%9890$s" ++"%9891$s" "%9892$s" "%9893$s" "%9894$s" "%9895$s" "%9896$s" "%9897$s" "%9898$s" "%9899$s" "%9900$s" ++"%9901$s" "%9902$s" "%9903$s" "%9904$s" "%9905$s" "%9906$s" "%9907$s" "%9908$s" "%9909$s" "%9910$s" ++"%9911$s" "%9912$s" "%9913$s" "%9914$s" "%9915$s" "%9916$s" "%9917$s" "%9918$s" "%9919$s" "%9920$s" ++"%9921$s" "%9922$s" "%9923$s" "%9924$s" "%9925$s" "%9926$s" "%9927$s" "%9928$s" "%9929$s" "%9930$s" ++"%9931$s" "%9932$s" "%9933$s" "%9934$s" "%9935$s" "%9936$s" "%9937$s" "%9938$s" "%9939$s" "%9940$s" ++"%9941$s" "%9942$s" "%9943$s" "%9944$s" "%9945$s" "%9946$s" "%9947$s" "%9948$s" "%9949$s" "%9950$s" ++"%9951$s" "%9952$s" "%9953$s" "%9954$s" "%9955$s" "%9956$s" "%9957$s" "%9958$s" "%9959$s" "%9960$s" ++"%9961$s" "%9962$s" "%9963$s" "%9964$s" "%9965$s" "%9966$s" "%9967$s" "%9968$s" "%9969$s" "%9970$s" ++"%9971$s" "%9972$s" "%9973$s" "%9974$s" "%9975$s" "%9976$s" "%9977$s" "%9978$s" "%9979$s" "%9980$s" ++"%9981$s" "%9982$s" "%9983$s" "%9984$s" "%9985$s" "%9986$s" "%9987$s" "%9988$s" "%9989$s" "%9990$s" ++"%9991$s" "%9992$s" "%9993$s" "%9994$s" "%9995$s" "%9996$s" "%9997$s" "%9998$s" "%9999$s" "%10000$s" ++"%10001$s", ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 10 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 20 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 30 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 40 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 50 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 60 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 70 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 80 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 90 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1000 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1010 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1020 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1030 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1040 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1050 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1060 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1070 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1080 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1090 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 1990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2000 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2010 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2020 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2030 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2040 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2050 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2060 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2070 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2080 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2090 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 2990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3000 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3010 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3020 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3030 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3040 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3050 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3060 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3070 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3080 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3090 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 3990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4000 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4010 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4020 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4030 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4040 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4050 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4060 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4070 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4080 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4090 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 4990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5000 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5010 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5020 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5030 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5040 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5050 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5060 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5070 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5080 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5090 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 5990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6000 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6010 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6020 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6030 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6040 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6050 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6060 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6070 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6080 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6090 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 6990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7000 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7010 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7020 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7030 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7040 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7050 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7060 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7070 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7080 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7090 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 7990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8000 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8010 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8020 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8030 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8040 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8050 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8060 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8070 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8080 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8090 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 8990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9000 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9010 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9020 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9030 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9040 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9050 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9060 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9070 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9080 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9090 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9100 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9110 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9120 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9130 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9140 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9150 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9160 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9170 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9180 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9190 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9200 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9210 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9220 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9230 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9240 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9250 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9260 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9270 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9280 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9290 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9300 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9310 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9320 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9330 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9340 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9350 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9360 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9370 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9380 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9390 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9400 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9410 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9420 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9430 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9440 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9450 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9460 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9470 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9480 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9490 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9500 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9510 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9520 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9530 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9540 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9550 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9560 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9570 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9580 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9590 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9600 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9610 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9620 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9630 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9640 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9650 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9660 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9670 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9680 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9690 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9700 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9710 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9720 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9730 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9740 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9750 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9760 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9770 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9780 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9790 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9800 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9810 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9820 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9830 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9840 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9850 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9860 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9870 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9880 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9890 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9900 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9910 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9920 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9930 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9940 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9950 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9960 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9970 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9980 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 9990 */ ++"a", "a", "a", "a", "a", "a", "a", "a", "a", "a", /* 10000 */ ++"\n"); ++ return 0; ++} +--- gcc/testsuite/gcc.target/aarch64/stack-check-12.c ++++ gcc/testsuite/gcc.target/aarch64/stack-check-12.c +@@ -0,0 +1,20 @@ ++/* { dg-do compile } */ ++/* { dg-options "-O2 -fstack-clash-protection --param stack-clash-protection-guard-size=12" } */ ++/* { dg-require-effective-target supports_stack_clash_protection } */ ++ ++extern void arf (unsigned long int *, unsigned long int *); ++void ++frob () ++{ ++ unsigned long int num[1000]; ++ unsigned long int den[1000]; ++ arf (den, num); ++} ++ ++/* This verifies that the scheduler did not break the dependencies ++ by adjusting the offsets within the probe and that the scheduler ++ did not reorder around the stack probes. */ ++/* { dg-final { scan-assembler-times "sub\\tsp, sp, #4096\\n\\tstr\\txzr, .sp, 4088." 3 } } */ ++ ++ ++ +--- gcc/testsuite/gcc.target/aarch64/stack-check-13.c ++++ gcc/testsuite/gcc.target/aarch64/stack-check-13.c +@@ -0,0 +1,28 @@ ++/* { dg-do compile } */ ++/* { dg-options "-O2 -fstack-clash-protection --param stack-clash-protection-guard-size=12" } */ ++/* { dg-require-effective-target supports_stack_clash_protection } */ ++ ++#define ARG32(X) X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X,X ++#define ARG192(X) ARG32(X),ARG32(X),ARG32(X),ARG32(X),ARG32(X),ARG32(X) ++void out1(ARG192(__int128)); ++int t1(int); ++ ++int t3(int x) ++{ ++ if (x < 1000) ++ return t1 (x) + 1; ++ ++ out1 (ARG192(1)); ++ return 0; ++} ++ ++ ++ ++/* This test creates a large (> 1k) outgoing argument area that needs ++ to be probed. We don't test the exact size of the space or the ++ exact offset to make the test a little less sensitive to trivial ++ output changes. */ ++/* { dg-final { scan-assembler-times "sub\\tsp, sp, #....\\n\\tstr\\txzr, \\\[sp" 1 } } */ ++ ++ ++ +--- gcc/testsuite/gcc.target/aarch64/stack-check-14.c ++++ gcc/testsuite/gcc.target/aarch64/stack-check-14.c +@@ -0,0 +1,25 @@ ++/* { dg-do compile } */ ++/* { dg-options "-O2 -fstack-clash-protection --param stack-clash-protection-guard-size=12" } */ ++/* { dg-require-effective-target supports_stack_clash_protection } */ ++ ++int t1(int); ++ ++int t2(int x) ++{ ++ char *p = __builtin_alloca (4050); ++ x = t1 (x); ++ return p[x]; ++} ++ ++ ++/* This test has a constant sized alloca that is smaller than the ++ probe interval. But it actually requires two probes instead ++ of one because of the optimistic assumptions we made in the ++ aarch64 prologue code WRT probing state. ++ ++ The form can change quite a bit so we just check for two ++ probes without looking at the actual address. */ ++/* { dg-final { scan-assembler-times "str\\txzr," 2 } } */ ++ ++ ++ +--- gcc/testsuite/gcc.target/aarch64/stack-check-15.c ++++ gcc/testsuite/gcc.target/aarch64/stack-check-15.c +@@ -0,0 +1,24 @@ ++/* { dg-do compile } */ ++/* { dg-options "-O2 -fstack-clash-protection --param stack-clash-protection-guard-size=12" } */ ++/* { dg-require-effective-target supports_stack_clash_protection } */ ++ ++int t1(int); ++ ++int t2(int x) ++{ ++ char *p = __builtin_alloca (x); ++ x = t1 (x); ++ return p[x]; ++} ++ ++ ++/* This test has a variable sized alloca. It requires 3 probes. ++ One in the loop, one for the residual and at the end of the ++ alloca area. ++ ++ The form can change quite a bit so we just check for two ++ probes without looking at the actual address. */ ++/* { dg-final { scan-assembler-times "str\\txzr," 3 } } */ ++ ++ ++ +--- gcc/testsuite/lib/target-supports.exp ++++ gcc/testsuite/lib/target-supports.exp +@@ -8384,14 +8384,9 @@ proc check_effective_target_arm_coproc4_ok { } { + # + proc check_effective_target_supports_stack_clash_protection { } { + +- # Temporary until the target bits are fully ACK'd. +-# if { [istarget aarch*-*-*] } { +-# return 1 +-# } +- + if { [istarget x86_64-*-*] || [istarget i?86-*-*] + || [istarget powerpc*-*-*] || [istarget rs6000*-*-*] +- || [istarget s390*-*-*] } { ++ || [istarget aarch64*-**] || [istarget s390*-*-*] } { + return 1 + } + return 0 diff --git a/sources b/sources index 82a36e5..aba179a 100644 --- a/sources +++ b/sources @@ -1,3 +1,3 @@ -SHA512 (gcc-7.2.1-20180101.tar.bz2) = c59c014297c05e1b41fb72db5a1fdce777be190d9990b2ae2a642cacd6d530b0be8e7ece72fe651a6da9d6e3eaae3c72790d65bc15b54917634e219ffd98b5e2 +SHA512 (gcc-7.2.1-20180104.tar.bz2) = 26c4f527bd990fec36b22eb6ede87fde58833d0457544771cfc04e368661fcf141a218deeff70738575dc584e2a3cf68e4c6b86d2f842db09cc7278b3e39b53e SHA512 (nvptx-newlib-aadc8eb0ec43b7cd0dd2dfb484bae63c8b05ef24.tar.bz2) = 38f97c9297ad108568352a4d28277455a3c01fd8b7864e798037e5006b6f757022e874bbf3f165775fe3b873781bc108137bbeb42dd5ed3c7d3e6747746fa918 SHA512 (nvptx-tools-c28050f60193b3b95a18866a96f03334e874e78f.tar.bz2) = 95b577a06a93bb044dbc8033e550cb36bcf2ab2687da030a7318cdc90e7467ed49665e247dcafb5ff4a7e92cdc264291d19728bd17fab902fb64b22491269330