public inbox for libc-alpha@sourceware.org
 help / color / mirror / Atom feed
* Re: [PATCH v5 6/6] x86: Reduce code size of mem{move|pcpy|cpy}-ssse3
@ 2022-04-15  2:25 Mayshao-oc
  2022-04-15  5:03 ` Noah Goldstein
  0 siblings, 1 reply; 3+ messages in thread
From: Mayshao-oc @ 2022-04-15  2:25 UTC (permalink / raw)
  To: GNU C Library; +Cc: Noah Goldstein, H.J. Lu, Louis Qi(BJ-RD)

On Thu, Apr 14 2022 at 11:47 PM Noah Goldstein <goldstein.w.n@gmail.com> wrote:
> The goal is to remove most SSSE3 function as SSE4, AVX2, and EVEX are
> generally preferable. memcpy/memmove is one exception where avoiding
> unaligned loads with `palignr` is important for some targets.
>
> This commit replaces memmove-ssse3 with a better optimized are lower
> code footprint verion. As well it aliases memcpy to memmove.
>
> Aside from this function all other SSSE3 functions should be safe to
> remove.
>
> The performance is not changed drastically although shows overall
> improvements without any major regressions or gains.
>
> bench-memcpy geometric_mean(N=50) New / Original: 0.957
>
> bench-memcpy-random geometric_mean(N=50) New / Original: 0.912
>
> bench-memcpy-large geometric_mean(N=50) New / Original: 0.892
>
> Benchmarks where run on Zhaoxin KX-6840@2000MHz See attached numbers
> for all results.
>
> More important this saves 7246 bytes of code size in memmove an
> additional 10741 bytes by reusing memmove code for memcpy (total 17987
> bytes saves). As well an additional 896 bytes of rodata for the jump
> table entries.
> ---
>
> Results For: bench-memcpy
> length, align1, align2, dst > src, New Time / Old Time
>      1,      0,      0,         0,               0.946
>      1,      0,      0,         1,               0.946
>      1,     32,      0,         0,               0.948
>      1,     32,      0,         1,               1.185
>      1,      0,     32,         0,               0.982
>      1,      0,     32,         1,                1.14
>      1,     32,     32,         0,               0.981
>      1,     32,     32,         1,               1.057
>      1,   2048,      0,         0,               0.945
>      1,   2048,      0,         1,               0.945
>      2,      0,      0,         0,               1.041
>      2,      0,      0,         1,               1.041
>      2,      1,      0,         0,               1.044
>      2,      1,      0,         1,               1.044
>      2,     33,      0,         0,               1.044
>      2,     33,      0,         1,               1.044
>      2,      0,      1,         0,               1.041
>      2,      0,      1,         1,               1.041
>      2,      0,     33,         0,               1.042
>      2,      0,     33,         1,               1.041
>      2,      1,      1,         0,               1.041
>      2,      1,      1,         1,               1.041
>      2,     33,     33,         0,               1.041
>      2,     33,     33,         1,               1.041
>      2,   2048,      0,         0,               1.042
>      2,   2048,      0,         1,               1.041
>      2,   2049,      0,         0,               1.044
>      2,   2049,      0,         1,               1.044
>      2,   2048,      1,         0,               1.041
>      2,   2048,      1,         1,               1.042
>      2,   2049,      1,         0,               1.042
>      2,   2049,      1,         1,               1.042
>      4,      0,      0,         0,               0.962
>      4,      0,      0,         1,               0.962
>      4,      2,      0,         0,                0.98
>      4,      2,      0,         1,               0.984
>      4,     34,      0,         0,               0.986
>      4,     34,      0,         1,               0.987
>      4,      0,      2,         0,               0.962
>      4,      0,      2,         1,               0.962
>      4,      0,     34,         0,               0.962
>      4,      0,     34,         1,               0.962
>      4,      2,      2,         0,               0.962
>      4,      2,      2,         1,               0.962
>      4,     34,     34,         0,               0.962
>      4,     34,     34,         1,               0.962
>      4,   2048,      0,         0,               0.962
>      4,   2048,      0,         1,               0.962
>      4,   2050,      0,         0,               0.996
>      4,   2050,      0,         1,                 1.0
>      4,   2048,      2,         0,               0.962
>      4,   2048,      2,         1,               0.962
>      4,   2050,      2,         0,               0.962
>      4,   2050,      2,         1,               0.962
>      8,      0,      0,         0,               0.962
>      8,      0,      0,         1,               0.962
>      8,      3,      0,         0,                 1.0
>      8,      3,      0,         1,                 1.0
>      8,     35,      0,         0,               1.001
>      8,     35,      0,         1,                 1.0
>      8,      0,      3,         0,               0.962
>      8,      0,      3,         1,               0.962
>      8,      0,     35,         0,               0.962
>      8,      0,     35,         1,               0.962
>      8,      3,      3,         0,               0.962
>      8,      3,      3,         1,               0.962
>      8,     35,     35,         0,               0.962
>      8,     35,     35,         1,               0.962
>      8,   2048,      0,         0,               0.962
>      8,   2048,      0,         1,               0.962
>      8,   2051,      0,         0,                 1.0
>      8,   2051,      0,         1,                 1.0
>      8,   2048,      3,         0,               0.962
>      8,   2048,      3,         1,               0.962
>      8,   2051,      3,         0,               0.962
>      8,   2051,      3,         1,               0.962
>     16,      0,      0,         0,               0.798
>     16,      0,      0,         1,               0.799
>     16,      4,      0,         0,               0.801
>     16,      4,      0,         1,               0.801
>     16,     36,      0,         0,               0.801
>     16,     36,      0,         1,               0.801
>     16,      0,      4,         0,               0.798
>     16,      0,      4,         1,               0.799
>     16,      0,     36,         0,               0.799
>     16,      0,     36,         1,               0.799
>     16,      4,      4,         0,               0.799
>     16,      4,      4,         1,               0.799
>     16,     36,     36,         0,               0.799
>     16,     36,     36,         1,               0.799
>     16,   2048,      0,         0,               0.799
>     16,   2048,      0,         1,               0.799
>     16,   2052,      0,         0,               0.801
>     16,   2052,      0,         1,               0.801
>     16,   2048,      4,         0,               0.798
>     16,   2048,      4,         1,               0.799
>     16,   2052,      4,         0,               0.799
>     16,   2052,      4,         1,               0.799
>     32,      0,      0,         0,               0.472
>     32,      0,      0,         1,               0.472
>     32,      5,      0,         0,               0.472
>     32,      5,      0,         1,               0.472
>     32,     37,      0,         0,               0.962
>     32,     37,      0,         1,               0.962
>     32,      0,      5,         0,               0.472
>     32,      0,      5,         1,               0.472
>     32,      0,     37,         0,               1.021
>     32,      0,     37,         1,               1.021
>     32,      5,      5,         0,               0.472
>     32,      5,      5,         1,               0.472
>     32,     37,     37,         0,               1.011
>     32,     37,     37,         1,               1.011
>     32,   2048,      0,         0,               0.472
>     32,   2048,      0,         1,               0.472
>     32,   2053,      0,         0,               0.472
>     32,   2053,      0,         1,               0.472
>     32,   2048,      5,         0,               0.472
>     32,   2048,      5,         1,               0.472
>     32,   2053,      5,         0,               0.472
>     32,   2053,      5,         1,               0.472
>     64,      0,      0,         0,                 1.0
>     64,      0,      0,         1,                 1.0
>     64,      6,      0,         0,               0.862
>     64,      6,      0,         1,               0.862
>     64,     38,      0,         0,               0.912
>     64,     38,      0,         1,               0.912
>     64,      0,      6,         0,               0.896
>     64,      0,      6,         1,               0.896
>     64,      0,     38,         0,               0.906
>     64,      0,     38,         1,               0.906
>     64,      6,      6,         0,                0.91
>     64,      6,      6,         1,                0.91
>     64,     38,     38,         0,               0.883
>     64,     38,     38,         1,               0.883
>     64,   2048,      0,         0,                 1.0
>     64,   2048,      0,         1,                 1.0
>     64,   2054,      0,         0,               0.862
>     64,   2054,      0,         1,               0.862
>     64,   2048,      6,         0,               0.887
>     64,   2048,      6,         1,               0.887
>     64,   2054,      6,         0,               0.887
>     64,   2054,      6,         1,               0.887
>    128,      0,      0,         0,               0.857
>    128,      0,      0,         1,               0.857
>    128,      7,      0,         0,               0.875
>    128,      7,      0,         1,               0.875
>    128,     39,      0,         0,               0.892
>    128,     39,      0,         1,               0.892
>    128,      0,      7,         0,               1.183
>    128,      0,      7,         1,               1.183
>    128,      0,     39,         0,               1.113
>    128,      0,     39,         1,               1.113
>    128,      7,      7,         0,               0.692
>    128,      7,      7,         1,               0.692
>    128,     39,     39,         0,               1.104
>    128,     39,     39,         1,               1.104
>    128,   2048,      0,         0,               0.857
>    128,   2048,      0,         1,               0.857
>    128,   2055,      0,         0,               0.875
>    128,   2055,      0,         1,               0.875
>    128,   2048,      7,         0,               0.959
>    128,   2048,      7,         1,               0.959
>    128,   2055,      7,         0,               1.036
>    128,   2055,      7,         1,               1.036
>    256,      0,      0,         0,               0.889
>    256,      0,      0,         1,               0.889
>    256,      8,      0,         0,               0.966
>    256,      8,      0,         1,               0.966
>    256,     40,      0,         0,               0.983
>    256,     40,      0,         1,               0.983
>    256,      0,      8,         0,                1.29
>    256,      0,      8,         1,                1.29
>    256,      0,     40,         0,               1.274
>    256,      0,     40,         1,               1.274
>    256,      8,      8,         0,               0.865
>    256,      8,      8,         1,               0.865
>    256,     40,     40,         0,               1.477
>    256,     40,     40,         1,               1.477
>    256,   2048,      0,         0,               0.889
>    256,   2048,      0,         1,               0.889
>    256,   2056,      0,         0,               0.966
>    256,   2056,      0,         1,               0.966
>    256,   2048,      8,         0,               0.952
>    256,   2048,      8,         1,               0.952
>    256,   2056,      8,         0,               0.878
>    256,   2056,      8,         1,               0.878
>    512,      0,      0,         0,               1.077
>    512,      0,      0,         1,               1.077
>    512,      9,      0,         0,                 1.0
>    512,      9,      0,         1,                 1.0
>    512,     41,      0,         0,               0.954
>    512,     41,      0,         1,               0.954
>    512,      0,      9,         0,               1.191
>    512,      0,      9,         1,               1.191
>    512,      0,     41,         0,               1.181
>    512,      0,     41,         1,               1.181
>    512,      9,      9,         0,               0.765
>    512,      9,      9,         1,               0.765
>    512,     41,     41,         0,               0.905
>    512,     41,     41,         1,               0.905
>    512,   2048,      0,         0,               1.077
>    512,   2048,      0,         1,               1.077
>    512,   2057,      0,         0,                 1.0
>    512,   2057,      0,         1,                 1.0
>    512,   2048,      9,         0,                 1.0
>    512,   2048,      9,         1,                 1.0
>    512,   2057,      9,         0,               0.733
>    512,   2057,      9,         1,               0.733
>   1024,      0,      0,         0,               1.143
>   1024,      0,      0,         1,               1.143
>   1024,     10,      0,         0,               1.015
>   1024,     10,      0,         1,               1.015
>   1024,     42,      0,         0,               1.045
>   1024,     42,      0,         1,               1.045
>   1024,      0,     10,         0,               1.126
>   1024,      0,     10,         1,               1.126
>   1024,      0,     42,         0,               1.114
>   1024,      0,     42,         1,               1.114
>   1024,     10,     10,         0,                0.89
>   1024,     10,     10,         1,                0.89
>   1024,     42,     42,         0,               0.986
>   1024,     42,     42,         1,               0.986
>   1024,   2048,      0,         0,               1.143
>   1024,   2048,      0,         1,               1.143
>   1024,   2058,      0,         0,               1.015
>   1024,   2058,      0,         1,               1.015
>   1024,   2048,     10,         0,                1.03
>   1024,   2048,     10,         1,                1.03
>   1024,   2058,     10,         0,               0.854
>   1024,   2058,     10,         1,               0.854
>   2048,      0,      0,         0,               1.005
>   2048,      0,      0,         1,               1.005
>   2048,     11,      0,         0,               1.013
>   2048,     11,      0,         1,               1.014
>   2048,     43,      0,         0,               1.044
>   2048,     43,      0,         1,               1.044
>   2048,      0,     11,         0,               1.002
>   2048,      0,     11,         1,               1.003
>   2048,      0,     43,         0,               1.003
>   2048,      0,     43,         1,               1.003
>   2048,     11,     11,         0,                0.92
>   2048,     11,     11,         1,                0.92
>   2048,     43,     43,         0,                 1.0
>   2048,     43,     43,         1,                 1.0
>   2048,   2048,      0,         0,               1.005
>   2048,   2048,      0,         1,               1.005
>   2048,   2059,      0,         0,               0.904
>   2048,   2059,      0,         1,               0.904
>   2048,   2048,     11,         0,                 1.0
>   2048,   2048,     11,         1,                 1.0
>   2048,   2059,     11,         0,               0.979
>   2048,   2059,     11,         1,               0.979
>   4096,      0,      0,         0,               1.014
>   4096,      0,      0,         1,               1.014
>   4096,     12,      0,         0,               0.855
>   4096,     12,      0,         1,               0.855
>   4096,     44,      0,         0,               0.857
>   4096,     44,      0,         1,               0.857
>   4096,      0,     12,         0,               0.932
>   4096,      0,     12,         1,               0.932
>   4096,      0,     44,         0,               0.932
>   4096,      0,     44,         1,               0.933
>   4096,     12,     12,         0,               0.999
>   4096,     12,     12,         1,               0.999
>   4096,     44,     44,         0,               1.051
>   4096,     44,     44,         1,               1.051
>   4096,   2048,      0,         0,               1.014
>   4096,   2048,      0,         1,               1.014
>   4096,   2060,      0,         0,               0.967
>   4096,   2060,      0,         1,               0.967
>   4096,   2048,     12,         0,               0.769
>   4096,   2048,     12,         1,               0.769
>   4096,   2060,     12,         0,               0.943
>   4096,   2060,     12,         1,               0.943
>   8192,      0,      0,         0,               1.045
>   8192,      0,      0,         1,               1.046
>   8192,     13,      0,         0,               0.885
>   8192,     13,      0,         1,               0.885
>   8192,     45,      0,         0,               0.887
>   8192,     45,      0,         1,               0.887
>   8192,      0,     13,         0,               0.942
>   8192,      0,     13,         1,               0.942
>   8192,      0,     45,         0,               0.942
>   8192,      0,     45,         1,               0.942
>   8192,     13,     13,         0,                1.03
>   8192,     13,     13,         1,               1.029
>   8192,     45,     45,         0,               1.048
>   8192,     45,     45,         1,               1.049
>   8192,   2048,      0,         0,               1.048
>   8192,   2048,      0,         1,               1.048
>   8192,   2061,      0,         0,               1.011
>   8192,   2061,      0,         1,               1.011
>   8192,   2048,     13,         0,               0.789
>   8192,   2048,     13,         1,               0.788
>   8192,   2061,     13,         0,               0.991
>   8192,   2061,     13,         1,               0.992
>  16384,      0,      0,         0,               1.026
>  16384,      0,      0,         1,               1.011
>  16384,     14,      0,         0,               0.943
>  16384,     14,      0,         1,                0.95
>  16384,     46,      0,         0,               0.856
>  16384,     46,      0,         1,                0.86
>  16384,      0,     14,         0,               0.815
>  16384,      0,     14,         1,               0.817
>  16384,      0,     46,         0,               0.859
>  16384,      0,     46,         1,               0.867
>  16384,     14,     14,         0,               0.987
>  16384,     14,     14,         1,               0.979
>  16384,     46,     46,         0,               1.027
>  16384,     46,     46,         1,               1.031
>  16384,   2048,      0,         0,               1.078
>  16384,   2048,      0,         1,               1.084
>  16384,   2062,      0,         0,               0.851
>  16384,   2062,      0,         1,                0.85
>  16384,   2048,     14,         0,               0.935
>  16384,   2048,     14,         1,               0.932
>  16384,   2062,     14,         0,               1.015
>  16384,   2062,     14,         1,               1.012
>  32768,      0,      0,         0,               0.978
>  32768,      0,      0,         1,               0.979
>  32768,     15,      0,         0,               1.006
>  32768,     15,      0,         1,               1.006
>  32768,     47,      0,         0,               1.004
>  32768,     47,      0,         1,               1.004
>  32768,      0,     15,         0,               1.045
>  32768,      0,     15,         1,               1.045
>  32768,      0,     47,         0,               1.011
>  32768,      0,     47,         1,               1.011
>  32768,     15,     15,         0,               0.977
>  32768,     15,     15,         1,               0.977
>  32768,     47,     47,         0,                0.96
>  32768,     47,     47,         1,                0.96
>  32768,   2048,      0,         0,               0.978
>  32768,   2048,      0,         1,               0.978
>  32768,   2063,      0,         0,               1.004
>  32768,   2063,      0,         1,               1.004
>  32768,   2048,     15,         0,               1.036
>  32768,   2048,     15,         1,               1.036
>  32768,   2063,     15,         0,               0.978
>  32768,   2063,     15,         1,               0.978
>  65536,      0,      0,         0,               0.981
>  65536,      0,      0,         1,               0.981
>  65536,     16,      0,         0,               0.987
>  65536,     16,      0,         1,               0.987
>  65536,     48,      0,         0,               0.968
>  65536,     48,      0,         1,               0.968
>  65536,      0,     16,         0,               1.014
>  65536,      0,     16,         1,               1.014
>  65536,      0,     48,         0,               0.984
>  65536,      0,     48,         1,               0.984
>  65536,     16,     16,         0,                1.01
>  65536,     16,     16,         1,                1.01
>  65536,     48,     48,         0,               0.968
>  65536,     48,     48,         1,               0.968
>  65536,   2048,      0,         0,               0.982
>  65536,   2048,      0,         1,               0.982
>  65536,   2064,      0,         0,               0.987
>  65536,   2064,      0,         1,               0.987
>  65536,   2048,     16,         0,               1.012
>  65536,   2048,     16,         1,               1.012
>  65536,   2064,     16,         0,               1.007
>  65536,   2064,     16,         1,               1.007
>      0,      0,      0,         0,               0.867
>      0,   2048,      0,         0,               0.867
>      0,   4095,      0,         0,               0.868
>      0,      0,   4095,         0,               0.866
>      1,      1,      0,         0,               1.108
>      1,      0,      1,         0,               0.946
>      1,      1,      1,         0,               0.946
>      1,   2049,      0,         0,               0.947
>      1,   2048,      1,         0,               0.945
>      1,   2049,      1,         0,               0.945
>      1,   4095,      0,         0,               1.482
>      1,      0,   4095,         0,               0.981
>      2,      2,      0,         0,               1.044
>      2,      0,      2,         0,               1.041
>      2,      2,      2,         0,               1.041
>      2,   2050,      0,         0,               1.044
>      2,   2048,      2,         0,               1.042
>      2,   2050,      2,         0,               1.041
>      2,   4095,      0,         0,               1.057
>      2,      0,   4095,         0,               1.022
>      3,      0,      0,         0,               0.899
>      3,      3,      0,         0,               0.902
>      3,      0,      3,         0,                 0.9
>      3,      3,      3,         0,                 0.9
>      3,   2048,      0,         0,                 0.9
>      3,   2051,      0,         0,               0.902
>      3,   2048,      3,         0,                 0.9
>      3,   2051,      3,         0,                 0.9
>      3,   4095,      0,         0,               0.261
>      3,      0,   4095,         0,               0.211
>      4,      4,      0,         0,               0.965
>      4,      0,      4,         0,               0.962
>      4,      4,      4,         0,               0.962
>      4,   2052,      0,         0,               0.969
>      4,   2048,      4,         0,               0.962
>      4,   2052,      4,         0,               0.962
>      4,   4095,      0,         0,               1.971
>      4,      0,   4095,         0,               1.988
>      5,      0,      0,         0,               0.898
>      5,      5,      0,         0,                 0.9
>      5,      0,      5,         0,               0.898
>      5,      5,      5,         0,               0.898
>      5,   2048,      0,         0,               0.898
>      5,   2053,      0,         0,                 0.9
>      5,   2048,      5,         0,               0.898
>      5,   2053,      5,         0,               0.898
>      5,   4095,      0,         0,               0.935
>      5,      0,   4095,         0,                1.02
>      6,      0,      0,         0,               0.898
>      6,      6,      0,         0,                 0.9
>      6,      0,      6,         0,               0.898
>      6,      6,      6,         0,               0.898
>      6,   2048,      0,         0,               0.898
>      6,   2054,      0,         0,                 0.9
>      6,   2048,      6,         0,               0.898
>      6,   2054,      6,         0,               0.898
>      6,   4095,      0,         0,               0.935
>      6,      0,   4095,         0,               1.021
>      7,      0,      0,         0,               0.898
>      7,      7,      0,         0,                 0.9
>      7,      0,      7,         0,               0.898
>      7,      7,      7,         0,               0.898
>      7,   2048,      0,         0,               0.898
>      7,   2055,      0,         0,                 0.9
>      7,   2048,      7,         0,               0.898
>      7,   2055,      7,         0,               0.898
>      7,   4095,      0,         0,               0.935
>      7,      0,   4095,         0,               1.021
>      8,      8,      0,         0,               1.001
>      8,      0,      8,         0,               0.962
>      8,      8,      8,         0,               0.962
>      8,   2056,      0,         0,                 1.0
>      8,   2048,      8,         0,               0.962
>      8,   2056,      8,         0,               0.962
>      8,   4095,      0,         0,               1.971
>      8,      0,   4095,         0,               1.988
>      9,      0,      0,         0,               0.898
>      9,      9,      0,         0,                 0.9
>      9,      0,      9,         0,               0.899
>      9,      9,      9,         0,               0.899
>      9,   2048,      0,         0,               0.899
>      9,   2057,      0,         0,                 0.9
>      9,   2048,      9,         0,               0.899
>      9,   2057,      9,         0,               0.899
>      9,   4095,      0,         0,               0.935
>      9,      0,   4095,         0,               1.019
>     10,      0,      0,         0,               0.898
>     10,     10,      0,         0,                 0.9
>     10,      0,     10,         0,               0.899
>     10,     10,     10,         0,               0.899
>     10,   2048,      0,         0,               0.899
>     10,   2058,      0,         0,                 0.9
>     10,   2048,     10,         0,               0.899
>     10,   2058,     10,         0,               0.899
>     10,   4095,      0,         0,               0.935
>     10,      0,   4095,         0,                1.02
>     11,      0,      0,         0,               0.898
>     11,     11,      0,         0,                 0.9
>     11,      0,     11,         0,               0.899
>     11,     11,     11,         0,               0.899
>     11,   2048,      0,         0,               0.899
>     11,   2059,      0,         0,                 0.9
>     11,   2048,     11,         0,               0.899
>     11,   2059,     11,         0,               0.899
>     11,   4095,      0,         0,               0.935
>     11,      0,   4095,         0,                1.02
>     12,      0,      0,         0,               0.898
>     12,     12,      0,         0,                 0.9
>     12,      0,     12,         0,               0.899
>     12,     12,     12,         0,               0.899
>     12,   2048,      0,         0,               0.899
>     12,   2060,      0,         0,                 0.9
>     12,   2048,     12,         0,               0.899
>     12,   2060,     12,         0,               0.899
>     12,   4095,      0,         0,               0.935
>     12,      0,   4095,         0,               1.018
>     13,      0,      0,         0,               0.897
>     13,     13,      0,         0,               0.901
>     13,      0,     13,         0,               0.898
>     13,     13,     13,         0,               0.898
>     13,   2048,      0,         0,               0.898
>     13,   2061,      0,         0,                 0.9
>     13,   2048,     13,         0,               0.898
>     13,   2061,     13,         0,               0.898
>     13,   4095,      0,         0,               0.935
>     13,      0,   4095,         0,               1.019
>     14,      0,      0,         0,               0.897
>     14,     14,      0,         0,                 0.9
>     14,      0,     14,         0,               0.898
>     14,     14,     14,         0,               0.898
>     14,   2048,      0,         0,               0.898
>     14,   2062,      0,         0,                 0.9
>     14,   2048,     14,         0,               0.898
>     14,   2062,     14,         0,               0.898
>     14,   4095,      0,         0,               0.935
>     14,      0,   4095,         0,                1.02
>     15,      0,      0,         0,               0.897
>     15,     15,      0,         0,               0.901
>     15,      0,     15,         0,               0.898
>     15,     15,     15,         0,               0.898
>     15,   2048,      0,         0,               0.898
>     15,   2063,      0,         0,                 0.9
>     15,   2048,     15,         0,               0.898
>     15,   2063,     15,         0,               0.898
>     15,   4095,      0,         0,               0.935
>     15,      0,   4095,         0,                1.02
>     16,     16,      0,         0,               0.801
>     16,      0,     16,         0,               0.799
>     16,     16,     16,         0,               0.799
>     16,   2064,      0,         0,               0.801
>     16,   2048,     16,         0,               0.799
>     16,   2064,     16,         0,               0.799
>     16,   4095,      0,         0,               1.818
>     16,      0,   4095,         0,               1.957
>     17,      0,      0,         0,               0.798
>     17,     17,      0,         0,               0.801
>     17,      0,     17,         0,               0.799
>     17,     17,     17,         0,               0.799
>     17,   2048,      0,         0,               0.799
>     17,   2065,      0,         0,               0.801
>     17,   2048,     17,         0,               0.799
>     17,   2065,     17,         0,               0.799
>     17,   4095,      0,         0,               0.938
>     17,      0,   4095,         0,               1.021
>     18,      0,      0,         0,               0.798
>     18,     18,      0,         0,               0.801
>     18,      0,     18,         0,               0.799
>     18,     18,     18,         0,               0.799
>     18,   2048,      0,         0,               0.799
>     18,   2066,      0,         0,               0.801
>     18,   2048,     18,         0,               0.799
>     18,   2066,     18,         0,               0.799
>     18,   4095,      0,         0,               0.938
>     18,      0,   4095,         0,               1.021
>     19,      0,      0,         0,               0.798
>     19,     19,      0,         0,               0.801
>     19,      0,     19,         0,               0.799
>     19,     19,     19,         0,               0.799
>     19,   2048,      0,         0,               0.799
>     19,   2067,      0,         0,               0.801
>     19,   2048,     19,         0,               0.799
>     19,   2067,     19,         0,               0.799
>     19,   4095,      0,         0,               0.938
>     19,      0,   4095,         0,               1.021
>     20,      0,      0,         0,               0.798
>     20,     20,      0,         0,               0.801
>     20,      0,     20,         0,               0.799
>     20,     20,     20,         0,               0.799
>     20,   2048,      0,         0,               0.799
>     20,   2068,      0,         0,               0.801
>     20,   2048,     20,         0,               0.799
>     20,   2068,     20,         0,               0.799
>     20,   4095,      0,         0,               0.937
>     20,      0,   4095,         0,               1.021
>     21,      0,      0,         0,               0.798
>     21,     21,      0,         0,               0.801
>     21,      0,     21,         0,               0.799
>     21,     21,     21,         0,               0.799
>     21,   2048,      0,         0,               0.799
>     21,   2069,      0,         0,               0.801
>     21,   2048,     21,         0,               0.799
>     21,   2069,     21,         0,               0.799
>     21,   4095,      0,         0,               0.938
>     21,      0,   4095,         0,               1.021
>     22,      0,      0,         0,               0.798
>     22,     22,      0,         0,               0.801
>     22,      0,     22,         0,               0.799
>     22,     22,     22,         0,               0.799
>     22,   2048,      0,         0,               0.799
>     22,   2070,      0,         0,               0.801
>     22,   2048,     22,         0,               0.799
>     22,   2070,     22,         0,               0.799
>     22,   4095,      0,         0,               0.938
>     22,      0,   4095,         0,               1.021
>     23,      0,      0,         0,               0.798
>     23,     23,      0,         0,               0.801
>     23,      0,     23,         0,               0.799
>     23,     23,     23,         0,               0.799
>     23,   2048,      0,         0,               0.799
>     23,   2071,      0,         0,               0.801
>     23,   2048,     23,         0,               0.799
>     23,   2071,     23,         0,               0.799
>     23,   4095,      0,         0,               0.938
>     23,      0,   4095,         0,               1.021
>     24,      0,      0,         0,               0.798
>     24,     24,      0,         0,               0.801
>     24,      0,     24,         0,               0.799
>     24,     24,     24,         0,               0.799
>     24,   2048,      0,         0,               0.799
>     24,   2072,      0,         0,               0.801
>     24,   2048,     24,         0,               0.799
>     24,   2072,     24,         0,               0.799
>     24,   4095,      0,         0,               0.937
>     24,      0,   4095,         0,               1.021
>     25,      0,      0,         0,               0.501
>     25,     25,      0,         0,               0.502
>     25,      0,     25,         0,               0.502
>     25,     25,     25,         0,               0.501
>     25,   2048,      0,         0,               0.501
>     25,   2073,      0,         0,               0.502
>     25,   2048,     25,         0,               0.502
>     25,   2073,     25,         0,               0.501
>     25,   4095,      0,         0,               0.974
>     25,      0,   4095,         0,                0.98
>     26,      0,      0,         0,               0.501
>     26,     26,      0,         0,               0.502
>     26,      0,     26,         0,               0.502
>     26,     26,     26,         0,               0.501
>     26,   2048,      0,         0,               0.501
>     26,   2074,      0,         0,               0.502
>     26,   2048,     26,         0,               0.502
>     26,   2074,     26,         0,               0.501
>     26,   4095,      0,         0,               0.974
>     26,      0,   4095,         0,                 1.0
>     27,      0,      0,         0,               0.501
>     27,     27,      0,         0,               0.502
>     27,      0,     27,         0,               0.502
>     27,     27,     27,         0,               0.501
>     27,   2048,      0,         0,               0.501
>     27,   2075,      0,         0,               0.502
>     27,   2048,     27,         0,               0.502
>     27,   2075,     27,         0,               0.501
>     27,   4095,      0,         0,               0.974
>     27,      0,   4095,         0,                 1.0
>     28,      0,      0,         0,               0.501
>     28,     28,      0,         0,               0.502
>     28,      0,     28,         0,               0.502
>     28,     28,     28,         0,               0.501
>     28,   2048,      0,         0,               0.501
>     28,   2076,      0,         0,               0.502
>     28,   2048,     28,         0,               0.502
>     28,   2076,     28,         0,               0.502
>     28,   4095,      0,         0,               0.974
>     28,      0,   4095,         0,                 1.0
>     29,      0,      0,         0,               0.472
>     29,     29,      0,         0,               0.472
>     29,      0,     29,         0,               0.472
>     29,     29,     29,         0,               0.472
>     29,   2048,      0,         0,               0.472
>     29,   2077,      0,         0,               0.472
>     29,   2048,     29,         0,               0.472
>     29,   2077,     29,         0,               0.472
>     29,   4095,      0,         0,               0.974
>     29,      0,   4095,         0,                 1.0
>     30,      0,      0,         0,               0.472
>     30,     30,      0,         0,               0.472
>     30,      0,     30,         0,               0.472
>     30,     30,     30,         0,               0.472
>     30,   2048,      0,         0,               0.472
>     30,   2078,      0,         0,               0.472
>     30,   2048,     30,         0,               0.472
>     30,   2078,     30,         0,               0.472
>     30,   4095,      0,         0,               0.974
>     30,      0,   4095,         0,                 1.0
>     31,      0,      0,         0,               0.472
>     31,     31,      0,         0,               0.472
>     31,      0,     31,         0,               0.472
>     31,     31,     31,         0,               0.472
>     31,   2048,      0,         0,               0.472
>     31,   2079,      0,         0,               0.472
>     31,   2048,     31,         0,               0.472
>     31,   2079,     31,         0,               0.472
>     31,   4095,      0,         0,               0.974
>     31,      0,   4095,         0,                 1.0
>     48,      0,      0,         0,                 1.0
>     48,      0,      0,         1,                 1.0
>     48,      3,      0,         0,                 1.0
>     48,      3,      0,         1,                 1.0
>     48,      0,      3,         0,                 1.0
>     48,      0,      3,         1,                 1.0
>     48,      3,      3,         0,                 1.0
>     48,      3,      3,         1,                 1.0
>     48,   2048,      0,         0,                 1.0
>     48,   2048,      0,         1,                 1.0
>     48,   2051,      0,         0,                 1.0
>     48,   2051,      0,         1,                 1.0
>     48,   2048,      3,         0,                 1.0
>     48,   2048,      3,         1,                 1.0
>     48,   2051,      3,         0,                 1.0
>     48,   2051,      3,         1,                 1.0
>     80,      0,      0,         0,               0.781
>     80,      0,      0,         1,               0.782
>     80,      5,      0,         0,               0.976
>     80,      5,      0,         1,               0.976
>     80,      0,      5,         0,               1.232
>     80,      0,      5,         1,               1.232
>     80,      5,      5,         0,               1.542
>     80,      5,      5,         1,               1.543
>     80,   2048,      0,         0,               0.781
>     80,   2048,      0,         1,               0.782
>     80,   2053,      0,         0,               0.976
>     80,   2053,      0,         1,               0.976
>     80,   2048,      5,         0,               1.093
>     80,   2048,      5,         1,               1.093
>     80,   2053,      5,         0,               1.371
>     80,   2053,      5,         1,               1.371
>     96,      0,      0,         0,               0.758
>     96,      0,      0,         1,               0.758
>     96,      6,      0,         0,               0.929
>     96,      6,      0,         1,               0.929
>     96,      0,      6,         0,               1.204
>     96,      0,      6,         1,               1.204
>     96,      6,      6,         0,               1.559
>     96,      6,      6,         1,               1.562
>     96,   2048,      0,         0,               0.758
>     96,   2048,      0,         1,               0.758
>     96,   2054,      0,         0,               0.929
>     96,   2054,      0,         1,               0.929
>     96,   2048,      6,         0,               1.068
>     96,   2048,      6,         1,               1.068
>     96,   2054,      6,         0,               1.562
>     96,   2054,      6,         1,               1.562
>    112,      0,      0,         0,               0.736
>    112,      0,      0,         1,               0.736
>    112,      7,      0,         0,               0.675
>    112,      7,      0,         1,               0.675
>    112,      0,      7,         0,               0.778
>    112,      0,      7,         1,               0.778
>    112,      7,      7,         0,               0.909
>    112,      7,      7,         1,               0.909
>    112,   2048,      0,         0,               0.736
>    112,   2048,      0,         1,               0.736
>    112,   2055,      0,         0,               0.675
>    112,   2055,      0,         1,               0.675
>    112,   2048,      7,         0,               0.778
>    112,   2048,      7,         1,               0.778
>    112,   2055,      7,         0,               0.909
>    112,   2055,      7,         1,               0.909
>    144,      0,      0,         0,               0.857
>    144,      0,      0,         1,               0.857
>    144,      9,      0,         0,               0.939
>    144,      9,      0,         1,               0.939
>    144,      0,      9,         0,               1.137
>    144,      0,      9,         1,               1.137
>    144,      9,      9,         0,               1.514
>    144,      9,      9,         1,               1.514
>    144,   2048,      0,         0,               0.857
>    144,   2048,      0,         1,               0.857
>    144,   2057,      0,         0,               0.939
>    144,   2057,      0,         1,               0.939
>    144,   2048,      9,         0,               0.922
>    144,   2048,      9,         1,               0.922
>    144,   2057,      9,         0,               1.514
>    144,   2057,      9,         1,               1.514
>    160,      0,      0,         0,               0.698
>    160,      0,      0,         1,               0.698
>    160,     10,      0,         0,                0.91
>    160,     10,      0,         1,                0.91
>    160,      0,     10,         0,               1.211
>    160,      0,     10,         1,               1.212
>    160,     10,     10,         0,               1.357
>    160,     10,     10,         1,               1.357
>    160,   2048,      0,         0,               0.698
>    160,   2048,      0,         1,               0.698
>    160,   2058,      0,         0,                0.91
>    160,   2058,      0,         1,                0.91
>    160,   2048,     10,         0,               0.923
>    160,   2048,     10,         1,               0.923
>    160,   2058,     10,         0,               1.357
>    160,   2058,     10,         1,               1.357
>    176,      0,      0,         0,               0.796
>    176,      0,      0,         1,               0.796
>    176,     11,      0,         0,               0.804
>    176,     11,      0,         1,               0.804
>    176,      0,     11,         0,               0.774
>    176,      0,     11,         1,               0.774
>    176,     11,     11,         0,               0.814
>    176,     11,     11,         1,               0.814
>    176,   2048,      0,         0,               0.796
>    176,   2048,      0,         1,               0.796
>    176,   2059,      0,         0,               0.804
>    176,   2059,      0,         1,               0.804
>    176,   2048,     11,         0,               0.774
>    176,   2048,     11,         1,               0.774
>    176,   2059,     11,         0,               0.814
>    176,   2059,     11,         1,               0.814
>    192,      0,      0,         0,               0.778
>    192,      0,      0,         1,               0.778
>    192,     12,      0,         0,               0.881
>    192,     12,      0,         1,               0.881
>    192,      0,     12,         0,               1.167
>    192,      0,     12,         1,               1.167
>    192,     12,     12,         0,               0.841
>    192,     12,     12,         1,               0.841
>    192,   2048,      0,         0,               0.778
>    192,   2048,      0,         1,               0.778
>    192,   2060,      0,         0,               0.881
>    192,   2060,      0,         1,               0.881
>    192,   2048,     12,         0,               0.889
>    192,   2048,     12,         1,               0.889
>    192,   2060,     12,         0,               0.906
>    192,   2060,     12,         1,               0.906
>    208,      0,      0,         0,               0.833
>    208,      0,      0,         1,               0.833
>    208,     13,      0,         0,               0.921
>    208,     13,      0,         1,               0.921
>    208,      0,     13,         0,               1.003
>    208,      0,     13,         1,                0.85
>    208,     13,     13,         0,               1.333
>    208,     13,     13,         1,               1.333
>    208,   2048,      0,         0,               0.834
>    208,   2048,      0,         1,               0.833
>    208,   2061,      0,         0,               0.921
>    208,   2061,      0,         1,               0.921
>    208,   2048,     13,         0,               0.833
>    208,   2048,     13,         1,               0.833
>    208,   2061,     13,         0,               1.333
>    208,   2061,     13,         1,               1.333
>    224,      0,      0,         0,                0.93
>    224,      0,      0,         1,                0.93
>    224,     14,      0,         0,                 1.0
>    224,     14,      0,         1,                 1.0
>    224,      0,     14,         0,                1.15
>    224,      0,     14,         1,                1.15
>    224,     14,     14,         0,               1.452
>    224,     14,     14,         1,               1.452
>    224,   2048,      0,         0,                0.93
>    224,   2048,      0,         1,                0.93
>    224,   2062,      0,         0,                 1.0
>    224,   2062,      0,         1,                 1.0
>    224,   2048,     14,         0,               0.833
>    224,   2048,     14,         1,               0.833
>    224,   2062,     14,         0,               1.452
>    224,   2062,     14,         1,               1.452
>    240,      0,      0,         0,               0.909
>    240,      0,      0,         1,               0.909
>    240,     15,      0,         0,               0.797
>    240,     15,      0,         1,               0.797
>    240,      0,     15,         0,               0.771
>    240,      0,     15,         1,               0.771
>    240,     15,     15,         0,                0.93
>    240,     15,     15,         1,                0.93
>    240,   2048,      0,         0,               0.909
>    240,   2048,      0,         1,               0.909
>    240,   2063,      0,         0,               0.797
>    240,   2063,      0,         1,               0.797
>    240,   2048,     15,         0,               0.771
>    240,   2048,     15,         1,               0.771
>    240,   2063,     15,         0,                0.93
>    240,   2063,     15,         1,                0.93
>    272,      0,      0,         0,                 0.9
>    272,      0,      0,         1,                 0.9
>    272,     17,      0,         0,               1.015
>    272,     17,      0,         1,               1.015
>    272,      0,     17,         0,               0.927
>    272,      0,     17,         1,               0.927
>    272,     17,     17,         0,               0.892
>    272,     17,     17,         1,               0.892
>    272,   2048,      0,         0,                 0.9
>    272,   2048,      0,         1,                 0.9
>    272,   2065,      0,         0,               1.015
>    272,   2065,      0,         1,               1.015
>    272,   2048,     17,         0,               0.927
>    272,   2048,     17,         1,               0.927
>    272,   2065,     17,         0,               0.878
>    272,   2065,     17,         1,               0.878
>    288,      0,      0,         0,               0.882
>    288,      0,      0,         1,               0.882
>    288,     18,      0,         0,               0.803
>    288,     18,      0,         1,               0.803
>    288,      0,     18,         0,               0.768
>    288,      0,     18,         1,               0.768
>    288,     18,     18,         0,               0.882
>    288,     18,     18,         1,               0.882
>    288,   2048,      0,         0,               0.882
>    288,   2048,      0,         1,               0.882
>    288,   2066,      0,         0,               0.803
>    288,   2066,      0,         1,               0.803
>    288,   2048,     18,         0,               0.768
>    288,   2048,     18,         1,               0.768
>    288,   2066,     18,         0,               0.882
>    288,   2066,     18,         1,               0.882
>    304,      0,      0,         0,               0.865
>    304,      0,      0,         1,               0.866
>    304,     19,      0,         0,               0.944
>    304,     19,      0,         1,               0.944
>    304,      0,     19,         0,               0.943
>    304,      0,     19,         1,               0.943
>    304,     19,     19,         0,               0.956
>    304,     19,     19,         1,               0.956
>    304,   2048,      0,         0,               0.865
>    304,   2048,      0,         1,               0.865
>    304,   2067,      0,         0,               0.944
>    304,   2067,      0,         1,               0.944
>    304,   2048,     19,         0,               0.943
>    304,   2048,     19,         1,               0.943
>    304,   2067,     19,         0,               0.947
>    304,   2067,     19,         1,               0.947
>    320,      0,      0,         0,               0.944
>    320,      0,      0,         1,               0.944
>    320,     20,      0,         0,               0.962
>    320,     20,      0,         1,               0.962
>    320,      0,     20,         0,               1.214
>    320,      0,     20,         1,               1.214
>    320,     20,     20,         0,               1.365
>    320,     20,     20,         1,               1.365
>    320,   2048,      0,         0,               0.944
>    320,   2048,      0,         1,               0.944
>    320,   2068,      0,         0,               0.962
>    320,   2068,      0,         1,               0.962
>    320,   2048,     20,         0,               0.914
>    320,   2048,     20,         1,               0.914
>    320,   2068,     20,         0,               1.365
>    320,   2068,     20,         1,               1.365
>    336,      0,      0,         0,                 1.0
>    336,      0,      0,         1,                 1.0
>    336,     21,      0,         0,               0.986
>    336,     21,      0,         1,               0.986
>    336,      0,     21,         0,               0.853
>    336,      0,     21,         1,               0.853
>    336,     21,     21,         0,               0.843
>    336,     21,     21,         1,               0.843
>    336,   2048,      0,         0,                 1.0
>    336,   2048,      0,         1,                 1.0
>    336,   2069,      0,         0,               0.986
>    336,   2069,      0,         1,               0.986
>    336,   2048,     21,         0,               0.853
>    336,   2048,     21,         1,               0.853
>    336,   2069,     21,         0,               0.831
>    336,   2069,     21,         1,               0.831
>    352,      0,      0,         0,                0.98
>    352,      0,      0,         1,                0.98
>    352,     22,      0,         0,               0.811
>    352,     22,      0,         1,               0.811
>    352,      0,     22,         0,               0.882
>    352,      0,     22,         1,               0.882
>    352,     22,     22,         0,                 1.1
>    352,     22,     22,         1,                 1.1
>    352,   2048,      0,         0,                0.98
>    352,   2048,      0,         1,                0.98
>    352,   2070,      0,         0,               0.811
>    352,   2070,      0,         1,               0.811
>    352,   2048,     22,         0,               0.882
>    352,   2048,     22,         1,               0.882
>    352,   2070,     22,         0,                 1.1
>    352,   2070,     22,         1,                 1.1
>    368,      0,      0,         0,               1.058
>    368,      0,      0,         1,               1.058
>    368,     23,      0,         0,                 1.0
>    368,     23,      0,         1,                 1.0
>    368,      0,     23,         0,               0.948
>    368,      0,     23,         1,               0.948
>    368,     23,     23,         0,               0.723
>    368,     23,     23,         1,               0.723
>    368,   2048,      0,         0,               1.058
>    368,   2048,      0,         1,               1.058
>    368,   2071,      0,         0,                 1.0
>    368,   2071,      0,         1,                 1.0
>    368,   2048,     23,         0,               0.948
>    368,   2048,     23,         1,               0.948
>    368,   2071,     23,         0,               0.701
>    368,   2071,     23,         1,               0.701
>    384,      0,      0,         0,               1.012
>    384,      0,      0,         1,               1.012
>    384,     24,      0,         0,                1.04
>    384,     24,      0,         1,                1.04
>    384,      0,     24,         0,               1.154
>    384,      0,     24,         1,               1.154
>    384,     24,     24,         0,               1.423
>    384,     24,     24,         1,               1.423
>    384,   2048,      0,         0,               1.012
>    384,   2048,      0,         1,               1.012
>    384,   2072,      0,         0,                1.04
>    384,   2072,      0,         1,                1.04
>    384,   2048,     24,         0,                0.91
>    384,   2048,     24,         1,                0.91
>    384,   2072,     24,         0,               1.423
>    384,   2072,     24,         1,               1.423
>    400,      0,      0,         0,               0.948
>    400,      0,      0,         1,               0.948
>    400,     25,      0,         0,               0.957
>    400,     25,      0,         1,               0.957
>    400,      0,     25,         0,               1.054
>    400,      0,     25,         1,               1.097
>    400,     25,     25,         0,               0.885
>    400,     25,     25,         1,               0.885
>    400,   2048,      0,         0,               0.948
>    400,   2048,      0,         1,               0.948
>    400,   2073,      0,         0,               0.957
>    400,   2073,      0,         1,               0.957
>    400,   2048,     25,         0,                0.94
>    400,   2048,     25,         1,                0.94
>    400,   2073,     25,         0,               0.908
>    400,   2073,     25,         1,               0.908
>    416,      0,      0,         0,               1.017
>    416,      0,      0,         1,               1.017
>    416,     26,      0,         0,               0.903
>    416,     26,      0,         1,               0.903
>    416,      0,     26,         0,               0.881
>    416,      0,     26,         1,               0.881
>    416,     26,     26,         0,               1.035
>    416,     26,     26,         1,               1.035
>    416,   2048,      0,         0,               1.017
>    416,   2048,      0,         1,               1.017
>    416,   2074,      0,         0,               0.903
>    416,   2074,      0,         1,               0.903
>    416,   2048,     26,         0,               0.881
>    416,   2048,     26,         1,               0.881
>    416,   2074,     26,         0,               1.035
>    416,   2074,     26,         1,               1.035
>    432,      0,      0,         0,                 1.0
>    432,      0,      0,         1,                 1.0
>    432,     27,      0,         0,               0.933
>    432,     27,      0,         1,               0.933
>    432,      0,     27,         0,               0.941
>    432,      0,     27,         1,               0.941
>    432,     27,     27,         0,               0.953
>    432,     27,     27,         1,               0.954
>    432,   2048,      0,         0,                 1.0
>    432,   2048,      0,         1,                 1.0
>    432,   2075,      0,         0,               0.933
>    432,   2075,      0,         1,               0.933
>    432,   2048,     27,         0,               0.941
>    432,   2048,     27,         1,               0.941
>    432,   2075,     27,         0,                0.93
>    432,   2075,     27,         1,                0.93
>    448,      0,      0,         0,               0.984
>    448,      0,      0,         1,               0.984
>    448,     28,      0,         0,               0.896
>    448,     28,      0,         1,               0.896
>    448,      0,     28,         0,               1.244
>    448,      0,     28,         1,               1.244
>    448,     28,     28,         0,               1.333
>    448,     28,     28,         1,               1.333
>    448,   2048,      0,         0,               0.984
>    448,   2048,      0,         1,               0.984
>    448,   2076,      0,         0,               0.896
>    448,   2076,      0,         1,               0.896
>    448,   2048,     28,         0,               0.988
>    448,   2048,     28,         1,               0.988
>    448,   2076,     28,         0,               1.333
>    448,   2076,     28,         1,               1.333
>    464,      0,      0,         0,               1.083
>    464,      0,      0,         1,               1.083
>    464,     29,      0,         0,               0.978
>    464,     29,      0,         1,               0.978
>    464,      0,     29,         0,               0.924
>    464,      0,     29,         1,               0.924
>    464,     29,     29,         0,               0.901
>    464,     29,     29,         1,               0.901
>    464,   2048,      0,         0,               1.083
>    464,   2048,      0,         1,               1.083
>    464,   2077,      0,         0,               0.978
>    464,   2077,      0,         1,               0.978
>    464,   2048,     29,         0,               0.924
>    464,   2048,     29,         1,               0.924
>    464,   2077,     29,         0,                0.89
>    464,   2077,     29,         1,                0.89
>    480,      0,      0,         0,               1.066
>    480,      0,      0,         1,               1.066
>    480,     30,      0,         0,                 0.9
>    480,     30,      0,         1,                 0.9
>    480,      0,     30,         0,                0.88
>    480,      0,     30,         1,                0.88
>    480,     30,     30,         0,               1.083
>    480,     30,     30,         1,               1.083
>    480,   2048,      0,         0,               1.066
>    480,   2048,      0,         1,               1.066
>    480,   2078,      0,         0,                 0.9
>    480,   2078,      0,         1,                 0.9
>    480,   2048,     30,         0,                0.88
>    480,   2048,     30,         1,                0.88
>    480,   2078,     30,         0,               1.083
>    480,   2078,     30,         1,               1.083
>    496,      0,      0,         0,               1.032
>    496,      0,      0,         1,               1.032
>    496,     31,      0,         0,                0.95
>    496,     31,      0,         1,                0.95
>    496,      0,     31,         0,               1.011
>    496,      0,     31,         1,               1.011
>    496,     31,     31,         0,               0.973
>    496,     31,     31,         1,               0.973
>    496,   2048,      0,         0,               1.032
>    496,   2048,      0,         1,               1.032
>    496,   2079,      0,         0,                0.95
>    496,   2079,      0,         1,                0.95
>    496,   2048,     31,         0,               1.011
>    496,   2048,     31,         1,               1.011
>    496,   2079,     31,         0,               0.941
>    496,   2079,     31,         1,               0.941
>   1024,     32,      0,         0,               1.143
>   1024,     32,      0,         1,               1.143
>   1024,      0,     32,         0,               1.143
>   1024,      0,     32,         1,               1.143
>   1024,     32,     32,         0,               1.143
>   1024,     32,     32,         1,               1.143
>   1024,   2080,      0,         0,               1.143
>   1024,   2080,      0,         1,               1.143
>   1024,   2048,     32,         0,               1.143
>   1024,   2048,     32,         1,               1.143
>   1024,   2080,     32,         0,               1.143
>   1024,   2080,     32,         1,               1.143
>   1056,      0,      0,         0,               1.165
>   1056,      0,      0,         1,               1.162
>   1056,     33,      0,         0,               1.067
>   1056,     33,      0,         1,               1.067
>   1056,      0,     33,         0,               0.977
>   1056,      0,     33,         1,               0.977
>   1056,     33,     33,         0,               1.043
>   1056,     33,     33,         1,               1.043
>   1056,   2048,      0,         0,               1.168
>   1056,   2048,      0,         1,               1.168
>   1056,   2081,      0,         0,               1.067
>   1056,   2081,      0,         1,               1.067
>   1056,   2048,     33,         0,               0.977
>   1056,   2048,     33,         1,               0.977
>   1056,   2081,     33,         0,                 1.0
>   1056,   2081,     33,         1,                 1.0
>   1088,      0,      0,         0,               1.171
>   1088,      0,      0,         1,               1.171
>   1088,     34,      0,         0,               1.041
>   1088,     34,      0,         1,               1.041
>   1088,      0,     34,         0,               1.079
>   1088,      0,     34,         1,               1.079
>   1088,     34,     34,         0,               0.966
>   1088,     34,     34,         1,               0.966
>   1088,   2048,      0,         0,               1.171
>   1088,   2048,      0,         1,               1.171
>   1088,   2082,      0,         0,               1.041
>   1088,   2082,      0,         1,               1.041
>   1088,   2048,     34,         0,               0.994
>   1088,   2048,     34,         1,               0.994
>   1088,   2082,     34,         0,               0.966
>   1088,   2082,     34,         1,               0.966
>   1120,      0,      0,         0,               1.154
>   1120,      0,      0,         1,               1.151
>   1120,     35,      0,         0,               1.051
>   1120,     35,      0,         1,               1.051
>   1120,      0,     35,         0,                 1.0
>   1120,      0,     35,         1,                 1.0
>   1120,     35,     35,         0,               1.068
>   1120,     35,     35,         1,               1.068
>   1120,   2048,      0,         0,               1.151
>   1120,   2048,      0,         1,               1.151
>   1120,   2083,      0,         0,               1.051
>   1120,   2083,      0,         1,               1.051
>   1120,   2048,     35,         0,                 1.0
>   1120,   2048,     35,         1,                 1.0
>   1120,   2083,     35,         0,               1.027
>   1120,   2083,     35,         1,               1.027
>   1152,      0,      0,         0,               1.159
>   1152,      0,      0,         1,               1.159
>   1152,     36,      0,         0,               1.034
>   1152,     36,      0,         1,               1.034
>   1152,      0,     36,         0,                1.07
>   1152,      0,     36,         1,                1.07
>   1152,     36,     36,         0,               0.967
>   1152,     36,     36,         1,               0.967
>   1152,   2048,      0,         0,               1.159
>   1152,   2048,      0,         1,               1.159
>   1152,   2084,      0,         0,               1.034
>   1152,   2084,      0,         1,               1.034
>   1152,   2048,     36,         0,               0.984
>   1152,   2048,     36,         1,               0.984
>   1152,   2084,     36,         0,               0.967
>   1152,   2084,     36,         1,               0.967
>   1184,      0,      0,         0,               1.157
>   1184,      0,      0,         1,               1.157
>   1184,     37,      0,         0,               1.066
>   1184,     37,      0,         1,               1.066
>   1184,      0,     37,         0,               0.993
>   1184,      0,     37,         1,               0.993
>   1184,     37,     37,         0,                1.08
>   1184,     37,     37,         1,               1.081
>   1184,   2048,      0,         0,               1.157
>   1184,   2048,      0,         1,               1.157
>   1184,   2085,      0,         0,               1.066
>   1184,   2085,      0,         1,               1.066
>   1184,   2048,     37,         0,               0.993
>   1184,   2048,     37,         1,               0.993
>   1184,   2085,     37,         0,                1.04
>   1184,   2085,     37,         1,                1.04
>   1216,      0,      0,         0,               1.139
>   1216,      0,      0,         1,               1.139
>   1216,     38,      0,         0,               1.024
>   1216,     38,      0,         1,               1.024
>   1216,      0,     38,         0,               1.086
>   1216,      0,     38,         1,               1.087
>   1216,     38,     38,         0,                 1.0
>   1216,     38,     38,         1,                 1.0
>   1216,   2048,      0,         0,               1.138
>   1216,   2048,      0,         1,               1.138
>   1216,   2086,      0,         0,               1.024
>   1216,   2086,      0,         1,               1.024
>   1216,   2048,     38,         0,                1.01
>   1216,   2048,     38,         1,                1.01
>   1216,   2086,     38,         0,                 1.0
>   1216,   2086,     38,         1,                 1.0
>   1248,      0,      0,         0,               1.175
>   1248,      0,      0,         1,               1.174
>   1248,     39,      0,         0,               1.074
>   1248,     39,      0,         1,               1.074
>   1248,      0,     39,         0,               0.975
>   1248,      0,     39,         1,               0.985
>   1248,     39,     39,         0,               1.064
>   1248,     39,     39,         1,               1.064
>   1248,   2048,      0,         0,               1.179
>   1248,   2048,      0,         1,               1.178
>   1248,   2087,      0,         0,               1.074
>   1248,   2087,      0,         1,               1.074
>   1248,   2048,     39,         0,               0.985
>   1248,   2048,     39,         1,               0.985
>   1248,   2087,     39,         0,               1.026
>   1248,   2087,     39,         1,               1.026
>   1280,      0,      0,         0,               0.992
>   1280,      0,      0,         1,               0.992
>   1280,     40,      0,         0,               1.051
>   1280,     40,      0,         1,               1.051
>   1280,      0,     40,         0,               1.044
>   1280,      0,     40,         1,               1.044
>   1280,     40,     40,         0,               1.252
>   1280,     40,     40,         1,               1.252
>   1280,   2048,      0,         0,               0.992
>   1280,   2048,      0,         1,               0.992
>   1280,   2088,      0,         0,               1.051
>   1280,   2088,      0,         1,               1.051
>   1280,   2048,     40,         0,               0.946
>   1280,   2048,     40,         1,               0.946
>   1280,   2088,     40,         0,               1.252
>   1280,   2088,     40,         1,               1.252
>   1312,      0,      0,         0,               0.969
>   1312,      0,      0,         1,               0.969
>   1312,     41,      0,         0,               0.988
>   1312,     41,      0,         1,               0.988
>   1312,      0,     41,         0,               0.837
>   1312,      0,     41,         1,               0.837
>   1312,     41,     41,         0,               1.025
>   1312,     41,     41,         1,               1.025
>   1312,   2048,      0,         0,               0.969
>   1312,   2048,      0,         1,               0.969
>   1312,   2089,      0,         0,               0.988
>   1312,   2089,      0,         1,               0.987
>   1312,   2048,     41,         0,               0.837
>   1312,   2048,     41,         1,               0.837
>   1312,   2089,     41,         0,               0.975
>   1312,   2089,     41,         1,               0.975
>   1344,      0,      0,         0,               0.987
>   1344,      0,      0,         1,               0.988
>   1344,     42,      0,         0,               1.031
>   1344,     42,      0,         1,               1.031
>   1344,      0,     42,         0,               1.033
>   1344,      0,     42,         1,               1.033
>   1344,     42,     42,         0,               0.982
>   1344,     42,     42,         1,               0.982
>   1344,   2048,      0,         0,               0.992
>   1344,   2048,      0,         1,               0.992
>   1344,   2090,      0,         0,               1.031
>   1344,   2090,      0,         1,               1.031
>   1344,   2048,     42,         0,               0.943
>   1344,   2048,     42,         1,               0.943
>   1344,   2090,     42,         0,               0.982
>   1344,   2090,     42,         1,               0.982
>   1376,      0,      0,         0,               1.016
>   1376,      0,      0,         1,               1.016
>   1376,     43,      0,         0,               1.005
>   1376,     43,      0,         1,               1.005
>   1376,      0,     43,         0,               0.829
>   1376,      0,     43,         1,               0.829
>   1376,     43,     43,         0,               1.024
>   1376,     43,     43,         1,               1.024
>   1376,   2048,      0,         0,               1.005
>   1376,   2048,      0,         1,               1.013
>   1376,   2091,      0,         0,               1.005
>   1376,   2091,      0,         1,               1.005
>   1376,   2048,     43,         0,               0.829
>   1376,   2048,     43,         1,               0.829
>   1376,   2091,     43,         0,                0.98
>   1376,   2091,     43,         1,                0.98
>   1408,      0,      0,         0,               0.988
>   1408,      0,      0,         1,               0.988
>   1408,     44,      0,         0,               1.015
>   1408,     44,      0,         1,               1.015
>   1408,      0,     44,         0,               1.023
>   1408,      0,     44,         1,                1.03
>   1408,     44,     44,         0,               0.998
>   1408,     44,     44,         1,               0.994
>   1408,   2048,      0,         0,               0.988
>   1408,   2048,      0,         1,               0.988
>   1408,   2092,      0,         0,               1.015
>   1408,   2092,      0,         1,               1.015
>   1408,   2048,     44,         0,               0.955
>   1408,   2048,     44,         1,               0.955
>   1408,   2092,     44,         0,               0.999
>   1408,   2092,     44,         1,               0.994
>   1440,      0,      0,         0,               0.986
>   1440,      0,      0,         1,               0.986
>   1440,     45,      0,         0,               1.008
>   1440,     45,      0,         1,               1.008
>   1440,      0,     45,         0,               0.814
>   1440,      0,     45,         1,               0.814
>   1440,     45,     45,         0,               1.006
>   1440,     45,     45,         1,               1.006
>   1440,   2048,      0,         0,               0.986
>   1440,   2048,      0,         1,               0.986
>   1440,   2093,      0,         0,               1.008
>   1440,   2093,      0,         1,               1.008
>   1440,   2048,     45,         0,               0.814
>   1440,   2048,     45,         1,               0.814
>   1440,   2093,     45,         0,               0.966
>   1440,   2093,     45,         1,               0.966
>   1472,      0,      0,         0,               0.993
>   1472,      0,      0,         1,               0.992
>   1472,     46,      0,         0,               1.045
>   1472,     46,      0,         1,               1.045
>   1472,      0,     46,         0,               1.026
>   1472,      0,     46,         1,               1.026
>   1472,     46,     46,         0,               0.966
>   1472,     46,     46,         1,               0.966
>   1472,   2048,      0,         0,               0.999
>   1472,   2048,      0,         1,               0.997
>   1472,   2094,      0,         0,               1.045
>   1472,   2094,      0,         1,               1.045
>   1472,   2048,     46,         0,               0.939
>   1472,   2048,     46,         1,               0.939
>   1472,   2094,     46,         0,               0.966
>   1472,   2094,     46,         1,               0.966
>   1504,      0,      0,         0,               0.991
>   1504,      0,      0,         1,               0.991
>   1504,     47,      0,         0,               0.999
>   1504,     47,      0,         1,               0.999
>   1504,      0,     47,         0,               0.826
>   1504,      0,     47,         1,               0.826
>   1504,     47,     47,         0,               1.023
>   1504,     47,     47,         1,               1.023
>   1504,   2048,      0,         0,               0.993
>   1504,   2048,      0,         1,               0.993
>   1504,   2095,      0,         0,               0.999
>   1504,   2095,      0,         1,               0.999
>   1504,   2048,     47,         0,               0.826
>   1504,   2048,     47,         1,               0.826
>   1504,   2095,     47,         0,               0.993
>   1504,   2095,     47,         1,               0.993
>   1536,      0,      0,         0,               0.994
>   1536,      0,      0,         1,               0.993
>   1536,     48,      0,         0,               1.019
>   1536,     48,      0,         1,               1.019
>   1536,      0,     48,         0,               1.025
>   1536,      0,     48,         1,               1.025
>   1536,     48,     48,         0,               0.993
>   1536,     48,     48,         1,               0.993
>   1536,   2048,      0,         0,               0.994
>   1536,   2048,      0,         1,               0.994
>   1536,   2096,      0,         0,               1.019
>   1536,   2096,      0,         1,               1.019
>   1536,   2048,     48,         0,               1.025
>   1536,   2048,     48,         1,               1.025
>   1536,   2096,     48,         0,               0.994
>   1536,   2096,     48,         1,               0.994
>   1568,      0,      0,         0,               0.994
>   1568,      0,      0,         1,               0.994
>   1568,     49,      0,         0,               0.903
>   1568,     49,      0,         1,               0.903
>   1568,      0,     49,         0,               1.147
>   1568,      0,     49,         1,               1.147
>   1568,     49,     49,         0,               1.461
>   1568,     49,     49,         1,                1.46
>   1568,   2048,      0,         0,               0.994
>   1568,   2048,      0,         1,               0.993
>   1568,   2097,      0,         0,               0.903
>   1568,   2097,      0,         1,               0.903
>   1568,   2048,     49,         0,                1.09
>   1568,   2048,     49,         1,                1.09
>   1568,   2097,     49,         0,                1.46
>   1568,   2097,     49,         1,                1.46
>   1600,      0,      0,         0,               0.981
>   1600,      0,      0,         1,               0.981
>   1600,     50,      0,         0,               1.022
>   1600,     50,      0,         1,               1.022
>   1600,      0,     50,         0,               1.017
>   1600,      0,     50,         1,               1.017
>   1600,     50,     50,         0,               0.973
>   1600,     50,     50,         1,               0.973
>   1600,   2048,      0,         0,               0.981
>   1600,   2048,      0,         1,               0.981
>   1600,   2098,      0,         0,               1.022
>   1600,   2098,      0,         1,               1.022
>   1600,   2048,     50,         0,               0.961
>   1600,   2048,     50,         1,               0.961
>   1600,   2098,     50,         0,               0.973
>   1600,   2098,     50,         1,               0.973
>   1632,      0,      0,         0,               1.018
>   1632,      0,      0,         1,               1.018
>   1632,     51,      0,         0,               0.893
>   1632,     51,      0,         1,               0.893
>   1632,      0,     51,         0,               1.134
>   1632,      0,     51,         1,               1.134
>   1632,     51,     51,         0,               1.444
>   1632,     51,     51,         1,               1.444
>   1632,   2048,      0,         0,               1.019
>   1632,   2048,      0,         1,               1.019
>   1632,   2099,      0,         0,               0.893
>   1632,   2099,      0,         1,               0.893
>   1632,   2048,     51,         0,               1.079
>   1632,   2048,     51,         1,               1.079
>   1632,   2099,     51,         0,               1.449
>   1632,   2099,     51,         1,               1.449
>   1664,      0,      0,         0,               1.006
>   1664,      0,      0,         1,               1.006
>   1664,     52,      0,         0,               0.982
>   1664,     52,      0,         1,               0.986
>   1664,      0,     52,         0,               1.004
>   1664,      0,     52,         1,               1.004
>   1664,     52,     52,         0,               0.976
>   1664,     52,     52,         1,               0.976
>   1664,   2048,      0,         0,               1.006
>   1664,   2048,      0,         1,               1.006
>   1664,   2100,      0,         0,               0.983
>   1664,   2100,      0,         1,               0.983
>   1664,   2048,     52,         0,               0.946
>   1664,   2048,     52,         1,               0.946
>   1664,   2100,     52,         0,               0.976
>   1664,   2100,     52,         1,               0.976
>   1696,      0,      0,         0,                0.99
>   1696,      0,      0,         1,                0.99
>   1696,     53,      0,         0,               0.884
>   1696,     53,      0,         1,               0.884
>   1696,      0,     53,         0,               1.141
>   1696,      0,     53,         1,               1.141
>   1696,     53,     53,         0,                1.43
>   1696,     53,     53,         1,               1.428
>   1696,   2048,      0,         0,               0.994
>   1696,   2048,      0,         1,               0.993
>   1696,   2101,      0,         0,               0.884
>   1696,   2101,      0,         1,               0.884
>   1696,   2048,     53,         0,               1.088
>   1696,   2048,     53,         1,               1.088
>   1696,   2101,     53,         0,               1.429
>   1696,   2101,     53,         1,               1.429
>   1728,      0,      0,         0,               0.978
>   1728,      0,      0,         1,               0.977
>   1728,     54,      0,         0,               1.032
>   1728,     54,      0,         1,               1.033
>   1728,      0,     54,         0,                 1.0
>   1728,      0,     54,         1,                 1.0
>   1728,     54,     54,         0,                0.96
>   1728,     54,     54,         1,                0.96
>   1728,   2048,      0,         0,               0.976
>   1728,   2048,      0,         1,               0.976
>   1728,   2102,      0,         0,               1.033
>   1728,   2102,      0,         1,               1.033
>   1728,   2048,     54,         0,               0.947
>   1728,   2048,     54,         1,               0.947
>   1728,   2102,     54,         0,                0.96
>   1728,   2102,     54,         1,                0.96
>   1760,      0,      0,         0,               1.019
>   1760,      0,      0,         1,               1.022
>   1760,     55,      0,         0,                 0.9
>   1760,     55,      0,         1,                 0.9
>   1760,      0,     55,         0,               1.125
>   1760,      0,     55,         1,               1.125
>   1760,     55,     55,         0,               1.438
>   1760,     55,     55,         1,               1.439
>   1760,   2048,      0,         0,               1.015
>   1760,   2048,      0,         1,               1.015
>   1760,   2103,      0,         0,                 0.9
>   1760,   2103,      0,         1,                 0.9
>   1760,   2048,     55,         0,               1.073
>   1760,   2048,     55,         1,               1.074
>   1760,   2103,     55,         0,               1.435
>   1760,   2103,     55,         1,                1.44
>   1792,      0,      0,         0,               1.003
>   1792,      0,      0,         1,               1.002
>   1792,     56,      0,         0,               1.028
>   1792,     56,      0,         1,               1.028
>   1792,      0,     56,         0,               1.014
>   1792,      0,     56,         1,               1.015
>   1792,     56,     56,         0,               1.191
>   1792,     56,     56,         1,               1.191
>   1792,   2048,      0,         0,               1.003
>   1792,   2048,      0,         1,               1.003
>   1792,   2104,      0,         0,               1.028
>   1792,   2104,      0,         1,               1.028
>   1792,   2048,     56,         0,               0.963
>   1792,   2048,     56,         1,               0.963
>   1792,   2104,     56,         0,               1.191
>   1792,   2104,     56,         1,               1.191
>   1824,      0,      0,         0,               1.001
>   1824,      0,      0,         1,               1.001
>   1824,     57,      0,         0,               0.891
>   1824,     57,      0,         1,               0.891
>   1824,      0,     57,         0,               1.114
>   1824,      0,     57,         1,               1.114
>   1824,     57,     57,         0,               1.407
>   1824,     57,     57,         1,               1.407
>   1824,   2048,      0,         0,               1.001
>   1824,   2048,      0,         1,               1.001
>   1824,   2105,      0,         0,               0.891
>   1824,   2105,      0,         1,               0.891
>   1824,   2048,     57,         0,               1.064
>   1824,   2048,     57,         1,               1.064
>   1824,   2105,     57,         0,               1.407
>   1824,   2105,     57,         1,               1.407
>   1856,      0,      0,         0,               0.991
>   1856,      0,      0,         1,               0.991
>   1856,     58,      0,         0,               1.042
>   1856,     58,      0,         1,               1.042
>   1856,      0,     58,         0,               1.007
>   1856,      0,     58,         1,               1.007
>   1856,     58,     58,         0,                0.98
>   1856,     58,     58,         1,               0.972
>   1856,   2048,      0,         0,               0.992
>   1856,   2048,      0,         1,               0.992
>   1856,   2106,      0,         0,               1.042
>   1856,   2106,      0,         1,               1.042
>   1856,   2048,     58,         0,               0.954
>   1856,   2048,     58,         1,               0.954
>   1856,   2106,     58,         0,                0.98
>   1856,   2106,     58,         1,               0.972
>   1888,      0,      0,         0,               0.993
>   1888,      0,      0,         1,               0.992
>   1888,     59,      0,         0,               0.883
>   1888,     59,      0,         1,               0.883
>   1888,      0,     59,         0,               1.124
>   1888,      0,     59,         1,               1.125
>   1888,     59,     59,         0,               1.413
>   1888,     59,     59,         1,               1.413
>   1888,   2048,      0,         0,               0.986
>   1888,   2048,      0,         1,               0.991
>   1888,   2107,      0,         0,               0.883
>   1888,   2107,      0,         1,               0.883
>   1888,   2048,     59,         0,               1.076
>   1888,   2048,     59,         1,               1.076
>   1888,   2107,     59,         0,               1.413
>   1888,   2107,     59,         1,               1.413
>   1920,      0,      0,         0,                 1.0
>   1920,      0,      0,         1,                 1.0
>   1920,     60,      0,         0,               1.033
>   1920,     60,      0,         1,               1.034
>   1920,      0,     60,         0,               0.996
>   1920,      0,     60,         1,               0.997
>   1920,     60,     60,         0,               0.968
>   1920,     60,     60,         1,               0.968
>   1920,   2048,      0,         0,                 1.0
>   1920,   2048,      0,         1,                 1.0
>   1920,   2108,      0,         0,               1.034
>   1920,   2108,      0,         1,               1.034
>   1920,   2048,     60,         0,               0.949
>   1920,   2048,     60,         1,               0.949
>   1920,   2108,     60,         0,               0.968
>   1920,   2108,     60,         1,               0.968
>   1952,      0,      0,         0,               1.004
>   1952,      0,      0,         1,               1.004
>   1952,     61,      0,         0,               0.897
>   1952,     61,      0,         1,               0.898
>   1952,      0,     61,         0,               1.118
>   1952,      0,     61,         1,               1.118
>   1952,     61,     61,         0,               1.387
>   1952,     61,     61,         1,               1.387
>   1952,   2048,      0,         0,               1.004
>   1952,   2048,      0,         1,               1.004
>   1952,   2109,      0,         0,               0.898
>   1952,   2109,      0,         1,               0.898
>   1952,   2048,     61,         0,               1.071
>   1952,   2048,     61,         1,               1.071
>   1952,   2109,     61,         0,               1.387
>   1952,   2109,     61,         1,               1.387
>   1984,      0,      0,         0,               0.993
>   1984,      0,      0,         1,               0.993
>   1984,     62,      0,         0,               1.025
>   1984,     62,      0,         1,               1.025
>   1984,      0,     62,         0,               1.005
>   1984,      0,     62,         1,               1.007
>   1984,     62,     62,         0,               0.982
>   1984,     62,     62,         1,               0.982
>   1984,   2048,      0,         0,               0.993
>   1984,   2048,      0,         1,               0.993
>   1984,   2110,      0,         0,               1.025
>   1984,   2110,      0,         1,               1.025
>   1984,   2048,     62,         0,                0.96
>   1984,   2048,     62,         1,                0.96
>   1984,   2110,     62,         0,               0.982
>   1984,   2110,     62,         1,               0.982
>   2016,      0,      0,         0,               0.999
>   2016,      0,      0,         1,               0.999
>   2016,     63,      0,         0,               0.889
>   2016,     63,      0,         1,                0.89
>   2016,      0,     63,         0,               1.093
>   2016,      0,     63,         1,               1.094
>   2016,     63,     63,         0,               1.362
>   2016,     63,     63,         1,               1.363
>   2016,   2048,      0,         0,                 1.0
>   2016,   2048,      0,         1,                 1.0
>   2016,   2111,      0,         0,               0.965
>   2016,   2111,      0,         1,               0.965
>   2016,   2048,     63,         0,               1.049
>   2016,   2048,     63,         1,               1.049
>   2016,   2111,     63,         0,               1.405
>   2016,   2111,     63,         1,               1.405
>   2048,     32,      0,         0,                1.01
>   2048,     32,      0,         1,                1.01
>   2048,      0,     32,         0,               1.005
>   2048,      0,     32,         1,               1.005
>   2048,     32,     32,         0,               1.005
>   2048,     32,     32,         1,               1.005
>   2048,      0,      1,         0,               0.983
>   2048,      0,      1,         1,               0.984
>   2048,      1,      0,         0,               1.039
>   2048,      1,      0,         1,               1.039
>   2048,     32,      1,         0,               1.063
>   2048,     32,      1,         1,               1.063
>   2048,      1,     32,         0,                0.94
>   2048,      1,     32,         1,                0.94
>   2048,   2048,      1,         0,               0.981
>   2048,   2048,      1,         1,               0.981
>   2048,   2049,      0,         0,               0.904
>   2048,   2049,      0,         1,               0.904
>   2112,      0,      0,         0,               0.996
>   2112,      0,      0,         1,               0.996
>   2112,      1,      0,         0,               1.031
>   2112,      1,      0,         1,               1.031
>   2112,     33,      0,         0,                1.01
>   2112,     33,      0,         1,                1.01
>   2112,      0,      1,         0,               0.972
>   2112,      0,      1,         1,               0.972
>   2112,      0,     33,         0,               0.988
>   2112,      0,     33,         1,               0.988
>   2112,      1,      1,         0,               0.914
>   2112,      1,      1,         1,               0.914
>   2112,     33,     33,         0,               0.983
>   2112,     33,     33,         1,               0.983
>   2112,   2048,      0,         0,               0.993
>   2112,   2048,      0,         1,               0.991
>   2112,   2049,      0,         0,               1.031
>   2112,   2049,      0,         1,               1.031
>   2112,   2048,      1,         0,               0.955
>   2112,   2048,      1,         1,               0.955
>   2112,   2049,      1,         0,               0.906
>   2112,   2049,      1,         1,               0.906
>   2112,     33,      1,         0,               1.163
>   2112,     33,      1,         1,               1.164
>   2112,      1,     33,         0,               1.046
>   2112,      1,     33,         1,               1.046
>   2176,      0,      0,         0,               0.985
>   2176,      0,      0,         1,               0.985
>   2176,      2,      0,         0,               1.023
>   2176,      2,      0,         1,               1.023
>   2176,     34,      0,         0,                 1.0
>   2176,     34,      0,         1,                 1.0
>   2176,      0,      2,         0,               0.984
>   2176,      0,      2,         1,               0.985
>   2176,      0,     34,         0,               0.986
>   2176,      0,     34,         1,               0.993
>   2176,      2,      2,         0,               0.928
>   2176,      2,      2,         1,               0.928
>   2176,     34,     34,         0,               1.004
>   2176,     34,     34,         1,               1.004
>   2176,   2048,      0,         0,               0.985
>   2176,   2048,      0,         1,               0.985
>   2176,   2050,      0,         0,               1.023
>   2176,   2050,      0,         1,               1.023
>   2176,   2048,      2,         0,               0.802
>   2176,   2048,      2,         1,               0.802
>   2176,   2050,      2,         0,               0.894
>   2176,   2050,      2,         1,               0.894
>   2176,      2,      1,         0,               1.068
>   2176,      2,      1,         1,               1.068
>   2176,      1,      2,         0,               0.976
>   2176,      1,      2,         1,               0.976
>   2176,     34,      1,         0,               1.077
>   2176,     34,      1,         1,               1.077
>   2176,      1,     34,         0,               0.978
>   2176,      1,     34,         1,               0.978
>   2176,   2050,      1,         0,               1.061
>   2176,   2050,      1,         1,               1.061
>   2176,   2049,      2,         0,               0.971
>   2176,   2049,      2,         1,               0.971
>   2240,      0,      0,         0,               0.994
>   2240,      0,      0,         1,               0.994
>   2240,      3,      0,         0,               1.038
>   2240,      3,      0,         1,               1.039
>   2240,     35,      0,         0,               1.019
>   2240,     35,      0,         1,               1.019
>   2240,      0,      3,         0,               0.979
>   2240,      0,      3,         1,                0.98
>   2240,      0,     35,         0,               0.991
>   2240,      0,     35,         1,               0.991
>   2240,      3,      3,         0,               0.931
>   2240,      3,      3,         1,               0.931
>   2240,     35,     35,         0,               0.999
>   2240,     35,     35,         1,               0.999
>   2240,   2048,      0,         0,               0.995
>   2240,   2048,      0,         1,               0.995
>   2240,   2051,      0,         0,               1.039
>   2240,   2051,      0,         1,               1.039
>   2240,   2048,      3,         0,               0.799
>   2240,   2048,      3,         1,               0.799
>   2240,   2051,      3,         0,               0.889
>   2240,   2051,      3,         1,               0.889
>   2240,      3,      1,         0,                1.06
>   2240,      3,      1,         1,                1.06
>   2240,      1,      3,         0,               0.968
>   2240,      1,      3,         1,               0.968
>   2240,     35,      1,         0,               1.071
>   2240,     35,      1,         1,               1.071
>   2240,      1,     35,         0,               0.971
>   2240,      1,     35,         1,               0.971
>   2240,   2051,      1,         0,               1.057
>   2240,   2051,      1,         1,               1.057
>   2240,   2049,      3,         0,               0.966
>   2240,   2049,      3,         1,               0.966
>   2304,      0,      0,         0,               0.988
>   2304,      0,      0,         1,               0.988
>   2304,      4,      0,         0,               1.031
>   2304,      4,      0,         1,               1.032
>   2304,     36,      0,         0,               1.011
>   2304,     36,      0,         1,               1.011
>   2304,      0,      4,         0,               0.968
>   2304,      0,      4,         1,               0.967
>   2304,      0,     36,         0,               0.988
>   2304,      0,     36,         1,               0.988
>   2304,      4,      4,         0,               0.931
>   2304,      4,      4,         1,               0.931
>   2304,     36,     36,         0,               0.992
>   2304,     36,     36,         1,               0.992
>   2304,   2048,      0,         0,               0.988
>   2304,   2048,      0,         1,               0.988
>   2304,   2052,      0,         0,               1.032
>   2304,   2052,      0,         1,               1.032
>   2304,   2048,      4,         0,               0.793
>   2304,   2048,      4,         1,               0.793
>   2304,   2052,      4,         0,               0.884
>   2304,   2052,      4,         1,               0.884
>   2304,      4,      1,         0,               0.989
>   2304,      4,      1,         1,               0.989
>   2304,      1,      4,         0,               0.897
>   2304,      1,      4,         1,               0.898
>   2304,     36,      1,         0,               1.057
>   2304,     36,      1,         1,               1.057
>   2304,      1,     36,         0,               0.966
>   2304,      1,     36,         1,               0.966
>   2304,   2052,      1,         0,               1.052
>   2304,   2052,      1,         1,               1.052
>   2304,   2049,      4,         0,               0.955
>   2304,   2049,      4,         1,               0.955
>   2368,      0,      0,         0,               0.999
>   2368,      0,      0,         1,                 1.0
>   2368,      5,      0,         0,               1.024
>   2368,      5,      0,         1,               1.025
>   2368,     37,      0,         0,                 1.0
>   2368,     37,      0,         1,                 1.0
>   2368,      0,      5,         0,                0.98
>   2368,      0,      5,         1,               0.981
>   2368,      0,     37,         0,               0.986
>   2368,      0,     37,         1,               0.981
>   2368,      5,      5,         0,               0.944
>   2368,      5,      5,         1,               0.944
>   2368,     37,     37,         0,               1.003
>   2368,     37,     37,         1,               1.003
>   2368,   2048,      0,         0,               1.002
>   2368,   2048,      0,         1,               1.002
>   2368,   2053,      0,         0,               1.025
>   2368,   2053,      0,         1,               1.025
>   2368,   2048,      5,         0,               0.801
>   2368,   2048,      5,         1,               0.801
>   2368,   2053,      5,         0,               0.907
>   2368,   2053,      5,         1,               0.907
>   2368,      5,      1,         0,               1.071
>   2368,      5,      1,         1,               1.071
>   2368,      1,      5,         0,               0.973
>   2368,      1,      5,         1,               0.973
>   2368,     37,      1,         0,                1.07
>   2368,     37,      1,         1,                1.07
>   2368,      1,     37,         0,               0.974
>   2368,      1,     37,         1,               0.974
>   2368,   2053,      1,         0,               1.065
>   2368,   2053,      1,         1,               1.065
>   2368,   2049,      5,         0,               0.967
>   2368,   2049,      5,         1,               0.967
>   2432,      0,      0,         0,               0.968
>   2432,      0,      0,         1,               1.002
>   2432,      6,      0,         0,               1.032
>   2432,      6,      0,         1,               1.033
>   2432,     38,      0,         0,               1.021
>   2432,     38,      0,         1,               1.021
>   2432,      0,      6,         0,               0.973
>   2432,      0,      6,         1,               0.976
>   2432,      0,     38,         0,               0.986
>   2432,      0,     38,         1,               0.986
>   2432,      6,      6,         0,               0.926
>   2432,      6,      6,         1,               0.926
>   2432,     38,     38,         0,                 1.0
>   2432,     38,     38,         1,                 1.0
>   2432,   2048,      0,         0,               1.005
>   2432,   2048,      0,         1,               1.004
>   2432,   2054,      0,         0,               1.032
>   2432,   2054,      0,         1,               1.033
>   2432,   2048,      6,         0,               0.797
>   2432,   2048,      6,         1,               0.797
>   2432,   2054,      6,         0,               0.898
>   2432,   2054,      6,         1,               0.898
>   2432,      6,      1,         0,               1.058
>   2432,      6,      1,         1,               1.058
>   2432,      1,      6,         0,                0.96
>   2432,      1,      6,         1,                0.96
>   2432,     38,      1,         0,               1.062
>   2432,     38,      1,         1,               1.062
>   2432,      1,     38,         0,               0.963
>   2432,      1,     38,         1,               0.963
>   2432,   2054,      1,         0,               1.054
>   2432,   2054,      1,         1,               1.054
>   2432,   2049,      6,         0,               0.957
>   2432,   2049,      6,         1,               0.957
>   2496,      0,      0,         0,               1.013
>   2496,      0,      0,         1,               1.013
>   2496,      7,      0,         0,               1.025
>   2496,      7,      0,         1,               1.026
>   2496,     39,      0,         0,               1.013
>   2496,     39,      0,         1,               1.013
>   2496,      0,      7,         0,               0.964
>   2496,      0,      7,         1,               0.966
>   2496,      0,     39,         0,               0.979
>   2496,      0,     39,         1,               0.979
>   2496,      7,      7,         0,               0.925
>   2496,      7,      7,         1,               0.925
>   2496,     39,     39,         0,               0.989
>   2496,     39,     39,         1,               0.989
>   2496,   2048,      0,         0,               1.013
>   2496,   2048,      0,         1,               1.013
>   2496,   2055,      0,         0,               1.026
>   2496,   2055,      0,         1,               1.026
>   2496,   2048,      7,         0,               0.792
>   2496,   2048,      7,         1,               0.792
>   2496,   2055,      7,         0,                0.93
>   2496,   2055,      7,         1,                0.93
>   2496,      7,      1,         0,               0.982
>   2496,      7,      1,         1,               0.982
>   2496,      1,      7,         0,               0.893
>   2496,      1,      7,         1,               0.893
>   2496,     39,      1,         0,               1.048
>   2496,     39,      1,         1,               1.049
>   2496,      1,     39,         0,               0.958
>   2496,      1,     39,         1,               0.958
>   2496,   2055,      1,         0,               1.042
>   2496,   2055,      1,         1,               1.042
>   2496,   2049,      7,         0,               0.947
>   2496,   2049,      7,         1,               0.947
>   2560,      0,      0,         0,               0.993
>   2560,      0,      0,         1,               0.993
>   2560,      8,      0,         0,               1.031
>   2560,      8,      0,         1,               1.032
>   2560,     40,      0,         0,               1.029
>   2560,     40,      0,         1,               1.029
>   2560,      0,      8,         0,               0.992
>   2560,      0,      8,         1,               0.992
>   2560,      0,     40,         0,               0.981
>   2560,      0,     40,         1,                0.98
>   2560,      8,      8,         0,               0.943
>   2560,      8,      8,         1,               0.942
>   2560,     40,     40,         0,               1.141
>   2560,     40,     40,         1,               1.141
>   2560,   2048,      0,         0,               0.993
>   2560,   2048,      0,         1,               0.993
>   2560,   2056,      0,         0,               1.032
>   2560,   2056,      0,         1,               1.032
>   2560,   2048,      8,         0,               0.812
>   2560,   2048,      8,         1,               0.812
>   2560,   2056,      8,         0,               0.912
>   2560,   2056,      8,         1,               0.912
>   2560,      8,      1,         0,               1.069
>   2560,      8,      1,         1,               1.069
>   2560,      1,      8,         0,               0.974
>   2560,      1,      8,         1,               0.974
>   2560,     40,      1,         0,               1.068
>   2560,     40,      1,         1,               1.068
>   2560,      1,     40,         0,               0.996
>   2560,      1,     40,         1,               0.996
>   2560,   2056,      1,         0,               1.063
>   2560,   2056,      1,         1,               1.063
>   2560,   2049,      8,         0,               0.969
>   2560,   2049,      8,         1,               0.969
>   2624,      0,      0,         0,               0.997
>   2624,      0,      0,         1,               0.997
>   2624,      9,      0,         0,               1.008
>   2624,      9,      0,         1,               1.012
>   2624,     41,      0,         0,               1.044
>   2624,     41,      0,         1,               1.044
>   2624,      0,      9,         0,               0.988
>   2624,      0,      9,         1,                0.99
>   2624,      0,     41,         0,                0.99
>   2624,      0,     41,         1,                0.99
>   2624,      9,      9,         0,               0.943
>   2624,      9,      9,         1,               0.943
>   2624,     41,     41,         0,               0.993
>   2624,     41,     41,         1,               0.993
>   2624,   2048,      0,         0,               0.998
>   2624,   2048,      0,         1,               0.998
>   2624,   2057,      0,         0,               1.012
>   2624,   2057,      0,         1,               1.012
>   2624,   2048,      9,         0,                0.81
>   2624,   2048,      9,         1,                0.81
>   2624,   2057,      9,         0,               0.907
>   2624,   2057,      9,         1,               0.907
>   2624,      9,      1,         0,               1.085
>   2624,      9,      1,         1,               1.084
>   2624,      1,      9,         0,               0.962
>   2624,      1,      9,         1,               0.963
>   2624,     41,      1,         0,               1.078
>   2624,     41,      1,         1,               1.078
>   2624,      1,     41,         0,               0.962
>   2624,      1,     41,         1,               0.962
>   2624,   2057,      1,         0,               1.081
>   2624,   2057,      1,         1,               1.081
>   2624,   2049,      9,         0,               0.959
>   2624,   2049,      9,         1,               0.959
>   2688,      0,      0,         0,               0.995
>   2688,      0,      0,         1,               0.995
>   2688,     10,      0,         0,               1.003
>   2688,     10,      0,         1,               1.006
>   2688,     42,      0,         0,               1.036
>   2688,     42,      0,         1,               1.036
>   2688,      0,     10,         0,               0.978
>   2688,      0,     10,         1,               0.979
>   2688,      0,     42,         0,               0.978
>   2688,      0,     42,         1,               0.977
>   2688,     10,     10,         0,               0.942
>   2688,     10,     10,         1,               0.942
>   2688,     42,     42,         0,               0.989
>   2688,     42,     42,         1,               0.989
>   2688,   2048,      0,         0,               0.995
>   2688,   2048,      0,         1,               0.995
>   2688,   2058,      0,         0,               1.006
>   2688,   2058,      0,         1,               1.006
>   2688,   2048,     10,         0,               0.804
>   2688,   2048,     10,         1,               0.804
>   2688,   2058,     10,         0,               0.905
>   2688,   2058,     10,         1,               0.905
>   2688,     10,      1,         0,               0.985
>   2688,     10,      1,         1,               0.985
>   2688,      1,     10,         0,               0.892
>   2688,      1,     10,         1,               0.892
>   2688,     42,      1,         0,               1.048
>   2688,     42,      1,         1,               1.048
>   2688,      1,     42,         0,               0.958
>   2688,      1,     42,         1,               0.958
>   2688,   2058,      1,         0,               1.046
>   2688,   2058,      1,         1,               1.046
>   2688,   2049,     10,         0,               0.948
>   2688,   2049,     10,         1,               0.948
>   2752,      0,      0,         0,               0.998
>   2752,      0,      0,         1,               0.993
>   2752,     11,      0,         0,                0.96
>   2752,     11,      0,         1,                0.96
>   2752,     43,      0,         0,               0.979
>   2752,     43,      0,         1,               0.979
>   2752,      0,     11,         0,               0.939
>   2752,      0,     11,         1,               0.939
>   2752,      0,     43,         0,                0.93
>   2752,      0,     43,         1,                0.93
>   2752,     11,     11,         0,               0.949
>   2752,     11,     11,         1,               0.949
>   2752,     43,     43,         0,               1.007
>   2752,     43,     43,         1,               1.007
>   2752,   2048,      0,         0,               0.993
>   2752,   2048,      0,         1,               0.994
>   2752,   2059,      0,         0,                0.96
>   2752,   2059,      0,         1,                0.96
>   2752,   2048,     11,         0,                0.77
>   2752,   2048,     11,         1,                0.77
>   2752,   2059,     11,         0,               0.916
>   2752,   2059,     11,         1,               0.916
>   2752,     11,      1,         0,                 1.0
>   2752,     11,      1,         1,                 1.0
>   2752,      1,     11,         0,               0.933
>   2752,      1,     11,         1,               0.933
>   2752,     43,      1,         0,               1.028
>   2752,     43,      1,         1,               1.028
>   2752,      1,     43,         0,               0.925
>   2752,      1,     43,         1,               0.925
>   2752,   2059,      1,         0,               0.995
>   2752,   2059,      1,         1,               0.995
>   2752,   2049,     11,         0,               0.929
>   2752,   2049,     11,         1,               0.929
>   2816,      0,      0,         0,               1.004
>   2816,      0,      0,         1,               1.004
>   2816,     12,      0,         0,               0.897
>   2816,     12,      0,         1,               0.894
>   2816,     44,      0,         0,               0.914
>   2816,     44,      0,         1,               0.914
>   2816,      0,     12,         0,               0.877
>   2816,      0,     12,         1,               0.874
>   2816,      0,     44,         0,               0.871
>   2816,      0,     44,         1,                0.87
>   2816,     12,     12,         0,               0.948
>   2816,     12,     12,         1,               0.948
>   2816,     44,     44,         0,               1.009
>   2816,     44,     44,         1,               1.009
>   2816,   2048,      0,         0,               1.005
>   2816,   2048,      0,         1,               1.005
>   2816,   2060,      0,         0,               0.894
>   2816,   2060,      0,         1,               0.894
>   2816,   2048,     12,         0,               0.715
>   2816,   2048,     12,         1,               0.713
>   2816,   2060,     12,         0,               0.915
>   2816,   2060,     12,         1,               0.915
>   2816,     12,      1,         0,               0.918
>   2816,     12,      1,         1,               0.917
>   2816,      1,     12,         0,               0.863
>   2816,      1,     12,         1,               0.863
>   2816,     44,      1,         0,               0.944
>   2816,     44,      1,         1,               0.943
>   2816,      1,     44,         0,               0.861
>   2816,      1,     44,         1,               0.861
>   2816,   2060,      1,         0,               0.919
>   2816,   2060,      1,         1,               0.924
>   2816,   2049,     12,         0,                0.86
>   2816,   2049,     12,         1,                0.86
>   2880,      0,      0,         0,               0.989
>   2880,      0,      0,         1,               0.989
>   2880,     13,      0,         0,               0.967
>   2880,     13,      0,         1,               0.967
>   2880,     45,      0,         0,               0.987
>   2880,     45,      0,         1,               0.987
>   2880,      0,     13,         0,               0.925
>   2880,      0,     13,         1,               0.925
>   2880,      0,     45,         0,               0.927
>   2880,      0,     45,         1,               0.927
>   2880,     13,     13,         0,               0.944
>   2880,     13,     13,         1,               0.944
>   2880,     45,     45,         0,               1.003
>   2880,     45,     45,         1,               1.003
>   2880,   2048,      0,         0,               0.989
>   2880,   2048,      0,         1,               0.989
>   2880,   2061,      0,         0,               0.967
>   2880,   2061,      0,         1,               0.967
>   2880,   2048,     13,         0,                0.76
>   2880,   2048,     13,         1,                0.76
>   2880,   2061,     13,         0,                0.91
>   2880,   2061,     13,         1,                0.91
>   2880,     13,      1,         0,               0.922
>   2880,     13,      1,         1,               0.922
>   2880,      1,     13,         0,               0.859
>   2880,      1,     13,         1,               0.859
>   2880,     45,      1,         0,               1.013
>   2880,     45,      1,         1,               1.013
>   2880,      1,     45,         0,                0.92
>   2880,      1,     45,         1,                0.92
>   2880,   2061,      1,         0,               0.984
>   2880,   2061,      1,         1,               0.984
>   2880,   2049,     13,         0,               0.918
>   2880,   2049,     13,         1,               0.918
>   2944,      0,      0,         0,               1.014
>   2944,      0,      0,         1,               1.015
>   2944,     14,      0,         0,               0.961
>   2944,     14,      0,         1,               0.961
>   2944,     46,      0,         0,               0.979
>   2944,     46,      0,         1,               0.979
>   2944,      0,     14,         0,               0.934
>   2944,      0,     14,         1,               0.937
>   2944,      0,     46,         0,               0.924
>   2944,      0,     46,         1,               0.921
>   2944,     14,     14,         0,               0.953
>   2944,     14,     14,         1,               0.953
>   2944,     46,     46,         0,               1.009
>   2944,     46,     46,         1,               1.009
>   2944,   2048,      0,         0,               1.015
>   2944,   2048,      0,         1,               1.015
>   2944,   2062,      0,         0,               0.961
>   2944,   2062,      0,         1,               0.961
>   2944,   2048,     14,         0,               0.769
>   2944,   2048,     14,         1,               0.769
>   2944,   2062,     14,         0,               0.923
>   2944,   2062,     14,         1,               0.923
>   2944,     14,      1,         0,               0.999
>   2944,     14,      1,         1,               0.999
>   2944,      1,     14,         0,               0.927
>   2944,      1,     14,         1,               0.927
>   2944,     46,      1,         0,               1.027
>   2944,     46,      1,         1,               1.027
>   2944,      1,     46,         0,               0.918
>   2944,      1,     46,         1,               0.918
>   2944,   2062,      1,         0,               0.995
>   2944,   2062,      1,         1,               0.995
>   2944,   2049,     14,         0,               0.922
>   2944,   2049,     14,         1,               0.922
>   3008,      0,      0,         0,               0.998
>   3008,      0,      0,         1,               0.997
>   3008,     15,      0,         0,               0.953
>   3008,     15,      0,         1,               0.953
>   3008,     47,      0,         0,               0.996
>   3008,     47,      0,         1,               0.996
>   3008,      0,     15,         0,               0.933
>   3008,      0,     15,         1,               0.929
>   3008,      0,     47,         0,               0.933
>   3008,      0,     47,         1,               0.933
>   3008,     15,     15,         0,                0.95
>   3008,     15,     15,         1,               0.949
>   3008,     47,     47,         0,               1.003
>   3008,     47,     47,         1,               1.003
>   3008,   2048,      0,         0,               0.998
>   3008,   2048,      0,         1,               0.998
>   3008,   2063,      0,         0,               0.953
>   3008,   2063,      0,         1,               0.953
>   3008,   2048,     15,         0,               0.766
>   3008,   2048,     15,         1,               0.766
>   3008,   2063,     15,         0,               0.916
>   3008,   2063,     15,         1,               0.916
>   3008,     15,      1,         0,               0.996
>   3008,     15,      1,         1,               0.996
>   3008,      1,     15,         0,               0.927
>   3008,      1,     15,         1,               0.927
>   3008,     47,      1,         0,               1.026
>   3008,     47,      1,         1,               1.026
>   3008,      1,     47,         0,               0.918
>   3008,      1,     47,         1,               0.918
>   3008,   2063,      1,         0,               0.994
>   3008,   2063,      1,         1,               0.994
>   3008,   2049,     15,         0,               0.925
>   3008,   2049,     15,         1,               0.925
>   3072,      0,      0,         0,               1.015
>   3072,      0,      0,         1,               1.016
>   3072,     16,      0,         0,               1.045
>   3072,     16,      0,         1,               1.045
>   3072,     48,      0,         0,               1.045
>   3072,     48,      0,         1,               1.045
>   3072,      0,     16,         0,               1.049
>   3072,      0,     16,         1,               1.049
>   3072,      0,     48,         0,               1.049
>   3072,      0,     48,         1,               1.049
>   3072,     16,     16,         0,               1.016
>   3072,     16,     16,         1,               1.015
>   3072,     48,     48,         0,               1.015
>   3072,     48,     48,         1,               1.016
>   3072,   2048,      0,         0,               1.016
>   3072,   2048,      0,         1,               1.016
>   3072,   2064,      0,         0,               1.045
>   3072,   2064,      0,         1,               1.045
>   3072,   2048,     16,         0,               1.049
>   3072,   2048,     16,         1,               1.049
>   3072,   2064,     16,         0,               1.016
>   3072,   2064,     16,         1,               1.016
>   3072,     16,      1,         0,               0.815
>   3072,     16,      1,         1,               0.815
>   3072,      1,     16,         0,               0.872
>   3072,      1,     16,         1,               0.872
>   3072,     48,      1,         0,               1.017
>   3072,     48,      1,         1,               1.017
>   3072,      1,     48,         0,               0.872
>   3072,      1,     48,         1,               0.872
>   3072,   2064,      1,         0,               0.815
>   3072,   2064,      1,         1,               0.815
>   3072,   2049,     16,         0,               0.872
>   3072,   2049,     16,         1,               0.872
>   3136,      0,      0,         0,               0.995
>   3136,      0,      0,         1,               0.996
>   3136,     17,      0,         0,               0.949
>   3136,     17,      0,         1,               0.949
>   3136,     49,      0,         0,               0.987
>   3136,     49,      0,         1,               0.987
>   3136,      0,     17,         0,               0.922
>   3136,      0,     17,         1,               0.919
>   3136,      0,     49,         0,               0.931
>   3136,      0,     49,         1,               0.931
>   3136,     17,     17,         0,               1.122
>   3136,     17,     17,         1,               1.119
>   3136,     49,     49,         0,               0.987
>   3136,     49,     49,         1,               0.987
>   3136,   2048,      0,         0,               0.997
>   3136,   2048,      0,         1,               0.997
>   3136,   2065,      0,         0,               0.949
>   3136,   2065,      0,         1,               0.949
>   3136,   2048,     17,         0,               0.896
>   3136,   2048,     17,         1,               0.896
>   3136,   2065,     17,         0,               1.122
>   3136,   2065,     17,         1,                1.12
>   3136,     17,      1,         0,               1.185
>   3136,     17,      1,         1,               1.185
>   3136,      1,     17,         0,               1.124
>   3136,      1,     17,         1,               1.124
>   3136,     49,      1,         0,                1.11
>   3136,     49,      1,         1,               1.109
>   3136,      1,     49,         0,               1.044
>   3136,      1,     49,         1,               1.044
>   3136,   2065,      1,         0,               1.147
>   3136,   2065,      1,         1,               1.147
>   3136,   2049,     17,         0,               1.103
>   3136,   2049,     17,         1,               1.103
>   3200,      0,      0,         0,               1.006
>   3200,      0,      0,         1,               1.006
>   3200,     18,      0,         0,               0.978
>   3200,     18,      0,         1,               0.978
>   3200,     50,      0,         0,               0.998
>   3200,     50,      0,         1,               0.998
>   3200,      0,     18,         0,               0.932
>   3200,      0,     18,         1,               0.932
>   3200,      0,     50,         0,                0.93
>   3200,      0,     50,         1,                0.93
>   3200,     18,     18,         0,                1.11
>   3200,     18,     18,         1,                1.11
>   3200,     50,     50,         0,               0.994
>   3200,     50,     50,         1,               0.994
>   3200,   2048,      0,         0,               1.007
>   3200,   2048,      0,         1,               1.007
>   3200,   2066,      0,         0,               0.978
>   3200,   2066,      0,         1,               0.978
>   3200,   2048,     18,         0,               0.894
>   3200,   2048,     18,         1,               0.894
>   3200,   2066,     18,         0,                1.11
>   3200,   2066,     18,         1,                1.11
>   3200,     18,      1,         0,               1.002
>   3200,     18,      1,         1,               1.002
>   3200,      1,     18,         0,               0.917
>   3200,      1,     18,         1,               0.917
>   3200,     50,      1,         0,               0.963
>   3200,     50,      1,         1,               0.964
>   3200,      1,     50,         0,               0.888
>   3200,      1,     50,         1,               0.888
>   3200,   2066,      1,         0,               1.002
>   3200,   2066,      1,         1,               1.002
>   3200,   2049,     18,         0,               0.914
>   3200,   2049,     18,         1,               0.914
>   3264,      0,      0,         0,               0.994
>   3264,      0,      0,         1,               0.994
>   3264,     19,      0,         0,               0.959
>   3264,     19,      0,         1,               0.959
>   3264,     51,      0,         0,               0.994
>   3264,     51,      0,         1,               0.994
>   3264,      0,     19,         0,               0.927
>   3264,      0,     19,         1,               0.927
>   3264,      0,     51,         0,               0.927
>   3264,      0,     51,         1,               0.927
>   3264,     19,     19,         0,                 1.1
>   3264,     19,     19,         1,               1.099
>   3264,     51,     51,         0,               0.982
>   3264,     51,     51,         1,               0.982
>   3264,   2048,      0,         0,               0.994
>   3264,   2048,      0,         1,               0.994
>   3264,   2067,      0,         0,               0.959
>   3264,   2067,      0,         1,               0.959
>   3264,   2048,     19,         0,               0.891
>   3264,   2048,     19,         1,               0.891
>   3264,   2067,     19,         0,               1.099
>   3264,   2067,     19,         1,               1.099
>   3264,     19,      1,         0,               0.977
>   3264,     19,      1,         1,               0.976
>   3264,      1,     19,         0,               0.921
>   3264,      1,     19,         1,               0.921
>   3264,     51,      1,         0,               0.959
>   3264,     51,      1,         1,               0.959
>   3264,      1,     51,         0,               0.886
>   3264,      1,     51,         1,               0.886
>   3264,   2067,      1,         0,               0.976
>   3264,   2067,      1,         1,               0.976
>   3264,   2049,     19,         0,               0.917
>   3264,   2049,     19,         1,               0.917
>   3328,      0,      0,         0,               0.997
>   3328,      0,      0,         1,               0.993
>   3328,     20,      0,         0,               0.955
>   3328,     20,      0,         1,               0.955
>   3328,     52,      0,         0,                0.99
>   3328,     52,      0,         1,                0.99
>   3328,      0,     20,         0,               0.925
>   3328,      0,     20,         1,               0.927
>   3328,      0,     52,         0,               0.933
>   3328,      0,     52,         1,               0.933
>   3328,     20,     20,         0,                1.11
>   3328,     20,     20,         1,                1.11
>   3328,     52,     52,         0,               0.988
>   3328,     52,     52,         1,               0.988
>   3328,   2048,      0,         0,               0.996
>   3328,   2048,      0,         1,               0.993
>   3328,   2068,      0,         0,               0.955
>   3328,   2068,      0,         1,               0.955
>   3328,   2048,     20,         0,                 0.9
>   3328,   2048,     20,         1,                 0.9
>   3328,   2068,     20,         0,               1.109
>   3328,   2068,     20,         1,               1.109
>   3328,     20,      1,         0,               0.996
>   3328,     20,      1,         1,               0.996
>   3328,      1,     20,         0,               0.927
>   3328,      1,     20,         1,               0.927
>   3328,     52,      1,         0,               0.972
>   3328,     52,      1,         1,               0.972
>   3328,      1,     52,         0,               0.901
>   3328,      1,     52,         1,               0.901
>   3328,   2068,      1,         0,               0.996
>   3328,   2068,      1,         1,               0.996
>   3328,   2049,     20,         0,               0.924
>   3328,   2049,     20,         1,               0.924
>   3392,      0,      0,         0,               0.996
>   3392,      0,      0,         1,                 1.0
>   3392,     21,      0,         0,               0.964
>   3392,     21,      0,         1,               0.964
>   3392,     53,      0,         0,               0.999
>   3392,     53,      0,         1,               0.999
>   3392,      0,     21,         0,               0.932
>   3392,      0,     21,         1,               0.932
>   3392,      0,     53,         0,                0.93
>   3392,      0,     53,         1,                0.93
>   3392,     21,     21,         0,               1.113
>   3392,     21,     21,         1,               1.113
>   3392,     53,     53,         0,               0.983
>   3392,     53,     53,         1,               0.983
>   3392,   2048,      0,         0,                 1.0
>   3392,   2048,      0,         1,                 1.0
>   3392,   2069,      0,         0,               0.964
>   3392,   2069,      0,         1,               0.964
>   3392,   2048,     21,         0,               0.896
>   3392,   2048,     21,         1,               0.896
>   3392,   2069,     21,         0,               1.113
>   3392,   2069,     21,         1,               1.113
>   3392,     21,      1,         0,               0.994
>   3392,     21,      1,         1,               0.994
>   3392,      1,     21,         0,               0.918
>   3392,      1,     21,         1,               0.918
>   3392,     53,      1,         0,               0.972
>   3392,     53,      1,         1,               0.972
>   3392,      1,     53,         0,               0.891
>   3392,      1,     53,         1,               0.891
>   3392,   2069,      1,         0,               0.994
>   3392,   2069,      1,         1,               0.994
>   3392,   2049,     21,         0,               0.915
>   3392,   2049,     21,         1,               0.915
>   3456,      0,      0,         0,               0.995
>   3456,      0,      0,         1,               0.995
>   3456,     22,      0,         0,               0.965
>   3456,     22,      0,         1,               0.965
>   3456,     54,      0,         0,               0.996
>   3456,     54,      0,         1,               0.996
>   3456,      0,     22,         0,               0.927
>   3456,      0,     22,         1,               0.927
>   3456,      0,     54,         0,               0.927
>   3456,      0,     54,         1,               0.927
>   3456,     22,     22,         0,               1.106
>   3456,     22,     22,         1,               1.107
>   3456,     54,     54,         0,                0.98
>   3456,     54,     54,         1,                0.98
>   3456,   2048,      0,         0,               0.995
>   3456,   2048,      0,         1,               0.995
>   3456,   2070,      0,         0,               0.965
>   3456,   2070,      0,         1,               0.965
>   3456,   2048,     22,         0,               0.893
>   3456,   2048,     22,         1,               0.893
>   3456,   2070,     22,         0,               1.107
>   3456,   2070,     22,         1,               1.107
>   3456,     22,      1,         0,               0.988
>   3456,     22,      1,         1,               0.988
>   3456,      1,     22,         0,               0.915
>   3456,      1,     22,         1,               0.915
>   3456,     54,      1,         0,               0.963
>   3456,     54,      1,         1,               0.963
>   3456,      1,     54,         0,               0.887
>   3456,      1,     54,         1,               0.887
>   3456,   2070,      1,         0,               0.988
>   3456,   2070,      1,         1,               0.988
>   3456,   2049,     22,         0,               0.911
>   3456,   2049,     22,         1,               0.911
>   3520,      0,      0,         0,               1.016
>   3520,      0,      0,         1,               1.016
>   3520,     23,      0,         0,               0.957
>   3520,     23,      0,         1,               0.957
>   3520,     55,      0,         0,               0.991
>   3520,     55,      0,         1,               0.991
>   3520,      0,     23,         0,               0.918
>   3520,      0,     23,         1,               0.929
>   3520,      0,     55,         0,               0.935
>   3520,      0,     55,         1,               0.934
>   3520,     23,     23,         0,               1.111
>   3520,     23,     23,         1,               1.111
>   3520,     55,     55,         0,               0.994
>   3520,     55,     55,         1,               0.994
>   3520,   2048,      0,         0,               1.016
>   3520,   2048,      0,         1,               1.016
>   3520,   2071,      0,         0,               0.957
>   3520,   2071,      0,         1,               0.957
>   3520,   2048,     23,         0,               0.903
>   3520,   2048,     23,         1,               0.902
>   3520,   2071,     23,         0,               1.111
>   3520,   2071,     23,         1,               1.111
>   3520,     23,      1,         0,               0.997
>   3520,     23,      1,         1,               0.997
>   3520,      1,     23,         0,               0.926
>   3520,      1,     23,         1,               0.927
>   3520,     55,      1,         0,               0.976
>   3520,     55,      1,         1,               0.976
>   3520,      1,     55,         0,               0.902
>   3520,      1,     55,         1,               0.902
>   3520,   2071,      1,         0,               0.997
>   3520,   2071,      1,         1,               0.997
>   3520,   2049,     23,         0,               0.924
>   3520,   2049,     23,         1,               0.924
>   3584,      0,      0,         0,               1.005
>   3584,      0,      0,         1,               1.004
>   3584,     24,      0,         0,               0.985
>   3584,     24,      0,         1,               0.979
>   3584,     56,      0,         0,               1.006
>   3584,     56,      0,         1,               1.006
>   3584,      0,     24,         0,               0.931
>   3584,      0,     24,         1,               0.931
>   3584,      0,     56,         0,                0.93
>   3584,      0,     56,         1,                0.93
>   3584,     24,     24,         0,               1.111
>   3584,     24,     24,         1,                1.11
>   3584,     56,     56,         0,               1.102
>   3584,     56,     56,         1,               1.101
>   3584,   2048,      0,         0,               1.006
>   3584,   2048,      0,         1,               1.005
>   3584,   2072,      0,         0,               0.983
>   3584,   2072,      0,         1,               0.977
>   3584,   2048,     24,         0,               0.896
>   3584,   2048,     24,         1,               0.897
>   3584,   2072,     24,         0,               1.111
>   3584,   2072,     24,         1,               1.111
>   3584,     24,      1,         0,               1.004
>   3584,     24,      1,         1,               1.004
>   3584,      1,     24,         0,               0.921
>   3584,      1,     24,         1,               0.921
>   3584,     56,      1,         0,                0.97
>   3584,     56,      1,         1,                0.97
>   3584,      1,     56,         0,               0.891
>   3584,      1,     56,         1,               0.891
>   3584,   2072,      1,         0,               1.004
>   3584,   2072,      1,         1,               1.004
>   3584,   2049,     24,         0,               0.918
>   3584,   2049,     24,         1,               0.918
>   3648,      0,      0,         0,               1.012
>   3648,      0,      0,         1,               1.012
>   3648,     25,      0,         0,                0.96
>   3648,     25,      0,         1,                0.96
>   3648,     57,      0,         0,               0.988
>   3648,     57,      0,         1,               0.988
>   3648,      0,     25,         0,               0.927
>   3648,      0,     25,         1,               0.927
>   3648,      0,     57,         0,               0.927
>   3648,      0,     57,         1,               0.927
>   3648,     25,     25,         0,                 1.1
>   3648,     25,     25,         1,                 1.1
>   3648,     57,     57,         0,               0.986
>   3648,     57,     57,         1,               0.986
>   3648,   2048,      0,         0,               1.012
>   3648,   2048,      0,         1,               1.012
>   3648,   2073,      0,         0,                0.96
>   3648,   2073,      0,         1,                0.96
>   3648,   2048,     25,         0,               0.895
>   3648,   2048,     25,         1,               0.894
>   3648,   2073,     25,         0,               1.103
>   3648,   2073,     25,         1,               1.103
>   3648,     25,      1,         0,               1.032
>   3648,     25,      1,         1,               1.032
>   3648,      1,     25,         0,                 0.9
>   3648,      1,     25,         1,               0.901
>   3648,     57,      1,         0,               0.974
>   3648,     57,      1,         1,               0.974
>   3648,      1,     57,         0,               0.888
>   3648,      1,     57,         1,               0.888
>   3648,   2073,      1,         0,               1.032
>   3648,   2073,      1,         1,               1.032
>   3648,   2049,     25,         0,               0.895
>   3648,   2049,     25,         1,               0.896
>   3712,      0,      0,         0,               0.996
>   3712,      0,      0,         1,               0.996
>   3712,     26,      0,         0,               0.959
>   3712,     26,      0,         1,               0.959
>   3712,     58,      0,         0,               0.995
>   3712,     58,      0,         1,               0.995
>   3712,      0,     26,         0,                0.92
>   3712,      0,     26,         1,               0.919
>   3712,      0,     58,         0,               0.931
>   3712,      0,     58,         1,               0.931
>   3712,     26,     26,         0,               1.103
>   3712,     26,     26,         1,               1.101
>   3712,     58,     58,         0,                0.99
>   3712,     58,     58,         1,               0.989
>   3712,   2048,      0,         0,               0.997
>   3712,   2048,      0,         1,               0.997
>   3712,   2074,      0,         0,               0.959
>   3712,   2074,      0,         1,               0.959
>   3712,   2048,     26,         0,               0.901
>   3712,   2048,     26,         1,               0.901
>   3712,   2074,     26,         0,               1.103
>   3712,   2074,     26,         1,               1.103
>   3712,     26,      1,         0,               1.001
>   3712,     26,      1,         1,               1.001
>   3712,      1,     26,         0,               0.928
>   3712,      1,     26,         1,               0.928
>   3712,     58,      1,         0,               0.974
>   3712,     58,      1,         1,               0.974
>   3712,      1,     58,         0,               0.903
>   3712,      1,     58,         1,               0.902
>   3712,   2074,      1,         0,               1.001
>   3712,   2074,      1,         1,               1.001
>   3712,   2049,     26,         0,               0.925
>   3712,   2049,     26,         1,               0.925
>   3776,      0,      0,         0,               1.003
>   3776,      0,      0,         1,               1.003
>   3776,     27,      0,         0,               0.964
>   3776,     27,      0,         1,               0.963
>   3776,     59,      0,         0,               1.004
>   3776,     59,      0,         1,               1.004
>   3776,      0,     27,         0,               0.931
>   3776,      0,     27,         1,               0.931
>   3776,      0,     59,         0,               0.929
>   3776,      0,     59,         1,               0.929
>   3776,     27,     27,         0,               1.097
>   3776,     27,     27,         1,               1.097
>   3776,     59,     59,         0,               0.992
>   3776,     59,     59,         1,               0.992
>   3776,   2048,      0,         0,               1.003
>   3776,   2048,      0,         1,               1.003
>   3776,   2075,      0,         0,               0.964
>   3776,   2075,      0,         1,               0.963
>   3776,   2048,     27,         0,               0.898
>   3776,   2048,     27,         1,               0.898
>   3776,   2075,     27,         0,               1.097
>   3776,   2075,     27,         1,               1.097
>   3776,     27,      1,         0,               0.991
>   3776,     27,      1,         1,               0.991
>   3776,      1,     27,         0,               0.919
>   3776,      1,     27,         1,               0.919
>   3776,     59,      1,         0,               0.979
>   3776,     59,      1,         1,               0.979
>   3776,      1,     59,         0,               0.894
>   3776,      1,     59,         1,               0.894
>   3776,   2075,      1,         0,               0.991
>   3776,   2075,      1,         1,               0.991
>   3776,   2049,     27,         0,               0.916
>   3776,   2049,     27,         1,               0.917
>   3840,      0,      0,         0,               0.998
>   3840,      0,      0,         1,               0.998
>   3840,     28,      0,         0,               0.968
>   3840,     28,      0,         1,               0.968
>   3840,     60,      0,         0,               1.001
>   3840,     60,      0,         1,               1.001
>   3840,      0,     28,         0,               0.927
>   3840,      0,     28,         1,               0.927
>   3840,      0,     60,         0,               0.927
>   3840,      0,     60,         1,               0.927
>   3840,     28,     28,         0,               1.094
>   3840,     28,     28,         1,               1.094
>   3840,     60,     60,         0,               0.982
>   3840,     60,     60,         1,               0.982
>   3840,   2048,      0,         0,               0.998
>   3840,   2048,      0,         1,               0.998
>   3840,   2076,      0,         0,               0.968
>   3840,   2076,      0,         1,               0.968
>   3840,   2048,     28,         0,               0.896
>   3840,   2048,     28,         1,               0.896
>   3840,   2076,     28,         0,               1.094
>   3840,   2076,     28,         1,               1.094
>   3840,     28,      1,         0,                0.99
>   3840,     28,      1,         1,                0.99
>   3840,      1,     28,         0,                0.91
>   3840,      1,     28,         1,                0.91
>   3840,     60,      1,         0,               0.969
>   3840,     60,      1,         1,               0.969
>   3840,      1,     60,         0,                0.89
>   3840,      1,     60,         1,               0.891
>   3840,   2076,      1,         0,                0.99
>   3840,   2076,      1,         1,                0.99
>   3840,   2049,     28,         0,               0.906
>   3840,   2049,     28,         1,               0.906
>   3904,      0,      0,         0,               1.001
>   3904,      0,      0,         1,               0.998
>   3904,     29,      0,         0,               0.961
>   3904,     29,      0,         1,               0.961
>   3904,     61,      0,         0,               0.997
>   3904,     61,      0,         1,               0.997
>   3904,      0,     29,         0,                0.92
>   3904,      0,     29,         1,               0.926
>   3904,      0,     61,         0,               0.933
>   3904,      0,     61,         1,               0.933
>   3904,     29,     29,         0,               1.103
>   3904,     29,     29,         1,               1.103
>   3904,     61,     61,         0,               0.995
>   3904,     61,     61,         1,               0.995
>   3904,   2048,      0,         0,               0.998
>   3904,   2048,      0,         1,               0.998
>   3904,   2077,      0,         0,               0.961
>   3904,   2077,      0,         1,               0.961
>   3904,   2048,     29,         0,               0.904
>   3904,   2048,     29,         1,               0.904
>   3904,   2077,     29,         0,               1.102
>   3904,   2077,     29,         1,               1.102
>   3904,     29,      1,         0,                 1.0
>   3904,     29,      1,         1,                 1.0
>   3904,      1,     29,         0,               0.911
>   3904,      1,     29,         1,               0.911
>   3904,     61,      1,         0,                0.98
>   3904,     61,      1,         1,                0.98
>   3904,      1,     61,         0,               0.904
>   3904,      1,     61,         1,               0.904
>   3904,   2077,      1,         0,                 1.0
>   3904,   2077,      1,         1,                 1.0
>   3904,   2049,     29,         0,               0.906
>   3904,   2049,     29,         1,               0.907
>   3968,      0,      0,         0,               1.003
>   3968,      0,      0,         1,               1.003
>   3968,     30,      0,         0,               0.969
>   3968,     30,      0,         1,               0.969
>   3968,     62,      0,         0,               1.005
>   3968,     62,      0,         1,               1.006
>   3968,      0,     30,         0,               0.931
>   3968,      0,     30,         1,               0.931
>   3968,      0,     62,         0,                0.93
>   3968,      0,     62,         1,                0.93
>   3968,     30,     30,         0,               1.103
>   3968,     30,     30,         1,               1.103
>   3968,     62,     62,         0,                0.99
>   3968,     62,     62,         1,                0.99
>   3968,   2048,      0,         0,               1.004
>   3968,   2048,      0,         1,               1.004
>   3968,   2078,      0,         0,               0.968
>   3968,   2078,      0,         1,               0.969
>   3968,   2048,     30,         0,               0.899
>   3968,   2048,     30,         1,               0.899
>   3968,   2078,     30,         0,               1.105
>   3968,   2078,     30,         1,               1.105
>   3968,     30,      1,         0,               0.993
>   3968,     30,      1,         1,               0.993
>   3968,      1,     30,         0,               0.914
>   3968,      1,     30,         1,               0.913
>   3968,     62,      1,         0,               0.978
>   3968,     62,      1,         1,               0.978
>   3968,      1,     62,         0,               0.895
>   3968,      1,     62,         1,               0.895
>   3968,   2078,      1,         0,               0.993
>   3968,   2078,      1,         1,               0.993
>   3968,   2049,     30,         0,               0.911
>   3968,   2049,     30,         1,               0.911
>   4032,      0,      0,         0,               0.995
>   4032,      0,      0,         1,               0.995
>   4032,     31,      0,         0,               0.967
>   4032,     31,      0,         1,               0.967
>   4032,     63,      0,         0,               1.003
>   4032,     63,      0,         1,               1.002
>   4032,      0,     31,         0,               0.927
>   4032,      0,     31,         1,               0.927
>   4032,      0,     63,         0,               0.927
>   4032,      0,     63,         1,               0.927
>   4032,     31,     31,         0,                1.09
>   4032,     31,     31,         1,                1.09
>   4032,     63,     63,         0,               0.987
>   4032,     63,     63,         1,               0.987
>   4032,   2048,      0,         0,               0.995
>   4032,   2048,      0,         1,               0.995
>   4032,   2079,      0,         0,               0.967
>   4032,   2079,      0,         1,               0.967
>   4032,   2048,     31,         0,               0.897
>   4032,   2048,     31,         1,               0.897
>   4032,   2079,     31,         0,                1.09
>   4032,   2079,     31,         1,                1.09
>   4032,     31,      1,         0,               0.989
>   4032,     31,      1,         1,               0.989
>   4032,      1,     31,         0,               0.922
>   4032,      1,     31,         1,               0.923
>   4032,     63,      1,         0,               0.971
>   4032,     63,      1,         1,               0.972
>   4032,      1,     63,         0,               0.892
>   4032,      1,     63,         1,               0.892
>   4032,   2079,      1,         0,               0.988
>   4032,   2079,      1,         1,               0.988
>   4032,   2049,     31,         0,               0.919
>   4032,   2049,     31,         1,               0.919
>   4096,     32,      0,         0,               1.014
>   4096,     32,      0,         1,               1.014
>   4096,     64,      0,         0,               1.014
>   4096,     64,      0,         1,               1.014
>   4096,      0,     32,         0,               1.013
>   4096,      0,     32,         1,               1.013
>   4096,      0,     64,         0,               1.013
>   4096,      0,     64,         1,               1.013
>   4096,     32,     32,         0,               1.014
>   4096,     32,     32,         1,               1.014
>   4096,     64,     64,         0,               1.014
>   4096,     64,     64,         1,               1.014
>   4096,   2080,      0,         0,               1.014
>   4096,   2080,      0,         1,               1.014
>   4096,   2048,     32,         0,               1.014
>   4096,   2048,     32,         1,               1.014
>   4096,   2080,     32,         0,               1.014
>   4096,   2080,     32,         1,               1.014
>   4096,     32,      1,         0,               0.975
>   4096,     32,      1,         1,               0.975
>   4096,      1,     32,         0,               0.769
>   4096,      1,     32,         1,               0.769
>   4096,     64,      1,         0,               0.858
>   4096,     64,      1,         1,               0.858
>   4096,      1,     64,         0,               0.769
>   4096,      1,     64,         1,               0.769
>   4096,   2080,      1,         0,               0.829
>   4096,   2080,      1,         1,               0.829
>   4096,   2049,     32,         0,               0.886
>   4096,   2049,     32,         1,               0.886
>   4160,      0,      0,         0,               1.003
>   4160,      0,      0,         1,               1.003
>   4160,     33,      0,         0,               1.004
>   4160,     33,      0,         1,               1.004
>   4160,     65,      0,         0,               0.999
>   4160,     65,      0,         1,               0.999
>   4160,      0,     33,         0,               0.931
>   4160,      0,     33,         1,               0.931
>   4160,      0,     65,         0,               0.765
>   4160,      0,     65,         1,               0.765
>   4160,     33,     33,         0,               0.998
>   4160,     33,     33,         1,               0.998
>   4160,     65,     65,         0,               0.942
>   4160,     65,     65,         1,               0.942
>   4160,   2048,      0,         0,               1.003
>   4160,   2048,      0,         1,               1.003
>   4160,   2081,      0,         0,               1.005
>   4160,   2081,      0,         1,               1.005
>   4160,   2048,     33,         0,               0.899
>   4160,   2048,     33,         1,               0.899
>   4160,   2081,     33,         0,               1.002
>   4160,   2081,     33,         1,               1.002
>   4160,     33,      1,         0,               1.114
>   4160,     33,      1,         1,               1.114
>   4160,      1,     33,         0,                1.01
>   4160,      1,     33,         1,                1.01
>   4160,     65,      1,         0,               1.077
>   4160,     65,      1,         1,               1.077
>   4160,      1,     65,         0,               0.935
>   4160,      1,     65,         1,               0.936
>   4160,   2081,      1,         0,               1.077
>   4160,   2081,      1,         1,               1.077
>   4160,   2049,     33,         0,               1.008
>   4160,   2049,     33,         1,               1.007
>   4224,      0,      0,         0,               1.014
>   4224,      0,      0,         1,               1.014
>   4224,     34,      0,         0,                 1.0
>   4224,     34,      0,         1,                 1.0
>   4224,     66,      0,         0,               1.001
>   4224,     66,      0,         1,               1.001
>   4224,      0,     34,         0,               0.928
>   4224,      0,     34,         1,               0.928
>   4224,      0,     66,         0,               0.762
>   4224,      0,     66,         1,               0.762
>   4224,     34,     34,         0,               0.998
>   4224,     34,     34,         1,               0.998
>   4224,     66,     66,         0,               0.959
>   4224,     66,     66,         1,               0.959
>   4224,   2048,      0,         0,               1.014
>   4224,   2048,      0,         1,               1.014
>   4224,   2082,      0,         0,               1.001
>   4224,   2082,      0,         1,               1.001
>   4224,   2048,     34,         0,               0.899
>   4224,   2048,     34,         1,               0.898
>   4224,   2082,     34,         0,               0.998
>   4224,   2082,     34,         1,               0.997
>   4224,     34,      1,         0,               1.024
>   4224,     34,      1,         1,               1.024
>   4224,      1,     34,         0,               0.923
>   4224,      1,     34,         1,               0.923
>   4224,     66,      1,         0,               1.013
>   4224,     66,      1,         1,               1.013
>   4224,      1,     66,         0,               0.917
>   4224,      1,     66,         1,               0.917
>   4224,   2082,      1,         0,               1.022
>   4224,   2082,      1,         1,               1.022
>   4224,   2049,     34,         0,                0.92
>   4224,   2049,     34,         1,                0.92
>   4288,      0,      0,         0,               0.999
>   4288,      0,      0,         1,               0.999
>   4288,     35,      0,         0,               0.995
>   4288,     35,      0,         1,               0.996
>   4288,     67,      0,         0,               0.998
>   4288,     67,      0,         1,               0.998
>   4288,      0,     35,         0,               0.917
>   4288,      0,     35,         1,               0.919
>   4288,      0,     67,         0,               0.767
>   4288,      0,     67,         1,               0.767
>   4288,     35,     35,         0,               1.004
>   4288,     35,     35,         1,               1.004
>   4288,     67,     67,         0,               0.995
>   4288,     67,     67,         1,               0.995
>   4288,   2048,      0,         0,               0.999
>   4288,   2048,      0,         1,               0.999
>   4288,   2083,      0,         0,               0.995
>   4288,   2083,      0,         1,               0.995
>   4288,   2048,     35,         0,               0.905
>   4288,   2048,     35,         1,               0.904
>   4288,   2083,     35,         0,               1.004
>   4288,   2083,     35,         1,               1.004
>   4288,     35,      1,         0,               1.032
>   4288,     35,      1,         1,               1.033
>   4288,      1,     35,         0,               0.928
>   4288,      1,     35,         1,               0.928
>   4288,     67,      1,         0,               1.019
>   4288,     67,      1,         1,               1.019
>   4288,      1,     67,         0,               0.924
>   4288,      1,     67,         1,               0.924
>   4288,   2083,      1,         0,                1.03
>   4288,   2083,      1,         1,               1.031
>   4288,   2049,     35,         0,               0.925
>   4288,   2049,     35,         1,               0.925
>   4352,      0,      0,         0,               1.005
>   4352,      0,      0,         1,               1.006
>   4352,     36,      0,         0,               1.006
>   4352,     36,      0,         1,               1.007
>   4352,     68,      0,         0,               1.006
>   4352,     68,      0,         1,               1.007
>   4352,      0,     36,         0,               0.929
>   4352,      0,     36,         1,               0.928
>   4352,      0,     68,         0,               0.766
>   4352,      0,     68,         1,               0.765
>   4352,     36,     36,         0,               0.998
>   4352,     36,     36,         1,               0.998
>   4352,     68,     68,         0,               0.964
>   4352,     68,     68,         1,               0.964
>   4352,   2048,      0,         0,               1.006
>   4352,   2048,      0,         1,               1.006
>   4352,   2084,      0,         0,               1.007
>   4352,   2084,      0,         1,               1.007
>   4352,   2048,     36,         0,               0.897
>   4352,   2048,     36,         1,               0.898
>   4352,   2084,     36,         0,               0.998
>   4352,   2084,     36,         1,               0.998
>   4352,     36,      1,         0,               1.031
>   4352,     36,      1,         1,               1.031
>   4352,      1,     36,         0,               0.924
>   4352,      1,     36,         1,               0.925
>   4352,     68,      1,         0,               0.999
>   4352,     68,      1,         1,               0.999
>   4352,      1,     68,         0,               0.922
>   4352,      1,     68,         1,               0.922
>   4352,   2084,      1,         0,               1.032
>   4352,   2084,      1,         1,                1.03
>   4352,   2049,     36,         0,               0.923
>   4352,   2049,     36,         1,               0.923
>   4416,      0,      0,         0,               0.997
>   4416,      0,      0,         1,               0.997
>   4416,     37,      0,         0,               1.001
>   4416,     37,      0,         1,               1.002
>   4416,     69,      0,         0,               1.004
>   4416,     69,      0,         1,               1.003
>   4416,      0,     37,         0,               0.928
>   4416,      0,     37,         1,               0.927
>   4416,      0,     69,         0,               0.762
>   4416,      0,     69,         1,               0.763
>   4416,     37,     37,         0,               0.994
>   4416,     37,     37,         1,               0.994
>   4416,     69,     69,         0,               0.959
>   4416,     69,     69,         1,               0.959
>   4416,   2048,      0,         0,               0.997
>   4416,   2048,      0,         1,               0.997
>   4416,   2085,      0,         0,               1.002
>   4416,   2085,      0,         1,               1.001
>   4416,   2048,     37,         0,                 0.9
>   4416,   2048,     37,         1,                 0.9
>   4416,   2085,     37,         0,               0.994
>   4416,   2085,     37,         1,               0.994
>   4416,     37,      1,         0,               1.024
>   4416,     37,      1,         1,               1.025
>   4416,      1,     37,         0,               0.922
>   4416,      1,     37,         1,               0.922
>   4416,     69,      1,         0,               1.008
>   4416,     69,      1,         1,               1.009
>   4416,      1,     69,         0,               0.913
>   4416,      1,     69,         1,               0.912
>   4416,   2085,      1,         0,               1.025
>   4416,   2085,      1,         1,               1.024
>   4416,   2049,     37,         0,                0.92
>   4416,   2049,     37,         1,               0.919
>   4480,      0,      0,         0,                 1.0
>   4480,      0,      0,         1,               0.998
>   4480,     38,      0,         0,               0.996
>   4480,     38,      0,         1,               0.996
>   4480,     70,      0,         0,               0.992
>   4480,     70,      0,         1,               0.992
>   4480,      0,     38,         0,               0.919
>   4480,      0,     38,         1,               0.916
>   4480,      0,     70,         0,               0.767
>   4480,      0,     70,         1,               0.767
>   4480,     38,     38,         0,               1.002
>   4480,     38,     38,         1,               1.002
>   4480,     70,     70,         0,               0.963
>   4480,     70,     70,         1,               0.963
>   4480,   2048,      0,         0,               0.998
>   4480,   2048,      0,         1,               0.998
>   4480,   2086,      0,         0,               0.996
>   4480,   2086,      0,         1,               0.996
>   4480,   2048,     38,         0,               0.907
>   4480,   2048,     38,         1,               0.907
>   4480,   2086,     38,         0,               1.002
>   4480,   2086,     38,         1,               1.002
>   4480,     38,      1,         0,               1.023
>   4480,     38,      1,         1,               1.024
>   4480,      1,     38,         0,               0.914
>   4480,      1,     38,         1,               0.913
>   4480,     70,      1,         0,                1.01
>   4480,     70,      1,         1,               1.011
>   4480,      1,     70,         0,               0.922
>   4480,      1,     70,         1,               0.922
>   4480,   2086,      1,         0,               1.024
>   4480,   2086,      1,         1,               1.024
>   4480,   2049,     38,         0,               0.911
>   4480,   2049,     38,         1,                0.91
>   4544,      0,      0,         0,               1.002
>   4544,      0,      0,         1,               1.002
>   4544,     39,      0,         0,               1.007
>   4544,     39,      0,         1,               1.007
>   4544,     71,      0,         0,                1.01
>   4544,     71,      0,         1,               1.008
>   4544,      0,     39,         0,                0.93
>   4544,      0,     39,         1,                0.93
>   4544,      0,     71,         0,               0.766
>   4544,      0,     71,         1,               0.766
>   4544,     39,     39,         0,               1.001
>   4544,     39,     39,         1,               1.001
>   4544,     71,     71,         0,               0.966
>   4544,     71,     71,         1,               0.966
>   4544,   2048,      0,         0,               1.002
>   4544,   2048,      0,         1,               1.002
>   4544,   2087,      0,         0,               1.008
>   4544,   2087,      0,         1,               1.008
>   4544,   2048,     39,         0,               0.901
>   4544,   2048,     39,         1,               0.902
>   4544,   2087,     39,         0,               1.001
>   4544,   2087,     39,         1,               1.001
>   4544,     39,      1,         0,               1.032
>   4544,     39,      1,         1,               1.032
>   4544,      1,     39,         0,               0.925
>   4544,      1,     39,         1,               0.925
>   4544,     71,      1,         0,               0.997
>   4544,     71,      1,         1,               0.998
>   4544,      1,     71,         0,               0.921
>   4544,      1,     71,         1,               0.922
>   4544,   2087,      1,         0,               1.032
>   4544,   2087,      1,         1,               1.032
>   4544,   2049,     39,         0,               0.924
>   4544,   2049,     39,         1,               0.923
>   4608,      0,      0,         0,               0.999
>   4608,      0,      0,         1,               0.998
>   4608,     40,      0,         0,               1.013
>   4608,     40,      0,         1,               1.012
>   4608,     72,      0,         0,               1.013
>   4608,     72,      0,         1,               1.013
>   4608,      0,     40,         0,               0.925
>   4608,      0,     40,         1,               0.926
>   4608,      0,     72,         0,               0.765
>   4608,      0,     72,         1,               0.765
>   4608,     40,     40,         0,               1.085
>   4608,     40,     40,         1,               1.086
>   4608,     72,     72,         0,               0.966
>   4608,     72,     72,         1,               0.966
>   4608,   2048,      0,         0,               0.999
>   4608,   2048,      0,         1,               0.999
>   4608,   2088,      0,         0,               1.012
>   4608,   2088,      0,         1,               1.013
>   4608,   2048,     40,         0,               0.898
>   4608,   2048,     40,         1,               0.898
>   4608,   2088,     40,         0,               1.087
>   4608,   2088,     40,         1,               1.087
>   4608,     40,      1,         0,               1.006
>   4608,     40,      1,         1,               1.007
>   4608,      1,     40,         0,               0.919
>   4608,      1,     40,         1,               0.919
>   4608,     72,      1,         0,               1.012
>   4608,     72,      1,         1,               1.012
>   4608,      1,     72,         0,               0.914
>   4608,      1,     72,         1,               0.914
>   4608,   2088,      1,         0,               1.006
>   4608,   2088,      1,         1,               1.007
>   4608,   2049,     40,         0,               0.916
>   4608,   2049,     40,         1,               0.916
>   4672,      0,      0,         0,               1.014
>   4672,      0,      0,         1,               1.014
>   4672,     41,      0,         0,               1.002
>   4672,     41,      0,         1,               1.002
>   4672,     73,      0,         0,               0.976
>   4672,     73,      0,         1,               0.975
>   4672,      0,     41,         0,               0.919
>   4672,      0,     41,         1,               0.919
>   4672,      0,     73,         0,               0.772
>   4672,      0,     73,         1,               0.772
>   4672,     41,     41,         0,               1.012
>   4672,     41,     41,         1,               1.012
>   4672,     73,     73,         0,               0.973
>   4672,     73,     73,         1,               0.973
>   4672,   2048,      0,         0,               1.014
>   4672,   2048,      0,         1,               1.014
>   4672,   2089,      0,         0,               1.003
>   4672,   2089,      0,         1,               1.002
>   4672,   2048,     41,         0,               0.907
>   4672,   2048,     41,         1,               0.908
>   4672,   2089,     41,         0,               1.012
>   4672,   2089,     41,         1,               1.012
>   4672,     41,      1,         0,                1.02
>   4672,     41,      1,         1,                1.02
>   4672,      1,     41,         0,               0.916
>   4672,      1,     41,         1,               0.914
>   4672,     73,      1,         0,               1.024
>   4672,     73,      1,         1,               1.024
>   4672,      1,     73,         0,               0.927
>   4672,      1,     73,         1,               0.927
>   4672,   2089,      1,         0,               1.019
>   4672,   2089,      1,         1,                1.02
>   4672,   2049,     41,         0,               0.912
>   4672,   2049,     41,         1,               0.912
>   4736,      0,      0,         0,               1.007
>   4736,      0,      0,         1,               1.006
>   4736,     42,      0,         0,               1.012
>   4736,     42,      0,         1,               1.013
>   4736,     74,      0,         0,               0.976
>   4736,     74,      0,         1,               0.975
>   4736,      0,     42,         0,                0.93
>   4736,      0,     42,         1,               0.931
>   4736,      0,     74,         0,               0.769
>   4736,      0,     74,         1,                0.77
>   4736,     42,     42,         0,               1.007
>   4736,     42,     42,         1,               1.007
>   4736,     74,     74,         0,               0.965
>   4736,     74,     74,         1,               0.965
>   4736,   2048,      0,         0,               1.006
>   4736,   2048,      0,         1,               1.007
>   4736,   2090,      0,         0,               1.012
>   4736,   2090,      0,         1,               1.013
>   4736,   2048,     42,         0,               0.902
>   4736,   2048,     42,         1,               0.901
>   4736,   2090,     42,         0,               1.007
>   4736,   2090,     42,         1,               1.007
>   4736,     42,      1,         0,               1.032
>   4736,     42,      1,         1,               1.032
>   4736,      1,     42,         0,               0.919
>   4736,      1,     42,         1,               0.919
>   4736,     74,      1,         0,               1.017
>   4736,     74,      1,         1,               1.018
>   4736,      1,     74,         0,               0.919
>   4736,      1,     74,         1,               0.918
>   4736,   2090,      1,         0,               1.031
>   4736,   2090,      1,         1,               1.031
>   4736,   2049,     42,         0,               0.916
>   4736,   2049,     42,         1,               0.916
>   4800,      0,      0,         0,               1.012
>   4800,      0,      0,         1,               1.012
>   4800,     43,      0,         0,               1.008
>   4800,     43,      0,         1,               1.009
>   4800,     75,      0,         0,                0.99
>   4800,     75,      0,         1,                0.99
>   4800,      0,     43,         0,               0.929
>   4800,      0,     43,         1,               0.927
>   4800,      0,     75,         0,               0.768
>   4800,      0,     75,         1,               0.768
>   4800,     43,     43,         0,               1.004
>   4800,     43,     43,         1,               1.004
>   4800,     75,     75,         0,               0.965
>   4800,     75,     75,         1,               0.965
>   4800,   2048,      0,         0,               1.012
>   4800,   2048,      0,         1,               1.012
>   4800,   2091,      0,         0,               1.009
>   4800,   2091,      0,         1,               1.008
>   4800,   2048,     43,         0,               0.901
>   4800,   2048,     43,         1,               0.901
>   4800,   2091,     43,         0,               1.004
>   4800,   2091,     43,         1,               1.004
>   4800,     43,      1,         0,               1.026
>   4800,     43,      1,         1,               1.026
>   4800,      1,     43,         0,               0.923
>   4800,      1,     43,         1,               0.922
>   4800,     75,      1,         0,               0.993
>   4800,     75,      1,         1,               0.991
>   4800,      1,     75,         0,               0.921
>   4800,      1,     75,         1,                0.92
>   4800,   2091,      1,         0,               1.026
>   4800,   2091,      1,         1,               1.026
>   4800,   2049,     43,         0,                0.92
>   4800,   2049,     43,         1,               0.919
>   4864,      0,      0,         0,               0.999
>   4864,      0,      0,         1,               0.999
>   4864,     44,      0,         0,               0.998
>   4864,     44,      0,         1,               0.998
>   4864,     76,      0,         0,               0.981
>   4864,     76,      0,         1,               0.981
>   4864,      0,     44,         0,               0.916
>   4864,      0,     44,         1,               0.918
>   4864,      0,     76,         0,               0.772
>   4864,      0,     76,         1,               0.771
>   4864,     44,     44,         0,               1.006
>   4864,     44,     44,         1,               1.005
>   4864,     76,     76,         0,                0.97
>   4864,     76,     76,         1,                0.97
>   4864,   2048,      0,         0,               0.999
>   4864,   2048,      0,         1,               0.999
>   4864,   2092,      0,         0,               0.997
>   4864,   2092,      0,         1,               0.997
>   4864,   2048,     44,         0,               0.908
>   4864,   2048,     44,         1,               0.907
>   4864,   2092,     44,         0,               1.005
>   4864,   2092,     44,         1,               1.005
>   4864,     44,      1,         0,               0.893
>   4864,     44,      1,         1,               0.893
>   4864,      1,     44,         0,               0.922
>   4864,      1,     44,         1,               0.921
>   4864,     76,      1,         0,               0.866
>   4864,     76,      1,         1,               0.866
>   4864,      1,     76,         0,               0.919
>   4864,      1,     76,         1,               0.919
>   4864,   2092,      1,         0,               0.893
>   4864,   2092,      1,         1,               0.893
>   4864,   2049,     44,         0,               0.919
>   4864,   2049,     44,         1,               0.919
>   4928,      0,      0,         0,               1.005
>   4928,      0,      0,         1,               1.005
>   4928,     45,      0,         0,               1.005
>   4928,     45,      0,         1,               1.005
>   4928,     77,      0,         0,                0.97
>   4928,     77,      0,         1,                0.97
>   4928,      0,     45,         0,               0.931
>   4928,      0,     45,         1,               0.932
>   4928,      0,     77,         0,               0.771
>   4928,      0,     77,         1,               0.771
>   4928,     45,     45,         0,                 1.0
>   4928,     45,     45,         1,                 1.0
>   4928,     77,     77,         0,               0.972
>   4928,     77,     77,         1,               0.972
>   4928,   2048,      0,         0,               1.005
>   4928,   2048,      0,         1,               1.005
>   4928,   2093,      0,         0,               1.005
>   4928,   2093,      0,         1,               1.005
>   4928,   2048,     45,         0,               0.904
>   4928,   2048,     45,         1,               0.905
>   4928,   2093,     45,         0,                 1.0
>   4928,   2093,     45,         1,                 1.0
>   4928,     45,      1,         0,               1.024
>   4928,     45,      1,         1,               1.024
>   4928,      1,     45,         0,               0.913
>   4928,      1,     45,         1,               0.912
>   4928,     77,      1,         0,               0.996
>   4928,     77,      1,         1,               0.996
>   4928,      1,     77,         0,               0.925
>   4928,      1,     77,         1,               0.925
>   4928,   2093,      1,         0,               1.025
>   4928,   2093,      1,         1,               1.024
>   4928,   2049,     45,         0,               0.916
>   4928,   2049,     45,         1,               0.911
>   4992,      0,      0,         0,                 1.0
>   4992,      0,      0,         1,                 1.0
>   4992,     46,      0,         0,               1.009
>   4992,     46,      0,         1,               1.009
>   4992,     78,      0,         0,               0.992
>   4992,     78,      0,         1,               0.992
>   4992,      0,     46,         0,               0.908
>   4992,      0,     46,         1,               0.908
>   4992,      0,     78,         0,               0.751
>   4992,      0,     78,         1,               0.752
>   4992,     46,     46,         0,               0.997
>   4992,     46,     46,         1,               0.997
>   4992,     78,     78,         0,               0.968
>   4992,     78,     78,         1,               0.969
>   4992,   2048,      0,         0,                 1.0
>   4992,   2048,      0,         1,               1.001
>   4992,   2094,      0,         0,               1.008
>   4992,   2094,      0,         1,               1.009
>   4992,   2048,     46,         0,               0.883
>   4992,   2048,     46,         1,               0.883
>   4992,   2094,     46,         0,               0.997
>   4992,   2094,     46,         1,               0.997
>   4992,     46,      1,         0,               1.025
>   4992,     46,      1,         1,               1.025
>   4992,      1,     46,         0,               0.923
>   4992,      1,     46,         1,               0.923
>   4992,     78,      1,         0,                 1.0
>   4992,     78,      1,         1,               1.001
>   4992,      1,     78,         0,                0.92
>   4992,      1,     78,         1,                0.92
>   4992,   2094,      1,         0,               1.025
>   4992,   2094,      1,         1,               1.026
>   4992,   2049,     46,         0,                0.92
>   4992,   2049,     46,         1,               0.921
>   5056,      0,      0,         0,               1.002
>   5056,      0,      0,         1,               1.001
>   5056,     47,      0,         0,               1.006
>   5056,     47,      0,         1,               1.006
>   5056,     79,      0,         0,                0.99
>   5056,     79,      0,         1,               0.988
>   5056,      0,     47,         0,               0.917
>   5056,      0,     47,         1,               0.916
>   5056,      0,     79,         0,               0.771
>   5056,      0,     79,         1,               0.772
>   5056,     47,     47,         0,               1.006
>   5056,     47,     47,         1,               1.006
>   5056,     79,     79,         0,               0.972
>   5056,     79,     79,         1,               0.973
>   5056,   2048,      0,         0,               1.003
>   5056,   2048,      0,         1,               1.001
>   5056,   2095,      0,         0,               1.005
>   5056,   2095,      0,         1,               1.004
>   5056,   2048,     47,         0,               0.908
>   5056,   2048,     47,         1,               0.909
>   5056,   2095,     47,         0,               1.006
>   5056,   2095,     47,         1,               1.006
>   5056,     47,      1,         0,               1.032
>   5056,     47,      1,         1,               1.034
>   5056,      1,     47,         0,               0.926
>   5056,      1,     47,         1,               0.926
>   5056,     79,      1,         0,               1.003
>   5056,     79,      1,         1,               1.004
>   5056,      1,     79,         0,               0.927
>   5056,      1,     79,         1,               0.927
>   5056,   2095,      1,         0,               1.034
>   5056,   2095,      1,         1,               1.033
>   5056,   2049,     47,         0,               0.924
>   5056,   2049,     47,         1,               0.923
>   5120,      0,      0,         0,               1.003
>   5120,      0,      0,         1,               1.004
>   5120,     48,      0,         0,               1.068
>   5120,     48,      0,         1,               1.068
>   5120,     80,      0,         0,               1.068
>   5120,     80,      0,         1,               1.068
>   5120,      0,     48,         0,               1.065
>   5120,      0,     48,         1,               1.064
>   5120,      0,     80,         0,               1.065
>   5120,      0,     80,         1,               1.065
>   5120,     48,     48,         0,               1.004
>   5120,     48,     48,         1,               1.005
>   5120,     80,     80,         0,               1.005
>   5120,     80,     80,         1,               1.005
>   5120,   2048,      0,         0,               1.005
>   5120,   2048,      0,         1,               1.005
>   5120,   2096,      0,         0,               1.068
>   5120,   2096,      0,         1,               1.068
>   5120,   2048,     48,         0,               1.066
>   5120,   2048,     48,         1,               1.065
>   5120,   2096,     48,         0,               1.005
>   5120,   2096,     48,         1,               1.005
>   5120,     48,      1,         0,               1.032
>   5120,     48,      1,         1,               1.032
>   5120,      1,     48,         0,               0.899
>   5120,      1,     48,         1,               0.899
>   5120,     80,      1,         0,               0.844
>   5120,     80,      1,         1,               0.843
>   5120,      1,     80,         0,               0.892
>   5120,      1,     80,         1,               0.892
>   5120,   2096,      1,         0,               0.856
>   5120,   2096,      1,         1,               0.856
>   5120,   2049,     48,         0,               0.898
>   5120,   2049,     48,         1,               0.898
>
>
> Results For: bench-memcpy-large
>   length, align1, align2, dst > src, New Time / Old Time
>    65543,      0,      0,         0,               0.977
>    65543,      0,      0,         1,               0.976
>    65551,      0,      3,         0,                1.01
>    65551,      0,      3,         1,               1.011
>    65567,      3,      0,         0,                1.02
>    65567,      3,      0,         1,                1.02
>    65599,      3,      5,         0,               1.056
>    65599,      3,      5,         1,               1.057
>    65536,      0,    127,         0,               1.043
>    65536,      0,    127,         1,               1.043
>    65536,      0,    255,         0,                1.07
>    65536,      0,    255,         1,               1.071
>    65536,      0,    256,         0,               0.978
>    65536,      0,    256,         1,               0.979
>    65536,      0,   4064,         0,               1.017
>    65536,      0,   4064,         1,               1.018
>   131079,      0,      0,         0,               0.979
>   131079,      0,      0,         1,               0.979
>   131087,      0,      3,         0,               1.016
>   131087,      0,      3,         1,               1.016
>   131103,      3,      0,         0,               1.022
>   131103,      3,      0,         1,               1.022
>   131135,      3,      5,         0,               1.063
>   131135,      3,      5,         1,               1.063
>   131072,      0,    127,         0,               1.048
>   131072,      0,    127,         1,               1.048
>   131072,      0,    255,         0,               1.074
>   131072,      0,    255,         1,               1.074
>   131072,      0,    256,         0,               0.982
>   131072,      0,    256,         1,               0.982
>   131072,      0,   4064,         0,               1.018
>   131072,      0,   4064,         1,               1.019
>   262151,      0,      0,         0,               0.984
>   262151,      0,      0,         1,               0.984
>   262159,      0,      3,         0,               1.024
>   262159,      0,      3,         1,               1.024
>   262175,      3,      0,         0,                1.03
>   262175,      3,      0,         1,                1.03
>   262207,      3,      5,         0,               1.068
>   262207,      3,      5,         1,               1.069
>   262144,      0,    127,         0,               1.056
>   262144,      0,    127,         1,               1.056
>   262144,      0,    255,         0,               1.078
>   262144,      0,    255,         1,               1.078
>   262144,      0,    256,         0,               0.986
>   262144,      0,    256,         1,               0.986
>   262144,      0,   4064,         0,                1.02
>   262144,      0,   4064,         1,                1.02
>   524295,      0,      0,         0,               0.692
>   524295,      0,      0,         1,               0.692
>   524303,      0,      3,         0,               0.736
>   524303,      0,      3,         1,               0.736
>   524319,      3,      0,         0,               0.759
>   524319,      3,      0,         1,               0.759
>   524351,      3,      5,         0,               0.758
>   524351,      3,      5,         1,               0.759
>   524288,      0,    127,         0,               1.057
>   524288,      0,    127,         1,               1.057
>   524288,      0,    255,         0,               1.079
>   524288,      0,    255,         1,               1.079
>   524288,      0,    256,         0,               0.987
>   524288,      0,    256,         1,               0.987
>   524288,      0,   4064,         0,                1.02
>   524288,      0,   4064,         1,                1.02
>  1048583,      0,      0,         0,               0.948
>  1048583,      0,      0,         1,               0.949
>  1048591,      0,      3,         0,               0.734
>  1048591,      0,      3,         1,               0.735
>  1048607,      3,      0,         0,               0.758
>  1048607,      3,      0,         1,               0.757
>  1048639,      3,      5,         0,               0.757
>  1048639,      3,      5,         1,               0.757
>  1048576,      0,    127,         0,               0.761
>  1048576,      0,    127,         1,               0.763
>  1048576,      0,    255,         0,               0.751
>  1048576,      0,    255,         1,               0.751
>  1048576,      0,    256,         0,                0.93
>  1048576,      0,    256,         1,                0.93
>  1048576,      0,   4064,         0,                0.93
>  1048576,      0,   4064,         1,                0.93
>  2097159,      0,      0,         0,               0.928
>  2097159,      0,      0,         1,               0.931
>  2097167,      0,      3,         0,               0.735
>  2097167,      0,      3,         1,               0.734
>  2097183,      3,      0,         0,               0.759
>  2097183,      3,      0,         1,                0.76
>  2097215,      3,      5,         0,               0.758
>  2097215,      3,      5,         1,               0.757
>  2097152,      0,    127,         0,                0.77
>  2097152,      0,    127,         1,                0.77
>  2097152,      0,    255,         0,               0.745
>  2097152,      0,    255,         1,               0.745
>  2097152,      0,    256,         0,               0.924
>  2097152,      0,    256,         1,               0.925
>  2097152,      0,   4064,         0,               0.926
>  2097152,      0,   4064,         1,               0.927
>  4194311,      0,      0,         0,               0.886
>  4194311,      0,      0,         1,                0.89
>  4194319,      0,      3,         0,               0.746
>  4194319,      0,      3,         1,               0.745
>  4194335,      3,      0,         0,               0.816
>  4194335,      3,      0,         1,               0.816
>  4194367,      3,      5,         0,                0.78
>  4194367,      3,      5,         1,               0.781
>  4194304,      0,    127,         0,               0.792
>  4194304,      0,    127,         1,               0.791
>  4194304,      0,    255,         0,               0.803
>  4194304,      0,    255,         1,               0.799
>  4194304,      0,    256,         0,               0.865
>  4194304,      0,    256,         1,               0.863
>  4194304,      0,   4064,         0,               0.953
>  4194304,      0,   4064,         1,                0.95
>  8388615,      0,      0,         0,               0.876
>  8388615,      0,      0,         1,               0.877
>  8388623,      0,      3,         0,               0.762
>  8388623,      0,      3,         1,               0.762
>  8388639,      3,      0,         0,               0.871
>  8388639,      3,      0,         1,                0.87
>  8388671,      3,      5,         0,               0.805
>  8388671,      3,      5,         1,               0.808
>  8388608,      0,    127,         0,               0.824
>  8388608,      0,    127,         1,               0.823
>  8388608,      0,    255,         0,               0.858
>  8388608,      0,    255,         1,               0.857
>  8388608,      0,    256,         0,               0.843
>  8388608,      0,    256,         1,                0.84
>  8388608,      0,   4064,         0,               0.981
>  8388608,      0,   4064,         1,               0.981
> 16777223,      0,      0,         0,               0.881
> 16777223,      0,      0,         1,               0.882
> 16777231,      0,      3,         0,               0.765
> 16777231,      0,      3,         1,               0.765
> 16777247,      3,      0,         0,                0.87
> 16777247,      3,      0,         1,                0.87
> 16777279,      3,      5,         0,               0.807
> 16777279,      3,      5,         1,               0.811
> 16777216,      0,    127,         0,               0.827
> 16777216,      0,    127,         1,               0.827
> 16777216,      0,    255,         0,               0.858
> 16777216,      0,    255,         1,               0.857
> 16777216,      0,    256,         0,               0.848
> 16777216,      0,    256,         1,               0.844
> 16777216,      0,   4064,         0,                0.98
> 16777216,      0,   4064,         1,               0.981
> 33554439,      0,      0,         0,               0.883
> 33554439,      0,      0,         1,               0.884
> 33554447,      0,      3,         0,               0.767
> 33554447,      0,      3,         1,               0.766
> 33554463,      3,      0,         0,                0.87
> 33554463,      3,      0,         1,                0.87
> 33554495,      3,      5,         0,               0.809
> 33554495,      3,      5,         1,               0.813
> 33554432,      0,    127,         0,               0.829
> 33554432,      0,    127,         1,               0.829
> 33554432,      0,    255,         0,               0.857
> 33554432,      0,    255,         1,               0.857
> 33554432,      0,    256,         0,                0.85
> 33554432,      0,    256,         1,               0.846
> 33554432,      0,   4064,         0,               0.981
> 33554432,      0,   4064,         1,               0.981
>
>
> Results For: bench-memcpy-random
>  length, New Time / Old Time
>   32768,               0.888
>   65536,               0.906
>  131072,               0.915
>  262144,               0.919
>  524288,               0.921
> 1048576,               0.929
>
>  sysdeps/x86_64/multiarch/Makefile        |    1 -
>  sysdeps/x86_64/multiarch/memcpy-ssse3.S  | 3151 ----------------------
>  sysdeps/x86_64/multiarch/memmove-ssse3.S |  384 ++-
>  3 files changed, 380 insertions(+), 3156 deletions(-)
>  delete mode 100644 sysdeps/x86_64/multiarch/memcpy-ssse3.S
>
> diff --git a/sysdeps/x86_64/multiarch/Makefile b/sysdeps/x86_64/multiarch/Makefile
> index 303fb5d734..e7ea963fc0 100644
> --- a/sysdeps/x86_64/multiarch/Makefile
> +++ b/sysdeps/x86_64/multiarch/Makefile
> @@ -16,7 +16,6 @@ sysdep_routines += \
>    memcmpeq-avx2-rtm \
>    memcmpeq-evex \
>    memcmpeq-sse2 \
> -  memcpy-ssse3 \
>    memmove-avx-unaligned-erms \
>    memmove-avx-unaligned-erms-rtm \
>    memmove-avx512-no-vzeroupper \
> diff --git a/sysdeps/x86_64/multiarch/memcpy-ssse3.S b/sysdeps/x86_64/multiarch/memcpy-ssse3.S
> deleted file mode 100644
> index 65644d3a09..0000000000
> --- a/sysdeps/x86_64/multiarch/memcpy-ssse3.S
> +++ /dev/null
> @@ -1,3151 +0,0 @@
> -/* memcpy with SSSE3
> -   Copyright (C) 2010-2022 Free Software Foundation, Inc.
> -   This file is part of the GNU C Library.
> -
> -   The GNU C Library is free software; you can redistribute it and/or
> -   modify it under the terms of the GNU Lesser General Public
> -   License as published by the Free Software Foundation; either
> -   version 2.1 of the License, or (at your option) any later version.
> -
> -   The GNU C Library is distributed in the hope that it will be useful,
> -   but WITHOUT ANY WARRANTY; without even the implied warranty of
> -   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
> -   Lesser General Public License for more details.
> -
> -   You should have received a copy of the GNU Lesser General Public
> -   License along with the GNU C Library; if not, see
> -   <https://www.gnu.org/licenses/>.  */
> -
> -#include <sysdep.h>
> -
> -#if IS_IN (libc)
> -
> -#include "asm-syntax.h"
> -
> -#ifndef MEMCPY
> -# define MEMCPY __memcpy_ssse3
> -# define MEMCPY_CHK __memcpy_chk_ssse3
> -# define MEMPCPY __mempcpy_ssse3
> -# define MEMPCPY_CHK __mempcpy_chk_ssse3
> -#endif
> -
> -#define JMPTBL(I, B) I - B
> -
> -/* Branch to an entry in a jump table.  TABLE is a jump table with
> -   relative offsets.  INDEX is a register contains the index into the
> -   jump table.  SCALE is the scale of INDEX.  */
> -#define BRANCH_TO_JMPTBL_ENTRY(TABLE, INDEX, SCALE) \
> -  lea TABLE(%rip), %r11; \
> -  movslq (%r11, INDEX, SCALE), INDEX; \
> -  lea (%r11, INDEX), INDEX; \
> -  _CET_NOTRACK jmp *INDEX; \
> -  ud2
> -
> - .section .text.ssse3,"ax",@progbits
> -#if !defined USE_AS_MEMPCPY && !defined USE_AS_MEMMOVE
> -ENTRY (MEMPCPY_CHK)
> - cmp %RDX_LP, %RCX_LP
> - jb HIDDEN_JUMPTARGET (__chk_fail)
> -END (MEMPCPY_CHK)
> -
> -ENTRY (MEMPCPY)
> - mov %RDI_LP, %RAX_LP
> - add %RDX_LP, %RAX_LP
> - jmp L(start)
> -END (MEMPCPY)
> -#endif
> -
> -#if !defined USE_AS_BCOPY
> -ENTRY (MEMCPY_CHK)
> - cmp %RDX_LP, %RCX_LP
> - jb HIDDEN_JUMPTARGET (__chk_fail)
> -END (MEMCPY_CHK)
> -#endif
> -
> -ENTRY (MEMCPY)
> - mov %RDI_LP, %RAX_LP
> -#ifdef USE_AS_MEMPCPY
> - add %RDX_LP, %RAX_LP
> -#endif
> -
> -#ifdef __ILP32__
> - /* Clear the upper 32 bits.  */
> - mov %edx, %edx
> -#endif
> -
> -#ifdef USE_AS_MEMMOVE
> - cmp %rsi, %rdi
> - jb L(copy_forward)
> - je L(write_0bytes)
> - cmp $79, %rdx
> - jbe L(copy_forward)
> - jmp L(copy_backward)
> -L(copy_forward):
> -#endif
> -L(start):
> - cmp $79, %rdx
> - lea     L(table_less_80bytes)(%rip), %r11
> - ja L(80bytesormore)
> - movslq (%r11, %rdx, 4), %r9
> - add %rdx, %rsi
> - add %rdx, %rdi
> - add %r11, %r9
> - _CET_NOTRACK jmp *%r9
> - ud2
> -
> - .p2align 4
> -L(80bytesormore):
> -#ifndef USE_AS_MEMMOVE
> - cmp %dil, %sil
> - jle L(copy_backward)
> -#endif
> -
> - movdqu (%rsi), %xmm0
> - mov %rdi, %rcx
> - and $-16, %rdi
> - add $16, %rdi
> - mov %rcx, %r8
> - sub %rdi, %rcx
> - add %rcx, %rdx
> - sub %rcx, %rsi
> -
> -#ifdef SHARED_CACHE_SIZE_HALF
> - mov $SHARED_CACHE_SIZE_HALF, %RCX_LP
> -#else
> - mov __x86_shared_cache_size_half(%rip), %RCX_LP
> -#endif
> - cmp %rcx, %rdx
> - mov %rsi, %r9
> - ja L(large_page_fwd)
> - and $0xf, %r9
> - jz L(shl_0)
> -#ifdef DATA_CACHE_SIZE_HALF
> - mov $DATA_CACHE_SIZE_HALF, %RCX_LP
> -#else
> - mov __x86_data_cache_size_half(%rip), %RCX_LP
> -#endif
> - BRANCH_TO_JMPTBL_ENTRY (L(shl_table), %r9, 4)
> -
> - .p2align 4
> -L(copy_backward):
> - movdqu -16(%rsi, %rdx), %xmm0
> - add %rdx, %rsi
> - lea -16(%rdi, %rdx), %r8
> - add %rdx, %rdi
> -
> - mov %rdi, %rcx
> - and $0xf, %rcx
> - xor %rcx, %rdi
> - sub %rcx, %rdx
> - sub %rcx, %rsi
> -
> -#ifdef SHARED_CACHE_SIZE_HALF
> - mov $SHARED_CACHE_SIZE_HALF, %RCX_LP
> -#else
> - mov __x86_shared_cache_size_half(%rip), %RCX_LP
> -#endif
> -
> - cmp %rcx, %rdx
> - mov %rsi, %r9
> - ja L(large_page_bwd)
> - and $0xf, %r9
> - jz L(shl_0_bwd)
> -#ifdef DATA_CACHE_SIZE_HALF
> - mov $DATA_CACHE_SIZE_HALF, %RCX_LP
> -#else
> - mov __x86_data_cache_size_half(%rip), %RCX_LP
> -#endif
> - BRANCH_TO_JMPTBL_ENTRY (L(shl_table_bwd), %r9, 4)
> -
> - .p2align 4
> -L(shl_0):
> - sub $16, %rdx
> - movdqa (%rsi), %xmm1
> - add $16, %rsi
> - movdqa %xmm1, (%rdi)
> - add $16, %rdi
> - cmp $128, %rdx
> - movdqu %xmm0, (%r8)
> - ja L(shl_0_gobble)
> - cmp $64, %rdx
> - jb L(shl_0_less_64bytes)
> - movaps (%rsi), %xmm4
> - movaps 16(%rsi), %xmm1
> - movaps 32(%rsi), %xmm2
> - movaps 48(%rsi), %xmm3
> - movaps %xmm4, (%rdi)
> - movaps %xmm1, 16(%rdi)
> - movaps %xmm2, 32(%rdi)
> - movaps %xmm3, 48(%rdi)
> - sub $64, %rdx
> - add $64, %rsi
> - add $64, %rdi
> -L(shl_0_less_64bytes):
> - add %rdx, %rsi
> - add %rdx, %rdi
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_0_gobble):
> -#ifdef DATA_CACHE_SIZE_HALF
> - cmp $DATA_CACHE_SIZE_HALF, %RDX_LP
> -#else
> - cmp __x86_data_cache_size_half(%rip), %RDX_LP
> -#endif
> - lea -128(%rdx), %rdx
> - jae L(shl_0_gobble_mem_loop)
> -L(shl_0_gobble_cache_loop):
> - movdqa (%rsi), %xmm4
> - movaps 0x10(%rsi), %xmm1
> - movaps 0x20(%rsi), %xmm2
> - movaps 0x30(%rsi), %xmm3
> -
> - movdqa %xmm4, (%rdi)
> - movaps %xmm1, 0x10(%rdi)
> - movaps %xmm2, 0x20(%rdi)
> - movaps %xmm3, 0x30(%rdi)
> -
> - sub $128, %rdx
> - movaps 0x40(%rsi), %xmm4
> - movaps 0x50(%rsi), %xmm5
> - movaps 0x60(%rsi), %xmm6
> - movaps 0x70(%rsi), %xmm7
> - lea 0x80(%rsi), %rsi
> - movaps %xmm4, 0x40(%rdi)
> - movaps %xmm5, 0x50(%rdi)
> - movaps %xmm6, 0x60(%rdi)
> - movaps %xmm7, 0x70(%rdi)
> - lea 0x80(%rdi), %rdi
> -
> - jae L(shl_0_gobble_cache_loop)
> - cmp $-0x40, %rdx
> - lea 0x80(%rdx), %rdx
> - jl L(shl_0_cache_less_64bytes)
> -
> - movdqa (%rsi), %xmm4
> - sub $0x40, %rdx
> - movdqa 0x10(%rsi), %xmm1
> -
> - movdqa %xmm4, (%rdi)
> - movdqa %xmm1, 0x10(%rdi)
> -
> - movdqa 0x20(%rsi), %xmm4
> - movdqa 0x30(%rsi), %xmm1
> - add $0x40, %rsi
> -
> - movdqa %xmm4, 0x20(%rdi)
> - movdqa %xmm1, 0x30(%rdi)
> - add $0x40, %rdi
> -L(shl_0_cache_less_64bytes):
> - add %rdx, %rsi
> - add %rdx, %rdi
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_0_gobble_mem_loop):
> - prefetcht0 0x1c0(%rsi)
> - prefetcht0 0x280(%rsi)
> -
> - movdqa (%rsi), %xmm0
> - movdqa 0x10(%rsi), %xmm1
> - movdqa 0x20(%rsi), %xmm2
> - movdqa 0x30(%rsi), %xmm3
> - movdqa 0x40(%rsi), %xmm4
> - movdqa 0x50(%rsi), %xmm5
> - movdqa 0x60(%rsi), %xmm6
> - movdqa 0x70(%rsi), %xmm7
> - lea 0x80(%rsi), %rsi
> - sub $0x80, %rdx
> - movdqa %xmm0, (%rdi)
> - movdqa %xmm1, 0x10(%rdi)
> - movdqa %xmm2, 0x20(%rdi)
> - movdqa %xmm3, 0x30(%rdi)
> - movdqa %xmm4, 0x40(%rdi)
> - movdqa %xmm5, 0x50(%rdi)
> - movdqa %xmm6, 0x60(%rdi)
> - movdqa %xmm7, 0x70(%rdi)
> - lea 0x80(%rdi), %rdi
> -
> - jae L(shl_0_gobble_mem_loop)
> - cmp $-0x40, %rdx
> - lea 0x80(%rdx), %rdx
> - jl L(shl_0_mem_less_64bytes)
> -
> - movdqa (%rsi), %xmm0
> - sub $0x40, %rdx
> - movdqa 0x10(%rsi), %xmm1
> -
> - movdqa %xmm0, (%rdi)
> - movdqa %xmm1, 0x10(%rdi)
> -
> - movdqa 0x20(%rsi), %xmm0
> - movdqa 0x30(%rsi), %xmm1
> - add $0x40, %rsi
> -
> - movdqa %xmm0, 0x20(%rdi)
> - movdqa %xmm1, 0x30(%rdi)
> - add $0x40, %rdi
> -L(shl_0_mem_less_64bytes):
> - cmp $0x20, %rdx
> - jb L(shl_0_mem_less_32bytes)
> - movdqa (%rsi), %xmm0
> - sub $0x20, %rdx
> - movdqa 0x10(%rsi), %xmm1
> - add $0x20, %rsi
> - movdqa %xmm0, (%rdi)
> - movdqa %xmm1, 0x10(%rdi)
> - add $0x20, %rdi
> -L(shl_0_mem_less_32bytes):
> - add %rdx, %rdi
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_0_bwd):
> - sub $16, %rdx
> - movdqa -0x10(%rsi), %xmm1
> - sub $16, %rsi
> - movdqa %xmm1, -0x10(%rdi)
> - sub $16, %rdi
> - cmp $0x80, %rdx
> - movdqu %xmm0, (%r8)
> - ja L(shl_0_gobble_bwd)
> - cmp $64, %rdx
> - jb L(shl_0_less_64bytes_bwd)
> - movaps -0x10(%rsi), %xmm0
> - movaps -0x20(%rsi), %xmm1
> - movaps -0x30(%rsi), %xmm2
> - movaps -0x40(%rsi), %xmm3
> - movaps %xmm0, -0x10(%rdi)
> - movaps %xmm1, -0x20(%rdi)
> - movaps %xmm2, -0x30(%rdi)
> - movaps %xmm3, -0x40(%rdi)
> - sub $64, %rdx
> - sub $0x40, %rsi
> - sub $0x40, %rdi
> -L(shl_0_less_64bytes_bwd):
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_0_gobble_bwd):
> -#ifdef DATA_CACHE_SIZE_HALF
> - cmp $DATA_CACHE_SIZE_HALF, %RDX_LP
> -#else
> - cmp __x86_data_cache_size_half(%rip), %RDX_LP
> -#endif
> - lea -128(%rdx), %rdx
> - jae L(shl_0_gobble_mem_bwd_loop)
> -L(shl_0_gobble_bwd_loop):
> - movdqa -0x10(%rsi), %xmm0
> - movaps -0x20(%rsi), %xmm1
> - movaps -0x30(%rsi), %xmm2
> - movaps -0x40(%rsi), %xmm3
> -
> - movdqa %xmm0, -0x10(%rdi)
> - movaps %xmm1, -0x20(%rdi)
> - movaps %xmm2, -0x30(%rdi)
> - movaps %xmm3, -0x40(%rdi)
> -
> - sub $0x80, %rdx
> - movaps -0x50(%rsi), %xmm4
> - movaps -0x60(%rsi), %xmm5
> - movaps -0x70(%rsi), %xmm6
> - movaps -0x80(%rsi), %xmm7
> - lea -0x80(%rsi), %rsi
> - movaps %xmm4, -0x50(%rdi)
> - movaps %xmm5, -0x60(%rdi)
> - movaps %xmm6, -0x70(%rdi)
> - movaps %xmm7, -0x80(%rdi)
> - lea -0x80(%rdi), %rdi
> -
> - jae L(shl_0_gobble_bwd_loop)
> - cmp $-0x40, %rdx
> - lea 0x80(%rdx), %rdx
> - jl L(shl_0_gobble_bwd_less_64bytes)
> -
> - movdqa -0x10(%rsi), %xmm0
> - sub $0x40, %rdx
> - movdqa -0x20(%rsi), %xmm1
> -
> - movdqa %xmm0, -0x10(%rdi)
> - movdqa %xmm1, -0x20(%rdi)
> -
> - movdqa -0x30(%rsi), %xmm0
> - movdqa -0x40(%rsi), %xmm1
> - sub $0x40, %rsi
> -
> - movdqa %xmm0, -0x30(%rdi)
> - movdqa %xmm1, -0x40(%rdi)
> - sub $0x40, %rdi
> -L(shl_0_gobble_bwd_less_64bytes):
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_0_gobble_mem_bwd_loop):
> - prefetcht0 -0x1c0(%rsi)
> - prefetcht0 -0x280(%rsi)
> - movdqa -0x10(%rsi), %xmm0
> - movdqa -0x20(%rsi), %xmm1
> - movdqa -0x30(%rsi), %xmm2
> - movdqa -0x40(%rsi), %xmm3
> - movdqa -0x50(%rsi), %xmm4
> - movdqa -0x60(%rsi), %xmm5
> - movdqa -0x70(%rsi), %xmm6
> - movdqa -0x80(%rsi), %xmm7
> - lea -0x80(%rsi), %rsi
> - sub $0x80, %rdx
> - movdqa %xmm0, -0x10(%rdi)
> - movdqa %xmm1, -0x20(%rdi)
> - movdqa %xmm2, -0x30(%rdi)
> - movdqa %xmm3, -0x40(%rdi)
> - movdqa %xmm4, -0x50(%rdi)
> - movdqa %xmm5, -0x60(%rdi)
> - movdqa %xmm6, -0x70(%rdi)
> - movdqa %xmm7, -0x80(%rdi)
> - lea -0x80(%rdi), %rdi
> -
> - jae L(shl_0_gobble_mem_bwd_loop)
> - cmp $-0x40, %rdx
> - lea 0x80(%rdx), %rdx
> - jl L(shl_0_mem_bwd_less_64bytes)
> -
> - movdqa -0x10(%rsi), %xmm0
> - sub $0x40, %rdx
> - movdqa -0x20(%rsi), %xmm1
> -
> - movdqa %xmm0, -0x10(%rdi)
> - movdqa %xmm1, -0x20(%rdi)
> -
> - movdqa -0x30(%rsi), %xmm0
> - movdqa -0x40(%rsi), %xmm1
> - sub $0x40, %rsi
> -
> - movdqa %xmm0, -0x30(%rdi)
> - movdqa %xmm1, -0x40(%rdi)
> - sub $0x40, %rdi
> -L(shl_0_mem_bwd_less_64bytes):
> - cmp $0x20, %rdx
> - jb L(shl_0_mem_bwd_less_32bytes)
> - movdqa -0x10(%rsi), %xmm0
> - sub $0x20, %rdx
> - movdqa -0x20(%rsi), %xmm1
> - sub $0x20, %rsi
> - movdqa %xmm0, -0x10(%rdi)
> - movdqa %xmm1, -0x20(%rdi)
> - sub $0x20, %rdi
> -L(shl_0_mem_bwd_less_32bytes):
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_1):
> - lea (L(shl_1_loop_L1)-L(shl_1))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x01(%rsi), %xmm1
> - jb L(L1_fwd)
> - lea (L(shl_1_loop_L2)-L(shl_1_loop_L1))(%r9), %r9
> -L(L1_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_1_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_1_loop_L1):
> - sub $64, %rdx
> - movaps 0x0f(%rsi), %xmm2
> - movaps 0x1f(%rsi), %xmm3
> - movaps 0x2f(%rsi), %xmm4
> - movaps 0x3f(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $1, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $1, %xmm3, %xmm4
> - palignr $1, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $1, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_1_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_1_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_1_bwd):
> - lea (L(shl_1_bwd_loop_L1)-L(shl_1_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x01(%rsi), %xmm1
> - jb L(L1_bwd)
> - lea (L(shl_1_bwd_loop_L2)-L(shl_1_bwd_loop_L1))(%r9), %r9
> -L(L1_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_1_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_1_bwd_loop_L1):
> - movaps -0x11(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x21(%rsi), %xmm3
> - movaps -0x31(%rsi), %xmm4
> - movaps -0x41(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $1, %xmm2, %xmm1
> - palignr $1, %xmm3, %xmm2
> - palignr $1, %xmm4, %xmm3
> - palignr $1, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_1_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_1_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_2):
> - lea (L(shl_2_loop_L1)-L(shl_2))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x02(%rsi), %xmm1
> - jb L(L2_fwd)
> - lea (L(shl_2_loop_L2)-L(shl_2_loop_L1))(%r9), %r9
> -L(L2_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_2_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_2_loop_L1):
> - sub $64, %rdx
> - movaps 0x0e(%rsi), %xmm2
> - movaps 0x1e(%rsi), %xmm3
> - movaps 0x2e(%rsi), %xmm4
> - movaps 0x3e(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $2, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $2, %xmm3, %xmm4
> - palignr $2, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $2, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_2_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_2_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_2_bwd):
> - lea (L(shl_2_bwd_loop_L1)-L(shl_2_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x02(%rsi), %xmm1
> - jb L(L2_bwd)
> - lea (L(shl_2_bwd_loop_L2)-L(shl_2_bwd_loop_L1))(%r9), %r9
> -L(L2_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_2_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_2_bwd_loop_L1):
> - movaps -0x12(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x22(%rsi), %xmm3
> - movaps -0x32(%rsi), %xmm4
> - movaps -0x42(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $2, %xmm2, %xmm1
> - palignr $2, %xmm3, %xmm2
> - palignr $2, %xmm4, %xmm3
> - palignr $2, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_2_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_2_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_3):
> - lea (L(shl_3_loop_L1)-L(shl_3))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x03(%rsi), %xmm1
> - jb L(L3_fwd)
> - lea (L(shl_3_loop_L2)-L(shl_3_loop_L1))(%r9), %r9
> -L(L3_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_3_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_3_loop_L1):
> - sub $64, %rdx
> - movaps 0x0d(%rsi), %xmm2
> - movaps 0x1d(%rsi), %xmm3
> - movaps 0x2d(%rsi), %xmm4
> - movaps 0x3d(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $3, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $3, %xmm3, %xmm4
> - palignr $3, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $3, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_3_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_3_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_3_bwd):
> - lea (L(shl_3_bwd_loop_L1)-L(shl_3_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x03(%rsi), %xmm1
> - jb L(L3_bwd)
> - lea (L(shl_3_bwd_loop_L2)-L(shl_3_bwd_loop_L1))(%r9), %r9
> -L(L3_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_3_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_3_bwd_loop_L1):
> - movaps -0x13(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x23(%rsi), %xmm3
> - movaps -0x33(%rsi), %xmm4
> - movaps -0x43(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $3, %xmm2, %xmm1
> - palignr $3, %xmm3, %xmm2
> - palignr $3, %xmm4, %xmm3
> - palignr $3, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_3_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_3_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_4):
> - lea (L(shl_4_loop_L1)-L(shl_4))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x04(%rsi), %xmm1
> - jb L(L4_fwd)
> - lea (L(shl_4_loop_L2)-L(shl_4_loop_L1))(%r9), %r9
> -L(L4_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_4_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_4_loop_L1):
> - sub $64, %rdx
> - movaps 0x0c(%rsi), %xmm2
> - movaps 0x1c(%rsi), %xmm3
> - movaps 0x2c(%rsi), %xmm4
> - movaps 0x3c(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $4, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $4, %xmm3, %xmm4
> - palignr $4, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $4, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_4_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_4_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_4_bwd):
> - lea (L(shl_4_bwd_loop_L1)-L(shl_4_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x04(%rsi), %xmm1
> - jb L(L4_bwd)
> - lea (L(shl_4_bwd_loop_L2)-L(shl_4_bwd_loop_L1))(%r9), %r9
> -L(L4_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_4_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_4_bwd_loop_L1):
> - movaps -0x14(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x24(%rsi), %xmm3
> - movaps -0x34(%rsi), %xmm4
> - movaps -0x44(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $4, %xmm2, %xmm1
> - palignr $4, %xmm3, %xmm2
> - palignr $4, %xmm4, %xmm3
> - palignr $4, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_4_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_4_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_5):
> - lea (L(shl_5_loop_L1)-L(shl_5))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x05(%rsi), %xmm1
> - jb L(L5_fwd)
> - lea (L(shl_5_loop_L2)-L(shl_5_loop_L1))(%r9), %r9
> -L(L5_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_5_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_5_loop_L1):
> - sub $64, %rdx
> - movaps 0x0b(%rsi), %xmm2
> - movaps 0x1b(%rsi), %xmm3
> - movaps 0x2b(%rsi), %xmm4
> - movaps 0x3b(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $5, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $5, %xmm3, %xmm4
> - palignr $5, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $5, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_5_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_5_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_5_bwd):
> - lea (L(shl_5_bwd_loop_L1)-L(shl_5_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x05(%rsi), %xmm1
> - jb L(L5_bwd)
> - lea (L(shl_5_bwd_loop_L2)-L(shl_5_bwd_loop_L1))(%r9), %r9
> -L(L5_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_5_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_5_bwd_loop_L1):
> - movaps -0x15(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x25(%rsi), %xmm3
> - movaps -0x35(%rsi), %xmm4
> - movaps -0x45(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $5, %xmm2, %xmm1
> - palignr $5, %xmm3, %xmm2
> - palignr $5, %xmm4, %xmm3
> - palignr $5, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_5_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_5_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_6):
> - lea (L(shl_6_loop_L1)-L(shl_6))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x06(%rsi), %xmm1
> - jb L(L6_fwd)
> - lea (L(shl_6_loop_L2)-L(shl_6_loop_L1))(%r9), %r9
> -L(L6_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_6_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_6_loop_L1):
> - sub $64, %rdx
> - movaps 0x0a(%rsi), %xmm2
> - movaps 0x1a(%rsi), %xmm3
> - movaps 0x2a(%rsi), %xmm4
> - movaps 0x3a(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $6, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $6, %xmm3, %xmm4
> - palignr $6, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $6, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_6_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_6_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_6_bwd):
> - lea (L(shl_6_bwd_loop_L1)-L(shl_6_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x06(%rsi), %xmm1
> - jb L(L6_bwd)
> - lea (L(shl_6_bwd_loop_L2)-L(shl_6_bwd_loop_L1))(%r9), %r9
> -L(L6_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_6_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_6_bwd_loop_L1):
> - movaps -0x16(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x26(%rsi), %xmm3
> - movaps -0x36(%rsi), %xmm4
> - movaps -0x46(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $6, %xmm2, %xmm1
> - palignr $6, %xmm3, %xmm2
> - palignr $6, %xmm4, %xmm3
> - palignr $6, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_6_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_6_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_7):
> - lea (L(shl_7_loop_L1)-L(shl_7))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x07(%rsi), %xmm1
> - jb L(L7_fwd)
> - lea (L(shl_7_loop_L2)-L(shl_7_loop_L1))(%r9), %r9
> -L(L7_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_7_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_7_loop_L1):
> - sub $64, %rdx
> - movaps 0x09(%rsi), %xmm2
> - movaps 0x19(%rsi), %xmm3
> - movaps 0x29(%rsi), %xmm4
> - movaps 0x39(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $7, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $7, %xmm3, %xmm4
> - palignr $7, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $7, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_7_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_7_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_7_bwd):
> - lea (L(shl_7_bwd_loop_L1)-L(shl_7_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x07(%rsi), %xmm1
> - jb L(L7_bwd)
> - lea (L(shl_7_bwd_loop_L2)-L(shl_7_bwd_loop_L1))(%r9), %r9
> -L(L7_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_7_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_7_bwd_loop_L1):
> - movaps -0x17(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x27(%rsi), %xmm3
> - movaps -0x37(%rsi), %xmm4
> - movaps -0x47(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $7, %xmm2, %xmm1
> - palignr $7, %xmm3, %xmm2
> - palignr $7, %xmm4, %xmm3
> - palignr $7, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_7_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_7_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_8):
> - lea (L(shl_8_loop_L1)-L(shl_8))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x08(%rsi), %xmm1
> - jb L(L8_fwd)
> - lea (L(shl_8_loop_L2)-L(shl_8_loop_L1))(%r9), %r9
> -L(L8_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> -L(shl_8_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_8_loop_L1):
> - sub $64, %rdx
> - movaps 0x08(%rsi), %xmm2
> - movaps 0x18(%rsi), %xmm3
> - movaps 0x28(%rsi), %xmm4
> - movaps 0x38(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $8, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $8, %xmm3, %xmm4
> - palignr $8, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $8, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_8_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> - .p2align 4
> -L(shl_8_end):
> - lea 64(%rdx), %rdx
> - movaps %xmm4, -0x20(%rdi)
> - add %rdx, %rsi
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_8_bwd):
> - lea (L(shl_8_bwd_loop_L1)-L(shl_8_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x08(%rsi), %xmm1
> - jb L(L8_bwd)
> - lea (L(shl_8_bwd_loop_L2)-L(shl_8_bwd_loop_L1))(%r9), %r9
> -L(L8_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_8_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_8_bwd_loop_L1):
> - movaps -0x18(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x28(%rsi), %xmm3
> - movaps -0x38(%rsi), %xmm4
> - movaps -0x48(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $8, %xmm2, %xmm1
> - palignr $8, %xmm3, %xmm2
> - palignr $8, %xmm4, %xmm3
> - palignr $8, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_8_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_8_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_9):
> - lea (L(shl_9_loop_L1)-L(shl_9))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x09(%rsi), %xmm1
> - jb L(L9_fwd)
> - lea (L(shl_9_loop_L2)-L(shl_9_loop_L1))(%r9), %r9
> -L(L9_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_9_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_9_loop_L1):
> - sub $64, %rdx
> - movaps 0x07(%rsi), %xmm2
> - movaps 0x17(%rsi), %xmm3
> - movaps 0x27(%rsi), %xmm4
> - movaps 0x37(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $9, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $9, %xmm3, %xmm4
> - palignr $9, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $9, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_9_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_9_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_9_bwd):
> - lea (L(shl_9_bwd_loop_L1)-L(shl_9_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x09(%rsi), %xmm1
> - jb L(L9_bwd)
> - lea (L(shl_9_bwd_loop_L2)-L(shl_9_bwd_loop_L1))(%r9), %r9
> -L(L9_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_9_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_9_bwd_loop_L1):
> - movaps -0x19(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x29(%rsi), %xmm3
> - movaps -0x39(%rsi), %xmm4
> - movaps -0x49(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $9, %xmm2, %xmm1
> - palignr $9, %xmm3, %xmm2
> - palignr $9, %xmm4, %xmm3
> - palignr $9, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_9_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_9_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_10):
> - lea (L(shl_10_loop_L1)-L(shl_10))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0a(%rsi), %xmm1
> - jb L(L10_fwd)
> - lea (L(shl_10_loop_L2)-L(shl_10_loop_L1))(%r9), %r9
> -L(L10_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_10_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_10_loop_L1):
> - sub $64, %rdx
> - movaps 0x06(%rsi), %xmm2
> - movaps 0x16(%rsi), %xmm3
> - movaps 0x26(%rsi), %xmm4
> - movaps 0x36(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $10, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $10, %xmm3, %xmm4
> - palignr $10, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $10, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_10_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_10_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_10_bwd):
> - lea (L(shl_10_bwd_loop_L1)-L(shl_10_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0a(%rsi), %xmm1
> - jb L(L10_bwd)
> - lea (L(shl_10_bwd_loop_L2)-L(shl_10_bwd_loop_L1))(%r9), %r9
> -L(L10_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_10_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_10_bwd_loop_L1):
> - movaps -0x1a(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x2a(%rsi), %xmm3
> - movaps -0x3a(%rsi), %xmm4
> - movaps -0x4a(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $10, %xmm2, %xmm1
> - palignr $10, %xmm3, %xmm2
> - palignr $10, %xmm4, %xmm3
> - palignr $10, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_10_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_10_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_11):
> - lea (L(shl_11_loop_L1)-L(shl_11))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0b(%rsi), %xmm1
> - jb L(L11_fwd)
> - lea (L(shl_11_loop_L2)-L(shl_11_loop_L1))(%r9), %r9
> -L(L11_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_11_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_11_loop_L1):
> - sub $64, %rdx
> - movaps 0x05(%rsi), %xmm2
> - movaps 0x15(%rsi), %xmm3
> - movaps 0x25(%rsi), %xmm4
> - movaps 0x35(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $11, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $11, %xmm3, %xmm4
> - palignr $11, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $11, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_11_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_11_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_11_bwd):
> - lea (L(shl_11_bwd_loop_L1)-L(shl_11_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0b(%rsi), %xmm1
> - jb L(L11_bwd)
> - lea (L(shl_11_bwd_loop_L2)-L(shl_11_bwd_loop_L1))(%r9), %r9
> -L(L11_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_11_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_11_bwd_loop_L1):
> - movaps -0x1b(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x2b(%rsi), %xmm3
> - movaps -0x3b(%rsi), %xmm4
> - movaps -0x4b(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $11, %xmm2, %xmm1
> - palignr $11, %xmm3, %xmm2
> - palignr $11, %xmm4, %xmm3
> - palignr $11, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_11_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_11_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_12):
> - lea (L(shl_12_loop_L1)-L(shl_12))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0c(%rsi), %xmm1
> - jb L(L12_fwd)
> - lea (L(shl_12_loop_L2)-L(shl_12_loop_L1))(%r9), %r9
> -L(L12_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_12_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_12_loop_L1):
> - sub $64, %rdx
> - movaps 0x04(%rsi), %xmm2
> - movaps 0x14(%rsi), %xmm3
> - movaps 0x24(%rsi), %xmm4
> - movaps 0x34(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $12, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $12, %xmm3, %xmm4
> - palignr $12, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $12, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_12_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_12_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_12_bwd):
> - lea (L(shl_12_bwd_loop_L1)-L(shl_12_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0c(%rsi), %xmm1
> - jb L(L12_bwd)
> - lea (L(shl_12_bwd_loop_L2)-L(shl_12_bwd_loop_L1))(%r9), %r9
> -L(L12_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_12_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_12_bwd_loop_L1):
> - movaps -0x1c(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x2c(%rsi), %xmm3
> - movaps -0x3c(%rsi), %xmm4
> - movaps -0x4c(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $12, %xmm2, %xmm1
> - palignr $12, %xmm3, %xmm2
> - palignr $12, %xmm4, %xmm3
> - palignr $12, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_12_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_12_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_13):
> - lea (L(shl_13_loop_L1)-L(shl_13))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0d(%rsi), %xmm1
> - jb L(L13_fwd)
> - lea (L(shl_13_loop_L2)-L(shl_13_loop_L1))(%r9), %r9
> -L(L13_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_13_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_13_loop_L1):
> - sub $64, %rdx
> - movaps 0x03(%rsi), %xmm2
> - movaps 0x13(%rsi), %xmm3
> - movaps 0x23(%rsi), %xmm4
> - movaps 0x33(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $13, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $13, %xmm3, %xmm4
> - palignr $13, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $13, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_13_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_13_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_13_bwd):
> - lea (L(shl_13_bwd_loop_L1)-L(shl_13_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0d(%rsi), %xmm1
> - jb L(L13_bwd)
> - lea (L(shl_13_bwd_loop_L2)-L(shl_13_bwd_loop_L1))(%r9), %r9
> -L(L13_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_13_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_13_bwd_loop_L1):
> - movaps -0x1d(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x2d(%rsi), %xmm3
> - movaps -0x3d(%rsi), %xmm4
> - movaps -0x4d(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $13, %xmm2, %xmm1
> - palignr $13, %xmm3, %xmm2
> - palignr $13, %xmm4, %xmm3
> - palignr $13, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_13_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_13_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_14):
> - lea (L(shl_14_loop_L1)-L(shl_14))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0e(%rsi), %xmm1
> - jb L(L14_fwd)
> - lea (L(shl_14_loop_L2)-L(shl_14_loop_L1))(%r9), %r9
> -L(L14_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_14_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_14_loop_L1):
> - sub $64, %rdx
> - movaps 0x02(%rsi), %xmm2
> - movaps 0x12(%rsi), %xmm3
> - movaps 0x22(%rsi), %xmm4
> - movaps 0x32(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $14, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $14, %xmm3, %xmm4
> - palignr $14, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $14, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_14_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_14_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_14_bwd):
> - lea (L(shl_14_bwd_loop_L1)-L(shl_14_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0e(%rsi), %xmm1
> - jb L(L14_bwd)
> - lea (L(shl_14_bwd_loop_L2)-L(shl_14_bwd_loop_L1))(%r9), %r9
> -L(L14_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_14_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_14_bwd_loop_L1):
> - movaps -0x1e(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x2e(%rsi), %xmm3
> - movaps -0x3e(%rsi), %xmm4
> - movaps -0x4e(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $14, %xmm2, %xmm1
> - palignr $14, %xmm3, %xmm2
> - palignr $14, %xmm4, %xmm3
> - palignr $14, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_14_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_14_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_15):
> - lea (L(shl_15_loop_L1)-L(shl_15))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0f(%rsi), %xmm1
> - jb L(L15_fwd)
> - lea (L(shl_15_loop_L2)-L(shl_15_loop_L1))(%r9), %r9
> -L(L15_fwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_15_loop_L2):
> - prefetchnta 0x1c0(%rsi)
> -L(shl_15_loop_L1):
> - sub $64, %rdx
> - movaps 0x01(%rsi), %xmm2
> - movaps 0x11(%rsi), %xmm3
> - movaps 0x21(%rsi), %xmm4
> - movaps 0x31(%rsi), %xmm5
> - movdqa %xmm5, %xmm6
> - palignr $15, %xmm4, %xmm5
> - lea 64(%rsi), %rsi
> - palignr $15, %xmm3, %xmm4
> - palignr $15, %xmm2, %xmm3
> - lea 64(%rdi), %rdi
> - palignr $15, %xmm1, %xmm2
> - movdqa %xmm6, %xmm1
> - movdqa %xmm2, -0x40(%rdi)
> - movaps %xmm3, -0x30(%rdi)
> - jb L(shl_15_end)
> - movaps %xmm4, -0x20(%rdi)
> - movaps %xmm5, -0x10(%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_15_end):
> - movaps %xmm4, -0x20(%rdi)
> - lea 64(%rdx), %rdx
> - movaps %xmm5, -0x10(%rdi)
> - add %rdx, %rdi
> - movdqu %xmm0, (%r8)
> - add %rdx, %rsi
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(shl_15_bwd):
> - lea (L(shl_15_bwd_loop_L1)-L(shl_15_bwd))(%r9), %r9
> - cmp %rcx, %rdx
> - movaps -0x0f(%rsi), %xmm1
> - jb L(L15_bwd)
> - lea (L(shl_15_bwd_loop_L2)-L(shl_15_bwd_loop_L1))(%r9), %r9
> -L(L15_bwd):
> - lea -64(%rdx), %rdx
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_15_bwd_loop_L2):
> - prefetchnta -0x1c0(%rsi)
> -L(shl_15_bwd_loop_L1):
> - movaps -0x1f(%rsi), %xmm2
> - sub $0x40, %rdx
> - movaps -0x2f(%rsi), %xmm3
> - movaps -0x3f(%rsi), %xmm4
> - movaps -0x4f(%rsi), %xmm5
> - lea -0x40(%rsi), %rsi
> - palignr $15, %xmm2, %xmm1
> - palignr $15, %xmm3, %xmm2
> - palignr $15, %xmm4, %xmm3
> - palignr $15, %xmm5, %xmm4
> -
> - movaps %xmm1, -0x10(%rdi)
> - movaps %xmm5, %xmm1
> -
> - movaps %xmm2, -0x20(%rdi)
> - lea -0x40(%rdi), %rdi
> -
> - movaps %xmm3, 0x10(%rdi)
> - jb L(shl_15_bwd_end)
> - movaps %xmm4, (%rdi)
> - _CET_NOTRACK jmp *%r9
> - ud2
> -L(shl_15_bwd_end):
> - movaps %xmm4, (%rdi)
> - lea 64(%rdx), %rdx
> - movdqu %xmm0, (%r8)
> - BRANCH_TO_JMPTBL_ENTRY(L(table_less_80bytes), %rdx, 4)
> -
> - .p2align 4
> -L(write_72bytes):
> - movdqu -72(%rsi), %xmm0
> - movdqu -56(%rsi), %xmm1
> - mov -40(%rsi), %r8
> - mov -32(%rsi), %r9
> - mov -24(%rsi), %r10
> - mov -16(%rsi), %r11
> - mov -8(%rsi), %rcx
> - movdqu %xmm0, -72(%rdi)
> - movdqu %xmm1, -56(%rdi)
> - mov %r8, -40(%rdi)
> - mov %r9, -32(%rdi)
> - mov %r10, -24(%rdi)
> - mov %r11, -16(%rdi)
> - mov %rcx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_64bytes):
> - movdqu -64(%rsi), %xmm0
> - mov -48(%rsi), %rcx
> - mov -40(%rsi), %r8
> - mov -32(%rsi), %r9
> - mov -24(%rsi), %r10
> - mov -16(%rsi), %r11
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -64(%rdi)
> - mov %rcx, -48(%rdi)
> - mov %r8, -40(%rdi)
> - mov %r9, -32(%rdi)
> - mov %r10, -24(%rdi)
> - mov %r11, -16(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_56bytes):
> - movdqu -56(%rsi), %xmm0
> - mov -40(%rsi), %r8
> - mov -32(%rsi), %r9
> - mov -24(%rsi), %r10
> - mov -16(%rsi), %r11
> - mov -8(%rsi), %rcx
> - movdqu %xmm0, -56(%rdi)
> - mov %r8, -40(%rdi)
> - mov %r9, -32(%rdi)
> - mov %r10, -24(%rdi)
> - mov %r11, -16(%rdi)
> - mov %rcx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_48bytes):
> - mov -48(%rsi), %rcx
> - mov -40(%rsi), %r8
> - mov -32(%rsi), %r9
> - mov -24(%rsi), %r10
> - mov -16(%rsi), %r11
> - mov -8(%rsi), %rdx
> - mov %rcx, -48(%rdi)
> - mov %r8, -40(%rdi)
> - mov %r9, -32(%rdi)
> - mov %r10, -24(%rdi)
> - mov %r11, -16(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_40bytes):
> - mov -40(%rsi), %r8
> - mov -32(%rsi), %r9
> - mov -24(%rsi), %r10
> - mov -16(%rsi), %r11
> - mov -8(%rsi), %rdx
> - mov %r8, -40(%rdi)
> - mov %r9, -32(%rdi)
> - mov %r10, -24(%rdi)
> - mov %r11, -16(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_32bytes):
> - mov -32(%rsi), %r9
> - mov -24(%rsi), %r10
> - mov -16(%rsi), %r11
> - mov -8(%rsi), %rdx
> - mov %r9, -32(%rdi)
> - mov %r10, -24(%rdi)
> - mov %r11, -16(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_24bytes):
> - mov -24(%rsi), %r10
> - mov -16(%rsi), %r11
> - mov -8(%rsi), %rdx
> - mov %r10, -24(%rdi)
> - mov %r11, -16(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_16bytes):
> - mov -16(%rsi), %r11
> - mov -8(%rsi), %rdx
> - mov %r11, -16(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_8bytes):
> - mov -8(%rsi), %rdx
> - mov %rdx, -8(%rdi)
> -L(write_0bytes):
> - ret
> -
> - .p2align 4
> -L(write_73bytes):
> - movdqu -73(%rsi), %xmm0
> - movdqu -57(%rsi), %xmm1
> - mov -41(%rsi), %rcx
> - mov -33(%rsi), %r9
> - mov -25(%rsi), %r10
> - mov -17(%rsi), %r11
> - mov -9(%rsi), %r8
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -73(%rdi)
> - movdqu %xmm1, -57(%rdi)
> - mov %rcx, -41(%rdi)
> - mov %r9, -33(%rdi)
> - mov %r10, -25(%rdi)
> - mov %r11, -17(%rdi)
> - mov %r8, -9(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_65bytes):
> - movdqu -65(%rsi), %xmm0
> - movdqu -49(%rsi), %xmm1
> - mov -33(%rsi), %r9
> - mov -25(%rsi), %r10
> - mov -17(%rsi), %r11
> - mov -9(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -65(%rdi)
> - movdqu %xmm1, -49(%rdi)
> - mov %r9, -33(%rdi)
> - mov %r10, -25(%rdi)
> - mov %r11, -17(%rdi)
> - mov %rcx, -9(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_57bytes):
> - movdqu -57(%rsi), %xmm0
> - mov -41(%rsi), %r8
> - mov -33(%rsi), %r9
> - mov -25(%rsi), %r10
> - mov -17(%rsi), %r11
> - mov -9(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -57(%rdi)
> - mov %r8, -41(%rdi)
> - mov %r9, -33(%rdi)
> - mov %r10, -25(%rdi)
> - mov %r11, -17(%rdi)
> - mov %rcx, -9(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_49bytes):
> - movdqu -49(%rsi), %xmm0
> - mov -33(%rsi), %r9
> - mov -25(%rsi), %r10
> - mov -17(%rsi), %r11
> - mov -9(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -49(%rdi)
> - mov %r9, -33(%rdi)
> - mov %r10, -25(%rdi)
> - mov %r11, -17(%rdi)
> - mov %rcx, -9(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_41bytes):
> - mov -41(%rsi), %r8
> - mov -33(%rsi), %r9
> - mov -25(%rsi), %r10
> - mov -17(%rsi), %r11
> - mov -9(%rsi), %rcx
> - mov -1(%rsi), %dl
> - mov %r8, -41(%rdi)
> - mov %r9, -33(%rdi)
> - mov %r10, -25(%rdi)
> - mov %r11, -17(%rdi)
> - mov %rcx, -9(%rdi)
> - mov %dl, -1(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_33bytes):
> - mov -33(%rsi), %r9
> - mov -25(%rsi), %r10
> - mov -17(%rsi), %r11
> - mov -9(%rsi), %rcx
> - mov -1(%rsi), %dl
> - mov %r9, -33(%rdi)
> - mov %r10, -25(%rdi)
> - mov %r11, -17(%rdi)
> - mov %rcx, -9(%rdi)
> - mov %dl, -1(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_25bytes):
> - mov -25(%rsi), %r10
> - mov -17(%rsi), %r11
> - mov -9(%rsi), %rcx
> - mov -1(%rsi), %dl
> - mov %r10, -25(%rdi)
> - mov %r11, -17(%rdi)
> - mov %rcx, -9(%rdi)
> - mov %dl, -1(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_17bytes):
> - mov -17(%rsi), %r11
> - mov -9(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r11, -17(%rdi)
> - mov %rcx, -9(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_9bytes):
> - mov -9(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %rcx, -9(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_1bytes):
> - mov -1(%rsi), %dl
> - mov %dl, -1(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_74bytes):
> - movdqu -74(%rsi), %xmm0
> - movdqu -58(%rsi), %xmm1
> - mov -42(%rsi), %r8
> - mov -34(%rsi), %r9
> - mov -26(%rsi), %r10
> - mov -18(%rsi), %r11
> - mov -10(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -74(%rdi)
> - movdqu %xmm1, -58(%rdi)
> - mov %r8, -42(%rdi)
> - mov %r9, -34(%rdi)
> - mov %r10, -26(%rdi)
> - mov %r11, -18(%rdi)
> - mov %rcx, -10(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_66bytes):
> - movdqu -66(%rsi), %xmm0
> - movdqu -50(%rsi), %xmm1
> - mov -42(%rsi), %r8
> - mov -34(%rsi), %r9
> - mov -26(%rsi), %r10
> - mov -18(%rsi), %r11
> - mov -10(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -66(%rdi)
> - movdqu %xmm1, -50(%rdi)
> - mov %r8, -42(%rdi)
> - mov %r9, -34(%rdi)
> - mov %r10, -26(%rdi)
> - mov %r11, -18(%rdi)
> - mov %rcx, -10(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_58bytes):
> - movdqu -58(%rsi), %xmm1
> - mov -42(%rsi), %r8
> - mov -34(%rsi), %r9
> - mov -26(%rsi), %r10
> - mov -18(%rsi), %r11
> - mov -10(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm1, -58(%rdi)
> - mov %r8, -42(%rdi)
> - mov %r9, -34(%rdi)
> - mov %r10, -26(%rdi)
> - mov %r11, -18(%rdi)
> - mov %rcx, -10(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_50bytes):
> - movdqu -50(%rsi), %xmm0
> - mov -34(%rsi), %r9
> - mov -26(%rsi), %r10
> - mov -18(%rsi), %r11
> - mov -10(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -50(%rdi)
> - mov %r9, -34(%rdi)
> - mov %r10, -26(%rdi)
> - mov %r11, -18(%rdi)
> - mov %rcx, -10(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_42bytes):
> - mov -42(%rsi), %r8
> - mov -34(%rsi), %r9
> - mov -26(%rsi), %r10
> - mov -18(%rsi), %r11
> - mov -10(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r8, -42(%rdi)
> - mov %r9, -34(%rdi)
> - mov %r10, -26(%rdi)
> - mov %r11, -18(%rdi)
> - mov %rcx, -10(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_34bytes):
> - mov -34(%rsi), %r9
> - mov -26(%rsi), %r10
> - mov -18(%rsi), %r11
> - mov -10(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r9, -34(%rdi)
> - mov %r10, -26(%rdi)
> - mov %r11, -18(%rdi)
> - mov %rcx, -10(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_26bytes):
> - mov -26(%rsi), %r10
> - mov -18(%rsi), %r11
> - mov -10(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r10, -26(%rdi)
> - mov %r11, -18(%rdi)
> - mov %rcx, -10(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_18bytes):
> - mov -18(%rsi), %r11
> - mov -10(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r11, -18(%rdi)
> - mov %rcx, -10(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_10bytes):
> - mov -10(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %rcx, -10(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_2bytes):
> - mov -2(%rsi), %dx
> - mov %dx, -2(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_75bytes):
> - movdqu -75(%rsi), %xmm0
> - movdqu -59(%rsi), %xmm1
> - mov -43(%rsi), %r8
> - mov -35(%rsi), %r9
> - mov -27(%rsi), %r10
> - mov -19(%rsi), %r11
> - mov -11(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -75(%rdi)
> - movdqu %xmm1, -59(%rdi)
> - mov %r8, -43(%rdi)
> - mov %r9, -35(%rdi)
> - mov %r10, -27(%rdi)
> - mov %r11, -19(%rdi)
> - mov %rcx, -11(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_67bytes):
> - movdqu -67(%rsi), %xmm0
> - movdqu -59(%rsi), %xmm1
> - mov -43(%rsi), %r8
> - mov -35(%rsi), %r9
> - mov -27(%rsi), %r10
> - mov -19(%rsi), %r11
> - mov -11(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -67(%rdi)
> - movdqu %xmm1, -59(%rdi)
> - mov %r8, -43(%rdi)
> - mov %r9, -35(%rdi)
> - mov %r10, -27(%rdi)
> - mov %r11, -19(%rdi)
> - mov %rcx, -11(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_59bytes):
> - movdqu -59(%rsi), %xmm0
> - mov -43(%rsi), %r8
> - mov -35(%rsi), %r9
> - mov -27(%rsi), %r10
> - mov -19(%rsi), %r11
> - mov -11(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -59(%rdi)
> - mov %r8, -43(%rdi)
> - mov %r9, -35(%rdi)
> - mov %r10, -27(%rdi)
> - mov %r11, -19(%rdi)
> - mov %rcx, -11(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_51bytes):
> - movdqu -51(%rsi), %xmm0
> - mov -35(%rsi), %r9
> - mov -27(%rsi), %r10
> - mov -19(%rsi), %r11
> - mov -11(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -51(%rdi)
> - mov %r9, -35(%rdi)
> - mov %r10, -27(%rdi)
> - mov %r11, -19(%rdi)
> - mov %rcx, -11(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_43bytes):
> - mov -43(%rsi), %r8
> - mov -35(%rsi), %r9
> - mov -27(%rsi), %r10
> - mov -19(%rsi), %r11
> - mov -11(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r8, -43(%rdi)
> - mov %r9, -35(%rdi)
> - mov %r10, -27(%rdi)
> - mov %r11, -19(%rdi)
> - mov %rcx, -11(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_35bytes):
> - mov -35(%rsi), %r9
> - mov -27(%rsi), %r10
> - mov -19(%rsi), %r11
> - mov -11(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r9, -35(%rdi)
> - mov %r10, -27(%rdi)
> - mov %r11, -19(%rdi)
> - mov %rcx, -11(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_27bytes):
> - mov -27(%rsi), %r10
> - mov -19(%rsi), %r11
> - mov -11(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r10, -27(%rdi)
> - mov %r11, -19(%rdi)
> - mov %rcx, -11(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_19bytes):
> - mov -19(%rsi), %r11
> - mov -11(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r11, -19(%rdi)
> - mov %rcx, -11(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_11bytes):
> - mov -11(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %rcx, -11(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_3bytes):
> - mov -3(%rsi), %dx
> - mov -2(%rsi), %cx
> - mov %dx, -3(%rdi)
> - mov %cx, -2(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_76bytes):
> - movdqu -76(%rsi), %xmm0
> - movdqu -60(%rsi), %xmm1
> - mov -44(%rsi), %r8
> - mov -36(%rsi), %r9
> - mov -28(%rsi), %r10
> - mov -20(%rsi), %r11
> - mov -12(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -76(%rdi)
> - movdqu %xmm1, -60(%rdi)
> - mov %r8, -44(%rdi)
> - mov %r9, -36(%rdi)
> - mov %r10, -28(%rdi)
> - mov %r11, -20(%rdi)
> - mov %rcx, -12(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_68bytes):
> - movdqu -68(%rsi), %xmm0
> - movdqu -52(%rsi), %xmm1
> - mov -36(%rsi), %r9
> - mov -28(%rsi), %r10
> - mov -20(%rsi), %r11
> - mov -12(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -68(%rdi)
> - movdqu %xmm1, -52(%rdi)
> - mov %r9, -36(%rdi)
> - mov %r10, -28(%rdi)
> - mov %r11, -20(%rdi)
> - mov %rcx, -12(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_60bytes):
> - movdqu -60(%rsi), %xmm0
> - mov -44(%rsi), %r8
> - mov -36(%rsi), %r9
> - mov -28(%rsi), %r10
> - mov -20(%rsi), %r11
> - mov -12(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -60(%rdi)
> - mov %r8, -44(%rdi)
> - mov %r9, -36(%rdi)
> - mov %r10, -28(%rdi)
> - mov %r11, -20(%rdi)
> - mov %rcx, -12(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_52bytes):
> - movdqu -52(%rsi), %xmm0
> - mov -36(%rsi), %r9
> - mov -28(%rsi), %r10
> - mov -20(%rsi), %r11
> - mov -12(%rsi), %rcx
> - mov -4(%rsi), %edx
> - movdqu %xmm0, -52(%rdi)
> - mov %r9, -36(%rdi)
> - mov %r10, -28(%rdi)
> - mov %r11, -20(%rdi)
> - mov %rcx, -12(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_44bytes):
> - mov -44(%rsi), %r8
> - mov -36(%rsi), %r9
> - mov -28(%rsi), %r10
> - mov -20(%rsi), %r11
> - mov -12(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r8, -44(%rdi)
> - mov %r9, -36(%rdi)
> - mov %r10, -28(%rdi)
> - mov %r11, -20(%rdi)
> - mov %rcx, -12(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_36bytes):
> - mov -36(%rsi), %r9
> - mov -28(%rsi), %r10
> - mov -20(%rsi), %r11
> - mov -12(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r9, -36(%rdi)
> - mov %r10, -28(%rdi)
> - mov %r11, -20(%rdi)
> - mov %rcx, -12(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_28bytes):
> - mov -28(%rsi), %r10
> - mov -20(%rsi), %r11
> - mov -12(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r10, -28(%rdi)
> - mov %r11, -20(%rdi)
> - mov %rcx, -12(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_20bytes):
> - mov -20(%rsi), %r11
> - mov -12(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %r11, -20(%rdi)
> - mov %rcx, -12(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_12bytes):
> - mov -12(%rsi), %rcx
> - mov -4(%rsi), %edx
> - mov %rcx, -12(%rdi)
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_4bytes):
> - mov -4(%rsi), %edx
> - mov %edx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_77bytes):
> - movdqu -77(%rsi), %xmm0
> - movdqu -61(%rsi), %xmm1
> - mov -45(%rsi), %r8
> - mov -37(%rsi), %r9
> - mov -29(%rsi), %r10
> - mov -21(%rsi), %r11
> - mov -13(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -77(%rdi)
> - movdqu %xmm1, -61(%rdi)
> - mov %r8, -45(%rdi)
> - mov %r9, -37(%rdi)
> - mov %r10, -29(%rdi)
> - mov %r11, -21(%rdi)
> - mov %rcx, -13(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_69bytes):
> - movdqu -69(%rsi), %xmm0
> - movdqu -53(%rsi), %xmm1
> - mov -37(%rsi), %r9
> - mov -29(%rsi), %r10
> - mov -21(%rsi), %r11
> - mov -13(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -69(%rdi)
> - movdqu %xmm1, -53(%rdi)
> - mov %r9, -37(%rdi)
> - mov %r10, -29(%rdi)
> - mov %r11, -21(%rdi)
> - mov %rcx, -13(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_61bytes):
> - movdqu -61(%rsi), %xmm0
> - mov -45(%rsi), %r8
> - mov -37(%rsi), %r9
> - mov -29(%rsi), %r10
> - mov -21(%rsi), %r11
> - mov -13(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -61(%rdi)
> - mov %r8, -45(%rdi)
> - mov %r9, -37(%rdi)
> - mov %r10, -29(%rdi)
> - mov %r11, -21(%rdi)
> - mov %rcx, -13(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_53bytes):
> - movdqu -53(%rsi), %xmm0
> - mov -45(%rsi), %r8
> - mov -37(%rsi), %r9
> - mov -29(%rsi), %r10
> - mov -21(%rsi), %r11
> - mov -13(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -53(%rdi)
> - mov %r9, -37(%rdi)
> - mov %r10, -29(%rdi)
> - mov %r11, -21(%rdi)
> - mov %rcx, -13(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_45bytes):
> - mov -45(%rsi), %r8
> - mov -37(%rsi), %r9
> - mov -29(%rsi), %r10
> - mov -21(%rsi), %r11
> - mov -13(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r8, -45(%rdi)
> - mov %r9, -37(%rdi)
> - mov %r10, -29(%rdi)
> - mov %r11, -21(%rdi)
> - mov %rcx, -13(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_37bytes):
> - mov -37(%rsi), %r9
> - mov -29(%rsi), %r10
> - mov -21(%rsi), %r11
> - mov -13(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r9, -37(%rdi)
> - mov %r10, -29(%rdi)
> - mov %r11, -21(%rdi)
> - mov %rcx, -13(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_29bytes):
> - mov -29(%rsi), %r10
> - mov -21(%rsi), %r11
> - mov -13(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r10, -29(%rdi)
> - mov %r11, -21(%rdi)
> - mov %rcx, -13(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_21bytes):
> - mov -21(%rsi), %r11
> - mov -13(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r11, -21(%rdi)
> - mov %rcx, -13(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_13bytes):
> - mov -13(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %rcx, -13(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_5bytes):
> - mov -5(%rsi), %edx
> - mov -4(%rsi), %ecx
> - mov %edx, -5(%rdi)
> - mov %ecx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_78bytes):
> - movdqu -78(%rsi), %xmm0
> - movdqu -62(%rsi), %xmm1
> - mov -46(%rsi), %r8
> - mov -38(%rsi), %r9
> - mov -30(%rsi), %r10
> - mov -22(%rsi), %r11
> - mov -14(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -78(%rdi)
> - movdqu %xmm1, -62(%rdi)
> - mov %r8, -46(%rdi)
> - mov %r9, -38(%rdi)
> - mov %r10, -30(%rdi)
> - mov %r11, -22(%rdi)
> - mov %rcx, -14(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_70bytes):
> - movdqu -70(%rsi), %xmm0
> - movdqu -54(%rsi), %xmm1
> - mov -38(%rsi), %r9
> - mov -30(%rsi), %r10
> - mov -22(%rsi), %r11
> - mov -14(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -70(%rdi)
> - movdqu %xmm1, -54(%rdi)
> - mov %r9, -38(%rdi)
> - mov %r10, -30(%rdi)
> - mov %r11, -22(%rdi)
> - mov %rcx, -14(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_62bytes):
> - movdqu -62(%rsi), %xmm0
> - mov -46(%rsi), %r8
> - mov -38(%rsi), %r9
> - mov -30(%rsi), %r10
> - mov -22(%rsi), %r11
> - mov -14(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -62(%rdi)
> - mov %r8, -46(%rdi)
> - mov %r9, -38(%rdi)
> - mov %r10, -30(%rdi)
> - mov %r11, -22(%rdi)
> - mov %rcx, -14(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_54bytes):
> - movdqu -54(%rsi), %xmm0
> - mov -38(%rsi), %r9
> - mov -30(%rsi), %r10
> - mov -22(%rsi), %r11
> - mov -14(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -54(%rdi)
> - mov %r9, -38(%rdi)
> - mov %r10, -30(%rdi)
> - mov %r11, -22(%rdi)
> - mov %rcx, -14(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_46bytes):
> - mov -46(%rsi), %r8
> - mov -38(%rsi), %r9
> - mov -30(%rsi), %r10
> - mov -22(%rsi), %r11
> - mov -14(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r8, -46(%rdi)
> - mov %r9, -38(%rdi)
> - mov %r10, -30(%rdi)
> - mov %r11, -22(%rdi)
> - mov %rcx, -14(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_38bytes):
> - mov -38(%rsi), %r9
> - mov -30(%rsi), %r10
> - mov -22(%rsi), %r11
> - mov -14(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r9, -38(%rdi)
> - mov %r10, -30(%rdi)
> - mov %r11, -22(%rdi)
> - mov %rcx, -14(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_30bytes):
> - mov -30(%rsi), %r10
> - mov -22(%rsi), %r11
> - mov -14(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r10, -30(%rdi)
> - mov %r11, -22(%rdi)
> - mov %rcx, -14(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_22bytes):
> - mov -22(%rsi), %r11
> - mov -14(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r11, -22(%rdi)
> - mov %rcx, -14(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_14bytes):
> - mov -14(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %rcx, -14(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_6bytes):
> - mov -6(%rsi), %edx
> - mov -4(%rsi), %ecx
> - mov %edx, -6(%rdi)
> - mov %ecx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_79bytes):
> - movdqu -79(%rsi), %xmm0
> - movdqu -63(%rsi), %xmm1
> - mov -47(%rsi), %r8
> - mov -39(%rsi), %r9
> - mov -31(%rsi), %r10
> - mov -23(%rsi), %r11
> - mov -15(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -79(%rdi)
> - movdqu %xmm1, -63(%rdi)
> - mov %r8, -47(%rdi)
> - mov %r9, -39(%rdi)
> - mov %r10, -31(%rdi)
> - mov %r11, -23(%rdi)
> - mov %rcx, -15(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_71bytes):
> - movdqu -71(%rsi), %xmm0
> - movdqu -55(%rsi), %xmm1
> - mov -39(%rsi), %r9
> - mov -31(%rsi), %r10
> - mov -23(%rsi), %r11
> - mov -15(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -71(%rdi)
> - movdqu %xmm1, -55(%rdi)
> - mov %r9, -39(%rdi)
> - mov %r10, -31(%rdi)
> - mov %r11, -23(%rdi)
> - mov %rcx, -15(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_63bytes):
> - movdqu -63(%rsi), %xmm0
> - mov -47(%rsi), %r8
> - mov -39(%rsi), %r9
> - mov -31(%rsi), %r10
> - mov -23(%rsi), %r11
> - mov -15(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -63(%rdi)
> - mov %r8, -47(%rdi)
> - mov %r9, -39(%rdi)
> - mov %r10, -31(%rdi)
> - mov %r11, -23(%rdi)
> - mov %rcx, -15(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_55bytes):
> - movdqu -55(%rsi), %xmm0
> - mov -39(%rsi), %r9
> - mov -31(%rsi), %r10
> - mov -23(%rsi), %r11
> - mov -15(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - movdqu %xmm0, -55(%rdi)
> - mov %r9, -39(%rdi)
> - mov %r10, -31(%rdi)
> - mov %r11, -23(%rdi)
> - mov %rcx, -15(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_47bytes):
> - mov -47(%rsi), %r8
> - mov -39(%rsi), %r9
> - mov -31(%rsi), %r10
> - mov -23(%rsi), %r11
> - mov -15(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r8, -47(%rdi)
> - mov %r9, -39(%rdi)
> - mov %r10, -31(%rdi)
> - mov %r11, -23(%rdi)
> - mov %rcx, -15(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_39bytes):
> - mov -39(%rsi), %r9
> - mov -31(%rsi), %r10
> - mov -23(%rsi), %r11
> - mov -15(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r9, -39(%rdi)
> - mov %r10, -31(%rdi)
> - mov %r11, -23(%rdi)
> - mov %rcx, -15(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_31bytes):
> - mov -31(%rsi), %r10
> - mov -23(%rsi), %r11
> - mov -15(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r10, -31(%rdi)
> - mov %r11, -23(%rdi)
> - mov %rcx, -15(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_23bytes):
> - mov -23(%rsi), %r11
> - mov -15(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %r11, -23(%rdi)
> - mov %rcx, -15(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_15bytes):
> - mov -15(%rsi), %rcx
> - mov -8(%rsi), %rdx
> - mov %rcx, -15(%rdi)
> - mov %rdx, -8(%rdi)
> - ret
> -
> - .p2align 4
> -L(write_7bytes):
> - mov -7(%rsi), %edx
> - mov -4(%rsi), %ecx
> - mov %edx, -7(%rdi)
> - mov %ecx, -4(%rdi)
> - ret
> -
> - .p2align 4
> -L(large_page_fwd):
> - movdqu (%rsi), %xmm1
> - lea 16(%rsi), %rsi
> - movdqu %xmm0, (%r8)
> - movntdq %xmm1, (%rdi)
> - lea 16(%rdi), %rdi
> - lea -0x90(%rdx), %rdx
> -#ifdef USE_AS_MEMMOVE
> - mov %rsi, %r9
> - sub %rdi, %r9
> - cmp %rdx, %r9
> - jae L(memmove_is_memcpy_fwd)
> - shl $2, %rcx
> - cmp %rcx, %rdx
> - jb L(ll_cache_copy_fwd_start)
> -L(memmove_is_memcpy_fwd):
> -#endif
> -L(large_page_loop):
> - movdqu (%rsi), %xmm0
> - movdqu 0x10(%rsi), %xmm1
> - movdqu 0x20(%rsi), %xmm2
> - movdqu 0x30(%rsi), %xmm3
> - movdqu 0x40(%rsi), %xmm4
> - movdqu 0x50(%rsi), %xmm5
> - movdqu 0x60(%rsi), %xmm6
> - movdqu 0x70(%rsi), %xmm7
> - lea 0x80(%rsi), %rsi
> -
> - sub $0x80, %rdx
> - movntdq %xmm0, (%rdi)
> - movntdq %xmm1, 0x10(%rdi)
> - movntdq %xmm2, 0x20(%rdi)
> - movntdq %xmm3, 0x30(%rdi)
> - movntdq %xmm4, 0x40(%rdi)
> - movntdq %xmm5, 0x50(%rdi)
> - movntdq %xmm6, 0x60(%rdi)
> - movntdq %xmm7, 0x70(%rdi)
> - lea 0x80(%rdi), %rdi
> - jae L(large_page_loop)
> - cmp $-0x40, %rdx
> - lea 0x80(%rdx), %rdx
> - jl L(large_page_less_64bytes)
> -
> - movdqu (%rsi), %xmm0
> - movdqu 0x10(%rsi), %xmm1
> - movdqu 0x20(%rsi), %xmm2
> - movdqu 0x30(%rsi), %xmm3
> - lea 0x40(%rsi), %rsi
> -
> - movntdq %xmm0, (%rdi)
> - movntdq %xmm1, 0x10(%rdi)
> - movntdq %xmm2, 0x20(%rdi)
> - movntdq %xmm3, 0x30(%rdi)
> - lea 0x40(%rdi), %rdi
> - sub $0x40, %rdx
> -L(large_page_less_64bytes):
> - add %rdx, %rsi
> - add %rdx, %rdi
> - sfence
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -
> -#ifdef USE_AS_MEMMOVE
> - .p2align 4
> -L(ll_cache_copy_fwd_start):
> - prefetcht0 0x1c0(%rsi)
> - prefetcht0 0x200(%rsi)
> - movdqu (%rsi), %xmm0
> - movdqu 0x10(%rsi), %xmm1
> - movdqu 0x20(%rsi), %xmm2
> - movdqu 0x30(%rsi), %xmm3
> - movdqu 0x40(%rsi), %xmm4
> - movdqu 0x50(%rsi), %xmm5
> - movdqu 0x60(%rsi), %xmm6
> - movdqu 0x70(%rsi), %xmm7
> - lea 0x80(%rsi), %rsi
> -
> - sub $0x80, %rdx
> - movaps %xmm0, (%rdi)
> - movaps %xmm1, 0x10(%rdi)
> - movaps %xmm2, 0x20(%rdi)
> - movaps %xmm3, 0x30(%rdi)
> - movaps %xmm4, 0x40(%rdi)
> - movaps %xmm5, 0x50(%rdi)
> - movaps %xmm6, 0x60(%rdi)
> - movaps %xmm7, 0x70(%rdi)
> - lea 0x80(%rdi), %rdi
> - jae L(ll_cache_copy_fwd_start)
> - cmp $-0x40, %rdx
> - lea 0x80(%rdx), %rdx
> - jl L(large_page_ll_less_fwd_64bytes)
> -
> - movdqu (%rsi), %xmm0
> - movdqu 0x10(%rsi), %xmm1
> - movdqu 0x20(%rsi), %xmm2
> - movdqu 0x30(%rsi), %xmm3
> - lea 0x40(%rsi), %rsi
> -
> - movaps %xmm0, (%rdi)
> - movaps %xmm1, 0x10(%rdi)
> - movaps %xmm2, 0x20(%rdi)
> - movaps %xmm3, 0x30(%rdi)
> - lea 0x40(%rdi), %rdi
> - sub $0x40, %rdx
> -L(large_page_ll_less_fwd_64bytes):
> - add %rdx, %rsi
> - add %rdx, %rdi
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -
> -#endif
> - .p2align 4
> -L(large_page_bwd):
> - movdqu -0x10(%rsi), %xmm1
> - lea -16(%rsi), %rsi
> - movdqu %xmm0, (%r8)
> - movdqa %xmm1, -0x10(%rdi)
> - lea -16(%rdi), %rdi
> - lea -0x90(%rdx), %rdx
> -#ifdef USE_AS_MEMMOVE
> - mov %rdi, %r9
> - sub %rsi, %r9
> - cmp %rdx, %r9
> - jae L(memmove_is_memcpy_bwd)
> - cmp %rcx, %r9
> - jb L(ll_cache_copy_bwd_start)
> -L(memmove_is_memcpy_bwd):
> -#endif
> -L(large_page_bwd_loop):
> - movdqu -0x10(%rsi), %xmm0
> - movdqu -0x20(%rsi), %xmm1
> - movdqu -0x30(%rsi), %xmm2
> - movdqu -0x40(%rsi), %xmm3
> - movdqu -0x50(%rsi), %xmm4
> - movdqu -0x60(%rsi), %xmm5
> - movdqu -0x70(%rsi), %xmm6
> - movdqu -0x80(%rsi), %xmm7
> - lea -0x80(%rsi), %rsi
> -
> - sub $0x80, %rdx
> - movntdq %xmm0, -0x10(%rdi)
> - movntdq %xmm1, -0x20(%rdi)
> - movntdq %xmm2, -0x30(%rdi)
> - movntdq %xmm3, -0x40(%rdi)
> - movntdq %xmm4, -0x50(%rdi)
> - movntdq %xmm5, -0x60(%rdi)
> - movntdq %xmm6, -0x70(%rdi)
> - movntdq %xmm7, -0x80(%rdi)
> - lea -0x80(%rdi), %rdi
> - jae L(large_page_bwd_loop)
> - cmp $-0x40, %rdx
> - lea 0x80(%rdx), %rdx
> - jl L(large_page_less_bwd_64bytes)
> -
> - movdqu -0x10(%rsi), %xmm0
> - movdqu -0x20(%rsi), %xmm1
> - movdqu -0x30(%rsi), %xmm2
> - movdqu -0x40(%rsi), %xmm3
> - lea -0x40(%rsi), %rsi
> -
> - movntdq %xmm0, -0x10(%rdi)
> - movntdq %xmm1, -0x20(%rdi)
> - movntdq %xmm2, -0x30(%rdi)
> - movntdq %xmm3, -0x40(%rdi)
> - lea -0x40(%rdi), %rdi
> - sub $0x40, %rdx
> -L(large_page_less_bwd_64bytes):
> - sfence
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -
> -#ifdef USE_AS_MEMMOVE
> - .p2align 4
> -L(ll_cache_copy_bwd_start):
> - prefetcht0 -0x1c0(%rsi)
> - prefetcht0 -0x200(%rsi)
> - movdqu -0x10(%rsi), %xmm0
> - movdqu -0x20(%rsi), %xmm1
> - movdqu -0x30(%rsi), %xmm2
> - movdqu -0x40(%rsi), %xmm3
> - movdqu -0x50(%rsi), %xmm4
> - movdqu -0x60(%rsi), %xmm5
> - movdqu -0x70(%rsi), %xmm6
> - movdqu -0x80(%rsi), %xmm7
> - lea -0x80(%rsi), %rsi
> -
> - sub $0x80, %rdx
> - movaps %xmm0, -0x10(%rdi)
> - movaps %xmm1, -0x20(%rdi)
> - movaps %xmm2, -0x30(%rdi)
> - movaps %xmm3, -0x40(%rdi)
> - movaps %xmm4, -0x50(%rdi)
> - movaps %xmm5, -0x60(%rdi)
> - movaps %xmm6, -0x70(%rdi)
> - movaps %xmm7, -0x80(%rdi)
> - lea -0x80(%rdi), %rdi
> - jae L(ll_cache_copy_bwd_start)
> - cmp $-0x40, %rdx
> - lea 0x80(%rdx), %rdx
> - jl L(large_page_ll_less_bwd_64bytes)
> -
> - movdqu -0x10(%rsi), %xmm0
> - movdqu -0x20(%rsi), %xmm1
> - movdqu -0x30(%rsi), %xmm2
> - movdqu -0x40(%rsi), %xmm3
> - lea -0x40(%rsi), %rsi
> -
> - movaps %xmm0, -0x10(%rdi)
> - movaps %xmm1, -0x20(%rdi)
> - movaps %xmm2, -0x30(%rdi)
> - movaps %xmm3, -0x40(%rdi)
> - lea -0x40(%rdi), %rdi
> - sub $0x40, %rdx
> -L(large_page_ll_less_bwd_64bytes):
> - BRANCH_TO_JMPTBL_ENTRY (L(table_less_80bytes), %rdx, 4)
> -#endif
> -
> -END (MEMCPY)
> -
> - .section .rodata.ssse3,"a",@progbits
> - .p2align 3
> -L(table_less_80bytes):
> - .int JMPTBL (L(write_0bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_1bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_2bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_3bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_4bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_5bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_6bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_7bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_8bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_9bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_10bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_11bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_12bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_13bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_14bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_15bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_16bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_17bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_18bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_19bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_20bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_21bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_22bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_23bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_24bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_25bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_26bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_27bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_28bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_29bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_30bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_31bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_32bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_33bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_34bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_35bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_36bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_37bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_38bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_39bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_40bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_41bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_42bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_43bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_44bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_45bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_46bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_47bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_48bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_49bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_50bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_51bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_52bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_53bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_54bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_55bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_56bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_57bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_58bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_59bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_60bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_61bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_62bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_63bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_64bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_65bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_66bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_67bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_68bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_69bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_70bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_71bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_72bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_73bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_74bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_75bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_76bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_77bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_78bytes), L(table_less_80bytes))
> - .int JMPTBL (L(write_79bytes), L(table_less_80bytes))
> -
> - .p2align 3
> -L(shl_table):
> - .int JMPTBL (L(shl_0), L(shl_table))
> - .int JMPTBL (L(shl_1), L(shl_table))
> - .int JMPTBL (L(shl_2), L(shl_table))
> - .int JMPTBL (L(shl_3), L(shl_table))
> - .int JMPTBL (L(shl_4), L(shl_table))
> - .int JMPTBL (L(shl_5), L(shl_table))
> - .int JMPTBL (L(shl_6), L(shl_table))
> - .int JMPTBL (L(shl_7), L(shl_table))
> - .int JMPTBL (L(shl_8), L(shl_table))
> - .int JMPTBL (L(shl_9), L(shl_table))
> - .int JMPTBL (L(shl_10), L(shl_table))
> - .int JMPTBL (L(shl_11), L(shl_table))
> - .int JMPTBL (L(shl_12), L(shl_table))
> - .int JMPTBL (L(shl_13), L(shl_table))
> - .int JMPTBL (L(shl_14), L(shl_table))
> - .int JMPTBL (L(shl_15), L(shl_table))
> -
> - .p2align 3
> -L(shl_table_bwd):
> - .int JMPTBL (L(shl_0_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_1_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_2_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_3_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_4_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_5_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_6_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_7_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_8_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_9_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_10_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_11_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_12_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_13_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_14_bwd), L(shl_table_bwd))
> - .int JMPTBL (L(shl_15_bwd), L(shl_table_bwd))
> -
> -#endif
> diff --git a/sysdeps/x86_64/multiarch/memmove-ssse3.S b/sysdeps/x86_64/multiarch/memmove-ssse3.S
> index 295430b1ef..215583e7bd 100644
> --- a/sysdeps/x86_64/multiarch/memmove-ssse3.S
> +++ b/sysdeps/x86_64/multiarch/memmove-ssse3.S
> @@ -1,4 +1,380 @@
> -#define USE_AS_MEMMOVE
> -#define MEMCPY __memmove_ssse3
> -#define MEMCPY_CHK __memmove_chk_ssse3
> -#include "memcpy-ssse3.S"
> +#include <sysdep.h>
> +
> +#ifndef MEMMOVE
> +# define MEMMOVE __memmove_ssse3
> +# define MEMMOVE_CHK __memmove_chk_ssse3
> +# define MEMCPY __memcpy_ssse3
> +# define MEMCPY_CHK __memcpy_chk_ssse3
> +# define MEMPCPY __mempcpy_ssse3
> +# define MEMPCPY_CHK __mempcpy_chk_ssse3
> +#endif
> +
> + .section .text.ssse3, "ax", @progbits
> +ENTRY(MEMPCPY_CHK)
> + cmp %RDX_LP, %RCX_LP
> + jb HIDDEN_JUMPTARGET(__chk_fail)
> +END(MEMPCPY_CHK)
> +
> +ENTRY(MEMPCPY)
> + mov %RDI_LP, %RAX_LP
> + add %RDX_LP, %RAX_LP
> + jmp L(start)
> +END(MEMPCPY)
> +
> +ENTRY(MEMMOVE_CHK)
> + cmp %RDX_LP, %RCX_LP
> + jb HIDDEN_JUMPTARGET(__chk_fail)
> +END(MEMMOVE_CHK)
> +
> +ENTRY_P2ALIGN(MEMMOVE, 6)
> + movq %rdi, %rax
> +L(start):
> + cmpq $16, %rdx
> + jb L(copy_0_15)
> +
> + /* These loads are always useful.  */
> + movups 0(%rsi), %xmm0
> + movups -16(%rsi, %rdx), %xmm7
> + cmpq $32, %rdx
> + ja L(more_2x_vec)
> +
> + movups %xmm0, 0(%rdi)
> + movups %xmm7, -16(%rdi, %rdx)
> + ret
> +
> + .p2align 4,, 4
> +L(copy_0_15):
> + cmpl $4, %edx
> + jb L(copy_0_3)
> + cmpl $8, %edx
> + jb L(copy_4_7)
> + movq 0(%rsi), %rcx
> + movq -8(%rsi, %rdx), %rsi
> + movq %rcx, 0(%rdi)
> + movq %rsi, -8(%rdi, %rdx)
> + ret
> +
> + .p2align 4,, 4
> +L(copy_4_7):
> + movl 0(%rsi), %ecx
> + movl -4(%rsi, %rdx), %esi
> + movl %ecx, 0(%rdi)
> + movl %esi, -4(%rdi, %rdx)
> + ret
> +
> + .p2align 4,, 4
> +L(copy_0_3):
> + decl %edx
> + jl L(copy_0_0)
> + movb (%rsi), %cl
> + je L(copy_1_1)
> +
> + movzwl -1(%rsi, %rdx), %esi
> + movw %si, -1(%rdi, %rdx)
> +L(copy_1_1):
> + movb %cl, (%rdi)
> +L(copy_0_0):
> + ret
> +
> + .p2align 4,, 4
> +L(copy_4x_vec):
> + movups 16(%rsi), %xmm1
> + movups -32(%rsi, %rdx), %xmm2
> +
> + movups %xmm0, 0(%rdi)
> + movups %xmm1, 16(%rdi)
> + movups %xmm2, -32(%rdi, %rdx)
> + movups %xmm7, -16(%rdi, %rdx)
> +L(nop):
> + ret
> +
> + .p2align 4
> +L(more_2x_vec):
> + cmpq $64, %rdx
> + jbe L(copy_4x_vec)
> +
> + /* We use rcx later to get alignr value.  */
> + movq %rdi, %rcx
> +
> + /* Backward copy for overlap + dst > src for memmove safety.  */
> + subq %rsi, %rcx
> + cmpq %rdx, %rcx
> + jb L(copy_backward)
> +
> + /* Load tail.  */
> +
> + /* -16(%rsi, %rdx) already loaded into xmm7.  */
> + movups -32(%rsi, %rdx), %xmm8
> + movups -48(%rsi, %rdx), %xmm9
> +
> + /* Get misalignment.  */
> + andl $0xf, %ecx
> +
> + movq %rsi, %r9
> + addq %rcx, %rsi
> + andq $-16, %rsi
> + /* Get first vec for `palignr`.  */
> + movaps (%rsi), %xmm1
> +
> + /* We have loaded (%rsi) so safe to do this store before the
> +    loop.  */
> + movups %xmm0, (%rdi)
> +
> +#ifdef SHARED_CACHE_SIZE_HALF
> + cmp $SHARED_CACHE_SIZE_HALF, %RDX_LP
> +#else
> + cmp __x86_shared_cache_size_half(%rip), %rdx
> +#endif
> + ja L(large_memcpy)
> +
> + leaq -64(%rdi, %rdx), %r8
> + andq $-16, %rdi
> + movl $48, %edx
> +
> + leaq L(loop_fwd_start)(%rip), %r9
> + sall $6, %ecx
> + addq %r9, %rcx
> + jmp * %rcx
> +
> + .p2align 4,, 8
> +L(copy_backward):
> + testq %rcx, %rcx
> + jz L(nop)
> +
> + /* Preload tail.  */
> +
> + /* (%rsi) already loaded into xmm0.  */
> + movups 16(%rsi), %xmm4
> + movups 32(%rsi), %xmm5
> +
> + movq %rdi, %r8
> + subq %rdi, %rsi
> + leaq -49(%rdi, %rdx), %rdi
> + andq $-16, %rdi
> + addq %rdi, %rsi
> + andq $-16, %rsi
> +
> + movaps 48(%rsi), %xmm6
> +
> +
> + leaq L(loop_bkwd_start)(%rip), %r9
> + andl $0xf, %ecx
> + sall $6, %ecx
> + addq %r9, %rcx
> + jmp * %rcx
> +
> + .p2align 4,, 8
> +L(large_memcpy):
> + movups -64(%r9, %rdx), %xmm10
> + movups -80(%r9, %rdx), %xmm11
> +
> + sall $5, %ecx
> + leal (%rcx, %rcx, 2), %r8d
> + leaq -96(%rdi, %rdx), %rcx
> + andq $-16, %rdi
> + leaq L(large_loop_fwd_start)(%rip), %rdx
> + addq %r8, %rdx
> + jmp * %rdx
> +
> +
> + /* Instead of a typical jump table all 16 loops are exactly
> +    64-bytes in size. So, we can just jump to first loop + r8 *
> +    64. Before modifying any loop ensure all their sizes match!
> + */
> + .p2align 6
> +L(loop_fwd_start):
> +L(loop_fwd_0x0):
> + movaps 16(%rsi), %xmm1
> + movaps 32(%rsi), %xmm2
> + movaps 48(%rsi), %xmm3
> + movaps %xmm1, 16(%rdi)
> + movaps %xmm2, 32(%rdi)
> + movaps %xmm3, 48(%rdi)
> + addq %rdx, %rdi
> + addq %rdx, %rsi
> + cmpq %rdi, %r8
> + ja L(loop_fwd_0x0)
> +L(end_loop_fwd):
> + movups %xmm9, 16(%r8)
> + movups %xmm8, 32(%r8)
> + movups %xmm7, 48(%r8)
> + ret
> +
> + /* Extactly 64 bytes if `jmp L(end_loop_fwd)` is long encoding.
> +    60 bytes otherwise.  */
> +#define ALIGNED_LOOP_FWD(align_by); \
> + .p2align 6; \
> +L(loop_fwd_ ## align_by): \
> + movaps 16(%rsi), %xmm0; \
> + movaps 32(%rsi), %xmm2; \
> + movaps 48(%rsi), %xmm3; \
> + movaps %xmm3, %xmm4; \
> + palignr $align_by, %xmm2, %xmm3; \
> + palignr $align_by, %xmm0, %xmm2; \
> + palignr $align_by, %xmm1, %xmm0; \
> + movaps %xmm4, %xmm1; \
> + movaps %xmm0, 16(%rdi); \
> + movaps %xmm2, 32(%rdi); \
> + movaps %xmm3, 48(%rdi); \
> + addq %rdx, %rdi; \
> + addq %rdx, %rsi; \
> + cmpq %rdi, %r8; \
> + ja L(loop_fwd_ ## align_by); \
> + jmp L(end_loop_fwd);
> +
> + /* Must be in descending order.  */
> + ALIGNED_LOOP_FWD (0xf)
> + ALIGNED_LOOP_FWD (0xe)
> + ALIGNED_LOOP_FWD (0xd)
> + ALIGNED_LOOP_FWD (0xc)
> + ALIGNED_LOOP_FWD (0xb)
> + ALIGNED_LOOP_FWD (0xa)
> + ALIGNED_LOOP_FWD (0x9)
> + ALIGNED_LOOP_FWD (0x8)
> + ALIGNED_LOOP_FWD (0x7)
> + ALIGNED_LOOP_FWD (0x6)
> + ALIGNED_LOOP_FWD (0x5)
> + ALIGNED_LOOP_FWD (0x4)
> + ALIGNED_LOOP_FWD (0x3)
> + ALIGNED_LOOP_FWD (0x2)
> + ALIGNED_LOOP_FWD (0x1)
> +
> + .p2align 6
> +L(large_loop_fwd_start):
> +L(large_loop_fwd_0x0):
> + movaps 16(%rsi), %xmm1
> + movaps 32(%rsi), %xmm2
> + movaps 48(%rsi), %xmm3
> + movaps 64(%rsi), %xmm4
> + movaps 80(%rsi), %xmm5
> + movntps %xmm1, 16(%rdi)
> + movntps %xmm2, 32(%rdi)
> + movntps %xmm3, 48(%rdi)
> + movntps %xmm4, 64(%rdi)
> + movntps %xmm5, 80(%rdi)
> + addq $80, %rdi
> + addq $80, %rsi
> + cmpq %rdi, %rcx
> + ja L(large_loop_fwd_0x0)
> +
> + /* Ensure no icache line split on tail.  */
> + .p2align 4
> +L(end_large_loop_fwd):
> + sfence
> + movups %xmm11, 16(%rcx)
> + movups %xmm10, 32(%rcx)
> + movups %xmm9, 48(%rcx)
> + movups %xmm8, 64(%rcx)
> + movups %xmm7, 80(%rcx)
> + ret
> +
> +
> + /* Size > 64 bytes and <= 96 bytes. 32-byte align between ensure
> +    96-byte spacing between each.  */
> +#define ALIGNED_LARGE_LOOP_FWD(align_by); \
> + .p2align 5; \
> +L(large_loop_fwd_ ## align_by): \
> + movaps 16(%rsi), %xmm0; \
> + movaps 32(%rsi), %xmm2; \
> + movaps 48(%rsi), %xmm3; \
> + movaps 64(%rsi), %xmm4; \
> + movaps 80(%rsi), %xmm5; \
> + movaps %xmm5, %xmm6; \
> + palignr $align_by, %xmm4, %xmm5; \
> + palignr $align_by, %xmm3, %xmm4; \
> + palignr $align_by, %xmm2, %xmm3; \
> + palignr $align_by, %xmm0, %xmm2; \
> + palignr $align_by, %xmm1, %xmm0; \
> + movaps %xmm6, %xmm1; \
> + movntps %xmm0, 16(%rdi); \
> + movntps %xmm2, 32(%rdi); \
> + movntps %xmm3, 48(%rdi); \
> + movntps %xmm4, 64(%rdi); \
> + movntps %xmm5, 80(%rdi); \
> + addq $80, %rdi; \
> + addq $80, %rsi; \
> + cmpq %rdi, %rcx; \
> + ja L(large_loop_fwd_ ## align_by); \
> + jmp L(end_large_loop_fwd);
> +
> + /* Must be in descending order.  */
> + ALIGNED_LARGE_LOOP_FWD (0xf)
> + ALIGNED_LARGE_LOOP_FWD (0xe)
> + ALIGNED_LARGE_LOOP_FWD (0xd)
> + ALIGNED_LARGE_LOOP_FWD (0xc)
> + ALIGNED_LARGE_LOOP_FWD (0xb)
> + ALIGNED_LARGE_LOOP_FWD (0xa)
> + ALIGNED_LARGE_LOOP_FWD (0x9)
> + ALIGNED_LARGE_LOOP_FWD (0x8)
> + ALIGNED_LARGE_LOOP_FWD (0x7)
> + ALIGNED_LARGE_LOOP_FWD (0x6)
> + ALIGNED_LARGE_LOOP_FWD (0x5)
> + ALIGNED_LARGE_LOOP_FWD (0x4)
> + ALIGNED_LARGE_LOOP_FWD (0x3)
> + ALIGNED_LARGE_LOOP_FWD (0x2)
> + ALIGNED_LARGE_LOOP_FWD (0x1)
> +
> +
> + .p2align 6
> +L(loop_bkwd_start):
> +L(loop_bkwd_0x0):
> + movaps 32(%rsi), %xmm1
> + movaps 16(%rsi), %xmm2
> + movaps 0(%rsi), %xmm3
> + movaps %xmm1, 32(%rdi)
> + movaps %xmm2, 16(%rdi)
> + movaps %xmm3, 0(%rdi)
> + subq $48, %rdi
> + subq $48, %rsi
> + cmpq %rdi, %r8
> + jb L(loop_bkwd_0x0)
> +L(end_loop_bkwd):
> + movups %xmm7, -16(%r8, %rdx)
> + movups %xmm0, 0(%r8)
> + movups %xmm4, 16(%r8)
> + movups %xmm5, 32(%r8)
> +
> + ret
> +
> +
> + /* Extactly 64 bytes if `jmp L(end_loop_bkwd)` is long encoding.
> +    60 bytes otherwise.  */
> +#define ALIGNED_LOOP_BKWD(align_by); \
> + .p2align 6; \
> +L(loop_bkwd_ ## align_by): \
> + movaps 32(%rsi), %xmm1; \
> + movaps 16(%rsi), %xmm2; \
> + movaps 0(%rsi), %xmm3; \
> + palignr $align_by, %xmm1, %xmm6; \
> + palignr $align_by, %xmm2, %xmm1; \
> + palignr $align_by, %xmm3, %xmm2; \
> + movaps %xmm6, 32(%rdi); \
> + movaps %xmm1, 16(%rdi); \
> + movaps %xmm2, 0(%rdi); \
> + subq $48, %rdi; \
> + subq $48, %rsi; \
> + movaps %xmm3, %xmm6; \
> + cmpq %rdi, %r8; \
> + jb L(loop_bkwd_ ## align_by); \
> + jmp L(end_loop_bkwd);
> +
> + /* Must be in descending order.  */
> + ALIGNED_LOOP_BKWD (0xf)
> + ALIGNED_LOOP_BKWD (0xe)
> + ALIGNED_LOOP_BKWD (0xd)
> + ALIGNED_LOOP_BKWD (0xc)
> + ALIGNED_LOOP_BKWD (0xb)
> + ALIGNED_LOOP_BKWD (0xa)
> + ALIGNED_LOOP_BKWD (0x9)
> + ALIGNED_LOOP_BKWD (0x8)
> + ALIGNED_LOOP_BKWD (0x7)
> + ALIGNED_LOOP_BKWD (0x6)
> + ALIGNED_LOOP_BKWD (0x5)
> + ALIGNED_LOOP_BKWD (0x4)
> + ALIGNED_LOOP_BKWD (0x3)
> + ALIGNED_LOOP_BKWD (0x2)
> + ALIGNED_LOOP_BKWD (0x1)
> +END(MEMMOVE)
> +
> +strong_alias (MEMMOVE, MEMCPY)
> +strong_alias (MEMMOVE_CHK, MEMCPY_CHK)
> --
> 2.25.1

This patch is okey for Zhaoxin platforms.

Thanks so much.

Best Regards,
May Shao


^ permalink raw reply	[flat|nested] 3+ messages in thread
* [PATCH v1 2/6] x86: Remove str{n}{case}cmp-ssse3
@ 2022-03-25 18:36 Noah Goldstein
  2022-04-14 16:47 ` [PATCH v5 1/6] x86: Remove {w}memcmp-ssse3 Noah Goldstein
  0 siblings, 1 reply; 3+ messages in thread
From: Noah Goldstein @ 2022-03-25 18:36 UTC (permalink / raw)
  To: libc-alpha

With SSE2, SSE4.1, AVX2, and EVEX versions very few targets prefer
SSSE3. As a result its no longer with the code size cost.
---
 sysdeps/x86_64/multiarch/Makefile             |   4 -
 sysdeps/x86_64/multiarch/ifunc-impl-list.c    |  16 --
 sysdeps/x86_64/multiarch/ifunc-strcasecmp.h   |   4 -
 sysdeps/x86_64/multiarch/strcasecmp_l-ssse3.S |   6 -
 sysdeps/x86_64/multiarch/strcmp-ssse3.S       |   5 -
 sysdeps/x86_64/multiarch/strcmp.c             |   4 -
 sysdeps/x86_64/multiarch/strncase_l-ssse3.S   |   6 -
 sysdeps/x86_64/multiarch/strncmp-ssse3.S      |  28 ----
 sysdeps/x86_64/multiarch/strncmp.c            |   4 -
 sysdeps/x86_64/strcmp.S                       | 155 ++++--------------
 10 files changed, 30 insertions(+), 202 deletions(-)
 delete mode 100644 sysdeps/x86_64/multiarch/strcasecmp_l-ssse3.S
 delete mode 100644 sysdeps/x86_64/multiarch/strcmp-ssse3.S
 delete mode 100644 sysdeps/x86_64/multiarch/strncase_l-ssse3.S
 delete mode 100644 sysdeps/x86_64/multiarch/strncmp-ssse3.S

diff --git a/sysdeps/x86_64/multiarch/Makefile b/sysdeps/x86_64/multiarch/Makefile
index 51222dfab1..ed2def288d 100644
--- a/sysdeps/x86_64/multiarch/Makefile
+++ b/sysdeps/x86_64/multiarch/Makefile
@@ -58,7 +58,6 @@ sysdep_routines += \
   strcasecmp_l-evex \
   strcasecmp_l-sse2 \
   strcasecmp_l-sse4_2 \
-  strcasecmp_l-ssse3 \
   strcat-avx2 \
   strcat-avx2-rtm \
   strcat-evex \
@@ -80,7 +79,6 @@ sysdep_routines += \
   strcmp-sse2 \
   strcmp-sse2-unaligned \
   strcmp-sse4_2 \
-  strcmp-ssse3 \
   strcpy-avx2 \
   strcpy-avx2-rtm \
   strcpy-evex \
@@ -98,7 +96,6 @@ sysdep_routines += \
   strncase_l-evex \
   strncase_l-sse2 \
   strncase_l-sse4_2 \
-  strncase_l-ssse3 \
   strncat-avx2 \
   strncat-avx2-rtm \
   strncat-c \
@@ -110,7 +107,6 @@ sysdep_routines += \
   strncmp-evex \
   strncmp-sse2 \
   strncmp-sse4_2 \
-  strncmp-ssse3 \
   strncpy-avx2 \
   strncpy-avx2-rtm \
   strncpy-c \
diff --git a/sysdeps/x86_64/multiarch/ifunc-impl-list.c b/sysdeps/x86_64/multiarch/ifunc-impl-list.c
index f389928a4e..7e2be3554b 100644
--- a/sysdeps/x86_64/multiarch/ifunc-impl-list.c
+++ b/sysdeps/x86_64/multiarch/ifunc-impl-list.c
@@ -448,9 +448,6 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array,
 	      IFUNC_IMPL_ADD (array, i, strcasecmp,
 			      CPU_FEATURE_USABLE (SSE4_2),
 			      __strcasecmp_sse42)
-	      IFUNC_IMPL_ADD (array, i, strcasecmp,
-			      CPU_FEATURE_USABLE (SSSE3),
-			      __strcasecmp_ssse3)
 	      IFUNC_IMPL_ADD (array, i, strcasecmp, 1, __strcasecmp_sse2))
 
   /* Support sysdeps/x86_64/multiarch/strcasecmp_l.c.  */
@@ -469,9 +466,6 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array,
 	      IFUNC_IMPL_ADD (array, i, strcasecmp_l,
 			      CPU_FEATURE_USABLE (SSE4_2),
 			      __strcasecmp_l_sse42)
-	      IFUNC_IMPL_ADD (array, i, strcasecmp_l,
-			      CPU_FEATURE_USABLE (SSSE3),
-			      __strcasecmp_l_ssse3)
 	      IFUNC_IMPL_ADD (array, i, strcasecmp_l, 1,
 			      __strcasecmp_l_sse2))
 
@@ -560,8 +554,6 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array,
 			      __strcmp_evex)
 	      IFUNC_IMPL_ADD (array, i, strcmp, CPU_FEATURE_USABLE (SSE4_2),
 			      __strcmp_sse42)
-	      IFUNC_IMPL_ADD (array, i, strcmp, CPU_FEATURE_USABLE (SSSE3),
-			      __strcmp_ssse3)
 	      IFUNC_IMPL_ADD (array, i, strcmp, 1, __strcmp_sse2_unaligned)
 	      IFUNC_IMPL_ADD (array, i, strcmp, 1, __strcmp_sse2))
 
@@ -604,9 +596,6 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array,
 	      IFUNC_IMPL_ADD (array, i, strncasecmp,
 			      CPU_FEATURE_USABLE (SSE4_2),
 			      __strncasecmp_sse42)
-	      IFUNC_IMPL_ADD (array, i, strncasecmp,
-			      CPU_FEATURE_USABLE (SSSE3),
-			      __strncasecmp_ssse3)
 	      IFUNC_IMPL_ADD (array, i, strncasecmp, 1,
 			      __strncasecmp_sse2))
 
@@ -626,9 +615,6 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array,
 	      IFUNC_IMPL_ADD (array, i, strncasecmp_l,
 			      CPU_FEATURE_USABLE (SSE4_2),
 			      __strncasecmp_l_sse42)
-	      IFUNC_IMPL_ADD (array, i, strncasecmp_l,
-			      CPU_FEATURE_USABLE (SSSE3),
-			      __strncasecmp_l_ssse3)
 	      IFUNC_IMPL_ADD (array, i, strncasecmp_l, 1,
 			      __strncasecmp_l_sse2))
 
@@ -1054,8 +1040,6 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array,
 			      __strncmp_evex)
 	      IFUNC_IMPL_ADD (array, i, strncmp, CPU_FEATURE_USABLE (SSE4_2),
 			      __strncmp_sse42)
-	      IFUNC_IMPL_ADD (array, i, strncmp, CPU_FEATURE_USABLE (SSSE3),
-			      __strncmp_ssse3)
 	      IFUNC_IMPL_ADD (array, i, strncmp, 1, __strncmp_sse2))
 
 #ifdef SHARED
diff --git a/sysdeps/x86_64/multiarch/ifunc-strcasecmp.h b/sysdeps/x86_64/multiarch/ifunc-strcasecmp.h
index 766539c241..296d32071b 100644
--- a/sysdeps/x86_64/multiarch/ifunc-strcasecmp.h
+++ b/sysdeps/x86_64/multiarch/ifunc-strcasecmp.h
@@ -20,7 +20,6 @@
 #include <init-arch.h>
 
 extern __typeof (REDIRECT_NAME) OPTIMIZE (sse2) attribute_hidden;
-extern __typeof (REDIRECT_NAME) OPTIMIZE (ssse3) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (sse42) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (avx2) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (avx2_rtm) attribute_hidden;
@@ -49,8 +48,5 @@ IFUNC_SELECTOR (void)
       && !CPU_FEATURES_ARCH_P (cpu_features, Slow_SSE4_2))
     return OPTIMIZE (sse42);
 
-  if (CPU_FEATURE_USABLE_P (cpu_features, SSSE3))
-    return OPTIMIZE (ssse3);
-
   return OPTIMIZE (sse2);
 }
diff --git a/sysdeps/x86_64/multiarch/strcasecmp_l-ssse3.S b/sysdeps/x86_64/multiarch/strcasecmp_l-ssse3.S
deleted file mode 100644
index fb2f9ae14a..0000000000
--- a/sysdeps/x86_64/multiarch/strcasecmp_l-ssse3.S
+++ /dev/null
@@ -1,6 +0,0 @@
-#define USE_SSSE3 1
-#define USE_AS_STRCASECMP_L
-#define NO_NOLOCALE_ALIAS
-#define STRCMP __strcasecmp_l_ssse3
-#define __strcasecmp __strcasecmp_ssse3
-#include "../strcmp.S"
diff --git a/sysdeps/x86_64/multiarch/strcmp-ssse3.S b/sysdeps/x86_64/multiarch/strcmp-ssse3.S
deleted file mode 100644
index 1b7fa33c91..0000000000
--- a/sysdeps/x86_64/multiarch/strcmp-ssse3.S
+++ /dev/null
@@ -1,5 +0,0 @@
-#if IS_IN (libc)
-# define USE_SSSE3 1
-# define STRCMP __strcmp_ssse3
-# include "../strcmp.S"
-#endif
diff --git a/sysdeps/x86_64/multiarch/strcmp.c b/sysdeps/x86_64/multiarch/strcmp.c
index 68cb73baad..a248c2a6e6 100644
--- a/sysdeps/x86_64/multiarch/strcmp.c
+++ b/sysdeps/x86_64/multiarch/strcmp.c
@@ -28,7 +28,6 @@
 
 extern __typeof (REDIRECT_NAME) OPTIMIZE (sse2) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (sse2_unaligned) attribute_hidden;
-extern __typeof (REDIRECT_NAME) OPTIMIZE (ssse3) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (avx2) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (avx2_rtm) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (evex) attribute_hidden;
@@ -56,9 +55,6 @@ IFUNC_SELECTOR (void)
   if (CPU_FEATURES_ARCH_P (cpu_features, Fast_Unaligned_Load))
     return OPTIMIZE (sse2_unaligned);
 
-  if (CPU_FEATURE_USABLE_P (cpu_features, SSSE3))
-    return OPTIMIZE (ssse3);
-
   return OPTIMIZE (sse2);
 }
 
diff --git a/sysdeps/x86_64/multiarch/strncase_l-ssse3.S b/sysdeps/x86_64/multiarch/strncase_l-ssse3.S
deleted file mode 100644
index 6728678688..0000000000
--- a/sysdeps/x86_64/multiarch/strncase_l-ssse3.S
+++ /dev/null
@@ -1,6 +0,0 @@
-#define USE_SSSE3 1
-#define USE_AS_STRNCASECMP_L
-#define NO_NOLOCALE_ALIAS
-#define STRCMP __strncasecmp_l_ssse3
-#define __strncasecmp __strncasecmp_ssse3
-#include "../strcmp.S"
diff --git a/sysdeps/x86_64/multiarch/strncmp-ssse3.S b/sysdeps/x86_64/multiarch/strncmp-ssse3.S
deleted file mode 100644
index ec37308347..0000000000
--- a/sysdeps/x86_64/multiarch/strncmp-ssse3.S
+++ /dev/null
@@ -1,28 +0,0 @@
-/* strcmp optimized with SSSE3.
-   Copyright (C) 2017-2022 Free Software Foundation, Inc.
-   This file is part of the GNU C Library.
-
-   The GNU C Library is free software; you can redistribute it and/or
-   modify it under the terms of the GNU Lesser General Public
-   License as published by the Free Software Foundation; either
-   version 2.1 of the License, or (at your option) any later version.
-
-   The GNU C Library is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-   Lesser General Public License for more details.
-
-   You should have received a copy of the GNU Lesser General Public
-   License along with the GNU C Library; if not, see
-   <https://www.gnu.org/licenses/>.  */
-
-#include <sysdep.h>
-
-#define STRCMP __strncmp_ssse3
-
-#undef libc_hidden_builtin_def
-#define libc_hidden_builtin_def(strcmp)
-
-#define USE_SSSE3 1
-#define USE_AS_STRNCMP
-#include <sysdeps/x86_64/strcmp.S>
diff --git a/sysdeps/x86_64/multiarch/strncmp.c b/sysdeps/x86_64/multiarch/strncmp.c
index fca74199d8..70ae6547c9 100644
--- a/sysdeps/x86_64/multiarch/strncmp.c
+++ b/sysdeps/x86_64/multiarch/strncmp.c
@@ -27,7 +27,6 @@
 # include <init-arch.h>
 
 extern __typeof (REDIRECT_NAME) OPTIMIZE (sse2) attribute_hidden;
-extern __typeof (REDIRECT_NAME) OPTIMIZE (ssse3) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (sse42) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (avx2) attribute_hidden;
 extern __typeof (REDIRECT_NAME) OPTIMIZE (avx2_rtm) attribute_hidden;
@@ -57,9 +56,6 @@ IFUNC_SELECTOR (void)
       && !CPU_FEATURES_ARCH_P (cpu_features, Slow_SSE4_2))
     return OPTIMIZE (sse42);
 
-  if (CPU_FEATURE_USABLE_P (cpu_features, SSSE3))
-    return OPTIMIZE (ssse3);
-
   return OPTIMIZE (sse2);
 }
 
diff --git a/sysdeps/x86_64/strcmp.S b/sysdeps/x86_64/strcmp.S
index 99d8b36f1d..c38dc627f9 100644
--- a/sysdeps/x86_64/strcmp.S
+++ b/sysdeps/x86_64/strcmp.S
@@ -59,12 +59,7 @@
 # endif
 #endif
 
-#ifndef USE_SSSE3
 	.text
-#else
-	.section .text.ssse3,"ax",@progbits
-#endif
-
 #ifdef USE_AS_STRCASECMP_L
 # ifndef ENTRY2
 #  define ENTRY2(name) ENTRY (name)
@@ -343,13 +338,10 @@ LABEL(gobble_ashr_1):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4		 /* store for next cycle */
 
-#ifndef USE_SSSE3
 	psrldq	$1, %xmm3
 	pslldq	$15, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$1, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -373,13 +365,10 @@ LABEL(gobble_ashr_1):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4		/* store for next cycle */
 
-#ifndef USE_SSSE3
 	psrldq	$1, %xmm3
 	pslldq	$15, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$1, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -473,13 +462,10 @@ LABEL(gobble_ashr_2):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$2, %xmm3
 	pslldq	$14, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$2, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -504,13 +490,10 @@ LABEL(gobble_ashr_2):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$2, %xmm3
 	pslldq	$14, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$2, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -598,13 +581,10 @@ LABEL(gobble_ashr_3):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$3, %xmm3
 	pslldq	$13, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$3, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -629,13 +609,10 @@ LABEL(gobble_ashr_3):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$3, %xmm3
 	pslldq	$13, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$3, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -723,13 +700,10 @@ LABEL(gobble_ashr_4):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$4, %xmm3
 	pslldq	$12, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$4, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -754,13 +728,10 @@ LABEL(gobble_ashr_4):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$4, %xmm3
 	pslldq	$12, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$4, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -848,13 +819,10 @@ LABEL(gobble_ashr_5):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$5, %xmm3
 	pslldq	$11, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$5, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -879,13 +847,10 @@ LABEL(gobble_ashr_5):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$5, %xmm3
 	pslldq	$11, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$5, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -973,13 +938,10 @@ LABEL(gobble_ashr_6):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$6, %xmm3
 	pslldq	$10, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$6, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1004,13 +966,10 @@ LABEL(gobble_ashr_6):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$6, %xmm3
 	pslldq	$10, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$6, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1098,13 +1057,10 @@ LABEL(gobble_ashr_7):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$7, %xmm3
 	pslldq	$9, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$7, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1129,13 +1085,10 @@ LABEL(gobble_ashr_7):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$7, %xmm3
 	pslldq	$9, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$7, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1223,13 +1176,10 @@ LABEL(gobble_ashr_8):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$8, %xmm3
 	pslldq	$8, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$8, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1254,13 +1204,10 @@ LABEL(gobble_ashr_8):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$8, %xmm3
 	pslldq	$8, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$8, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1348,13 +1295,10 @@ LABEL(gobble_ashr_9):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$9, %xmm3
 	pslldq	$7, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$9, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1379,13 +1323,10 @@ LABEL(gobble_ashr_9):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$9, %xmm3
 	pslldq	$7, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$9, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1473,13 +1414,10 @@ LABEL(gobble_ashr_10):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$10, %xmm3
 	pslldq	$6, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$10, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1504,13 +1442,10 @@ LABEL(gobble_ashr_10):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$10, %xmm3
 	pslldq	$6, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$10, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1598,13 +1533,10 @@ LABEL(gobble_ashr_11):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$11, %xmm3
 	pslldq	$5, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$11, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1629,13 +1561,10 @@ LABEL(gobble_ashr_11):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$11, %xmm3
 	pslldq	$5, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$11, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1723,13 +1652,10 @@ LABEL(gobble_ashr_12):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$12, %xmm3
 	pslldq	$4, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$12, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1754,13 +1680,10 @@ LABEL(gobble_ashr_12):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$12, %xmm3
 	pslldq	$4, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$12, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1848,13 +1771,10 @@ LABEL(gobble_ashr_13):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$13, %xmm3
 	pslldq	$3, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$13, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1879,13 +1799,10 @@ LABEL(gobble_ashr_13):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$13, %xmm3
 	pslldq	$3, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$13, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -1973,13 +1890,10 @@ LABEL(gobble_ashr_14):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$14, %xmm3
 	pslldq	$2, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$14, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -2004,13 +1918,10 @@ LABEL(gobble_ashr_14):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$14, %xmm3
 	pslldq	$2, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$14, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -2100,13 +2011,10 @@ LABEL(gobble_ashr_15):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$15, %xmm3
 	pslldq	$1, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$15, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
@@ -2131,13 +2039,10 @@ LABEL(gobble_ashr_15):
 	movdqa	(%rdi, %rcx), %xmm2
 	movdqa	%xmm2, %xmm4
 
-#ifndef USE_SSSE3
 	psrldq	$15, %xmm3
 	pslldq	$1, %xmm2
 	por	%xmm3, %xmm2		/* merge into one 16byte value */
-#else
-	palignr	$15, %xmm3, %xmm2	/* merge into one 16byte value */
-#endif
+
 	TOLOWER (%xmm1, %xmm2)
 
 	pcmpeqb	%xmm1, %xmm0
-- 
2.25.1


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2022-04-15  5:03 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-04-15  2:25 [PATCH v5 6/6] x86: Reduce code size of mem{move|pcpy|cpy}-ssse3 Mayshao-oc
2022-04-15  5:03 ` Noah Goldstein
  -- strict thread matches above, loose matches on Subject: below --
2022-03-25 18:36 [PATCH v1 2/6] x86: Remove str{n}{case}cmp-ssse3 Noah Goldstein
2022-04-14 16:47 ` [PATCH v5 1/6] x86: Remove {w}memcmp-ssse3 Noah Goldstein
2022-04-14 16:47   ` [PATCH v5 6/6] x86: Reduce code size of mem{move|pcpy|cpy}-ssse3 Noah Goldstein

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).