# Copyright 2017 Google Inc. # # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. # This file is generated semi-automatically with this command: # $ src/jumper/build_stages.py #if defined(__MACH__) #define HIDDEN .private_extern #define FUNCTION(name) #define BALIGN4 .align 2 #define BALIGN8 .align 3 #define BALIGN16 .align 4 #define BALIGN32 .align 5 #else .section .note.GNU-stack,"",%progbits #define HIDDEN .hidden #define FUNCTION(name) .type name,%function #define BALIGN4 .balign 4 #define BALIGN8 .balign 8 #define BALIGN16 .balign 16 #define BALIGN32 .balign 32 #endif .text #if defined(__aarch64__) BALIGN4 HIDDEN _sk_start_pipeline_aarch64 .globl _sk_start_pipeline_aarch64 FUNCTION(_sk_start_pipeline_aarch64) _sk_start_pipeline_aarch64: .long 0xa9ba6ffc // stp x28, x27, [sp, #-96]! .long 0xa90167fa // stp x26, x25, [sp, #16] .long 0xa9025ff8 // stp x24, x23, [sp, #32] .long 0xa90357f6 // stp x22, x21, [sp, #48] .long 0xa9044ff4 // stp x20, x19, [sp, #64] .long 0xa9057bfd // stp x29, x30, [sp, #80] .long 0xaa0403f4 // mov x20, x4 .long 0xf840869a // ldr x26, [x20], #8 .long 0xaa0303f5 // mov x21, x3 .long 0xaa0103f7 // mov x23, x1 .long 0xaa0503f3 // mov x19, x5 .long 0xaa0203f6 // mov x22, x2 .long 0xeb1502ff // cmp x23, x21 .long 0xaa0003f8 // mov x24, x0 .long 0x910143fd // add x29, sp, #0x50 .long 0x54000342 // b.cs a4 <_sk_start_pipeline_aarch64+0xa4> // b.hs, b.nlast .long 0x9100131b // add x27, x24, #0x4 .long 0xeb16037f // cmp x27, x22 .long 0xaa1803e2 // mov x2, x24 .long 0x540001a8 // b.hi 80 <_sk_start_pipeline_aarch64+0x80> // b.pmore .long 0xaa1803f9 // mov x25, x24 .long 0xaa1303e0 // mov x0, x19 .long 0xaa1403e1 // mov x1, x20 .long 0xaa1903e2 // mov x2, x25 .long 0xaa1703e3 // mov x3, x23 .long 0xaa1f03e4 // mov x4, xzr .long 0xd63f0340 // blr x26 .long 0x91001322 // add x2, x25, #0x4 .long 0x91002328 // add x8, x25, #0x8 .long 0xeb16011f // cmp x8, x22 .long 0xaa0203f9 // mov x25, x2 .long 0x54fffec9 // b.ls 54 <_sk_start_pipeline_aarch64+0x54> // b.plast .long 0xcb0202c4 // sub x4, x22, x2 .long 0xb40000a4 // cbz x4, 98 <_sk_start_pipeline_aarch64+0x98> .long 0xaa1303e0 // mov x0, x19 .long 0xaa1403e1 // mov x1, x20 .long 0xaa1703e3 // mov x3, x23 .long 0xd63f0340 // blr x26 .long 0x910006f7 // add x23, x23, #0x1 .long 0xeb1502ff // cmp x23, x21 .long 0x54fffd21 // b.ne 44 <_sk_start_pipeline_aarch64+0x44> // b.any .long 0xa9457bfd // ldp x29, x30, [sp, #80] .long 0xa9444ff4 // ldp x20, x19, [sp, #64] .long 0xa94357f6 // ldp x22, x21, [sp, #48] .long 0xa9425ff8 // ldp x24, x23, [sp, #32] .long 0xa94167fa // ldp x26, x25, [sp, #16] .long 0xa8c66ffc // ldp x28, x27, [sp], #96 .long 0xd65f03c0 // ret HIDDEN _sk_just_return_aarch64 .globl _sk_just_return_aarch64 FUNCTION(_sk_just_return_aarch64) _sk_just_return_aarch64: .long 0xd65f03c0 // ret HIDDEN _sk_seed_shader_aarch64 .globl _sk_seed_shader_aarch64 FUNCTION(_sk_seed_shader_aarch64) _sk_seed_shader_aarch64: .long 0x3dc00007 // ldr q7, [x0] .long 0x4e040c40 // dup v0.4s, w2 .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f0167e1 // movi v1.4s, #0x3f, lsl #24 .long 0x4e040c66 // dup v6.4s, w3 .long 0x4e21d800 // scvtf v0.4s, v0.4s .long 0x4e21d8c6 // scvtf v6.4s, v6.4s .long 0x4e21d400 // fadd v0.4s, v0.4s, v1.4s .long 0x4f03f602 // fmov v2.4s, #1.000000000000000000e+00 .long 0x6f00e403 // movi v3.2d, #0x0 .long 0x6f00e404 // movi v4.2d, #0x0 .long 0x6f00e405 // movi v5.2d, #0x0 .long 0x4e21d4c1 // fadd v1.4s, v6.4s, v1.4s .long 0x6f00e406 // movi v6.2d, #0x0 .long 0x4e27d400 // fadd v0.4s, v0.4s, v7.4s .long 0x6f00e407 // movi v7.2d, #0x0 .long 0xd61f00a0 // br x5 HIDDEN _sk_dither_aarch64 .globl _sk_dither_aarch64 FUNCTION(_sk_dither_aarch64) _sk_dither_aarch64: .long 0x3dc00811 // ldr q17, [x0, #32] .long 0x4e040c50 // dup v16.4s, w2 .long 0x4e040c72 // dup v18.4s, w3 .long 0x4f000433 // movi v19.4s, #0x1 .long 0x4f000455 // movi v21.4s, #0x2 .long 0x4eb08630 // add v16.4s, v17.4s, v16.4s .long 0x4f000494 // movi v20.4s, #0x4 .long 0x52a79008 // mov w8, #0x3c800000 .long 0x6e301e51 // eor v17.16b, v18.16b, v16.16b .long 0x4e331e12 // and v18.16b, v16.16b, v19.16b .long 0x4e351e17 // and v23.16b, v16.16b, v21.16b .long 0x4e040d16 // dup v22.4s, w8 .long 0x4e341e10 // and v16.16b, v16.16b, v20.16b .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4f245652 // shl v18.4s, v18.4s, #4 .long 0x4f2156f7 // shl v23.4s, v23.4s, #1 .long 0x4e331e33 // and v19.16b, v17.16b, v19.16b .long 0x4eb21ef2 // orr v18.16b, v23.16b, v18.16b .long 0x6f3e0610 // ushr v16.4s, v16.4s, #2 .long 0x4e351e35 // and v21.16b, v17.16b, v21.16b .long 0x4eb01e50 // orr v16.16b, v18.16b, v16.16b .long 0x4f255673 // shl v19.4s, v19.4s, #5 .long 0x4e341e31 // and v17.16b, v17.16b, v20.16b .long 0x4f2256b5 // shl v21.4s, v21.4s, #2 .long 0x4eb31e10 // orr v16.16b, v16.16b, v19.16b .long 0xbd400117 // ldr s23, [x8] .long 0x6f3f0631 // ushr v17.4s, v17.4s, #1 .long 0x4eb51e10 // orr v16.16b, v16.16b, v21.16b .long 0x52b7df89 // mov w9, #0xbefc0000 .long 0x4eb11e10 // orr v16.16b, v16.16b, v17.16b .long 0x4e040d34 // dup v20.4s, w9 .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x4e30ced4 // fmla v20.4s, v22.4s, v16.4s .long 0x4f979290 // fmul v16.4s, v20.4s, v23.s[0] .long 0x4e20d600 // fadd v0.4s, v16.4s, v0.4s .long 0x4e21d601 // fadd v1.4s, v16.4s, v1.4s .long 0x4e22d602 // fadd v2.4s, v16.4s, v2.4s .long 0x6f00e412 // movi v18.2d, #0x0 .long 0x4ea3f400 // fmin v0.4s, v0.4s, v3.4s .long 0x4ea3f421 // fmin v1.4s, v1.4s, v3.4s .long 0x4ea3f442 // fmin v2.4s, v2.4s, v3.4s .long 0x4e20f640 // fmax v0.4s, v18.4s, v0.4s .long 0x4e21f641 // fmax v1.4s, v18.4s, v1.4s .long 0x4e22f642 // fmax v2.4s, v18.4s, v2.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_uniform_color_aarch64 .globl _sk_uniform_color_aarch64 FUNCTION(_sk_uniform_color_aarch64) _sk_uniform_color_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xaa0803ea // mov x10, x8 .long 0x4ddfc940 // ld1r {v0.4s}, [x10], #4 .long 0x91002109 // add x9, x8, #0x8 .long 0x91003108 // add x8, x8, #0xc .long 0x4d40c922 // ld1r {v2.4s}, [x9] .long 0x4d40c903 // ld1r {v3.4s}, [x8] .long 0x4d40c941 // ld1r {v1.4s}, [x10] .long 0xd61f00a0 // br x5 HIDDEN _sk_black_color_aarch64 .globl _sk_black_color_aarch64 FUNCTION(_sk_black_color_aarch64) _sk_black_color_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f03f603 // fmov v3.4s, #1.000000000000000000e+00 .long 0x6f00e400 // movi v0.2d, #0x0 .long 0x6f00e401 // movi v1.2d, #0x0 .long 0x6f00e402 // movi v2.2d, #0x0 .long 0xd61f00a0 // br x5 HIDDEN _sk_white_color_aarch64 .globl _sk_white_color_aarch64 FUNCTION(_sk_white_color_aarch64) _sk_white_color_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f03f600 // fmov v0.4s, #1.000000000000000000e+00 .long 0x4ea01c01 // mov v1.16b, v0.16b .long 0x4ea01c02 // mov v2.16b, v0.16b .long 0x4ea01c03 // mov v3.16b, v0.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_load_rgba_aarch64 .globl _sk_load_rgba_aarch64 FUNCTION(_sk_load_rgba_aarch64) _sk_load_rgba_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xad400500 // ldp q0, q1, [x8] .long 0xad410d02 // ldp q2, q3, [x8, #32] .long 0xd61f00a0 // br x5 HIDDEN _sk_store_rgba_aarch64 .globl _sk_store_rgba_aarch64 FUNCTION(_sk_store_rgba_aarch64) _sk_store_rgba_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xad000500 // stp q0, q1, [x8] .long 0xad010d02 // stp q2, q3, [x8, #32] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_clear_aarch64 .globl _sk_clear_aarch64 FUNCTION(_sk_clear_aarch64) _sk_clear_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6f00e400 // movi v0.2d, #0x0 .long 0x6f00e401 // movi v1.2d, #0x0 .long 0x6f00e402 // movi v2.2d, #0x0 .long 0x6f00e403 // movi v3.2d, #0x0 .long 0xd61f00a0 // br x5 HIDDEN _sk_srcatop_aarch64 .globl _sk_srcatop_aarch64 FUNCTION(_sk_srcatop_aarch64) _sk_srcatop_aarch64: .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x6e27dc00 // fmul v0.4s, v0.4s, v7.4s .long 0x6e27dc21 // fmul v1.4s, v1.4s, v7.4s .long 0x6e27dc42 // fmul v2.4s, v2.4s, v7.4s .long 0x4ea3d610 // fsub v16.4s, v16.4s, v3.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e30cc80 // fmla v0.4s, v4.4s, v16.4s .long 0x4e30cca1 // fmla v1.4s, v5.4s, v16.4s .long 0x4e30ccc2 // fmla v2.4s, v6.4s, v16.4s .long 0x6e27de10 // fmul v16.4s, v16.4s, v7.4s .long 0x4e23ccf0 // fmla v16.4s, v7.4s, v3.4s .long 0x4eb01e03 // mov v3.16b, v16.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_dstatop_aarch64 .globl _sk_dstatop_aarch64 FUNCTION(_sk_dstatop_aarch64) _sk_dstatop_aarch64: .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4ea7d610 // fsub v16.4s, v16.4s, v7.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e20de00 // fmul v0.4s, v16.4s, v0.4s .long 0x6e21de01 // fmul v1.4s, v16.4s, v1.4s .long 0x6e22de02 // fmul v2.4s, v16.4s, v2.4s .long 0x6e23de10 // fmul v16.4s, v16.4s, v3.4s .long 0x4e23ccf0 // fmla v16.4s, v7.4s, v3.4s .long 0x4e23cc80 // fmla v0.4s, v4.4s, v3.4s .long 0x4e23cca1 // fmla v1.4s, v5.4s, v3.4s .long 0x4e23ccc2 // fmla v2.4s, v6.4s, v3.4s .long 0x4eb01e03 // mov v3.16b, v16.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_srcin_aarch64 .globl _sk_srcin_aarch64 FUNCTION(_sk_srcin_aarch64) _sk_srcin_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e27dc00 // fmul v0.4s, v0.4s, v7.4s .long 0x6e27dc21 // fmul v1.4s, v1.4s, v7.4s .long 0x6e27dc42 // fmul v2.4s, v2.4s, v7.4s .long 0x6e27dc63 // fmul v3.4s, v3.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_dstin_aarch64 .globl _sk_dstin_aarch64 FUNCTION(_sk_dstin_aarch64) _sk_dstin_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e24dc60 // fmul v0.4s, v3.4s, v4.4s .long 0x6e25dc61 // fmul v1.4s, v3.4s, v5.4s .long 0x6e26dc62 // fmul v2.4s, v3.4s, v6.4s .long 0x6e27dc63 // fmul v3.4s, v3.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_srcout_aarch64 .globl _sk_srcout_aarch64 FUNCTION(_sk_srcout_aarch64) _sk_srcout_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4ea7d610 // fsub v16.4s, v16.4s, v7.4s .long 0x6e20de00 // fmul v0.4s, v16.4s, v0.4s .long 0x6e21de01 // fmul v1.4s, v16.4s, v1.4s .long 0x6e22de02 // fmul v2.4s, v16.4s, v2.4s .long 0x6e23de03 // fmul v3.4s, v16.4s, v3.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_dstout_aarch64 .globl _sk_dstout_aarch64 FUNCTION(_sk_dstout_aarch64) _sk_dstout_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f03f600 // fmov v0.4s, #1.000000000000000000e+00 .long 0x4ea3d403 // fsub v3.4s, v0.4s, v3.4s .long 0x6e24dc60 // fmul v0.4s, v3.4s, v4.4s .long 0x6e25dc61 // fmul v1.4s, v3.4s, v5.4s .long 0x6e26dc62 // fmul v2.4s, v3.4s, v6.4s .long 0x6e27dc63 // fmul v3.4s, v3.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_srcover_aarch64 .globl _sk_srcover_aarch64 FUNCTION(_sk_srcover_aarch64) _sk_srcover_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4ea3d610 // fsub v16.4s, v16.4s, v3.4s .long 0x4e24ce00 // fmla v0.4s, v16.4s, v4.4s .long 0x4e25ce01 // fmla v1.4s, v16.4s, v5.4s .long 0x4e26ce02 // fmla v2.4s, v16.4s, v6.4s .long 0x4e27ce03 // fmla v3.4s, v16.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_dstover_aarch64 .globl _sk_dstover_aarch64 FUNCTION(_sk_dstover_aarch64) _sk_dstover_aarch64: .long 0x4f03f611 // fmov v17.4s, #1.000000000000000000e+00 .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4ea41c90 // mov v16.16b, v4.16b .long 0x4ea7d634 // fsub v20.4s, v17.4s, v7.4s .long 0x4ea51cb1 // mov v17.16b, v5.16b .long 0x4ea61cd2 // mov v18.16b, v6.16b .long 0x4ea71cf3 // mov v19.16b, v7.16b .long 0x4e20ce90 // fmla v16.4s, v20.4s, v0.4s .long 0x4e21ce91 // fmla v17.4s, v20.4s, v1.4s .long 0x4e22ce92 // fmla v18.4s, v20.4s, v2.4s .long 0x4e23ce93 // fmla v19.4s, v20.4s, v3.4s .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4eb11e21 // mov v1.16b, v17.16b .long 0x4eb21e42 // mov v2.16b, v18.16b .long 0x4eb31e63 // mov v3.16b, v19.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_modulate_aarch64 .globl _sk_modulate_aarch64 FUNCTION(_sk_modulate_aarch64) _sk_modulate_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e24dc00 // fmul v0.4s, v0.4s, v4.4s .long 0x6e25dc21 // fmul v1.4s, v1.4s, v5.4s .long 0x6e26dc42 // fmul v2.4s, v2.4s, v6.4s .long 0x6e27dc63 // fmul v3.4s, v3.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_multiply_aarch64 .globl _sk_multiply_aarch64 FUNCTION(_sk_multiply_aarch64) _sk_multiply_aarch64: .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4ea7d613 // fsub v19.4s, v16.4s, v7.4s .long 0x4ea3d614 // fsub v20.4s, v16.4s, v3.4s .long 0x6e20de70 // fmul v16.4s, v19.4s, v0.4s .long 0x6e21de71 // fmul v17.4s, v19.4s, v1.4s .long 0x6e22de72 // fmul v18.4s, v19.4s, v2.4s .long 0x6e23de73 // fmul v19.4s, v19.4s, v3.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e34cc90 // fmla v16.4s, v4.4s, v20.4s .long 0x4e34ccb1 // fmla v17.4s, v5.4s, v20.4s .long 0x4e34ccd2 // fmla v18.4s, v6.4s, v20.4s .long 0x4e34ccf3 // fmla v19.4s, v7.4s, v20.4s .long 0x4e20cc90 // fmla v16.4s, v4.4s, v0.4s .long 0x4e21ccb1 // fmla v17.4s, v5.4s, v1.4s .long 0x4e22ccd2 // fmla v18.4s, v6.4s, v2.4s .long 0x4e23ccf3 // fmla v19.4s, v7.4s, v3.4s .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4eb11e21 // mov v1.16b, v17.16b .long 0x4eb21e42 // mov v2.16b, v18.16b .long 0x4eb31e63 // mov v3.16b, v19.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_plus__aarch64 .globl _sk_plus__aarch64 FUNCTION(_sk_plus__aarch64) _sk_plus__aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e24d400 // fadd v0.4s, v0.4s, v4.4s .long 0x4e25d421 // fadd v1.4s, v1.4s, v5.4s .long 0x4e26d442 // fadd v2.4s, v2.4s, v6.4s .long 0x4e27d463 // fadd v3.4s, v3.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_screen_aarch64 .globl _sk_screen_aarch64 FUNCTION(_sk_screen_aarch64) _sk_screen_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e24d410 // fadd v16.4s, v0.4s, v4.4s .long 0x4e25d431 // fadd v17.4s, v1.4s, v5.4s .long 0x4e26d452 // fadd v18.4s, v2.4s, v6.4s .long 0x4e27d473 // fadd v19.4s, v3.4s, v7.4s .long 0x4ea4cc10 // fmls v16.4s, v0.4s, v4.4s .long 0x4ea5cc31 // fmls v17.4s, v1.4s, v5.4s .long 0x4ea6cc52 // fmls v18.4s, v2.4s, v6.4s .long 0x4ea7cc73 // fmls v19.4s, v3.4s, v7.4s .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4eb11e21 // mov v1.16b, v17.16b .long 0x4eb21e42 // mov v2.16b, v18.16b .long 0x4eb31e63 // mov v3.16b, v19.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_xor__aarch64 .globl _sk_xor__aarch64 FUNCTION(_sk_xor__aarch64) _sk_xor__aarch64: .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4ea7d611 // fsub v17.4s, v16.4s, v7.4s .long 0x4ea3d610 // fsub v16.4s, v16.4s, v3.4s .long 0x6e20de20 // fmul v0.4s, v17.4s, v0.4s .long 0x6e21de21 // fmul v1.4s, v17.4s, v1.4s .long 0x6e22de22 // fmul v2.4s, v17.4s, v2.4s .long 0x6e23de23 // fmul v3.4s, v17.4s, v3.4s .long 0x4e30cc80 // fmla v0.4s, v4.4s, v16.4s .long 0x4e30cca1 // fmla v1.4s, v5.4s, v16.4s .long 0x4e30ccc2 // fmla v2.4s, v6.4s, v16.4s .long 0x4e30cce3 // fmla v3.4s, v7.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_darken_aarch64 .globl _sk_darken_aarch64 FUNCTION(_sk_darken_aarch64) _sk_darken_aarch64: .long 0x6e27dc10 // fmul v16.4s, v0.4s, v7.4s .long 0x6e24dc71 // fmul v17.4s, v3.4s, v4.4s .long 0x6e27dc32 // fmul v18.4s, v1.4s, v7.4s .long 0x6e25dc73 // fmul v19.4s, v3.4s, v5.4s .long 0x4e31f610 // fmax v16.4s, v16.4s, v17.4s .long 0x4e24d400 // fadd v0.4s, v0.4s, v4.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e27dc51 // fmul v17.4s, v2.4s, v7.4s .long 0x4e33f652 // fmax v18.4s, v18.4s, v19.4s .long 0x6e26dc73 // fmul v19.4s, v3.4s, v6.4s .long 0x4eb0d400 // fsub v0.4s, v0.4s, v16.4s .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4e33f631 // fmax v17.4s, v17.4s, v19.4s .long 0x4e25d421 // fadd v1.4s, v1.4s, v5.4s .long 0x4e26d442 // fadd v2.4s, v2.4s, v6.4s .long 0x4ea3d610 // fsub v16.4s, v16.4s, v3.4s .long 0x4eb2d421 // fsub v1.4s, v1.4s, v18.4s .long 0x4eb1d442 // fsub v2.4s, v2.4s, v17.4s .long 0x4e27ce03 // fmla v3.4s, v16.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_lighten_aarch64 .globl _sk_lighten_aarch64 FUNCTION(_sk_lighten_aarch64) _sk_lighten_aarch64: .long 0x6e27dc10 // fmul v16.4s, v0.4s, v7.4s .long 0x6e24dc71 // fmul v17.4s, v3.4s, v4.4s .long 0x6e27dc32 // fmul v18.4s, v1.4s, v7.4s .long 0x6e25dc73 // fmul v19.4s, v3.4s, v5.4s .long 0x4eb1f610 // fmin v16.4s, v16.4s, v17.4s .long 0x4e24d400 // fadd v0.4s, v0.4s, v4.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e27dc51 // fmul v17.4s, v2.4s, v7.4s .long 0x4eb3f652 // fmin v18.4s, v18.4s, v19.4s .long 0x6e26dc73 // fmul v19.4s, v3.4s, v6.4s .long 0x4eb0d400 // fsub v0.4s, v0.4s, v16.4s .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4eb3f631 // fmin v17.4s, v17.4s, v19.4s .long 0x4e25d421 // fadd v1.4s, v1.4s, v5.4s .long 0x4e26d442 // fadd v2.4s, v2.4s, v6.4s .long 0x4ea3d610 // fsub v16.4s, v16.4s, v3.4s .long 0x4eb2d421 // fsub v1.4s, v1.4s, v18.4s .long 0x4eb1d442 // fsub v2.4s, v2.4s, v17.4s .long 0x4e27ce03 // fmla v3.4s, v16.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_difference_aarch64 .globl _sk_difference_aarch64 FUNCTION(_sk_difference_aarch64) _sk_difference_aarch64: .long 0x6e27dc10 // fmul v16.4s, v0.4s, v7.4s .long 0x6e24dc71 // fmul v17.4s, v3.4s, v4.4s .long 0x6e27dc32 // fmul v18.4s, v1.4s, v7.4s .long 0x6e25dc73 // fmul v19.4s, v3.4s, v5.4s .long 0x4eb1f610 // fmin v16.4s, v16.4s, v17.4s .long 0x4eb3f652 // fmin v18.4s, v18.4s, v19.4s .long 0x4e24d400 // fadd v0.4s, v0.4s, v4.4s .long 0x4e30d610 // fadd v16.4s, v16.4s, v16.4s .long 0x6e27dc51 // fmul v17.4s, v2.4s, v7.4s .long 0x6e26dc73 // fmul v19.4s, v3.4s, v6.4s .long 0x4eb0d400 // fsub v0.4s, v0.4s, v16.4s .long 0x4e25d421 // fadd v1.4s, v1.4s, v5.4s .long 0x4e32d650 // fadd v16.4s, v18.4s, v18.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4eb3f631 // fmin v17.4s, v17.4s, v19.4s .long 0x4eb0d421 // fsub v1.4s, v1.4s, v16.4s .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4e26d442 // fadd v2.4s, v2.4s, v6.4s .long 0x4e31d631 // fadd v17.4s, v17.4s, v17.4s .long 0x4ea3d610 // fsub v16.4s, v16.4s, v3.4s .long 0x4eb1d442 // fsub v2.4s, v2.4s, v17.4s .long 0x4e27ce03 // fmla v3.4s, v16.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_exclusion_aarch64 .globl _sk_exclusion_aarch64 FUNCTION(_sk_exclusion_aarch64) _sk_exclusion_aarch64: .long 0x4e24d410 // fadd v16.4s, v0.4s, v4.4s .long 0x6e24dc00 // fmul v0.4s, v0.4s, v4.4s .long 0x4e20d400 // fadd v0.4s, v0.4s, v0.4s .long 0x4ea0d600 // fsub v0.4s, v16.4s, v0.4s .long 0x4e25d430 // fadd v16.4s, v1.4s, v5.4s .long 0x6e25dc21 // fmul v1.4s, v1.4s, v5.4s .long 0x4e21d421 // fadd v1.4s, v1.4s, v1.4s .long 0x4ea1d601 // fsub v1.4s, v16.4s, v1.4s .long 0x4e26d450 // fadd v16.4s, v2.4s, v6.4s .long 0x6e26dc42 // fmul v2.4s, v2.4s, v6.4s .long 0x4e22d442 // fadd v2.4s, v2.4s, v2.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4ea2d602 // fsub v2.4s, v16.4s, v2.4s .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4ea3d610 // fsub v16.4s, v16.4s, v3.4s .long 0x4e27ce03 // fmla v3.4s, v16.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_colorburn_aarch64 .globl _sk_colorburn_aarch64 FUNCTION(_sk_colorburn_aarch64) _sk_colorburn_aarch64: .long 0x4ea4d4f3 // fsub v19.4s, v7.4s, v4.4s .long 0x6e23de73 // fmul v19.4s, v19.4s, v3.4s .long 0x4f03f611 // fmov v17.4s, #1.000000000000000000e+00 .long 0x6e20fe73 // fdiv v19.4s, v19.4s, v0.4s .long 0x4ea7d634 // fsub v20.4s, v17.4s, v7.4s .long 0x4eb3f4f3 // fmin v19.4s, v7.4s, v19.4s .long 0x6e20de95 // fmul v21.4s, v20.4s, v0.4s .long 0x4eb3d4f3 // fsub v19.4s, v7.4s, v19.4s .long 0x4e24d6b6 // fadd v22.4s, v21.4s, v4.4s .long 0x4e33cc75 // fmla v21.4s, v3.4s, v19.4s .long 0x4ea5d4f3 // fsub v19.4s, v7.4s, v5.4s .long 0x6e23de73 // fmul v19.4s, v19.4s, v3.4s .long 0x6e21fe73 // fdiv v19.4s, v19.4s, v1.4s .long 0x4ea0d812 // fcmeq v18.4s, v0.4s, #0.0 .long 0x4eb3f4f3 // fmin v19.4s, v7.4s, v19.4s .long 0x6e751c12 // bsl v18.16b, v0.16b, v21.16b .long 0x6e21de80 // fmul v0.4s, v20.4s, v1.4s .long 0x4eb3d4f3 // fsub v19.4s, v7.4s, v19.4s .long 0x4e25d415 // fadd v21.4s, v0.4s, v5.4s .long 0x4e33cc60 // fmla v0.4s, v3.4s, v19.4s .long 0x4ea0d833 // fcmeq v19.4s, v1.4s, #0.0 .long 0x6e601c33 // bsl v19.16b, v1.16b, v0.16b .long 0x4ea6d4e0 // fsub v0.4s, v7.4s, v6.4s .long 0x6e23dc00 // fmul v0.4s, v0.4s, v3.4s .long 0x6e22fc00 // fdiv v0.4s, v0.4s, v2.4s .long 0x4ea0f4e0 // fmin v0.4s, v7.4s, v0.4s .long 0x6e22de81 // fmul v1.4s, v20.4s, v2.4s .long 0x4ea0d4e0 // fsub v0.4s, v7.4s, v0.4s .long 0x4e26d434 // fadd v20.4s, v1.4s, v6.4s .long 0x4e20cc61 // fmla v1.4s, v3.4s, v0.4s .long 0x4ea0d840 // fcmeq v0.4s, v2.4s, #0.0 .long 0x4ea3d631 // fsub v17.4s, v17.4s, v3.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e27e490 // fcmeq v16.4s, v4.4s, v7.4s .long 0x6e611c40 // bsl v0.16b, v2.16b, v1.16b .long 0x4e31cc92 // fmla v18.4s, v4.4s, v17.4s .long 0x4e27e4a1 // fcmeq v1.4s, v5.4s, v7.4s .long 0x4e27e4c2 // fcmeq v2.4s, v6.4s, v7.4s .long 0x4e31ccb3 // fmla v19.4s, v5.4s, v17.4s .long 0x4e31ccc0 // fmla v0.4s, v6.4s, v17.4s .long 0x6e721ed0 // bsl v16.16b, v22.16b, v18.16b .long 0x6e731ea1 // bsl v1.16b, v21.16b, v19.16b .long 0x6e601e82 // bsl v2.16b, v20.16b, v0.16b .long 0x4e27ce23 // fmla v3.4s, v17.4s, v7.4s .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_colordodge_aarch64 .globl _sk_colordodge_aarch64 FUNCTION(_sk_colordodge_aarch64) _sk_colordodge_aarch64: .long 0x4f03f612 // fmov v18.4s, #1.000000000000000000e+00 .long 0x6e24dc71 // fmul v17.4s, v3.4s, v4.4s .long 0x4ea0d474 // fsub v20.4s, v3.4s, v0.4s .long 0x6e25dc75 // fmul v21.4s, v3.4s, v5.4s .long 0x4ea1d476 // fsub v22.4s, v3.4s, v1.4s .long 0x4ea7d657 // fsub v23.4s, v18.4s, v7.4s .long 0x6e34fe31 // fdiv v17.4s, v17.4s, v20.4s .long 0x6e36feb4 // fdiv v20.4s, v21.4s, v22.4s .long 0x6e20def5 // fmul v21.4s, v23.4s, v0.4s .long 0x4eb1f4f1 // fmin v17.4s, v7.4s, v17.4s .long 0x4e23e413 // fcmeq v19.4s, v0.4s, v3.4s .long 0x4e24d6b6 // fadd v22.4s, v21.4s, v4.4s .long 0x4e31cc75 // fmla v21.4s, v3.4s, v17.4s .long 0x6e751c13 // bsl v19.16b, v0.16b, v21.16b .long 0x6e21dee0 // fmul v0.4s, v23.4s, v1.4s .long 0x4eb4f4f4 // fmin v20.4s, v7.4s, v20.4s .long 0x4e25d415 // fadd v21.4s, v0.4s, v5.4s .long 0x4e34cc60 // fmla v0.4s, v3.4s, v20.4s .long 0x4e23e434 // fcmeq v20.4s, v1.4s, v3.4s .long 0x6e601c34 // bsl v20.16b, v1.16b, v0.16b .long 0x6e26dc60 // fmul v0.4s, v3.4s, v6.4s .long 0x4ea2d461 // fsub v1.4s, v3.4s, v2.4s .long 0x6e21fc00 // fdiv v0.4s, v0.4s, v1.4s .long 0x6e22dee1 // fmul v1.4s, v23.4s, v2.4s .long 0x4ea0f4e0 // fmin v0.4s, v7.4s, v0.4s .long 0x4e26d437 // fadd v23.4s, v1.4s, v6.4s .long 0x4e20cc61 // fmla v1.4s, v3.4s, v0.4s .long 0x4e23e440 // fcmeq v0.4s, v2.4s, v3.4s .long 0x6e611c40 // bsl v0.16b, v2.16b, v1.16b .long 0x4ea3d641 // fsub v1.4s, v18.4s, v3.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4ea0d890 // fcmeq v16.4s, v4.4s, #0.0 .long 0x4ea0d8b1 // fcmeq v17.4s, v5.4s, #0.0 .long 0x4e21cc93 // fmla v19.4s, v4.4s, v1.4s .long 0x4e21ccb4 // fmla v20.4s, v5.4s, v1.4s .long 0x4ea0d8c2 // fcmeq v2.4s, v6.4s, #0.0 .long 0x4e21ccc0 // fmla v0.4s, v6.4s, v1.4s .long 0x6e731ed0 // bsl v16.16b, v22.16b, v19.16b .long 0x6e741eb1 // bsl v17.16b, v21.16b, v20.16b .long 0x6e601ee2 // bsl v2.16b, v23.16b, v0.16b .long 0x4e27cc23 // fmla v3.4s, v1.4s, v7.4s .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4eb11e21 // mov v1.16b, v17.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_hardlight_aarch64 .globl _sk_hardlight_aarch64 FUNCTION(_sk_hardlight_aarch64) _sk_hardlight_aarch64: .long 0x4ea4d4f4 // fsub v20.4s, v7.4s, v4.4s .long 0x4ea0d475 // fsub v21.4s, v3.4s, v0.4s .long 0x6e34deb4 // fmul v20.4s, v21.4s, v20.4s .long 0x4e20d411 // fadd v17.4s, v0.4s, v0.4s .long 0x6e24dc12 // fmul v18.4s, v0.4s, v4.4s .long 0x6e27dc73 // fmul v19.4s, v3.4s, v7.4s .long 0x4e34d694 // fadd v20.4s, v20.4s, v20.4s .long 0x6e31e471 // fcmge v17.4s, v3.4s, v17.4s .long 0x4e32d652 // fadd v18.4s, v18.4s, v18.4s .long 0x4eb4d674 // fsub v20.4s, v19.4s, v20.4s .long 0x6e741e51 // bsl v17.16b, v18.16b, v20.16b .long 0x4ea5d4f2 // fsub v18.4s, v7.4s, v5.4s .long 0x4ea1d474 // fsub v20.4s, v3.4s, v1.4s .long 0x6e32de92 // fmul v18.4s, v20.4s, v18.4s .long 0x4e21d436 // fadd v22.4s, v1.4s, v1.4s .long 0x6e25dc35 // fmul v21.4s, v1.4s, v5.4s .long 0x4e32d652 // fadd v18.4s, v18.4s, v18.4s .long 0x6e36e476 // fcmge v22.4s, v3.4s, v22.4s .long 0x4e35d6b5 // fadd v21.4s, v21.4s, v21.4s .long 0x4eb2d672 // fsub v18.4s, v19.4s, v18.4s .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x6e721eb6 // bsl v22.16b, v21.16b, v18.16b .long 0x4ea6d4f2 // fsub v18.4s, v7.4s, v6.4s .long 0x4ea2d475 // fsub v21.4s, v3.4s, v2.4s .long 0x6e32deb2 // fmul v18.4s, v21.4s, v18.4s .long 0x4ea7d615 // fsub v21.4s, v16.4s, v7.4s .long 0x4e22d454 // fadd v20.4s, v2.4s, v2.4s .long 0x6e20dea0 // fmul v0.4s, v21.4s, v0.4s .long 0x6e21dea1 // fmul v1.4s, v21.4s, v1.4s .long 0x6e22deb5 // fmul v21.4s, v21.4s, v2.4s .long 0x6e26dc42 // fmul v2.4s, v2.4s, v6.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e32d652 // fadd v18.4s, v18.4s, v18.4s .long 0x4ea3d610 // fsub v16.4s, v16.4s, v3.4s .long 0x6e34e474 // fcmge v20.4s, v3.4s, v20.4s .long 0x4e22d442 // fadd v2.4s, v2.4s, v2.4s .long 0x4eb2d672 // fsub v18.4s, v19.4s, v18.4s .long 0x4e30cc80 // fmla v0.4s, v4.4s, v16.4s .long 0x4e30cca1 // fmla v1.4s, v5.4s, v16.4s .long 0x4e30ccd5 // fmla v21.4s, v6.4s, v16.4s .long 0x6e721c54 // bsl v20.16b, v2.16b, v18.16b .long 0x4e31d400 // fadd v0.4s, v0.4s, v17.4s .long 0x4e36d421 // fadd v1.4s, v1.4s, v22.4s .long 0x4e34d6a2 // fadd v2.4s, v21.4s, v20.4s .long 0x4e27ce03 // fmla v3.4s, v16.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_overlay_aarch64 .globl _sk_overlay_aarch64 FUNCTION(_sk_overlay_aarch64) _sk_overlay_aarch64: .long 0x4ea4d4f4 // fsub v20.4s, v7.4s, v4.4s .long 0x4ea0d475 // fsub v21.4s, v3.4s, v0.4s .long 0x6e34deb4 // fmul v20.4s, v21.4s, v20.4s .long 0x4e24d491 // fadd v17.4s, v4.4s, v4.4s .long 0x6e24dc12 // fmul v18.4s, v0.4s, v4.4s .long 0x6e27dc73 // fmul v19.4s, v3.4s, v7.4s .long 0x4e34d694 // fadd v20.4s, v20.4s, v20.4s .long 0x6e31e4f1 // fcmge v17.4s, v7.4s, v17.4s .long 0x4e32d652 // fadd v18.4s, v18.4s, v18.4s .long 0x4eb4d674 // fsub v20.4s, v19.4s, v20.4s .long 0x6e741e51 // bsl v17.16b, v18.16b, v20.16b .long 0x4ea5d4f2 // fsub v18.4s, v7.4s, v5.4s .long 0x4ea1d474 // fsub v20.4s, v3.4s, v1.4s .long 0x6e32de92 // fmul v18.4s, v20.4s, v18.4s .long 0x4e25d4b6 // fadd v22.4s, v5.4s, v5.4s .long 0x6e25dc35 // fmul v21.4s, v1.4s, v5.4s .long 0x4e32d652 // fadd v18.4s, v18.4s, v18.4s .long 0x6e36e4f6 // fcmge v22.4s, v7.4s, v22.4s .long 0x4e35d6b5 // fadd v21.4s, v21.4s, v21.4s .long 0x4eb2d672 // fsub v18.4s, v19.4s, v18.4s .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x6e721eb6 // bsl v22.16b, v21.16b, v18.16b .long 0x4ea6d4f2 // fsub v18.4s, v7.4s, v6.4s .long 0x4ea2d475 // fsub v21.4s, v3.4s, v2.4s .long 0x6e32deb2 // fmul v18.4s, v21.4s, v18.4s .long 0x4ea7d615 // fsub v21.4s, v16.4s, v7.4s .long 0x4e26d4d4 // fadd v20.4s, v6.4s, v6.4s .long 0x6e20dea0 // fmul v0.4s, v21.4s, v0.4s .long 0x6e21dea1 // fmul v1.4s, v21.4s, v1.4s .long 0x6e22deb5 // fmul v21.4s, v21.4s, v2.4s .long 0x6e26dc42 // fmul v2.4s, v2.4s, v6.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e32d652 // fadd v18.4s, v18.4s, v18.4s .long 0x4ea3d610 // fsub v16.4s, v16.4s, v3.4s .long 0x6e34e4f4 // fcmge v20.4s, v7.4s, v20.4s .long 0x4e22d442 // fadd v2.4s, v2.4s, v2.4s .long 0x4eb2d672 // fsub v18.4s, v19.4s, v18.4s .long 0x4e30cc80 // fmla v0.4s, v4.4s, v16.4s .long 0x4e30cca1 // fmla v1.4s, v5.4s, v16.4s .long 0x4e30ccd5 // fmla v21.4s, v6.4s, v16.4s .long 0x6e721c54 // bsl v20.16b, v2.16b, v18.16b .long 0x4e31d400 // fadd v0.4s, v0.4s, v17.4s .long 0x4e36d421 // fadd v1.4s, v1.4s, v22.4s .long 0x4e34d6a2 // fadd v2.4s, v21.4s, v20.4s .long 0x4e27ce03 // fmla v3.4s, v16.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_softlight_aarch64 .globl _sk_softlight_aarch64 FUNCTION(_sk_softlight_aarch64) _sk_softlight_aarch64: .long 0x4ea0c8f5 // fcmgt v21.4s, v7.4s, #0.0 .long 0x6e27fc96 // fdiv v22.4s, v4.4s, v7.4s .long 0x6e27fcb8 // fdiv v24.4s, v5.4s, v7.4s .long 0x6e27fcd9 // fdiv v25.4s, v6.4s, v7.4s .long 0x4e351ed6 // and v22.16b, v22.16b, v21.16b .long 0x4e351f18 // and v24.16b, v24.16b, v21.16b .long 0x4e351f35 // and v21.16b, v25.16b, v21.16b .long 0x6ea1dad9 // frsqrte v25.4s, v22.4s .long 0x6e39df3d // fmul v29.4s, v25.4s, v25.4s .long 0x4ebdfedd // frsqrts v29.4s, v22.4s, v29.4s .long 0x6e3ddf39 // fmul v25.4s, v25.4s, v29.4s .long 0x4ea1db3d // frecpe v29.4s, v25.4s .long 0x6ea0fada // fneg v26.4s, v22.4s .long 0x6ea1db1b // frsqrte v27.4s, v24.4s .long 0x4e3dff39 // frecps v25.4s, v25.4s, v29.4s .long 0x4e3dcf3a // fmla v26.4s, v25.4s, v29.4s .long 0x6e3bdf7d // fmul v29.4s, v27.4s, v27.4s .long 0x4ebdff1d // frsqrts v29.4s, v24.4s, v29.4s .long 0x6e3ddf7b // fmul v27.4s, v27.4s, v29.4s .long 0x4ea1db7d // frecpe v29.4s, v27.4s .long 0x6ea0fb1c // fneg v28.4s, v24.4s .long 0x6ea1dab9 // frsqrte v25.4s, v21.4s .long 0x4e3dff7b // frecps v27.4s, v27.4s, v29.4s .long 0x4e3dcf7c // fmla v28.4s, v27.4s, v29.4s .long 0x6e39df3d // fmul v29.4s, v25.4s, v25.4s .long 0x4ebdfebd // frsqrts v29.4s, v21.4s, v29.4s .long 0x6e3ddf39 // fmul v25.4s, v25.4s, v29.4s .long 0x4ea1db3d // frecpe v29.4s, v25.4s .long 0x6ea0fabb // fneg v27.4s, v21.4s .long 0x4e3dff39 // frecps v25.4s, v25.4s, v29.4s .long 0x4e3dcf3b // fmla v27.4s, v25.4s, v29.4s .long 0x4e36d6d9 // fadd v25.4s, v22.4s, v22.4s .long 0x4f07f613 // fmov v19.4s, #-1.000000000000000000e+00 .long 0x4e39d739 // fadd v25.4s, v25.4s, v25.4s .long 0x4e24d497 // fadd v23.4s, v4.4s, v4.4s .long 0x4e33d6dd // fadd v29.4s, v22.4s, v19.4s .long 0x4e39cf39 // fmla v25.4s, v25.4s, v25.4s .long 0x4f00f794 // fmov v20.4s, #7.000000000000000000e+00 .long 0x6e39dfb9 // fmul v25.4s, v29.4s, v25.4s .long 0x4e37d6f7 // fadd v23.4s, v23.4s, v23.4s .long 0x6e37e4f7 // fcmge v23.4s, v7.4s, v23.4s .long 0x4e36ce99 // fmla v25.4s, v20.4s, v22.4s .long 0x6e7a1f37 // bsl v23.16b, v25.16b, v26.16b .long 0x4e38d719 // fadd v25.4s, v24.4s, v24.4s .long 0x4e39d739 // fadd v25.4s, v25.4s, v25.4s .long 0x4e33d71a // fadd v26.4s, v24.4s, v19.4s .long 0x4e39cf39 // fmla v25.4s, v25.4s, v25.4s .long 0x6e39df59 // fmul v25.4s, v26.4s, v25.4s .long 0x4e25d4ba // fadd v26.4s, v5.4s, v5.4s .long 0x4e3ad75a // fadd v26.4s, v26.4s, v26.4s .long 0x6e3ae4fa // fcmge v26.4s, v7.4s, v26.4s .long 0x4e38ce99 // fmla v25.4s, v20.4s, v24.4s .long 0x6e7c1f3a // bsl v26.16b, v25.16b, v28.16b .long 0x4e35d6bc // fadd v28.4s, v21.4s, v21.4s .long 0x4e3cd79c // fadd v28.4s, v28.4s, v28.4s .long 0x4e33d6b3 // fadd v19.4s, v21.4s, v19.4s .long 0x4e3ccf9c // fmla v28.4s, v28.4s, v28.4s .long 0x6e3cde73 // fmul v19.4s, v19.4s, v28.4s .long 0x4e35ce93 // fmla v19.4s, v20.4s, v21.4s .long 0x4e26d4d4 // fadd v20.4s, v6.4s, v6.4s .long 0x4e34d694 // fadd v20.4s, v20.4s, v20.4s .long 0x4f03f612 // fmov v18.4s, #1.000000000000000000e+00 .long 0x6e34e4f4 // fcmge v20.4s, v7.4s, v20.4s .long 0x4e20d411 // fadd v17.4s, v0.4s, v0.4s .long 0x6e7b1e74 // bsl v20.16b, v19.16b, v27.16b .long 0x4ea7d65b // fsub v27.4s, v18.4s, v7.4s .long 0x4ea31c70 // mov v16.16b, v3.16b .long 0x4e21d43d // fadd v29.4s, v1.4s, v1.4s .long 0x4e22d45c // fadd v28.4s, v2.4s, v2.4s .long 0x6e20df60 // fmul v0.4s, v27.4s, v0.4s .long 0x6e21df61 // fmul v1.4s, v27.4s, v1.4s .long 0x6e22df62 // fmul v2.4s, v27.4s, v2.4s .long 0x4ea3d63b // fsub v27.4s, v17.4s, v3.4s .long 0x4eb6d656 // fsub v22.4s, v18.4s, v22.4s .long 0x4ea31c79 // mov v25.16b, v3.16b .long 0x4e3bced0 // fmla v16.4s, v22.4s, v27.4s .long 0x4ea3d7b6 // fsub v22.4s, v29.4s, v3.4s .long 0x4eb8d658 // fsub v24.4s, v18.4s, v24.4s .long 0x4ea31c73 // mov v19.16b, v3.16b .long 0x4e36cf19 // fmla v25.4s, v24.4s, v22.4s .long 0x4ea3d798 // fsub v24.4s, v28.4s, v3.4s .long 0x4eb5d655 // fsub v21.4s, v18.4s, v21.4s .long 0x4e38ceb3 // fmla v19.4s, v21.4s, v24.4s .long 0x6e27df7b // fmul v27.4s, v27.4s, v7.4s .long 0x6e27ded6 // fmul v22.4s, v22.4s, v7.4s .long 0x6e27df18 // fmul v24.4s, v24.4s, v7.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e37df77 // fmul v23.4s, v27.4s, v23.4s .long 0x6e3aded6 // fmul v22.4s, v22.4s, v26.4s .long 0x6e34df14 // fmul v20.4s, v24.4s, v20.4s .long 0x4ea3d652 // fsub v18.4s, v18.4s, v3.4s .long 0x6e31e471 // fcmge v17.4s, v3.4s, v17.4s .long 0x6e3de475 // fcmge v21.4s, v3.4s, v29.4s .long 0x6e3ce47c // fcmge v28.4s, v3.4s, v28.4s .long 0x6e24de10 // fmul v16.4s, v16.4s, v4.4s .long 0x6e25df39 // fmul v25.4s, v25.4s, v5.4s .long 0x6e26de73 // fmul v19.4s, v19.4s, v6.4s .long 0x4e23cc97 // fmla v23.4s, v4.4s, v3.4s .long 0x4e23ccb6 // fmla v22.4s, v5.4s, v3.4s .long 0x4e23ccd4 // fmla v20.4s, v6.4s, v3.4s .long 0x4e32cc80 // fmla v0.4s, v4.4s, v18.4s .long 0x4e32cca1 // fmla v1.4s, v5.4s, v18.4s .long 0x4e32ccc2 // fmla v2.4s, v6.4s, v18.4s .long 0x6e771e11 // bsl v17.16b, v16.16b, v23.16b .long 0x6e761f35 // bsl v21.16b, v25.16b, v22.16b .long 0x6e741e7c // bsl v28.16b, v19.16b, v20.16b .long 0x4e31d400 // fadd v0.4s, v0.4s, v17.4s .long 0x4e35d421 // fadd v1.4s, v1.4s, v21.4s .long 0x4e3cd442 // fadd v2.4s, v2.4s, v28.4s .long 0x4e27ce43 // fmla v3.4s, v18.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_hue_aarch64 .globl _sk_hue_aarch64 FUNCTION(_sk_hue_aarch64) _sk_hue_aarch64: .long 0x6e23dc32 // fmul v18.4s, v1.4s, v3.4s .long 0x6e23dc53 // fmul v19.4s, v2.4s, v3.4s .long 0x4e26f4b5 // fmax v21.4s, v5.4s, v6.4s .long 0x4ea6f4b7 // fmin v23.4s, v5.4s, v6.4s .long 0x6e23dc11 // fmul v17.4s, v0.4s, v3.4s .long 0x4e35f495 // fmax v21.4s, v4.4s, v21.4s .long 0x4eb7f497 // fmin v23.4s, v4.4s, v23.4s .long 0x4eb3f65b // fmin v27.4s, v18.4s, v19.4s .long 0x52a7d328 // mov w8, #0x3e990000 .long 0x4f03f619 // fmov v25.4s, #1.000000000000000000e+00 .long 0x4e33f65c // fmax v28.4s, v18.4s, v19.4s .long 0x4eb7d6b5 // fsub v21.4s, v21.4s, v23.4s .long 0x4ebbf63b // fmin v27.4s, v17.4s, v27.4s .long 0x72933348 // movk w8, #0x999a .long 0x4ea7d737 // fsub v23.4s, v25.4s, v7.4s .long 0x4e3cf63c // fmax v28.4s, v17.4s, v28.4s .long 0x4ebbd652 // fsub v18.4s, v18.4s, v27.4s .long 0x6e23deb5 // fmul v21.4s, v21.4s, v3.4s .long 0x4e040d16 // dup v22.4s, w8 .long 0x52a7e2e8 // mov w8, #0x3f170000 .long 0x6e20dee0 // fmul v0.4s, v23.4s, v0.4s .long 0x6e21dee1 // fmul v1.4s, v23.4s, v1.4s .long 0x6e22dee2 // fmul v2.4s, v23.4s, v2.4s .long 0x4ea3d739 // fsub v25.4s, v25.4s, v3.4s .long 0x4ebbd79c // fsub v28.4s, v28.4s, v27.4s .long 0x4ebbd631 // fsub v17.4s, v17.4s, v27.4s .long 0x6e32deb2 // fmul v18.4s, v21.4s, v18.4s .long 0x728147a8 // movk w8, #0xa3d .long 0x4ebbd673 // fsub v19.4s, v19.4s, v27.4s .long 0x4e39cc80 // fmla v0.4s, v4.4s, v25.4s .long 0x4e39cca1 // fmla v1.4s, v5.4s, v25.4s .long 0x4e39ccc2 // fmla v2.4s, v6.4s, v25.4s .long 0x4ea0db99 // fcmeq v25.4s, v28.4s, #0.0 .long 0x6e31deb1 // fmul v17.4s, v21.4s, v17.4s .long 0x6e3cfe52 // fdiv v18.4s, v18.4s, v28.4s .long 0x4e040d18 // dup v24.4s, w8 .long 0x52a7bc28 // mov w8, #0x3de10000 .long 0x6e33deb3 // fmul v19.4s, v21.4s, v19.4s .long 0x6e3cfe31 // fdiv v17.4s, v17.4s, v28.4s .long 0x4e791e52 // bic v18.16b, v18.16b, v25.16b .long 0x7288f5c8 // movk w8, #0x47ae .long 0x6e3cfe73 // fdiv v19.4s, v19.4s, v28.4s .long 0x4e791e31 // bic v17.16b, v17.16b, v25.16b .long 0x6e38de55 // fmul v21.4s, v18.4s, v24.4s .long 0x4e040d17 // dup v23.4s, w8 .long 0x6e38dcbb // fmul v27.4s, v5.4s, v24.4s .long 0x4e791e73 // bic v19.16b, v19.16b, v25.16b .long 0x4e31ced5 // fmla v21.4s, v22.4s, v17.4s .long 0x4e24cedb // fmla v27.4s, v22.4s, v4.4s .long 0x4e33cef5 // fmla v21.4s, v23.4s, v19.4s .long 0x4e26cefb // fmla v27.4s, v23.4s, v6.4s .long 0x6ea0fab5 // fneg v21.4s, v21.4s .long 0x4e3bcc75 // fmla v21.4s, v3.4s, v27.4s .long 0x6e27dc74 // fmul v20.4s, v3.4s, v7.4s .long 0x4e27d47a // fadd v26.4s, v3.4s, v7.4s .long 0x4e35d623 // fadd v3.4s, v17.4s, v21.4s .long 0x4e35d651 // fadd v17.4s, v18.4s, v21.4s .long 0x6e38de38 // fmul v24.4s, v17.4s, v24.4s .long 0x4e35d672 // fadd v18.4s, v19.4s, v21.4s .long 0x4e23ced8 // fmla v24.4s, v22.4s, v3.4s .long 0x4eb2f633 // fmin v19.4s, v17.4s, v18.4s .long 0x4e32cef8 // fmla v24.4s, v23.4s, v18.4s .long 0x4eb3f473 // fmin v19.4s, v3.4s, v19.4s .long 0x4eb8d479 // fsub v25.4s, v3.4s, v24.4s .long 0x6ea0ca76 // fcmge v22.4s, v19.4s, #0.0 .long 0x4eb3d713 // fsub v19.4s, v24.4s, v19.4s .long 0x6e39df19 // fmul v25.4s, v24.4s, v25.4s .long 0x6e33ff39 // fdiv v25.4s, v25.4s, v19.4s .long 0x4e32f635 // fmax v21.4s, v17.4s, v18.4s .long 0x4eb61edb // mov v27.16b, v22.16b .long 0x4e39d719 // fadd v25.4s, v24.4s, v25.4s .long 0x4e35f475 // fmax v21.4s, v3.4s, v21.4s .long 0x6e791c7b // bsl v27.16b, v3.16b, v25.16b .long 0x4eb8d623 // fsub v3.4s, v17.4s, v24.4s .long 0x6e23df03 // fmul v3.4s, v24.4s, v3.4s .long 0x6e33fc63 // fdiv v3.4s, v3.4s, v19.4s .long 0x4eb61ed9 // mov v25.16b, v22.16b .long 0x4e23d703 // fadd v3.4s, v24.4s, v3.4s .long 0x6e631e39 // bsl v25.16b, v17.16b, v3.16b .long 0x4eb8d651 // fsub v17.4s, v18.4s, v24.4s .long 0x6e31df11 // fmul v17.4s, v24.4s, v17.4s .long 0x6e33fe31 // fdiv v17.4s, v17.4s, v19.4s .long 0x4e31d711 // fadd v17.4s, v24.4s, v17.4s .long 0x6e711e56 // bsl v22.16b, v18.16b, v17.16b .long 0x4eb8d69c // fsub v28.4s, v20.4s, v24.4s .long 0x4eb8d771 // fsub v17.4s, v27.4s, v24.4s .long 0x4eb8d732 // fsub v18.4s, v25.4s, v24.4s .long 0x4eb8d6d3 // fsub v19.4s, v22.4s, v24.4s .long 0x6eb4e6b7 // fcmgt v23.4s, v21.4s, v20.4s .long 0x4eb8d6b5 // fsub v21.4s, v21.4s, v24.4s .long 0x6e31df91 // fmul v17.4s, v28.4s, v17.4s .long 0x6e32df92 // fmul v18.4s, v28.4s, v18.4s .long 0x6e33df93 // fmul v19.4s, v28.4s, v19.4s .long 0x6e35fe31 // fdiv v17.4s, v17.4s, v21.4s .long 0x6e35fe52 // fdiv v18.4s, v18.4s, v21.4s .long 0x6e35fe73 // fdiv v19.4s, v19.4s, v21.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4eb71ee3 // mov v3.16b, v23.16b .long 0x4eb71efc // mov v28.16b, v23.16b .long 0x4e31d711 // fadd v17.4s, v24.4s, v17.4s .long 0x4e32d712 // fadd v18.4s, v24.4s, v18.4s .long 0x4e33d713 // fadd v19.4s, v24.4s, v19.4s .long 0x6f00e410 // movi v16.2d, #0x0 .long 0x6e7b1e23 // bsl v3.16b, v17.16b, v27.16b .long 0x6e791e5c // bsl v28.16b, v18.16b, v25.16b .long 0x6e761e77 // bsl v23.16b, v19.16b, v22.16b .long 0x4e30f463 // fmax v3.4s, v3.4s, v16.4s .long 0x4e30f791 // fmax v17.4s, v28.4s, v16.4s .long 0x4e30f6f0 // fmax v16.4s, v23.4s, v16.4s .long 0x4e23d400 // fadd v0.4s, v0.4s, v3.4s .long 0x4e31d421 // fadd v1.4s, v1.4s, v17.4s .long 0x4e30d442 // fadd v2.4s, v2.4s, v16.4s .long 0x4eb4d743 // fsub v3.4s, v26.4s, v20.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_saturation_aarch64 .globl _sk_saturation_aarch64 FUNCTION(_sk_saturation_aarch64) _sk_saturation_aarch64: .long 0x6e25dc72 // fmul v18.4s, v3.4s, v5.4s .long 0x6e26dc73 // fmul v19.4s, v3.4s, v6.4s .long 0x4e22f435 // fmax v21.4s, v1.4s, v2.4s .long 0x4ea2f437 // fmin v23.4s, v1.4s, v2.4s .long 0x6e24dc71 // fmul v17.4s, v3.4s, v4.4s .long 0x4e35f415 // fmax v21.4s, v0.4s, v21.4s .long 0x4eb7f417 // fmin v23.4s, v0.4s, v23.4s .long 0x4eb3f65b // fmin v27.4s, v18.4s, v19.4s .long 0x52a7d328 // mov w8, #0x3e990000 .long 0x4f03f619 // fmov v25.4s, #1.000000000000000000e+00 .long 0x4e33f65c // fmax v28.4s, v18.4s, v19.4s .long 0x4eb7d6b5 // fsub v21.4s, v21.4s, v23.4s .long 0x4ebbf63b // fmin v27.4s, v17.4s, v27.4s .long 0x72933348 // movk w8, #0x999a .long 0x4ea7d737 // fsub v23.4s, v25.4s, v7.4s .long 0x4e3cf63c // fmax v28.4s, v17.4s, v28.4s .long 0x4ebbd652 // fsub v18.4s, v18.4s, v27.4s .long 0x6e27deb5 // fmul v21.4s, v21.4s, v7.4s .long 0x4e040d16 // dup v22.4s, w8 .long 0x52a7e2e8 // mov w8, #0x3f170000 .long 0x6e20dee0 // fmul v0.4s, v23.4s, v0.4s .long 0x6e21dee1 // fmul v1.4s, v23.4s, v1.4s .long 0x6e22dee2 // fmul v2.4s, v23.4s, v2.4s .long 0x4ea3d739 // fsub v25.4s, v25.4s, v3.4s .long 0x4ebbd79c // fsub v28.4s, v28.4s, v27.4s .long 0x4ebbd631 // fsub v17.4s, v17.4s, v27.4s .long 0x6e32deb2 // fmul v18.4s, v21.4s, v18.4s .long 0x728147a8 // movk w8, #0xa3d .long 0x4ebbd673 // fsub v19.4s, v19.4s, v27.4s .long 0x4e39cc80 // fmla v0.4s, v4.4s, v25.4s .long 0x4e39cca1 // fmla v1.4s, v5.4s, v25.4s .long 0x4e39ccc2 // fmla v2.4s, v6.4s, v25.4s .long 0x4ea0db99 // fcmeq v25.4s, v28.4s, #0.0 .long 0x6e31deb1 // fmul v17.4s, v21.4s, v17.4s .long 0x6e3cfe52 // fdiv v18.4s, v18.4s, v28.4s .long 0x4e040d18 // dup v24.4s, w8 .long 0x52a7bc28 // mov w8, #0x3de10000 .long 0x6e33deb3 // fmul v19.4s, v21.4s, v19.4s .long 0x6e3cfe31 // fdiv v17.4s, v17.4s, v28.4s .long 0x4e791e52 // bic v18.16b, v18.16b, v25.16b .long 0x7288f5c8 // movk w8, #0x47ae .long 0x6e3cfe73 // fdiv v19.4s, v19.4s, v28.4s .long 0x4e791e31 // bic v17.16b, v17.16b, v25.16b .long 0x6e38de55 // fmul v21.4s, v18.4s, v24.4s .long 0x4e040d17 // dup v23.4s, w8 .long 0x6e38dcbb // fmul v27.4s, v5.4s, v24.4s .long 0x4e791e73 // bic v19.16b, v19.16b, v25.16b .long 0x4e31ced5 // fmla v21.4s, v22.4s, v17.4s .long 0x4e24cedb // fmla v27.4s, v22.4s, v4.4s .long 0x4e33cef5 // fmla v21.4s, v23.4s, v19.4s .long 0x4e26cefb // fmla v27.4s, v23.4s, v6.4s .long 0x6ea0fab5 // fneg v21.4s, v21.4s .long 0x4e3bcc75 // fmla v21.4s, v3.4s, v27.4s .long 0x6e27dc74 // fmul v20.4s, v3.4s, v7.4s .long 0x4e27d47a // fadd v26.4s, v3.4s, v7.4s .long 0x4e35d623 // fadd v3.4s, v17.4s, v21.4s .long 0x4e35d651 // fadd v17.4s, v18.4s, v21.4s .long 0x6e38de38 // fmul v24.4s, v17.4s, v24.4s .long 0x4e35d672 // fadd v18.4s, v19.4s, v21.4s .long 0x4e23ced8 // fmla v24.4s, v22.4s, v3.4s .long 0x4eb2f633 // fmin v19.4s, v17.4s, v18.4s .long 0x4e32cef8 // fmla v24.4s, v23.4s, v18.4s .long 0x4eb3f473 // fmin v19.4s, v3.4s, v19.4s .long 0x4eb8d479 // fsub v25.4s, v3.4s, v24.4s .long 0x6ea0ca76 // fcmge v22.4s, v19.4s, #0.0 .long 0x4eb3d713 // fsub v19.4s, v24.4s, v19.4s .long 0x6e39df19 // fmul v25.4s, v24.4s, v25.4s .long 0x6e33ff39 // fdiv v25.4s, v25.4s, v19.4s .long 0x4e32f635 // fmax v21.4s, v17.4s, v18.4s .long 0x4eb61edb // mov v27.16b, v22.16b .long 0x4e39d719 // fadd v25.4s, v24.4s, v25.4s .long 0x4e35f475 // fmax v21.4s, v3.4s, v21.4s .long 0x6e791c7b // bsl v27.16b, v3.16b, v25.16b .long 0x4eb8d623 // fsub v3.4s, v17.4s, v24.4s .long 0x6e23df03 // fmul v3.4s, v24.4s, v3.4s .long 0x6e33fc63 // fdiv v3.4s, v3.4s, v19.4s .long 0x4eb61ed9 // mov v25.16b, v22.16b .long 0x4e23d703 // fadd v3.4s, v24.4s, v3.4s .long 0x6e631e39 // bsl v25.16b, v17.16b, v3.16b .long 0x4eb8d651 // fsub v17.4s, v18.4s, v24.4s .long 0x6e31df11 // fmul v17.4s, v24.4s, v17.4s .long 0x6e33fe31 // fdiv v17.4s, v17.4s, v19.4s .long 0x4e31d711 // fadd v17.4s, v24.4s, v17.4s .long 0x6e711e56 // bsl v22.16b, v18.16b, v17.16b .long 0x4eb8d69c // fsub v28.4s, v20.4s, v24.4s .long 0x4eb8d771 // fsub v17.4s, v27.4s, v24.4s .long 0x4eb8d732 // fsub v18.4s, v25.4s, v24.4s .long 0x4eb8d6d3 // fsub v19.4s, v22.4s, v24.4s .long 0x6eb4e6b7 // fcmgt v23.4s, v21.4s, v20.4s .long 0x4eb8d6b5 // fsub v21.4s, v21.4s, v24.4s .long 0x6e31df91 // fmul v17.4s, v28.4s, v17.4s .long 0x6e32df92 // fmul v18.4s, v28.4s, v18.4s .long 0x6e33df93 // fmul v19.4s, v28.4s, v19.4s .long 0x6e35fe31 // fdiv v17.4s, v17.4s, v21.4s .long 0x6e35fe52 // fdiv v18.4s, v18.4s, v21.4s .long 0x6e35fe73 // fdiv v19.4s, v19.4s, v21.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4eb71ee3 // mov v3.16b, v23.16b .long 0x4eb71efc // mov v28.16b, v23.16b .long 0x4e31d711 // fadd v17.4s, v24.4s, v17.4s .long 0x4e32d712 // fadd v18.4s, v24.4s, v18.4s .long 0x4e33d713 // fadd v19.4s, v24.4s, v19.4s .long 0x6f00e410 // movi v16.2d, #0x0 .long 0x6e7b1e23 // bsl v3.16b, v17.16b, v27.16b .long 0x6e791e5c // bsl v28.16b, v18.16b, v25.16b .long 0x6e761e77 // bsl v23.16b, v19.16b, v22.16b .long 0x4e30f463 // fmax v3.4s, v3.4s, v16.4s .long 0x4e30f791 // fmax v17.4s, v28.4s, v16.4s .long 0x4e30f6f0 // fmax v16.4s, v23.4s, v16.4s .long 0x4e23d400 // fadd v0.4s, v0.4s, v3.4s .long 0x4e31d421 // fadd v1.4s, v1.4s, v17.4s .long 0x4e30d442 // fadd v2.4s, v2.4s, v16.4s .long 0x4eb4d743 // fsub v3.4s, v26.4s, v20.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_color_aarch64 .globl _sk_color_aarch64 FUNCTION(_sk_color_aarch64) _sk_color_aarch64: .long 0x52a7d328 // mov w8, #0x3e990000 .long 0x72933348 // movk w8, #0x999a .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a7e2e8 // mov w8, #0x3f170000 .long 0x728147a8 // movk w8, #0xa3d .long 0x6e27dc33 // fmul v19.4s, v1.4s, v7.4s .long 0x4e040d15 // dup v21.4s, w8 .long 0x52a7bc28 // mov w8, #0x3de10000 .long 0x6e27dc11 // fmul v17.4s, v0.4s, v7.4s .long 0x7288f5c8 // movk w8, #0x47ae .long 0x4f03f617 // fmov v23.4s, #1.000000000000000000e+00 .long 0x6e35de7c // fmul v28.4s, v19.4s, v21.4s .long 0x6e27dc54 // fmul v20.4s, v2.4s, v7.4s .long 0x4e040d19 // dup v25.4s, w8 .long 0x4ea7d6fa // fsub v26.4s, v23.4s, v7.4s .long 0x6e35dcbb // fmul v27.4s, v5.4s, v21.4s .long 0x4e31ce5c // fmla v28.4s, v18.4s, v17.4s .long 0x4ea3d6f7 // fsub v23.4s, v23.4s, v3.4s .long 0x6e20df40 // fmul v0.4s, v26.4s, v0.4s .long 0x6e21df41 // fmul v1.4s, v26.4s, v1.4s .long 0x6e22df42 // fmul v2.4s, v26.4s, v2.4s .long 0x4e24ce5b // fmla v27.4s, v18.4s, v4.4s .long 0x4e34cf3c // fmla v28.4s, v25.4s, v20.4s .long 0x4e37cc80 // fmla v0.4s, v4.4s, v23.4s .long 0x4e37cca1 // fmla v1.4s, v5.4s, v23.4s .long 0x4e37ccc2 // fmla v2.4s, v6.4s, v23.4s .long 0x4e26cf3b // fmla v27.4s, v25.4s, v6.4s .long 0x6ea0fb97 // fneg v23.4s, v28.4s .long 0x4e3bcc77 // fmla v23.4s, v3.4s, v27.4s .long 0x6e27dc70 // fmul v16.4s, v3.4s, v7.4s .long 0x4e27d478 // fadd v24.4s, v3.4s, v7.4s .long 0x4e37d623 // fadd v3.4s, v17.4s, v23.4s .long 0x4e37d671 // fadd v17.4s, v19.4s, v23.4s .long 0x6e35de35 // fmul v21.4s, v17.4s, v21.4s .long 0x4e37d693 // fadd v19.4s, v20.4s, v23.4s .long 0x4e23ce55 // fmla v21.4s, v18.4s, v3.4s .long 0x4eb3f634 // fmin v20.4s, v17.4s, v19.4s .long 0x4e33cf35 // fmla v21.4s, v25.4s, v19.4s .long 0x4eb4f474 // fmin v20.4s, v3.4s, v20.4s .long 0x4eb5d47a // fsub v26.4s, v3.4s, v21.4s .long 0x6ea0ca92 // fcmge v18.4s, v20.4s, #0.0 .long 0x4eb4d6b4 // fsub v20.4s, v21.4s, v20.4s .long 0x6e3adeba // fmul v26.4s, v21.4s, v26.4s .long 0x6e34ff5a // fdiv v26.4s, v26.4s, v20.4s .long 0x4e33f637 // fmax v23.4s, v17.4s, v19.4s .long 0x4eb21e5b // mov v27.16b, v18.16b .long 0x4e3ad6ba // fadd v26.4s, v21.4s, v26.4s .long 0x4e37f477 // fmax v23.4s, v3.4s, v23.4s .long 0x6e7a1c7b // bsl v27.16b, v3.16b, v26.16b .long 0x4eb5d623 // fsub v3.4s, v17.4s, v21.4s .long 0x6e23dea3 // fmul v3.4s, v21.4s, v3.4s .long 0x6e34fc63 // fdiv v3.4s, v3.4s, v20.4s .long 0x4eb21e5a // mov v26.16b, v18.16b .long 0x4e23d6a3 // fadd v3.4s, v21.4s, v3.4s .long 0x6e631e3a // bsl v26.16b, v17.16b, v3.16b .long 0x4eb5d671 // fsub v17.4s, v19.4s, v21.4s .long 0x6e31deb1 // fmul v17.4s, v21.4s, v17.4s .long 0x6e34fe31 // fdiv v17.4s, v17.4s, v20.4s .long 0x4e31d6b1 // fadd v17.4s, v21.4s, v17.4s .long 0x6e711e72 // bsl v18.16b, v19.16b, v17.16b .long 0x4eb5d61c // fsub v28.4s, v16.4s, v21.4s .long 0x4eb5d771 // fsub v17.4s, v27.4s, v21.4s .long 0x4eb5d753 // fsub v19.4s, v26.4s, v21.4s .long 0x4eb5d654 // fsub v20.4s, v18.4s, v21.4s .long 0x6eb0e6f9 // fcmgt v25.4s, v23.4s, v16.4s .long 0x4eb5d6f7 // fsub v23.4s, v23.4s, v21.4s .long 0x6e31df91 // fmul v17.4s, v28.4s, v17.4s .long 0x6e33df93 // fmul v19.4s, v28.4s, v19.4s .long 0x6e34df94 // fmul v20.4s, v28.4s, v20.4s .long 0x6e37fe31 // fdiv v17.4s, v17.4s, v23.4s .long 0x6e37fe73 // fdiv v19.4s, v19.4s, v23.4s .long 0x6e37fe94 // fdiv v20.4s, v20.4s, v23.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4eb91f23 // mov v3.16b, v25.16b .long 0x4eb91f3c // mov v28.16b, v25.16b .long 0x4e31d6b1 // fadd v17.4s, v21.4s, v17.4s .long 0x4e33d6b3 // fadd v19.4s, v21.4s, v19.4s .long 0x4e34d6b4 // fadd v20.4s, v21.4s, v20.4s .long 0x6f00e416 // movi v22.2d, #0x0 .long 0x6e7b1e23 // bsl v3.16b, v17.16b, v27.16b .long 0x6e7a1e7c // bsl v28.16b, v19.16b, v26.16b .long 0x6e721e99 // bsl v25.16b, v20.16b, v18.16b .long 0x4e36f463 // fmax v3.4s, v3.4s, v22.4s .long 0x4e36f791 // fmax v17.4s, v28.4s, v22.4s .long 0x4e36f732 // fmax v18.4s, v25.4s, v22.4s .long 0x4e23d400 // fadd v0.4s, v0.4s, v3.4s .long 0x4e31d421 // fadd v1.4s, v1.4s, v17.4s .long 0x4e32d442 // fadd v2.4s, v2.4s, v18.4s .long 0x4eb0d703 // fsub v3.4s, v24.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_luminosity_aarch64 .globl _sk_luminosity_aarch64 FUNCTION(_sk_luminosity_aarch64) _sk_luminosity_aarch64: .long 0x52a7d328 // mov w8, #0x3e990000 .long 0x72933348 // movk w8, #0x999a .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a7e2e8 // mov w8, #0x3f170000 .long 0x728147a8 // movk w8, #0xa3d .long 0x6e25dc73 // fmul v19.4s, v3.4s, v5.4s .long 0x4e040d15 // dup v21.4s, w8 .long 0x52a7bc28 // mov w8, #0x3de10000 .long 0x6e24dc71 // fmul v17.4s, v3.4s, v4.4s .long 0x7288f5c8 // movk w8, #0x47ae .long 0x4f03f617 // fmov v23.4s, #1.000000000000000000e+00 .long 0x6e35de7b // fmul v27.4s, v19.4s, v21.4s .long 0x6e26dc74 // fmul v20.4s, v3.4s, v6.4s .long 0x6e27dc70 // fmul v16.4s, v3.4s, v7.4s .long 0x4e27d478 // fadd v24.4s, v3.4s, v7.4s .long 0x4e040d19 // dup v25.4s, w8 .long 0x4ea7d6fa // fsub v26.4s, v23.4s, v7.4s .long 0x4ea3d6e3 // fsub v3.4s, v23.4s, v3.4s .long 0x6e35dc37 // fmul v23.4s, v1.4s, v21.4s .long 0x4e31ce5b // fmla v27.4s, v18.4s, v17.4s .long 0x4e20ce57 // fmla v23.4s, v18.4s, v0.4s .long 0x4e34cf3b // fmla v27.4s, v25.4s, v20.4s .long 0x6e20df5c // fmul v28.4s, v26.4s, v0.4s .long 0x4e22cf37 // fmla v23.4s, v25.4s, v2.4s .long 0x6ea0fb60 // fneg v0.4s, v27.4s .long 0x6e21df41 // fmul v1.4s, v26.4s, v1.4s .long 0x6e22df5a // fmul v26.4s, v26.4s, v2.4s .long 0x4e37cce0 // fmla v0.4s, v7.4s, v23.4s .long 0x4e23cc9c // fmla v28.4s, v4.4s, v3.4s .long 0x4e23cca1 // fmla v1.4s, v5.4s, v3.4s .long 0x4e23ccda // fmla v26.4s, v6.4s, v3.4s .long 0x4e20d663 // fadd v3.4s, v19.4s, v0.4s .long 0x4e20d622 // fadd v2.4s, v17.4s, v0.4s .long 0x4e20d680 // fadd v0.4s, v20.4s, v0.4s .long 0x6e35dc74 // fmul v20.4s, v3.4s, v21.4s .long 0x4e22ce54 // fmla v20.4s, v18.4s, v2.4s .long 0x4ea0f471 // fmin v17.4s, v3.4s, v0.4s .long 0x4e20cf34 // fmla v20.4s, v25.4s, v0.4s .long 0x4eb1f451 // fmin v17.4s, v2.4s, v17.4s .long 0x4eb4d457 // fsub v23.4s, v2.4s, v20.4s .long 0x6ea0ca32 // fcmge v18.4s, v17.4s, #0.0 .long 0x4eb1d691 // fsub v17.4s, v20.4s, v17.4s .long 0x6e37de97 // fmul v23.4s, v20.4s, v23.4s .long 0x6e31fef7 // fdiv v23.4s, v23.4s, v17.4s .long 0x4e20f473 // fmax v19.4s, v3.4s, v0.4s .long 0x4eb21e59 // mov v25.16b, v18.16b .long 0x4e37d697 // fadd v23.4s, v20.4s, v23.4s .long 0x4e33f453 // fmax v19.4s, v2.4s, v19.4s .long 0x6e771c59 // bsl v25.16b, v2.16b, v23.16b .long 0x4eb4d462 // fsub v2.4s, v3.4s, v20.4s .long 0x6e22de82 // fmul v2.4s, v20.4s, v2.4s .long 0x6e31fc42 // fdiv v2.4s, v2.4s, v17.4s .long 0x4eb21e57 // mov v23.16b, v18.16b .long 0x4e22d682 // fadd v2.4s, v20.4s, v2.4s .long 0x6e621c77 // bsl v23.16b, v3.16b, v2.16b .long 0x4eb4d403 // fsub v3.4s, v0.4s, v20.4s .long 0x6e23de83 // fmul v3.4s, v20.4s, v3.4s .long 0x6e31fc63 // fdiv v3.4s, v3.4s, v17.4s .long 0x4e23d683 // fadd v3.4s, v20.4s, v3.4s .long 0x6e631c12 // bsl v18.16b, v0.16b, v3.16b .long 0x4eb4d61b // fsub v27.4s, v16.4s, v20.4s .long 0x4eb4d720 // fsub v0.4s, v25.4s, v20.4s .long 0x4eb4d6e3 // fsub v3.4s, v23.4s, v20.4s .long 0x4eb4d651 // fsub v17.4s, v18.4s, v20.4s .long 0x6eb0e675 // fcmgt v21.4s, v19.4s, v16.4s .long 0x4eb4d673 // fsub v19.4s, v19.4s, v20.4s .long 0x6e20df60 // fmul v0.4s, v27.4s, v0.4s .long 0x6e23df63 // fmul v3.4s, v27.4s, v3.4s .long 0x6e31df71 // fmul v17.4s, v27.4s, v17.4s .long 0x6e33fc00 // fdiv v0.4s, v0.4s, v19.4s .long 0x6e33fc63 // fdiv v3.4s, v3.4s, v19.4s .long 0x6e33fe31 // fdiv v17.4s, v17.4s, v19.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4eb51ea2 // mov v2.16b, v21.16b .long 0x4eb51ebb // mov v27.16b, v21.16b .long 0x4e20d680 // fadd v0.4s, v20.4s, v0.4s .long 0x4e23d683 // fadd v3.4s, v20.4s, v3.4s .long 0x4e31d691 // fadd v17.4s, v20.4s, v17.4s .long 0x6f00e416 // movi v22.2d, #0x0 .long 0x6e791c02 // bsl v2.16b, v0.16b, v25.16b .long 0x6e771c7b // bsl v27.16b, v3.16b, v23.16b .long 0x6e721e35 // bsl v21.16b, v17.16b, v18.16b .long 0x4e36f440 // fmax v0.4s, v2.4s, v22.4s .long 0x4e36f762 // fmax v2.4s, v27.4s, v22.4s .long 0x4e36f6a3 // fmax v3.4s, v21.4s, v22.4s .long 0x4e20d780 // fadd v0.4s, v28.4s, v0.4s .long 0x4e22d421 // fadd v1.4s, v1.4s, v2.4s .long 0x4e23d742 // fadd v2.4s, v26.4s, v3.4s .long 0x4eb0d703 // fsub v3.4s, v24.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_srcover_rgba_8888_aarch64 .globl _sk_srcover_rgba_8888_aarch64 FUNCTION(_sk_srcover_rgba_8888_aarch64) _sk_srcover_rgba_8888_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897908 // add x8, x8, x9, asr #30 .long 0xb5000504 // cbnz x4, 1168 <_sk_srcover_rgba_8888_aarch64+0xbc> .long 0x3dc00104 // ldr q4, [x8] .long 0x6f00e625 // movi v5.2d, #0xff000000ff .long 0x6f380486 // ushr v6.4s, v4.4s, #8 .long 0x6f300487 // ushr v7.4s, v4.4s, #16 .long 0x6f280490 // ushr v16.4s, v4.4s, #24 .long 0x4f03f611 // fmov v17.4s, #1.000000000000000000e+00 .long 0x52a86fe9 // mov w9, #0x437f0000 .long 0x4e251cc6 // and v6.16b, v6.16b, v5.16b .long 0x4e251cf2 // and v18.16b, v7.16b, v5.16b .long 0x4e21da07 // scvtf v7.4s, v16.4s .long 0x4ea3d630 // fsub v16.4s, v17.4s, v3.4s .long 0x4e040d31 // dup v17.4s, w9 .long 0x4e251c84 // and v4.16b, v4.16b, v5.16b .long 0x4e21d8c5 // scvtf v5.4s, v6.4s .long 0x6e31dc21 // fmul v1.4s, v1.4s, v17.4s .long 0x4e21d884 // scvtf v4.4s, v4.4s .long 0x6e31dc00 // fmul v0.4s, v0.4s, v17.4s .long 0x4e25ce01 // fmla v1.4s, v16.4s, v5.4s .long 0x4e21da46 // scvtf v6.4s, v18.4s .long 0x6e31dc42 // fmul v2.4s, v2.4s, v17.4s .long 0x6e31dc63 // fmul v3.4s, v3.4s, v17.4s .long 0x4e24ce00 // fmla v0.4s, v16.4s, v4.4s .long 0x6e21a831 // fcvtnu v17.4s, v1.4s .long 0x4e26ce02 // fmla v2.4s, v16.4s, v6.4s .long 0x4e27ce03 // fmla v3.4s, v16.4s, v7.4s .long 0x6e21a810 // fcvtnu v16.4s, v0.4s .long 0x4f285631 // shl v17.4s, v17.4s, #8 .long 0x4eb01e30 // orr v16.16b, v17.16b, v16.16b .long 0x6e21a851 // fcvtnu v17.4s, v2.4s .long 0x4f305631 // shl v17.4s, v17.4s, #16 .long 0x4eb11e10 // orr v16.16b, v16.16b, v17.16b .long 0x6e21a871 // fcvtnu v17.4s, v3.4s .long 0x4f385631 // shl v17.4s, v17.4s, #24 .long 0x4eb11e10 // orr v16.16b, v16.16b, v17.16b .long 0xb5000284 // cbnz x4, 11a4 <_sk_srcover_rgba_8888_aarch64+0xf8> .long 0x3d800110 // str q16, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000300 // b.eq 11d0 <_sk_srcover_rgba_8888_aarch64+0x124> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x6f00e404 // movi v4.2d, #0x0 .long 0x540000c0 // b.eq 1194 <_sk_srcover_rgba_8888_aarch64+0xe8> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffa61 // b.ne 10d0 <_sk_srcover_rgba_8888_aarch64+0x24> // b.any .long 0x91002109 // add x9, x8, #0x8 .long 0x4e040fe4 // dup v4.4s, wzr .long 0x4d408124 // ld1 {v4.s}[2], [x9] .long 0xfd400105 // ldr d5, [x8] .long 0x6e054084 // ext v4.16b, v4.16b, v5.16b, #8 .long 0x6e044084 // ext v4.16b, v4.16b, v4.16b, #8 .long 0x17ffffcc // b 10d0 <_sk_srcover_rgba_8888_aarch64+0x24> .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000180 // b.eq 11dc <_sk_srcover_rgba_8888_aarch64+0x130> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x540000a0 // b.eq 11c8 <_sk_srcover_rgba_8888_aarch64+0x11c> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffd01 // b.ne 115c <_sk_srcover_rgba_8888_aarch64+0xb0> // b.any .long 0x91002109 // add x9, x8, #0x8 .long 0x4d008130 // st1 {v16.s}[2], [x9] .long 0xfd000110 // str d16, [x8] .long 0x17ffffe4 // b 115c <_sk_srcover_rgba_8888_aarch64+0xb0> .long 0x4e040fe4 // dup v4.4s, wzr .long 0x0d408104 // ld1 {v4.s}[0], [x8] .long 0x17ffffbe // b 10d0 <_sk_srcover_rgba_8888_aarch64+0x24> .long 0x0d008110 // st1 {v16.s}[0], [x8] .long 0x17ffffdf // b 115c <_sk_srcover_rgba_8888_aarch64+0xb0> HIDDEN _sk_clamp_0_aarch64 .globl _sk_clamp_0_aarch64 FUNCTION(_sk_clamp_0_aarch64) _sk_clamp_0_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6f00e410 // movi v16.2d, #0x0 .long 0x4e30f400 // fmax v0.4s, v0.4s, v16.4s .long 0x4e30f421 // fmax v1.4s, v1.4s, v16.4s .long 0x4e30f442 // fmax v2.4s, v2.4s, v16.4s .long 0x4e30f463 // fmax v3.4s, v3.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_clamp_1_aarch64 .globl _sk_clamp_1_aarch64 FUNCTION(_sk_clamp_1_aarch64) _sk_clamp_1_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4eb0f400 // fmin v0.4s, v0.4s, v16.4s .long 0x4eb0f421 // fmin v1.4s, v1.4s, v16.4s .long 0x4eb0f442 // fmin v2.4s, v2.4s, v16.4s .long 0x4eb0f463 // fmin v3.4s, v3.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_clamp_a_aarch64 .globl _sk_clamp_a_aarch64 FUNCTION(_sk_clamp_a_aarch64) _sk_clamp_a_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4eb0f463 // fmin v3.4s, v3.4s, v16.4s .long 0x4ea3f400 // fmin v0.4s, v0.4s, v3.4s .long 0x4ea3f421 // fmin v1.4s, v1.4s, v3.4s .long 0x4ea3f442 // fmin v2.4s, v2.4s, v3.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_clamp_a_dst_aarch64 .globl _sk_clamp_a_dst_aarch64 FUNCTION(_sk_clamp_a_dst_aarch64) _sk_clamp_a_dst_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4eb0f4e7 // fmin v7.4s, v7.4s, v16.4s .long 0x4ea7f484 // fmin v4.4s, v4.4s, v7.4s .long 0x4ea7f4a5 // fmin v5.4s, v5.4s, v7.4s .long 0x4ea7f4c6 // fmin v6.4s, v6.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_set_rgb_aarch64 .globl _sk_set_rgb_aarch64 FUNCTION(_sk_set_rgb_aarch64) _sk_set_rgb_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xaa0803e9 // mov x9, x8 .long 0x4ddfc920 // ld1r {v0.4s}, [x9], #4 .long 0x91002108 // add x8, x8, #0x8 .long 0x4d40c902 // ld1r {v2.4s}, [x8] .long 0x4d40c921 // ld1r {v1.4s}, [x9] .long 0xd61f00a0 // br x5 HIDDEN _sk_swap_rb_aarch64 .globl _sk_swap_rb_aarch64 FUNCTION(_sk_swap_rb_aarch64) _sk_swap_rb_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4ea01c10 // mov v16.16b, v0.16b .long 0x4ea21c40 // mov v0.16b, v2.16b .long 0x4eb01e02 // mov v2.16b, v16.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_invert_aarch64 .globl _sk_invert_aarch64 FUNCTION(_sk_invert_aarch64) _sk_invert_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4ea0d600 // fsub v0.4s, v16.4s, v0.4s .long 0x4ea1d601 // fsub v1.4s, v16.4s, v1.4s .long 0x4ea2d602 // fsub v2.4s, v16.4s, v2.4s .long 0x4ea3d603 // fsub v3.4s, v16.4s, v3.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_move_src_dst_aarch64 .globl _sk_move_src_dst_aarch64 FUNCTION(_sk_move_src_dst_aarch64) _sk_move_src_dst_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4ea01c04 // mov v4.16b, v0.16b .long 0x4ea11c25 // mov v5.16b, v1.16b .long 0x4ea21c46 // mov v6.16b, v2.16b .long 0x4ea31c67 // mov v7.16b, v3.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_move_dst_src_aarch64 .globl _sk_move_dst_src_aarch64 FUNCTION(_sk_move_dst_src_aarch64) _sk_move_dst_src_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4ea41c80 // mov v0.16b, v4.16b .long 0x4ea51ca1 // mov v1.16b, v5.16b .long 0x4ea61cc2 // mov v2.16b, v6.16b .long 0x4ea71ce3 // mov v3.16b, v7.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_premul_aarch64 .globl _sk_premul_aarch64 FUNCTION(_sk_premul_aarch64) _sk_premul_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e23dc00 // fmul v0.4s, v0.4s, v3.4s .long 0x6e23dc21 // fmul v1.4s, v1.4s, v3.4s .long 0x6e23dc42 // fmul v2.4s, v2.4s, v3.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_premul_dst_aarch64 .globl _sk_premul_dst_aarch64 FUNCTION(_sk_premul_dst_aarch64) _sk_premul_dst_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e27dc84 // fmul v4.4s, v4.4s, v7.4s .long 0x6e27dca5 // fmul v5.4s, v5.4s, v7.4s .long 0x6e27dcc6 // fmul v6.4s, v6.4s, v7.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_unpremul_aarch64 .globl _sk_unpremul_aarch64 FUNCTION(_sk_unpremul_aarch64) _sk_unpremul_aarch64: .long 0x4f03f611 // fmov v17.4s, #1.000000000000000000e+00 .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4ea0d870 // fcmeq v16.4s, v3.4s, #0.0 .long 0x6e23fe31 // fdiv v17.4s, v17.4s, v3.4s .long 0x4e701e30 // bic v16.16b, v17.16b, v16.16b .long 0x6e20de00 // fmul v0.4s, v16.4s, v0.4s .long 0x6e21de01 // fmul v1.4s, v16.4s, v1.4s .long 0x6e22de02 // fmul v2.4s, v16.4s, v2.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_from_srgb_aarch64 .globl _sk_from_srgb_aarch64 FUNCTION(_sk_from_srgb_aarch64) _sk_from_srgb_aarch64: .long 0x52a7d328 // mov w8, #0x3e990000 .long 0x72933348 // movk w8, #0x999a .long 0x4e040d10 // dup v16.4s, w8 .long 0x52a7e648 // mov w8, #0x3f320000 .long 0x7291eb88 // movk w8, #0x8f5c .long 0x4e040d11 // dup v17.4s, w8 .long 0x52a76468 // mov w8, #0x3b230000 .long 0x729ae148 // movk w8, #0xd70a .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a7b3c8 // mov w8, #0x3d9e0000 .long 0x72907228 // movk w8, #0x8391 .long 0x6e22dc54 // fmul v20.4s, v2.4s, v2.4s .long 0x4eb11e35 // mov v21.16b, v17.16b .long 0x4eb11e37 // mov v23.16b, v17.16b .long 0x4e22ce11 // fmla v17.4s, v16.4s, v2.4s .long 0x4eb21e56 // mov v22.16b, v18.16b .long 0x4eb21e58 // mov v24.16b, v18.16b .long 0x4e34ce32 // fmla v18.4s, v17.4s, v20.4s .long 0x4e040d11 // dup v17.4s, w8 .long 0x52a7ac28 // mov w8, #0x3d610000 .long 0x6e20dc13 // fmul v19.4s, v0.4s, v0.4s .long 0x7288f5c8 // movk w8, #0x47ae .long 0x4e20ce15 // fmla v21.4s, v16.4s, v0.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e21dc34 // fmul v20.4s, v1.4s, v1.4s .long 0x4e33ceb6 // fmla v22.4s, v21.4s, v19.4s .long 0x4e040d13 // dup v19.4s, w8 .long 0x4e21ce17 // fmla v23.4s, v16.4s, v1.4s .long 0x6e31dc15 // fmul v21.4s, v0.4s, v17.4s .long 0x6ea0e660 // fcmgt v0.4s, v19.4s, v0.4s .long 0x6e31dc30 // fmul v16.4s, v1.4s, v17.4s .long 0x6ea1e661 // fcmgt v1.4s, v19.4s, v1.4s .long 0x6e31dc51 // fmul v17.4s, v2.4s, v17.4s .long 0x6ea2e662 // fcmgt v2.4s, v19.4s, v2.4s .long 0x4e34cef8 // fmla v24.4s, v23.4s, v20.4s .long 0x6e761ea0 // bsl v0.16b, v21.16b, v22.16b .long 0x6e781e01 // bsl v1.16b, v16.16b, v24.16b .long 0x6e721e22 // bsl v2.16b, v17.16b, v18.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_from_srgb_dst_aarch64 .globl _sk_from_srgb_dst_aarch64 FUNCTION(_sk_from_srgb_dst_aarch64) _sk_from_srgb_dst_aarch64: .long 0x52a7d328 // mov w8, #0x3e990000 .long 0x72933348 // movk w8, #0x999a .long 0x4e040d10 // dup v16.4s, w8 .long 0x52a7e648 // mov w8, #0x3f320000 .long 0x7291eb88 // movk w8, #0x8f5c .long 0x4e040d11 // dup v17.4s, w8 .long 0x52a76468 // mov w8, #0x3b230000 .long 0x729ae148 // movk w8, #0xd70a .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a7b3c8 // mov w8, #0x3d9e0000 .long 0x72907228 // movk w8, #0x8391 .long 0x6e26dcd4 // fmul v20.4s, v6.4s, v6.4s .long 0x4eb11e35 // mov v21.16b, v17.16b .long 0x4eb11e37 // mov v23.16b, v17.16b .long 0x4e26ce11 // fmla v17.4s, v16.4s, v6.4s .long 0x4eb21e56 // mov v22.16b, v18.16b .long 0x4eb21e58 // mov v24.16b, v18.16b .long 0x4e34ce32 // fmla v18.4s, v17.4s, v20.4s .long 0x4e040d11 // dup v17.4s, w8 .long 0x52a7ac28 // mov w8, #0x3d610000 .long 0x6e24dc93 // fmul v19.4s, v4.4s, v4.4s .long 0x7288f5c8 // movk w8, #0x47ae .long 0x4e24ce15 // fmla v21.4s, v16.4s, v4.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e25dcb4 // fmul v20.4s, v5.4s, v5.4s .long 0x4e33ceb6 // fmla v22.4s, v21.4s, v19.4s .long 0x4e040d13 // dup v19.4s, w8 .long 0x4e25ce17 // fmla v23.4s, v16.4s, v5.4s .long 0x6e31dc95 // fmul v21.4s, v4.4s, v17.4s .long 0x6ea4e664 // fcmgt v4.4s, v19.4s, v4.4s .long 0x6e31dcb0 // fmul v16.4s, v5.4s, v17.4s .long 0x6ea5e665 // fcmgt v5.4s, v19.4s, v5.4s .long 0x6e31dcd1 // fmul v17.4s, v6.4s, v17.4s .long 0x6ea6e666 // fcmgt v6.4s, v19.4s, v6.4s .long 0x4e34cef8 // fmla v24.4s, v23.4s, v20.4s .long 0x6e761ea4 // bsl v4.16b, v21.16b, v22.16b .long 0x6e781e05 // bsl v5.16b, v16.16b, v24.16b .long 0x6e721e26 // bsl v6.16b, v17.16b, v18.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_to_srgb_aarch64 .globl _sk_to_srgb_aarch64 FUNCTION(_sk_to_srgb_aarch64) _sk_to_srgb_aarch64: .long 0x52a829c8 // mov w8, #0x414e0000 .long 0x72970a48 // movk w8, #0xb852 .long 0x4e040d11 // dup v17.4s, w8 .long 0x52b76408 // mov w8, #0xbb200000 .long 0x729ae728 // movk w8, #0xd739 .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a77308 // mov w8, #0x3b980000 .long 0x72963508 // movk w8, #0xb1a8 .long 0x6ea1d810 // frsqrte v16.4s, v0.4s .long 0x4e040d13 // dup v19.4s, w8 .long 0x52a78c48 // mov w8, #0x3c620000 .long 0x6ea1d834 // frsqrte v20.4s, v1.4s .long 0x6ea1d855 // frsqrte v21.4s, v2.4s .long 0x7293f748 // movk w8, #0x9fba .long 0x6e30de16 // fmul v22.4s, v16.4s, v16.4s .long 0x6e34de97 // fmul v23.4s, v20.4s, v20.4s .long 0x6e35deb8 // fmul v24.4s, v21.4s, v21.4s .long 0x4eb6fc16 // frsqrts v22.4s, v0.4s, v22.4s .long 0x6e31dc19 // fmul v25.4s, v0.4s, v17.4s .long 0x6ea0e660 // fcmgt v0.4s, v19.4s, v0.4s .long 0x4eb7fc37 // frsqrts v23.4s, v1.4s, v23.4s .long 0x6e31dc3a // fmul v26.4s, v1.4s, v17.4s .long 0x6ea1e661 // fcmgt v1.4s, v19.4s, v1.4s .long 0x4eb8fc58 // frsqrts v24.4s, v2.4s, v24.4s .long 0x6e31dc51 // fmul v17.4s, v2.4s, v17.4s .long 0x6ea2e662 // fcmgt v2.4s, v19.4s, v2.4s .long 0x4e040d13 // dup v19.4s, w8 .long 0x52a7f208 // mov w8, #0x3f900000 .long 0x72947ae8 // movk w8, #0xa3d7 .long 0x6e36de10 // fmul v16.4s, v16.4s, v22.4s .long 0x4e040d16 // dup v22.4s, w8 .long 0x6e37de94 // fmul v20.4s, v20.4s, v23.4s .long 0x4eb31e77 // mov v23.16b, v19.16b .long 0x6e38deb5 // fmul v21.4s, v21.4s, v24.4s .long 0x4eb31e78 // mov v24.16b, v19.16b .long 0x52a7c208 // mov w8, #0x3e100000 .long 0x4e30ce57 // fmla v23.4s, v18.4s, v16.4s .long 0x4e34ce58 // fmla v24.4s, v18.4s, v20.4s .long 0x4e35ce53 // fmla v19.4s, v18.4s, v21.4s .long 0x4eb61ed2 // mov v18.16b, v22.16b .long 0x7298c988 // movk w8, #0xc64c .long 0x4e30cef2 // fmla v18.4s, v23.4s, v16.4s .long 0x4eb61ed7 // mov v23.16b, v22.16b .long 0x4e35ce76 // fmla v22.4s, v19.4s, v21.4s .long 0x4e040d13 // dup v19.4s, w8 .long 0x4e33d610 // fadd v16.4s, v16.4s, v19.4s .long 0x4e34cf17 // fmla v23.4s, v24.4s, v20.4s .long 0x4e33d694 // fadd v20.4s, v20.4s, v19.4s .long 0x4e33d6b3 // fadd v19.4s, v21.4s, v19.4s .long 0x4ea1da15 // frecpe v21.4s, v16.4s .long 0x4e35fe10 // frecps v16.4s, v16.4s, v21.4s .long 0x6e30deb0 // fmul v16.4s, v21.4s, v16.4s .long 0x4ea1da95 // frecpe v21.4s, v20.4s .long 0x4e35fe94 // frecps v20.4s, v20.4s, v21.4s .long 0x6e34deb4 // fmul v20.4s, v21.4s, v20.4s .long 0x4ea1da75 // frecpe v21.4s, v19.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e35fe73 // frecps v19.4s, v19.4s, v21.4s .long 0x6e33deb3 // fmul v19.4s, v21.4s, v19.4s .long 0x6e30de50 // fmul v16.4s, v18.4s, v16.4s .long 0x6e34def2 // fmul v18.4s, v23.4s, v20.4s .long 0x6e33ded3 // fmul v19.4s, v22.4s, v19.4s .long 0x6e701f20 // bsl v0.16b, v25.16b, v16.16b .long 0x6e721f41 // bsl v1.16b, v26.16b, v18.16b .long 0x6e731e22 // bsl v2.16b, v17.16b, v19.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_rgb_to_hsl_aarch64 .globl _sk_rgb_to_hsl_aarch64 FUNCTION(_sk_rgb_to_hsl_aarch64) _sk_rgb_to_hsl_aarch64: .long 0x4e21f410 // fmax v16.4s, v0.4s, v1.4s .long 0x4ea1f411 // fmin v17.4s, v0.4s, v1.4s .long 0x6ea1e454 // fcmgt v20.4s, v2.4s, v1.4s .long 0x4f00f715 // fmov v21.4s, #6.000000000000000000e+00 .long 0x4e22f610 // fmax v16.4s, v16.4s, v2.4s .long 0x4ea2f631 // fmin v17.4s, v17.4s, v2.4s .long 0x4f03f612 // fmov v18.4s, #1.000000000000000000e+00 .long 0x4e341eb4 // and v20.16b, v21.16b, v20.16b .long 0x4eb1d615 // fsub v21.4s, v16.4s, v17.4s .long 0x4ea2d433 // fsub v19.4s, v1.4s, v2.4s .long 0x4ea0d456 // fsub v22.4s, v2.4s, v0.4s .long 0x4f026417 // movi v23.4s, #0x40, lsl #24 .long 0x6e35fe42 // fdiv v2.4s, v18.4s, v21.4s .long 0x4ea1d418 // fsub v24.4s, v0.4s, v1.4s .long 0x4f00f619 // fmov v25.4s, #4.000000000000000000e+00 .long 0x4f0167fa // movi v26.4s, #0x3f, lsl #24 .long 0x4eb0d6f2 // fsub v18.4s, v23.4s, v16.4s .long 0x4e36cc57 // fmla v23.4s, v2.4s, v22.4s .long 0x4e31e616 // fcmeq v22.4s, v16.4s, v17.4s .long 0x4e20e600 // fcmeq v0.4s, v16.4s, v0.4s .long 0x4e21e601 // fcmeq v1.4s, v16.4s, v1.4s .long 0x4e31d610 // fadd v16.4s, v16.4s, v17.4s .long 0x52a7c548 // mov w8, #0x3e2a0000 .long 0x4e33cc54 // fmla v20.4s, v2.4s, v19.4s .long 0x4e38cc59 // fmla v25.4s, v2.4s, v24.4s .long 0x6e3ade02 // fmul v2.4s, v16.4s, v26.4s .long 0x72955568 // movk w8, #0xaaab .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4eb1d651 // fsub v17.4s, v18.4s, v17.4s .long 0x6ebae452 // fcmgt v18.4s, v2.4s, v26.4s .long 0x6e791ee1 // bsl v1.16b, v23.16b, v25.16b .long 0x4e040d13 // dup v19.4s, w8 .long 0x6e701e32 // bsl v18.16b, v17.16b, v16.16b .long 0x6e611e80 // bsl v0.16b, v20.16b, v1.16b .long 0x6e32fea1 // fdiv v1.4s, v21.4s, v18.4s .long 0x6e33dc00 // fmul v0.4s, v0.4s, v19.4s .long 0x4e761c00 // bic v0.16b, v0.16b, v22.16b .long 0x4e761c21 // bic v1.16b, v1.16b, v22.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_hsl_to_rgb_aarch64 .globl _sk_hsl_to_rgb_aarch64 FUNCTION(_sk_hsl_to_rgb_aarch64) _sk_hsl_to_rgb_aarch64: .long 0x52a7d548 // mov w8, #0x3eaa0000 .long 0x72955568 // movk w8, #0xaaab .long 0x4e040d14 // dup v20.4s, w8 .long 0x52a7e548 // mov w8, #0x3f2a0000 .long 0x72955568 // movk w8, #0xaaab .long 0x4f0167f1 // movi v17.4s, #0x3f, lsl #24 .long 0x6e22dc32 // fmul v18.4s, v1.4s, v2.4s .long 0x4e040d17 // dup v23.4s, w8 .long 0x52b7d548 // mov w8, #0xbeaa0000 .long 0x4ea0d830 // fcmeq v16.4s, v1.4s, #0.0 .long 0x72955568 // movk w8, #0xaaab .long 0x6e31e45a // fcmge v26.4s, v2.4s, v17.4s .long 0x4eb2d421 // fsub v1.4s, v1.4s, v18.4s .long 0x4e040d18 // dup v24.4s, w8 .long 0x4e219819 // frintm v25.4s, v0.4s .long 0x6e721c3a // bsl v26.16b, v1.16b, v18.16b .long 0x4e34d401 // fadd v1.4s, v0.4s, v20.4s .long 0x4eb9d419 // fsub v25.4s, v0.4s, v25.4s .long 0x4e38d400 // fadd v0.4s, v0.4s, v24.4s .long 0x4e22d754 // fadd v20.4s, v26.4s, v2.4s .long 0x4e219838 // frintm v24.4s, v1.4s .long 0x4f026413 // movi v19.4s, #0x40, lsl #24 .long 0x4f00f715 // fmov v21.4s, #6.000000000000000000e+00 .long 0x4e21981b // frintm v27.4s, v0.4s .long 0x6ea0fa9c // fneg v28.4s, v20.4s .long 0x4eb8d421 // fsub v1.4s, v1.4s, v24.4s .long 0x4f00f616 // fmov v22.4s, #4.000000000000000000e+00 .long 0x4ebbd418 // fsub v24.4s, v0.4s, v27.4s .long 0x4e22ce7c // fmla v28.4s, v19.4s, v2.4s .long 0x6e35dc20 // fmul v0.4s, v1.4s, v21.4s .long 0x6e35df32 // fmul v18.4s, v25.4s, v21.4s .long 0x6e35df13 // fmul v19.4s, v24.4s, v21.4s .long 0x4ebcd695 // fsub v21.4s, v20.4s, v28.4s .long 0x4ea0d6db // fsub v27.4s, v22.4s, v0.4s .long 0x4ebc1f9d // mov v29.16b, v28.16b .long 0x4e3bcebd // fmla v29.4s, v21.4s, v27.4s .long 0x4ebc1f9b // mov v27.16b, v28.16b .long 0x4eb2d6da // fsub v26.4s, v22.4s, v18.4s .long 0x4e20cebb // fmla v27.4s, v21.4s, v0.4s .long 0x4ebc1f80 // mov v0.16b, v28.16b .long 0x4e3acea0 // fmla v0.4s, v21.4s, v26.4s .long 0x4ebc1f9a // mov v26.16b, v28.16b .long 0x4eb3d6d6 // fsub v22.4s, v22.4s, v19.4s .long 0x4e32ceba // fmla v26.4s, v21.4s, v18.4s .long 0x4ebc1f92 // mov v18.16b, v28.16b .long 0x52a7c548 // mov w8, #0x3e2a0000 .long 0x4e36ceb2 // fmla v18.4s, v21.4s, v22.4s .long 0x6e37e436 // fcmge v22.4s, v1.4s, v23.4s .long 0x72955568 // movk w8, #0xaaab .long 0x6e7d1f96 // bsl v22.16b, v28.16b, v29.16b .long 0x6e37e73d // fcmge v29.4s, v25.4s, v23.4s .long 0x6e37e717 // fcmge v23.4s, v24.4s, v23.4s .long 0x6e601f9d // bsl v29.16b, v28.16b, v0.16b .long 0x4e040d1e // dup v30.4s, w8 .long 0x6e721f97 // bsl v23.16b, v28.16b, v18.16b .long 0x4e33cebc // fmla v28.4s, v21.4s, v19.4s .long 0x6e31e732 // fcmge v18.4s, v25.4s, v17.4s .long 0x6e31e435 // fcmge v21.4s, v1.4s, v17.4s .long 0x6e31e711 // fcmge v17.4s, v24.4s, v17.4s .long 0x6e3ee718 // fcmge v24.4s, v24.4s, v30.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e741ef1 // bsl v17.16b, v23.16b, v20.16b .long 0x6e3ee733 // fcmge v19.4s, v25.4s, v30.4s .long 0x6e3ee439 // fcmge v25.4s, v1.4s, v30.4s .long 0x6e741ed5 // bsl v21.16b, v22.16b, v20.16b .long 0x6e741fb2 // bsl v18.16b, v29.16b, v20.16b .long 0x6e7c1e38 // bsl v24.16b, v17.16b, v28.16b .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4eb01e01 // mov v1.16b, v16.16b .long 0x6e7b1eb9 // bsl v25.16b, v21.16b, v27.16b .long 0x6e7a1e53 // bsl v19.16b, v18.16b, v26.16b .long 0x6e781c50 // bsl v16.16b, v2.16b, v24.16b .long 0x6e791c40 // bsl v0.16b, v2.16b, v25.16b .long 0x6e731c41 // bsl v1.16b, v2.16b, v19.16b .long 0x4eb01e02 // mov v2.16b, v16.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_scale_1_float_aarch64 .globl _sk_scale_1_float_aarch64 FUNCTION(_sk_scale_1_float_aarch64) _sk_scale_1_float_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xbd400110 // ldr s16, [x8] .long 0x4f909000 // fmul v0.4s, v0.4s, v16.s[0] .long 0x4f909021 // fmul v1.4s, v1.4s, v16.s[0] .long 0x4f909042 // fmul v2.4s, v2.4s, v16.s[0] .long 0x4f909063 // fmul v3.4s, v3.4s, v16.s[0] .long 0xd61f00a0 // br x5 HIDDEN _sk_scale_u8_aarch64 .globl _sk_scale_u8_aarch64 FUNCTION(_sk_scale_u8_aarch64) _sk_scale_u8_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x93407c6a // sxtw x10, w3 .long 0xf9400109 // ldr x9, [x8] .long 0xb9800908 // ldrsw x8, [x8, #8] .long 0x9b0a2508 // madd x8, x8, x10, x9 .long 0x8b22c108 // add x8, x8, w2, sxtw .long 0xb50002e4 // cbnz x4, 17b8 <_sk_scale_u8_aarch64+0x74> .long 0x39400109 // ldrb w9, [x8] .long 0x3940050a // ldrb w10, [x8, #1] .long 0x3940090b // ldrb w11, [x8, #2] .long 0x39400d08 // ldrb w8, [x8, #3] .long 0x4e021d30 // mov v16.h[0], w9 .long 0x4e061d50 // mov v16.h[1], w10 .long 0x4e0a1d70 // mov v16.h[2], w11 .long 0x4e0e1d10 // mov v16.h[3], w8 .long 0x2f07b7f0 // bic v16.4h, #0xff, lsl #8 .long 0x52a77008 // mov w8, #0x3b800000 .long 0x72901028 // movk w8, #0x8081 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x2f10a610 // uxtl v16.4s, v16.4h .long 0x4e040d11 // dup v17.4s, w8 .long 0x6e21da10 // ucvtf v16.4s, v16.4s .long 0x6e31de10 // fmul v16.4s, v16.4s, v17.4s .long 0x6e20de00 // fmul v0.4s, v16.4s, v0.4s .long 0x6e21de01 // fmul v1.4s, v16.4s, v1.4s .long 0x6e22de02 // fmul v2.4s, v16.4s, v2.4s .long 0x6e23de03 // fmul v3.4s, v16.4s, v3.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 1804 <_sk_scale_u8_aarch64+0xc0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e410 // movi d16, #0x0 .long 0x540000c0 // b.eq 17e4 <_sk_scale_u8_aarch64+0xa0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffd61 // b.ne 1780 <_sk_scale_u8_aarch64+0x3c> // b.any .long 0x39400909 // ldrb w9, [x8, #2] .long 0x0e020ff0 // dup v16.4h, wzr .long 0x4e0a1d30 // mov v16.h[2], w9 .long 0x39400109 // ldrb w9, [x8] .long 0x39400508 // ldrb w8, [x8, #1] .long 0x4e041d31 // mov v17.s[0], w9 .long 0x4e0c1d11 // mov v17.s[1], w8 .long 0x0e401a31 // uzp1 v17.4h, v17.4h, v0.4h .long 0x2e112210 // ext v16.8b, v16.8b, v17.8b, #4 .long 0x2e102210 // ext v16.8b, v16.8b, v16.8b, #4 .long 0x17ffffe0 // b 1780 <_sk_scale_u8_aarch64+0x3c> .long 0x39400108 // ldrb w8, [x8] .long 0x0e020ff0 // dup v16.4h, wzr .long 0x4e021d10 // mov v16.h[0], w8 .long 0x17ffffdc // b 1780 <_sk_scale_u8_aarch64+0x3c> HIDDEN _sk_lerp_1_float_aarch64 .globl _sk_lerp_1_float_aarch64 FUNCTION(_sk_lerp_1_float_aarch64) _sk_lerp_1_float_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ea4d411 // fsub v17.4s, v0.4s, v4.4s .long 0x4ea41c80 // mov v0.16b, v4.16b .long 0x4ea5d432 // fsub v18.4s, v1.4s, v5.4s .long 0xbd400110 // ldr s16, [x8] .long 0x4ea51ca1 // mov v1.16b, v5.16b .long 0x4f901220 // fmla v0.4s, v17.4s, v16.s[0] .long 0x4ea6d451 // fsub v17.4s, v2.4s, v6.4s .long 0x4f901241 // fmla v1.4s, v18.4s, v16.s[0] .long 0x4ea61cc2 // mov v2.16b, v6.16b .long 0x4ea7d472 // fsub v18.4s, v3.4s, v7.4s .long 0x4ea71ce3 // mov v3.16b, v7.16b .long 0x4f901222 // fmla v2.4s, v17.4s, v16.s[0] .long 0x4f901243 // fmla v3.4s, v18.4s, v16.s[0] .long 0xd61f00a0 // br x5 HIDDEN _sk_lerp_u8_aarch64 .globl _sk_lerp_u8_aarch64 FUNCTION(_sk_lerp_u8_aarch64) _sk_lerp_u8_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x93407c6a // sxtw x10, w3 .long 0xf9400109 // ldr x9, [x8] .long 0xb9800908 // ldrsw x8, [x8, #8] .long 0x9b0a2508 // madd x8, x8, x10, x9 .long 0x8b22c108 // add x8, x8, w2, sxtw .long 0xb50003e4 // cbnz x4, 18e4 <_sk_lerp_u8_aarch64+0x94> .long 0x39400109 // ldrb w9, [x8] .long 0x3940050a // ldrb w10, [x8, #1] .long 0x3940090b // ldrb w11, [x8, #2] .long 0x39400d08 // ldrb w8, [x8, #3] .long 0x4e021d30 // mov v16.h[0], w9 .long 0x4e061d50 // mov v16.h[1], w10 .long 0x4e0a1d70 // mov v16.h[2], w11 .long 0x4e0e1d10 // mov v16.h[3], w8 .long 0x2f07b7f0 // bic v16.4h, #0xff, lsl #8 .long 0x52a77008 // mov w8, #0x3b800000 .long 0x72901028 // movk w8, #0x8081 .long 0x4ea4d411 // fsub v17.4s, v0.4s, v4.4s .long 0x2f10a600 // uxtl v0.4s, v16.4h .long 0x4e040d10 // dup v16.4s, w8 .long 0x6e21d800 // ucvtf v0.4s, v0.4s .long 0xf9400425 // ldr x5, [x1, #8] .long 0x6e30dc10 // fmul v16.4s, v0.4s, v16.4s .long 0x4ea41c80 // mov v0.16b, v4.16b .long 0x4ea5d432 // fsub v18.4s, v1.4s, v5.4s .long 0x4ea51ca1 // mov v1.16b, v5.16b .long 0x4e31ce00 // fmla v0.4s, v16.4s, v17.4s .long 0x4ea6d451 // fsub v17.4s, v2.4s, v6.4s .long 0x4e32ce01 // fmla v1.4s, v16.4s, v18.4s .long 0x4ea61cc2 // mov v2.16b, v6.16b .long 0x4ea7d472 // fsub v18.4s, v3.4s, v7.4s .long 0x4ea71ce3 // mov v3.16b, v7.16b .long 0x4e31ce02 // fmla v2.4s, v16.4s, v17.4s .long 0x4e32ce03 // fmla v3.4s, v16.4s, v18.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 1930 <_sk_lerp_u8_aarch64+0xe0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e410 // movi d16, #0x0 .long 0x540000c0 // b.eq 1910 <_sk_lerp_u8_aarch64+0xc0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffc61 // b.ne 188c <_sk_lerp_u8_aarch64+0x3c> // b.any .long 0x39400909 // ldrb w9, [x8, #2] .long 0x0e020ff0 // dup v16.4h, wzr .long 0x4e0a1d30 // mov v16.h[2], w9 .long 0x39400109 // ldrb w9, [x8] .long 0x39400508 // ldrb w8, [x8, #1] .long 0x4e041d31 // mov v17.s[0], w9 .long 0x4e0c1d11 // mov v17.s[1], w8 .long 0x0e401a31 // uzp1 v17.4h, v17.4h, v0.4h .long 0x2e112210 // ext v16.8b, v16.8b, v17.8b, #4 .long 0x2e102210 // ext v16.8b, v16.8b, v16.8b, #4 .long 0x17ffffd8 // b 188c <_sk_lerp_u8_aarch64+0x3c> .long 0x39400108 // ldrb w8, [x8] .long 0x0e020ff0 // dup v16.4h, wzr .long 0x4e021d10 // mov v16.h[0], w8 .long 0x17ffffd4 // b 188c <_sk_lerp_u8_aarch64+0x3c> HIDDEN _sk_lerp_565_aarch64 .globl _sk_lerp_565_aarch64 FUNCTION(_sk_lerp_565_aarch64) _sk_lerp_565_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897d08 // add x8, x8, x9, asr #31 .long 0xb50005c4 // cbnz x4, 1a14 <_sk_lerp_565_aarch64+0xd4> .long 0xfd400110 // ldr d16, [x8] .long 0x321b17e8 // orr w8, wzr, #0x7e0 .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a6f088 // mov w8, #0x37840000 .long 0x2f10a610 // uxtl v16.4s, v16.4h .long 0x4f072711 // movi v17.4s, #0xf8, lsl #8 .long 0x72842108 // movk w8, #0x2108 .long 0x4f0007f3 // movi v19.4s, #0x1f .long 0x4e311e11 // and v17.16b, v16.16b, v17.16b .long 0x4e331e13 // and v19.16b, v16.16b, v19.16b .long 0x4e321e10 // and v16.16b, v16.16b, v18.16b .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a7a088 // mov w8, #0x3d040000 .long 0x72842108 // movk w8, #0x2108 .long 0x4e21da31 // scvtf v17.4s, v17.4s .long 0x6e32de31 // fmul v17.4s, v17.4s, v18.4s .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a74048 // mov w8, #0x3a020000 .long 0x72810428 // movk w8, #0x821 .long 0x4ea4d414 // fsub v20.4s, v0.4s, v4.4s .long 0x4e21da60 // scvtf v0.4s, v19.4s .long 0x6e32dc12 // fmul v18.4s, v0.4s, v18.4s .long 0x4e040d00 // dup v0.4s, w8 .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x6e20de10 // fmul v16.4s, v16.4s, v0.4s .long 0x4ea41c80 // mov v0.16b, v4.16b .long 0x4e34ce20 // fmla v0.4s, v17.4s, v20.4s .long 0x4ea7d463 // fsub v3.4s, v3.4s, v7.4s .long 0x4ea71cf4 // mov v20.16b, v7.16b .long 0x4ea5d433 // fsub v19.4s, v1.4s, v5.4s .long 0x4ea6d441 // fsub v1.4s, v2.4s, v6.4s .long 0x4ea61cc2 // mov v2.16b, v6.16b .long 0x4e23ce34 // fmla v20.4s, v17.4s, v3.4s .long 0x4ea71cf1 // mov v17.16b, v7.16b .long 0x4e21ce42 // fmla v2.4s, v18.4s, v1.4s .long 0x4e23ce51 // fmla v17.4s, v18.4s, v3.4s .long 0x4ea71cf2 // mov v18.16b, v7.16b .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4e23ce12 // fmla v18.4s, v16.4s, v3.4s .long 0x4ea51ca1 // mov v1.16b, v5.16b .long 0x4e31f643 // fmax v3.4s, v18.4s, v17.4s .long 0x4e33ce01 // fmla v1.4s, v16.4s, v19.4s .long 0x4e23f683 // fmax v3.4s, v20.4s, v3.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 1a60 <_sk_lerp_565_aarch64+0x120> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e410 // movi d16, #0x0 .long 0x540000c0 // b.eq 1a40 <_sk_lerp_565_aarch64+0x100> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fff9a1 // b.ne 1964 <_sk_lerp_565_aarch64+0x24> // b.any .long 0x91001109 // add x9, x8, #0x4 .long 0x0e020ff0 // dup v16.4h, wzr .long 0x0d405130 // ld1 {v16.h}[2], [x9] .long 0x79400109 // ldrh w9, [x8] .long 0x79400508 // ldrh w8, [x8, #2] .long 0x4e041d31 // mov v17.s[0], w9 .long 0x4e0c1d11 // mov v17.s[1], w8 .long 0x0e401a31 // uzp1 v17.4h, v17.4h, v0.4h .long 0x2e112210 // ext v16.8b, v16.8b, v17.8b, #4 .long 0x2e102210 // ext v16.8b, v16.8b, v16.8b, #4 .long 0x17ffffc2 // b 1964 <_sk_lerp_565_aarch64+0x24> .long 0x0e020ff0 // dup v16.4h, wzr .long 0x0d404110 // ld1 {v16.h}[0], [x8] .long 0x17ffffbf // b 1964 <_sk_lerp_565_aarch64+0x24> HIDDEN _sk_load_tables_aarch64 .globl _sk_load_tables_aarch64 FUNCTION(_sk_load_tables_aarch64) _sk_load_tables_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xf9400109 // ldr x9, [x8] .long 0x8b020929 // add x9, x9, x2, lsl #2 .long 0xb50006e4 // cbnz x4, 1b54 <_sk_load_tables_aarch64+0xe8> .long 0x3dc00122 // ldr q2, [x9] .long 0xa940a909 // ldp x9, x10, [x8, #8] .long 0x6f00e620 // movi v0.2d, #0xff000000ff .long 0x6f380441 // ushr v1.4s, v2.4s, #8 .long 0x4e201c50 // and v16.16b, v2.16b, v0.16b .long 0x4e201c21 // and v1.16b, v1.16b, v0.16b .long 0x1e26020e // fmov w14, s16 .long 0xf9400d08 // ldr x8, [x8, #24] .long 0x6f300443 // ushr v3.4s, v2.4s, #16 .long 0x1e260025 // fmov w5, s1 .long 0x8b2e492e // add x14, x9, w14, uxtw #2 .long 0x52a7700b // mov w11, #0x3b800000 .long 0x4e201c63 // and v3.16b, v3.16b, v0.16b .long 0x0d4081c0 // ld1 {v0.s}[0], [x14] .long 0x8b254945 // add x5, x10, w5, uxtw #2 .long 0x7290102b // movk w11, #0x8081 .long 0x0e0c3c2f // mov w15, v1.s[1] .long 0x0e143c30 // mov w16, v1.s[2] .long 0x0e1c3c31 // mov w17, v1.s[3] .long 0x0d4080a1 // ld1 {v1.s}[0], [x5] .long 0x4e040d71 // dup v17.4s, w11 .long 0x0e0c3e0b // mov w11, v16.s[1] .long 0x1e26006e // fmov w14, s3 .long 0x6f280442 // ushr v2.4s, v2.4s, #24 .long 0x0e143e0c // mov w12, v16.s[2] .long 0xbc705952 // ldr s18, [x10, w16, uxtw #2] .long 0x0e143c70 // mov w16, v3.s[2] .long 0x4e21d842 // scvtf v2.4s, v2.4s .long 0x8b2e490e // add x14, x8, w14, uxtw #2 .long 0x8b2b492b // add x11, x9, w11, uxtw #2 .long 0x0e1c3e0d // mov w13, v16.s[3] .long 0xbc6c5930 // ldr s16, [x9, w12, uxtw #2] .long 0x0e0c3c6c // mov w12, v3.s[1] .long 0xbc705913 // ldr s19, [x8, w16, uxtw #2] .long 0x0e1c3c70 // mov w16, v3.s[3] .long 0x6e31dc43 // fmul v3.4s, v2.4s, v17.4s .long 0x0d4081c2 // ld1 {v2.s}[0], [x14] .long 0x0d409160 // ld1 {v0.s}[1], [x11] .long 0x8b2f494b // add x11, x10, w15, uxtw #2 .long 0x0d409161 // ld1 {v1.s}[1], [x11] .long 0x8b2c490b // add x11, x8, w12, uxtw #2 .long 0x0d409162 // ld1 {v2.s}[1], [x11] .long 0x6e140600 // mov v0.s[2], v16.s[0] .long 0xbc6d5930 // ldr s16, [x9, w13, uxtw #2] .long 0x6e140641 // mov v1.s[2], v18.s[0] .long 0xbc715951 // ldr s17, [x10, w17, uxtw #2] .long 0xbc705912 // ldr s18, [x8, w16, uxtw #2] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x6e140662 // mov v2.s[2], v19.s[0] .long 0x6e1c0600 // mov v0.s[3], v16.s[0] .long 0x6e1c0621 // mov v1.s[3], v17.s[0] .long 0x6e1c0642 // mov v2.s[3], v18.s[0] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x1200048a // and w10, w4, #0x3 .long 0x7100055f // cmp w10, #0x1 .long 0x540001a0 // b.eq 1b90 <_sk_load_tables_aarch64+0x124> // b.none .long 0x7100095f // cmp w10, #0x2 .long 0x6f00e402 // movi v2.2d, #0x0 .long 0x540000c0 // b.eq 1b80 <_sk_load_tables_aarch64+0x114> // b.none .long 0x71000d5f // cmp w10, #0x3 .long 0x54fff881 // b.ne 1a80 <_sk_load_tables_aarch64+0x14> // b.any .long 0x9100212a // add x10, x9, #0x8 .long 0x4e040fe2 // dup v2.4s, wzr .long 0x4d408142 // ld1 {v2.s}[2], [x10] .long 0xfd400120 // ldr d0, [x9] .long 0x6e004040 // ext v0.16b, v2.16b, v0.16b, #8 .long 0x6e004002 // ext v2.16b, v0.16b, v0.16b, #8 .long 0x17ffffbd // b 1a80 <_sk_load_tables_aarch64+0x14> .long 0x4e040fe2 // dup v2.4s, wzr .long 0x0d408122 // ld1 {v2.s}[0], [x9] .long 0x17ffffba // b 1a80 <_sk_load_tables_aarch64+0x14> HIDDEN _sk_load_tables_u16_be_aarch64 .globl _sk_load_tables_u16_be_aarch64 FUNCTION(_sk_load_tables_u16_be_aarch64) _sk_load_tables_u16_be_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xf9400109 // ldr x9, [x8] .long 0x8b020d29 // add x9, x9, x2, lsl #3 .long 0xb5000744 // cbnz x4, 1c90 <_sk_load_tables_u16_be_aarch64+0xf4> .long 0x0c400520 // ld4 {v0.4h-v3.4h}, [x9] .long 0xa940a909 // ldp x9, x10, [x8, #8] .long 0x2f07b7e0 // bic v0.4h, #0xff, lsl #8 .long 0x52a6f00b // mov w11, #0x37800000 .long 0x7280100b // movk w11, #0x80 .long 0x2f10a410 // uxtl v16.4s, v0.4h .long 0x2f07b7e1 // bic v1.4h, #0xff, lsl #8 .long 0xf9400d08 // ldr x8, [x8, #24] .long 0x4e040d71 // dup v17.4s, w11 .long 0x0e0c3e0b // mov w11, v16.s[1] .long 0x0e143e0c // mov w12, v16.s[2] .long 0x0e1c3e0d // mov w13, v16.s[3] .long 0x1e26020e // fmov w14, s16 .long 0x2f10a430 // uxtl v16.4s, v1.4h .long 0x2f07b7e2 // bic v2.4h, #0xff, lsl #8 .long 0x0e0c3e0f // mov w15, v16.s[1] .long 0xbc6c5932 // ldr s18, [x9, w12, uxtw #2] .long 0x0e143e0c // mov w12, v16.s[2] .long 0xbc6d5933 // ldr s19, [x9, w13, uxtw #2] .long 0x0e1c3e0d // mov w13, v16.s[3] .long 0x8b2e492e // add x14, x9, w14, uxtw #2 .long 0x8b2b4929 // add x9, x9, w11, uxtw #2 .long 0x1e26020b // fmov w11, s16 .long 0x2f10a450 // uxtl v16.4s, v2.4h .long 0x0f185474 // shl v20.4h, v3.4h, #8 .long 0x2f180462 // ushr v2.4h, v3.4h, #8 .long 0x0ea21e82 // orr v2.8b, v20.8b, v2.8b .long 0x8b2b494b // add x11, x10, w11, uxtw #2 .long 0x0d4081c0 // ld1 {v0.s}[0], [x14] .long 0x1e26020e // fmov w14, s16 .long 0x2f10a442 // uxtl v2.4s, v2.4h .long 0x0d408161 // ld1 {v1.s}[0], [x11] .long 0x8b2e490b // add x11, x8, w14, uxtw #2 .long 0x6e21d842 // ucvtf v2.4s, v2.4s .long 0x6e31dc43 // fmul v3.4s, v2.4s, v17.4s .long 0x0d408162 // ld1 {v2.s}[0], [x11] .long 0x8b2f494f // add x15, x10, w15, uxtw #2 .long 0xbc6c5955 // ldr s21, [x10, w12, uxtw #2] .long 0xbc6d5956 // ldr s22, [x10, w13, uxtw #2] .long 0x0e0c3e0a // mov w10, v16.s[1] .long 0x0e143e0c // mov w12, v16.s[2] .long 0x0d409120 // ld1 {v0.s}[1], [x9] .long 0x8b2a4909 // add x9, x8, w10, uxtw #2 .long 0x0e1c3e0d // mov w13, v16.s[3] .long 0xbc6c5910 // ldr s16, [x8, w12, uxtw #2] .long 0x0d4091e1 // ld1 {v1.s}[1], [x15] .long 0x0d409122 // ld1 {v2.s}[1], [x9] .long 0xbc6d5911 // ldr s17, [x8, w13, uxtw #2] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x6e140640 // mov v0.s[2], v18.s[0] .long 0x6e1406a1 // mov v1.s[2], v21.s[0] .long 0x6e140602 // mov v2.s[2], v16.s[0] .long 0x6e1c0660 // mov v0.s[3], v19.s[0] .long 0x6e1c06c1 // mov v1.s[3], v22.s[0] .long 0x6e1c0622 // mov v2.s[3], v17.s[0] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x0d606120 // ld4 {v0.h-v3.h}[0], [x9] .long 0xf100049f // cmp x4, #0x1 .long 0x54fff8c0 // b.eq 1bb0 <_sk_load_tables_u16_be_aarch64+0x14> // b.none .long 0x9100212a // add x10, x9, #0x8 .long 0x0d606940 // ld4 {v0.h-v3.h}[1], [x10] .long 0xf1000c9f // cmp x4, #0x3 .long 0x54fff843 // b.cc 1bb0 <_sk_load_tables_u16_be_aarch64+0x14> // b.lo, b.ul, b.last .long 0x91004129 // add x9, x9, #0x10 .long 0x0d607120 // ld4 {v0.h-v3.h}[2], [x9] .long 0x17ffffbf // b 1bb0 <_sk_load_tables_u16_be_aarch64+0x14> HIDDEN _sk_load_tables_rgb_u16_be_aarch64 .globl _sk_load_tables_rgb_u16_be_aarch64 FUNCTION(_sk_load_tables_rgb_u16_be_aarch64) _sk_load_tables_rgb_u16_be_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x321f07ea // orr w10, wzr, #0x6 .long 0xf9400109 // ldr x9, [x8] .long 0x9b0a2449 // madd x9, x2, x10, x9 .long 0xb5000664 // cbnz x4, 1d94 <_sk_load_tables_rgb_u16_be_aarch64+0xdc> .long 0x0c404520 // ld3 {v0.4h-v2.4h}, [x9] .long 0xa940a909 // ldp x9, x10, [x8, #8] .long 0x2f07b7e0 // bic v0.4h, #0xff, lsl #8 .long 0x2f10a403 // uxtl v3.4s, v0.4h .long 0x2f07b7e1 // bic v1.4h, #0xff, lsl #8 .long 0xf9400d0b // ldr x11, [x8, #24] .long 0x0e0c3c68 // mov w8, v3.s[1] .long 0x0e143c6c // mov w12, v3.s[2] .long 0x0e1c3c6d // mov w13, v3.s[3] .long 0x1e26006e // fmov w14, s3 .long 0x2f10a423 // uxtl v3.4s, v1.4h .long 0x2f07b7e2 // bic v2.4h, #0xff, lsl #8 .long 0xbc6c5930 // ldr s16, [x9, w12, uxtw #2] .long 0xbc6d5931 // ldr s17, [x9, w13, uxtw #2] .long 0x8b2e492e // add x14, x9, w14, uxtw #2 .long 0x8b284928 // add x8, x9, w8, uxtw #2 .long 0x1e260069 // fmov w9, s3 .long 0x2f10a442 // uxtl v2.4s, v2.4h .long 0x8b294949 // add x9, x10, w9, uxtw #2 .long 0x0d4081c0 // ld1 {v0.s}[0], [x14] .long 0x0e143c4e // mov w14, v2.s[2] .long 0x0d408121 // ld1 {v1.s}[0], [x9] .long 0xbc6e5972 // ldr s18, [x11, w14, uxtw #2] .long 0x1e26004e // fmov w14, s2 .long 0x0e0c3c6f // mov w15, v3.s[1] .long 0x0e143c6c // mov w12, v3.s[2] .long 0x8b2e496e // add x14, x11, w14, uxtw #2 .long 0x0e1c3c6d // mov w13, v3.s[3] .long 0xbc6c5943 // ldr s3, [x10, w12, uxtw #2] .long 0x0e0c3c4c // mov w12, v2.s[1] .long 0x0e1c3c49 // mov w9, v2.s[3] .long 0x0d4081c2 // ld1 {v2.s}[0], [x14] .long 0x0d409100 // ld1 {v0.s}[1], [x8] .long 0x8b2f4948 // add x8, x10, w15, uxtw #2 .long 0x0d409101 // ld1 {v1.s}[1], [x8] .long 0x8b2c4968 // add x8, x11, w12, uxtw #2 .long 0x0d409102 // ld1 {v2.s}[1], [x8] .long 0x6e140600 // mov v0.s[2], v16.s[0] .long 0xbc6d5950 // ldr s16, [x10, w13, uxtw #2] .long 0x6e140461 // mov v1.s[2], v3.s[0] .long 0xbc695963 // ldr s3, [x11, w9, uxtw #2] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004028 // add x8, x1, #0x10 .long 0x6e140642 // mov v2.s[2], v18.s[0] .long 0x6e1c0620 // mov v0.s[3], v17.s[0] .long 0x6e1c0601 // mov v1.s[3], v16.s[0] .long 0x6e1c0462 // mov v2.s[3], v3.s[0] .long 0x4f03f603 // fmov v3.4s, #1.000000000000000000e+00 .long 0xaa0803e1 // mov x1, x8 .long 0xd61f00a0 // br x5 .long 0x0d406120 // ld3 {v0.h-v2.h}[0], [x9] .long 0xf100049f // cmp x4, #0x1 .long 0x54fff9a0 // b.eq 1cd0 <_sk_load_tables_rgb_u16_be_aarch64+0x18> // b.none .long 0x9100192a // add x10, x9, #0x6 .long 0x0d406940 // ld3 {v0.h-v2.h}[1], [x10] .long 0xf1000c9f // cmp x4, #0x3 .long 0x54fff923 // b.cc 1cd0 <_sk_load_tables_rgb_u16_be_aarch64+0x18> // b.lo, b.ul, b.last .long 0x91003129 // add x9, x9, #0xc .long 0x0d407120 // ld3 {v0.h-v2.h}[2], [x9] .long 0x17ffffc6 // b 1cd0 <_sk_load_tables_rgb_u16_be_aarch64+0x18> HIDDEN _sk_byte_tables_aarch64 .globl _sk_byte_tables_aarch64 FUNCTION(_sk_byte_tables_aarch64) _sk_byte_tables_aarch64: .long 0xd10103ff // sub sp, sp, #0x40 .long 0xaa0103e8 // mov x8, x1 .long 0x91002109 // add x9, x8, #0x8 .long 0xa9015ff8 // stp x24, x23, [sp, #16] .long 0xa90257f6 // stp x22, x21, [sp, #32] .long 0xa9034ff4 // stp x20, x19, [sp, #48] .long 0xf90007e9 // str x9, [sp, #8] .long 0xf8410429 // ldr x9, [x1], #16 .long 0x52a86fea // mov w10, #0x437f0000 .long 0x4e040d51 // dup v17.4s, w10 .long 0x52a7700b // mov w11, #0x3b800000 .long 0xa9405d34 // ldp x20, x23, [x9] .long 0x6e31dc00 // fmul v0.4s, v0.4s, v17.4s .long 0x7290102b // movk w11, #0x8081 .long 0x6e21a800 // fcvtnu v0.4s, v0.4s .long 0x4e040d70 // dup v16.4s, w11 .long 0x0e0c3c0a // mov w10, v0.s[1] .long 0x0e143c0b // mov w11, v0.s[2] .long 0x0e1c3c0c // mov w12, v0.s[3] .long 0x1e26000d // fmov w13, s0 .long 0x386d4a8d // ldrb w13, [x20, w13, uxtw] .long 0x386a4a8a // ldrb w10, [x20, w10, uxtw] .long 0x386b4a8b // ldrb w11, [x20, w11, uxtw] .long 0x386c4a8c // ldrb w12, [x20, w12, uxtw] .long 0xa9412534 // ldp x20, x9, [x9, #16] .long 0x6e31dc42 // fmul v2.4s, v2.4s, v17.4s .long 0x6e31dc21 // fmul v1.4s, v1.4s, v17.4s .long 0x6e31dc63 // fmul v3.4s, v3.4s, v17.4s .long 0x6e21a842 // fcvtnu v2.4s, v2.4s .long 0x6e21a821 // fcvtnu v1.4s, v1.4s .long 0x6e21a863 // fcvtnu v3.4s, v3.4s .long 0x0e0c3c45 // mov w5, v2.s[1] .long 0x0e143c46 // mov w6, v2.s[2] .long 0x0e1c3c47 // mov w7, v2.s[3] .long 0x1e260053 // fmov w19, s2 .long 0x1e260031 // fmov w17, s1 .long 0x38734a93 // ldrb w19, [x20, w19, uxtw] .long 0x38654a85 // ldrb w5, [x20, w5, uxtw] .long 0x38664a86 // ldrb w6, [x20, w6, uxtw] .long 0x38674a87 // ldrb w7, [x20, w7, uxtw] .long 0x1e260074 // fmov w20, s3 .long 0x0e0c3c2e // mov w14, v1.s[1] .long 0x0e0c3c75 // mov w21, v3.s[1] .long 0x38714af1 // ldrb w17, [x23, w17, uxtw] .long 0x38744934 // ldrb w20, [x9, w20, uxtw] .long 0x0e143c2f // mov w15, v1.s[2] .long 0x0e1c3c30 // mov w16, v1.s[3] .long 0x0e143c76 // mov w22, v3.s[2] .long 0x386e4aee // ldrb w14, [x23, w14, uxtw] .long 0x38754935 // ldrb w21, [x9, w21, uxtw] .long 0x386f4aef // ldrb w15, [x23, w15, uxtw] .long 0x38704af0 // ldrb w16, [x23, w16, uxtw] .long 0x0e1c3c77 // mov w23, v3.s[3] .long 0x38764936 // ldrb w22, [x9, w22, uxtw] .long 0x38774929 // ldrb w9, [x9, w23, uxtw] .long 0x4e021da0 // mov v0.h[0], w13 .long 0x4e021e21 // mov v1.h[0], w17 .long 0x4e021e62 // mov v2.h[0], w19 .long 0x4e021e83 // mov v3.h[0], w20 .long 0x4e061d40 // mov v0.h[1], w10 .long 0x4e061dc1 // mov v1.h[1], w14 .long 0x4e061ca2 // mov v2.h[1], w5 .long 0x4e061ea3 // mov v3.h[1], w21 .long 0x4e0a1d60 // mov v0.h[2], w11 .long 0x4e0a1de1 // mov v1.h[2], w15 .long 0x4e0a1cc2 // mov v2.h[2], w6 .long 0x4e0a1ec3 // mov v3.h[2], w22 .long 0x4e0e1d80 // mov v0.h[3], w12 .long 0x4e0e1e01 // mov v1.h[3], w16 .long 0x4e0e1ce2 // mov v2.h[3], w7 .long 0x4e0e1d23 // mov v3.h[3], w9 .long 0xf9400505 // ldr x5, [x8, #8] .long 0x2f07b7e0 // bic v0.4h, #0xff, lsl #8 .long 0x2f07b7e1 // bic v1.4h, #0xff, lsl #8 .long 0x2f07b7e2 // bic v2.4h, #0xff, lsl #8 .long 0x2f07b7e3 // bic v3.4h, #0xff, lsl #8 .long 0xa9434ff4 // ldp x20, x19, [sp, #48] .long 0xa94257f6 // ldp x22, x21, [sp, #32] .long 0xa9415ff8 // ldp x24, x23, [sp, #16] .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x2f10a421 // uxtl v1.4s, v1.4h .long 0x2f10a442 // uxtl v2.4s, v2.4h .long 0x2f10a463 // uxtl v3.4s, v3.4h .long 0x6e21d800 // ucvtf v0.4s, v0.4s .long 0x6e21d821 // ucvtf v1.4s, v1.4s .long 0x6e21d842 // ucvtf v2.4s, v2.4s .long 0x6e21d863 // ucvtf v3.4s, v3.4s .long 0x6e30dc00 // fmul v0.4s, v0.4s, v16.4s .long 0x6e30dc21 // fmul v1.4s, v1.4s, v16.4s .long 0x6e30dc42 // fmul v2.4s, v2.4s, v16.4s .long 0x6e30dc63 // fmul v3.4s, v3.4s, v16.4s .long 0x910103ff // add sp, sp, #0x40 .long 0xd61f00a0 // br x5 HIDDEN _sk_byte_tables_rgb_aarch64 .globl _sk_byte_tables_rgb_aarch64 FUNCTION(_sk_byte_tables_rgb_aarch64) _sk_byte_tables_rgb_aarch64: .long 0xa9bf4ff4 // stp x20, x19, [sp, #-16]! .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x52a77009 // mov w9, #0x3b800000 .long 0x72901029 // movk w9, #0x8081 .long 0x4e040d30 // dup v16.4s, w9 .long 0xb9401909 // ldr w9, [x8, #24] .long 0xa9402d0a // ldp x10, x11, [x8] .long 0xf9400908 // ldr x8, [x8, #16] .long 0x51000529 // sub w9, w9, #0x1 .long 0x4e040d31 // dup v17.4s, w9 .long 0x4e21da31 // scvtf v17.4s, v17.4s .long 0x6e21de21 // fmul v1.4s, v17.4s, v1.4s .long 0x6e20de20 // fmul v0.4s, v17.4s, v0.4s .long 0x6e22de22 // fmul v2.4s, v17.4s, v2.4s .long 0x6e21a821 // fcvtnu v1.4s, v1.4s .long 0x6e21a800 // fcvtnu v0.4s, v0.4s .long 0x6e21a842 // fcvtnu v2.4s, v2.4s .long 0x0e0c3c2f // mov w15, v1.s[1] .long 0x0e143c30 // mov w16, v1.s[2] .long 0x0e1c3c31 // mov w17, v1.s[3] .long 0x1e260026 // fmov w6, s1 .long 0x1e26000e // fmov w14, s0 .long 0x38664966 // ldrb w6, [x11, w6, uxtw] .long 0x386f496f // ldrb w15, [x11, w15, uxtw] .long 0x38704970 // ldrb w16, [x11, w16, uxtw] .long 0x3871496b // ldrb w11, [x11, w17, uxtw] .long 0x1e260051 // fmov w17, s2 .long 0x0e0c3c09 // mov w9, v0.s[1] .long 0x386e494e // ldrb w14, [x10, w14, uxtw] .long 0x0e0c3c47 // mov w7, v2.s[1] .long 0x38714911 // ldrb w17, [x8, w17, uxtw] .long 0x0e143c0c // mov w12, v0.s[2] .long 0x0e1c3c0d // mov w13, v0.s[3] .long 0x0e143c53 // mov w19, v2.s[2] .long 0x38694949 // ldrb w9, [x10, w9, uxtw] .long 0x38674907 // ldrb w7, [x8, w7, uxtw] .long 0x386c494c // ldrb w12, [x10, w12, uxtw] .long 0x386d494a // ldrb w10, [x10, w13, uxtw] .long 0x0e1c3c4d // mov w13, v2.s[3] .long 0x38734913 // ldrb w19, [x8, w19, uxtw] .long 0x386d4908 // ldrb w8, [x8, w13, uxtw] .long 0x4e021dc0 // mov v0.h[0], w14 .long 0x4e021cc1 // mov v1.h[0], w6 .long 0x4e021e22 // mov v2.h[0], w17 .long 0x4e061d20 // mov v0.h[1], w9 .long 0x4e061de1 // mov v1.h[1], w15 .long 0x4e061ce2 // mov v2.h[1], w7 .long 0x4e0a1d80 // mov v0.h[2], w12 .long 0x4e0a1e01 // mov v1.h[2], w16 .long 0x4e0a1e62 // mov v2.h[2], w19 .long 0x4e0e1d40 // mov v0.h[3], w10 .long 0x4e0e1d61 // mov v1.h[3], w11 .long 0x4e0e1d02 // mov v2.h[3], w8 .long 0x2f07b7e0 // bic v0.4h, #0xff, lsl #8 .long 0x2f07b7e1 // bic v1.4h, #0xff, lsl #8 .long 0x2f07b7e2 // bic v2.4h, #0xff, lsl #8 .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x2f10a421 // uxtl v1.4s, v1.4h .long 0x2f10a442 // uxtl v2.4s, v2.4h .long 0x6e21d800 // ucvtf v0.4s, v0.4s .long 0x6e21d821 // ucvtf v1.4s, v1.4s .long 0x6e21d842 // ucvtf v2.4s, v2.4s .long 0x6e30dc00 // fmul v0.4s, v0.4s, v16.4s .long 0x6e30dc21 // fmul v1.4s, v1.4s, v16.4s .long 0x6e30dc42 // fmul v2.4s, v2.4s, v16.4s .long 0xa8c14ff4 // ldp x20, x19, [sp], #16 .long 0xd61f00a0 // br x5 HIDDEN _sk_table_r_aarch64 .globl _sk_table_r_aarch64 FUNCTION(_sk_table_r_aarch64) _sk_table_r_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x51000529 // sub w9, w9, #0x1 .long 0x4e040d30 // dup v16.4s, w9 .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x6e20de00 // fmul v0.4s, v16.4s, v0.4s .long 0x6e21a810 // fcvtnu v16.4s, v0.4s .long 0x1e26020b // fmov w11, s16 .long 0x8b2b490b // add x11, x8, w11, uxtw #2 .long 0x0d408160 // ld1 {v0.s}[0], [x11] .long 0x0e0c3e09 // mov w9, v16.s[1] .long 0x0e143e0a // mov w10, v16.s[2] .long 0x8b294909 // add x9, x8, w9, uxtw #2 .long 0x0e1c3e0b // mov w11, v16.s[3] .long 0xbc6a5910 // ldr s16, [x8, w10, uxtw #2] .long 0x0d409120 // ld1 {v0.s}[1], [x9] .long 0xbc6b5911 // ldr s17, [x8, w11, uxtw #2] .long 0x6e140600 // mov v0.s[2], v16.s[0] .long 0x6e1c0620 // mov v0.s[3], v17.s[0] .long 0xd61f00a0 // br x5 HIDDEN _sk_table_g_aarch64 .globl _sk_table_g_aarch64 FUNCTION(_sk_table_g_aarch64) _sk_table_g_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x51000529 // sub w9, w9, #0x1 .long 0x4e040d30 // dup v16.4s, w9 .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x6e21de01 // fmul v1.4s, v16.4s, v1.4s .long 0x6e21a830 // fcvtnu v16.4s, v1.4s .long 0x1e26020b // fmov w11, s16 .long 0x8b2b490b // add x11, x8, w11, uxtw #2 .long 0x0d408161 // ld1 {v1.s}[0], [x11] .long 0x0e0c3e09 // mov w9, v16.s[1] .long 0x0e143e0a // mov w10, v16.s[2] .long 0x8b294909 // add x9, x8, w9, uxtw #2 .long 0x0e1c3e0b // mov w11, v16.s[3] .long 0xbc6a5910 // ldr s16, [x8, w10, uxtw #2] .long 0x0d409121 // ld1 {v1.s}[1], [x9] .long 0xbc6b5911 // ldr s17, [x8, w11, uxtw #2] .long 0x6e140601 // mov v1.s[2], v16.s[0] .long 0x6e1c0621 // mov v1.s[3], v17.s[0] .long 0xd61f00a0 // br x5 HIDDEN _sk_table_b_aarch64 .globl _sk_table_b_aarch64 FUNCTION(_sk_table_b_aarch64) _sk_table_b_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x51000529 // sub w9, w9, #0x1 .long 0x4e040d30 // dup v16.4s, w9 .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x6e22de02 // fmul v2.4s, v16.4s, v2.4s .long 0x6e21a850 // fcvtnu v16.4s, v2.4s .long 0x1e26020b // fmov w11, s16 .long 0x8b2b490b // add x11, x8, w11, uxtw #2 .long 0x0d408162 // ld1 {v2.s}[0], [x11] .long 0x0e0c3e09 // mov w9, v16.s[1] .long 0x0e143e0a // mov w10, v16.s[2] .long 0x8b294909 // add x9, x8, w9, uxtw #2 .long 0x0e1c3e0b // mov w11, v16.s[3] .long 0xbc6a5910 // ldr s16, [x8, w10, uxtw #2] .long 0x0d409122 // ld1 {v2.s}[1], [x9] .long 0xbc6b5911 // ldr s17, [x8, w11, uxtw #2] .long 0x6e140602 // mov v2.s[2], v16.s[0] .long 0x6e1c0622 // mov v2.s[3], v17.s[0] .long 0xd61f00a0 // br x5 HIDDEN _sk_table_a_aarch64 .globl _sk_table_a_aarch64 FUNCTION(_sk_table_a_aarch64) _sk_table_a_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x51000529 // sub w9, w9, #0x1 .long 0x4e040d30 // dup v16.4s, w9 .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x6e23de03 // fmul v3.4s, v16.4s, v3.4s .long 0x6e21a870 // fcvtnu v16.4s, v3.4s .long 0x1e26020b // fmov w11, s16 .long 0x8b2b490b // add x11, x8, w11, uxtw #2 .long 0x0d408163 // ld1 {v3.s}[0], [x11] .long 0x0e0c3e09 // mov w9, v16.s[1] .long 0x0e143e0a // mov w10, v16.s[2] .long 0x8b294909 // add x9, x8, w9, uxtw #2 .long 0x0e1c3e0b // mov w11, v16.s[3] .long 0xbc6a5910 // ldr s16, [x8, w10, uxtw #2] .long 0x0d409123 // ld1 {v3.s}[1], [x9] .long 0xbc6b5911 // ldr s17, [x8, w11, uxtw #2] .long 0x6e140603 // mov v3.s[2], v16.s[0] .long 0x6e1c0623 // mov v3.s[3], v17.s[0] .long 0xd61f00a0 // br x5 HIDDEN _sk_parametric_r_aarch64 .globl _sk_parametric_r_aarch64 FUNCTION(_sk_parametric_r_aarch64) _sk_parametric_r_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x4f016696 // movi v22.4s, #0x34, lsl #24 .long 0x91004109 // add x9, x8, #0x10 .long 0x9100610a // add x10, x8, #0x18 .long 0x4d40c932 // ld1r {v18.4s}, [x9] .long 0xaa0803e9 // mov x9, x8 .long 0xbd400d11 // ldr s17, [x8, #12] .long 0x4d40c950 // ld1r {v16.4s}, [x10] .long 0x4ddfc933 // ld1r {v19.4s}, [x9], #4 .long 0x9100210a // add x10, x8, #0x8 .long 0x4d40c954 // ld1r {v20.4s}, [x10] .long 0x4f911010 // fmla v16.4s, v0.4s, v17.s[0] .long 0xbd400135 // ldr s21, [x9] .long 0x52b85f09 // mov w9, #0xc2f80000 .long 0x728e6ee9 // movk w9, #0x7377 .long 0x4e040d37 // dup v23.4s, w9 .long 0x52a7f7e9 // mov w9, #0x3fbf0000 .long 0x7297eea9 // movk w9, #0xbf75 .long 0x4f951014 // fmla v20.4s, v0.4s, v21.s[0] .long 0x6e20e640 // fcmge v0.4s, v18.4s, v0.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a7d689 // mov w9, #0x3eb40000 .long 0x4f03d7f1 // movi v17.4s, #0x7f, msl #16 .long 0x72889f29 // movk w9, #0x44f9 .long 0x4e21da95 // scvtf v21.4s, v20.4s .long 0x4e311e91 // and v17.16b, v20.16b, v17.16b .long 0x4e040d34 // dup v20.4s, w9 .long 0x52a7fb89 // mov w9, #0x3fdc0000 .long 0x4e35ced7 // fmla v23.4s, v22.4s, v21.4s .long 0x729d3469 // movk w9, #0xe9a3 .long 0x4f0177f1 // orr v17.4s, #0x3f, lsl #24 .long 0x4eb2ce37 // fmls v23.4s, v17.4s, v18.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a85e49 // mov w9, #0x42f20000 .long 0x72918a29 // movk w9, #0x8c51 .long 0x4e34d631 // fadd v17.4s, v17.4s, v20.4s .long 0x4e040d34 // dup v20.4s, w9 .long 0x52a7f7c9 // mov w9, #0x3fbe0000 .long 0x729791a9 // movk w9, #0xbc8d .long 0x6e31fe51 // fdiv v17.4s, v18.4s, v17.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a81349 // mov w9, #0x409a0000 .long 0x4eb1d6f1 // fsub v17.4s, v23.4s, v17.4s .long 0x729ebf09 // movk w9, #0xf5f8 .long 0x6e31de71 // fmul v17.4s, v19.4s, v17.4s .long 0x4e040d35 // dup v21.4s, w9 .long 0x52a83ba9 // mov w9, #0x41dd0000 .long 0x4e219a33 // frintm v19.4s, v17.4s .long 0x729a5fc9 // movk w9, #0xd2fe .long 0x4e34d634 // fadd v20.4s, v17.4s, v20.4s .long 0x4eb3d631 // fsub v17.4s, v17.4s, v19.4s .long 0x4eb2ce34 // fmls v20.4s, v17.4s, v18.4s .long 0x4eb1d6b1 // fsub v17.4s, v21.4s, v17.4s .long 0x4e040d35 // dup v21.4s, w9 .long 0x91005108 // add x8, x8, #0x14 .long 0x6e31feb1 // fdiv v17.4s, v21.4s, v17.4s .long 0x4e31d691 // fadd v17.4s, v20.4s, v17.4s .long 0x4d40c914 // ld1r {v20.4s}, [x8] .long 0x4f026573 // movi v19.4s, #0x4b, lsl #24 .long 0x6e33de31 // fmul v17.4s, v17.4s, v19.4s .long 0x6e21aa31 // fcvtnu v17.4s, v17.4s .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4e34d631 // fadd v17.4s, v17.4s, v20.4s .long 0x6f00e412 // movi v18.2d, #0x0 .long 0x6e711e00 // bsl v0.16b, v16.16b, v17.16b .long 0x4f03f615 // fmov v21.4s, #1.000000000000000000e+00 .long 0x4e32f400 // fmax v0.4s, v0.4s, v18.4s .long 0x4eb5f400 // fmin v0.4s, v0.4s, v21.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_parametric_g_aarch64 .globl _sk_parametric_g_aarch64 FUNCTION(_sk_parametric_g_aarch64) _sk_parametric_g_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x4f016696 // movi v22.4s, #0x34, lsl #24 .long 0x91004109 // add x9, x8, #0x10 .long 0x9100610a // add x10, x8, #0x18 .long 0x4d40c932 // ld1r {v18.4s}, [x9] .long 0xaa0803e9 // mov x9, x8 .long 0xbd400d11 // ldr s17, [x8, #12] .long 0x4d40c950 // ld1r {v16.4s}, [x10] .long 0x4ddfc933 // ld1r {v19.4s}, [x9], #4 .long 0x9100210a // add x10, x8, #0x8 .long 0x4d40c954 // ld1r {v20.4s}, [x10] .long 0x4f911030 // fmla v16.4s, v1.4s, v17.s[0] .long 0xbd400135 // ldr s21, [x9] .long 0x52b85f09 // mov w9, #0xc2f80000 .long 0x728e6ee9 // movk w9, #0x7377 .long 0x4e040d37 // dup v23.4s, w9 .long 0x52a7f7e9 // mov w9, #0x3fbf0000 .long 0x7297eea9 // movk w9, #0xbf75 .long 0x4f951034 // fmla v20.4s, v1.4s, v21.s[0] .long 0x6e21e641 // fcmge v1.4s, v18.4s, v1.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a7d689 // mov w9, #0x3eb40000 .long 0x4f03d7f1 // movi v17.4s, #0x7f, msl #16 .long 0x72889f29 // movk w9, #0x44f9 .long 0x4e21da95 // scvtf v21.4s, v20.4s .long 0x4e311e91 // and v17.16b, v20.16b, v17.16b .long 0x4e040d34 // dup v20.4s, w9 .long 0x52a7fb89 // mov w9, #0x3fdc0000 .long 0x4e35ced7 // fmla v23.4s, v22.4s, v21.4s .long 0x729d3469 // movk w9, #0xe9a3 .long 0x4f0177f1 // orr v17.4s, #0x3f, lsl #24 .long 0x4eb2ce37 // fmls v23.4s, v17.4s, v18.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a85e49 // mov w9, #0x42f20000 .long 0x72918a29 // movk w9, #0x8c51 .long 0x4e34d631 // fadd v17.4s, v17.4s, v20.4s .long 0x4e040d34 // dup v20.4s, w9 .long 0x52a7f7c9 // mov w9, #0x3fbe0000 .long 0x729791a9 // movk w9, #0xbc8d .long 0x6e31fe51 // fdiv v17.4s, v18.4s, v17.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a81349 // mov w9, #0x409a0000 .long 0x4eb1d6f1 // fsub v17.4s, v23.4s, v17.4s .long 0x729ebf09 // movk w9, #0xf5f8 .long 0x6e31de71 // fmul v17.4s, v19.4s, v17.4s .long 0x4e040d35 // dup v21.4s, w9 .long 0x52a83ba9 // mov w9, #0x41dd0000 .long 0x4e219a33 // frintm v19.4s, v17.4s .long 0x729a5fc9 // movk w9, #0xd2fe .long 0x4e34d634 // fadd v20.4s, v17.4s, v20.4s .long 0x4eb3d631 // fsub v17.4s, v17.4s, v19.4s .long 0x4eb2ce34 // fmls v20.4s, v17.4s, v18.4s .long 0x4eb1d6b1 // fsub v17.4s, v21.4s, v17.4s .long 0x4e040d35 // dup v21.4s, w9 .long 0x91005108 // add x8, x8, #0x14 .long 0x6e31feb1 // fdiv v17.4s, v21.4s, v17.4s .long 0x4e31d691 // fadd v17.4s, v20.4s, v17.4s .long 0x4d40c914 // ld1r {v20.4s}, [x8] .long 0x4f026573 // movi v19.4s, #0x4b, lsl #24 .long 0x6e33de31 // fmul v17.4s, v17.4s, v19.4s .long 0x6e21aa31 // fcvtnu v17.4s, v17.4s .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4e34d631 // fadd v17.4s, v17.4s, v20.4s .long 0x6f00e412 // movi v18.2d, #0x0 .long 0x6e711e01 // bsl v1.16b, v16.16b, v17.16b .long 0x4f03f615 // fmov v21.4s, #1.000000000000000000e+00 .long 0x4e32f421 // fmax v1.4s, v1.4s, v18.4s .long 0x4eb5f421 // fmin v1.4s, v1.4s, v21.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_parametric_b_aarch64 .globl _sk_parametric_b_aarch64 FUNCTION(_sk_parametric_b_aarch64) _sk_parametric_b_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x4f016696 // movi v22.4s, #0x34, lsl #24 .long 0x91004109 // add x9, x8, #0x10 .long 0x9100610a // add x10, x8, #0x18 .long 0x4d40c932 // ld1r {v18.4s}, [x9] .long 0xaa0803e9 // mov x9, x8 .long 0xbd400d11 // ldr s17, [x8, #12] .long 0x4d40c950 // ld1r {v16.4s}, [x10] .long 0x4ddfc933 // ld1r {v19.4s}, [x9], #4 .long 0x9100210a // add x10, x8, #0x8 .long 0x4d40c954 // ld1r {v20.4s}, [x10] .long 0x4f911050 // fmla v16.4s, v2.4s, v17.s[0] .long 0xbd400135 // ldr s21, [x9] .long 0x52b85f09 // mov w9, #0xc2f80000 .long 0x728e6ee9 // movk w9, #0x7377 .long 0x4e040d37 // dup v23.4s, w9 .long 0x52a7f7e9 // mov w9, #0x3fbf0000 .long 0x7297eea9 // movk w9, #0xbf75 .long 0x4f951054 // fmla v20.4s, v2.4s, v21.s[0] .long 0x6e22e642 // fcmge v2.4s, v18.4s, v2.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a7d689 // mov w9, #0x3eb40000 .long 0x4f03d7f1 // movi v17.4s, #0x7f, msl #16 .long 0x72889f29 // movk w9, #0x44f9 .long 0x4e21da95 // scvtf v21.4s, v20.4s .long 0x4e311e91 // and v17.16b, v20.16b, v17.16b .long 0x4e040d34 // dup v20.4s, w9 .long 0x52a7fb89 // mov w9, #0x3fdc0000 .long 0x4e35ced7 // fmla v23.4s, v22.4s, v21.4s .long 0x729d3469 // movk w9, #0xe9a3 .long 0x4f0177f1 // orr v17.4s, #0x3f, lsl #24 .long 0x4eb2ce37 // fmls v23.4s, v17.4s, v18.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a85e49 // mov w9, #0x42f20000 .long 0x72918a29 // movk w9, #0x8c51 .long 0x4e34d631 // fadd v17.4s, v17.4s, v20.4s .long 0x4e040d34 // dup v20.4s, w9 .long 0x52a7f7c9 // mov w9, #0x3fbe0000 .long 0x729791a9 // movk w9, #0xbc8d .long 0x6e31fe51 // fdiv v17.4s, v18.4s, v17.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a81349 // mov w9, #0x409a0000 .long 0x4eb1d6f1 // fsub v17.4s, v23.4s, v17.4s .long 0x729ebf09 // movk w9, #0xf5f8 .long 0x6e31de71 // fmul v17.4s, v19.4s, v17.4s .long 0x4e040d35 // dup v21.4s, w9 .long 0x52a83ba9 // mov w9, #0x41dd0000 .long 0x4e219a33 // frintm v19.4s, v17.4s .long 0x729a5fc9 // movk w9, #0xd2fe .long 0x4e34d634 // fadd v20.4s, v17.4s, v20.4s .long 0x4eb3d631 // fsub v17.4s, v17.4s, v19.4s .long 0x4eb2ce34 // fmls v20.4s, v17.4s, v18.4s .long 0x4eb1d6b1 // fsub v17.4s, v21.4s, v17.4s .long 0x4e040d35 // dup v21.4s, w9 .long 0x91005108 // add x8, x8, #0x14 .long 0x6e31feb1 // fdiv v17.4s, v21.4s, v17.4s .long 0x4e31d691 // fadd v17.4s, v20.4s, v17.4s .long 0x4d40c914 // ld1r {v20.4s}, [x8] .long 0x4f026573 // movi v19.4s, #0x4b, lsl #24 .long 0x6e33de31 // fmul v17.4s, v17.4s, v19.4s .long 0x6e21aa31 // fcvtnu v17.4s, v17.4s .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4e34d631 // fadd v17.4s, v17.4s, v20.4s .long 0x6f00e412 // movi v18.2d, #0x0 .long 0x6e711e02 // bsl v2.16b, v16.16b, v17.16b .long 0x4f03f615 // fmov v21.4s, #1.000000000000000000e+00 .long 0x4e32f442 // fmax v2.4s, v2.4s, v18.4s .long 0x4eb5f442 // fmin v2.4s, v2.4s, v21.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_parametric_a_aarch64 .globl _sk_parametric_a_aarch64 FUNCTION(_sk_parametric_a_aarch64) _sk_parametric_a_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x4f016696 // movi v22.4s, #0x34, lsl #24 .long 0x91004109 // add x9, x8, #0x10 .long 0x9100610a // add x10, x8, #0x18 .long 0x4d40c932 // ld1r {v18.4s}, [x9] .long 0xaa0803e9 // mov x9, x8 .long 0xbd400d11 // ldr s17, [x8, #12] .long 0x4d40c950 // ld1r {v16.4s}, [x10] .long 0x4ddfc933 // ld1r {v19.4s}, [x9], #4 .long 0x9100210a // add x10, x8, #0x8 .long 0x4d40c954 // ld1r {v20.4s}, [x10] .long 0x4f911070 // fmla v16.4s, v3.4s, v17.s[0] .long 0xbd400135 // ldr s21, [x9] .long 0x52b85f09 // mov w9, #0xc2f80000 .long 0x728e6ee9 // movk w9, #0x7377 .long 0x4e040d37 // dup v23.4s, w9 .long 0x52a7f7e9 // mov w9, #0x3fbf0000 .long 0x7297eea9 // movk w9, #0xbf75 .long 0x4f951074 // fmla v20.4s, v3.4s, v21.s[0] .long 0x6e23e643 // fcmge v3.4s, v18.4s, v3.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a7d689 // mov w9, #0x3eb40000 .long 0x4f03d7f1 // movi v17.4s, #0x7f, msl #16 .long 0x72889f29 // movk w9, #0x44f9 .long 0x4e21da95 // scvtf v21.4s, v20.4s .long 0x4e311e91 // and v17.16b, v20.16b, v17.16b .long 0x4e040d34 // dup v20.4s, w9 .long 0x52a7fb89 // mov w9, #0x3fdc0000 .long 0x4e35ced7 // fmla v23.4s, v22.4s, v21.4s .long 0x729d3469 // movk w9, #0xe9a3 .long 0x4f0177f1 // orr v17.4s, #0x3f, lsl #24 .long 0x4eb2ce37 // fmls v23.4s, v17.4s, v18.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a85e49 // mov w9, #0x42f20000 .long 0x72918a29 // movk w9, #0x8c51 .long 0x4e34d631 // fadd v17.4s, v17.4s, v20.4s .long 0x4e040d34 // dup v20.4s, w9 .long 0x52a7f7c9 // mov w9, #0x3fbe0000 .long 0x729791a9 // movk w9, #0xbc8d .long 0x6e31fe51 // fdiv v17.4s, v18.4s, v17.4s .long 0x4e040d32 // dup v18.4s, w9 .long 0x52a81349 // mov w9, #0x409a0000 .long 0x4eb1d6f1 // fsub v17.4s, v23.4s, v17.4s .long 0x729ebf09 // movk w9, #0xf5f8 .long 0x6e31de71 // fmul v17.4s, v19.4s, v17.4s .long 0x4e040d35 // dup v21.4s, w9 .long 0x52a83ba9 // mov w9, #0x41dd0000 .long 0x4e219a33 // frintm v19.4s, v17.4s .long 0x729a5fc9 // movk w9, #0xd2fe .long 0x4e34d634 // fadd v20.4s, v17.4s, v20.4s .long 0x4eb3d631 // fsub v17.4s, v17.4s, v19.4s .long 0x4eb2ce34 // fmls v20.4s, v17.4s, v18.4s .long 0x4eb1d6b1 // fsub v17.4s, v21.4s, v17.4s .long 0x4e040d35 // dup v21.4s, w9 .long 0x91005108 // add x8, x8, #0x14 .long 0x6e31feb1 // fdiv v17.4s, v21.4s, v17.4s .long 0x4e31d691 // fadd v17.4s, v20.4s, v17.4s .long 0x4d40c914 // ld1r {v20.4s}, [x8] .long 0x4f026573 // movi v19.4s, #0x4b, lsl #24 .long 0x6e33de31 // fmul v17.4s, v17.4s, v19.4s .long 0x6e21aa31 // fcvtnu v17.4s, v17.4s .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4e34d631 // fadd v17.4s, v17.4s, v20.4s .long 0x6f00e412 // movi v18.2d, #0x0 .long 0x6e711e03 // bsl v3.16b, v16.16b, v17.16b .long 0x4f03f615 // fmov v21.4s, #1.000000000000000000e+00 .long 0x4e32f463 // fmax v3.4s, v3.4s, v18.4s .long 0x4eb5f463 // fmin v3.4s, v3.4s, v21.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_gamma_aarch64 .globl _sk_gamma_aarch64 FUNCTION(_sk_gamma_aarch64) _sk_gamma_aarch64: .long 0x52b85f08 // mov w8, #0xc2f80000 .long 0x728e6ee8 // movk w8, #0x7377 .long 0x4e040d10 // dup v16.4s, w8 .long 0x52a7d688 // mov w8, #0x3eb40000 .long 0x72889f28 // movk w8, #0x44f9 .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a85e48 // mov w8, #0x42f20000 .long 0x72918a28 // movk w8, #0x8c51 .long 0x4e040d13 // dup v19.4s, w8 .long 0x52a81348 // mov w8, #0x409a0000 .long 0x729ebf08 // movk w8, #0xf5f8 .long 0x4e040d15 // dup v21.4s, w8 .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x52a7f7e9 // mov w9, #0x3fbf0000 .long 0x4f01669a // movi v26.4s, #0x34, lsl #24 .long 0x4e21d85b // scvtf v27.4s, v2.4s .long 0x7297eea9 // movk w9, #0xbf75 .long 0x4eb01e1c // mov v28.16b, v16.16b .long 0x4eb01e1d // mov v29.16b, v16.16b .long 0x4e3bcf50 // fmla v16.4s, v26.4s, v27.4s .long 0x4f03d7fb // movi v27.4s, #0x7f, msl #16 .long 0x4e040d31 // dup v17.4s, w9 .long 0x52a7fb89 // mov w9, #0x3fdc0000 .long 0x4e21d819 // scvtf v25.4s, v0.4s .long 0x4e3b1c00 // and v0.16b, v0.16b, v27.16b .long 0x4e3b1c42 // and v2.16b, v2.16b, v27.16b .long 0x4e3b1c3b // and v27.16b, v1.16b, v27.16b .long 0x729d3469 // movk w9, #0xe9a3 .long 0xbd400118 // ldr s24, [x8] .long 0x4e21d821 // scvtf v1.4s, v1.4s .long 0x4f0177e0 // orr v0.4s, #0x3f, lsl #24 .long 0x4f0177fb // orr v27.4s, #0x3f, lsl #24 .long 0x4f0177e2 // orr v2.4s, #0x3f, lsl #24 .long 0x4e040d37 // dup v23.4s, w9 .long 0x4e39cf5c // fmla v28.4s, v26.4s, v25.4s .long 0x4e21cf5d // fmla v29.4s, v26.4s, v1.4s .long 0x4e32d401 // fadd v1.4s, v0.4s, v18.4s .long 0x4e32d77a // fadd v26.4s, v27.4s, v18.4s .long 0x4eb1cc50 // fmls v16.4s, v2.4s, v17.4s .long 0x4e32d442 // fadd v2.4s, v2.4s, v18.4s .long 0x4eb1cc1c // fmls v28.4s, v0.4s, v17.4s .long 0x6e21fee0 // fdiv v0.4s, v23.4s, v1.4s .long 0x4eb1cf7d // fmls v29.4s, v27.4s, v17.4s .long 0x6e3afee1 // fdiv v1.4s, v23.4s, v26.4s .long 0x6e22fee2 // fdiv v2.4s, v23.4s, v2.4s .long 0x52a7f7c9 // mov w9, #0x3fbe0000 .long 0x4ea0d780 // fsub v0.4s, v28.4s, v0.4s .long 0x4ea1d7a1 // fsub v1.4s, v29.4s, v1.4s .long 0x4ea2d602 // fsub v2.4s, v16.4s, v2.4s .long 0x729791a9 // movk w9, #0xbc8d .long 0x4f989000 // fmul v0.4s, v0.4s, v24.s[0] .long 0x4f989021 // fmul v1.4s, v1.4s, v24.s[0] .long 0x4f989042 // fmul v2.4s, v2.4s, v24.s[0] .long 0x4e040d34 // dup v20.4s, w9 .long 0x52a83ba9 // mov w9, #0x41dd0000 .long 0x4e219810 // frintm v16.4s, v0.4s .long 0x4e219832 // frintm v18.4s, v1.4s .long 0x4e219858 // frintm v24.4s, v2.4s .long 0x729a5fc9 // movk w9, #0xd2fe .long 0x4e33d411 // fadd v17.4s, v0.4s, v19.4s .long 0x4e33d437 // fadd v23.4s, v1.4s, v19.4s .long 0x4e33d453 // fadd v19.4s, v2.4s, v19.4s .long 0x4eb0d400 // fsub v0.4s, v0.4s, v16.4s .long 0x4eb2d421 // fsub v1.4s, v1.4s, v18.4s .long 0x4eb8d442 // fsub v2.4s, v2.4s, v24.4s .long 0x4e040d36 // dup v22.4s, w9 .long 0x4eb4cc11 // fmls v17.4s, v0.4s, v20.4s .long 0x4ea0d6a0 // fsub v0.4s, v21.4s, v0.4s .long 0x4eb4cc37 // fmls v23.4s, v1.4s, v20.4s .long 0x4ea1d6a1 // fsub v1.4s, v21.4s, v1.4s .long 0x4eb4cc53 // fmls v19.4s, v2.4s, v20.4s .long 0x4ea2d6a2 // fsub v2.4s, v21.4s, v2.4s .long 0x6e20fec0 // fdiv v0.4s, v22.4s, v0.4s .long 0x6e21fec1 // fdiv v1.4s, v22.4s, v1.4s .long 0x6e22fec2 // fdiv v2.4s, v22.4s, v2.4s .long 0x4f026579 // movi v25.4s, #0x4b, lsl #24 .long 0x4e20d620 // fadd v0.4s, v17.4s, v0.4s .long 0x4e21d6e1 // fadd v1.4s, v23.4s, v1.4s .long 0x4e22d662 // fadd v2.4s, v19.4s, v2.4s .long 0x6e39dc00 // fmul v0.4s, v0.4s, v25.4s .long 0x6e39dc21 // fmul v1.4s, v1.4s, v25.4s .long 0x6e39dc42 // fmul v2.4s, v2.4s, v25.4s .long 0x6e21a800 // fcvtnu v0.4s, v0.4s .long 0x6e21a821 // fcvtnu v1.4s, v1.4s .long 0x6e21a842 // fcvtnu v2.4s, v2.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_lab_to_xyz_aarch64 .globl _sk_lab_to_xyz_aarch64 FUNCTION(_sk_lab_to_xyz_aarch64) _sk_lab_to_xyz_aarch64: .long 0x52a85908 // mov w8, #0x42c80000 .long 0x4e040d10 // dup v16.4s, w8 .long 0x52a86fe8 // mov w8, #0x437f0000 .long 0x4f066471 // movi v17.4s, #0xc3, lsl #24 .long 0x4e040d13 // dup v19.4s, w8 .long 0x52a781a8 // mov w8, #0x3c0d0000 .long 0x7287b968 // movk w8, #0x3dcb .long 0x4eb11e34 // mov v20.16b, v17.16b .long 0x4e21ce74 // fmla v20.4s, v19.4s, v1.4s .long 0x4e040d01 // dup v1.4s, w8 .long 0x52a76068 // mov w8, #0x3b030000 .long 0x72824de8 // movk w8, #0x126f .long 0x4e22ce71 // fmla v17.4s, v19.4s, v2.4s .long 0x4e040d02 // dup v2.4s, w8 .long 0x52a77468 // mov w8, #0x3ba30000 .long 0x729ae148 // movk w8, #0xd70a .long 0x4e040d13 // dup v19.4s, w8 .long 0x52a78228 // mov w8, #0x3c110000 .long 0x4f01f612 // fmov v18.4s, #1.600000000000000000e+01 .long 0x72831848 // movk w8, #0x18c2 .long 0x4e20ce12 // fmla v18.4s, v16.4s, v0.4s .long 0x4e040d00 // dup v0.4s, w8 .long 0x52b7c1a8 // mov w8, #0xbe0d0000 .long 0x7287b968 // movk w8, #0x3dcb .long 0x6e21de41 // fmul v1.4s, v18.4s, v1.4s .long 0x4e040d10 // dup v16.4s, w8 .long 0x52a7c068 // mov w8, #0x3e030000 .long 0x4ea11c32 // mov v18.16b, v1.16b .long 0x72900a08 // movk w8, #0x8050 .long 0x4eb3ce32 // fmls v18.4s, v17.4s, v19.4s .long 0x6e21dc31 // fmul v17.4s, v1.4s, v1.4s .long 0x4ea11c35 // mov v21.16b, v1.16b .long 0x4e30d433 // fadd v19.4s, v1.4s, v16.4s .long 0x6e31dc31 // fmul v17.4s, v1.4s, v17.4s .long 0x4e34cc55 // fmla v21.4s, v2.4s, v20.4s .long 0x4e040d02 // dup v2.4s, w8 .long 0x6e22de73 // fmul v19.4s, v19.4s, v2.4s .long 0x6ea0e621 // fcmgt v1.4s, v17.4s, v0.4s .long 0x6e731e21 // bsl v1.16b, v17.16b, v19.16b .long 0x6e32de51 // fmul v17.4s, v18.4s, v18.4s .long 0x4e30d653 // fadd v19.4s, v18.4s, v16.4s .long 0x6e31de51 // fmul v17.4s, v18.4s, v17.4s .long 0x52a7eec8 // mov w8, #0x3f760000 .long 0x6e22de72 // fmul v18.4s, v19.4s, v2.4s .long 0x6ea0e633 // fcmgt v19.4s, v17.4s, v0.4s .long 0x729ae3e8 // movk w8, #0xd71f .long 0x6e721e33 // bsl v19.16b, v17.16b, v18.16b .long 0x6e35deb2 // fmul v18.4s, v21.4s, v21.4s .long 0x4e040d11 // dup v17.4s, w8 .long 0x52a7ea68 // mov w8, #0x3f530000 .long 0x4e30d6b0 // fadd v16.4s, v21.4s, v16.4s .long 0x6e32deb2 // fmul v18.4s, v21.4s, v18.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x72881ec8 // movk w8, #0x40f6 .long 0x6e22de02 // fmul v2.4s, v16.4s, v2.4s .long 0x6ea0e640 // fcmgt v0.4s, v18.4s, v0.4s .long 0x4e040d14 // dup v20.4s, w8 .long 0x6e621e40 // bsl v0.16b, v18.16b, v2.16b .long 0x6e31dc00 // fmul v0.4s, v0.4s, v17.4s .long 0x6e34de62 // fmul v2.4s, v19.4s, v20.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_load_a8_aarch64 .globl _sk_load_a8_aarch64 FUNCTION(_sk_load_a8_aarch64) _sk_load_a8_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x93407c6a // sxtw x10, w3 .long 0xf9400109 // ldr x9, [x8] .long 0xb9800908 // ldrsw x8, [x8, #8] .long 0x9b0a2508 // madd x8, x8, x10, x9 .long 0x8b22c108 // add x8, x8, w2, sxtw .long 0xb50002e4 // cbnz x4, 28ac <_sk_load_a8_aarch64+0x74> .long 0x39400109 // ldrb w9, [x8] .long 0x3940050a // ldrb w10, [x8, #1] .long 0x3940090b // ldrb w11, [x8, #2] .long 0x39400d08 // ldrb w8, [x8, #3] .long 0x4e021d22 // mov v2.h[0], w9 .long 0x4e061d42 // mov v2.h[1], w10 .long 0x4e0a1d62 // mov v2.h[2], w11 .long 0x4e0e1d02 // mov v2.h[3], w8 .long 0x2f07b7e2 // bic v2.4h, #0xff, lsl #8 .long 0x52a77008 // mov w8, #0x3b800000 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72901028 // movk w8, #0x8081 .long 0x2f10a442 // uxtl v2.4s, v2.4h .long 0x4e040d03 // dup v3.4s, w8 .long 0x91004028 // add x8, x1, #0x10 .long 0x6e21d842 // ucvtf v2.4s, v2.4s .long 0x6f00e400 // movi v0.2d, #0x0 .long 0x6f00e401 // movi v1.2d, #0x0 .long 0x6e23dc43 // fmul v3.4s, v2.4s, v3.4s .long 0x6f00e402 // movi v2.2d, #0x0 .long 0xaa0803e1 // mov x1, x8 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 28f8 <_sk_load_a8_aarch64+0xc0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e402 // movi d2, #0x0 .long 0x540000c0 // b.eq 28d8 <_sk_load_a8_aarch64+0xa0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffd61 // b.ne 2874 <_sk_load_a8_aarch64+0x3c> // b.any .long 0x39400909 // ldrb w9, [x8, #2] .long 0x0e020fe2 // dup v2.4h, wzr .long 0x4e0a1d22 // mov v2.h[2], w9 .long 0x39400109 // ldrb w9, [x8] .long 0x39400508 // ldrb w8, [x8, #1] .long 0x4e041d20 // mov v0.s[0], w9 .long 0x4e0c1d00 // mov v0.s[1], w8 .long 0x0e401800 // uzp1 v0.4h, v0.4h, v0.4h .long 0x2e002040 // ext v0.8b, v2.8b, v0.8b, #4 .long 0x2e002002 // ext v2.8b, v0.8b, v0.8b, #4 .long 0x17ffffe0 // b 2874 <_sk_load_a8_aarch64+0x3c> .long 0x39400108 // ldrb w8, [x8] .long 0x0e020fe2 // dup v2.4h, wzr .long 0x4e021d02 // mov v2.h[0], w8 .long 0x17ffffdc // b 2874 <_sk_load_a8_aarch64+0x3c> HIDDEN _sk_load_a8_dst_aarch64 .globl _sk_load_a8_dst_aarch64 FUNCTION(_sk_load_a8_dst_aarch64) _sk_load_a8_dst_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x93407c6a // sxtw x10, w3 .long 0xf9400109 // ldr x9, [x8] .long 0xb9800908 // ldrsw x8, [x8, #8] .long 0x9b0a2508 // madd x8, x8, x10, x9 .long 0x8b22c108 // add x8, x8, w2, sxtw .long 0xb50002e4 // cbnz x4, 297c <_sk_load_a8_dst_aarch64+0x74> .long 0x39400109 // ldrb w9, [x8] .long 0x3940050a // ldrb w10, [x8, #1] .long 0x3940090b // ldrb w11, [x8, #2] .long 0x39400d08 // ldrb w8, [x8, #3] .long 0x4e021d26 // mov v6.h[0], w9 .long 0x4e061d46 // mov v6.h[1], w10 .long 0x4e0a1d66 // mov v6.h[2], w11 .long 0x4e0e1d06 // mov v6.h[3], w8 .long 0x2f07b7e6 // bic v6.4h, #0xff, lsl #8 .long 0x52a77008 // mov w8, #0x3b800000 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72901028 // movk w8, #0x8081 .long 0x2f10a4c6 // uxtl v6.4s, v6.4h .long 0x4e040d07 // dup v7.4s, w8 .long 0x91004028 // add x8, x1, #0x10 .long 0x6e21d8c6 // ucvtf v6.4s, v6.4s .long 0x6f00e404 // movi v4.2d, #0x0 .long 0x6f00e405 // movi v5.2d, #0x0 .long 0x6e27dcc7 // fmul v7.4s, v6.4s, v7.4s .long 0x6f00e406 // movi v6.2d, #0x0 .long 0xaa0803e1 // mov x1, x8 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 29c8 <_sk_load_a8_dst_aarch64+0xc0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e406 // movi d6, #0x0 .long 0x540000c0 // b.eq 29a8 <_sk_load_a8_dst_aarch64+0xa0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffd61 // b.ne 2944 <_sk_load_a8_dst_aarch64+0x3c> // b.any .long 0x39400909 // ldrb w9, [x8, #2] .long 0x0e020fe6 // dup v6.4h, wzr .long 0x4e0a1d26 // mov v6.h[2], w9 .long 0x39400109 // ldrb w9, [x8] .long 0x39400508 // ldrb w8, [x8, #1] .long 0x4e041d24 // mov v4.s[0], w9 .long 0x4e0c1d04 // mov v4.s[1], w8 .long 0x0e401884 // uzp1 v4.4h, v4.4h, v0.4h .long 0x2e0420c4 // ext v4.8b, v6.8b, v4.8b, #4 .long 0x2e042086 // ext v6.8b, v4.8b, v4.8b, #4 .long 0x17ffffe0 // b 2944 <_sk_load_a8_dst_aarch64+0x3c> .long 0x39400108 // ldrb w8, [x8] .long 0x0e020fe6 // dup v6.4h, wzr .long 0x4e021d06 // mov v6.h[0], w8 .long 0x17ffffdc // b 2944 <_sk_load_a8_dst_aarch64+0x3c> HIDDEN _sk_gather_a8_aarch64 .globl _sk_gather_a8_aarch64 FUNCTION(_sk_gather_a8_aarch64) _sk_gather_a8_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ea1b821 // fcvtzs v1.4s, v1.4s .long 0x4ea1b800 // fcvtzs v0.4s, v0.4s .long 0x91002109 // add x9, x8, #0x8 .long 0x4d40c922 // ld1r {v2.4s}, [x9] .long 0xf9400108 // ldr x8, [x8] .long 0x52a77009 // mov w9, #0x3b800000 .long 0x72901029 // movk w9, #0x8081 .long 0x4ea19440 // mla v0.4s, v2.4s, v1.4s .long 0x1e26000c // fmov w12, s0 .long 0x4e040d23 // dup v3.4s, w9 .long 0x0e0c3c09 // mov w9, v0.s[1] .long 0x386c490c // ldrb w12, [x8, w12, uxtw] .long 0x0e143c0a // mov w10, v0.s[2] .long 0x38694909 // ldrb w9, [x8, w9, uxtw] .long 0x0e1c3c0b // mov w11, v0.s[3] .long 0x386a490a // ldrb w10, [x8, w10, uxtw] .long 0x386b4908 // ldrb w8, [x8, w11, uxtw] .long 0x4e021d82 // mov v2.h[0], w12 .long 0x4e061d22 // mov v2.h[1], w9 .long 0x4e0a1d42 // mov v2.h[2], w10 .long 0x4e0e1d02 // mov v2.h[3], w8 .long 0x2f07b7e2 // bic v2.4h, #0xff, lsl #8 .long 0x2f10a442 // uxtl v2.4s, v2.4h .long 0x6e21d842 // ucvtf v2.4s, v2.4s .long 0x6f00e400 // movi v0.2d, #0x0 .long 0x6f00e401 // movi v1.2d, #0x0 .long 0x6e23dc43 // fmul v3.4s, v2.4s, v3.4s .long 0x6f00e402 // movi v2.2d, #0x0 .long 0xd61f00a0 // br x5 HIDDEN _sk_store_a8_aarch64 .globl _sk_store_a8_aarch64 FUNCTION(_sk_store_a8_aarch64) _sk_store_a8_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52a86fe9 // mov w9, #0x437f0000 .long 0x4e040d30 // dup v16.4s, w9 .long 0x93407c6a // sxtw x10, w3 .long 0xf9400109 // ldr x9, [x8] .long 0xb9800908 // ldrsw x8, [x8, #8] .long 0x6e30dc70 // fmul v16.4s, v3.4s, v16.4s .long 0x6e21aa10 // fcvtnu v16.4s, v16.4s .long 0x0e612a10 // xtn v16.4h, v16.4s .long 0x9b0a2508 // madd x8, x8, x10, x9 .long 0x8b22c108 // add x8, x8, w2, sxtw .long 0xb5000184 // cbnz x4, 2aac <_sk_store_a8_aarch64+0x5c> .long 0x0e0e3e09 // umov w9, v16.h[3] .long 0x0e0a3e0a // umov w10, v16.h[2] .long 0x0e063e0b // umov w11, v16.h[1] .long 0x0e023e0c // umov w12, v16.h[0] .long 0x39000d09 // strb w9, [x8, #3] .long 0x3900090a // strb w10, [x8, #2] .long 0x3900050b // strb w11, [x8, #1] .long 0x3900010c // strb w12, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000180 // b.eq 2ae4 <_sk_store_a8_aarch64+0x94> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x540000a0 // b.eq 2ad0 <_sk_store_a8_aarch64+0x80> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffee1 // b.ne 2aa0 <_sk_store_a8_aarch64+0x50> // b.any .long 0x0e0a3e09 // umov w9, v16.h[2] .long 0x39000909 // strb w9, [x8, #2] .long 0x0e023e09 // umov w9, v16.h[0] .long 0x0e063e0a // umov w10, v16.h[1] .long 0x3900050a // strb w10, [x8, #1] .long 0x39000109 // strb w9, [x8] .long 0x17fffff0 // b 2aa0 <_sk_store_a8_aarch64+0x50> .long 0x0e023e09 // umov w9, v16.h[0] .long 0x39000109 // strb w9, [x8] .long 0x17ffffed // b 2aa0 <_sk_store_a8_aarch64+0x50> HIDDEN _sk_load_g8_aarch64 .globl _sk_load_g8_aarch64 FUNCTION(_sk_load_g8_aarch64) _sk_load_g8_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x93407c6a // sxtw x10, w3 .long 0xf9400109 // ldr x9, [x8] .long 0xb9800908 // ldrsw x8, [x8, #8] .long 0x9b0a2508 // madd x8, x8, x10, x9 .long 0x8b22c108 // add x8, x8, w2, sxtw .long 0xb50002e4 // cbnz x4, 2b64 <_sk_load_g8_aarch64+0x74> .long 0x39400109 // ldrb w9, [x8] .long 0x3940050a // ldrb w10, [x8, #1] .long 0x3940090b // ldrb w11, [x8, #2] .long 0x39400d08 // ldrb w8, [x8, #3] .long 0x4e021d20 // mov v0.h[0], w9 .long 0x4e061d40 // mov v0.h[1], w10 .long 0x4e0a1d60 // mov v0.h[2], w11 .long 0x4e0e1d00 // mov v0.h[3], w8 .long 0x2f07b7e0 // bic v0.4h, #0xff, lsl #8 .long 0x52a77008 // mov w8, #0x3b800000 .long 0x72901028 // movk w8, #0x8081 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x4e040d01 // dup v1.4s, w8 .long 0x6e21d800 // ucvtf v0.4s, v0.4s .long 0x91004028 // add x8, x1, #0x10 .long 0x6e21dc00 // fmul v0.4s, v0.4s, v1.4s .long 0x4f03f603 // fmov v3.4s, #1.000000000000000000e+00 .long 0xaa0803e1 // mov x1, x8 .long 0x4ea01c01 // mov v1.16b, v0.16b .long 0x4ea01c02 // mov v2.16b, v0.16b .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 2bb0 <_sk_load_g8_aarch64+0xc0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e400 // movi d0, #0x0 .long 0x540000c0 // b.eq 2b90 <_sk_load_g8_aarch64+0xa0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffd61 // b.ne 2b2c <_sk_load_g8_aarch64+0x3c> // b.any .long 0x39400909 // ldrb w9, [x8, #2] .long 0x0e020fe0 // dup v0.4h, wzr .long 0x4e0a1d20 // mov v0.h[2], w9 .long 0x39400109 // ldrb w9, [x8] .long 0x39400508 // ldrb w8, [x8, #1] .long 0x4e041d21 // mov v1.s[0], w9 .long 0x4e0c1d01 // mov v1.s[1], w8 .long 0x0e401821 // uzp1 v1.4h, v1.4h, v0.4h .long 0x2e012000 // ext v0.8b, v0.8b, v1.8b, #4 .long 0x2e002000 // ext v0.8b, v0.8b, v0.8b, #4 .long 0x17ffffe0 // b 2b2c <_sk_load_g8_aarch64+0x3c> .long 0x39400108 // ldrb w8, [x8] .long 0x0e020fe0 // dup v0.4h, wzr .long 0x4e021d00 // mov v0.h[0], w8 .long 0x17ffffdc // b 2b2c <_sk_load_g8_aarch64+0x3c> HIDDEN _sk_load_g8_dst_aarch64 .globl _sk_load_g8_dst_aarch64 FUNCTION(_sk_load_g8_dst_aarch64) _sk_load_g8_dst_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x93407c6a // sxtw x10, w3 .long 0xf9400109 // ldr x9, [x8] .long 0xb9800908 // ldrsw x8, [x8, #8] .long 0x9b0a2508 // madd x8, x8, x10, x9 .long 0x8b22c108 // add x8, x8, w2, sxtw .long 0xb50002e4 // cbnz x4, 2c34 <_sk_load_g8_dst_aarch64+0x74> .long 0x39400109 // ldrb w9, [x8] .long 0x3940050a // ldrb w10, [x8, #1] .long 0x3940090b // ldrb w11, [x8, #2] .long 0x39400d08 // ldrb w8, [x8, #3] .long 0x4e021d24 // mov v4.h[0], w9 .long 0x4e061d44 // mov v4.h[1], w10 .long 0x4e0a1d64 // mov v4.h[2], w11 .long 0x4e0e1d04 // mov v4.h[3], w8 .long 0x2f07b7e4 // bic v4.4h, #0xff, lsl #8 .long 0x52a77008 // mov w8, #0x3b800000 .long 0x72901028 // movk w8, #0x8081 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x2f10a484 // uxtl v4.4s, v4.4h .long 0x4e040d05 // dup v5.4s, w8 .long 0x6e21d884 // ucvtf v4.4s, v4.4s .long 0x91004028 // add x8, x1, #0x10 .long 0x6e25dc84 // fmul v4.4s, v4.4s, v5.4s .long 0x4f03f607 // fmov v7.4s, #1.000000000000000000e+00 .long 0xaa0803e1 // mov x1, x8 .long 0x4ea41c85 // mov v5.16b, v4.16b .long 0x4ea41c86 // mov v6.16b, v4.16b .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 2c80 <_sk_load_g8_dst_aarch64+0xc0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e404 // movi d4, #0x0 .long 0x540000c0 // b.eq 2c60 <_sk_load_g8_dst_aarch64+0xa0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffd61 // b.ne 2bfc <_sk_load_g8_dst_aarch64+0x3c> // b.any .long 0x39400909 // ldrb w9, [x8, #2] .long 0x0e020fe4 // dup v4.4h, wzr .long 0x4e0a1d24 // mov v4.h[2], w9 .long 0x39400109 // ldrb w9, [x8] .long 0x39400508 // ldrb w8, [x8, #1] .long 0x4e041d25 // mov v5.s[0], w9 .long 0x4e0c1d05 // mov v5.s[1], w8 .long 0x0e4018a5 // uzp1 v5.4h, v5.4h, v0.4h .long 0x2e052084 // ext v4.8b, v4.8b, v5.8b, #4 .long 0x2e042084 // ext v4.8b, v4.8b, v4.8b, #4 .long 0x17ffffe0 // b 2bfc <_sk_load_g8_dst_aarch64+0x3c> .long 0x39400108 // ldrb w8, [x8] .long 0x0e020fe4 // dup v4.4h, wzr .long 0x4e021d04 // mov v4.h[0], w8 .long 0x17ffffdc // b 2bfc <_sk_load_g8_dst_aarch64+0x3c> HIDDEN _sk_gather_g8_aarch64 .globl _sk_gather_g8_aarch64 FUNCTION(_sk_gather_g8_aarch64) _sk_gather_g8_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ea1b821 // fcvtzs v1.4s, v1.4s .long 0x4ea1b800 // fcvtzs v0.4s, v0.4s .long 0x91002109 // add x9, x8, #0x8 .long 0x4d40c922 // ld1r {v2.4s}, [x9] .long 0xf9400108 // ldr x8, [x8] .long 0x52a77009 // mov w9, #0x3b800000 .long 0x72901029 // movk w9, #0x8081 .long 0x4ea19440 // mla v0.4s, v2.4s, v1.4s .long 0x1e26000c // fmov w12, s0 .long 0x4e040d23 // dup v3.4s, w9 .long 0x0e0c3c09 // mov w9, v0.s[1] .long 0x386c490c // ldrb w12, [x8, w12, uxtw] .long 0x0e143c0a // mov w10, v0.s[2] .long 0x38694909 // ldrb w9, [x8, w9, uxtw] .long 0x0e1c3c0b // mov w11, v0.s[3] .long 0x386a490a // ldrb w10, [x8, w10, uxtw] .long 0x386b4908 // ldrb w8, [x8, w11, uxtw] .long 0x4e021d80 // mov v0.h[0], w12 .long 0x4e061d20 // mov v0.h[1], w9 .long 0x4e0a1d40 // mov v0.h[2], w10 .long 0x4e0e1d00 // mov v0.h[3], w8 .long 0x2f07b7e0 // bic v0.4h, #0xff, lsl #8 .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x6e21d800 // ucvtf v0.4s, v0.4s .long 0x6e23dc00 // fmul v0.4s, v0.4s, v3.4s .long 0x4f03f603 // fmov v3.4s, #1.000000000000000000e+00 .long 0x4ea01c01 // mov v1.16b, v0.16b .long 0x4ea01c02 // mov v2.16b, v0.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_load_565_aarch64 .globl _sk_load_565_aarch64 FUNCTION(_sk_load_565_aarch64) _sk_load_565_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897d08 // add x8, x8, x9, asr #31 .long 0xb50003c4 // cbnz x4, 2d9c <_sk_load_565_aarch64+0x94> .long 0xfd400100 // ldr d0, [x8] .long 0x321b17e8 // orr w8, wzr, #0x7e0 .long 0x4e040d02 // dup v2.4s, w8 .long 0x52a6f088 // mov w8, #0x37840000 .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x4f072701 // movi v1.4s, #0xf8, lsl #8 .long 0x72842108 // movk w8, #0x2108 .long 0x4f0007e3 // movi v3.4s, #0x1f .long 0x4e211c01 // and v1.16b, v0.16b, v1.16b .long 0x4e231c03 // and v3.16b, v0.16b, v3.16b .long 0x4e221c10 // and v16.16b, v0.16b, v2.16b .long 0x4e040d00 // dup v0.4s, w8 .long 0x52a7a088 // mov w8, #0x3d040000 .long 0x72842108 // movk w8, #0x2108 .long 0x4e21d821 // scvtf v1.4s, v1.4s .long 0x6e20dc20 // fmul v0.4s, v1.4s, v0.4s .long 0x4e040d01 // dup v1.4s, w8 .long 0x52a74048 // mov w8, #0x3a020000 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72810428 // movk w8, #0x821 .long 0x4e21d862 // scvtf v2.4s, v3.4s .long 0x6e21dc42 // fmul v2.4s, v2.4s, v1.4s .long 0x4e040d01 // dup v1.4s, w8 .long 0x91004028 // add x8, x1, #0x10 .long 0x4e21da03 // scvtf v3.4s, v16.4s .long 0x6e21dc61 // fmul v1.4s, v3.4s, v1.4s .long 0x4f03f603 // fmov v3.4s, #1.000000000000000000e+00 .long 0xaa0803e1 // mov x1, x8 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 2de8 <_sk_load_565_aarch64+0xe0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e400 // movi d0, #0x0 .long 0x540000c0 // b.eq 2dc8 <_sk_load_565_aarch64+0xc0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffba1 // b.ne 2d2c <_sk_load_565_aarch64+0x24> // b.any .long 0x91001109 // add x9, x8, #0x4 .long 0x0e020fe0 // dup v0.4h, wzr .long 0x0d405120 // ld1 {v0.h}[2], [x9] .long 0x79400109 // ldrh w9, [x8] .long 0x79400508 // ldrh w8, [x8, #2] .long 0x4e041d21 // mov v1.s[0], w9 .long 0x4e0c1d01 // mov v1.s[1], w8 .long 0x0e401821 // uzp1 v1.4h, v1.4h, v0.4h .long 0x2e012000 // ext v0.8b, v0.8b, v1.8b, #4 .long 0x2e002000 // ext v0.8b, v0.8b, v0.8b, #4 .long 0x17ffffd2 // b 2d2c <_sk_load_565_aarch64+0x24> .long 0x0e020fe0 // dup v0.4h, wzr .long 0x0d404100 // ld1 {v0.h}[0], [x8] .long 0x17ffffcf // b 2d2c <_sk_load_565_aarch64+0x24> HIDDEN _sk_load_565_dst_aarch64 .globl _sk_load_565_dst_aarch64 FUNCTION(_sk_load_565_dst_aarch64) _sk_load_565_dst_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897d08 // add x8, x8, x9, asr #31 .long 0xb50003c4 // cbnz x4, 2e88 <_sk_load_565_dst_aarch64+0x94> .long 0xfd400104 // ldr d4, [x8] .long 0x321b17e8 // orr w8, wzr, #0x7e0 .long 0x4e040d06 // dup v6.4s, w8 .long 0x52a6f088 // mov w8, #0x37840000 .long 0x2f10a484 // uxtl v4.4s, v4.4h .long 0x4f072705 // movi v5.4s, #0xf8, lsl #8 .long 0x72842108 // movk w8, #0x2108 .long 0x4f0007e7 // movi v7.4s, #0x1f .long 0x4e251c85 // and v5.16b, v4.16b, v5.16b .long 0x4e271c87 // and v7.16b, v4.16b, v7.16b .long 0x4e261c90 // and v16.16b, v4.16b, v6.16b .long 0x4e040d04 // dup v4.4s, w8 .long 0x52a7a088 // mov w8, #0x3d040000 .long 0x72842108 // movk w8, #0x2108 .long 0x4e21d8a5 // scvtf v5.4s, v5.4s .long 0x6e24dca4 // fmul v4.4s, v5.4s, v4.4s .long 0x4e040d05 // dup v5.4s, w8 .long 0x52a74048 // mov w8, #0x3a020000 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72810428 // movk w8, #0x821 .long 0x4e21d8e6 // scvtf v6.4s, v7.4s .long 0x6e25dcc6 // fmul v6.4s, v6.4s, v5.4s .long 0x4e040d05 // dup v5.4s, w8 .long 0x91004028 // add x8, x1, #0x10 .long 0x4e21da07 // scvtf v7.4s, v16.4s .long 0x6e25dce5 // fmul v5.4s, v7.4s, v5.4s .long 0x4f03f607 // fmov v7.4s, #1.000000000000000000e+00 .long 0xaa0803e1 // mov x1, x8 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 2ed4 <_sk_load_565_dst_aarch64+0xe0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e404 // movi d4, #0x0 .long 0x540000c0 // b.eq 2eb4 <_sk_load_565_dst_aarch64+0xc0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffba1 // b.ne 2e18 <_sk_load_565_dst_aarch64+0x24> // b.any .long 0x91001109 // add x9, x8, #0x4 .long 0x0e020fe4 // dup v4.4h, wzr .long 0x0d405124 // ld1 {v4.h}[2], [x9] .long 0x79400109 // ldrh w9, [x8] .long 0x79400508 // ldrh w8, [x8, #2] .long 0x4e041d25 // mov v5.s[0], w9 .long 0x4e0c1d05 // mov v5.s[1], w8 .long 0x0e4018a5 // uzp1 v5.4h, v5.4h, v0.4h .long 0x2e052084 // ext v4.8b, v4.8b, v5.8b, #4 .long 0x2e042084 // ext v4.8b, v4.8b, v4.8b, #4 .long 0x17ffffd2 // b 2e18 <_sk_load_565_dst_aarch64+0x24> .long 0x0e020fe4 // dup v4.4h, wzr .long 0x0d404104 // ld1 {v4.h}[0], [x8] .long 0x17ffffcf // b 2e18 <_sk_load_565_dst_aarch64+0x24> HIDDEN _sk_gather_565_aarch64 .globl _sk_gather_565_aarch64 FUNCTION(_sk_gather_565_aarch64) _sk_gather_565_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ea1b821 // fcvtzs v1.4s, v1.4s .long 0x4ea1b800 // fcvtzs v0.4s, v0.4s .long 0x91002109 // add x9, x8, #0x8 .long 0x4d40c922 // ld1r {v2.4s}, [x9] .long 0xf9400108 // ldr x8, [x8] .long 0x321b17e9 // orr w9, wzr, #0x7e0 .long 0x4e040d23 // dup v3.4s, w9 .long 0x4ea19440 // mla v0.4s, v2.4s, v1.4s .long 0x1e26000c // fmov w12, s0 .long 0x0e0c3c09 // mov w9, v0.s[1] .long 0x8b2c450c // add x12, x8, w12, uxtw #1 .long 0x0e143c0a // mov w10, v0.s[2] .long 0x0e1c3c0b // mov w11, v0.s[3] .long 0x0d404180 // ld1 {v0.h}[0], [x12] .long 0x78695909 // ldrh w9, [x8, w9, uxtw #1] .long 0x786a590a // ldrh w10, [x8, w10, uxtw #1] .long 0x786b5908 // ldrh w8, [x8, w11, uxtw #1] .long 0x4f072701 // movi v1.4s, #0xf8, lsl #8 .long 0x4e061d20 // mov v0.h[1], w9 .long 0x4e0a1d40 // mov v0.h[2], w10 .long 0x4e0e1d00 // mov v0.h[3], w8 .long 0x52a6f08b // mov w11, #0x37840000 .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x7284210b // movk w11, #0x2108 .long 0x52a74049 // mov w9, #0x3a020000 .long 0x4f0007e2 // movi v2.4s, #0x1f .long 0x4e211c01 // and v1.16b, v0.16b, v1.16b .long 0x72810429 // movk w9, #0x821 .long 0x52a7a08a // mov w10, #0x3d040000 .long 0x4e231c03 // and v3.16b, v0.16b, v3.16b .long 0x4e221c02 // and v2.16b, v0.16b, v2.16b .long 0x4e040d60 // dup v0.4s, w11 .long 0x4e21d821 // scvtf v1.4s, v1.4s .long 0x7284210a // movk w10, #0x2108 .long 0x6e20dc20 // fmul v0.4s, v1.4s, v0.4s .long 0x4e040d21 // dup v1.4s, w9 .long 0x4e21d863 // scvtf v3.4s, v3.4s .long 0x6e21dc61 // fmul v1.4s, v3.4s, v1.4s .long 0x4e040d43 // dup v3.4s, w10 .long 0x4e21d842 // scvtf v2.4s, v2.4s .long 0x6e23dc42 // fmul v2.4s, v2.4s, v3.4s .long 0x4f03f603 // fmov v3.4s, #1.000000000000000000e+00 .long 0xd61f00a0 // br x5 HIDDEN _sk_store_565_aarch64 .globl _sk_store_565_aarch64 FUNCTION(_sk_store_565_aarch64) _sk_store_565_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52a84f8a // mov w10, #0x427c0000 .long 0x4e040d50 // dup v16.4s, w10 .long 0x4f01f7f1 // fmov v17.4s, #3.100000000000000000e+01 .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x6e31dc12 // fmul v18.4s, v0.4s, v17.4s .long 0x6e30dc30 // fmul v16.4s, v1.4s, v16.4s .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s .long 0x6e21aa10 // fcvtnu v16.4s, v16.4s .long 0x6e31dc51 // fmul v17.4s, v2.4s, v17.4s .long 0x4f2b5652 // shl v18.4s, v18.4s, #11 .long 0x4f255610 // shl v16.4s, v16.4s, #5 .long 0x1b037d29 // mul w9, w9, w3 .long 0x6e21aa31 // fcvtnu v17.4s, v17.4s .long 0x4eb21e10 // orr v16.16b, v16.16b, v18.16b .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x4eb11e10 // orr v16.16b, v16.16b, v17.16b .long 0x8b897d08 // add x8, x8, x9, asr #31 .long 0x0e612a10 // xtn v16.4h, v16.4s .long 0xb50000a4 // cbnz x4, 2ff8 <_sk_store_565_aarch64+0x68> .long 0xfd000110 // str d16, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000120 // b.eq 3024 <_sk_store_565_aarch64+0x94> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x540000a0 // b.eq 301c <_sk_store_565_aarch64+0x8c> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffee1 // b.ne 2fec <_sk_store_565_aarch64+0x5c> // b.any .long 0x91001109 // add x9, x8, #0x4 .long 0x0d005130 // st1 {v16.h}[2], [x9] .long 0x91000909 // add x9, x8, #0x2 .long 0x0d004930 // st1 {v16.h}[1], [x9] .long 0x0d004110 // st1 {v16.h}[0], [x8] .long 0x17fffff1 // b 2fec <_sk_store_565_aarch64+0x5c> HIDDEN _sk_load_4444_aarch64 .globl _sk_load_4444_aarch64 FUNCTION(_sk_load_4444_aarch64) _sk_load_4444_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897d08 // add x8, x8, x9, asr #31 .long 0xb5000444 // cbnz x4, 30d0 <_sk_load_4444_aarch64+0xa4> .long 0xfd400100 // ldr d0, [x8] .long 0x52a6f108 // mov w8, #0x37880000 .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x4f072601 // movi v1.4s, #0xf0, lsl #8 .long 0x72911128 // movk w8, #0x8889 .long 0x4f0025e2 // movi v2.4s, #0xf, lsl #8 .long 0x4f070603 // movi v3.4s, #0xf0 .long 0x4f0005f0 // movi v16.4s, #0xf .long 0x4e211c01 // and v1.16b, v0.16b, v1.16b .long 0x4e221c02 // and v2.16b, v0.16b, v2.16b .long 0x4e231c03 // and v3.16b, v0.16b, v3.16b .long 0x4e301c10 // and v16.16b, v0.16b, v16.16b .long 0x4e040d00 // dup v0.4s, w8 .long 0x52a73108 // mov w8, #0x39880000 .long 0x72911128 // movk w8, #0x8889 .long 0x4e21d821 // scvtf v1.4s, v1.4s .long 0x6e20dc20 // fmul v0.4s, v1.4s, v0.4s .long 0x4e040d01 // dup v1.4s, w8 .long 0x52a77108 // mov w8, #0x3b880000 .long 0x72911128 // movk w8, #0x8889 .long 0x4e21d842 // scvtf v2.4s, v2.4s .long 0x6e21dc41 // fmul v1.4s, v2.4s, v1.4s .long 0x4e040d02 // dup v2.4s, w8 .long 0x52a7b108 // mov w8, #0x3d880000 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72911128 // movk w8, #0x8889 .long 0x4e21d863 // scvtf v3.4s, v3.4s .long 0x6e22dc62 // fmul v2.4s, v3.4s, v2.4s .long 0x4e040d03 // dup v3.4s, w8 .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x6e23de03 // fmul v3.4s, v16.4s, v3.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 311c <_sk_load_4444_aarch64+0xf0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e400 // movi d0, #0x0 .long 0x540000c0 // b.eq 30fc <_sk_load_4444_aarch64+0xd0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffb21 // b.ne 3050 <_sk_load_4444_aarch64+0x24> // b.any .long 0x91001109 // add x9, x8, #0x4 .long 0x0e020fe0 // dup v0.4h, wzr .long 0x0d405120 // ld1 {v0.h}[2], [x9] .long 0x79400109 // ldrh w9, [x8] .long 0x79400508 // ldrh w8, [x8, #2] .long 0x4e041d21 // mov v1.s[0], w9 .long 0x4e0c1d01 // mov v1.s[1], w8 .long 0x0e401821 // uzp1 v1.4h, v1.4h, v0.4h .long 0x2e012000 // ext v0.8b, v0.8b, v1.8b, #4 .long 0x2e002000 // ext v0.8b, v0.8b, v0.8b, #4 .long 0x17ffffce // b 3050 <_sk_load_4444_aarch64+0x24> .long 0x0e020fe0 // dup v0.4h, wzr .long 0x0d404100 // ld1 {v0.h}[0], [x8] .long 0x17ffffcb // b 3050 <_sk_load_4444_aarch64+0x24> HIDDEN _sk_load_4444_dst_aarch64 .globl _sk_load_4444_dst_aarch64 FUNCTION(_sk_load_4444_dst_aarch64) _sk_load_4444_dst_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897d08 // add x8, x8, x9, asr #31 .long 0xb5000444 // cbnz x4, 31cc <_sk_load_4444_dst_aarch64+0xa4> .long 0xfd400104 // ldr d4, [x8] .long 0x52a6f108 // mov w8, #0x37880000 .long 0x2f10a484 // uxtl v4.4s, v4.4h .long 0x4f072605 // movi v5.4s, #0xf0, lsl #8 .long 0x72911128 // movk w8, #0x8889 .long 0x4f0025e6 // movi v6.4s, #0xf, lsl #8 .long 0x4f070607 // movi v7.4s, #0xf0 .long 0x4f0005f0 // movi v16.4s, #0xf .long 0x4e251c85 // and v5.16b, v4.16b, v5.16b .long 0x4e261c86 // and v6.16b, v4.16b, v6.16b .long 0x4e271c87 // and v7.16b, v4.16b, v7.16b .long 0x4e301c90 // and v16.16b, v4.16b, v16.16b .long 0x4e040d04 // dup v4.4s, w8 .long 0x52a73108 // mov w8, #0x39880000 .long 0x72911128 // movk w8, #0x8889 .long 0x4e21d8a5 // scvtf v5.4s, v5.4s .long 0x6e24dca4 // fmul v4.4s, v5.4s, v4.4s .long 0x4e040d05 // dup v5.4s, w8 .long 0x52a77108 // mov w8, #0x3b880000 .long 0x72911128 // movk w8, #0x8889 .long 0x4e21d8c6 // scvtf v6.4s, v6.4s .long 0x6e25dcc5 // fmul v5.4s, v6.4s, v5.4s .long 0x4e040d06 // dup v6.4s, w8 .long 0x52a7b108 // mov w8, #0x3d880000 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72911128 // movk w8, #0x8889 .long 0x4e21d8e7 // scvtf v7.4s, v7.4s .long 0x6e26dce6 // fmul v6.4s, v7.4s, v6.4s .long 0x4e040d07 // dup v7.4s, w8 .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x6e27de07 // fmul v7.4s, v16.4s, v7.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000220 // b.eq 3218 <_sk_load_4444_dst_aarch64+0xf0> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x2f00e404 // movi d4, #0x0 .long 0x540000c0 // b.eq 31f8 <_sk_load_4444_dst_aarch64+0xd0> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffb21 // b.ne 314c <_sk_load_4444_dst_aarch64+0x24> // b.any .long 0x91001109 // add x9, x8, #0x4 .long 0x0e020fe4 // dup v4.4h, wzr .long 0x0d405124 // ld1 {v4.h}[2], [x9] .long 0x79400109 // ldrh w9, [x8] .long 0x79400508 // ldrh w8, [x8, #2] .long 0x4e041d25 // mov v5.s[0], w9 .long 0x4e0c1d05 // mov v5.s[1], w8 .long 0x0e4018a5 // uzp1 v5.4h, v5.4h, v0.4h .long 0x2e052084 // ext v4.8b, v4.8b, v5.8b, #4 .long 0x2e042084 // ext v4.8b, v4.8b, v4.8b, #4 .long 0x17ffffce // b 314c <_sk_load_4444_dst_aarch64+0x24> .long 0x0e020fe4 // dup v4.4h, wzr .long 0x0d404104 // ld1 {v4.h}[0], [x8] .long 0x17ffffcb // b 314c <_sk_load_4444_dst_aarch64+0x24> HIDDEN _sk_gather_4444_aarch64 .globl _sk_gather_4444_aarch64 FUNCTION(_sk_gather_4444_aarch64) _sk_gather_4444_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ea1b821 // fcvtzs v1.4s, v1.4s .long 0x4ea1b800 // fcvtzs v0.4s, v0.4s .long 0x4f070603 // movi v3.4s, #0xf0 .long 0x91002109 // add x9, x8, #0x8 .long 0x4d40c922 // ld1r {v2.4s}, [x9] .long 0xf9400108 // ldr x8, [x8] .long 0x4f0005f0 // movi v16.4s, #0xf .long 0x4ea19440 // mla v0.4s, v2.4s, v1.4s .long 0x1e26000c // fmov w12, s0 .long 0x0e0c3c09 // mov w9, v0.s[1] .long 0x8b2c450c // add x12, x8, w12, uxtw #1 .long 0x0e143c0a // mov w10, v0.s[2] .long 0x0e1c3c0b // mov w11, v0.s[3] .long 0x0d404180 // ld1 {v0.h}[0], [x12] .long 0x78695909 // ldrh w9, [x8, w9, uxtw #1] .long 0x786a590a // ldrh w10, [x8, w10, uxtw #1] .long 0x786b5908 // ldrh w8, [x8, w11, uxtw #1] .long 0x4f072601 // movi v1.4s, #0xf0, lsl #8 .long 0x4e061d20 // mov v0.h[1], w9 .long 0x4e0a1d40 // mov v0.h[2], w10 .long 0x4e0e1d00 // mov v0.h[3], w8 .long 0x52a6f10b // mov w11, #0x37880000 .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x7291112b // movk w11, #0x8889 .long 0x4f0025e2 // movi v2.4s, #0xf, lsl #8 .long 0x52a73109 // mov w9, #0x39880000 .long 0x4e211c01 // and v1.16b, v0.16b, v1.16b .long 0x72911129 // movk w9, #0x8889 .long 0x52a7710a // mov w10, #0x3b880000 .long 0x4e221c02 // and v2.16b, v0.16b, v2.16b .long 0x4e231c03 // and v3.16b, v0.16b, v3.16b .long 0x4e301c10 // and v16.16b, v0.16b, v16.16b .long 0x4e040d60 // dup v0.4s, w11 .long 0x4e21d821 // scvtf v1.4s, v1.4s .long 0x7291112a // movk w10, #0x8889 .long 0x52a7b108 // mov w8, #0x3d880000 .long 0x6e20dc20 // fmul v0.4s, v1.4s, v0.4s .long 0x4e040d21 // dup v1.4s, w9 .long 0x4e21d842 // scvtf v2.4s, v2.4s .long 0x72911128 // movk w8, #0x8889 .long 0x6e21dc41 // fmul v1.4s, v2.4s, v1.4s .long 0x4e040d42 // dup v2.4s, w10 .long 0x4e21d863 // scvtf v3.4s, v3.4s .long 0x6e22dc62 // fmul v2.4s, v3.4s, v2.4s .long 0x4e040d03 // dup v3.4s, w8 .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x6e23de03 // fmul v3.4s, v16.4s, v3.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_store_4444_aarch64 .globl _sk_store_4444_aarch64 FUNCTION(_sk_store_4444_aarch64) _sk_store_4444_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x4f01f5d0 // fmov v16.4s, #1.500000000000000000e+01 .long 0x6e30dc11 // fmul v17.4s, v0.4s, v16.4s .long 0x6e30dc32 // fmul v18.4s, v1.4s, v16.4s .long 0x6e21aa31 // fcvtnu v17.4s, v17.4s .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s .long 0xb9400909 // ldr w9, [x8, #8] .long 0x4f2c5631 // shl v17.4s, v17.4s, #12 .long 0x4f285652 // shl v18.4s, v18.4s, #8 .long 0xf9400108 // ldr x8, [x8] .long 0x4eb11e51 // orr v17.16b, v18.16b, v17.16b .long 0x6e30dc52 // fmul v18.4s, v2.4s, v16.4s .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s .long 0x6e30dc70 // fmul v16.4s, v3.4s, v16.4s .long 0x4f245652 // shl v18.4s, v18.4s, #4 .long 0x1b037d29 // mul w9, w9, w3 .long 0x6e21aa10 // fcvtnu v16.4s, v16.4s .long 0x4eb21e31 // orr v17.16b, v17.16b, v18.16b .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x4eb01e30 // orr v16.16b, v17.16b, v16.16b .long 0x8b897d08 // add x8, x8, x9, asr #31 .long 0x0e612a10 // xtn v16.4h, v16.4s .long 0xb50000a4 // cbnz x4, 3358 <_sk_store_4444_aarch64+0x70> .long 0xfd000110 // str d16, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000120 // b.eq 3384 <_sk_store_4444_aarch64+0x9c> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x540000a0 // b.eq 337c <_sk_store_4444_aarch64+0x94> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffee1 // b.ne 334c <_sk_store_4444_aarch64+0x64> // b.any .long 0x91001109 // add x9, x8, #0x4 .long 0x0d005130 // st1 {v16.h}[2], [x9] .long 0x91000909 // add x9, x8, #0x2 .long 0x0d004930 // st1 {v16.h}[1], [x9] .long 0x0d004110 // st1 {v16.h}[0], [x8] .long 0x17fffff1 // b 334c <_sk_store_4444_aarch64+0x64> HIDDEN _sk_load_8888_aarch64 .globl _sk_load_8888_aarch64 FUNCTION(_sk_load_8888_aarch64) _sk_load_8888_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897908 // add x8, x8, x9, asr #30 .long 0xb50002e4 // cbnz x4, 3404 <_sk_load_8888_aarch64+0x78> .long 0x3dc00100 // ldr q0, [x8] .long 0x6f00e621 // movi v1.2d, #0xff000000ff .long 0x52a77008 // mov w8, #0x3b800000 .long 0x6f380402 // ushr v2.4s, v0.4s, #8 .long 0x6f300403 // ushr v3.4s, v0.4s, #16 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72901028 // movk w8, #0x8081 .long 0x6f280410 // ushr v16.4s, v0.4s, #24 .long 0x4e211c00 // and v0.16b, v0.16b, v1.16b .long 0x4e211c42 // and v2.16b, v2.16b, v1.16b .long 0x4e211c61 // and v1.16b, v3.16b, v1.16b .long 0x4e040d11 // dup v17.4s, w8 .long 0x4e21da03 // scvtf v3.4s, v16.4s .long 0x4e21d800 // scvtf v0.4s, v0.4s .long 0x4e21d842 // scvtf v2.4s, v2.4s .long 0x4e21d830 // scvtf v16.4s, v1.4s .long 0x6e31dc63 // fmul v3.4s, v3.4s, v17.4s .long 0x6e31dc00 // fmul v0.4s, v0.4s, v17.4s .long 0x6e31dc41 // fmul v1.4s, v2.4s, v17.4s .long 0x6e31de02 // fmul v2.4s, v16.4s, v17.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x540001a0 // b.eq 3440 <_sk_load_8888_aarch64+0xb4> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x6f00e400 // movi v0.2d, #0x0 .long 0x540000c0 // b.eq 3430 <_sk_load_8888_aarch64+0xa4> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffc81 // b.ne 33b0 <_sk_load_8888_aarch64+0x24> // b.any .long 0x91002109 // add x9, x8, #0x8 .long 0x4e040fe0 // dup v0.4s, wzr .long 0x4d408120 // ld1 {v0.s}[2], [x9] .long 0xfd400101 // ldr d1, [x8] .long 0x6e014000 // ext v0.16b, v0.16b, v1.16b, #8 .long 0x6e004000 // ext v0.16b, v0.16b, v0.16b, #8 .long 0x17ffffdd // b 33b0 <_sk_load_8888_aarch64+0x24> .long 0x4e040fe0 // dup v0.4s, wzr .long 0x0d408100 // ld1 {v0.s}[0], [x8] .long 0x17ffffda // b 33b0 <_sk_load_8888_aarch64+0x24> HIDDEN _sk_load_8888_dst_aarch64 .globl _sk_load_8888_dst_aarch64 FUNCTION(_sk_load_8888_dst_aarch64) _sk_load_8888_dst_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897908 // add x8, x8, x9, asr #30 .long 0xb50002e4 // cbnz x4, 34c4 <_sk_load_8888_dst_aarch64+0x78> .long 0x3dc00104 // ldr q4, [x8] .long 0x6f00e625 // movi v5.2d, #0xff000000ff .long 0x52a77008 // mov w8, #0x3b800000 .long 0x6f380486 // ushr v6.4s, v4.4s, #8 .long 0x6f300487 // ushr v7.4s, v4.4s, #16 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72901028 // movk w8, #0x8081 .long 0x6f280490 // ushr v16.4s, v4.4s, #24 .long 0x4e251c84 // and v4.16b, v4.16b, v5.16b .long 0x4e251cc6 // and v6.16b, v6.16b, v5.16b .long 0x4e251ce5 // and v5.16b, v7.16b, v5.16b .long 0x4e040d11 // dup v17.4s, w8 .long 0x4e21da07 // scvtf v7.4s, v16.4s .long 0x4e21d884 // scvtf v4.4s, v4.4s .long 0x4e21d8c6 // scvtf v6.4s, v6.4s .long 0x4e21d8b0 // scvtf v16.4s, v5.4s .long 0x6e31dce7 // fmul v7.4s, v7.4s, v17.4s .long 0x6e31dc84 // fmul v4.4s, v4.4s, v17.4s .long 0x6e31dcc5 // fmul v5.4s, v6.4s, v17.4s .long 0x6e31de06 // fmul v6.4s, v16.4s, v17.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x540001a0 // b.eq 3500 <_sk_load_8888_dst_aarch64+0xb4> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x6f00e404 // movi v4.2d, #0x0 .long 0x540000c0 // b.eq 34f0 <_sk_load_8888_dst_aarch64+0xa4> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffc81 // b.ne 3470 <_sk_load_8888_dst_aarch64+0x24> // b.any .long 0x91002109 // add x9, x8, #0x8 .long 0x4e040fe4 // dup v4.4s, wzr .long 0x4d408124 // ld1 {v4.s}[2], [x9] .long 0xfd400105 // ldr d5, [x8] .long 0x6e054084 // ext v4.16b, v4.16b, v5.16b, #8 .long 0x6e044084 // ext v4.16b, v4.16b, v4.16b, #8 .long 0x17ffffdd // b 3470 <_sk_load_8888_dst_aarch64+0x24> .long 0x4e040fe4 // dup v4.4s, wzr .long 0x0d408104 // ld1 {v4.s}[0], [x8] .long 0x17ffffda // b 3470 <_sk_load_8888_dst_aarch64+0x24> HIDDEN _sk_gather_8888_aarch64 .globl _sk_gather_8888_aarch64 FUNCTION(_sk_gather_8888_aarch64) _sk_gather_8888_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ea1b821 // fcvtzs v1.4s, v1.4s .long 0x4ea1b800 // fcvtzs v0.4s, v0.4s .long 0x91002109 // add x9, x8, #0x8 .long 0x4d40c922 // ld1r {v2.4s}, [x9] .long 0xf9400108 // ldr x8, [x8] .long 0x4ea19440 // mla v0.4s, v2.4s, v1.4s .long 0x1e26000c // fmov w12, s0 .long 0x8b2c490c // add x12, x8, w12, uxtw #2 .long 0x0e0c3c09 // mov w9, v0.s[1] .long 0x0e143c0a // mov w10, v0.s[2] .long 0x0e1c3c0b // mov w11, v0.s[3] .long 0x0d408180 // ld1 {v0.s}[0], [x12] .long 0x8b294909 // add x9, x8, w9, uxtw #2 .long 0xb86a590a // ldr w10, [x8, w10, uxtw #2] .long 0xb86b5908 // ldr w8, [x8, w11, uxtw #2] .long 0x0d409120 // ld1 {v0.s}[1], [x9] .long 0x6f00e621 // movi v1.2d, #0xff000000ff .long 0x52a77009 // mov w9, #0x3b800000 .long 0x72901029 // movk w9, #0x8081 .long 0x4e141d40 // mov v0.s[2], w10 .long 0x4e1c1d00 // mov v0.s[3], w8 .long 0x6f380410 // ushr v16.4s, v0.4s, #8 .long 0x6f300411 // ushr v17.4s, v0.4s, #16 .long 0x4e211c03 // and v3.16b, v0.16b, v1.16b .long 0x6f280400 // ushr v0.4s, v0.4s, #24 .long 0x4e211e10 // and v16.16b, v16.16b, v1.16b .long 0x4e211e21 // and v1.16b, v17.16b, v1.16b .long 0x4e040d22 // dup v2.4s, w9 .long 0x4e21d863 // scvtf v3.4s, v3.4s .long 0x4e21d811 // scvtf v17.4s, v0.4s .long 0x4e21da10 // scvtf v16.4s, v16.4s .long 0x4e21d832 // scvtf v18.4s, v1.4s .long 0x6e22dc60 // fmul v0.4s, v3.4s, v2.4s .long 0x6e22de23 // fmul v3.4s, v17.4s, v2.4s .long 0x6e22de01 // fmul v1.4s, v16.4s, v2.4s .long 0x6e22de42 // fmul v2.4s, v18.4s, v2.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_store_8888_aarch64 .globl _sk_store_8888_aarch64 FUNCTION(_sk_store_8888_aarch64) _sk_store_8888_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52a86fea // mov w10, #0x437f0000 .long 0x4e040d50 // dup v16.4s, w10 .long 0x6e30dc32 // fmul v18.4s, v1.4s, v16.4s .long 0xb9400909 // ldr w9, [x8, #8] .long 0x6e30dc11 // fmul v17.4s, v0.4s, v16.4s .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s .long 0xf9400108 // ldr x8, [x8] .long 0x6e21aa31 // fcvtnu v17.4s, v17.4s .long 0x4f285652 // shl v18.4s, v18.4s, #8 .long 0x4eb11e51 // orr v17.16b, v18.16b, v17.16b .long 0x6e30dc52 // fmul v18.4s, v2.4s, v16.4s .long 0x6e30dc70 // fmul v16.4s, v3.4s, v16.4s .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s .long 0x1b037d29 // mul w9, w9, w3 .long 0x6e21aa10 // fcvtnu v16.4s, v16.4s .long 0x4f305652 // shl v18.4s, v18.4s, #16 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x4f385610 // shl v16.4s, v16.4s, #24 .long 0x4eb21e31 // orr v17.16b, v17.16b, v18.16b .long 0x8b897908 // add x8, x8, x9, asr #30 .long 0x4eb01e30 // orr v16.16b, v17.16b, v16.16b .long 0xb50000a4 // cbnz x4, 3614 <_sk_store_8888_aarch64+0x70> .long 0x3d800110 // str q16, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000120 // b.eq 3640 <_sk_store_8888_aarch64+0x9c> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x540000a0 // b.eq 3638 <_sk_store_8888_aarch64+0x94> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffee1 // b.ne 3608 <_sk_store_8888_aarch64+0x64> // b.any .long 0x91002109 // add x9, x8, #0x8 .long 0x4d008130 // st1 {v16.s}[2], [x9] .long 0xfd000110 // str d16, [x8] .long 0x17fffff3 // b 3608 <_sk_store_8888_aarch64+0x64> .long 0x0d008110 // st1 {v16.s}[0], [x8] .long 0x17fffff1 // b 3608 <_sk_store_8888_aarch64+0x64> HIDDEN _sk_load_bgra_aarch64 .globl _sk_load_bgra_aarch64 FUNCTION(_sk_load_bgra_aarch64) _sk_load_bgra_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897908 // add x8, x8, x9, asr #30 .long 0xb50002e4 // cbnz x4, 36c0 <_sk_load_bgra_aarch64+0x78> .long 0x3dc00100 // ldr q0, [x8] .long 0x6f00e621 // movi v1.2d, #0xff000000ff .long 0x52a77008 // mov w8, #0x3b800000 .long 0x6f380402 // ushr v2.4s, v0.4s, #8 .long 0x6f300403 // ushr v3.4s, v0.4s, #16 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72901028 // movk w8, #0x8081 .long 0x6f280410 // ushr v16.4s, v0.4s, #24 .long 0x4e211c00 // and v0.16b, v0.16b, v1.16b .long 0x4e211c42 // and v2.16b, v2.16b, v1.16b .long 0x4e211c61 // and v1.16b, v3.16b, v1.16b .long 0x4e040d11 // dup v17.4s, w8 .long 0x4e21da03 // scvtf v3.4s, v16.4s .long 0x4e21d800 // scvtf v0.4s, v0.4s .long 0x4e21d850 // scvtf v16.4s, v2.4s .long 0x4e21d832 // scvtf v18.4s, v1.4s .long 0x6e31dc63 // fmul v3.4s, v3.4s, v17.4s .long 0x6e31dc02 // fmul v2.4s, v0.4s, v17.4s .long 0x6e31de01 // fmul v1.4s, v16.4s, v17.4s .long 0x6e31de40 // fmul v0.4s, v18.4s, v17.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x540001a0 // b.eq 36fc <_sk_load_bgra_aarch64+0xb4> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x6f00e400 // movi v0.2d, #0x0 .long 0x540000c0 // b.eq 36ec <_sk_load_bgra_aarch64+0xa4> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffc81 // b.ne 366c <_sk_load_bgra_aarch64+0x24> // b.any .long 0x91002109 // add x9, x8, #0x8 .long 0x4e040fe0 // dup v0.4s, wzr .long 0x4d408120 // ld1 {v0.s}[2], [x9] .long 0xfd400101 // ldr d1, [x8] .long 0x6e014000 // ext v0.16b, v0.16b, v1.16b, #8 .long 0x6e004000 // ext v0.16b, v0.16b, v0.16b, #8 .long 0x17ffffdd // b 366c <_sk_load_bgra_aarch64+0x24> .long 0x4e040fe0 // dup v0.4s, wzr .long 0x0d408100 // ld1 {v0.s}[0], [x8] .long 0x17ffffda // b 366c <_sk_load_bgra_aarch64+0x24> HIDDEN _sk_load_bgra_dst_aarch64 .globl _sk_load_bgra_dst_aarch64 FUNCTION(_sk_load_bgra_dst_aarch64) _sk_load_bgra_dst_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897908 // add x8, x8, x9, asr #30 .long 0xb50002e4 // cbnz x4, 3780 <_sk_load_bgra_dst_aarch64+0x78> .long 0x3dc00104 // ldr q4, [x8] .long 0x6f00e625 // movi v5.2d, #0xff000000ff .long 0x52a77008 // mov w8, #0x3b800000 .long 0x6f380486 // ushr v6.4s, v4.4s, #8 .long 0x6f300487 // ushr v7.4s, v4.4s, #16 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x72901028 // movk w8, #0x8081 .long 0x6f280490 // ushr v16.4s, v4.4s, #24 .long 0x4e251c84 // and v4.16b, v4.16b, v5.16b .long 0x4e251cc6 // and v6.16b, v6.16b, v5.16b .long 0x4e251ce5 // and v5.16b, v7.16b, v5.16b .long 0x4e040d11 // dup v17.4s, w8 .long 0x4e21da07 // scvtf v7.4s, v16.4s .long 0x4e21d884 // scvtf v4.4s, v4.4s .long 0x4e21d8d0 // scvtf v16.4s, v6.4s .long 0x4e21d8b2 // scvtf v18.4s, v5.4s .long 0x6e31dce7 // fmul v7.4s, v7.4s, v17.4s .long 0x6e31dc86 // fmul v6.4s, v4.4s, v17.4s .long 0x6e31de05 // fmul v5.4s, v16.4s, v17.4s .long 0x6e31de44 // fmul v4.4s, v18.4s, v17.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x540001a0 // b.eq 37bc <_sk_load_bgra_dst_aarch64+0xb4> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x6f00e404 // movi v4.2d, #0x0 .long 0x540000c0 // b.eq 37ac <_sk_load_bgra_dst_aarch64+0xa4> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffc81 // b.ne 372c <_sk_load_bgra_dst_aarch64+0x24> // b.any .long 0x91002109 // add x9, x8, #0x8 .long 0x4e040fe4 // dup v4.4s, wzr .long 0x4d408124 // ld1 {v4.s}[2], [x9] .long 0xfd400105 // ldr d5, [x8] .long 0x6e054084 // ext v4.16b, v4.16b, v5.16b, #8 .long 0x6e044084 // ext v4.16b, v4.16b, v4.16b, #8 .long 0x17ffffdd // b 372c <_sk_load_bgra_dst_aarch64+0x24> .long 0x4e040fe4 // dup v4.4s, wzr .long 0x0d408104 // ld1 {v4.s}[0], [x8] .long 0x17ffffda // b 372c <_sk_load_bgra_dst_aarch64+0x24> HIDDEN _sk_gather_bgra_aarch64 .globl _sk_gather_bgra_aarch64 FUNCTION(_sk_gather_bgra_aarch64) _sk_gather_bgra_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ea1b821 // fcvtzs v1.4s, v1.4s .long 0x4ea1b800 // fcvtzs v0.4s, v0.4s .long 0x91002109 // add x9, x8, #0x8 .long 0x4d40c922 // ld1r {v2.4s}, [x9] .long 0xf9400108 // ldr x8, [x8] .long 0x4ea19440 // mla v0.4s, v2.4s, v1.4s .long 0x1e26000c // fmov w12, s0 .long 0x8b2c490c // add x12, x8, w12, uxtw #2 .long 0x0e0c3c09 // mov w9, v0.s[1] .long 0x0e143c0a // mov w10, v0.s[2] .long 0x0e1c3c0b // mov w11, v0.s[3] .long 0x0d408180 // ld1 {v0.s}[0], [x12] .long 0x8b294909 // add x9, x8, w9, uxtw #2 .long 0xb86a590a // ldr w10, [x8, w10, uxtw #2] .long 0xb86b5908 // ldr w8, [x8, w11, uxtw #2] .long 0x0d409120 // ld1 {v0.s}[1], [x9] .long 0x6f00e621 // movi v1.2d, #0xff000000ff .long 0x52a77009 // mov w9, #0x3b800000 .long 0x72901029 // movk w9, #0x8081 .long 0x4e141d40 // mov v0.s[2], w10 .long 0x4e1c1d00 // mov v0.s[3], w8 .long 0x6f380403 // ushr v3.4s, v0.4s, #8 .long 0x6f300411 // ushr v17.4s, v0.4s, #16 .long 0x4e211c02 // and v2.16b, v0.16b, v1.16b .long 0x6f280400 // ushr v0.4s, v0.4s, #24 .long 0x4e211c63 // and v3.16b, v3.16b, v1.16b .long 0x4e211e21 // and v1.16b, v17.16b, v1.16b .long 0x4e040d30 // dup v16.4s, w9 .long 0x4e21d842 // scvtf v2.4s, v2.4s .long 0x4e21d800 // scvtf v0.4s, v0.4s .long 0x4e21d871 // scvtf v17.4s, v3.4s .long 0x4e21d832 // scvtf v18.4s, v1.4s .long 0x6e30dc42 // fmul v2.4s, v2.4s, v16.4s .long 0x6e30dc03 // fmul v3.4s, v0.4s, v16.4s .long 0x6e30de21 // fmul v1.4s, v17.4s, v16.4s .long 0x6e30de40 // fmul v0.4s, v18.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_store_bgra_aarch64 .globl _sk_store_bgra_aarch64 FUNCTION(_sk_store_bgra_aarch64) _sk_store_bgra_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52a86fea // mov w10, #0x437f0000 .long 0x4e040d50 // dup v16.4s, w10 .long 0x6e30dc32 // fmul v18.4s, v1.4s, v16.4s .long 0xb9400909 // ldr w9, [x8, #8] .long 0x6e30dc51 // fmul v17.4s, v2.4s, v16.4s .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s .long 0xf9400108 // ldr x8, [x8] .long 0x6e21aa31 // fcvtnu v17.4s, v17.4s .long 0x4f285652 // shl v18.4s, v18.4s, #8 .long 0x4eb11e51 // orr v17.16b, v18.16b, v17.16b .long 0x6e30dc12 // fmul v18.4s, v0.4s, v16.4s .long 0x6e30dc70 // fmul v16.4s, v3.4s, v16.4s .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s .long 0x1b037d29 // mul w9, w9, w3 .long 0x6e21aa10 // fcvtnu v16.4s, v16.4s .long 0x4f305652 // shl v18.4s, v18.4s, #16 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x4f385610 // shl v16.4s, v16.4s, #24 .long 0x4eb21e31 // orr v17.16b, v17.16b, v18.16b .long 0x8b897908 // add x8, x8, x9, asr #30 .long 0x4eb01e30 // orr v16.16b, v17.16b, v16.16b .long 0xb50000a4 // cbnz x4, 38d0 <_sk_store_bgra_aarch64+0x70> .long 0x3d800110 // str q16, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x12000489 // and w9, w4, #0x3 .long 0x7100053f // cmp w9, #0x1 .long 0x54000120 // b.eq 38fc <_sk_store_bgra_aarch64+0x9c> // b.none .long 0x7100093f // cmp w9, #0x2 .long 0x540000a0 // b.eq 38f4 <_sk_store_bgra_aarch64+0x94> // b.none .long 0x71000d3f // cmp w9, #0x3 .long 0x54fffee1 // b.ne 38c4 <_sk_store_bgra_aarch64+0x64> // b.any .long 0x91002109 // add x9, x8, #0x8 .long 0x4d008130 // st1 {v16.s}[2], [x9] .long 0xfd000110 // str d16, [x8] .long 0x17fffff3 // b 38c4 <_sk_store_bgra_aarch64+0x64> .long 0x0d008110 // st1 {v16.s}[0], [x8] .long 0x17fffff1 // b 38c4 <_sk_store_bgra_aarch64+0x64> HIDDEN _sk_load_f16_aarch64 .globl _sk_load_f16_aarch64 FUNCTION(_sk_load_f16_aarch64) _sk_load_f16_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29cd08 // add x8, x8, w9, sxtw #3 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897508 // add x8, x8, x9, asr #29 .long 0xb5000124 // cbnz x4, 3944 <_sk_load_f16_aarch64+0x40> .long 0x0c400510 // ld4 {v16.4h-v19.4h}, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x0e217a00 // fcvtl v0.4s, v16.4h .long 0x0e217a21 // fcvtl v1.4s, v17.4h .long 0x0e217a42 // fcvtl v2.4s, v18.4h .long 0x0e217a63 // fcvtl v3.4s, v19.4h .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x0d606110 // ld4 {v16.h-v19.h}[0], [x8] .long 0xf100049f // cmp x4, #0x1 .long 0x54fffee0 // b.eq 3928 <_sk_load_f16_aarch64+0x24> // b.none .long 0x91002109 // add x9, x8, #0x8 .long 0x0d606930 // ld4 {v16.h-v19.h}[1], [x9] .long 0xf1000c9f // cmp x4, #0x3 .long 0x54fffe63 // b.cc 3928 <_sk_load_f16_aarch64+0x24> // b.lo, b.ul, b.last .long 0x91004108 // add x8, x8, #0x10 .long 0x0d607110 // ld4 {v16.h-v19.h}[2], [x8] .long 0x17fffff0 // b 3928 <_sk_load_f16_aarch64+0x24> HIDDEN _sk_load_f16_dst_aarch64 .globl _sk_load_f16_dst_aarch64 FUNCTION(_sk_load_f16_dst_aarch64) _sk_load_f16_dst_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29cd08 // add x8, x8, w9, sxtw #3 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897508 // add x8, x8, x9, asr #29 .long 0xb5000124 // cbnz x4, 39ac <_sk_load_f16_dst_aarch64+0x40> .long 0x0c400510 // ld4 {v16.4h-v19.4h}, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x0e217a04 // fcvtl v4.4s, v16.4h .long 0x0e217a25 // fcvtl v5.4s, v17.4h .long 0x0e217a46 // fcvtl v6.4s, v18.4h .long 0x0e217a67 // fcvtl v7.4s, v19.4h .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x0d606110 // ld4 {v16.h-v19.h}[0], [x8] .long 0xf100049f // cmp x4, #0x1 .long 0x54fffee0 // b.eq 3990 <_sk_load_f16_dst_aarch64+0x24> // b.none .long 0x91002109 // add x9, x8, #0x8 .long 0x0d606930 // ld4 {v16.h-v19.h}[1], [x9] .long 0xf1000c9f // cmp x4, #0x3 .long 0x54fffe63 // b.cc 3990 <_sk_load_f16_dst_aarch64+0x24> // b.lo, b.ul, b.last .long 0x91004108 // add x8, x8, #0x10 .long 0x0d607110 // ld4 {v16.h-v19.h}[2], [x8] .long 0x17fffff0 // b 3990 <_sk_load_f16_dst_aarch64+0x24> HIDDEN _sk_gather_f16_aarch64 .globl _sk_gather_f16_aarch64 FUNCTION(_sk_gather_f16_aarch64) _sk_gather_f16_aarch64: .long 0xa9bf7bfd // stp x29, x30, [sp, #-16]! .long 0xd100c3e9 // sub x9, sp, #0x30 .long 0x910003fd // mov x29, sp .long 0x927be93f // and sp, x9, #0xffffffffffffffe0 .long 0xf9400028 // ldr x8, [x1] .long 0x4ea1b821 // fcvtzs v1.4s, v1.4s .long 0x4ea1b800 // fcvtzs v0.4s, v0.4s .long 0x91002109 // add x9, x8, #0x8 .long 0x4d40c922 // ld1r {v2.4s}, [x9] .long 0xf9400108 // ldr x8, [x8] .long 0x4ea19440 // mla v0.4s, v2.4s, v1.4s .long 0x0e143c0a // mov w10, v0.s[2] .long 0x1e26000c // fmov w12, s0 .long 0x8b2c4d0c // add x12, x8, w12, uxtw #3 .long 0x8b2a4d0a // add x10, x8, w10, uxtw #3 .long 0x0e0c3c09 // mov w9, v0.s[1] .long 0x0e1c3c0b // mov w11, v0.s[3] .long 0x0d408540 // ld1 {v0.d}[0], [x10] .long 0x0d408581 // ld1 {v1.d}[0], [x12] .long 0x8b294d09 // add x9, x8, w9, uxtw #3 .long 0x8b2b4d08 // add x8, x8, w11, uxtw #3 .long 0x4d408500 // ld1 {v0.d}[1], [x8] .long 0x4d408521 // ld1 {v1.d}[1], [x9] .long 0x910003e8 // mov x8, sp .long 0xad0003e1 // stp q1, q0, [sp] .long 0x0c400510 // ld4 {v16.4h-v19.4h}, [x8] .long 0xf9400428 // ldr x8, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0x0e217a00 // fcvtl v0.4s, v16.4h .long 0x0e217a21 // fcvtl v1.4s, v17.4h .long 0x0e217a42 // fcvtl v2.4s, v18.4h .long 0x0e217a63 // fcvtl v3.4s, v19.4h .long 0xd63f0100 // blr x8 .long 0x910003bf // mov sp, x29 .long 0xa8c17bfd // ldp x29, x30, [sp], #16 .long 0xd65f03c0 // ret HIDDEN _sk_store_f16_aarch64 .globl _sk_store_f16_aarch64 FUNCTION(_sk_store_f16_aarch64) _sk_store_f16_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x0e216810 // fcvtn v16.4h, v0.4s .long 0x0e216831 // fcvtn v17.4h, v1.4s .long 0x0e216852 // fcvtn v18.4h, v2.4s .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x0e216873 // fcvtn v19.4h, v3.4s .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29cd08 // add x8, x8, w9, sxtw #3 .long 0xd3607c49 // lsl x9, x2, #32 .long 0x8b897508 // add x8, x8, x9, asr #29 .long 0xb50000a4 // cbnz x4, 3aa4 <_sk_store_f16_aarch64+0x40> .long 0x0c000510 // st4 {v16.4h-v19.4h}, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0xf100049f // cmp x4, #0x1 .long 0x0d206110 // st4 {v16.h-v19.h}[0], [x8] .long 0x54ffff60 // b.eq 3a98 <_sk_store_f16_aarch64+0x34> // b.none .long 0x91002109 // add x9, x8, #0x8 .long 0xf1000c9f // cmp x4, #0x3 .long 0x0d206930 // st4 {v16.h-v19.h}[1], [x9] .long 0x54fffee3 // b.cc 3a98 <_sk_store_f16_aarch64+0x34> // b.lo, b.ul, b.last .long 0x91004108 // add x8, x8, #0x10 .long 0x0d207110 // st4 {v16.h-v19.h}[2], [x8] .long 0x17fffff4 // b 3a98 <_sk_store_f16_aarch64+0x34> HIDDEN _sk_load_u16_be_aarch64 .globl _sk_load_u16_be_aarch64 FUNCTION(_sk_load_u16_be_aarch64) _sk_load_u16_be_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x531e744a // lsl w10, w2, #2 .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0x8b2ac508 // add x8, x8, w10, sxtw #1 .long 0xb5000404 // cbnz x4, 3b68 <_sk_load_u16_be_aarch64+0x9c> .long 0x0c400500 // ld4 {v0.4h-v3.4h}, [x8] .long 0x0f185410 // shl v16.4h, v0.4h, #8 .long 0x2f180411 // ushr v17.4h, v0.4h, #8 .long 0x0f185432 // shl v18.4h, v1.4h, #8 .long 0x2f180433 // ushr v19.4h, v1.4h, #8 .long 0x0f185454 // shl v20.4h, v2.4h, #8 .long 0x2f180455 // ushr v21.4h, v2.4h, #8 .long 0x0f185476 // shl v22.4h, v3.4h, #8 .long 0x2f180460 // ushr v0.4h, v3.4h, #8 .long 0x52a6f008 // mov w8, #0x37800000 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x0eb11e01 // orr v1.8b, v16.8b, v17.8b .long 0x0eb31e42 // orr v2.8b, v18.8b, v19.8b .long 0x0eb51e90 // orr v16.8b, v20.8b, v21.8b .long 0x0ea01ec0 // orr v0.8b, v22.8b, v0.8b .long 0x72801008 // movk w8, #0x80 .long 0x2f10a421 // uxtl v1.4s, v1.4h .long 0x2f10a442 // uxtl v2.4s, v2.4h .long 0x2f10a610 // uxtl v16.4s, v16.4h .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x4e040d03 // dup v3.4s, w8 .long 0x6e21d821 // ucvtf v1.4s, v1.4s .long 0x6e21d842 // ucvtf v2.4s, v2.4s .long 0x6e21da10 // ucvtf v16.4s, v16.4s .long 0x6e21d811 // ucvtf v17.4s, v0.4s .long 0x6e23dc20 // fmul v0.4s, v1.4s, v3.4s .long 0x6e23dc41 // fmul v1.4s, v2.4s, v3.4s .long 0x6e23de02 // fmul v2.4s, v16.4s, v3.4s .long 0x6e23de23 // fmul v3.4s, v17.4s, v3.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x0d606100 // ld4 {v0.h-v3.h}[0], [x8] .long 0xf100049f // cmp x4, #0x1 .long 0x54fffc00 // b.eq 3af0 <_sk_load_u16_be_aarch64+0x24> // b.none .long 0x91002109 // add x9, x8, #0x8 .long 0x0d606920 // ld4 {v0.h-v3.h}[1], [x9] .long 0xf1000c9f // cmp x4, #0x3 .long 0x54fffb83 // b.cc 3af0 <_sk_load_u16_be_aarch64+0x24> // b.lo, b.ul, b.last .long 0x91004108 // add x8, x8, #0x10 .long 0x0d607100 // ld4 {v0.h-v3.h}[2], [x8] .long 0x17ffffd9 // b 3af0 <_sk_load_u16_be_aarch64+0x24> HIDDEN _sk_load_rgb_u16_be_aarch64 .globl _sk_load_rgb_u16_be_aarch64 FUNCTION(_sk_load_rgb_u16_be_aarch64) _sk_load_rgb_u16_be_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0x0b020449 // add w9, w2, w2, lsl #1 .long 0xd3607d29 // lsl x9, x9, #32 .long 0x8b897d08 // add x8, x8, x9, asr #31 .long 0xb5000384 // cbnz x4, 3c20 <_sk_load_rgb_u16_be_aarch64+0x90> .long 0x0c404500 // ld3 {v0.4h-v2.4h}, [x8] .long 0x0f185403 // shl v3.4h, v0.4h, #8 .long 0x2f180410 // ushr v16.4h, v0.4h, #8 .long 0x0f185431 // shl v17.4h, v1.4h, #8 .long 0x2f180432 // ushr v18.4h, v1.4h, #8 .long 0x0f185453 // shl v19.4h, v2.4h, #8 .long 0x2f180440 // ushr v0.4h, v2.4h, #8 .long 0x52a6f008 // mov w8, #0x37800000 .long 0xf9400425 // ldr x5, [x1, #8] .long 0x0eb01c61 // orr v1.8b, v3.8b, v16.8b .long 0x0eb21e23 // orr v3.8b, v17.8b, v18.8b .long 0x0ea01e60 // orr v0.8b, v19.8b, v0.8b .long 0x72801008 // movk w8, #0x80 .long 0x2f10a421 // uxtl v1.4s, v1.4h .long 0x2f10a463 // uxtl v3.4s, v3.4h .long 0x2f10a400 // uxtl v0.4s, v0.4h .long 0x4e040d02 // dup v2.4s, w8 .long 0x91004028 // add x8, x1, #0x10 .long 0x6e21d821 // ucvtf v1.4s, v1.4s .long 0x6e21d863 // ucvtf v3.4s, v3.4s .long 0x6e21d810 // ucvtf v16.4s, v0.4s .long 0x6e22dc20 // fmul v0.4s, v1.4s, v2.4s .long 0x6e22dc61 // fmul v1.4s, v3.4s, v2.4s .long 0x6e22de02 // fmul v2.4s, v16.4s, v2.4s .long 0x4f03f603 // fmov v3.4s, #1.000000000000000000e+00 .long 0xaa0803e1 // mov x1, x8 .long 0xd61f00a0 // br x5 .long 0x0d406100 // ld3 {v0.h-v2.h}[0], [x8] .long 0xf100049f // cmp x4, #0x1 .long 0x54fffc80 // b.eq 3bb8 <_sk_load_rgb_u16_be_aarch64+0x28> // b.none .long 0x91001909 // add x9, x8, #0x6 .long 0x0d406920 // ld3 {v0.h-v2.h}[1], [x9] .long 0xf1000c9f // cmp x4, #0x3 .long 0x54fffc03 // b.cc 3bb8 <_sk_load_rgb_u16_be_aarch64+0x28> // b.lo, b.ul, b.last .long 0x91003108 // add x8, x8, #0xc .long 0x0d407100 // ld3 {v0.h-v2.h}[2], [x8] .long 0x17ffffdd // b 3bb8 <_sk_load_rgb_u16_be_aarch64+0x28> HIDDEN _sk_store_u16_be_aarch64 .globl _sk_store_u16_be_aarch64 FUNCTION(_sk_store_u16_be_aarch64) _sk_store_u16_be_aarch64: .long 0x52a8efea // mov w10, #0x477f0000 .long 0x729fe00a // movk w10, #0xff00 .long 0x4e040d54 // dup v20.4s, w10 .long 0xf9400028 // ldr x8, [x1] .long 0x6e34dc10 // fmul v16.4s, v0.4s, v20.4s .long 0x6e34dc31 // fmul v17.4s, v1.4s, v20.4s .long 0x6e21aa10 // fcvtnu v16.4s, v16.4s .long 0x6e21aa31 // fcvtnu v17.4s, v17.4s .long 0x0e612a10 // xtn v16.4h, v16.4s .long 0x0e612a31 // xtn v17.4h, v17.4s .long 0x0f185612 // shl v18.4h, v16.4h, #8 .long 0x2f180610 // ushr v16.4h, v16.4h, #8 .long 0x0f185635 // shl v21.4h, v17.4h, #8 .long 0x2f180636 // ushr v22.4h, v17.4h, #8 .long 0x0eb01e50 // orr v16.8b, v18.8b, v16.8b .long 0xf940010a // ldr x10, [x8] .long 0xb9400908 // ldr w8, [x8, #8] .long 0x0eb61eb1 // orr v17.8b, v21.8b, v22.8b .long 0x6e34dc55 // fmul v21.4s, v2.4s, v20.4s .long 0x6e34dc74 // fmul v20.4s, v3.4s, v20.4s .long 0x6e21aab5 // fcvtnu v21.4s, v21.4s .long 0x6e21aa94 // fcvtnu v20.4s, v20.4s .long 0x0e612ab5 // xtn v21.4h, v21.4s .long 0x0e612a94 // xtn v20.4h, v20.4s .long 0x0f1856b6 // shl v22.4h, v21.4h, #8 .long 0x2f1806b5 // ushr v21.4h, v21.4h, #8 .long 0x1b037d08 // mul w8, w8, w3 .long 0x531e7449 // lsl w9, w2, #2 .long 0x0eb51ed2 // orr v18.8b, v22.8b, v21.8b .long 0x0f185695 // shl v21.4h, v20.4h, #8 .long 0x2f180694 // ushr v20.4h, v20.4h, #8 .long 0x8b28c548 // add x8, x10, w8, sxtw #1 .long 0x8b29c508 // add x8, x8, w9, sxtw #1 .long 0x0eb41eb3 // orr v19.8b, v21.8b, v20.8b .long 0xb50000a4 // cbnz x4, 3ce4 <_sk_store_u16_be_aarch64+0x9c> .long 0x0c000510 // st4 {v16.4h-v19.4h}, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0xf100049f // cmp x4, #0x1 .long 0x0d206110 // st4 {v16.h-v19.h}[0], [x8] .long 0x54ffff60 // b.eq 3cd8 <_sk_store_u16_be_aarch64+0x90> // b.none .long 0x91002109 // add x9, x8, #0x8 .long 0xf1000c9f // cmp x4, #0x3 .long 0x0d206930 // st4 {v16.h-v19.h}[1], [x9] .long 0x54fffee3 // b.cc 3cd8 <_sk_store_u16_be_aarch64+0x90> // b.lo, b.ul, b.last .long 0x91004108 // add x8, x8, #0x10 .long 0x0d207110 // st4 {v16.h-v19.h}[2], [x8] .long 0x17fffff4 // b 3cd8 <_sk_store_u16_be_aarch64+0x90> HIDDEN _sk_load_f32_aarch64 .globl _sk_load_f32_aarch64 FUNCTION(_sk_load_f32_aarch64) _sk_load_f32_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x531e744a // lsl w10, w2, #2 .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0x8b2ac908 // add x8, x8, w10, sxtw #2 .long 0xb50000a4 // cbnz x4, 3d3c <_sk_load_f32_aarch64+0x30> .long 0x4c400900 // ld4 {v0.4s-v3.4s}, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x0d60a100 // ld4 {v0.s-v3.s}[0], [x8] .long 0xf100049f // cmp x4, #0x1 .long 0x54ffff60 // b.eq 3d30 <_sk_load_f32_aarch64+0x24> // b.none .long 0x91004109 // add x9, x8, #0x10 .long 0x0d60b120 // ld4 {v0.s-v3.s}[1], [x9] .long 0xf1000c9f // cmp x4, #0x3 .long 0x54fffee3 // b.cc 3d30 <_sk_load_f32_aarch64+0x24> // b.lo, b.ul, b.last .long 0x91008108 // add x8, x8, #0x20 .long 0x4d60a100 // ld4 {v0.s-v3.s}[2], [x8] .long 0x17fffff4 // b 3d30 <_sk_load_f32_aarch64+0x24> HIDDEN _sk_load_f32_dst_aarch64 .globl _sk_load_f32_dst_aarch64 FUNCTION(_sk_load_f32_dst_aarch64) _sk_load_f32_dst_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x531e744a // lsl w10, w2, #2 .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0x8b2ac908 // add x8, x8, w10, sxtw #2 .long 0xb50000a4 // cbnz x4, 3d94 <_sk_load_f32_dst_aarch64+0x30> .long 0x4c400904 // ld4 {v4.4s-v7.4s}, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0x0d60a104 // ld4 {v4.s-v7.s}[0], [x8] .long 0xf100049f // cmp x4, #0x1 .long 0x54ffff60 // b.eq 3d88 <_sk_load_f32_dst_aarch64+0x24> // b.none .long 0x91004109 // add x9, x8, #0x10 .long 0x0d60b124 // ld4 {v4.s-v7.s}[1], [x9] .long 0xf1000c9f // cmp x4, #0x3 .long 0x54fffee3 // b.cc 3d88 <_sk_load_f32_dst_aarch64+0x24> // b.lo, b.ul, b.last .long 0x91008108 // add x8, x8, #0x20 .long 0x4d60a104 // ld4 {v4.s-v7.s}[2], [x8] .long 0x17fffff4 // b 3d88 <_sk_load_f32_dst_aarch64+0x24> HIDDEN _sk_store_f32_aarch64 .globl _sk_store_f32_aarch64 FUNCTION(_sk_store_f32_aarch64) _sk_store_f32_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x531e744a // lsl w10, w2, #2 .long 0xb9400909 // ldr w9, [x8, #8] .long 0xf9400108 // ldr x8, [x8] .long 0x1b037d29 // mul w9, w9, w3 .long 0x8b29c908 // add x8, x8, w9, sxtw #2 .long 0x8b2ac908 // add x8, x8, w10, sxtw #2 .long 0xb50000a4 // cbnz x4, 3dec <_sk_store_f32_aarch64+0x30> .long 0x4c000900 // st4 {v0.4s-v3.4s}, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 .long 0xf100049f // cmp x4, #0x1 .long 0x0d20a100 // st4 {v0.s-v3.s}[0], [x8] .long 0x54ffff60 // b.eq 3de0 <_sk_store_f32_aarch64+0x24> // b.none .long 0x91004109 // add x9, x8, #0x10 .long 0xf1000c9f // cmp x4, #0x3 .long 0x0d20b120 // st4 {v0.s-v3.s}[1], [x9] .long 0x54fffee3 // b.cc 3de0 <_sk_store_f32_aarch64+0x24> // b.lo, b.ul, b.last .long 0x91008108 // add x8, x8, #0x20 .long 0x4d20a100 // st4 {v0.s-v3.s}[2], [x8] .long 0x17fffff4 // b 3de0 <_sk_store_f32_aarch64+0x24> HIDDEN _sk_clamp_x_aarch64 .globl _sk_clamp_x_aarch64 FUNCTION(_sk_clamp_x_aarch64) _sk_clamp_x_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x6f00e411 // movi v17.2d, #0x0 .long 0x4e20f620 // fmax v0.4s, v17.4s, v0.4s .long 0x6f07e7f1 // movi v17.2d, #0xffffffffffffffff .long 0x4d40c910 // ld1r {v16.4s}, [x8] .long 0x4eb18610 // add v16.4s, v16.4s, v17.4s .long 0x4eb0f400 // fmin v0.4s, v0.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_clamp_y_aarch64 .globl _sk_clamp_y_aarch64 FUNCTION(_sk_clamp_y_aarch64) _sk_clamp_y_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x6f00e411 // movi v17.2d, #0x0 .long 0x4e21f621 // fmax v1.4s, v17.4s, v1.4s .long 0x6f07e7f1 // movi v17.2d, #0xffffffffffffffff .long 0x4d40c910 // ld1r {v16.4s}, [x8] .long 0x4eb18610 // add v16.4s, v16.4s, v17.4s .long 0x4eb0f421 // fmin v1.4s, v1.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_repeat_x_aarch64 .globl _sk_repeat_x_aarch64 FUNCTION(_sk_repeat_x_aarch64) _sk_repeat_x_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ddfc910 // ld1r {v16.4s}, [x8], #4 .long 0xbd400111 // ldr s17, [x8] .long 0x4f919011 // fmul v17.4s, v0.4s, v17.s[0] .long 0x4e219a31 // frintm v17.4s, v17.4s .long 0x4eb1ce00 // fmls v0.4s, v16.4s, v17.4s .long 0x6f07e7f1 // movi v17.2d, #0xffffffffffffffff .long 0x4eb18610 // add v16.4s, v16.4s, v17.4s .long 0x6f00e411 // movi v17.2d, #0x0 .long 0x4e20f620 // fmax v0.4s, v17.4s, v0.4s .long 0x4eb0f400 // fmin v0.4s, v0.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_repeat_y_aarch64 .globl _sk_repeat_y_aarch64 FUNCTION(_sk_repeat_y_aarch64) _sk_repeat_y_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ddfc910 // ld1r {v16.4s}, [x8], #4 .long 0xbd400111 // ldr s17, [x8] .long 0x4f919031 // fmul v17.4s, v1.4s, v17.s[0] .long 0x4e219a31 // frintm v17.4s, v17.4s .long 0x4eb1ce01 // fmls v1.4s, v16.4s, v17.4s .long 0x6f07e7f1 // movi v17.2d, #0xffffffffffffffff .long 0x4eb18610 // add v16.4s, v16.4s, v17.4s .long 0x6f00e411 // movi v17.2d, #0x0 .long 0x4e21f621 // fmax v1.4s, v17.4s, v1.4s .long 0x4eb0f421 // fmin v1.4s, v1.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_mirror_x_aarch64 .globl _sk_mirror_x_aarch64 FUNCTION(_sk_mirror_x_aarch64) _sk_mirror_x_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x1e2c1012 // fmov s18, #5.000000000000000000e-01 .long 0x6f00e413 // movi v19.2d, #0x0 .long 0x2d404111 // ldp s17, s16, [x8] .long 0x1e320a10 // fmul s16, s16, s18 .long 0x4e040632 // dup v18.4s, v17.s[0] .long 0x4eb2d400 // fsub v0.4s, v0.4s, v18.4s .long 0x4f909010 // fmul v16.4s, v0.4s, v16.s[0] .long 0x1e312a31 // fadd s17, s17, s17 .long 0x4e219a10 // frintm v16.4s, v16.4s .long 0x4f915200 // fmls v0.4s, v16.4s, v17.s[0] .long 0x4eb2d400 // fsub v0.4s, v0.4s, v18.4s .long 0x6f07e7f0 // movi v16.2d, #0xffffffffffffffff .long 0x4ea0f800 // fabs v0.4s, v0.4s .long 0x4eb08650 // add v16.4s, v18.4s, v16.4s .long 0x4e20f660 // fmax v0.4s, v19.4s, v0.4s .long 0x4eb0f400 // fmin v0.4s, v0.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_mirror_y_aarch64 .globl _sk_mirror_y_aarch64 FUNCTION(_sk_mirror_y_aarch64) _sk_mirror_y_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x1e2c1012 // fmov s18, #5.000000000000000000e-01 .long 0x6f00e413 // movi v19.2d, #0x0 .long 0x2d404111 // ldp s17, s16, [x8] .long 0x1e320a10 // fmul s16, s16, s18 .long 0x4e040632 // dup v18.4s, v17.s[0] .long 0x4eb2d421 // fsub v1.4s, v1.4s, v18.4s .long 0x4f909030 // fmul v16.4s, v1.4s, v16.s[0] .long 0x1e312a31 // fadd s17, s17, s17 .long 0x4e219a10 // frintm v16.4s, v16.4s .long 0x4f915201 // fmls v1.4s, v16.4s, v17.s[0] .long 0x4eb2d421 // fsub v1.4s, v1.4s, v18.4s .long 0x6f07e7f0 // movi v16.2d, #0xffffffffffffffff .long 0x4ea0f821 // fabs v1.4s, v1.4s .long 0x4eb08650 // add v16.4s, v18.4s, v16.4s .long 0x4e21f661 // fmax v1.4s, v19.4s, v1.4s .long 0x4eb0f421 // fmin v1.4s, v1.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_clamp_x_1_aarch64 .globl _sk_clamp_x_1_aarch64 FUNCTION(_sk_clamp_x_1_aarch64) _sk_clamp_x_1_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6f00e410 // movi v16.2d, #0x0 .long 0x4e20f600 // fmax v0.4s, v16.4s, v0.4s .long 0x4f03f610 // fmov v16.4s, #1.000000000000000000e+00 .long 0x4eb0f400 // fmin v0.4s, v0.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_repeat_x_1_aarch64 .globl _sk_repeat_x_1_aarch64 FUNCTION(_sk_repeat_x_1_aarch64) _sk_repeat_x_1_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e219810 // frintm v16.4s, v0.4s .long 0x4eb0d400 // fsub v0.4s, v0.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_mirror_x_1_aarch64 .globl _sk_mirror_x_1_aarch64 FUNCTION(_sk_mirror_x_1_aarch64) _sk_mirror_x_1_aarch64: .long 0x4f07f610 // fmov v16.4s, #-1.000000000000000000e+00 .long 0x4f0167f1 // movi v17.4s, #0x3f, lsl #24 .long 0x4e30d400 // fadd v0.4s, v0.4s, v16.4s .long 0x6e31dc11 // fmul v17.4s, v0.4s, v17.4s .long 0x4e219a31 // frintm v17.4s, v17.4s .long 0x4e31d631 // fadd v17.4s, v17.4s, v17.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4eb1d400 // fsub v0.4s, v0.4s, v17.4s .long 0x4e30d400 // fadd v0.4s, v0.4s, v16.4s .long 0x4ea0f800 // fabs v0.4s, v0.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_luminance_to_alpha_aarch64 .globl _sk_luminance_to_alpha_aarch64 FUNCTION(_sk_luminance_to_alpha_aarch64) _sk_luminance_to_alpha_aarch64: .long 0x52a7cb28 // mov w8, #0x3e590000 .long 0x72967a08 // movk w8, #0xb3d0 .long 0x4e040d11 // dup v17.4s, w8 .long 0x52a7e6e8 // mov w8, #0x3f370000 .long 0x7282eb28 // movk w8, #0x1759 .long 0x4ea01c10 // mov v16.16b, v0.16b .long 0x4e040d00 // dup v0.4s, w8 .long 0x52a7b268 // mov w8, #0x3d930000 .long 0xf8408425 // ldr x5, [x1], #8 .long 0x729bb308 // movk w8, #0xdd98 .long 0x6e20dc23 // fmul v3.4s, v1.4s, v0.4s .long 0x4e30ce23 // fmla v3.4s, v17.4s, v16.4s .long 0x4e040d10 // dup v16.4s, w8 .long 0x6f00e400 // movi v0.2d, #0x0 .long 0x6f00e401 // movi v1.2d, #0x0 .long 0x4e22ce03 // fmla v3.4s, v16.4s, v2.4s .long 0x6f00e402 // movi v2.2d, #0x0 .long 0xd61f00a0 // br x5 HIDDEN _sk_matrix_translate_aarch64 .globl _sk_matrix_translate_aarch64 FUNCTION(_sk_matrix_translate_aarch64) _sk_matrix_translate_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4ddfc910 // ld1r {v16.4s}, [x8], #4 .long 0x4d40c911 // ld1r {v17.4s}, [x8] .long 0x4e20d600 // fadd v0.4s, v16.4s, v0.4s .long 0x4e21d621 // fadd v1.4s, v17.4s, v1.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_matrix_scale_translate_aarch64 .globl _sk_matrix_scale_translate_aarch64 FUNCTION(_sk_matrix_scale_translate_aarch64) _sk_matrix_scale_translate_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xaa0803e9 // mov x9, x8 .long 0x2d414d12 // ldp s18, s19, [x8, #8] .long 0x4ddfc930 // ld1r {v16.4s}, [x9], #4 .long 0x4d40c931 // ld1r {v17.4s}, [x9] .long 0x4f921010 // fmla v16.4s, v0.4s, v18.s[0] .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4f931031 // fmla v17.4s, v1.4s, v19.s[0] .long 0x4eb11e21 // mov v1.16b, v17.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_matrix_2x3_aarch64 .globl _sk_matrix_2x3_aarch64 FUNCTION(_sk_matrix_2x3_aarch64) _sk_matrix_2x3_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xaa0803e9 // mov x9, x8 .long 0x9100410a // add x10, x8, #0x10 .long 0x4ddfc932 // ld1r {v18.4s}, [x9], #4 .long 0x4d40c950 // ld1r {v16.4s}, [x10] .long 0x2d415113 // ldp s19, s20, [x8, #8] .long 0x9100510a // add x10, x8, #0x14 .long 0x4d40c951 // ld1r {v17.4s}, [x10] .long 0x4f931030 // fmla v16.4s, v1.4s, v19.s[0] .long 0xbd400133 // ldr s19, [x9] .long 0x4f941031 // fmla v17.4s, v1.4s, v20.s[0] .long 0x4e20ce50 // fmla v16.4s, v18.4s, v0.4s .long 0x4f931011 // fmla v17.4s, v0.4s, v19.s[0] .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4eb11e21 // mov v1.16b, v17.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_matrix_3x4_aarch64 .globl _sk_matrix_3x4_aarch64 FUNCTION(_sk_matrix_3x4_aarch64) _sk_matrix_3x4_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xaa0803e9 // mov x9, x8 .long 0x9100910a // add x10, x8, #0x24 .long 0x4ddfc933 // ld1r {v19.4s}, [x9], #4 .long 0x4d40c950 // ld1r {v16.4s}, [x10] .long 0x9100a10a // add x10, x8, #0x28 .long 0x4d40c951 // ld1r {v17.4s}, [x10] .long 0x9100b10a // add x10, x8, #0x2c .long 0x2d435514 // ldp s20, s21, [x8, #24] .long 0xbd402116 // ldr s22, [x8, #32] .long 0x4d40c952 // ld1r {v18.4s}, [x10] .long 0x4f941050 // fmla v16.4s, v2.4s, v20.s[0] .long 0x4f951051 // fmla v17.4s, v2.4s, v21.s[0] .long 0x4f961052 // fmla v18.4s, v2.4s, v22.s[0] .long 0x2d425502 // ldp s2, s21, [x8, #16] .long 0x2d415d14 // ldp s20, s23, [x8, #8] .long 0x4f821031 // fmla v17.4s, v1.4s, v2.s[0] .long 0xbd400122 // ldr s2, [x9] .long 0x4f971030 // fmla v16.4s, v1.4s, v23.s[0] .long 0x4f951032 // fmla v18.4s, v1.4s, v21.s[0] .long 0x4e20ce70 // fmla v16.4s, v19.4s, v0.4s .long 0x4f941012 // fmla v18.4s, v0.4s, v20.s[0] .long 0x4f821011 // fmla v17.4s, v0.4s, v2.s[0] .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4eb11e21 // mov v1.16b, v17.16b .long 0x4eb21e42 // mov v2.16b, v18.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_matrix_4x5_aarch64 .globl _sk_matrix_4x5_aarch64 FUNCTION(_sk_matrix_4x5_aarch64) _sk_matrix_4x5_aarch64: .long 0xf9400029 // ldr x9, [x1] .long 0xaa0903e8 // mov x8, x9 .long 0x9101012a // add x10, x9, #0x40 .long 0x4ddfc914 // ld1r {v20.4s}, [x8], #4 .long 0x4d40c950 // ld1r {v16.4s}, [x10] .long 0x9101112a // add x10, x9, #0x44 .long 0x4d40c951 // ld1r {v17.4s}, [x10] .long 0x9101212a // add x10, x9, #0x48 .long 0x4d40c952 // ld1r {v18.4s}, [x10] .long 0x2d465533 // ldp s19, s21, [x9, #48] .long 0x2d475d36 // ldp s22, s23, [x9, #56] .long 0x9101312a // add x10, x9, #0x4c .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f931070 // fmla v16.4s, v3.4s, v19.s[0] .long 0x4d40c953 // ld1r {v19.4s}, [x10] .long 0x4f951071 // fmla v17.4s, v3.4s, v21.s[0] .long 0x4f961072 // fmla v18.4s, v3.4s, v22.s[0] .long 0x2d445935 // ldp s21, s22, [x9, #32] .long 0x4f971073 // fmla v19.4s, v3.4s, v23.s[0] .long 0x2d455d23 // ldp s3, s23, [x9, #40] .long 0x91004021 // add x1, x1, #0x10 .long 0x4f951050 // fmla v16.4s, v2.4s, v21.s[0] .long 0x4f961051 // fmla v17.4s, v2.4s, v22.s[0] .long 0x2d425935 // ldp s21, s22, [x9, #16] .long 0x4f971053 // fmla v19.4s, v2.4s, v23.s[0] .long 0x4f831052 // fmla v18.4s, v2.4s, v3.s[0] .long 0x2d410d22 // ldp s2, s3, [x9, #8] .long 0x4f951030 // fmla v16.4s, v1.4s, v21.s[0] .long 0x2d435d35 // ldp s21, s23, [x9, #24] .long 0x4f961031 // fmla v17.4s, v1.4s, v22.s[0] .long 0xbd400116 // ldr s22, [x8] .long 0x4e20ce90 // fmla v16.4s, v20.4s, v0.4s .long 0x4f951032 // fmla v18.4s, v1.4s, v21.s[0] .long 0x4f971033 // fmla v19.4s, v1.4s, v23.s[0] .long 0x4f821012 // fmla v18.4s, v0.4s, v2.s[0] .long 0x4f831013 // fmla v19.4s, v0.4s, v3.s[0] .long 0x4f961011 // fmla v17.4s, v0.4s, v22.s[0] .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4eb11e21 // mov v1.16b, v17.16b .long 0x4eb21e42 // mov v2.16b, v18.16b .long 0x4eb31e63 // mov v3.16b, v19.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_matrix_4x3_aarch64 .globl _sk_matrix_4x3_aarch64 FUNCTION(_sk_matrix_4x3_aarch64) _sk_matrix_4x3_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0xaa0803e9 // mov x9, x8 .long 0x9100810a // add x10, x8, #0x20 .long 0x4ddfc932 // ld1r {v18.4s}, [x9], #4 .long 0x4d40c950 // ld1r {v16.4s}, [x10] .long 0x9100910a // add x10, x8, #0x24 .long 0x4d40c951 // ld1r {v17.4s}, [x10] .long 0x9100a10a // add x10, x8, #0x28 .long 0x2d425113 // ldp s19, s20, [x8, #16] .long 0x4d40c942 // ld1r {v2.4s}, [x10] .long 0x9100b10a // add x10, x8, #0x2c .long 0x2d435915 // ldp s21, s22, [x8, #24] .long 0x4d40c943 // ld1r {v3.4s}, [x10] .long 0x4f931030 // fmla v16.4s, v1.4s, v19.s[0] .long 0x4e20ce50 // fmla v16.4s, v18.4s, v0.4s .long 0xbd400132 // ldr s18, [x9] .long 0x4f941031 // fmla v17.4s, v1.4s, v20.s[0] .long 0x4f951022 // fmla v2.4s, v1.4s, v21.s[0] .long 0x4f961023 // fmla v3.4s, v1.4s, v22.s[0] .long 0x2d414d01 // ldp s1, s19, [x8, #8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f921011 // fmla v17.4s, v0.4s, v18.s[0] .long 0x91004021 // add x1, x1, #0x10 .long 0x4f811002 // fmla v2.4s, v0.4s, v1.s[0] .long 0x4f931003 // fmla v3.4s, v0.4s, v19.s[0] .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x4eb11e21 // mov v1.16b, v17.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_matrix_perspective_aarch64 .globl _sk_matrix_perspective_aarch64 FUNCTION(_sk_matrix_perspective_aarch64) _sk_matrix_perspective_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xaa0803e9 // mov x9, x8 .long 0x9100510a // add x10, x8, #0x14 .long 0x4ddfc930 // ld1r {v16.4s}, [x9], #4 .long 0x4d40c951 // ld1r {v17.4s}, [x10] .long 0x9100810a // add x10, x8, #0x20 .long 0x4d40c952 // ld1r {v18.4s}, [x10] .long 0x2d41d113 // ldp s19, s20, [x8, #12] .long 0x2d435915 // ldp s21, s22, [x8, #24] .long 0x91002108 // add x8, x8, #0x8 .long 0x4f941031 // fmla v17.4s, v1.4s, v20.s[0] .long 0x4d40c914 // ld1r {v20.4s}, [x8] .long 0x4f961032 // fmla v18.4s, v1.4s, v22.s[0] .long 0xbd400136 // ldr s22, [x9] .long 0x4f951012 // fmla v18.4s, v0.4s, v21.s[0] .long 0x4f931011 // fmla v17.4s, v0.4s, v19.s[0] .long 0x4f961034 // fmla v20.4s, v1.4s, v22.s[0] .long 0x4ea1da41 // frecpe v1.4s, v18.4s .long 0x4e21fe52 // frecps v18.4s, v18.4s, v1.4s .long 0x6e32dc32 // fmul v18.4s, v1.4s, v18.4s .long 0x4e20ce14 // fmla v20.4s, v16.4s, v0.4s .long 0x6e32de21 // fmul v1.4s, v17.4s, v18.4s .long 0x6e32de80 // fmul v0.4s, v20.4s, v18.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_evenly_spaced_gradient_aarch64 .globl _sk_evenly_spaced_gradient_aarch64 FUNCTION(_sk_evenly_spaced_gradient_aarch64) _sk_evenly_spaced_gradient_aarch64: .long 0xd10043ff // sub sp, sp, #0x10 .long 0xaa0103e8 // mov x8, x1 .long 0x91002109 // add x9, x8, #0x8 .long 0xf90007e9 // str x9, [sp, #8] .long 0xf841042a // ldr x10, [x1], #16 .long 0xa940254b // ldp x11, x9, [x10] .long 0xa942354c // ldp x12, x13, [x10, #32] .long 0xa9413d4e // ldp x14, x15, [x10, #16] .long 0xa9434550 // ldp x16, x17, [x10, #48] .long 0xd100056b // sub x11, x11, #0x1 .long 0x9e230161 // ucvtf s1, x11 .long 0xf940214a // ldr x10, [x10, #64] .long 0x4f819001 // fmul v1.4s, v0.4s, v1.s[0] .long 0x4ea1b821 // fcvtzs v1.4s, v1.4s .long 0x6f20a422 // uxtl2 v2.2d, v1.4s .long 0x2f20a421 // uxtl v1.2d, v1.2s .long 0x9e660025 // fmov x5, d1 .long 0x9e660047 // fmov x7, d2 .long 0x4e183c2b // mov x11, v1.d[1] .long 0x4e183c46 // mov x6, v2.d[1] .long 0xbc677921 // ldr s1, [x9, x7, lsl #2] .long 0xbc6779a2 // ldr s2, [x13, x7, lsl #2] .long 0xbc6779c3 // ldr s3, [x14, x7, lsl #2] .long 0xbc677a11 // ldr s17, [x16, x7, lsl #2] .long 0xbc6779f2 // ldr s18, [x15, x7, lsl #2] .long 0xbc677a33 // ldr s19, [x17, x7, lsl #2] .long 0xbc677994 // ldr s20, [x12, x7, lsl #2] .long 0xbc677955 // ldr s21, [x10, x7, lsl #2] .long 0x8b050927 // add x7, x9, x5, lsl #2 .long 0x0d4080f6 // ld1 {v22.s}[0], [x7] .long 0x8b0509a7 // add x7, x13, x5, lsl #2 .long 0x0d4080f0 // ld1 {v16.s}[0], [x7] .long 0x8b0b0927 // add x7, x9, x11, lsl #2 .long 0x0d4090f6 // ld1 {v22.s}[1], [x7] .long 0x8b0509c7 // add x7, x14, x5, lsl #2 .long 0x0d4080f7 // ld1 {v23.s}[0], [x7] .long 0x8b050a07 // add x7, x16, x5, lsl #2 .long 0x6e140436 // mov v22.s[2], v1.s[0] .long 0x0d4080e1 // ld1 {v1.s}[0], [x7] .long 0x8b0b09a7 // add x7, x13, x11, lsl #2 .long 0x0d4090f0 // ld1 {v16.s}[1], [x7] .long 0x8b0b09c7 // add x7, x14, x11, lsl #2 .long 0x0d4090f7 // ld1 {v23.s}[1], [x7] .long 0x8b0509e7 // add x7, x15, x5, lsl #2 .long 0x0d4080f8 // ld1 {v24.s}[0], [x7] .long 0x8b050a27 // add x7, x17, x5, lsl #2 .long 0x6e140450 // mov v16.s[2], v2.s[0] .long 0x0d4080e2 // ld1 {v2.s}[0], [x7] .long 0x8b0b0a07 // add x7, x16, x11, lsl #2 .long 0x0d4090e1 // ld1 {v1.s}[1], [x7] .long 0x8b0b09e7 // add x7, x15, x11, lsl #2 .long 0x0d4090f8 // ld1 {v24.s}[1], [x7] .long 0x8b050987 // add x7, x12, x5, lsl #2 .long 0x8b050945 // add x5, x10, x5, lsl #2 .long 0x6e140477 // mov v23.s[2], v3.s[0] .long 0x0d4080a3 // ld1 {v3.s}[0], [x5] .long 0x8b0b0a25 // add x5, x17, x11, lsl #2 .long 0x6e140621 // mov v1.s[2], v17.s[0] .long 0x0d4080f1 // ld1 {v17.s}[0], [x7] .long 0x0d4090a2 // ld1 {v2.s}[1], [x5] .long 0x8b0b0985 // add x5, x12, x11, lsl #2 .long 0x6e140658 // mov v24.s[2], v18.s[0] .long 0x0d4090b1 // ld1 {v17.s}[1], [x5] .long 0x6e140662 // mov v2.s[2], v19.s[0] .long 0xbc667932 // ldr s18, [x9, x6, lsl #2] .long 0xbc6679b3 // ldr s19, [x13, x6, lsl #2] .long 0x6e140691 // mov v17.s[2], v20.s[0] .long 0xbc6679d4 // ldr s20, [x14, x6, lsl #2] .long 0x6e1c0656 // mov v22.s[3], v18.s[0] .long 0xbc667a12 // ldr s18, [x16, x6, lsl #2] .long 0x6e1c0670 // mov v16.s[3], v19.s[0] .long 0xbc6679f3 // ldr s19, [x15, x6, lsl #2] .long 0x8b0b094b // add x11, x10, x11, lsl #2 .long 0x0d409163 // ld1 {v3.s}[1], [x11] .long 0x6e1c0697 // mov v23.s[3], v20.s[0] .long 0xbc667a34 // ldr s20, [x17, x6, lsl #2] .long 0x6e1c0641 // mov v1.s[3], v18.s[0] .long 0xbc667992 // ldr s18, [x12, x6, lsl #2] .long 0x6e1c0678 // mov v24.s[3], v19.s[0] .long 0xbc667953 // ldr s19, [x10, x6, lsl #2] .long 0xf9400505 // ldr x5, [x8, #8] .long 0x6e1406a3 // mov v3.s[2], v21.s[0] .long 0x6e1c0682 // mov v2.s[3], v20.s[0] .long 0x6e1c0651 // mov v17.s[3], v18.s[0] .long 0x6e1c0663 // mov v3.s[3], v19.s[0] .long 0x4e20ced0 // fmla v16.4s, v22.4s, v0.4s .long 0x4e20cee1 // fmla v1.4s, v23.4s, v0.4s .long 0x4e20cf02 // fmla v2.4s, v24.4s, v0.4s .long 0x4e20ce23 // fmla v3.4s, v17.4s, v0.4s .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x910043ff // add sp, sp, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_gauss_a_to_rgba_aarch64 .globl _sk_gauss_a_to_rgba_aarch64 FUNCTION(_sk_gauss_a_to_rgba_aarch64) _sk_gauss_a_to_rgba_aarch64: .long 0x52b80228 // mov w8, #0xc0110000 .long 0x728205a8 // movk w8, #0x102d .long 0x52a80729 // mov w9, #0x40390000 .long 0x728f0249 // movk w9, #0x7812 .long 0x4e040d00 // dup v0.4s, w8 .long 0x52a7cb48 // mov w8, #0x3e5a0000 .long 0x72928408 // movk w8, #0x9420 .long 0x4e040d21 // dup v1.4s, w9 .long 0x52a7c3c9 // mov w9, #0x3e1e0000 .long 0x7293a089 // movk w9, #0x9d04 .long 0x4e040d02 // dup v2.4s, w8 .long 0x52a73428 // mov w8, #0x39a10000 .long 0x4e23cc01 // fmla v1.4s, v0.4s, v3.4s .long 0x72830008 // movk w8, #0x1800 .long 0x4e040d30 // dup v16.4s, w9 .long 0xf8408425 // ldr x5, [x1], #8 .long 0x4e23cc22 // fmla v2.4s, v1.4s, v3.4s .long 0x4e040d00 // dup v0.4s, w8 .long 0x4e23cc50 // fmla v16.4s, v2.4s, v3.4s .long 0x4e23ce00 // fmla v0.4s, v16.4s, v3.4s .long 0x4ea01c01 // mov v1.16b, v0.16b .long 0x4ea01c02 // mov v2.16b, v0.16b .long 0x4ea01c03 // mov v3.16b, v0.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_gradient_aarch64 .globl _sk_gradient_aarch64 FUNCTION(_sk_gradient_aarch64) _sk_gradient_aarch64: .long 0xd10043ff // sub sp, sp, #0x10 .long 0x91002028 // add x8, x1, #0x8 .long 0xf90007e8 // str x8, [sp, #8] .long 0xf9400028 // ldr x8, [x1] .long 0x6f00e401 // movi v1.2d, #0x0 .long 0x6f00e411 // movi v17.2d, #0x0 .long 0xf9400109 // ldr x9, [x8] .long 0xf100093f // cmp x9, #0x2 .long 0x540001c3 // b.cc 446c <_sk_gradient_aarch64+0x58> // b.lo, b.ul, b.last .long 0xf940250a // ldr x10, [x8, #72] .long 0xd1000529 // sub x9, x9, #0x1 .long 0x6f00e401 // movi v1.2d, #0x0 .long 0x4f000422 // movi v2.4s, #0x1 .long 0x9100114a // add x10, x10, #0x4 .long 0x4ddfc943 // ld1r {v3.4s}, [x10], #4 .long 0xd1000529 // sub x9, x9, #0x1 .long 0x6e23e403 // fcmge v3.4s, v0.4s, v3.4s .long 0x4e221c63 // and v3.16b, v3.16b, v2.16b .long 0x4ea18461 // add v1.4s, v3.4s, v1.4s .long 0xb5ffff69 // cbnz x9, 444c <_sk_gradient_aarch64+0x38> .long 0x6f20a431 // uxtl2 v17.2d, v1.4s .long 0x2f20a421 // uxtl v1.2d, v1.2s .long 0xa940b10a // ldp x10, x12, [x8, #8] .long 0xa942b90d // ldp x13, x14, [x8, #40] .long 0x9e66002b // fmov x11, d1 .long 0xa941c10f // ldp x15, x16, [x8, #24] .long 0x8b0b0941 // add x1, x10, x11, lsl #2 .long 0xa943a111 // ldp x17, x8, [x8, #56] .long 0x0d408032 // ld1 {v18.s}[0], [x1] .long 0x8b0b09a1 // add x1, x13, x11, lsl #2 .long 0x0d408030 // ld1 {v16.s}[0], [x1] .long 0x8b0b0981 // add x1, x12, x11, lsl #2 .long 0x0d408033 // ld1 {v19.s}[0], [x1] .long 0x8b0b09c1 // add x1, x14, x11, lsl #2 .long 0x4e183c29 // mov x9, v1.d[1] .long 0x0d408021 // ld1 {v1.s}[0], [x1] .long 0x8b0b09e1 // add x1, x15, x11, lsl #2 .long 0x0d408034 // ld1 {v20.s}[0], [x1] .long 0x8b0b0a21 // add x1, x17, x11, lsl #2 .long 0x0d408022 // ld1 {v2.s}[0], [x1] .long 0x8b0b0a01 // add x1, x16, x11, lsl #2 .long 0x8b0b090b // add x11, x8, x11, lsl #2 .long 0x0d408163 // ld1 {v3.s}[0], [x11] .long 0x8b09094b // add x11, x10, x9, lsl #2 .long 0x0d409172 // ld1 {v18.s}[1], [x11] .long 0x8b0909ab // add x11, x13, x9, lsl #2 .long 0x0d409170 // ld1 {v16.s}[1], [x11] .long 0x8b09098b // add x11, x12, x9, lsl #2 .long 0x0d409173 // ld1 {v19.s}[1], [x11] .long 0x8b0909cb // add x11, x14, x9, lsl #2 .long 0x0d409161 // ld1 {v1.s}[1], [x11] .long 0x8b0909eb // add x11, x15, x9, lsl #2 .long 0x9e660225 // fmov x5, d17 .long 0x0d409174 // ld1 {v20.s}[1], [x11] .long 0x4e183e2b // mov x11, v17.d[1] .long 0xbc6b7951 // ldr s17, [x10, x11, lsl #2] .long 0x8b05094a // add x10, x10, x5, lsl #2 .long 0x4d408152 // ld1 {v18.s}[2], [x10] .long 0x8b0509aa // add x10, x13, x5, lsl #2 .long 0x0d408035 // ld1 {v21.s}[0], [x1] .long 0xbc6b79b6 // ldr s22, [x13, x11, lsl #2] .long 0x4d408150 // ld1 {v16.s}[2], [x10] .long 0x8b05098a // add x10, x12, x5, lsl #2 .long 0x4d408153 // ld1 {v19.s}[2], [x10] .long 0x8b0509ca // add x10, x14, x5, lsl #2 .long 0x4d408141 // ld1 {v1.s}[2], [x10] .long 0x8b090a2a // add x10, x17, x9, lsl #2 .long 0xbc6b7997 // ldr s23, [x12, x11, lsl #2] .long 0x8b0509ec // add x12, x15, x5, lsl #2 .long 0x0d409142 // ld1 {v2.s}[1], [x10] .long 0x8b090a0a // add x10, x16, x9, lsl #2 .long 0x8b090909 // add x9, x8, x9, lsl #2 .long 0x6e1c0632 // mov v18.s[3], v17.s[0] .long 0xbc6b79d1 // ldr s17, [x14, x11, lsl #2] .long 0x6e1c06d0 // mov v16.s[3], v22.s[0] .long 0xbc6b79f6 // ldr s22, [x15, x11, lsl #2] .long 0x0d409155 // ld1 {v21.s}[1], [x10] .long 0x4d408194 // ld1 {v20.s}[2], [x12] .long 0x0d409123 // ld1 {v3.s}[1], [x9] .long 0xf94007e1 // ldr x1, [sp, #8] .long 0x8b050a2d // add x13, x17, x5, lsl #2 .long 0x8b050a0e // add x14, x16, x5, lsl #2 .long 0x8b05090f // add x15, x8, x5, lsl #2 .long 0x6e1c06f3 // mov v19.s[3], v23.s[0] .long 0xbc6b7a37 // ldr s23, [x17, x11, lsl #2] .long 0x6e1c0621 // mov v1.s[3], v17.s[0] .long 0xbc6b7a11 // ldr s17, [x16, x11, lsl #2] .long 0x4d4081a2 // ld1 {v2.s}[2], [x13] .long 0x4d4081d5 // ld1 {v21.s}[2], [x14] .long 0x6e1c06d4 // mov v20.s[3], v22.s[0] .long 0xbc6b7916 // ldr s22, [x8, x11, lsl #2] .long 0x4d4081e3 // ld1 {v3.s}[2], [x15] .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e1c06e2 // mov v2.s[3], v23.s[0] .long 0x6e1c0635 // mov v21.s[3], v17.s[0] .long 0x6e1c06c3 // mov v3.s[3], v22.s[0] .long 0x4e20ce50 // fmla v16.4s, v18.4s, v0.4s .long 0x4e20ce61 // fmla v1.4s, v19.4s, v0.4s .long 0x4e20ce82 // fmla v2.4s, v20.4s, v0.4s .long 0x4e20cea3 // fmla v3.4s, v21.4s, v0.4s .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0x910043ff // add sp, sp, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_evenly_spaced_2_stop_gradient_aarch64 .globl _sk_evenly_spaced_2_stop_gradient_aarch64 FUNCTION(_sk_evenly_spaced_2_stop_gradient_aarch64) _sk_evenly_spaced_2_stop_gradient_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0xaa0803e9 // mov x9, x8 .long 0x9100410a // add x10, x8, #0x10 .long 0x4ddfc931 // ld1r {v17.4s}, [x9], #4 .long 0x4d40c950 // ld1r {v16.4s}, [x10] .long 0x9100510a // add x10, x8, #0x14 .long 0x4d40c941 // ld1r {v1.4s}, [x10] .long 0x9100610a // add x10, x8, #0x18 .long 0x4d40c942 // ld1r {v2.4s}, [x10] .long 0x9100710a // add x10, x8, #0x1c .long 0x2d414d12 // ldp s18, s19, [x8, #8] .long 0x4d40c943 // ld1r {v3.4s}, [x10] .long 0x4e20ce30 // fmla v16.4s, v17.4s, v0.4s .long 0xbd400131 // ldr s17, [x9] .long 0x4f921002 // fmla v2.4s, v0.4s, v18.s[0] .long 0x4f931003 // fmla v3.4s, v0.4s, v19.s[0] .long 0x4f911001 // fmla v1.4s, v0.4s, v17.s[0] .long 0x4eb01e00 // mov v0.16b, v16.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_xy_to_unit_angle_aarch64 .globl _sk_xy_to_unit_angle_aarch64 FUNCTION(_sk_xy_to_unit_angle_aarch64) _sk_xy_to_unit_angle_aarch64: .long 0x52b77ce8 // mov w8, #0xbbe70000 .long 0x72856de8 // movk w8, #0x2b6f .long 0x4ea0f810 // fabs v16.4s, v0.4s .long 0x4ea0f831 // fabs v17.4s, v1.4s .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a79948 // mov w8, #0x3cca0000 .long 0x729af3e8 // movk w8, #0xd79f .long 0x4eb1f614 // fmin v20.4s, v16.4s, v17.4s .long 0x4e31f615 // fmax v21.4s, v16.4s, v17.4s .long 0x4e040d13 // dup v19.4s, w8 .long 0x52b7aa88 // mov w8, #0xbd540000 .long 0x6e35fe94 // fdiv v20.4s, v20.4s, v21.4s .long 0x728c9a88 // movk w8, #0x64d4 .long 0x6e34de95 // fmul v21.4s, v20.4s, v20.4s .long 0x4e35ce53 // fmla v19.4s, v18.4s, v21.4s .long 0x4e040d12 // dup v18.4s, w8 .long 0x52a7c448 // mov w8, #0x3e220000 .long 0x729e1528 // movk w8, #0xf0a9 .long 0x4e35ce72 // fmla v18.4s, v19.4s, v21.4s .long 0x4e040d13 // dup v19.4s, w8 .long 0x4e35ce53 // fmla v19.4s, v18.4s, v21.4s .long 0x4f02f612 // fmov v18.4s, #2.500000000000000000e-01 .long 0x6e33de93 // fmul v19.4s, v20.4s, v19.4s .long 0x6eb0e630 // fcmgt v16.4s, v17.4s, v16.4s .long 0x4eb3d652 // fsub v18.4s, v18.4s, v19.4s .long 0x4f0167f5 // movi v21.4s, #0x3f, lsl #24 .long 0x6e731e50 // bsl v16.16b, v18.16b, v19.16b .long 0x4ea0e800 // fcmlt v0.4s, v0.4s, #0.0 .long 0x4eb0d6b2 // fsub v18.4s, v21.4s, v16.4s .long 0x4f03f614 // fmov v20.4s, #1.000000000000000000e+00 .long 0x6e701e40 // bsl v0.16b, v18.16b, v16.16b .long 0x4ea0e831 // fcmlt v17.4s, v1.4s, #0.0 .long 0x4ea0d690 // fsub v16.4s, v20.4s, v0.4s .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e601e11 // bsl v17.16b, v16.16b, v0.16b .long 0x6ea0ca20 // fcmge v0.4s, v17.4s, #0.0 .long 0x4ea0ea30 // fcmlt v16.4s, v17.4s, #0.0 .long 0x4ea01e00 // orr v0.16b, v16.16b, v0.16b .long 0x4e201e20 // and v0.16b, v17.16b, v0.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_xy_to_radius_aarch64 .globl _sk_xy_to_radius_aarch64 FUNCTION(_sk_xy_to_radius_aarch64) _sk_xy_to_radius_aarch64: .long 0xf8408425 // ldr x5, [x1], #8 .long 0x6e21dc30 // fmul v16.4s, v1.4s, v1.4s .long 0x4e20cc10 // fmla v16.4s, v0.4s, v0.4s .long 0x6ea1fa00 // fsqrt v0.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_xy_to_2pt_conical_quadratic_max_aarch64 .globl _sk_xy_to_2pt_conical_quadratic_max_aarch64 FUNCTION(_sk_xy_to_2pt_conical_quadratic_max_aarch64) _sk_xy_to_2pt_conical_quadratic_max_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4f04f614 // fmov v20.4s, #-4.000000000000000000e+00 .long 0x2d444d10 // ldp s16, s19, [x8, #32] .long 0x2d454911 // ldp s17, s18, [x8, #40] .long 0x4f909290 // fmul v16.4s, v20.4s, v16.s[0] .long 0x4f0167f4 // movi v20.4s, #0x3f, lsl #24 .long 0x4f939293 // fmul v19.4s, v20.4s, v19.s[0] .long 0x6e21dc34 // fmul v20.4s, v1.4s, v1.4s .long 0x1e310a52 // fmul s18, s18, s17 .long 0x1e310a31 // fmul s17, s17, s17 .long 0x4e20cc14 // fmla v20.4s, v0.4s, v0.4s .long 0x4e040652 // dup v18.4s, v18.s[0] .long 0x4e040631 // dup v17.4s, v17.s[0] .long 0x4e20d640 // fadd v0.4s, v18.4s, v0.4s .long 0x4eb1d691 // fsub v17.4s, v20.4s, v17.4s .long 0x4f066412 // movi v18.4s, #0xc0, lsl #24 .long 0x6e32dc00 // fmul v0.4s, v0.4s, v18.4s .long 0x6e31de10 // fmul v16.4s, v16.4s, v17.4s .long 0x4e20cc10 // fmla v16.4s, v0.4s, v0.4s .long 0x6ea0f811 // fneg v17.4s, v0.4s .long 0x6ea1fa10 // fsqrt v16.4s, v16.4s .long 0x4ea0d600 // fsub v0.4s, v16.4s, v0.4s .long 0x4eb0d630 // fsub v16.4s, v17.4s, v16.4s .long 0x6e20de60 // fmul v0.4s, v19.4s, v0.4s .long 0x6e30de70 // fmul v16.4s, v19.4s, v16.4s .long 0x4e30f400 // fmax v0.4s, v0.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_xy_to_2pt_conical_quadratic_min_aarch64 .globl _sk_xy_to_2pt_conical_quadratic_min_aarch64 FUNCTION(_sk_xy_to_2pt_conical_quadratic_min_aarch64) _sk_xy_to_2pt_conical_quadratic_min_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x4f04f614 // fmov v20.4s, #-4.000000000000000000e+00 .long 0x2d444d10 // ldp s16, s19, [x8, #32] .long 0x2d454911 // ldp s17, s18, [x8, #40] .long 0x4f909290 // fmul v16.4s, v20.4s, v16.s[0] .long 0x4f0167f4 // movi v20.4s, #0x3f, lsl #24 .long 0x4f939293 // fmul v19.4s, v20.4s, v19.s[0] .long 0x6e21dc34 // fmul v20.4s, v1.4s, v1.4s .long 0x1e310a52 // fmul s18, s18, s17 .long 0x1e310a31 // fmul s17, s17, s17 .long 0x4e20cc14 // fmla v20.4s, v0.4s, v0.4s .long 0x4e040652 // dup v18.4s, v18.s[0] .long 0x4e040631 // dup v17.4s, v17.s[0] .long 0x4e20d640 // fadd v0.4s, v18.4s, v0.4s .long 0x4eb1d691 // fsub v17.4s, v20.4s, v17.4s .long 0x4f066412 // movi v18.4s, #0xc0, lsl #24 .long 0x6e32dc00 // fmul v0.4s, v0.4s, v18.4s .long 0x6e31de10 // fmul v16.4s, v16.4s, v17.4s .long 0x4e20cc10 // fmla v16.4s, v0.4s, v0.4s .long 0x6ea0f811 // fneg v17.4s, v0.4s .long 0x6ea1fa10 // fsqrt v16.4s, v16.4s .long 0x4ea0d600 // fsub v0.4s, v16.4s, v0.4s .long 0x4eb0d630 // fsub v16.4s, v17.4s, v16.4s .long 0x6e20de60 // fmul v0.4s, v19.4s, v0.4s .long 0x6e30de70 // fmul v16.4s, v19.4s, v16.4s .long 0x4eb0f400 // fmin v0.4s, v0.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_xy_to_2pt_conical_linear_aarch64 .globl _sk_xy_to_2pt_conical_linear_aarch64 FUNCTION(_sk_xy_to_2pt_conical_linear_aarch64) _sk_xy_to_2pt_conical_linear_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x6e21dc32 // fmul v18.4s, v1.4s, v1.4s .long 0x4e20cc12 // fmla v18.4s, v0.4s, v0.4s .long 0x2d454510 // ldp s16, s17, [x8, #40] .long 0x1e300a31 // fmul s17, s17, s16 .long 0x1e300a10 // fmul s16, s16, s16 .long 0x4e040631 // dup v17.4s, v17.s[0] .long 0x4e040610 // dup v16.4s, v16.s[0] .long 0x4e20d620 // fadd v0.4s, v17.4s, v0.4s .long 0x4f066411 // movi v17.4s, #0xc0, lsl #24 .long 0x4eb0d650 // fsub v16.4s, v18.4s, v16.4s .long 0x6e31dc00 // fmul v0.4s, v0.4s, v17.4s .long 0x6ea0fa10 // fneg v16.4s, v16.4s .long 0x6e20fe00 // fdiv v0.4s, v16.4s, v0.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_mask_2pt_conical_degenerates_aarch64 .globl _sk_mask_2pt_conical_degenerates_aarch64 FUNCTION(_sk_mask_2pt_conical_degenerates_aarch64) _sk_mask_2pt_conical_degenerates_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x6ea0c812 // fcmge v18.4s, v0.4s, #0.0 .long 0x4ea0e813 // fcmlt v19.4s, v0.4s, #0.0 .long 0x4eb21e72 // orr v18.16b, v19.16b, v18.16b .long 0x9100a109 // add x9, x8, #0x28 .long 0xbd402d10 // ldr s16, [x8, #44] .long 0x4d40c931 // ld1r {v17.4s}, [x9] .long 0x4f901011 // fmla v17.4s, v0.4s, v16.s[0] .long 0x6ea0ca30 // fcmge v16.4s, v17.4s, #0.0 .long 0x0e612a10 // xtn v16.4h, v16.4s .long 0x0e612a51 // xtn v17.4h, v18.4s .long 0x0e311e10 // and v16.8b, v16.8b, v17.8b .long 0x2f10a610 // uxtl v16.4s, v16.4h .long 0x4f3f5610 // shl v16.4s, v16.4s, #31 .long 0x4f210610 // sshr v16.4s, v16.4s, #31 .long 0x3d800110 // str q16, [x8] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_apply_vector_mask_aarch64 .globl _sk_apply_vector_mask_aarch64 FUNCTION(_sk_apply_vector_mask_aarch64) _sk_apply_vector_mask_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x3dc00110 // ldr q16, [x8] .long 0x4e201e00 // and v0.16b, v16.16b, v0.16b .long 0x4e211e01 // and v1.16b, v16.16b, v1.16b .long 0x4e221e02 // and v2.16b, v16.16b, v2.16b .long 0x4e231e03 // and v3.16b, v16.16b, v3.16b .long 0xd61f00a0 // br x5 HIDDEN _sk_save_xy_aarch64 .globl _sk_save_xy_aarch64 FUNCTION(_sk_save_xy_aarch64) _sk_save_xy_aarch64: .long 0x4f0167f0 // movi v16.4s, #0x3f, lsl #24 .long 0xf9400028 // ldr x8, [x1] .long 0x4e30d411 // fadd v17.4s, v0.4s, v16.4s .long 0x4e30d430 // fadd v16.4s, v1.4s, v16.4s .long 0x4e219a32 // frintm v18.4s, v17.4s .long 0x4eb2d631 // fsub v17.4s, v17.4s, v18.4s .long 0x4e219a12 // frintm v18.4s, v16.4s .long 0x4eb2d610 // fsub v16.4s, v16.4s, v18.4s .long 0x3d800100 // str q0, [x8] .long 0x3d800901 // str q1, [x8, #32] .long 0x3d801111 // str q17, [x8, #64] .long 0x3d801910 // str q16, [x8, #96] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_accumulate_aarch64 .globl _sk_accumulate_aarch64 FUNCTION(_sk_accumulate_aarch64) _sk_accumulate_aarch64: .long 0xa8c11428 // ldp x8, x5, [x1], #16 .long 0x3dc02110 // ldr q16, [x8, #128] .long 0x3dc02911 // ldr q17, [x8, #160] .long 0x6e31de10 // fmul v16.4s, v16.4s, v17.4s .long 0x4e30cc04 // fmla v4.4s, v0.4s, v16.4s .long 0x4e30cc25 // fmla v5.4s, v1.4s, v16.4s .long 0x4e30cc46 // fmla v6.4s, v2.4s, v16.4s .long 0x4e30cc67 // fmla v7.4s, v3.4s, v16.4s .long 0xd61f00a0 // br x5 HIDDEN _sk_bilinear_nx_aarch64 .globl _sk_bilinear_nx_aarch64 FUNCTION(_sk_bilinear_nx_aarch64) _sk_bilinear_nx_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x4f03f611 // fmov v17.4s, #1.000000000000000000e+00 .long 0x3dc01100 // ldr q0, [x8, #64] .long 0x3dc00110 // ldr q16, [x8] .long 0x4ea0d620 // fsub v0.4s, v17.4s, v0.4s .long 0x3d802100 // str q0, [x8, #128] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f0567e0 // movi v0.4s, #0xbf, lsl #24 .long 0x4e20d600 // fadd v0.4s, v16.4s, v0.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bilinear_px_aarch64 .globl _sk_bilinear_px_aarch64 FUNCTION(_sk_bilinear_px_aarch64) _sk_bilinear_px_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x3dc01100 // ldr q0, [x8, #64] .long 0x3dc00110 // ldr q16, [x8] .long 0x3d802100 // str q0, [x8, #128] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f0167e0 // movi v0.4s, #0x3f, lsl #24 .long 0x4e20d600 // fadd v0.4s, v16.4s, v0.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bilinear_ny_aarch64 .globl _sk_bilinear_ny_aarch64 FUNCTION(_sk_bilinear_ny_aarch64) _sk_bilinear_ny_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x4f03f611 // fmov v17.4s, #1.000000000000000000e+00 .long 0x3dc01901 // ldr q1, [x8, #96] .long 0x3dc00910 // ldr q16, [x8, #32] .long 0x4ea1d621 // fsub v1.4s, v17.4s, v1.4s .long 0x3d802901 // str q1, [x8, #160] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f0567e1 // movi v1.4s, #0xbf, lsl #24 .long 0x4e21d601 // fadd v1.4s, v16.4s, v1.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bilinear_py_aarch64 .globl _sk_bilinear_py_aarch64 FUNCTION(_sk_bilinear_py_aarch64) _sk_bilinear_py_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x3dc01901 // ldr q1, [x8, #96] .long 0x3dc00910 // ldr q16, [x8, #32] .long 0x3d802901 // str q1, [x8, #160] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f0167e1 // movi v1.4s, #0x3f, lsl #24 .long 0x4e21d601 // fadd v1.4s, v16.4s, v1.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bicubic_n3x_aarch64 .globl _sk_bicubic_n3x_aarch64 FUNCTION(_sk_bicubic_n3x_aarch64) _sk_bicubic_n3x_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52a7d8e9 // mov w9, #0x3ec70000 .long 0x72838e49 // movk w9, #0x1c72 .long 0x4e040d30 // dup v16.4s, w9 .long 0x3dc01111 // ldr q17, [x8, #64] .long 0x52b7d549 // mov w9, #0xbeaa0000 .long 0x4f03f600 // fmov v0.4s, #1.000000000000000000e+00 .long 0x72955569 // movk w9, #0xaaab .long 0x4e040d32 // dup v18.4s, w9 .long 0x4eb1d400 // fsub v0.4s, v0.4s, v17.4s .long 0x6e20dc11 // fmul v17.4s, v0.4s, v0.4s .long 0x4e20ce12 // fmla v18.4s, v16.4s, v0.4s .long 0x6e32de20 // fmul v0.4s, v17.4s, v18.4s .long 0x3dc00113 // ldr q19, [x8] .long 0x3d802100 // str q0, [x8, #128] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f07f700 // fmov v0.4s, #-1.500000000000000000e+00 .long 0x4e20d660 // fadd v0.4s, v19.4s, v0.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bicubic_n1x_aarch64 .globl _sk_bicubic_n1x_aarch64 FUNCTION(_sk_bicubic_n1x_aarch64) _sk_bicubic_n1x_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52b7f2a9 // mov w9, #0xbf950000 .long 0x4f03f600 // fmov v0.4s, #1.000000000000000000e+00 .long 0x728aaaa9 // movk w9, #0x5555 .long 0x3dc01110 // ldr q16, [x8, #64] .long 0x4f03f711 // fmov v17.4s, #1.500000000000000000e+00 .long 0x4f0167f2 // movi v18.4s, #0x3f, lsl #24 .long 0x4eb0d400 // fsub v0.4s, v0.4s, v16.4s .long 0x4e040d30 // dup v16.4s, w9 .long 0x52a7ac69 // mov w9, #0x3d630000 .long 0x7291c729 // movk w9, #0x8e39 .long 0x4e20ce11 // fmla v17.4s, v16.4s, v0.4s .long 0x4e20ce32 // fmla v18.4s, v17.4s, v0.4s .long 0x4e040d31 // dup v17.4s, w9 .long 0x4e20ce51 // fmla v17.4s, v18.4s, v0.4s .long 0x3dc00110 // ldr q16, [x8] .long 0x3d802111 // str q17, [x8, #128] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f0567e0 // movi v0.4s, #0xbf, lsl #24 .long 0x4e20d600 // fadd v0.4s, v16.4s, v0.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bicubic_p1x_aarch64 .globl _sk_bicubic_p1x_aarch64 FUNCTION(_sk_bicubic_p1x_aarch64) _sk_bicubic_p1x_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52b7f2a9 // mov w9, #0xbf950000 .long 0x728aaaa9 // movk w9, #0x5555 .long 0x4f03f711 // fmov v17.4s, #1.500000000000000000e+00 .long 0x3dc01112 // ldr q18, [x8, #64] .long 0x3dc00100 // ldr q0, [x8] .long 0x4e040d33 // dup v19.4s, w9 .long 0x52a7ac69 // mov w9, #0x3d630000 .long 0x4f0167f0 // movi v16.4s, #0x3f, lsl #24 .long 0x7291c729 // movk w9, #0x8e39 .long 0x4e32ce71 // fmla v17.4s, v19.4s, v18.4s .long 0x4e30d400 // fadd v0.4s, v0.4s, v16.4s .long 0x4e32ce30 // fmla v16.4s, v17.4s, v18.4s .long 0x4e040d31 // dup v17.4s, w9 .long 0x4e32ce11 // fmla v17.4s, v16.4s, v18.4s .long 0x3d802111 // str q17, [x8, #128] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bicubic_p3x_aarch64 .globl _sk_bicubic_p3x_aarch64 FUNCTION(_sk_bicubic_p3x_aarch64) _sk_bicubic_p3x_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52a7d8e9 // mov w9, #0x3ec70000 .long 0x72838e49 // movk w9, #0x1c72 .long 0x4e040d20 // dup v0.4s, w9 .long 0x3dc01110 // ldr q16, [x8, #64] .long 0x52b7d549 // mov w9, #0xbeaa0000 .long 0x72955569 // movk w9, #0xaaab .long 0x4e040d31 // dup v17.4s, w9 .long 0x6e30de13 // fmul v19.4s, v16.4s, v16.4s .long 0x4e30cc11 // fmla v17.4s, v0.4s, v16.4s .long 0x6e31de60 // fmul v0.4s, v19.4s, v17.4s .long 0x3dc00112 // ldr q18, [x8] .long 0x3d802100 // str q0, [x8, #128] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f03f700 // fmov v0.4s, #1.500000000000000000e+00 .long 0x4e20d640 // fadd v0.4s, v18.4s, v0.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bicubic_n3y_aarch64 .globl _sk_bicubic_n3y_aarch64 FUNCTION(_sk_bicubic_n3y_aarch64) _sk_bicubic_n3y_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52a7d8e9 // mov w9, #0x3ec70000 .long 0x72838e49 // movk w9, #0x1c72 .long 0x4e040d30 // dup v16.4s, w9 .long 0x3dc01911 // ldr q17, [x8, #96] .long 0x52b7d549 // mov w9, #0xbeaa0000 .long 0x4f03f601 // fmov v1.4s, #1.000000000000000000e+00 .long 0x72955569 // movk w9, #0xaaab .long 0x4e040d32 // dup v18.4s, w9 .long 0x4eb1d421 // fsub v1.4s, v1.4s, v17.4s .long 0x6e21dc31 // fmul v17.4s, v1.4s, v1.4s .long 0x4e21ce12 // fmla v18.4s, v16.4s, v1.4s .long 0x6e32de21 // fmul v1.4s, v17.4s, v18.4s .long 0x3dc00913 // ldr q19, [x8, #32] .long 0x3d802901 // str q1, [x8, #160] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f07f701 // fmov v1.4s, #-1.500000000000000000e+00 .long 0x4e21d661 // fadd v1.4s, v19.4s, v1.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bicubic_n1y_aarch64 .globl _sk_bicubic_n1y_aarch64 FUNCTION(_sk_bicubic_n1y_aarch64) _sk_bicubic_n1y_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52b7f2a9 // mov w9, #0xbf950000 .long 0x4f03f601 // fmov v1.4s, #1.000000000000000000e+00 .long 0x728aaaa9 // movk w9, #0x5555 .long 0x3dc01910 // ldr q16, [x8, #96] .long 0x4f03f711 // fmov v17.4s, #1.500000000000000000e+00 .long 0x4f0167f2 // movi v18.4s, #0x3f, lsl #24 .long 0x4eb0d421 // fsub v1.4s, v1.4s, v16.4s .long 0x4e040d30 // dup v16.4s, w9 .long 0x52a7ac69 // mov w9, #0x3d630000 .long 0x7291c729 // movk w9, #0x8e39 .long 0x4e21ce11 // fmla v17.4s, v16.4s, v1.4s .long 0x4e21ce32 // fmla v18.4s, v17.4s, v1.4s .long 0x4e040d31 // dup v17.4s, w9 .long 0x4e21ce51 // fmla v17.4s, v18.4s, v1.4s .long 0x3dc00910 // ldr q16, [x8, #32] .long 0x3d802911 // str q17, [x8, #160] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f0567e1 // movi v1.4s, #0xbf, lsl #24 .long 0x4e21d601 // fadd v1.4s, v16.4s, v1.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bicubic_p1y_aarch64 .globl _sk_bicubic_p1y_aarch64 FUNCTION(_sk_bicubic_p1y_aarch64) _sk_bicubic_p1y_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52b7f2a9 // mov w9, #0xbf950000 .long 0x728aaaa9 // movk w9, #0x5555 .long 0x4f03f711 // fmov v17.4s, #1.500000000000000000e+00 .long 0x3dc01912 // ldr q18, [x8, #96] .long 0x3dc00901 // ldr q1, [x8, #32] .long 0x4e040d33 // dup v19.4s, w9 .long 0x52a7ac69 // mov w9, #0x3d630000 .long 0x4f0167f0 // movi v16.4s, #0x3f, lsl #24 .long 0x7291c729 // movk w9, #0x8e39 .long 0x4e32ce71 // fmla v17.4s, v19.4s, v18.4s .long 0x4e30d421 // fadd v1.4s, v1.4s, v16.4s .long 0x4e32ce30 // fmla v16.4s, v17.4s, v18.4s .long 0x4e040d31 // dup v17.4s, w9 .long 0x4e32ce11 // fmla v17.4s, v16.4s, v18.4s .long 0x3d802911 // str q17, [x8, #160] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_bicubic_p3y_aarch64 .globl _sk_bicubic_p3y_aarch64 FUNCTION(_sk_bicubic_p3y_aarch64) _sk_bicubic_p3y_aarch64: .long 0xf9400028 // ldr x8, [x1] .long 0x52a7d8e9 // mov w9, #0x3ec70000 .long 0x72838e49 // movk w9, #0x1c72 .long 0x4e040d21 // dup v1.4s, w9 .long 0x3dc01910 // ldr q16, [x8, #96] .long 0x52b7d549 // mov w9, #0xbeaa0000 .long 0x72955569 // movk w9, #0xaaab .long 0x4e040d31 // dup v17.4s, w9 .long 0x6e30de13 // fmul v19.4s, v16.4s, v16.4s .long 0x4e30cc31 // fmla v17.4s, v1.4s, v16.4s .long 0x6e31de61 // fmul v1.4s, v19.4s, v17.4s .long 0x3dc00912 // ldr q18, [x8, #32] .long 0x3d802901 // str q1, [x8, #160] .long 0xf9400425 // ldr x5, [x1, #8] .long 0x4f03f701 // fmov v1.4s, #1.500000000000000000e+00 .long 0x4e21d641 // fadd v1.4s, v18.4s, v1.4s .long 0x91004021 // add x1, x1, #0x10 .long 0xd61f00a0 // br x5 HIDDEN _sk_callback_aarch64 .globl _sk_callback_aarch64 FUNCTION(_sk_callback_aarch64) _sk_callback_aarch64: .long 0xd10203ff // sub sp, sp, #0x80 .long 0xa9045ff8 // stp x24, x23, [sp, #64] .long 0xa90557f6 // stp x22, x21, [sp, #80] .long 0xa9064ff4 // stp x20, x19, [sp, #96] .long 0xa9077bfd // stp x29, x30, [sp, #112] .long 0xad011fe6 // stp q6, q7, [sp, #32] .long 0xad0017e4 // stp q4, q5, [sp] .long 0xaa0103f6 // mov x22, x1 .long 0xf94002d8 // ldr x24, [x22] .long 0xaa0403f3 // mov x19, x4 .long 0xf100027f // cmp x19, #0x0 .long 0x321e03e9 // orr w9, wzr, #0x4 .long 0x91002308 // add x8, x24, #0x8 .long 0x4c000900 // st4 {v0.4s-v3.4s}, [x8] .long 0xf9400308 // ldr x8, [x24] .long 0xaa0003f7 // mov x23, x0 .long 0x1a891261 // csel w1, w19, w9, ne // ne = any .long 0xaa1803e0 // mov x0, x24 .long 0x9101c3fd // add x29, sp, #0x70 .long 0xaa0303f4 // mov x20, x3 .long 0xaa0203f5 // mov x21, x2 .long 0xd63f0100 // blr x8 .long 0xf9404708 // ldr x8, [x24, #136] .long 0xf94006c5 // ldr x5, [x22, #8] .long 0x910042c1 // add x1, x22, #0x10 .long 0xaa1703e0 // mov x0, x23 .long 0x4c400900 // ld4 {v0.4s-v3.4s}, [x8] .long 0xaa1503e2 // mov x2, x21 .long 0xaa1403e3 // mov x3, x20 .long 0xaa1303e4 // mov x4, x19 .long 0xad4017e4 // ldp q4, q5, [sp] .long 0xad411fe6 // ldp q6, q7, [sp, #32] .long 0xa9477bfd // ldp x29, x30, [sp, #112] .long 0xa9464ff4 // ldp x20, x19, [sp, #96] .long 0xa94557f6 // ldp x22, x21, [sp, #80] .long 0xa9445ff8 // ldp x24, x23, [sp, #64] .long 0x910203ff // add sp, sp, #0x80 .long 0xd61f00a0 // br x5 #elif defined(__arm__) BALIGN4 HIDDEN _sk_start_pipeline_vfp4 .globl _sk_start_pipeline_vfp4 FUNCTION(_sk_start_pipeline_vfp4) _sk_start_pipeline_vfp4: .long 0xe92d4ff0 // push {r4, r5, r6, r7, r8, r9, sl, fp, lr} .long 0xe28db01c // add fp, sp, #28 .long 0xe24dd06c // sub sp, sp, #108 .long 0xe7c3d01f // bfc sp, #0, #4 .long 0xe1a06001 // mov r6, r1 .long 0xe1a05002 // mov r5, r2 .long 0xe1a09000 // mov r9, r0 .long 0xe1560003 // cmp r6, r3 .long 0xe58d300c // str r3, [sp, #12] .long 0x2a00001f // bcs a8 .long 0xe59b4008 // ldr r4, [fp, #8] .long 0xe2898004 // add r8, r9, #4 .long 0xe28d7010 // add r7, sp, #16 .long 0xe494a004 // ldr sl, [r4], #4 .long 0xe3a00000 // mov r0, #0 .long 0xe58d9010 // str r9, [sp, #16] .long 0xe58d6014 // str r6, [sp, #20] .long 0xe1580005 // cmp r8, r5 .long 0xe58d0018 // str r0, [sp, #24] .long 0xe59b000c // ldr r0, [fp, #12] .long 0xe58d001c // str r0, [sp, #28] .long 0xe1a00009 // mov r0, r9 .long 0x8a000008 // bhi 80 .long 0xe1a00007 // mov r0, r7 .long 0xe1a01004 // mov r1, r4 .long 0xe12fff3a // blx sl .long 0xe59d1010 // ldr r1, [sp, #16] .long 0xe2810004 // add r0, r1, #4 .long 0xe2811008 // add r1, r1, #8 .long 0xe1510005 // cmp r1, r5 .long 0xe58d0010 // str r0, [sp, #16] .long 0x9afffff6 // bls 5c .long 0xe0550000 // subs r0, r5, r0 .long 0x0a000003 // beq 98 .long 0xe58d0018 // str r0, [sp, #24] .long 0xe1a00007 // mov r0, r7 .long 0xe1a01004 // mov r1, r4 .long 0xe12fff3a // blx sl .long 0xe59d000c // ldr r0, [sp, #12] .long 0xe2866001 // add r6, r6, #1 .long 0xe1560000 // cmp r6, r0 .long 0x1affffe3 // bne 38 .long 0xe24bd01c // sub sp, fp, #28 .long 0xe8bd8ff0 // pop {r4, r5, r6, r7, r8, r9, sl, fp, pc} HIDDEN _sk_just_return_vfp4 .globl _sk_just_return_vfp4 FUNCTION(_sk_just_return_vfp4) _sk_just_return_vfp4: .long 0xe12fff1e // bx lr .long 0xe320f000 // nop {0} HIDDEN _sk_seed_shader_vfp4 .globl _sk_seed_shader_vfp4 FUNCTION(_sk_seed_shader_vfp4) _sk_seed_shader_vfp4: .long 0xe1a02000 // mov r2, r0 .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf4e20cbd // vld1.32 {d16[]-d17[]}, [r2 :32]! .long 0xf2c06050 // vmov.i32 q11, #0 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xe590200c // ldr r2, [r0, #12] .long 0xe28f3040 // add r3, pc, #64 .long 0xf2400de4 // vadd.f32 q8, q8, q10 .long 0xf4234acf // vld1.64 {d4-d5}, [r3] .long 0xf4628a8f // vld1.32 {d24-d25}, [r2] .long 0xe2802040 // add r2, r0, #64 .long 0xf2022de4 // vadd.f32 q1, q9, q10 .long 0xf4426aef // vst1.64 {d22-d23}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf2080de0 // vadd.f32 q0, q12, q8 .long 0xf4426aef // vst1.64 {d22-d23}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf2806050 // vmov.i32 q3, #0 .long 0xf4426aef // vst1.64 {d22-d23}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf4426aef // vst1.64 {d22-d23}, [r2 :128] .long 0xe4912004 // ldr r2, [r1], #4 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_dither_vfp4 .globl _sk_dither_vfp4 FUNCTION(_sk_dither_vfp4) _sk_dither_vfp4: .long 0xe590200c // ldr r2, [r0, #12] .long 0xe1a03000 // mov r3, r0 .long 0xf4e30cbd // vld1.32 {d16[]-d17[]}, [r3 :32]! .long 0xf2c04051 // vmov.i32 q10, #1 .long 0xe2822020 // add r2, r2, #32 .long 0xf2c06054 // vmov.i32 q11, #4 .long 0xf4e3acbf // vld1.32 {d26[]-d27[]}, [r3 :32] .long 0xf4622a8f // vld1.32 {d18-d19}, [r2] .long 0xe3a025f2 // mov r2, #1015021568 .long 0xf26208e0 // vadd.i32 q8, q9, q8 .long 0xf2c02052 // vmov.i32 q9, #2 .long 0xf24081f4 // vand q12, q8, q10 .long 0xf240c1f2 // vand q14, q8, q9 .long 0xf34aa1f0 // veor q13, q13, q8 .long 0xf24001f6 // vand q8, q8, q11 .long 0xf2e48578 // vshl.s32 q12, q12, #4 .long 0xf2e1c57c // vshl.s32 q14, q14, #1 .long 0xf24a41f4 // vand q10, q13, q10 .long 0xf3fe0070 // vshr.u32 q8, q8, #2 .long 0xf26c81f8 // vorr q12, q14, q12 .long 0xf24a21f2 // vand q9, q13, q9 .long 0xf2e54574 // vshl.s32 q10, q10, #5 .long 0xf26801f0 // vorr q8, q12, q8 .long 0xf24a61f6 // vand q11, q13, q11 .long 0xf26001f4 // vorr q8, q8, q10 .long 0xf2e22572 // vshl.s32 q9, q9, #2 .long 0xf3ff4076 // vshr.u32 q10, q11, #1 .long 0xf26001f2 // vorr q8, q8, q9 .long 0xeea22b90 // vdup.32 q9, r2 .long 0xe28f2054 // add r2, pc, #84 .long 0xe5913000 // ldr r3, [r1] .long 0xf26001f4 // vorr q8, q8, q10 .long 0xf2c06050 // vmov.i32 q11, #0 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3400df2 // vmul.f32 q8, q8, q9 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf2400de2 // vadd.f32 q8, q8, q9 .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xf3420df0 // vmul.f32 q8, q9, q8 .long 0xf2402dc0 // vadd.f32 q9, q8, q0 .long 0xf2404dc2 // vadd.f32 q10, q8, q1 .long 0xf2400dc4 // vadd.f32 q8, q8, q2 .long 0xf2622fc6 // vmin.f32 q9, q9, q3 .long 0xf2644fc6 // vmin.f32 q10, q10, q3 .long 0xf2600fc6 // vmin.f32 q8, q8, q3 .long 0xf2060fe2 // vmax.f32 q0, q11, q9 .long 0xf2062fe4 // vmax.f32 q1, q11, q10 .long 0xf2064fe0 // vmax.f32 q2, q11, q8 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0xbefc0000 // .word 0xbefc0000 .long 0xbefc0000 // .word 0xbefc0000 .long 0xbefc0000 // .word 0xbefc0000 .long 0xbefc0000 // .word 0xbefc0000 HIDDEN _sk_uniform_color_vfp4 .globl _sk_uniform_color_vfp4 FUNCTION(_sk_uniform_color_vfp4) _sk_uniform_color_vfp4: .long 0xe92d4800 // push {fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xe283200c // add r2, r3, #12 .long 0xe1a0e003 // mov lr, r3 .long 0xf4ae0cbd // vld1.32 {d0[]-d1[]}, [lr :32]! .long 0xf4a26cbf // vld1.32 {d6[]-d7[]}, [r2 :32] .long 0xe2832008 // add r2, r3, #8 .long 0xf4a24cbf // vld1.32 {d4[]-d5[]}, [r2 :32] .long 0xf4ae2cbf // vld1.32 {d2[]-d3[]}, [lr :32] .long 0xe8bd4800 // pop {fp, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_black_color_vfp4 .globl _sk_black_color_vfp4 FUNCTION(_sk_black_color_vfp4) _sk_black_color_vfp4: .long 0xe28f2018 // add r2, pc, #24 .long 0xf2800050 // vmov.i32 q0, #0 .long 0xf4226acf // vld1.64 {d6-d7}, [r2] .long 0xf2802050 // vmov.i32 q1, #0 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_white_color_vfp4 .globl _sk_white_color_vfp4 FUNCTION(_sk_white_color_vfp4) _sk_white_color_vfp4: .long 0xe28f2018 // add r2, pc, #24 .long 0xf4220acf // vld1.64 {d0-d1}, [r2] .long 0xf2202150 // vorr q1, q0, q0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2204150 // vorr q2, q0, q0 .long 0xf2206150 // vorr q3, q0, q0 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_load_rgba_vfp4 .globl _sk_load_rgba_vfp4 FUNCTION(_sk_load_rgba_vfp4) _sk_load_rgba_vfp4: .long 0xe92d4800 // push {fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xe2832030 // add r2, r3, #48 .long 0xe1a0e003 // mov lr, r3 .long 0xf4226a8f // vld1.32 {d6-d7}, [r2] .long 0xe2832020 // add r2, r3, #32 .long 0xf42e0a8d // vld1.32 {d0-d1}, [lr]! .long 0xf4224a8f // vld1.32 {d4-d5}, [r2] .long 0xf42e2a8f // vld1.32 {d2-d3}, [lr] .long 0xe8bd4800 // pop {fp, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_store_rgba_vfp4 .globl _sk_store_rgba_vfp4 FUNCTION(_sk_store_rgba_vfp4) _sk_store_rgba_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xe1a03002 // mov r3, r2 .long 0xf4030a8d // vst1.32 {d0-d1}, [r3]! .long 0xf4032a8f // vst1.32 {d2-d3}, [r3] .long 0xe2823020 // add r3, r2, #32 .long 0xe2822030 // add r2, r2, #48 .long 0xf4034a8f // vst1.32 {d4-d5}, [r3] .long 0xf4026a8f // vst1.32 {d6-d7}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 HIDDEN _sk_clear_vfp4 .globl _sk_clear_vfp4 FUNCTION(_sk_clear_vfp4) _sk_clear_vfp4: .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2800050 // vmov.i32 q0, #0 .long 0xf2802050 // vmov.i32 q1, #0 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xf2806050 // vmov.i32 q3, #0 .long 0xe12fff12 // bx r2 HIDDEN _sk_srcatop_vfp4 .globl _sk_srcatop_vfp4 FUNCTION(_sk_srcatop_vfp4) _sk_srcatop_vfp4: .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2802040 // add r2, r0, #64 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf2602dc6 // vsub.f32 q9, q8, q3 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf3046dd6 // vmul.f32 q3, q10, q3 .long 0xf3042dd2 // vmul.f32 q1, q10, q1 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xf3044dd4 // vmul.f32 q2, q10, q2 .long 0xe2802030 // add r2, r0, #48 .long 0xf3420df0 // vmul.f32 q8, q9, q8 .long 0xf4628aef // vld1.64 {d24-d25}, [r2 :128] .long 0xf2026cf4 // vfma.f32 q3, q9, q10 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2022cf6 // vfma.f32 q1, q9, q11 .long 0xf2440cd0 // vfma.f32 q8, q10, q0 .long 0xf2024cf8 // vfma.f32 q2, q9, q12 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xe12fff12 // bx r2 HIDDEN _sk_dstatop_vfp4 .globl _sk_dstatop_vfp4 FUNCTION(_sk_dstatop_vfp4) _sk_dstatop_vfp4: .long 0xe2802040 // add r2, r0, #64 .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf2606de4 // vsub.f32 q11, q8, q10 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf3400dd6 // vmul.f32 q8, q8, q3 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf3444dd6 // vmul.f32 q10, q10, q3 .long 0xf3422dd6 // vmul.f32 q9, q9, q3 .long 0xe2802030 // add r2, r0, #48 .long 0xf3064dd4 // vmul.f32 q2, q11, q2 .long 0xf4628aef // vld1.64 {d24-d25}, [r2 :128] .long 0xf2460cd0 // vfma.f32 q8, q11, q0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2462cd2 // vfma.f32 q9, q11, q1 .long 0xf2464cd6 // vfma.f32 q10, q11, q3 .long 0xf2084cd6 // vfma.f32 q2, q12, q3 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xf22461f4 // vorr q3, q10, q10 .long 0xe12fff12 // bx r2 HIDDEN _sk_srcin_vfp4 .globl _sk_srcin_vfp4 FUNCTION(_sk_srcin_vfp4) _sk_srcin_vfp4: .long 0xe2802040 // add r2, r0, #64 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xf3000dd0 // vmul.f32 q0, q8, q0 .long 0xf3002dd2 // vmul.f32 q1, q8, q1 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3004dd4 // vmul.f32 q2, q8, q2 .long 0xf3006dd6 // vmul.f32 q3, q8, q3 .long 0xe12fff12 // bx r2 HIDDEN _sk_dstin_vfp4 .globl _sk_dstin_vfp4 FUNCTION(_sk_dstin_vfp4) _sk_dstin_vfp4: .long 0xe2802010 // add r2, r0, #16 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf3000dd6 // vmul.f32 q0, q8, q3 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf3024dd6 // vmul.f32 q2, q9, q3 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf3042dd6 // vmul.f32 q1, q10, q3 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xf3006dd6 // vmul.f32 q3, q8, q3 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xe12fff12 // bx r2 HIDDEN _sk_srcout_vfp4 .globl _sk_srcout_vfp4 FUNCTION(_sk_srcout_vfp4) _sk_srcout_vfp4: .long 0xe2802040 // add r2, r0, #64 .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3000dd0 // vmul.f32 q0, q8, q0 .long 0xf3002dd2 // vmul.f32 q1, q8, q1 .long 0xf3004dd4 // vmul.f32 q2, q8, q2 .long 0xf3006dd6 // vmul.f32 q3, q8, q3 .long 0xe12fff12 // bx r2 HIDDEN _sk_dstout_vfp4 .globl _sk_dstout_vfp4 FUNCTION(_sk_dstout_vfp4) _sk_dstout_vfp4: .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2802010 // add r2, r0, #16 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf2600dc6 // vsub.f32 q8, q8, q3 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf3000df2 // vmul.f32 q0, q8, q9 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf3002df6 // vmul.f32 q1, q8, q11 .long 0xf3004df4 // vmul.f32 q2, q8, q10 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3006df2 // vmul.f32 q3, q8, q9 .long 0xe12fff12 // bx r2 HIDDEN _sk_srcover_vfp4 .globl _sk_srcover_vfp4 FUNCTION(_sk_srcover_vfp4) _sk_srcover_vfp4: .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2802010 // add r2, r0, #16 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf2600dc6 // vsub.f32 q8, q8, q3 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf2020cf0 // vfma.f32 q0, q9, q8 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf2042cf0 // vfma.f32 q1, q10, q8 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xf2024cf0 // vfma.f32 q2, q9, q8 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2046cf0 // vfma.f32 q3, q10, q8 .long 0xe12fff12 // bx r2 HIDDEN _sk_dstover_vfp4 .globl _sk_dstover_vfp4 FUNCTION(_sk_dstover_vfp4) _sk_dstover_vfp4: .long 0xe2802040 // add r2, r0, #64 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf2628de0 // vsub.f32 q12, q9, q8 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xf2402c78 // vfma.f32 q9, q0, q12 .long 0xf2424c78 // vfma.f32 q10, q1, q12 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2446c78 // vfma.f32 q11, q2, q12 .long 0xf2460c78 // vfma.f32 q8, q3, q12 .long 0xf22201f2 // vorr q0, q9, q9 .long 0xf22421f4 // vorr q1, q10, q10 .long 0xf22641f6 // vorr q2, q11, q11 .long 0xf22061f0 // vorr q3, q8, q8 .long 0xe12fff12 // bx r2 HIDDEN _sk_modulate_vfp4 .globl _sk_modulate_vfp4 FUNCTION(_sk_modulate_vfp4) _sk_modulate_vfp4: .long 0xe2802010 // add r2, r0, #16 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf3000dd0 // vmul.f32 q0, q8, q0 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf3024dd4 // vmul.f32 q2, q9, q2 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf3042dd2 // vmul.f32 q1, q10, q1 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xf3006dd6 // vmul.f32 q3, q8, q3 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xe12fff12 // bx r2 HIDDEN _sk_multiply_vfp4 .globl _sk_multiply_vfp4 FUNCTION(_sk_multiply_vfp4) _sk_multiply_vfp4: .long 0xed2d8b04 // vpush {d8-d9} .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2802040 // add r2, r0, #64 .long 0xf4628aef // vld1.64 {d24-d25}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf260ade8 // vsub.f32 q13, q8, q12 .long 0xf462caef // vld1.64 {d28-d29}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf2606dc6 // vsub.f32 q11, q8, q3 .long 0xf4228aef // vld1.64 {d8-d9}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf34a2dd4 // vmul.f32 q9, q13, q2 .long 0xf34aedd6 // vmul.f32 q15, q13, q3 .long 0xf3460dfc // vmul.f32 q8, q11, q14 .long 0xf3464df8 // vmul.f32 q10, q11, q12 .long 0xf2420de0 // vadd.f32 q8, q9, q8 .long 0xf2442dee // vadd.f32 q9, q10, q15 .long 0xf34aedd0 // vmul.f32 q15, q13, q0 .long 0xf3464dd8 // vmul.f32 q10, q11, q4 .long 0xf34aadd2 // vmul.f32 q13, q13, q1 .long 0xf24c0cd4 // vfma.f32 q8, q14, q2 .long 0xf2482cd6 // vfma.f32 q9, q12, q3 .long 0xf2444dee // vadd.f32 q10, q10, q15 .long 0xf462eaef // vld1.64 {d30-d31}, [r2 :128] .long 0xf3466dfe // vmul.f32 q11, q11, q15 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2484c50 // vfma.f32 q10, q4, q0 .long 0xf22041f0 // vorr q2, q8, q8 .long 0xf2466dea // vadd.f32 q11, q11, q13 .long 0xf22261f2 // vorr q3, q9, q9 .long 0xf24e6cd2 // vfma.f32 q11, q15, q1 .long 0xf22401f4 // vorr q0, q10, q10 .long 0xf22621f6 // vorr q1, q11, q11 .long 0xecbd8b04 // vpop {d8-d9} .long 0xe12fff12 // bx r2 HIDDEN _sk_plus__vfp4 .globl _sk_plus__vfp4 FUNCTION(_sk_plus__vfp4) _sk_plus__vfp4: .long 0xe2802010 // add r2, r0, #16 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf2000dc0 // vadd.f32 q0, q8, q0 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf2022dc2 // vadd.f32 q1, q9, q1 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf2004dc4 // vadd.f32 q2, q8, q2 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2026dc6 // vadd.f32 q3, q9, q3 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xe12fff12 // bx r2 HIDDEN _sk_screen_vfp4 .globl _sk_screen_vfp4 FUNCTION(_sk_screen_vfp4) _sk_screen_vfp4: .long 0xe2802010 // add r2, r0, #16 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf2460dc0 // vadd.f32 q8, q11, q0 .long 0xf4628aef // vld1.64 {d24-d25}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf2482dc2 // vadd.f32 q9, q12, q1 .long 0xf462aaef // vld1.64 {d26-d27}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf24a4dc4 // vadd.f32 q10, q13, q2 .long 0xf462caef // vld1.64 {d28-d29}, [r2 :128] .long 0xf2660cd0 // vfms.f32 q8, q11, q0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf24c6dc6 // vadd.f32 q11, q14, q3 .long 0xf2682cd2 // vfms.f32 q9, q12, q1 .long 0xf26a4cd4 // vfms.f32 q10, q13, q2 .long 0xf26c6cd6 // vfms.f32 q11, q14, q3 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xf22441f4 // vorr q2, q10, q10 .long 0xf22661f6 // vorr q3, q11, q11 .long 0xe12fff12 // bx r2 HIDDEN _sk_xor__vfp4 .globl _sk_xor__vfp4 FUNCTION(_sk_xor__vfp4) _sk_xor__vfp4: .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2802010 // add r2, r0, #16 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf2606dc6 // vsub.f32 q11, q8, q3 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf2608de4 // vsub.f32 q12, q8, q10 .long 0xf462aaef // vld1.64 {d26-d27}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf3460df2 // vmul.f32 q8, q11, q9 .long 0xf3462dfa // vmul.f32 q9, q11, q13 .long 0xf462aaef // vld1.64 {d26-d27}, [r2 :128] .long 0xf3464df4 // vmul.f32 q10, q11, q10 .long 0xf3084dd4 // vmul.f32 q2, q12, q2 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2480cd0 // vfma.f32 q8, q12, q0 .long 0xf2482cd2 // vfma.f32 q9, q12, q1 .long 0xf2484cd6 // vfma.f32 q10, q12, q3 .long 0xf2064cfa // vfma.f32 q2, q11, q13 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xf22461f4 // vorr q3, q10, q10 .long 0xe12fff12 // bx r2 HIDDEN _sk_darken_vfp4 .globl _sk_darken_vfp4 FUNCTION(_sk_darken_vfp4) _sk_darken_vfp4: .long 0xe2802040 // add r2, r0, #64 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf340add0 // vmul.f32 q13, q8, q0 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf3446dd6 // vmul.f32 q11, q10, q3 .long 0xf4628aef // vld1.64 {d24-d25}, [r2 :128] .long 0xf340edd2 // vmul.f32 q15, q8, q1 .long 0xf348cdd6 // vmul.f32 q14, q12, q3 .long 0xe2802030 // add r2, r0, #48 .long 0xf2444dc0 // vadd.f32 q10, q10, q0 .long 0xf24a6fe6 // vmax.f32 q11, q13, q11 .long 0xf462aaef // vld1.64 {d26-d27}, [r2 :128] .long 0xf24ecfec // vmax.f32 q14, q15, q14 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf24aedc4 // vadd.f32 q15, q13, q2 .long 0xf34aadd6 // vmul.f32 q13, q13, q3 .long 0xf3000dd4 // vmul.f32 q0, q8, q2 .long 0xf2622dc6 // vsub.f32 q9, q9, q3 .long 0xf2488dc2 // vadd.f32 q12, q12, q1 .long 0xf240af6a // vmax.f32 q13, q0, q13 .long 0xf2006cf2 // vfma.f32 q3, q8, q9 .long 0xf2240de6 // vsub.f32 q0, q10, q11 .long 0xf2282dec // vsub.f32 q1, q12, q14 .long 0xf22e4dea // vsub.f32 q2, q15, q13 .long 0xe12fff12 // bx r2 HIDDEN _sk_lighten_vfp4 .globl _sk_lighten_vfp4 FUNCTION(_sk_lighten_vfp4) _sk_lighten_vfp4: .long 0xe2802040 // add r2, r0, #64 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf340add0 // vmul.f32 q13, q8, q0 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf3446dd6 // vmul.f32 q11, q10, q3 .long 0xf4628aef // vld1.64 {d24-d25}, [r2 :128] .long 0xf340edd2 // vmul.f32 q15, q8, q1 .long 0xf348cdd6 // vmul.f32 q14, q12, q3 .long 0xe2802030 // add r2, r0, #48 .long 0xf2444dc0 // vadd.f32 q10, q10, q0 .long 0xf26a6fe6 // vmin.f32 q11, q13, q11 .long 0xf462aaef // vld1.64 {d26-d27}, [r2 :128] .long 0xf26ecfec // vmin.f32 q14, q15, q14 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf24aedc4 // vadd.f32 q15, q13, q2 .long 0xf34aadd6 // vmul.f32 q13, q13, q3 .long 0xf3000dd4 // vmul.f32 q0, q8, q2 .long 0xf2622dc6 // vsub.f32 q9, q9, q3 .long 0xf2488dc2 // vadd.f32 q12, q12, q1 .long 0xf260af6a // vmin.f32 q13, q0, q13 .long 0xf2006cf2 // vfma.f32 q3, q8, q9 .long 0xf2240de6 // vsub.f32 q0, q10, q11 .long 0xf2282dec // vsub.f32 q1, q12, q14 .long 0xf22e4dea // vsub.f32 q2, q15, q13 .long 0xe12fff12 // bx r2 HIDDEN _sk_difference_vfp4 .globl _sk_difference_vfp4 FUNCTION(_sk_difference_vfp4) _sk_difference_vfp4: .long 0xe2802010 // add r2, r0, #16 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf3404dd6 // vmul.f32 q10, q8, q3 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf3426dd0 // vmul.f32 q11, q9, q0 .long 0xf4628aef // vld1.64 {d24-d25}, [r2 :128] .long 0xf342cdd4 // vmul.f32 q14, q9, q2 .long 0xf348add6 // vmul.f32 q13, q12, q3 .long 0xe2802020 // add r2, r0, #32 .long 0xf342edd2 // vmul.f32 q15, q9, q1 .long 0xf2400dc0 // vadd.f32 q8, q8, q0 .long 0xf2664fe4 // vmin.f32 q10, q11, q10 .long 0xf26c6fea // vmin.f32 q11, q14, q13 .long 0xf462aaef // vld1.64 {d26-d27}, [r2 :128] .long 0xf34acdd6 // vmul.f32 q14, q13, q3 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2444de4 // vadd.f32 q10, q10, q10 .long 0xf24aadc2 // vadd.f32 q13, q13, q1 .long 0xf26ecfec // vmin.f32 q14, q15, q14 .long 0xf2c7ef50 // vmov.f32 q15, #1 .long 0xf2488dc4 // vadd.f32 q12, q12, q2 .long 0xf26eedc6 // vsub.f32 q15, q15, q3 .long 0xf24ccdec // vadd.f32 q14, q14, q14 .long 0xf2466de6 // vadd.f32 q11, q11, q11 .long 0xf2026cfe // vfma.f32 q3, q9, q15 .long 0xf2200de4 // vsub.f32 q0, q8, q10 .long 0xf22a2dec // vsub.f32 q1, q13, q14 .long 0xf2284de6 // vsub.f32 q2, q12, q11 .long 0xe12fff12 // bx r2 HIDDEN _sk_exclusion_vfp4 .globl _sk_exclusion_vfp4 FUNCTION(_sk_exclusion_vfp4) _sk_exclusion_vfp4: .long 0xe2802010 // add r2, r0, #16 .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf3424dd0 // vmul.f32 q10, q9, q0 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf3468dd2 // vmul.f32 q12, q11, q1 .long 0xf462aaef // vld1.64 {d26-d27}, [r2 :128] .long 0xf2600dc6 // vsub.f32 q8, q8, q3 .long 0xe2802040 // add r2, r0, #64 .long 0xf34acdd4 // vmul.f32 q14, q13, q2 .long 0xf462eaef // vld1.64 {d30-d31}, [r2 :128] .long 0xf2422dc0 // vadd.f32 q9, q9, q0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2444de4 // vadd.f32 q10, q10, q10 .long 0xf2466dc2 // vadd.f32 q11, q11, q1 .long 0xf2488de8 // vadd.f32 q12, q12, q12 .long 0xf24aadc4 // vadd.f32 q13, q13, q2 .long 0xf24ccdec // vadd.f32 q14, q14, q14 .long 0xf20e6cf0 // vfma.f32 q3, q15, q8 .long 0xf2220de4 // vsub.f32 q0, q9, q10 .long 0xf2262de8 // vsub.f32 q1, q11, q12 .long 0xf22a4dec // vsub.f32 q2, q13, q14 .long 0xe12fff12 // bx r2 HIDDEN _sk_colorburn_vfp4 .globl _sk_colorburn_vfp4 FUNCTION(_sk_colorburn_vfp4) _sk_colorburn_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xe2802030 // add r2, r0, #48 .long 0xf2c76f50 // vmov.f32 q11, #1 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf2668dc6 // vsub.f32 q12, q11, q3 .long 0xf3b9c540 // vceq.f32 q6, q0, #0 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf2604de2 // vsub.f32 q10, q8, q9 .long 0xf266cde0 // vsub.f32 q14, q11, q8 .long 0xf348edf2 // vmul.f32 q15, q12, q9 .long 0xf3048dd6 // vmul.f32 q4, q10, q3 .long 0xeec9baa5 // vdiv.f32 s23, s19, s11 .long 0xee89ba05 // vdiv.f32 s22, s18, s10 .long 0xeec8aaa4 // vdiv.f32 s21, s17, s9 .long 0xee88aa04 // vdiv.f32 s20, s16, s8 .long 0xf2604fca // vmin.f32 q10, q8, q5 .long 0xf260ade4 // vsub.f32 q13, q8, q10 .long 0xf34c4dd4 // vmul.f32 q10, q14, q2 .long 0xf34a6dd6 // vmul.f32 q11, q13, q3 .long 0xf462aaef // vld1.64 {d26-d27}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf2446de6 // vadd.f32 q11, q10, q11 .long 0xf20eade6 // vadd.f32 q5, q15, q11 .long 0xf2606dea // vsub.f32 q11, q8, q13 .long 0xf24eedc4 // vadd.f32 q15, q15, q2 .long 0xf3068dd6 // vmul.f32 q4, q11, q3 .long 0xf3f96544 // vceq.f32 q11, q2, #0 .long 0xf35e61da // vbsl q11, q15, q5 .long 0xeec95aa3 // vdiv.f32 s11, s19, s7 .long 0xee895a03 // vdiv.f32 s10, s18, s6 .long 0xeec84aa2 // vdiv.f32 s9, s17, s5 .long 0xee884a02 // vdiv.f32 s8, s16, s4 .long 0xf260efc4 // vmin.f32 q15, q8, q2 .long 0xf30c8dd2 // vmul.f32 q4, q14, q1 .long 0xf3084dfa // vmul.f32 q2, q12, q13 .long 0xf34ccdd0 // vmul.f32 q14, q14, q0 .long 0xf260edee // vsub.f32 q15, q8, q15 .long 0xf34eedd6 // vmul.f32 q15, q15, q3 .long 0xf248ed6e // vadd.f32 q15, q4, q15 .long 0xf204ad6e // vadd.f32 q5, q2, q15 .long 0xf3f9e542 // vceq.f32 q15, q1, #0 .long 0xf2044d42 // vadd.f32 q2, q2, q1 .long 0xf354e15a // vbsl q15, q2, q5 .long 0xf422aaef // vld1.64 {d10-d11}, [r2 :128] .long 0xf2202dca // vsub.f32 q1, q8, q5 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3022d56 // vmul.f32 q1, q1, q3 .long 0xeec35aa1 // vdiv.f32 s11, s7, s3 .long 0xee835a01 // vdiv.f32 s10, s6, s2 .long 0xeec24aa0 // vdiv.f32 s9, s5, s1 .long 0xee824a00 // vdiv.f32 s8, s4, s0 .long 0xf2202fc4 // vmin.f32 q1, q8, q2 .long 0xf3084dda // vmul.f32 q2, q12, q5 .long 0xf2202dc2 // vsub.f32 q1, q8, q1 .long 0xf3022d56 // vmul.f32 q1, q1, q3 .long 0xf2006cf8 // vfma.f32 q3, q8, q12 .long 0xf20c2dc2 // vadd.f32 q1, q14, q1 .long 0xf2042d42 // vadd.f32 q1, q2, q1 .long 0xf2044d40 // vadd.f32 q2, q2, q0 .long 0xf20a0e60 // vceq.f32 q0, q5, q8 .long 0xf314c152 // vbsl q6, q2, q1 .long 0xf2024ee0 // vceq.f32 q2, q9, q8 .long 0xf2442de2 // vadd.f32 q9, q10, q9 .long 0xf20a2ee0 // vceq.f32 q1, q13, q8 .long 0xf2484d6a // vadd.f32 q10, q4, q13 .long 0xf24a0d6c // vadd.f32 q8, q5, q14 .long 0xf31241f6 // vbsl q2, q9, q11 .long 0xf31421fe // vbsl q1, q10, q15 .long 0xf31001dc // vbsl q0, q8, q6 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff12 // bx r2 HIDDEN _sk_colordodge_vfp4 .globl _sk_colordodge_vfp4 FUNCTION(_sk_colordodge_vfp4) _sk_colordodge_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xe2802030 // add r2, r0, #48 .long 0xf226ad44 // vsub.f32 q5, q3, q2 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf300cdd6 // vmul.f32 q6, q8, q3 .long 0xf2c74f50 // vmov.f32 q10, #1 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf264ade2 // vsub.f32 q13, q10, q9 .long 0xf2646dc6 // vsub.f32 q11, q10, q3 .long 0xeecd9aab // vdiv.f32 s19, s27, s23 .long 0xee8d9a0b // vdiv.f32 s18, s26, s22 .long 0xeecc8aaa // vdiv.f32 s17, s25, s21 .long 0xee8c8a0a // vdiv.f32 s16, s24, s20 .long 0xf262cfc8 // vmin.f32 q14, q9, q4 .long 0xf34a8dd4 // vmul.f32 q12, q13, q2 .long 0xf34c4dd6 // vmul.f32 q10, q14, q3 .long 0xf346cdf0 // vmul.f32 q14, q11, q8 .long 0xf248ede4 // vadd.f32 q15, q12, q10 .long 0xf20c8dc4 // vadd.f32 q4, q14, q2 .long 0xf2444e46 // vceq.f32 q10, q2, q3 .long 0xf24ccdee // vadd.f32 q14, q14, q15 .long 0xf2264d42 // vsub.f32 q2, q3, q1 .long 0xf358417c // vbsl q10, q4, q14 .long 0xf462caef // vld1.64 {d28-d29}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf30c8dd6 // vmul.f32 q4, q14, q3 .long 0xeec9baa5 // vdiv.f32 s23, s19, s11 .long 0xee89ba05 // vdiv.f32 s22, s18, s10 .long 0xeec8aaa4 // vdiv.f32 s21, s17, s9 .long 0xee88aa04 // vdiv.f32 s20, s16, s8 .long 0xf262efca // vmin.f32 q15, q9, q5 .long 0xf30a4dd2 // vmul.f32 q2, q13, q1 .long 0xf3068dfc // vmul.f32 q4, q11, q14 .long 0xf34aadd0 // vmul.f32 q13, q13, q0 .long 0xf34eedd6 // vmul.f32 q15, q15, q3 .long 0xf244ed6e // vadd.f32 q15, q2, q15 .long 0xf208ad6e // vadd.f32 q5, q4, q15 .long 0xf242ee46 // vceq.f32 q15, q1, q3 .long 0xf2082d42 // vadd.f32 q1, q4, q1 .long 0xf2268d40 // vsub.f32 q4, q3, q0 .long 0xf352e15a // vbsl q15, q1, q5 .long 0xf4222aef // vld1.64 {d2-d3}, [r2 :128] .long 0xf302ad56 // vmul.f32 q5, q1, q3 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xeecbdaa9 // vdiv.f32 s27, s23, s19 .long 0xee8bda09 // vdiv.f32 s26, s22, s18 .long 0xeecacaa8 // vdiv.f32 s25, s21, s17 .long 0xee8aca08 // vdiv.f32 s24, s20, s16 .long 0xf2228fcc // vmin.f32 q4, q9, q6 .long 0xf306add2 // vmul.f32 q5, q11, q1 .long 0xf200ce46 // vceq.f32 q6, q0, q3 .long 0xf3088d56 // vmul.f32 q4, q4, q3 .long 0xf2026cf6 // vfma.f32 q3, q9, q11 .long 0xf20a0d40 // vadd.f32 q0, q5, q0 .long 0xf20a8dc8 // vadd.f32 q4, q13, q4 .long 0xf2482de0 // vadd.f32 q9, q12, q8 .long 0xf2446d6c // vadd.f32 q11, q2, q14 .long 0xf3b94560 // vceq.f32 q2, q8, #0 .long 0xf2428d6a // vadd.f32 q12, q1, q13 .long 0xf20a8d48 // vadd.f32 q4, q5, q4 .long 0xf310c158 // vbsl q6, q0, q4 .long 0xf3b90542 // vceq.f32 q0, q1, #0 .long 0xf3b9256c // vceq.f32 q1, q14, #0 .long 0xf31801dc // vbsl q0, q12, q6 .long 0xf31621fe // vbsl q1, q11, q15 .long 0xf31241f4 // vbsl q2, q9, q10 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff12 // bx r2 HIDDEN _sk_hardlight_vfp4 .globl _sk_hardlight_vfp4 FUNCTION(_sk_hardlight_vfp4) _sk_hardlight_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xf2c74f50 // vmov.f32 q10, #1 .long 0xe2802040 // add r2, r0, #64 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf264ade2 // vsub.f32 q13, q10, q9 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf2640dc6 // vsub.f32 q8, q10, q3 .long 0xf462caef // vld1.64 {d28-d29}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf266ed42 // vsub.f32 q15, q3, q1 .long 0xf34a8dd4 // vmul.f32 q12, q13, q2 .long 0xf3404df6 // vmul.f32 q10, q8, q11 .long 0xf30cadd2 // vmul.f32 q5, q14, q1 .long 0xf2484de4 // vadd.f32 q10, q12, q10 .long 0xf2628dec // vsub.f32 q12, q9, q14 .long 0xf340cdfc // vmul.f32 q14, q8, q14 .long 0xf20aad4a // vadd.f32 q5, q5, q5 .long 0xf34e8df8 // vmul.f32 q12, q15, q12 .long 0xf342edd6 // vmul.f32 q15, q9, q3 .long 0xf2488de8 // vadd.f32 q12, q12, q12 .long 0xf22e8de8 // vsub.f32 q4, q15, q12 .long 0xf2428d42 // vadd.f32 q12, q1, q1 .long 0xf30a2dd2 // vmul.f32 q1, q13, q1 .long 0xf34aadd0 // vmul.f32 q13, q13, q0 .long 0xf3468e68 // vcge.f32 q12, q3, q12 .long 0xf242cd6c // vadd.f32 q14, q1, q14 .long 0xf4222aef // vld1.64 {d2-d3}, [r2 :128] .long 0xf302cd50 // vmul.f32 q6, q1, q0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf35a8158 // vbsl q12, q5, q4 .long 0xf2228dc2 // vsub.f32 q4, q9, q1 .long 0xf226ad40 // vsub.f32 q5, q3, q0 .long 0xf3002dd2 // vmul.f32 q1, q8, q1 .long 0xf20ccd4c // vadd.f32 q6, q6, q6 .long 0xf30a8d58 // vmul.f32 q4, q5, q4 .long 0xf200ad40 // vadd.f32 q5, q0, q0 .long 0xf2220de6 // vsub.f32 q0, q9, q11 .long 0xf242ad6a // vadd.f32 q13, q1, q13 .long 0xf2262d44 // vsub.f32 q1, q3, q2 .long 0xf2088d48 // vadd.f32 q4, q4, q4 .long 0xf3466dd4 // vmul.f32 q11, q11, q2 .long 0xf3020d50 // vmul.f32 q0, q1, q0 .long 0xf306ae4a // vcge.f32 q5, q3, q5 .long 0xf22e8dc8 // vsub.f32 q4, q15, q4 .long 0xf2000d40 // vadd.f32 q0, q0, q0 .long 0xf31ca158 // vbsl q5, q6, q4 .long 0xf2466de6 // vadd.f32 q11, q11, q11 .long 0xf26eedc0 // vsub.f32 q15, q15, q0 .long 0xf2040d44 // vadd.f32 q0, q2, q2 .long 0xf2082dec // vadd.f32 q1, q12, q14 .long 0xf3068e40 // vcge.f32 q4, q3, q0 .long 0xf2026cf0 // vfma.f32 q3, q9, q8 .long 0xf20a0d6a // vadd.f32 q0, q5, q13 .long 0xf31681fe // vbsl q4, q11, q15 .long 0xf2084d64 // vadd.f32 q2, q4, q10 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff12 // bx r2 HIDDEN _sk_overlay_vfp4 .globl _sk_overlay_vfp4 FUNCTION(_sk_overlay_vfp4) _sk_overlay_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xf2c74f50 // vmov.f32 q10, #1 .long 0xe2802040 // add r2, r0, #64 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf264ade2 // vsub.f32 q13, q10, q9 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf2640dc6 // vsub.f32 q8, q10, q3 .long 0xf462caef // vld1.64 {d28-d29}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf266ed42 // vsub.f32 q15, q3, q1 .long 0xf34a8dd4 // vmul.f32 q12, q13, q2 .long 0xf3404df6 // vmul.f32 q10, q8, q11 .long 0xf30cadd2 // vmul.f32 q5, q14, q1 .long 0xf30a2dd2 // vmul.f32 q1, q13, q1 .long 0xf34aadd0 // vmul.f32 q13, q13, q0 .long 0xf2484de4 // vadd.f32 q10, q12, q10 .long 0xf2628dec // vsub.f32 q12, q9, q14 .long 0xf20aad4a // vadd.f32 q5, q5, q5 .long 0xf34e8df8 // vmul.f32 q12, q15, q12 .long 0xf342edd6 // vmul.f32 q15, q9, q3 .long 0xf2488de8 // vadd.f32 q12, q12, q12 .long 0xf22e8de8 // vsub.f32 q4, q15, q12 .long 0xf24c8dec // vadd.f32 q12, q14, q14 .long 0xf340cdfc // vmul.f32 q14, q8, q14 .long 0xf3428ee8 // vcge.f32 q12, q9, q12 .long 0xf242cd6c // vadd.f32 q14, q1, q14 .long 0xf4222aef // vld1.64 {d2-d3}, [r2 :128] .long 0xf302cd50 // vmul.f32 q6, q1, q0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf35a8158 // vbsl q12, q5, q4 .long 0xf2228dc2 // vsub.f32 q4, q9, q1 .long 0xf226ad40 // vsub.f32 q5, q3, q0 .long 0xf2220de6 // vsub.f32 q0, q9, q11 .long 0xf20ccd4c // vadd.f32 q6, q6, q6 .long 0xf30a8d58 // vmul.f32 q4, q5, q4 .long 0xf202ad42 // vadd.f32 q5, q1, q1 .long 0xf3002dd2 // vmul.f32 q1, q8, q1 .long 0xf2088d48 // vadd.f32 q4, q4, q4 .long 0xf302aeca // vcge.f32 q5, q9, q5 .long 0xf242ad6a // vadd.f32 q13, q1, q13 .long 0xf2262d44 // vsub.f32 q1, q3, q2 .long 0xf22e8dc8 // vsub.f32 q4, q15, q4 .long 0xf31ca158 // vbsl q5, q6, q4 .long 0xf3020d50 // vmul.f32 q0, q1, q0 .long 0xf2026cf0 // vfma.f32 q3, q9, q8 .long 0xf2082dec // vadd.f32 q1, q12, q14 .long 0xf2000d40 // vadd.f32 q0, q0, q0 .long 0xf26eedc0 // vsub.f32 q15, q15, q0 .long 0xf2060de6 // vadd.f32 q0, q11, q11 .long 0xf3466dd4 // vmul.f32 q11, q11, q2 .long 0xf3028ec0 // vcge.f32 q4, q9, q0 .long 0xf2466de6 // vadd.f32 q11, q11, q11 .long 0xf20a0d6a // vadd.f32 q0, q5, q13 .long 0xf31681fe // vbsl q4, q11, q15 .long 0xf2084d64 // vadd.f32 q2, q4, q10 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff12 // bx r2 HIDDEN _sk_softlight_vfp4 .globl _sk_softlight_vfp4 FUNCTION(_sk_softlight_vfp4) _sk_softlight_vfp4: .long 0xe92d0030 // push {r4, r5} .long 0xed2d8b10 // vpush {d8-d15} .long 0xe24dd028 // sub sp, sp, #40 .long 0xf2624152 // vorr q10, q1, q1 .long 0xe28d3010 // add r3, sp, #16 .long 0xe2802040 // add r2, r0, #64 .long 0xf2c06050 // vmov.i32 q11, #0 .long 0xec834b04 // vstmia r3, {d4-d5} .long 0xf3872f50 // vmov.f32 q1, #-1 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xeccd4b04 // vstmia sp, {d20-d21} .long 0xf4228aef // vld1.64 {d8-d9}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf422aaef // vld1.64 {d10-d11}, [r2 :128] .long 0xf3f90448 // vcgt.f32 q8, q4, #0 .long 0xf26021f0 // vorr q9, q8, q8 .long 0xe2802010 // add r2, r0, #16 .long 0xeecbdaa9 // vdiv.f32 s27, s23, s19 .long 0xee8bda09 // vdiv.f32 s26, s22, s18 .long 0xeecacaa8 // vdiv.f32 s25, s21, s17 .long 0xee8aca08 // vdiv.f32 s24, s20, s16 .long 0xf35c2176 // vbsl q9, q6, q11 .long 0xf3fb65e2 // vrsqrte.f32 q11, q9 .long 0xf242ade2 // vadd.f32 q13, q9, q9 .long 0xf242cdc2 // vadd.f32 q14, q9, q1 .long 0xf3468df6 // vmul.f32 q12, q11, q11 .long 0xf24aadea // vadd.f32 q13, q13, q13 .long 0xf2628ff8 // vrsqrts.f32 q12, q9, q12 .long 0xf3466df8 // vmul.f32 q11, q11, q12 .long 0xf3fb8566 // vrecpe.f32 q12, q11 .long 0xf2466ff8 // vrecps.f32 q11, q11, q12 .long 0xf3486df6 // vmul.f32 q11, q12, q11 .long 0xf34a8dfa // vmul.f32 q12, q13, q13 .long 0xf2666de2 // vsub.f32 q11, q11, q9 .long 0xf24aade8 // vadd.f32 q13, q13, q12 .long 0xf34ccdfa // vmul.f32 q14, q14, q13 .long 0xf2c1af5c // vmov.f32 q13, #7 .long 0xf342edfa // vmul.f32 q15, q9, q13 .long 0xf24ecdec // vadd.f32 q14, q15, q14 .long 0xf24aed4a // vadd.f32 q15, q5, q5 .long 0xf24eedee // vadd.f32 q15, q15, q15 .long 0xf348ee6e // vcge.f32 q15, q4, q15 .long 0xf35ce1f6 // vbsl q15, q14, q11 .long 0xf244cde4 // vadd.f32 q14, q10, q10 .long 0xf22ccdc6 // vsub.f32 q6, q14, q3 .long 0xf34c6d58 // vmul.f32 q11, q6, q4 .long 0xf3466dfe // vmul.f32 q11, q11, q15 .long 0xf34aed56 // vmul.f32 q15, q5, q3 .long 0xf24eede6 // vadd.f32 q15, q15, q11 .long 0xf2c76f50 // vmov.f32 q11, #1 .long 0xf2662de2 // vsub.f32 q9, q11, q9 .long 0xf34c2d72 // vmul.f32 q9, q6, q9 .long 0xf2422dc6 // vadd.f32 q9, q9, q3 .long 0xf30acd72 // vmul.f32 q6, q5, q9 .long 0xf3462e6c // vcge.f32 q9, q3, q14 .long 0xf260c1f0 // vorr q14, q8, q8 .long 0xf35c217e // vbsl q9, q6, q15 .long 0xf422caef // vld1.64 {d12-d13}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xeecdfaa9 // vdiv.f32 s31, s27, s19 .long 0xee8dfa09 // vdiv.f32 s30, s26, s18 .long 0xeecceaa8 // vdiv.f32 s29, s25, s17 .long 0xee8cea08 // vdiv.f32 s28, s24, s16 .long 0xf35ec154 // vbsl q14, q7, q2 .long 0xf2204150 // vorr q2, q0, q0 .long 0xf3fbe5ec // vrsqrte.f32 q15, q14 .long 0xf30eedfe // vmul.f32 q7, q15, q15 .long 0xf22cefde // vrsqrts.f32 q7, q14, q7 .long 0xf34eedde // vmul.f32 q15, q15, q7 .long 0xf3bbe56e // vrecpe.f32 q7, q15 .long 0xf24eefde // vrecps.f32 q15, q15, q7 .long 0xf34eed7e // vmul.f32 q15, q7, q15 .long 0xf20cedec // vadd.f32 q7, q14, q14 .long 0xf26eedec // vsub.f32 q15, q15, q14 .long 0xf20eed4e // vadd.f32 q7, q7, q7 .long 0xf34e4d5e // vmul.f32 q10, q7, q7 .long 0xf24e4d64 // vadd.f32 q10, q7, q10 .long 0xf20cedc2 // vadd.f32 q7, q14, q1 .long 0xf34e4d74 // vmul.f32 q10, q7, q10 .long 0xf30cedfa // vmul.f32 q7, q14, q13 .long 0xf266cdec // vsub.f32 q14, q11, q14 .long 0xf24e4d64 // vadd.f32 q10, q7, q10 .long 0xf20ced4c // vadd.f32 q7, q6, q6 .long 0xf20eed4e // vadd.f32 q7, q7, q7 .long 0xf308ee4e // vcge.f32 q7, q4, q7 .long 0xf314e1fe // vbsl q7, q10, q15 .long 0xf2404d40 // vadd.f32 q10, q0, q0 .long 0xf264edc6 // vsub.f32 q15, q10, q3 .long 0xf34e8dd8 // vmul.f32 q12, q15, q4 .long 0xf34ecdfc // vmul.f32 q14, q15, q14 .long 0xf3488dde // vmul.f32 q12, q12, q7 .long 0xf30ced56 // vmul.f32 q7, q6, q3 .long 0xf24ccdc6 // vadd.f32 q14, q14, q3 .long 0xf24e8d68 // vadd.f32 q12, q7, q12 .long 0xf422eaef // vld1.64 {d14-d15}, [r2 :128] .long 0xe28d2010 // add r2, sp, #16 .long 0xeecf1aa9 // vdiv.f32 s3, s31, s19 .long 0xee8f1a09 // vdiv.f32 s2, s30, s18 .long 0xeece0aa8 // vdiv.f32 s1, s29, s17 .long 0xee8e0a08 // vdiv.f32 s0, s28, s16 .long 0xf34ced7c // vmul.f32 q15, q6, q14 .long 0xf346ce64 // vcge.f32 q14, q3, q10 .long 0xf2c04050 // vmov.i32 q10, #0 .long 0xf3500174 // vbsl q8, q0, q10 .long 0xec920b04 // vldmia r2, {d0-d1} .long 0xf35ec1f8 // vbsl q14, q15, q12 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3fb45e0 // vrsqrte.f32 q10, q8 .long 0xf340adfa // vmul.f32 q13, q8, q13 .long 0xf3448df4 // vmul.f32 q12, q10, q10 .long 0xf2608ff8 // vrsqrts.f32 q12, q8, q12 .long 0xf3444df8 // vmul.f32 q10, q10, q12 .long 0xf3fb8564 // vrecpe.f32 q12, q10 .long 0xf2444ff8 // vrecps.f32 q10, q10, q12 .long 0xf3484df4 // vmul.f32 q10, q12, q10 .long 0xf2408de0 // vadd.f32 q12, q8, q8 .long 0xf2644de0 // vsub.f32 q10, q10, q8 .long 0xf2488de8 // vadd.f32 q12, q12, q12 .long 0xf348edf8 // vmul.f32 q15, q12, q12 .long 0xf2488dee // vadd.f32 q12, q12, q15 .long 0xf240edc2 // vadd.f32 q15, q8, q1 .long 0xec9d2b04 // vldmia sp, {d2-d3} .long 0xf2660de0 // vsub.f32 q8, q11, q8 .long 0xf34e8df8 // vmul.f32 q12, q15, q12 .long 0xf24a8de8 // vadd.f32 q12, q13, q12 .long 0xf24ead4e // vadd.f32 q13, q7, q7 .long 0xf24aadea // vadd.f32 q13, q13, q13 .long 0xf348ae6a // vcge.f32 q13, q4, q13 .long 0xf358a1f4 // vbsl q13, q12, q10 .long 0xf2404d40 // vadd.f32 q10, q0, q0 .long 0xf2648dc6 // vsub.f32 q12, q10, q3 .long 0xf3464e64 // vcge.f32 q10, q3, q10 .long 0xf348edd8 // vmul.f32 q15, q12, q4 .long 0xf3480df0 // vmul.f32 q8, q12, q8 .long 0xf2668dc6 // vsub.f32 q12, q11, q3 .long 0xf2666dc8 // vsub.f32 q11, q11, q4 .long 0xf34eadfa // vmul.f32 q13, q15, q13 .long 0xf34eed56 // vmul.f32 q15, q7, q3 .long 0xf2400dc6 // vadd.f32 q8, q8, q3 .long 0xf3060dd0 // vmul.f32 q0, q11, q0 .long 0xf3062dd2 // vmul.f32 q1, q11, q1 .long 0xf24eadea // vadd.f32 q13, q15, q13 .long 0xf348edde // vmul.f32 q15, q12, q7 .long 0xf3466dd4 // vmul.f32 q11, q11, q2 .long 0xf34e0d70 // vmul.f32 q8, q7, q8 .long 0xf2086c78 // vfma.f32 q3, q4, q12 .long 0xf240ed6e // vadd.f32 q15, q0, q15 .long 0xf3080dda // vmul.f32 q0, q12, q5 .long 0xf35041fa // vbsl q10, q8, q13 .long 0xf20e4de4 // vadd.f32 q2, q15, q10 .long 0xf2022d40 // vadd.f32 q1, q1, q0 .long 0xf3080ddc // vmul.f32 q0, q12, q6 .long 0xf2022d62 // vadd.f32 q1, q1, q9 .long 0xf2406d66 // vadd.f32 q11, q0, q11 .long 0xf2060dec // vadd.f32 q0, q11, q14 .long 0xe28dd028 // add sp, sp, #40 .long 0xecbd8b10 // vpop {d8-d15} .long 0xe8bd0030 // pop {r4, r5} .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} HIDDEN _sk_hue_vfp4 .globl _sk_hue_vfp4 FUNCTION(_sk_hue_vfp4) _sk_hue_vfp4: .long 0xe92d0030 // push {r4, r5} .long 0xed2d8b10 // vpush {d8-d15} .long 0xe24dd068 // sub sp, sp, #104 .long 0xf3440d56 // vmul.f32 q8, q2, q3 .long 0xe28d3050 // add r3, sp, #80 .long 0xf342ed56 // vmul.f32 q15, q1, q3 .long 0xe2802030 // add r2, r0, #48 .long 0xf3404d56 // vmul.f32 q10, q0, q3 .long 0xec834b04 // vstmia r3, {d4-d5} .long 0xe28d3030 // add r3, sp, #48 .long 0xec832b04 // vstmia r3, {d2-d3} .long 0xe28d3040 // add r3, sp, #64 .long 0xf26e2fe0 // vmin.f32 q9, q15, q8 .long 0xec830b04 // vstmia r3, {d0-d1} .long 0xe28d3020 // add r3, sp, #32 .long 0xf24e6fe0 // vmax.f32 q11, q15, q8 .long 0xf4222aef // vld1.64 {d2-d3}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf2642fe2 // vmin.f32 q9, q10, q9 .long 0xf2446fe6 // vmax.f32 q11, q10, q11 .long 0xf2648de2 // vsub.f32 q12, q10, q9 .long 0xf2260de2 // vsub.f32 q0, q11, q9 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf266afc2 // vmin.f32 q13, q11, q1 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xf246cfc2 // vmax.f32 q14, q11, q1 .long 0xec832b04 // vstmia r3, {d2-d3} .long 0xe28d3010 // add r3, sp, #16 .long 0xf26eede2 // vsub.f32 q15, q15, q9 .long 0xecc34b04 // vstmia r3, {d20-d21} .long 0xe28f2f9d // add r2, pc, #628 .long 0xf264afea // vmin.f32 q13, q10, q13 .long 0xe28d3030 // add r3, sp, #48 .long 0xf244cfec // vmax.f32 q14, q10, q14 .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf26cadea // vsub.f32 q13, q14, q13 .long 0xf34acdd6 // vmul.f32 q14, q13, q3 .long 0xf30c4df8 // vmul.f32 q2, q14, q12 .long 0xf3f98540 // vceq.f32 q12, q0, #0 .long 0xf268a1f8 // vorr q13, q12, q12 .long 0xeec59aa1 // vdiv.f32 s19, s11, s3 .long 0xee859a01 // vdiv.f32 s18, s10, s2 .long 0xeec48aa0 // vdiv.f32 s17, s9, s1 .long 0xee848a00 // vdiv.f32 s16, s8, s0 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xf354a158 // vbsl q13, q2, q4 .long 0xf30c8dfe // vmul.f32 q4, q14, q15 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xf268e1f8 // vorr q15, q12, q12 .long 0xeec9baa1 // vdiv.f32 s23, s19, s3 .long 0xee89ba01 // vdiv.f32 s22, s18, s2 .long 0xeec8aaa0 // vdiv.f32 s21, s17, s1 .long 0xee88aa00 // vdiv.f32 s20, s16, s0 .long 0xf4228acf // vld1.64 {d8-d9}, [r2] .long 0xf354e15a // vbsl q15, q2, q5 .long 0xe28f2e22 // add r2, pc, #544 .long 0xf422aacf // vld1.64 {d10-d11}, [r2] .long 0xe28f2f8a // add r2, pc, #552 .long 0xf30ecdd8 // vmul.f32 q6, q15, q4 .long 0xf30aedda // vmul.f32 q7, q13, q5 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xe2802040 // add r2, r0, #64 .long 0xf20ecd4c // vadd.f32 q6, q7, q6 .long 0xf30cedf0 // vmul.f32 q7, q14, q8 .long 0xf346cdd8 // vmul.f32 q14, q11, q4 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xeecf5aa1 // vdiv.f32 s11, s31, s3 .long 0xee8f5a01 // vdiv.f32 s10, s30, s2 .long 0xeece4aa0 // vdiv.f32 s9, s29, s1 .long 0xee8e4a00 // vdiv.f32 s8, s28, s0 .long 0xf3040dda // vmul.f32 q0, q10, q5 .long 0xf35081d4 // vbsl q12, q8, q2 .long 0xf2c04050 // vmov.i32 q10, #0 .long 0xf3480df2 // vmul.f32 q8, q12, q9 .long 0xf240cd6c // vadd.f32 q14, q0, q14 .long 0xf3020d72 // vmul.f32 q0, q1, q9 .long 0xf24c0d60 // vadd.f32 q8, q6, q8 .long 0xf24ccdc0 // vadd.f32 q14, q14, q0 .long 0xf34ccdd6 // vmul.f32 q14, q14, q3 .long 0xf26ccde0 // vsub.f32 q14, q14, q8 .long 0xf20e0dec // vadd.f32 q0, q15, q14 .long 0xf24a0dec // vadd.f32 q8, q13, q14 .long 0xf248cdec // vadd.f32 q14, q12, q14 .long 0xf340ed58 // vmul.f32 q15, q0, q4 .long 0xf340adda // vmul.f32 q13, q8, q5 .long 0xf34c2df2 // vmul.f32 q9, q14, q9 .long 0xf24aadee // vadd.f32 q13, q13, q15 .long 0xf462eaef // vld1.64 {d30-d31}, [r2 :128] .long 0xf2428dea // vadd.f32 q12, q9, q13 .long 0xf2602d68 // vsub.f32 q9, q0, q12 .long 0xf3088df2 // vmul.f32 q4, q12, q9 .long 0xf2602f6c // vmin.f32 q9, q0, q14 .long 0xf2602fe2 // vmin.f32 q9, q8, q9 .long 0xf228ade2 // vsub.f32 q5, q12, q9 .long 0xeec95aab // vdiv.f32 s11, s19, s23 .long 0xee895a0b // vdiv.f32 s10, s18, s22 .long 0xeec84aaa // vdiv.f32 s9, s17, s21 .long 0xee884a0a // vdiv.f32 s8, s16, s20 .long 0xf3b984e2 // vcge.f32 q4, q9, #0 .long 0xf248adc4 // vadd.f32 q13, q12, q2 .long 0xf2284158 // vorr q2, q4, q4 .long 0xf310417a // vbsl q2, q0, q13 .long 0xf34eadd6 // vmul.f32 q13, q15, q3 .long 0xf2000f6c // vmax.f32 q0, q0, q14 .long 0xf224cd68 // vsub.f32 q6, q2, q12 .long 0xf26a2de8 // vsub.f32 q9, q13, q12 .long 0xf200efc0 // vmax.f32 q7, q8, q0 .long 0xf302cddc // vmul.f32 q6, q9, q6 .long 0xf22e0d68 // vsub.f32 q0, q7, q12 .long 0xf32eee6a // vcgt.f32 q7, q7, q13 .long 0xeecd3aa1 // vdiv.f32 s7, s27, s3 .long 0xee8d3a01 // vdiv.f32 s6, s26, s2 .long 0xeecc2aa0 // vdiv.f32 s5, s25, s1 .long 0xee8c2a00 // vdiv.f32 s4, s24, s0 .long 0xf2082dc2 // vadd.f32 q1, q12, q1 .long 0xf22ec15e // vorr q6, q7, q7 .long 0xf312c154 // vbsl q6, q1, q2 .long 0xf20c2f64 // vmax.f32 q1, q6, q10 .long 0xec8d2b04 // vstmia sp, {d2-d3} .long 0xf2202de8 // vsub.f32 q1, q8, q12 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3082dd2 // vmul.f32 q1, q12, q1 .long 0xeec35aab // vdiv.f32 s11, s7, s23 .long 0xee835a0b // vdiv.f32 s10, s6, s22 .long 0xeec24aaa // vdiv.f32 s9, s5, s21 .long 0xee824a0a // vdiv.f32 s8, s4, s20 .long 0xf2082dc4 // vadd.f32 q1, q12, q2 .long 0xf2284158 // vorr q2, q4, q4 .long 0xf31041d2 // vbsl q2, q8, q1 .long 0xf2640d68 // vsub.f32 q8, q2, q12 .long 0xf3022df0 // vmul.f32 q1, q9, q8 .long 0xeec3daa1 // vdiv.f32 s27, s7, s3 .long 0xee83da01 // vdiv.f32 s26, s6, s2 .long 0xeec2caa0 // vdiv.f32 s25, s5, s1 .long 0xee82ca00 // vdiv.f32 s24, s4, s0 .long 0xf2480dcc // vadd.f32 q8, q12, q6 .long 0xf22e215e // vorr q1, q7, q7 .long 0xf280c050 // vmov.i32 q6, #0 .long 0xf31021d4 // vbsl q1, q8, q2 .long 0xf2420f64 // vmax.f32 q8, q1, q10 .long 0xf22c2de8 // vsub.f32 q1, q14, q12 .long 0xf3082dd2 // vmul.f32 q1, q12, q1 .long 0xeec35aab // vdiv.f32 s11, s7, s23 .long 0xee835a0b // vdiv.f32 s10, s6, s22 .long 0xeec24aaa // vdiv.f32 s9, s5, s21 .long 0xee824a0a // vdiv.f32 s8, s4, s20 .long 0xf2082dc4 // vadd.f32 q1, q12, q2 .long 0xf31c81d2 // vbsl q4, q14, q1 .long 0xf268cd68 // vsub.f32 q14, q4, q12 .long 0xf3022dfc // vmul.f32 q1, q9, q14 .long 0xecd3cb04 // vldmia r3, {d28-d29} .long 0xe28d3010 // add r3, sp, #16 .long 0xeec35aa1 // vdiv.f32 s11, s7, s3 .long 0xee835a01 // vdiv.f32 s10, s6, s2 .long 0xeec24aa0 // vdiv.f32 s9, s5, s1 .long 0xee824a00 // vdiv.f32 s8, s4, s0 .long 0xf2482dc4 // vadd.f32 q9, q12, q2 .long 0xf312e1d8 // vbsl q7, q9, q4 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf2628dc6 // vsub.f32 q12, q9, q3 .long 0xf2622dee // vsub.f32 q9, q9, q15 .long 0xf3484df6 // vmul.f32 q10, q12, q11 .long 0xecd36b04 // vldmia r3, {d22-d23} .long 0xe28d3040 // add r3, sp, #64 .long 0xf342cdfc // vmul.f32 q14, q9, q14 .long 0xf3486df6 // vmul.f32 q11, q12, q11 .long 0xf2444dec // vadd.f32 q10, q10, q14 .long 0xecd3cb04 // vldmia r3, {d28-d29} .long 0xe28d3020 // add r3, sp, #32 .long 0xf342cdfc // vmul.f32 q14, q9, q14 .long 0xf2466dec // vadd.f32 q11, q11, q14 .long 0xf24ecdc6 // vadd.f32 q14, q15, q3 .long 0xecd3eb04 // vldmia r3, {d30-d31} .long 0xe28d3050 // add r3, sp, #80 .long 0xf3488dfe // vmul.f32 q12, q12, q15 .long 0xecd3eb04 // vldmia r3, {d30-d31} .long 0xf2060de0 // vadd.f32 q0, q11, q8 .long 0xf3422dfe // vmul.f32 q9, q9, q15 .long 0xecdd0b04 // vldmia sp, {d16-d17} .long 0xf22c6dea // vsub.f32 q3, q14, q13 .long 0xf2042de0 // vadd.f32 q1, q10, q8 .long 0xf2482de2 // vadd.f32 q9, q12, q9 .long 0xf24e8f4c // vmax.f32 q12, q7, q6 .long 0xf2024de8 // vadd.f32 q2, q9, q12 .long 0xe28dd068 // add sp, sp, #104 .long 0xecbd8b10 // vpop {d8-d15} .long 0xe8bd0030 // pop {r4, r5} .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae HIDDEN _sk_saturation_vfp4 .globl _sk_saturation_vfp4 FUNCTION(_sk_saturation_vfp4) _sk_saturation_vfp4: .long 0xe92d0030 // push {r4, r5} .long 0xed2d8b10 // vpush {d8-d15} .long 0xe24dd068 // sub sp, sp, #104 .long 0xe28d3010 // add r3, sp, #16 .long 0xf2604150 // vorr q10, q0, q0 .long 0xe2802030 // add r2, r0, #48 .long 0xec832b04 // vstmia r3, {d2-d3} .long 0xe28d3020 // add r3, sp, #32 .long 0xecc34b04 // vstmia r3, {d20-d21} .long 0xe28d3050 // add r3, sp, #80 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xecc30b04 // vstmia r3, {d16-d17} .long 0xf3400dd6 // vmul.f32 q8, q8, q3 .long 0xe28d3040 // add r3, sp, #64 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf3028dd6 // vmul.f32 q4, q9, q3 .long 0xecc32b04 // vstmia r3, {d18-d19} .long 0xe28d3030 // add r3, sp, #48 .long 0xf4628aef // vld1.64 {d24-d25}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf3482dd6 // vmul.f32 q9, q12, q3 .long 0xf2686f60 // vmin.f32 q11, q4, q8 .long 0xeccd8b04 // vstmia sp, {d24-d25} .long 0xf248cf60 // vmax.f32 q14, q4, q8 .long 0xec834b04 // vstmia r3, {d4-d5} .long 0xe28d3010 // add r3, sp, #16 .long 0xf262afe6 // vmin.f32 q13, q9, q11 .long 0xf2426fec // vmax.f32 q11, q9, q14 .long 0xf242cf44 // vmax.f32 q14, q1, q2 .long 0xf2622dea // vsub.f32 q9, q9, q13 .long 0xf2260dea // vsub.f32 q0, q11, q13 .long 0xf2626f44 // vmin.f32 q11, q1, q2 .long 0xf244cfec // vmax.f32 q14, q10, q14 .long 0xf2288d6a // vsub.f32 q4, q4, q13 .long 0xf2646fe6 // vmin.f32 q11, q10, q11 .long 0xf2c04050 // vmov.i32 q10, #0 .long 0xf2600dea // vsub.f32 q8, q8, q13 .long 0xf26ccde6 // vsub.f32 q14, q14, q11 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xe28f2f97 // add r2, pc, #604 .long 0xf34cedf6 // vmul.f32 q15, q14, q11 .long 0xf30e2df2 // vmul.f32 q1, q15, q9 .long 0xf3f92540 // vceq.f32 q9, q0, #0 .long 0xf30e8dd8 // vmul.f32 q4, q15, q4 .long 0xf262c1f2 // vorr q14, q9, q9 .long 0xeec3baa1 // vdiv.f32 s23, s7, s3 .long 0xee83ba01 // vdiv.f32 s22, s6, s2 .long 0xeec2aaa0 // vdiv.f32 s21, s5, s1 .long 0xee82aa00 // vdiv.f32 s20, s4, s0 .long 0xf354c1da // vbsl q14, q10, q5 .long 0xeec9baa1 // vdiv.f32 s23, s19, s3 .long 0xee89ba01 // vdiv.f32 s22, s18, s2 .long 0xeec8aaa0 // vdiv.f32 s21, s17, s1 .long 0xee88aa00 // vdiv.f32 s20, s16, s0 .long 0xf2c04050 // vmov.i32 q10, #0 .long 0xf22281f2 // vorr q4, q9, q9 .long 0xf31481da // vbsl q4, q10, q5 .long 0xf422aacf // vld1.64 {d10-d11}, [r2] .long 0xe28f2e22 // add r2, pc, #544 .long 0xf422cacf // vld1.64 {d12-d13}, [r2] .long 0xe28f2f8a // add r2, pc, #552 .long 0xf308ed5a // vmul.f32 q7, q4, q5 .long 0xf30c4ddc // vmul.f32 q2, q14, q6 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xf2c04050 // vmov.i32 q10, #0 .long 0xe28d2040 // add r2, sp, #64 .long 0xf2044d4e // vadd.f32 q2, q2, q7 .long 0xf30eedf0 // vmul.f32 q7, q15, q8 .long 0xeecf3aa1 // vdiv.f32 s7, s31, s3 .long 0xee8f3a01 // vdiv.f32 s6, s30, s2 .long 0xeece2aa0 // vdiv.f32 s5, s29, s1 .long 0xee8e2a00 // vdiv.f32 s4, s28, s0 .long 0xf35421d2 // vbsl q9, q10, q1 .long 0xecd24b04 // vldmia r2, {d20-d21} .long 0xe28d2050 // add r2, sp, #80 .long 0xf344edda // vmul.f32 q15, q10, q5 .long 0xf3080ddc // vmul.f32 q0, q12, q6 .long 0xecd24b04 // vldmia r2, {d20-d21} .long 0xf3420dfa // vmul.f32 q8, q9, q13 .long 0xe28d2040 // add r2, sp, #64 .long 0xf2c08050 // vmov.i32 q12, #0 .long 0xf240ed6e // vadd.f32 q15, q0, q15 .long 0xf3040dfa // vmul.f32 q0, q10, q13 .long 0xf2440d60 // vadd.f32 q8, q2, q8 .long 0xf24eedc0 // vadd.f32 q15, q15, q0 .long 0xf34eedd6 // vmul.f32 q15, q15, q3 .long 0xf26eede0 // vsub.f32 q15, q15, q8 .long 0xf24c0dee // vadd.f32 q8, q14, q15 .long 0xf2080d6e // vadd.f32 q0, q4, q15 .long 0xf242edee // vadd.f32 q15, q9, q15 .long 0xf340cddc // vmul.f32 q14, q8, q6 .long 0xf3002d5a // vmul.f32 q1, q0, q5 .long 0xf34e2dfa // vmul.f32 q9, q15, q13 .long 0xf24ccdc2 // vadd.f32 q14, q14, q1 .long 0xf242adec // vadd.f32 q13, q9, q14 .long 0xf2602d6a // vsub.f32 q9, q0, q13 .long 0xf30a8df2 // vmul.f32 q4, q13, q9 .long 0xf2602f6e // vmin.f32 q9, q0, q15 .long 0xf2602fe2 // vmin.f32 q9, q8, q9 .long 0xf22aade2 // vsub.f32 q5, q13, q9 .long 0xeec93aab // vdiv.f32 s7, s19, s23 .long 0xee893a0b // vdiv.f32 s6, s18, s22 .long 0xeec82aaa // vdiv.f32 s5, s17, s21 .long 0xee882a0a // vdiv.f32 s4, s16, s20 .long 0xf3b984e2 // vcge.f32 q4, q9, #0 .long 0xf24acdc2 // vadd.f32 q14, q13, q1 .long 0xf2282158 // vorr q1, q4, q4 .long 0xf310217c // vbsl q1, q0, q14 .long 0xf346cdd6 // vmul.f32 q14, q11, q3 .long 0xf2224d6a // vsub.f32 q2, q1, q13 .long 0xf2000f6e // vmax.f32 q0, q0, q15 .long 0xf26c2dea // vsub.f32 q9, q14, q13 .long 0xf302cdd4 // vmul.f32 q6, q9, q2 .long 0xf2004fc0 // vmax.f32 q2, q8, q0 .long 0xf2240d6a // vsub.f32 q0, q2, q13 .long 0xeecdfaa1 // vdiv.f32 s31, s27, s3 .long 0xee8dfa01 // vdiv.f32 s30, s26, s2 .long 0xeecceaa0 // vdiv.f32 s29, s25, s1 .long 0xee8cea00 // vdiv.f32 s28, s24, s0 .long 0xf20acdce // vadd.f32 q6, q13, q7 .long 0xf324ee6c // vcgt.f32 q7, q2, q14 .long 0xf22e415e // vorr q2, q7, q7 .long 0xf31c4152 // vbsl q2, q6, q1 .long 0xf2202dea // vsub.f32 q1, q8, q13 .long 0xf2444f68 // vmax.f32 q10, q2, q12 .long 0xf30a2dd2 // vmul.f32 q1, q13, q1 .long 0xeec35aab // vdiv.f32 s11, s7, s23 .long 0xee835a0b // vdiv.f32 s10, s6, s22 .long 0xeec24aaa // vdiv.f32 s9, s5, s21 .long 0xee824a0a // vdiv.f32 s8, s4, s20 .long 0xf20a2dc4 // vadd.f32 q1, q13, q2 .long 0xf2284158 // vorr q2, q4, q4 .long 0xf31041d2 // vbsl q2, q8, q1 .long 0xf2640d6a // vsub.f32 q8, q2, q13 .long 0xf3022df0 // vmul.f32 q1, q9, q8 .long 0xeec3daa1 // vdiv.f32 s27, s7, s3 .long 0xee83da01 // vdiv.f32 s26, s6, s2 .long 0xeec2caa0 // vdiv.f32 s25, s5, s1 .long 0xee82ca00 // vdiv.f32 s24, s4, s0 .long 0xf24a0dcc // vadd.f32 q8, q13, q6 .long 0xf22e215e // vorr q1, q7, q7 .long 0xf280c050 // vmov.i32 q6, #0 .long 0xf31021d4 // vbsl q1, q8, q2 .long 0xf2420f68 // vmax.f32 q8, q1, q12 .long 0xecd28b04 // vldmia r2, {d24-d25} .long 0xf22e2dea // vsub.f32 q1, q15, q13 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf30a2dd2 // vmul.f32 q1, q13, q1 .long 0xeec35aab // vdiv.f32 s11, s7, s23 .long 0xee835a0b // vdiv.f32 s10, s6, s22 .long 0xeec24aaa // vdiv.f32 s9, s5, s21 .long 0xee824a0a // vdiv.f32 s8, s4, s20 .long 0xf20a2dc4 // vadd.f32 q1, q13, q2 .long 0xf31e81d2 // vbsl q4, q15, q1 .long 0xf268ed6a // vsub.f32 q15, q4, q13 .long 0xf3022dfe // vmul.f32 q1, q9, q15 .long 0xecd3eb04 // vldmia r3, {d30-d31} .long 0xe28d3020 // add r3, sp, #32 .long 0xeec35aa1 // vdiv.f32 s11, s7, s3 .long 0xee835a01 // vdiv.f32 s10, s6, s2 .long 0xeec24aa0 // vdiv.f32 s9, s5, s1 .long 0xee824a00 // vdiv.f32 s8, s4, s0 .long 0xf24a2dc4 // vadd.f32 q9, q13, q2 .long 0xec930b04 // vldmia r3, {d0-d1} .long 0xe28d3050 // add r3, sp, #80 .long 0xf312e1d8 // vbsl q7, q9, q4 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf262adc6 // vsub.f32 q13, q9, q3 .long 0xf2622de6 // vsub.f32 q9, q9, q11 .long 0xf2466dc6 // vadd.f32 q11, q11, q3 .long 0xf34a8df8 // vmul.f32 q12, q13, q12 .long 0xf342edfe // vmul.f32 q15, q9, q15 .long 0xf3020dd0 // vmul.f32 q0, q9, q0 .long 0xf2266dec // vsub.f32 q3, q11, q14 .long 0xf2488dee // vadd.f32 q12, q12, q15 .long 0xecddeb04 // vldmia sp, {d30-d31} .long 0xf34aedfe // vmul.f32 q15, q13, q15 .long 0xf2082de4 // vadd.f32 q1, q12, q10 .long 0xf24eedc0 // vadd.f32 q15, q15, q0 .long 0xec930b04 // vldmia r3, {d0-d1} .long 0xe28d3030 // add r3, sp, #48 .long 0xf34aadd0 // vmul.f32 q13, q13, q0 .long 0xec930b04 // vldmia r3, {d0-d1} .long 0xf3422dd0 // vmul.f32 q9, q9, q0 .long 0xf20e0de0 // vadd.f32 q0, q15, q8 .long 0xf24a2de2 // vadd.f32 q9, q13, q9 .long 0xf24eaf4c // vmax.f32 q13, q7, q6 .long 0xf2024dea // vadd.f32 q2, q9, q13 .long 0xe28dd068 // add sp, sp, #104 .long 0xecbd8b10 // vpop {d8-d15} .long 0xe8bd0030 // pop {r4, r5} .long 0xe12fff12 // bx r2 .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae HIDDEN _sk_color_vfp4 .globl _sk_color_vfp4 FUNCTION(_sk_color_vfp4) _sk_color_vfp4: .long 0xe92d0030 // push {r4, r5} .long 0xed2d8b10 // vpush {d8-d15} .long 0xe24dd068 // sub sp, sp, #104 .long 0xe28d3030 // add r3, sp, #48 .long 0xe2802040 // add r2, r0, #64 .long 0xec834b04 // vstmia r3, {d4-d5} .long 0xe28d3040 // add r3, sp, #64 .long 0xec832b04 // vstmia r3, {d2-d3} .long 0xe28d3050 // add r3, sp, #80 .long 0xec830b04 // vstmia r3, {d0-d1} .long 0xe28d3020 // add r3, sp, #32 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe28f2e22 // add r2, pc, #544 .long 0xf3440dd2 // vmul.f32 q8, q10, q1 .long 0xf3442dd0 // vmul.f32 q9, q10, q0 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xe28f2e22 // add r2, pc, #544 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe28f2f8a // add r2, pc, #552 .long 0xf3406df8 // vmul.f32 q11, q8, q12 .long 0xf462eacf // vld1.64 {d30-d31}, [r2] .long 0xf342cdfa // vmul.f32 q14, q9, q13 .long 0xe2802020 // add r2, r0, #32 .long 0xf4222aef // vld1.64 {d2-d3}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xec8d2b04 // vstmia sp, {d2-d3} .long 0xf3022d78 // vmul.f32 q1, q1, q12 .long 0xf24c6de6 // vadd.f32 q11, q14, q11 .long 0xf344cdd4 // vmul.f32 q14, q10, q2 .long 0xf30c0dfe // vmul.f32 q0, q14, q15 .long 0xf2406d66 // vadd.f32 q11, q0, q11 .long 0xf4220aef // vld1.64 {d0-d1}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf3008d7a // vmul.f32 q4, q0, q13 .long 0xec830b04 // vstmia r3, {d0-d1} .long 0xe28d3040 // add r3, sp, #64 .long 0xf4220aef // vld1.64 {d0-d1}, [r2 :128] .long 0xe28d2010 // add r2, sp, #16 .long 0xf300ad7e // vmul.f32 q5, q0, q15 .long 0xec820b04 // vstmia r2, {d0-d1} .long 0xf2088d42 // vadd.f32 q4, q4, q1 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2088d4a // vadd.f32 q4, q4, q5 .long 0xf3088d56 // vmul.f32 q4, q4, q3 .long 0xf2288d66 // vsub.f32 q4, q4, q11 .long 0xf2406dc8 // vadd.f32 q11, q8, q4 .long 0xf2420dc8 // vadd.f32 q8, q9, q4 .long 0xf24ccdc8 // vadd.f32 q14, q14, q4 .long 0xf3468df8 // vmul.f32 q12, q11, q12 .long 0xf3402dfa // vmul.f32 q9, q8, q13 .long 0xf2422de8 // vadd.f32 q9, q9, q12 .long 0xf34c8dfe // vmul.f32 q12, q14, q15 .long 0xf2488de2 // vadd.f32 q12, q12, q9 .long 0xf2662de8 // vsub.f32 q9, q11, q12 .long 0xf308adf2 // vmul.f32 q5, q12, q9 .long 0xf2662fec // vmin.f32 q9, q11, q14 .long 0xf2602fe2 // vmin.f32 q9, q8, q9 .long 0xf3f9e4e2 // vcge.f32 q15, q9, #0 .long 0xf2288de2 // vsub.f32 q4, q12, q9 .long 0xeecbdaa9 // vdiv.f32 s27, s23, s19 .long 0xee8bda09 // vdiv.f32 s26, s22, s18 .long 0xeecacaa8 // vdiv.f32 s25, s21, s17 .long 0xee8aca08 // vdiv.f32 s24, s20, s16 .long 0xf248adcc // vadd.f32 q13, q12, q6 .long 0xf22ec1fe // vorr q6, q15, q15 .long 0xf316c1fa // vbsl q6, q11, q13 .long 0xf2466fec // vmax.f32 q11, q11, q14 .long 0xf344add6 // vmul.f32 q13, q10, q3 .long 0xf22cad68 // vsub.f32 q5, q6, q12 .long 0xf2406fe6 // vmax.f32 q11, q8, q11 .long 0xf26a2de8 // vsub.f32 q9, q13, q12 .long 0xf226ede8 // vsub.f32 q7, q11, q12 .long 0xf302adda // vmul.f32 q5, q9, q5 .long 0xf3666eea // vcgt.f32 q11, q11, q13 .long 0xeecb5aaf // vdiv.f32 s11, s23, s31 .long 0xee8b5a0f // vdiv.f32 s10, s22, s30 .long 0xeeca4aae // vdiv.f32 s9, s21, s29 .long 0xee8a4a0e // vdiv.f32 s8, s20, s28 .long 0xf2084dc4 // vadd.f32 q2, q12, q2 .long 0xf226a1f6 // vorr q5, q11, q11 .long 0xf314a15c // vbsl q5, q2, q6 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xf20acf44 // vmax.f32 q6, q5, q2 .long 0xf220ade8 // vsub.f32 q5, q8, q12 .long 0xf308adda // vmul.f32 q5, q12, q5 .long 0xeecb3aa9 // vdiv.f32 s7, s23, s19 .long 0xee8b3a09 // vdiv.f32 s6, s22, s18 .long 0xeeca2aa8 // vdiv.f32 s5, s21, s17 .long 0xee8a2a08 // vdiv.f32 s4, s20, s16 .long 0xf2082dc2 // vadd.f32 q1, q12, q1 .long 0xf22ea1fe // vorr q5, q15, q15 .long 0xf310a1d2 // vbsl q5, q8, q1 .long 0xf26a0d68 // vsub.f32 q8, q5, q12 .long 0xf3022df0 // vmul.f32 q1, q9, q8 .long 0xeec31aaf // vdiv.f32 s3, s7, s31 .long 0xee831a0f // vdiv.f32 s2, s6, s30 .long 0xeec20aae // vdiv.f32 s1, s5, s29 .long 0xee820a0e // vdiv.f32 s0, s4, s28 .long 0xf2480dc0 // vadd.f32 q8, q12, q0 .long 0xf22601f6 // vorr q0, q11, q11 .long 0xf31001da // vbsl q0, q8, q5 .long 0xf2400f44 // vmax.f32 q8, q0, q2 .long 0xf22c0de8 // vsub.f32 q0, q14, q12 .long 0xf3080dd0 // vmul.f32 q0, q12, q0 .long 0xeec13aa9 // vdiv.f32 s7, s3, s19 .long 0xee813a09 // vdiv.f32 s6, s2, s18 .long 0xeec02aa8 // vdiv.f32 s5, s1, s17 .long 0xee802a08 // vdiv.f32 s4, s0, s16 .long 0xf2080dc2 // vadd.f32 q0, q12, q1 .long 0xf35ce1d0 // vbsl q15, q14, q0 .long 0xf26ecde8 // vsub.f32 q14, q15, q12 .long 0xf3020dfc // vmul.f32 q0, q9, q14 .long 0xecddcb04 // vldmia sp, {d28-d29} .long 0xeec13aaf // vdiv.f32 s7, s3, s31 .long 0xee813a0f // vdiv.f32 s6, s2, s30 .long 0xeec02aae // vdiv.f32 s5, s1, s29 .long 0xee802a0e // vdiv.f32 s4, s0, s28 .long 0xf2482dc2 // vadd.f32 q9, q12, q1 .long 0xf35261fe // vbsl q11, q9, q15 .long 0xecd3eb04 // vldmia r3, {d30-d31} .long 0xe28d3020 // add r3, sp, #32 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf2466fc4 // vmax.f32 q11, q11, q2 .long 0xf2628dc6 // vsub.f32 q12, q9, q3 .long 0xf2622de4 // vsub.f32 q9, q9, q10 .long 0xf2444dc6 // vadd.f32 q10, q10, q3 .long 0xf348cdfc // vmul.f32 q14, q12, q14 .long 0xf342edfe // vmul.f32 q15, q9, q15 .long 0xf2246dea // vsub.f32 q3, q10, q13 .long 0xf24ecdec // vadd.f32 q14, q15, q14 .long 0xecd3eb04 // vldmia r3, {d30-d31} .long 0xe28d3050 // add r3, sp, #80 .long 0xf348edfe // vmul.f32 q15, q12, q15 .long 0xec930b04 // vldmia r3, {d0-d1} .long 0xe28d3010 // add r3, sp, #16 .long 0xf3020dd0 // vmul.f32 q0, q9, q0 .long 0xf20c2dcc // vadd.f32 q1, q14, q6 .long 0xf240ed6e // vadd.f32 q15, q0, q15 .long 0xec930b04 // vldmia r3, {d0-d1} .long 0xe28d3030 // add r3, sp, #48 .long 0xf3488dd0 // vmul.f32 q12, q12, q0 .long 0xec930b04 // vldmia r3, {d0-d1} .long 0xf3422dd0 // vmul.f32 q9, q9, q0 .long 0xf20e0de0 // vadd.f32 q0, q15, q8 .long 0xf2422de8 // vadd.f32 q9, q9, q12 .long 0xf2024de6 // vadd.f32 q2, q9, q11 .long 0xe28dd068 // add sp, sp, #104 .long 0xecbd8b10 // vpop {d8-d15} .long 0xe8bd0030 // pop {r4, r5} .long 0xe12fff12 // bx r2 .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae HIDDEN _sk_luminosity_vfp4 .globl _sk_luminosity_vfp4 FUNCTION(_sk_luminosity_vfp4) _sk_luminosity_vfp4: .long 0xe92d0030 // push {r4, r5} .long 0xed2d8b10 // vpush {d8-d15} .long 0xe24dd068 // sub sp, sp, #104 .long 0xe28d3020 // add r3, sp, #32 .long 0xe2802020 // add r2, r0, #32 .long 0xec834b04 // vstmia r3, {d4-d5} .long 0xe28d3010 // add r3, sp, #16 .long 0xec8d2b04 // vstmia sp, {d2-d3} .long 0xec830b04 // vstmia r3, {d0-d1} .long 0xe28d3040 // add r3, sp, #64 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xecc30b04 // vstmia r3, {d16-d17} .long 0xe28d3050 // add r3, sp, #80 .long 0xf3400dd6 // vmul.f32 q8, q8, q3 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xf3442dd6 // vmul.f32 q9, q10, q3 .long 0xecc34b04 // vstmia r3, {d20-d21} .long 0xe28f2f82 // add r2, pc, #520 .long 0xe28d3030 // add r3, sp, #48 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xe28f2f83 // add r2, pc, #524 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe2802030 // add r2, r0, #48 .long 0xf3404df8 // vmul.f32 q10, q8, q12 .long 0xf462caef // vld1.64 {d28-d29}, [r2 :128] .long 0xf3426dfa // vmul.f32 q11, q9, q13 .long 0xf3008d7a // vmul.f32 q4, q0, q13 .long 0xecc3cb04 // vstmia r3, {d28-d29} .long 0xf34ccdd6 // vmul.f32 q14, q14, q3 .long 0xe28f2f7e // add r2, pc, #504 .long 0xe28d3050 // add r3, sp, #80 .long 0xf462eacf // vld1.64 {d30-d31}, [r2] .long 0xe2802040 // add r2, r0, #64 .long 0xf2464de4 // vadd.f32 q10, q11, q10 .long 0xf34c6dfe // vmul.f32 q11, q14, q15 .long 0xf2444de6 // vadd.f32 q10, q10, q11 .long 0xf3426d78 // vmul.f32 q11, q1, q12 .long 0xf2486d66 // vadd.f32 q11, q4, q11 .long 0xf3048d7e // vmul.f32 q4, q2, q15 .long 0xf2068dc8 // vadd.f32 q4, q11, q4 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xe28d2040 // add r2, sp, #64 .long 0xf3088d76 // vmul.f32 q4, q4, q11 .long 0xf2288d64 // vsub.f32 q4, q4, q10 .long 0xf2404dc8 // vadd.f32 q10, q8, q4 .long 0xf2420dc8 // vadd.f32 q8, q9, q4 .long 0xf24ccdc8 // vadd.f32 q14, q14, q4 .long 0xf3448df8 // vmul.f32 q12, q10, q12 .long 0xf3402dfa // vmul.f32 q9, q8, q13 .long 0xf2422de8 // vadd.f32 q9, q9, q12 .long 0xf34c8dfe // vmul.f32 q12, q14, q15 .long 0xf2488de2 // vadd.f32 q12, q12, q9 .long 0xf2642de8 // vsub.f32 q9, q10, q12 .long 0xf308adf2 // vmul.f32 q5, q12, q9 .long 0xf2642fec // vmin.f32 q9, q10, q14 .long 0xf2602fe2 // vmin.f32 q9, q8, q9 .long 0xf3f9e4e2 // vcge.f32 q15, q9, #0 .long 0xf2288de2 // vsub.f32 q4, q12, q9 .long 0xeecbdaa9 // vdiv.f32 s27, s23, s19 .long 0xee8bda09 // vdiv.f32 s26, s22, s18 .long 0xeecacaa8 // vdiv.f32 s25, s21, s17 .long 0xee8aca08 // vdiv.f32 s24, s20, s16 .long 0xf248adcc // vadd.f32 q13, q12, q6 .long 0xf22ec1fe // vorr q6, q15, q15 .long 0xf314c1fa // vbsl q6, q10, q13 .long 0xf2444fec // vmax.f32 q10, q10, q14 .long 0xf346add6 // vmul.f32 q13, q11, q3 .long 0xf22cad68 // vsub.f32 q5, q6, q12 .long 0xf2404fe4 // vmax.f32 q10, q8, q10 .long 0xf26a2de8 // vsub.f32 q9, q13, q12 .long 0xf224ede8 // vsub.f32 q7, q10, q12 .long 0xf302adda // vmul.f32 q5, q9, q5 .long 0xf3644eea // vcgt.f32 q10, q10, q13 .long 0xeecb5aaf // vdiv.f32 s11, s23, s31 .long 0xee8b5a0f // vdiv.f32 s10, s22, s30 .long 0xeeca4aae // vdiv.f32 s9, s21, s29 .long 0xee8a4a0e // vdiv.f32 s8, s20, s28 .long 0xf2084dc4 // vadd.f32 q2, q12, q2 .long 0xf224a1f4 // vorr q5, q10, q10 .long 0xf314a15c // vbsl q5, q2, q6 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xf20acf44 // vmax.f32 q6, q5, q2 .long 0xf220ade8 // vsub.f32 q5, q8, q12 .long 0xf308adda // vmul.f32 q5, q12, q5 .long 0xeecb3aa9 // vdiv.f32 s7, s23, s19 .long 0xee8b3a09 // vdiv.f32 s6, s22, s18 .long 0xeeca2aa8 // vdiv.f32 s5, s21, s17 .long 0xee8a2a08 // vdiv.f32 s4, s20, s16 .long 0xf2082dc2 // vadd.f32 q1, q12, q1 .long 0xf22ea1fe // vorr q5, q15, q15 .long 0xf310a1d2 // vbsl q5, q8, q1 .long 0xf26a0d68 // vsub.f32 q8, q5, q12 .long 0xf3022df0 // vmul.f32 q1, q9, q8 .long 0xeec31aaf // vdiv.f32 s3, s7, s31 .long 0xee831a0f // vdiv.f32 s2, s6, s30 .long 0xeec20aae // vdiv.f32 s1, s5, s29 .long 0xee820a0e // vdiv.f32 s0, s4, s28 .long 0xf2480dc0 // vadd.f32 q8, q12, q0 .long 0xf22401f4 // vorr q0, q10, q10 .long 0xf31001da // vbsl q0, q8, q5 .long 0xf2400f44 // vmax.f32 q8, q0, q2 .long 0xf22c0de8 // vsub.f32 q0, q14, q12 .long 0xf3080dd0 // vmul.f32 q0, q12, q0 .long 0xeec13aa9 // vdiv.f32 s7, s3, s19 .long 0xee813a09 // vdiv.f32 s6, s2, s18 .long 0xeec02aa8 // vdiv.f32 s5, s1, s17 .long 0xee802a08 // vdiv.f32 s4, s0, s16 .long 0xf2080dc2 // vadd.f32 q0, q12, q1 .long 0xf35ce1d0 // vbsl q15, q14, q0 .long 0xf26ecde8 // vsub.f32 q14, q15, q12 .long 0xf3020dfc // vmul.f32 q0, q9, q14 .long 0xecd2cb04 // vldmia r2, {d28-d29} .long 0xe4912004 // ldr r2, [r1], #4 .long 0xeec13aaf // vdiv.f32 s7, s3, s31 .long 0xee813a0f // vdiv.f32 s6, s2, s30 .long 0xeec02aae // vdiv.f32 s5, s1, s29 .long 0xee802a0e // vdiv.f32 s4, s0, s28 .long 0xf2482dc2 // vadd.f32 q9, q12, q1 .long 0xf35241fe // vbsl q10, q9, q15 .long 0xecddeb04 // vldmia sp, {d30-d31} .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf2444fc4 // vmax.f32 q10, q10, q2 .long 0xf2628dc6 // vsub.f32 q12, q9, q3 .long 0xf2622de6 // vsub.f32 q9, q9, q11 .long 0xf2466dc6 // vadd.f32 q11, q11, q3 .long 0xf348cdfc // vmul.f32 q14, q12, q14 .long 0xf342edfe // vmul.f32 q15, q9, q15 .long 0xf2266dea // vsub.f32 q3, q11, q13 .long 0xf24ccdee // vadd.f32 q14, q14, q15 .long 0xecd3eb04 // vldmia r3, {d30-d31} .long 0xe28d3010 // add r3, sp, #16 .long 0xf348edfe // vmul.f32 q15, q12, q15 .long 0xec930b04 // vldmia r3, {d0-d1} .long 0xe28d3030 // add r3, sp, #48 .long 0xf3020dd0 // vmul.f32 q0, q9, q0 .long 0xf20c2dcc // vadd.f32 q1, q14, q6 .long 0xf24eedc0 // vadd.f32 q15, q15, q0 .long 0xec930b04 // vldmia r3, {d0-d1} .long 0xe28d3020 // add r3, sp, #32 .long 0xf3488dd0 // vmul.f32 q12, q12, q0 .long 0xec930b04 // vldmia r3, {d0-d1} .long 0xf3422dd0 // vmul.f32 q9, q9, q0 .long 0xf20e0de0 // vadd.f32 q0, q15, q8 .long 0xf2482de2 // vadd.f32 q9, q12, q9 .long 0xf2024de4 // vadd.f32 q2, q9, q10 .long 0xe28dd068 // add sp, sp, #104 .long 0xecbd8b10 // vpop {d8-d15} .long 0xe8bd0030 // pop {r4, r5} .long 0xe12fff12 // bx r2 .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3f170a3d // .word 0x3f170a3d .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae .long 0x3de147ae // .word 0x3de147ae HIDDEN _sk_srcover_rgba_8888_vfp4 .globl _sk_srcover_rgba_8888_vfp4 FUNCTION(_sk_srcover_rgba_8888_vfp4) _sk_srcover_rgba_8888_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xed2d8b08 // vpush {d8-d11} .long 0xe5912000 // ldr r2, [r1] .long 0xe280c040 // add ip, r0, #64 .long 0xe5905004 // ldr r5, [r0, #4] .long 0xe280e030 // add lr, r0, #48 .long 0xe5906000 // ldr r6, [r0] .long 0xe5924000 // ldr r4, [r2] .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe5903008 // ldr r3, [r0, #8] .long 0xe0020592 // mul r2, r2, r5 .long 0xe2805010 // add r5, r0, #16 .long 0xe3530000 // cmp r3, #0 .long 0xe0842102 // add r2, r4, r2, lsl #2 .long 0xe2804020 // add r4, r0, #32 .long 0xe0822106 // add r2, r2, r6, lsl #2 .long 0x1a000032 // bne 1ba0 .long 0xf4620a8f // vld1.32 {d16-d17}, [r2] .long 0xf3c7405f // vmov.i32 q10, #255 .long 0xe28f6f51 // add r6, pc, #324 .long 0xf3f02070 // vshr.u32 q9, q8, #16 .long 0xf4668acf // vld1.64 {d24-d25}, [r6] .long 0xf2c76f50 // vmov.f32 q11, #1 .long 0xe3530000 // cmp r3, #0 .long 0xf240e1f4 // vand q15, q8, q10 .long 0xf3a88070 // vshr.u32 q4, q8, #24 .long 0xf3f80070 // vshr.u32 q8, q8, #8 .long 0xf2666dc6 // vsub.f32 q11, q11, q3 .long 0xf24001f4 // vand q8, q8, q10 .long 0xf3bb8648 // vcvt.f32.s32 q4, q4 .long 0xf3066d78 // vmul.f32 q3, q3, q12 .long 0xf24221f4 // vand q9, q9, q10 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3022d78 // vmul.f32 q1, q1, q12 .long 0xf3fbe66e // vcvt.f32.s32 q15, q15 .long 0xf3000d78 // vmul.f32 q0, q0, q12 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf3044d78 // vmul.f32 q2, q2, q12 .long 0xf2086c76 // vfma.f32 q3, q4, q11 .long 0xf445eaef // vst1.64 {d30-d31}, [r5 :128] .long 0xf2002cf6 // vfma.f32 q1, q8, q11 .long 0xf4440aef // vst1.64 {d16-d17}, [r4 :128] .long 0xf20e0cf6 // vfma.f32 q0, q15, q11 .long 0xf44e2aef // vst1.64 {d18-d19}, [lr :128] .long 0xf2024cf6 // vfma.f32 q2, q9, q11 .long 0xf40c8aef // vst1.64 {d8-d9}, [ip :128] .long 0xf2c3a65f // vmov.i32 q13, #1056964608 .long 0xf206ad6a // vadd.f32 q5, q3, q13 .long 0xf2424d6a // vadd.f32 q10, q1, q13 .long 0xf240ed6a // vadd.f32 q15, q0, q13 .long 0xf244cd6a // vadd.f32 q14, q2, q13 .long 0xf3bba7ca // vcvt.u32.f32 q5, q5 .long 0xf3fb47e4 // vcvt.u32.f32 q10, q10 .long 0xf3fbe7ee // vcvt.u32.f32 q15, q15 .long 0xf3fbc7ec // vcvt.u32.f32 q14, q14 .long 0xf2b8a55a // vshl.s32 q5, q5, #24 .long 0xf2e84574 // vshl.s32 q10, q10, #8 .long 0xf26ee1da // vorr q15, q15, q5 .long 0xf2f0c57c // vshl.s32 q14, q14, #16 .long 0xf26e01f4 // vorr q8, q15, q10 .long 0xf26001fc // vorr q8, q8, q14 .long 0x1a000015 // bne 1be0 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xecbd8b08 // vpop {d8-d11} .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff12 // bx r2 .long 0xe2036003 // and r6, r3, #3 .long 0xe3560001 // cmp r6, #1 .long 0x0a000017 // beq 1c0c .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe3560002 // cmp r6, #2 .long 0x0a000005 // beq 1bd0 .long 0xe3560003 // cmp r6, #3 .long 0x1affffc5 // bne 1ad8 .long 0xe3a06000 // mov r6, #0 .long 0xeea06b90 // vdup.32 q8, r6 .long 0xe2826008 // add r6, r2, #8 .long 0xf4e6183f // vld1.32 {d17[0]}, [r6 :32] .long 0xedd22b00 // vldr d18, [r2] .long 0xf2f008e2 // vext.8 q8, q8, q9, #8 .long 0xf2f008e0 // vext.8 q8, q8, q8, #8 .long 0xeaffffbd // b 1ad8 .long 0xe2033003 // and r3, r3, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a00000b // beq 1c1c .long 0xe3530002 // cmp r3, #2 .long 0x0a000003 // beq 1c04 .long 0xe3530003 // cmp r3, #3 .long 0x1affffe3 // bne 1b8c .long 0xe2823008 // add r3, r2, #8 .long 0xf4c3183f // vst1.32 {d17[0]}, [r3 :32] .long 0xedc20b00 // vstr d16, [r2] .long 0xeaffffdf // b 1b8c .long 0xe3a06000 // mov r6, #0 .long 0xeea06b90 // vdup.32 q8, r6 .long 0xf4e2083f // vld1.32 {d16[0]}, [r2 :32] .long 0xeaffffae // b 1ad8 .long 0xf4c2083f // vst1.32 {d16[0]}, [r2 :32] .long 0xeaffffd9 // b 1b8c .long 0xe320f000 // nop {0} .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 HIDDEN _sk_clamp_0_vfp4 .globl _sk_clamp_0_vfp4 FUNCTION(_sk_clamp_0_vfp4) _sk_clamp_0_vfp4: .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2000f60 // vmax.f32 q0, q0, q8 .long 0xf2022f60 // vmax.f32 q1, q1, q8 .long 0xf2044f60 // vmax.f32 q2, q2, q8 .long 0xf2066f60 // vmax.f32 q3, q3, q8 .long 0xe12fff12 // bx r2 HIDDEN _sk_clamp_1_vfp4 .globl _sk_clamp_1_vfp4 FUNCTION(_sk_clamp_1_vfp4) _sk_clamp_1_vfp4: .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2200f60 // vmin.f32 q0, q0, q8 .long 0xf2222f60 // vmin.f32 q1, q1, q8 .long 0xf2244f60 // vmin.f32 q2, q2, q8 .long 0xf2266f60 // vmin.f32 q3, q3, q8 .long 0xe12fff12 // bx r2 HIDDEN _sk_clamp_a_vfp4 .globl _sk_clamp_a_vfp4 FUNCTION(_sk_clamp_a_vfp4) _sk_clamp_a_vfp4: .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2266f60 // vmin.f32 q3, q3, q8 .long 0xf2200f46 // vmin.f32 q0, q0, q3 .long 0xf2222f46 // vmin.f32 q1, q1, q3 .long 0xf2244f46 // vmin.f32 q2, q2, q3 .long 0xe12fff12 // bx r2 HIDDEN _sk_clamp_a_dst_vfp4 .globl _sk_clamp_a_dst_vfp4 FUNCTION(_sk_clamp_a_dst_vfp4) _sk_clamp_a_dst_vfp4: .long 0xe2802040 // add r2, r0, #64 .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2620fe0 // vmin.f32 q8, q9, q8 .long 0xf4420aef // vst1.64 {d16-d17}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2622fe0 // vmin.f32 q9, q9, q8 .long 0xf4422aef // vst1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2622fe0 // vmin.f32 q9, q9, q8 .long 0xf4422aef // vst1.64 {d18-d19}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2620fe0 // vmin.f32 q8, q9, q8 .long 0xf4420aef // vst1.64 {d16-d17}, [r2 :128] .long 0xe4912004 // ldr r2, [r1], #4 .long 0xe12fff12 // bx r2 HIDDEN _sk_set_rgb_vfp4 .globl _sk_set_rgb_vfp4 FUNCTION(_sk_set_rgb_vfp4) _sk_set_rgb_vfp4: .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xe2832008 // add r2, r3, #8 .long 0xf4a30cbd // vld1.32 {d0[]-d1[]}, [r3 :32]! .long 0xf4a24cbf // vld1.32 {d4[]-d5[]}, [r2 :32] .long 0xf4a32cbf // vld1.32 {d2[]-d3[]}, [r3 :32] .long 0xe12fff1c // bx ip HIDDEN _sk_swap_rb_vfp4 .globl _sk_swap_rb_vfp4 FUNCTION(_sk_swap_rb_vfp4) _sk_swap_rb_vfp4: .long 0xf2600150 // vorr q8, q0, q0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2240154 // vorr q0, q2, q2 .long 0xf22041f0 // vorr q2, q8, q8 .long 0xe12fff12 // bx r2 HIDDEN _sk_invert_vfp4 .globl _sk_invert_vfp4 FUNCTION(_sk_invert_vfp4) _sk_invert_vfp4: .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2200dc0 // vsub.f32 q0, q8, q0 .long 0xf2202dc2 // vsub.f32 q1, q8, q1 .long 0xf2204dc4 // vsub.f32 q2, q8, q2 .long 0xf2206dc6 // vsub.f32 q3, q8, q3 .long 0xe12fff12 // bx r2 HIDDEN _sk_move_src_dst_vfp4 .globl _sk_move_src_dst_vfp4 FUNCTION(_sk_move_src_dst_vfp4) _sk_move_src_dst_vfp4: .long 0xe2802010 // add r2, r0, #16 .long 0xf4020aef // vst1.64 {d0-d1}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf4022aef // vst1.64 {d2-d3}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf4024aef // vst1.64 {d4-d5}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf4026aef // vst1.64 {d6-d7}, [r2 :128] .long 0xe4912004 // ldr r2, [r1], #4 .long 0xe12fff12 // bx r2 HIDDEN _sk_move_dst_src_vfp4 .globl _sk_move_dst_src_vfp4 FUNCTION(_sk_move_dst_src_vfp4) _sk_move_dst_src_vfp4: .long 0xe2802040 // add r2, r0, #64 .long 0xe2803010 // add r3, r0, #16 .long 0xf4226aef // vld1.64 {d6-d7}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf4224aef // vld1.64 {d4-d5}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf4222aef // vld1.64 {d2-d3}, [r2 :128] .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf4230aef // vld1.64 {d0-d1}, [r3 :128] .long 0xe12fff12 // bx r2 HIDDEN _sk_premul_vfp4 .globl _sk_premul_vfp4 FUNCTION(_sk_premul_vfp4) _sk_premul_vfp4: .long 0xf3000d56 // vmul.f32 q0, q0, q3 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3022d56 // vmul.f32 q1, q1, q3 .long 0xf3044d56 // vmul.f32 q2, q2, q3 .long 0xe12fff12 // bx r2 HIDDEN _sk_premul_dst_vfp4 .globl _sk_premul_dst_vfp4 FUNCTION(_sk_premul_dst_vfp4) _sk_premul_dst_vfp4: .long 0xe2802040 // add r2, r0, #64 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf3422df0 // vmul.f32 q9, q9, q8 .long 0xf4422aef // vst1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf3402df2 // vmul.f32 q9, q8, q9 .long 0xf4422aef // vst1.64 {d18-d19}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf3420df0 // vmul.f32 q8, q9, q8 .long 0xf4420aef // vst1.64 {d16-d17}, [r2 :128] .long 0xe4912004 // ldr r2, [r1], #4 .long 0xe12fff12 // bx r2 HIDDEN _sk_unpremul_vfp4 .globl _sk_unpremul_vfp4 FUNCTION(_sk_unpremul_vfp4) _sk_unpremul_vfp4: .long 0xed2dab04 // vpush {d10-d11} .long 0xed2d8b02 // vpush {d8} .long 0xeeb78a00 // vmov.f32 s16, #112 .long 0xf3f92546 // vceq.f32 q9, q3, #0 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xeec8ba27 // vdiv.f32 s23, s16, s15 .long 0xee88ba07 // vdiv.f32 s22, s16, s14 .long 0xeec8aa26 // vdiv.f32 s21, s16, s13 .long 0xee88aa06 // vdiv.f32 s20, s16, s12 .long 0xf35021da // vbsl q9, q8, q5 .long 0xf3020dd0 // vmul.f32 q0, q9, q0 .long 0xf3022dd2 // vmul.f32 q1, q9, q1 .long 0xf3024dd4 // vmul.f32 q2, q9, q2 .long 0xecbd8b02 // vpop {d8} .long 0xecbdab04 // vpop {d10-d11} .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} HIDDEN _sk_from_srgb_vfp4 .globl _sk_from_srgb_vfp4 FUNCTION(_sk_from_srgb_vfp4) _sk_from_srgb_vfp4: .long 0xed2d8b04 // vpush {d8-d9} .long 0xe28f2094 // add r2, pc, #148 .long 0xf3408d50 // vmul.f32 q12, q0, q0 .long 0xf4620acf // vld1.64 {d16-d17}, [r2] .long 0xe28f2098 // add r2, pc, #152 .long 0xf342ad52 // vmul.f32 q13, q1, q1 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xe28f209c // add r2, pc, #156 .long 0xf26621f6 // vorr q9, q11, q11 .long 0xf26641f6 // vorr q10, q11, q11 .long 0xf462cacf // vld1.64 {d28-d29}, [r2] .long 0xf2402c70 // vfma.f32 q9, q0, q8 .long 0xe28f2098 // add r2, pc, #152 .long 0xf2424c70 // vfma.f32 q10, q1, q8 .long 0xf26ce1fc // vorr q15, q14, q14 .long 0xf2446c70 // vfma.f32 q11, q2, q8 .long 0xf22c81fc // vorr q4, q14, q14 .long 0xf248ecf2 // vfma.f32 q15, q12, q9 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xe28f208c // add r2, pc, #140 .long 0xf20a8cf4 // vfma.f32 q4, q13, q10 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xf3680ec2 // vcgt.f32 q8, q12, q1 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3022d7a // vmul.f32 q1, q1, q13 .long 0xf3682ec4 // vcgt.f32 q9, q12, q2 .long 0xf3684ec0 // vcgt.f32 q10, q12, q0 .long 0xf3448d7a // vmul.f32 q12, q2, q13 .long 0xf340ad7a // vmul.f32 q13, q0, q13 .long 0xf3040d54 // vmul.f32 q0, q2, q2 .long 0xf3520158 // vbsl q8, q1, q4 .long 0xf35a41fe // vbsl q10, q13, q15 .long 0xf240cc76 // vfma.f32 q14, q0, q11 .long 0xf35821fc // vbsl q9, q12, q14 .long 0xf22401f4 // vorr q0, q10, q10 .long 0xf22021f0 // vorr q1, q8, q8 .long 0xf22241f2 // vorr q2, q9, q9 .long 0xecbd8b04 // vpop {d8-d9} .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3f328f5c // .word 0x3f328f5c .long 0x3f328f5c // .word 0x3f328f5c .long 0x3f328f5c // .word 0x3f328f5c .long 0x3f328f5c // .word 0x3f328f5c .long 0x3b23d70a // .word 0x3b23d70a .long 0x3b23d70a // .word 0x3b23d70a .long 0x3b23d70a // .word 0x3b23d70a .long 0x3b23d70a // .word 0x3b23d70a .long 0x3d6147ae // .word 0x3d6147ae .long 0x3d6147ae // .word 0x3d6147ae .long 0x3d6147ae // .word 0x3d6147ae .long 0x3d6147ae // .word 0x3d6147ae .long 0x3d9e8391 // .word 0x3d9e8391 .long 0x3d9e8391 // .word 0x3d9e8391 .long 0x3d9e8391 // .word 0x3d9e8391 .long 0x3d9e8391 // .word 0x3d9e8391 HIDDEN _sk_from_srgb_dst_vfp4 .globl _sk_from_srgb_dst_vfp4 FUNCTION(_sk_from_srgb_dst_vfp4) _sk_from_srgb_dst_vfp4: .long 0xed2d8b08 // vpush {d8-d11} .long 0xe28f20ac // add r2, pc, #172 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xe2802010 // add r2, r0, #16 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe28f30ac // add r3, pc, #172 .long 0xf4630acf // vld1.64 {d16-d17}, [r3] .long 0xe28f30b4 // add r3, pc, #180 .long 0xf26061f0 // vorr q11, q8, q8 .long 0xf2446cf2 // vfma.f32 q11, q10, q9 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xe28f30b4 // add r3, pc, #180 .long 0xf463cacf // vld1.64 {d28-d29}, [r3] .long 0xf344adf4 // vmul.f32 q13, q10, q10 .long 0xf368eee4 // vcgt.f32 q15, q12, q10 .long 0xe28f30b4 // add r3, pc, #180 .long 0xf4238acf // vld1.64 {d8-d9}, [r3] .long 0xf3444dfc // vmul.f32 q10, q10, q14 .long 0xf228a158 // vorr q5, q4, q4 .long 0xf20aacf6 // vfma.f32 q5, q13, q11 .long 0xf354e1da // vbsl q15, q10, q5 .long 0xf26061f0 // vorr q11, q8, q8 .long 0xf228a158 // vorr q5, q4, q4 .long 0xf442eaef // vst1.64 {d30-d31}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xf2446cf2 // vfma.f32 q11, q10, q9 .long 0xf344adf4 // vmul.f32 q13, q10, q10 .long 0xf368eee4 // vcgt.f32 q15, q12, q10 .long 0xf3444dfc // vmul.f32 q10, q10, q14 .long 0xf20aacf6 // vfma.f32 q5, q13, q11 .long 0xf354e1da // vbsl q15, q10, q5 .long 0xf442eaef // vst1.64 {d30-d31}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xf2440cf2 // vfma.f32 q8, q10, q9 .long 0xf3442df4 // vmul.f32 q9, q10, q10 .long 0xf3686ee4 // vcgt.f32 q11, q12, q10 .long 0xf3444dfc // vmul.f32 q10, q10, q14 .long 0xf2028cf0 // vfma.f32 q4, q9, q8 .long 0xf35461d8 // vbsl q11, q10, q4 .long 0xf4426aef // vst1.64 {d22-d23}, [r2 :128] .long 0xe4912004 // ldr r2, [r1], #4 .long 0xecbd8b08 // vpop {d8-d11} .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3e99999a // .word 0x3e99999a .long 0x3f328f5c // .word 0x3f328f5c .long 0x3f328f5c // .word 0x3f328f5c .long 0x3f328f5c // .word 0x3f328f5c .long 0x3f328f5c // .word 0x3f328f5c .long 0x3d6147ae // .word 0x3d6147ae .long 0x3d6147ae // .word 0x3d6147ae .long 0x3d6147ae // .word 0x3d6147ae .long 0x3d6147ae // .word 0x3d6147ae .long 0x3d9e8391 // .word 0x3d9e8391 .long 0x3d9e8391 // .word 0x3d9e8391 .long 0x3d9e8391 // .word 0x3d9e8391 .long 0x3d9e8391 // .word 0x3d9e8391 .long 0x3b23d70a // .word 0x3b23d70a .long 0x3b23d70a // .word 0x3b23d70a .long 0x3b23d70a // .word 0x3b23d70a .long 0x3b23d70a // .word 0x3b23d70a HIDDEN _sk_to_srgb_vfp4 .globl _sk_to_srgb_vfp4 FUNCTION(_sk_to_srgb_vfp4) _sk_to_srgb_vfp4: .long 0xed2d8b08 // vpush {d8-d11} .long 0xf3fb05c0 // vrsqrte.f32 q8, q0 .long 0xe28f20f8 // add r2, pc, #248 .long 0xf3402df0 // vmul.f32 q9, q8, q8 .long 0xf2602f72 // vrsqrts.f32 q9, q0, q9 .long 0xf3400df2 // vmul.f32 q8, q8, q9 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xe28f20f4 // add r2, pc, #244 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xe28f20fc // add r2, pc, #252 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe28f2f41 // add r2, pc, #260 .long 0xf26ac1fa // vorr q14, q13, q13 .long 0xf240ccf8 // vfma.f32 q14, q8, q12 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xe28f2f41 // add r2, pc, #260 .long 0xf22681f6 // vorr q4, q11, q11 .long 0xf2404de2 // vadd.f32 q10, q8, q9 .long 0xf3fbe564 // vrecpe.f32 q15, q10 .long 0xf2008cfc // vfma.f32 q4, q8, q14 .long 0xf3fb05c2 // vrsqrte.f32 q8, q1 .long 0xf2444ffe // vrecps.f32 q10, q10, q15 .long 0xf340cdf0 // vmul.f32 q14, q8, q8 .long 0xf262cf7c // vrsqrts.f32 q14, q1, q14 .long 0xf34e4df4 // vmul.f32 q10, q15, q10 .long 0xf266e1f6 // vorr q15, q11, q11 .long 0xf3400dfc // vmul.f32 q8, q8, q14 .long 0xf26ac1fa // vorr q14, q13, q13 .long 0xf240ccf8 // vfma.f32 q14, q8, q12 .long 0xf240ecfc // vfma.f32 q15, q8, q14 .long 0xf2400de2 // vadd.f32 q8, q8, q9 .long 0xf3fbc560 // vrecpe.f32 q14, q8 .long 0xf2400ffc // vrecps.f32 q8, q8, q14 .long 0xf34c0df0 // vmul.f32 q8, q14, q8 .long 0xf3fbc5c4 // vrsqrte.f32 q14, q2 .long 0xf30cadfc // vmul.f32 q5, q14, q14 .long 0xf224af5a // vrsqrts.f32 q5, q2, q5 .long 0xf34ccdda // vmul.f32 q14, q14, q5 .long 0xf24c2de2 // vadd.f32 q9, q14, q9 .long 0xf24cacf8 // vfma.f32 q13, q14, q12 .long 0xf3fb8562 // vrecpe.f32 q12, q9 .long 0xf2422ff8 // vrecps.f32 q9, q9, q12 .long 0xf24c6cfa // vfma.f32 q11, q14, q13 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe28f20a0 // add r2, pc, #160 .long 0xf34ecdf0 // vmul.f32 q14, q15, q8 .long 0xf348ed74 // vmul.f32 q15, q4, q10 .long 0xf4228acf // vld1.64 {d8-d9}, [r2] .long 0xf36a0ec4 // vcgt.f32 q8, q13, q2 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3044d58 // vmul.f32 q2, q2, q4 .long 0xf36a4ec0 // vcgt.f32 q10, q13, q0 .long 0xf3488df2 // vmul.f32 q12, q12, q9 .long 0xf36a2ec2 // vcgt.f32 q9, q13, q1 .long 0xf3022d58 // vmul.f32 q1, q1, q4 .long 0xf340ad58 // vmul.f32 q13, q0, q4 .long 0xf3466df8 // vmul.f32 q11, q11, q12 .long 0xf3540176 // vbsl q8, q2, q11 .long 0xf352217c // vbsl q9, q1, q14 .long 0xf35a41fe // vbsl q10, q13, q15 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xf22401f4 // vorr q0, q10, q10 .long 0xf22041f0 // vorr q2, q8, q8 .long 0xecbd8b08 // vpop {d8-d11} .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3e10c64c // .word 0x3e10c64c .long 0x3e10c64c // .word 0x3e10c64c .long 0x3e10c64c // .word 0x3e10c64c .long 0x3e10c64c // .word 0x3e10c64c .long 0xbb20d739 // .word 0xbb20d739 .long 0xbb20d739 // .word 0xbb20d739 .long 0xbb20d739 // .word 0xbb20d739 .long 0xbb20d739 // .word 0xbb20d739 .long 0x3c629fba // .word 0x3c629fba .long 0x3c629fba // .word 0x3c629fba .long 0x3c629fba // .word 0x3c629fba .long 0x3c629fba // .word 0x3c629fba .long 0x3f90a3d7 // .word 0x3f90a3d7 .long 0x3f90a3d7 // .word 0x3f90a3d7 .long 0x3f90a3d7 // .word 0x3f90a3d7 .long 0x3f90a3d7 // .word 0x3f90a3d7 .long 0x3b98b1a8 // .word 0x3b98b1a8 .long 0x3b98b1a8 // .word 0x3b98b1a8 .long 0x3b98b1a8 // .word 0x3b98b1a8 .long 0x3b98b1a8 // .word 0x3b98b1a8 .long 0x414eb852 // .word 0x414eb852 .long 0x414eb852 // .word 0x414eb852 .long 0x414eb852 // .word 0x414eb852 .long 0x414eb852 // .word 0x414eb852 HIDDEN _sk_rgb_to_hsl_vfp4 .globl _sk_rgb_to_hsl_vfp4 FUNCTION(_sk_rgb_to_hsl_vfp4) _sk_rgb_to_hsl_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xf2600f42 // vmin.f32 q8, q0, q1 .long 0xe28f20c8 // add r2, pc, #200 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe28f20d0 // add r2, pc, #208 .long 0xf2402f42 // vmax.f32 q9, q0, q1 .long 0xeeb7ca00 // vmov.f32 s24, #112 .long 0xf2600fc4 // vmin.f32 q8, q8, q2 .long 0xf2422fc4 // vmax.f32 q9, q9, q2 .long 0xf2624d44 // vsub.f32 q10, q1, q2 .long 0xf3648e42 // vcgt.f32 q12, q2, q1 .long 0xf2228de0 // vsub.f32 q4, q9, q8 .long 0xf260cd42 // vsub.f32 q14, q0, q1 .long 0xf2c1ef50 // vmov.f32 q15, #4 .long 0xeeccba29 // vdiv.f32 s23, s24, s19 .long 0xee8cba09 // vdiv.f32 s22, s24, s18 .long 0xeeccaa28 // vdiv.f32 s21, s24, s17 .long 0xee8caa08 // vdiv.f32 s20, s24, s16 .long 0xf3446dda // vmul.f32 q11, q10, q5 .long 0xf2c04050 // vmov.i32 q10, #0 .long 0xf35a81f4 // vbsl q12, q13, q10 .long 0xf34ccdda // vmul.f32 q14, q14, q5 .long 0xf2486de6 // vadd.f32 q11, q12, q11 .long 0xf2648d40 // vsub.f32 q12, q2, q0 .long 0xf24ccdee // vadd.f32 q14, q14, q15 .long 0xf242ede0 // vadd.f32 q15, q9, q8 .long 0xf3488dda // vmul.f32 q12, q12, q5 .long 0xf283a65f // vmov.i32 q5, #1056964608 .long 0xf2c4a650 // vmov.i32 q13, #1073741824 .long 0xf30e4dda // vmul.f32 q2, q15, q5 .long 0xf2488dea // vadd.f32 q12, q12, q13 .long 0xf26aade2 // vsub.f32 q13, q13, q9 .long 0xf324ce4a // vcgt.f32 q6, q2, q5 .long 0xf26aade0 // vsub.f32 q13, q13, q8 .long 0xf2420ee0 // vceq.f32 q8, q9, q8 .long 0xf31ac1fe // vbsl q6, q13, q15 .long 0xf242aec0 // vceq.f32 q13, q9, q0 .long 0xeec9baad // vdiv.f32 s23, s19, s27 .long 0xee89ba0d // vdiv.f32 s22, s18, s26 .long 0xeec8aaac // vdiv.f32 s21, s17, s25 .long 0xee88aa0c // vdiv.f32 s20, s16, s24 .long 0xf2422ec2 // vceq.f32 q9, q9, q1 .long 0xf35821fc // vbsl q9, q12, q14 .long 0xf356a1f2 // vbsl q13, q11, q9 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xf26021f0 // vorr q9, q8, q8 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf35401da // vbsl q8, q10, q5 .long 0xf35421fa // vbsl q9, q10, q13 .long 0xf22021f0 // vorr q1, q8, q8 .long 0xf3020df6 // vmul.f32 q0, q9, q11 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x40c00000 // .word 0x40c00000 .long 0x40c00000 // .word 0x40c00000 .long 0x40c00000 // .word 0x40c00000 .long 0x40c00000 // .word 0x40c00000 .long 0x3e2aaaab // .word 0x3e2aaaab .long 0x3e2aaaab // .word 0x3e2aaaab .long 0x3e2aaaab // .word 0x3e2aaaab .long 0x3e2aaaab // .word 0x3e2aaaab HIDDEN _sk_hsl_to_rgb_vfp4 .globl _sk_hsl_to_rgb_vfp4 FUNCTION(_sk_hsl_to_rgb_vfp4) _sk_hsl_to_rgb_vfp4: .long 0xe92d0030 // push {r4, r5} .long 0xed2d8b10 // vpush {d8-d15} .long 0xe24dd028 // sub sp, sp, #40 .long 0xe28d3010 // add r3, sp, #16 .long 0xf3424d54 // vmul.f32 q10, q1, q2 .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xec836b04 // vstmia r3, {d6-d7} .long 0xe28f2f63 // add r2, pc, #396 .long 0xf3446e66 // vcge.f32 q11, q2, q11 .long 0xe28d3010 // add r3, sp, #16 .long 0xf4620acf // vld1.64 {d16-d17}, [r2] .long 0xe28f2f63 // add r2, pc, #396 .long 0xf2400d60 // vadd.f32 q8, q0, q8 .long 0xf4228acf // vld1.64 {d8-d9}, [r2] .long 0xe28f2e19 // add r2, pc, #400 .long 0xf2628d64 // vsub.f32 q12, q1, q10 .long 0xf422eacf // vld1.64 {d14-d15}, [r2] .long 0xf2c0a050 // vmov.i32 q13, #0 .long 0xf3fb2760 // vcvt.s32.f32 q9, q8 .long 0xf35861f4 // vbsl q11, q12, q10 .long 0xf283665f // vmov.i32 q3, #1056964608 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf2464dc4 // vadd.f32 q10, q11, q2 .long 0xf2446d44 // vadd.f32 q11, q2, q2 .long 0xf362cee0 // vcgt.f32 q14, q9, q8 .long 0xf281cf50 // vmov.f32 q6, #4 .long 0xf2666de4 // vsub.f32 q11, q11, q10 .long 0xf358c17a // vbsl q14, q4, q13 .long 0xf283a65f // vmov.i32 q5, #1056964608 .long 0xf2622dec // vsub.f32 q9, q9, q14 .long 0xf264cde6 // vsub.f32 q14, q10, q11 .long 0xf260ade2 // vsub.f32 q13, q8, q9 .long 0xf2c10f58 // vmov.f32 q8, #6 .long 0xf2c12f50 // vmov.f32 q9, #4 .long 0xf34a0df0 // vmul.f32 q8, q13, q8 .long 0xf34aeece // vcge.f32 q15, q13, q7 .long 0xf2628de0 // vsub.f32 q12, q9, q8 .long 0xf34c0df0 // vmul.f32 q8, q14, q8 .long 0xf2c02050 // vmov.i32 q9, #0 .long 0xf34c8df8 // vmul.f32 q12, q14, q12 .long 0xf2460de0 // vadd.f32 q8, q11, q8 .long 0xf2468de8 // vadd.f32 q12, q11, q12 .long 0xeccd0b04 // vstmia sp, {d16-d17} .long 0xe28f2f4b // add r2, pc, #300 .long 0xf356e1f8 // vbsl q15, q11, q12 .long 0xf4620acf // vld1.64 {d16-d17}, [r2] .long 0xe28f2e13 // add r2, pc, #304 .long 0xf2400d60 // vadd.f32 q8, q0, q8 .long 0xf34a8ec6 // vcge.f32 q12, q13, q3 .long 0xf3bb6760 // vcvt.s32.f32 q3, q8 .long 0xf35e81f4 // vbsl q12, q15, q10 .long 0xf3bb6646 // vcvt.f32.s32 q3, q3 .long 0xf366ee60 // vcgt.f32 q15, q3, q8 .long 0xf358e172 // vbsl q15, q4, q9 .long 0xf266ed6e // vsub.f32 q15, q3, q15 .long 0xf2602dee // vsub.f32 q9, q8, q15 .long 0xf2c10f58 // vmov.f32 q8, #6 .long 0xf342edf0 // vmul.f32 q15, q9, q8 .long 0xf3420ece // vcge.f32 q8, q9, q7 .long 0xf22c6d6e // vsub.f32 q3, q6, q15 .long 0xf280c050 // vmov.i32 q6, #0 .long 0xf30c6dd6 // vmul.f32 q3, q14, q3 .long 0xf2066dc6 // vadd.f32 q3, q11, q3 .long 0xf35601d6 // vbsl q8, q11, q3 .long 0xf3026eca // vcge.f32 q3, q9, q5 .long 0xf31061f4 // vbsl q3, q8, q10 .long 0xf34c0dfe // vmul.f32 q8, q14, q15 .long 0xf3fbe740 // vcvt.s32.f32 q15, q0 .long 0xf2460de0 // vadd.f32 q8, q11, q8 .long 0xf3fbe66e // vcvt.f32.s32 q15, q15 .long 0xf32eaec0 // vcgt.f32 q5, q15, q0 .long 0xf318a15c // vbsl q5, q4, q6 .long 0xf2818f50 // vmov.f32 q4, #4 .long 0xf26eedca // vsub.f32 q15, q15, q5 .long 0xf260ed6e // vsub.f32 q15, q0, q15 .long 0xf2810f58 // vmov.f32 q0, #6 .long 0xf30e0dd0 // vmul.f32 q0, q15, q0 .long 0xf30eaece // vcge.f32 q5, q15, q7 .long 0xf2288d40 // vsub.f32 q4, q4, q0 .long 0xf30c8dd8 // vmul.f32 q4, q14, q4 .long 0xf2068dc8 // vadd.f32 q4, q11, q4 .long 0xf316a1d8 // vbsl q5, q11, q4 .long 0xf283865f // vmov.i32 q4, #1056964608 .long 0xf30e8ec8 // vcge.f32 q4, q15, q4 .long 0xf31a8174 // vbsl q4, q5, q10 .long 0xf34c4dd0 // vmul.f32 q10, q14, q0 .long 0xf2464de4 // vadd.f32 q10, q11, q10 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xf3422ee6 // vcge.f32 q9, q9, q11 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf34aaee6 // vcge.f32 q13, q13, q11 .long 0xf34e6ee6 // vcge.f32 q11, q15, q11 .long 0xf3562170 // vbsl q9, q3, q8 .long 0xecdd0b04 // vldmia sp, {d16-d17} .long 0xf358a1f0 // vbsl q13, q12, q8 .long 0xf3f90542 // vceq.f32 q8, q1, #0 .long 0xec936b04 // vldmia r3, {d6-d7} .long 0xf22001f0 // vorr q0, q8, q8 .long 0xf22021f0 // vorr q1, q8, q8 .long 0xf354017a // vbsl q8, q2, q13 .long 0xf3586174 // vbsl q11, q4, q10 .long 0xf3142176 // vbsl q1, q2, q11 .long 0xf3140172 // vbsl q0, q2, q9 .long 0xf22041f0 // vorr q2, q8, q8 .long 0xe28dd028 // add sp, sp, #40 .long 0xecbd8b10 // vpop {d8-d15} .long 0xe8bd0030 // pop {r4, r5} .long 0xe12fff12 // bx r2 .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f2aaaab // .word 0x3f2aaaab .long 0x3f2aaaab // .word 0x3f2aaaab .long 0x3f2aaaab // .word 0x3f2aaaab .long 0x3f2aaaab // .word 0x3f2aaaab .long 0x3eaaaaab // .word 0x3eaaaaab .long 0x3eaaaaab // .word 0x3eaaaaab .long 0x3eaaaaab // .word 0x3eaaaaab .long 0x3eaaaaab // .word 0x3eaaaaab .long 0x3e2aaaab // .word 0x3e2aaaab .long 0x3e2aaaab // .word 0x3e2aaaab .long 0x3e2aaaab // .word 0x3e2aaaab .long 0x3e2aaaab // .word 0x3e2aaaab HIDDEN _sk_scale_1_float_vfp4 .globl _sk_scale_1_float_vfp4 FUNCTION(_sk_scale_1_float_vfp4) _sk_scale_1_float_vfp4: .long 0xe5913000 // ldr r3, [r1] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf4e30cbf // vld1.32 {d16[]-d17[]}, [r3 :32] .long 0xf3000dd0 // vmul.f32 q0, q8, q0 .long 0xf3002dd2 // vmul.f32 q1, q8, q1 .long 0xf3004dd4 // vmul.f32 q2, q8, q2 .long 0xf3006dd6 // vmul.f32 q3, q8, q3 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} HIDDEN _sk_scale_u8_vfp4 .globl _sk_scale_u8_vfp4 FUNCTION(_sk_scale_u8_vfp4) _sk_scale_u8_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe24dd008 // sub sp, sp, #8 .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0224392 // mla r2, r2, r3, r4 .long 0xe082200e // add r2, r2, lr .long 0x1a000013 // bne 250c .long 0xe5922000 // ldr r2, [r2] .long 0xe58d2000 // str r2, [sp] .long 0xe1a0200d // mov r2, sp .long 0xf4e2083f // vld1.32 {d16[0]}, [r2 :32] .long 0xf3c80a30 // vmovl.u8 q8, d16 .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xe28f209c // add r2, pc, #156 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3400df2 // vmul.f32 q8, q8, q9 .long 0xf3000dd0 // vmul.f32 q0, q8, q0 .long 0xf3002dd2 // vmul.f32 q1, q8, q1 .long 0xf3004dd4 // vmul.f32 q2, q8, q2 .long 0xf3006dd6 // vmul.f32 q3, q8, q3 .long 0xe28dd008 // add sp, sp, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a000012 // beq 2564 .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3530002 // cmp r3, #2 .long 0x0a000005 // beq 253c .long 0xe3530003 // cmp r3, #3 .long 0x1affffe8 // bne 24d0 .long 0xe3a04000 // mov r4, #0 .long 0xe5d23002 // ldrb r3, [r2, #2] .long 0xee804bb0 // vdup.16 d16, r4 .long 0xee203bb0 // vmov.16 d16[2], r3 .long 0xe1d220b0 // ldrh r2, [r2] .long 0xe1cd20b4 // strh r2, [sp, #4] .long 0xe28d2004 // add r2, sp, #4 .long 0xf4e2241f // vld1.16 {d18[0]}, [r2 :16] .long 0xf3c82a32 // vmovl.u8 q9, d18 .long 0xf3d02a32 // vmovl.u16 q9, d18 .long 0xf3f62124 // vuzp.16 d18, d20 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffda // b 24d0 .long 0xe3a03000 // mov r3, #0 .long 0xe5d22000 // ldrb r2, [r2] .long 0xee803bb0 // vdup.16 d16, r3 .long 0xee002bb0 // vmov.16 d16[0], r2 .long 0xeaffffd5 // b 24d0 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_lerp_1_float_vfp4 .globl _sk_lerp_1_float_vfp4 FUNCTION(_sk_lerp_1_float_vfp4) _sk_lerp_1_float_vfp4: .long 0xe2802030 // add r2, r0, #48 .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xe2802010 // add r2, r0, #16 .long 0xf2648d60 // vsub.f32 q12, q2, q8 .long 0xf4e3ecbf // vld1.32 {d30[]-d31[]}, [r3 :32] .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf260ad62 // vsub.f32 q13, q0, q9 .long 0xf4624aef // vld1.64 {d20-d21}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf262cd64 // vsub.f32 q14, q1, q10 .long 0xf4626aef // vld1.64 {d22-d23}, [r2 :128] .long 0xf2260d66 // vsub.f32 q0, q3, q11 .long 0xf2480cfe // vfma.f32 q8, q12, q15 .long 0xf24c4cfe // vfma.f32 q10, q14, q15 .long 0xf2406c7e // vfma.f32 q11, q0, q15 .long 0xf24a2cfe // vfma.f32 q9, q13, q15 .long 0xf22041f0 // vorr q2, q8, q8 .long 0xf22421f4 // vorr q1, q10, q10 .long 0xf22661f6 // vorr q3, q11, q11 .long 0xf22201f2 // vorr q0, q9, q9 .long 0xe12fff1c // bx ip HIDDEN _sk_lerp_u8_vfp4 .globl _sk_lerp_u8_vfp4 FUNCTION(_sk_lerp_u8_vfp4) _sk_lerp_u8_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe24dd008 // sub sp, sp, #8 .long 0xe5912000 // ldr r2, [r1] .long 0xe280c040 // add ip, r0, #64 .long 0xe8900058 // ldm r0, {r3, r4, r6} .long 0xe280e030 // add lr, r0, #48 .long 0xe5925000 // ldr r5, [r2] .long 0xe3560000 // cmp r6, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0225492 // mla r2, r2, r4, r5 .long 0xe0824003 // add r4, r2, r3 .long 0xe2803020 // add r3, r0, #32 .long 0xe2802010 // add r2, r0, #16 .long 0x1a00001f // bne 26a0 .long 0xe5944000 // ldr r4, [r4] .long 0xe58d4000 // str r4, [sp] .long 0xe1a0400d // mov r4, sp .long 0xf4e4083f // vld1.32 {d16[0]}, [r4 :32] .long 0xf3c80a30 // vmovl.u8 q8, d16 .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xf4634aef // vld1.64 {d20-d21}, [r3 :128] .long 0xf262cd64 // vsub.f32 q14, q1, q10 .long 0xf3d02a30 // vmovl.u16 q9, d16 .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xf2608d60 // vsub.f32 q12, q0, q8 .long 0xf3fb66e2 // vcvt.f32.u32 q11, q9 .long 0xf46e2aef // vld1.64 {d18-d19}, [lr :128] .long 0xe28f20b4 // add r2, pc, #180 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xf264ed62 // vsub.f32 q15, q2, q9 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf346adfa // vmul.f32 q13, q11, q13 .long 0xf46c6aef // vld1.64 {d22-d23}, [ip :128] .long 0xf2260d66 // vsub.f32 q0, q3, q11 .long 0xf24c4cfa // vfma.f32 q10, q14, q13 .long 0xf24e2cfa // vfma.f32 q9, q15, q13 .long 0xf2406c7a // vfma.f32 q11, q0, q13 .long 0xf2480cfa // vfma.f32 q8, q12, q13 .long 0xf22421f4 // vorr q1, q10, q10 .long 0xf22241f2 // vorr q2, q9, q9 .long 0xf22661f6 // vorr q3, q11, q11 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xe28dd008 // add sp, sp, #8 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff12 // bx r2 .long 0xe2065003 // and r5, r6, #3 .long 0xe3550001 // cmp r5, #1 .long 0x0a000012 // beq 26f8 .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3550002 // cmp r5, #2 .long 0x0a000005 // beq 26d0 .long 0xe3550003 // cmp r5, #3 .long 0x1affffdc // bne 2634 .long 0xe3a06000 // mov r6, #0 .long 0xe5d45002 // ldrb r5, [r4, #2] .long 0xee806bb0 // vdup.16 d16, r6 .long 0xee205bb0 // vmov.16 d16[2], r5 .long 0xe1d440b0 // ldrh r4, [r4] .long 0xe1cd40b4 // strh r4, [sp, #4] .long 0xe28d4004 // add r4, sp, #4 .long 0xf4e4241f // vld1.16 {d18[0]}, [r4 :16] .long 0xf3c82a32 // vmovl.u8 q9, d18 .long 0xf3d02a32 // vmovl.u16 q9, d18 .long 0xf3f62124 // vuzp.16 d18, d20 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffce // b 2634 .long 0xe3a05000 // mov r5, #0 .long 0xe5d44000 // ldrb r4, [r4] .long 0xee805bb0 // vdup.16 d16, r5 .long 0xee004bb0 // vmov.16 d16[0], r4 .long 0xeaffffc9 // b 2634 .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_lerp_565_vfp4 .globl _sk_lerp_565_vfp4 FUNCTION(_sk_lerp_565_vfp4) _sk_lerp_565_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe24dd004 // sub sp, sp, #4 .long 0xe5912000 // ldr r2, [r1] .long 0xe280e020 // add lr, r0, #32 .long 0xe8900058 // ldm r0, {r3, r4, r6} .long 0xe280c010 // add ip, r0, #16 .long 0xe5925000 // ldr r5, [r2] .long 0xe3560000 // cmp r6, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020492 // mul r2, r2, r4 .long 0xe0852082 // add r2, r5, r2, lsl #1 .long 0xe0824083 // add r4, r2, r3, lsl #1 .long 0xe2803040 // add r3, r0, #64 .long 0xe2802030 // add r2, r0, #48 .long 0x1a00002e // bne 2818 .long 0xf464074f // vld1.16 {d16}, [r4] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xe3a04e7e // mov r4, #2016 .long 0xf2c1205f // vmov.i32 q9, #31 .long 0xeea64b90 // vdup.32 q11, r4 .long 0xf3c74258 // vmov.i32 q10, #63488 .long 0xf24021f2 // vand q9, q8, q9 .long 0xf24061f6 // vand q11, q8, q11 .long 0xf24001f4 // vand q8, q8, q10 .long 0xf3fb4666 // vcvt.f32.s32 q10, q11 .long 0xf4636aef // vld1.64 {d22-d23}, [r3 :128] .long 0xe28f30f0 // add r3, pc, #240 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xe28f30f4 // add r3, pc, #244 .long 0xf463cacf // vld1.64 {d28-d29}, [r3] .long 0xf266ad66 // vsub.f32 q13, q3, q11 .long 0xe28f30f8 // add r3, pc, #248 .long 0xf344cdfc // vmul.f32 q14, q10, q14 .long 0xf3428df8 // vmul.f32 q12, q9, q12 .long 0xf4632acf // vld1.64 {d18-d19}, [r3] .long 0xf26641f6 // vorr q10, q11, q11 .long 0xf22661f6 // vorr q3, q11, q11 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf24a4cf8 // vfma.f32 q10, q13, q12 .long 0xf20a6cfc // vfma.f32 q3, q13, q14 .long 0xf340edf2 // vmul.f32 q15, q8, q9 .long 0xf46e2aef // vld1.64 {d18-d19}, [lr :128] .long 0xf4620aef // vld1.64 {d16-d17}, [r2 :128] .long 0xf2244d60 // vsub.f32 q2, q2, q8 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf24a6cfe // vfma.f32 q11, q13, q15 .long 0xf262ad62 // vsub.f32 q13, q1, q9 .long 0xf2062f64 // vmax.f32 q1, q3, q10 .long 0xf46c4aef // vld1.64 {d20-d21}, [ip :128] .long 0xf2200d64 // vsub.f32 q0, q0, q10 .long 0xf2440c78 // vfma.f32 q8, q2, q12 .long 0xf24a2cfc // vfma.f32 q9, q13, q14 .long 0xf2404c7e // vfma.f32 q10, q0, q15 .long 0xf2066fc2 // vmax.f32 q3, q11, q1 .long 0xf22041f0 // vorr q2, q8, q8 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xf22401f4 // vorr q0, q10, q10 .long 0xe28dd004 // add sp, sp, #4 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff12 // bx r2 .long 0xe2065003 // and r5, r6, #3 .long 0xe3550001 // cmp r5, #1 .long 0x0a000011 // beq 286c .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3550002 // cmp r5, #2 .long 0x0a000005 // beq 2848 .long 0xe3550003 // cmp r5, #3 .long 0x1affffc9 // bne 2760 .long 0xe3a05000 // mov r5, #0 .long 0xee805bb0 // vdup.16 d16, r5 .long 0xe2845004 // add r5, r4, #4 .long 0xf4e5049f // vld1.16 {d16[2]}, [r5 :16] .long 0xe5944000 // ldr r4, [r4] .long 0xe58d4000 // str r4, [sp] .long 0xe1a0400d // mov r4, sp .long 0xf4e4183f // vld1.32 {d17[0]}, [r4 :32] .long 0xf3d02a31 // vmovl.u16 q9, d17 .long 0xf3f62121 // vuzp.16 d18, d17 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffbc // b 2760 .long 0xe3a05000 // mov r5, #0 .long 0xee805bb0 // vdup.16 d16, r5 .long 0xf4e4041f // vld1.16 {d16[0]}, [r4 :16] .long 0xeaffffb8 // b 2760 .long 0xe320f000 // nop {0} .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 HIDDEN _sk_load_tables_vfp4 .globl _sk_load_tables_vfp4 FUNCTION(_sk_load_tables_vfp4) _sk_load_tables_vfp4: .long 0xe92d47f0 // push {r4, r5, r6, r7, r8, r9, sl, lr} .long 0xe5916000 // ldr r6, [r1] .long 0xe5902000 // ldr r2, [r0] .long 0xe5903008 // ldr r3, [r0, #8] .long 0xe5964000 // ldr r4, [r6] .long 0xe3530000 // cmp r3, #0 .long 0xe084e102 // add lr, r4, r2, lsl #2 .long 0x1a000036 // bne 29ac .long 0xf46e0a8f // vld1.32 {d16-d17}, [lr] .long 0xf3c7405f // vmov.i32 q10, #255 .long 0xe5967004 // ldr r7, [r6, #4] .long 0xf3f02070 // vshr.u32 q9, q8, #16 .long 0xe596200c // ldr r2, [r6, #12] .long 0xf24061f4 // vand q11, q8, q10 .long 0xe5963008 // ldr r3, [r6, #8] .long 0xf24221f4 // vand q9, q9, q10 .long 0xe28f6f42 // add r6, pc, #264 .long 0xf4668acf // vld1.64 {d24-d25}, [r6] .long 0xee375b90 // vmov.32 r5, d23[1] .long 0xee334b90 // vmov.32 r4, d19[1] .long 0xee17eb90 // vmov.32 lr, d23[0] .long 0xee368b90 // vmov.32 r8, d22[1] .long 0xee16ab90 // vmov.32 sl, d22[0] .long 0xf3f86070 // vshr.u32 q11, q8, #8 .long 0xee32cb90 // vmov.32 ip, d18[1] .long 0xf3e80070 // vshr.u32 q8, q8, #24 .long 0xf24641f4 // vand q10, q11, q10 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xee156b90 // vmov.32 r6, d21[0] .long 0xf3006df8 // vmul.f32 q3, q8, q12 .long 0xe0875105 // add r5, r7, r5, lsl #2 .long 0xe0829104 // add r9, r2, r4, lsl #2 .long 0xee354b90 // vmov.32 r4, d21[1] .long 0xedd51a00 // vldr s3, [r5] .long 0xe087510e // add r5, r7, lr, lsl #2 .long 0xedd95a00 // vldr s11, [r9] .long 0xed951a00 // vldr s2, [r5] .long 0xe0875108 // add r5, r7, r8, lsl #2 .long 0xe087710a // add r7, r7, sl, lsl #2 .long 0xe082c10c // add ip, r2, ip, lsl #2 .long 0xedd50a00 // vldr s1, [r5] .long 0xee345b90 // vmov.32 r5, d20[1] .long 0xed970a00 // vldr s0, [r7] .long 0xe0837104 // add r7, r3, r4, lsl #2 .long 0xee144b90 // vmov.32 r4, d20[0] .long 0xedd73a00 // vldr s7, [r7] .long 0xe0837106 // add r7, r3, r6, lsl #2 .long 0xee136b90 // vmov.32 r6, d19[0] .long 0xed973a00 // vldr s6, [r7] .long 0xe0837105 // add r7, r3, r5, lsl #2 .long 0xee125b90 // vmov.32 r5, d18[0] .long 0xedd72a00 // vldr s5, [r7] .long 0xe0833104 // add r3, r3, r4, lsl #2 .long 0xed932a00 // vldr s4, [r3] .long 0xe0823106 // add r3, r2, r6, lsl #2 .long 0xed935a00 // vldr s10, [r3] .long 0xe0822105 // add r2, r2, r5, lsl #2 .long 0xeddc4a00 // vldr s9, [ip] .long 0xed924a00 // vldr s8, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd47f0 // pop {r4, r5, r6, r7, r8, r9, sl, lr} .long 0xe12fff12 // bx r2 .long 0xe203c003 // and ip, r3, #3 .long 0xe35c0001 // cmp ip, #1 .long 0x0a00000c // beq 29ec .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe35c0002 // cmp ip, #2 .long 0x0a000005 // beq 29dc .long 0xe35c0003 // cmp ip, #3 .long 0x1affffc1 // bne 28d4 .long 0xe3a02000 // mov r2, #0 .long 0xeea02b90 // vdup.32 q8, r2 .long 0xe28e2008 // add r2, lr, #8 .long 0xf4e2183f // vld1.32 {d17[0]}, [r2 :32] .long 0xedde2b00 // vldr d18, [lr] .long 0xf2f008e2 // vext.8 q8, q8, q9, #8 .long 0xf2f008e0 // vext.8 q8, q8, q8, #8 .long 0xeaffffb9 // b 28d4 .long 0xe3a02000 // mov r2, #0 .long 0xeea02b90 // vdup.32 q8, r2 .long 0xf4ee083f // vld1.32 {d16[0]}, [lr :32] .long 0xeaffffb5 // b 28d4 .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_load_tables_u16_be_vfp4 .globl _sk_load_tables_u16_be_vfp4 FUNCTION(_sk_load_tables_u16_be_vfp4) _sk_load_tables_u16_be_vfp4: .long 0xe92d47f0 // push {r4, r5, r6, r7, r8, r9, sl, lr} .long 0xe5918000 // ldr r8, [r1] .long 0xe5903000 // ldr r3, [r0] .long 0xe590e008 // ldr lr, [r0, #8] .long 0xe5982000 // ldr r2, [r8] .long 0xe35e0000 // cmp lr, #0 .long 0xe082c183 // add ip, r2, r3, lsl #3 .long 0x1a000039 // bne 2b18 .long 0xf46c004f // vld4.16 {d16-d19}, [ip] .long 0xf3c72b3f // vbic.i16 d18, #65280 .long 0xe5986004 // ldr r6, [r8, #4] .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xe5983008 // ldr r3, [r8, #8] .long 0xe598200c // ldr r2, [r8, #12] .long 0xe28f40f0 // add r4, pc, #240 .long 0xf3d04a32 // vmovl.u16 q10, d18 .long 0xf4646acf // vld1.64 {d22-d23}, [r4] .long 0xf3d08a30 // vmovl.u16 q12, d16 .long 0xf3c71b3f // vbic.i16 d17, #65280 .long 0xf2d80533 // vshl.s16 d16, d19, #8 .long 0xee355b90 // vmov.32 r5, d21[1] .long 0xee397b90 // vmov.32 r7, d25[1] .long 0xee199b90 // vmov.32 r9, d25[0] .long 0xee388b90 // vmov.32 r8, d24[1] .long 0xee18ab90 // vmov.32 sl, d24[0] .long 0xf3d08a31 // vmovl.u16 q12, d17 .long 0xee34cb90 // vmov.32 ip, d20[1] .long 0xe082e105 // add lr, r2, r5, lsl #2 .long 0xee195b90 // vmov.32 r5, d25[0] .long 0xe0864107 // add r4, r6, r7, lsl #2 .long 0xee397b90 // vmov.32 r7, d25[1] .long 0xedde5a00 // vldr s11, [lr] .long 0xedd41a00 // vldr s3, [r4] .long 0xe0864109 // add r4, r6, r9, lsl #2 .long 0xed941a00 // vldr s2, [r4] .long 0xe0864108 // add r4, r6, r8, lsl #2 .long 0xe082c10c // add ip, r2, ip, lsl #2 .long 0xedd40a00 // vldr s1, [r4] .long 0xe086410a // add r4, r6, sl, lsl #2 .long 0xee386b90 // vmov.32 r6, d24[1] .long 0xed940a00 // vldr s0, [r4] .long 0xe0834107 // add r4, r3, r7, lsl #2 .long 0xee187b90 // vmov.32 r7, d24[0] .long 0xf3d88033 // vshr.u16 d24, d19, #8 .long 0xedd43a00 // vldr s7, [r4] .long 0xe0834105 // add r4, r3, r5, lsl #2 .long 0xee155b90 // vmov.32 r5, d21[0] .long 0xf26001b8 // vorr d16, d16, d24 .long 0xed943a00 // vldr s6, [r4] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xe0834106 // add r4, r3, r6, lsl #2 .long 0xee146b90 // vmov.32 r6, d20[0] .long 0xedd42a00 // vldr s5, [r4] .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3006df6 // vmul.f32 q3, q8, q11 .long 0xe0833107 // add r3, r3, r7, lsl #2 .long 0xed932a00 // vldr s4, [r3] .long 0xe0823105 // add r3, r2, r5, lsl #2 .long 0xed935a00 // vldr s10, [r3] .long 0xeddc4a00 // vldr s9, [ip] .long 0xe0822106 // add r2, r2, r6, lsl #2 .long 0xed924a00 // vldr s8, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd47f0 // pop {r4, r5, r6, r7, r8, r9, sl, lr} .long 0xe12fff12 // bx r2 .long 0xf4ec070f // vld4.16 {d16[0],d17[0],d18[0],d19[0]}, [ip] .long 0xe35e0001 // cmp lr, #1 .long 0x0affffc3 // beq 2a34 .long 0xe28c2008 // add r2, ip, #8 .long 0xe35e0003 // cmp lr, #3 .long 0xf4e2074f // vld4.16 {d16[1],d17[1],d18[1],d19[1]}, [r2] .long 0x3affffbf // bcc 2a34 .long 0xe28c2010 // add r2, ip, #16 .long 0xf4e2078f // vld4.16 {d16[2],d17[2],d18[2],d19[2]}, [r2] .long 0xeaffffbc // b 2a34 .long 0x37800080 // .word 0x37800080 .long 0x37800080 // .word 0x37800080 .long 0x37800080 // .word 0x37800080 .long 0x37800080 // .word 0x37800080 HIDDEN _sk_load_tables_rgb_u16_be_vfp4 .globl _sk_load_tables_rgb_u16_be_vfp4 FUNCTION(_sk_load_tables_rgb_u16_be_vfp4) _sk_load_tables_rgb_u16_be_vfp4: .long 0xe92d47f0 // push {r4, r5, r6, r7, r8, r9, sl, lr} .long 0xe5903000 // ldr r3, [r0] .long 0xe5918000 // ldr r8, [r1] .long 0xe590e008 // ldr lr, [r0, #8] .long 0xe0833083 // add r3, r3, r3, lsl #1 .long 0xe5982000 // ldr r2, [r8] .long 0xe35e0000 // cmp lr, #0 .long 0xe082c083 // add ip, r2, r3, lsl #1 .long 0x1a000033 // bne 2c44 .long 0xf46c044f // vld3.16 {d16-d18}, [ip] .long 0xf3c72b3f // vbic.i16 d18, #65280 .long 0xe5987004 // ldr r7, [r8, #4] .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xe5983008 // ldr r3, [r8, #8] .long 0xe598200c // ldr r2, [r8, #12] .long 0xe28f40dc // add r4, pc, #220 .long 0xf3d04a32 // vmovl.u16 q10, d18 .long 0xf4246acf // vld1.64 {d6-d7}, [r4] .long 0xf3d06a30 // vmovl.u16 q11, d16 .long 0xf3c71b3f // vbic.i16 d17, #65280 .long 0xee355b90 // vmov.32 r5, d21[1] .long 0xee376b90 // vmov.32 r6, d23[1] .long 0xf3d00a31 // vmovl.u16 q8, d17 .long 0xee17eb90 // vmov.32 lr, d23[0] .long 0xee368b90 // vmov.32 r8, d22[1] .long 0xee16ab90 // vmov.32 sl, d22[0] .long 0xee314b90 // vmov.32 r4, d17[1] .long 0xee34cb90 // vmov.32 ip, d20[1] .long 0xe0829105 // add r9, r2, r5, lsl #2 .long 0xe0875106 // add r5, r7, r6, lsl #2 .long 0xee116b90 // vmov.32 r6, d17[0] .long 0xedd95a00 // vldr s11, [r9] .long 0xedd51a00 // vldr s3, [r5] .long 0xe087510e // add r5, r7, lr, lsl #2 .long 0xed951a00 // vldr s2, [r5] .long 0xe0875108 // add r5, r7, r8, lsl #2 .long 0xe087710a // add r7, r7, sl, lsl #2 .long 0xe082c10c // add ip, r2, ip, lsl #2 .long 0xedd50a00 // vldr s1, [r5] .long 0xee305b90 // vmov.32 r5, d16[1] .long 0xed970a00 // vldr s0, [r7] .long 0xe0837104 // add r7, r3, r4, lsl #2 .long 0xee104b90 // vmov.32 r4, d16[0] .long 0xedd73a00 // vldr s7, [r7] .long 0xe0837106 // add r7, r3, r6, lsl #2 .long 0xee156b90 // vmov.32 r6, d21[0] .long 0xed973a00 // vldr s6, [r7] .long 0xe0837105 // add r7, r3, r5, lsl #2 .long 0xee145b90 // vmov.32 r5, d20[0] .long 0xedd72a00 // vldr s5, [r7] .long 0xe0833104 // add r3, r3, r4, lsl #2 .long 0xed932a00 // vldr s4, [r3] .long 0xe0823106 // add r3, r2, r6, lsl #2 .long 0xed935a00 // vldr s10, [r3] .long 0xeddc4a00 // vldr s9, [ip] .long 0xe0822105 // add r2, r2, r5, lsl #2 .long 0xed924a00 // vldr s8, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd47f0 // pop {r4, r5, r6, r7, r8, r9, sl, lr} .long 0xe12fff12 // bx r2 .long 0xf4ec060f // vld3.16 {d16[0],d17[0],d18[0]}, [ip] .long 0xe35e0001 // cmp lr, #1 .long 0x0affffc9 // beq 2b78 .long 0xe28c2006 // add r2, ip, #6 .long 0xe35e0003 // cmp lr, #3 .long 0xf4e2064f // vld3.16 {d16[1],d17[1],d18[1]}, [r2] .long 0x3affffc5 // bcc 2b78 .long 0xe28c200c // add r2, ip, #12 .long 0xf4e2068f // vld3.16 {d16[2],d17[2],d18[2]}, [r2] .long 0xeaffffc2 // b 2b78 .long 0xe320f000 // nop {0} .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_byte_tables_vfp4 .globl _sk_byte_tables_vfp4 FUNCTION(_sk_byte_tables_vfp4) _sk_byte_tables_vfp4: .long 0xe92d48f0 // push {r4, r5, r6, r7, fp, lr} .long 0xe28f2f55 // add r2, pc, #340 .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xf2c3865f // vmov.i32 q12, #1056964608 .long 0xf2420c7a // vfma.f32 q8, q1, q13 .long 0xe8911040 // ldm r1, {r6, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xf2468c7a // vfma.f32 q12, q3, q13 .long 0xe8960018 // ldm r6, {r3, r4} .long 0xe5962008 // ldr r2, [r6, #8] .long 0xe596e00c // ldr lr, [r6, #12] .long 0xf3fb27e0 // vcvt.u32.f32 q9, q8 .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf2400c7a // vfma.f32 q8, q0, q13 .long 0xf3fb87e8 // vcvt.u32.f32 q12, q12 .long 0xee127b90 // vmov.32 r7, d18[0] .long 0xee325b90 // vmov.32 r5, d18[1] .long 0xf3fb47e0 // vcvt.u32.f32 q10, q8 .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf2440c7a // vfma.f32 q8, q2, q13 .long 0xf3fb67e0 // vcvt.u32.f32 q11, q8 .long 0xe7d46007 // ldrb r6, [r4, r7] .long 0xee147b90 // vmov.32 r7, d20[0] .long 0xe7d45005 // ldrb r5, [r4, r5] .long 0xee006bb0 // vmov.16 d16[0], r6 .long 0xee005bf0 // vmov.16 d16[1], r5 .long 0xe7d36007 // ldrb r6, [r3, r7] .long 0xee167b90 // vmov.32 r7, d22[0] .long 0xee016bb0 // vmov.16 d17[0], r6 .long 0xe7d26007 // ldrb r6, [r2, r7] .long 0xee187b90 // vmov.32 r7, d24[0] .long 0xee0a6bb0 // vmov.16 d26[0], r6 .long 0xe7de6007 // ldrb r6, [lr, r7] .long 0xee347b90 // vmov.32 r7, d20[1] .long 0xee0b6bb0 // vmov.16 d27[0], r6 .long 0xee176b90 // vmov.32 r6, d23[0] .long 0xe7d35007 // ldrb r5, [r3, r7] .long 0xee367b90 // vmov.32 r7, d22[1] .long 0xee015bf0 // vmov.16 d17[1], r5 .long 0xe7d25006 // ldrb r5, [r2, r6] .long 0xe7d26007 // ldrb r6, [r2, r7] .long 0xee387b90 // vmov.32 r7, d24[1] .long 0xee0a6bf0 // vmov.16 d26[1], r6 .long 0xee2a5bb0 // vmov.16 d26[2], r5 .long 0xee195b90 // vmov.32 r5, d25[0] .long 0xe7de6007 // ldrb r6, [lr, r7] .long 0xee157b90 // vmov.32 r7, d21[0] .long 0xee0b6bf0 // vmov.16 d27[1], r6 .long 0xe7de5005 // ldrb r5, [lr, r5] .long 0xee2b5bb0 // vmov.16 d27[2], r5 .long 0xe7d36007 // ldrb r6, [r3, r7] .long 0xee137b90 // vmov.32 r7, d19[0] .long 0xee216bb0 // vmov.16 d17[2], r6 .long 0xe7d46007 // ldrb r6, [r4, r7] .long 0xee337b90 // vmov.32 r7, d19[1] .long 0xee206bb0 // vmov.16 d16[2], r6 .long 0xee356b90 // vmov.32 r6, d21[1] .long 0xe7d44007 // ldrb r4, [r4, r7] .long 0xee397b90 // vmov.32 r7, d25[1] .long 0xee204bf0 // vmov.16 d16[3], r4 .long 0xe7d33006 // ldrb r3, [r3, r6] .long 0xee376b90 // vmov.32 r6, d23[1] .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xee213bf0 // vmov.16 d17[3], r3 .long 0xf3c71b3f // vbic.i16 d17, #65280 .long 0xf3d02a31 // vmovl.u16 q9, d17 .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf3fb26e2 // vcvt.f32.u32 q9, q9 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xe7de3007 // ldrb r3, [lr, r7] .long 0xee2b3bf0 // vmov.16 d27[3], r3 .long 0xe7d22006 // ldrb r2, [r2, r6] .long 0xf3c7bb3f // vbic.i16 d27, #65280 .long 0xee2a2bf0 // vmov.16 d26[3], r2 .long 0xf3d06a3b // vmovl.u16 q11, d27 .long 0xe28f2038 // add r2, pc, #56 .long 0xf3c7ab3f // vbic.i16 d26, #65280 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xf3fb66e6 // vcvt.f32.u32 q11, q11 .long 0xf3d04a3a // vmovl.u16 q10, d26 .long 0xf3020df8 // vmul.f32 q0, q9, q12 .long 0xf3002df8 // vmul.f32 q1, q8, q12 .long 0xf3fb46e4 // vcvt.f32.u32 q10, q10 .long 0xf3066df8 // vmul.f32 q3, q11, q12 .long 0xf3044df8 // vmul.f32 q2, q10, q12 .long 0xe8bd48f0 // pop {r4, r5, r6, r7, fp, lr} .long 0xe12fff1c // bx ip .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_byte_tables_rgb_vfp4 .globl _sk_byte_tables_rgb_vfp4 FUNCTION(_sk_byte_tables_rgb_vfp4) _sk_byte_tables_rgb_vfp4: .long 0xe92d48f0 // push {r4, r5, r6, r7, fp, lr} .long 0xe8911010 // ldm r1, {r4, ip} .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xe2811008 // add r1, r1, #8 .long 0xe5943000 // ldr r3, [r4] .long 0xe9944004 // ldmib r4, {r2, lr} .long 0xe594400c // ldr r4, [r4, #12] .long 0xe2444001 // sub r4, r4, #1 .long 0xeea04b90 // vdup.32 q8, r4 .long 0xf3fb4660 // vcvt.f32.s32 q10, q8 .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf2440c74 // vfma.f32 q8, q2, q10 .long 0xf2422c74 // vfma.f32 q9, q1, q10 .long 0xf2406c74 // vfma.f32 q11, q0, q10 .long 0xf3fb07e0 // vcvt.u32.f32 q8, q8 .long 0xf3fb27e2 // vcvt.u32.f32 q9, q9 .long 0xf3fb47e6 // vcvt.u32.f32 q10, q11 .long 0xee104b90 // vmov.32 r4, d16[0] .long 0xee317b90 // vmov.32 r7, d17[1] .long 0xee125b90 // vmov.32 r5, d18[0] .long 0xee146b90 // vmov.32 r6, d20[0] .long 0xe7de4004 // ldrb r4, [lr, r4] .long 0xe7de7007 // ldrb r7, [lr, r7] .long 0xe7d25005 // ldrb r5, [r2, r5] .long 0xee074bb0 // vmov.16 d23[0], r4 .long 0xe7d34006 // ldrb r4, [r3, r6] .long 0xee065bb0 // vmov.16 d22[0], r5 .long 0xee155b90 // vmov.32 r5, d21[0] .long 0xee346b90 // vmov.32 r6, d20[1] .long 0xee084bb0 // vmov.16 d24[0], r4 .long 0xe7d34005 // ldrb r4, [r3, r5] .long 0xe7d35006 // ldrb r5, [r3, r6] .long 0xee326b90 // vmov.32 r6, d18[1] .long 0xee085bf0 // vmov.16 d24[1], r5 .long 0xee284bb0 // vmov.16 d24[2], r4 .long 0xee134b90 // vmov.32 r4, d19[0] .long 0xe7d25006 // ldrb r5, [r2, r6] .long 0xee306b90 // vmov.32 r6, d16[1] .long 0xee065bf0 // vmov.16 d22[1], r5 .long 0xe7d24004 // ldrb r4, [r2, r4] .long 0xee264bb0 // vmov.16 d22[2], r4 .long 0xe7de5006 // ldrb r5, [lr, r6] .long 0xee356b90 // vmov.32 r6, d21[1] .long 0xee075bf0 // vmov.16 d23[1], r5 .long 0xee115b90 // vmov.32 r5, d17[0] .long 0xe7d33006 // ldrb r3, [r3, r6] .long 0xee336b90 // vmov.32 r6, d19[1] .long 0xee283bf0 // vmov.16 d24[3], r3 .long 0xe7de5005 // ldrb r5, [lr, r5] .long 0xf3c78b3f // vbic.i16 d24, #65280 .long 0xee275bb0 // vmov.16 d23[2], r5 .long 0xf3d00a38 // vmovl.u16 q8, d24 .long 0xee277bf0 // vmov.16 d23[3], r7 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3c77b3f // vbic.i16 d23, #65280 .long 0xf3d04a37 // vmovl.u16 q10, d23 .long 0xf3fb46e4 // vcvt.f32.u32 q10, q10 .long 0xe7d22006 // ldrb r2, [r2, r6] .long 0xee262bf0 // vmov.16 d22[3], r2 .long 0xe28f2020 // add r2, pc, #32 .long 0xf3c76b3f // vbic.i16 d22, #65280 .long 0xf3d02a36 // vmovl.u16 q9, d22 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xf3000df6 // vmul.f32 q0, q8, q11 .long 0xf3fb26e2 // vcvt.f32.u32 q9, q9 .long 0xf3044df6 // vmul.f32 q2, q10, q11 .long 0xf3022df6 // vmul.f32 q1, q9, q11 .long 0xe8bd48f0 // pop {r4, r5, r6, r7, fp, lr} .long 0xe12fff1c // bx ip .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_table_r_vfp4 .globl _sk_table_r_vfp4 FUNCTION(_sk_table_r_vfp4) _sk_table_r_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xe2811008 // add r1, r1, #8 .long 0xe893000c // ldm r3, {r2, r3} .long 0xe2433001 // sub r3, r3, #1 .long 0xeea03b90 // vdup.32 q8, r3 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf2402c70 // vfma.f32 q9, q0, q8 .long 0xf3fb07e2 // vcvt.u32.f32 q8, q9 .long 0xee313b90 // vmov.32 r3, d17[1] .long 0xee114b90 // vmov.32 r4, d17[0] .long 0xee30eb90 // vmov.32 lr, d16[1] .long 0xee106b90 // vmov.32 r6, d16[0] .long 0xe0823103 // add r3, r2, r3, lsl #2 .long 0xedd31a00 // vldr s3, [r3] .long 0xe0823104 // add r3, r2, r4, lsl #2 .long 0xe082510e // add r5, r2, lr, lsl #2 .long 0xe0822106 // add r2, r2, r6, lsl #2 .long 0xed931a00 // vldr s2, [r3] .long 0xedd50a00 // vldr s1, [r5] .long 0xed920a00 // vldr s0, [r2] .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_table_g_vfp4 .globl _sk_table_g_vfp4 FUNCTION(_sk_table_g_vfp4) _sk_table_g_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xe2811008 // add r1, r1, #8 .long 0xe893000c // ldm r3, {r2, r3} .long 0xe2433001 // sub r3, r3, #1 .long 0xeea03b90 // vdup.32 q8, r3 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf2422c70 // vfma.f32 q9, q1, q8 .long 0xf3fb07e2 // vcvt.u32.f32 q8, q9 .long 0xee313b90 // vmov.32 r3, d17[1] .long 0xee114b90 // vmov.32 r4, d17[0] .long 0xee30eb90 // vmov.32 lr, d16[1] .long 0xee106b90 // vmov.32 r6, d16[0] .long 0xe0823103 // add r3, r2, r3, lsl #2 .long 0xedd33a00 // vldr s7, [r3] .long 0xe0823104 // add r3, r2, r4, lsl #2 .long 0xe082510e // add r5, r2, lr, lsl #2 .long 0xe0822106 // add r2, r2, r6, lsl #2 .long 0xed933a00 // vldr s6, [r3] .long 0xedd52a00 // vldr s5, [r5] .long 0xed922a00 // vldr s4, [r2] .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_table_b_vfp4 .globl _sk_table_b_vfp4 FUNCTION(_sk_table_b_vfp4) _sk_table_b_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xe2811008 // add r1, r1, #8 .long 0xe893000c // ldm r3, {r2, r3} .long 0xe2433001 // sub r3, r3, #1 .long 0xeea03b90 // vdup.32 q8, r3 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf2442c70 // vfma.f32 q9, q2, q8 .long 0xf3fb07e2 // vcvt.u32.f32 q8, q9 .long 0xee313b90 // vmov.32 r3, d17[1] .long 0xee114b90 // vmov.32 r4, d17[0] .long 0xee30eb90 // vmov.32 lr, d16[1] .long 0xee106b90 // vmov.32 r6, d16[0] .long 0xe0823103 // add r3, r2, r3, lsl #2 .long 0xedd35a00 // vldr s11, [r3] .long 0xe0823104 // add r3, r2, r4, lsl #2 .long 0xe082510e // add r5, r2, lr, lsl #2 .long 0xe0822106 // add r2, r2, r6, lsl #2 .long 0xed935a00 // vldr s10, [r3] .long 0xedd54a00 // vldr s9, [r5] .long 0xed924a00 // vldr s8, [r2] .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_table_a_vfp4 .globl _sk_table_a_vfp4 FUNCTION(_sk_table_a_vfp4) _sk_table_a_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xe2811008 // add r1, r1, #8 .long 0xe893000c // ldm r3, {r2, r3} .long 0xe2433001 // sub r3, r3, #1 .long 0xeea03b90 // vdup.32 q8, r3 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf2462c70 // vfma.f32 q9, q3, q8 .long 0xf3fb07e2 // vcvt.u32.f32 q8, q9 .long 0xee313b90 // vmov.32 r3, d17[1] .long 0xee114b90 // vmov.32 r4, d17[0] .long 0xee30eb90 // vmov.32 lr, d16[1] .long 0xee106b90 // vmov.32 r6, d16[0] .long 0xe0823103 // add r3, r2, r3, lsl #2 .long 0xedd37a00 // vldr s15, [r3] .long 0xe0823104 // add r3, r2, r4, lsl #2 .long 0xe082510e // add r5, r2, lr, lsl #2 .long 0xe0822106 // add r2, r2, r6, lsl #2 .long 0xed937a00 // vldr s14, [r3] .long 0xedd56a00 // vldr s13, [r5] .long 0xed926a00 // vldr s12, [r2] .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_parametric_r_vfp4 .globl _sk_parametric_r_vfp4 FUNCTION(_sk_parametric_r_vfp4) _sk_parametric_r_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xe8911004 // ldm r1, {r2, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xed9fca65 // vldr s24, [pc, #404] .long 0xe1a03002 // mov r3, r2 .long 0xf4e30cbd // vld1.32 {d16[]-d17[]}, [r3 :32]! .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe2823008 // add r3, r2, #8 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xe28f3f43 // add r3, pc, #268 .long 0xf2424cd0 // vfma.f32 q10, q9, q0 .long 0xf2c72d5f // vmov.i32 q9, #8388607 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f3f43 // add r3, pc, #268 .long 0xf24421f2 // vand q9, q10, q9 .long 0xf2c3275f // vorr.i32 q9, #1056964608 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf202ade6 // vadd.f32 q5, q9, q11 .long 0xf2c36654 // vmov.i32 q11, #872415232 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30fc // add r3, pc, #252 .long 0xeecc9a2b // vdiv.f32 s19, s24, s23 .long 0xee8c9a0b // vdiv.f32 s18, s24, s22 .long 0xeecc8a2a // vdiv.f32 s17, s24, s21 .long 0xee8c8a0a // vdiv.f32 s16, s24, s20 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf3422df6 // vmul.f32 q9, q9, q11 .long 0xf2444de8 // vadd.f32 q10, q10, q12 .long 0xe28f30ec // add r3, pc, #236 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xe28f30f4 // add r3, pc, #244 .long 0xed9faa49 // vldr s20, [pc, #292] .long 0xf2642de2 // vsub.f32 q9, q10, q9 .long 0xf2622dc8 // vsub.f32 q9, q9, q4 .long 0xf3402df2 // vmul.f32 q9, q8, q9 .long 0xf3fb0762 // vcvt.s32.f32 q8, q9 .long 0xf3fb4660 // vcvt.f32.s32 q10, q8 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xf3646ee2 // vcgt.f32 q11, q10, q9 .long 0xf35861f0 // vbsl q11, q12, q8 .long 0xf2644de6 // vsub.f32 q10, q10, q11 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30d4 // add r3, pc, #212 .long 0xf2624de4 // vsub.f32 q10, q9, q10 .long 0xf226cde4 // vsub.f32 q6, q11, q10 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30d4 // add r3, pc, #212 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf2422de6 // vadd.f32 q9, q9, q11 .long 0xe282300c // add r3, r2, #12 .long 0xf3444df8 // vmul.f32 q10, q10, q12 .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xeeca9a2d // vdiv.f32 s19, s20, s27 .long 0xee8a9a0d // vdiv.f32 s18, s20, s26 .long 0xeeca8a2c // vdiv.f32 s17, s20, s25 .long 0xee8a8a0c // vdiv.f32 s16, s20, s24 .long 0xf2622de4 // vsub.f32 q9, q9, q10 .long 0xf2c4465b // vmov.i32 q10, #1258291200 .long 0xf2422dc8 // vadd.f32 q9, q9, q4 .long 0xf2426cf4 // vfma.f32 q11, q9, q10 .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe2823018 // add r3, r2, #24 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xe2823010 // add r3, r2, #16 .long 0xf2424cd0 // vfma.f32 q10, q9, q0 .long 0xe2822014 // add r2, r2, #20 .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xf3fb27e6 // vcvt.u32.f32 q9, q11 .long 0xf4e36cbf // vld1.32 {d22[]-d23[]}, [r3 :32] .long 0xf3466ec0 // vcge.f32 q11, q11, q0 .long 0xf2482de2 // vadd.f32 q9, q12, q9 .long 0xf35461f2 // vbsl q11, q10, q9 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf2460fe0 // vmax.f32 q8, q11, q8 .long 0xf2200fe2 // vmin.f32 q0, q8, q9 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff1c // bx ip .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fdce9a3 // .word 0x3fdce9a3 .long 0x41ddd2fe // .word 0x41ddd2fe HIDDEN _sk_parametric_g_vfp4 .globl _sk_parametric_g_vfp4 FUNCTION(_sk_parametric_g_vfp4) _sk_parametric_g_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xe8911004 // ldm r1, {r2, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xed9fca65 // vldr s24, [pc, #404] .long 0xe1a03002 // mov r3, r2 .long 0xf4e30cbd // vld1.32 {d16[]-d17[]}, [r3 :32]! .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe2823008 // add r3, r2, #8 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xe28f3f43 // add r3, pc, #268 .long 0xf2424cd2 // vfma.f32 q10, q9, q1 .long 0xf2c72d5f // vmov.i32 q9, #8388607 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f3f43 // add r3, pc, #268 .long 0xf24421f2 // vand q9, q10, q9 .long 0xf2c3275f // vorr.i32 q9, #1056964608 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf202ade6 // vadd.f32 q5, q9, q11 .long 0xf2c36654 // vmov.i32 q11, #872415232 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30fc // add r3, pc, #252 .long 0xeecc9a2b // vdiv.f32 s19, s24, s23 .long 0xee8c9a0b // vdiv.f32 s18, s24, s22 .long 0xeecc8a2a // vdiv.f32 s17, s24, s21 .long 0xee8c8a0a // vdiv.f32 s16, s24, s20 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf3422df6 // vmul.f32 q9, q9, q11 .long 0xf2444de8 // vadd.f32 q10, q10, q12 .long 0xe28f30ec // add r3, pc, #236 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xe28f30f4 // add r3, pc, #244 .long 0xed9faa49 // vldr s20, [pc, #292] .long 0xf2642de2 // vsub.f32 q9, q10, q9 .long 0xf2622dc8 // vsub.f32 q9, q9, q4 .long 0xf3402df2 // vmul.f32 q9, q8, q9 .long 0xf3fb0762 // vcvt.s32.f32 q8, q9 .long 0xf3fb4660 // vcvt.f32.s32 q10, q8 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xf3646ee2 // vcgt.f32 q11, q10, q9 .long 0xf35861f0 // vbsl q11, q12, q8 .long 0xf2644de6 // vsub.f32 q10, q10, q11 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30d4 // add r3, pc, #212 .long 0xf2624de4 // vsub.f32 q10, q9, q10 .long 0xf226cde4 // vsub.f32 q6, q11, q10 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30d4 // add r3, pc, #212 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf2422de6 // vadd.f32 q9, q9, q11 .long 0xe282300c // add r3, r2, #12 .long 0xf3444df8 // vmul.f32 q10, q10, q12 .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xeeca9a2d // vdiv.f32 s19, s20, s27 .long 0xee8a9a0d // vdiv.f32 s18, s20, s26 .long 0xeeca8a2c // vdiv.f32 s17, s20, s25 .long 0xee8a8a0c // vdiv.f32 s16, s20, s24 .long 0xf2622de4 // vsub.f32 q9, q9, q10 .long 0xf2c4465b // vmov.i32 q10, #1258291200 .long 0xf2422dc8 // vadd.f32 q9, q9, q4 .long 0xf2426cf4 // vfma.f32 q11, q9, q10 .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe2823018 // add r3, r2, #24 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xe2823010 // add r3, r2, #16 .long 0xf2424cd2 // vfma.f32 q10, q9, q1 .long 0xe2822014 // add r2, r2, #20 .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xf3fb27e6 // vcvt.u32.f32 q9, q11 .long 0xf4e36cbf // vld1.32 {d22[]-d23[]}, [r3 :32] .long 0xf3466ec2 // vcge.f32 q11, q11, q1 .long 0xf2482de2 // vadd.f32 q9, q12, q9 .long 0xf35461f2 // vbsl q11, q10, q9 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf2460fe0 // vmax.f32 q8, q11, q8 .long 0xf2202fe2 // vmin.f32 q1, q8, q9 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff1c // bx ip .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fdce9a3 // .word 0x3fdce9a3 .long 0x41ddd2fe // .word 0x41ddd2fe HIDDEN _sk_parametric_b_vfp4 .globl _sk_parametric_b_vfp4 FUNCTION(_sk_parametric_b_vfp4) _sk_parametric_b_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xe8911004 // ldm r1, {r2, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xed9fca65 // vldr s24, [pc, #404] .long 0xe1a03002 // mov r3, r2 .long 0xf4e30cbd // vld1.32 {d16[]-d17[]}, [r3 :32]! .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe2823008 // add r3, r2, #8 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xe28f3f43 // add r3, pc, #268 .long 0xf2424cd4 // vfma.f32 q10, q9, q2 .long 0xf2c72d5f // vmov.i32 q9, #8388607 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f3f43 // add r3, pc, #268 .long 0xf24421f2 // vand q9, q10, q9 .long 0xf2c3275f // vorr.i32 q9, #1056964608 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf202ade6 // vadd.f32 q5, q9, q11 .long 0xf2c36654 // vmov.i32 q11, #872415232 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30fc // add r3, pc, #252 .long 0xeecc9a2b // vdiv.f32 s19, s24, s23 .long 0xee8c9a0b // vdiv.f32 s18, s24, s22 .long 0xeecc8a2a // vdiv.f32 s17, s24, s21 .long 0xee8c8a0a // vdiv.f32 s16, s24, s20 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf3422df6 // vmul.f32 q9, q9, q11 .long 0xf2444de8 // vadd.f32 q10, q10, q12 .long 0xe28f30ec // add r3, pc, #236 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xe28f30f4 // add r3, pc, #244 .long 0xed9faa49 // vldr s20, [pc, #292] .long 0xf2642de2 // vsub.f32 q9, q10, q9 .long 0xf2622dc8 // vsub.f32 q9, q9, q4 .long 0xf3402df2 // vmul.f32 q9, q8, q9 .long 0xf3fb0762 // vcvt.s32.f32 q8, q9 .long 0xf3fb4660 // vcvt.f32.s32 q10, q8 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xf3646ee2 // vcgt.f32 q11, q10, q9 .long 0xf35861f0 // vbsl q11, q12, q8 .long 0xf2644de6 // vsub.f32 q10, q10, q11 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30d4 // add r3, pc, #212 .long 0xf2624de4 // vsub.f32 q10, q9, q10 .long 0xf226cde4 // vsub.f32 q6, q11, q10 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30d4 // add r3, pc, #212 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf2422de6 // vadd.f32 q9, q9, q11 .long 0xe282300c // add r3, r2, #12 .long 0xf3444df8 // vmul.f32 q10, q10, q12 .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xeeca9a2d // vdiv.f32 s19, s20, s27 .long 0xee8a9a0d // vdiv.f32 s18, s20, s26 .long 0xeeca8a2c // vdiv.f32 s17, s20, s25 .long 0xee8a8a0c // vdiv.f32 s16, s20, s24 .long 0xf2622de4 // vsub.f32 q9, q9, q10 .long 0xf2c4465b // vmov.i32 q10, #1258291200 .long 0xf2422dc8 // vadd.f32 q9, q9, q4 .long 0xf2426cf4 // vfma.f32 q11, q9, q10 .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe2823018 // add r3, r2, #24 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xe2823010 // add r3, r2, #16 .long 0xf2424cd4 // vfma.f32 q10, q9, q2 .long 0xe2822014 // add r2, r2, #20 .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xf3fb27e6 // vcvt.u32.f32 q9, q11 .long 0xf4e36cbf // vld1.32 {d22[]-d23[]}, [r3 :32] .long 0xf3466ec4 // vcge.f32 q11, q11, q2 .long 0xf2482de2 // vadd.f32 q9, q12, q9 .long 0xf35461f2 // vbsl q11, q10, q9 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf2460fe0 // vmax.f32 q8, q11, q8 .long 0xf2204fe2 // vmin.f32 q2, q8, q9 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff1c // bx ip .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fdce9a3 // .word 0x3fdce9a3 .long 0x41ddd2fe // .word 0x41ddd2fe HIDDEN _sk_parametric_a_vfp4 .globl _sk_parametric_a_vfp4 FUNCTION(_sk_parametric_a_vfp4) _sk_parametric_a_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xe8911004 // ldm r1, {r2, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xed9fca65 // vldr s24, [pc, #404] .long 0xe1a03002 // mov r3, r2 .long 0xf4e30cbd // vld1.32 {d16[]-d17[]}, [r3 :32]! .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe2823008 // add r3, r2, #8 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xe28f3f43 // add r3, pc, #268 .long 0xf2424cd6 // vfma.f32 q10, q9, q3 .long 0xf2c72d5f // vmov.i32 q9, #8388607 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f3f43 // add r3, pc, #268 .long 0xf24421f2 // vand q9, q10, q9 .long 0xf2c3275f // vorr.i32 q9, #1056964608 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf202ade6 // vadd.f32 q5, q9, q11 .long 0xf2c36654 // vmov.i32 q11, #872415232 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30fc // add r3, pc, #252 .long 0xeecc9a2b // vdiv.f32 s19, s24, s23 .long 0xee8c9a0b // vdiv.f32 s18, s24, s22 .long 0xeecc8a2a // vdiv.f32 s17, s24, s21 .long 0xee8c8a0a // vdiv.f32 s16, s24, s20 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf3422df6 // vmul.f32 q9, q9, q11 .long 0xf2444de8 // vadd.f32 q10, q10, q12 .long 0xe28f30ec // add r3, pc, #236 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xe28f30f4 // add r3, pc, #244 .long 0xed9faa49 // vldr s20, [pc, #292] .long 0xf2642de2 // vsub.f32 q9, q10, q9 .long 0xf2622dc8 // vsub.f32 q9, q9, q4 .long 0xf3402df2 // vmul.f32 q9, q8, q9 .long 0xf3fb0762 // vcvt.s32.f32 q8, q9 .long 0xf3fb4660 // vcvt.f32.s32 q10, q8 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xf3646ee2 // vcgt.f32 q11, q10, q9 .long 0xf35861f0 // vbsl q11, q12, q8 .long 0xf2644de6 // vsub.f32 q10, q10, q11 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30d4 // add r3, pc, #212 .long 0xf2624de4 // vsub.f32 q10, q9, q10 .long 0xf226cde4 // vsub.f32 q6, q11, q10 .long 0xf4636acf // vld1.64 {d22-d23}, [r3] .long 0xe28f30d4 // add r3, pc, #212 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf2422de6 // vadd.f32 q9, q9, q11 .long 0xe282300c // add r3, r2, #12 .long 0xf3444df8 // vmul.f32 q10, q10, q12 .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xeeca9a2d // vdiv.f32 s19, s20, s27 .long 0xee8a9a0d // vdiv.f32 s18, s20, s26 .long 0xeeca8a2c // vdiv.f32 s17, s20, s25 .long 0xee8a8a0c // vdiv.f32 s16, s20, s24 .long 0xf2622de4 // vsub.f32 q9, q9, q10 .long 0xf2c4465b // vmov.i32 q10, #1258291200 .long 0xf2422dc8 // vadd.f32 q9, q9, q4 .long 0xf2426cf4 // vfma.f32 q11, q9, q10 .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe2823018 // add r3, r2, #24 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xe2823010 // add r3, r2, #16 .long 0xf2424cd6 // vfma.f32 q10, q9, q3 .long 0xe2822014 // add r2, r2, #20 .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xf3fb27e6 // vcvt.u32.f32 q9, q11 .long 0xf4e36cbf // vld1.32 {d22[]-d23[]}, [r3 :32] .long 0xf3466ec6 // vcge.f32 q11, q11, q3 .long 0xf2482de2 // vadd.f32 q9, q12, q9 .long 0xf35461f2 // vbsl q11, q10, q9 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf2460fe0 // vmax.f32 q8, q11, q8 .long 0xf2206fe2 // vmin.f32 q3, q8, q9 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff1c // bx ip .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fdce9a3 // .word 0x3fdce9a3 .long 0x41ddd2fe // .word 0x41ddd2fe HIDDEN _sk_gamma_vfp4 .globl _sk_gamma_vfp4 FUNCTION(_sk_gamma_vfp4) _sk_gamma_vfp4: .long 0xe92d0030 // push {r4, r5} .long 0xed2d8b10 // vpush {d8-d15} .long 0xe24dd038 // sub sp, sp, #56 .long 0xf2c70d5f // vmov.i32 q8, #8388607 .long 0xe28d4020 // add r4, sp, #32 .long 0xed9fcaa7 // vldr s24, [pc, #668] .long 0xf3fb2644 // vcvt.f32.s32 q9, q2 .long 0xec846b04 // vstmia r4, {d6-d7} .long 0xe28f2e22 // add r2, pc, #544 .long 0xf2440170 // vand q8, q2, q8 .long 0xe28d4010 // add r4, sp, #16 .long 0xf2c3075f // vorr.i32 q8, #1056964608 .long 0xf422aacf // vld1.64 {d10-d11}, [r2] .long 0xf2c34654 // vmov.i32 q10, #872415232 .long 0xe28f2f86 // add r2, pc, #536 .long 0xf2006dca // vadd.f32 q3, q8, q5 .long 0xf462cacf // vld1.64 {d28-d29}, [r2] .long 0xe28f2f87 // add r2, pc, #540 .long 0xf3422df4 // vmul.f32 q9, q9, q10 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xf3400dfc // vmul.f32 q8, q8, q14 .long 0xe5913000 // ldr r3, [r1] .long 0xf2c76d5f // vmov.i32 q11, #8388607 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf280e050 // vmov.i32 q7, #0 .long 0xeecc5a27 // vdiv.f32 s11, s24, s15 .long 0xe2811008 // add r1, r1, #8 .long 0xf4e3ecbf // vld1.32 {d30[]-d31[]}, [r3 :32] .long 0xe28f3c02 // add r3, pc, #512 .long 0xf2422dea // vadd.f32 q9, q9, q13 .long 0xee8c5a07 // vdiv.f32 s10, s24, s14 .long 0xeecc4a26 // vdiv.f32 s9, s24, s13 .long 0xee8c4a06 // vdiv.f32 s8, s24, s12 .long 0xf2620de0 // vsub.f32 q8, q9, q8 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xed9f6a8a // vldr s12, [pc, #552] .long 0xeeb07a4c // vmov.f32 s14, s24 .long 0xf2600dc4 // vsub.f32 q8, q8, q2 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xf3402dfe // vmul.f32 q9, q8, q15 .long 0xf3fb0762 // vcvt.s32.f32 q8, q9 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3604ee2 // vcgt.f32 q10, q8, q9 .long 0xf35841d4 // vbsl q10, q12, q2 .long 0xf2600de4 // vsub.f32 q8, q8, q10 .long 0xf2620de0 // vsub.f32 q8, q9, q8 .long 0xecc40b04 // vstmia r4, {d16-d17} .long 0xe28f3f71 // add r3, pc, #452 .long 0xf4634acf // vld1.64 {d20-d21}, [r3] .long 0xf2248de0 // vsub.f32 q4, q10, q8 .long 0xf2420176 // vand q8, q1, q11 .long 0xf2c3075f // vorr.i32 q8, #1056964608 .long 0xf3fb6642 // vcvt.f32.s32 q11, q1 .long 0xeec65a29 // vdiv.f32 s11, s12, s19 .long 0xee865a09 // vdiv.f32 s10, s12, s18 .long 0xec8d8b04 // vstmia sp, {d8-d9} .long 0xf2832654 // vmov.i32 q1, #872415232 .long 0xe28f3f6b // add r3, pc, #428 .long 0xeec64a28 // vdiv.f32 s9, s12, s17 .long 0xf2008dca // vadd.f32 q4, q8, q5 .long 0xf3466dd2 // vmul.f32 q11, q11, q1 .long 0xf3400dfc // vmul.f32 q8, q8, q14 .long 0xeec7da29 // vdiv.f32 s27, s14, s19 .long 0xee87da09 // vdiv.f32 s26, s14, s18 .long 0xeec7ca28 // vdiv.f32 s25, s14, s17 .long 0xee87ca08 // vdiv.f32 s24, s14, s16 .long 0xf2466dea // vadd.f32 q11, q11, q13 .long 0xf2660de0 // vsub.f32 q8, q11, q8 .long 0xf2600dcc // vsub.f32 q8, q8, q6 .long 0xf3406dfe // vmul.f32 q11, q8, q15 .long 0xf3fb0766 // vcvt.s32.f32 q8, q11 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3202ee6 // vcgt.f32 q1, q8, q11 .long 0xf31821de // vbsl q1, q12, q7 .long 0xf220e150 // vorr q7, q0, q0 .long 0xf2600dc2 // vsub.f32 q8, q8, q1 .long 0xf2870d5f // vmov.i32 q0, #8388607 .long 0xf20e0150 // vand q0, q7, q0 .long 0xf226cde0 // vsub.f32 q6, q11, q8 .long 0xf4630acf // vld1.64 {d16-d17}, [r3] .long 0xe28f3e16 // add r3, pc, #352 .long 0xf283075f // vorr.i32 q0, #1056964608 .long 0xf200ad4a // vadd.f32 q5, q0, q5 .long 0xf2248dcc // vsub.f32 q4, q10, q6 .long 0xf30ccd70 // vmul.f32 q6, q6, q8 .long 0xf340cd7c // vmul.f32 q14, q0, q14 .long 0xf3bb064e // vcvt.f32.s32 q0, q7 .long 0xeec63a29 // vdiv.f32 s7, s12, s19 .long 0xee863a09 // vdiv.f32 s6, s12, s18 .long 0xeec62a28 // vdiv.f32 s5, s12, s17 .long 0xee862a08 // vdiv.f32 s4, s12, s16 .long 0xf4238acf // vld1.64 {d8-d9}, [r3] .long 0xe28d3010 // add r3, sp, #16 .long 0xf2466dc8 // vadd.f32 q11, q11, q4 .long 0xf2422dc8 // vadd.f32 q9, q9, q4 .long 0xf2666dcc // vsub.f32 q11, q11, q6 .long 0xeec7da2b // vdiv.f32 s27, s14, s23 .long 0xee87da0b // vdiv.f32 s26, s14, s22 .long 0xeec7ca2a // vdiv.f32 s25, s14, s21 .long 0xee87ca0a // vdiv.f32 s24, s14, s20 .long 0xf283a654 // vmov.i32 q5, #872415232 .long 0xf3000d5a // vmul.f32 q0, q0, q5 .long 0xf240ad6a // vadd.f32 q13, q0, q13 .long 0xf2800050 // vmov.i32 q0, #0 .long 0xf26aadec // vsub.f32 q13, q13, q14 .long 0xf26aadcc // vsub.f32 q13, q13, q6 .long 0xf34aadfe // vmul.f32 q13, q13, q15 .long 0xf3fbc76a // vcvt.s32.f32 q14, q13 .long 0xf3fbc66c // vcvt.f32.s32 q14, q14 .long 0xf36ceeea // vcgt.f32 q15, q14, q13 .long 0xf358e1d0 // vbsl q15, q12, q0 .long 0xf26c8dee // vsub.f32 q12, q14, q15 .long 0xf26a8de8 // vsub.f32 q12, q13, q12 .long 0xf2240de8 // vsub.f32 q0, q10, q12 .long 0xf3484df0 // vmul.f32 q10, q12, q8 .long 0xf24a8dc8 // vadd.f32 q12, q13, q4 .long 0xf2c3a65f // vmov.i32 q13, #1056964608 .long 0xeec6da21 // vdiv.f32 s27, s12, s3 .long 0xee86da01 // vdiv.f32 s26, s12, s2 .long 0xeec6ca20 // vdiv.f32 s25, s12, s1 .long 0xee86ca00 // vdiv.f32 s24, s12, s0 .long 0xec9d0b04 // vldmia sp, {d0-d1} .long 0xf2684de4 // vsub.f32 q10, q12, q10 .long 0xee864a00 // vdiv.f32 s8, s12, s0 .long 0xecd38b04 // vldmia r3, {d24-d25} .long 0xe28d3020 // add r3, sp, #32 .long 0xf3480df0 // vmul.f32 q8, q12, q8 .long 0xec936b04 // vldmia r3, {d6-d7} .long 0xf2c3865f // vmov.i32 q12, #1056964608 .long 0xf2620de0 // vsub.f32 q8, q9, q8 .long 0xf2442dcc // vadd.f32 q9, q10, q6 .long 0xf2464dc2 // vadd.f32 q10, q11, q1 .long 0xf2400dc4 // vadd.f32 q8, q8, q2 .long 0xf2c4665b // vmov.i32 q11, #1258291200 .long 0xf242acf6 // vfma.f32 q13, q9, q11 .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xf2442cf6 // vfma.f32 q9, q10, q11 .long 0xf2408cf6 // vfma.f32 q12, q8, q11 .long 0xf3bb07ea // vcvt.u32.f32 q0, q13 .long 0xf3bb27e2 // vcvt.u32.f32 q1, q9 .long 0xf3bb47e8 // vcvt.u32.f32 q2, q12 .long 0xe28dd038 // add sp, sp, #56 .long 0xecbd8b10 // vpop {d8-d15} .long 0xe8bd0030 // pop {r4, r5} .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3eb444f9 // .word 0x3eb444f9 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0x3fbfbf75 // .word 0x3fbfbf75 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0xc2f87377 // .word 0xc2f87377 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x409af5f8 // .word 0x409af5f8 .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x3fbebc8d // .word 0x3fbebc8d .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x42f28c51 // .word 0x42f28c51 .long 0x3fdce9a3 // .word 0x3fdce9a3 .long 0x41ddd2fe // .word 0x41ddd2fe HIDDEN _sk_lab_to_xyz_vfp4 .globl _sk_lab_to_xyz_vfp4 FUNCTION(_sk_lab_to_xyz_vfp4) _sk_lab_to_xyz_vfp4: .long 0xed2d8b04 // vpush {d8-d9} .long 0xe28f20dc // add r2, pc, #220 .long 0xf3c46653 // vmov.i32 q11, #-1023410176 .long 0xf4620acf // vld1.64 {d16-d17}, [r2] .long 0xe28f20e0 // add r2, pc, #224 .long 0xf2c38f50 // vmov.f32 q12, #16 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf3424d70 // vmul.f32 q10, q1, q8 .long 0xf3440d70 // vmul.f32 q8, q2, q8 .long 0xe28f20dc // add r2, pc, #220 .long 0xf3402d72 // vmul.f32 q9, q0, q9 .long 0xf2444de6 // vadd.f32 q10, q10, q11 .long 0xf2422de8 // vadd.f32 q9, q9, q12 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xe28f20d8 // add r2, pc, #216 .long 0xf2400de6 // vadd.f32 q8, q8, q11 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe28f20dc // add r2, pc, #220 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xf3444dfa // vmul.f32 q10, q10, q13 .long 0xf3422df8 // vmul.f32 q9, q9, q12 .long 0xe28f20dc // add r2, pc, #220 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe28f20e4 // add r2, pc, #228 .long 0xf3400df6 // vmul.f32 q8, q8, q11 .long 0xf4228acf // vld1.64 {d8-d9}, [r2] .long 0xe28f20e8 // add r2, pc, #232 .long 0xf2424de4 // vadd.f32 q10, q9, q10 .long 0xf2620de0 // vsub.f32 q8, q9, q8 .long 0xf3428df2 // vmul.f32 q12, q9, q9 .long 0xf244edea // vadd.f32 q15, q10, q13 .long 0xf3446df4 // vmul.f32 q11, q10, q10 .long 0xf340cdf0 // vmul.f32 q14, q8, q8 .long 0xf3428df8 // vmul.f32 q12, q9, q12 .long 0xf2422dea // vadd.f32 q9, q9, q13 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf2406dea // vadd.f32 q11, q8, q13 .long 0xf3400dfc // vmul.f32 q8, q8, q14 .long 0xf462cacf // vld1.64 {d28-d29}, [r2] .long 0xf34eedd8 // vmul.f32 q15, q15, q4 .long 0xe28f20c0 // add r2, pc, #192 .long 0xf3240eec // vcgt.f32 q0, q10, q14 .long 0xf3282eec // vcgt.f32 q1, q12, q14 .long 0xf360aeec // vcgt.f32 q13, q8, q14 .long 0xf3466dd8 // vmul.f32 q11, q11, q4 .long 0xf31401fe // vbsl q0, q10, q15 .long 0xf4624acf // vld1.64 {d20-d21}, [r2] .long 0xe28f20b4 // add r2, pc, #180 .long 0xf350a1f6 // vbsl q13, q8, q11 .long 0xf4620acf // vld1.64 {d16-d17}, [r2] .long 0xf3000d74 // vmul.f32 q0, q0, q10 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf30a4df0 // vmul.f32 q2, q13, q8 .long 0xf3420dd8 // vmul.f32 q8, q9, q4 .long 0xf31821f0 // vbsl q1, q12, q8 .long 0xecbd8b04 // vpop {d8-d9} .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x42c80000 // .word 0x42c80000 .long 0x42c80000 // .word 0x42c80000 .long 0x42c80000 // .word 0x42c80000 .long 0x42c80000 // .word 0x42c80000 .long 0x3c0d3dcb // .word 0x3c0d3dcb .long 0x3c0d3dcb // .word 0x3c0d3dcb .long 0x3c0d3dcb // .word 0x3c0d3dcb .long 0x3c0d3dcb // .word 0x3c0d3dcb .long 0x3b03126f // .word 0x3b03126f .long 0x3b03126f // .word 0x3b03126f .long 0x3b03126f // .word 0x3b03126f .long 0x3b03126f // .word 0x3b03126f .long 0x3ba3d70a // .word 0x3ba3d70a .long 0x3ba3d70a // .word 0x3ba3d70a .long 0x3ba3d70a // .word 0x3ba3d70a .long 0x3ba3d70a // .word 0x3ba3d70a .long 0xbe0d3dcb // .word 0xbe0d3dcb .long 0xbe0d3dcb // .word 0xbe0d3dcb .long 0xbe0d3dcb // .word 0xbe0d3dcb .long 0xbe0d3dcb // .word 0xbe0d3dcb .long 0x3e038050 // .word 0x3e038050 .long 0x3e038050 // .word 0x3e038050 .long 0x3e038050 // .word 0x3e038050 .long 0x3e038050 // .word 0x3e038050 .long 0x3c1118c2 // .word 0x3c1118c2 .long 0x3c1118c2 // .word 0x3c1118c2 .long 0x3c1118c2 // .word 0x3c1118c2 .long 0x3c1118c2 // .word 0x3c1118c2 .long 0x3f76d71f // .word 0x3f76d71f .long 0x3f76d71f // .word 0x3f76d71f .long 0x3f76d71f // .word 0x3f76d71f .long 0x3f76d71f // .word 0x3f76d71f .long 0x3f5340f6 // .word 0x3f5340f6 .long 0x3f5340f6 // .word 0x3f5340f6 .long 0x3f5340f6 // .word 0x3f5340f6 .long 0x3f5340f6 // .word 0x3f5340f6 HIDDEN _sk_load_a8_vfp4 .globl _sk_load_a8_vfp4 FUNCTION(_sk_load_a8_vfp4) _sk_load_a8_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe24dd008 // sub sp, sp, #8 .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0224392 // mla r2, r2, r3, r4 .long 0xe082200e // add r2, r2, lr .long 0x1a000012 // bne 3c28 .long 0xe5922000 // ldr r2, [r2] .long 0xe58d2000 // str r2, [sp] .long 0xe1a0200d // mov r2, sp .long 0xf4e2083f // vld1.32 {d16[0]}, [r2 :32] .long 0xf3c80a30 // vmovl.u8 q8, d16 .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xe28f209c // add r2, pc, #156 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf2800050 // vmov.i32 q0, #0 .long 0xf2802050 // vmov.i32 q1, #0 .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3006df2 // vmul.f32 q3, q8, q9 .long 0xe28dd008 // add sp, sp, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a000012 // beq 3c80 .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3530002 // cmp r3, #2 .long 0x0a000005 // beq 3c58 .long 0xe3530003 // cmp r3, #3 .long 0x1affffe9 // bne 3bf0 .long 0xe3a04000 // mov r4, #0 .long 0xe5d23002 // ldrb r3, [r2, #2] .long 0xee804bb0 // vdup.16 d16, r4 .long 0xee203bb0 // vmov.16 d16[2], r3 .long 0xe1d220b0 // ldrh r2, [r2] .long 0xe1cd20b4 // strh r2, [sp, #4] .long 0xe28d2004 // add r2, sp, #4 .long 0xf4e2241f // vld1.16 {d18[0]}, [r2 :16] .long 0xf3c82a32 // vmovl.u8 q9, d18 .long 0xf3d02a32 // vmovl.u16 q9, d18 .long 0xf3f62124 // vuzp.16 d18, d20 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffdb // b 3bf0 .long 0xe3a03000 // mov r3, #0 .long 0xe5d22000 // ldrb r2, [r2] .long 0xee803bb0 // vdup.16 d16, r3 .long 0xee002bb0 // vmov.16 d16[0], r2 .long 0xeaffffd6 // b 3bf0 .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_load_a8_dst_vfp4 .globl _sk_load_a8_dst_vfp4 FUNCTION(_sk_load_a8_dst_vfp4) _sk_load_a8_dst_vfp4: .long 0xe92d4830 // push {r4, r5, fp, lr} .long 0xe24dd008 // sub sp, sp, #8 .long 0xe5913000 // ldr r3, [r1] .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe590c000 // ldr ip, [r0] .long 0xe2805030 // add r5, r0, #48 .long 0xe9904004 // ldmib r0, {r2, lr} .long 0xe5934000 // ldr r4, [r3] .long 0xe35e0000 // cmp lr, #0 .long 0xe5933004 // ldr r3, [r3, #4] .long 0xf4450aef // vst1.64 {d16-d17}, [r5 :128] .long 0xe0224293 // mla r2, r3, r2, r4 .long 0xe2803020 // add r3, r0, #32 .long 0xf4430aef // vst1.64 {d16-d17}, [r3 :128] .long 0xe2803010 // add r3, r0, #16 .long 0xf4430aef // vst1.64 {d16-d17}, [r3 :128] .long 0xe082300c // add r3, r2, ip .long 0xe280c040 // add ip, r0, #64 .long 0x1a000011 // bne 3d3c .long 0xe5932000 // ldr r2, [r3] .long 0xe58d2000 // str r2, [sp] .long 0xe1a0200d // mov r2, sp .long 0xf4e2083f // vld1.32 {d16[0]}, [r2 :32] .long 0xf3c80a30 // vmovl.u8 q8, d16 .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xe28f2094 // add r2, pc, #148 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3400df2 // vmul.f32 q8, q8, q9 .long 0xf44c0aef // vst1.64 {d16-d17}, [ip :128] .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe28dd008 // add sp, sp, #8 .long 0xe8bd4830 // pop {r4, r5, fp, lr} .long 0xe12fff13 // bx r3 .long 0xe20e2003 // and r2, lr, #3 .long 0xe3520001 // cmp r2, #1 .long 0x0a000012 // beq 3d94 .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3520002 // cmp r2, #2 .long 0x0a000005 // beq 3d6c .long 0xe3520003 // cmp r2, #3 .long 0x1affffea // bne 3d08 .long 0xe3a05000 // mov r5, #0 .long 0xe5d32002 // ldrb r2, [r3, #2] .long 0xee805bb0 // vdup.16 d16, r5 .long 0xee202bb0 // vmov.16 d16[2], r2 .long 0xe1d320b0 // ldrh r2, [r3] .long 0xe1cd20b4 // strh r2, [sp, #4] .long 0xe28d2004 // add r2, sp, #4 .long 0xf4e2241f // vld1.16 {d18[0]}, [r2 :16] .long 0xf3c82a32 // vmovl.u8 q9, d18 .long 0xf3d02a32 // vmovl.u16 q9, d18 .long 0xf3f62124 // vuzp.16 d18, d20 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffdc // b 3d08 .long 0xe5d32000 // ldrb r2, [r3] .long 0xe3a03000 // mov r3, #0 .long 0xee803bb0 // vdup.16 d16, r3 .long 0xee002bb0 // vmov.16 d16[0], r2 .long 0xeaffffd7 // b 3d08 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_gather_a8_vfp4 .globl _sk_gather_a8_vfp4 FUNCTION(_sk_gather_a8_vfp4) _sk_gather_a8_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf3fb0742 // vcvt.s32.f32 q8, q1 .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb2740 // vcvt.s32.f32 q9, q0 .long 0xe4932004 // ldr r2, [r3], #4 .long 0xf2800050 // vmov.i32 q0, #0 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xf2802050 // vmov.i32 q1, #0 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xf26429e0 // vmla.i32 q9, q10, q8 .long 0xee123b90 // vmov.32 r3, d18[0] .long 0xee32eb90 // vmov.32 lr, d18[1] .long 0xee134b90 // vmov.32 r4, d19[0] .long 0xee336b90 // vmov.32 r6, d19[1] .long 0xe7d23003 // ldrb r3, [r2, r3] .long 0xe7d2500e // ldrb r5, [r2, lr] .long 0xee003bb0 // vmov.16 d16[0], r3 .long 0xe7d23004 // ldrb r3, [r2, r4] .long 0xe7d22006 // ldrb r2, [r2, r6] .long 0xee005bf0 // vmov.16 d16[1], r5 .long 0xee203bb0 // vmov.16 d16[2], r3 .long 0xee202bf0 // vmov.16 d16[3], r2 .long 0xe28f201c // add r2, pc, #28 .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3006df2 // vmul.f32 q3, q8, q9 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff1c // bx ip .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_store_a8_vfp4 .globl _sk_store_a8_vfp4 FUNCTION(_sk_store_a8_vfp4) _sk_store_a8_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe28f2094 // add r2, pc, #148 .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf2460c72 // vfma.f32 q8, q3, q9 .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xf3fb07e0 // vcvt.u32.f32 q8, q8 .long 0xe0224392 // mla r2, r2, r3, r4 .long 0xe082200e // add r2, r2, lr .long 0xf3f60220 // vmovn.i32 d16, q8 .long 0x1a000005 // bne 3ea0 .long 0xf3f20121 // vuzp.8 d16, d17 .long 0xf4c2080f // vst1.32 {d16[0]}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a00000a // beq 3ed8 .long 0xe3530002 // cmp r3, #2 .long 0x0a000003 // beq 3ec4 .long 0xe3530003 // cmp r3, #3 .long 0x1afffff4 // bne 3e90 .long 0xeeb03bb0 // vmov.u16 r3, d16[2] .long 0xe5c23002 // strb r3, [r2, #2] .long 0xee903bf0 // vmov.u16 r3, d16[1] .long 0xee904bb0 // vmov.u16 r4, d16[0] .long 0xe5c23001 // strb r3, [r2, #1] .long 0xe5c24000 // strb r4, [r2] .long 0xeaffffed // b 3e90 .long 0xee903bb0 // vmov.u16 r3, d16[0] .long 0xe5c23000 // strb r3, [r2] .long 0xeaffffea // b 3e90 .long 0xe320f000 // nop {0} .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 HIDDEN _sk_load_g8_vfp4 .globl _sk_load_g8_vfp4 FUNCTION(_sk_load_g8_vfp4) _sk_load_g8_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe24dd008 // sub sp, sp, #8 .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0224392 // mla r2, r2, r3, r4 .long 0xe082200e // add r2, r2, lr .long 0x1a000013 // bne 3f74 .long 0xe5922000 // ldr r2, [r2] .long 0xe58d2000 // str r2, [sp] .long 0xe1a0200d // mov r2, sp .long 0xf4e2083f // vld1.32 {d16[0]}, [r2 :32] .long 0xf3c80a30 // vmovl.u8 q8, d16 .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xe28f209c // add r2, pc, #156 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xe28f20a4 // add r2, pc, #164 .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf4226acf // vld1.64 {d6-d7}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3000df2 // vmul.f32 q0, q8, q9 .long 0xf2202150 // vorr q1, q0, q0 .long 0xf2204150 // vorr q2, q0, q0 .long 0xe28dd008 // add sp, sp, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a000012 // beq 3fcc .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3530002 // cmp r3, #2 .long 0x0a000005 // beq 3fa4 .long 0xe3530003 // cmp r3, #3 .long 0x1affffe8 // bne 3f38 .long 0xe3a04000 // mov r4, #0 .long 0xe5d23002 // ldrb r3, [r2, #2] .long 0xee804bb0 // vdup.16 d16, r4 .long 0xee203bb0 // vmov.16 d16[2], r3 .long 0xe1d220b0 // ldrh r2, [r2] .long 0xe1cd20b4 // strh r2, [sp, #4] .long 0xe28d2004 // add r2, sp, #4 .long 0xf4e2241f // vld1.16 {d18[0]}, [r2 :16] .long 0xf3c82a32 // vmovl.u8 q9, d18 .long 0xf3d02a32 // vmovl.u16 q9, d18 .long 0xf3f62124 // vuzp.16 d18, d20 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffda // b 3f38 .long 0xe3a03000 // mov r3, #0 .long 0xe5d22000 // ldrb r2, [r2] .long 0xee803bb0 // vdup.16 d16, r3 .long 0xee002bb0 // vmov.16 d16[0], r2 .long 0xeaffffd5 // b 3f38 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_load_g8_dst_vfp4 .globl _sk_load_g8_dst_vfp4 FUNCTION(_sk_load_g8_dst_vfp4) _sk_load_g8_dst_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe24dd008 // sub sp, sp, #8 .long 0xe5912000 // ldr r2, [r1] .long 0xe280c040 // add ip, r0, #64 .long 0xe8900058 // ldm r0, {r3, r4, r6} .long 0xe280e030 // add lr, r0, #48 .long 0xe5925000 // ldr r5, [r2] .long 0xe3560000 // cmp r6, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0225492 // mla r2, r2, r4, r5 .long 0xe0824003 // add r4, r2, r3 .long 0xe2802020 // add r2, r0, #32 .long 0xe2803010 // add r3, r0, #16 .long 0x1a000015 // bne 4090 .long 0xe5944000 // ldr r4, [r4] .long 0xe58d4000 // str r4, [sp] .long 0xe1a0400d // mov r4, sp .long 0xf4e4083f // vld1.32 {d16[0]}, [r4 :32] .long 0xf3c80a30 // vmovl.u8 q8, d16 .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xe28f40a8 // add r4, pc, #168 .long 0xf4642acf // vld1.64 {d18-d19}, [r4] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3400df2 // vmul.f32 q8, q8, q9 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf44e0aef // vst1.64 {d16-d17}, [lr :128] .long 0xf4420aef // vst1.64 {d16-d17}, [r2 :128] .long 0xe2812008 // add r2, r1, #8 .long 0xf4430aef // vst1.64 {d16-d17}, [r3 :128] .long 0xf44c2aef // vst1.64 {d18-d19}, [ip :128] .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe28dd008 // add sp, sp, #8 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff13 // bx r3 .long 0xe2065003 // and r5, r6, #3 .long 0xe3550001 // cmp r5, #1 .long 0x0a000012 // beq 40e8 .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3550002 // cmp r5, #2 .long 0x0a000005 // beq 40c0 .long 0xe3550003 // cmp r5, #3 .long 0x1affffe6 // bne 404c .long 0xe3a06000 // mov r6, #0 .long 0xe5d45002 // ldrb r5, [r4, #2] .long 0xee806bb0 // vdup.16 d16, r6 .long 0xee205bb0 // vmov.16 d16[2], r5 .long 0xe1d440b0 // ldrh r4, [r4] .long 0xe1cd40b4 // strh r4, [sp, #4] .long 0xe28d4004 // add r4, sp, #4 .long 0xf4e4241f // vld1.16 {d18[0]}, [r4 :16] .long 0xf3c82a32 // vmovl.u8 q9, d18 .long 0xf3d02a32 // vmovl.u16 q9, d18 .long 0xf3f62124 // vuzp.16 d18, d20 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffd8 // b 404c .long 0xe3a05000 // mov r5, #0 .long 0xe5d44000 // ldrb r4, [r4] .long 0xee805bb0 // vdup.16 d16, r5 .long 0xee004bb0 // vmov.16 d16[0], r4 .long 0xeaffffd3 // b 404c .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_gather_g8_vfp4 .globl _sk_gather_g8_vfp4 FUNCTION(_sk_gather_g8_vfp4) _sk_gather_g8_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf3fb0742 // vcvt.s32.f32 q8, q1 .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb2740 // vcvt.s32.f32 q9, q0 .long 0xe4932004 // ldr r2, [r3], #4 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xf26429e0 // vmla.i32 q9, q10, q8 .long 0xee123b90 // vmov.32 r3, d18[0] .long 0xee32eb90 // vmov.32 lr, d18[1] .long 0xee134b90 // vmov.32 r4, d19[0] .long 0xee336b90 // vmov.32 r6, d19[1] .long 0xe7d23003 // ldrb r3, [r2, r3] .long 0xe7d2500e // ldrb r5, [r2, lr] .long 0xee003bb0 // vmov.16 d16[0], r3 .long 0xe7d23004 // ldrb r3, [r2, r4] .long 0xe7d22006 // ldrb r2, [r2, r6] .long 0xee005bf0 // vmov.16 d16[1], r5 .long 0xee203bb0 // vmov.16 d16[2], r3 .long 0xee202bf0 // vmov.16 d16[3], r2 .long 0xe28f2028 // add r2, pc, #40 .long 0xf3c70b3f // vbic.i16 d16, #65280 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xe28f202c // add r2, pc, #44 .long 0xf4226acf // vld1.64 {d6-d7}, [r2] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3000df2 // vmul.f32 q0, q8, q9 .long 0xf2202150 // vorr q1, q0, q0 .long 0xf2204150 // vorr q2, q0, q0 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff1c // bx ip .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_load_565_vfp4 .globl _sk_load_565_vfp4 FUNCTION(_sk_load_565_vfp4) _sk_load_565_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe24dd004 // sub sp, sp, #4 .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020392 // mul r2, r2, r3 .long 0xe0842082 // add r2, r4, r2, lsl #1 .long 0xe082208e // add r2, r2, lr, lsl #1 .long 0x1a00001b // bne 4250 .long 0xf462074f // vld1.16 {d16}, [r2] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xe3a02e7e // mov r2, #2016 .long 0xf3c74258 // vmov.i32 q10, #63488 .long 0xeea22b90 // vdup.32 q9, r2 .long 0xf2c1605f // vmov.i32 q11, #31 .long 0xe28f20b8 // add r2, pc, #184 .long 0xf24021f2 // vand q9, q8, q9 .long 0xf24041f4 // vand q10, q8, q10 .long 0xf24001f6 // vand q8, q8, q11 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xe28f20b0 // add r2, pc, #176 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xe28f20b8 // add r2, pc, #184 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe28f20bc // add r2, pc, #188 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf4226acf // vld1.64 {d6-d7}, [r2] .long 0xf3040df6 // vmul.f32 q0, q10, q11 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf3022df8 // vmul.f32 q1, q9, q12 .long 0xe2811008 // add r1, r1, #8 .long 0xf3004dfa // vmul.f32 q2, q8, q13 .long 0xe28dd004 // add sp, sp, #4 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a000011 // beq 42a4 .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3530002 // cmp r3, #2 .long 0x0a000005 // beq 4280 .long 0xe3530003 // cmp r3, #3 .long 0x1affffdc // bne 41e4 .long 0xe3a03000 // mov r3, #0 .long 0xee803bb0 // vdup.16 d16, r3 .long 0xe2823004 // add r3, r2, #4 .long 0xf4e3049f // vld1.16 {d16[2]}, [r3 :16] .long 0xe5922000 // ldr r2, [r2] .long 0xe58d2000 // str r2, [sp] .long 0xe1a0200d // mov r2, sp .long 0xf4e2183f // vld1.32 {d17[0]}, [r2 :32] .long 0xf3d02a31 // vmovl.u16 q9, d17 .long 0xf3f62121 // vuzp.16 d18, d17 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffcf // b 41e4 .long 0xe3a03000 // mov r3, #0 .long 0xee803bb0 // vdup.16 d16, r3 .long 0xf4e2041f // vld1.16 {d16[0]}, [r2 :16] .long 0xeaffffcb // b 41e4 .long 0xe320f000 // nop {0} .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_load_565_dst_vfp4 .globl _sk_load_565_dst_vfp4 FUNCTION(_sk_load_565_dst_vfp4) _sk_load_565_dst_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe24dd004 // sub sp, sp, #4 .long 0xe5912000 // ldr r2, [r1] .long 0xe280c040 // add ip, r0, #64 .long 0xe8900058 // ldm r0, {r3, r4, r6} .long 0xe280e030 // add lr, r0, #48 .long 0xe5925000 // ldr r5, [r2] .long 0xe3560000 // cmp r6, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020492 // mul r2, r2, r4 .long 0xe0852082 // add r2, r5, r2, lsl #1 .long 0xe0824083 // add r4, r2, r3, lsl #1 .long 0xe2802020 // add r2, r0, #32 .long 0xe2803010 // add r3, r0, #16 .long 0x1a00001f // bne 43b4 .long 0xf464074f // vld1.16 {d16}, [r4] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xe3a04e7e // mov r4, #2016 .long 0xf3c72258 // vmov.i32 q9, #63488 .long 0xeea44b90 // vdup.32 q10, r4 .long 0xf2c1605f // vmov.i32 q11, #31 .long 0xe28f40c4 // add r4, pc, #196 .long 0xf24021f2 // vand q9, q8, q9 .long 0xf24041f4 // vand q10, q8, q10 .long 0xf24001f6 // vand q8, q8, q11 .long 0xf4646acf // vld1.64 {d22-d23}, [r4] .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xe28f40bc // add r4, pc, #188 .long 0xf4648acf // vld1.64 {d24-d25}, [r4] .long 0xe28f40c4 // add r4, pc, #196 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3422df6 // vmul.f32 q9, q9, q11 .long 0xf4646acf // vld1.64 {d22-d23}, [r4] .long 0xf3444df8 // vmul.f32 q10, q10, q12 .long 0xf3400df6 // vmul.f32 q8, q8, q11 .long 0xf2c76f50 // vmov.f32 q11, #1 .long 0xf4432aef // vst1.64 {d18-d19}, [r3 :128] .long 0xf4424aef // vst1.64 {d20-d21}, [r2 :128] .long 0xe2812008 // add r2, r1, #8 .long 0xf44e0aef // vst1.64 {d16-d17}, [lr :128] .long 0xf44c6aef // vst1.64 {d22-d23}, [ip :128] .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe28dd004 // add sp, sp, #4 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff13 // bx r3 .long 0xe2065003 // and r5, r6, #3 .long 0xe3550001 // cmp r5, #1 .long 0x0a000011 // beq 4408 .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3550002 // cmp r5, #2 .long 0x0a000005 // beq 43e4 .long 0xe3550003 // cmp r5, #3 .long 0x1affffd8 // bne 4338 .long 0xe3a05000 // mov r5, #0 .long 0xee805bb0 // vdup.16 d16, r5 .long 0xe2845004 // add r5, r4, #4 .long 0xf4e5049f // vld1.16 {d16[2]}, [r5 :16] .long 0xe5944000 // ldr r4, [r4] .long 0xe58d4000 // str r4, [sp] .long 0xe1a0400d // mov r4, sp .long 0xf4e4183f // vld1.32 {d17[0]}, [r4 :32] .long 0xf3d02a31 // vmovl.u16 q9, d17 .long 0xf3f62121 // vuzp.16 d18, d17 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffcb // b 4338 .long 0xe3a05000 // mov r5, #0 .long 0xee805bb0 // vdup.16 d16, r5 .long 0xf4e4041f // vld1.16 {d16[0]}, [r4 :16] .long 0xeaffffc7 // b 4338 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 HIDDEN _sk_gather_565_vfp4 .globl _sk_gather_565_vfp4 FUNCTION(_sk_gather_565_vfp4) _sk_gather_565_vfp4: .long 0xe92d4830 // push {r4, r5, fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf3fb0742 // vcvt.s32.f32 q8, q1 .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb2740 // vcvt.s32.f32 q9, q0 .long 0xe4932004 // ldr r2, [r3], #4 .long 0xf2c1605f // vmov.i32 q11, #31 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xf26429e0 // vmla.i32 q9, q10, q8 .long 0xf3c74258 // vmov.i32 q10, #63488 .long 0xee123b90 // vmov.32 r3, d18[0] .long 0xee324b90 // vmov.32 r4, d18[1] .long 0xee13eb90 // vmov.32 lr, d19[0] .long 0xee335b90 // vmov.32 r5, d19[1] .long 0xe0823083 // add r3, r2, r3, lsl #1 .long 0xe0824084 // add r4, r2, r4, lsl #1 .long 0xf4e3041f // vld1.16 {d16[0]}, [r3 :16] .long 0xe082308e // add r3, r2, lr, lsl #1 .long 0xe0822085 // add r2, r2, r5, lsl #1 .long 0xf4e4045f // vld1.16 {d16[1]}, [r4 :16] .long 0xe1d330b0 // ldrh r3, [r3] .long 0xe1d220b0 // ldrh r2, [r2] .long 0xee203bb0 // vmov.16 d16[2], r3 .long 0xee202bf0 // vmov.16 d16[3], r2 .long 0xe3a02e7e // mov r2, #2016 .long 0xeea22b90 // vdup.32 q9, r2 .long 0xe28f2048 // add r2, pc, #72 .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf24021f2 // vand q9, q8, q9 .long 0xf24041f4 // vand q10, q8, q10 .long 0xf24001f6 // vand q8, q8, q11 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xe28f203c // add r2, pc, #60 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xe28f2044 // add r2, pc, #68 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe28f2048 // add r2, pc, #72 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf4226acf // vld1.64 {d6-d7}, [r2] .long 0xf3040df6 // vmul.f32 q0, q10, q11 .long 0xf3022df8 // vmul.f32 q1, q9, q12 .long 0xf3004dfa // vmul.f32 q2, q8, q13 .long 0xe8bd4830 // pop {r4, r5, fp, lr} .long 0xe12fff1c // bx ip .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x37842108 // .word 0x37842108 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3a020821 // .word 0x3a020821 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3d042108 // .word 0x3d042108 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_store_565_vfp4 .globl _sk_store_565_vfp4 FUNCTION(_sk_store_565_vfp4) _sk_store_565_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe28f20c4 // add r2, pc, #196 .long 0xf2c30f5f // vmov.f32 q8, #31 .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xf2c3865f // vmov.i32 q12, #1056964608 .long 0xf2404c70 // vfma.f32 q10, q0, q8 .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xf2428c76 // vfma.f32 q12, q1, q11 .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xe5924000 // ldr r4, [r2] .long 0xf2442c70 // vfma.f32 q9, q2, q8 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe35c0000 // cmp ip, #0 .long 0xe0020392 // mul r2, r2, r3 .long 0xf3fb07e4 // vcvt.u32.f32 q8, q10 .long 0xf3fb47e8 // vcvt.u32.f32 q10, q12 .long 0xf3fb27e2 // vcvt.u32.f32 q9, q9 .long 0xe0842082 // add r2, r4, r2, lsl #1 .long 0xe082208e // add r2, r2, lr, lsl #1 .long 0xf2eb0570 // vshl.s32 q8, q8, #11 .long 0xf2e54574 // vshl.s32 q10, q10, #5 .long 0xf26401f0 // vorr q8, q10, q8 .long 0xf26001f2 // vorr q8, q8, q9 .long 0xf3f60220 // vmovn.i32 d16, q8 .long 0x1a000004 // bne 45c4 .long 0xf442074f // vst1.16 {d16}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a00000c // beq 4604 .long 0xe3530002 // cmp r3, #2 .long 0x0a000003 // beq 45e8 .long 0xe3530003 // cmp r3, #3 .long 0x1afffff4 // bne 45b4 .long 0xe2823004 // add r3, r2, #4 .long 0xf4c3049f // vst1.16 {d16[2]}, [r3 :16] .long 0xee903bb0 // vmov.u16 r3, d16[0] .long 0xee904bf0 // vmov.u16 r4, d16[1] .long 0xee003b90 // vmov.32 d16[0], r3 .long 0xee204b90 // vmov.32 d16[1], r4 .long 0xf3f60121 // vuzp.16 d16, d17 .long 0xf4c2080f // vst1.32 {d16[0]}, [r2] .long 0xeaffffeb // b 45b4 .long 0xf4c2041f // vst1.16 {d16[0]}, [r2 :16] .long 0xeaffffe9 // b 45b4 .long 0xe320f000 // nop {0} .long 0x427c0000 // .word 0x427c0000 .long 0x427c0000 // .word 0x427c0000 .long 0x427c0000 // .word 0x427c0000 .long 0x427c0000 // .word 0x427c0000 HIDDEN _sk_load_4444_vfp4 .globl _sk_load_4444_vfp4 FUNCTION(_sk_load_4444_vfp4) _sk_load_4444_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe24dd004 // sub sp, sp, #4 .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020392 // mul r2, r2, r3 .long 0xe0842082 // add r2, r4, r2, lsl #1 .long 0xe082208e // add r2, r2, lr, lsl #1 .long 0x1a00001e // bne 46cc .long 0xf462074f // vld1.16 {d16}, [r2] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xe28f20d0 // add r2, pc, #208 .long 0xf3c72250 // vmov.i32 q9, #61440 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xf3c74050 // vmov.i32 q10, #240 .long 0xe28f20d0 // add r2, pc, #208 .long 0xf24021f2 // vand q9, q8, q9 .long 0xf2c0625f // vmov.i32 q11, #3840 .long 0xf2c0805f // vmov.i32 q12, #15 .long 0xf24041f4 // vand q10, q8, q10 .long 0xf24061f6 // vand q11, q8, q11 .long 0xf24001f8 // vand q8, q8, q12 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xe28f20bc // add r2, pc, #188 .long 0xf462cacf // vld1.64 {d28-d29}, [r2] .long 0xe28f20c4 // add r2, pc, #196 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3020df8 // vmul.f32 q0, q9, q12 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf3062dfc // vmul.f32 q1, q11, q14 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf3044dfa // vmul.f32 q2, q10, q13 .long 0xf3006df2 // vmul.f32 q3, q8, q9 .long 0xe2811008 // add r1, r1, #8 .long 0xe28dd004 // add sp, sp, #4 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a000011 // beq 4720 .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3530002 // cmp r3, #2 .long 0x0a000005 // beq 46fc .long 0xe3530003 // cmp r3, #3 .long 0x1affffd9 // bne 4654 .long 0xe3a03000 // mov r3, #0 .long 0xee803bb0 // vdup.16 d16, r3 .long 0xe2823004 // add r3, r2, #4 .long 0xf4e3049f // vld1.16 {d16[2]}, [r3 :16] .long 0xe5922000 // ldr r2, [r2] .long 0xe58d2000 // str r2, [sp] .long 0xe1a0200d // mov r2, sp .long 0xf4e2183f // vld1.32 {d17[0]}, [r2 :32] .long 0xf3d02a31 // vmovl.u16 q9, d17 .long 0xf3f62121 // vuzp.16 d18, d17 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffcc // b 4654 .long 0xe3a03000 // mov r3, #0 .long 0xee803bb0 // vdup.16 d16, r3 .long 0xf4e2041f // vld1.16 {d16[0]}, [r2 :16] .long 0xeaffffc8 // b 4654 .long 0x3b888889 // .word 0x3b888889 .long 0x3b888889 // .word 0x3b888889 .long 0x3b888889 // .word 0x3b888889 .long 0x3b888889 // .word 0x3b888889 .long 0x37888889 // .word 0x37888889 .long 0x37888889 // .word 0x37888889 .long 0x37888889 // .word 0x37888889 .long 0x37888889 // .word 0x37888889 .long 0x39888889 // .word 0x39888889 .long 0x39888889 // .word 0x39888889 .long 0x39888889 // .word 0x39888889 .long 0x39888889 // .word 0x39888889 .long 0x3d888889 // .word 0x3d888889 .long 0x3d888889 // .word 0x3d888889 .long 0x3d888889 // .word 0x3d888889 .long 0x3d888889 // .word 0x3d888889 HIDDEN _sk_load_4444_dst_vfp4 .globl _sk_load_4444_dst_vfp4 FUNCTION(_sk_load_4444_dst_vfp4) _sk_load_4444_dst_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe24dd004 // sub sp, sp, #4 .long 0xe5912000 // ldr r2, [r1] .long 0xe280c040 // add ip, r0, #64 .long 0xe8900058 // ldm r0, {r3, r4, r6} .long 0xe280e030 // add lr, r0, #48 .long 0xe5925000 // ldr r5, [r2] .long 0xe3560000 // cmp r6, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020492 // mul r2, r2, r4 .long 0xe0852082 // add r2, r5, r2, lsl #1 .long 0xe0824083 // add r4, r2, r3, lsl #1 .long 0xe2802020 // add r2, r0, #32 .long 0xe2803010 // add r3, r0, #16 .long 0x1a000023 // bne 483c .long 0xf464074f // vld1.16 {d16}, [r4] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xe28f40e4 // add r4, pc, #228 .long 0xf3c72250 // vmov.i32 q9, #61440 .long 0xf464aacf // vld1.64 {d26-d27}, [r4] .long 0xf2c0425f // vmov.i32 q10, #3840 .long 0xe28f40e4 // add r4, pc, #228 .long 0xf24021f2 // vand q9, q8, q9 .long 0xf24041f4 // vand q10, q8, q10 .long 0xf3c76050 // vmov.i32 q11, #240 .long 0xf2c0805f // vmov.i32 q12, #15 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf24061f6 // vand q11, q8, q11 .long 0xf24001f8 // vand q8, q8, q12 .long 0xf4648acf // vld1.64 {d24-d25}, [r4] .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xe28f40cc // add r4, pc, #204 .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3422dfa // vmul.f32 q9, q9, q13 .long 0xf464aacf // vld1.64 {d26-d27}, [r4] .long 0xe28f40c8 // add r4, pc, #200 .long 0xf3444df8 // vmul.f32 q10, q10, q12 .long 0xf4648acf // vld1.64 {d24-d25}, [r4] .long 0xf3466dfa // vmul.f32 q11, q11, q13 .long 0xf3400df8 // vmul.f32 q8, q8, q12 .long 0xf4432aef // vst1.64 {d18-d19}, [r3 :128] .long 0xf4424aef // vst1.64 {d20-d21}, [r2 :128] .long 0xe2812008 // add r2, r1, #8 .long 0xf44e6aef // vst1.64 {d22-d23}, [lr :128] .long 0xf44c0aef // vst1.64 {d16-d17}, [ip :128] .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe28dd004 // add sp, sp, #4 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff13 // bx r3 .long 0xe2065003 // and r5, r6, #3 .long 0xe3550001 // cmp r5, #1 .long 0x0a000011 // beq 4890 .long 0xf2c00010 // vmov.i32 d16, #0 .long 0xe3550002 // cmp r5, #2 .long 0x0a000005 // beq 486c .long 0xe3550003 // cmp r5, #3 .long 0x1affffd4 // bne 47b0 .long 0xe3a05000 // mov r5, #0 .long 0xee805bb0 // vdup.16 d16, r5 .long 0xe2845004 // add r5, r4, #4 .long 0xf4e5049f // vld1.16 {d16[2]}, [r5 :16] .long 0xe5944000 // ldr r4, [r4] .long 0xe58d4000 // str r4, [sp] .long 0xe1a0400d // mov r4, sp .long 0xf4e4183f // vld1.32 {d17[0]}, [r4 :32] .long 0xf3d02a31 // vmovl.u16 q9, d17 .long 0xf3f62121 // vuzp.16 d18, d17 .long 0xf2f004a2 // vext.8 d16, d16, d18, #4 .long 0xf2f004a0 // vext.8 d16, d16, d16, #4 .long 0xeaffffc7 // b 47b0 .long 0xe3a05000 // mov r5, #0 .long 0xee805bb0 // vdup.16 d16, r5 .long 0xf4e4041f // vld1.16 {d16[0]}, [r4 :16] .long 0xeaffffc3 // b 47b0 .long 0x37888889 // .word 0x37888889 .long 0x37888889 // .word 0x37888889 .long 0x37888889 // .word 0x37888889 .long 0x37888889 // .word 0x37888889 .long 0x39888889 // .word 0x39888889 .long 0x39888889 // .word 0x39888889 .long 0x39888889 // .word 0x39888889 .long 0x39888889 // .word 0x39888889 .long 0x3b888889 // .word 0x3b888889 .long 0x3b888889 // .word 0x3b888889 .long 0x3b888889 // .word 0x3b888889 .long 0x3b888889 // .word 0x3b888889 .long 0x3d888889 // .word 0x3d888889 .long 0x3d888889 // .word 0x3d888889 .long 0x3d888889 // .word 0x3d888889 .long 0x3d888889 // .word 0x3d888889 HIDDEN _sk_gather_4444_vfp4 .globl _sk_gather_4444_vfp4 FUNCTION(_sk_gather_4444_vfp4) _sk_gather_4444_vfp4: .long 0xe92d4830 // push {r4, r5, fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf3fb0742 // vcvt.s32.f32 q8, q1 .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb2740 // vcvt.s32.f32 q9, q0 .long 0xe4932004 // ldr r2, [r3], #4 .long 0xf2c0625f // vmov.i32 q11, #3840 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xf2c0805f // vmov.i32 q12, #15 .long 0xf26429e0 // vmla.i32 q9, q10, q8 .long 0xf3c74050 // vmov.i32 q10, #240 .long 0xee123b90 // vmov.32 r3, d18[0] .long 0xee324b90 // vmov.32 r4, d18[1] .long 0xee13eb90 // vmov.32 lr, d19[0] .long 0xee335b90 // vmov.32 r5, d19[1] .long 0xf3c72250 // vmov.i32 q9, #61440 .long 0xe0823083 // add r3, r2, r3, lsl #1 .long 0xe0824084 // add r4, r2, r4, lsl #1 .long 0xf4e3041f // vld1.16 {d16[0]}, [r3 :16] .long 0xe082308e // add r3, r2, lr, lsl #1 .long 0xe0822085 // add r2, r2, r5, lsl #1 .long 0xf4e4045f // vld1.16 {d16[1]}, [r4 :16] .long 0xe1d330b0 // ldrh r3, [r3] .long 0xe1d220b0 // ldrh r2, [r2] .long 0xee203bb0 // vmov.16 d16[2], r3 .long 0xee202bf0 // vmov.16 d16[3], r2 .long 0xe28f2058 // add r2, pc, #88 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xe28f2060 // add r2, pc, #96 .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf24021f2 // vand q9, q8, q9 .long 0xf24041f4 // vand q10, q8, q10 .long 0xf24061f6 // vand q11, q8, q11 .long 0xf24001f8 // vand q8, q8, q12 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xe28f2050 // add r2, pc, #80 .long 0xf462cacf // vld1.64 {d28-d29}, [r2] .long 0xe28f2058 // add r2, pc, #88 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3020df8 // vmul.f32 q0, q9, q12 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf3062dfc // vmul.f32 q1, q11, q14 .long 0xf3044dfa // vmul.f32 q2, q10, q13 .long 0xf3006df2 // vmul.f32 q3, q8, q9 .long 0xe8bd4830 // pop {r4, r5, fp, lr} .long 0xe12fff1c // bx ip .long 0xe320f000 // nop {0} .long 0x3b888889 // .word 0x3b888889 .long 0x3b888889 // .word 0x3b888889 .long 0x3b888889 // .word 0x3b888889 .long 0x3b888889 // .word 0x3b888889 .long 0x37888889 // .word 0x37888889 .long 0x37888889 // .word 0x37888889 .long 0x37888889 // .word 0x37888889 .long 0x37888889 // .word 0x37888889 .long 0x39888889 // .word 0x39888889 .long 0x39888889 // .word 0x39888889 .long 0x39888889 // .word 0x39888889 .long 0x39888889 // .word 0x39888889 .long 0x3d888889 // .word 0x3d888889 .long 0x3d888889 // .word 0x3d888889 .long 0x3d888889 // .word 0x3d888889 .long 0x3d888889 // .word 0x3d888889 HIDDEN _sk_store_4444_vfp4 .globl _sk_store_4444_vfp4 FUNCTION(_sk_store_4444_vfp4) _sk_store_4444_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xf2c20f5e // vmov.f32 q8, #15 .long 0xe5912000 // ldr r2, [r1] .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xe590e000 // ldr lr, [r0] .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xf2404c70 // vfma.f32 q10, q0, q8 .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xf2426c70 // vfma.f32 q11, q1, q8 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xf2c3865f // vmov.i32 q12, #1056964608 .long 0xf2448c70 // vfma.f32 q12, q2, q8 .long 0xe0020392 // mul r2, r2, r3 .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xf2462c70 // vfma.f32 q9, q3, q8 .long 0xf3fb07e4 // vcvt.u32.f32 q8, q10 .long 0xe0842082 // add r2, r4, r2, lsl #1 .long 0xf3fb47e6 // vcvt.u32.f32 q10, q11 .long 0xe082208e // add r2, r2, lr, lsl #1 .long 0xf3fb67e8 // vcvt.u32.f32 q11, q12 .long 0xf2ec0570 // vshl.s32 q8, q8, #12 .long 0xf3fb27e2 // vcvt.u32.f32 q9, q9 .long 0xf2e84574 // vshl.s32 q10, q10, #8 .long 0xf2e46576 // vshl.s32 q11, q11, #4 .long 0xf26401f0 // vorr q8, q10, q8 .long 0xf26001f6 // vorr q8, q8, q11 .long 0xf26001f2 // vorr q8, q8, q9 .long 0xf3f60220 // vmovn.i32 d16, q8 .long 0x1a000004 // bne 4a78 .long 0xf442074f // vst1.16 {d16}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a00000c // beq 4ab8 .long 0xe3530002 // cmp r3, #2 .long 0x0a000003 // beq 4a9c .long 0xe3530003 // cmp r3, #3 .long 0x1afffff4 // bne 4a68 .long 0xe2823004 // add r3, r2, #4 .long 0xf4c3049f // vst1.16 {d16[2]}, [r3 :16] .long 0xee903bb0 // vmov.u16 r3, d16[0] .long 0xee904bf0 // vmov.u16 r4, d16[1] .long 0xee003b90 // vmov.32 d16[0], r3 .long 0xee204b90 // vmov.32 d16[1], r4 .long 0xf3f60121 // vuzp.16 d16, d17 .long 0xf4c2080f // vst1.32 {d16[0]}, [r2] .long 0xeaffffeb // b 4a68 .long 0xf4c2041f // vst1.16 {d16[0]}, [r2 :16] .long 0xeaffffe9 // b 4a68 HIDDEN _sk_load_8888_vfp4 .globl _sk_load_8888_vfp4 FUNCTION(_sk_load_8888_vfp4) _sk_load_8888_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020392 // mul r2, r2, r3 .long 0xe0842102 // add r2, r4, r2, lsl #2 .long 0xe082210e // add r2, r2, lr, lsl #2 .long 0x1a000015 // bne 4b44 .long 0xf4620a8f // vld1.32 {d16-d17}, [r2] .long 0xf3c7205f // vmov.i32 q9, #255 .long 0xe28f209c // add r2, pc, #156 .long 0xf3f84070 // vshr.u32 q10, q8, #8 .long 0xf3f08070 // vshr.u32 q12, q8, #16 .long 0xf3e86070 // vshr.u32 q11, q8, #24 .long 0xf24001f2 // vand q8, q8, q9 .long 0xf24441f2 // vand q10, q10, q9 .long 0xf24821f2 // vand q9, q12, q9 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf3066df8 // vmul.f32 q3, q11, q12 .long 0xf3000df8 // vmul.f32 q0, q8, q12 .long 0xf3042df8 // vmul.f32 q1, q10, q12 .long 0xf3024df8 // vmul.f32 q2, q9, q12 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a00000c // beq 4b84 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe3530002 // cmp r3, #2 .long 0x0a000005 // beq 4b74 .long 0xe3530003 // cmp r3, #3 .long 0x1affffe2 // bne 4af0 .long 0xe3a03000 // mov r3, #0 .long 0xeea03b90 // vdup.32 q8, r3 .long 0xe2823008 // add r3, r2, #8 .long 0xf4e3183f // vld1.32 {d17[0]}, [r3 :32] .long 0xedd22b00 // vldr d18, [r2] .long 0xf2f008e2 // vext.8 q8, q8, q9, #8 .long 0xf2f008e0 // vext.8 q8, q8, q8, #8 .long 0xeaffffda // b 4af0 .long 0xe3a03000 // mov r3, #0 .long 0xeea03b90 // vdup.32 q8, r3 .long 0xf4e2083f // vld1.32 {d16[0]}, [r2 :32] .long 0xeaffffd6 // b 4af0 .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_load_8888_dst_vfp4 .globl _sk_load_8888_dst_vfp4 FUNCTION(_sk_load_8888_dst_vfp4) _sk_load_8888_dst_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe5912000 // ldr r2, [r1] .long 0xe280c040 // add ip, r0, #64 .long 0xe8900058 // ldm r0, {r3, r4, r6} .long 0xe280e030 // add lr, r0, #48 .long 0xe5925000 // ldr r5, [r2] .long 0xe3560000 // cmp r6, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020492 // mul r2, r2, r4 .long 0xe0852102 // add r2, r5, r2, lsl #2 .long 0xe0824103 // add r4, r2, r3, lsl #2 .long 0xe2802020 // add r2, r0, #32 .long 0xe2803010 // add r3, r0, #16 .long 0x1a00001a // bne 4c4c .long 0xf4640a8f // vld1.32 {d16-d17}, [r4] .long 0xf3c7205f // vmov.i32 q9, #255 .long 0xe28f40b0 // add r4, pc, #176 .long 0xf3f84070 // vshr.u32 q10, q8, #8 .long 0xf3f08070 // vshr.u32 q12, q8, #16 .long 0xf24061f2 // vand q11, q8, q9 .long 0xf24441f2 // vand q10, q10, q9 .long 0xf24821f2 // vand q9, q12, q9 .long 0xf4648acf // vld1.64 {d24-d25}, [r4] .long 0xf3e80070 // vshr.u32 q8, q8, #24 .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3466df8 // vmul.f32 q11, q11, q12 .long 0xf3444df8 // vmul.f32 q10, q10, q12 .long 0xf3422df8 // vmul.f32 q9, q9, q12 .long 0xf3400df8 // vmul.f32 q8, q8, q12 .long 0xf4436aef // vst1.64 {d22-d23}, [r3 :128] .long 0xf4424aef // vst1.64 {d20-d21}, [r2 :128] .long 0xe2812008 // add r2, r1, #8 .long 0xf44e2aef // vst1.64 {d18-d19}, [lr :128] .long 0xf44c0aef // vst1.64 {d16-d17}, [ip :128] .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff13 // bx r3 .long 0xe2065003 // and r5, r6, #3 .long 0xe3550001 // cmp r5, #1 .long 0x0a00000c // beq 4c8c .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe3550002 // cmp r5, #2 .long 0x0a000005 // beq 4c7c .long 0xe3550003 // cmp r5, #3 .long 0x1affffdd // bne 4be4 .long 0xe3a05000 // mov r5, #0 .long 0xeea05b90 // vdup.32 q8, r5 .long 0xe2845008 // add r5, r4, #8 .long 0xf4e5183f // vld1.32 {d17[0]}, [r5 :32] .long 0xedd42b00 // vldr d18, [r4] .long 0xf2f008e2 // vext.8 q8, q8, q9, #8 .long 0xf2f008e0 // vext.8 q8, q8, q8, #8 .long 0xeaffffd5 // b 4be4 .long 0xe3a05000 // mov r5, #0 .long 0xeea05b90 // vdup.32 q8, r5 .long 0xf4e4083f // vld1.32 {d16[0]}, [r4 :32] .long 0xeaffffd1 // b 4be4 .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_gather_8888_vfp4 .globl _sk_gather_8888_vfp4 FUNCTION(_sk_gather_8888_vfp4) _sk_gather_8888_vfp4: .long 0xe92d4830 // push {r4, r5, fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf3fb0742 // vcvt.s32.f32 q8, q1 .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb2740 // vcvt.s32.f32 q9, q0 .long 0xe4932004 // ldr r2, [r3], #4 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xf26429e0 // vmla.i32 q9, q10, q8 .long 0xee133b90 // vmov.32 r3, d19[0] .long 0xee12eb90 // vmov.32 lr, d18[0] .long 0xee334b90 // vmov.32 r4, d19[1] .long 0xee325b90 // vmov.32 r5, d18[1] .long 0xf3c7205f // vmov.i32 q9, #255 .long 0xe0823103 // add r3, r2, r3, lsl #2 .long 0xf4e3183f // vld1.32 {d17[0]}, [r3 :32] .long 0xe082310e // add r3, r2, lr, lsl #2 .long 0xf4e3083f // vld1.32 {d16[0]}, [r3 :32] .long 0xe0823104 // add r3, r2, r4, lsl #2 .long 0xe0822105 // add r2, r2, r5, lsl #2 .long 0xf4e318bf // vld1.32 {d17[1]}, [r3 :32] .long 0xf4e208bf // vld1.32 {d16[1]}, [r2 :32] .long 0xe28f2044 // add r2, pc, #68 .long 0xf3f84070 // vshr.u32 q10, q8, #8 .long 0xf24061f2 // vand q11, q8, q9 .long 0xf3e88070 // vshr.u32 q12, q8, #24 .long 0xf3f00070 // vshr.u32 q8, q8, #16 .long 0xf24441f2 // vand q10, q10, q9 .long 0xf24001f2 // vand q8, q8, q9 .long 0xf3fb2664 // vcvt.f32.s32 q9, q10 .long 0xf4624acf // vld1.64 {d20-d21}, [r2] .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3fb8668 // vcvt.f32.s32 q12, q12 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3060df4 // vmul.f32 q0, q11, q10 .long 0xf3086df4 // vmul.f32 q3, q12, q10 .long 0xf3022df4 // vmul.f32 q1, q9, q10 .long 0xf3004df4 // vmul.f32 q2, q8, q10 .long 0xe8bd4830 // pop {r4, r5, fp, lr} .long 0xe12fff1c // bx ip .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_store_8888_vfp4 .globl _sk_store_8888_vfp4 FUNCTION(_sk_store_8888_vfp4) _sk_store_8888_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe28f20bc // add r2, pc, #188 .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xf2444c72 // vfma.f32 q10, q2, q9 .long 0xe5912000 // ldr r2, [r1] .long 0xf2426c72 // vfma.f32 q11, q1, q9 .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf2c3865f // vmov.i32 q12, #1056964608 .long 0xe5924000 // ldr r4, [r2] .long 0xf2400c72 // vfma.f32 q8, q0, q9 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe35c0000 // cmp ip, #0 .long 0xf2468c72 // vfma.f32 q12, q3, q9 .long 0xe0020392 // mul r2, r2, r3 .long 0xf3fb27e4 // vcvt.u32.f32 q9, q10 .long 0xf3fb47e6 // vcvt.u32.f32 q10, q11 .long 0xf3fb07e0 // vcvt.u32.f32 q8, q8 .long 0xe0842102 // add r2, r4, r2, lsl #2 .long 0xe082210e // add r2, r2, lr, lsl #2 .long 0xf3fb67e8 // vcvt.u32.f32 q11, q12 .long 0xf2e84574 // vshl.s32 q10, q10, #8 .long 0xf2f02572 // vshl.s32 q9, q9, #16 .long 0xf26401f0 // vorr q8, q10, q8 .long 0xf2f84576 // vshl.s32 q10, q11, #24 .long 0xf26001f2 // vorr q8, q8, q9 .long 0xf26001f4 // vorr q8, q8, q10 .long 0x1a000004 // bne 4df0 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a000007 // beq 4e1c .long 0xe3530002 // cmp r3, #2 .long 0x0a000003 // beq 4e14 .long 0xe3530003 // cmp r3, #3 .long 0x1afffff4 // bne 4de0 .long 0xe2823008 // add r3, r2, #8 .long 0xf4c3183f // vst1.32 {d17[0]}, [r3 :32] .long 0xedc20b00 // vstr d16, [r2] .long 0xeafffff0 // b 4de0 .long 0xf4c2083f // vst1.32 {d16[0]}, [r2 :32] .long 0xeaffffee // b 4de0 .long 0xe320f000 // nop {0} .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 HIDDEN _sk_load_bgra_vfp4 .globl _sk_load_bgra_vfp4 FUNCTION(_sk_load_bgra_vfp4) _sk_load_bgra_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020392 // mul r2, r2, r3 .long 0xe0842102 // add r2, r4, r2, lsl #2 .long 0xe082210e // add r2, r2, lr, lsl #2 .long 0x1a000015 // bne 4ebc .long 0xf4620a8f // vld1.32 {d16-d17}, [r2] .long 0xf3c7205f // vmov.i32 q9, #255 .long 0xe28f209c // add r2, pc, #156 .long 0xf3f04070 // vshr.u32 q10, q8, #16 .long 0xf3f88070 // vshr.u32 q12, q8, #8 .long 0xf3e86070 // vshr.u32 q11, q8, #24 .long 0xf24001f2 // vand q8, q8, q9 .long 0xf24441f2 // vand q10, q10, q9 .long 0xf24821f2 // vand q9, q12, q9 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf3066df8 // vmul.f32 q3, q11, q12 .long 0xf3004df8 // vmul.f32 q2, q8, q12 .long 0xf3040df8 // vmul.f32 q0, q10, q12 .long 0xf3022df8 // vmul.f32 q1, q9, q12 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a00000c // beq 4efc .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe3530002 // cmp r3, #2 .long 0x0a000005 // beq 4eec .long 0xe3530003 // cmp r3, #3 .long 0x1affffe2 // bne 4e68 .long 0xe3a03000 // mov r3, #0 .long 0xeea03b90 // vdup.32 q8, r3 .long 0xe2823008 // add r3, r2, #8 .long 0xf4e3183f // vld1.32 {d17[0]}, [r3 :32] .long 0xedd22b00 // vldr d18, [r2] .long 0xf2f008e2 // vext.8 q8, q8, q9, #8 .long 0xf2f008e0 // vext.8 q8, q8, q8, #8 .long 0xeaffffda // b 4e68 .long 0xe3a03000 // mov r3, #0 .long 0xeea03b90 // vdup.32 q8, r3 .long 0xf4e2083f // vld1.32 {d16[0]}, [r2 :32] .long 0xeaffffd6 // b 4e68 .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_load_bgra_dst_vfp4 .globl _sk_load_bgra_dst_vfp4 FUNCTION(_sk_load_bgra_dst_vfp4) _sk_load_bgra_dst_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe5912000 // ldr r2, [r1] .long 0xe280c040 // add ip, r0, #64 .long 0xe8900058 // ldm r0, {r3, r4, r6} .long 0xe280e030 // add lr, r0, #48 .long 0xe5925000 // ldr r5, [r2] .long 0xe3560000 // cmp r6, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020492 // mul r2, r2, r4 .long 0xe0852102 // add r2, r5, r2, lsl #2 .long 0xe0824103 // add r4, r2, r3, lsl #2 .long 0xe2802020 // add r2, r0, #32 .long 0xe2803010 // add r3, r0, #16 .long 0x1a00001a // bne 4fc4 .long 0xf4640a8f // vld1.32 {d16-d17}, [r4] .long 0xf3c7205f // vmov.i32 q9, #255 .long 0xe28f40b0 // add r4, pc, #176 .long 0xf3f84070 // vshr.u32 q10, q8, #8 .long 0xf3f08070 // vshr.u32 q12, q8, #16 .long 0xf24061f2 // vand q11, q8, q9 .long 0xf24441f2 // vand q10, q10, q9 .long 0xf24821f2 // vand q9, q12, q9 .long 0xf4648acf // vld1.64 {d24-d25}, [r4] .long 0xf3e80070 // vshr.u32 q8, q8, #24 .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3fb2662 // vcvt.f32.s32 q9, q9 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3466df8 // vmul.f32 q11, q11, q12 .long 0xf3444df8 // vmul.f32 q10, q10, q12 .long 0xf3422df8 // vmul.f32 q9, q9, q12 .long 0xf3400df8 // vmul.f32 q8, q8, q12 .long 0xf44e6aef // vst1.64 {d22-d23}, [lr :128] .long 0xf4424aef // vst1.64 {d20-d21}, [r2 :128] .long 0xe2812008 // add r2, r1, #8 .long 0xf4432aef // vst1.64 {d18-d19}, [r3 :128] .long 0xf44c0aef // vst1.64 {d16-d17}, [ip :128] .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff13 // bx r3 .long 0xe2065003 // and r5, r6, #3 .long 0xe3550001 // cmp r5, #1 .long 0x0a00000c // beq 5004 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe3550002 // cmp r5, #2 .long 0x0a000005 // beq 4ff4 .long 0xe3550003 // cmp r5, #3 .long 0x1affffdd // bne 4f5c .long 0xe3a05000 // mov r5, #0 .long 0xeea05b90 // vdup.32 q8, r5 .long 0xe2845008 // add r5, r4, #8 .long 0xf4e5183f // vld1.32 {d17[0]}, [r5 :32] .long 0xedd42b00 // vldr d18, [r4] .long 0xf2f008e2 // vext.8 q8, q8, q9, #8 .long 0xf2f008e0 // vext.8 q8, q8, q8, #8 .long 0xeaffffd5 // b 4f5c .long 0xe3a05000 // mov r5, #0 .long 0xeea05b90 // vdup.32 q8, r5 .long 0xf4e4083f // vld1.32 {d16[0]}, [r4 :32] .long 0xeaffffd1 // b 4f5c .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_gather_bgra_vfp4 .globl _sk_gather_bgra_vfp4 FUNCTION(_sk_gather_bgra_vfp4) _sk_gather_bgra_vfp4: .long 0xe92d4830 // push {r4, r5, fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf3fb0742 // vcvt.s32.f32 q8, q1 .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb2740 // vcvt.s32.f32 q9, q0 .long 0xe4932004 // ldr r2, [r3], #4 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xf26429e0 // vmla.i32 q9, q10, q8 .long 0xee133b90 // vmov.32 r3, d19[0] .long 0xee12eb90 // vmov.32 lr, d18[0] .long 0xee334b90 // vmov.32 r4, d19[1] .long 0xee325b90 // vmov.32 r5, d18[1] .long 0xf3c7205f // vmov.i32 q9, #255 .long 0xe0823103 // add r3, r2, r3, lsl #2 .long 0xf4e3183f // vld1.32 {d17[0]}, [r3 :32] .long 0xe082310e // add r3, r2, lr, lsl #2 .long 0xf4e3083f // vld1.32 {d16[0]}, [r3 :32] .long 0xe0823104 // add r3, r2, r4, lsl #2 .long 0xe0822105 // add r2, r2, r5, lsl #2 .long 0xf4e318bf // vld1.32 {d17[1]}, [r3 :32] .long 0xf4e208bf // vld1.32 {d16[1]}, [r2 :32] .long 0xe28f2044 // add r2, pc, #68 .long 0xf3f04070 // vshr.u32 q10, q8, #16 .long 0xf24061f2 // vand q11, q8, q9 .long 0xf3e88070 // vshr.u32 q12, q8, #24 .long 0xf3f80070 // vshr.u32 q8, q8, #8 .long 0xf24441f2 // vand q10, q10, q9 .long 0xf24001f2 // vand q8, q8, q9 .long 0xf3fb2664 // vcvt.f32.s32 q9, q10 .long 0xf4624acf // vld1.64 {d20-d21}, [r2] .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3fb8668 // vcvt.f32.s32 q12, q12 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3064df4 // vmul.f32 q2, q11, q10 .long 0xf3086df4 // vmul.f32 q3, q12, q10 .long 0xf3020df4 // vmul.f32 q0, q9, q10 .long 0xf3002df4 // vmul.f32 q1, q8, q10 .long 0xe8bd4830 // pop {r4, r5, fp, lr} .long 0xe12fff1c // bx ip .long 0xe320f000 // nop {0} .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 .long 0x3b808081 // .word 0x3b808081 HIDDEN _sk_store_bgra_vfp4 .globl _sk_store_bgra_vfp4 FUNCTION(_sk_store_bgra_vfp4) _sk_store_bgra_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe28f20bc // add r2, pc, #188 .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xf2424c72 // vfma.f32 q10, q1, q9 .long 0xe5912000 // ldr r2, [r1] .long 0xf2406c72 // vfma.f32 q11, q0, q9 .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf2c3865f // vmov.i32 q12, #1056964608 .long 0xe5924000 // ldr r4, [r2] .long 0xf2440c72 // vfma.f32 q8, q2, q9 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe35c0000 // cmp ip, #0 .long 0xf2468c72 // vfma.f32 q12, q3, q9 .long 0xe0020392 // mul r2, r2, r3 .long 0xf3fb27e4 // vcvt.u32.f32 q9, q10 .long 0xf3fb47e6 // vcvt.u32.f32 q10, q11 .long 0xf3fb07e0 // vcvt.u32.f32 q8, q8 .long 0xe0842102 // add r2, r4, r2, lsl #2 .long 0xe082210e // add r2, r2, lr, lsl #2 .long 0xf3fb67e8 // vcvt.u32.f32 q11, q12 .long 0xf2f04574 // vshl.s32 q10, q10, #16 .long 0xf2e82572 // vshl.s32 q9, q9, #8 .long 0xf26001f4 // vorr q8, q8, q10 .long 0xf2f84576 // vshl.s32 q10, q11, #24 .long 0xf26001f2 // vorr q8, q8, q9 .long 0xf26001f4 // vorr q8, q8, q10 .long 0x1a000004 // bne 5168 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe20c3003 // and r3, ip, #3 .long 0xe3530001 // cmp r3, #1 .long 0x0a000007 // beq 5194 .long 0xe3530002 // cmp r3, #2 .long 0x0a000003 // beq 518c .long 0xe3530003 // cmp r3, #3 .long 0x1afffff4 // bne 5158 .long 0xe2823008 // add r3, r2, #8 .long 0xf4c3183f // vst1.32 {d17[0]}, [r3 :32] .long 0xedc20b00 // vstr d16, [r2] .long 0xeafffff0 // b 5158 .long 0xf4c2083f // vst1.32 {d16[0]}, [r2 :32] .long 0xeaffffee // b 5158 .long 0xe320f000 // nop {0} .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 .long 0x437f0000 // .word 0x437f0000 HIDDEN _sk_load_f16_vfp4 .globl _sk_load_f16_vfp4 FUNCTION(_sk_load_f16_vfp4) _sk_load_f16_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe5913000 // ldr r3, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901004 // ldmib r0, {r2, ip} .long 0xe5934000 // ldr r4, [r3] .long 0xe35c0000 // cmp ip, #0 .long 0xe5933004 // ldr r3, [r3, #4] .long 0xe0020293 // mul r2, r3, r2 .long 0xe0842182 // add r2, r4, r2, lsl #3 .long 0xe082318e // add r3, r2, lr, lsl #3 .long 0x1a000008 // bne 5200 .long 0xf463004f // vld4.16 {d16-d19}, [r3] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf3b60720 // vcvt.f32.f16 q0, d16 .long 0xe2811008 // add r1, r1, #8 .long 0xf3b62721 // vcvt.f32.f16 q1, d17 .long 0xf3b64722 // vcvt.f32.f16 q2, d18 .long 0xf3b66723 // vcvt.f32.f16 q3, d19 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xf4e3070f // vld4.16 {d16[0],d17[0],d18[0],d19[0]}, [r3] .long 0xe35c0001 // cmp ip, #1 .long 0x0afffff4 // beq 51e0 .long 0xe2832008 // add r2, r3, #8 .long 0xe35c0003 // cmp ip, #3 .long 0xf4e2074f // vld4.16 {d16[1],d17[1],d18[1],d19[1]}, [r2] .long 0x3afffff0 // bcc 51e0 .long 0xe2832010 // add r2, r3, #16 .long 0xf4e2078f // vld4.16 {d16[2],d17[2],d18[2],d19[2]}, [r2] .long 0xeaffffed // b 51e0 HIDDEN _sk_load_f16_dst_vfp4 .globl _sk_load_f16_dst_vfp4 FUNCTION(_sk_load_f16_dst_vfp4) _sk_load_f16_dst_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe5912000 // ldr r2, [r1] .long 0xe280c040 // add ip, r0, #64 .long 0xe8900068 // ldm r0, {r3, r5, r6} .long 0xe280e030 // add lr, r0, #48 .long 0xe5924000 // ldr r4, [r2] .long 0xe3560000 // cmp r6, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020592 // mul r2, r2, r5 .long 0xe0842182 // add r2, r4, r2, lsl #3 .long 0xe0825183 // add r5, r2, r3, lsl #3 .long 0xe2802020 // add r2, r0, #32 .long 0xe2803010 // add r3, r0, #16 .long 0x1a00000d // bne 5298 .long 0xf465004f // vld4.16 {d16-d19}, [r5] .long 0xf3f64720 // vcvt.f32.f16 q10, d16 .long 0xf3f66721 // vcvt.f32.f16 q11, d17 .long 0xf3f68722 // vcvt.f32.f16 q12, d18 .long 0xf3f60723 // vcvt.f32.f16 q8, d19 .long 0xf4434aef // vst1.64 {d20-d21}, [r3 :128] .long 0xf4426aef // vst1.64 {d22-d23}, [r2 :128] .long 0xe2812008 // add r2, r1, #8 .long 0xf44e8aef // vst1.64 {d24-d25}, [lr :128] .long 0xf44c0aef // vst1.64 {d16-d17}, [ip :128] .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff13 // bx r3 .long 0xf4e5070f // vld4.16 {d16[0],d17[0],d18[0],d19[0]}, [r5] .long 0xe3560001 // cmp r6, #1 .long 0x0affffef // beq 5264 .long 0xe2854008 // add r4, r5, #8 .long 0xe3560003 // cmp r6, #3 .long 0xf4e4074f // vld4.16 {d16[1],d17[1],d18[1],d19[1]}, [r4] .long 0x3affffeb // bcc 5264 .long 0xe2854010 // add r4, r5, #16 .long 0xf4e4078f // vld4.16 {d16[2],d17[2],d18[2],d19[2]}, [r4] .long 0xeaffffe8 // b 5264 HIDDEN _sk_gather_f16_vfp4 .globl _sk_gather_f16_vfp4 FUNCTION(_sk_gather_f16_vfp4) _sk_gather_f16_vfp4: .long 0xe92d4c10 // push {r4, sl, fp, lr} .long 0xe28db008 // add fp, sp, #8 .long 0xe24dd030 // sub sp, sp, #48 .long 0xe7c4d01f // bfc sp, #0, #5 .long 0xe5912000 // ldr r2, [r1] .long 0xf3fb0742 // vcvt.s32.f32 q8, q1 .long 0xf3fb2740 // vcvt.s32.f32 q9, q0 .long 0xe4923004 // ldr r3, [r2], #4 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xf26429e0 // vmla.i32 q9, q10, q8 .long 0xee33cb90 // vmov.32 ip, d19[1] .long 0xee322b90 // vmov.32 r2, d18[1] .long 0xee13eb90 // vmov.32 lr, d19[0] .long 0xee124b90 // vmov.32 r4, d18[0] .long 0xe083c18c // add ip, r3, ip, lsl #3 .long 0xe0832182 // add r2, r3, r2, lsl #3 .long 0xe083e18e // add lr, r3, lr, lsl #3 .long 0xeddc3b00 // vldr d19, [ip] .long 0xedd21b00 // vldr d17, [r2] .long 0xe0832184 // add r2, r3, r4, lsl #3 .long 0xedde2b00 // vldr d18, [lr] .long 0xedd20b00 // vldr d16, [r2] .long 0xe1a0200d // mov r2, sp .long 0xe3823010 // orr r3, r2, #16 .long 0xf4432aef // vst1.64 {d18-d19}, [r3 :128] .long 0xf4420aef // vst1.64 {d16-d17}, [r2 :128] .long 0xf462007f // vld4.16 {d16-d19}, [r2 :256] .long 0xf3b60720 // vcvt.f32.f16 q0, d16 .long 0xf3b62721 // vcvt.f32.f16 q1, d17 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf3b64722 // vcvt.f32.f16 q2, d18 .long 0xf3b66723 // vcvt.f32.f16 q3, d19 .long 0xe12fff32 // blx r2 .long 0xe24bd008 // sub sp, fp, #8 .long 0xe8bd8c10 // pop {r4, sl, fp, pc} HIDDEN _sk_store_f16_vfp4 .globl _sk_store_f16_vfp4 FUNCTION(_sk_store_f16_vfp4) _sk_store_f16_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe5912000 // ldr r2, [r1] .long 0xf3f63606 // vcvt.f16.f32 d19, q3 .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xf3f62604 // vcvt.f16.f32 d18, q2 .long 0xe5924000 // ldr r4, [r2] .long 0xf3f61602 // vcvt.f16.f32 d17, q1 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe35c0000 // cmp ip, #0 .long 0xf3f60600 // vcvt.f16.f32 d16, q0 .long 0xe0020392 // mul r2, r2, r3 .long 0xe0842182 // add r2, r4, r2, lsl #3 .long 0xe082218e // add r2, r2, lr, lsl #3 .long 0x1a000004 // bne 53a0 .long 0xf442004f // vst4.16 {d16-d19}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe35c0001 // cmp ip, #1 .long 0xf4c2070f // vst4.16 {d16[0],d17[0],d18[0],d19[0]}, [r2] .long 0x0afffff8 // beq 5390 .long 0xe2823008 // add r3, r2, #8 .long 0xe35c0003 // cmp ip, #3 .long 0xf4c3074f // vst4.16 {d16[1],d17[1],d18[1],d19[1]}, [r3] .long 0x3afffff4 // bcc 5390 .long 0xe2822010 // add r2, r2, #16 .long 0xf4c2078f // vst4.16 {d16[2],d17[2],d18[2],d19[2]}, [r2] .long 0xeafffff1 // b 5390 HIDDEN _sk_load_u16_be_vfp4 .globl _sk_load_u16_be_vfp4 FUNCTION(_sk_load_u16_be_vfp4) _sk_load_u16_be_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe5913000 // ldr r3, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901004 // ldmib r0, {r2, ip} .long 0xe5934000 // ldr r4, [r3] .long 0xe35c0000 // cmp ip, #0 .long 0xe5933004 // ldr r3, [r3, #4] .long 0xe0020293 // mul r2, r3, r2 .long 0xe0842082 // add r2, r4, r2, lsl #1 .long 0xe082318e // add r3, r2, lr, lsl #3 .long 0x1a00001e // bne 5470 .long 0xf463004f // vld4.16 {d16-d19}, [r3] .long 0xf3d84030 // vshr.u16 d20, d16, #8 .long 0xe28f2094 // add r2, pc, #148 .long 0xf2d85530 // vshl.s16 d21, d16, #8 .long 0xf3d86031 // vshr.u16 d22, d17, #8 .long 0xf2d87531 // vshl.s16 d23, d17, #8 .long 0xf2d80533 // vshl.s16 d16, d19, #8 .long 0xf3d8a033 // vshr.u16 d26, d19, #8 .long 0xf3d88032 // vshr.u16 d24, d18, #8 .long 0xf2d89532 // vshl.s16 d25, d18, #8 .long 0xf26511b4 // vorr d17, d21, d20 .long 0xf26721b6 // vorr d18, d23, d22 .long 0xf26931b8 // vorr d19, d25, d24 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xf26001ba // vorr d16, d16, d26 .long 0xf3d04a31 // vmovl.u16 q10, d17 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf3d06a32 // vmovl.u16 q11, d18 .long 0xe2811008 // add r1, r1, #8 .long 0xf3d02a33 // vmovl.u16 q9, d19 .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf3fb46e4 // vcvt.f32.u32 q10, q10 .long 0xf3fb66e6 // vcvt.f32.u32 q11, q11 .long 0xf3fb26e2 // vcvt.f32.u32 q9, q9 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3040df8 // vmul.f32 q0, q10, q12 .long 0xf3062df8 // vmul.f32 q1, q11, q12 .long 0xf3024df8 // vmul.f32 q2, q9, q12 .long 0xf3006df8 // vmul.f32 q3, q8, q12 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xf4e3070f // vld4.16 {d16[0],d17[0],d18[0],d19[0]}, [r3] .long 0xe35c0001 // cmp ip, #1 .long 0x0affffde // beq 53f8 .long 0xe2832008 // add r2, r3, #8 .long 0xe35c0003 // cmp ip, #3 .long 0xf4e2074f // vld4.16 {d16[1],d17[1],d18[1],d19[1]}, [r2] .long 0x3affffda // bcc 53f8 .long 0xe2832010 // add r2, r3, #16 .long 0xf4e2078f // vld4.16 {d16[2],d17[2],d18[2],d19[2]}, [r2] .long 0xeaffffd7 // b 53f8 .long 0x37800080 // .word 0x37800080 .long 0x37800080 // .word 0x37800080 .long 0x37800080 // .word 0x37800080 .long 0x37800080 // .word 0x37800080 HIDDEN _sk_load_rgb_u16_be_vfp4 .globl _sk_load_rgb_u16_be_vfp4 FUNCTION(_sk_load_rgb_u16_be_vfp4) _sk_load_rgb_u16_be_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe5913000 // ldr r3, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901004 // ldmib r0, {r2, ip} .long 0xe5934000 // ldr r4, [r3] .long 0xe35c0000 // cmp ip, #0 .long 0xe5933004 // ldr r3, [r3, #4] .long 0xe0020293 // mul r2, r3, r2 .long 0xe08e308e // add r3, lr, lr, lsl #1 .long 0xe0842082 // add r2, r4, r2, lsl #1 .long 0xe0823083 // add r3, r2, r3, lsl #1 .long 0x1a00001a // bne 5544 .long 0xf463044f // vld3.16 {d16-d18}, [r3] .long 0xf3d84030 // vshr.u16 d20, d16, #8 .long 0xe28f2088 // add r2, pc, #136 .long 0xf2d85530 // vshl.s16 d21, d16, #8 .long 0xf3d86031 // vshr.u16 d22, d17, #8 .long 0xf2d87531 // vshl.s16 d23, d17, #8 .long 0xf2d80532 // vshl.s16 d16, d18, #8 .long 0xf3d88032 // vshr.u16 d24, d18, #8 .long 0xf26721b6 // vorr d18, d23, d22 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xf26511b4 // vorr d17, d21, d20 .long 0xe28f2074 // add r2, pc, #116 .long 0xf26001b8 // vorr d16, d16, d24 .long 0xf4226acf // vld1.64 {d6-d7}, [r2] .long 0xf3d02a32 // vmovl.u16 q9, d18 .long 0xf3d04a31 // vmovl.u16 q10, d17 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xe2811008 // add r1, r1, #8 .long 0xf3fb26e2 // vcvt.f32.u32 q9, q9 .long 0xf3fb46e4 // vcvt.f32.u32 q10, q10 .long 0xf3fb06e0 // vcvt.f32.u32 q8, q8 .long 0xf3022df6 // vmul.f32 q1, q9, q11 .long 0xf3040df6 // vmul.f32 q0, q10, q11 .long 0xf3004df6 // vmul.f32 q2, q8, q11 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xf4e3060f // vld3.16 {d16[0],d17[0],d18[0]}, [r3] .long 0xe35c0001 // cmp ip, #1 .long 0x0affffe2 // beq 54dc .long 0xe2832006 // add r2, r3, #6 .long 0xe35c0003 // cmp ip, #3 .long 0xf4e2064f // vld3.16 {d16[1],d17[1],d18[1]}, [r2] .long 0x3affffde // bcc 54dc .long 0xe283200c // add r2, r3, #12 .long 0xf4e2068f // vld3.16 {d16[2],d17[2],d18[2]}, [r2] .long 0xeaffffdb // b 54dc .long 0xe320f000 // nop {0} .long 0x37800080 // .word 0x37800080 .long 0x37800080 // .word 0x37800080 .long 0x37800080 // .word 0x37800080 .long 0x37800080 // .word 0x37800080 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_store_u16_be_vfp4 .globl _sk_store_u16_be_vfp4 FUNCTION(_sk_store_u16_be_vfp4) _sk_store_u16_be_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe28f20d4 // add r2, pc, #212 .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xf2440c72 // vfma.f32 q8, q2, q9 .long 0xe5913000 // ldr r3, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xf2424c72 // vfma.f32 q10, q1, q9 .long 0xe9901004 // ldmib r0, {r2, ip} .long 0xf2466c72 // vfma.f32 q11, q3, q9 .long 0xe5934000 // ldr r4, [r3] .long 0xe5933004 // ldr r3, [r3, #4] .long 0xe35c0000 // cmp ip, #0 .long 0xf2c3865f // vmov.i32 q12, #1056964608 .long 0xf2408c72 // vfma.f32 q12, q0, q9 .long 0xe0020293 // mul r2, r3, r2 .long 0xf3fb07e0 // vcvt.u32.f32 q8, q8 .long 0xf3fb27e4 // vcvt.u32.f32 q9, q10 .long 0xf3fb47e6 // vcvt.u32.f32 q10, q11 .long 0xe0842082 // add r2, r4, r2, lsl #1 .long 0xf3f60220 // vmovn.i32 d16, q8 .long 0xe082318e // add r3, r2, lr, lsl #3 .long 0xf3fb67e8 // vcvt.u32.f32 q11, q12 .long 0xf3f62222 // vmovn.i32 d18, q9 .long 0xf3f63224 // vmovn.i32 d19, q10 .long 0xf3d85030 // vshr.u16 d21, d16, #8 .long 0xf3d81033 // vshr.u16 d17, d19, #8 .long 0xf3f64226 // vmovn.i32 d20, q11 .long 0xf2d86530 // vshl.s16 d22, d16, #8 .long 0xf2d80533 // vshl.s16 d16, d19, #8 .long 0xf3d87032 // vshr.u16 d23, d18, #8 .long 0xf2d88532 // vshl.s16 d24, d18, #8 .long 0xf26031b1 // vorr d19, d16, d17 .long 0xf26621b5 // vorr d18, d22, d21 .long 0xf3d89034 // vshr.u16 d25, d20, #8 .long 0xf2d84534 // vshl.s16 d20, d20, #8 .long 0xf26811b7 // vorr d17, d24, d23 .long 0xf26401b9 // vorr d16, d20, d25 .long 0x1a000004 // bne 5648 .long 0xf443004f // vst4.16 {d16-d19}, [r3] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe35c0001 // cmp ip, #1 .long 0xf4c3070f // vst4.16 {d16[0],d17[0],d18[0],d19[0]}, [r3] .long 0x0afffff8 // beq 5638 .long 0xe2832008 // add r2, r3, #8 .long 0xe35c0003 // cmp ip, #3 .long 0xf4c2074f // vst4.16 {d16[1],d17[1],d18[1],d19[1]}, [r2] .long 0x3afffff4 // bcc 5638 .long 0xe2832010 // add r2, r3, #16 .long 0xf4c2078f // vst4.16 {d16[2],d17[2],d18[2],d19[2]}, [r2] .long 0xeafffff1 // b 5638 .long 0x477fff00 // .word 0x477fff00 .long 0x477fff00 // .word 0x477fff00 .long 0x477fff00 // .word 0x477fff00 .long 0x477fff00 // .word 0x477fff00 HIDDEN _sk_load_f32_vfp4 .globl _sk_load_f32_vfp4 FUNCTION(_sk_load_f32_vfp4) _sk_load_f32_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020392 // mul r2, r2, r3 .long 0xe0842102 // add r2, r4, r2, lsl #2 .long 0xe082220e // add r2, r2, lr, lsl #4 .long 0x1a000009 // bne 56d4 .long 0xf462018d // vld4.32 {d16,d18,d20,d22}, [r2]! .long 0xf462118f // vld4.32 {d17,d19,d21,d23}, [r2] .long 0xf22001f0 // vorr q0, q8, q8 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xf22441f4 // vorr q2, q10, q10 .long 0xf22661f6 // vorr q3, q11, q11 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xf4a20b4f // vld4.32 {d0[0],d2[0],d4[0],d6[0]}, [r2] .long 0xe35c0001 // cmp ip, #1 .long 0x0afffff8 // beq 56c4 .long 0xe2823010 // add r3, r2, #16 .long 0xe35c0003 // cmp ip, #3 .long 0xf4a30bcf // vld4.32 {d0[1],d2[1],d4[1],d6[1]}, [r3] .long 0x3afffff4 // bcc 56c4 .long 0xe2822020 // add r2, r2, #32 .long 0xf4a21b4f // vld4.32 {d1[0],d3[0],d5[0],d7[0]}, [r2] .long 0xeafffff1 // b 56c4 HIDDEN _sk_load_f32_dst_vfp4 .globl _sk_load_f32_dst_vfp4 FUNCTION(_sk_load_f32_dst_vfp4) _sk_load_f32_dst_vfp4: .long 0xe92d4070 // push {r4, r5, r6, lr} .long 0xe5912000 // ldr r2, [r1] .long 0xe280c040 // add ip, r0, #64 .long 0xe8900058 // ldm r0, {r3, r4, r6} .long 0xe280e030 // add lr, r0, #48 .long 0xe5925000 // ldr r5, [r2] .long 0xe3560000 // cmp r6, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020492 // mul r2, r2, r4 .long 0xe0852102 // add r2, r5, r2, lsl #2 .long 0xe0824203 // add r4, r2, r3, lsl #4 .long 0xe2802020 // add r2, r0, #32 .long 0xe2803010 // add r3, r0, #16 .long 0x1a00000e // bne 5770 .long 0xf464818d // vld4.32 {d24,d26,d28,d30}, [r4]! .long 0xf464918f // vld4.32 {d25,d27,d29,d31}, [r4] .long 0xf26801f8 // vorr q8, q12, q12 .long 0xf26a21fa // vorr q9, q13, q13 .long 0xf26c41fc // vorr q10, q14, q14 .long 0xf26e61fe // vorr q11, q15, q15 .long 0xf4430aef // vst1.64 {d16-d17}, [r3 :128] .long 0xf4422aef // vst1.64 {d18-d19}, [r2 :128] .long 0xe2812008 // add r2, r1, #8 .long 0xf44e4aef // vst1.64 {d20-d21}, [lr :128] .long 0xf44c6aef // vst1.64 {d22-d23}, [ip :128] .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe8bd4070 // pop {r4, r5, r6, lr} .long 0xe12fff13 // bx r3 .long 0xf4e40b4f // vld4.32 {d16[0],d18[0],d20[0],d22[0]}, [r4] .long 0xe3560001 // cmp r6, #1 .long 0x0afffff3 // beq 574c .long 0xe2845010 // add r5, r4, #16 .long 0xe3560003 // cmp r6, #3 .long 0xf4e50bcf // vld4.32 {d16[1],d18[1],d20[1],d22[1]}, [r5] .long 0x3affffef // bcc 574c .long 0xe2844020 // add r4, r4, #32 .long 0xf4e41b4f // vld4.32 {d17[0],d19[0],d21[0],d23[0]}, [r4] .long 0xeaffffec // b 574c HIDDEN _sk_store_f32_vfp4 .globl _sk_store_f32_vfp4 FUNCTION(_sk_store_f32_vfp4) _sk_store_f32_vfp4: .long 0xe92d4010 // push {r4, lr} .long 0xe5912000 // ldr r2, [r1] .long 0xe590e000 // ldr lr, [r0] .long 0xe9901008 // ldmib r0, {r3, ip} .long 0xe5924000 // ldr r4, [r2] .long 0xe35c0000 // cmp ip, #0 .long 0xe5922004 // ldr r2, [r2, #4] .long 0xe0020392 // mul r2, r2, r3 .long 0xe0842102 // add r2, r4, r2, lsl #2 .long 0xe082220e // add r2, r2, lr, lsl #4 .long 0x1a000005 // bne 57dc .long 0xf402018d // vst4.32 {d0,d2,d4,d6}, [r2]! .long 0xf402118f // vst4.32 {d1,d3,d5,d7}, [r2] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe8bd4010 // pop {r4, lr} .long 0xe12fff12 // bx r2 .long 0xe35c0001 // cmp ip, #1 .long 0xf4820b4f // vst4.32 {d0[0],d2[0],d4[0],d6[0]}, [r2] .long 0x0afffff8 // beq 57cc .long 0xe2823010 // add r3, r2, #16 .long 0xe35c0003 // cmp ip, #3 .long 0xf4830bcf // vst4.32 {d0[1],d2[1],d4[1],d6[1]}, [r3] .long 0x3afffff4 // bcc 57cc .long 0xe2822020 // add r2, r2, #32 .long 0xf4821b4f // vst4.32 {d1[0],d3[0],d5[0],d7[0]}, [r2] .long 0xeafffff1 // b 57cc HIDDEN _sk_clamp_x_vfp4 .globl _sk_clamp_x_vfp4 FUNCTION(_sk_clamp_x_vfp4) _sk_clamp_x_vfp4: .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe5913000 // ldr r3, [r1] .long 0xf3c72e5f // vmov.i8 q9, #255 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf2400fc0 // vmax.f32 q8, q8, q0 .long 0xe2811008 // add r1, r1, #8 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xf26428e2 // vadd.i32 q9, q10, q9 .long 0xf2200fe2 // vmin.f32 q0, q8, q9 .long 0xe12fff12 // bx r2 HIDDEN _sk_clamp_y_vfp4 .globl _sk_clamp_y_vfp4 FUNCTION(_sk_clamp_y_vfp4) _sk_clamp_y_vfp4: .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe5913000 // ldr r3, [r1] .long 0xf3c72e5f // vmov.i8 q9, #255 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf2400fc2 // vmax.f32 q8, q8, q1 .long 0xe2811008 // add r1, r1, #8 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xf26428e2 // vadd.i32 q9, q10, q9 .long 0xf2202fe2 // vmin.f32 q1, q8, q9 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} HIDDEN _sk_repeat_x_vfp4 .globl _sk_repeat_x_vfp4 FUNCTION(_sk_repeat_x_vfp4) _sk_repeat_x_vfp4: .long 0xe5913000 // ldr r3, [r1] .long 0xf2c06050 // vmov.i32 q11, #0 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf4e30cbd // vld1.32 {d16[]-d17[]}, [r3 :32]! .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe28f3038 // add r3, pc, #56 .long 0xf3422dd0 // vmul.f32 q9, q9, q0 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf3fb4762 // vcvt.s32.f32 q10, q9 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3642ee2 // vcgt.f32 q9, q10, q9 .long 0xf35821f6 // vbsl q9, q12, q11 .long 0xf2642de2 // vsub.f32 q9, q10, q9 .long 0xf3c74e5f // vmov.i8 q10, #255 .long 0xf3402df2 // vmul.f32 q9, q8, q9 .long 0xf26008e4 // vadd.i32 q8, q8, q10 .long 0xf2602d62 // vsub.f32 q9, q0, q9 .long 0xf2462fe2 // vmax.f32 q9, q11, q9 .long 0xf2220fe0 // vmin.f32 q0, q9, q8 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_repeat_y_vfp4 .globl _sk_repeat_y_vfp4 FUNCTION(_sk_repeat_y_vfp4) _sk_repeat_y_vfp4: .long 0xe5913000 // ldr r3, [r1] .long 0xf2c06050 // vmov.i32 q11, #0 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf4e30cbd // vld1.32 {d16[]-d17[]}, [r3 :32]! .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xe28f3038 // add r3, pc, #56 .long 0xf3422dd2 // vmul.f32 q9, q9, q1 .long 0xf4638acf // vld1.64 {d24-d25}, [r3] .long 0xf3fb4762 // vcvt.s32.f32 q10, q9 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3642ee2 // vcgt.f32 q9, q10, q9 .long 0xf35821f6 // vbsl q9, q12, q11 .long 0xf2642de2 // vsub.f32 q9, q10, q9 .long 0xf3c74e5f // vmov.i8 q10, #255 .long 0xf3402df2 // vmul.f32 q9, q8, q9 .long 0xf26008e4 // vadd.i32 q8, q8, q10 .long 0xf2622d62 // vsub.f32 q9, q1, q9 .long 0xf2462fe2 // vmax.f32 q9, q11, q9 .long 0xf2222fe0 // vmin.f32 q1, q9, q8 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_mirror_x_vfp4 .globl _sk_mirror_x_vfp4 FUNCTION(_sk_mirror_x_vfp4) _sk_mirror_x_vfp4: .long 0xed2d8b06 // vpush {d8-d10} .long 0xe5913000 // ldr r3, [r1] .long 0xeeb6aa00 // vmov.f32 s20, #96 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf2c08050 // vmov.i32 q12, #0 .long 0xe2811008 // add r1, r1, #8 .long 0xed938a00 // vldr s16, [r3] .long 0xed939a01 // vldr s18, [r3, #4] .long 0xe28f3050 // add r3, pc, #80 .long 0xf3f40c48 // vdup.32 q8, d8[0] .long 0xf2602d60 // vsub.f32 q9, q0, q8 .long 0xf463aacf // vld1.64 {d26-d27}, [r3] .long 0xee290a0a // vmul.f32 s0, s18, s20 .long 0xf3e249c0 // vmul.f32 q10, q9, d0[0] .long 0xee380a08 // vadd.f32 s0, s16, s16 .long 0xf3fb6764 // vcvt.s32.f32 q11, q10 .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3664ee4 // vcgt.f32 q10, q11, q10 .long 0xf35a41f8 // vbsl q10, q13, q12 .long 0xf2664de4 // vsub.f32 q10, q11, q10 .long 0xf3e449c0 // vmul.f32 q10, q10, d0[0] .long 0xf2622de4 // vsub.f32 q9, q9, q10 .long 0xf3c74e5f // vmov.i8 q10, #255 .long 0xf2622de0 // vsub.f32 q9, q9, q8 .long 0xf26008e4 // vadd.i32 q8, q8, q10 .long 0xf3f92762 // vabs.f32 q9, q9 .long 0xf2482fe2 // vmax.f32 q9, q12, q9 .long 0xf2220fe0 // vmin.f32 q0, q9, q8 .long 0xecbd8b06 // vpop {d8-d10} .long 0xe12fff12 // bx r2 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_mirror_y_vfp4 .globl _sk_mirror_y_vfp4 FUNCTION(_sk_mirror_y_vfp4) _sk_mirror_y_vfp4: .long 0xed2d8b06 // vpush {d8-d10} .long 0xe5913000 // ldr r3, [r1] .long 0xeeb6aa00 // vmov.f32 s20, #96 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xf2c08050 // vmov.i32 q12, #0 .long 0xe2811008 // add r1, r1, #8 .long 0xed938a00 // vldr s16, [r3] .long 0xed939a01 // vldr s18, [r3, #4] .long 0xe28f3050 // add r3, pc, #80 .long 0xf3f40c48 // vdup.32 q8, d8[0] .long 0xf2622d60 // vsub.f32 q9, q1, q8 .long 0xf463aacf // vld1.64 {d26-d27}, [r3] .long 0xee292a0a // vmul.f32 s4, s18, s20 .long 0xf3e249c2 // vmul.f32 q10, q9, d2[0] .long 0xee382a08 // vadd.f32 s4, s16, s16 .long 0xf3fb6764 // vcvt.s32.f32 q11, q10 .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3664ee4 // vcgt.f32 q10, q11, q10 .long 0xf35a41f8 // vbsl q10, q13, q12 .long 0xf2664de4 // vsub.f32 q10, q11, q10 .long 0xf3e449c2 // vmul.f32 q10, q10, d2[0] .long 0xf2622de4 // vsub.f32 q9, q9, q10 .long 0xf3c74e5f // vmov.i8 q10, #255 .long 0xf2622de0 // vsub.f32 q9, q9, q8 .long 0xf26008e4 // vadd.i32 q8, q8, q10 .long 0xf3f92762 // vabs.f32 q9, q9 .long 0xf2482fe2 // vmax.f32 q9, q12, q9 .long 0xf2222fe0 // vmin.f32 q1, q9, q8 .long 0xecbd8b06 // vpop {d8-d10} .long 0xe12fff12 // bx r2 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_clamp_x_1_vfp4 .globl _sk_clamp_x_1_vfp4 FUNCTION(_sk_clamp_x_1_vfp4) _sk_clamp_x_1_vfp4: .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2c72f50 // vmov.f32 q9, #1 .long 0xf2400fc0 // vmax.f32 q8, q8, q0 .long 0xf2200fe2 // vmin.f32 q0, q8, q9 .long 0xe12fff12 // bx r2 HIDDEN _sk_repeat_x_1_vfp4 .globl _sk_repeat_x_1_vfp4 FUNCTION(_sk_repeat_x_1_vfp4) _sk_repeat_x_1_vfp4: .long 0xf3fb0740 // vcvt.s32.f32 q8, q0 .long 0xe28f2024 // add r2, pc, #36 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xf2c04050 // vmov.i32 q10, #0 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3fb0660 // vcvt.f32.s32 q8, q8 .long 0xf3602ec0 // vcgt.f32 q9, q8, q0 .long 0xf35621f4 // vbsl q9, q11, q10 .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf2200d60 // vsub.f32 q0, q0, q8 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_mirror_x_1_vfp4 .globl _sk_mirror_x_1_vfp4 FUNCTION(_sk_mirror_x_1_vfp4) _sk_mirror_x_1_vfp4: .long 0xf3c70f50 // vmov.f32 q8, #-1 .long 0xe28f203c // add r2, pc, #60 .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf462aacf // vld1.64 {d26-d27}, [r2] .long 0xf2402d60 // vadd.f32 q9, q0, q8 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2c08050 // vmov.i32 q12, #0 .long 0xf3424df4 // vmul.f32 q10, q9, q10 .long 0xf3fb6764 // vcvt.s32.f32 q11, q10 .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3664ee4 // vcgt.f32 q10, q11, q10 .long 0xf35a41f8 // vbsl q10, q13, q12 .long 0xf2664de4 // vsub.f32 q10, q11, q10 .long 0xf2444de4 // vadd.f32 q10, q10, q10 .long 0xf2622de4 // vsub.f32 q9, q9, q10 .long 0xf2420de0 // vadd.f32 q8, q9, q8 .long 0xf3b90760 // vabs.f32 q0, q8 .long 0xe12fff12 // bx r2 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_luminance_to_alpha_vfp4 .globl _sk_luminance_to_alpha_vfp4 FUNCTION(_sk_luminance_to_alpha_vfp4) _sk_luminance_to_alpha_vfp4: .long 0xe28f2038 // add r2, pc, #56 .long 0xf4620acf // vld1.64 {d16-d17}, [r2] .long 0xe28f2040 // add r2, pc, #64 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xf3420d70 // vmul.f32 q8, q1, q8 .long 0xe28f2044 // add r2, pc, #68 .long 0xf2802050 // vmov.i32 q1, #0 .long 0xf3402d72 // vmul.f32 q9, q0, q9 .long 0xf2800050 // vmov.i32 q0, #0 .long 0xf2026de0 // vadd.f32 q3, q9, q8 .long 0xf4620acf // vld1.64 {d16-d17}, [r2] .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2046c70 // vfma.f32 q3, q2, q8 .long 0xf2804050 // vmov.i32 q2, #0 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0x3f371759 // .word 0x3f371759 .long 0x3f371759 // .word 0x3f371759 .long 0x3f371759 // .word 0x3f371759 .long 0x3f371759 // .word 0x3f371759 .long 0x3e59b3d0 // .word 0x3e59b3d0 .long 0x3e59b3d0 // .word 0x3e59b3d0 .long 0x3e59b3d0 // .word 0x3e59b3d0 .long 0x3e59b3d0 // .word 0x3e59b3d0 .long 0x3d93dd98 // .word 0x3d93dd98 .long 0x3d93dd98 // .word 0x3d93dd98 .long 0x3d93dd98 // .word 0x3d93dd98 .long 0x3d93dd98 // .word 0x3d93dd98 HIDDEN _sk_matrix_translate_vfp4 .globl _sk_matrix_translate_vfp4 FUNCTION(_sk_matrix_translate_vfp4) _sk_matrix_translate_vfp4: .long 0xe5913000 // ldr r3, [r1] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf4e30cbd // vld1.32 {d16[]-d17[]}, [r3 :32]! .long 0xf2000dc0 // vadd.f32 q0, q8, q0 .long 0xf4e32cbf // vld1.32 {d18[]-d19[]}, [r3 :32] .long 0xf2022dc2 // vadd.f32 q1, q9, q1 .long 0xe12fff12 // bx r2 HIDDEN _sk_matrix_scale_translate_vfp4 .globl _sk_matrix_scale_translate_vfp4 FUNCTION(_sk_matrix_scale_translate_vfp4) _sk_matrix_scale_translate_vfp4: .long 0xe92d4800 // push {fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xe2832008 // add r2, r3, #8 .long 0xe1a0e003 // mov lr, r3 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xe283200c // add r2, r3, #12 .long 0xf4ee0cbd // vld1.32 {d16[]-d17[]}, [lr :32]! .long 0xf2400c72 // vfma.f32 q8, q0, q9 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xf4ee2cbf // vld1.32 {d18[]-d19[]}, [lr :32] .long 0xf2422c74 // vfma.f32 q9, q1, q10 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xe8bd4800 // pop {fp, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_matrix_2x3_vfp4 .globl _sk_matrix_2x3_vfp4 FUNCTION(_sk_matrix_2x3_vfp4) _sk_matrix_2x3_vfp4: .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xe283200c // add r2, r3, #12 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xe2832008 // add r2, r3, #8 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xe2832010 // add r2, r3, #16 .long 0xf4e20cbf // vld1.32 {d16[]-d17[]}, [r2 :32] .long 0xe2832014 // add r2, r3, #20 .long 0xf2420c72 // vfma.f32 q8, q1, q9 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xf2422c74 // vfma.f32 q9, q1, q10 .long 0xf4e34cbd // vld1.32 {d20[]-d21[]}, [r3 :32]! .long 0xf4e36cbf // vld1.32 {d22[]-d23[]}, [r3 :32] .long 0xf2400c74 // vfma.f32 q8, q0, q10 .long 0xf2402c76 // vfma.f32 q9, q0, q11 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xe12fff1c // bx ip HIDDEN _sk_matrix_3x4_vfp4 .globl _sk_matrix_3x4_vfp4 FUNCTION(_sk_matrix_3x4_vfp4) _sk_matrix_3x4_vfp4: .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xe2832020 // add r2, r3, #32 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe283201c // add r2, r3, #28 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xe2832018 // add r2, r3, #24 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xe2832024 // add r2, r3, #36 .long 0xf4e20cbf // vld1.32 {d16[]-d17[]}, [r2 :32] .long 0xe2832028 // add r2, r3, #40 .long 0xf2440c72 // vfma.f32 q8, q2, q9 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xe283202c // add r2, r3, #44 .long 0xf2442c74 // vfma.f32 q9, q2, q10 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xe283200c // add r2, r3, #12 .long 0xf2444c76 // vfma.f32 q10, q2, q11 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe2832010 // add r2, r3, #16 .long 0xf2420c76 // vfma.f32 q8, q1, q11 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe2832014 // add r2, r3, #20 .long 0xf2422c76 // vfma.f32 q9, q1, q11 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe2832008 // add r2, r3, #8 .long 0xf2424c76 // vfma.f32 q10, q1, q11 .long 0xf4e36cbd // vld1.32 {d22[]-d23[]}, [r3 :32]! .long 0xf4e38cbf // vld1.32 {d24[]-d25[]}, [r3 :32] .long 0xf2400c76 // vfma.f32 q8, q0, q11 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xf2402c78 // vfma.f32 q9, q0, q12 .long 0xf2404c76 // vfma.f32 q10, q0, q11 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xf22441f4 // vorr q2, q10, q10 .long 0xe12fff1c // bx ip HIDDEN _sk_matrix_4x5_vfp4 .globl _sk_matrix_4x5_vfp4 FUNCTION(_sk_matrix_4x5_vfp4) _sk_matrix_4x5_vfp4: .long 0xe92d4800 // push {fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf2620152 // vorr q8, q1, q1 .long 0xf2666156 // vorr q11, q3, q3 .long 0xe2832030 // add r2, r3, #48 .long 0xf2644154 // vorr q10, q2, q2 .long 0xe1a0e003 // mov lr, r3 .long 0xe2811008 // add r1, r1, #8 .long 0xf4e2acbf // vld1.32 {d26[]-d27[]}, [r2 :32] .long 0xe2832038 // add r2, r3, #56 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xe283203c // add r2, r3, #60 .long 0xf4e2ccbf // vld1.32 {d28[]-d29[]}, [r2 :32] .long 0xe2832034 // add r2, r3, #52 .long 0xf4e2ecbf // vld1.32 {d30[]-d31[]}, [r2 :32] .long 0xe2832044 // add r2, r3, #68 .long 0xf4a22cbf // vld1.32 {d2[]-d3[]}, [r2 :32] .long 0xe283204c // add r2, r3, #76 .long 0xf2062cfe // vfma.f32 q1, q11, q15 .long 0xf4a26cbf // vld1.32 {d6[]-d7[]}, [r2 :32] .long 0xe2832048 // add r2, r3, #72 .long 0xf2066cfc // vfma.f32 q3, q11, q14 .long 0xf4a24cbf // vld1.32 {d4[]-d5[]}, [r2 :32] .long 0xe2832040 // add r2, r3, #64 .long 0xf2064cf2 // vfma.f32 q2, q11, q9 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xe283202c // add r2, r3, #44 .long 0xf2462cfa // vfma.f32 q9, q11, q13 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe2832028 // add r2, r3, #40 .long 0xf4ee8cbd // vld1.32 {d24[]-d25[]}, [lr :32]! .long 0xf2046cf6 // vfma.f32 q3, q10, q11 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe2832020 // add r2, r3, #32 .long 0xf2044cf6 // vfma.f32 q2, q10, q11 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe2832024 // add r2, r3, #36 .long 0xf2442cf6 // vfma.f32 q9, q10, q11 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe2832018 // add r2, r3, #24 .long 0xf2042cf6 // vfma.f32 q1, q10, q11 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xe2832010 // add r2, r3, #16 .long 0xf2004cf4 // vfma.f32 q2, q8, q10 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xe2832014 // add r2, r3, #20 .long 0xf2402cf4 // vfma.f32 q9, q8, q10 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xe283201c // add r2, r3, #28 .long 0xf2002cf4 // vfma.f32 q1, q8, q10 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xe2832008 // add r2, r3, #8 .long 0xf2006cf4 // vfma.f32 q3, q8, q10 .long 0xf4e20cbf // vld1.32 {d16[]-d17[]}, [r2 :32] .long 0xe283200c // add r2, r3, #12 .long 0xf2004c70 // vfma.f32 q2, q0, q8 .long 0xf4ee4cbf // vld1.32 {d20[]-d21[]}, [lr :32] .long 0xf2402c78 // vfma.f32 q9, q0, q12 .long 0xf2002c74 // vfma.f32 q1, q0, q10 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xf2006c74 // vfma.f32 q3, q0, q10 .long 0xf22201f2 // vorr q0, q9, q9 .long 0xe8bd4800 // pop {fp, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_matrix_4x3_vfp4 .globl _sk_matrix_4x3_vfp4 FUNCTION(_sk_matrix_4x3_vfp4) _sk_matrix_4x3_vfp4: .long 0xe92d4800 // push {fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xe283201c // add r2, r3, #28 .long 0xe1a0e003 // mov lr, r3 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe2832014 // add r2, r3, #20 .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xe2832010 // add r2, r3, #16 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xe2832018 // add r2, r3, #24 .long 0xf4e20cbf // vld1.32 {d16[]-d17[]}, [r2 :32] .long 0xe2832028 // add r2, r3, #40 .long 0xf4a24cbf // vld1.32 {d4[]-d5[]}, [r2 :32] .long 0xe2832020 // add r2, r3, #32 .long 0xf2024c70 // vfma.f32 q2, q1, q8 .long 0xf4e20cbf // vld1.32 {d16[]-d17[]}, [r2 :32] .long 0xe2832024 // add r2, r3, #36 .long 0xf2420c72 // vfma.f32 q8, q1, q9 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xe283202c // add r2, r3, #44 .long 0xf2422c78 // vfma.f32 q9, q1, q12 .long 0xf4ee4cbd // vld1.32 {d20[]-d21[]}, [lr :32]! .long 0xf4a26cbf // vld1.32 {d6[]-d7[]}, [r2 :32] .long 0xe2832008 // add r2, r3, #8 .long 0xf2026c76 // vfma.f32 q3, q1, q11 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe283200c // add r2, r3, #12 .long 0xf2400c74 // vfma.f32 q8, q0, q10 .long 0xf4ee4cbf // vld1.32 {d20[]-d21[]}, [lr :32] .long 0xf2402c74 // vfma.f32 q9, q0, q10 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xf2004c76 // vfma.f32 q2, q0, q11 .long 0xf2006c74 // vfma.f32 q3, q0, q10 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xf22221f2 // vorr q1, q9, q9 .long 0xe8bd4800 // pop {fp, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_matrix_perspective_vfp4 .globl _sk_matrix_perspective_vfp4 FUNCTION(_sk_matrix_perspective_vfp4) _sk_matrix_perspective_vfp4: .long 0xe92d4800 // push {fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xe283201c // add r2, r3, #28 .long 0xe1a0e003 // mov lr, r3 .long 0xf4e20cbf // vld1.32 {d16[]-d17[]}, [r2 :32] .long 0xe2832020 // add r2, r3, #32 .long 0xf4e22cbf // vld1.32 {d18[]-d19[]}, [r2 :32] .long 0xe2832018 // add r2, r3, #24 .long 0xf2422c70 // vfma.f32 q9, q1, q8 .long 0xf4e20cbf // vld1.32 {d16[]-d17[]}, [r2 :32] .long 0xe2832008 // add r2, r3, #8 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xe2832010 // add r2, r3, #16 .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xe2832014 // add r2, r3, #20 .long 0xf2402c70 // vfma.f32 q9, q0, q8 .long 0xf4ee0cbd // vld1.32 {d16[]-d17[]}, [lr :32]! .long 0xf4eeacbf // vld1.32 {d26[]-d27[]}, [lr :32] .long 0xf2424c7a // vfma.f32 q10, q1, q13 .long 0xf4e2acbf // vld1.32 {d26[]-d27[]}, [r2 :32] .long 0xe283200c // add r2, r3, #12 .long 0xf242ac78 // vfma.f32 q13, q1, q12 .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xf3fb6562 // vrecpe.f32 q11, q9 .long 0xf2404c70 // vfma.f32 q10, q0, q8 .long 0xf240ac78 // vfma.f32 q13, q0, q12 .long 0xf2422ff6 // vrecps.f32 q9, q9, q11 .long 0xf3460df2 // vmul.f32 q8, q11, q9 .long 0xf3040df0 // vmul.f32 q0, q10, q8 .long 0xf30a2df0 // vmul.f32 q1, q13, q8 .long 0xe8bd4800 // pop {fp, lr} .long 0xe12fff1c // bx ip HIDDEN _sk_evenly_spaced_gradient_vfp4 .globl _sk_evenly_spaced_gradient_vfp4 FUNCTION(_sk_evenly_spaced_gradient_vfp4) _sk_evenly_spaced_gradient_vfp4: .long 0xe92d4ff0 // push {r4, r5, r6, r7, r8, r9, sl, fp, lr} .long 0xe24dd004 // sub sp, sp, #4 .long 0xed2d8b10 // vpush {d8-d15} .long 0xe24dd008 // sub sp, sp, #8 .long 0xe2812004 // add r2, r1, #4 .long 0xe58d2004 // str r2, [sp, #4] .long 0xe1a0c001 // mov ip, r1 .long 0xf2600150 // vorr q8, q0, q0 .long 0xe49c4008 // ldr r4, [ip], #8 .long 0xe8944204 // ldm r4, {r2, r9, lr} .long 0xe2422001 // sub r2, r2, #1 .long 0xe5943010 // ldr r3, [r4, #16] .long 0xe5948020 // ldr r8, [r4, #32] .long 0xeea22b90 // vdup.32 q9, r2 .long 0xe594700c // ldr r7, [r4, #12] .long 0xf3fb26e2 // vcvt.f32.u32 q9, q9 .long 0xe594a01c // ldr sl, [r4, #28] .long 0xf3422df0 // vmul.f32 q9, q9, q8 .long 0xf3fb2762 // vcvt.s32.f32 q9, q9 .long 0xee336b90 // vmov.32 r6, d19[1] .long 0xee32bb90 // vmov.32 fp, d18[1] .long 0xe0832106 // add r2, r3, r6, lsl #2 .long 0xedd2ba00 // vldr s23, [r2] .long 0xee132b90 // vmov.32 r2, d19[0] .long 0xe0835102 // add r5, r3, r2, lsl #2 .long 0xed95ba00 // vldr s22, [r5] .long 0xe083510b // add r5, r3, fp, lsl #2 .long 0xedd5aa00 // vldr s21, [r5] .long 0xee125b90 // vmov.32 r5, d18[0] .long 0xe0833105 // add r3, r3, r5, lsl #2 .long 0xed93aa00 // vldr s20, [r3] .long 0xe0883106 // add r3, r8, r6, lsl #2 .long 0xedd37a00 // vldr s15, [r3] .long 0xe0883102 // add r3, r8, r2, lsl #2 .long 0xed937a00 // vldr s14, [r3] .long 0xe0873106 // add r3, r7, r6, lsl #2 .long 0xedd3da00 // vldr s27, [r3] .long 0xe0873102 // add r3, r7, r2, lsl #2 .long 0xed93da00 // vldr s26, [r3] .long 0xe087310b // add r3, r7, fp, lsl #2 .long 0xedd3ca00 // vldr s25, [r3] .long 0xe0873105 // add r3, r7, r5, lsl #2 .long 0xed93ca00 // vldr s24, [r3] .long 0xe08a3106 // add r3, sl, r6, lsl #2 .long 0xedd35a00 // vldr s11, [r3] .long 0xe5943018 // ldr r3, [r4, #24] .long 0xe5944014 // ldr r4, [r4, #20] .long 0xe0837106 // add r7, r3, r6, lsl #2 .long 0xedd73a00 // vldr s7, [r7] .long 0xe0837102 // add r7, r3, r2, lsl #2 .long 0xed973a00 // vldr s6, [r7] .long 0xe083710b // add r7, r3, fp, lsl #2 .long 0xe0833105 // add r3, r3, r5, lsl #2 .long 0xedd72a00 // vldr s5, [r7] .long 0xe0847106 // add r7, r4, r6, lsl #2 .long 0xedd79a00 // vldr s19, [r7] .long 0xe0847102 // add r7, r4, r2, lsl #2 .long 0xed932a00 // vldr s4, [r3] .long 0xe08a310b // add r3, sl, fp, lsl #2 .long 0xed979a00 // vldr s18, [r7] .long 0xe08e7106 // add r7, lr, r6, lsl #2 .long 0xe0896106 // add r6, r9, r6, lsl #2 .long 0xedd7fa00 // vldr s31, [r7] .long 0xe08e7105 // add r7, lr, r5, lsl #2 .long 0xedd61a00 // vldr s3, [r6] .long 0xe0896102 // add r6, r9, r2, lsl #2 .long 0xed961a00 // vldr s2, [r6] .long 0xe089610b // add r6, r9, fp, lsl #2 .long 0xedd60a00 // vldr s1, [r6] .long 0xe0896105 // add r6, r9, r5, lsl #2 .long 0xed960a00 // vldr s0, [r6] .long 0xe084610b // add r6, r4, fp, lsl #2 .long 0xe0844105 // add r4, r4, r5, lsl #2 .long 0xedd68a00 // vldr s17, [r6] .long 0xe08a6105 // add r6, sl, r5, lsl #2 .long 0xed948a00 // vldr s16, [r4] .long 0xe08e4102 // add r4, lr, r2, lsl #2 .long 0xe08a2102 // add r2, sl, r2, lsl #2 .long 0xf2008cd0 // vfma.f32 q4, q8, q0 .long 0xed94fa00 // vldr s30, [r4] .long 0xed925a00 // vldr s10, [r2] .long 0xe08e410b // add r4, lr, fp, lsl #2 .long 0xe088210b // add r2, r8, fp, lsl #2 .long 0xedd4ea00 // vldr s29, [r4] .long 0xe0884105 // add r4, r8, r5, lsl #2 .long 0xedd26a00 // vldr s13, [r2] .long 0xedd34a00 // vldr s9, [r3] .long 0xed946a00 // vldr s12, [r4] .long 0xed964a00 // vldr s8, [r6] .long 0xed97ea00 // vldr s28, [r7] .long 0xf2006cda // vfma.f32 q3, q8, q5 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe1a0100c // mov r1, ip .long 0xf2002cde // vfma.f32 q1, q8, q7 .long 0xf2004cdc // vfma.f32 q2, q8, q6 .long 0xf2280158 // vorr q0, q4, q4 .long 0xe28dd008 // add sp, sp, #8 .long 0xecbd8b10 // vpop {d8-d15} .long 0xe28dd004 // add sp, sp, #4 .long 0xe8bd4ff0 // pop {r4, r5, r6, r7, r8, r9, sl, fp, lr} .long 0xe12fff12 // bx r2 HIDDEN _sk_gauss_a_to_rgba_vfp4 .globl _sk_gauss_a_to_rgba_vfp4 FUNCTION(_sk_gauss_a_to_rgba_vfp4) _sk_gauss_a_to_rgba_vfp4: .long 0xe28f2048 // add r2, pc, #72 .long 0xf4620acf // vld1.64 {d16-d17}, [r2] .long 0xe28f2050 // add r2, pc, #80 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xe28f2058 // add r2, pc, #88 .long 0xf2462c70 // vfma.f32 q9, q3, q8 .long 0xf4620acf // vld1.64 {d16-d17}, [r2] .long 0xe28f205c // add r2, pc, #92 .long 0xf2460c72 // vfma.f32 q8, q3, q9 .long 0xf4622acf // vld1.64 {d18-d19}, [r2] .long 0xe28f2060 // add r2, pc, #96 .long 0xf4220acf // vld1.64 {d0-d1}, [r2] .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2462c70 // vfma.f32 q9, q3, q8 .long 0xf2060c72 // vfma.f32 q0, q3, q9 .long 0xf2202150 // vorr q1, q0, q0 .long 0xf2204150 // vorr q2, q0, q0 .long 0xf2206150 // vorr q3, q0, q0 .long 0xe12fff12 // bx r2 .long 0xe320f000 // nop {0} .long 0xc011102d // .word 0xc011102d .long 0xc011102d // .word 0xc011102d .long 0xc011102d // .word 0xc011102d .long 0xc011102d // .word 0xc011102d .long 0x40397812 // .word 0x40397812 .long 0x40397812 // .word 0x40397812 .long 0x40397812 // .word 0x40397812 .long 0x40397812 // .word 0x40397812 .long 0x3e5a9420 // .word 0x3e5a9420 .long 0x3e5a9420 // .word 0x3e5a9420 .long 0x3e5a9420 // .word 0x3e5a9420 .long 0x3e5a9420 // .word 0x3e5a9420 .long 0x3e1e9d04 // .word 0x3e1e9d04 .long 0x3e1e9d04 // .word 0x3e1e9d04 .long 0x3e1e9d04 // .word 0x3e1e9d04 .long 0x3e1e9d04 // .word 0x3e1e9d04 .long 0x39a11800 // .word 0x39a11800 .long 0x39a11800 // .word 0x39a11800 .long 0x39a11800 // .word 0x39a11800 .long 0x39a11800 // .word 0x39a11800 HIDDEN _sk_gradient_vfp4 .globl _sk_gradient_vfp4 FUNCTION(_sk_gradient_vfp4) _sk_gradient_vfp4: .long 0xe92d47f0 // push {r4, r5, r6, r7, r8, r9, sl, lr} .long 0xed2d8b10 // vpush {d8-d15} .long 0xe24dd008 // sub sp, sp, #8 .long 0xe2812004 // add r2, r1, #4 .long 0xe58d2004 // str r2, [sp, #4] .long 0xe5913000 // ldr r3, [r1] .long 0xf2606150 // vorr q11, q0, q0 .long 0xf2c02050 // vmov.i32 q9, #0 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe5931000 // ldr r1, [r3] .long 0xe3510002 // cmp r1, #2 .long 0x3a00000a // bcc 6144 .long 0xe5932024 // ldr r2, [r3, #36] .long 0xf2c04051 // vmov.i32 q10, #1 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe2411001 // sub r1, r1, #1 .long 0xe2822004 // add r2, r2, #4 .long 0xf4e28cbd // vld1.32 {d24[]-d25[]}, [r2 :32]! .long 0xe2511001 // subs r1, r1, #1 .long 0xf3468ee8 // vcge.f32 q12, q11, q12 .long 0xf35481f2 // vbsl q12, q10, q9 .long 0xf26808e0 // vadd.i32 q8, q12, q8 .long 0x1afffff9 // bne 612c .long 0xee315b90 // vmov.32 r5, d17[1] .long 0xe5937010 // ldr r7, [r3, #16] .long 0xee112b90 // vmov.32 r2, d17[0] .long 0xe593c020 // ldr ip, [r3, #32] .long 0xee301b90 // vmov.32 r1, d16[1] .long 0xe593400c // ldr r4, [r3, #12] .long 0xe593801c // ldr r8, [r3, #28] .long 0xe5939008 // ldr r9, [r3, #8] .long 0xe593e004 // ldr lr, [r3, #4] .long 0xe0876105 // add r6, r7, r5, lsl #2 .long 0xedd6ba00 // vldr s23, [r6] .long 0xe0876102 // add r6, r7, r2, lsl #2 .long 0xed96ba00 // vldr s22, [r6] .long 0xe0876101 // add r6, r7, r1, lsl #2 .long 0xedd6aa00 // vldr s21, [r6] .long 0xee106b90 // vmov.32 r6, d16[0] .long 0xe0877106 // add r7, r7, r6, lsl #2 .long 0xe088a106 // add sl, r8, r6, lsl #2 .long 0xed97aa00 // vldr s20, [r7] .long 0xe08c7105 // add r7, ip, r5, lsl #2 .long 0xedd77a00 // vldr s15, [r7] .long 0xe08c7102 // add r7, ip, r2, lsl #2 .long 0xed977a00 // vldr s14, [r7] .long 0xe0847105 // add r7, r4, r5, lsl #2 .long 0xedd7da00 // vldr s27, [r7] .long 0xe0847102 // add r7, r4, r2, lsl #2 .long 0xed97da00 // vldr s26, [r7] .long 0xe0847101 // add r7, r4, r1, lsl #2 .long 0xe0844106 // add r4, r4, r6, lsl #2 .long 0xedd7ca00 // vldr s25, [r7] .long 0xed94ca00 // vldr s24, [r4] .long 0xe0884105 // add r4, r8, r5, lsl #2 .long 0xedd45a00 // vldr s11, [r4] .long 0xe5934018 // ldr r4, [r3, #24] .long 0xe5933014 // ldr r3, [r3, #20] .long 0xe0847105 // add r7, r4, r5, lsl #2 .long 0xedd73a00 // vldr s7, [r7] .long 0xe0897105 // add r7, r9, r5, lsl #2 .long 0xedd7fa00 // vldr s31, [r7] .long 0xe0897102 // add r7, r9, r2, lsl #2 .long 0xed97fa00 // vldr s30, [r7] .long 0xe0897101 // add r7, r9, r1, lsl #2 .long 0xedd7ea00 // vldr s29, [r7] .long 0xe0837105 // add r7, r3, r5, lsl #2 .long 0xe08e5105 // add r5, lr, r5, lsl #2 .long 0xedd79a00 // vldr s19, [r7] .long 0xe0837102 // add r7, r3, r2, lsl #2 .long 0xedd51a00 // vldr s3, [r5] .long 0xe08e5102 // add r5, lr, r2, lsl #2 .long 0xed979a00 // vldr s18, [r7] .long 0xe0837101 // add r7, r3, r1, lsl #2 .long 0xed951a00 // vldr s2, [r5] .long 0xe08e5101 // add r5, lr, r1, lsl #2 .long 0xedd78a00 // vldr s17, [r7] .long 0xe0837106 // add r7, r3, r6, lsl #2 .long 0xe0893106 // add r3, r9, r6, lsl #2 .long 0xedd50a00 // vldr s1, [r5] .long 0xe08c9106 // add r9, ip, r6, lsl #2 .long 0xe0845106 // add r5, r4, r6, lsl #2 .long 0xe08e6106 // add r6, lr, r6, lsl #2 .long 0xed978a00 // vldr s16, [r7] .long 0xe0847102 // add r7, r4, r2, lsl #2 .long 0xe0882102 // add r2, r8, r2, lsl #2 .long 0xed960a00 // vldr s0, [r6] .long 0xed93ea00 // vldr s28, [r3] .long 0xe0843101 // add r3, r4, r1, lsl #2 .long 0xf2068cd0 // vfma.f32 q4, q11, q0 .long 0xed973a00 // vldr s6, [r7] .long 0xe0887101 // add r7, r8, r1, lsl #2 .long 0xed925a00 // vldr s10, [r2] .long 0xe08c1101 // add r1, ip, r1, lsl #2 .long 0xedd32a00 // vldr s5, [r3] .long 0xedd74a00 // vldr s9, [r7] .long 0xedd16a00 // vldr s13, [r1] .long 0xe59d1004 // ldr r1, [sp, #4] .long 0xed952a00 // vldr s4, [r5] .long 0xed9a4a00 // vldr s8, [sl] .long 0xed996a00 // vldr s12, [r9] .long 0xf2062cde // vfma.f32 q1, q11, q7 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2064cdc // vfma.f32 q2, q11, q6 .long 0xf2066cda // vfma.f32 q3, q11, q5 .long 0xf2280158 // vorr q0, q4, q4 .long 0xe28dd008 // add sp, sp, #8 .long 0xecbd8b10 // vpop {d8-d15} .long 0xe8bd47f0 // pop {r4, r5, r6, r7, r8, r9, sl, lr} .long 0xe12fff12 // bx r2 HIDDEN _sk_evenly_spaced_2_stop_gradient_vfp4 .globl _sk_evenly_spaced_2_stop_gradient_vfp4 FUNCTION(_sk_evenly_spaced_2_stop_gradient_vfp4) _sk_evenly_spaced_2_stop_gradient_vfp4: .long 0xe92d4800 // push {fp, lr} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xe2811008 // add r1, r1, #8 .long 0xe283200c // add r2, r3, #12 .long 0xe1a0e003 // mov lr, r3 .long 0xf4e24cbf // vld1.32 {d20[]-d21[]}, [r2 :32] .long 0xe283201c // add r2, r3, #28 .long 0xf4a26cbf // vld1.32 {d6[]-d7[]}, [r2 :32] .long 0xe2832008 // add r2, r3, #8 .long 0xf2006c74 // vfma.f32 q3, q0, q10 .long 0xf4e26cbf // vld1.32 {d22[]-d23[]}, [r2 :32] .long 0xe2832018 // add r2, r3, #24 .long 0xf4a24cbf // vld1.32 {d4[]-d5[]}, [r2 :32] .long 0xe2832010 // add r2, r3, #16 .long 0xf2004c76 // vfma.f32 q2, q0, q11 .long 0xf4e20cbf // vld1.32 {d16[]-d17[]}, [r2 :32] .long 0xe2832014 // add r2, r3, #20 .long 0xf4ee2cbd // vld1.32 {d18[]-d19[]}, [lr :32]! .long 0xf2400c72 // vfma.f32 q8, q0, q9 .long 0xf4ee2cbf // vld1.32 {d18[]-d19[]}, [lr :32] .long 0xf4a22cbf // vld1.32 {d2[]-d3[]}, [r2 :32] .long 0xf2002c72 // vfma.f32 q1, q0, q9 .long 0xf22001f0 // vorr q0, q8, q8 .long 0xe8bd4800 // pop {fp, lr} .long 0xe12fff1c // bx ip .long 0xe320f000 // nop {0} HIDDEN _sk_xy_to_unit_angle_vfp4 .globl _sk_xy_to_unit_angle_vfp4 FUNCTION(_sk_xy_to_unit_angle_vfp4) _sk_xy_to_unit_angle_vfp4: .long 0xed2d8b0c // vpush {d8-d13} .long 0xf3f90742 // vabs.f32 q8, q1 .long 0xe28f20a8 // add r2, pc, #168 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xe28f20b0 // add r2, pc, #176 .long 0xf3f92740 // vabs.f32 q9, q0 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xe28f20b4 // add r2, pc, #180 .long 0xf202afe0 // vmax.f32 q5, q9, q8 .long 0xf222cfe0 // vmin.f32 q6, q9, q8 .long 0xf3600ee2 // vcgt.f32 q8, q8, q9 .long 0xeecd9aab // vdiv.f32 s19, s27, s23 .long 0xee8d9a0b // vdiv.f32 s18, s26, s22 .long 0xeecc8aaa // vdiv.f32 s17, s25, s21 .long 0xee8c8a0a // vdiv.f32 s16, s24, s20 .long 0xf3484d58 // vmul.f32 q10, q4, q4 .long 0xf3446df6 // vmul.f32 q11, q10, q11 .long 0xf2466de8 // vadd.f32 q11, q11, q12 .long 0xf4628acf // vld1.64 {d24-d25}, [r2] .long 0xe28f2094 // add r2, pc, #148 .long 0xf3446df6 // vmul.f32 q11, q10, q11 .long 0xf2466de8 // vadd.f32 q11, q11, q12 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf4626acf // vld1.64 {d22-d23}, [r2] .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf2444de6 // vadd.f32 q10, q10, q11 .long 0xf2c56f50 // vmov.f32 q11, #0.25 .long 0xf3484d74 // vmul.f32 q10, q4, q10 .long 0xf2662de4 // vsub.f32 q9, q11, q10 .long 0xf35201f4 // vbsl q8, q9, q10 .long 0xf3f94640 // vclt.f32 q10, q0, #0 .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xf2622de0 // vsub.f32 q9, q9, q8 .long 0xf35241f0 // vbsl q10, q9, q8 .long 0xf3f92642 // vclt.f32 q9, q1, #0 .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xf2600de4 // vsub.f32 q8, q8, q10 .long 0xf35021f4 // vbsl q9, q8, q10 .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xf3424ee0 // vcge.f32 q10, q9, q8 .long 0xf3606ee2 // vcgt.f32 q11, q8, q9 .long 0xf26641f4 // vorr q10, q11, q10 .long 0xf3b005e4 // vmvn q0, q10 .long 0xf31001f2 // vbsl q0, q8, q9 .long 0xecbd8b0c // vpop {d8-d13} .long 0xe12fff12 // bx r2 .long 0xbbe72b6f // .word 0xbbe72b6f .long 0xbbe72b6f // .word 0xbbe72b6f .long 0xbbe72b6f // .word 0xbbe72b6f .long 0xbbe72b6f // .word 0xbbe72b6f .long 0x3ccad79f // .word 0x3ccad79f .long 0x3ccad79f // .word 0x3ccad79f .long 0x3ccad79f // .word 0x3ccad79f .long 0x3ccad79f // .word 0x3ccad79f .long 0xbd5464d4 // .word 0xbd5464d4 .long 0xbd5464d4 // .word 0xbd5464d4 .long 0xbd5464d4 // .word 0xbd5464d4 .long 0xbd5464d4 // .word 0xbd5464d4 .long 0x3e22f0a9 // .word 0x3e22f0a9 .long 0x3e22f0a9 // .word 0x3e22f0a9 .long 0x3e22f0a9 // .word 0x3e22f0a9 .long 0x3e22f0a9 // .word 0x3e22f0a9 HIDDEN _sk_xy_to_radius_vfp4 .globl _sk_xy_to_radius_vfp4 FUNCTION(_sk_xy_to_radius_vfp4) _sk_xy_to_radius_vfp4: .long 0xf3420d52 // vmul.f32 q8, q1, q1 .long 0xe4912004 // ldr r2, [r1], #4 .long 0xf3402d50 // vmul.f32 q9, q0, q0 .long 0xf2420de0 // vadd.f32 q8, q9, q8 .long 0xf3fb25e0 // vrsqrte.f32 q9, q8 .long 0xf3424df2 // vmul.f32 q10, q9, q9 .long 0xf2604ff4 // vrsqrts.f32 q10, q8, q10 .long 0xf3422df4 // vmul.f32 q9, q9, q10 .long 0xf3424df2 // vmul.f32 q10, q9, q9 .long 0xf2604ff4 // vrsqrts.f32 q10, q8, q10 .long 0xf3422df4 // vmul.f32 q9, q9, q10 .long 0xf3000df2 // vmul.f32 q0, q8, q9 .long 0xe12fff12 // bx r2 HIDDEN _sk_xy_to_2pt_conical_quadratic_max_vfp4 .globl _sk_xy_to_2pt_conical_quadratic_max_vfp4 FUNCTION(_sk_xy_to_2pt_conical_quadratic_max_vfp4) _sk_xy_to_2pt_conical_quadratic_max_vfp4: .long 0xed2d8b04 // vpush {d8-d9} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf3420d52 // vmul.f32 q8, q1, q1 .long 0xf3402d50 // vmul.f32 q9, q0, q0 .long 0xe2832020 // add r2, r3, #32 .long 0xf3c14f50 // vmov.f32 q10, #-4 .long 0xed938a0a // vldr s16, [r3, #40] .long 0xe2811008 // add r1, r1, #8 .long 0xed939a0b // vldr s18, [r3, #44] .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xf3484df4 // vmul.f32 q10, q12, q10 .long 0xe2832024 // add r2, r3, #36 .long 0xee299a08 // vmul.f32 s18, s18, s16 .long 0xee288a08 // vmul.f32 s16, s16, s16 .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xf2420de0 // vadd.f32 q8, q9, q8 .long 0xf3f42c49 // vdup.32 q9, d9[0] .long 0xf3f46c48 // vdup.32 q11, d8[0] .long 0xf2422dc0 // vadd.f32 q9, q9, q0 .long 0xf2600de6 // vsub.f32 q8, q8, q11 .long 0xf3c46650 // vmov.i32 q11, #-1073741824 .long 0xf3422df6 // vmul.f32 q9, q9, q11 .long 0xf3440df0 // vmul.f32 q8, q10, q8 .long 0xf2420cf2 // vfma.f32 q8, q9, q9 .long 0xf3fb45e0 // vrsqrte.f32 q10, q8 .long 0xf3446df4 // vmul.f32 q11, q10, q10 .long 0xf2606ff6 // vrsqrts.f32 q11, q8, q11 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf3446df4 // vmul.f32 q11, q10, q10 .long 0xf2606ff6 // vrsqrts.f32 q11, q8, q11 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf3f967e2 // vneg.f32 q11, q9 .long 0xf3440df0 // vmul.f32 q8, q10, q8 .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf3484df4 // vmul.f32 q10, q12, q10 .long 0xf2666de0 // vsub.f32 q11, q11, q8 .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf3442df6 // vmul.f32 q9, q10, q11 .long 0xf3440df0 // vmul.f32 q8, q10, q8 .long 0xf2000fe2 // vmax.f32 q0, q8, q9 .long 0xecbd8b04 // vpop {d8-d9} .long 0xe12fff1c // bx ip HIDDEN _sk_xy_to_2pt_conical_quadratic_min_vfp4 .globl _sk_xy_to_2pt_conical_quadratic_min_vfp4 FUNCTION(_sk_xy_to_2pt_conical_quadratic_min_vfp4) _sk_xy_to_2pt_conical_quadratic_min_vfp4: .long 0xed2d8b04 // vpush {d8-d9} .long 0xe8911008 // ldm r1, {r3, ip} .long 0xf3420d52 // vmul.f32 q8, q1, q1 .long 0xf3402d50 // vmul.f32 q9, q0, q0 .long 0xe2832020 // add r2, r3, #32 .long 0xf3c14f50 // vmov.f32 q10, #-4 .long 0xed938a0a // vldr s16, [r3, #40] .long 0xe2811008 // add r1, r1, #8 .long 0xed939a0b // vldr s18, [r3, #44] .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xf3484df4 // vmul.f32 q10, q12, q10 .long 0xe2832024 // add r2, r3, #36 .long 0xee299a08 // vmul.f32 s18, s18, s16 .long 0xee288a08 // vmul.f32 s16, s16, s16 .long 0xf4e28cbf // vld1.32 {d24[]-d25[]}, [r2 :32] .long 0xf2420de0 // vadd.f32 q8, q9, q8 .long 0xf3f42c49 // vdup.32 q9, d9[0] .long 0xf3f46c48 // vdup.32 q11, d8[0] .long 0xf2422dc0 // vadd.f32 q9, q9, q0 .long 0xf2600de6 // vsub.f32 q8, q8, q11 .long 0xf3c46650 // vmov.i32 q11, #-1073741824 .long 0xf3422df6 // vmul.f32 q9, q9, q11 .long 0xf3440df0 // vmul.f32 q8, q10, q8 .long 0xf2420cf2 // vfma.f32 q8, q9, q9 .long 0xf3fb45e0 // vrsqrte.f32 q10, q8 .long 0xf3446df4 // vmul.f32 q11, q10, q10 .long 0xf2606ff6 // vrsqrts.f32 q11, q8, q11 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf3446df4 // vmul.f32 q11, q10, q10 .long 0xf2606ff6 // vrsqrts.f32 q11, q8, q11 .long 0xf3444df6 // vmul.f32 q10, q10, q11 .long 0xf3f967e2 // vneg.f32 q11, q9 .long 0xf3440df0 // vmul.f32 q8, q10, q8 .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf3484df4 // vmul.f32 q10, q12, q10 .long 0xf2666de0 // vsub.f32 q11, q11, q8 .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf3442df6 // vmul.f32 q9, q10, q11 .long 0xf3440df0 // vmul.f32 q8, q10, q8 .long 0xf2200fe2 // vmin.f32 q0, q8, q9 .long 0xecbd8b04 // vpop {d8-d9} .long 0xe12fff1c // bx ip HIDDEN _sk_xy_to_2pt_conical_linear_vfp4 .globl _sk_xy_to_2pt_conical_linear_vfp4 FUNCTION(_sk_xy_to_2pt_conical_linear_vfp4) _sk_xy_to_2pt_conical_linear_vfp4: .long 0xed2d8b08 // vpush {d8-d11} .long 0xe5913000 // ldr r3, [r1] .long 0xf3420d52 // vmul.f32 q8, q1, q1 .long 0xf3402d50 // vmul.f32 q9, q0, q0 .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xed938a0a // vldr s16, [r3, #40] .long 0xed939a0b // vldr s18, [r3, #44] .long 0xee28aa08 // vmul.f32 s20, s16, s16 .long 0xee298a08 // vmul.f32 s16, s18, s16 .long 0xf2420de0 // vadd.f32 q8, q9, q8 .long 0xf3f42c4a // vdup.32 q9, d10[0] .long 0xf3f44c48 // vdup.32 q10, d8[0] .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf2442dc0 // vadd.f32 q9, q10, q0 .long 0xf3c44650 // vmov.i32 q10, #-1073741824 .long 0xf3b987e0 // vneg.f32 q4, q8 .long 0xf302adf4 // vmul.f32 q5, q9, q10 .long 0xeec91aab // vdiv.f32 s3, s19, s23 .long 0xee891a0b // vdiv.f32 s2, s18, s22 .long 0xeec80aaa // vdiv.f32 s1, s17, s21 .long 0xee880a0a // vdiv.f32 s0, s16, s20 .long 0xecbd8b08 // vpop {d8-d11} .long 0xe12fff12 // bx r2 HIDDEN _sk_mask_2pt_conical_degenerates_vfp4 .globl _sk_mask_2pt_conical_degenerates_vfp4 FUNCTION(_sk_mask_2pt_conical_degenerates_vfp4) _sk_mask_2pt_conical_degenerates_vfp4: .long 0xf2c00050 // vmov.i32 q8, #0 .long 0xe5912000 // ldr r2, [r1] .long 0xf3402e60 // vcge.f32 q9, q0, q8 .long 0xe282302c // add r3, r2, #44 .long 0xf3600ec0 // vcgt.f32 q8, q8, q0 .long 0xf4e34cbf // vld1.32 {d20[]-d21[]}, [r3 :32] .long 0xe2823028 // add r3, r2, #40 .long 0xf4e36cbf // vld1.32 {d22[]-d23[]}, [r3 :32] .long 0xf2406c74 // vfma.f32 q11, q0, q10 .long 0xf26001f2 // vorr q8, q8, q9 .long 0xf3f924e6 // vcge.f32 q9, q11, #0 .long 0xf3f62222 // vmovn.i32 d18, q9 .long 0xf3f60220 // vmovn.i32 d16, q8 .long 0xf24201b0 // vand d16, d18, d16 .long 0xf2c1205f // vmov.i32 q9, #31 .long 0xf3d00a30 // vmovl.u16 q8, d16 .long 0xf3f923e2 // vneg.s32 q9, q9 .long 0xf2ff0570 // vshl.s32 q8, q8, #31 .long 0xf26204e0 // vshl.s32 q8, q8, q9 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 HIDDEN _sk_apply_vector_mask_vfp4 .globl _sk_apply_vector_mask_vfp4 FUNCTION(_sk_apply_vector_mask_vfp4) _sk_apply_vector_mask_vfp4: .long 0xe5913000 // ldr r3, [r1] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xf4630a8f // vld1.32 {d16-d17}, [r3] .long 0xf20001d0 // vand q0, q8, q0 .long 0xf20021d2 // vand q1, q8, q1 .long 0xf20041d4 // vand q2, q8, q2 .long 0xf20061d6 // vand q3, q8, q3 .long 0xe12fff12 // bx r2 HIDDEN _sk_save_xy_vfp4 .globl _sk_save_xy_vfp4 FUNCTION(_sk_save_xy_vfp4) _sk_save_xy_vfp4: .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xe28f206c // add r2, pc, #108 .long 0xf462cacf // vld1.64 {d28-d29}, [r2] .long 0xf2c0a050 // vmov.i32 q13, #0 .long 0xf2402d60 // vadd.f32 q9, q0, q8 .long 0xe5912000 // ldr r2, [r1] .long 0xf2420d60 // vadd.f32 q8, q1, q8 .long 0xe2823020 // add r3, r2, #32 .long 0xf4020a8f // vst1.32 {d0-d1}, [r2] .long 0xf3fb4762 // vcvt.s32.f32 q10, q9 .long 0xf4032a8f // vst1.32 {d2-d3}, [r3] .long 0xe2823040 // add r3, r2, #64 .long 0xf3fb6760 // vcvt.s32.f32 q11, q8 .long 0xe2822060 // add r2, r2, #96 .long 0xf3fb4664 // vcvt.f32.s32 q10, q10 .long 0xf3fb6666 // vcvt.f32.s32 q11, q11 .long 0xf3648ee2 // vcgt.f32 q12, q10, q9 .long 0xf366eee0 // vcgt.f32 q15, q11, q8 .long 0xf35c81fa // vbsl q12, q14, q13 .long 0xf35ce1fa // vbsl q15, q14, q13 .long 0xf2644de8 // vsub.f32 q10, q10, q12 .long 0xf2666dee // vsub.f32 q11, q11, q15 .long 0xf2622de4 // vsub.f32 q9, q9, q10 .long 0xf2600de6 // vsub.f32 q8, q8, q11 .long 0xf4432a8f // vst1.32 {d18-d19}, [r3] .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 .long 0x3f800000 // .word 0x3f800000 HIDDEN _sk_accumulate_vfp4 .globl _sk_accumulate_vfp4 FUNCTION(_sk_accumulate_vfp4) _sk_accumulate_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xe28230a0 // add r3, r2, #160 .long 0xe2822080 // add r2, r2, #128 .long 0xf4630a8f // vld1.32 {d16-d17}, [r3] .long 0xf4622a8f // vld1.32 {d18-d19}, [r2] .long 0xe2802010 // add r2, r0, #16 .long 0xf3420df0 // vmul.f32 q8, q9, q8 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2402cd0 // vfma.f32 q9, q8, q0 .long 0xf4422aef // vst1.64 {d18-d19}, [r2 :128] .long 0xe2802020 // add r2, r0, #32 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2402cd2 // vfma.f32 q9, q8, q1 .long 0xf4422aef // vst1.64 {d18-d19}, [r2 :128] .long 0xe2802030 // add r2, r0, #48 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2402cd4 // vfma.f32 q9, q8, q2 .long 0xf4422aef // vst1.64 {d18-d19}, [r2 :128] .long 0xe2802040 // add r2, r0, #64 .long 0xf4622aef // vld1.64 {d18-d19}, [r2 :128] .long 0xf2402cd6 // vfma.f32 q9, q8, q3 .long 0xf4422aef // vst1.64 {d18-d19}, [r2 :128] .long 0xe5912004 // ldr r2, [r1, #4] .long 0xe2811008 // add r1, r1, #8 .long 0xe12fff12 // bx r2 HIDDEN _sk_bilinear_nx_vfp4 .globl _sk_bilinear_nx_vfp4 FUNCTION(_sk_bilinear_nx_vfp4) _sk_bilinear_nx_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2823040 // add r3, r2, #64 .long 0xf4624a8f // vld1.32 {d20-d21}, [r2] .long 0xe2822080 // add r2, r2, #128 .long 0xf4632a8f // vld1.32 {d18-d19}, [r3] .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf3c3265f // vmov.i32 q9, #-1090519040 .long 0xf2040de2 // vadd.f32 q0, q10, q9 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 HIDDEN _sk_bilinear_px_vfp4 .globl _sk_bilinear_px_vfp4 FUNCTION(_sk_bilinear_px_vfp4) _sk_bilinear_px_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf4622a8f // vld1.32 {d18-d19}, [r2] .long 0xe2823040 // add r3, r2, #64 .long 0xf2020de0 // vadd.f32 q0, q9, q8 .long 0xe2822080 // add r2, r2, #128 .long 0xf4630a8f // vld1.32 {d16-d17}, [r3] .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 HIDDEN _sk_bilinear_ny_vfp4 .globl _sk_bilinear_ny_vfp4 FUNCTION(_sk_bilinear_ny_vfp4) _sk_bilinear_ny_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2823060 // add r3, r2, #96 .long 0xf4632a8f // vld1.32 {d18-d19}, [r3] .long 0xe2823020 // add r3, r2, #32 .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xe28220a0 // add r2, r2, #160 .long 0xf4634a8f // vld1.32 {d20-d21}, [r3] .long 0xf3c3265f // vmov.i32 q9, #-1090519040 .long 0xf2042de2 // vadd.f32 q1, q10, q9 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 HIDDEN _sk_bilinear_py_vfp4 .globl _sk_bilinear_py_vfp4 FUNCTION(_sk_bilinear_py_vfp4) _sk_bilinear_py_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xf2c3265f // vmov.i32 q9, #1056964608 .long 0xe2823060 // add r3, r2, #96 .long 0xf4630a8f // vld1.32 {d16-d17}, [r3] .long 0xe2823020 // add r3, r2, #32 .long 0xe28220a0 // add r2, r2, #160 .long 0xf4634a8f // vld1.32 {d20-d21}, [r3] .long 0xf2042de2 // vadd.f32 q1, q10, q9 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0xe320f000 // nop {0} HIDDEN _sk_bicubic_n3x_vfp4 .globl _sk_bicubic_n3x_vfp4 FUNCTION(_sk_bicubic_n3x_vfp4) _sk_bicubic_n3x_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2823040 // add r3, r2, #64 .long 0xf4632a8f // vld1.32 {d18-d19}, [r3] .long 0xe28f3040 // add r3, pc, #64 .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf4632acf // vld1.64 {d18-d19}, [r3] .long 0xe28f3044 // add r3, pc, #68 .long 0xf4634acf // vld1.64 {d20-d21}, [r3] .long 0xf2404cf2 // vfma.f32 q10, q8, q9 .long 0xf3400df0 // vmul.f32 q8, q8, q8 .long 0xf3c72f58 // vmov.f32 q9, #-1.5 .long 0xf3400df4 // vmul.f32 q8, q8, q10 .long 0xf4624a8f // vld1.32 {d20-d21}, [r2] .long 0xe2822080 // add r2, r2, #128 .long 0xf2040de2 // vadd.f32 q0, q10, q9 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0xe320f000 // nop {0} .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab HIDDEN _sk_bicubic_n1x_vfp4 .globl _sk_bicubic_n1x_vfp4 FUNCTION(_sk_bicubic_n1x_vfp4) _sk_bicubic_n1x_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2823040 // add r3, r2, #64 .long 0xf4632a8f // vld1.32 {d18-d19}, [r3] .long 0xe28f3048 // add r3, pc, #72 .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf4634acf // vld1.64 {d20-d21}, [r3] .long 0xe28f304c // add r3, pc, #76 .long 0xf2c72f58 // vmov.f32 q9, #1.5 .long 0xf2402cf4 // vfma.f32 q9, q8, q10 .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf2404cf2 // vfma.f32 q10, q8, q9 .long 0xf4632acf // vld1.64 {d18-d19}, [r3] .long 0xf2402cf4 // vfma.f32 q9, q8, q10 .long 0xf4624a8f // vld1.32 {d20-d21}, [r2] .long 0xe2822080 // add r2, r2, #128 .long 0xf3c3065f // vmov.i32 q8, #-1090519040 .long 0xf2040de0 // vadd.f32 q0, q10, q8 .long 0xf4422a8f // vst1.32 {d18-d19}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0xe320f000 // nop {0} .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 HIDDEN _sk_bicubic_p1x_vfp4 .globl _sk_bicubic_p1x_vfp4 FUNCTION(_sk_bicubic_p1x_vfp4) _sk_bicubic_p1x_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xe28f304c // add r3, pc, #76 .long 0xf4630acf // vld1.64 {d16-d17}, [r3] .long 0xf2c72f58 // vmov.f32 q9, #1.5 .long 0xe2823040 // add r3, r2, #64 .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xf4634a8f // vld1.32 {d20-d21}, [r3] .long 0xe28f3044 // add r3, pc, #68 .long 0xf2442cf0 // vfma.f32 q9, q10, q8 .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf2446cf2 // vfma.f32 q11, q10, q9 .long 0xf4632acf // vld1.64 {d18-d19}, [r3] .long 0xf2442cf6 // vfma.f32 q9, q10, q11 .long 0xf4624a8f // vld1.32 {d20-d21}, [r2] .long 0xe2822080 // add r2, r2, #128 .long 0xf2040de0 // vadd.f32 q0, q10, q8 .long 0xf4422a8f // vst1.32 {d18-d19}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0xe320f000 // nop {0} .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 HIDDEN _sk_bicubic_p3x_vfp4 .globl _sk_bicubic_p3x_vfp4 FUNCTION(_sk_bicubic_p3x_vfp4) _sk_bicubic_p3x_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xe28f3044 // add r3, pc, #68 .long 0xf4630acf // vld1.64 {d16-d17}, [r3] .long 0xe2823040 // add r3, r2, #64 .long 0xf4632a8f // vld1.32 {d18-d19}, [r3] .long 0xe28f3044 // add r3, pc, #68 .long 0xf4634acf // vld1.64 {d20-d21}, [r3] .long 0xf2424cf0 // vfma.f32 q10, q9, q8 .long 0xf3420df2 // vmul.f32 q8, q9, q9 .long 0xf2c72f58 // vmov.f32 q9, #1.5 .long 0xf3400df4 // vmul.f32 q8, q8, q10 .long 0xf4624a8f // vld1.32 {d20-d21}, [r2] .long 0xe2822080 // add r2, r2, #128 .long 0xf2040de2 // vadd.f32 q0, q10, q9 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0xe320f000 // nop {0} .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab HIDDEN _sk_bicubic_n3y_vfp4 .globl _sk_bicubic_n3y_vfp4 FUNCTION(_sk_bicubic_n3y_vfp4) _sk_bicubic_n3y_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2823060 // add r3, r2, #96 .long 0xf4632a8f // vld1.32 {d18-d19}, [r3] .long 0xe28f3040 // add r3, pc, #64 .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf4632acf // vld1.64 {d18-d19}, [r3] .long 0xe28f3044 // add r3, pc, #68 .long 0xf4634acf // vld1.64 {d20-d21}, [r3] .long 0xe2823020 // add r3, r2, #32 .long 0xe28220a0 // add r2, r2, #160 .long 0xf2404cf2 // vfma.f32 q10, q8, q9 .long 0xf3400df0 // vmul.f32 q8, q8, q8 .long 0xf3c72f58 // vmov.f32 q9, #-1.5 .long 0xf3400df4 // vmul.f32 q8, q8, q10 .long 0xf4634a8f // vld1.32 {d20-d21}, [r3] .long 0xf2042de2 // vadd.f32 q1, q10, q9 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab HIDDEN _sk_bicubic_n1y_vfp4 .globl _sk_bicubic_n1y_vfp4 FUNCTION(_sk_bicubic_n1y_vfp4) _sk_bicubic_n1y_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xf2c70f50 // vmov.f32 q8, #1 .long 0xe2823060 // add r3, r2, #96 .long 0xf4632a8f // vld1.32 {d18-d19}, [r3] .long 0xe28f3048 // add r3, pc, #72 .long 0xf2600de2 // vsub.f32 q8, q8, q9 .long 0xf4634acf // vld1.64 {d20-d21}, [r3] .long 0xe28f304c // add r3, pc, #76 .long 0xf2c72f58 // vmov.f32 q9, #1.5 .long 0xf2402cf4 // vfma.f32 q9, q8, q10 .long 0xf2c3465f // vmov.i32 q10, #1056964608 .long 0xf2404cf2 // vfma.f32 q10, q8, q9 .long 0xf4632acf // vld1.64 {d18-d19}, [r3] .long 0xe2823020 // add r3, r2, #32 .long 0xe28220a0 // add r2, r2, #160 .long 0xf2402cf4 // vfma.f32 q9, q8, q10 .long 0xf4634a8f // vld1.32 {d20-d21}, [r3] .long 0xf3c3065f // vmov.i32 q8, #-1090519040 .long 0xf2042de0 // vadd.f32 q1, q10, q8 .long 0xf4422a8f // vst1.32 {d18-d19}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 HIDDEN _sk_bicubic_p1y_vfp4 .globl _sk_bicubic_p1y_vfp4 FUNCTION(_sk_bicubic_p1y_vfp4) _sk_bicubic_p1y_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xe28f304c // add r3, pc, #76 .long 0xf4630acf // vld1.64 {d16-d17}, [r3] .long 0xf2c72f58 // vmov.f32 q9, #1.5 .long 0xe2823060 // add r3, r2, #96 .long 0xf2c3665f // vmov.i32 q11, #1056964608 .long 0xf4634a8f // vld1.32 {d20-d21}, [r3] .long 0xe28f3044 // add r3, pc, #68 .long 0xf2442cf0 // vfma.f32 q9, q10, q8 .long 0xf2c3065f // vmov.i32 q8, #1056964608 .long 0xf2446cf2 // vfma.f32 q11, q10, q9 .long 0xf4632acf // vld1.64 {d18-d19}, [r3] .long 0xe2823020 // add r3, r2, #32 .long 0xe28220a0 // add r2, r2, #160 .long 0xf2442cf6 // vfma.f32 q9, q10, q11 .long 0xf4634a8f // vld1.32 {d20-d21}, [r3] .long 0xf2042de0 // vadd.f32 q1, q10, q8 .long 0xf4422a8f // vst1.32 {d18-d19}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0xbf955555 // .word 0xbf955555 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 .long 0x3d638e39 // .word 0x3d638e39 HIDDEN _sk_bicubic_p3y_vfp4 .globl _sk_bicubic_p3y_vfp4 FUNCTION(_sk_bicubic_p3y_vfp4) _sk_bicubic_p3y_vfp4: .long 0xe5912000 // ldr r2, [r1] .long 0xe28f3044 // add r3, pc, #68 .long 0xf4630acf // vld1.64 {d16-d17}, [r3] .long 0xe2823060 // add r3, r2, #96 .long 0xf4632a8f // vld1.32 {d18-d19}, [r3] .long 0xe28f3044 // add r3, pc, #68 .long 0xf4634acf // vld1.64 {d20-d21}, [r3] .long 0xe2823020 // add r3, r2, #32 .long 0xf2424cf0 // vfma.f32 q10, q9, q8 .long 0xe28220a0 // add r2, r2, #160 .long 0xf3420df2 // vmul.f32 q8, q9, q9 .long 0xf2c72f58 // vmov.f32 q9, #1.5 .long 0xf3400df4 // vmul.f32 q8, q8, q10 .long 0xf4634a8f // vld1.32 {d20-d21}, [r3] .long 0xf2042de2 // vadd.f32 q1, q10, q9 .long 0xf4420a8f // vst1.32 {d16-d17}, [r2] .long 0xe2812008 // add r2, r1, #8 .long 0xe5913004 // ldr r3, [r1, #4] .long 0xe1a01002 // mov r1, r2 .long 0xe12fff13 // bx r3 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0x3ec71c72 // .word 0x3ec71c72 .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab .long 0xbeaaaaab // .word 0xbeaaaaab HIDDEN _sk_callback_vfp4 .globl _sk_callback_vfp4 FUNCTION(_sk_callback_vfp4) _sk_callback_vfp4: .long 0xe92d4c70 // push {r4, r5, r6, sl, fp, lr} .long 0xe28db010 // add fp, sp, #16 .long 0xe1a04001 // mov r4, r1 .long 0xe1a05000 // mov r5, r0 .long 0xe5946000 // ldr r6, [r4] .long 0xe5951008 // ldr r1, [r5, #8] .long 0xe2860004 // add r0, r6, #4 .long 0xe3510000 // cmp r1, #0 .long 0xf400018d // vst4.32 {d0,d2,d4,d6}, [r0]! .long 0x03a01004 // moveq r1, #4 .long 0xf400118f // vst4.32 {d1,d3,d5,d7}, [r0] .long 0xe1a00006 // mov r0, r6 .long 0xe5962000 // ldr r2, [r6] .long 0xe12fff32 // blx r2 .long 0xe5960084 // ldr r0, [r6, #132] .long 0xe2841008 // add r1, r4, #8 .long 0xf420018d // vld4.32 {d0,d2,d4,d6}, [r0]! .long 0xf420118f // vld4.32 {d1,d3,d5,d7}, [r0] .long 0xe1a00005 // mov r0, r5 .long 0xe5942004 // ldr r2, [r4, #4] .long 0xe8bd4c70 // pop {r4, r5, r6, sl, fp, lr} .long 0xe12fff12 // bx r2 #elif defined(__x86_64__) BALIGN32 HIDDEN _sk_start_pipeline_hsw .globl _sk_start_pipeline_hsw FUNCTION(_sk_start_pipeline_hsw) _sk_start_pipeline_hsw: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,236,40 // sub $0x28,%rsp .byte 72,137,211 // mov %rdx,%rbx .byte 73,137,246 // mov %rsi,%r14 .byte 72,137,125,208 // mov %rdi,-0x30(%rbp) .byte 76,137,198 // mov %r8,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,137,194 // mov %rax,%rdx .byte 72,137,77,176 // mov %rcx,-0x50(%rbp) .byte 73,57,206 // cmp %rcx,%r14 .byte 115,117 // jae a1 <_sk_start_pipeline_hsw+0xa1> .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,141,64,8 // lea 0x8(%rax),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 76,137,77,192 // mov %r9,-0x40(%rbp) .byte 72,137,85,200 // mov %rdx,-0x38(%rbp) .byte 73,137,221 // mov %rbx,%r13 .byte 73,137,244 // mov %rsi,%r12 .byte 72,139,85,208 // mov -0x30(%rbp),%rdx .byte 72,57,93,184 // cmp %rbx,-0x48(%rbp) .byte 119,45 // ja 7d <_sk_start_pipeline_hsw+0x7d> .byte 76,139,125,208 // mov -0x30(%rbp),%r15 .byte 69,49,192 // xor %r8d,%r8d .byte 76,137,207 // mov %r9,%rdi .byte 76,137,230 // mov %r12,%rsi .byte 76,137,250 // mov %r15,%rdx .byte 76,137,241 // mov %r14,%rcx .byte 255,85,200 // callq *-0x38(%rbp) .byte 76,137,235 // mov %r13,%rbx .byte 76,139,77,192 // mov -0x40(%rbp),%r9 .byte 73,141,87,8 // lea 0x8(%r15),%rdx .byte 73,131,199,16 // add $0x10,%r15 .byte 73,57,223 // cmp %rbx,%r15 .byte 73,137,215 // mov %rdx,%r15 .byte 118,215 // jbe 54 <_sk_start_pipeline_hsw+0x54> .byte 73,137,216 // mov %rbx,%r8 .byte 73,41,208 // sub %rdx,%r8 .byte 116,19 // je 98 <_sk_start_pipeline_hsw+0x98> .byte 76,137,207 // mov %r9,%rdi .byte 76,137,230 // mov %r12,%rsi .byte 76,137,241 // mov %r14,%rcx .byte 255,85,200 // callq *-0x38(%rbp) .byte 76,137,235 // mov %r13,%rbx .byte 76,139,77,192 // mov -0x40(%rbp),%r9 .byte 73,255,198 // inc %r14 .byte 76,59,117,176 // cmp -0x50(%rbp),%r14 .byte 117,165 // jne 46 <_sk_start_pipeline_hsw+0x46> .byte 72,131,196,40 // add $0x28,%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 197,248,119 // vzeroupper .byte 195 // retq HIDDEN _sk_just_return_hsw .globl _sk_just_return_hsw FUNCTION(_sk_just_return_hsw) _sk_just_return_hsw: .byte 195 // retq HIDDEN _sk_seed_shader_hsw .globl _sk_seed_shader_hsw FUNCTION(_sk_seed_shader_hsw) _sk_seed_shader_hsw: .byte 197,249,110,194 // vmovd %edx,%xmm0 .byte 196,226,125,88,192 // vpbroadcastd %xmm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,82,90,0,0 // vbroadcastss 0x5a52(%rip),%ymm1 # 5b1c <_sk_callback_hsw+0x142> .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 197,252,88,7 // vaddps (%rdi),%ymm0,%ymm0 .byte 197,249,110,209 // vmovd %ecx,%xmm2 .byte 196,226,125,88,210 // vpbroadcastd %xmm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 197,236,88,201 // vaddps %ymm1,%ymm2,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,21,50,90,0,0 // vbroadcastss 0x5a32(%rip),%ymm2 # 5b20 <_sk_callback_hsw+0x146> .byte 197,228,87,219 // vxorps %ymm3,%ymm3,%ymm3 .byte 197,220,87,228 // vxorps %ymm4,%ymm4,%ymm4 .byte 197,212,87,237 // vxorps %ymm5,%ymm5,%ymm5 .byte 197,204,87,246 // vxorps %ymm6,%ymm6,%ymm6 .byte 197,196,87,255 // vxorps %ymm7,%ymm7,%ymm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_dither_hsw .globl _sk_dither_hsw FUNCTION(_sk_dither_hsw) _sk_dither_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,121,110,194 // vmovd %edx,%xmm8 .byte 196,66,125,88,192 // vpbroadcastd %xmm8,%ymm8 .byte 197,61,254,71,32 // vpaddd 0x20(%rdi),%ymm8,%ymm8 .byte 197,121,110,201 // vmovd %ecx,%xmm9 .byte 196,66,125,88,201 // vpbroadcastd %xmm9,%ymm9 .byte 196,65,53,239,200 // vpxor %ymm8,%ymm9,%ymm9 .byte 196,98,125,88,21,249,89,0,0 // vpbroadcastd 0x59f9(%rip),%ymm10 # 5b24 <_sk_callback_hsw+0x14a> .byte 196,65,53,219,218 // vpand %ymm10,%ymm9,%ymm11 .byte 196,193,37,114,243,5 // vpslld $0x5,%ymm11,%ymm11 .byte 196,65,61,219,210 // vpand %ymm10,%ymm8,%ymm10 .byte 196,193,45,114,242,4 // vpslld $0x4,%ymm10,%ymm10 .byte 196,98,125,88,37,222,89,0,0 // vpbroadcastd 0x59de(%rip),%ymm12 # 5b28 <_sk_callback_hsw+0x14e> .byte 196,98,125,88,45,217,89,0,0 // vpbroadcastd 0x59d9(%rip),%ymm13 # 5b2c <_sk_callback_hsw+0x152> .byte 196,65,53,219,245 // vpand %ymm13,%ymm9,%ymm14 .byte 196,193,13,114,246,2 // vpslld $0x2,%ymm14,%ymm14 .byte 196,65,61,219,237 // vpand %ymm13,%ymm8,%ymm13 .byte 196,65,21,254,237 // vpaddd %ymm13,%ymm13,%ymm13 .byte 196,65,53,219,204 // vpand %ymm12,%ymm9,%ymm9 .byte 196,193,53,114,209,1 // vpsrld $0x1,%ymm9,%ymm9 .byte 196,65,61,219,196 // vpand %ymm12,%ymm8,%ymm8 .byte 196,193,61,114,208,2 // vpsrld $0x2,%ymm8,%ymm8 .byte 196,65,21,235,210 // vpor %ymm10,%ymm13,%ymm10 .byte 196,65,45,235,192 // vpor %ymm8,%ymm10,%ymm8 .byte 196,65,37,235,214 // vpor %ymm14,%ymm11,%ymm10 .byte 196,65,61,235,194 // vpor %ymm10,%ymm8,%ymm8 .byte 196,65,61,235,193 // vpor %ymm9,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 196,98,125,24,13,139,89,0,0 // vbroadcastss 0x598b(%rip),%ymm9 # 5b30 <_sk_callback_hsw+0x156> .byte 196,98,125,24,21,134,89,0,0 // vbroadcastss 0x5986(%rip),%ymm10 # 5b34 <_sk_callback_hsw+0x15a> .byte 196,66,61,184,209 // vfmadd231ps %ymm9,%ymm8,%ymm10 .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 196,65,60,89,194 // vmulps %ymm10,%ymm8,%ymm8 .byte 197,188,88,192 // vaddps %ymm0,%ymm8,%ymm0 .byte 197,188,88,201 // vaddps %ymm1,%ymm8,%ymm1 .byte 197,188,88,210 // vaddps %ymm2,%ymm8,%ymm2 .byte 197,252,93,195 // vminps %ymm3,%ymm0,%ymm0 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,188,95,192 // vmaxps %ymm0,%ymm8,%ymm0 .byte 197,244,93,203 // vminps %ymm3,%ymm1,%ymm1 .byte 197,188,95,201 // vmaxps %ymm1,%ymm8,%ymm1 .byte 197,236,93,211 // vminps %ymm3,%ymm2,%ymm2 .byte 197,188,95,210 // vmaxps %ymm2,%ymm8,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_uniform_color_hsw .globl _sk_uniform_color_hsw FUNCTION(_sk_uniform_color_hsw) _sk_uniform_color_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,0 // vbroadcastss (%rax),%ymm0 .byte 196,226,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm1 .byte 196,226,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm2 .byte 196,226,125,24,88,12 // vbroadcastss 0xc(%rax),%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_black_color_hsw .globl _sk_black_color_hsw FUNCTION(_sk_black_color_hsw) _sk_black_color_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,38,89,0,0 // vbroadcastss 0x5926(%rip),%ymm3 # 5b38 <_sk_callback_hsw+0x15e> .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,236,87,210 // vxorps %ymm2,%ymm2,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_white_color_hsw .globl _sk_white_color_hsw FUNCTION(_sk_white_color_hsw) _sk_white_color_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,17,89,0,0 // vbroadcastss 0x5911(%rip),%ymm0 # 5b3c <_sk_callback_hsw+0x162> .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 197,252,40,216 // vmovaps %ymm0,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_load_rgba_hsw .globl _sk_load_rgba_hsw FUNCTION(_sk_load_rgba_hsw) _sk_load_rgba_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,0 // vmovups (%rax),%ymm0 .byte 197,252,16,72,32 // vmovups 0x20(%rax),%ymm1 .byte 197,252,16,80,64 // vmovups 0x40(%rax),%ymm2 .byte 197,252,16,88,96 // vmovups 0x60(%rax),%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_rgba_hsw .globl _sk_store_rgba_hsw FUNCTION(_sk_store_rgba_hsw) _sk_store_rgba_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,17,0 // vmovups %ymm0,(%rax) .byte 197,252,17,72,32 // vmovups %ymm1,0x20(%rax) .byte 197,252,17,80,64 // vmovups %ymm2,0x40(%rax) .byte 197,252,17,88,96 // vmovups %ymm3,0x60(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clear_hsw .globl _sk_clear_hsw FUNCTION(_sk_clear_hsw) _sk_clear_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,236,87,210 // vxorps %ymm2,%ymm2,%ymm2 .byte 197,228,87,219 // vxorps %ymm3,%ymm3,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcatop_hsw .globl _sk_srcatop_hsw FUNCTION(_sk_srcatop_hsw) _sk_srcatop_hsw: .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 196,98,125,24,5,180,88,0,0 // vbroadcastss 0x58b4(%rip),%ymm8 # 5b40 <_sk_callback_hsw+0x166> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,226,61,184,196 // vfmadd231ps %ymm4,%ymm8,%ymm0 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 196,226,61,184,205 // vfmadd231ps %ymm5,%ymm8,%ymm1 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 196,226,61,184,214 // vfmadd231ps %ymm6,%ymm8,%ymm2 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 196,194,69,168,216 // vfmadd213ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstatop_hsw .globl _sk_dstatop_hsw FUNCTION(_sk_dstatop_hsw) _sk_dstatop_hsw: .byte 196,98,125,24,5,135,88,0,0 // vbroadcastss 0x5887(%rip),%ymm8 # 5b44 <_sk_callback_hsw+0x16a> .byte 197,60,92,199 // vsubps %ymm7,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 196,226,101,184,196 // vfmadd231ps %ymm4,%ymm3,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 196,226,101,184,205 // vfmadd231ps %ymm5,%ymm3,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 196,226,101,184,214 // vfmadd231ps %ymm6,%ymm3,%ymm2 .byte 197,60,89,195 // vmulps %ymm3,%ymm8,%ymm8 .byte 196,194,69,168,216 // vfmadd213ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcin_hsw .globl _sk_srcin_hsw FUNCTION(_sk_srcin_hsw) _sk_srcin_hsw: .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstin_hsw .globl _sk_dstin_hsw FUNCTION(_sk_dstin_hsw) _sk_dstin_hsw: .byte 197,228,89,196 // vmulps %ymm4,%ymm3,%ymm0 .byte 197,228,89,205 // vmulps %ymm5,%ymm3,%ymm1 .byte 197,228,89,214 // vmulps %ymm6,%ymm3,%ymm2 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcout_hsw .globl _sk_srcout_hsw FUNCTION(_sk_srcout_hsw) _sk_srcout_hsw: .byte 196,98,125,24,5,46,88,0,0 // vbroadcastss 0x582e(%rip),%ymm8 # 5b48 <_sk_callback_hsw+0x16e> .byte 197,60,92,199 // vsubps %ymm7,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 197,188,89,219 // vmulps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstout_hsw .globl _sk_dstout_hsw FUNCTION(_sk_dstout_hsw) _sk_dstout_hsw: .byte 196,226,125,24,5,17,88,0,0 // vbroadcastss 0x5811(%rip),%ymm0 # 5b4c <_sk_callback_hsw+0x172> .byte 197,252,92,219 // vsubps %ymm3,%ymm0,%ymm3 .byte 197,228,89,196 // vmulps %ymm4,%ymm3,%ymm0 .byte 197,228,89,205 // vmulps %ymm5,%ymm3,%ymm1 .byte 197,228,89,214 // vmulps %ymm6,%ymm3,%ymm2 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_hsw .globl _sk_srcover_hsw FUNCTION(_sk_srcover_hsw) _sk_srcover_hsw: .byte 196,98,125,24,5,244,87,0,0 // vbroadcastss 0x57f4(%rip),%ymm8 # 5b50 <_sk_callback_hsw+0x176> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,194,93,184,192 // vfmadd231ps %ymm8,%ymm4,%ymm0 .byte 196,194,85,184,200 // vfmadd231ps %ymm8,%ymm5,%ymm1 .byte 196,194,77,184,208 // vfmadd231ps %ymm8,%ymm6,%ymm2 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstover_hsw .globl _sk_dstover_hsw FUNCTION(_sk_dstover_hsw) _sk_dstover_hsw: .byte 196,98,125,24,5,211,87,0,0 // vbroadcastss 0x57d3(%rip),%ymm8 # 5b54 <_sk_callback_hsw+0x17a> .byte 197,60,92,199 // vsubps %ymm7,%ymm8,%ymm8 .byte 196,226,61,168,196 // vfmadd213ps %ymm4,%ymm8,%ymm0 .byte 196,226,61,168,205 // vfmadd213ps %ymm5,%ymm8,%ymm1 .byte 196,226,61,168,214 // vfmadd213ps %ymm6,%ymm8,%ymm2 .byte 196,226,61,168,223 // vfmadd213ps %ymm7,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_modulate_hsw .globl _sk_modulate_hsw FUNCTION(_sk_modulate_hsw) _sk_modulate_hsw: .byte 197,252,89,196 // vmulps %ymm4,%ymm0,%ymm0 .byte 197,244,89,205 // vmulps %ymm5,%ymm1,%ymm1 .byte 197,236,89,214 // vmulps %ymm6,%ymm2,%ymm2 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_multiply_hsw .globl _sk_multiply_hsw FUNCTION(_sk_multiply_hsw) _sk_multiply_hsw: .byte 196,98,125,24,5,158,87,0,0 // vbroadcastss 0x579e(%rip),%ymm8 # 5b58 <_sk_callback_hsw+0x17e> .byte 197,60,92,207 // vsubps %ymm7,%ymm8,%ymm9 .byte 197,52,89,208 // vmulps %ymm0,%ymm9,%ymm10 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,98,61,184,212 // vfmadd231ps %ymm4,%ymm8,%ymm10 .byte 196,194,93,168,194 // vfmadd213ps %ymm10,%ymm4,%ymm0 .byte 197,52,89,209 // vmulps %ymm1,%ymm9,%ymm10 .byte 196,98,61,184,213 // vfmadd231ps %ymm5,%ymm8,%ymm10 .byte 196,194,85,168,202 // vfmadd213ps %ymm10,%ymm5,%ymm1 .byte 197,52,89,210 // vmulps %ymm2,%ymm9,%ymm10 .byte 196,98,61,184,214 // vfmadd231ps %ymm6,%ymm8,%ymm10 .byte 196,194,77,168,210 // vfmadd213ps %ymm10,%ymm6,%ymm2 .byte 197,52,89,203 // vmulps %ymm3,%ymm9,%ymm9 .byte 196,66,69,168,193 // vfmadd213ps %ymm9,%ymm7,%ymm8 .byte 196,194,69,168,216 // vfmadd213ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_plus__hsw .globl _sk_plus__hsw FUNCTION(_sk_plus__hsw) _sk_plus__hsw: .byte 197,252,88,196 // vaddps %ymm4,%ymm0,%ymm0 .byte 197,244,88,205 // vaddps %ymm5,%ymm1,%ymm1 .byte 197,236,88,214 // vaddps %ymm6,%ymm2,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_screen_hsw .globl _sk_screen_hsw FUNCTION(_sk_screen_hsw) _sk_screen_hsw: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 196,194,93,172,192 // vfnmadd213ps %ymm8,%ymm4,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 196,194,85,172,200 // vfnmadd213ps %ymm8,%ymm5,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 196,194,77,172,208 // vfnmadd213ps %ymm8,%ymm6,%ymm2 .byte 197,100,88,199 // vaddps %ymm7,%ymm3,%ymm8 .byte 196,194,69,172,216 // vfnmadd213ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xor__hsw .globl _sk_xor__hsw FUNCTION(_sk_xor__hsw) _sk_xor__hsw: .byte 196,98,125,24,5,25,87,0,0 // vbroadcastss 0x5719(%rip),%ymm8 # 5b5c <_sk_callback_hsw+0x182> .byte 197,60,92,207 // vsubps %ymm7,%ymm8,%ymm9 .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,226,61,184,196 // vfmadd231ps %ymm4,%ymm8,%ymm0 .byte 197,180,89,201 // vmulps %ymm1,%ymm9,%ymm1 .byte 196,226,61,184,205 // vfmadd231ps %ymm5,%ymm8,%ymm1 .byte 197,180,89,210 // vmulps %ymm2,%ymm9,%ymm2 .byte 196,226,61,184,214 // vfmadd231ps %ymm6,%ymm8,%ymm2 .byte 197,180,89,219 // vmulps %ymm3,%ymm9,%ymm3 .byte 196,98,69,168,195 // vfmadd213ps %ymm3,%ymm7,%ymm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,195 // vmovaps %ymm8,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_darken_hsw .globl _sk_darken_hsw FUNCTION(_sk_darken_hsw) _sk_darken_hsw: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 197,100,89,204 // vmulps %ymm4,%ymm3,%ymm9 .byte 196,193,124,95,193 // vmaxps %ymm9,%ymm0,%ymm0 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 197,100,89,205 // vmulps %ymm5,%ymm3,%ymm9 .byte 196,193,116,95,201 // vmaxps %ymm9,%ymm1,%ymm1 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 197,100,89,206 // vmulps %ymm6,%ymm3,%ymm9 .byte 196,193,108,95,209 // vmaxps %ymm9,%ymm2,%ymm2 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 196,98,125,24,5,161,86,0,0 // vbroadcastss 0x56a1(%rip),%ymm8 # 5b60 <_sk_callback_hsw+0x186> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_lighten_hsw .globl _sk_lighten_hsw FUNCTION(_sk_lighten_hsw) _sk_lighten_hsw: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 197,100,89,204 // vmulps %ymm4,%ymm3,%ymm9 .byte 196,193,124,93,193 // vminps %ymm9,%ymm0,%ymm0 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 197,100,89,205 // vmulps %ymm5,%ymm3,%ymm9 .byte 196,193,116,93,201 // vminps %ymm9,%ymm1,%ymm1 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 197,100,89,206 // vmulps %ymm6,%ymm3,%ymm9 .byte 196,193,108,93,209 // vminps %ymm9,%ymm2,%ymm2 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 196,98,125,24,5,80,86,0,0 // vbroadcastss 0x5650(%rip),%ymm8 # 5b64 <_sk_callback_hsw+0x18a> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_difference_hsw .globl _sk_difference_hsw FUNCTION(_sk_difference_hsw) _sk_difference_hsw: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 197,100,89,204 // vmulps %ymm4,%ymm3,%ymm9 .byte 196,193,124,93,193 // vminps %ymm9,%ymm0,%ymm0 .byte 197,252,88,192 // vaddps %ymm0,%ymm0,%ymm0 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 197,100,89,205 // vmulps %ymm5,%ymm3,%ymm9 .byte 196,193,116,93,201 // vminps %ymm9,%ymm1,%ymm1 .byte 197,244,88,201 // vaddps %ymm1,%ymm1,%ymm1 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 197,100,89,206 // vmulps %ymm6,%ymm3,%ymm9 .byte 196,193,108,93,209 // vminps %ymm9,%ymm2,%ymm2 .byte 197,236,88,210 // vaddps %ymm2,%ymm2,%ymm2 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 196,98,125,24,5,243,85,0,0 // vbroadcastss 0x55f3(%rip),%ymm8 # 5b68 <_sk_callback_hsw+0x18e> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_exclusion_hsw .globl _sk_exclusion_hsw FUNCTION(_sk_exclusion_hsw) _sk_exclusion_hsw: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 197,252,89,196 // vmulps %ymm4,%ymm0,%ymm0 .byte 197,252,88,192 // vaddps %ymm0,%ymm0,%ymm0 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 197,244,89,205 // vmulps %ymm5,%ymm1,%ymm1 .byte 197,244,88,201 // vaddps %ymm1,%ymm1,%ymm1 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 197,236,89,214 // vmulps %ymm6,%ymm2,%ymm2 .byte 197,236,88,210 // vaddps %ymm2,%ymm2,%ymm2 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 196,98,125,24,5,177,85,0,0 // vbroadcastss 0x55b1(%rip),%ymm8 # 5b6c <_sk_callback_hsw+0x192> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_colorburn_hsw .globl _sk_colorburn_hsw FUNCTION(_sk_colorburn_hsw) _sk_colorburn_hsw: .byte 196,98,125,24,5,159,85,0,0 // vbroadcastss 0x559f(%rip),%ymm8 # 5b70 <_sk_callback_hsw+0x196> .byte 197,60,92,207 // vsubps %ymm7,%ymm8,%ymm9 .byte 197,52,89,216 // vmulps %ymm0,%ymm9,%ymm11 .byte 196,65,44,87,210 // vxorps %ymm10,%ymm10,%ymm10 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,228 // vmulps %ymm4,%ymm8,%ymm12 .byte 197,68,92,236 // vsubps %ymm4,%ymm7,%ymm13 .byte 197,20,89,235 // vmulps %ymm3,%ymm13,%ymm13 .byte 197,20,94,232 // vdivps %ymm0,%ymm13,%ymm13 .byte 196,65,68,93,237 // vminps %ymm13,%ymm7,%ymm13 .byte 196,65,68,92,237 // vsubps %ymm13,%ymm7,%ymm13 .byte 196,66,101,168,235 // vfmadd213ps %ymm11,%ymm3,%ymm13 .byte 196,65,28,88,237 // vaddps %ymm13,%ymm12,%ymm13 .byte 197,28,88,224 // vaddps %ymm0,%ymm12,%ymm12 .byte 196,193,124,194,194,0 // vcmpeqps %ymm10,%ymm0,%ymm0 .byte 196,195,21,74,196,0 // vblendvps %ymm0,%ymm12,%ymm13,%ymm0 .byte 197,92,194,231,0 // vcmpeqps %ymm7,%ymm4,%ymm12 .byte 197,36,88,220 // vaddps %ymm4,%ymm11,%ymm11 .byte 196,195,125,74,195,192 // vblendvps %ymm12,%ymm11,%ymm0,%ymm0 .byte 197,52,89,217 // vmulps %ymm1,%ymm9,%ymm11 .byte 197,60,89,229 // vmulps %ymm5,%ymm8,%ymm12 .byte 197,68,92,237 // vsubps %ymm5,%ymm7,%ymm13 .byte 197,20,89,235 // vmulps %ymm3,%ymm13,%ymm13 .byte 197,20,94,233 // vdivps %ymm1,%ymm13,%ymm13 .byte 196,65,68,93,237 // vminps %ymm13,%ymm7,%ymm13 .byte 196,65,68,92,237 // vsubps %ymm13,%ymm7,%ymm13 .byte 196,66,101,168,235 // vfmadd213ps %ymm11,%ymm3,%ymm13 .byte 196,65,28,88,237 // vaddps %ymm13,%ymm12,%ymm13 .byte 197,28,88,225 // vaddps %ymm1,%ymm12,%ymm12 .byte 196,193,116,194,202,0 // vcmpeqps %ymm10,%ymm1,%ymm1 .byte 196,195,21,74,204,16 // vblendvps %ymm1,%ymm12,%ymm13,%ymm1 .byte 197,84,194,231,0 // vcmpeqps %ymm7,%ymm5,%ymm12 .byte 197,36,88,221 // vaddps %ymm5,%ymm11,%ymm11 .byte 196,195,117,74,203,192 // vblendvps %ymm12,%ymm11,%ymm1,%ymm1 .byte 197,52,89,202 // vmulps %ymm2,%ymm9,%ymm9 .byte 196,65,108,194,210,0 // vcmpeqps %ymm10,%ymm2,%ymm10 .byte 197,60,89,222 // vmulps %ymm6,%ymm8,%ymm11 .byte 197,68,92,230 // vsubps %ymm6,%ymm7,%ymm12 .byte 197,28,89,227 // vmulps %ymm3,%ymm12,%ymm12 .byte 197,28,94,226 // vdivps %ymm2,%ymm12,%ymm12 .byte 197,164,88,210 // vaddps %ymm2,%ymm11,%ymm2 .byte 196,65,68,93,228 // vminps %ymm12,%ymm7,%ymm12 .byte 196,65,68,92,228 // vsubps %ymm12,%ymm7,%ymm12 .byte 196,66,101,168,225 // vfmadd213ps %ymm9,%ymm3,%ymm12 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 196,227,37,74,210,160 // vblendvps %ymm10,%ymm2,%ymm11,%ymm2 .byte 197,76,194,215,0 // vcmpeqps %ymm7,%ymm6,%ymm10 .byte 197,52,88,206 // vaddps %ymm6,%ymm9,%ymm9 .byte 196,195,109,74,209,160 // vblendvps %ymm10,%ymm9,%ymm2,%ymm2 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_colordodge_hsw .globl _sk_colordodge_hsw FUNCTION(_sk_colordodge_hsw) _sk_colordodge_hsw: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,98,125,24,13,170,84,0,0 // vbroadcastss 0x54aa(%rip),%ymm9 # 5b74 <_sk_callback_hsw+0x19a> .byte 197,52,92,215 // vsubps %ymm7,%ymm9,%ymm10 .byte 197,44,89,216 // vmulps %ymm0,%ymm10,%ymm11 .byte 197,52,92,203 // vsubps %ymm3,%ymm9,%ymm9 .byte 197,100,89,228 // vmulps %ymm4,%ymm3,%ymm12 .byte 197,100,92,232 // vsubps %ymm0,%ymm3,%ymm13 .byte 196,65,28,94,229 // vdivps %ymm13,%ymm12,%ymm12 .byte 197,52,89,236 // vmulps %ymm4,%ymm9,%ymm13 .byte 196,65,68,93,228 // vminps %ymm12,%ymm7,%ymm12 .byte 196,66,101,168,227 // vfmadd213ps %ymm11,%ymm3,%ymm12 .byte 196,65,20,88,228 // vaddps %ymm12,%ymm13,%ymm12 .byte 197,20,88,232 // vaddps %ymm0,%ymm13,%ymm13 .byte 197,252,194,195,0 // vcmpeqps %ymm3,%ymm0,%ymm0 .byte 196,195,29,74,197,0 // vblendvps %ymm0,%ymm13,%ymm12,%ymm0 .byte 196,65,92,194,224,0 // vcmpeqps %ymm8,%ymm4,%ymm12 .byte 197,36,88,220 // vaddps %ymm4,%ymm11,%ymm11 .byte 196,195,125,74,195,192 // vblendvps %ymm12,%ymm11,%ymm0,%ymm0 .byte 197,44,89,217 // vmulps %ymm1,%ymm10,%ymm11 .byte 197,100,89,229 // vmulps %ymm5,%ymm3,%ymm12 .byte 197,100,92,233 // vsubps %ymm1,%ymm3,%ymm13 .byte 196,65,28,94,229 // vdivps %ymm13,%ymm12,%ymm12 .byte 197,52,89,237 // vmulps %ymm5,%ymm9,%ymm13 .byte 196,65,68,93,228 // vminps %ymm12,%ymm7,%ymm12 .byte 196,66,101,168,227 // vfmadd213ps %ymm11,%ymm3,%ymm12 .byte 196,65,20,88,228 // vaddps %ymm12,%ymm13,%ymm12 .byte 197,20,88,233 // vaddps %ymm1,%ymm13,%ymm13 .byte 197,244,194,203,0 // vcmpeqps %ymm3,%ymm1,%ymm1 .byte 196,195,29,74,205,16 // vblendvps %ymm1,%ymm13,%ymm12,%ymm1 .byte 196,65,84,194,224,0 // vcmpeqps %ymm8,%ymm5,%ymm12 .byte 197,36,88,221 // vaddps %ymm5,%ymm11,%ymm11 .byte 196,195,117,74,203,192 // vblendvps %ymm12,%ymm11,%ymm1,%ymm1 .byte 197,44,89,210 // vmulps %ymm2,%ymm10,%ymm10 .byte 197,100,89,222 // vmulps %ymm6,%ymm3,%ymm11 .byte 197,100,92,226 // vsubps %ymm2,%ymm3,%ymm12 .byte 196,65,36,94,220 // vdivps %ymm12,%ymm11,%ymm11 .byte 197,52,89,230 // vmulps %ymm6,%ymm9,%ymm12 .byte 196,65,68,93,219 // vminps %ymm11,%ymm7,%ymm11 .byte 196,66,101,168,218 // vfmadd213ps %ymm10,%ymm3,%ymm11 .byte 196,65,28,88,219 // vaddps %ymm11,%ymm12,%ymm11 .byte 197,28,88,226 // vaddps %ymm2,%ymm12,%ymm12 .byte 197,236,194,211,0 // vcmpeqps %ymm3,%ymm2,%ymm2 .byte 196,195,37,74,212,32 // vblendvps %ymm2,%ymm12,%ymm11,%ymm2 .byte 196,65,76,194,192,0 // vcmpeqps %ymm8,%ymm6,%ymm8 .byte 197,44,88,214 // vaddps %ymm6,%ymm10,%ymm10 .byte 196,195,109,74,210,128 // vblendvps %ymm8,%ymm10,%ymm2,%ymm2 .byte 196,194,69,184,217 // vfmadd231ps %ymm9,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_hardlight_hsw .globl _sk_hardlight_hsw FUNCTION(_sk_hardlight_hsw) _sk_hardlight_hsw: .byte 196,98,125,24,5,203,83,0,0 // vbroadcastss 0x53cb(%rip),%ymm8 # 5b78 <_sk_callback_hsw+0x19e> .byte 197,60,92,215 // vsubps %ymm7,%ymm8,%ymm10 .byte 197,44,89,216 // vmulps %ymm0,%ymm10,%ymm11 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,98,61,184,220 // vfmadd231ps %ymm4,%ymm8,%ymm11 .byte 197,124,88,200 // vaddps %ymm0,%ymm0,%ymm9 .byte 197,52,194,227,2 // vcmpleps %ymm3,%ymm9,%ymm12 .byte 197,124,89,204 // vmulps %ymm4,%ymm0,%ymm9 .byte 196,65,52,88,233 // vaddps %ymm9,%ymm9,%ymm13 .byte 197,100,89,207 // vmulps %ymm7,%ymm3,%ymm9 .byte 197,68,92,244 // vsubps %ymm4,%ymm7,%ymm14 .byte 197,228,92,192 // vsubps %ymm0,%ymm3,%ymm0 .byte 196,193,124,89,198 // vmulps %ymm14,%ymm0,%ymm0 .byte 197,252,88,192 // vaddps %ymm0,%ymm0,%ymm0 .byte 197,180,92,192 // vsubps %ymm0,%ymm9,%ymm0 .byte 196,195,125,74,197,192 // vblendvps %ymm12,%ymm13,%ymm0,%ymm0 .byte 197,164,88,192 // vaddps %ymm0,%ymm11,%ymm0 .byte 197,44,89,217 // vmulps %ymm1,%ymm10,%ymm11 .byte 196,98,61,184,221 // vfmadd231ps %ymm5,%ymm8,%ymm11 .byte 197,116,88,225 // vaddps %ymm1,%ymm1,%ymm12 .byte 197,28,194,227,2 // vcmpleps %ymm3,%ymm12,%ymm12 .byte 197,116,89,237 // vmulps %ymm5,%ymm1,%ymm13 .byte 196,65,20,88,237 // vaddps %ymm13,%ymm13,%ymm13 .byte 197,68,92,245 // vsubps %ymm5,%ymm7,%ymm14 .byte 197,228,92,201 // vsubps %ymm1,%ymm3,%ymm1 .byte 196,193,116,89,206 // vmulps %ymm14,%ymm1,%ymm1 .byte 197,244,88,201 // vaddps %ymm1,%ymm1,%ymm1 .byte 197,180,92,201 // vsubps %ymm1,%ymm9,%ymm1 .byte 196,195,117,74,205,192 // vblendvps %ymm12,%ymm13,%ymm1,%ymm1 .byte 197,164,88,201 // vaddps %ymm1,%ymm11,%ymm1 .byte 197,44,89,210 // vmulps %ymm2,%ymm10,%ymm10 .byte 196,98,61,184,214 // vfmadd231ps %ymm6,%ymm8,%ymm10 .byte 197,108,88,218 // vaddps %ymm2,%ymm2,%ymm11 .byte 197,36,194,219,2 // vcmpleps %ymm3,%ymm11,%ymm11 .byte 197,108,89,230 // vmulps %ymm6,%ymm2,%ymm12 .byte 196,65,28,88,228 // vaddps %ymm12,%ymm12,%ymm12 .byte 197,68,92,238 // vsubps %ymm6,%ymm7,%ymm13 .byte 197,228,92,210 // vsubps %ymm2,%ymm3,%ymm2 .byte 196,193,108,89,213 // vmulps %ymm13,%ymm2,%ymm2 .byte 197,236,88,210 // vaddps %ymm2,%ymm2,%ymm2 .byte 197,180,92,210 // vsubps %ymm2,%ymm9,%ymm2 .byte 196,195,109,74,212,176 // vblendvps %ymm11,%ymm12,%ymm2,%ymm2 .byte 197,172,88,210 // vaddps %ymm2,%ymm10,%ymm2 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_overlay_hsw .globl _sk_overlay_hsw FUNCTION(_sk_overlay_hsw) _sk_overlay_hsw: .byte 196,98,125,24,5,3,83,0,0 // vbroadcastss 0x5303(%rip),%ymm8 # 5b7c <_sk_callback_hsw+0x1a2> .byte 197,60,92,215 // vsubps %ymm7,%ymm8,%ymm10 .byte 197,44,89,216 // vmulps %ymm0,%ymm10,%ymm11 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,98,61,184,220 // vfmadd231ps %ymm4,%ymm8,%ymm11 .byte 197,92,88,204 // vaddps %ymm4,%ymm4,%ymm9 .byte 197,52,194,231,2 // vcmpleps %ymm7,%ymm9,%ymm12 .byte 197,124,89,204 // vmulps %ymm4,%ymm0,%ymm9 .byte 196,65,52,88,233 // vaddps %ymm9,%ymm9,%ymm13 .byte 197,100,89,207 // vmulps %ymm7,%ymm3,%ymm9 .byte 197,68,92,244 // vsubps %ymm4,%ymm7,%ymm14 .byte 197,228,92,192 // vsubps %ymm0,%ymm3,%ymm0 .byte 196,193,124,89,198 // vmulps %ymm14,%ymm0,%ymm0 .byte 197,252,88,192 // vaddps %ymm0,%ymm0,%ymm0 .byte 197,180,92,192 // vsubps %ymm0,%ymm9,%ymm0 .byte 196,195,125,74,197,192 // vblendvps %ymm12,%ymm13,%ymm0,%ymm0 .byte 197,164,88,192 // vaddps %ymm0,%ymm11,%ymm0 .byte 197,44,89,217 // vmulps %ymm1,%ymm10,%ymm11 .byte 196,98,61,184,221 // vfmadd231ps %ymm5,%ymm8,%ymm11 .byte 197,84,88,229 // vaddps %ymm5,%ymm5,%ymm12 .byte 197,28,194,231,2 // vcmpleps %ymm7,%ymm12,%ymm12 .byte 197,116,89,237 // vmulps %ymm5,%ymm1,%ymm13 .byte 196,65,20,88,237 // vaddps %ymm13,%ymm13,%ymm13 .byte 197,68,92,245 // vsubps %ymm5,%ymm7,%ymm14 .byte 197,228,92,201 // vsubps %ymm1,%ymm3,%ymm1 .byte 196,193,116,89,206 // vmulps %ymm14,%ymm1,%ymm1 .byte 197,244,88,201 // vaddps %ymm1,%ymm1,%ymm1 .byte 197,180,92,201 // vsubps %ymm1,%ymm9,%ymm1 .byte 196,195,117,74,205,192 // vblendvps %ymm12,%ymm13,%ymm1,%ymm1 .byte 197,164,88,201 // vaddps %ymm1,%ymm11,%ymm1 .byte 197,44,89,210 // vmulps %ymm2,%ymm10,%ymm10 .byte 196,98,61,184,214 // vfmadd231ps %ymm6,%ymm8,%ymm10 .byte 197,76,88,222 // vaddps %ymm6,%ymm6,%ymm11 .byte 197,36,194,223,2 // vcmpleps %ymm7,%ymm11,%ymm11 .byte 197,108,89,230 // vmulps %ymm6,%ymm2,%ymm12 .byte 196,65,28,88,228 // vaddps %ymm12,%ymm12,%ymm12 .byte 197,68,92,238 // vsubps %ymm6,%ymm7,%ymm13 .byte 197,228,92,210 // vsubps %ymm2,%ymm3,%ymm2 .byte 196,193,108,89,213 // vmulps %ymm13,%ymm2,%ymm2 .byte 197,236,88,210 // vaddps %ymm2,%ymm2,%ymm2 .byte 197,180,92,210 // vsubps %ymm2,%ymm9,%ymm2 .byte 196,195,109,74,212,176 // vblendvps %ymm11,%ymm12,%ymm2,%ymm2 .byte 197,172,88,210 // vaddps %ymm2,%ymm10,%ymm2 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_softlight_hsw .globl _sk_softlight_hsw FUNCTION(_sk_softlight_hsw) _sk_softlight_hsw: .byte 197,252,17,84,36,200 // vmovups %ymm2,-0x38(%rsp) .byte 197,252,40,209 // vmovaps %ymm1,%ymm2 .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 196,65,52,87,201 // vxorps %ymm9,%ymm9,%ymm9 .byte 197,52,194,215,1 // vcmpltps %ymm7,%ymm9,%ymm10 .byte 197,92,94,199 // vdivps %ymm7,%ymm4,%ymm8 .byte 196,67,53,74,232,160 // vblendvps %ymm10,%ymm8,%ymm9,%ymm13 .byte 196,65,20,88,197 // vaddps %ymm13,%ymm13,%ymm8 .byte 196,65,60,88,192 // vaddps %ymm8,%ymm8,%ymm8 .byte 196,66,61,168,192 // vfmadd213ps %ymm8,%ymm8,%ymm8 .byte 196,98,125,24,29,14,82,0,0 // vbroadcastss 0x520e(%rip),%ymm11 # 5b84 <_sk_callback_hsw+0x1aa> .byte 196,65,20,88,227 // vaddps %ymm11,%ymm13,%ymm12 .byte 196,65,28,89,192 // vmulps %ymm8,%ymm12,%ymm8 .byte 196,98,125,24,37,255,81,0,0 // vbroadcastss 0x51ff(%rip),%ymm12 # 5b88 <_sk_callback_hsw+0x1ae> .byte 196,66,21,184,196 // vfmadd231ps %ymm12,%ymm13,%ymm8 .byte 196,65,124,82,245 // vrsqrtps %ymm13,%ymm14 .byte 196,65,124,83,246 // vrcpps %ymm14,%ymm14 .byte 196,65,12,92,245 // vsubps %ymm13,%ymm14,%ymm14 .byte 197,92,88,252 // vaddps %ymm4,%ymm4,%ymm15 .byte 196,65,4,88,255 // vaddps %ymm15,%ymm15,%ymm15 .byte 197,4,194,255,2 // vcmpleps %ymm7,%ymm15,%ymm15 .byte 196,67,13,74,240,240 // vblendvps %ymm15,%ymm8,%ymm14,%ymm14 .byte 197,116,88,249 // vaddps %ymm1,%ymm1,%ymm15 .byte 196,98,125,24,5,194,81,0,0 // vbroadcastss 0x51c2(%rip),%ymm8 # 5b80 <_sk_callback_hsw+0x1a6> .byte 196,65,60,92,237 // vsubps %ymm13,%ymm8,%ymm13 .byte 197,132,92,195 // vsubps %ymm3,%ymm15,%ymm0 .byte 196,98,125,168,235 // vfmadd213ps %ymm3,%ymm0,%ymm13 .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 196,193,124,89,198 // vmulps %ymm14,%ymm0,%ymm0 .byte 197,20,89,236 // vmulps %ymm4,%ymm13,%ymm13 .byte 196,226,101,184,196 // vfmadd231ps %ymm4,%ymm3,%ymm0 .byte 197,4,194,243,2 // vcmpleps %ymm3,%ymm15,%ymm14 .byte 196,195,125,74,197,224 // vblendvps %ymm14,%ymm13,%ymm0,%ymm0 .byte 197,252,17,68,36,168 // vmovups %ymm0,-0x58(%rsp) .byte 197,212,94,199 // vdivps %ymm7,%ymm5,%ymm0 .byte 196,227,53,74,192,160 // vblendvps %ymm10,%ymm0,%ymm9,%ymm0 .byte 197,124,88,240 // vaddps %ymm0,%ymm0,%ymm14 .byte 196,65,12,88,246 // vaddps %ymm14,%ymm14,%ymm14 .byte 196,66,13,168,246 // vfmadd213ps %ymm14,%ymm14,%ymm14 .byte 196,65,124,88,251 // vaddps %ymm11,%ymm0,%ymm15 .byte 196,65,4,89,246 // vmulps %ymm14,%ymm15,%ymm14 .byte 196,66,125,184,244 // vfmadd231ps %ymm12,%ymm0,%ymm14 .byte 197,124,82,248 // vrsqrtps %ymm0,%ymm15 .byte 196,65,124,83,255 // vrcpps %ymm15,%ymm15 .byte 197,4,92,248 // vsubps %ymm0,%ymm15,%ymm15 .byte 197,84,88,237 // vaddps %ymm5,%ymm5,%ymm13 .byte 196,65,20,88,237 // vaddps %ymm13,%ymm13,%ymm13 .byte 197,20,194,239,2 // vcmpleps %ymm7,%ymm13,%ymm13 .byte 196,67,5,74,238,208 // vblendvps %ymm13,%ymm14,%ymm15,%ymm13 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,108,88,242 // vaddps %ymm2,%ymm2,%ymm14 .byte 197,12,92,251 // vsubps %ymm3,%ymm14,%ymm15 .byte 196,226,5,168,195 // vfmadd213ps %ymm3,%ymm15,%ymm0 .byte 197,4,89,255 // vmulps %ymm7,%ymm15,%ymm15 .byte 196,65,4,89,237 // vmulps %ymm13,%ymm15,%ymm13 .byte 197,252,89,197 // vmulps %ymm5,%ymm0,%ymm0 .byte 196,98,101,184,237 // vfmadd231ps %ymm5,%ymm3,%ymm13 .byte 197,12,194,243,2 // vcmpleps %ymm3,%ymm14,%ymm14 .byte 196,99,21,74,240,224 // vblendvps %ymm14,%ymm0,%ymm13,%ymm14 .byte 197,204,94,199 // vdivps %ymm7,%ymm6,%ymm0 .byte 196,227,53,74,192,160 // vblendvps %ymm10,%ymm0,%ymm9,%ymm0 .byte 197,124,88,200 // vaddps %ymm0,%ymm0,%ymm9 .byte 196,65,52,88,201 // vaddps %ymm9,%ymm9,%ymm9 .byte 196,66,53,168,201 // vfmadd213ps %ymm9,%ymm9,%ymm9 .byte 196,65,124,88,211 // vaddps %ymm11,%ymm0,%ymm10 .byte 196,65,44,89,201 // vmulps %ymm9,%ymm10,%ymm9 .byte 196,66,125,184,204 // vfmadd231ps %ymm12,%ymm0,%ymm9 .byte 197,124,82,208 // vrsqrtps %ymm0,%ymm10 .byte 196,65,124,83,210 // vrcpps %ymm10,%ymm10 .byte 197,44,92,208 // vsubps %ymm0,%ymm10,%ymm10 .byte 197,76,88,222 // vaddps %ymm6,%ymm6,%ymm11 .byte 196,65,36,88,219 // vaddps %ymm11,%ymm11,%ymm11 .byte 197,36,194,223,2 // vcmpleps %ymm7,%ymm11,%ymm11 .byte 196,67,45,74,201,176 // vblendvps %ymm11,%ymm9,%ymm10,%ymm9 .byte 197,124,16,100,36,200 // vmovups -0x38(%rsp),%ymm12 .byte 196,65,28,88,212 // vaddps %ymm12,%ymm12,%ymm10 .byte 197,44,92,219 // vsubps %ymm3,%ymm10,%ymm11 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 196,226,37,168,195 // vfmadd213ps %ymm3,%ymm11,%ymm0 .byte 197,36,89,223 // vmulps %ymm7,%ymm11,%ymm11 .byte 196,65,36,89,201 // vmulps %ymm9,%ymm11,%ymm9 .byte 197,252,89,198 // vmulps %ymm6,%ymm0,%ymm0 .byte 196,98,101,184,206 // vfmadd231ps %ymm6,%ymm3,%ymm9 .byte 197,44,194,211,2 // vcmpleps %ymm3,%ymm10,%ymm10 .byte 196,99,53,74,200,160 // vblendvps %ymm10,%ymm0,%ymm9,%ymm9 .byte 197,60,92,215 // vsubps %ymm7,%ymm8,%ymm10 .byte 197,172,89,193 // vmulps %ymm1,%ymm10,%ymm0 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,226,61,184,196 // vfmadd231ps %ymm4,%ymm8,%ymm0 .byte 197,252,88,68,36,168 // vaddps -0x58(%rsp),%ymm0,%ymm0 .byte 197,172,89,202 // vmulps %ymm2,%ymm10,%ymm1 .byte 196,226,61,184,205 // vfmadd231ps %ymm5,%ymm8,%ymm1 .byte 196,193,116,88,206 // vaddps %ymm14,%ymm1,%ymm1 .byte 196,193,44,89,212 // vmulps %ymm12,%ymm10,%ymm2 .byte 196,226,61,184,214 // vfmadd231ps %ymm6,%ymm8,%ymm2 .byte 196,193,108,88,209 // vaddps %ymm9,%ymm2,%ymm2 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_hue_hsw .globl _sk_hue_hsw FUNCTION(_sk_hue_hsw) _sk_hue_hsw: .byte 197,124,40,194 // vmovaps %ymm2,%ymm8 .byte 197,124,17,68,36,200 // vmovups %ymm8,-0x38(%rsp) .byte 197,252,17,76,36,168 // vmovups %ymm1,-0x58(%rsp) .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 197,108,89,203 // vmulps %ymm3,%ymm2,%ymm9 .byte 197,116,89,211 // vmulps %ymm3,%ymm1,%ymm10 .byte 197,60,89,219 // vmulps %ymm3,%ymm8,%ymm11 .byte 197,84,95,198 // vmaxps %ymm6,%ymm5,%ymm8 .byte 196,65,92,95,192 // vmaxps %ymm8,%ymm4,%ymm8 .byte 197,84,93,230 // vminps %ymm6,%ymm5,%ymm12 .byte 196,65,92,93,228 // vminps %ymm12,%ymm4,%ymm12 .byte 196,65,60,92,196 // vsubps %ymm12,%ymm8,%ymm8 .byte 197,60,89,227 // vmulps %ymm3,%ymm8,%ymm12 .byte 196,65,44,93,195 // vminps %ymm11,%ymm10,%ymm8 .byte 196,65,52,93,232 // vminps %ymm8,%ymm9,%ymm13 .byte 196,65,44,95,195 // vmaxps %ymm11,%ymm10,%ymm8 .byte 196,65,52,95,192 // vmaxps %ymm8,%ymm9,%ymm8 .byte 196,65,60,92,245 // vsubps %ymm13,%ymm8,%ymm14 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,65,12,194,248,0 // vcmpeqps %ymm8,%ymm14,%ymm15 .byte 196,65,52,92,205 // vsubps %ymm13,%ymm9,%ymm9 .byte 196,65,28,89,201 // vmulps %ymm9,%ymm12,%ymm9 .byte 196,65,52,94,206 // vdivps %ymm14,%ymm9,%ymm9 .byte 196,67,53,74,200,240 // vblendvps %ymm15,%ymm8,%ymm9,%ymm9 .byte 196,65,44,92,213 // vsubps %ymm13,%ymm10,%ymm10 .byte 196,65,28,89,210 // vmulps %ymm10,%ymm12,%ymm10 .byte 196,65,44,94,214 // vdivps %ymm14,%ymm10,%ymm10 .byte 196,195,45,74,200,240 // vblendvps %ymm15,%ymm8,%ymm10,%ymm1 .byte 196,65,36,92,213 // vsubps %ymm13,%ymm11,%ymm10 .byte 196,65,28,89,210 // vmulps %ymm10,%ymm12,%ymm10 .byte 196,65,44,94,214 // vdivps %ymm14,%ymm10,%ymm10 .byte 196,67,45,74,224,240 // vblendvps %ymm15,%ymm8,%ymm10,%ymm12 .byte 196,98,125,24,53,198,79,0,0 // vbroadcastss 0x4fc6(%rip),%ymm14 # 5b8c <_sk_callback_hsw+0x1b2> .byte 196,98,125,24,61,193,79,0,0 // vbroadcastss 0x4fc1(%rip),%ymm15 # 5b90 <_sk_callback_hsw+0x1b6> .byte 196,65,84,89,239 // vmulps %ymm15,%ymm5,%ymm13 .byte 196,66,93,184,238 // vfmadd231ps %ymm14,%ymm4,%ymm13 .byte 196,226,125,24,5,178,79,0,0 // vbroadcastss 0x4fb2(%rip),%ymm0 # 5b94 <_sk_callback_hsw+0x1ba> .byte 196,98,77,184,232 // vfmadd231ps %ymm0,%ymm6,%ymm13 .byte 196,65,116,89,215 // vmulps %ymm15,%ymm1,%ymm10 .byte 196,66,53,184,214 // vfmadd231ps %ymm14,%ymm9,%ymm10 .byte 196,98,29,184,208 // vfmadd231ps %ymm0,%ymm12,%ymm10 .byte 196,66,101,170,234 // vfmsub213ps %ymm10,%ymm3,%ymm13 .byte 196,65,52,88,213 // vaddps %ymm13,%ymm9,%ymm10 .byte 196,65,116,88,221 // vaddps %ymm13,%ymm1,%ymm11 .byte 196,65,28,88,229 // vaddps %ymm13,%ymm12,%ymm12 .byte 196,193,36,93,204 // vminps %ymm12,%ymm11,%ymm1 .byte 197,44,93,233 // vminps %ymm1,%ymm10,%ymm13 .byte 196,65,36,89,207 // vmulps %ymm15,%ymm11,%ymm9 .byte 196,66,45,184,206 // vfmadd231ps %ymm14,%ymm10,%ymm9 .byte 196,98,29,184,200 // vfmadd231ps %ymm0,%ymm12,%ymm9 .byte 196,193,44,92,193 // vsubps %ymm9,%ymm10,%ymm0 .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 196,193,52,92,205 // vsubps %ymm13,%ymm9,%ymm1 .byte 197,252,94,193 // vdivps %ymm1,%ymm0,%ymm0 .byte 196,65,36,92,241 // vsubps %ymm9,%ymm11,%ymm14 .byte 196,65,52,89,246 // vmulps %ymm14,%ymm9,%ymm14 .byte 197,12,94,241 // vdivps %ymm1,%ymm14,%ymm14 .byte 196,65,28,92,249 // vsubps %ymm9,%ymm12,%ymm15 .byte 196,65,52,89,255 // vmulps %ymm15,%ymm9,%ymm15 .byte 197,132,94,201 // vdivps %ymm1,%ymm15,%ymm1 .byte 196,65,60,194,237,2 // vcmpleps %ymm13,%ymm8,%ymm13 .byte 196,65,52,88,246 // vaddps %ymm14,%ymm9,%ymm14 .byte 196,67,13,74,243,208 // vblendvps %ymm13,%ymm11,%ymm14,%ymm14 .byte 196,65,36,95,220 // vmaxps %ymm12,%ymm11,%ymm11 .byte 197,180,88,201 // vaddps %ymm1,%ymm9,%ymm1 .byte 196,195,117,74,204,208 // vblendvps %ymm13,%ymm12,%ymm1,%ymm1 .byte 197,180,88,192 // vaddps %ymm0,%ymm9,%ymm0 .byte 196,195,125,74,194,208 // vblendvps %ymm13,%ymm10,%ymm0,%ymm0 .byte 197,100,89,231 // vmulps %ymm7,%ymm3,%ymm12 .byte 196,65,44,95,211 // vmaxps %ymm11,%ymm10,%ymm10 .byte 196,65,124,92,217 // vsubps %ymm9,%ymm0,%ymm11 .byte 196,65,28,92,233 // vsubps %ymm9,%ymm12,%ymm13 .byte 196,65,20,89,219 // vmulps %ymm11,%ymm13,%ymm11 .byte 196,65,28,194,250,1 // vcmpltps %ymm10,%ymm12,%ymm15 .byte 196,65,44,92,209 // vsubps %ymm9,%ymm10,%ymm10 .byte 196,65,36,94,218 // vdivps %ymm10,%ymm11,%ymm11 .byte 196,65,52,88,219 // vaddps %ymm11,%ymm9,%ymm11 .byte 196,195,125,74,195,240 // vblendvps %ymm15,%ymm11,%ymm0,%ymm0 .byte 196,65,12,92,217 // vsubps %ymm9,%ymm14,%ymm11 .byte 196,65,20,89,219 // vmulps %ymm11,%ymm13,%ymm11 .byte 196,65,36,94,218 // vdivps %ymm10,%ymm11,%ymm11 .byte 196,65,52,88,219 // vaddps %ymm11,%ymm9,%ymm11 .byte 196,67,13,74,219,240 // vblendvps %ymm15,%ymm11,%ymm14,%ymm11 .byte 196,65,116,92,241 // vsubps %ymm9,%ymm1,%ymm14 .byte 196,65,20,89,238 // vmulps %ymm14,%ymm13,%ymm13 .byte 196,65,20,94,210 // vdivps %ymm10,%ymm13,%ymm10 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,195,117,74,201,240 // vblendvps %ymm15,%ymm9,%ymm1,%ymm1 .byte 196,193,124,95,192 // vmaxps %ymm8,%ymm0,%ymm0 .byte 196,65,36,95,200 // vmaxps %ymm8,%ymm11,%ymm9 .byte 196,65,116,95,192 // vmaxps %ymm8,%ymm1,%ymm8 .byte 196,226,125,24,13,159,78,0,0 // vbroadcastss 0x4e9f(%rip),%ymm1 # 5b98 <_sk_callback_hsw+0x1be> .byte 197,116,92,215 // vsubps %ymm7,%ymm1,%ymm10 .byte 197,172,89,210 // vmulps %ymm2,%ymm10,%ymm2 .byte 197,116,92,219 // vsubps %ymm3,%ymm1,%ymm11 .byte 196,226,37,184,212 // vfmadd231ps %ymm4,%ymm11,%ymm2 .byte 197,236,88,192 // vaddps %ymm0,%ymm2,%ymm0 .byte 197,172,89,76,36,168 // vmulps -0x58(%rsp),%ymm10,%ymm1 .byte 196,226,37,184,205 // vfmadd231ps %ymm5,%ymm11,%ymm1 .byte 196,193,116,88,201 // vaddps %ymm9,%ymm1,%ymm1 .byte 197,172,89,84,36,200 // vmulps -0x38(%rsp),%ymm10,%ymm2 .byte 196,98,77,168,218 // vfmadd213ps %ymm2,%ymm6,%ymm11 .byte 196,193,36,88,208 // vaddps %ymm8,%ymm11,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 196,193,100,92,220 // vsubps %ymm12,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_saturation_hsw .globl _sk_saturation_hsw FUNCTION(_sk_saturation_hsw) _sk_saturation_hsw: .byte 197,124,40,194 // vmovaps %ymm2,%ymm8 .byte 197,252,17,76,36,168 // vmovups %ymm1,-0x58(%rsp) .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 197,100,89,204 // vmulps %ymm4,%ymm3,%ymm9 .byte 197,100,89,213 // vmulps %ymm5,%ymm3,%ymm10 .byte 197,100,89,222 // vmulps %ymm6,%ymm3,%ymm11 .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,252,17,68,36,200 // vmovups %ymm0,-0x38(%rsp) .byte 197,116,95,192 // vmaxps %ymm0,%ymm1,%ymm8 .byte 196,65,108,95,192 // vmaxps %ymm8,%ymm2,%ymm8 .byte 197,116,93,224 // vminps %ymm0,%ymm1,%ymm12 .byte 196,65,108,93,228 // vminps %ymm12,%ymm2,%ymm12 .byte 196,65,60,92,196 // vsubps %ymm12,%ymm8,%ymm8 .byte 197,60,89,231 // vmulps %ymm7,%ymm8,%ymm12 .byte 196,65,44,93,195 // vminps %ymm11,%ymm10,%ymm8 .byte 196,65,52,93,232 // vminps %ymm8,%ymm9,%ymm13 .byte 196,65,44,95,195 // vmaxps %ymm11,%ymm10,%ymm8 .byte 196,65,52,95,192 // vmaxps %ymm8,%ymm9,%ymm8 .byte 196,65,60,92,245 // vsubps %ymm13,%ymm8,%ymm14 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,65,12,194,248,0 // vcmpeqps %ymm8,%ymm14,%ymm15 .byte 196,65,52,92,205 // vsubps %ymm13,%ymm9,%ymm9 .byte 196,65,28,89,201 // vmulps %ymm9,%ymm12,%ymm9 .byte 196,65,52,94,206 // vdivps %ymm14,%ymm9,%ymm9 .byte 196,67,53,74,200,240 // vblendvps %ymm15,%ymm8,%ymm9,%ymm9 .byte 196,65,44,92,213 // vsubps %ymm13,%ymm10,%ymm10 .byte 196,65,28,89,210 // vmulps %ymm10,%ymm12,%ymm10 .byte 196,65,44,94,214 // vdivps %ymm14,%ymm10,%ymm10 .byte 196,195,45,74,200,240 // vblendvps %ymm15,%ymm8,%ymm10,%ymm1 .byte 196,65,36,92,213 // vsubps %ymm13,%ymm11,%ymm10 .byte 196,65,28,89,210 // vmulps %ymm10,%ymm12,%ymm10 .byte 196,65,44,94,214 // vdivps %ymm14,%ymm10,%ymm10 .byte 196,67,45,74,224,240 // vblendvps %ymm15,%ymm8,%ymm10,%ymm12 .byte 196,98,125,24,53,182,77,0,0 // vbroadcastss 0x4db6(%rip),%ymm14 # 5b9c <_sk_callback_hsw+0x1c2> .byte 196,98,125,24,61,177,77,0,0 // vbroadcastss 0x4db1(%rip),%ymm15 # 5ba0 <_sk_callback_hsw+0x1c6> .byte 196,65,84,89,239 // vmulps %ymm15,%ymm5,%ymm13 .byte 196,66,93,184,238 // vfmadd231ps %ymm14,%ymm4,%ymm13 .byte 196,226,125,24,5,162,77,0,0 // vbroadcastss 0x4da2(%rip),%ymm0 # 5ba4 <_sk_callback_hsw+0x1ca> .byte 196,98,77,184,232 // vfmadd231ps %ymm0,%ymm6,%ymm13 .byte 196,65,116,89,215 // vmulps %ymm15,%ymm1,%ymm10 .byte 196,66,53,184,214 // vfmadd231ps %ymm14,%ymm9,%ymm10 .byte 196,98,29,184,208 // vfmadd231ps %ymm0,%ymm12,%ymm10 .byte 196,66,101,170,234 // vfmsub213ps %ymm10,%ymm3,%ymm13 .byte 196,65,52,88,213 // vaddps %ymm13,%ymm9,%ymm10 .byte 196,65,116,88,221 // vaddps %ymm13,%ymm1,%ymm11 .byte 196,65,28,88,229 // vaddps %ymm13,%ymm12,%ymm12 .byte 196,193,36,93,204 // vminps %ymm12,%ymm11,%ymm1 .byte 197,44,93,233 // vminps %ymm1,%ymm10,%ymm13 .byte 196,65,36,89,207 // vmulps %ymm15,%ymm11,%ymm9 .byte 196,66,45,184,206 // vfmadd231ps %ymm14,%ymm10,%ymm9 .byte 196,98,29,184,200 // vfmadd231ps %ymm0,%ymm12,%ymm9 .byte 196,193,44,92,193 // vsubps %ymm9,%ymm10,%ymm0 .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 196,193,52,92,205 // vsubps %ymm13,%ymm9,%ymm1 .byte 197,252,94,193 // vdivps %ymm1,%ymm0,%ymm0 .byte 196,65,36,92,241 // vsubps %ymm9,%ymm11,%ymm14 .byte 196,65,52,89,246 // vmulps %ymm14,%ymm9,%ymm14 .byte 197,12,94,241 // vdivps %ymm1,%ymm14,%ymm14 .byte 196,65,28,92,249 // vsubps %ymm9,%ymm12,%ymm15 .byte 196,65,52,89,255 // vmulps %ymm15,%ymm9,%ymm15 .byte 197,132,94,201 // vdivps %ymm1,%ymm15,%ymm1 .byte 196,65,60,194,237,2 // vcmpleps %ymm13,%ymm8,%ymm13 .byte 196,65,52,88,246 // vaddps %ymm14,%ymm9,%ymm14 .byte 196,67,13,74,243,208 // vblendvps %ymm13,%ymm11,%ymm14,%ymm14 .byte 196,65,36,95,220 // vmaxps %ymm12,%ymm11,%ymm11 .byte 197,180,88,201 // vaddps %ymm1,%ymm9,%ymm1 .byte 196,195,117,74,204,208 // vblendvps %ymm13,%ymm12,%ymm1,%ymm1 .byte 197,180,88,192 // vaddps %ymm0,%ymm9,%ymm0 .byte 196,195,125,74,194,208 // vblendvps %ymm13,%ymm10,%ymm0,%ymm0 .byte 197,100,89,231 // vmulps %ymm7,%ymm3,%ymm12 .byte 196,65,44,95,211 // vmaxps %ymm11,%ymm10,%ymm10 .byte 196,65,124,92,217 // vsubps %ymm9,%ymm0,%ymm11 .byte 196,65,28,92,233 // vsubps %ymm9,%ymm12,%ymm13 .byte 196,65,20,89,219 // vmulps %ymm11,%ymm13,%ymm11 .byte 196,65,28,194,250,1 // vcmpltps %ymm10,%ymm12,%ymm15 .byte 196,65,44,92,209 // vsubps %ymm9,%ymm10,%ymm10 .byte 196,65,36,94,218 // vdivps %ymm10,%ymm11,%ymm11 .byte 196,65,52,88,219 // vaddps %ymm11,%ymm9,%ymm11 .byte 196,195,125,74,195,240 // vblendvps %ymm15,%ymm11,%ymm0,%ymm0 .byte 196,65,12,92,217 // vsubps %ymm9,%ymm14,%ymm11 .byte 196,65,20,89,219 // vmulps %ymm11,%ymm13,%ymm11 .byte 196,65,36,94,218 // vdivps %ymm10,%ymm11,%ymm11 .byte 196,65,52,88,219 // vaddps %ymm11,%ymm9,%ymm11 .byte 196,67,13,74,219,240 // vblendvps %ymm15,%ymm11,%ymm14,%ymm11 .byte 196,65,116,92,241 // vsubps %ymm9,%ymm1,%ymm14 .byte 196,65,20,89,238 // vmulps %ymm14,%ymm13,%ymm13 .byte 196,65,20,94,210 // vdivps %ymm10,%ymm13,%ymm10 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,195,117,74,201,240 // vblendvps %ymm15,%ymm9,%ymm1,%ymm1 .byte 196,193,124,95,192 // vmaxps %ymm8,%ymm0,%ymm0 .byte 196,65,36,95,200 // vmaxps %ymm8,%ymm11,%ymm9 .byte 196,65,116,95,192 // vmaxps %ymm8,%ymm1,%ymm8 .byte 196,226,125,24,13,143,76,0,0 // vbroadcastss 0x4c8f(%rip),%ymm1 # 5ba8 <_sk_callback_hsw+0x1ce> .byte 197,116,92,215 // vsubps %ymm7,%ymm1,%ymm10 .byte 197,172,89,210 // vmulps %ymm2,%ymm10,%ymm2 .byte 197,116,92,219 // vsubps %ymm3,%ymm1,%ymm11 .byte 196,226,37,184,212 // vfmadd231ps %ymm4,%ymm11,%ymm2 .byte 197,236,88,192 // vaddps %ymm0,%ymm2,%ymm0 .byte 197,172,89,76,36,168 // vmulps -0x58(%rsp),%ymm10,%ymm1 .byte 196,226,37,184,205 // vfmadd231ps %ymm5,%ymm11,%ymm1 .byte 196,193,116,88,201 // vaddps %ymm9,%ymm1,%ymm1 .byte 197,172,89,84,36,200 // vmulps -0x38(%rsp),%ymm10,%ymm2 .byte 196,98,77,168,218 // vfmadd213ps %ymm2,%ymm6,%ymm11 .byte 196,193,36,88,208 // vaddps %ymm8,%ymm11,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 196,193,100,92,220 // vsubps %ymm12,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_color_hsw .globl _sk_color_hsw FUNCTION(_sk_color_hsw) _sk_color_hsw: .byte 197,124,40,202 // vmovaps %ymm2,%ymm9 .byte 197,124,17,76,36,200 // vmovups %ymm9,-0x38(%rsp) .byte 197,252,17,76,36,168 // vmovups %ymm1,-0x58(%rsp) .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 197,108,89,199 // vmulps %ymm7,%ymm2,%ymm8 .byte 197,116,89,215 // vmulps %ymm7,%ymm1,%ymm10 .byte 197,52,89,223 // vmulps %ymm7,%ymm9,%ymm11 .byte 196,98,125,24,45,40,76,0,0 // vbroadcastss 0x4c28(%rip),%ymm13 # 5bac <_sk_callback_hsw+0x1d2> .byte 196,98,125,24,53,35,76,0,0 // vbroadcastss 0x4c23(%rip),%ymm14 # 5bb0 <_sk_callback_hsw+0x1d6> .byte 196,65,84,89,230 // vmulps %ymm14,%ymm5,%ymm12 .byte 196,66,93,184,229 // vfmadd231ps %ymm13,%ymm4,%ymm12 .byte 196,98,125,24,61,20,76,0,0 // vbroadcastss 0x4c14(%rip),%ymm15 # 5bb4 <_sk_callback_hsw+0x1da> .byte 196,66,77,184,231 // vfmadd231ps %ymm15,%ymm6,%ymm12 .byte 196,65,44,89,206 // vmulps %ymm14,%ymm10,%ymm9 .byte 196,66,61,184,205 // vfmadd231ps %ymm13,%ymm8,%ymm9 .byte 196,66,37,184,207 // vfmadd231ps %ymm15,%ymm11,%ymm9 .byte 196,66,101,170,225 // vfmsub213ps %ymm9,%ymm3,%ymm12 .byte 196,65,60,88,204 // vaddps %ymm12,%ymm8,%ymm9 .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 196,65,44,93,195 // vminps %ymm11,%ymm10,%ymm8 .byte 196,65,52,93,224 // vminps %ymm8,%ymm9,%ymm12 .byte 196,65,44,89,198 // vmulps %ymm14,%ymm10,%ymm8 .byte 196,66,53,184,197 // vfmadd231ps %ymm13,%ymm9,%ymm8 .byte 196,66,37,184,199 // vfmadd231ps %ymm15,%ymm11,%ymm8 .byte 196,65,52,92,232 // vsubps %ymm8,%ymm9,%ymm13 .byte 196,65,60,89,237 // vmulps %ymm13,%ymm8,%ymm13 .byte 196,65,60,92,244 // vsubps %ymm12,%ymm8,%ymm14 .byte 196,193,20,94,198 // vdivps %ymm14,%ymm13,%ymm0 .byte 196,65,44,92,248 // vsubps %ymm8,%ymm10,%ymm15 .byte 196,65,60,89,255 // vmulps %ymm15,%ymm8,%ymm15 .byte 196,65,4,94,254 // vdivps %ymm14,%ymm15,%ymm15 .byte 196,65,36,92,232 // vsubps %ymm8,%ymm11,%ymm13 .byte 196,65,60,89,237 // vmulps %ymm13,%ymm8,%ymm13 .byte 196,65,20,94,238 // vdivps %ymm14,%ymm13,%ymm13 .byte 196,65,12,87,246 // vxorps %ymm14,%ymm14,%ymm14 .byte 196,65,12,194,228,2 // vcmpleps %ymm12,%ymm14,%ymm12 .byte 196,65,60,88,255 // vaddps %ymm15,%ymm8,%ymm15 .byte 196,67,5,74,250,192 // vblendvps %ymm12,%ymm10,%ymm15,%ymm15 .byte 196,65,44,95,211 // vmaxps %ymm11,%ymm10,%ymm10 .byte 196,65,60,88,237 // vaddps %ymm13,%ymm8,%ymm13 .byte 196,67,21,74,219,192 // vblendvps %ymm12,%ymm11,%ymm13,%ymm11 .byte 197,188,88,192 // vaddps %ymm0,%ymm8,%ymm0 .byte 196,195,125,74,201,192 // vblendvps %ymm12,%ymm9,%ymm0,%ymm1 .byte 197,100,89,231 // vmulps %ymm7,%ymm3,%ymm12 .byte 196,65,52,95,202 // vmaxps %ymm10,%ymm9,%ymm9 .byte 196,65,116,92,208 // vsubps %ymm8,%ymm1,%ymm10 .byte 196,65,28,92,232 // vsubps %ymm8,%ymm12,%ymm13 .byte 196,65,20,89,210 // vmulps %ymm10,%ymm13,%ymm10 .byte 196,193,28,194,193,1 // vcmpltps %ymm9,%ymm12,%ymm0 .byte 196,65,52,92,200 // vsubps %ymm8,%ymm9,%ymm9 .byte 196,65,44,94,209 // vdivps %ymm9,%ymm10,%ymm10 .byte 196,65,60,88,210 // vaddps %ymm10,%ymm8,%ymm10 .byte 196,195,117,74,202,0 // vblendvps %ymm0,%ymm10,%ymm1,%ymm1 .byte 196,65,4,92,208 // vsubps %ymm8,%ymm15,%ymm10 .byte 196,65,20,89,210 // vmulps %ymm10,%ymm13,%ymm10 .byte 196,65,44,94,209 // vdivps %ymm9,%ymm10,%ymm10 .byte 196,65,60,88,210 // vaddps %ymm10,%ymm8,%ymm10 .byte 196,67,5,74,210,0 // vblendvps %ymm0,%ymm10,%ymm15,%ymm10 .byte 196,65,36,92,248 // vsubps %ymm8,%ymm11,%ymm15 .byte 196,65,20,89,239 // vmulps %ymm15,%ymm13,%ymm13 .byte 196,65,20,94,201 // vdivps %ymm9,%ymm13,%ymm9 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 196,195,37,74,192,0 // vblendvps %ymm0,%ymm8,%ymm11,%ymm0 .byte 196,193,116,95,206 // vmaxps %ymm14,%ymm1,%ymm1 .byte 196,65,44,95,198 // vmaxps %ymm14,%ymm10,%ymm8 .byte 196,65,124,95,206 // vmaxps %ymm14,%ymm0,%ymm9 .byte 196,226,125,24,5,246,74,0,0 // vbroadcastss 0x4af6(%rip),%ymm0 # 5bb8 <_sk_callback_hsw+0x1de> .byte 197,124,92,215 // vsubps %ymm7,%ymm0,%ymm10 .byte 197,172,89,210 // vmulps %ymm2,%ymm10,%ymm2 .byte 197,124,92,219 // vsubps %ymm3,%ymm0,%ymm11 .byte 196,226,37,184,212 // vfmadd231ps %ymm4,%ymm11,%ymm2 .byte 197,236,88,193 // vaddps %ymm1,%ymm2,%ymm0 .byte 197,172,89,76,36,168 // vmulps -0x58(%rsp),%ymm10,%ymm1 .byte 196,226,37,184,205 // vfmadd231ps %ymm5,%ymm11,%ymm1 .byte 196,193,116,88,200 // vaddps %ymm8,%ymm1,%ymm1 .byte 197,172,89,84,36,200 // vmulps -0x38(%rsp),%ymm10,%ymm2 .byte 196,98,77,168,218 // vfmadd213ps %ymm2,%ymm6,%ymm11 .byte 196,193,36,88,209 // vaddps %ymm9,%ymm11,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 196,193,100,92,220 // vsubps %ymm12,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_luminosity_hsw .globl _sk_luminosity_hsw FUNCTION(_sk_luminosity_hsw) _sk_luminosity_hsw: .byte 197,124,40,202 // vmovaps %ymm2,%ymm9 .byte 197,124,17,76,36,168 // vmovups %ymm9,-0x58(%rsp) .byte 197,252,17,76,36,200 // vmovups %ymm1,-0x38(%rsp) .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 197,100,89,196 // vmulps %ymm4,%ymm3,%ymm8 .byte 197,100,89,213 // vmulps %ymm5,%ymm3,%ymm10 .byte 197,100,89,222 // vmulps %ymm6,%ymm3,%ymm11 .byte 196,98,125,24,45,143,74,0,0 // vbroadcastss 0x4a8f(%rip),%ymm13 # 5bbc <_sk_callback_hsw+0x1e2> .byte 196,98,125,24,53,138,74,0,0 // vbroadcastss 0x4a8a(%rip),%ymm14 # 5bc0 <_sk_callback_hsw+0x1e6> .byte 196,65,116,89,230 // vmulps %ymm14,%ymm1,%ymm12 .byte 196,66,109,184,229 // vfmadd231ps %ymm13,%ymm2,%ymm12 .byte 196,98,125,24,61,123,74,0,0 // vbroadcastss 0x4a7b(%rip),%ymm15 # 5bc4 <_sk_callback_hsw+0x1ea> .byte 196,66,53,184,231 // vfmadd231ps %ymm15,%ymm9,%ymm12 .byte 196,65,44,89,206 // vmulps %ymm14,%ymm10,%ymm9 .byte 196,66,61,184,205 // vfmadd231ps %ymm13,%ymm8,%ymm9 .byte 196,66,37,184,207 // vfmadd231ps %ymm15,%ymm11,%ymm9 .byte 196,66,69,170,225 // vfmsub213ps %ymm9,%ymm7,%ymm12 .byte 196,65,60,88,204 // vaddps %ymm12,%ymm8,%ymm9 .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 196,65,44,93,195 // vminps %ymm11,%ymm10,%ymm8 .byte 196,65,52,93,224 // vminps %ymm8,%ymm9,%ymm12 .byte 196,65,44,89,198 // vmulps %ymm14,%ymm10,%ymm8 .byte 196,66,53,184,197 // vfmadd231ps %ymm13,%ymm9,%ymm8 .byte 196,66,37,184,199 // vfmadd231ps %ymm15,%ymm11,%ymm8 .byte 196,65,52,92,232 // vsubps %ymm8,%ymm9,%ymm13 .byte 196,65,60,89,237 // vmulps %ymm13,%ymm8,%ymm13 .byte 196,65,60,92,244 // vsubps %ymm12,%ymm8,%ymm14 .byte 196,193,20,94,198 // vdivps %ymm14,%ymm13,%ymm0 .byte 196,65,44,92,248 // vsubps %ymm8,%ymm10,%ymm15 .byte 196,65,60,89,255 // vmulps %ymm15,%ymm8,%ymm15 .byte 196,65,4,94,254 // vdivps %ymm14,%ymm15,%ymm15 .byte 196,65,36,92,232 // vsubps %ymm8,%ymm11,%ymm13 .byte 196,65,60,89,237 // vmulps %ymm13,%ymm8,%ymm13 .byte 196,65,20,94,238 // vdivps %ymm14,%ymm13,%ymm13 .byte 196,65,12,87,246 // vxorps %ymm14,%ymm14,%ymm14 .byte 196,65,12,194,228,2 // vcmpleps %ymm12,%ymm14,%ymm12 .byte 196,65,60,88,255 // vaddps %ymm15,%ymm8,%ymm15 .byte 196,67,5,74,250,192 // vblendvps %ymm12,%ymm10,%ymm15,%ymm15 .byte 196,65,44,95,211 // vmaxps %ymm11,%ymm10,%ymm10 .byte 196,65,60,88,237 // vaddps %ymm13,%ymm8,%ymm13 .byte 196,67,21,74,219,192 // vblendvps %ymm12,%ymm11,%ymm13,%ymm11 .byte 197,188,88,192 // vaddps %ymm0,%ymm8,%ymm0 .byte 196,195,125,74,201,192 // vblendvps %ymm12,%ymm9,%ymm0,%ymm1 .byte 197,100,89,231 // vmulps %ymm7,%ymm3,%ymm12 .byte 196,65,52,95,202 // vmaxps %ymm10,%ymm9,%ymm9 .byte 196,65,116,92,208 // vsubps %ymm8,%ymm1,%ymm10 .byte 196,65,28,92,232 // vsubps %ymm8,%ymm12,%ymm13 .byte 196,65,20,89,210 // vmulps %ymm10,%ymm13,%ymm10 .byte 196,193,28,194,193,1 // vcmpltps %ymm9,%ymm12,%ymm0 .byte 196,65,52,92,200 // vsubps %ymm8,%ymm9,%ymm9 .byte 196,65,44,94,209 // vdivps %ymm9,%ymm10,%ymm10 .byte 196,65,60,88,210 // vaddps %ymm10,%ymm8,%ymm10 .byte 196,195,117,74,202,0 // vblendvps %ymm0,%ymm10,%ymm1,%ymm1 .byte 196,65,4,92,208 // vsubps %ymm8,%ymm15,%ymm10 .byte 196,65,20,89,210 // vmulps %ymm10,%ymm13,%ymm10 .byte 196,65,44,94,209 // vdivps %ymm9,%ymm10,%ymm10 .byte 196,65,60,88,210 // vaddps %ymm10,%ymm8,%ymm10 .byte 196,67,5,74,210,0 // vblendvps %ymm0,%ymm10,%ymm15,%ymm10 .byte 196,65,36,92,248 // vsubps %ymm8,%ymm11,%ymm15 .byte 196,65,20,89,239 // vmulps %ymm15,%ymm13,%ymm13 .byte 196,65,20,94,201 // vdivps %ymm9,%ymm13,%ymm9 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 196,195,37,74,192,0 // vblendvps %ymm0,%ymm8,%ymm11,%ymm0 .byte 196,193,116,95,206 // vmaxps %ymm14,%ymm1,%ymm1 .byte 196,65,44,95,198 // vmaxps %ymm14,%ymm10,%ymm8 .byte 196,65,124,95,206 // vmaxps %ymm14,%ymm0,%ymm9 .byte 196,226,125,24,5,93,73,0,0 // vbroadcastss 0x495d(%rip),%ymm0 # 5bc8 <_sk_callback_hsw+0x1ee> .byte 197,124,92,215 // vsubps %ymm7,%ymm0,%ymm10 .byte 197,172,89,210 // vmulps %ymm2,%ymm10,%ymm2 .byte 197,124,92,219 // vsubps %ymm3,%ymm0,%ymm11 .byte 196,226,37,184,212 // vfmadd231ps %ymm4,%ymm11,%ymm2 .byte 197,236,88,193 // vaddps %ymm1,%ymm2,%ymm0 .byte 197,172,89,76,36,200 // vmulps -0x38(%rsp),%ymm10,%ymm1 .byte 196,226,37,184,205 // vfmadd231ps %ymm5,%ymm11,%ymm1 .byte 196,193,116,88,200 // vaddps %ymm8,%ymm1,%ymm1 .byte 197,172,89,84,36,168 // vmulps -0x58(%rsp),%ymm10,%ymm2 .byte 196,98,77,168,218 // vfmadd213ps %ymm2,%ymm6,%ymm11 .byte 196,193,36,88,209 // vaddps %ymm9,%ymm11,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 196,193,100,92,220 // vsubps %ymm12,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_rgba_8888_hsw .globl _sk_srcover_rgba_8888_hsw FUNCTION(_sk_srcover_rgba_8888_hsw) _sk_srcover_rgba_8888_hsw: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,178,0,0,0 // jne 1386 <_sk_srcover_rgba_8888_hsw+0xd9> .byte 197,252,16,56 // vmovups (%rax),%ymm7 .byte 197,196,84,37,32,77,0,0 // vandps 0x4d20(%rip),%ymm7,%ymm4 # 6000 <_sk_callback_hsw+0x626> .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,226,69,0,45,51,77,0,0 // vpshufb 0x4d33(%rip),%ymm7,%ymm5 # 6020 <_sk_callback_hsw+0x646> .byte 197,252,91,237 // vcvtdq2ps %ymm5,%ymm5 .byte 196,226,69,0,53,70,77,0,0 // vpshufb 0x4d46(%rip),%ymm7,%ymm6 # 6040 <_sk_callback_hsw+0x666> .byte 197,252,91,246 // vcvtdq2ps %ymm6,%ymm6 .byte 197,197,114,215,24 // vpsrld $0x18,%ymm7,%ymm7 .byte 197,252,91,255 // vcvtdq2ps %ymm7,%ymm7 .byte 196,98,125,24,5,188,72,0,0 // vbroadcastss 0x48bc(%rip),%ymm8 # 5bcc <_sk_callback_hsw+0x1f2> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,98,125,24,13,179,72,0,0 // vbroadcastss 0x48b3(%rip),%ymm9 # 5bd0 <_sk_callback_hsw+0x1f6> .byte 196,193,124,89,193 // vmulps %ymm9,%ymm0,%ymm0 .byte 196,194,93,184,192 // vfmadd231ps %ymm8,%ymm4,%ymm0 .byte 196,193,116,89,201 // vmulps %ymm9,%ymm1,%ymm1 .byte 196,194,85,184,200 // vfmadd231ps %ymm8,%ymm5,%ymm1 .byte 196,193,108,89,209 // vmulps %ymm9,%ymm2,%ymm2 .byte 196,194,77,184,208 // vfmadd231ps %ymm8,%ymm6,%ymm2 .byte 196,193,100,89,217 // vmulps %ymm9,%ymm3,%ymm3 .byte 196,194,69,184,216 // vfmadd231ps %ymm8,%ymm7,%ymm3 .byte 197,125,91,192 // vcvtps2dq %ymm0,%ymm8 .byte 197,125,91,201 // vcvtps2dq %ymm1,%ymm9 .byte 196,193,53,114,241,8 // vpslld $0x8,%ymm9,%ymm9 .byte 196,65,53,235,192 // vpor %ymm8,%ymm9,%ymm8 .byte 197,125,91,202 // vcvtps2dq %ymm2,%ymm9 .byte 196,193,53,114,241,16 // vpslld $0x10,%ymm9,%ymm9 .byte 197,125,91,211 // vcvtps2dq %ymm3,%ymm10 .byte 196,193,45,114,242,24 // vpslld $0x18,%ymm10,%ymm10 .byte 196,65,53,235,202 // vpor %ymm10,%ymm9,%ymm9 .byte 196,65,61,235,193 // vpor %ymm9,%ymm8,%ymm8 .byte 77,133,192 // test %r8,%r8 .byte 117,52 // jne 13af <_sk_srcover_rgba_8888_hsw+0x102> .byte 197,124,17,0 // vmovups %ymm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,226 // vmovq %r10,%xmm4 .byte 196,226,125,33,228 // vpmovsxbd %xmm4,%ymm4 .byte 196,226,93,44,56 // vmaskmovps (%rax),%ymm4,%ymm7 .byte 233,41,255,255,255 // jmpq 12d8 <_sk_srcover_rgba_8888_hsw+0x2b> .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,65,249,110,202 // vmovq %r10,%xmm9 .byte 196,66,125,33,201 // vpmovsxbd %xmm9,%ymm9 .byte 196,98,53,46,0 // vmaskmovps %ymm8,%ymm9,(%rax) .byte 235,170 // jmp 137f <_sk_srcover_rgba_8888_hsw+0xd2> HIDDEN _sk_clamp_0_hsw .globl _sk_clamp_0_hsw FUNCTION(_sk_clamp_0_hsw) _sk_clamp_0_hsw: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,124,95,192 // vmaxps %ymm8,%ymm0,%ymm0 .byte 196,193,116,95,200 // vmaxps %ymm8,%ymm1,%ymm1 .byte 196,193,108,95,208 // vmaxps %ymm8,%ymm2,%ymm2 .byte 196,193,100,95,216 // vmaxps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_1_hsw .globl _sk_clamp_1_hsw FUNCTION(_sk_clamp_1_hsw) _sk_clamp_1_hsw: .byte 196,98,125,24,5,217,71,0,0 // vbroadcastss 0x47d9(%rip),%ymm8 # 5bd4 <_sk_callback_hsw+0x1fa> .byte 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 .byte 196,193,116,93,200 // vminps %ymm8,%ymm1,%ymm1 .byte 196,193,108,93,208 // vminps %ymm8,%ymm2,%ymm2 .byte 196,193,100,93,216 // vminps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_a_hsw .globl _sk_clamp_a_hsw FUNCTION(_sk_clamp_a_hsw) _sk_clamp_a_hsw: .byte 196,98,125,24,5,188,71,0,0 // vbroadcastss 0x47bc(%rip),%ymm8 # 5bd8 <_sk_callback_hsw+0x1fe> .byte 196,193,100,93,216 // vminps %ymm8,%ymm3,%ymm3 .byte 197,252,93,195 // vminps %ymm3,%ymm0,%ymm0 .byte 197,244,93,203 // vminps %ymm3,%ymm1,%ymm1 .byte 197,236,93,211 // vminps %ymm3,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_a_dst_hsw .globl _sk_clamp_a_dst_hsw FUNCTION(_sk_clamp_a_dst_hsw) _sk_clamp_a_dst_hsw: .byte 196,98,125,24,5,162,71,0,0 // vbroadcastss 0x47a2(%rip),%ymm8 # 5bdc <_sk_callback_hsw+0x202> .byte 196,193,68,93,248 // vminps %ymm8,%ymm7,%ymm7 .byte 197,220,93,231 // vminps %ymm7,%ymm4,%ymm4 .byte 197,212,93,239 // vminps %ymm7,%ymm5,%ymm5 .byte 197,204,93,247 // vminps %ymm7,%ymm6,%ymm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_set_rgb_hsw .globl _sk_set_rgb_hsw FUNCTION(_sk_set_rgb_hsw) _sk_set_rgb_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,0 // vbroadcastss (%rax),%ymm0 .byte 196,226,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm1 .byte 196,226,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_swap_rb_hsw .globl _sk_swap_rb_hsw FUNCTION(_sk_swap_rb_hsw) _sk_swap_rb_hsw: .byte 197,124,40,192 // vmovaps %ymm0,%ymm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,194 // vmovaps %ymm2,%ymm0 .byte 197,124,41,194 // vmovaps %ymm8,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_invert_hsw .globl _sk_invert_hsw FUNCTION(_sk_invert_hsw) _sk_invert_hsw: .byte 196,98,125,24,5,97,71,0,0 // vbroadcastss 0x4761(%rip),%ymm8 # 5be0 <_sk_callback_hsw+0x206> .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 197,188,92,219 // vsubps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_move_src_dst_hsw .globl _sk_move_src_dst_hsw FUNCTION(_sk_move_src_dst_hsw) _sk_move_src_dst_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,224 // vmovaps %ymm0,%ymm4 .byte 197,252,40,233 // vmovaps %ymm1,%ymm5 .byte 197,252,40,242 // vmovaps %ymm2,%ymm6 .byte 197,252,40,251 // vmovaps %ymm3,%ymm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_move_dst_src_hsw .globl _sk_move_dst_src_hsw FUNCTION(_sk_move_dst_src_hsw) _sk_move_dst_src_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,196 // vmovaps %ymm4,%ymm0 .byte 197,252,40,205 // vmovaps %ymm5,%ymm1 .byte 197,252,40,214 // vmovaps %ymm6,%ymm2 .byte 197,252,40,223 // vmovaps %ymm7,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_hsw .globl _sk_premul_hsw FUNCTION(_sk_premul_hsw) _sk_premul_hsw: .byte 197,252,89,195 // vmulps %ymm3,%ymm0,%ymm0 .byte 197,244,89,203 // vmulps %ymm3,%ymm1,%ymm1 .byte 197,236,89,211 // vmulps %ymm3,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_dst_hsw .globl _sk_premul_dst_hsw FUNCTION(_sk_premul_dst_hsw) _sk_premul_dst_hsw: .byte 197,220,89,231 // vmulps %ymm7,%ymm4,%ymm4 .byte 197,212,89,239 // vmulps %ymm7,%ymm5,%ymm5 .byte 197,204,89,247 // vmulps %ymm7,%ymm6,%ymm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_unpremul_hsw .globl _sk_unpremul_hsw FUNCTION(_sk_unpremul_hsw) _sk_unpremul_hsw: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,65,100,194,200,0 // vcmpeqps %ymm8,%ymm3,%ymm9 .byte 196,98,125,24,21,245,70,0,0 // vbroadcastss 0x46f5(%rip),%ymm10 # 5be4 <_sk_callback_hsw+0x20a> .byte 197,44,94,211 // vdivps %ymm3,%ymm10,%ymm10 .byte 196,67,45,74,192,144 // vblendvps %ymm9,%ymm8,%ymm10,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_from_srgb_hsw .globl _sk_from_srgb_hsw FUNCTION(_sk_from_srgb_hsw) _sk_from_srgb_hsw: .byte 196,98,125,24,5,214,70,0,0 // vbroadcastss 0x46d6(%rip),%ymm8 # 5be8 <_sk_callback_hsw+0x20e> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 197,124,89,208 // vmulps %ymm0,%ymm0,%ymm10 .byte 196,98,125,24,29,200,70,0,0 // vbroadcastss 0x46c8(%rip),%ymm11 # 5bec <_sk_callback_hsw+0x212> .byte 196,98,125,24,37,195,70,0,0 // vbroadcastss 0x46c3(%rip),%ymm12 # 5bf0 <_sk_callback_hsw+0x216> .byte 196,65,124,40,236 // vmovaps %ymm12,%ymm13 .byte 196,66,125,168,235 // vfmadd213ps %ymm11,%ymm0,%ymm13 .byte 196,98,125,24,53,180,70,0,0 // vbroadcastss 0x46b4(%rip),%ymm14 # 5bf4 <_sk_callback_hsw+0x21a> .byte 196,66,45,168,238 // vfmadd213ps %ymm14,%ymm10,%ymm13 .byte 196,98,125,24,21,170,70,0,0 // vbroadcastss 0x46aa(%rip),%ymm10 # 5bf8 <_sk_callback_hsw+0x21e> .byte 196,193,124,194,194,1 // vcmpltps %ymm10,%ymm0,%ymm0 .byte 196,195,21,74,193,0 // vblendvps %ymm0,%ymm9,%ymm13,%ymm0 .byte 196,65,116,89,200 // vmulps %ymm8,%ymm1,%ymm9 .byte 197,116,89,233 // vmulps %ymm1,%ymm1,%ymm13 .byte 196,65,124,40,252 // vmovaps %ymm12,%ymm15 .byte 196,66,117,168,251 // vfmadd213ps %ymm11,%ymm1,%ymm15 .byte 196,66,21,168,254 // vfmadd213ps %ymm14,%ymm13,%ymm15 .byte 196,193,116,194,202,1 // vcmpltps %ymm10,%ymm1,%ymm1 .byte 196,195,5,74,201,16 // vblendvps %ymm1,%ymm9,%ymm15,%ymm1 .byte 196,65,108,89,192 // vmulps %ymm8,%ymm2,%ymm8 .byte 197,108,89,202 // vmulps %ymm2,%ymm2,%ymm9 .byte 196,66,109,168,227 // vfmadd213ps %ymm11,%ymm2,%ymm12 .byte 196,66,53,168,230 // vfmadd213ps %ymm14,%ymm9,%ymm12 .byte 196,193,108,194,210,1 // vcmpltps %ymm10,%ymm2,%ymm2 .byte 196,195,29,74,208,32 // vblendvps %ymm2,%ymm8,%ymm12,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_from_srgb_dst_hsw .globl _sk_from_srgb_dst_hsw FUNCTION(_sk_from_srgb_dst_hsw) _sk_from_srgb_dst_hsw: .byte 196,98,125,24,5,82,70,0,0 // vbroadcastss 0x4652(%rip),%ymm8 # 5bfc <_sk_callback_hsw+0x222> .byte 196,65,92,89,200 // vmulps %ymm8,%ymm4,%ymm9 .byte 197,92,89,212 // vmulps %ymm4,%ymm4,%ymm10 .byte 196,98,125,24,29,68,70,0,0 // vbroadcastss 0x4644(%rip),%ymm11 # 5c00 <_sk_callback_hsw+0x226> .byte 196,98,125,24,37,63,70,0,0 // vbroadcastss 0x463f(%rip),%ymm12 # 5c04 <_sk_callback_hsw+0x22a> .byte 196,65,124,40,236 // vmovaps %ymm12,%ymm13 .byte 196,66,93,168,235 // vfmadd213ps %ymm11,%ymm4,%ymm13 .byte 196,98,125,24,53,48,70,0,0 // vbroadcastss 0x4630(%rip),%ymm14 # 5c08 <_sk_callback_hsw+0x22e> .byte 196,66,45,168,238 // vfmadd213ps %ymm14,%ymm10,%ymm13 .byte 196,98,125,24,21,38,70,0,0 // vbroadcastss 0x4626(%rip),%ymm10 # 5c0c <_sk_callback_hsw+0x232> .byte 196,193,92,194,226,1 // vcmpltps %ymm10,%ymm4,%ymm4 .byte 196,195,21,74,225,64 // vblendvps %ymm4,%ymm9,%ymm13,%ymm4 .byte 196,65,84,89,200 // vmulps %ymm8,%ymm5,%ymm9 .byte 197,84,89,237 // vmulps %ymm5,%ymm5,%ymm13 .byte 196,65,124,40,252 // vmovaps %ymm12,%ymm15 .byte 196,66,85,168,251 // vfmadd213ps %ymm11,%ymm5,%ymm15 .byte 196,66,21,168,254 // vfmadd213ps %ymm14,%ymm13,%ymm15 .byte 196,193,84,194,234,1 // vcmpltps %ymm10,%ymm5,%ymm5 .byte 196,195,5,74,233,80 // vblendvps %ymm5,%ymm9,%ymm15,%ymm5 .byte 196,65,76,89,192 // vmulps %ymm8,%ymm6,%ymm8 .byte 197,76,89,206 // vmulps %ymm6,%ymm6,%ymm9 .byte 196,66,77,168,227 // vfmadd213ps %ymm11,%ymm6,%ymm12 .byte 196,66,53,168,230 // vfmadd213ps %ymm14,%ymm9,%ymm12 .byte 196,193,76,194,242,1 // vcmpltps %ymm10,%ymm6,%ymm6 .byte 196,195,29,74,240,96 // vblendvps %ymm6,%ymm8,%ymm12,%ymm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_to_srgb_hsw .globl _sk_to_srgb_hsw FUNCTION(_sk_to_srgb_hsw) _sk_to_srgb_hsw: .byte 197,124,82,200 // vrsqrtps %ymm0,%ymm9 .byte 196,98,125,24,5,202,69,0,0 // vbroadcastss 0x45ca(%rip),%ymm8 # 5c10 <_sk_callback_hsw+0x236> .byte 196,65,124,89,208 // vmulps %ymm8,%ymm0,%ymm10 .byte 196,98,125,24,29,192,69,0,0 // vbroadcastss 0x45c0(%rip),%ymm11 # 5c14 <_sk_callback_hsw+0x23a> .byte 196,98,125,24,37,187,69,0,0 // vbroadcastss 0x45bb(%rip),%ymm12 # 5c18 <_sk_callback_hsw+0x23e> .byte 196,65,124,40,236 // vmovaps %ymm12,%ymm13 .byte 196,66,53,168,235 // vfmadd213ps %ymm11,%ymm9,%ymm13 .byte 196,98,125,24,53,172,69,0,0 // vbroadcastss 0x45ac(%rip),%ymm14 # 5c1c <_sk_callback_hsw+0x242> .byte 196,66,53,168,238 // vfmadd213ps %ymm14,%ymm9,%ymm13 .byte 196,98,125,24,61,162,69,0,0 // vbroadcastss 0x45a2(%rip),%ymm15 # 5c20 <_sk_callback_hsw+0x246> .byte 196,65,52,88,207 // vaddps %ymm15,%ymm9,%ymm9 .byte 196,65,124,83,201 // vrcpps %ymm9,%ymm9 .byte 196,65,20,89,201 // vmulps %ymm9,%ymm13,%ymm9 .byte 196,98,125,24,45,142,69,0,0 // vbroadcastss 0x458e(%rip),%ymm13 # 5c24 <_sk_callback_hsw+0x24a> .byte 196,193,124,194,197,1 // vcmpltps %ymm13,%ymm0,%ymm0 .byte 196,195,53,74,194,0 // vblendvps %ymm0,%ymm10,%ymm9,%ymm0 .byte 197,124,82,201 // vrsqrtps %ymm1,%ymm9 .byte 196,65,124,40,212 // vmovaps %ymm12,%ymm10 .byte 196,66,53,168,211 // vfmadd213ps %ymm11,%ymm9,%ymm10 .byte 196,66,53,168,214 // vfmadd213ps %ymm14,%ymm9,%ymm10 .byte 196,65,52,88,207 // vaddps %ymm15,%ymm9,%ymm9 .byte 196,65,124,83,201 // vrcpps %ymm9,%ymm9 .byte 196,65,44,89,201 // vmulps %ymm9,%ymm10,%ymm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,193,116,194,205,1 // vcmpltps %ymm13,%ymm1,%ymm1 .byte 196,195,53,74,202,16 // vblendvps %ymm1,%ymm10,%ymm9,%ymm1 .byte 197,124,82,202 // vrsqrtps %ymm2,%ymm9 .byte 196,66,53,168,227 // vfmadd213ps %ymm11,%ymm9,%ymm12 .byte 196,66,53,168,230 // vfmadd213ps %ymm14,%ymm9,%ymm12 .byte 196,65,52,88,207 // vaddps %ymm15,%ymm9,%ymm9 .byte 196,65,124,83,201 // vrcpps %ymm9,%ymm9 .byte 196,65,28,89,201 // vmulps %ymm9,%ymm12,%ymm9 .byte 196,65,108,89,192 // vmulps %ymm8,%ymm2,%ymm8 .byte 196,193,108,194,213,1 // vcmpltps %ymm13,%ymm2,%ymm2 .byte 196,195,53,74,208,32 // vblendvps %ymm2,%ymm8,%ymm9,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_rgb_to_hsl_hsw .globl _sk_rgb_to_hsl_hsw FUNCTION(_sk_rgb_to_hsl_hsw) _sk_rgb_to_hsl_hsw: .byte 197,124,95,193 // vmaxps %ymm1,%ymm0,%ymm8 .byte 197,60,95,194 // vmaxps %ymm2,%ymm8,%ymm8 .byte 197,124,93,201 // vminps %ymm1,%ymm0,%ymm9 .byte 197,52,93,202 // vminps %ymm2,%ymm9,%ymm9 .byte 196,65,60,92,209 // vsubps %ymm9,%ymm8,%ymm10 .byte 196,98,125,24,29,3,69,0,0 // vbroadcastss 0x4503(%rip),%ymm11 # 5c28 <_sk_callback_hsw+0x24e> .byte 196,65,36,94,218 // vdivps %ymm10,%ymm11,%ymm11 .byte 197,116,92,226 // vsubps %ymm2,%ymm1,%ymm12 .byte 197,116,194,234,1 // vcmpltps %ymm2,%ymm1,%ymm13 .byte 196,98,125,24,53,240,68,0,0 // vbroadcastss 0x44f0(%rip),%ymm14 # 5c2c <_sk_callback_hsw+0x252> .byte 196,65,4,87,255 // vxorps %ymm15,%ymm15,%ymm15 .byte 196,67,5,74,238,208 // vblendvps %ymm13,%ymm14,%ymm15,%ymm13 .byte 196,66,37,168,229 // vfmadd213ps %ymm13,%ymm11,%ymm12 .byte 197,236,92,208 // vsubps %ymm0,%ymm2,%ymm2 .byte 197,124,92,233 // vsubps %ymm1,%ymm0,%ymm13 .byte 196,98,125,24,53,215,68,0,0 // vbroadcastss 0x44d7(%rip),%ymm14 # 5c34 <_sk_callback_hsw+0x25a> .byte 196,66,37,168,238 // vfmadd213ps %ymm14,%ymm11,%ymm13 .byte 196,98,125,24,53,197,68,0,0 // vbroadcastss 0x44c5(%rip),%ymm14 # 5c30 <_sk_callback_hsw+0x256> .byte 196,194,37,168,214 // vfmadd213ps %ymm14,%ymm11,%ymm2 .byte 197,188,194,201,0 // vcmpeqps %ymm1,%ymm8,%ymm1 .byte 196,227,21,74,202,16 // vblendvps %ymm1,%ymm2,%ymm13,%ymm1 .byte 197,188,194,192,0 // vcmpeqps %ymm0,%ymm8,%ymm0 .byte 196,195,117,74,196,0 // vblendvps %ymm0,%ymm12,%ymm1,%ymm0 .byte 196,193,60,88,201 // vaddps %ymm9,%ymm8,%ymm1 .byte 196,98,125,24,29,168,68,0,0 // vbroadcastss 0x44a8(%rip),%ymm11 # 5c3c <_sk_callback_hsw+0x262> .byte 196,193,116,89,211 // vmulps %ymm11,%ymm1,%ymm2 .byte 197,36,194,218,1 // vcmpltps %ymm2,%ymm11,%ymm11 .byte 196,65,12,92,224 // vsubps %ymm8,%ymm14,%ymm12 .byte 196,65,28,92,225 // vsubps %ymm9,%ymm12,%ymm12 .byte 196,195,117,74,204,176 // vblendvps %ymm11,%ymm12,%ymm1,%ymm1 .byte 196,65,60,194,193,0 // vcmpeqps %ymm9,%ymm8,%ymm8 .byte 197,172,94,201 // vdivps %ymm1,%ymm10,%ymm1 .byte 196,195,125,74,199,128 // vblendvps %ymm8,%ymm15,%ymm0,%ymm0 .byte 196,195,117,74,207,128 // vblendvps %ymm8,%ymm15,%ymm1,%ymm1 .byte 196,98,125,24,5,107,68,0,0 // vbroadcastss 0x446b(%rip),%ymm8 # 5c38 <_sk_callback_hsw+0x25e> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_hsl_to_rgb_hsw .globl _sk_hsl_to_rgb_hsw FUNCTION(_sk_hsl_to_rgb_hsw) _sk_hsl_to_rgb_hsw: .byte 72,131,236,56 // sub $0x38,%rsp .byte 197,252,17,60,36 // vmovups %ymm7,(%rsp) .byte 197,252,17,116,36,224 // vmovups %ymm6,-0x20(%rsp) .byte 197,252,17,108,36,192 // vmovups %ymm5,-0x40(%rsp) .byte 197,252,17,100,36,160 // vmovups %ymm4,-0x60(%rsp) .byte 197,252,17,92,36,128 // vmovups %ymm3,-0x80(%rsp) .byte 197,252,40,233 // vmovaps %ymm1,%ymm5 .byte 197,252,40,224 // vmovaps %ymm0,%ymm4 .byte 196,98,125,24,5,56,68,0,0 // vbroadcastss 0x4438(%rip),%ymm8 # 5c40 <_sk_callback_hsw+0x266> .byte 197,60,194,202,2 // vcmpleps %ymm2,%ymm8,%ymm9 .byte 197,84,89,210 // vmulps %ymm2,%ymm5,%ymm10 .byte 196,65,84,92,218 // vsubps %ymm10,%ymm5,%ymm11 .byte 196,67,45,74,203,144 // vblendvps %ymm9,%ymm11,%ymm10,%ymm9 .byte 197,52,88,210 // vaddps %ymm2,%ymm9,%ymm10 .byte 196,98,125,24,13,27,68,0,0 // vbroadcastss 0x441b(%rip),%ymm9 # 5c44 <_sk_callback_hsw+0x26a> .byte 196,66,109,170,202 // vfmsub213ps %ymm10,%ymm2,%ymm9 .byte 196,98,125,24,29,17,68,0,0 // vbroadcastss 0x4411(%rip),%ymm11 # 5c48 <_sk_callback_hsw+0x26e> .byte 196,65,92,88,219 // vaddps %ymm11,%ymm4,%ymm11 .byte 196,67,125,8,227,1 // vroundps $0x1,%ymm11,%ymm12 .byte 196,65,36,92,252 // vsubps %ymm12,%ymm11,%ymm15 .byte 196,65,44,92,217 // vsubps %ymm9,%ymm10,%ymm11 .byte 196,98,125,24,45,251,67,0,0 // vbroadcastss 0x43fb(%rip),%ymm13 # 5c50 <_sk_callback_hsw+0x276> .byte 196,193,4,89,197 // vmulps %ymm13,%ymm15,%ymm0 .byte 196,98,125,24,53,241,67,0,0 // vbroadcastss 0x43f1(%rip),%ymm14 # 5c54 <_sk_callback_hsw+0x27a> .byte 197,12,92,224 // vsubps %ymm0,%ymm14,%ymm12 .byte 196,66,37,168,225 // vfmadd213ps %ymm9,%ymm11,%ymm12 .byte 196,226,125,24,29,215,67,0,0 // vbroadcastss 0x43d7(%rip),%ymm3 # 5c4c <_sk_callback_hsw+0x272> .byte 196,193,100,194,255,2 // vcmpleps %ymm15,%ymm3,%ymm7 .byte 196,195,29,74,249,112 // vblendvps %ymm7,%ymm9,%ymm12,%ymm7 .byte 196,65,60,194,231,2 // vcmpleps %ymm15,%ymm8,%ymm12 .byte 196,227,45,74,255,192 // vblendvps %ymm12,%ymm7,%ymm10,%ymm7 .byte 196,98,125,24,37,194,67,0,0 // vbroadcastss 0x43c2(%rip),%ymm12 # 5c58 <_sk_callback_hsw+0x27e> .byte 196,65,28,194,255,2 // vcmpleps %ymm15,%ymm12,%ymm15 .byte 196,194,37,168,193 // vfmadd213ps %ymm9,%ymm11,%ymm0 .byte 196,99,125,74,255,240 // vblendvps %ymm15,%ymm7,%ymm0,%ymm15 .byte 196,227,125,8,196,1 // vroundps $0x1,%ymm4,%ymm0 .byte 197,220,92,192 // vsubps %ymm0,%ymm4,%ymm0 .byte 196,193,124,89,253 // vmulps %ymm13,%ymm0,%ymm7 .byte 197,140,92,207 // vsubps %ymm7,%ymm14,%ymm1 .byte 196,194,37,168,201 // vfmadd213ps %ymm9,%ymm11,%ymm1 .byte 197,228,194,240,2 // vcmpleps %ymm0,%ymm3,%ymm6 .byte 196,195,117,74,201,96 // vblendvps %ymm6,%ymm9,%ymm1,%ymm1 .byte 197,188,194,240,2 // vcmpleps %ymm0,%ymm8,%ymm6 .byte 196,227,45,74,201,96 // vblendvps %ymm6,%ymm1,%ymm10,%ymm1 .byte 197,156,194,192,2 // vcmpleps %ymm0,%ymm12,%ymm0 .byte 196,194,37,168,249 // vfmadd213ps %ymm9,%ymm11,%ymm7 .byte 196,227,69,74,201,0 // vblendvps %ymm0,%ymm1,%ymm7,%ymm1 .byte 196,226,125,24,5,110,67,0,0 // vbroadcastss 0x436e(%rip),%ymm0 # 5c5c <_sk_callback_hsw+0x282> .byte 197,220,88,192 // vaddps %ymm0,%ymm4,%ymm0 .byte 196,227,125,8,224,1 // vroundps $0x1,%ymm0,%ymm4 .byte 197,252,92,196 // vsubps %ymm4,%ymm0,%ymm0 .byte 197,228,194,216,2 // vcmpleps %ymm0,%ymm3,%ymm3 .byte 196,193,124,89,229 // vmulps %ymm13,%ymm0,%ymm4 .byte 197,140,92,244 // vsubps %ymm4,%ymm14,%ymm6 .byte 196,194,37,168,241 // vfmadd213ps %ymm9,%ymm11,%ymm6 .byte 196,195,77,74,217,48 // vblendvps %ymm3,%ymm9,%ymm6,%ymm3 .byte 197,188,194,240,2 // vcmpleps %ymm0,%ymm8,%ymm6 .byte 196,227,45,74,219,96 // vblendvps %ymm6,%ymm3,%ymm10,%ymm3 .byte 196,98,37,184,204 // vfmadd231ps %ymm4,%ymm11,%ymm9 .byte 197,156,194,192,2 // vcmpleps %ymm0,%ymm12,%ymm0 .byte 196,227,53,74,219,0 // vblendvps %ymm0,%ymm3,%ymm9,%ymm3 .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,212,194,224,0 // vcmpeqps %ymm0,%ymm5,%ymm4 .byte 196,227,5,74,194,64 // vblendvps %ymm4,%ymm2,%ymm15,%ymm0 .byte 196,227,117,74,202,64 // vblendvps %ymm4,%ymm2,%ymm1,%ymm1 .byte 196,227,101,74,210,64 // vblendvps %ymm4,%ymm2,%ymm3,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,92,36,128 // vmovups -0x80(%rsp),%ymm3 .byte 197,252,16,100,36,160 // vmovups -0x60(%rsp),%ymm4 .byte 197,252,16,108,36,192 // vmovups -0x40(%rsp),%ymm5 .byte 197,252,16,116,36,224 // vmovups -0x20(%rsp),%ymm6 .byte 197,252,16,60,36 // vmovups (%rsp),%ymm7 .byte 72,131,196,56 // add $0x38,%rsp .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_1_float_hsw .globl _sk_scale_1_float_hsw FUNCTION(_sk_scale_1_float_hsw) _sk_scale_1_float_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 197,188,89,219 // vmulps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_u8_hsw .globl _sk_scale_u8_hsw FUNCTION(_sk_scale_u8_hsw) _sk_scale_u8_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,59 // jne 19df <_sk_scale_u8_hsw+0x54> .byte 196,66,121,48,4,25 // vpmovzxbw (%r9,%rbx,1),%xmm8 .byte 197,57,219,5,78,73,0,0 // vpand 0x494e(%rip),%xmm8,%xmm8 # 6300 <_sk_callback_hsw+0x926> .byte 196,66,125,51,192 // vpmovzxwd %xmm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 196,98,125,24,13,155,66,0,0 // vbroadcastss 0x429b(%rip),%ymm9 # 5c60 <_sk_callback_hsw+0x286> .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 197,188,89,219 // vmulps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,182 // ja 19aa <_sk_scale_u8_hsw+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,121,0,0,0 // lea 0x79(%rip),%r11 # 1a78 <_sk_scale_u8_hsw+0xed> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 235,151 // jmp 19aa <_sk_scale_u8_hsw+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 197,57,196,192,2 // vpinsrw $0x2,%eax,%xmm8,%xmm8 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,121,110,200 // vmovd %eax,%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,67,57,2,193,1 // vpblendd $0x1,%xmm9,%xmm8,%xmm8 .byte 233,110,255,255,255 // jmpq 19aa <_sk_scale_u8_hsw+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 197,57,196,192,6 // vpinsrw $0x6,%eax,%xmm8,%xmm8 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,57,196,192,5 // vpinsrw $0x5,%eax,%xmm8,%xmm8 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,57,196,192,4 // vpinsrw $0x4,%eax,%xmm8,%xmm8 .byte 196,65,121,110,12,25 // vmovd (%r9,%rbx,1),%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,67,49,2,192,12 // vpblendd $0xc,%xmm8,%xmm9,%xmm8 .byte 233,50,255,255,255 // jmpq 19aa <_sk_scale_u8_hsw+0x1f> .byte 144 // nop .byte 255 // (bad) .byte 255 // (bad) .byte 255,171,255,255,255,155 // ljmp *-0x64000001(%rbx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 234 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 223,255 // (bad) .byte 255 // (bad) .byte 255,212 // callq *%rsp .byte 255 // (bad) .byte 255 // (bad) .byte 255,196 // inc %esp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_lerp_1_float_hsw .globl _sk_lerp_1_float_hsw FUNCTION(_sk_lerp_1_float_hsw) _sk_lerp_1_float_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 197,252,92,196 // vsubps %ymm4,%ymm0,%ymm0 .byte 196,226,61,168,196 // vfmadd213ps %ymm4,%ymm8,%ymm0 .byte 197,244,92,205 // vsubps %ymm5,%ymm1,%ymm1 .byte 196,226,61,168,205 // vfmadd213ps %ymm5,%ymm8,%ymm1 .byte 197,236,92,214 // vsubps %ymm6,%ymm2,%ymm2 .byte 196,226,61,168,214 // vfmadd213ps %ymm6,%ymm8,%ymm2 .byte 197,228,92,223 // vsubps %ymm7,%ymm3,%ymm3 .byte 196,226,61,168,223 // vfmadd213ps %ymm7,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_lerp_u8_hsw .globl _sk_lerp_u8_hsw FUNCTION(_sk_lerp_u8_hsw) _sk_lerp_u8_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,79 // jne 1b2b <_sk_lerp_u8_hsw+0x68> .byte 196,66,121,48,4,25 // vpmovzxbw (%r9,%rbx,1),%xmm8 .byte 197,57,219,5,38,72,0,0 // vpand 0x4826(%rip),%xmm8,%xmm8 # 6310 <_sk_callback_hsw+0x936> .byte 196,66,125,51,192 // vpmovzxwd %xmm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 196,98,125,24,13,103,65,0,0 // vbroadcastss 0x4167(%rip),%ymm9 # 5c64 <_sk_callback_hsw+0x28a> .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 197,252,92,196 // vsubps %ymm4,%ymm0,%ymm0 .byte 196,226,61,168,196 // vfmadd213ps %ymm4,%ymm8,%ymm0 .byte 197,244,92,205 // vsubps %ymm5,%ymm1,%ymm1 .byte 196,226,61,168,205 // vfmadd213ps %ymm5,%ymm8,%ymm1 .byte 197,236,92,214 // vsubps %ymm6,%ymm2,%ymm2 .byte 196,226,61,168,214 // vfmadd213ps %ymm6,%ymm8,%ymm2 .byte 197,228,92,223 // vsubps %ymm7,%ymm3,%ymm3 .byte 196,226,61,168,223 // vfmadd213ps %ymm7,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,162 // ja 1ae2 <_sk_lerp_u8_hsw+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,121,0,0,0 // lea 0x79(%rip),%r11 # 1bc4 <_sk_lerp_u8_hsw+0x101> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 235,131 // jmp 1ae2 <_sk_lerp_u8_hsw+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 197,57,196,192,2 // vpinsrw $0x2,%eax,%xmm8,%xmm8 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,121,110,200 // vmovd %eax,%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,67,57,2,193,1 // vpblendd $0x1,%xmm9,%xmm8,%xmm8 .byte 233,90,255,255,255 // jmpq 1ae2 <_sk_lerp_u8_hsw+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 197,57,196,192,6 // vpinsrw $0x6,%eax,%xmm8,%xmm8 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,57,196,192,5 // vpinsrw $0x5,%eax,%xmm8,%xmm8 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,57,196,192,4 // vpinsrw $0x4,%eax,%xmm8,%xmm8 .byte 196,65,121,110,12,25 // vmovd (%r9,%rbx,1),%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,67,49,2,192,12 // vpblendd $0xc,%xmm8,%xmm9,%xmm8 .byte 233,30,255,255,255 // jmpq 1ae2 <_sk_lerp_u8_hsw+0x1f> .byte 144 // nop .byte 255 // (bad) .byte 255 // (bad) .byte 255,171,255,255,255,155 // ljmp *-0x64000001(%rbx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 234 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 223,255 // (bad) .byte 255 // (bad) .byte 255,212 // callq *%rsp .byte 255 // (bad) .byte 255 // (bad) .byte 255,196 // inc %esp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_lerp_565_hsw .globl _sk_lerp_565_hsw FUNCTION(_sk_lerp_565_hsw) _sk_lerp_565_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 15,133,170,0,0,0 // jne 1caa <_sk_lerp_565_hsw+0xca> .byte 196,65,122,111,4,89 // vmovdqu (%r9,%rbx,2),%xmm8 .byte 196,66,125,51,192 // vpmovzxwd %xmm8,%ymm8 .byte 196,98,125,88,13,84,64,0,0 // vpbroadcastd 0x4054(%rip),%ymm9 # 5c68 <_sk_callback_hsw+0x28e> .byte 196,65,61,219,201 // vpand %ymm9,%ymm8,%ymm9 .byte 196,65,124,91,201 // vcvtdq2ps %ymm9,%ymm9 .byte 196,98,125,24,21,69,64,0,0 // vbroadcastss 0x4045(%rip),%ymm10 # 5c6c <_sk_callback_hsw+0x292> .byte 196,65,52,89,202 // vmulps %ymm10,%ymm9,%ymm9 .byte 196,98,125,88,21,59,64,0,0 // vpbroadcastd 0x403b(%rip),%ymm10 # 5c70 <_sk_callback_hsw+0x296> .byte 196,65,61,219,210 // vpand %ymm10,%ymm8,%ymm10 .byte 196,65,124,91,210 // vcvtdq2ps %ymm10,%ymm10 .byte 196,98,125,24,29,44,64,0,0 // vbroadcastss 0x402c(%rip),%ymm11 # 5c74 <_sk_callback_hsw+0x29a> .byte 196,65,44,89,211 // vmulps %ymm11,%ymm10,%ymm10 .byte 196,98,125,88,29,34,64,0,0 // vpbroadcastd 0x4022(%rip),%ymm11 # 5c78 <_sk_callback_hsw+0x29e> .byte 196,65,61,219,195 // vpand %ymm11,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 196,98,125,24,29,19,64,0,0 // vbroadcastss 0x4013(%rip),%ymm11 # 5c7c <_sk_callback_hsw+0x2a2> .byte 196,65,60,89,195 // vmulps %ymm11,%ymm8,%ymm8 .byte 197,252,92,196 // vsubps %ymm4,%ymm0,%ymm0 .byte 196,226,53,168,196 // vfmadd213ps %ymm4,%ymm9,%ymm0 .byte 197,244,92,205 // vsubps %ymm5,%ymm1,%ymm1 .byte 196,226,45,168,205 // vfmadd213ps %ymm5,%ymm10,%ymm1 .byte 197,236,92,214 // vsubps %ymm6,%ymm2,%ymm2 .byte 196,226,61,168,214 // vfmadd213ps %ymm6,%ymm8,%ymm2 .byte 197,228,92,223 // vsubps %ymm7,%ymm3,%ymm3 .byte 196,98,101,168,207 // vfmadd213ps %ymm7,%ymm3,%ymm9 .byte 196,98,101,168,215 // vfmadd213ps %ymm7,%ymm3,%ymm10 .byte 196,98,101,168,199 // vfmadd213ps %ymm7,%ymm3,%ymm8 .byte 196,193,44,95,216 // vmaxps %ymm8,%ymm10,%ymm3 .byte 197,180,95,219 // vmaxps %ymm3,%ymm9,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,67,255,255,255 // ja 1c06 <_sk_lerp_565_hsw+0x26> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,102,0,0,0 // lea 0x66(%rip),%r11 # 1d34 <_sk_lerp_565_hsw+0x154> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 233,33,255,255,255 // jmpq 1c06 <_sk_lerp_565_hsw+0x26> .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 196,65,57,196,68,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm8,%xmm8 .byte 196,65,121,110,12,89 // vmovd (%r9,%rbx,2),%xmm9 .byte 196,67,57,2,193,1 // vpblendd $0x1,%xmm9,%xmm8,%xmm8 .byte 233,3,255,255,255 // jmpq 1c06 <_sk_lerp_565_hsw+0x26> .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 196,65,57,196,68,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm8,%xmm8 .byte 196,65,57,196,68,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm8,%xmm8 .byte 196,65,57,196,68,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm8,%xmm8 .byte 196,65,122,126,12,89 // vmovq (%r9,%rbx,2),%xmm9 .byte 196,67,49,2,192,12 // vpblendd $0xc,%xmm8,%xmm9,%xmm8 .byte 233,213,254,255,255 // jmpq 1c06 <_sk_lerp_565_hsw+0x26> .byte 15,31,0 // nopl (%rax) .byte 163,255,255,255,190,255,255,255,177 // movabs %eax,0xb1ffffffbeffffff .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 236 // in (%dx),%al .byte 255 // (bad) .byte 255 // (bad) .byte 255,228 // jmpq *%rsp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 220,255 // fdivr %st,%st(7) .byte 255 // (bad) .byte 255,207 // dec %edi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_tables_hsw .globl _sk_load_tables_hsw FUNCTION(_sk_load_tables_hsw) _sk_load_tables_hsw: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10 .byte 76,3,16 // add (%rax),%r10 .byte 77,133,192 // test %r8,%r8 .byte 117,105 // jne 1dce <_sk_load_tables_hsw+0x7e> .byte 196,193,124,16,26 // vmovups (%r10),%ymm3 .byte 197,228,84,13,238,66,0,0 // vandps 0x42ee(%rip),%ymm3,%ymm1 # 6060 <_sk_callback_hsw+0x686> .byte 196,65,61,118,192 // vpcmpeqd %ymm8,%ymm8,%ymm8 .byte 72,139,72,8 // mov 0x8(%rax),%rcx .byte 76,139,80,16 // mov 0x10(%rax),%r10 .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 196,226,109,146,4,137 // vgatherdps %ymm2,(%rcx,%ymm1,4),%ymm0 .byte 196,226,101,0,21,238,66,0,0 // vpshufb 0x42ee(%rip),%ymm3,%ymm2 # 6080 <_sk_callback_hsw+0x6a6> .byte 196,65,53,118,201 // vpcmpeqd %ymm9,%ymm9,%ymm9 .byte 196,194,53,146,12,146 // vgatherdps %ymm9,(%r10,%ymm2,4),%ymm1 .byte 72,139,64,24 // mov 0x18(%rax),%rax .byte 196,98,101,0,13,246,66,0,0 // vpshufb 0x42f6(%rip),%ymm3,%ymm9 # 60a0 <_sk_callback_hsw+0x6c6> .byte 196,162,61,146,20,136 // vgatherdps %ymm8,(%rax,%ymm9,4),%ymm2 .byte 197,229,114,211,24 // vpsrld $0x18,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,98,125,24,5,190,62,0,0 // vbroadcastss 0x3ebe(%rip),%ymm8 # 5c80 <_sk_callback_hsw+0x2a6> .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,195,255,255,255,255 // mov $0xffffffffffffffff,%r11 .byte 73,211,235 // shr %cl,%r11 .byte 196,193,249,110,195 // vmovq %r11,%xmm0 .byte 196,226,125,33,192 // vpmovsxbd %xmm0,%ymm0 .byte 196,194,125,44,26 // vmaskmovps (%r10),%ymm0,%ymm3 .byte 233,115,255,255,255 // jmpq 1d6a <_sk_load_tables_hsw+0x1a> HIDDEN _sk_load_tables_u16_be_hsw .globl _sk_load_tables_u16_be_hsw FUNCTION(_sk_load_tables_u16_be_hsw) _sk_load_tables_u16_be_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 76,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10 .byte 77,133,192 // test %r8,%r8 .byte 15,133,201,0,0,0 // jne 1ed6 <_sk_load_tables_u16_be_hsw+0xdf> .byte 196,1,121,16,4,81 // vmovupd (%r9,%r10,2),%xmm8 .byte 196,129,121,16,84,81,16 // vmovupd 0x10(%r9,%r10,2),%xmm2 .byte 196,129,121,16,92,81,32 // vmovupd 0x20(%r9,%r10,2),%xmm3 .byte 196,1,122,111,76,81,48 // vmovdqu 0x30(%r9,%r10,2),%xmm9 .byte 197,185,97,194 // vpunpcklwd %xmm2,%xmm8,%xmm0 .byte 197,185,105,210 // vpunpckhwd %xmm2,%xmm8,%xmm2 .byte 196,193,97,97,201 // vpunpcklwd %xmm9,%xmm3,%xmm1 .byte 196,193,97,105,217 // vpunpckhwd %xmm9,%xmm3,%xmm3 .byte 197,121,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm8 .byte 197,121,105,202 // vpunpckhwd %xmm2,%xmm0,%xmm9 .byte 197,241,97,195 // vpunpcklwd %xmm3,%xmm1,%xmm0 .byte 197,241,105,219 // vpunpckhwd %xmm3,%xmm1,%xmm3 .byte 197,185,108,200 // vpunpcklqdq %xmm0,%xmm8,%xmm1 .byte 197,185,109,208 // vpunpckhqdq %xmm0,%xmm8,%xmm2 .byte 197,49,108,195 // vpunpcklqdq %xmm3,%xmm9,%xmm8 .byte 197,121,111,21,194,68,0,0 // vmovdqa 0x44c2(%rip),%xmm10 # 6320 <_sk_callback_hsw+0x946> .byte 196,193,113,219,194 // vpand %xmm10,%xmm1,%xmm0 .byte 196,226,125,51,200 // vpmovzxwd %xmm0,%ymm1 .byte 196,65,37,118,219 // vpcmpeqd %ymm11,%ymm11,%ymm11 .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 76,139,80,16 // mov 0x10(%rax),%r10 .byte 196,65,29,118,228 // vpcmpeqd %ymm12,%ymm12,%ymm12 .byte 196,194,29,146,4,137 // vgatherdps %ymm12,(%r9,%ymm1,4),%ymm0 .byte 196,193,105,219,202 // vpand %xmm10,%xmm2,%xmm1 .byte 196,226,125,51,209 // vpmovzxwd %xmm1,%ymm2 .byte 196,65,29,118,228 // vpcmpeqd %ymm12,%ymm12,%ymm12 .byte 196,194,29,146,12,146 // vgatherdps %ymm12,(%r10,%ymm2,4),%ymm1 .byte 72,139,64,24 // mov 0x18(%rax),%rax .byte 196,193,57,219,210 // vpand %xmm10,%xmm8,%xmm2 .byte 196,98,125,51,194 // vpmovzxwd %xmm2,%ymm8 .byte 196,162,37,146,20,128 // vgatherdps %ymm11,(%rax,%ymm8,4),%ymm2 .byte 197,177,109,219 // vpunpckhqdq %xmm3,%xmm9,%xmm3 .byte 197,185,113,243,8 // vpsllw $0x8,%xmm3,%xmm8 .byte 197,225,113,211,8 // vpsrlw $0x8,%xmm3,%xmm3 .byte 197,185,235,219 // vpor %xmm3,%xmm8,%xmm3 .byte 196,226,125,51,219 // vpmovzxwd %xmm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,98,125,24,5,183,61,0,0 // vbroadcastss 0x3db7(%rip),%ymm8 # 5c84 <_sk_callback_hsw+0x2aa> .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,1,123,16,4,81 // vmovsd (%r9,%r10,2),%xmm8 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,85 // je 1f3c <_sk_load_tables_u16_be_hsw+0x145> .byte 196,1,57,22,68,81,8 // vmovhpd 0x8(%r9,%r10,2),%xmm8,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,72 // jb 1f3c <_sk_load_tables_u16_be_hsw+0x145> .byte 196,129,123,16,84,81,16 // vmovsd 0x10(%r9,%r10,2),%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 116,72 // je 1f49 <_sk_load_tables_u16_be_hsw+0x152> .byte 196,129,105,22,84,81,24 // vmovhpd 0x18(%r9,%r10,2),%xmm2,%xmm2 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,59 // jb 1f49 <_sk_load_tables_u16_be_hsw+0x152> .byte 196,129,123,16,92,81,32 // vmovsd 0x20(%r9,%r10,2),%xmm3 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 15,132,9,255,255,255 // je 1e28 <_sk_load_tables_u16_be_hsw+0x31> .byte 196,129,97,22,92,81,40 // vmovhpd 0x28(%r9,%r10,2),%xmm3,%xmm3 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,130,248,254,255,255 // jb 1e28 <_sk_load_tables_u16_be_hsw+0x31> .byte 196,1,122,126,76,81,48 // vmovq 0x30(%r9,%r10,2),%xmm9 .byte 233,236,254,255,255 // jmpq 1e28 <_sk_load_tables_u16_be_hsw+0x31> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 197,233,87,210 // vxorpd %xmm2,%xmm2,%xmm2 .byte 233,223,254,255,255 // jmpq 1e28 <_sk_load_tables_u16_be_hsw+0x31> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 233,214,254,255,255 // jmpq 1e28 <_sk_load_tables_u16_be_hsw+0x31> HIDDEN _sk_load_tables_rgb_u16_be_hsw .globl _sk_load_tables_rgb_u16_be_hsw FUNCTION(_sk_load_tables_rgb_u16_be_hsw) _sk_load_tables_rgb_u16_be_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 76,141,20,82 // lea (%rdx,%rdx,2),%r10 .byte 77,133,192 // test %r8,%r8 .byte 15,133,193,0,0,0 // jne 2025 <_sk_load_tables_rgb_u16_be_hsw+0xd3> .byte 196,129,122,111,4,81 // vmovdqu (%r9,%r10,2),%xmm0 .byte 196,129,122,111,84,81,12 // vmovdqu 0xc(%r9,%r10,2),%xmm2 .byte 196,129,122,111,76,81,24 // vmovdqu 0x18(%r9,%r10,2),%xmm1 .byte 196,129,122,111,92,81,32 // vmovdqu 0x20(%r9,%r10,2),%xmm3 .byte 197,225,115,219,4 // vpsrldq $0x4,%xmm3,%xmm3 .byte 197,185,115,216,6 // vpsrldq $0x6,%xmm0,%xmm8 .byte 197,177,115,218,6 // vpsrldq $0x6,%xmm2,%xmm9 .byte 197,161,115,217,6 // vpsrldq $0x6,%xmm1,%xmm11 .byte 197,169,115,219,6 // vpsrldq $0x6,%xmm3,%xmm10 .byte 197,249,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm0 .byte 196,193,57,97,209 // vpunpcklwd %xmm9,%xmm8,%xmm2 .byte 197,241,97,203 // vpunpcklwd %xmm3,%xmm1,%xmm1 .byte 196,193,33,97,218 // vpunpcklwd %xmm10,%xmm11,%xmm3 .byte 197,121,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm8 .byte 197,249,105,194 // vpunpckhwd %xmm2,%xmm0,%xmm0 .byte 197,241,97,211 // vpunpcklwd %xmm3,%xmm1,%xmm2 .byte 197,241,105,203 // vpunpckhwd %xmm3,%xmm1,%xmm1 .byte 197,185,108,218 // vpunpcklqdq %xmm2,%xmm8,%xmm3 .byte 197,185,109,210 // vpunpckhqdq %xmm2,%xmm8,%xmm2 .byte 197,121,108,193 // vpunpcklqdq %xmm1,%xmm0,%xmm8 .byte 197,121,111,13,98,67,0,0 // vmovdqa 0x4362(%rip),%xmm9 # 6330 <_sk_callback_hsw+0x956> .byte 196,193,97,219,193 // vpand %xmm9,%xmm3,%xmm0 .byte 196,226,125,51,200 // vpmovzxwd %xmm0,%ymm1 .byte 197,229,118,219 // vpcmpeqd %ymm3,%ymm3,%ymm3 .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 76,139,80,16 // mov 0x10(%rax),%r10 .byte 196,65,45,118,210 // vpcmpeqd %ymm10,%ymm10,%ymm10 .byte 196,194,45,146,4,137 // vgatherdps %ymm10,(%r9,%ymm1,4),%ymm0 .byte 196,193,105,219,201 // vpand %xmm9,%xmm2,%xmm1 .byte 196,226,125,51,209 // vpmovzxwd %xmm1,%ymm2 .byte 196,65,45,118,210 // vpcmpeqd %ymm10,%ymm10,%ymm10 .byte 196,194,45,146,12,146 // vgatherdps %ymm10,(%r10,%ymm2,4),%ymm1 .byte 72,139,64,24 // mov 0x18(%rax),%rax .byte 196,193,57,219,209 // vpand %xmm9,%xmm8,%xmm2 .byte 196,98,125,51,194 // vpmovzxwd %xmm2,%ymm8 .byte 196,162,101,146,20,128 // vgatherdps %ymm3,(%rax,%ymm8,4),%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,101,60,0,0 // vbroadcastss 0x3c65(%rip),%ymm3 # 5c88 <_sk_callback_hsw+0x2ae> .byte 255,224 // jmpq *%rax .byte 196,129,121,110,4,81 // vmovd (%r9,%r10,2),%xmm0 .byte 196,129,121,196,68,81,4,2 // vpinsrw $0x2,0x4(%r9,%r10,2),%xmm0,%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,5 // jne 203e <_sk_load_tables_rgb_u16_be_hsw+0xec> .byte 233,90,255,255,255 // jmpq 1f98 <_sk_load_tables_rgb_u16_be_hsw+0x46> .byte 196,129,121,110,76,81,6 // vmovd 0x6(%r9,%r10,2),%xmm1 .byte 196,1,113,196,68,81,10,2 // vpinsrw $0x2,0xa(%r9,%r10,2),%xmm1,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,26 // jb 206d <_sk_load_tables_rgb_u16_be_hsw+0x11b> .byte 196,129,121,110,76,81,12 // vmovd 0xc(%r9,%r10,2),%xmm1 .byte 196,129,113,196,84,81,16,2 // vpinsrw $0x2,0x10(%r9,%r10,2),%xmm1,%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 117,10 // jne 2072 <_sk_load_tables_rgb_u16_be_hsw+0x120> .byte 233,43,255,255,255 // jmpq 1f98 <_sk_load_tables_rgb_u16_be_hsw+0x46> .byte 233,38,255,255,255 // jmpq 1f98 <_sk_load_tables_rgb_u16_be_hsw+0x46> .byte 196,129,121,110,76,81,18 // vmovd 0x12(%r9,%r10,2),%xmm1 .byte 196,1,113,196,76,81,22,2 // vpinsrw $0x2,0x16(%r9,%r10,2),%xmm1,%xmm9 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,26 // jb 20a1 <_sk_load_tables_rgb_u16_be_hsw+0x14f> .byte 196,129,121,110,76,81,24 // vmovd 0x18(%r9,%r10,2),%xmm1 .byte 196,129,113,196,76,81,28,2 // vpinsrw $0x2,0x1c(%r9,%r10,2),%xmm1,%xmm1 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 117,10 // jne 20a6 <_sk_load_tables_rgb_u16_be_hsw+0x154> .byte 233,247,254,255,255 // jmpq 1f98 <_sk_load_tables_rgb_u16_be_hsw+0x46> .byte 233,242,254,255,255 // jmpq 1f98 <_sk_load_tables_rgb_u16_be_hsw+0x46> .byte 196,129,121,110,92,81,30 // vmovd 0x1e(%r9,%r10,2),%xmm3 .byte 196,1,97,196,92,81,34,2 // vpinsrw $0x2,0x22(%r9,%r10,2),%xmm3,%xmm11 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,20 // jb 20cf <_sk_load_tables_rgb_u16_be_hsw+0x17d> .byte 196,129,121,110,92,81,36 // vmovd 0x24(%r9,%r10,2),%xmm3 .byte 196,129,97,196,92,81,40,2 // vpinsrw $0x2,0x28(%r9,%r10,2),%xmm3,%xmm3 .byte 233,201,254,255,255 // jmpq 1f98 <_sk_load_tables_rgb_u16_be_hsw+0x46> .byte 233,196,254,255,255 // jmpq 1f98 <_sk_load_tables_rgb_u16_be_hsw+0x46> HIDDEN _sk_byte_tables_hsw .globl _sk_byte_tables_hsw FUNCTION(_sk_byte_tables_hsw) _sk_byte_tables_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,5,173,59,0,0 // vbroadcastss 0x3bad(%rip),%ymm8 # 5c8c <_sk_callback_hsw+0x2b2> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,125,91,200 // vcvtps2dq %ymm0,%ymm9 .byte 196,65,249,126,201 // vmovq %xmm9,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 76,139,24 // mov (%rax),%r11 .byte 196,131,121,32,4,19,0 // vpinsrb $0x0,(%r11,%r10,1),%xmm0,%xmm0 .byte 196,67,249,22,202,1 // vpextrq $0x1,%xmm9,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,3,121,32,20,11,1 // vpinsrb $0x1,(%r11,%r9,1),%xmm0,%xmm10 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,99,125,57,200,1 // vextracti128 $0x1,%ymm9,%xmm0 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,67,41,32,201,2 // vpinsrb $0x2,%r9d,%xmm10,%xmm9 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,49,32,202,3 // vpinsrb $0x3,%r10d,%xmm9,%xmm9 .byte 69,137,202 // mov %r9d,%r10d .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,49,32,202,4 // vpinsrb $0x4,%r10d,%xmm9,%xmm9 .byte 196,195,249,22,194,1 // vpextrq $0x1,%xmm0,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,195,49,32,193,5 // vpinsrb $0x5,%r9d,%xmm9,%xmm0 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,195,121,32,193,6 // vpinsrb $0x6,%r9d,%xmm0,%xmm0 .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,121,32,202,7 // vpinsrb $0x7,%r10d,%xmm0,%xmm9 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 197,253,91,201 // vcvtps2dq %ymm1,%ymm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 69,137,211 // mov %r10d,%r11d .byte 196,131,121,32,4,25,0 // vpinsrb $0x0,(%r9,%r11,1),%xmm0,%xmm0 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,121,32,4,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm0,%xmm0 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,57,201,1 // vextracti128 $0x1,%ymm1,%xmm1 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,2 // vpinsrb $0x2,%r10d,%xmm0,%xmm0 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 196,195,121,32,195,3 // vpinsrb $0x3,%r11d,%xmm0,%xmm0 .byte 69,137,211 // mov %r10d,%r11d .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 196,195,121,32,195,4 // vpinsrb $0x4,%r11d,%xmm0,%xmm0 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,5 // vpinsrb $0x5,%r10d,%xmm0,%xmm0 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,6 // vpinsrb $0x6,%r10d,%xmm0,%xmm0 .byte 71,15,182,12,25 // movzbl (%r9,%r11,1),%r9d .byte 196,195,121,32,201,7 // vpinsrb $0x7,%r9d,%xmm0,%xmm1 .byte 76,139,72,16 // mov 0x10(%rax),%r9 .byte 196,193,108,89,192 // vmulps %ymm8,%ymm2,%ymm0 .byte 197,253,91,192 // vcvtps2dq %ymm0,%ymm0 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 69,137,211 // mov %r10d,%r11d .byte 196,131,121,32,20,25,0 // vpinsrb $0x0,(%r9,%r11,1),%xmm0,%xmm2 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,105,32,20,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm2,%xmm2 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,105,32,210,2 // vpinsrb $0x2,%r10d,%xmm2,%xmm2 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 196,195,105,32,211,3 // vpinsrb $0x3,%r11d,%xmm2,%xmm2 .byte 69,137,211 // mov %r10d,%r11d .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 196,195,105,32,211,4 // vpinsrb $0x4,%r11d,%xmm2,%xmm2 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,105,32,194,5 // vpinsrb $0x5,%r10d,%xmm2,%xmm0 .byte 69,137,218 // mov %r11d,%r10d .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,6 // vpinsrb $0x6,%r10d,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 71,15,182,12,25 // movzbl (%r9,%r11,1),%r9d .byte 196,195,121,32,209,7 // vpinsrb $0x7,%r9d,%xmm0,%xmm2 .byte 76,139,80,24 // mov 0x18(%rax),%r10 .byte 196,193,100,89,192 // vmulps %ymm8,%ymm3,%ymm0 .byte 197,253,91,192 // vcvtps2dq %ymm0,%ymm0 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 68,137,200 // mov %r9d,%eax .byte 196,195,121,32,28,2,0 // vpinsrb $0x0,(%r10,%rax,1),%xmm0,%xmm3 .byte 196,227,249,22,192,1 // vpextrq $0x1,%xmm0,%rax .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,131,97,32,28,10,1 // vpinsrb $0x1,(%r10,%r9,1),%xmm3,%xmm3 .byte 65,137,193 // mov %eax,%r9d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 71,15,182,12,10 // movzbl (%r10,%r9,1),%r9d .byte 196,195,97,32,217,2 // vpinsrb $0x2,%r9d,%xmm3,%xmm3 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,227,97,32,216,3 // vpinsrb $0x3,%eax,%xmm3,%xmm3 .byte 68,137,200 // mov %r9d,%eax .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,227,97,32,216,4 // vpinsrb $0x4,%eax,%xmm3,%xmm3 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,233,32 // shr $0x20,%r9 .byte 67,15,182,4,10 // movzbl (%r10,%r9,1),%eax .byte 196,227,97,32,192,5 // vpinsrb $0x5,%eax,%xmm3,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,227,121,32,216,6 // vpinsrb $0x6,%eax,%xmm0,%xmm3 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,26 // movzbl (%r10,%r11,1),%eax .byte 196,194,125,49,193 // vpmovzxbd %xmm9,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,5,82,57,0,0 // vbroadcastss 0x3952(%rip),%ymm8 # 5c90 <_sk_callback_hsw+0x2b6> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 196,226,125,49,201 // vpmovzxbd %xmm1,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 196,226,125,49,210 // vpmovzxbd %xmm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 196,227,97,32,216,7 // vpinsrb $0x7,%eax,%xmm3,%xmm3 .byte 196,226,125,49,219 // vpmovzxbd %xmm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_byte_tables_rgb_hsw .globl _sk_byte_tables_rgb_hsw FUNCTION(_sk_byte_tables_rgb_hsw) _sk_byte_tables_rgb_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,139,72,24 // mov 0x18(%rax),%r9d .byte 65,255,201 // dec %r9d .byte 196,65,121,110,193 // vmovd %r9d,%xmm8 .byte 196,66,125,88,192 // vpbroadcastd %xmm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,125,91,200 // vcvtps2dq %ymm0,%ymm9 .byte 196,65,249,126,201 // vmovq %xmm9,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 76,139,24 // mov (%rax),%r11 .byte 196,131,121,32,4,19,0 // vpinsrb $0x0,(%r11,%r10,1),%xmm0,%xmm0 .byte 196,67,249,22,202,1 // vpextrq $0x1,%xmm9,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,3,121,32,20,11,1 // vpinsrb $0x1,(%r11,%r9,1),%xmm0,%xmm10 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,99,125,57,200,1 // vextracti128 $0x1,%ymm9,%xmm0 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,67,41,32,201,2 // vpinsrb $0x2,%r9d,%xmm10,%xmm9 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,49,32,202,3 // vpinsrb $0x3,%r10d,%xmm9,%xmm9 .byte 69,137,202 // mov %r9d,%r10d .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,49,32,202,4 // vpinsrb $0x4,%r10d,%xmm9,%xmm9 .byte 196,195,249,22,194,1 // vpextrq $0x1,%xmm0,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,195,49,32,193,5 // vpinsrb $0x5,%r9d,%xmm9,%xmm0 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,195,121,32,193,6 // vpinsrb $0x6,%r9d,%xmm0,%xmm0 .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,121,32,202,7 // vpinsrb $0x7,%r10d,%xmm0,%xmm9 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,253,91,201 // vcvtps2dq %ymm1,%ymm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 69,137,211 // mov %r10d,%r11d .byte 196,131,121,32,4,25,0 // vpinsrb $0x0,(%r9,%r11,1),%xmm0,%xmm0 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,121,32,4,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm0,%xmm0 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,57,201,1 // vextracti128 $0x1,%ymm1,%xmm1 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,2 // vpinsrb $0x2,%r10d,%xmm0,%xmm0 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 196,195,121,32,195,3 // vpinsrb $0x3,%r11d,%xmm0,%xmm0 .byte 69,137,211 // mov %r10d,%r11d .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 196,195,121,32,195,4 // vpinsrb $0x4,%r11d,%xmm0,%xmm0 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,5 // vpinsrb $0x5,%r10d,%xmm0,%xmm0 .byte 69,137,218 // mov %r11d,%r10d .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,6 // vpinsrb $0x6,%r10d,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 71,15,182,12,25 // movzbl (%r9,%r11,1),%r9d .byte 196,195,121,32,201,7 // vpinsrb $0x7,%r9d,%xmm0,%xmm1 .byte 76,139,80,16 // mov 0x10(%rax),%r10 .byte 197,188,89,194 // vmulps %ymm2,%ymm8,%ymm0 .byte 197,253,91,192 // vcvtps2dq %ymm0,%ymm0 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 68,137,200 // mov %r9d,%eax .byte 196,195,121,32,20,2,0 // vpinsrb $0x0,(%r10,%rax,1),%xmm0,%xmm2 .byte 196,227,249,22,192,1 // vpextrq $0x1,%xmm0,%rax .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,131,105,32,20,10,1 // vpinsrb $0x1,(%r10,%r9,1),%xmm2,%xmm2 .byte 65,137,193 // mov %eax,%r9d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 71,15,182,12,10 // movzbl (%r10,%r9,1),%r9d .byte 196,195,105,32,209,2 // vpinsrb $0x2,%r9d,%xmm2,%xmm2 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,227,105,32,208,3 // vpinsrb $0x3,%eax,%xmm2,%xmm2 .byte 68,137,200 // mov %r9d,%eax .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,227,105,32,208,4 // vpinsrb $0x4,%eax,%xmm2,%xmm2 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,233,32 // shr $0x20,%r9 .byte 67,15,182,4,10 // movzbl (%r10,%r9,1),%eax .byte 196,227,105,32,192,5 // vpinsrb $0x5,%eax,%xmm2,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,227,121,32,208,6 // vpinsrb $0x6,%eax,%xmm0,%xmm2 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,26 // movzbl (%r10,%r11,1),%eax .byte 196,194,125,49,193 // vpmovzxbd %xmm9,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,5,62,55,0,0 // vbroadcastss 0x373e(%rip),%ymm8 # 5c94 <_sk_callback_hsw+0x2ba> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 196,226,125,49,201 // vpmovzxbd %xmm1,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 196,227,105,32,208,7 // vpinsrb $0x7,%eax,%xmm2,%xmm2 .byte 196,226,125,49,210 // vpmovzxbd %xmm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_table_r_hsw .globl _sk_table_r_hsw FUNCTION(_sk_table_r_hsw) _sk_table_r_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 196,66,125,88,192 // vpbroadcastd %xmm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,125,91,192 // vcvtps2dq %ymm0,%ymm8 .byte 196,65,53,118,201 // vpcmpeqd %ymm9,%ymm9,%ymm9 .byte 196,130,53,146,4,129 // vgatherdps %ymm9,(%r9,%ymm8,4),%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_table_g_hsw .globl _sk_table_g_hsw FUNCTION(_sk_table_g_hsw) _sk_table_g_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 196,66,125,88,192 // vpbroadcastd %xmm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,125,91,193 // vcvtps2dq %ymm1,%ymm8 .byte 196,65,53,118,201 // vpcmpeqd %ymm9,%ymm9,%ymm9 .byte 196,130,53,146,12,129 // vgatherdps %ymm9,(%r9,%ymm8,4),%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_table_b_hsw .globl _sk_table_b_hsw FUNCTION(_sk_table_b_hsw) _sk_table_b_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 196,66,125,88,192 // vpbroadcastd %xmm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 197,125,91,194 // vcvtps2dq %ymm2,%ymm8 .byte 196,65,53,118,201 // vpcmpeqd %ymm9,%ymm9,%ymm9 .byte 196,130,53,146,20,129 // vgatherdps %ymm9,(%r9,%ymm8,4),%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_table_a_hsw .globl _sk_table_a_hsw FUNCTION(_sk_table_a_hsw) _sk_table_a_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 196,66,125,88,192 // vpbroadcastd %xmm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,219 // vmulps %ymm3,%ymm8,%ymm3 .byte 197,125,91,195 // vcvtps2dq %ymm3,%ymm8 .byte 196,65,53,118,201 // vpcmpeqd %ymm9,%ymm9,%ymm9 .byte 196,130,53,146,28,129 // vgatherdps %ymm9,(%r9,%ymm8,4),%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_r_hsw .globl _sk_parametric_r_hsw FUNCTION(_sk_parametric_r_hsw) _sk_parametric_r_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,65,124,194,192,2 // vcmpleps %ymm8,%ymm0,%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 196,66,125,168,202 // vfmadd213ps %ymm10,%ymm0,%ymm9 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 196,66,125,168,211 // vfmadd213ps %ymm11,%ymm0,%ymm10 .byte 196,226,125,24,0 // vbroadcastss (%rax),%ymm0 .byte 196,65,124,91,218 // vcvtdq2ps %ymm10,%ymm11 .byte 196,98,125,24,37,24,54,0,0 // vbroadcastss 0x3618(%rip),%ymm12 # 5c98 <_sk_callback_hsw+0x2be> .byte 196,98,125,24,45,19,54,0,0 // vbroadcastss 0x3613(%rip),%ymm13 # 5c9c <_sk_callback_hsw+0x2c2> .byte 196,65,44,84,213 // vandps %ymm13,%ymm10,%ymm10 .byte 196,98,125,24,45,9,54,0,0 // vbroadcastss 0x3609(%rip),%ymm13 # 5ca0 <_sk_callback_hsw+0x2c6> .byte 196,65,44,86,213 // vorps %ymm13,%ymm10,%ymm10 .byte 196,98,125,24,45,255,53,0,0 // vbroadcastss 0x35ff(%rip),%ymm13 # 5ca4 <_sk_callback_hsw+0x2ca> .byte 196,66,37,184,236 // vfmadd231ps %ymm12,%ymm11,%ymm13 .byte 196,98,125,24,29,245,53,0,0 // vbroadcastss 0x35f5(%rip),%ymm11 # 5ca8 <_sk_callback_hsw+0x2ce> .byte 196,66,45,172,221 // vfnmadd213ps %ymm13,%ymm10,%ymm11 .byte 196,98,125,24,37,235,53,0,0 // vbroadcastss 0x35eb(%rip),%ymm12 # 5cac <_sk_callback_hsw+0x2d2> .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,98,125,24,37,225,53,0,0 // vbroadcastss 0x35e1(%rip),%ymm12 # 5cb0 <_sk_callback_hsw+0x2d6> .byte 196,65,28,94,210 // vdivps %ymm10,%ymm12,%ymm10 .byte 196,65,36,92,210 // vsubps %ymm10,%ymm11,%ymm10 .byte 196,193,124,89,194 // vmulps %ymm10,%ymm0,%ymm0 .byte 196,99,125,8,208,1 // vroundps $0x1,%ymm0,%ymm10 .byte 196,65,124,92,210 // vsubps %ymm10,%ymm0,%ymm10 .byte 196,98,125,24,29,194,53,0,0 // vbroadcastss 0x35c2(%rip),%ymm11 # 5cb4 <_sk_callback_hsw+0x2da> .byte 196,193,124,88,195 // vaddps %ymm11,%ymm0,%ymm0 .byte 196,98,125,24,29,184,53,0,0 // vbroadcastss 0x35b8(%rip),%ymm11 # 5cb8 <_sk_callback_hsw+0x2de> .byte 196,98,45,172,216 // vfnmadd213ps %ymm0,%ymm10,%ymm11 .byte 196,226,125,24,5,174,53,0,0 // vbroadcastss 0x35ae(%rip),%ymm0 # 5cbc <_sk_callback_hsw+0x2e2> .byte 196,193,124,92,194 // vsubps %ymm10,%ymm0,%ymm0 .byte 196,98,125,24,21,164,53,0,0 // vbroadcastss 0x35a4(%rip),%ymm10 # 5cc0 <_sk_callback_hsw+0x2e6> .byte 197,172,94,192 // vdivps %ymm0,%ymm10,%ymm0 .byte 197,164,88,192 // vaddps %ymm0,%ymm11,%ymm0 .byte 196,98,125,24,21,151,53,0,0 // vbroadcastss 0x3597(%rip),%ymm10 # 5cc4 <_sk_callback_hsw+0x2ea> .byte 196,193,124,89,194 // vmulps %ymm10,%ymm0,%ymm0 .byte 197,253,91,192 // vcvtps2dq %ymm0,%ymm0 .byte 196,98,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm10 .byte 196,193,124,88,194 // vaddps %ymm10,%ymm0,%ymm0 .byte 196,195,125,74,193,128 // vblendvps %ymm8,%ymm9,%ymm0,%ymm0 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,124,95,192 // vmaxps %ymm8,%ymm0,%ymm0 .byte 196,98,125,24,5,110,53,0,0 // vbroadcastss 0x356e(%rip),%ymm8 # 5cc8 <_sk_callback_hsw+0x2ee> .byte 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_g_hsw .globl _sk_parametric_g_hsw FUNCTION(_sk_parametric_g_hsw) _sk_parametric_g_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,65,116,194,192,2 // vcmpleps %ymm8,%ymm1,%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 196,66,117,168,202 // vfmadd213ps %ymm10,%ymm1,%ymm9 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 196,66,117,168,211 // vfmadd213ps %ymm11,%ymm1,%ymm10 .byte 196,226,125,24,8 // vbroadcastss (%rax),%ymm1 .byte 196,65,124,91,218 // vcvtdq2ps %ymm10,%ymm11 .byte 196,98,125,24,37,38,53,0,0 // vbroadcastss 0x3526(%rip),%ymm12 # 5ccc <_sk_callback_hsw+0x2f2> .byte 196,98,125,24,45,33,53,0,0 // vbroadcastss 0x3521(%rip),%ymm13 # 5cd0 <_sk_callback_hsw+0x2f6> .byte 196,65,44,84,213 // vandps %ymm13,%ymm10,%ymm10 .byte 196,98,125,24,45,23,53,0,0 // vbroadcastss 0x3517(%rip),%ymm13 # 5cd4 <_sk_callback_hsw+0x2fa> .byte 196,65,44,86,213 // vorps %ymm13,%ymm10,%ymm10 .byte 196,98,125,24,45,13,53,0,0 // vbroadcastss 0x350d(%rip),%ymm13 # 5cd8 <_sk_callback_hsw+0x2fe> .byte 196,66,37,184,236 // vfmadd231ps %ymm12,%ymm11,%ymm13 .byte 196,98,125,24,29,3,53,0,0 // vbroadcastss 0x3503(%rip),%ymm11 # 5cdc <_sk_callback_hsw+0x302> .byte 196,66,45,172,221 // vfnmadd213ps %ymm13,%ymm10,%ymm11 .byte 196,98,125,24,37,249,52,0,0 // vbroadcastss 0x34f9(%rip),%ymm12 # 5ce0 <_sk_callback_hsw+0x306> .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,98,125,24,37,239,52,0,0 // vbroadcastss 0x34ef(%rip),%ymm12 # 5ce4 <_sk_callback_hsw+0x30a> .byte 196,65,28,94,210 // vdivps %ymm10,%ymm12,%ymm10 .byte 196,65,36,92,210 // vsubps %ymm10,%ymm11,%ymm10 .byte 196,193,116,89,202 // vmulps %ymm10,%ymm1,%ymm1 .byte 196,99,125,8,209,1 // vroundps $0x1,%ymm1,%ymm10 .byte 196,65,116,92,210 // vsubps %ymm10,%ymm1,%ymm10 .byte 196,98,125,24,29,208,52,0,0 // vbroadcastss 0x34d0(%rip),%ymm11 # 5ce8 <_sk_callback_hsw+0x30e> .byte 196,193,116,88,203 // vaddps %ymm11,%ymm1,%ymm1 .byte 196,98,125,24,29,198,52,0,0 // vbroadcastss 0x34c6(%rip),%ymm11 # 5cec <_sk_callback_hsw+0x312> .byte 196,98,45,172,217 // vfnmadd213ps %ymm1,%ymm10,%ymm11 .byte 196,226,125,24,13,188,52,0,0 // vbroadcastss 0x34bc(%rip),%ymm1 # 5cf0 <_sk_callback_hsw+0x316> .byte 196,193,116,92,202 // vsubps %ymm10,%ymm1,%ymm1 .byte 196,98,125,24,21,178,52,0,0 // vbroadcastss 0x34b2(%rip),%ymm10 # 5cf4 <_sk_callback_hsw+0x31a> .byte 197,172,94,201 // vdivps %ymm1,%ymm10,%ymm1 .byte 197,164,88,201 // vaddps %ymm1,%ymm11,%ymm1 .byte 196,98,125,24,21,165,52,0,0 // vbroadcastss 0x34a5(%rip),%ymm10 # 5cf8 <_sk_callback_hsw+0x31e> .byte 196,193,116,89,202 // vmulps %ymm10,%ymm1,%ymm1 .byte 197,253,91,201 // vcvtps2dq %ymm1,%ymm1 .byte 196,98,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm10 .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 196,195,117,74,201,128 // vblendvps %ymm8,%ymm9,%ymm1,%ymm1 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,116,95,200 // vmaxps %ymm8,%ymm1,%ymm1 .byte 196,98,125,24,5,124,52,0,0 // vbroadcastss 0x347c(%rip),%ymm8 # 5cfc <_sk_callback_hsw+0x322> .byte 196,193,116,93,200 // vminps %ymm8,%ymm1,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_b_hsw .globl _sk_parametric_b_hsw FUNCTION(_sk_parametric_b_hsw) _sk_parametric_b_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,65,108,194,192,2 // vcmpleps %ymm8,%ymm2,%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 196,66,109,168,202 // vfmadd213ps %ymm10,%ymm2,%ymm9 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 196,66,109,168,211 // vfmadd213ps %ymm11,%ymm2,%ymm10 .byte 196,226,125,24,16 // vbroadcastss (%rax),%ymm2 .byte 196,65,124,91,218 // vcvtdq2ps %ymm10,%ymm11 .byte 196,98,125,24,37,52,52,0,0 // vbroadcastss 0x3434(%rip),%ymm12 # 5d00 <_sk_callback_hsw+0x326> .byte 196,98,125,24,45,47,52,0,0 // vbroadcastss 0x342f(%rip),%ymm13 # 5d04 <_sk_callback_hsw+0x32a> .byte 196,65,44,84,213 // vandps %ymm13,%ymm10,%ymm10 .byte 196,98,125,24,45,37,52,0,0 // vbroadcastss 0x3425(%rip),%ymm13 # 5d08 <_sk_callback_hsw+0x32e> .byte 196,65,44,86,213 // vorps %ymm13,%ymm10,%ymm10 .byte 196,98,125,24,45,27,52,0,0 // vbroadcastss 0x341b(%rip),%ymm13 # 5d0c <_sk_callback_hsw+0x332> .byte 196,66,37,184,236 // vfmadd231ps %ymm12,%ymm11,%ymm13 .byte 196,98,125,24,29,17,52,0,0 // vbroadcastss 0x3411(%rip),%ymm11 # 5d10 <_sk_callback_hsw+0x336> .byte 196,66,45,172,221 // vfnmadd213ps %ymm13,%ymm10,%ymm11 .byte 196,98,125,24,37,7,52,0,0 // vbroadcastss 0x3407(%rip),%ymm12 # 5d14 <_sk_callback_hsw+0x33a> .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,98,125,24,37,253,51,0,0 // vbroadcastss 0x33fd(%rip),%ymm12 # 5d18 <_sk_callback_hsw+0x33e> .byte 196,65,28,94,210 // vdivps %ymm10,%ymm12,%ymm10 .byte 196,65,36,92,210 // vsubps %ymm10,%ymm11,%ymm10 .byte 196,193,108,89,210 // vmulps %ymm10,%ymm2,%ymm2 .byte 196,99,125,8,210,1 // vroundps $0x1,%ymm2,%ymm10 .byte 196,65,108,92,210 // vsubps %ymm10,%ymm2,%ymm10 .byte 196,98,125,24,29,222,51,0,0 // vbroadcastss 0x33de(%rip),%ymm11 # 5d1c <_sk_callback_hsw+0x342> .byte 196,193,108,88,211 // vaddps %ymm11,%ymm2,%ymm2 .byte 196,98,125,24,29,212,51,0,0 // vbroadcastss 0x33d4(%rip),%ymm11 # 5d20 <_sk_callback_hsw+0x346> .byte 196,98,45,172,218 // vfnmadd213ps %ymm2,%ymm10,%ymm11 .byte 196,226,125,24,21,202,51,0,0 // vbroadcastss 0x33ca(%rip),%ymm2 # 5d24 <_sk_callback_hsw+0x34a> .byte 196,193,108,92,210 // vsubps %ymm10,%ymm2,%ymm2 .byte 196,98,125,24,21,192,51,0,0 // vbroadcastss 0x33c0(%rip),%ymm10 # 5d28 <_sk_callback_hsw+0x34e> .byte 197,172,94,210 // vdivps %ymm2,%ymm10,%ymm2 .byte 197,164,88,210 // vaddps %ymm2,%ymm11,%ymm2 .byte 196,98,125,24,21,179,51,0,0 // vbroadcastss 0x33b3(%rip),%ymm10 # 5d2c <_sk_callback_hsw+0x352> .byte 196,193,108,89,210 // vmulps %ymm10,%ymm2,%ymm2 .byte 197,253,91,210 // vcvtps2dq %ymm2,%ymm2 .byte 196,98,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm10 .byte 196,193,108,88,210 // vaddps %ymm10,%ymm2,%ymm2 .byte 196,195,109,74,209,128 // vblendvps %ymm8,%ymm9,%ymm2,%ymm2 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,108,95,208 // vmaxps %ymm8,%ymm2,%ymm2 .byte 196,98,125,24,5,138,51,0,0 // vbroadcastss 0x338a(%rip),%ymm8 # 5d30 <_sk_callback_hsw+0x356> .byte 196,193,108,93,208 // vminps %ymm8,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_a_hsw .globl _sk_parametric_a_hsw FUNCTION(_sk_parametric_a_hsw) _sk_parametric_a_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,65,100,194,192,2 // vcmpleps %ymm8,%ymm3,%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 196,66,101,168,202 // vfmadd213ps %ymm10,%ymm3,%ymm9 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 196,66,101,168,211 // vfmadd213ps %ymm11,%ymm3,%ymm10 .byte 196,226,125,24,24 // vbroadcastss (%rax),%ymm3 .byte 196,65,124,91,218 // vcvtdq2ps %ymm10,%ymm11 .byte 196,98,125,24,37,66,51,0,0 // vbroadcastss 0x3342(%rip),%ymm12 # 5d34 <_sk_callback_hsw+0x35a> .byte 196,98,125,24,45,61,51,0,0 // vbroadcastss 0x333d(%rip),%ymm13 # 5d38 <_sk_callback_hsw+0x35e> .byte 196,65,44,84,213 // vandps %ymm13,%ymm10,%ymm10 .byte 196,98,125,24,45,51,51,0,0 // vbroadcastss 0x3333(%rip),%ymm13 # 5d3c <_sk_callback_hsw+0x362> .byte 196,65,44,86,213 // vorps %ymm13,%ymm10,%ymm10 .byte 196,98,125,24,45,41,51,0,0 // vbroadcastss 0x3329(%rip),%ymm13 # 5d40 <_sk_callback_hsw+0x366> .byte 196,66,37,184,236 // vfmadd231ps %ymm12,%ymm11,%ymm13 .byte 196,98,125,24,29,31,51,0,0 // vbroadcastss 0x331f(%rip),%ymm11 # 5d44 <_sk_callback_hsw+0x36a> .byte 196,66,45,172,221 // vfnmadd213ps %ymm13,%ymm10,%ymm11 .byte 196,98,125,24,37,21,51,0,0 // vbroadcastss 0x3315(%rip),%ymm12 # 5d48 <_sk_callback_hsw+0x36e> .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,98,125,24,37,11,51,0,0 // vbroadcastss 0x330b(%rip),%ymm12 # 5d4c <_sk_callback_hsw+0x372> .byte 196,65,28,94,210 // vdivps %ymm10,%ymm12,%ymm10 .byte 196,65,36,92,210 // vsubps %ymm10,%ymm11,%ymm10 .byte 196,193,100,89,218 // vmulps %ymm10,%ymm3,%ymm3 .byte 196,99,125,8,211,1 // vroundps $0x1,%ymm3,%ymm10 .byte 196,65,100,92,210 // vsubps %ymm10,%ymm3,%ymm10 .byte 196,98,125,24,29,236,50,0,0 // vbroadcastss 0x32ec(%rip),%ymm11 # 5d50 <_sk_callback_hsw+0x376> .byte 196,193,100,88,219 // vaddps %ymm11,%ymm3,%ymm3 .byte 196,98,125,24,29,226,50,0,0 // vbroadcastss 0x32e2(%rip),%ymm11 # 5d54 <_sk_callback_hsw+0x37a> .byte 196,98,45,172,219 // vfnmadd213ps %ymm3,%ymm10,%ymm11 .byte 196,226,125,24,29,216,50,0,0 // vbroadcastss 0x32d8(%rip),%ymm3 # 5d58 <_sk_callback_hsw+0x37e> .byte 196,193,100,92,218 // vsubps %ymm10,%ymm3,%ymm3 .byte 196,98,125,24,21,206,50,0,0 // vbroadcastss 0x32ce(%rip),%ymm10 # 5d5c <_sk_callback_hsw+0x382> .byte 197,172,94,219 // vdivps %ymm3,%ymm10,%ymm3 .byte 197,164,88,219 // vaddps %ymm3,%ymm11,%ymm3 .byte 196,98,125,24,21,193,50,0,0 // vbroadcastss 0x32c1(%rip),%ymm10 # 5d60 <_sk_callback_hsw+0x386> .byte 196,193,100,89,218 // vmulps %ymm10,%ymm3,%ymm3 .byte 197,253,91,219 // vcvtps2dq %ymm3,%ymm3 .byte 196,98,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm10 .byte 196,193,100,88,218 // vaddps %ymm10,%ymm3,%ymm3 .byte 196,195,101,74,217,128 // vblendvps %ymm8,%ymm9,%ymm3,%ymm3 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,100,95,216 // vmaxps %ymm8,%ymm3,%ymm3 .byte 196,98,125,24,5,152,50,0,0 // vbroadcastss 0x3298(%rip),%ymm8 # 5d64 <_sk_callback_hsw+0x38a> .byte 196,193,100,93,216 // vminps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_gamma_hsw .globl _sk_gamma_hsw FUNCTION(_sk_gamma_hsw) _sk_gamma_hsw: .byte 72,131,236,56 // sub $0x38,%rsp .byte 197,252,17,60,36 // vmovups %ymm7,(%rsp) .byte 197,252,17,116,36,224 // vmovups %ymm6,-0x20(%rsp) .byte 197,252,17,108,36,192 // vmovups %ymm5,-0x40(%rsp) .byte 197,252,17,100,36,160 // vmovups %ymm4,-0x60(%rsp) .byte 197,252,17,92,36,128 // vmovups %ymm3,-0x80(%rsp) .byte 197,252,40,250 // vmovaps %ymm2,%ymm7 .byte 197,252,40,241 // vmovaps %ymm1,%ymm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,91,208 // vcvtdq2ps %ymm0,%ymm10 .byte 196,98,125,24,29,91,50,0,0 // vbroadcastss 0x325b(%rip),%ymm11 # 5d68 <_sk_callback_hsw+0x38e> .byte 196,226,125,24,45,86,50,0,0 // vbroadcastss 0x3256(%rip),%ymm5 # 5d6c <_sk_callback_hsw+0x392> .byte 197,124,84,205 // vandps %ymm5,%ymm0,%ymm9 .byte 196,226,125,24,37,77,50,0,0 // vbroadcastss 0x324d(%rip),%ymm4 # 5d70 <_sk_callback_hsw+0x396> .byte 197,52,86,228 // vorps %ymm4,%ymm9,%ymm12 .byte 196,98,125,24,45,68,50,0,0 // vbroadcastss 0x3244(%rip),%ymm13 # 5d74 <_sk_callback_hsw+0x39a> .byte 196,66,37,168,213 // vfmadd213ps %ymm13,%ymm11,%ymm10 .byte 196,98,125,24,13,58,50,0,0 // vbroadcastss 0x323a(%rip),%ymm9 # 5d78 <_sk_callback_hsw+0x39e> .byte 196,66,29,188,209 // vfnmadd231ps %ymm9,%ymm12,%ymm10 .byte 197,124,91,246 // vcvtdq2ps %ymm6,%ymm14 .byte 196,66,37,168,245 // vfmadd213ps %ymm13,%ymm11,%ymm14 .byte 197,124,91,255 // vcvtdq2ps %ymm7,%ymm15 .byte 196,66,37,168,253 // vfmadd213ps %ymm13,%ymm11,%ymm15 .byte 196,98,125,24,29,30,50,0,0 // vbroadcastss 0x321e(%rip),%ymm11 # 5d7c <_sk_callback_hsw+0x3a2> .byte 196,65,28,88,227 // vaddps %ymm11,%ymm12,%ymm12 .byte 196,98,125,24,45,20,50,0,0 // vbroadcastss 0x3214(%rip),%ymm13 # 5d80 <_sk_callback_hsw+0x3a6> .byte 196,65,20,94,228 // vdivps %ymm12,%ymm13,%ymm12 .byte 196,65,44,92,212 // vsubps %ymm12,%ymm10,%ymm10 .byte 196,98,125,24,32 // vbroadcastss (%rax),%ymm12 .byte 196,65,44,89,212 // vmulps %ymm12,%ymm10,%ymm10 .byte 196,67,125,8,194,1 // vroundps $0x1,%ymm10,%ymm8 .byte 196,65,44,92,192 // vsubps %ymm8,%ymm10,%ymm8 .byte 196,226,125,24,21,240,49,0,0 // vbroadcastss 0x31f0(%rip),%ymm2 # 5d84 <_sk_callback_hsw+0x3aa> .byte 197,44,88,210 // vaddps %ymm2,%ymm10,%ymm10 .byte 196,226,125,24,29,231,49,0,0 // vbroadcastss 0x31e7(%rip),%ymm3 # 5d88 <_sk_callback_hsw+0x3ae> .byte 196,98,61,188,211 // vfnmadd231ps %ymm3,%ymm8,%ymm10 .byte 196,226,125,24,13,221,49,0,0 // vbroadcastss 0x31dd(%rip),%ymm1 # 5d8c <_sk_callback_hsw+0x3b2> .byte 196,65,116,92,192 // vsubps %ymm8,%ymm1,%ymm8 .byte 196,226,125,24,5,211,49,0,0 // vbroadcastss 0x31d3(%rip),%ymm0 # 5d90 <_sk_callback_hsw+0x3b6> .byte 196,65,124,94,192 // vdivps %ymm8,%ymm0,%ymm8 .byte 196,65,44,88,192 // vaddps %ymm8,%ymm10,%ymm8 .byte 197,204,84,245 // vandps %ymm5,%ymm6,%ymm6 .byte 197,204,86,244 // vorps %ymm4,%ymm6,%ymm6 .byte 196,66,77,188,241 // vfnmadd231ps %ymm9,%ymm6,%ymm14 .byte 196,193,76,88,243 // vaddps %ymm11,%ymm6,%ymm6 .byte 197,148,94,246 // vdivps %ymm6,%ymm13,%ymm6 .byte 197,140,92,246 // vsubps %ymm6,%ymm14,%ymm6 .byte 196,193,76,89,244 // vmulps %ymm12,%ymm6,%ymm6 .byte 196,99,125,8,214,1 // vroundps $0x1,%ymm6,%ymm10 .byte 196,65,76,92,210 // vsubps %ymm10,%ymm6,%ymm10 .byte 197,204,88,242 // vaddps %ymm2,%ymm6,%ymm6 .byte 196,226,45,188,243 // vfnmadd231ps %ymm3,%ymm10,%ymm6 .byte 196,65,116,92,210 // vsubps %ymm10,%ymm1,%ymm10 .byte 196,65,124,94,210 // vdivps %ymm10,%ymm0,%ymm10 .byte 196,193,76,88,242 // vaddps %ymm10,%ymm6,%ymm6 .byte 197,196,84,237 // vandps %ymm5,%ymm7,%ymm5 .byte 197,212,86,228 // vorps %ymm4,%ymm5,%ymm4 .byte 196,66,93,188,249 // vfnmadd231ps %ymm9,%ymm4,%ymm15 .byte 196,193,92,88,227 // vaddps %ymm11,%ymm4,%ymm4 .byte 197,148,94,228 // vdivps %ymm4,%ymm13,%ymm4 .byte 197,132,92,228 // vsubps %ymm4,%ymm15,%ymm4 .byte 196,193,92,89,228 // vmulps %ymm12,%ymm4,%ymm4 .byte 196,227,125,8,236,1 // vroundps $0x1,%ymm4,%ymm5 .byte 197,220,92,237 // vsubps %ymm5,%ymm4,%ymm5 .byte 197,220,88,210 // vaddps %ymm2,%ymm4,%ymm2 .byte 196,226,85,188,211 // vfnmadd231ps %ymm3,%ymm5,%ymm2 .byte 197,244,92,205 // vsubps %ymm5,%ymm1,%ymm1 .byte 197,252,94,193 // vdivps %ymm1,%ymm0,%ymm0 .byte 197,236,88,192 // vaddps %ymm0,%ymm2,%ymm0 .byte 196,226,125,24,13,68,49,0,0 // vbroadcastss 0x3144(%rip),%ymm1 # 5d94 <_sk_callback_hsw+0x3ba> .byte 197,188,89,209 // vmulps %ymm1,%ymm8,%ymm2 .byte 197,204,89,217 // vmulps %ymm1,%ymm6,%ymm3 .byte 197,252,89,225 // vmulps %ymm1,%ymm0,%ymm4 .byte 197,253,91,194 // vcvtps2dq %ymm2,%ymm0 .byte 197,253,91,203 // vcvtps2dq %ymm3,%ymm1 .byte 197,253,91,212 // vcvtps2dq %ymm4,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,92,36,128 // vmovups -0x80(%rsp),%ymm3 .byte 197,252,16,100,36,160 // vmovups -0x60(%rsp),%ymm4 .byte 197,252,16,108,36,192 // vmovups -0x40(%rsp),%ymm5 .byte 197,252,16,116,36,224 // vmovups -0x20(%rsp),%ymm6 .byte 197,252,16,60,36 // vmovups (%rsp),%ymm7 .byte 72,131,196,56 // add $0x38,%rsp .byte 255,224 // jmpq *%rax HIDDEN _sk_lab_to_xyz_hsw .globl _sk_lab_to_xyz_hsw FUNCTION(_sk_lab_to_xyz_hsw) _sk_lab_to_xyz_hsw: .byte 196,98,125,24,5,2,49,0,0 // vbroadcastss 0x3102(%rip),%ymm8 # 5d98 <_sk_callback_hsw+0x3be> .byte 196,98,125,24,13,253,48,0,0 // vbroadcastss 0x30fd(%rip),%ymm9 # 5d9c <_sk_callback_hsw+0x3c2> .byte 196,98,125,24,21,248,48,0,0 // vbroadcastss 0x30f8(%rip),%ymm10 # 5da0 <_sk_callback_hsw+0x3c6> .byte 196,194,53,168,202 // vfmadd213ps %ymm10,%ymm9,%ymm1 .byte 196,194,53,168,210 // vfmadd213ps %ymm10,%ymm9,%ymm2 .byte 196,98,125,24,13,233,48,0,0 // vbroadcastss 0x30e9(%rip),%ymm9 # 5da4 <_sk_callback_hsw+0x3ca> .byte 196,66,125,184,200 // vfmadd231ps %ymm8,%ymm0,%ymm9 .byte 196,226,125,24,5,223,48,0,0 // vbroadcastss 0x30df(%rip),%ymm0 # 5da8 <_sk_callback_hsw+0x3ce> .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 196,98,125,24,5,214,48,0,0 // vbroadcastss 0x30d6(%rip),%ymm8 # 5dac <_sk_callback_hsw+0x3d2> .byte 196,98,117,168,192 // vfmadd213ps %ymm0,%ymm1,%ymm8 .byte 196,98,125,24,13,204,48,0,0 // vbroadcastss 0x30cc(%rip),%ymm9 # 5db0 <_sk_callback_hsw+0x3d6> .byte 196,98,109,172,200 // vfnmadd213ps %ymm0,%ymm2,%ymm9 .byte 196,193,60,89,200 // vmulps %ymm8,%ymm8,%ymm1 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 196,226,125,24,21,185,48,0,0 // vbroadcastss 0x30b9(%rip),%ymm2 # 5db4 <_sk_callback_hsw+0x3da> .byte 197,108,194,209,1 // vcmpltps %ymm1,%ymm2,%ymm10 .byte 196,98,125,24,29,175,48,0,0 // vbroadcastss 0x30af(%rip),%ymm11 # 5db8 <_sk_callback_hsw+0x3de> .byte 196,65,60,88,195 // vaddps %ymm11,%ymm8,%ymm8 .byte 196,98,125,24,37,165,48,0,0 // vbroadcastss 0x30a5(%rip),%ymm12 # 5dbc <_sk_callback_hsw+0x3e2> .byte 196,65,60,89,196 // vmulps %ymm12,%ymm8,%ymm8 .byte 196,99,61,74,193,160 // vblendvps %ymm10,%ymm1,%ymm8,%ymm8 .byte 197,252,89,200 // vmulps %ymm0,%ymm0,%ymm1 .byte 197,252,89,201 // vmulps %ymm1,%ymm0,%ymm1 .byte 197,108,194,209,1 // vcmpltps %ymm1,%ymm2,%ymm10 .byte 196,193,124,88,195 // vaddps %ymm11,%ymm0,%ymm0 .byte 196,193,124,89,196 // vmulps %ymm12,%ymm0,%ymm0 .byte 196,227,125,74,201,160 // vblendvps %ymm10,%ymm1,%ymm0,%ymm1 .byte 196,193,52,89,193 // vmulps %ymm9,%ymm9,%ymm0 .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 197,236,194,208,1 // vcmpltps %ymm0,%ymm2,%ymm2 .byte 196,65,52,88,203 // vaddps %ymm11,%ymm9,%ymm9 .byte 196,65,52,89,204 // vmulps %ymm12,%ymm9,%ymm9 .byte 196,227,53,74,208,32 // vblendvps %ymm2,%ymm0,%ymm9,%ymm2 .byte 196,226,125,24,5,90,48,0,0 // vbroadcastss 0x305a(%rip),%ymm0 # 5dc0 <_sk_callback_hsw+0x3e6> .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 196,98,125,24,5,81,48,0,0 // vbroadcastss 0x3051(%rip),%ymm8 # 5dc4 <_sk_callback_hsw+0x3ea> .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_load_a8_hsw .globl _sk_load_a8_hsw FUNCTION(_sk_load_a8_hsw) _sk_load_a8_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,53 // jne 2dca <_sk_load_a8_hsw+0x4e> .byte 196,194,121,48,4,25 // vpmovzxbw (%r9,%rbx,1),%xmm0 .byte 197,249,219,5,157,53,0,0 // vpand 0x359d(%rip),%xmm0,%xmm0 # 6340 <_sk_callback_hsw+0x966> .byte 196,226,125,51,192 // vpmovzxwd %xmm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,19,48,0,0 // vbroadcastss 0x3013(%rip),%ymm1 # 5dc8 <_sk_callback_hsw+0x3ee> .byte 197,252,89,217 // vmulps %ymm1,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,236,87,210 // vxorps %ymm2,%ymm2,%ymm2 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,189 // ja 2d9b <_sk_load_a8_hsw+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,119,0,0,0 // lea 0x77(%rip),%r11 # 2e60 <_sk_load_a8_hsw+0xe4> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 235,158 // jmp 2d9b <_sk_load_a8_hsw+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,2 // vpinsrw $0x2,%eax,%xmm0,%xmm0 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,249,110,200 // vmovd %eax,%xmm1 .byte 196,226,121,48,201 // vpmovzxbw %xmm1,%xmm1 .byte 196,227,121,2,193,1 // vpblendd $0x1,%xmm1,%xmm0,%xmm0 .byte 233,118,255,255,255 // jmpq 2d9b <_sk_load_a8_hsw+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,249,196,192,5 // vpinsrw $0x5,%eax,%xmm0,%xmm0 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,249,196,192,4 // vpinsrw $0x4,%eax,%xmm0,%xmm0 .byte 196,193,121,110,12,25 // vmovd (%r9,%rbx,1),%xmm1 .byte 196,226,121,48,201 // vpmovzxbw %xmm1,%xmm1 .byte 196,227,113,2,192,12 // vpblendd $0xc,%xmm0,%xmm1,%xmm0 .byte 233,59,255,255,255 // jmpq 2d9b <_sk_load_a8_hsw+0x1f> .byte 146 // xchg %eax,%edx .byte 255 // (bad) .byte 255 // (bad) .byte 255,172,255,255,255,157,255 // ljmp *-0x620001(%rdi,%rdi,8) .byte 255 // (bad) .byte 255 // (bad) .byte 234 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 223,255 // (bad) .byte 255 // (bad) .byte 255,212 // callq *%rsp .byte 255 // (bad) .byte 255 // (bad) .byte 255,197 // inc %ebp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_a8_dst_hsw .globl _sk_load_a8_dst_hsw FUNCTION(_sk_load_a8_dst_hsw) _sk_load_a8_dst_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,53 // jne 2eca <_sk_load_a8_dst_hsw+0x4e> .byte 196,194,121,48,36,25 // vpmovzxbw (%r9,%rbx,1),%xmm4 .byte 197,217,219,37,173,52,0,0 // vpand 0x34ad(%rip),%xmm4,%xmm4 # 6350 <_sk_callback_hsw+0x976> .byte 196,226,125,51,228 // vpmovzxwd %xmm4,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,226,125,24,45,23,47,0,0 // vbroadcastss 0x2f17(%rip),%ymm5 # 5dcc <_sk_callback_hsw+0x3f2> .byte 197,220,89,253 // vmulps %ymm5,%ymm4,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,220,87,228 // vxorps %ymm4,%ymm4,%ymm4 .byte 197,212,87,237 // vxorps %ymm5,%ymm5,%ymm5 .byte 197,204,87,246 // vxorps %ymm6,%ymm6,%ymm6 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,189 // ja 2e9b <_sk_load_a8_dst_hsw+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,119,0,0,0 // lea 0x77(%rip),%r11 # 2f60 <_sk_load_a8_dst_hsw+0xe4> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,249,110,224 // vmovd %eax,%xmm4 .byte 235,158 // jmp 2e9b <_sk_load_a8_dst_hsw+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,217,196,224,2 // vpinsrw $0x2,%eax,%xmm4,%xmm4 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,249,110,232 // vmovd %eax,%xmm5 .byte 196,226,121,48,237 // vpmovzxbw %xmm5,%xmm5 .byte 196,227,89,2,229,1 // vpblendd $0x1,%xmm5,%xmm4,%xmm4 .byte 233,118,255,255,255 // jmpq 2e9b <_sk_load_a8_dst_hsw+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,217,196,224,6 // vpinsrw $0x6,%eax,%xmm4,%xmm4 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,217,196,224,5 // vpinsrw $0x5,%eax,%xmm4,%xmm4 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,217,196,224,4 // vpinsrw $0x4,%eax,%xmm4,%xmm4 .byte 196,193,121,110,44,25 // vmovd (%r9,%rbx,1),%xmm5 .byte 196,226,121,48,237 // vpmovzxbw %xmm5,%xmm5 .byte 196,227,81,2,228,12 // vpblendd $0xc,%xmm4,%xmm5,%xmm4 .byte 233,59,255,255,255 // jmpq 2e9b <_sk_load_a8_dst_hsw+0x1f> .byte 146 // xchg %eax,%edx .byte 255 // (bad) .byte 255 // (bad) .byte 255,172,255,255,255,157,255 // ljmp *-0x620001(%rdi,%rdi,8) .byte 255 // (bad) .byte 255 // (bad) .byte 234 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 223,255 // (bad) .byte 255 // (bad) .byte 255,212 // callq *%rsp .byte 255 // (bad) .byte 255 // (bad) .byte 255,197 // inc %ebp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_gather_a8_hsw .globl _sk_gather_a8_hsw FUNCTION(_sk_gather_a8_hsw) _sk_gather_a8_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 196,226,125,88,80,8 // vpbroadcastd 0x8(%rax),%ymm2 .byte 196,226,109,64,201 // vpmulld %ymm1,%ymm2,%ymm1 .byte 197,254,91,192 // vcvttps2dq %ymm0,%ymm0 .byte 197,245,254,192 // vpaddd %ymm0,%ymm1,%ymm0 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,195,121,32,12,1,0 // vpinsrb $0x0,(%r9,%rax,1),%xmm0,%xmm1 .byte 196,227,249,22,192,1 // vpextrq $0x1,%xmm0,%rax .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,113,32,12,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm1,%xmm1 .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,113,32,202,2 // vpinsrb $0x2,%r10d,%xmm1,%xmm1 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,113,32,200,3 // vpinsrb $0x3,%eax,%xmm1,%xmm1 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,113,32,200,4 // vpinsrb $0x4,%eax,%xmm1,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,182,4,17 // movzbl (%r9,%r10,1),%eax .byte 196,227,113,32,192,5 // vpinsrb $0x5,%eax,%xmm1,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,121,32,192,6 // vpinsrb $0x6,%eax,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 196,227,121,32,192,7 // vpinsrb $0x7,%eax,%xmm0,%xmm0 .byte 196,226,125,49,192 // vpmovzxbd %xmm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,158,45,0,0 // vbroadcastss 0x2d9e(%rip),%ymm1 # 5dd0 <_sk_callback_hsw+0x3f6> .byte 197,252,89,217 // vmulps %ymm1,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,237,239,210 // vpxor %ymm2,%ymm2,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_store_a8_hsw .globl _sk_store_a8_hsw FUNCTION(_sk_store_a8_hsw) _sk_store_a8_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 196,98,125,24,5,113,45,0,0 // vbroadcastss 0x2d71(%rip),%ymm8 # 5dd4 <_sk_callback_hsw+0x3fa> .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,67,125,25,193,1 // vextractf128 $0x1,%ymm8,%xmm9 .byte 196,66,57,43,193 // vpackusdw %xmm9,%xmm8,%xmm8 .byte 196,65,57,103,192 // vpackuswb %xmm8,%xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 308d <_sk_store_a8_hsw+0x47> .byte 196,65,123,17,4,25 // vmovsd %xmm8,(%r9,%rbx,1) .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,235 // ja 3088 <_sk_store_a8_hsw+0x42> .byte 196,66,121,48,192 // vpmovzxbw %xmm8,%xmm8 .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,87,0,0,0 // lea 0x57(%rip),%r11 # 3104 <_sk_store_a8_hsw+0xbe> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,67,121,20,4,25,0 // vpextrb $0x0,%xmm8,(%r9,%rbx,1) .byte 235,201 // jmp 3088 <_sk_store_a8_hsw+0x42> .byte 196,67,121,20,68,25,2,4 // vpextrb $0x4,%xmm8,0x2(%r9,%rbx,1) .byte 196,98,57,0,5,144,50,0,0 // vpshufb 0x3290(%rip),%xmm8,%xmm8 # 6360 <_sk_callback_hsw+0x986> .byte 196,67,121,21,4,25,0 // vpextrw $0x0,%xmm8,(%r9,%rbx,1) .byte 235,175 // jmp 3088 <_sk_store_a8_hsw+0x42> .byte 196,67,121,20,68,25,6,12 // vpextrb $0xc,%xmm8,0x6(%r9,%rbx,1) .byte 196,67,121,20,68,25,5,10 // vpextrb $0xa,%xmm8,0x5(%r9,%rbx,1) .byte 196,67,121,20,68,25,4,8 // vpextrb $0x8,%xmm8,0x4(%r9,%rbx,1) .byte 196,98,57,0,5,118,50,0,0 // vpshufb 0x3276(%rip),%xmm8,%xmm8 # 6370 <_sk_callback_hsw+0x996> .byte 196,65,121,126,4,25 // vmovd %xmm8,(%r9,%rbx,1) .byte 235,134 // jmp 3088 <_sk_store_a8_hsw+0x42> .byte 102,144 // xchg %ax,%ax .byte 178,255 // mov $0xff,%dl .byte 255 // (bad) .byte 255,195 // inc %ebx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 187,255,255,255,237 // mov $0xedffffff,%ebx .byte 255 // (bad) .byte 255 // (bad) .byte 255,229 // jmpq *%rbp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 221,255 // (bad) .byte 255 // (bad) .byte 255,213 // callq *%rbp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_g8_hsw .globl _sk_load_g8_hsw FUNCTION(_sk_load_g8_hsw) _sk_load_g8_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,58 // jne 3173 <_sk_load_g8_hsw+0x53> .byte 196,194,121,48,4,25 // vpmovzxbw (%r9,%rbx,1),%xmm0 .byte 197,249,219,5,57,50,0,0 // vpand 0x3239(%rip),%xmm0,%xmm0 # 6380 <_sk_callback_hsw+0x9a6> .byte 196,226,125,51,192 // vpmovzxwd %xmm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,127,44,0,0 // vbroadcastss 0x2c7f(%rip),%ymm1 # 5dd8 <_sk_callback_hsw+0x3fe> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,116,44,0,0 // vbroadcastss 0x2c74(%rip),%ymm3 # 5ddc <_sk_callback_hsw+0x402> .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,184 // ja 313f <_sk_load_g8_hsw+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,122,0,0,0 // lea 0x7a(%rip),%r11 # 320c <_sk_load_g8_hsw+0xec> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 235,153 // jmp 313f <_sk_load_g8_hsw+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,2 // vpinsrw $0x2,%eax,%xmm0,%xmm0 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,249,110,200 // vmovd %eax,%xmm1 .byte 196,226,121,48,201 // vpmovzxbw %xmm1,%xmm1 .byte 196,227,121,2,193,1 // vpblendd $0x1,%xmm1,%xmm0,%xmm0 .byte 233,113,255,255,255 // jmpq 313f <_sk_load_g8_hsw+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,249,196,192,5 // vpinsrw $0x5,%eax,%xmm0,%xmm0 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,249,196,192,4 // vpinsrw $0x4,%eax,%xmm0,%xmm0 .byte 196,193,121,110,12,25 // vmovd (%r9,%rbx,1),%xmm1 .byte 196,226,121,48,201 // vpmovzxbw %xmm1,%xmm1 .byte 196,227,113,2,192,12 // vpblendd $0xc,%xmm0,%xmm1,%xmm0 .byte 233,54,255,255,255 // jmpq 313f <_sk_load_g8_hsw+0x1f> .byte 15,31,0 // nopl (%rax) .byte 143 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,169,255,255,255,154 // ljmp *-0x65000001(%rcx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,231 // jmpq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 220,255 // fdivr %st,%st(7) .byte 255 // (bad) .byte 255,209 // callq *%rcx .byte 255 // (bad) .byte 255 // (bad) .byte 255,194 // inc %edx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_g8_dst_hsw .globl _sk_load_g8_dst_hsw FUNCTION(_sk_load_g8_dst_hsw) _sk_load_g8_dst_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,58 // jne 327b <_sk_load_g8_dst_hsw+0x53> .byte 196,194,121,48,36,25 // vpmovzxbw (%r9,%rbx,1),%xmm4 .byte 197,217,219,37,65,49,0,0 // vpand 0x3141(%rip),%xmm4,%xmm4 # 6390 <_sk_callback_hsw+0x9b6> .byte 196,226,125,51,228 // vpmovzxwd %xmm4,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,226,125,24,45,127,43,0,0 // vbroadcastss 0x2b7f(%rip),%ymm5 # 5de0 <_sk_callback_hsw+0x406> .byte 197,220,89,229 // vmulps %ymm5,%ymm4,%ymm4 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,61,116,43,0,0 // vbroadcastss 0x2b74(%rip),%ymm7 # 5de4 <_sk_callback_hsw+0x40a> .byte 197,252,40,236 // vmovaps %ymm4,%ymm5 .byte 197,252,40,244 // vmovaps %ymm4,%ymm6 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,184 // ja 3247 <_sk_load_g8_dst_hsw+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,122,0,0,0 // lea 0x7a(%rip),%r11 # 3314 <_sk_load_g8_dst_hsw+0xec> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,249,110,224 // vmovd %eax,%xmm4 .byte 235,153 // jmp 3247 <_sk_load_g8_dst_hsw+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,217,196,224,2 // vpinsrw $0x2,%eax,%xmm4,%xmm4 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,249,110,232 // vmovd %eax,%xmm5 .byte 196,226,121,48,237 // vpmovzxbw %xmm5,%xmm5 .byte 196,227,89,2,229,1 // vpblendd $0x1,%xmm5,%xmm4,%xmm4 .byte 233,113,255,255,255 // jmpq 3247 <_sk_load_g8_dst_hsw+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,217,196,224,6 // vpinsrw $0x6,%eax,%xmm4,%xmm4 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,217,196,224,5 // vpinsrw $0x5,%eax,%xmm4,%xmm4 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,217,196,224,4 // vpinsrw $0x4,%eax,%xmm4,%xmm4 .byte 196,193,121,110,44,25 // vmovd (%r9,%rbx,1),%xmm5 .byte 196,226,121,48,237 // vpmovzxbw %xmm5,%xmm5 .byte 196,227,81,2,228,12 // vpblendd $0xc,%xmm4,%xmm5,%xmm4 .byte 233,54,255,255,255 // jmpq 3247 <_sk_load_g8_dst_hsw+0x1f> .byte 15,31,0 // nopl (%rax) .byte 143 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,169,255,255,255,154 // ljmp *-0x65000001(%rcx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,231 // jmpq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 220,255 // fdivr %st,%st(7) .byte 255 // (bad) .byte 255,209 // callq *%rcx .byte 255 // (bad) .byte 255 // (bad) .byte 255,194 // inc %edx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_gather_g8_hsw .globl _sk_gather_g8_hsw FUNCTION(_sk_gather_g8_hsw) _sk_gather_g8_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 196,226,125,88,80,8 // vpbroadcastd 0x8(%rax),%ymm2 .byte 196,226,109,64,201 // vpmulld %ymm1,%ymm2,%ymm1 .byte 197,254,91,192 // vcvttps2dq %ymm0,%ymm0 .byte 197,245,254,192 // vpaddd %ymm0,%ymm1,%ymm0 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,195,121,32,12,1,0 // vpinsrb $0x0,(%r9,%rax,1),%xmm0,%xmm1 .byte 196,227,249,22,192,1 // vpextrq $0x1,%xmm0,%rax .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,113,32,12,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm1,%xmm1 .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,113,32,202,2 // vpinsrb $0x2,%r10d,%xmm1,%xmm1 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,113,32,200,3 // vpinsrb $0x3,%eax,%xmm1,%xmm1 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,113,32,200,4 // vpinsrb $0x4,%eax,%xmm1,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,182,4,17 // movzbl (%r9,%r10,1),%eax .byte 196,227,113,32,192,5 // vpinsrb $0x5,%eax,%xmm1,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,121,32,192,6 // vpinsrb $0x6,%eax,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 196,227,121,32,192,7 // vpinsrb $0x7,%eax,%xmm0,%xmm0 .byte 196,226,125,49,192 // vpmovzxbd %xmm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,2,42,0,0 // vbroadcastss 0x2a02(%rip),%ymm1 # 5de8 <_sk_callback_hsw+0x40e> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,247,41,0,0 // vbroadcastss 0x29f7(%rip),%ymm3 # 5dec <_sk_callback_hsw+0x412> .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_load_565_hsw .globl _sk_load_565_hsw FUNCTION(_sk_load_565_hsw) _sk_load_565_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,115 // jne 348e <_sk_load_565_hsw+0x8f> .byte 196,193,122,111,4,89 // vmovdqu (%r9,%rbx,2),%xmm0 .byte 196,226,125,51,208 // vpmovzxwd %xmm0,%ymm2 .byte 196,226,125,88,5,193,41,0,0 // vpbroadcastd 0x29c1(%rip),%ymm0 # 5df0 <_sk_callback_hsw+0x416> .byte 197,237,219,192 // vpand %ymm0,%ymm2,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,180,41,0,0 // vbroadcastss 0x29b4(%rip),%ymm1 # 5df4 <_sk_callback_hsw+0x41a> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 196,226,125,88,13,171,41,0,0 // vpbroadcastd 0x29ab(%rip),%ymm1 # 5df8 <_sk_callback_hsw+0x41e> .byte 197,237,219,201 // vpand %ymm1,%ymm2,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,226,125,24,29,158,41,0,0 // vbroadcastss 0x299e(%rip),%ymm3 # 5dfc <_sk_callback_hsw+0x422> .byte 197,244,89,203 // vmulps %ymm3,%ymm1,%ymm1 .byte 196,226,125,88,29,149,41,0,0 // vpbroadcastd 0x2995(%rip),%ymm3 # 5e00 <_sk_callback_hsw+0x426> .byte 197,237,219,211 // vpand %ymm3,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,226,125,24,29,136,41,0,0 // vbroadcastss 0x2988(%rip),%ymm3 # 5e04 <_sk_callback_hsw+0x42a> .byte 197,236,89,211 // vmulps %ymm3,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,125,41,0,0 // vbroadcastss 0x297d(%rip),%ymm3 # 5e08 <_sk_callback_hsw+0x42e> .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,123,255,255,255 // ja 3421 <_sk_load_565_hsw+0x22> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,99,0,0,0 // lea 0x63(%rip),%r11 # 3514 <_sk_load_565_hsw+0x115> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 233,89,255,255,255 // jmpq 3421 <_sk_load_565_hsw+0x22> .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 196,193,121,196,68,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,110,12,89 // vmovd (%r9,%rbx,2),%xmm1 .byte 196,227,121,2,193,1 // vpblendd $0x1,%xmm1,%xmm0,%xmm0 .byte 233,60,255,255,255 // jmpq 3421 <_sk_load_565_hsw+0x22> .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 196,193,121,196,68,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,196,68,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,196,68,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,122,126,12,89 // vmovq (%r9,%rbx,2),%xmm1 .byte 196,227,113,2,192,12 // vpblendd $0xc,%xmm0,%xmm1,%xmm0 .byte 233,15,255,255,255 // jmpq 3421 <_sk_load_565_hsw+0x22> .byte 102,144 // xchg %ax,%ax .byte 166 // cmpsb %es:(%rdi),%ds:(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,192 // inc %eax .byte 255 // (bad) .byte 255 // (bad) .byte 255,180,255,255,255,237,255 // pushq -0x120001(%rdi,%rdi,8) .byte 255 // (bad) .byte 255,229 // jmpq *%rbp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 221,255 // (bad) .byte 255 // (bad) .byte 255,209 // callq *%rcx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_565_dst_hsw .globl _sk_load_565_dst_hsw FUNCTION(_sk_load_565_dst_hsw) _sk_load_565_dst_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,115 // jne 35bf <_sk_load_565_dst_hsw+0x8f> .byte 196,193,122,111,36,89 // vmovdqu (%r9,%rbx,2),%xmm4 .byte 196,226,125,51,244 // vpmovzxwd %xmm4,%ymm6 .byte 196,226,125,88,37,172,40,0,0 // vpbroadcastd 0x28ac(%rip),%ymm4 # 5e0c <_sk_callback_hsw+0x432> .byte 197,205,219,228 // vpand %ymm4,%ymm6,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,226,125,24,45,159,40,0,0 // vbroadcastss 0x289f(%rip),%ymm5 # 5e10 <_sk_callback_hsw+0x436> .byte 197,220,89,229 // vmulps %ymm5,%ymm4,%ymm4 .byte 196,226,125,88,45,150,40,0,0 // vpbroadcastd 0x2896(%rip),%ymm5 # 5e14 <_sk_callback_hsw+0x43a> .byte 197,205,219,237 // vpand %ymm5,%ymm6,%ymm5 .byte 197,252,91,237 // vcvtdq2ps %ymm5,%ymm5 .byte 196,226,125,24,61,137,40,0,0 // vbroadcastss 0x2889(%rip),%ymm7 # 5e18 <_sk_callback_hsw+0x43e> .byte 197,212,89,239 // vmulps %ymm7,%ymm5,%ymm5 .byte 196,226,125,88,61,128,40,0,0 // vpbroadcastd 0x2880(%rip),%ymm7 # 5e1c <_sk_callback_hsw+0x442> .byte 197,205,219,247 // vpand %ymm7,%ymm6,%ymm6 .byte 197,252,91,246 // vcvtdq2ps %ymm6,%ymm6 .byte 196,226,125,24,61,115,40,0,0 // vbroadcastss 0x2873(%rip),%ymm7 # 5e20 <_sk_callback_hsw+0x446> .byte 197,204,89,247 // vmulps %ymm7,%ymm6,%ymm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,61,104,40,0,0 // vbroadcastss 0x2868(%rip),%ymm7 # 5e24 <_sk_callback_hsw+0x44a> .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,123,255,255,255 // ja 3552 <_sk_load_565_dst_hsw+0x22> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,98,0,0,0 // lea 0x62(%rip),%r11 # 3644 <_sk_load_565_dst_hsw+0x114> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,249,110,224 // vmovd %eax,%xmm4 .byte 233,89,255,255,255 // jmpq 3552 <_sk_load_565_dst_hsw+0x22> .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 196,193,89,196,100,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,121,110,44,89 // vmovd (%r9,%rbx,2),%xmm5 .byte 196,227,89,2,229,1 // vpblendd $0x1,%xmm5,%xmm4,%xmm4 .byte 233,60,255,255,255 // jmpq 3552 <_sk_load_565_dst_hsw+0x22> .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 196,193,89,196,100,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,89,196,100,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,89,196,100,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,122,126,44,89 // vmovq (%r9,%rbx,2),%xmm5 .byte 196,227,81,2,228,12 // vpblendd $0xc,%xmm4,%xmm5,%xmm4 .byte 233,15,255,255,255 // jmpq 3552 <_sk_load_565_dst_hsw+0x22> .byte 144 // nop .byte 167 // cmpsl %es:(%rdi),%ds:(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,193 // inc %ecx .byte 255 // (bad) .byte 255 // (bad) .byte 255,181,255,255,255,238 // pushq -0x11000001(%rbp) .byte 255 // (bad) .byte 255 // (bad) .byte 255,230 // jmpq *%rsi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 222,255 // fdivrp %st,%st(7) .byte 255 // (bad) .byte 255,210 // callq *%rdx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_gather_565_hsw .globl _sk_gather_565_hsw FUNCTION(_sk_gather_565_hsw) _sk_gather_565_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 196,226,125,88,80,8 // vpbroadcastd 0x8(%rax),%ymm2 .byte 196,226,109,64,201 // vpmulld %ymm1,%ymm2,%ymm1 .byte 197,254,91,192 // vcvttps2dq %ymm0,%ymm0 .byte 197,245,254,192 // vpaddd %ymm0,%ymm1,%ymm0 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,249,110,200 // vmovd %eax,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,183,4,81 // movzwl (%r9,%r10,2),%eax .byte 197,241,196,200,1 // vpinsrw $0x1,%eax,%xmm1,%xmm1 .byte 68,137,216 // mov %r11d,%eax .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,241,196,200,2 // vpinsrw $0x2,%eax,%xmm1,%xmm1 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 197,241,196,200,3 // vpinsrw $0x3,%eax,%xmm1,%xmm1 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,241,196,200,4 // vpinsrw $0x4,%eax,%xmm1,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,183,4,81 // movzwl (%r9,%r10,2),%eax .byte 197,241,196,192,5 // vpinsrw $0x5,%eax,%xmm1,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 197,249,196,192,7 // vpinsrw $0x7,%eax,%xmm0,%xmm0 .byte 196,226,125,51,208 // vpmovzxwd %xmm0,%ymm2 .byte 196,226,125,88,5,23,39,0,0 // vpbroadcastd 0x2717(%rip),%ymm0 # 5e28 <_sk_callback_hsw+0x44e> .byte 197,237,219,192 // vpand %ymm0,%ymm2,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,10,39,0,0 // vbroadcastss 0x270a(%rip),%ymm1 # 5e2c <_sk_callback_hsw+0x452> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 196,226,125,88,13,1,39,0,0 // vpbroadcastd 0x2701(%rip),%ymm1 # 5e30 <_sk_callback_hsw+0x456> .byte 197,237,219,201 // vpand %ymm1,%ymm2,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,226,125,24,29,244,38,0,0 // vbroadcastss 0x26f4(%rip),%ymm3 # 5e34 <_sk_callback_hsw+0x45a> .byte 197,244,89,203 // vmulps %ymm3,%ymm1,%ymm1 .byte 196,226,125,88,29,235,38,0,0 // vpbroadcastd 0x26eb(%rip),%ymm3 # 5e38 <_sk_callback_hsw+0x45e> .byte 197,237,219,211 // vpand %ymm3,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,226,125,24,29,222,38,0,0 // vbroadcastss 0x26de(%rip),%ymm3 # 5e3c <_sk_callback_hsw+0x462> .byte 197,236,89,211 // vmulps %ymm3,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,211,38,0,0 // vbroadcastss 0x26d3(%rip),%ymm3 # 5e40 <_sk_callback_hsw+0x466> .byte 255,224 // jmpq *%rax HIDDEN _sk_store_565_hsw .globl _sk_store_565_hsw FUNCTION(_sk_store_565_hsw) _sk_store_565_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 196,98,125,24,5,181,38,0,0 // vbroadcastss 0x26b5(%rip),%ymm8 # 5e44 <_sk_callback_hsw+0x46a> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,193,53,114,241,11 // vpslld $0xb,%ymm9,%ymm9 .byte 196,98,125,24,21,160,38,0,0 // vbroadcastss 0x26a0(%rip),%ymm10 # 5e48 <_sk_callback_hsw+0x46e> .byte 196,65,116,89,210 // vmulps %ymm10,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,45,114,242,5 // vpslld $0x5,%ymm10,%ymm10 .byte 196,65,45,235,201 // vpor %ymm9,%ymm10,%ymm9 .byte 196,65,108,89,192 // vmulps %ymm8,%ymm2,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,65,53,235,192 // vpor %ymm8,%ymm9,%ymm8 .byte 196,67,125,57,193,1 // vextracti128 $0x1,%ymm8,%xmm9 .byte 196,66,57,43,193 // vpackusdw %xmm9,%xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 37e7 <_sk_store_565_hsw+0x78> .byte 196,65,122,127,4,89 // vmovdqu %xmm8,(%r9,%rbx,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,235 // ja 37e2 <_sk_store_565_hsw+0x73> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,66,0,0,0 // lea 0x42(%rip),%r11 # 3844 <_sk_store_565_hsw+0xd5> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,67,121,21,4,89,0 // vpextrw $0x0,%xmm8,(%r9,%rbx,2) .byte 235,206 // jmp 37e2 <_sk_store_565_hsw+0x73> .byte 196,67,121,21,68,89,4,2 // vpextrw $0x2,%xmm8,0x4(%r9,%rbx,2) .byte 196,65,121,126,4,89 // vmovd %xmm8,(%r9,%rbx,2) .byte 235,190 // jmp 37e2 <_sk_store_565_hsw+0x73> .byte 196,67,121,21,68,89,12,6 // vpextrw $0x6,%xmm8,0xc(%r9,%rbx,2) .byte 196,67,121,21,68,89,10,5 // vpextrw $0x5,%xmm8,0xa(%r9,%rbx,2) .byte 196,67,121,21,68,89,8,4 // vpextrw $0x4,%xmm8,0x8(%r9,%rbx,2) .byte 196,65,121,214,4,89 // vmovq %xmm8,(%r9,%rbx,2) .byte 235,158 // jmp 37e2 <_sk_store_565_hsw+0x73> .byte 199 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 216,255 // fdivr %st(7),%st .byte 255 // (bad) .byte 255,208 // callq *%rax .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 248 // clc .byte 255 // (bad) .byte 255 // (bad) .byte 255,240 // push %rax .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 232,255,255,255,224 // callq ffffffffe100385c <_sk_callback_hsw+0xffffffffe0ffde82> .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_4444_hsw .globl _sk_load_4444_hsw FUNCTION(_sk_load_4444_hsw) _sk_load_4444_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 15,133,139,0,0,0 // jne 390b <_sk_load_4444_hsw+0xab> .byte 196,193,122,111,4,89 // vmovdqu (%r9,%rbx,2),%xmm0 .byte 196,226,125,51,216 // vpmovzxwd %xmm0,%ymm3 .byte 196,226,125,88,5,184,37,0,0 // vpbroadcastd 0x25b8(%rip),%ymm0 # 5e4c <_sk_callback_hsw+0x472> .byte 197,229,219,192 // vpand %ymm0,%ymm3,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,171,37,0,0 // vbroadcastss 0x25ab(%rip),%ymm1 # 5e50 <_sk_callback_hsw+0x476> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 196,226,125,88,13,162,37,0,0 // vpbroadcastd 0x25a2(%rip),%ymm1 # 5e54 <_sk_callback_hsw+0x47a> .byte 197,229,219,201 // vpand %ymm1,%ymm3,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,226,125,24,21,149,37,0,0 // vbroadcastss 0x2595(%rip),%ymm2 # 5e58 <_sk_callback_hsw+0x47e> .byte 197,244,89,202 // vmulps %ymm2,%ymm1,%ymm1 .byte 196,226,125,88,21,140,37,0,0 // vpbroadcastd 0x258c(%rip),%ymm2 # 5e5c <_sk_callback_hsw+0x482> .byte 197,229,219,210 // vpand %ymm2,%ymm3,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,98,125,24,5,127,37,0,0 // vbroadcastss 0x257f(%rip),%ymm8 # 5e60 <_sk_callback_hsw+0x486> .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 196,98,125,88,5,117,37,0,0 // vpbroadcastd 0x2575(%rip),%ymm8 # 5e64 <_sk_callback_hsw+0x48a> .byte 196,193,101,219,216 // vpand %ymm8,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,98,125,24,5,103,37,0,0 // vbroadcastss 0x2567(%rip),%ymm8 # 5e68 <_sk_callback_hsw+0x48e> .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,99,255,255,255 // ja 3886 <_sk_load_4444_hsw+0x26> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,98,0,0,0 // lea 0x62(%rip),%r11 # 3990 <_sk_load_4444_hsw+0x130> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 233,65,255,255,255 // jmpq 3886 <_sk_load_4444_hsw+0x26> .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 196,193,121,196,68,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,110,12,89 // vmovd (%r9,%rbx,2),%xmm1 .byte 196,227,121,2,193,1 // vpblendd $0x1,%xmm1,%xmm0,%xmm0 .byte 233,36,255,255,255 // jmpq 3886 <_sk_load_4444_hsw+0x26> .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 196,193,121,196,68,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,196,68,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,196,68,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,122,126,12,89 // vmovq (%r9,%rbx,2),%xmm1 .byte 196,227,113,2,192,12 // vpblendd $0xc,%xmm0,%xmm1,%xmm0 .byte 233,247,254,255,255 // jmpq 3886 <_sk_load_4444_hsw+0x26> .byte 144 // nop .byte 167 // cmpsl %es:(%rdi),%ds:(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,193 // inc %ecx .byte 255 // (bad) .byte 255 // (bad) .byte 255,181,255,255,255,238 // pushq -0x11000001(%rbp) .byte 255 // (bad) .byte 255 // (bad) .byte 255,230 // jmpq *%rsi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 222,255 // fdivrp %st,%st(7) .byte 255 // (bad) .byte 255,210 // callq *%rdx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_4444_dst_hsw .globl _sk_load_4444_dst_hsw FUNCTION(_sk_load_4444_dst_hsw) _sk_load_4444_dst_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 15,133,139,0,0,0 // jne 3a57 <_sk_load_4444_dst_hsw+0xab> .byte 196,193,122,111,36,89 // vmovdqu (%r9,%rbx,2),%xmm4 .byte 196,226,125,51,252 // vpmovzxwd %xmm4,%ymm7 .byte 196,226,125,88,37,140,36,0,0 // vpbroadcastd 0x248c(%rip),%ymm4 # 5e6c <_sk_callback_hsw+0x492> .byte 197,197,219,228 // vpand %ymm4,%ymm7,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,226,125,24,45,127,36,0,0 // vbroadcastss 0x247f(%rip),%ymm5 # 5e70 <_sk_callback_hsw+0x496> .byte 197,220,89,229 // vmulps %ymm5,%ymm4,%ymm4 .byte 196,226,125,88,45,118,36,0,0 // vpbroadcastd 0x2476(%rip),%ymm5 # 5e74 <_sk_callback_hsw+0x49a> .byte 197,197,219,237 // vpand %ymm5,%ymm7,%ymm5 .byte 197,252,91,237 // vcvtdq2ps %ymm5,%ymm5 .byte 196,226,125,24,53,105,36,0,0 // vbroadcastss 0x2469(%rip),%ymm6 # 5e78 <_sk_callback_hsw+0x49e> .byte 197,212,89,238 // vmulps %ymm6,%ymm5,%ymm5 .byte 196,226,125,88,53,96,36,0,0 // vpbroadcastd 0x2460(%rip),%ymm6 # 5e7c <_sk_callback_hsw+0x4a2> .byte 197,197,219,246 // vpand %ymm6,%ymm7,%ymm6 .byte 197,252,91,246 // vcvtdq2ps %ymm6,%ymm6 .byte 196,98,125,24,5,83,36,0,0 // vbroadcastss 0x2453(%rip),%ymm8 # 5e80 <_sk_callback_hsw+0x4a6> .byte 196,193,76,89,240 // vmulps %ymm8,%ymm6,%ymm6 .byte 196,98,125,88,5,73,36,0,0 // vpbroadcastd 0x2449(%rip),%ymm8 # 5e84 <_sk_callback_hsw+0x4aa> .byte 196,193,69,219,248 // vpand %ymm8,%ymm7,%ymm7 .byte 197,252,91,255 // vcvtdq2ps %ymm7,%ymm7 .byte 196,98,125,24,5,59,36,0,0 // vbroadcastss 0x243b(%rip),%ymm8 # 5e88 <_sk_callback_hsw+0x4ae> .byte 196,193,68,89,248 // vmulps %ymm8,%ymm7,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,99,255,255,255 // ja 39d2 <_sk_load_4444_dst_hsw+0x26> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,98,0,0,0 // lea 0x62(%rip),%r11 # 3adc <_sk_load_4444_dst_hsw+0x130> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,249,110,224 // vmovd %eax,%xmm4 .byte 233,65,255,255,255 // jmpq 39d2 <_sk_load_4444_dst_hsw+0x26> .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 196,193,89,196,100,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,121,110,44,89 // vmovd (%r9,%rbx,2),%xmm5 .byte 196,227,89,2,229,1 // vpblendd $0x1,%xmm5,%xmm4,%xmm4 .byte 233,36,255,255,255 // jmpq 39d2 <_sk_load_4444_dst_hsw+0x26> .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 196,193,89,196,100,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,89,196,100,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,89,196,100,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,122,126,44,89 // vmovq (%r9,%rbx,2),%xmm5 .byte 196,227,81,2,228,12 // vpblendd $0xc,%xmm4,%xmm5,%xmm4 .byte 233,247,254,255,255 // jmpq 39d2 <_sk_load_4444_dst_hsw+0x26> .byte 144 // nop .byte 167 // cmpsl %es:(%rdi),%ds:(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,193 // inc %ecx .byte 255 // (bad) .byte 255 // (bad) .byte 255,181,255,255,255,238 // pushq -0x11000001(%rbp) .byte 255 // (bad) .byte 255 // (bad) .byte 255,230 // jmpq *%rsi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 222,255 // fdivrp %st,%st(7) .byte 255 // (bad) .byte 255,210 // callq *%rdx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_gather_4444_hsw .globl _sk_gather_4444_hsw FUNCTION(_sk_gather_4444_hsw) _sk_gather_4444_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 196,226,125,88,80,8 // vpbroadcastd 0x8(%rax),%ymm2 .byte 196,226,109,64,201 // vpmulld %ymm1,%ymm2,%ymm1 .byte 197,254,91,192 // vcvttps2dq %ymm0,%ymm0 .byte 197,245,254,192 // vpaddd %ymm0,%ymm1,%ymm0 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,249,110,200 // vmovd %eax,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,183,4,81 // movzwl (%r9,%r10,2),%eax .byte 197,241,196,200,1 // vpinsrw $0x1,%eax,%xmm1,%xmm1 .byte 68,137,216 // mov %r11d,%eax .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,241,196,200,2 // vpinsrw $0x2,%eax,%xmm1,%xmm1 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 197,241,196,200,3 // vpinsrw $0x3,%eax,%xmm1,%xmm1 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,241,196,200,4 // vpinsrw $0x4,%eax,%xmm1,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,183,4,81 // movzwl (%r9,%r10,2),%eax .byte 197,241,196,192,5 // vpinsrw $0x5,%eax,%xmm1,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 197,249,196,192,7 // vpinsrw $0x7,%eax,%xmm0,%xmm0 .byte 196,226,125,51,216 // vpmovzxwd %xmm0,%ymm3 .byte 196,226,125,88,5,227,34,0,0 // vpbroadcastd 0x22e3(%rip),%ymm0 # 5e8c <_sk_callback_hsw+0x4b2> .byte 197,229,219,192 // vpand %ymm0,%ymm3,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,214,34,0,0 // vbroadcastss 0x22d6(%rip),%ymm1 # 5e90 <_sk_callback_hsw+0x4b6> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 196,226,125,88,13,205,34,0,0 // vpbroadcastd 0x22cd(%rip),%ymm1 # 5e94 <_sk_callback_hsw+0x4ba> .byte 197,229,219,201 // vpand %ymm1,%ymm3,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,226,125,24,21,192,34,0,0 // vbroadcastss 0x22c0(%rip),%ymm2 # 5e98 <_sk_callback_hsw+0x4be> .byte 197,244,89,202 // vmulps %ymm2,%ymm1,%ymm1 .byte 196,226,125,88,21,183,34,0,0 // vpbroadcastd 0x22b7(%rip),%ymm2 # 5e9c <_sk_callback_hsw+0x4c2> .byte 197,229,219,210 // vpand %ymm2,%ymm3,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,98,125,24,5,170,34,0,0 // vbroadcastss 0x22aa(%rip),%ymm8 # 5ea0 <_sk_callback_hsw+0x4c6> .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 196,98,125,88,5,160,34,0,0 // vpbroadcastd 0x22a0(%rip),%ymm8 # 5ea4 <_sk_callback_hsw+0x4ca> .byte 196,193,101,219,216 // vpand %ymm8,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,98,125,24,5,146,34,0,0 // vbroadcastss 0x2292(%rip),%ymm8 # 5ea8 <_sk_callback_hsw+0x4ce> .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_4444_hsw .globl _sk_store_4444_hsw FUNCTION(_sk_store_4444_hsw) _sk_store_4444_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 196,98,125,24,5,109,34,0,0 // vbroadcastss 0x226d(%rip),%ymm8 # 5eac <_sk_callback_hsw+0x4d2> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,193,53,114,241,12 // vpslld $0xc,%ymm9,%ymm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,45,114,242,8 // vpslld $0x8,%ymm10,%ymm10 .byte 196,65,45,235,201 // vpor %ymm9,%ymm10,%ymm9 .byte 196,65,108,89,208 // vmulps %ymm8,%ymm2,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,45,114,242,4 // vpslld $0x4,%ymm10,%ymm10 .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,65,45,235,192 // vpor %ymm8,%ymm10,%ymm8 .byte 196,65,53,235,192 // vpor %ymm8,%ymm9,%ymm8 .byte 196,67,125,57,193,1 // vextracti128 $0x1,%ymm8,%xmm9 .byte 196,66,57,43,193 // vpackusdw %xmm9,%xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 3ca3 <_sk_store_4444_hsw+0x84> .byte 196,65,122,127,4,89 // vmovdqu %xmm8,(%r9,%rbx,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,235 // ja 3c9e <_sk_store_4444_hsw+0x7f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,66,0,0,0 // lea 0x42(%rip),%r11 # 3d00 <_sk_store_4444_hsw+0xe1> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,67,121,21,4,89,0 // vpextrw $0x0,%xmm8,(%r9,%rbx,2) .byte 235,206 // jmp 3c9e <_sk_store_4444_hsw+0x7f> .byte 196,67,121,21,68,89,4,2 // vpextrw $0x2,%xmm8,0x4(%r9,%rbx,2) .byte 196,65,121,126,4,89 // vmovd %xmm8,(%r9,%rbx,2) .byte 235,190 // jmp 3c9e <_sk_store_4444_hsw+0x7f> .byte 196,67,121,21,68,89,12,6 // vpextrw $0x6,%xmm8,0xc(%r9,%rbx,2) .byte 196,67,121,21,68,89,10,5 // vpextrw $0x5,%xmm8,0xa(%r9,%rbx,2) .byte 196,67,121,21,68,89,8,4 // vpextrw $0x4,%xmm8,0x8(%r9,%rbx,2) .byte 196,65,121,214,4,89 // vmovq %xmm8,(%r9,%rbx,2) .byte 235,158 // jmp 3c9e <_sk_store_4444_hsw+0x7f> .byte 199 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 216,255 // fdivr %st(7),%st .byte 255 // (bad) .byte 255,208 // callq *%rax .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 248 // clc .byte 255 // (bad) .byte 255 // (bad) .byte 255,240 // push %rax .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 232,255,255,255,224 // callq ffffffffe1003d18 <_sk_callback_hsw+0xffffffffe0ffe33e> .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_8888_hsw .globl _sk_load_8888_hsw FUNCTION(_sk_load_8888_hsw) _sk_load_8888_hsw: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,87 // jne 3d96 <_sk_load_8888_hsw+0x7a> .byte 197,252,16,24 // vmovups (%rax),%ymm3 .byte 197,228,84,5,117,35,0,0 // vandps 0x2375(%rip),%ymm3,%ymm0 # 60c0 <_sk_callback_hsw+0x6e6> .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,5,88,33,0,0 // vbroadcastss 0x2158(%rip),%ymm8 # 5eb0 <_sk_callback_hsw+0x4d6> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 196,226,101,0,13,122,35,0,0 // vpshufb 0x237a(%rip),%ymm3,%ymm1 # 60e0 <_sk_callback_hsw+0x706> .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 196,226,101,0,21,136,35,0,0 // vpshufb 0x2388(%rip),%ymm3,%ymm2 # 6100 <_sk_callback_hsw+0x726> .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 197,229,114,211,24 // vpsrld $0x18,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,194 // vmovq %r10,%xmm0 .byte 196,226,125,33,192 // vpmovsxbd %xmm0,%ymm0 .byte 196,226,125,44,24 // vmaskmovps (%rax),%ymm0,%ymm3 .byte 235,135 // jmp 3d43 <_sk_load_8888_hsw+0x27> HIDDEN _sk_load_8888_dst_hsw .globl _sk_load_8888_dst_hsw FUNCTION(_sk_load_8888_dst_hsw) _sk_load_8888_dst_hsw: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,87 // jne 3e36 <_sk_load_8888_dst_hsw+0x7a> .byte 197,252,16,56 // vmovups (%rax),%ymm7 .byte 197,196,84,37,53,35,0,0 // vandps 0x2335(%rip),%ymm7,%ymm4 # 6120 <_sk_callback_hsw+0x746> .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,98,125,24,5,188,32,0,0 // vbroadcastss 0x20bc(%rip),%ymm8 # 5eb4 <_sk_callback_hsw+0x4da> .byte 196,193,92,89,224 // vmulps %ymm8,%ymm4,%ymm4 .byte 196,226,69,0,45,58,35,0,0 // vpshufb 0x233a(%rip),%ymm7,%ymm5 # 6140 <_sk_callback_hsw+0x766> .byte 197,252,91,237 // vcvtdq2ps %ymm5,%ymm5 .byte 196,193,84,89,232 // vmulps %ymm8,%ymm5,%ymm5 .byte 196,226,69,0,53,72,35,0,0 // vpshufb 0x2348(%rip),%ymm7,%ymm6 # 6160 <_sk_callback_hsw+0x786> .byte 197,252,91,246 // vcvtdq2ps %ymm6,%ymm6 .byte 196,193,76,89,240 // vmulps %ymm8,%ymm6,%ymm6 .byte 197,197,114,215,24 // vpsrld $0x18,%ymm7,%ymm7 .byte 197,252,91,255 // vcvtdq2ps %ymm7,%ymm7 .byte 196,193,68,89,248 // vmulps %ymm8,%ymm7,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,226 // vmovq %r10,%xmm4 .byte 196,226,125,33,228 // vpmovsxbd %xmm4,%ymm4 .byte 196,226,93,44,56 // vmaskmovps (%rax),%ymm4,%ymm7 .byte 235,135 // jmp 3de3 <_sk_load_8888_dst_hsw+0x27> HIDDEN _sk_gather_8888_hsw .globl _sk_gather_8888_hsw FUNCTION(_sk_gather_8888_hsw) _sk_gather_8888_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 196,226,125,88,80,8 // vpbroadcastd 0x8(%rax),%ymm2 .byte 196,226,109,64,201 // vpmulld %ymm1,%ymm2,%ymm1 .byte 197,254,91,192 // vcvttps2dq %ymm0,%ymm0 .byte 197,245,254,192 // vpaddd %ymm0,%ymm1,%ymm0 .byte 197,245,118,201 // vpcmpeqd %ymm1,%ymm1,%ymm1 .byte 196,194,117,144,28,129 // vpgatherdd %ymm1,(%r9,%ymm0,4),%ymm3 .byte 197,229,219,5,246,34,0,0 // vpand 0x22f6(%rip),%ymm3,%ymm0 # 6180 <_sk_callback_hsw+0x7a6> .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,5,33,32,0,0 // vbroadcastss 0x2021(%rip),%ymm8 # 5eb8 <_sk_callback_hsw+0x4de> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 196,226,101,0,13,251,34,0,0 // vpshufb 0x22fb(%rip),%ymm3,%ymm1 # 61a0 <_sk_callback_hsw+0x7c6> .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 196,226,101,0,21,9,35,0,0 // vpshufb 0x2309(%rip),%ymm3,%ymm2 # 61c0 <_sk_callback_hsw+0x7e6> .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 197,229,114,211,24 // vpsrld $0x18,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_8888_hsw .globl _sk_store_8888_hsw FUNCTION(_sk_store_8888_hsw) _sk_store_8888_hsw: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 196,98,125,24,5,195,31,0,0 // vbroadcastss 0x1fc3(%rip),%ymm8 # 5ebc <_sk_callback_hsw+0x4e2> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,45,114,242,8 // vpslld $0x8,%ymm10,%ymm10 .byte 196,65,45,235,201 // vpor %ymm9,%ymm10,%ymm9 .byte 196,65,108,89,208 // vmulps %ymm8,%ymm2,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,45,114,242,16 // vpslld $0x10,%ymm10,%ymm10 .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,193,61,114,240,24 // vpslld $0x18,%ymm8,%ymm8 .byte 196,65,45,235,192 // vpor %ymm8,%ymm10,%ymm8 .byte 196,65,53,235,192 // vpor %ymm8,%ymm9,%ymm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 3f52 <_sk_store_8888_hsw+0x80> .byte 197,124,17,0 // vmovups %ymm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,65,249,110,202 // vmovq %r10,%xmm9 .byte 196,66,125,33,201 // vpmovsxbd %xmm9,%ymm9 .byte 196,98,53,46,0 // vmaskmovps %ymm8,%ymm9,(%rax) .byte 235,211 // jmp 3f4b <_sk_store_8888_hsw+0x79> HIDDEN _sk_load_bgra_hsw .globl _sk_load_bgra_hsw FUNCTION(_sk_load_bgra_hsw) _sk_load_bgra_hsw: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,87 // jne 3ff2 <_sk_load_bgra_hsw+0x7a> .byte 197,252,16,24 // vmovups (%rax),%ymm3 .byte 197,228,84,5,57,34,0,0 // vandps 0x2239(%rip),%ymm3,%ymm0 # 61e0 <_sk_callback_hsw+0x806> .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,5,12,31,0,0 // vbroadcastss 0x1f0c(%rip),%ymm8 # 5ec0 <_sk_callback_hsw+0x4e6> .byte 196,193,124,89,208 // vmulps %ymm8,%ymm0,%ymm2 .byte 196,226,101,0,5,62,34,0,0 // vpshufb 0x223e(%rip),%ymm3,%ymm0 # 6200 <_sk_callback_hsw+0x826> .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,193,124,89,200 // vmulps %ymm8,%ymm0,%ymm1 .byte 196,226,101,0,5,76,34,0,0 // vpshufb 0x224c(%rip),%ymm3,%ymm0 # 6220 <_sk_callback_hsw+0x846> .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,229,114,211,24 // vpsrld $0x18,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,194 // vmovq %r10,%xmm0 .byte 196,226,125,33,192 // vpmovsxbd %xmm0,%ymm0 .byte 196,226,125,44,24 // vmaskmovps (%rax),%ymm0,%ymm3 .byte 235,135 // jmp 3f9f <_sk_load_bgra_hsw+0x27> HIDDEN _sk_load_bgra_dst_hsw .globl _sk_load_bgra_dst_hsw FUNCTION(_sk_load_bgra_dst_hsw) _sk_load_bgra_dst_hsw: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,87 // jne 4092 <_sk_load_bgra_dst_hsw+0x7a> .byte 197,252,16,56 // vmovups (%rax),%ymm7 .byte 197,196,84,37,249,33,0,0 // vandps 0x21f9(%rip),%ymm7,%ymm4 # 6240 <_sk_callback_hsw+0x866> .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,98,125,24,5,112,30,0,0 // vbroadcastss 0x1e70(%rip),%ymm8 # 5ec4 <_sk_callback_hsw+0x4ea> .byte 196,193,92,89,240 // vmulps %ymm8,%ymm4,%ymm6 .byte 196,226,69,0,37,254,33,0,0 // vpshufb 0x21fe(%rip),%ymm7,%ymm4 # 6260 <_sk_callback_hsw+0x886> .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,193,92,89,232 // vmulps %ymm8,%ymm4,%ymm5 .byte 196,226,69,0,37,12,34,0,0 // vpshufb 0x220c(%rip),%ymm7,%ymm4 # 6280 <_sk_callback_hsw+0x8a6> .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,193,92,89,224 // vmulps %ymm8,%ymm4,%ymm4 .byte 197,197,114,215,24 // vpsrld $0x18,%ymm7,%ymm7 .byte 197,252,91,255 // vcvtdq2ps %ymm7,%ymm7 .byte 196,193,68,89,248 // vmulps %ymm8,%ymm7,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,226 // vmovq %r10,%xmm4 .byte 196,226,125,33,228 // vpmovsxbd %xmm4,%ymm4 .byte 196,226,93,44,56 // vmaskmovps (%rax),%ymm4,%ymm7 .byte 235,135 // jmp 403f <_sk_load_bgra_dst_hsw+0x27> HIDDEN _sk_gather_bgra_hsw .globl _sk_gather_bgra_hsw FUNCTION(_sk_gather_bgra_hsw) _sk_gather_bgra_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 196,226,125,88,80,8 // vpbroadcastd 0x8(%rax),%ymm2 .byte 196,226,109,64,201 // vpmulld %ymm1,%ymm2,%ymm1 .byte 197,254,91,192 // vcvttps2dq %ymm0,%ymm0 .byte 197,245,254,192 // vpaddd %ymm0,%ymm1,%ymm0 .byte 197,245,118,201 // vpcmpeqd %ymm1,%ymm1,%ymm1 .byte 196,194,117,144,28,129 // vpgatherdd %ymm1,(%r9,%ymm0,4),%ymm3 .byte 197,229,219,5,186,33,0,0 // vpand 0x21ba(%rip),%ymm3,%ymm0 # 62a0 <_sk_callback_hsw+0x8c6> .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,5,213,29,0,0 // vbroadcastss 0x1dd5(%rip),%ymm8 # 5ec8 <_sk_callback_hsw+0x4ee> .byte 196,193,124,89,208 // vmulps %ymm8,%ymm0,%ymm2 .byte 196,226,101,0,5,191,33,0,0 // vpshufb 0x21bf(%rip),%ymm3,%ymm0 # 62c0 <_sk_callback_hsw+0x8e6> .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,193,124,89,200 // vmulps %ymm8,%ymm0,%ymm1 .byte 196,226,101,0,5,205,33,0,0 // vpshufb 0x21cd(%rip),%ymm3,%ymm0 # 62e0 <_sk_callback_hsw+0x906> .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,229,114,211,24 // vpsrld $0x18,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_bgra_hsw .globl _sk_store_bgra_hsw FUNCTION(_sk_store_bgra_hsw) _sk_store_bgra_hsw: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 196,98,125,24,5,119,29,0,0 // vbroadcastss 0x1d77(%rip),%ymm8 # 5ecc <_sk_callback_hsw+0x4f2> .byte 196,65,108,89,200 // vmulps %ymm8,%ymm2,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,45,114,242,8 // vpslld $0x8,%ymm10,%ymm10 .byte 196,65,45,235,201 // vpor %ymm9,%ymm10,%ymm9 .byte 196,65,124,89,208 // vmulps %ymm8,%ymm0,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,45,114,242,16 // vpslld $0x10,%ymm10,%ymm10 .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,193,61,114,240,24 // vpslld $0x18,%ymm8,%ymm8 .byte 196,65,45,235,192 // vpor %ymm8,%ymm10,%ymm8 .byte 196,65,53,235,192 // vpor %ymm8,%ymm9,%ymm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 41ae <_sk_store_bgra_hsw+0x80> .byte 197,124,17,0 // vmovups %ymm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,65,249,110,202 // vmovq %r10,%xmm9 .byte 196,66,125,33,201 // vpmovsxbd %xmm9,%ymm9 .byte 196,98,53,46,0 // vmaskmovps %ymm8,%ymm9,(%rax) .byte 235,211 // jmp 41a7 <_sk_store_bgra_hsw+0x79> HIDDEN _sk_load_f16_hsw .globl _sk_load_f16_hsw FUNCTION(_sk_load_f16_hsw) _sk_load_f16_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,101 // jne 4255 <_sk_load_f16_hsw+0x81> .byte 196,65,121,16,4,193 // vmovupd (%r9,%rax,8),%xmm8 .byte 196,193,121,16,84,193,16 // vmovupd 0x10(%r9,%rax,8),%xmm2 .byte 196,193,121,16,92,193,32 // vmovupd 0x20(%r9,%rax,8),%xmm3 .byte 196,65,122,111,76,193,48 // vmovdqu 0x30(%r9,%rax,8),%xmm9 .byte 197,185,97,194 // vpunpcklwd %xmm2,%xmm8,%xmm0 .byte 197,185,105,210 // vpunpckhwd %xmm2,%xmm8,%xmm2 .byte 196,193,97,97,201 // vpunpcklwd %xmm9,%xmm3,%xmm1 .byte 196,193,97,105,217 // vpunpckhwd %xmm9,%xmm3,%xmm3 .byte 197,121,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm8 .byte 197,121,105,202 // vpunpckhwd %xmm2,%xmm0,%xmm9 .byte 197,241,97,211 // vpunpcklwd %xmm3,%xmm1,%xmm2 .byte 197,241,105,219 // vpunpckhwd %xmm3,%xmm1,%xmm3 .byte 197,185,108,194 // vpunpcklqdq %xmm2,%xmm8,%xmm0 .byte 196,226,125,19,192 // vcvtph2ps %xmm0,%ymm0 .byte 197,185,109,202 // vpunpckhqdq %xmm2,%xmm8,%xmm1 .byte 196,226,125,19,201 // vcvtph2ps %xmm1,%ymm1 .byte 197,177,108,211 // vpunpcklqdq %xmm3,%xmm9,%xmm2 .byte 196,226,125,19,210 // vcvtph2ps %xmm2,%ymm2 .byte 197,177,109,219 // vpunpckhqdq %xmm3,%xmm9,%xmm3 .byte 196,226,125,19,219 // vcvtph2ps %xmm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,65,123,16,4,193 // vmovsd (%r9,%rax,8),%xmm8 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,85 // je 42bb <_sk_load_f16_hsw+0xe7> .byte 196,65,57,22,68,193,8 // vmovhpd 0x8(%r9,%rax,8),%xmm8,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,72 // jb 42bb <_sk_load_f16_hsw+0xe7> .byte 196,193,123,16,84,193,16 // vmovsd 0x10(%r9,%rax,8),%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 116,72 // je 42c8 <_sk_load_f16_hsw+0xf4> .byte 196,193,105,22,84,193,24 // vmovhpd 0x18(%r9,%rax,8),%xmm2,%xmm2 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,59 // jb 42c8 <_sk_load_f16_hsw+0xf4> .byte 196,193,123,16,92,193,32 // vmovsd 0x20(%r9,%rax,8),%xmm3 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 15,132,109,255,255,255 // je 420b <_sk_load_f16_hsw+0x37> .byte 196,193,97,22,92,193,40 // vmovhpd 0x28(%r9,%rax,8),%xmm3,%xmm3 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,130,92,255,255,255 // jb 420b <_sk_load_f16_hsw+0x37> .byte 196,65,122,126,76,193,48 // vmovq 0x30(%r9,%rax,8),%xmm9 .byte 233,80,255,255,255 // jmpq 420b <_sk_load_f16_hsw+0x37> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 197,233,87,210 // vxorpd %xmm2,%xmm2,%xmm2 .byte 233,67,255,255,255 // jmpq 420b <_sk_load_f16_hsw+0x37> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 233,58,255,255,255 // jmpq 420b <_sk_load_f16_hsw+0x37> HIDDEN _sk_load_f16_dst_hsw .globl _sk_load_f16_dst_hsw FUNCTION(_sk_load_f16_dst_hsw) _sk_load_f16_dst_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,101 // jne 4352 <_sk_load_f16_dst_hsw+0x81> .byte 196,65,121,16,4,193 // vmovupd (%r9,%rax,8),%xmm8 .byte 196,193,121,16,116,193,16 // vmovupd 0x10(%r9,%rax,8),%xmm6 .byte 196,193,121,16,124,193,32 // vmovupd 0x20(%r9,%rax,8),%xmm7 .byte 196,65,122,111,76,193,48 // vmovdqu 0x30(%r9,%rax,8),%xmm9 .byte 197,185,97,230 // vpunpcklwd %xmm6,%xmm8,%xmm4 .byte 197,185,105,246 // vpunpckhwd %xmm6,%xmm8,%xmm6 .byte 196,193,65,97,233 // vpunpcklwd %xmm9,%xmm7,%xmm5 .byte 196,193,65,105,249 // vpunpckhwd %xmm9,%xmm7,%xmm7 .byte 197,89,97,198 // vpunpcklwd %xmm6,%xmm4,%xmm8 .byte 197,89,105,206 // vpunpckhwd %xmm6,%xmm4,%xmm9 .byte 197,209,97,247 // vpunpcklwd %xmm7,%xmm5,%xmm6 .byte 197,209,105,255 // vpunpckhwd %xmm7,%xmm5,%xmm7 .byte 197,185,108,230 // vpunpcklqdq %xmm6,%xmm8,%xmm4 .byte 196,226,125,19,228 // vcvtph2ps %xmm4,%ymm4 .byte 197,185,109,238 // vpunpckhqdq %xmm6,%xmm8,%xmm5 .byte 196,226,125,19,237 // vcvtph2ps %xmm5,%ymm5 .byte 197,177,108,247 // vpunpcklqdq %xmm7,%xmm9,%xmm6 .byte 196,226,125,19,246 // vcvtph2ps %xmm6,%ymm6 .byte 197,177,109,255 // vpunpckhqdq %xmm7,%xmm9,%xmm7 .byte 196,226,125,19,255 // vcvtph2ps %xmm7,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,65,123,16,4,193 // vmovsd (%r9,%rax,8),%xmm8 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,85 // je 43b8 <_sk_load_f16_dst_hsw+0xe7> .byte 196,65,57,22,68,193,8 // vmovhpd 0x8(%r9,%rax,8),%xmm8,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,72 // jb 43b8 <_sk_load_f16_dst_hsw+0xe7> .byte 196,193,123,16,116,193,16 // vmovsd 0x10(%r9,%rax,8),%xmm6 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 116,72 // je 43c5 <_sk_load_f16_dst_hsw+0xf4> .byte 196,193,73,22,116,193,24 // vmovhpd 0x18(%r9,%rax,8),%xmm6,%xmm6 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,59 // jb 43c5 <_sk_load_f16_dst_hsw+0xf4> .byte 196,193,123,16,124,193,32 // vmovsd 0x20(%r9,%rax,8),%xmm7 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 15,132,109,255,255,255 // je 4308 <_sk_load_f16_dst_hsw+0x37> .byte 196,193,65,22,124,193,40 // vmovhpd 0x28(%r9,%rax,8),%xmm7,%xmm7 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,130,92,255,255,255 // jb 4308 <_sk_load_f16_dst_hsw+0x37> .byte 196,65,122,126,76,193,48 // vmovq 0x30(%r9,%rax,8),%xmm9 .byte 233,80,255,255,255 // jmpq 4308 <_sk_load_f16_dst_hsw+0x37> .byte 197,193,87,255 // vxorpd %xmm7,%xmm7,%xmm7 .byte 197,201,87,246 // vxorpd %xmm6,%xmm6,%xmm6 .byte 233,67,255,255,255 // jmpq 4308 <_sk_load_f16_dst_hsw+0x37> .byte 197,193,87,255 // vxorpd %xmm7,%xmm7,%xmm7 .byte 233,58,255,255,255 // jmpq 4308 <_sk_load_f16_dst_hsw+0x37> HIDDEN _sk_gather_f16_hsw .globl _sk_gather_f16_hsw FUNCTION(_sk_gather_f16_hsw) _sk_gather_f16_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 196,226,125,88,80,8 // vpbroadcastd 0x8(%rax),%ymm2 .byte 196,226,109,64,201 // vpmulld %ymm1,%ymm2,%ymm1 .byte 197,254,91,192 // vcvttps2dq %ymm0,%ymm0 .byte 197,245,254,192 // vpaddd %ymm0,%ymm1,%ymm0 .byte 197,245,118,201 // vpcmpeqd %ymm1,%ymm1,%ymm1 .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 196,194,237,144,28,193 // vpgatherdq %ymm2,(%r9,%xmm0,8),%ymm3 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,194,245,144,20,193 // vpgatherdq %ymm1,(%r9,%xmm0,8),%ymm2 .byte 196,227,125,57,216,1 // vextracti128 $0x1,%ymm3,%xmm0 .byte 196,227,125,57,209,1 // vextracti128 $0x1,%ymm2,%xmm1 .byte 197,97,97,192 // vpunpcklwd %xmm0,%xmm3,%xmm8 .byte 197,225,105,192 // vpunpckhwd %xmm0,%xmm3,%xmm0 .byte 197,233,97,217 // vpunpcklwd %xmm1,%xmm2,%xmm3 .byte 197,233,105,201 // vpunpckhwd %xmm1,%xmm2,%xmm1 .byte 197,57,97,200 // vpunpcklwd %xmm0,%xmm8,%xmm9 .byte 197,57,105,192 // vpunpckhwd %xmm0,%xmm8,%xmm8 .byte 197,225,97,209 // vpunpcklwd %xmm1,%xmm3,%xmm2 .byte 197,225,105,217 // vpunpckhwd %xmm1,%xmm3,%xmm3 .byte 197,177,108,194 // vpunpcklqdq %xmm2,%xmm9,%xmm0 .byte 196,226,125,19,192 // vcvtph2ps %xmm0,%ymm0 .byte 197,177,109,202 // vpunpckhqdq %xmm2,%xmm9,%xmm1 .byte 196,226,125,19,201 // vcvtph2ps %xmm1,%ymm1 .byte 197,185,108,211 // vpunpcklqdq %xmm3,%xmm8,%xmm2 .byte 196,226,125,19,210 // vcvtph2ps %xmm2,%ymm2 .byte 197,185,109,219 // vpunpckhqdq %xmm3,%xmm8,%xmm3 .byte 196,226,125,19,219 // vcvtph2ps %xmm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_f16_hsw .globl _sk_store_f16_hsw FUNCTION(_sk_store_f16_hsw) _sk_store_f16_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 196,195,125,29,192,4 // vcvtps2ph $0x4,%ymm0,%xmm8 .byte 196,195,125,29,201,4 // vcvtps2ph $0x4,%ymm1,%xmm9 .byte 196,195,125,29,210,4 // vcvtps2ph $0x4,%ymm2,%xmm10 .byte 196,195,125,29,219,4 // vcvtps2ph $0x4,%ymm3,%xmm11 .byte 196,65,57,97,225 // vpunpcklwd %xmm9,%xmm8,%xmm12 .byte 196,65,57,105,193 // vpunpckhwd %xmm9,%xmm8,%xmm8 .byte 196,65,41,97,203 // vpunpcklwd %xmm11,%xmm10,%xmm9 .byte 196,65,41,105,235 // vpunpckhwd %xmm11,%xmm10,%xmm13 .byte 196,65,25,98,217 // vpunpckldq %xmm9,%xmm12,%xmm11 .byte 196,65,25,106,209 // vpunpckhdq %xmm9,%xmm12,%xmm10 .byte 196,65,57,98,205 // vpunpckldq %xmm13,%xmm8,%xmm9 .byte 196,65,57,106,197 // vpunpckhdq %xmm13,%xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,31 // jne 44d3 <_sk_store_f16_hsw+0x7b> .byte 196,65,120,17,28,193 // vmovups %xmm11,(%r9,%rax,8) .byte 196,65,120,17,84,193,16 // vmovups %xmm10,0x10(%r9,%rax,8) .byte 196,65,120,17,76,193,32 // vmovups %xmm9,0x20(%r9,%rax,8) .byte 196,65,122,127,68,193,48 // vmovdqu %xmm8,0x30(%r9,%rax,8) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,65,121,214,28,193 // vmovq %xmm11,(%r9,%rax,8) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,240 // je 44cf <_sk_store_f16_hsw+0x77> .byte 196,65,121,23,92,193,8 // vmovhpd %xmm11,0x8(%r9,%rax,8) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,227 // jb 44cf <_sk_store_f16_hsw+0x77> .byte 196,65,121,214,84,193,16 // vmovq %xmm10,0x10(%r9,%rax,8) .byte 116,218 // je 44cf <_sk_store_f16_hsw+0x77> .byte 196,65,121,23,84,193,24 // vmovhpd %xmm10,0x18(%r9,%rax,8) .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,205 // jb 44cf <_sk_store_f16_hsw+0x77> .byte 196,65,121,214,76,193,32 // vmovq %xmm9,0x20(%r9,%rax,8) .byte 116,196 // je 44cf <_sk_store_f16_hsw+0x77> .byte 196,65,121,23,76,193,40 // vmovhpd %xmm9,0x28(%r9,%rax,8) .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,183 // jb 44cf <_sk_store_f16_hsw+0x77> .byte 196,65,121,214,68,193,48 // vmovq %xmm8,0x30(%r9,%rax,8) .byte 235,174 // jmp 44cf <_sk_store_f16_hsw+0x77> HIDDEN _sk_load_u16_be_hsw .globl _sk_load_u16_be_hsw FUNCTION(_sk_load_u16_be_hsw) _sk_load_u16_be_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,204,0,0,0 // jne 4614 <_sk_load_u16_be_hsw+0xf3> .byte 196,65,121,16,4,65 // vmovupd (%r9,%rax,2),%xmm8 .byte 196,193,121,16,84,65,16 // vmovupd 0x10(%r9,%rax,2),%xmm2 .byte 196,193,121,16,92,65,32 // vmovupd 0x20(%r9,%rax,2),%xmm3 .byte 196,65,122,111,76,65,48 // vmovdqu 0x30(%r9,%rax,2),%xmm9 .byte 197,185,97,194 // vpunpcklwd %xmm2,%xmm8,%xmm0 .byte 197,185,105,210 // vpunpckhwd %xmm2,%xmm8,%xmm2 .byte 196,193,97,97,201 // vpunpcklwd %xmm9,%xmm3,%xmm1 .byte 196,193,97,105,217 // vpunpckhwd %xmm9,%xmm3,%xmm3 .byte 197,121,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm8 .byte 197,121,105,202 // vpunpckhwd %xmm2,%xmm0,%xmm9 .byte 197,241,97,211 // vpunpcklwd %xmm3,%xmm1,%xmm2 .byte 197,113,105,219 // vpunpckhwd %xmm3,%xmm1,%xmm11 .byte 197,185,108,194 // vpunpcklqdq %xmm2,%xmm8,%xmm0 .byte 197,241,113,240,8 // vpsllw $0x8,%xmm0,%xmm1 .byte 197,249,113,208,8 // vpsrlw $0x8,%xmm0,%xmm0 .byte 197,241,235,192 // vpor %xmm0,%xmm1,%xmm0 .byte 196,226,125,51,192 // vpmovzxwd %xmm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,21,39,25,0,0 // vbroadcastss 0x1927(%rip),%ymm10 # 5ed0 <_sk_callback_hsw+0x4f6> .byte 196,193,124,89,194 // vmulps %ymm10,%ymm0,%ymm0 .byte 197,185,109,202 // vpunpckhqdq %xmm2,%xmm8,%xmm1 .byte 197,233,113,241,8 // vpsllw $0x8,%xmm1,%xmm2 .byte 197,241,113,209,8 // vpsrlw $0x8,%xmm1,%xmm1 .byte 197,233,235,201 // vpor %xmm1,%xmm2,%xmm1 .byte 196,226,125,51,201 // vpmovzxwd %xmm1,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,202 // vmulps %ymm10,%ymm1,%ymm1 .byte 196,193,49,108,211 // vpunpcklqdq %xmm11,%xmm9,%xmm2 .byte 197,225,113,242,8 // vpsllw $0x8,%xmm2,%xmm3 .byte 197,233,113,210,8 // vpsrlw $0x8,%xmm2,%xmm2 .byte 197,225,235,210 // vpor %xmm2,%xmm3,%xmm2 .byte 196,226,125,51,210 // vpmovzxwd %xmm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,210 // vmulps %ymm10,%ymm2,%ymm2 .byte 196,193,49,109,219 // vpunpckhqdq %xmm11,%xmm9,%xmm3 .byte 197,185,113,243,8 // vpsllw $0x8,%xmm3,%xmm8 .byte 197,225,113,211,8 // vpsrlw $0x8,%xmm3,%xmm3 .byte 197,185,235,219 // vpor %xmm3,%xmm8,%xmm3 .byte 196,226,125,51,219 // vpmovzxwd %xmm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,218 // vmulps %ymm10,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,65,123,16,4,65 // vmovsd (%r9,%rax,2),%xmm8 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,85 // je 467a <_sk_load_u16_be_hsw+0x159> .byte 196,65,57,22,68,65,8 // vmovhpd 0x8(%r9,%rax,2),%xmm8,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,72 // jb 467a <_sk_load_u16_be_hsw+0x159> .byte 196,193,123,16,84,65,16 // vmovsd 0x10(%r9,%rax,2),%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 116,72 // je 4687 <_sk_load_u16_be_hsw+0x166> .byte 196,193,105,22,84,65,24 // vmovhpd 0x18(%r9,%rax,2),%xmm2,%xmm2 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,59 // jb 4687 <_sk_load_u16_be_hsw+0x166> .byte 196,193,123,16,92,65,32 // vmovsd 0x20(%r9,%rax,2),%xmm3 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 15,132,6,255,255,255 // je 4563 <_sk_load_u16_be_hsw+0x42> .byte 196,193,97,22,92,65,40 // vmovhpd 0x28(%r9,%rax,2),%xmm3,%xmm3 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,130,245,254,255,255 // jb 4563 <_sk_load_u16_be_hsw+0x42> .byte 196,65,122,126,76,65,48 // vmovq 0x30(%r9,%rax,2),%xmm9 .byte 233,233,254,255,255 // jmpq 4563 <_sk_load_u16_be_hsw+0x42> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 197,233,87,210 // vxorpd %xmm2,%xmm2,%xmm2 .byte 233,220,254,255,255 // jmpq 4563 <_sk_load_u16_be_hsw+0x42> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 233,211,254,255,255 // jmpq 4563 <_sk_load_u16_be_hsw+0x42> HIDDEN _sk_load_rgb_u16_be_hsw .globl _sk_load_rgb_u16_be_hsw FUNCTION(_sk_load_rgb_u16_be_hsw) _sk_load_rgb_u16_be_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,137,208 // mov %rdx,%rax .byte 72,193,224,32 // shl $0x20,%rax .byte 72,141,4,64 // lea (%rax,%rax,2),%rax .byte 72,193,248,32 // sar $0x20,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,204,0,0,0 // jne 4787 <_sk_load_rgb_u16_be_hsw+0xf7> .byte 196,193,122,111,4,65 // vmovdqu (%r9,%rax,2),%xmm0 .byte 196,193,122,111,84,65,12 // vmovdqu 0xc(%r9,%rax,2),%xmm2 .byte 196,193,122,111,76,65,24 // vmovdqu 0x18(%r9,%rax,2),%xmm1 .byte 196,193,122,111,92,65,32 // vmovdqu 0x20(%r9,%rax,2),%xmm3 .byte 197,225,115,219,4 // vpsrldq $0x4,%xmm3,%xmm3 .byte 197,185,115,216,6 // vpsrldq $0x6,%xmm0,%xmm8 .byte 197,177,115,218,6 // vpsrldq $0x6,%xmm2,%xmm9 .byte 197,161,115,217,6 // vpsrldq $0x6,%xmm1,%xmm11 .byte 197,169,115,219,6 // vpsrldq $0x6,%xmm3,%xmm10 .byte 197,249,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm0 .byte 196,193,57,97,209 // vpunpcklwd %xmm9,%xmm8,%xmm2 .byte 197,241,97,203 // vpunpcklwd %xmm3,%xmm1,%xmm1 .byte 196,193,33,97,218 // vpunpcklwd %xmm10,%xmm11,%xmm3 .byte 197,121,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm8 .byte 197,121,105,202 // vpunpckhwd %xmm2,%xmm0,%xmm9 .byte 197,241,97,211 // vpunpcklwd %xmm3,%xmm1,%xmm2 .byte 197,241,105,219 // vpunpckhwd %xmm3,%xmm1,%xmm3 .byte 197,185,108,194 // vpunpcklqdq %xmm2,%xmm8,%xmm0 .byte 197,241,113,240,8 // vpsllw $0x8,%xmm0,%xmm1 .byte 197,249,113,208,8 // vpsrlw $0x8,%xmm0,%xmm0 .byte 197,241,235,192 // vpor %xmm0,%xmm1,%xmm0 .byte 196,226,125,51,192 // vpmovzxwd %xmm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,21,159,23,0,0 // vbroadcastss 0x179f(%rip),%ymm10 # 5ed4 <_sk_callback_hsw+0x4fa> .byte 196,193,124,89,194 // vmulps %ymm10,%ymm0,%ymm0 .byte 197,185,109,202 // vpunpckhqdq %xmm2,%xmm8,%xmm1 .byte 197,233,113,241,8 // vpsllw $0x8,%xmm1,%xmm2 .byte 197,241,113,209,8 // vpsrlw $0x8,%xmm1,%xmm1 .byte 197,233,235,201 // vpor %xmm1,%xmm2,%xmm1 .byte 196,226,125,51,201 // vpmovzxwd %xmm1,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,202 // vmulps %ymm10,%ymm1,%ymm1 .byte 197,177,108,211 // vpunpcklqdq %xmm3,%xmm9,%xmm2 .byte 197,225,113,242,8 // vpsllw $0x8,%xmm2,%xmm3 .byte 197,233,113,210,8 // vpsrlw $0x8,%xmm2,%xmm2 .byte 197,225,235,210 // vpor %xmm2,%xmm3,%xmm2 .byte 196,226,125,51,210 // vpmovzxwd %xmm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,210 // vmulps %ymm10,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,83,23,0,0 // vbroadcastss 0x1753(%rip),%ymm3 # 5ed8 <_sk_callback_hsw+0x4fe> .byte 255,224 // jmpq *%rax .byte 196,193,121,110,4,65 // vmovd (%r9,%rax,2),%xmm0 .byte 196,193,121,196,68,65,4,2 // vpinsrw $0x2,0x4(%r9,%rax,2),%xmm0,%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,5 // jne 47a0 <_sk_load_rgb_u16_be_hsw+0x110> .byte 233,79,255,255,255 // jmpq 46ef <_sk_load_rgb_u16_be_hsw+0x5f> .byte 196,193,121,110,76,65,6 // vmovd 0x6(%r9,%rax,2),%xmm1 .byte 196,65,113,196,68,65,10,2 // vpinsrw $0x2,0xa(%r9,%rax,2),%xmm1,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,26 // jb 47cf <_sk_load_rgb_u16_be_hsw+0x13f> .byte 196,193,121,110,76,65,12 // vmovd 0xc(%r9,%rax,2),%xmm1 .byte 196,193,113,196,84,65,16,2 // vpinsrw $0x2,0x10(%r9,%rax,2),%xmm1,%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 117,10 // jne 47d4 <_sk_load_rgb_u16_be_hsw+0x144> .byte 233,32,255,255,255 // jmpq 46ef <_sk_load_rgb_u16_be_hsw+0x5f> .byte 233,27,255,255,255 // jmpq 46ef <_sk_load_rgb_u16_be_hsw+0x5f> .byte 196,193,121,110,76,65,18 // vmovd 0x12(%r9,%rax,2),%xmm1 .byte 196,65,113,196,76,65,22,2 // vpinsrw $0x2,0x16(%r9,%rax,2),%xmm1,%xmm9 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,26 // jb 4803 <_sk_load_rgb_u16_be_hsw+0x173> .byte 196,193,121,110,76,65,24 // vmovd 0x18(%r9,%rax,2),%xmm1 .byte 196,193,113,196,76,65,28,2 // vpinsrw $0x2,0x1c(%r9,%rax,2),%xmm1,%xmm1 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 117,10 // jne 4808 <_sk_load_rgb_u16_be_hsw+0x178> .byte 233,236,254,255,255 // jmpq 46ef <_sk_load_rgb_u16_be_hsw+0x5f> .byte 233,231,254,255,255 // jmpq 46ef <_sk_load_rgb_u16_be_hsw+0x5f> .byte 196,193,121,110,92,65,30 // vmovd 0x1e(%r9,%rax,2),%xmm3 .byte 196,65,97,196,92,65,34,2 // vpinsrw $0x2,0x22(%r9,%rax,2),%xmm3,%xmm11 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,20 // jb 4831 <_sk_load_rgb_u16_be_hsw+0x1a1> .byte 196,193,121,110,92,65,36 // vmovd 0x24(%r9,%rax,2),%xmm3 .byte 196,193,97,196,92,65,40,2 // vpinsrw $0x2,0x28(%r9,%rax,2),%xmm3,%xmm3 .byte 233,190,254,255,255 // jmpq 46ef <_sk_load_rgb_u16_be_hsw+0x5f> .byte 233,185,254,255,255 // jmpq 46ef <_sk_load_rgb_u16_be_hsw+0x5f> HIDDEN _sk_store_u16_be_hsw .globl _sk_store_u16_be_hsw FUNCTION(_sk_store_u16_be_hsw) _sk_store_u16_be_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 196,98,125,24,5,127,22,0,0 // vbroadcastss 0x167f(%rip),%ymm8 # 5edc <_sk_callback_hsw+0x502> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,67,125,25,202,1 // vextractf128 $0x1,%ymm9,%xmm10 .byte 196,66,49,43,202 // vpackusdw %xmm10,%xmm9,%xmm9 .byte 196,193,41,113,241,8 // vpsllw $0x8,%xmm9,%xmm10 .byte 196,193,49,113,209,8 // vpsrlw $0x8,%xmm9,%xmm9 .byte 196,65,41,235,201 // vpor %xmm9,%xmm10,%xmm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,67,125,25,211,1 // vextractf128 $0x1,%ymm10,%xmm11 .byte 196,66,41,43,211 // vpackusdw %xmm11,%xmm10,%xmm10 .byte 196,193,33,113,242,8 // vpsllw $0x8,%xmm10,%xmm11 .byte 196,193,41,113,210,8 // vpsrlw $0x8,%xmm10,%xmm10 .byte 196,65,33,235,210 // vpor %xmm10,%xmm11,%xmm10 .byte 196,65,108,89,216 // vmulps %ymm8,%ymm2,%ymm11 .byte 196,65,125,91,219 // vcvtps2dq %ymm11,%ymm11 .byte 196,67,125,25,220,1 // vextractf128 $0x1,%ymm11,%xmm12 .byte 196,66,33,43,220 // vpackusdw %xmm12,%xmm11,%xmm11 .byte 196,193,25,113,243,8 // vpsllw $0x8,%xmm11,%xmm12 .byte 196,193,33,113,211,8 // vpsrlw $0x8,%xmm11,%xmm11 .byte 196,65,25,235,219 // vpor %xmm11,%xmm12,%xmm11 .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,67,125,25,196,1 // vextractf128 $0x1,%ymm8,%xmm12 .byte 196,66,57,43,196 // vpackusdw %xmm12,%xmm8,%xmm8 .byte 196,193,25,113,240,8 // vpsllw $0x8,%xmm8,%xmm12 .byte 196,193,57,113,208,8 // vpsrlw $0x8,%xmm8,%xmm8 .byte 196,65,25,235,192 // vpor %xmm8,%xmm12,%xmm8 .byte 196,65,49,97,226 // vpunpcklwd %xmm10,%xmm9,%xmm12 .byte 196,65,49,105,234 // vpunpckhwd %xmm10,%xmm9,%xmm13 .byte 196,65,33,97,200 // vpunpcklwd %xmm8,%xmm11,%xmm9 .byte 196,65,33,105,192 // vpunpckhwd %xmm8,%xmm11,%xmm8 .byte 196,65,25,98,217 // vpunpckldq %xmm9,%xmm12,%xmm11 .byte 196,65,25,106,209 // vpunpckhdq %xmm9,%xmm12,%xmm10 .byte 196,65,17,98,200 // vpunpckldq %xmm8,%xmm13,%xmm9 .byte 196,65,17,106,192 // vpunpckhdq %xmm8,%xmm13,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,31 // jne 4941 <_sk_store_u16_be_hsw+0x10b> .byte 196,65,120,17,28,65 // vmovups %xmm11,(%r9,%rax,2) .byte 196,65,120,17,84,65,16 // vmovups %xmm10,0x10(%r9,%rax,2) .byte 196,65,120,17,76,65,32 // vmovups %xmm9,0x20(%r9,%rax,2) .byte 196,65,122,127,68,65,48 // vmovdqu %xmm8,0x30(%r9,%rax,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,65,121,214,28,65 // vmovq %xmm11,(%r9,%rax,2) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,240 // je 493d <_sk_store_u16_be_hsw+0x107> .byte 196,65,121,23,92,65,8 // vmovhpd %xmm11,0x8(%r9,%rax,2) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,227 // jb 493d <_sk_store_u16_be_hsw+0x107> .byte 196,65,121,214,84,65,16 // vmovq %xmm10,0x10(%r9,%rax,2) .byte 116,218 // je 493d <_sk_store_u16_be_hsw+0x107> .byte 196,65,121,23,84,65,24 // vmovhpd %xmm10,0x18(%r9,%rax,2) .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,205 // jb 493d <_sk_store_u16_be_hsw+0x107> .byte 196,65,121,214,76,65,32 // vmovq %xmm9,0x20(%r9,%rax,2) .byte 116,196 // je 493d <_sk_store_u16_be_hsw+0x107> .byte 196,65,121,23,76,65,40 // vmovhpd %xmm9,0x28(%r9,%rax,2) .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,183 // jb 493d <_sk_store_u16_be_hsw+0x107> .byte 196,65,121,214,68,65,48 // vmovq %xmm8,0x30(%r9,%rax,2) .byte 235,174 // jmp 493d <_sk_store_u16_be_hsw+0x107> HIDDEN _sk_load_f32_hsw .globl _sk_load_f32_hsw FUNCTION(_sk_load_f32_hsw) _sk_load_f32_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,135,128,0,0,0 // ja 4a1b <_sk_load_f32_hsw+0x8c> .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 77,99,210 // movslq %r10d,%r10 .byte 76,141,29,133,0,0,0 // lea 0x85(%rip),%r11 # 4a44 <_sk_load_f32_hsw+0xb5> .byte 75,99,4,131 // movslq (%r11,%r8,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,3,125,24,68,145,112,1 // vinsertf128 $0x1,0x70(%r9,%r10,4),%ymm0,%ymm8 .byte 196,131,125,24,92,145,96,1 // vinsertf128 $0x1,0x60(%r9,%r10,4),%ymm0,%ymm3 .byte 196,131,125,24,76,145,80,1 // vinsertf128 $0x1,0x50(%r9,%r10,4),%ymm0,%ymm1 .byte 196,131,125,24,84,145,64,1 // vinsertf128 $0x1,0x40(%r9,%r10,4),%ymm0,%ymm2 .byte 196,129,121,16,68,145,48 // vmovupd 0x30(%r9,%r10,4),%xmm0 .byte 196,195,125,13,192,12 // vblendpd $0xc,%ymm8,%ymm0,%ymm0 .byte 196,1,121,16,68,145,32 // vmovupd 0x20(%r9,%r10,4),%xmm8 .byte 196,99,61,13,203,12 // vblendpd $0xc,%ymm3,%ymm8,%ymm9 .byte 196,129,121,16,92,145,16 // vmovupd 0x10(%r9,%r10,4),%xmm3 .byte 196,99,101,13,209,12 // vblendpd $0xc,%ymm1,%ymm3,%ymm10 .byte 196,129,121,16,12,145 // vmovupd (%r9,%r10,4),%xmm1 .byte 196,227,117,13,202,12 // vblendpd $0xc,%ymm2,%ymm1,%ymm1 .byte 196,193,116,20,210 // vunpcklps %ymm10,%ymm1,%ymm2 .byte 196,193,116,21,218 // vunpckhps %ymm10,%ymm1,%ymm3 .byte 197,180,20,200 // vunpcklps %ymm0,%ymm9,%ymm1 .byte 197,52,21,192 // vunpckhps %ymm0,%ymm9,%ymm8 .byte 197,237,20,193 // vunpcklpd %ymm1,%ymm2,%ymm0 .byte 197,237,21,201 // vunpckhpd %ymm1,%ymm2,%ymm1 .byte 196,193,101,20,208 // vunpcklpd %ymm8,%ymm3,%ymm2 .byte 196,193,101,21,216 // vunpckhpd %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 144 // nop .byte 132,255 // test %bh,%bh .byte 255 // (bad) .byte 255,203 // dec %ebx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 190,255,255,255,177 // mov $0xb1ffffff,%esi .byte 255 // (bad) .byte 255 // (bad) .byte 255,164,255,255,255,156,255 // jmpq *-0x630001(%rdi,%rdi,8) .byte 255 // (bad) .byte 255,148,255,255,255,140,255 // callq *-0x730001(%rdi,%rdi,8) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_f32_dst_hsw .globl _sk_load_f32_dst_hsw FUNCTION(_sk_load_f32_dst_hsw) _sk_load_f32_dst_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,135,128,0,0,0 // ja 4af0 <_sk_load_f32_dst_hsw+0x8c> .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 77,99,210 // movslq %r10d,%r10 .byte 76,141,29,132,0,0,0 // lea 0x84(%rip),%r11 # 4b18 <_sk_load_f32_dst_hsw+0xb4> .byte 75,99,4,131 // movslq (%r11,%r8,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,3,125,24,68,145,112,1 // vinsertf128 $0x1,0x70(%r9,%r10,4),%ymm0,%ymm8 .byte 196,131,125,24,124,145,96,1 // vinsertf128 $0x1,0x60(%r9,%r10,4),%ymm0,%ymm7 .byte 196,131,125,24,108,145,80,1 // vinsertf128 $0x1,0x50(%r9,%r10,4),%ymm0,%ymm5 .byte 196,131,125,24,116,145,64,1 // vinsertf128 $0x1,0x40(%r9,%r10,4),%ymm0,%ymm6 .byte 196,129,121,16,100,145,48 // vmovupd 0x30(%r9,%r10,4),%xmm4 .byte 196,195,93,13,224,12 // vblendpd $0xc,%ymm8,%ymm4,%ymm4 .byte 196,1,121,16,68,145,32 // vmovupd 0x20(%r9,%r10,4),%xmm8 .byte 196,99,61,13,207,12 // vblendpd $0xc,%ymm7,%ymm8,%ymm9 .byte 196,129,121,16,124,145,16 // vmovupd 0x10(%r9,%r10,4),%xmm7 .byte 196,99,69,13,213,12 // vblendpd $0xc,%ymm5,%ymm7,%ymm10 .byte 196,129,121,16,44,145 // vmovupd (%r9,%r10,4),%xmm5 .byte 196,227,85,13,238,12 // vblendpd $0xc,%ymm6,%ymm5,%ymm5 .byte 196,193,84,20,242 // vunpcklps %ymm10,%ymm5,%ymm6 .byte 196,193,84,21,250 // vunpckhps %ymm10,%ymm5,%ymm7 .byte 197,180,20,236 // vunpcklps %ymm4,%ymm9,%ymm5 .byte 197,52,21,196 // vunpckhps %ymm4,%ymm9,%ymm8 .byte 197,205,20,229 // vunpcklpd %ymm5,%ymm6,%ymm4 .byte 197,205,21,237 // vunpckhpd %ymm5,%ymm6,%ymm5 .byte 196,193,69,20,240 // vunpcklpd %ymm8,%ymm7,%ymm6 .byte 196,193,69,21,248 // vunpckhpd %ymm8,%ymm7,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 133,255 // test %edi,%edi .byte 255 // (bad) .byte 255,204 // dec %esp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 191,255,255,255,178 // mov $0xb2ffffff,%edi .byte 255 // (bad) .byte 255 // (bad) .byte 255,165,255,255,255,157 // jmpq *-0x62000001(%rbp) .byte 255 // (bad) .byte 255 // (bad) .byte 255,149,255,255,255,141 // callq *-0x72000001(%rbp) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_store_f32_hsw .globl _sk_store_f32_hsw FUNCTION(_sk_store_f32_hsw) _sk_store_f32_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 197,124,20,193 // vunpcklps %ymm1,%ymm0,%ymm8 .byte 197,124,21,217 // vunpckhps %ymm1,%ymm0,%ymm11 .byte 197,108,20,203 // vunpcklps %ymm3,%ymm2,%ymm9 .byte 197,108,21,227 // vunpckhps %ymm3,%ymm2,%ymm12 .byte 196,65,61,20,209 // vunpcklpd %ymm9,%ymm8,%ymm10 .byte 196,65,61,21,201 // vunpckhpd %ymm9,%ymm8,%ymm9 .byte 196,65,37,20,196 // vunpcklpd %ymm12,%ymm11,%ymm8 .byte 196,65,37,21,220 // vunpckhpd %ymm12,%ymm11,%ymm11 .byte 77,133,192 // test %r8,%r8 .byte 117,55 // jne 4bb7 <_sk_store_f32_hsw+0x7f> .byte 196,67,45,24,225,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm12 .byte 196,67,61,24,235,1 // vinsertf128 $0x1,%xmm11,%ymm8,%ymm13 .byte 196,67,45,6,201,49 // vperm2f128 $0x31,%ymm9,%ymm10,%ymm9 .byte 196,67,61,6,195,49 // vperm2f128 $0x31,%ymm11,%ymm8,%ymm8 .byte 196,65,125,17,36,129 // vmovupd %ymm12,(%r9,%rax,4) .byte 196,65,125,17,108,129,32 // vmovupd %ymm13,0x20(%r9,%rax,4) .byte 196,65,125,17,76,129,64 // vmovupd %ymm9,0x40(%r9,%rax,4) .byte 196,65,125,17,68,129,96 // vmovupd %ymm8,0x60(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,65,121,17,20,129 // vmovupd %xmm10,(%r9,%rax,4) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,240 // je 4bb3 <_sk_store_f32_hsw+0x7b> .byte 196,65,121,17,76,129,16 // vmovupd %xmm9,0x10(%r9,%rax,4) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,227 // jb 4bb3 <_sk_store_f32_hsw+0x7b> .byte 196,65,121,17,68,129,32 // vmovupd %xmm8,0x20(%r9,%rax,4) .byte 116,218 // je 4bb3 <_sk_store_f32_hsw+0x7b> .byte 196,65,121,17,92,129,48 // vmovupd %xmm11,0x30(%r9,%rax,4) .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,205 // jb 4bb3 <_sk_store_f32_hsw+0x7b> .byte 196,67,125,25,84,129,64,1 // vextractf128 $0x1,%ymm10,0x40(%r9,%rax,4) .byte 116,195 // je 4bb3 <_sk_store_f32_hsw+0x7b> .byte 196,67,125,25,76,129,80,1 // vextractf128 $0x1,%ymm9,0x50(%r9,%rax,4) .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,181 // jb 4bb3 <_sk_store_f32_hsw+0x7b> .byte 196,67,125,25,68,129,96,1 // vextractf128 $0x1,%ymm8,0x60(%r9,%rax,4) .byte 235,171 // jmp 4bb3 <_sk_store_f32_hsw+0x7b> HIDDEN _sk_clamp_x_hsw .globl _sk_clamp_x_hsw FUNCTION(_sk_clamp_x_hsw) _sk_clamp_x_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,188,95,192 // vmaxps %ymm0,%ymm8,%ymm0 .byte 196,98,125,88,0 // vpbroadcastd (%rax),%ymm8 .byte 196,65,53,118,201 // vpcmpeqd %ymm9,%ymm9,%ymm9 .byte 196,65,61,254,193 // vpaddd %ymm9,%ymm8,%ymm8 .byte 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_y_hsw .globl _sk_clamp_y_hsw FUNCTION(_sk_clamp_y_hsw) _sk_clamp_y_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,188,95,201 // vmaxps %ymm1,%ymm8,%ymm1 .byte 196,98,125,88,0 // vpbroadcastd (%rax),%ymm8 .byte 196,65,53,118,201 // vpcmpeqd %ymm9,%ymm9,%ymm9 .byte 196,65,61,254,193 // vpaddd %ymm9,%ymm8,%ymm8 .byte 196,193,116,93,200 // vminps %ymm8,%ymm1,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_x_hsw .globl _sk_repeat_x_hsw FUNCTION(_sk_repeat_x_hsw) _sk_repeat_x_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,4 // vbroadcastss 0x4(%rax),%ymm8 .byte 197,60,89,192 // vmulps %ymm0,%ymm8,%ymm8 .byte 196,67,125,8,192,1 // vroundps $0x1,%ymm8,%ymm8 .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 196,98,53,172,192 // vfnmadd213ps %ymm0,%ymm9,%ymm8 .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 196,193,124,95,192 // vmaxps %ymm8,%ymm0,%ymm0 .byte 196,65,61,118,192 // vpcmpeqd %ymm8,%ymm8,%ymm8 .byte 196,65,53,254,192 // vpaddd %ymm8,%ymm9,%ymm8 .byte 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_y_hsw .globl _sk_repeat_y_hsw FUNCTION(_sk_repeat_y_hsw) _sk_repeat_y_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,4 // vbroadcastss 0x4(%rax),%ymm8 .byte 197,60,89,193 // vmulps %ymm1,%ymm8,%ymm8 .byte 196,67,125,8,192,1 // vroundps $0x1,%ymm8,%ymm8 .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 196,98,53,172,193 // vfnmadd213ps %ymm1,%ymm9,%ymm8 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 196,193,116,95,200 // vmaxps %ymm8,%ymm1,%ymm1 .byte 196,65,61,118,192 // vpcmpeqd %ymm8,%ymm8,%ymm8 .byte 196,65,53,254,192 // vpaddd %ymm8,%ymm9,%ymm8 .byte 196,193,116,93,200 // vminps %ymm8,%ymm1,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_x_hsw .globl _sk_mirror_x_hsw FUNCTION(_sk_mirror_x_hsw) _sk_mirror_x_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,122,16,0 // vmovss (%rax),%xmm8 .byte 197,122,16,72,4 // vmovss 0x4(%rax),%xmm9 .byte 196,66,125,24,208 // vbroadcastss %xmm8,%ymm10 .byte 196,65,124,92,218 // vsubps %ymm10,%ymm0,%ymm11 .byte 196,193,58,88,192 // vaddss %xmm8,%xmm8,%xmm0 .byte 196,98,125,24,192 // vbroadcastss %xmm0,%ymm8 .byte 197,178,89,5,251,17,0,0 // vmulss 0x11fb(%rip),%xmm9,%xmm0 # 5ee0 <_sk_callback_hsw+0x506> .byte 196,226,125,24,192 // vbroadcastss %xmm0,%ymm0 .byte 197,164,89,192 // vmulps %ymm0,%ymm11,%ymm0 .byte 196,227,125,8,192,1 // vroundps $0x1,%ymm0,%ymm0 .byte 196,194,61,172,195 // vfnmadd213ps %ymm11,%ymm8,%ymm0 .byte 196,193,124,92,194 // vsubps %ymm10,%ymm0,%ymm0 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,92,200 // vsubps %ymm0,%ymm8,%ymm9 .byte 197,180,84,192 // vandps %ymm0,%ymm9,%ymm0 .byte 197,188,95,192 // vmaxps %ymm0,%ymm8,%ymm0 .byte 196,65,61,118,192 // vpcmpeqd %ymm8,%ymm8,%ymm8 .byte 196,65,45,254,192 // vpaddd %ymm8,%ymm10,%ymm8 .byte 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_y_hsw .globl _sk_mirror_y_hsw FUNCTION(_sk_mirror_y_hsw) _sk_mirror_y_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,122,16,0 // vmovss (%rax),%xmm8 .byte 197,122,16,72,4 // vmovss 0x4(%rax),%xmm9 .byte 196,66,125,24,208 // vbroadcastss %xmm8,%ymm10 .byte 196,65,116,92,218 // vsubps %ymm10,%ymm1,%ymm11 .byte 196,193,58,88,200 // vaddss %xmm8,%xmm8,%xmm1 .byte 196,98,125,24,193 // vbroadcastss %xmm1,%ymm8 .byte 197,178,89,13,155,17,0,0 // vmulss 0x119b(%rip),%xmm9,%xmm1 # 5ee4 <_sk_callback_hsw+0x50a> .byte 196,226,125,24,201 // vbroadcastss %xmm1,%ymm1 .byte 197,164,89,201 // vmulps %ymm1,%ymm11,%ymm1 .byte 196,227,125,8,201,1 // vroundps $0x1,%ymm1,%ymm1 .byte 196,194,61,172,203 // vfnmadd213ps %ymm11,%ymm8,%ymm1 .byte 196,193,116,92,202 // vsubps %ymm10,%ymm1,%ymm1 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,92,201 // vsubps %ymm1,%ymm8,%ymm9 .byte 197,180,84,201 // vandps %ymm1,%ymm9,%ymm1 .byte 197,188,95,201 // vmaxps %ymm1,%ymm8,%ymm1 .byte 196,65,61,118,192 // vpcmpeqd %ymm8,%ymm8,%ymm8 .byte 196,65,45,254,192 // vpaddd %ymm8,%ymm10,%ymm8 .byte 196,193,116,93,200 // vminps %ymm8,%ymm1,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_x_1_hsw .globl _sk_clamp_x_1_hsw FUNCTION(_sk_clamp_x_1_hsw) _sk_clamp_x_1_hsw: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,188,95,192 // vmaxps %ymm0,%ymm8,%ymm0 .byte 196,98,125,24,5,80,17,0,0 // vbroadcastss 0x1150(%rip),%ymm8 # 5ee8 <_sk_callback_hsw+0x50e> .byte 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_x_1_hsw .globl _sk_repeat_x_1_hsw FUNCTION(_sk_repeat_x_1_hsw) _sk_repeat_x_1_hsw: .byte 196,99,125,8,192,1 // vroundps $0x1,%ymm0,%ymm8 .byte 196,193,124,92,192 // vsubps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_x_1_hsw .globl _sk_mirror_x_1_hsw FUNCTION(_sk_mirror_x_1_hsw) _sk_mirror_x_1_hsw: .byte 196,98,125,24,5,51,17,0,0 // vbroadcastss 0x1133(%rip),%ymm8 # 5eec <_sk_callback_hsw+0x512> .byte 196,193,124,88,192 // vaddps %ymm8,%ymm0,%ymm0 .byte 196,98,125,24,13,41,17,0,0 // vbroadcastss 0x1129(%rip),%ymm9 # 5ef0 <_sk_callback_hsw+0x516> .byte 196,65,124,89,201 // vmulps %ymm9,%ymm0,%ymm9 .byte 196,67,125,8,201,1 // vroundps $0x1,%ymm9,%ymm9 .byte 196,65,52,88,201 // vaddps %ymm9,%ymm9,%ymm9 .byte 196,193,124,92,193 // vsubps %ymm9,%ymm0,%ymm0 .byte 196,193,124,88,192 // vaddps %ymm8,%ymm0,%ymm0 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,92,192 // vsubps %ymm0,%ymm8,%ymm8 .byte 197,188,84,192 // vandps %ymm0,%ymm8,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_luminance_to_alpha_hsw .globl _sk_luminance_to_alpha_hsw FUNCTION(_sk_luminance_to_alpha_hsw) _sk_luminance_to_alpha_hsw: .byte 196,226,125,24,29,249,16,0,0 // vbroadcastss 0x10f9(%rip),%ymm3 # 5ef4 <_sk_callback_hsw+0x51a> .byte 196,98,125,24,5,244,16,0,0 // vbroadcastss 0x10f4(%rip),%ymm8 # 5ef8 <_sk_callback_hsw+0x51e> .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 196,226,125,184,203 // vfmadd231ps %ymm3,%ymm0,%ymm1 .byte 196,226,125,24,29,229,16,0,0 // vbroadcastss 0x10e5(%rip),%ymm3 # 5efc <_sk_callback_hsw+0x522> .byte 196,226,109,168,217 // vfmadd213ps %ymm1,%ymm2,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,236,87,210 // vxorps %ymm2,%ymm2,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_translate_hsw .globl _sk_matrix_translate_hsw FUNCTION(_sk_matrix_translate_hsw) _sk_matrix_translate_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 197,188,88,192 // vaddps %ymm0,%ymm8,%ymm0 .byte 196,98,125,24,64,4 // vbroadcastss 0x4(%rax),%ymm8 .byte 197,188,88,201 // vaddps %ymm1,%ymm8,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_scale_translate_hsw .globl _sk_matrix_scale_translate_hsw FUNCTION(_sk_matrix_scale_translate_hsw) _sk_matrix_scale_translate_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,8 // vbroadcastss 0x8(%rax),%ymm8 .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 196,194,61,168,193 // vfmadd213ps %ymm9,%ymm8,%ymm0 .byte 196,98,125,24,64,12 // vbroadcastss 0xc(%rax),%ymm8 .byte 196,98,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm9 .byte 196,194,61,168,201 // vfmadd213ps %ymm9,%ymm8,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_2x3_hsw .globl _sk_matrix_2x3_hsw FUNCTION(_sk_matrix_2x3_hsw) _sk_matrix_2x3_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 196,98,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm10 .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,66,117,184,194 // vfmadd231ps %ymm10,%ymm1,%ymm8 .byte 196,66,125,184,193 // vfmadd231ps %ymm9,%ymm0,%ymm8 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,12 // vbroadcastss 0xc(%rax),%ymm11 .byte 196,98,125,24,72,20 // vbroadcastss 0x14(%rax),%ymm9 .byte 196,66,117,184,203 // vfmadd231ps %ymm11,%ymm1,%ymm9 .byte 196,66,125,184,202 // vfmadd231ps %ymm10,%ymm0,%ymm9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,124,41,201 // vmovaps %ymm9,%ymm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_3x4_hsw .globl _sk_matrix_3x4_hsw FUNCTION(_sk_matrix_3x4_hsw) _sk_matrix_3x4_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 196,98,125,24,80,12 // vbroadcastss 0xc(%rax),%ymm10 .byte 196,98,125,24,88,24 // vbroadcastss 0x18(%rax),%ymm11 .byte 196,98,125,24,64,36 // vbroadcastss 0x24(%rax),%ymm8 .byte 196,66,109,184,195 // vfmadd231ps %ymm11,%ymm2,%ymm8 .byte 196,66,117,184,194 // vfmadd231ps %ymm10,%ymm1,%ymm8 .byte 196,66,125,184,193 // vfmadd231ps %ymm9,%ymm0,%ymm8 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,16 // vbroadcastss 0x10(%rax),%ymm11 .byte 196,98,125,24,96,28 // vbroadcastss 0x1c(%rax),%ymm12 .byte 196,98,125,24,72,40 // vbroadcastss 0x28(%rax),%ymm9 .byte 196,66,109,184,204 // vfmadd231ps %ymm12,%ymm2,%ymm9 .byte 196,66,117,184,203 // vfmadd231ps %ymm11,%ymm1,%ymm9 .byte 196,66,125,184,202 // vfmadd231ps %ymm10,%ymm0,%ymm9 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 196,98,125,24,96,20 // vbroadcastss 0x14(%rax),%ymm12 .byte 196,98,125,24,104,32 // vbroadcastss 0x20(%rax),%ymm13 .byte 196,98,125,24,80,44 // vbroadcastss 0x2c(%rax),%ymm10 .byte 196,66,109,184,213 // vfmadd231ps %ymm13,%ymm2,%ymm10 .byte 196,66,117,184,212 // vfmadd231ps %ymm12,%ymm1,%ymm10 .byte 196,66,125,184,211 // vfmadd231ps %ymm11,%ymm0,%ymm10 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,124,41,201 // vmovaps %ymm9,%ymm1 .byte 197,124,41,210 // vmovaps %ymm10,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_4x5_hsw .globl _sk_matrix_4x5_hsw FUNCTION(_sk_matrix_4x5_hsw) _sk_matrix_4x5_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 196,98,125,24,80,16 // vbroadcastss 0x10(%rax),%ymm10 .byte 196,98,125,24,88,32 // vbroadcastss 0x20(%rax),%ymm11 .byte 196,98,125,24,96,48 // vbroadcastss 0x30(%rax),%ymm12 .byte 196,98,125,24,64,64 // vbroadcastss 0x40(%rax),%ymm8 .byte 196,66,101,184,196 // vfmadd231ps %ymm12,%ymm3,%ymm8 .byte 196,66,109,184,195 // vfmadd231ps %ymm11,%ymm2,%ymm8 .byte 196,66,117,184,194 // vfmadd231ps %ymm10,%ymm1,%ymm8 .byte 196,66,125,184,193 // vfmadd231ps %ymm9,%ymm0,%ymm8 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,20 // vbroadcastss 0x14(%rax),%ymm11 .byte 196,98,125,24,96,36 // vbroadcastss 0x24(%rax),%ymm12 .byte 196,98,125,24,104,52 // vbroadcastss 0x34(%rax),%ymm13 .byte 196,98,125,24,72,68 // vbroadcastss 0x44(%rax),%ymm9 .byte 196,66,101,184,205 // vfmadd231ps %ymm13,%ymm3,%ymm9 .byte 196,66,109,184,204 // vfmadd231ps %ymm12,%ymm2,%ymm9 .byte 196,66,117,184,203 // vfmadd231ps %ymm11,%ymm1,%ymm9 .byte 196,66,125,184,202 // vfmadd231ps %ymm10,%ymm0,%ymm9 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 196,98,125,24,96,24 // vbroadcastss 0x18(%rax),%ymm12 .byte 196,98,125,24,104,40 // vbroadcastss 0x28(%rax),%ymm13 .byte 196,98,125,24,112,56 // vbroadcastss 0x38(%rax),%ymm14 .byte 196,98,125,24,80,72 // vbroadcastss 0x48(%rax),%ymm10 .byte 196,66,101,184,214 // vfmadd231ps %ymm14,%ymm3,%ymm10 .byte 196,66,109,184,213 // vfmadd231ps %ymm13,%ymm2,%ymm10 .byte 196,66,117,184,212 // vfmadd231ps %ymm12,%ymm1,%ymm10 .byte 196,66,125,184,211 // vfmadd231ps %ymm11,%ymm0,%ymm10 .byte 196,98,125,24,96,12 // vbroadcastss 0xc(%rax),%ymm12 .byte 196,98,125,24,104,28 // vbroadcastss 0x1c(%rax),%ymm13 .byte 196,98,125,24,112,44 // vbroadcastss 0x2c(%rax),%ymm14 .byte 196,98,125,24,120,60 // vbroadcastss 0x3c(%rax),%ymm15 .byte 196,98,125,24,88,76 // vbroadcastss 0x4c(%rax),%ymm11 .byte 196,66,101,184,223 // vfmadd231ps %ymm15,%ymm3,%ymm11 .byte 196,66,109,184,222 // vfmadd231ps %ymm14,%ymm2,%ymm11 .byte 196,66,117,184,221 // vfmadd231ps %ymm13,%ymm1,%ymm11 .byte 196,66,125,184,220 // vfmadd231ps %ymm12,%ymm0,%ymm11 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,124,41,201 // vmovaps %ymm9,%ymm1 .byte 197,124,41,210 // vmovaps %ymm10,%ymm2 .byte 197,124,41,219 // vmovaps %ymm11,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_4x3_hsw .globl _sk_matrix_4x3_hsw FUNCTION(_sk_matrix_4x3_hsw) _sk_matrix_4x3_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,16 // vbroadcastss (%rax),%ymm2 .byte 196,226,125,24,88,16 // vbroadcastss 0x10(%rax),%ymm3 .byte 196,98,125,24,64,32 // vbroadcastss 0x20(%rax),%ymm8 .byte 196,98,117,184,195 // vfmadd231ps %ymm3,%ymm1,%ymm8 .byte 196,98,125,184,194 // vfmadd231ps %ymm2,%ymm0,%ymm8 .byte 196,226,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm2 .byte 196,226,125,24,88,20 // vbroadcastss 0x14(%rax),%ymm3 .byte 196,98,125,24,72,36 // vbroadcastss 0x24(%rax),%ymm9 .byte 196,98,117,184,203 // vfmadd231ps %ymm3,%ymm1,%ymm9 .byte 196,98,125,184,202 // vfmadd231ps %ymm2,%ymm0,%ymm9 .byte 196,226,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm3 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 196,226,125,24,80,40 // vbroadcastss 0x28(%rax),%ymm2 .byte 196,194,117,184,210 // vfmadd231ps %ymm10,%ymm1,%ymm2 .byte 196,226,125,184,211 // vfmadd231ps %ymm3,%ymm0,%ymm2 .byte 196,98,125,24,80,12 // vbroadcastss 0xc(%rax),%ymm10 .byte 196,98,125,24,88,28 // vbroadcastss 0x1c(%rax),%ymm11 .byte 196,226,125,24,88,44 // vbroadcastss 0x2c(%rax),%ymm3 .byte 196,194,117,184,219 // vfmadd231ps %ymm11,%ymm1,%ymm3 .byte 196,194,125,184,218 // vfmadd231ps %ymm10,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,124,41,201 // vmovaps %ymm9,%ymm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_perspective_hsw .globl _sk_matrix_perspective_hsw FUNCTION(_sk_matrix_perspective_hsw) _sk_matrix_perspective_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 196,98,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm9 .byte 196,98,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm10 .byte 196,66,117,184,209 // vfmadd231ps %ymm9,%ymm1,%ymm10 .byte 196,66,125,184,208 // vfmadd231ps %ymm8,%ymm0,%ymm10 .byte 196,98,125,24,64,12 // vbroadcastss 0xc(%rax),%ymm8 .byte 196,98,125,24,72,16 // vbroadcastss 0x10(%rax),%ymm9 .byte 196,98,125,24,88,20 // vbroadcastss 0x14(%rax),%ymm11 .byte 196,66,117,184,217 // vfmadd231ps %ymm9,%ymm1,%ymm11 .byte 196,66,125,184,216 // vfmadd231ps %ymm8,%ymm0,%ymm11 .byte 196,98,125,24,64,24 // vbroadcastss 0x18(%rax),%ymm8 .byte 196,98,125,24,72,28 // vbroadcastss 0x1c(%rax),%ymm9 .byte 196,98,125,24,96,32 // vbroadcastss 0x20(%rax),%ymm12 .byte 196,66,117,184,225 // vfmadd231ps %ymm9,%ymm1,%ymm12 .byte 196,66,125,184,224 // vfmadd231ps %ymm8,%ymm0,%ymm12 .byte 196,193,124,83,204 // vrcpps %ymm12,%ymm1 .byte 197,172,89,193 // vmulps %ymm1,%ymm10,%ymm0 .byte 197,164,89,201 // vmulps %ymm1,%ymm11,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_evenly_spaced_gradient_hsw .globl _sk_evenly_spaced_gradient_hsw FUNCTION(_sk_evenly_spaced_gradient_hsw) _sk_evenly_spaced_gradient_hsw: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,16 // mov (%rax),%r10 .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 77,137,211 // mov %r10,%r11 .byte 73,255,203 // dec %r11 .byte 120,7 // js 5110 <_sk_evenly_spaced_gradient_hsw+0x19> .byte 196,193,242,42,203 // vcvtsi2ss %r11,%xmm1,%xmm1 .byte 235,22 // jmp 5126 <_sk_evenly_spaced_gradient_hsw+0x2f> .byte 76,137,219 // mov %r11,%rbx .byte 72,209,235 // shr %rbx .byte 65,131,227,1 // and $0x1,%r11d .byte 73,9,219 // or %rbx,%r11 .byte 196,193,242,42,203 // vcvtsi2ss %r11,%xmm1,%xmm1 .byte 197,242,88,201 // vaddss %xmm1,%xmm1,%xmm1 .byte 196,226,125,24,201 // vbroadcastss %xmm1,%ymm1 .byte 197,244,89,200 // vmulps %ymm0,%ymm1,%ymm1 .byte 197,126,91,217 // vcvttps2dq %ymm1,%ymm11 .byte 73,131,250,8 // cmp $0x8,%r10 .byte 119,70 // ja 517f <_sk_evenly_spaced_gradient_hsw+0x88> .byte 196,66,37,22,1 // vpermps (%r9),%ymm11,%ymm8 .byte 72,139,88,40 // mov 0x28(%rax),%rbx .byte 196,98,37,22,11 // vpermps (%rbx),%ymm11,%ymm9 .byte 72,139,88,16 // mov 0x10(%rax),%rbx .byte 76,139,72,24 // mov 0x18(%rax),%r9 .byte 196,226,37,22,11 // vpermps (%rbx),%ymm11,%ymm1 .byte 72,139,88,48 // mov 0x30(%rax),%rbx .byte 196,98,37,22,19 // vpermps (%rbx),%ymm11,%ymm10 .byte 196,194,37,22,17 // vpermps (%r9),%ymm11,%ymm2 .byte 72,139,88,56 // mov 0x38(%rax),%rbx .byte 196,98,37,22,35 // vpermps (%rbx),%ymm11,%ymm12 .byte 72,139,88,32 // mov 0x20(%rax),%rbx .byte 196,226,37,22,27 // vpermps (%rbx),%ymm11,%ymm3 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 196,98,37,22,40 // vpermps (%rax),%ymm11,%ymm13 .byte 235,110 // jmp 51ed <_sk_evenly_spaced_gradient_hsw+0xf6> .byte 196,65,13,118,246 // vpcmpeqd %ymm14,%ymm14,%ymm14 .byte 197,245,118,201 // vpcmpeqd %ymm1,%ymm1,%ymm1 .byte 196,2,117,146,4,153 // vgatherdps %ymm1,(%r9,%ymm11,4),%ymm8 .byte 72,139,88,40 // mov 0x28(%rax),%rbx .byte 197,245,118,201 // vpcmpeqd %ymm1,%ymm1,%ymm1 .byte 196,34,117,146,12,155 // vgatherdps %ymm1,(%rbx,%ymm11,4),%ymm9 .byte 72,139,88,16 // mov 0x10(%rax),%rbx .byte 76,139,72,24 // mov 0x18(%rax),%r9 .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 196,162,109,146,12,155 // vgatherdps %ymm2,(%rbx,%ymm11,4),%ymm1 .byte 72,139,88,48 // mov 0x30(%rax),%rbx .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 196,34,109,146,20,155 // vgatherdps %ymm2,(%rbx,%ymm11,4),%ymm10 .byte 197,229,118,219 // vpcmpeqd %ymm3,%ymm3,%ymm3 .byte 196,130,101,146,20,153 // vgatherdps %ymm3,(%r9,%ymm11,4),%ymm2 .byte 72,139,88,56 // mov 0x38(%rax),%rbx .byte 197,229,118,219 // vpcmpeqd %ymm3,%ymm3,%ymm3 .byte 196,34,101,146,36,155 // vgatherdps %ymm3,(%rbx,%ymm11,4),%ymm12 .byte 72,139,88,32 // mov 0x20(%rax),%rbx .byte 196,65,21,118,237 // vpcmpeqd %ymm13,%ymm13,%ymm13 .byte 196,162,21,146,28,155 // vgatherdps %ymm13,(%rbx,%ymm11,4),%ymm3 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 196,34,13,146,44,152 // vgatherdps %ymm14,(%rax,%ymm11,4),%ymm13 .byte 196,66,125,168,193 // vfmadd213ps %ymm9,%ymm0,%ymm8 .byte 196,194,125,168,202 // vfmadd213ps %ymm10,%ymm0,%ymm1 .byte 196,194,125,168,212 // vfmadd213ps %ymm12,%ymm0,%ymm2 .byte 196,194,125,168,221 // vfmadd213ps %ymm13,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_gauss_a_to_rgba_hsw .globl _sk_gauss_a_to_rgba_hsw FUNCTION(_sk_gauss_a_to_rgba_hsw) _sk_gauss_a_to_rgba_hsw: .byte 196,226,125,24,5,237,12,0,0 // vbroadcastss 0xced(%rip),%ymm0 # 5f00 <_sk_callback_hsw+0x526> .byte 196,226,125,24,13,232,12,0,0 // vbroadcastss 0xce8(%rip),%ymm1 # 5f04 <_sk_callback_hsw+0x52a> .byte 196,226,101,168,200 // vfmadd213ps %ymm0,%ymm3,%ymm1 .byte 196,226,125,24,5,222,12,0,0 // vbroadcastss 0xcde(%rip),%ymm0 # 5f08 <_sk_callback_hsw+0x52e> .byte 196,226,101,184,193 // vfmadd231ps %ymm1,%ymm3,%ymm0 .byte 196,226,125,24,13,212,12,0,0 // vbroadcastss 0xcd4(%rip),%ymm1 # 5f0c <_sk_callback_hsw+0x532> .byte 196,226,101,184,200 // vfmadd231ps %ymm0,%ymm3,%ymm1 .byte 196,226,125,24,5,202,12,0,0 // vbroadcastss 0xcca(%rip),%ymm0 # 5f10 <_sk_callback_hsw+0x536> .byte 196,226,101,184,193 // vfmadd231ps %ymm1,%ymm3,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 197,252,40,216 // vmovaps %ymm0,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_gradient_hsw .globl _sk_gradient_hsw FUNCTION(_sk_gradient_hsw) _sk_gradient_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 73,131,249,1 // cmp $0x1,%r9 .byte 15,134,180,0,0,0 // jbe 531e <_sk_gradient_hsw+0xc3> .byte 76,139,80,72 // mov 0x48(%rax),%r10 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 65,187,1,0,0,0 // mov $0x1,%r11d .byte 196,226,125,24,21,147,12,0,0 // vbroadcastss 0xc93(%rip),%ymm2 # 5f14 <_sk_callback_hsw+0x53a> .byte 196,65,53,239,201 // vpxor %ymm9,%ymm9,%ymm9 .byte 196,130,125,24,28,154 // vbroadcastss (%r10,%r11,4),%ymm3 .byte 197,228,194,216,2 // vcmpleps %ymm0,%ymm3,%ymm3 .byte 196,227,117,74,218,48 // vblendvps %ymm3,%ymm2,%ymm1,%ymm3 .byte 196,65,101,254,201 // vpaddd %ymm9,%ymm3,%ymm9 .byte 73,255,195 // inc %r11 .byte 77,57,217 // cmp %r11,%r9 .byte 117,226 // jne 5286 <_sk_gradient_hsw+0x2b> .byte 76,139,80,8 // mov 0x8(%rax),%r10 .byte 73,131,249,8 // cmp $0x8,%r9 .byte 118,121 // jbe 5327 <_sk_gradient_hsw+0xcc> .byte 196,65,13,118,246 // vpcmpeqd %ymm14,%ymm14,%ymm14 .byte 197,245,118,201 // vpcmpeqd %ymm1,%ymm1,%ymm1 .byte 196,2,117,146,4,138 // vgatherdps %ymm1,(%r10,%ymm9,4),%ymm8 .byte 76,139,72,40 // mov 0x28(%rax),%r9 .byte 197,245,118,201 // vpcmpeqd %ymm1,%ymm1,%ymm1 .byte 196,2,117,146,20,137 // vgatherdps %ymm1,(%r9,%ymm9,4),%ymm10 .byte 76,139,72,16 // mov 0x10(%rax),%r9 .byte 76,139,80,24 // mov 0x18(%rax),%r10 .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 196,130,109,146,12,137 // vgatherdps %ymm2,(%r9,%ymm9,4),%ymm1 .byte 76,139,72,48 // mov 0x30(%rax),%r9 .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 196,2,109,146,28,137 // vgatherdps %ymm2,(%r9,%ymm9,4),%ymm11 .byte 197,229,118,219 // vpcmpeqd %ymm3,%ymm3,%ymm3 .byte 196,130,101,146,20,138 // vgatherdps %ymm3,(%r10,%ymm9,4),%ymm2 .byte 76,139,72,56 // mov 0x38(%rax),%r9 .byte 197,229,118,219 // vpcmpeqd %ymm3,%ymm3,%ymm3 .byte 196,2,101,146,36,137 // vgatherdps %ymm3,(%r9,%ymm9,4),%ymm12 .byte 76,139,72,32 // mov 0x20(%rax),%r9 .byte 196,65,21,118,237 // vpcmpeqd %ymm13,%ymm13,%ymm13 .byte 196,130,21,146,28,137 // vgatherdps %ymm13,(%r9,%ymm9,4),%ymm3 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 196,34,13,146,44,136 // vgatherdps %ymm14,(%rax,%ymm9,4),%ymm13 .byte 235,77 // jmp 536b <_sk_gradient_hsw+0x110> .byte 76,139,80,8 // mov 0x8(%rax),%r10 .byte 196,65,52,87,201 // vxorps %ymm9,%ymm9,%ymm9 .byte 196,66,53,22,2 // vpermps (%r10),%ymm9,%ymm8 .byte 76,139,72,40 // mov 0x28(%rax),%r9 .byte 196,66,53,22,17 // vpermps (%r9),%ymm9,%ymm10 .byte 76,139,72,16 // mov 0x10(%rax),%r9 .byte 76,139,80,24 // mov 0x18(%rax),%r10 .byte 196,194,53,22,9 // vpermps (%r9),%ymm9,%ymm1 .byte 76,139,72,48 // mov 0x30(%rax),%r9 .byte 196,66,53,22,25 // vpermps (%r9),%ymm9,%ymm11 .byte 196,194,53,22,18 // vpermps (%r10),%ymm9,%ymm2 .byte 76,139,72,56 // mov 0x38(%rax),%r9 .byte 196,66,53,22,33 // vpermps (%r9),%ymm9,%ymm12 .byte 76,139,72,32 // mov 0x20(%rax),%r9 .byte 196,194,53,22,25 // vpermps (%r9),%ymm9,%ymm3 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 196,98,53,22,40 // vpermps (%rax),%ymm9,%ymm13 .byte 196,66,125,168,194 // vfmadd213ps %ymm10,%ymm0,%ymm8 .byte 196,194,125,168,203 // vfmadd213ps %ymm11,%ymm0,%ymm1 .byte 196,194,125,168,212 // vfmadd213ps %ymm12,%ymm0,%ymm2 .byte 196,194,125,168,221 // vfmadd213ps %ymm13,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_evenly_spaced_2_stop_gradient_hsw .globl _sk_evenly_spaced_2_stop_gradient_hsw FUNCTION(_sk_evenly_spaced_2_stop_gradient_hsw) _sk_evenly_spaced_2_stop_gradient_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,8 // vbroadcastss (%rax),%ymm1 .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,98,125,184,193 // vfmadd231ps %ymm1,%ymm0,%ymm8 .byte 196,226,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm2 .byte 196,226,125,24,72,20 // vbroadcastss 0x14(%rax),%ymm1 .byte 196,226,125,184,202 // vfmadd231ps %ymm2,%ymm0,%ymm1 .byte 196,226,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm3 .byte 196,226,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm2 .byte 196,226,125,184,211 // vfmadd231ps %ymm3,%ymm0,%ymm2 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,226,125,24,88,28 // vbroadcastss 0x1c(%rax),%ymm3 .byte 196,194,125,184,217 // vfmadd231ps %ymm9,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_unit_angle_hsw .globl _sk_xy_to_unit_angle_hsw FUNCTION(_sk_xy_to_unit_angle_hsw) _sk_xy_to_unit_angle_hsw: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,92,200 // vsubps %ymm0,%ymm8,%ymm9 .byte 197,52,84,200 // vandps %ymm0,%ymm9,%ymm9 .byte 197,60,92,209 // vsubps %ymm1,%ymm8,%ymm10 .byte 197,44,84,209 // vandps %ymm1,%ymm10,%ymm10 .byte 196,65,52,93,218 // vminps %ymm10,%ymm9,%ymm11 .byte 196,65,52,95,226 // vmaxps %ymm10,%ymm9,%ymm12 .byte 196,65,36,94,220 // vdivps %ymm12,%ymm11,%ymm11 .byte 196,65,36,89,227 // vmulps %ymm11,%ymm11,%ymm12 .byte 196,98,125,24,45,18,11,0,0 // vbroadcastss 0xb12(%rip),%ymm13 # 5f18 <_sk_callback_hsw+0x53e> .byte 196,98,125,24,53,13,11,0,0 // vbroadcastss 0xb0d(%rip),%ymm14 # 5f1c <_sk_callback_hsw+0x542> .byte 196,66,29,184,245 // vfmadd231ps %ymm13,%ymm12,%ymm14 .byte 196,98,125,24,45,3,11,0,0 // vbroadcastss 0xb03(%rip),%ymm13 # 5f20 <_sk_callback_hsw+0x546> .byte 196,66,29,184,238 // vfmadd231ps %ymm14,%ymm12,%ymm13 .byte 196,98,125,24,53,249,10,0,0 // vbroadcastss 0xaf9(%rip),%ymm14 # 5f24 <_sk_callback_hsw+0x54a> .byte 196,66,29,184,245 // vfmadd231ps %ymm13,%ymm12,%ymm14 .byte 196,65,36,89,222 // vmulps %ymm14,%ymm11,%ymm11 .byte 196,65,52,194,202,1 // vcmpltps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,21,228,10,0,0 // vbroadcastss 0xae4(%rip),%ymm10 # 5f28 <_sk_callback_hsw+0x54e> .byte 196,65,44,92,211 // vsubps %ymm11,%ymm10,%ymm10 .byte 196,67,37,74,202,144 // vblendvps %ymm9,%ymm10,%ymm11,%ymm9 .byte 196,193,124,194,192,1 // vcmpltps %ymm8,%ymm0,%ymm0 .byte 196,98,125,24,21,206,10,0,0 // vbroadcastss 0xace(%rip),%ymm10 # 5f2c <_sk_callback_hsw+0x552> .byte 196,65,44,92,209 // vsubps %ymm9,%ymm10,%ymm10 .byte 196,195,53,74,194,0 // vblendvps %ymm0,%ymm10,%ymm9,%ymm0 .byte 196,65,116,194,200,1 // vcmpltps %ymm8,%ymm1,%ymm9 .byte 196,98,125,24,21,184,10,0,0 // vbroadcastss 0xab8(%rip),%ymm10 # 5f30 <_sk_callback_hsw+0x556> .byte 197,44,92,208 // vsubps %ymm0,%ymm10,%ymm10 .byte 196,195,125,74,194,144 // vblendvps %ymm9,%ymm10,%ymm0,%ymm0 .byte 196,65,124,194,200,3 // vcmpunordps %ymm8,%ymm0,%ymm9 .byte 196,195,125,74,192,144 // vblendvps %ymm9,%ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_radius_hsw .globl _sk_xy_to_radius_hsw FUNCTION(_sk_xy_to_radius_hsw) _sk_xy_to_radius_hsw: .byte 197,116,89,193 // vmulps %ymm1,%ymm1,%ymm8 .byte 196,98,125,184,192 // vfmadd231ps %ymm0,%ymm0,%ymm8 .byte 196,193,124,81,192 // vsqrtps %ymm8,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_quadratic_max_hsw .globl _sk_xy_to_2pt_conical_quadratic_max_hsw FUNCTION(_sk_xy_to_2pt_conical_quadratic_max_hsw) _sk_xy_to_2pt_conical_quadratic_max_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,32 // vbroadcastss 0x20(%rax),%ymm8 .byte 197,122,16,72,40 // vmovss 0x28(%rax),%xmm9 .byte 197,50,89,80,44 // vmulss 0x2c(%rax),%xmm9,%xmm10 .byte 196,66,125,24,210 // vbroadcastss %xmm10,%ymm10 .byte 197,44,88,208 // vaddps %ymm0,%ymm10,%ymm10 .byte 196,98,125,24,29,108,10,0,0 // vbroadcastss 0xa6c(%rip),%ymm11 # 5f34 <_sk_callback_hsw+0x55a> .byte 196,65,44,89,211 // vmulps %ymm11,%ymm10,%ymm10 .byte 197,116,89,217 // vmulps %ymm1,%ymm1,%ymm11 .byte 196,98,125,184,216 // vfmadd231ps %ymm0,%ymm0,%ymm11 .byte 196,193,50,89,193 // vmulss %xmm9,%xmm9,%xmm0 .byte 196,226,125,24,192 // vbroadcastss %xmm0,%ymm0 .byte 197,164,92,192 // vsubps %ymm0,%ymm11,%ymm0 .byte 196,98,125,24,13,75,10,0,0 // vbroadcastss 0xa4b(%rip),%ymm9 # 5f38 <_sk_callback_hsw+0x55e> .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 196,194,45,184,194 // vfmadd231ps %ymm10,%ymm10,%ymm0 .byte 197,252,81,192 // vsqrtps %ymm0,%ymm0 .byte 196,98,125,24,64,36 // vbroadcastss 0x24(%rax),%ymm8 .byte 196,98,125,24,13,46,10,0,0 // vbroadcastss 0xa2e(%rip),%ymm9 # 5f3c <_sk_callback_hsw+0x562> .byte 196,65,44,87,201 // vxorps %ymm9,%ymm10,%ymm9 .byte 196,65,124,92,210 // vsubps %ymm10,%ymm0,%ymm10 .byte 196,98,125,24,29,31,10,0,0 // vbroadcastss 0xa1f(%rip),%ymm11 # 5f40 <_sk_callback_hsw+0x566> .byte 196,65,60,89,195 // vmulps %ymm11,%ymm8,%ymm8 .byte 196,65,44,89,208 // vmulps %ymm8,%ymm10,%ymm10 .byte 197,180,92,192 // vsubps %ymm0,%ymm9,%ymm0 .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,172,95,192 // vmaxps %ymm0,%ymm10,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_quadratic_min_hsw .globl _sk_xy_to_2pt_conical_quadratic_min_hsw FUNCTION(_sk_xy_to_2pt_conical_quadratic_min_hsw) _sk_xy_to_2pt_conical_quadratic_min_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,32 // vbroadcastss 0x20(%rax),%ymm8 .byte 197,122,16,72,40 // vmovss 0x28(%rax),%xmm9 .byte 197,50,89,80,44 // vmulss 0x2c(%rax),%xmm9,%xmm10 .byte 196,66,125,24,210 // vbroadcastss %xmm10,%ymm10 .byte 197,44,88,208 // vaddps %ymm0,%ymm10,%ymm10 .byte 196,98,125,24,29,228,9,0,0 // vbroadcastss 0x9e4(%rip),%ymm11 # 5f44 <_sk_callback_hsw+0x56a> .byte 196,65,44,89,211 // vmulps %ymm11,%ymm10,%ymm10 .byte 197,116,89,217 // vmulps %ymm1,%ymm1,%ymm11 .byte 196,98,125,184,216 // vfmadd231ps %ymm0,%ymm0,%ymm11 .byte 196,193,50,89,193 // vmulss %xmm9,%xmm9,%xmm0 .byte 196,226,125,24,192 // vbroadcastss %xmm0,%ymm0 .byte 197,164,92,192 // vsubps %ymm0,%ymm11,%ymm0 .byte 196,98,125,24,13,195,9,0,0 // vbroadcastss 0x9c3(%rip),%ymm9 # 5f48 <_sk_callback_hsw+0x56e> .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 196,194,45,184,194 // vfmadd231ps %ymm10,%ymm10,%ymm0 .byte 197,252,81,192 // vsqrtps %ymm0,%ymm0 .byte 196,98,125,24,64,36 // vbroadcastss 0x24(%rax),%ymm8 .byte 196,98,125,24,13,166,9,0,0 // vbroadcastss 0x9a6(%rip),%ymm9 # 5f4c <_sk_callback_hsw+0x572> .byte 196,65,44,87,201 // vxorps %ymm9,%ymm10,%ymm9 .byte 196,65,124,92,210 // vsubps %ymm10,%ymm0,%ymm10 .byte 196,98,125,24,29,151,9,0,0 // vbroadcastss 0x997(%rip),%ymm11 # 5f50 <_sk_callback_hsw+0x576> .byte 196,65,60,89,195 // vmulps %ymm11,%ymm8,%ymm8 .byte 196,65,44,89,208 // vmulps %ymm8,%ymm10,%ymm10 .byte 197,180,92,192 // vsubps %ymm0,%ymm9,%ymm0 .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,172,93,192 // vminps %ymm0,%ymm10,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_linear_hsw .globl _sk_xy_to_2pt_conical_linear_hsw FUNCTION(_sk_xy_to_2pt_conical_linear_hsw) _sk_xy_to_2pt_conical_linear_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,122,16,64,40 // vmovss 0x28(%rax),%xmm8 .byte 197,58,89,72,44 // vmulss 0x2c(%rax),%xmm8,%xmm9 .byte 196,66,125,24,201 // vbroadcastss %xmm9,%ymm9 .byte 197,52,88,200 // vaddps %ymm0,%ymm9,%ymm9 .byte 196,98,125,24,21,98,9,0,0 // vbroadcastss 0x962(%rip),%ymm10 # 5f54 <_sk_callback_hsw+0x57a> .byte 196,65,52,89,202 // vmulps %ymm10,%ymm9,%ymm9 .byte 197,116,89,209 // vmulps %ymm1,%ymm1,%ymm10 .byte 196,98,125,184,208 // vfmadd231ps %ymm0,%ymm0,%ymm10 .byte 196,193,58,89,192 // vmulss %xmm8,%xmm8,%xmm0 .byte 196,226,125,24,192 // vbroadcastss %xmm0,%ymm0 .byte 197,172,92,192 // vsubps %ymm0,%ymm10,%ymm0 .byte 196,98,125,24,5,65,9,0,0 // vbroadcastss 0x941(%rip),%ymm8 # 5f58 <_sk_callback_hsw+0x57e> .byte 196,193,124,87,192 // vxorps %ymm8,%ymm0,%ymm0 .byte 196,193,124,94,193 // vdivps %ymm9,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mask_2pt_conical_degenerates_hsw .globl _sk_mask_2pt_conical_degenerates_hsw FUNCTION(_sk_mask_2pt_conical_degenerates_hsw) _sk_mask_2pt_conical_degenerates_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,44 // vbroadcastss 0x2c(%rax),%ymm8 .byte 196,98,125,24,72,40 // vbroadcastss 0x28(%rax),%ymm9 .byte 196,66,125,184,200 // vfmadd231ps %ymm8,%ymm0,%ymm9 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,65,60,194,201,2 // vcmpleps %ymm9,%ymm8,%ymm9 .byte 196,65,124,194,192,7 // vcmpordps %ymm8,%ymm0,%ymm8 .byte 196,65,52,84,192 // vandps %ymm8,%ymm9,%ymm8 .byte 197,124,17,0 // vmovups %ymm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_apply_vector_mask_hsw .globl _sk_apply_vector_mask_hsw FUNCTION(_sk_apply_vector_mask_hsw) _sk_apply_vector_mask_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,16,0 // vmovups (%rax),%ymm8 .byte 197,188,84,192 // vandps %ymm0,%ymm8,%ymm0 .byte 197,188,84,201 // vandps %ymm1,%ymm8,%ymm1 .byte 197,188,84,210 // vandps %ymm2,%ymm8,%ymm2 .byte 197,188,84,219 // vandps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_save_xy_hsw .globl _sk_save_xy_hsw FUNCTION(_sk_save_xy_hsw) _sk_save_xy_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,5,225,8,0,0 // vbroadcastss 0x8e1(%rip),%ymm8 # 5f5c <_sk_callback_hsw+0x582> .byte 196,65,124,88,200 // vaddps %ymm8,%ymm0,%ymm9 .byte 196,67,125,8,209,1 // vroundps $0x1,%ymm9,%ymm10 .byte 196,65,52,92,202 // vsubps %ymm10,%ymm9,%ymm9 .byte 196,65,116,88,192 // vaddps %ymm8,%ymm1,%ymm8 .byte 196,67,125,8,208,1 // vroundps $0x1,%ymm8,%ymm10 .byte 196,65,60,92,194 // vsubps %ymm10,%ymm8,%ymm8 .byte 197,252,17,0 // vmovups %ymm0,(%rax) .byte 197,252,17,72,32 // vmovups %ymm1,0x20(%rax) .byte 197,124,17,72,64 // vmovups %ymm9,0x40(%rax) .byte 197,124,17,64,96 // vmovups %ymm8,0x60(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_accumulate_hsw .globl _sk_accumulate_hsw FUNCTION(_sk_accumulate_hsw) _sk_accumulate_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,16,128,128,0,0,0 // vmovups 0x80(%rax),%ymm8 .byte 197,60,89,128,160,0,0,0 // vmulps 0xa0(%rax),%ymm8,%ymm8 .byte 196,226,61,184,224 // vfmadd231ps %ymm0,%ymm8,%ymm4 .byte 196,226,61,184,233 // vfmadd231ps %ymm1,%ymm8,%ymm5 .byte 196,226,61,184,242 // vfmadd231ps %ymm2,%ymm8,%ymm6 .byte 196,98,101,168,199 // vfmadd213ps %ymm7,%ymm3,%ymm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,199 // vmovaps %ymm8,%ymm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_nx_hsw .globl _sk_bilinear_nx_hsw FUNCTION(_sk_bilinear_nx_hsw) _sk_bilinear_nx_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,117,8,0,0 // vbroadcastss 0x875(%rip),%ymm0 # 5f60 <_sk_callback_hsw+0x586> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 196,98,125,24,5,108,8,0,0 // vbroadcastss 0x86c(%rip),%ymm8 # 5f64 <_sk_callback_hsw+0x58a> .byte 197,60,92,64,64 // vsubps 0x40(%rax),%ymm8,%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_px_hsw .globl _sk_bilinear_px_hsw FUNCTION(_sk_bilinear_px_hsw) _sk_bilinear_px_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,84,8,0,0 // vbroadcastss 0x854(%rip),%ymm0 # 5f68 <_sk_callback_hsw+0x58e> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 197,124,16,64,64 // vmovups 0x40(%rax),%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_ny_hsw .globl _sk_bilinear_ny_hsw FUNCTION(_sk_bilinear_ny_hsw) _sk_bilinear_ny_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,56,8,0,0 // vbroadcastss 0x838(%rip),%ymm1 # 5f6c <_sk_callback_hsw+0x592> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 196,98,125,24,5,46,8,0,0 // vbroadcastss 0x82e(%rip),%ymm8 # 5f70 <_sk_callback_hsw+0x596> .byte 197,60,92,64,96 // vsubps 0x60(%rax),%ymm8,%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_py_hsw .globl _sk_bilinear_py_hsw FUNCTION(_sk_bilinear_py_hsw) _sk_bilinear_py_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,22,8,0,0 // vbroadcastss 0x816(%rip),%ymm1 # 5f74 <_sk_callback_hsw+0x59a> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 197,124,16,64,96 // vmovups 0x60(%rax),%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n3x_hsw .globl _sk_bicubic_n3x_hsw FUNCTION(_sk_bicubic_n3x_hsw) _sk_bicubic_n3x_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,249,7,0,0 // vbroadcastss 0x7f9(%rip),%ymm0 # 5f78 <_sk_callback_hsw+0x59e> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 196,98,125,24,5,240,7,0,0 // vbroadcastss 0x7f0(%rip),%ymm8 # 5f7c <_sk_callback_hsw+0x5a2> .byte 197,60,92,64,64 // vsubps 0x40(%rax),%ymm8,%ymm8 .byte 196,65,60,89,200 // vmulps %ymm8,%ymm8,%ymm9 .byte 196,98,125,24,21,225,7,0,0 // vbroadcastss 0x7e1(%rip),%ymm10 # 5f80 <_sk_callback_hsw+0x5a6> .byte 196,98,125,24,29,220,7,0,0 // vbroadcastss 0x7dc(%rip),%ymm11 # 5f84 <_sk_callback_hsw+0x5aa> .byte 196,66,61,168,218 // vfmadd213ps %ymm10,%ymm8,%ymm11 .byte 196,65,36,89,193 // vmulps %ymm9,%ymm11,%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n1x_hsw .globl _sk_bicubic_n1x_hsw FUNCTION(_sk_bicubic_n1x_hsw) _sk_bicubic_n1x_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,191,7,0,0 // vbroadcastss 0x7bf(%rip),%ymm0 # 5f88 <_sk_callback_hsw+0x5ae> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 196,98,125,24,5,182,7,0,0 // vbroadcastss 0x7b6(%rip),%ymm8 # 5f8c <_sk_callback_hsw+0x5b2> .byte 197,60,92,64,64 // vsubps 0x40(%rax),%ymm8,%ymm8 .byte 196,98,125,24,13,172,7,0,0 // vbroadcastss 0x7ac(%rip),%ymm9 # 5f90 <_sk_callback_hsw+0x5b6> .byte 196,98,125,24,21,167,7,0,0 // vbroadcastss 0x7a7(%rip),%ymm10 # 5f94 <_sk_callback_hsw+0x5ba> .byte 196,66,61,168,209 // vfmadd213ps %ymm9,%ymm8,%ymm10 .byte 196,98,125,24,13,157,7,0,0 // vbroadcastss 0x79d(%rip),%ymm9 # 5f98 <_sk_callback_hsw+0x5be> .byte 196,66,61,184,202 // vfmadd231ps %ymm10,%ymm8,%ymm9 .byte 196,98,125,24,21,147,7,0,0 // vbroadcastss 0x793(%rip),%ymm10 # 5f9c <_sk_callback_hsw+0x5c2> .byte 196,66,61,184,209 // vfmadd231ps %ymm9,%ymm8,%ymm10 .byte 197,124,17,144,128,0,0,0 // vmovups %ymm10,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p1x_hsw .globl _sk_bicubic_p1x_hsw FUNCTION(_sk_bicubic_p1x_hsw) _sk_bicubic_p1x_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,5,123,7,0,0 // vbroadcastss 0x77b(%rip),%ymm8 # 5fa0 <_sk_callback_hsw+0x5c6> .byte 197,188,88,0 // vaddps (%rax),%ymm8,%ymm0 .byte 197,124,16,72,64 // vmovups 0x40(%rax),%ymm9 .byte 196,98,125,24,21,109,7,0,0 // vbroadcastss 0x76d(%rip),%ymm10 # 5fa4 <_sk_callback_hsw+0x5ca> .byte 196,98,125,24,29,104,7,0,0 // vbroadcastss 0x768(%rip),%ymm11 # 5fa8 <_sk_callback_hsw+0x5ce> .byte 196,66,53,168,218 // vfmadd213ps %ymm10,%ymm9,%ymm11 .byte 196,66,53,168,216 // vfmadd213ps %ymm8,%ymm9,%ymm11 .byte 196,98,125,24,5,89,7,0,0 // vbroadcastss 0x759(%rip),%ymm8 # 5fac <_sk_callback_hsw+0x5d2> .byte 196,66,53,184,195 // vfmadd231ps %ymm11,%ymm9,%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p3x_hsw .globl _sk_bicubic_p3x_hsw FUNCTION(_sk_bicubic_p3x_hsw) _sk_bicubic_p3x_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,65,7,0,0 // vbroadcastss 0x741(%rip),%ymm0 # 5fb0 <_sk_callback_hsw+0x5d6> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 197,124,16,64,64 // vmovups 0x40(%rax),%ymm8 .byte 196,65,60,89,200 // vmulps %ymm8,%ymm8,%ymm9 .byte 196,98,125,24,21,46,7,0,0 // vbroadcastss 0x72e(%rip),%ymm10 # 5fb4 <_sk_callback_hsw+0x5da> .byte 196,98,125,24,29,41,7,0,0 // vbroadcastss 0x729(%rip),%ymm11 # 5fb8 <_sk_callback_hsw+0x5de> .byte 196,66,61,168,218 // vfmadd213ps %ymm10,%ymm8,%ymm11 .byte 196,65,52,89,195 // vmulps %ymm11,%ymm9,%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n3y_hsw .globl _sk_bicubic_n3y_hsw FUNCTION(_sk_bicubic_n3y_hsw) _sk_bicubic_n3y_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,12,7,0,0 // vbroadcastss 0x70c(%rip),%ymm1 # 5fbc <_sk_callback_hsw+0x5e2> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 196,98,125,24,5,2,7,0,0 // vbroadcastss 0x702(%rip),%ymm8 # 5fc0 <_sk_callback_hsw+0x5e6> .byte 197,60,92,64,96 // vsubps 0x60(%rax),%ymm8,%ymm8 .byte 196,65,60,89,200 // vmulps %ymm8,%ymm8,%ymm9 .byte 196,98,125,24,21,243,6,0,0 // vbroadcastss 0x6f3(%rip),%ymm10 # 5fc4 <_sk_callback_hsw+0x5ea> .byte 196,98,125,24,29,238,6,0,0 // vbroadcastss 0x6ee(%rip),%ymm11 # 5fc8 <_sk_callback_hsw+0x5ee> .byte 196,66,61,168,218 // vfmadd213ps %ymm10,%ymm8,%ymm11 .byte 196,65,36,89,193 // vmulps %ymm9,%ymm11,%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n1y_hsw .globl _sk_bicubic_n1y_hsw FUNCTION(_sk_bicubic_n1y_hsw) _sk_bicubic_n1y_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,209,6,0,0 // vbroadcastss 0x6d1(%rip),%ymm1 # 5fcc <_sk_callback_hsw+0x5f2> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 196,98,125,24,5,199,6,0,0 // vbroadcastss 0x6c7(%rip),%ymm8 # 5fd0 <_sk_callback_hsw+0x5f6> .byte 197,60,92,64,96 // vsubps 0x60(%rax),%ymm8,%ymm8 .byte 196,98,125,24,13,189,6,0,0 // vbroadcastss 0x6bd(%rip),%ymm9 # 5fd4 <_sk_callback_hsw+0x5fa> .byte 196,98,125,24,21,184,6,0,0 // vbroadcastss 0x6b8(%rip),%ymm10 # 5fd8 <_sk_callback_hsw+0x5fe> .byte 196,66,61,168,209 // vfmadd213ps %ymm9,%ymm8,%ymm10 .byte 196,98,125,24,13,174,6,0,0 // vbroadcastss 0x6ae(%rip),%ymm9 # 5fdc <_sk_callback_hsw+0x602> .byte 196,66,61,184,202 // vfmadd231ps %ymm10,%ymm8,%ymm9 .byte 196,98,125,24,21,164,6,0,0 // vbroadcastss 0x6a4(%rip),%ymm10 # 5fe0 <_sk_callback_hsw+0x606> .byte 196,66,61,184,209 // vfmadd231ps %ymm9,%ymm8,%ymm10 .byte 197,124,17,144,160,0,0,0 // vmovups %ymm10,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p1y_hsw .globl _sk_bicubic_p1y_hsw FUNCTION(_sk_bicubic_p1y_hsw) _sk_bicubic_p1y_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,5,140,6,0,0 // vbroadcastss 0x68c(%rip),%ymm8 # 5fe4 <_sk_callback_hsw+0x60a> .byte 197,188,88,72,32 // vaddps 0x20(%rax),%ymm8,%ymm1 .byte 197,124,16,72,96 // vmovups 0x60(%rax),%ymm9 .byte 196,98,125,24,21,125,6,0,0 // vbroadcastss 0x67d(%rip),%ymm10 # 5fe8 <_sk_callback_hsw+0x60e> .byte 196,98,125,24,29,120,6,0,0 // vbroadcastss 0x678(%rip),%ymm11 # 5fec <_sk_callback_hsw+0x612> .byte 196,66,53,168,218 // vfmadd213ps %ymm10,%ymm9,%ymm11 .byte 196,66,53,168,216 // vfmadd213ps %ymm8,%ymm9,%ymm11 .byte 196,98,125,24,5,105,6,0,0 // vbroadcastss 0x669(%rip),%ymm8 # 5ff0 <_sk_callback_hsw+0x616> .byte 196,66,53,184,195 // vfmadd231ps %ymm11,%ymm9,%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p3y_hsw .globl _sk_bicubic_p3y_hsw FUNCTION(_sk_bicubic_p3y_hsw) _sk_bicubic_p3y_hsw: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,81,6,0,0 // vbroadcastss 0x651(%rip),%ymm1 # 5ff4 <_sk_callback_hsw+0x61a> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 197,124,16,64,96 // vmovups 0x60(%rax),%ymm8 .byte 196,65,60,89,200 // vmulps %ymm8,%ymm8,%ymm9 .byte 196,98,125,24,21,61,6,0,0 // vbroadcastss 0x63d(%rip),%ymm10 # 5ff8 <_sk_callback_hsw+0x61e> .byte 196,98,125,24,29,56,6,0,0 // vbroadcastss 0x638(%rip),%ymm11 # 5ffc <_sk_callback_hsw+0x622> .byte 196,66,61,168,218 // vfmadd213ps %ymm10,%ymm8,%ymm11 .byte 196,65,52,89,195 // vmulps %ymm11,%ymm9,%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_callback_hsw .globl _sk_callback_hsw FUNCTION(_sk_callback_hsw) _sk_callback_hsw: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,228,224 // and $0xffffffffffffffe0,%rsp .byte 72,129,236,192,0,0,0 // sub $0xc0,%rsp .byte 197,252,41,188,36,128,0,0,0 // vmovaps %ymm7,0x80(%rsp) .byte 197,252,41,116,36,96 // vmovaps %ymm6,0x60(%rsp) .byte 197,252,41,108,36,64 // vmovaps %ymm5,0x40(%rsp) .byte 197,252,41,100,36,32 // vmovaps %ymm4,0x20(%rsp) .byte 76,137,195 // mov %r8,%rbx .byte 72,137,76,36,24 // mov %rcx,0x18(%rsp) .byte 73,137,215 // mov %rdx,%r15 .byte 73,137,252 // mov %rdi,%r12 .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,137,198 // mov %rax,%r14 .byte 73,137,245 // mov %rsi,%r13 .byte 197,252,20,225 // vunpcklps %ymm1,%ymm0,%ymm4 .byte 197,252,21,193 // vunpckhps %ymm1,%ymm0,%ymm0 .byte 197,236,20,203 // vunpcklps %ymm3,%ymm2,%ymm1 .byte 197,236,21,211 // vunpckhps %ymm3,%ymm2,%ymm2 .byte 197,221,20,217 // vunpcklpd %ymm1,%ymm4,%ymm3 .byte 197,221,21,201 // vunpckhpd %ymm1,%ymm4,%ymm1 .byte 197,253,20,226 // vunpcklpd %ymm2,%ymm0,%ymm4 .byte 197,253,21,194 // vunpckhpd %ymm2,%ymm0,%ymm0 .byte 196,227,101,24,209,1 // vinsertf128 $0x1,%xmm1,%ymm3,%ymm2 .byte 196,227,93,24,232,1 // vinsertf128 $0x1,%xmm0,%ymm4,%ymm5 .byte 196,227,101,6,201,49 // vperm2f128 $0x31,%ymm1,%ymm3,%ymm1 .byte 196,227,93,6,192,49 // vperm2f128 $0x31,%ymm0,%ymm4,%ymm0 .byte 196,193,125,17,86,8 // vmovupd %ymm2,0x8(%r14) .byte 196,193,125,17,110,40 // vmovupd %ymm5,0x28(%r14) .byte 196,193,125,17,78,72 // vmovupd %ymm1,0x48(%r14) .byte 196,193,125,17,70,104 // vmovupd %ymm0,0x68(%r14) .byte 72,133,219 // test %rbx,%rbx .byte 190,8,0,0,0 // mov $0x8,%esi .byte 15,69,243 // cmovne %ebx,%esi .byte 76,137,247 // mov %r14,%rdi .byte 197,248,119 // vzeroupper .byte 65,255,22 // callq *(%r14) .byte 73,139,134,136,0,0,0 // mov 0x88(%r14),%rax .byte 197,248,16,0 // vmovups (%rax),%xmm0 .byte 197,248,16,72,16 // vmovups 0x10(%rax),%xmm1 .byte 197,248,16,80,32 // vmovups 0x20(%rax),%xmm2 .byte 197,248,16,88,48 // vmovups 0x30(%rax),%xmm3 .byte 196,227,101,24,88,112,1 // vinsertf128 $0x1,0x70(%rax),%ymm3,%ymm3 .byte 196,227,109,24,80,96,1 // vinsertf128 $0x1,0x60(%rax),%ymm2,%ymm2 .byte 196,227,117,24,72,80,1 // vinsertf128 $0x1,0x50(%rax),%ymm1,%ymm1 .byte 196,227,125,24,64,64,1 // vinsertf128 $0x1,0x40(%rax),%ymm0,%ymm0 .byte 197,252,20,225 // vunpcklps %ymm1,%ymm0,%ymm4 .byte 197,252,21,233 // vunpckhps %ymm1,%ymm0,%ymm5 .byte 197,236,20,203 // vunpcklps %ymm3,%ymm2,%ymm1 .byte 197,236,21,219 // vunpckhps %ymm3,%ymm2,%ymm3 .byte 197,221,20,193 // vunpcklpd %ymm1,%ymm4,%ymm0 .byte 197,221,21,201 // vunpckhpd %ymm1,%ymm4,%ymm1 .byte 197,213,20,211 // vunpcklpd %ymm3,%ymm5,%ymm2 .byte 197,213,21,219 // vunpckhpd %ymm3,%ymm5,%ymm3 .byte 76,137,238 // mov %r13,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,231 // mov %r12,%rdi .byte 76,137,250 // mov %r15,%rdx .byte 72,139,76,36,24 // mov 0x18(%rsp),%rcx .byte 73,137,216 // mov %rbx,%r8 .byte 197,252,40,100,36,32 // vmovaps 0x20(%rsp),%ymm4 .byte 197,252,40,108,36,64 // vmovaps 0x40(%rsp),%ymm5 .byte 197,252,40,116,36,96 // vmovaps 0x60(%rsp),%ymm6 .byte 197,252,40,188,36,128,0,0,0 // vmovaps 0x80(%rsp),%ymm7 .byte 72,141,101,216 // lea -0x28(%rbp),%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax BALIGN4 .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,1 // cmpb $0x1,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 252 // cld .byte 190,0,0,128,63 // mov $0x3f800000,%esi .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,191,0,0,224,64,154 // cmpb $0x9a,0x40e00000(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,174 // ds cmp $0xae3f170a,%eax .byte 71,225,61 // rex.RXB loope 5bd5 <.literal4+0xb9> .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,174 // ds cmp $0xae3f170a,%eax .byte 71,225,61 // rex.RXB loope 5be5 <.literal4+0xc9> .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,174 // ds cmp $0xae3f170a,%eax .byte 71,225,61 // rex.RXB loope 5bf5 <.literal4+0xd9> .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,174 // ds cmp $0xae3f170a,%eax .byte 71,225,61 // rex.RXB loope 5c05 <.literal4+0xe9> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,127 // add %al,0x7f00003f(%rax) .byte 67,0,0 // rex.XB add %al,(%r8) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,145,131,158 // add %al,-0x617c6ec1(%rax) .byte 61,92,143,50,63 // cmp $0x3f328f5c,%eax .byte 154 // (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,10,215 // ds or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,145,131,158,61 // cmp $0x3d9e8391,%eax .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 154 // (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,10,215 // ds or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,82,184,78,65 // cmp $0x414eb852,%eax .byte 186,159,98,60,57 // mov $0x393c629f,%edx .byte 215 // xlat %ds:(%rbx) .byte 32,187,109,165,144,63 // and %bh,0x3f90a56d(%rbx) .byte 252 // cld .byte 191,16,62,168,177 // mov $0xb1a83e10,%edi .byte 152 // cwtl .byte 59,0 // cmp (%rax),%eax .byte 0,128,63,0,0,192 // add %al,-0x3fffffc1(%rax) .byte 64,0,0 // add %al,(%rax) .byte 0,64,0 // add %al,0x0(%rax) .byte 0,128,64,171,170,42 // add %al,0x2aaaab40(%rax) .byte 62,0,0 // add %al,%ds:(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,64,171 // add %al,-0x55(%rax) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 0,0 // add %al,(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 128,64,171,170 // addb $0xaa,-0x55(%rax) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,129,128,128,59 // mov $0x3b808081,%esi .byte 129,128,128,59,0,248,0,0,8,33 // addl $0x21080000,-0x7ffc480(%rax) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 5c79 <.literal4+0x15d> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,129,128,128,59 // and %eax,0x3b808081(,%rdi,1) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 129,128,128,59,129,128,128,59,0,0 // addl $0x3b80,-0x7f7ec480(%rax) .byte 0,52,255 // add %dh,(%rdi,%rdi,8) .byte 255 // (bad) .byte 127,0 // jg 5ca0 <.literal4+0x184> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 5d19 <.literal4+0x1fd> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,128,63,0,0,0 // add %al,0x3f(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 5cd4 <.literal4+0x1b8> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 5d4d <.literal4+0x231> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,128,63,0,0,0 // add %al,0x3f(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 5d08 <.literal4+0x1ec> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 5d81 <.literal4+0x265> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,128,63,0,0,0 // add %al,0x3f(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 5d3c <.literal4+0x220> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 5db5 <.literal4+0x299> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,128,63,0,0,0 // add %al,0x3f(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 5d70 <.literal4+0x254> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 5de9 <.literal4+0x2cd> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,200 // add %cl,%al .byte 66,0,0 // rex.X add %al,(%rax) .byte 127,67 // jg 5de3 <.literal4+0x2c7> .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 128,65,203,61 // addb $0x3d,-0x35(%rcx) .byte 13,60,111,18,3 // or $0x3126f3c,%eax .byte 59,10 // cmp (%rdx),%ecx .byte 215 // xlat %ds:(%rbx) .byte 163,59,194,24,17,60,203,61,13 // movabs %eax,0xd3dcb3c1118c23b .byte 190,80,128,3,62 // mov $0x3e038050,%esi .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 5e03 <.literal4+0x2e7> .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 129,128,128,59,0,0,128,63,129,128 // addl $0x80813f80,0x3b80(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,128,63,129,128,128 // add %al,-0x7f7f7ec1(%rax) .byte 59,0 // cmp (%rax),%eax .byte 0,128,63,0,248,0 // add %al,0xf8003f(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,132,55,224,7,0,0 // and %eax,0x7e0(%rdi,%rsi,1) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,0,0,128,63 // and %eax,0x3f800000(,%rdi,1) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 5e1d <.literal4+0x301> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,0,0,128,63 // and %eax,0x3f800000(,%rdi,1) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 5e39 <.literal4+0x31d> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,0,0,128,63 // and %eax,0x3f800000(,%rdi,1) .byte 0,0 // add %al,(%rax) .byte 248 // clc .byte 65,0,0 // add %al,(%r8) .byte 124,66 // jl 5e8e <.literal4+0x372> .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,0,15 // mov %ecx,0xf003788(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,240,0 // mov %ecx,0xf03988(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,59,15,0 // mov %ecx,0xf3b88(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,61,0,240 // mov %ecx,-0xfffc278(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,0,15 // mov %ecx,0xf003788(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,240,0 // mov %ecx,0xf03988(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,59,15,0 // mov %ecx,0xf3b88(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,61,0,240 // mov %ecx,-0xfffc278(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,0,15 // mov %ecx,0xf003788(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,240,0 // mov %ecx,0xf03988(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,59,15,0 // mov %ecx,0xf3b88(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,61,0,0 // mov %ecx,0x3d88(%rax) .byte 112,65 // jo 5ef1 <.literal4+0x3d5> .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 255 // (bad) .byte 127,71 // jg 5f27 <.literal4+0x40b> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,191,0,0,0 // add %al,0xbf(%rax) .byte 63 // (bad) .byte 208 // (bad) .byte 179,89 // mov $0x59,%bl .byte 62,89 // ds pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 152 // cwtl .byte 221,147,61,18,120,57 // fstl 0x3978123d(%rbx) .byte 64,45,16,17,192,32 // rex sub $0x20c01110,%eax .byte 148 // xchg %eax,%esp .byte 90 // pop %rdx .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,0,24 // add %bl,%ds:(%rax) .byte 161,57,1,0,0,0,111,43,231 // movabs 0xe72b6f0000000139,%eax .byte 187,159,215,202,60 // mov $0x3ccad79f,%ebx .byte 212 // (bad) .byte 100,84 // fs push %rsp .byte 189,169,240,34,62 // mov $0x3e22f0a9,%ebp .byte 0,0 // add %al,(%rax) .byte 128,62,0 // cmpb $0x0,(%rsi) .byte 0,0 // add %al,(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,0,0 // rolb $0x0,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,63 // add %al,0x3f000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,128,63 // add %bh,0x3f800000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,128,63 // add %bh,0x3f800000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,191,0,0,128,63,171 // sarb $0xab,0x3f800000(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,114,28,199,62 // mov $0x3ec71c72,%esi .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,128,63 // add %bh,0x3f800000(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,63,85 // sarb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,0,0,0,63 // mov $0x3f000000,%edi .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,63,85 // sarb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,57,142,99,61 // mov $0x3d638e39,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,171 // sarb $0xab,(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,114,28,199,62 // mov $0x3ec71c72,%esi .byte 0,0 // add %al,(%rax) .byte 192,191,0,0,128,63,171 // sarb $0xab,0x3f800000(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,114,28,199,62 // mov $0x3ec71c72,%esi .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,128,63 // add %bh,0x3f800000(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,63,85 // sarb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,0,0,0,63 // mov $0x3f000000,%edi .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,63,85 // sarb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,57,142,99,61 // mov $0x3d638e39,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,171 // sarb $0xab,(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,114,28,199,62 // mov $0x3ec71c72,%esi BALIGN32 .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,255 // add %edi,%edi .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a006028 <_sk_callback_hsw+0xa00064e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,17 // decl 0x11ffffff(%rip) # 12006030 <_sk_callback_hsw+0x12000656> .byte 255 // (bad) .byte 255 // (bad) .byte 255,21,255,255,255,25 // callq *0x19ffffff(%rip) # 1a006038 <_sk_callback_hsw+0x1a00065e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,29,255,255,255,2 // lcall *0x2ffffff(%rip) # 3006040 <_sk_callback_hsw+0x3000666> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,18 // callq *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,22 // callq *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,26 // lcall *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,30 // lcall *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,255 // add %edi,%edi .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a006088 <_sk_callback_hsw+0xa0006ae> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,17 // decl 0x11ffffff(%rip) # 12006090 <_sk_callback_hsw+0x120006b6> .byte 255 // (bad) .byte 255 // (bad) .byte 255,21,255,255,255,25 // callq *0x19ffffff(%rip) # 1a006098 <_sk_callback_hsw+0x1a0006be> .byte 255 // (bad) .byte 255 // (bad) .byte 255,29,255,255,255,2 // lcall *0x2ffffff(%rip) # 30060a0 <_sk_callback_hsw+0x30006c6> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,18 // callq *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,22 // callq *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,26 // lcall *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,30 // lcall *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,255 // add %edi,%edi .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a0060e8 <_sk_callback_hsw+0xa00070e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,17 // decl 0x11ffffff(%rip) # 120060f0 <_sk_callback_hsw+0x12000716> .byte 255 // (bad) .byte 255 // (bad) .byte 255,21,255,255,255,25 // callq *0x19ffffff(%rip) # 1a0060f8 <_sk_callback_hsw+0x1a00071e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,29,255,255,255,2 // lcall *0x2ffffff(%rip) # 3006100 <_sk_callback_hsw+0x3000726> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,18 // callq *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,22 // callq *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,26 // lcall *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,30 // lcall *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,255 // add %edi,%edi .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a006148 <_sk_callback_hsw+0xa00076e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,17 // decl 0x11ffffff(%rip) # 12006150 <_sk_callback_hsw+0x12000776> .byte 255 // (bad) .byte 255 // (bad) .byte 255,21,255,255,255,25 // callq *0x19ffffff(%rip) # 1a006158 <_sk_callback_hsw+0x1a00077e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,29,255,255,255,2 // lcall *0x2ffffff(%rip) # 3006160 <_sk_callback_hsw+0x3000786> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,18 // callq *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,22 // callq *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,26 // lcall *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,30 // lcall *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,255 // add %edi,%edi .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a0061a8 <_sk_callback_hsw+0xa0007ce> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,17 // decl 0x11ffffff(%rip) # 120061b0 <_sk_callback_hsw+0x120007d6> .byte 255 // (bad) .byte 255 // (bad) .byte 255,21,255,255,255,25 // callq *0x19ffffff(%rip) # 1a0061b8 <_sk_callback_hsw+0x1a0007de> .byte 255 // (bad) .byte 255 // (bad) .byte 255,29,255,255,255,2 // lcall *0x2ffffff(%rip) # 30061c0 <_sk_callback_hsw+0x30007e6> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,18 // callq *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,22 // callq *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,26 // lcall *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,30 // lcall *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,255 // add %edi,%edi .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a006208 <_sk_callback_hsw+0xa00082e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,17 // decl 0x11ffffff(%rip) # 12006210 <_sk_callback_hsw+0x12000836> .byte 255 // (bad) .byte 255 // (bad) .byte 255,21,255,255,255,25 // callq *0x19ffffff(%rip) # 1a006218 <_sk_callback_hsw+0x1a00083e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,29,255,255,255,2 // lcall *0x2ffffff(%rip) # 3006220 <_sk_callback_hsw+0x3000846> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,18 // callq *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,22 // callq *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,26 // lcall *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,30 // lcall *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,255 // add %edi,%edi .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a006268 <_sk_callback_hsw+0xa00088e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,17 // decl 0x11ffffff(%rip) # 12006270 <_sk_callback_hsw+0x12000896> .byte 255 // (bad) .byte 255 // (bad) .byte 255,21,255,255,255,25 // callq *0x19ffffff(%rip) # 1a006278 <_sk_callback_hsw+0x1a00089e> .byte 255 // (bad) .byte 255 // (bad) .byte 255,29,255,255,255,2 // lcall *0x2ffffff(%rip) # 3006280 <_sk_callback_hsw+0x30008a6> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,18 // callq *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,22 // callq *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,26 // lcall *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,30 // lcall *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,255 // add %edi,%edi .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a0062c8 <_sk_callback_hsw+0xa0008ee> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,17 // decl 0x11ffffff(%rip) # 120062d0 <_sk_callback_hsw+0x120008f6> .byte 255 // (bad) .byte 255 // (bad) .byte 255,21,255,255,255,25 // callq *0x19ffffff(%rip) # 1a0062d8 <_sk_callback_hsw+0x1a0008fe> .byte 255 // (bad) .byte 255 // (bad) .byte 255,29,255,255,255,2 // lcall *0x2ffffff(%rip) # 30062e0 <_sk_callback_hsw+0x3000906> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,18 // callq *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,22 // callq *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,26 // lcall *(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,30 // lcall *(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff BALIGN16 .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,2 // add %al,(%rdx) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) BALIGN32 HIDDEN _sk_start_pipeline_avx .globl _sk_start_pipeline_avx FUNCTION(_sk_start_pipeline_avx) _sk_start_pipeline_avx: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,236,40 // sub $0x28,%rsp .byte 72,137,211 // mov %rdx,%rbx .byte 73,137,246 // mov %rsi,%r14 .byte 72,137,125,208 // mov %rdi,-0x30(%rbp) .byte 76,137,198 // mov %r8,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,137,194 // mov %rax,%rdx .byte 72,137,77,176 // mov %rcx,-0x50(%rbp) .byte 73,57,206 // cmp %rcx,%r14 .byte 115,117 // jae a1 <_sk_start_pipeline_avx+0xa1> .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,141,64,8 // lea 0x8(%rax),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 76,137,77,192 // mov %r9,-0x40(%rbp) .byte 72,137,85,200 // mov %rdx,-0x38(%rbp) .byte 73,137,221 // mov %rbx,%r13 .byte 73,137,244 // mov %rsi,%r12 .byte 72,139,85,208 // mov -0x30(%rbp),%rdx .byte 72,57,93,184 // cmp %rbx,-0x48(%rbp) .byte 119,45 // ja 7d <_sk_start_pipeline_avx+0x7d> .byte 76,139,125,208 // mov -0x30(%rbp),%r15 .byte 69,49,192 // xor %r8d,%r8d .byte 76,137,207 // mov %r9,%rdi .byte 76,137,230 // mov %r12,%rsi .byte 76,137,250 // mov %r15,%rdx .byte 76,137,241 // mov %r14,%rcx .byte 255,85,200 // callq *-0x38(%rbp) .byte 76,137,235 // mov %r13,%rbx .byte 76,139,77,192 // mov -0x40(%rbp),%r9 .byte 73,141,87,8 // lea 0x8(%r15),%rdx .byte 73,131,199,16 // add $0x10,%r15 .byte 73,57,223 // cmp %rbx,%r15 .byte 73,137,215 // mov %rdx,%r15 .byte 118,215 // jbe 54 <_sk_start_pipeline_avx+0x54> .byte 73,137,216 // mov %rbx,%r8 .byte 73,41,208 // sub %rdx,%r8 .byte 116,19 // je 98 <_sk_start_pipeline_avx+0x98> .byte 76,137,207 // mov %r9,%rdi .byte 76,137,230 // mov %r12,%rsi .byte 76,137,241 // mov %r14,%rcx .byte 255,85,200 // callq *-0x38(%rbp) .byte 76,137,235 // mov %r13,%rbx .byte 76,139,77,192 // mov -0x40(%rbp),%r9 .byte 73,255,198 // inc %r14 .byte 76,59,117,176 // cmp -0x50(%rbp),%r14 .byte 117,165 // jne 46 <_sk_start_pipeline_avx+0x46> .byte 72,131,196,40 // add $0x28,%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 197,248,119 // vzeroupper .byte 195 // retq HIDDEN _sk_just_return_avx .globl _sk_just_return_avx FUNCTION(_sk_just_return_avx) _sk_just_return_avx: .byte 195 // retq HIDDEN _sk_seed_shader_avx .globl _sk_seed_shader_avx FUNCTION(_sk_seed_shader_avx) _sk_seed_shader_avx: .byte 197,249,110,194 // vmovd %edx,%xmm0 .byte 197,249,112,192,0 // vpshufd $0x0,%xmm0,%xmm0 .byte 196,227,125,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,228,122,0,0 // vbroadcastss 0x7ae4(%rip),%ymm1 # 7bb4 <_sk_callback_avx+0x144> .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 197,252,88,7 // vaddps (%rdi),%ymm0,%ymm0 .byte 197,249,110,209 // vmovd %ecx,%xmm2 .byte 197,249,112,210,0 // vpshufd $0x0,%xmm2,%xmm2 .byte 196,227,109,24,210,1 // vinsertf128 $0x1,%xmm2,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 197,236,88,201 // vaddps %ymm1,%ymm2,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,21,190,122,0,0 // vbroadcastss 0x7abe(%rip),%ymm2 # 7bb8 <_sk_callback_avx+0x148> .byte 197,228,87,219 // vxorps %ymm3,%ymm3,%ymm3 .byte 197,220,87,228 // vxorps %ymm4,%ymm4,%ymm4 .byte 197,212,87,237 // vxorps %ymm5,%ymm5,%ymm5 .byte 197,204,87,246 // vxorps %ymm6,%ymm6,%ymm6 .byte 197,196,87,255 // vxorps %ymm7,%ymm7,%ymm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_dither_avx .globl _sk_dither_avx FUNCTION(_sk_dither_avx) _sk_dither_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,16,71,32 // vmovups 0x20(%rdi),%ymm8 .byte 196,67,125,25,193,1 // vextractf128 $0x1,%ymm8,%xmm9 .byte 197,121,110,210 // vmovd %edx,%xmm10 .byte 196,65,121,112,210,0 // vpshufd $0x0,%xmm10,%xmm10 .byte 196,65,49,254,202 // vpaddd %xmm10,%xmm9,%xmm9 .byte 196,65,57,254,194 // vpaddd %xmm10,%xmm8,%xmm8 .byte 196,67,61,24,193,1 // vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 .byte 197,121,110,201 // vmovd %ecx,%xmm9 .byte 196,65,121,112,201,0 // vpshufd $0x0,%xmm9,%xmm9 .byte 196,67,53,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm9,%ymm9 .byte 196,65,52,87,208 // vxorps %ymm8,%ymm9,%ymm10 .byte 196,98,125,24,29,103,122,0,0 // vbroadcastss 0x7a67(%rip),%ymm11 # 7bbc <_sk_callback_avx+0x14c> .byte 196,65,44,84,203 // vandps %ymm11,%ymm10,%ymm9 .byte 196,193,25,114,241,5 // vpslld $0x5,%xmm9,%xmm12 .byte 196,67,125,25,201,1 // vextractf128 $0x1,%ymm9,%xmm9 .byte 196,193,49,114,241,5 // vpslld $0x5,%xmm9,%xmm9 .byte 196,67,29,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm12,%ymm9 .byte 196,65,60,84,219 // vandps %ymm11,%ymm8,%ymm11 .byte 196,193,25,114,243,4 // vpslld $0x4,%xmm11,%xmm12 .byte 196,67,125,25,219,1 // vextractf128 $0x1,%ymm11,%xmm11 .byte 196,193,33,114,243,4 // vpslld $0x4,%xmm11,%xmm11 .byte 196,67,29,24,219,1 // vinsertf128 $0x1,%xmm11,%ymm12,%ymm11 .byte 196,98,125,24,37,40,122,0,0 // vbroadcastss 0x7a28(%rip),%ymm12 # 7bc0 <_sk_callback_avx+0x150> .byte 196,98,125,24,45,35,122,0,0 // vbroadcastss 0x7a23(%rip),%ymm13 # 7bc4 <_sk_callback_avx+0x154> .byte 196,65,44,84,245 // vandps %ymm13,%ymm10,%ymm14 .byte 196,193,1,114,246,2 // vpslld $0x2,%xmm14,%xmm15 .byte 196,67,125,25,246,1 // vextractf128 $0x1,%ymm14,%xmm14 .byte 196,193,9,114,246,2 // vpslld $0x2,%xmm14,%xmm14 .byte 196,67,5,24,246,1 // vinsertf128 $0x1,%xmm14,%ymm15,%ymm14 .byte 196,65,60,84,237 // vandps %ymm13,%ymm8,%ymm13 .byte 196,65,17,254,253 // vpaddd %xmm13,%xmm13,%xmm15 .byte 196,67,125,25,237,1 // vextractf128 $0x1,%ymm13,%xmm13 .byte 196,65,17,254,237 // vpaddd %xmm13,%xmm13,%xmm13 .byte 196,67,5,24,237,1 // vinsertf128 $0x1,%xmm13,%ymm15,%ymm13 .byte 196,65,44,84,212 // vandps %ymm12,%ymm10,%ymm10 .byte 196,193,1,114,210,1 // vpsrld $0x1,%xmm10,%xmm15 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,210,1 // vpsrld $0x1,%xmm10,%xmm10 .byte 196,67,5,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm15,%ymm10 .byte 196,65,60,84,196 // vandps %ymm12,%ymm8,%ymm8 .byte 196,193,25,114,208,2 // vpsrld $0x2,%xmm8,%xmm12 .byte 196,67,125,25,192,1 // vextractf128 $0x1,%ymm8,%xmm8 .byte 196,193,57,114,208,2 // vpsrld $0x2,%xmm8,%xmm8 .byte 196,67,29,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm12,%ymm8 .byte 196,65,20,86,219 // vorps %ymm11,%ymm13,%ymm11 .byte 196,65,36,86,192 // vorps %ymm8,%ymm11,%ymm8 .byte 196,65,52,86,206 // vorps %ymm14,%ymm9,%ymm9 .byte 196,65,60,86,193 // vorps %ymm9,%ymm8,%ymm8 .byte 196,65,60,86,194 // vorps %ymm10,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 196,98,125,24,13,142,121,0,0 // vbroadcastss 0x798e(%rip),%ymm9 # 7bc8 <_sk_callback_avx+0x158> .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 196,98,125,24,13,132,121,0,0 // vbroadcastss 0x7984(%rip),%ymm9 # 7bcc <_sk_callback_avx+0x15c> .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 196,65,52,89,192 // vmulps %ymm8,%ymm9,%ymm8 .byte 197,188,88,192 // vaddps %ymm0,%ymm8,%ymm0 .byte 197,188,88,201 // vaddps %ymm1,%ymm8,%ymm1 .byte 197,188,88,210 // vaddps %ymm2,%ymm8,%ymm2 .byte 197,252,93,195 // vminps %ymm3,%ymm0,%ymm0 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,188,95,192 // vmaxps %ymm0,%ymm8,%ymm0 .byte 197,244,93,203 // vminps %ymm3,%ymm1,%ymm1 .byte 197,188,95,201 // vmaxps %ymm1,%ymm8,%ymm1 .byte 197,236,93,211 // vminps %ymm3,%ymm2,%ymm2 .byte 197,188,95,210 // vmaxps %ymm2,%ymm8,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_uniform_color_avx .globl _sk_uniform_color_avx FUNCTION(_sk_uniform_color_avx) _sk_uniform_color_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,0 // vbroadcastss (%rax),%ymm0 .byte 196,226,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm1 .byte 196,226,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm2 .byte 196,226,125,24,88,12 // vbroadcastss 0xc(%rax),%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_black_color_avx .globl _sk_black_color_avx FUNCTION(_sk_black_color_avx) _sk_black_color_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,36,121,0,0 // vbroadcastss 0x7924(%rip),%ymm3 # 7bd0 <_sk_callback_avx+0x160> .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,236,87,210 // vxorps %ymm2,%ymm2,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_white_color_avx .globl _sk_white_color_avx FUNCTION(_sk_white_color_avx) _sk_white_color_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,15,121,0,0 // vbroadcastss 0x790f(%rip),%ymm0 # 7bd4 <_sk_callback_avx+0x164> .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 197,252,40,216 // vmovaps %ymm0,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_load_rgba_avx .globl _sk_load_rgba_avx FUNCTION(_sk_load_rgba_avx) _sk_load_rgba_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,0 // vmovups (%rax),%ymm0 .byte 197,252,16,72,32 // vmovups 0x20(%rax),%ymm1 .byte 197,252,16,80,64 // vmovups 0x40(%rax),%ymm2 .byte 197,252,16,88,96 // vmovups 0x60(%rax),%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_rgba_avx .globl _sk_store_rgba_avx FUNCTION(_sk_store_rgba_avx) _sk_store_rgba_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,17,0 // vmovups %ymm0,(%rax) .byte 197,252,17,72,32 // vmovups %ymm1,0x20(%rax) .byte 197,252,17,80,64 // vmovups %ymm2,0x40(%rax) .byte 197,252,17,88,96 // vmovups %ymm3,0x60(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clear_avx .globl _sk_clear_avx FUNCTION(_sk_clear_avx) _sk_clear_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,236,87,210 // vxorps %ymm2,%ymm2,%ymm2 .byte 197,228,87,219 // vxorps %ymm3,%ymm3,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcatop_avx .globl _sk_srcatop_avx FUNCTION(_sk_srcatop_avx) _sk_srcatop_avx: .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 196,98,125,24,5,178,120,0,0 // vbroadcastss 0x78b2(%rip),%ymm8 # 7bd8 <_sk_callback_avx+0x168> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,204 // vmulps %ymm4,%ymm8,%ymm9 .byte 197,180,88,192 // vaddps %ymm0,%ymm9,%ymm0 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 197,60,89,205 // vmulps %ymm5,%ymm8,%ymm9 .byte 197,180,88,201 // vaddps %ymm1,%ymm9,%ymm1 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 197,60,89,206 // vmulps %ymm6,%ymm8,%ymm9 .byte 197,180,88,210 // vaddps %ymm2,%ymm9,%ymm2 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 196,193,100,88,216 // vaddps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstatop_avx .globl _sk_dstatop_avx FUNCTION(_sk_dstatop_avx) _sk_dstatop_avx: .byte 197,100,89,196 // vmulps %ymm4,%ymm3,%ymm8 .byte 196,98,125,24,13,116,120,0,0 // vbroadcastss 0x7874(%rip),%ymm9 # 7bdc <_sk_callback_avx+0x16c> .byte 197,52,92,207 // vsubps %ymm7,%ymm9,%ymm9 .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 197,188,88,192 // vaddps %ymm0,%ymm8,%ymm0 .byte 197,100,89,197 // vmulps %ymm5,%ymm3,%ymm8 .byte 197,180,89,201 // vmulps %ymm1,%ymm9,%ymm1 .byte 197,188,88,201 // vaddps %ymm1,%ymm8,%ymm1 .byte 197,100,89,198 // vmulps %ymm6,%ymm3,%ymm8 .byte 197,180,89,210 // vmulps %ymm2,%ymm9,%ymm2 .byte 197,188,88,210 // vaddps %ymm2,%ymm8,%ymm2 .byte 197,100,89,199 // vmulps %ymm7,%ymm3,%ymm8 .byte 197,180,89,219 // vmulps %ymm3,%ymm9,%ymm3 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcin_avx .globl _sk_srcin_avx FUNCTION(_sk_srcin_avx) _sk_srcin_avx: .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstin_avx .globl _sk_dstin_avx FUNCTION(_sk_dstin_avx) _sk_dstin_avx: .byte 197,228,89,196 // vmulps %ymm4,%ymm3,%ymm0 .byte 197,228,89,205 // vmulps %ymm5,%ymm3,%ymm1 .byte 197,228,89,214 // vmulps %ymm6,%ymm3,%ymm2 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcout_avx .globl _sk_srcout_avx FUNCTION(_sk_srcout_avx) _sk_srcout_avx: .byte 196,98,125,24,5,19,120,0,0 // vbroadcastss 0x7813(%rip),%ymm8 # 7be0 <_sk_callback_avx+0x170> .byte 197,60,92,199 // vsubps %ymm7,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 197,188,89,219 // vmulps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstout_avx .globl _sk_dstout_avx FUNCTION(_sk_dstout_avx) _sk_dstout_avx: .byte 196,226,125,24,5,246,119,0,0 // vbroadcastss 0x77f6(%rip),%ymm0 # 7be4 <_sk_callback_avx+0x174> .byte 197,252,92,219 // vsubps %ymm3,%ymm0,%ymm3 .byte 197,228,89,196 // vmulps %ymm4,%ymm3,%ymm0 .byte 197,228,89,205 // vmulps %ymm5,%ymm3,%ymm1 .byte 197,228,89,214 // vmulps %ymm6,%ymm3,%ymm2 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_avx .globl _sk_srcover_avx FUNCTION(_sk_srcover_avx) _sk_srcover_avx: .byte 196,98,125,24,5,217,119,0,0 // vbroadcastss 0x77d9(%rip),%ymm8 # 7be8 <_sk_callback_avx+0x178> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,204 // vmulps %ymm4,%ymm8,%ymm9 .byte 197,180,88,192 // vaddps %ymm0,%ymm9,%ymm0 .byte 197,60,89,205 // vmulps %ymm5,%ymm8,%ymm9 .byte 197,180,88,201 // vaddps %ymm1,%ymm9,%ymm1 .byte 197,60,89,206 // vmulps %ymm6,%ymm8,%ymm9 .byte 197,180,88,210 // vaddps %ymm2,%ymm9,%ymm2 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstover_avx .globl _sk_dstover_avx FUNCTION(_sk_dstover_avx) _sk_dstover_avx: .byte 196,98,125,24,5,172,119,0,0 // vbroadcastss 0x77ac(%rip),%ymm8 # 7bec <_sk_callback_avx+0x17c> .byte 197,60,92,199 // vsubps %ymm7,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,252,88,196 // vaddps %ymm4,%ymm0,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,244,88,205 // vaddps %ymm5,%ymm1,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 197,236,88,214 // vaddps %ymm6,%ymm2,%ymm2 .byte 197,188,89,219 // vmulps %ymm3,%ymm8,%ymm3 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_modulate_avx .globl _sk_modulate_avx FUNCTION(_sk_modulate_avx) _sk_modulate_avx: .byte 197,252,89,196 // vmulps %ymm4,%ymm0,%ymm0 .byte 197,244,89,205 // vmulps %ymm5,%ymm1,%ymm1 .byte 197,236,89,214 // vmulps %ymm6,%ymm2,%ymm2 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_multiply_avx .globl _sk_multiply_avx FUNCTION(_sk_multiply_avx) _sk_multiply_avx: .byte 196,98,125,24,5,107,119,0,0 // vbroadcastss 0x776b(%rip),%ymm8 # 7bf0 <_sk_callback_avx+0x180> .byte 197,60,92,207 // vsubps %ymm7,%ymm8,%ymm9 .byte 197,52,89,208 // vmulps %ymm0,%ymm9,%ymm10 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,220 // vmulps %ymm4,%ymm8,%ymm11 .byte 196,65,36,88,210 // vaddps %ymm10,%ymm11,%ymm10 .byte 197,252,89,196 // vmulps %ymm4,%ymm0,%ymm0 .byte 196,193,124,88,194 // vaddps %ymm10,%ymm0,%ymm0 .byte 197,52,89,209 // vmulps %ymm1,%ymm9,%ymm10 .byte 197,60,89,221 // vmulps %ymm5,%ymm8,%ymm11 .byte 196,65,36,88,210 // vaddps %ymm10,%ymm11,%ymm10 .byte 197,244,89,205 // vmulps %ymm5,%ymm1,%ymm1 .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 197,52,89,210 // vmulps %ymm2,%ymm9,%ymm10 .byte 197,60,89,222 // vmulps %ymm6,%ymm8,%ymm11 .byte 196,65,36,88,210 // vaddps %ymm10,%ymm11,%ymm10 .byte 197,236,89,214 // vmulps %ymm6,%ymm2,%ymm2 .byte 196,193,108,88,210 // vaddps %ymm10,%ymm2,%ymm2 .byte 197,52,89,203 // vmulps %ymm3,%ymm9,%ymm9 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 196,193,100,88,216 // vaddps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_plus__avx .globl _sk_plus__avx FUNCTION(_sk_plus__avx) _sk_plus__avx: .byte 197,252,88,196 // vaddps %ymm4,%ymm0,%ymm0 .byte 197,244,88,205 // vaddps %ymm5,%ymm1,%ymm1 .byte 197,236,88,214 // vaddps %ymm6,%ymm2,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_screen_avx .globl _sk_screen_avx FUNCTION(_sk_screen_avx) _sk_screen_avx: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 197,252,89,196 // vmulps %ymm4,%ymm0,%ymm0 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 197,244,89,205 // vmulps %ymm5,%ymm1,%ymm1 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 197,236,89,214 // vmulps %ymm6,%ymm2,%ymm2 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 197,100,88,199 // vaddps %ymm7,%ymm3,%ymm8 .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 197,188,92,219 // vsubps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xor__avx .globl _sk_xor__avx FUNCTION(_sk_xor__avx) _sk_xor__avx: .byte 196,98,125,24,5,186,118,0,0 // vbroadcastss 0x76ba(%rip),%ymm8 # 7bf4 <_sk_callback_avx+0x184> .byte 197,60,92,207 // vsubps %ymm7,%ymm8,%ymm9 .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,212 // vmulps %ymm4,%ymm8,%ymm10 .byte 197,172,88,192 // vaddps %ymm0,%ymm10,%ymm0 .byte 197,180,89,201 // vmulps %ymm1,%ymm9,%ymm1 .byte 197,60,89,213 // vmulps %ymm5,%ymm8,%ymm10 .byte 197,172,88,201 // vaddps %ymm1,%ymm10,%ymm1 .byte 197,180,89,210 // vmulps %ymm2,%ymm9,%ymm2 .byte 197,60,89,214 // vmulps %ymm6,%ymm8,%ymm10 .byte 197,172,88,210 // vaddps %ymm2,%ymm10,%ymm2 .byte 197,180,89,219 // vmulps %ymm3,%ymm9,%ymm3 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_darken_avx .globl _sk_darken_avx FUNCTION(_sk_darken_avx) _sk_darken_avx: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 197,100,89,204 // vmulps %ymm4,%ymm3,%ymm9 .byte 196,193,124,95,193 // vmaxps %ymm9,%ymm0,%ymm0 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 197,100,89,205 // vmulps %ymm5,%ymm3,%ymm9 .byte 196,193,116,95,201 // vmaxps %ymm9,%ymm1,%ymm1 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 197,100,89,206 // vmulps %ymm6,%ymm3,%ymm9 .byte 196,193,108,95,209 // vmaxps %ymm9,%ymm2,%ymm2 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 196,98,125,24,5,58,118,0,0 // vbroadcastss 0x763a(%rip),%ymm8 # 7bf8 <_sk_callback_avx+0x188> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_lighten_avx .globl _sk_lighten_avx FUNCTION(_sk_lighten_avx) _sk_lighten_avx: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 197,100,89,204 // vmulps %ymm4,%ymm3,%ymm9 .byte 196,193,124,93,193 // vminps %ymm9,%ymm0,%ymm0 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 197,100,89,205 // vmulps %ymm5,%ymm3,%ymm9 .byte 196,193,116,93,201 // vminps %ymm9,%ymm1,%ymm1 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 197,100,89,206 // vmulps %ymm6,%ymm3,%ymm9 .byte 196,193,108,93,209 // vminps %ymm9,%ymm2,%ymm2 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 196,98,125,24,5,230,117,0,0 // vbroadcastss 0x75e6(%rip),%ymm8 # 7bfc <_sk_callback_avx+0x18c> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_difference_avx .globl _sk_difference_avx FUNCTION(_sk_difference_avx) _sk_difference_avx: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 197,100,89,204 // vmulps %ymm4,%ymm3,%ymm9 .byte 196,193,124,93,193 // vminps %ymm9,%ymm0,%ymm0 .byte 197,252,88,192 // vaddps %ymm0,%ymm0,%ymm0 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 197,244,89,207 // vmulps %ymm7,%ymm1,%ymm1 .byte 197,100,89,205 // vmulps %ymm5,%ymm3,%ymm9 .byte 196,193,116,93,201 // vminps %ymm9,%ymm1,%ymm1 .byte 197,244,88,201 // vaddps %ymm1,%ymm1,%ymm1 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 197,236,89,215 // vmulps %ymm7,%ymm2,%ymm2 .byte 197,100,89,206 // vmulps %ymm6,%ymm3,%ymm9 .byte 196,193,108,93,209 // vminps %ymm9,%ymm2,%ymm2 .byte 197,236,88,210 // vaddps %ymm2,%ymm2,%ymm2 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 196,98,125,24,5,134,117,0,0 // vbroadcastss 0x7586(%rip),%ymm8 # 7c00 <_sk_callback_avx+0x190> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_exclusion_avx .globl _sk_exclusion_avx FUNCTION(_sk_exclusion_avx) _sk_exclusion_avx: .byte 197,124,88,196 // vaddps %ymm4,%ymm0,%ymm8 .byte 197,252,89,196 // vmulps %ymm4,%ymm0,%ymm0 .byte 197,252,88,192 // vaddps %ymm0,%ymm0,%ymm0 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,116,88,197 // vaddps %ymm5,%ymm1,%ymm8 .byte 197,244,89,205 // vmulps %ymm5,%ymm1,%ymm1 .byte 197,244,88,201 // vaddps %ymm1,%ymm1,%ymm1 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,108,88,198 // vaddps %ymm6,%ymm2,%ymm8 .byte 197,236,89,214 // vmulps %ymm6,%ymm2,%ymm2 .byte 197,236,88,210 // vaddps %ymm2,%ymm2,%ymm2 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 196,98,125,24,5,65,117,0,0 // vbroadcastss 0x7541(%rip),%ymm8 # 7c04 <_sk_callback_avx+0x194> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_colorburn_avx .globl _sk_colorburn_avx FUNCTION(_sk_colorburn_avx) _sk_colorburn_avx: .byte 196,98,125,24,5,44,117,0,0 // vbroadcastss 0x752c(%rip),%ymm8 # 7c08 <_sk_callback_avx+0x198> .byte 197,60,92,207 // vsubps %ymm7,%ymm8,%ymm9 .byte 197,52,89,216 // vmulps %ymm0,%ymm9,%ymm11 .byte 196,65,44,87,210 // vxorps %ymm10,%ymm10,%ymm10 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,228 // vmulps %ymm4,%ymm8,%ymm12 .byte 197,68,92,236 // vsubps %ymm4,%ymm7,%ymm13 .byte 197,20,89,235 // vmulps %ymm3,%ymm13,%ymm13 .byte 197,20,94,232 // vdivps %ymm0,%ymm13,%ymm13 .byte 196,65,68,93,237 // vminps %ymm13,%ymm7,%ymm13 .byte 196,65,68,92,237 // vsubps %ymm13,%ymm7,%ymm13 .byte 197,20,89,235 // vmulps %ymm3,%ymm13,%ymm13 .byte 196,65,36,88,237 // vaddps %ymm13,%ymm11,%ymm13 .byte 196,65,28,88,237 // vaddps %ymm13,%ymm12,%ymm13 .byte 197,28,88,224 // vaddps %ymm0,%ymm12,%ymm12 .byte 196,193,124,194,194,0 // vcmpeqps %ymm10,%ymm0,%ymm0 .byte 196,195,21,74,196,0 // vblendvps %ymm0,%ymm12,%ymm13,%ymm0 .byte 197,92,194,231,0 // vcmpeqps %ymm7,%ymm4,%ymm12 .byte 197,36,88,220 // vaddps %ymm4,%ymm11,%ymm11 .byte 196,195,125,74,195,192 // vblendvps %ymm12,%ymm11,%ymm0,%ymm0 .byte 197,52,89,217 // vmulps %ymm1,%ymm9,%ymm11 .byte 197,60,89,229 // vmulps %ymm5,%ymm8,%ymm12 .byte 197,68,92,237 // vsubps %ymm5,%ymm7,%ymm13 .byte 197,20,89,235 // vmulps %ymm3,%ymm13,%ymm13 .byte 197,20,94,233 // vdivps %ymm1,%ymm13,%ymm13 .byte 196,65,68,93,237 // vminps %ymm13,%ymm7,%ymm13 .byte 196,65,68,92,237 // vsubps %ymm13,%ymm7,%ymm13 .byte 197,20,89,235 // vmulps %ymm3,%ymm13,%ymm13 .byte 196,65,36,88,237 // vaddps %ymm13,%ymm11,%ymm13 .byte 196,65,28,88,237 // vaddps %ymm13,%ymm12,%ymm13 .byte 197,28,88,225 // vaddps %ymm1,%ymm12,%ymm12 .byte 196,193,116,194,202,0 // vcmpeqps %ymm10,%ymm1,%ymm1 .byte 196,195,21,74,204,16 // vblendvps %ymm1,%ymm12,%ymm13,%ymm1 .byte 197,84,194,231,0 // vcmpeqps %ymm7,%ymm5,%ymm12 .byte 197,36,88,221 // vaddps %ymm5,%ymm11,%ymm11 .byte 196,195,117,74,203,192 // vblendvps %ymm12,%ymm11,%ymm1,%ymm1 .byte 197,52,89,202 // vmulps %ymm2,%ymm9,%ymm9 .byte 196,65,108,194,210,0 // vcmpeqps %ymm10,%ymm2,%ymm10 .byte 197,60,89,222 // vmulps %ymm6,%ymm8,%ymm11 .byte 197,68,92,230 // vsubps %ymm6,%ymm7,%ymm12 .byte 197,28,89,227 // vmulps %ymm3,%ymm12,%ymm12 .byte 197,28,94,226 // vdivps %ymm2,%ymm12,%ymm12 .byte 197,164,88,210 // vaddps %ymm2,%ymm11,%ymm2 .byte 196,65,68,93,228 // vminps %ymm12,%ymm7,%ymm12 .byte 196,65,68,92,228 // vsubps %ymm12,%ymm7,%ymm12 .byte 197,28,89,227 // vmulps %ymm3,%ymm12,%ymm12 .byte 196,65,52,88,228 // vaddps %ymm12,%ymm9,%ymm12 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 196,227,37,74,210,160 // vblendvps %ymm10,%ymm2,%ymm11,%ymm2 .byte 197,76,194,215,0 // vcmpeqps %ymm7,%ymm6,%ymm10 .byte 197,52,88,206 // vaddps %ymm6,%ymm9,%ymm9 .byte 196,195,109,74,209,160 // vblendvps %ymm10,%ymm9,%ymm2,%ymm2 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_colordodge_avx .globl _sk_colordodge_avx FUNCTION(_sk_colordodge_avx) _sk_colordodge_avx: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,98,125,24,13,40,116,0,0 // vbroadcastss 0x7428(%rip),%ymm9 # 7c0c <_sk_callback_avx+0x19c> .byte 197,52,92,215 // vsubps %ymm7,%ymm9,%ymm10 .byte 197,44,89,216 // vmulps %ymm0,%ymm10,%ymm11 .byte 197,52,92,203 // vsubps %ymm3,%ymm9,%ymm9 .byte 197,100,89,228 // vmulps %ymm4,%ymm3,%ymm12 .byte 197,100,92,232 // vsubps %ymm0,%ymm3,%ymm13 .byte 196,65,28,94,229 // vdivps %ymm13,%ymm12,%ymm12 .byte 197,52,89,236 // vmulps %ymm4,%ymm9,%ymm13 .byte 196,65,68,93,228 // vminps %ymm12,%ymm7,%ymm12 .byte 197,28,89,227 // vmulps %ymm3,%ymm12,%ymm12 .byte 196,65,36,88,228 // vaddps %ymm12,%ymm11,%ymm12 .byte 196,65,20,88,228 // vaddps %ymm12,%ymm13,%ymm12 .byte 197,20,88,232 // vaddps %ymm0,%ymm13,%ymm13 .byte 197,252,194,195,0 // vcmpeqps %ymm3,%ymm0,%ymm0 .byte 196,195,29,74,197,0 // vblendvps %ymm0,%ymm13,%ymm12,%ymm0 .byte 196,65,92,194,224,0 // vcmpeqps %ymm8,%ymm4,%ymm12 .byte 197,36,88,220 // vaddps %ymm4,%ymm11,%ymm11 .byte 196,195,125,74,195,192 // vblendvps %ymm12,%ymm11,%ymm0,%ymm0 .byte 197,44,89,217 // vmulps %ymm1,%ymm10,%ymm11 .byte 197,100,89,229 // vmulps %ymm5,%ymm3,%ymm12 .byte 197,100,92,233 // vsubps %ymm1,%ymm3,%ymm13 .byte 196,65,28,94,229 // vdivps %ymm13,%ymm12,%ymm12 .byte 197,52,89,237 // vmulps %ymm5,%ymm9,%ymm13 .byte 196,65,68,93,228 // vminps %ymm12,%ymm7,%ymm12 .byte 197,28,89,227 // vmulps %ymm3,%ymm12,%ymm12 .byte 196,65,36,88,228 // vaddps %ymm12,%ymm11,%ymm12 .byte 196,65,20,88,228 // vaddps %ymm12,%ymm13,%ymm12 .byte 197,20,88,233 // vaddps %ymm1,%ymm13,%ymm13 .byte 197,244,194,203,0 // vcmpeqps %ymm3,%ymm1,%ymm1 .byte 196,195,29,74,205,16 // vblendvps %ymm1,%ymm13,%ymm12,%ymm1 .byte 196,65,84,194,224,0 // vcmpeqps %ymm8,%ymm5,%ymm12 .byte 197,36,88,221 // vaddps %ymm5,%ymm11,%ymm11 .byte 196,195,117,74,203,192 // vblendvps %ymm12,%ymm11,%ymm1,%ymm1 .byte 197,44,89,210 // vmulps %ymm2,%ymm10,%ymm10 .byte 197,100,89,222 // vmulps %ymm6,%ymm3,%ymm11 .byte 197,100,92,226 // vsubps %ymm2,%ymm3,%ymm12 .byte 196,65,36,94,220 // vdivps %ymm12,%ymm11,%ymm11 .byte 197,52,89,230 // vmulps %ymm6,%ymm9,%ymm12 .byte 196,65,68,93,219 // vminps %ymm11,%ymm7,%ymm11 .byte 197,36,89,219 // vmulps %ymm3,%ymm11,%ymm11 .byte 196,65,44,88,219 // vaddps %ymm11,%ymm10,%ymm11 .byte 196,65,28,88,219 // vaddps %ymm11,%ymm12,%ymm11 .byte 197,28,88,226 // vaddps %ymm2,%ymm12,%ymm12 .byte 197,236,194,211,0 // vcmpeqps %ymm3,%ymm2,%ymm2 .byte 196,195,37,74,212,32 // vblendvps %ymm2,%ymm12,%ymm11,%ymm2 .byte 196,65,76,194,192,0 // vcmpeqps %ymm8,%ymm6,%ymm8 .byte 197,44,88,214 // vaddps %ymm6,%ymm10,%ymm10 .byte 196,195,109,74,210,128 // vblendvps %ymm8,%ymm10,%ymm2,%ymm2 .byte 197,52,89,199 // vmulps %ymm7,%ymm9,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_hardlight_avx .globl _sk_hardlight_avx FUNCTION(_sk_hardlight_avx) _sk_hardlight_avx: .byte 196,98,125,24,5,58,115,0,0 // vbroadcastss 0x733a(%rip),%ymm8 # 7c10 <_sk_callback_avx+0x1a0> .byte 197,60,92,215 // vsubps %ymm7,%ymm8,%ymm10 .byte 197,44,89,200 // vmulps %ymm0,%ymm10,%ymm9 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,220 // vmulps %ymm4,%ymm8,%ymm11 .byte 196,65,36,88,217 // vaddps %ymm9,%ymm11,%ymm11 .byte 197,124,88,200 // vaddps %ymm0,%ymm0,%ymm9 .byte 197,52,194,227,2 // vcmpleps %ymm3,%ymm9,%ymm12 .byte 197,124,89,204 // vmulps %ymm4,%ymm0,%ymm9 .byte 196,65,52,88,233 // vaddps %ymm9,%ymm9,%ymm13 .byte 197,100,89,207 // vmulps %ymm7,%ymm3,%ymm9 .byte 197,68,92,244 // vsubps %ymm4,%ymm7,%ymm14 .byte 197,228,92,192 // vsubps %ymm0,%ymm3,%ymm0 .byte 196,193,124,89,198 // vmulps %ymm14,%ymm0,%ymm0 .byte 197,252,88,192 // vaddps %ymm0,%ymm0,%ymm0 .byte 197,180,92,192 // vsubps %ymm0,%ymm9,%ymm0 .byte 196,195,125,74,197,192 // vblendvps %ymm12,%ymm13,%ymm0,%ymm0 .byte 197,164,88,192 // vaddps %ymm0,%ymm11,%ymm0 .byte 197,44,89,217 // vmulps %ymm1,%ymm10,%ymm11 .byte 197,60,89,229 // vmulps %ymm5,%ymm8,%ymm12 .byte 196,65,28,88,219 // vaddps %ymm11,%ymm12,%ymm11 .byte 197,116,88,225 // vaddps %ymm1,%ymm1,%ymm12 .byte 197,28,194,227,2 // vcmpleps %ymm3,%ymm12,%ymm12 .byte 197,116,89,237 // vmulps %ymm5,%ymm1,%ymm13 .byte 196,65,20,88,237 // vaddps %ymm13,%ymm13,%ymm13 .byte 197,68,92,245 // vsubps %ymm5,%ymm7,%ymm14 .byte 197,228,92,201 // vsubps %ymm1,%ymm3,%ymm1 .byte 196,193,116,89,206 // vmulps %ymm14,%ymm1,%ymm1 .byte 197,244,88,201 // vaddps %ymm1,%ymm1,%ymm1 .byte 197,180,92,201 // vsubps %ymm1,%ymm9,%ymm1 .byte 196,195,117,74,205,192 // vblendvps %ymm12,%ymm13,%ymm1,%ymm1 .byte 197,164,88,201 // vaddps %ymm1,%ymm11,%ymm1 .byte 197,44,89,210 // vmulps %ymm2,%ymm10,%ymm10 .byte 197,60,89,222 // vmulps %ymm6,%ymm8,%ymm11 .byte 196,65,36,88,210 // vaddps %ymm10,%ymm11,%ymm10 .byte 197,108,88,218 // vaddps %ymm2,%ymm2,%ymm11 .byte 197,36,194,219,2 // vcmpleps %ymm3,%ymm11,%ymm11 .byte 197,108,89,230 // vmulps %ymm6,%ymm2,%ymm12 .byte 196,65,28,88,228 // vaddps %ymm12,%ymm12,%ymm12 .byte 197,68,92,238 // vsubps %ymm6,%ymm7,%ymm13 .byte 197,228,92,210 // vsubps %ymm2,%ymm3,%ymm2 .byte 196,193,108,89,213 // vmulps %ymm13,%ymm2,%ymm2 .byte 197,236,88,210 // vaddps %ymm2,%ymm2,%ymm2 .byte 197,180,92,210 // vsubps %ymm2,%ymm9,%ymm2 .byte 196,195,109,74,212,176 // vblendvps %ymm11,%ymm12,%ymm2,%ymm2 .byte 197,172,88,210 // vaddps %ymm2,%ymm10,%ymm2 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_overlay_avx .globl _sk_overlay_avx FUNCTION(_sk_overlay_avx) _sk_overlay_avx: .byte 196,98,125,24,5,99,114,0,0 // vbroadcastss 0x7263(%rip),%ymm8 # 7c14 <_sk_callback_avx+0x1a4> .byte 197,60,92,215 // vsubps %ymm7,%ymm8,%ymm10 .byte 197,44,89,200 // vmulps %ymm0,%ymm10,%ymm9 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,220 // vmulps %ymm4,%ymm8,%ymm11 .byte 196,65,36,88,217 // vaddps %ymm9,%ymm11,%ymm11 .byte 197,92,88,204 // vaddps %ymm4,%ymm4,%ymm9 .byte 197,52,194,231,2 // vcmpleps %ymm7,%ymm9,%ymm12 .byte 197,124,89,204 // vmulps %ymm4,%ymm0,%ymm9 .byte 196,65,52,88,233 // vaddps %ymm9,%ymm9,%ymm13 .byte 197,100,89,207 // vmulps %ymm7,%ymm3,%ymm9 .byte 197,68,92,244 // vsubps %ymm4,%ymm7,%ymm14 .byte 197,228,92,192 // vsubps %ymm0,%ymm3,%ymm0 .byte 196,193,124,89,198 // vmulps %ymm14,%ymm0,%ymm0 .byte 197,252,88,192 // vaddps %ymm0,%ymm0,%ymm0 .byte 197,180,92,192 // vsubps %ymm0,%ymm9,%ymm0 .byte 196,195,125,74,197,192 // vblendvps %ymm12,%ymm13,%ymm0,%ymm0 .byte 197,164,88,192 // vaddps %ymm0,%ymm11,%ymm0 .byte 197,44,89,217 // vmulps %ymm1,%ymm10,%ymm11 .byte 197,60,89,229 // vmulps %ymm5,%ymm8,%ymm12 .byte 196,65,28,88,219 // vaddps %ymm11,%ymm12,%ymm11 .byte 197,84,88,229 // vaddps %ymm5,%ymm5,%ymm12 .byte 197,28,194,231,2 // vcmpleps %ymm7,%ymm12,%ymm12 .byte 197,116,89,237 // vmulps %ymm5,%ymm1,%ymm13 .byte 196,65,20,88,237 // vaddps %ymm13,%ymm13,%ymm13 .byte 197,68,92,245 // vsubps %ymm5,%ymm7,%ymm14 .byte 197,228,92,201 // vsubps %ymm1,%ymm3,%ymm1 .byte 196,193,116,89,206 // vmulps %ymm14,%ymm1,%ymm1 .byte 197,244,88,201 // vaddps %ymm1,%ymm1,%ymm1 .byte 197,180,92,201 // vsubps %ymm1,%ymm9,%ymm1 .byte 196,195,117,74,205,192 // vblendvps %ymm12,%ymm13,%ymm1,%ymm1 .byte 197,164,88,201 // vaddps %ymm1,%ymm11,%ymm1 .byte 197,44,89,210 // vmulps %ymm2,%ymm10,%ymm10 .byte 197,60,89,222 // vmulps %ymm6,%ymm8,%ymm11 .byte 196,65,36,88,210 // vaddps %ymm10,%ymm11,%ymm10 .byte 197,76,88,222 // vaddps %ymm6,%ymm6,%ymm11 .byte 197,36,194,223,2 // vcmpleps %ymm7,%ymm11,%ymm11 .byte 197,108,89,230 // vmulps %ymm6,%ymm2,%ymm12 .byte 196,65,28,88,228 // vaddps %ymm12,%ymm12,%ymm12 .byte 197,68,92,238 // vsubps %ymm6,%ymm7,%ymm13 .byte 197,228,92,210 // vsubps %ymm2,%ymm3,%ymm2 .byte 196,193,108,89,213 // vmulps %ymm13,%ymm2,%ymm2 .byte 197,236,88,210 // vaddps %ymm2,%ymm2,%ymm2 .byte 197,180,92,210 // vsubps %ymm2,%ymm9,%ymm2 .byte 196,195,109,74,212,176 // vblendvps %ymm11,%ymm12,%ymm2,%ymm2 .byte 197,172,88,210 // vaddps %ymm2,%ymm10,%ymm2 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_softlight_avx .globl _sk_softlight_avx FUNCTION(_sk_softlight_avx) _sk_softlight_avx: .byte 197,252,17,84,36,200 // vmovups %ymm2,-0x38(%rsp) .byte 197,252,40,209 // vmovaps %ymm1,%ymm2 .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 196,65,52,87,201 // vxorps %ymm9,%ymm9,%ymm9 .byte 197,52,194,215,1 // vcmpltps %ymm7,%ymm9,%ymm10 .byte 197,92,94,199 // vdivps %ymm7,%ymm4,%ymm8 .byte 196,67,53,74,224,160 // vblendvps %ymm10,%ymm8,%ymm9,%ymm12 .byte 196,65,28,88,196 // vaddps %ymm12,%ymm12,%ymm8 .byte 196,65,60,88,192 // vaddps %ymm8,%ymm8,%ymm8 .byte 196,65,60,89,216 // vmulps %ymm8,%ymm8,%ymm11 .byte 196,65,60,88,195 // vaddps %ymm11,%ymm8,%ymm8 .byte 196,98,125,24,29,90,113,0,0 // vbroadcastss 0x715a(%rip),%ymm11 # 7c1c <_sk_callback_avx+0x1ac> .byte 196,65,28,88,235 // vaddps %ymm11,%ymm12,%ymm13 .byte 196,65,20,89,192 // vmulps %ymm8,%ymm13,%ymm8 .byte 196,98,125,24,45,75,113,0,0 // vbroadcastss 0x714b(%rip),%ymm13 # 7c20 <_sk_callback_avx+0x1b0> .byte 196,65,28,89,245 // vmulps %ymm13,%ymm12,%ymm14 .byte 196,65,12,88,192 // vaddps %ymm8,%ymm14,%ymm8 .byte 196,65,124,82,244 // vrsqrtps %ymm12,%ymm14 .byte 196,65,124,83,246 // vrcpps %ymm14,%ymm14 .byte 196,65,12,92,244 // vsubps %ymm12,%ymm14,%ymm14 .byte 197,92,88,252 // vaddps %ymm4,%ymm4,%ymm15 .byte 196,65,4,88,255 // vaddps %ymm15,%ymm15,%ymm15 .byte 197,4,194,255,2 // vcmpleps %ymm7,%ymm15,%ymm15 .byte 196,67,13,74,240,240 // vblendvps %ymm15,%ymm8,%ymm14,%ymm14 .byte 197,116,88,249 // vaddps %ymm1,%ymm1,%ymm15 .byte 196,98,125,24,5,9,113,0,0 // vbroadcastss 0x7109(%rip),%ymm8 # 7c18 <_sk_callback_avx+0x1a8> .byte 196,65,60,92,228 // vsubps %ymm12,%ymm8,%ymm12 .byte 197,132,92,195 // vsubps %ymm3,%ymm15,%ymm0 .byte 196,65,124,89,228 // vmulps %ymm12,%ymm0,%ymm12 .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 196,193,124,89,198 // vmulps %ymm14,%ymm0,%ymm0 .byte 197,100,89,244 // vmulps %ymm4,%ymm3,%ymm14 .byte 197,140,88,192 // vaddps %ymm0,%ymm14,%ymm0 .byte 197,28,88,227 // vaddps %ymm3,%ymm12,%ymm12 .byte 197,28,89,228 // vmulps %ymm4,%ymm12,%ymm12 .byte 197,4,194,243,2 // vcmpleps %ymm3,%ymm15,%ymm14 .byte 196,195,125,74,196,224 // vblendvps %ymm14,%ymm12,%ymm0,%ymm0 .byte 197,252,17,68,36,168 // vmovups %ymm0,-0x58(%rsp) .byte 197,212,94,199 // vdivps %ymm7,%ymm5,%ymm0 .byte 196,227,53,74,192,160 // vblendvps %ymm10,%ymm0,%ymm9,%ymm0 .byte 197,124,88,240 // vaddps %ymm0,%ymm0,%ymm14 .byte 196,65,12,88,246 // vaddps %ymm14,%ymm14,%ymm14 .byte 196,65,12,89,254 // vmulps %ymm14,%ymm14,%ymm15 .byte 196,65,12,88,247 // vaddps %ymm15,%ymm14,%ymm14 .byte 196,65,124,88,251 // vaddps %ymm11,%ymm0,%ymm15 .byte 196,65,4,89,246 // vmulps %ymm14,%ymm15,%ymm14 .byte 196,65,124,89,253 // vmulps %ymm13,%ymm0,%ymm15 .byte 196,65,4,88,246 // vaddps %ymm14,%ymm15,%ymm14 .byte 197,124,82,248 // vrsqrtps %ymm0,%ymm15 .byte 196,65,124,83,255 // vrcpps %ymm15,%ymm15 .byte 197,4,92,248 // vsubps %ymm0,%ymm15,%ymm15 .byte 197,84,88,229 // vaddps %ymm5,%ymm5,%ymm12 .byte 196,65,28,88,228 // vaddps %ymm12,%ymm12,%ymm12 .byte 197,28,194,231,2 // vcmpleps %ymm7,%ymm12,%ymm12 .byte 196,67,5,74,230,192 // vblendvps %ymm12,%ymm14,%ymm15,%ymm12 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,108,88,242 // vaddps %ymm2,%ymm2,%ymm14 .byte 197,12,92,251 // vsubps %ymm3,%ymm14,%ymm15 .byte 197,132,89,192 // vmulps %ymm0,%ymm15,%ymm0 .byte 197,4,89,255 // vmulps %ymm7,%ymm15,%ymm15 .byte 196,65,4,89,228 // vmulps %ymm12,%ymm15,%ymm12 .byte 197,100,89,253 // vmulps %ymm5,%ymm3,%ymm15 .byte 196,65,4,88,228 // vaddps %ymm12,%ymm15,%ymm12 .byte 197,252,88,195 // vaddps %ymm3,%ymm0,%ymm0 .byte 197,252,89,197 // vmulps %ymm5,%ymm0,%ymm0 .byte 197,12,194,243,2 // vcmpleps %ymm3,%ymm14,%ymm14 .byte 196,99,29,74,240,224 // vblendvps %ymm14,%ymm0,%ymm12,%ymm14 .byte 197,204,94,199 // vdivps %ymm7,%ymm6,%ymm0 .byte 196,227,53,74,192,160 // vblendvps %ymm10,%ymm0,%ymm9,%ymm0 .byte 197,124,88,200 // vaddps %ymm0,%ymm0,%ymm9 .byte 196,65,52,88,201 // vaddps %ymm9,%ymm9,%ymm9 .byte 196,65,52,89,209 // vmulps %ymm9,%ymm9,%ymm10 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,65,124,88,211 // vaddps %ymm11,%ymm0,%ymm10 .byte 196,65,44,89,201 // vmulps %ymm9,%ymm10,%ymm9 .byte 196,65,124,89,213 // vmulps %ymm13,%ymm0,%ymm10 .byte 196,65,44,88,201 // vaddps %ymm9,%ymm10,%ymm9 .byte 197,124,82,208 // vrsqrtps %ymm0,%ymm10 .byte 196,65,124,83,210 // vrcpps %ymm10,%ymm10 .byte 197,44,92,208 // vsubps %ymm0,%ymm10,%ymm10 .byte 197,76,88,222 // vaddps %ymm6,%ymm6,%ymm11 .byte 196,65,36,88,219 // vaddps %ymm11,%ymm11,%ymm11 .byte 197,36,194,223,2 // vcmpleps %ymm7,%ymm11,%ymm11 .byte 196,67,45,74,201,176 // vblendvps %ymm11,%ymm9,%ymm10,%ymm9 .byte 197,124,16,100,36,200 // vmovups -0x38(%rsp),%ymm12 .byte 196,65,28,88,212 // vaddps %ymm12,%ymm12,%ymm10 .byte 197,44,92,219 // vsubps %ymm3,%ymm10,%ymm11 .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,164,89,192 // vmulps %ymm0,%ymm11,%ymm0 .byte 197,36,89,223 // vmulps %ymm7,%ymm11,%ymm11 .byte 196,65,36,89,201 // vmulps %ymm9,%ymm11,%ymm9 .byte 197,100,89,222 // vmulps %ymm6,%ymm3,%ymm11 .byte 196,65,36,88,201 // vaddps %ymm9,%ymm11,%ymm9 .byte 197,252,88,195 // vaddps %ymm3,%ymm0,%ymm0 .byte 197,252,89,198 // vmulps %ymm6,%ymm0,%ymm0 .byte 197,44,194,211,2 // vcmpleps %ymm3,%ymm10,%ymm10 .byte 196,99,53,74,200,160 // vblendvps %ymm10,%ymm0,%ymm9,%ymm9 .byte 197,60,92,215 // vsubps %ymm7,%ymm8,%ymm10 .byte 197,172,89,193 // vmulps %ymm1,%ymm10,%ymm0 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,188,89,204 // vmulps %ymm4,%ymm8,%ymm1 .byte 197,244,88,192 // vaddps %ymm0,%ymm1,%ymm0 .byte 197,252,88,68,36,168 // vaddps -0x58(%rsp),%ymm0,%ymm0 .byte 197,172,89,202 // vmulps %ymm2,%ymm10,%ymm1 .byte 197,188,89,213 // vmulps %ymm5,%ymm8,%ymm2 .byte 197,236,88,201 // vaddps %ymm1,%ymm2,%ymm1 .byte 196,193,116,88,206 // vaddps %ymm14,%ymm1,%ymm1 .byte 196,193,44,89,212 // vmulps %ymm12,%ymm10,%ymm2 .byte 197,60,89,214 // vmulps %ymm6,%ymm8,%ymm10 .byte 197,172,88,210 // vaddps %ymm2,%ymm10,%ymm2 .byte 196,193,108,88,209 // vaddps %ymm9,%ymm2,%ymm2 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 197,188,88,219 // vaddps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_hue_avx .globl _sk_hue_avx FUNCTION(_sk_hue_avx) _sk_hue_avx: .byte 197,252,17,84,36,200 // vmovups %ymm2,-0x38(%rsp) .byte 197,124,40,193 // vmovaps %ymm1,%ymm8 .byte 197,124,17,68,36,168 // vmovups %ymm8,-0x58(%rsp) .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,116,89,203 // vmulps %ymm3,%ymm1,%ymm9 .byte 197,60,89,211 // vmulps %ymm3,%ymm8,%ymm10 .byte 197,108,89,219 // vmulps %ymm3,%ymm2,%ymm11 .byte 197,84,95,198 // vmaxps %ymm6,%ymm5,%ymm8 .byte 196,65,92,95,192 // vmaxps %ymm8,%ymm4,%ymm8 .byte 197,84,93,230 // vminps %ymm6,%ymm5,%ymm12 .byte 196,65,92,93,228 // vminps %ymm12,%ymm4,%ymm12 .byte 196,65,60,92,196 // vsubps %ymm12,%ymm8,%ymm8 .byte 197,60,89,227 // vmulps %ymm3,%ymm8,%ymm12 .byte 196,65,44,93,195 // vminps %ymm11,%ymm10,%ymm8 .byte 196,65,52,93,232 // vminps %ymm8,%ymm9,%ymm13 .byte 196,65,44,95,195 // vmaxps %ymm11,%ymm10,%ymm8 .byte 196,65,52,95,192 // vmaxps %ymm8,%ymm9,%ymm8 .byte 196,65,60,92,245 // vsubps %ymm13,%ymm8,%ymm14 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,65,12,194,248,0 // vcmpeqps %ymm8,%ymm14,%ymm15 .byte 196,65,52,92,205 // vsubps %ymm13,%ymm9,%ymm9 .byte 196,65,28,89,201 // vmulps %ymm9,%ymm12,%ymm9 .byte 196,65,52,94,206 // vdivps %ymm14,%ymm9,%ymm9 .byte 196,67,53,74,200,240 // vblendvps %ymm15,%ymm8,%ymm9,%ymm9 .byte 196,65,44,92,213 // vsubps %ymm13,%ymm10,%ymm10 .byte 196,65,28,89,210 // vmulps %ymm10,%ymm12,%ymm10 .byte 196,65,44,94,214 // vdivps %ymm14,%ymm10,%ymm10 .byte 196,67,45,74,208,240 // vblendvps %ymm15,%ymm8,%ymm10,%ymm10 .byte 196,65,36,92,221 // vsubps %ymm13,%ymm11,%ymm11 .byte 196,65,28,89,219 // vmulps %ymm11,%ymm12,%ymm11 .byte 196,65,36,94,222 // vdivps %ymm14,%ymm11,%ymm11 .byte 196,67,37,74,224,240 // vblendvps %ymm15,%ymm8,%ymm11,%ymm12 .byte 196,98,125,24,53,216,110,0,0 // vbroadcastss 0x6ed8(%rip),%ymm14 # 7c24 <_sk_callback_avx+0x1b4> .byte 196,65,92,89,222 // vmulps %ymm14,%ymm4,%ymm11 .byte 196,98,125,24,61,206,110,0,0 // vbroadcastss 0x6ece(%rip),%ymm15 # 7c28 <_sk_callback_avx+0x1b8> .byte 196,65,84,89,239 // vmulps %ymm15,%ymm5,%ymm13 .byte 196,65,36,88,221 // vaddps %ymm13,%ymm11,%ymm11 .byte 196,226,125,24,5,191,110,0,0 // vbroadcastss 0x6ebf(%rip),%ymm0 # 7c2c <_sk_callback_avx+0x1bc> .byte 197,76,89,232 // vmulps %ymm0,%ymm6,%ymm13 .byte 196,65,36,88,221 // vaddps %ymm13,%ymm11,%ymm11 .byte 196,65,52,89,238 // vmulps %ymm14,%ymm9,%ymm13 .byte 196,193,44,89,215 // vmulps %ymm15,%ymm10,%ymm2 .byte 197,148,88,210 // vaddps %ymm2,%ymm13,%ymm2 .byte 197,28,89,232 // vmulps %ymm0,%ymm12,%ymm13 .byte 196,193,108,88,213 // vaddps %ymm13,%ymm2,%ymm2 .byte 197,36,89,219 // vmulps %ymm3,%ymm11,%ymm11 .byte 197,164,92,210 // vsubps %ymm2,%ymm11,%ymm2 .byte 197,52,88,202 // vaddps %ymm2,%ymm9,%ymm9 .byte 197,44,88,218 // vaddps %ymm2,%ymm10,%ymm11 .byte 197,28,88,226 // vaddps %ymm2,%ymm12,%ymm12 .byte 196,193,36,93,212 // vminps %ymm12,%ymm11,%ymm2 .byte 197,52,93,234 // vminps %ymm2,%ymm9,%ymm13 .byte 196,193,52,89,214 // vmulps %ymm14,%ymm9,%ymm2 .byte 196,65,36,89,215 // vmulps %ymm15,%ymm11,%ymm10 .byte 196,193,108,88,210 // vaddps %ymm10,%ymm2,%ymm2 .byte 197,156,89,192 // vmulps %ymm0,%ymm12,%ymm0 .byte 197,124,88,210 // vaddps %ymm2,%ymm0,%ymm10 .byte 196,193,52,92,194 // vsubps %ymm10,%ymm9,%ymm0 .byte 197,172,89,192 // vmulps %ymm0,%ymm10,%ymm0 .byte 196,193,44,92,213 // vsubps %ymm13,%ymm10,%ymm2 .byte 197,252,94,194 // vdivps %ymm2,%ymm0,%ymm0 .byte 196,65,36,92,242 // vsubps %ymm10,%ymm11,%ymm14 .byte 196,65,44,89,246 // vmulps %ymm14,%ymm10,%ymm14 .byte 197,12,94,242 // vdivps %ymm2,%ymm14,%ymm14 .byte 196,65,28,92,250 // vsubps %ymm10,%ymm12,%ymm15 .byte 196,65,44,89,255 // vmulps %ymm15,%ymm10,%ymm15 .byte 197,132,94,210 // vdivps %ymm2,%ymm15,%ymm2 .byte 196,65,60,194,237,2 // vcmpleps %ymm13,%ymm8,%ymm13 .byte 196,65,44,88,246 // vaddps %ymm14,%ymm10,%ymm14 .byte 196,67,13,74,243,208 // vblendvps %ymm13,%ymm11,%ymm14,%ymm14 .byte 196,65,36,95,220 // vmaxps %ymm12,%ymm11,%ymm11 .byte 197,172,88,210 // vaddps %ymm2,%ymm10,%ymm2 .byte 196,195,109,74,212,208 // vblendvps %ymm13,%ymm12,%ymm2,%ymm2 .byte 197,172,88,192 // vaddps %ymm0,%ymm10,%ymm0 .byte 196,195,125,74,193,208 // vblendvps %ymm13,%ymm9,%ymm0,%ymm0 .byte 197,100,89,231 // vmulps %ymm7,%ymm3,%ymm12 .byte 196,65,52,95,203 // vmaxps %ymm11,%ymm9,%ymm9 .byte 196,65,124,92,218 // vsubps %ymm10,%ymm0,%ymm11 .byte 196,65,28,92,234 // vsubps %ymm10,%ymm12,%ymm13 .byte 196,65,20,89,219 // vmulps %ymm11,%ymm13,%ymm11 .byte 196,65,28,194,249,1 // vcmpltps %ymm9,%ymm12,%ymm15 .byte 196,65,52,92,202 // vsubps %ymm10,%ymm9,%ymm9 .byte 196,65,36,94,217 // vdivps %ymm9,%ymm11,%ymm11 .byte 196,65,44,88,219 // vaddps %ymm11,%ymm10,%ymm11 .byte 196,195,125,74,195,240 // vblendvps %ymm15,%ymm11,%ymm0,%ymm0 .byte 196,65,12,92,218 // vsubps %ymm10,%ymm14,%ymm11 .byte 196,65,20,89,219 // vmulps %ymm11,%ymm13,%ymm11 .byte 196,65,36,94,217 // vdivps %ymm9,%ymm11,%ymm11 .byte 196,65,44,88,219 // vaddps %ymm11,%ymm10,%ymm11 .byte 196,67,13,74,219,240 // vblendvps %ymm15,%ymm11,%ymm14,%ymm11 .byte 196,65,108,92,242 // vsubps %ymm10,%ymm2,%ymm14 .byte 196,65,20,89,238 // vmulps %ymm14,%ymm13,%ymm13 .byte 196,65,20,94,201 // vdivps %ymm9,%ymm13,%ymm9 .byte 196,65,44,88,201 // vaddps %ymm9,%ymm10,%ymm9 .byte 196,193,124,95,192 // vmaxps %ymm8,%ymm0,%ymm0 .byte 196,65,36,95,208 // vmaxps %ymm8,%ymm11,%ymm10 .byte 196,195,109,74,209,240 // vblendvps %ymm15,%ymm9,%ymm2,%ymm2 .byte 196,193,108,95,208 // vmaxps %ymm8,%ymm2,%ymm2 .byte 196,98,125,24,5,152,109,0,0 // vbroadcastss 0x6d98(%rip),%ymm8 # 7c30 <_sk_callback_avx+0x1c0> .byte 197,60,92,207 // vsubps %ymm7,%ymm8,%ymm9 .byte 197,180,89,201 // vmulps %ymm1,%ymm9,%ymm1 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,220 // vmulps %ymm4,%ymm8,%ymm11 .byte 197,164,88,201 // vaddps %ymm1,%ymm11,%ymm1 .byte 197,244,88,192 // vaddps %ymm0,%ymm1,%ymm0 .byte 197,180,89,76,36,168 // vmulps -0x58(%rsp),%ymm9,%ymm1 .byte 197,60,89,221 // vmulps %ymm5,%ymm8,%ymm11 .byte 197,164,88,201 // vaddps %ymm1,%ymm11,%ymm1 .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 197,52,89,76,36,200 // vmulps -0x38(%rsp),%ymm9,%ymm9 .byte 197,60,89,198 // vmulps %ymm6,%ymm8,%ymm8 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 197,188,88,210 // vaddps %ymm2,%ymm8,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 196,193,100,92,220 // vsubps %ymm12,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_saturation_avx .globl _sk_saturation_avx FUNCTION(_sk_saturation_avx) _sk_saturation_avx: .byte 197,124,40,193 // vmovaps %ymm1,%ymm8 .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,100,89,204 // vmulps %ymm4,%ymm3,%ymm9 .byte 197,100,89,213 // vmulps %ymm5,%ymm3,%ymm10 .byte 197,100,89,222 // vmulps %ymm6,%ymm3,%ymm11 .byte 197,252,17,84,36,200 // vmovups %ymm2,-0x38(%rsp) .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,252,17,68,36,168 // vmovups %ymm0,-0x58(%rsp) .byte 197,124,95,194 // vmaxps %ymm2,%ymm0,%ymm8 .byte 196,65,116,95,192 // vmaxps %ymm8,%ymm1,%ymm8 .byte 197,124,93,226 // vminps %ymm2,%ymm0,%ymm12 .byte 196,65,116,93,228 // vminps %ymm12,%ymm1,%ymm12 .byte 196,65,60,92,196 // vsubps %ymm12,%ymm8,%ymm8 .byte 197,60,89,231 // vmulps %ymm7,%ymm8,%ymm12 .byte 196,65,44,93,195 // vminps %ymm11,%ymm10,%ymm8 .byte 196,65,52,93,232 // vminps %ymm8,%ymm9,%ymm13 .byte 196,65,44,95,195 // vmaxps %ymm11,%ymm10,%ymm8 .byte 196,65,52,95,192 // vmaxps %ymm8,%ymm9,%ymm8 .byte 196,65,60,92,245 // vsubps %ymm13,%ymm8,%ymm14 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,65,12,194,248,0 // vcmpeqps %ymm8,%ymm14,%ymm15 .byte 196,65,52,92,205 // vsubps %ymm13,%ymm9,%ymm9 .byte 196,65,28,89,201 // vmulps %ymm9,%ymm12,%ymm9 .byte 196,65,52,94,206 // vdivps %ymm14,%ymm9,%ymm9 .byte 196,67,53,74,200,240 // vblendvps %ymm15,%ymm8,%ymm9,%ymm9 .byte 196,65,44,92,213 // vsubps %ymm13,%ymm10,%ymm10 .byte 196,65,28,89,210 // vmulps %ymm10,%ymm12,%ymm10 .byte 196,65,44,94,214 // vdivps %ymm14,%ymm10,%ymm10 .byte 196,67,45,74,208,240 // vblendvps %ymm15,%ymm8,%ymm10,%ymm10 .byte 196,65,36,92,221 // vsubps %ymm13,%ymm11,%ymm11 .byte 196,65,28,89,219 // vmulps %ymm11,%ymm12,%ymm11 .byte 196,65,36,94,222 // vdivps %ymm14,%ymm11,%ymm11 .byte 196,67,37,74,224,240 // vblendvps %ymm15,%ymm8,%ymm11,%ymm12 .byte 196,98,125,24,53,166,108,0,0 // vbroadcastss 0x6ca6(%rip),%ymm14 # 7c34 <_sk_callback_avx+0x1c4> .byte 196,65,92,89,222 // vmulps %ymm14,%ymm4,%ymm11 .byte 196,98,125,24,61,156,108,0,0 // vbroadcastss 0x6c9c(%rip),%ymm15 # 7c38 <_sk_callback_avx+0x1c8> .byte 196,65,84,89,239 // vmulps %ymm15,%ymm5,%ymm13 .byte 196,65,36,88,221 // vaddps %ymm13,%ymm11,%ymm11 .byte 196,226,125,24,5,141,108,0,0 // vbroadcastss 0x6c8d(%rip),%ymm0 # 7c3c <_sk_callback_avx+0x1cc> .byte 197,76,89,232 // vmulps %ymm0,%ymm6,%ymm13 .byte 196,65,36,88,221 // vaddps %ymm13,%ymm11,%ymm11 .byte 196,65,52,89,238 // vmulps %ymm14,%ymm9,%ymm13 .byte 196,193,44,89,215 // vmulps %ymm15,%ymm10,%ymm2 .byte 197,148,88,210 // vaddps %ymm2,%ymm13,%ymm2 .byte 197,28,89,232 // vmulps %ymm0,%ymm12,%ymm13 .byte 196,193,108,88,213 // vaddps %ymm13,%ymm2,%ymm2 .byte 197,36,89,219 // vmulps %ymm3,%ymm11,%ymm11 .byte 197,164,92,210 // vsubps %ymm2,%ymm11,%ymm2 .byte 197,52,88,202 // vaddps %ymm2,%ymm9,%ymm9 .byte 197,44,88,218 // vaddps %ymm2,%ymm10,%ymm11 .byte 197,28,88,226 // vaddps %ymm2,%ymm12,%ymm12 .byte 196,193,36,93,212 // vminps %ymm12,%ymm11,%ymm2 .byte 197,52,93,234 // vminps %ymm2,%ymm9,%ymm13 .byte 196,193,52,89,214 // vmulps %ymm14,%ymm9,%ymm2 .byte 196,65,36,89,215 // vmulps %ymm15,%ymm11,%ymm10 .byte 196,193,108,88,210 // vaddps %ymm10,%ymm2,%ymm2 .byte 197,156,89,192 // vmulps %ymm0,%ymm12,%ymm0 .byte 197,124,88,210 // vaddps %ymm2,%ymm0,%ymm10 .byte 196,193,52,92,194 // vsubps %ymm10,%ymm9,%ymm0 .byte 197,172,89,192 // vmulps %ymm0,%ymm10,%ymm0 .byte 196,193,44,92,213 // vsubps %ymm13,%ymm10,%ymm2 .byte 197,252,94,194 // vdivps %ymm2,%ymm0,%ymm0 .byte 196,65,36,92,242 // vsubps %ymm10,%ymm11,%ymm14 .byte 196,65,44,89,246 // vmulps %ymm14,%ymm10,%ymm14 .byte 197,12,94,242 // vdivps %ymm2,%ymm14,%ymm14 .byte 196,65,28,92,250 // vsubps %ymm10,%ymm12,%ymm15 .byte 196,65,44,89,255 // vmulps %ymm15,%ymm10,%ymm15 .byte 197,132,94,210 // vdivps %ymm2,%ymm15,%ymm2 .byte 196,65,60,194,237,2 // vcmpleps %ymm13,%ymm8,%ymm13 .byte 196,65,44,88,246 // vaddps %ymm14,%ymm10,%ymm14 .byte 196,67,13,74,243,208 // vblendvps %ymm13,%ymm11,%ymm14,%ymm14 .byte 196,65,36,95,220 // vmaxps %ymm12,%ymm11,%ymm11 .byte 197,172,88,210 // vaddps %ymm2,%ymm10,%ymm2 .byte 196,195,109,74,212,208 // vblendvps %ymm13,%ymm12,%ymm2,%ymm2 .byte 197,172,88,192 // vaddps %ymm0,%ymm10,%ymm0 .byte 196,195,125,74,193,208 // vblendvps %ymm13,%ymm9,%ymm0,%ymm0 .byte 197,100,89,231 // vmulps %ymm7,%ymm3,%ymm12 .byte 196,65,52,95,203 // vmaxps %ymm11,%ymm9,%ymm9 .byte 196,65,124,92,218 // vsubps %ymm10,%ymm0,%ymm11 .byte 196,65,28,92,234 // vsubps %ymm10,%ymm12,%ymm13 .byte 196,65,20,89,219 // vmulps %ymm11,%ymm13,%ymm11 .byte 196,65,28,194,249,1 // vcmpltps %ymm9,%ymm12,%ymm15 .byte 196,65,52,92,202 // vsubps %ymm10,%ymm9,%ymm9 .byte 196,65,36,94,217 // vdivps %ymm9,%ymm11,%ymm11 .byte 196,65,44,88,219 // vaddps %ymm11,%ymm10,%ymm11 .byte 196,195,125,74,195,240 // vblendvps %ymm15,%ymm11,%ymm0,%ymm0 .byte 196,65,12,92,218 // vsubps %ymm10,%ymm14,%ymm11 .byte 196,65,20,89,219 // vmulps %ymm11,%ymm13,%ymm11 .byte 196,65,36,94,217 // vdivps %ymm9,%ymm11,%ymm11 .byte 196,65,44,88,219 // vaddps %ymm11,%ymm10,%ymm11 .byte 196,67,13,74,219,240 // vblendvps %ymm15,%ymm11,%ymm14,%ymm11 .byte 196,65,108,92,242 // vsubps %ymm10,%ymm2,%ymm14 .byte 196,65,20,89,238 // vmulps %ymm14,%ymm13,%ymm13 .byte 196,65,20,94,201 // vdivps %ymm9,%ymm13,%ymm9 .byte 196,65,44,88,201 // vaddps %ymm9,%ymm10,%ymm9 .byte 196,193,124,95,192 // vmaxps %ymm8,%ymm0,%ymm0 .byte 196,65,36,95,208 // vmaxps %ymm8,%ymm11,%ymm10 .byte 196,195,109,74,209,240 // vblendvps %ymm15,%ymm9,%ymm2,%ymm2 .byte 196,193,108,95,208 // vmaxps %ymm8,%ymm2,%ymm2 .byte 196,98,125,24,5,102,107,0,0 // vbroadcastss 0x6b66(%rip),%ymm8 # 7c40 <_sk_callback_avx+0x1d0> .byte 197,60,92,207 // vsubps %ymm7,%ymm8,%ymm9 .byte 197,180,89,201 // vmulps %ymm1,%ymm9,%ymm1 .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 197,60,89,220 // vmulps %ymm4,%ymm8,%ymm11 .byte 197,164,88,201 // vaddps %ymm1,%ymm11,%ymm1 .byte 197,244,88,192 // vaddps %ymm0,%ymm1,%ymm0 .byte 197,180,89,76,36,168 // vmulps -0x58(%rsp),%ymm9,%ymm1 .byte 197,60,89,221 // vmulps %ymm5,%ymm8,%ymm11 .byte 197,164,88,201 // vaddps %ymm1,%ymm11,%ymm1 .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 197,52,89,76,36,200 // vmulps -0x38(%rsp),%ymm9,%ymm9 .byte 197,60,89,198 // vmulps %ymm6,%ymm8,%ymm8 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 197,188,88,210 // vaddps %ymm2,%ymm8,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 196,193,100,92,220 // vsubps %ymm12,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_color_avx .globl _sk_color_avx FUNCTION(_sk_color_avx) _sk_color_avx: .byte 197,252,17,84,36,136 // vmovups %ymm2,-0x78(%rsp) .byte 197,252,17,76,36,200 // vmovups %ymm1,-0x38(%rsp) .byte 197,252,17,68,36,168 // vmovups %ymm0,-0x58(%rsp) .byte 197,124,89,199 // vmulps %ymm7,%ymm0,%ymm8 .byte 197,116,89,207 // vmulps %ymm7,%ymm1,%ymm9 .byte 196,98,125,24,45,252,106,0,0 // vbroadcastss 0x6afc(%rip),%ymm13 # 7c44 <_sk_callback_avx+0x1d4> .byte 196,65,92,89,213 // vmulps %ymm13,%ymm4,%ymm10 .byte 196,98,125,24,53,242,106,0,0 // vbroadcastss 0x6af2(%rip),%ymm14 # 7c48 <_sk_callback_avx+0x1d8> .byte 196,65,84,89,222 // vmulps %ymm14,%ymm5,%ymm11 .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 196,98,125,24,61,227,106,0,0 // vbroadcastss 0x6ae3(%rip),%ymm15 # 7c4c <_sk_callback_avx+0x1dc> .byte 196,65,76,89,223 // vmulps %ymm15,%ymm6,%ymm11 .byte 196,193,44,88,195 // vaddps %ymm11,%ymm10,%ymm0 .byte 196,65,60,89,221 // vmulps %ymm13,%ymm8,%ymm11 .byte 196,65,52,89,230 // vmulps %ymm14,%ymm9,%ymm12 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 197,108,89,231 // vmulps %ymm7,%ymm2,%ymm12 .byte 196,65,28,89,215 // vmulps %ymm15,%ymm12,%ymm10 .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 197,252,89,195 // vmulps %ymm3,%ymm0,%ymm0 .byte 196,193,124,92,194 // vsubps %ymm10,%ymm0,%ymm0 .byte 197,60,88,192 // vaddps %ymm0,%ymm8,%ymm8 .byte 197,52,88,208 // vaddps %ymm0,%ymm9,%ymm10 .byte 197,28,88,216 // vaddps %ymm0,%ymm12,%ymm11 .byte 196,193,44,93,195 // vminps %ymm11,%ymm10,%ymm0 .byte 197,60,93,224 // vminps %ymm0,%ymm8,%ymm12 .byte 196,193,60,89,197 // vmulps %ymm13,%ymm8,%ymm0 .byte 196,65,44,89,206 // vmulps %ymm14,%ymm10,%ymm9 .byte 196,193,124,88,193 // vaddps %ymm9,%ymm0,%ymm0 .byte 196,65,36,89,207 // vmulps %ymm15,%ymm11,%ymm9 .byte 197,52,88,200 // vaddps %ymm0,%ymm9,%ymm9 .byte 196,193,60,92,193 // vsubps %ymm9,%ymm8,%ymm0 .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 196,65,52,92,236 // vsubps %ymm12,%ymm9,%ymm13 .byte 196,193,124,94,197 // vdivps %ymm13,%ymm0,%ymm0 .byte 196,65,44,92,241 // vsubps %ymm9,%ymm10,%ymm14 .byte 196,65,52,89,246 // vmulps %ymm14,%ymm9,%ymm14 .byte 196,65,12,94,245 // vdivps %ymm13,%ymm14,%ymm14 .byte 196,65,36,92,249 // vsubps %ymm9,%ymm11,%ymm15 .byte 196,65,52,89,255 // vmulps %ymm15,%ymm9,%ymm15 .byte 196,65,4,94,237 // vdivps %ymm13,%ymm15,%ymm13 .byte 196,65,4,87,255 // vxorps %ymm15,%ymm15,%ymm15 .byte 196,65,4,194,228,2 // vcmpleps %ymm12,%ymm15,%ymm12 .byte 196,65,52,88,246 // vaddps %ymm14,%ymm9,%ymm14 .byte 196,67,13,74,242,192 // vblendvps %ymm12,%ymm10,%ymm14,%ymm14 .byte 196,65,44,95,211 // vmaxps %ymm11,%ymm10,%ymm10 .byte 196,65,52,88,237 // vaddps %ymm13,%ymm9,%ymm13 .byte 196,67,21,74,219,192 // vblendvps %ymm12,%ymm11,%ymm13,%ymm11 .byte 197,180,88,192 // vaddps %ymm0,%ymm9,%ymm0 .byte 196,195,125,74,200,192 // vblendvps %ymm12,%ymm8,%ymm0,%ymm1 .byte 197,100,89,231 // vmulps %ymm7,%ymm3,%ymm12 .byte 196,65,60,95,194 // vmaxps %ymm10,%ymm8,%ymm8 .byte 196,65,116,92,209 // vsubps %ymm9,%ymm1,%ymm10 .byte 196,65,28,92,233 // vsubps %ymm9,%ymm12,%ymm13 .byte 196,65,20,89,210 // vmulps %ymm10,%ymm13,%ymm10 .byte 196,193,28,194,192,1 // vcmpltps %ymm8,%ymm12,%ymm0 .byte 196,65,60,92,193 // vsubps %ymm9,%ymm8,%ymm8 .byte 196,65,44,94,208 // vdivps %ymm8,%ymm10,%ymm10 .byte 196,65,52,88,210 // vaddps %ymm10,%ymm9,%ymm10 .byte 196,195,117,74,202,0 // vblendvps %ymm0,%ymm10,%ymm1,%ymm1 .byte 196,65,12,92,209 // vsubps %ymm9,%ymm14,%ymm10 .byte 196,65,20,89,210 // vmulps %ymm10,%ymm13,%ymm10 .byte 196,65,44,94,208 // vdivps %ymm8,%ymm10,%ymm10 .byte 196,65,52,88,210 // vaddps %ymm10,%ymm9,%ymm10 .byte 196,67,13,74,210,0 // vblendvps %ymm0,%ymm10,%ymm14,%ymm10 .byte 196,65,36,92,241 // vsubps %ymm9,%ymm11,%ymm14 .byte 196,65,20,89,238 // vmulps %ymm14,%ymm13,%ymm13 .byte 196,65,20,94,192 // vdivps %ymm8,%ymm13,%ymm8 .byte 196,65,52,88,192 // vaddps %ymm8,%ymm9,%ymm8 .byte 196,193,116,95,207 // vmaxps %ymm15,%ymm1,%ymm1 .byte 196,65,44,95,207 // vmaxps %ymm15,%ymm10,%ymm9 .byte 196,195,37,74,192,0 // vblendvps %ymm0,%ymm8,%ymm11,%ymm0 .byte 196,65,124,95,199 // vmaxps %ymm15,%ymm0,%ymm8 .byte 196,226,125,24,5,170,105,0,0 // vbroadcastss 0x69aa(%rip),%ymm0 # 7c50 <_sk_callback_avx+0x1e0> .byte 197,124,92,215 // vsubps %ymm7,%ymm0,%ymm10 .byte 197,172,89,84,36,168 // vmulps -0x58(%rsp),%ymm10,%ymm2 .byte 197,124,92,219 // vsubps %ymm3,%ymm0,%ymm11 .byte 197,164,89,196 // vmulps %ymm4,%ymm11,%ymm0 .byte 197,252,88,194 // vaddps %ymm2,%ymm0,%ymm0 .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 197,172,89,76,36,200 // vmulps -0x38(%rsp),%ymm10,%ymm1 .byte 197,164,89,213 // vmulps %ymm5,%ymm11,%ymm2 .byte 197,236,88,201 // vaddps %ymm1,%ymm2,%ymm1 .byte 196,193,116,88,201 // vaddps %ymm9,%ymm1,%ymm1 .byte 197,172,89,84,36,136 // vmulps -0x78(%rsp),%ymm10,%ymm2 .byte 197,36,89,206 // vmulps %ymm6,%ymm11,%ymm9 .byte 197,180,88,210 // vaddps %ymm2,%ymm9,%ymm2 .byte 196,193,108,88,208 // vaddps %ymm8,%ymm2,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 196,193,100,92,220 // vsubps %ymm12,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_luminosity_avx .globl _sk_luminosity_avx FUNCTION(_sk_luminosity_avx) _sk_luminosity_avx: .byte 197,124,40,226 // vmovaps %ymm2,%ymm12 .byte 197,124,17,100,36,168 // vmovups %ymm12,-0x58(%rsp) .byte 197,252,17,76,36,200 // vmovups %ymm1,-0x38(%rsp) .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 197,100,89,196 // vmulps %ymm4,%ymm3,%ymm8 .byte 197,100,89,205 // vmulps %ymm5,%ymm3,%ymm9 .byte 196,98,125,24,45,60,105,0,0 // vbroadcastss 0x693c(%rip),%ymm13 # 7c54 <_sk_callback_avx+0x1e4> .byte 196,65,108,89,213 // vmulps %ymm13,%ymm2,%ymm10 .byte 196,98,125,24,53,50,105,0,0 // vbroadcastss 0x6932(%rip),%ymm14 # 7c58 <_sk_callback_avx+0x1e8> .byte 196,65,116,89,222 // vmulps %ymm14,%ymm1,%ymm11 .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 196,98,125,24,61,35,105,0,0 // vbroadcastss 0x6923(%rip),%ymm15 # 7c5c <_sk_callback_avx+0x1ec> .byte 196,65,28,89,223 // vmulps %ymm15,%ymm12,%ymm11 .byte 196,193,44,88,195 // vaddps %ymm11,%ymm10,%ymm0 .byte 196,65,60,89,221 // vmulps %ymm13,%ymm8,%ymm11 .byte 196,65,52,89,230 // vmulps %ymm14,%ymm9,%ymm12 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 197,100,89,230 // vmulps %ymm6,%ymm3,%ymm12 .byte 196,65,28,89,215 // vmulps %ymm15,%ymm12,%ymm10 .byte 196,65,36,88,210 // vaddps %ymm10,%ymm11,%ymm10 .byte 197,252,89,199 // vmulps %ymm7,%ymm0,%ymm0 .byte 196,193,124,92,194 // vsubps %ymm10,%ymm0,%ymm0 .byte 197,60,88,192 // vaddps %ymm0,%ymm8,%ymm8 .byte 197,52,88,208 // vaddps %ymm0,%ymm9,%ymm10 .byte 197,28,88,216 // vaddps %ymm0,%ymm12,%ymm11 .byte 196,193,44,93,195 // vminps %ymm11,%ymm10,%ymm0 .byte 197,60,93,224 // vminps %ymm0,%ymm8,%ymm12 .byte 196,193,60,89,197 // vmulps %ymm13,%ymm8,%ymm0 .byte 196,65,44,89,206 // vmulps %ymm14,%ymm10,%ymm9 .byte 196,193,124,88,193 // vaddps %ymm9,%ymm0,%ymm0 .byte 196,65,36,89,207 // vmulps %ymm15,%ymm11,%ymm9 .byte 197,52,88,200 // vaddps %ymm0,%ymm9,%ymm9 .byte 196,193,60,92,193 // vsubps %ymm9,%ymm8,%ymm0 .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 196,65,52,92,236 // vsubps %ymm12,%ymm9,%ymm13 .byte 196,193,124,94,197 // vdivps %ymm13,%ymm0,%ymm0 .byte 196,65,44,92,241 // vsubps %ymm9,%ymm10,%ymm14 .byte 196,65,52,89,246 // vmulps %ymm14,%ymm9,%ymm14 .byte 196,65,12,94,245 // vdivps %ymm13,%ymm14,%ymm14 .byte 196,65,36,92,249 // vsubps %ymm9,%ymm11,%ymm15 .byte 196,65,52,89,255 // vmulps %ymm15,%ymm9,%ymm15 .byte 196,65,4,94,237 // vdivps %ymm13,%ymm15,%ymm13 .byte 196,65,4,87,255 // vxorps %ymm15,%ymm15,%ymm15 .byte 196,65,4,194,228,2 // vcmpleps %ymm12,%ymm15,%ymm12 .byte 196,65,52,88,246 // vaddps %ymm14,%ymm9,%ymm14 .byte 196,67,13,74,242,192 // vblendvps %ymm12,%ymm10,%ymm14,%ymm14 .byte 196,65,44,95,211 // vmaxps %ymm11,%ymm10,%ymm10 .byte 196,65,52,88,237 // vaddps %ymm13,%ymm9,%ymm13 .byte 196,67,21,74,219,192 // vblendvps %ymm12,%ymm11,%ymm13,%ymm11 .byte 197,180,88,192 // vaddps %ymm0,%ymm9,%ymm0 .byte 196,195,125,74,200,192 // vblendvps %ymm12,%ymm8,%ymm0,%ymm1 .byte 197,100,89,231 // vmulps %ymm7,%ymm3,%ymm12 .byte 196,65,60,95,194 // vmaxps %ymm10,%ymm8,%ymm8 .byte 196,65,116,92,209 // vsubps %ymm9,%ymm1,%ymm10 .byte 196,65,28,92,233 // vsubps %ymm9,%ymm12,%ymm13 .byte 196,65,20,89,210 // vmulps %ymm10,%ymm13,%ymm10 .byte 196,193,28,194,192,1 // vcmpltps %ymm8,%ymm12,%ymm0 .byte 196,65,60,92,193 // vsubps %ymm9,%ymm8,%ymm8 .byte 196,65,44,94,208 // vdivps %ymm8,%ymm10,%ymm10 .byte 196,65,52,88,210 // vaddps %ymm10,%ymm9,%ymm10 .byte 196,195,117,74,202,0 // vblendvps %ymm0,%ymm10,%ymm1,%ymm1 .byte 196,65,12,92,209 // vsubps %ymm9,%ymm14,%ymm10 .byte 196,65,20,89,210 // vmulps %ymm10,%ymm13,%ymm10 .byte 196,65,44,94,208 // vdivps %ymm8,%ymm10,%ymm10 .byte 196,65,52,88,210 // vaddps %ymm10,%ymm9,%ymm10 .byte 196,67,13,74,210,0 // vblendvps %ymm0,%ymm10,%ymm14,%ymm10 .byte 196,65,36,92,241 // vsubps %ymm9,%ymm11,%ymm14 .byte 196,65,20,89,238 // vmulps %ymm14,%ymm13,%ymm13 .byte 196,65,20,94,192 // vdivps %ymm8,%ymm13,%ymm8 .byte 196,65,52,88,192 // vaddps %ymm8,%ymm9,%ymm8 .byte 196,193,116,95,207 // vmaxps %ymm15,%ymm1,%ymm1 .byte 196,65,44,95,207 // vmaxps %ymm15,%ymm10,%ymm9 .byte 196,195,37,74,192,0 // vblendvps %ymm0,%ymm8,%ymm11,%ymm0 .byte 196,65,124,95,199 // vmaxps %ymm15,%ymm0,%ymm8 .byte 196,226,125,24,5,234,103,0,0 // vbroadcastss 0x67ea(%rip),%ymm0 # 7c60 <_sk_callback_avx+0x1f0> .byte 197,124,92,215 // vsubps %ymm7,%ymm0,%ymm10 .byte 197,172,89,210 // vmulps %ymm2,%ymm10,%ymm2 .byte 197,124,92,219 // vsubps %ymm3,%ymm0,%ymm11 .byte 197,164,89,196 // vmulps %ymm4,%ymm11,%ymm0 .byte 197,252,88,194 // vaddps %ymm2,%ymm0,%ymm0 .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 197,172,89,76,36,200 // vmulps -0x38(%rsp),%ymm10,%ymm1 .byte 197,164,89,213 // vmulps %ymm5,%ymm11,%ymm2 .byte 197,236,88,201 // vaddps %ymm1,%ymm2,%ymm1 .byte 196,193,116,88,201 // vaddps %ymm9,%ymm1,%ymm1 .byte 197,172,89,84,36,168 // vmulps -0x58(%rsp),%ymm10,%ymm2 .byte 197,36,89,206 // vmulps %ymm6,%ymm11,%ymm9 .byte 197,180,88,210 // vaddps %ymm2,%ymm9,%ymm2 .byte 196,193,108,88,208 // vaddps %ymm8,%ymm2,%ymm2 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 196,193,100,92,220 // vsubps %ymm12,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_rgba_8888_avx .globl _sk_srcover_rgba_8888_avx FUNCTION(_sk_srcover_rgba_8888_avx) _sk_srcover_rgba_8888_avx: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,41,1,0,0 // jne 1611 <_sk_srcover_rgba_8888_avx+0x150> .byte 197,252,16,56 // vmovups (%rax),%ymm7 .byte 197,124,40,13,140,109,0,0 // vmovaps 0x6d8c(%rip),%ymm9 # 8280 <_sk_callback_avx+0x810> .byte 196,193,68,84,225 // vandps %ymm9,%ymm7,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 197,209,114,215,8 // vpsrld $0x8,%xmm7,%xmm5 .byte 196,195,125,25,248,1 // vextractf128 $0x1,%ymm7,%xmm8 .byte 196,193,73,114,208,8 // vpsrld $0x8,%xmm8,%xmm6 .byte 196,227,85,24,238,1 // vinsertf128 $0x1,%xmm6,%ymm5,%ymm5 .byte 196,193,84,84,233 // vandps %ymm9,%ymm5,%ymm5 .byte 197,252,91,237 // vcvtdq2ps %ymm5,%ymm5 .byte 197,169,114,215,16 // vpsrld $0x10,%xmm7,%xmm10 .byte 196,193,73,114,208,16 // vpsrld $0x10,%xmm8,%xmm6 .byte 196,227,45,24,246,1 // vinsertf128 $0x1,%xmm6,%ymm10,%ymm6 .byte 196,193,76,84,241 // vandps %ymm9,%ymm6,%ymm6 .byte 197,252,91,246 // vcvtdq2ps %ymm6,%ymm6 .byte 197,177,114,215,24 // vpsrld $0x18,%xmm7,%xmm9 .byte 196,193,65,114,208,24 // vpsrld $0x18,%xmm8,%xmm7 .byte 196,227,53,24,255,1 // vinsertf128 $0x1,%xmm7,%ymm9,%ymm7 .byte 197,252,91,255 // vcvtdq2ps %ymm7,%ymm7 .byte 196,98,125,24,5,15,103,0,0 // vbroadcastss 0x670f(%rip),%ymm8 # 7c64 <_sk_callback_avx+0x1f4> .byte 197,60,92,195 // vsubps %ymm3,%ymm8,%ymm8 .byte 196,98,125,24,13,6,103,0,0 // vbroadcastss 0x6706(%rip),%ymm9 # 7c68 <_sk_callback_avx+0x1f8> .byte 196,193,124,89,193 // vmulps %ymm9,%ymm0,%ymm0 .byte 197,60,89,212 // vmulps %ymm4,%ymm8,%ymm10 .byte 196,193,124,88,194 // vaddps %ymm10,%ymm0,%ymm0 .byte 196,193,116,89,201 // vmulps %ymm9,%ymm1,%ymm1 .byte 197,60,89,213 // vmulps %ymm5,%ymm8,%ymm10 .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 196,193,108,89,209 // vmulps %ymm9,%ymm2,%ymm2 .byte 197,60,89,214 // vmulps %ymm6,%ymm8,%ymm10 .byte 196,193,108,88,210 // vaddps %ymm10,%ymm2,%ymm2 .byte 196,193,100,89,217 // vmulps %ymm9,%ymm3,%ymm3 .byte 197,60,89,199 // vmulps %ymm7,%ymm8,%ymm8 .byte 196,193,100,88,216 // vaddps %ymm8,%ymm3,%ymm3 .byte 197,125,91,192 // vcvtps2dq %ymm0,%ymm8 .byte 197,125,91,201 // vcvtps2dq %ymm1,%ymm9 .byte 196,193,41,114,241,8 // vpslld $0x8,%xmm9,%xmm10 .byte 196,67,125,25,201,1 // vextractf128 $0x1,%ymm9,%xmm9 .byte 196,193,49,114,241,8 // vpslld $0x8,%xmm9,%xmm9 .byte 196,67,45,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm9 .byte 196,65,53,86,192 // vorpd %ymm8,%ymm9,%ymm8 .byte 197,125,91,202 // vcvtps2dq %ymm2,%ymm9 .byte 196,193,41,114,241,16 // vpslld $0x10,%xmm9,%xmm10 .byte 196,67,125,25,201,1 // vextractf128 $0x1,%ymm9,%xmm9 .byte 196,193,49,114,241,16 // vpslld $0x10,%xmm9,%xmm9 .byte 196,67,45,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm9 .byte 197,125,91,211 // vcvtps2dq %ymm3,%ymm10 .byte 196,193,33,114,242,24 // vpslld $0x18,%xmm10,%xmm11 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,242,24 // vpslld $0x18,%xmm10,%xmm10 .byte 196,67,37,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 .byte 196,65,53,86,202 // vorpd %ymm10,%ymm9,%ymm9 .byte 196,65,61,86,193 // vorpd %ymm9,%ymm8,%ymm8 .byte 77,133,192 // test %r8,%r8 .byte 117,86 // jne 165c <_sk_srcover_rgba_8888_avx+0x19b> .byte 197,124,17,0 // vmovups %ymm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,226 // vmovq %r10,%xmm4 .byte 196,226,121,48,228 // vpmovzxbw %xmm4,%xmm4 .byte 196,226,89,0,45,151,106,0,0 // vpshufb 0x6a97(%rip),%xmm4,%xmm5 # 80d0 <_sk_callback_avx+0x660> .byte 196,226,121,33,237 // vpmovsxbd %xmm5,%xmm5 .byte 196,226,89,0,37,153,106,0,0 // vpshufb 0x6a99(%rip),%xmm4,%xmm4 # 80e0 <_sk_callback_avx+0x670> .byte 196,226,121,33,228 // vpmovsxbd %xmm4,%xmm4 .byte 196,227,85,24,228,1 // vinsertf128 $0x1,%xmm4,%ymm5,%ymm4 .byte 196,226,93,44,56 // vmaskmovps (%rax),%ymm4,%ymm7 .byte 233,144,254,255,255 // jmpq 14ec <_sk_srcover_rgba_8888_avx+0x2b> .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,65,249,110,202 // vmovq %r10,%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,98,49,0,21,76,106,0,0 // vpshufb 0x6a4c(%rip),%xmm9,%xmm10 # 80d0 <_sk_callback_avx+0x660> .byte 196,66,121,33,210 // vpmovsxbd %xmm10,%xmm10 .byte 196,98,49,0,13,78,106,0,0 // vpshufb 0x6a4e(%rip),%xmm9,%xmm9 # 80e0 <_sk_callback_avx+0x670> .byte 196,66,121,33,201 // vpmovsxbd %xmm9,%xmm9 .byte 196,67,45,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm9 .byte 196,98,53,46,0 // vmaskmovps %ymm8,%ymm9,(%rax) .byte 233,99,255,255,255 // jmpq 160a <_sk_srcover_rgba_8888_avx+0x149> HIDDEN _sk_clamp_0_avx .globl _sk_clamp_0_avx FUNCTION(_sk_clamp_0_avx) _sk_clamp_0_avx: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,124,95,192 // vmaxps %ymm8,%ymm0,%ymm0 .byte 196,193,116,95,200 // vmaxps %ymm8,%ymm1,%ymm1 .byte 196,193,108,95,208 // vmaxps %ymm8,%ymm2,%ymm2 .byte 196,193,100,95,216 // vmaxps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_1_avx .globl _sk_clamp_1_avx FUNCTION(_sk_clamp_1_avx) _sk_clamp_1_avx: .byte 196,98,125,24,5,159,101,0,0 // vbroadcastss 0x659f(%rip),%ymm8 # 7c6c <_sk_callback_avx+0x1fc> .byte 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 .byte 196,193,116,93,200 // vminps %ymm8,%ymm1,%ymm1 .byte 196,193,108,93,208 // vminps %ymm8,%ymm2,%ymm2 .byte 196,193,100,93,216 // vminps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_a_avx .globl _sk_clamp_a_avx FUNCTION(_sk_clamp_a_avx) _sk_clamp_a_avx: .byte 196,98,125,24,5,130,101,0,0 // vbroadcastss 0x6582(%rip),%ymm8 # 7c70 <_sk_callback_avx+0x200> .byte 196,193,100,93,216 // vminps %ymm8,%ymm3,%ymm3 .byte 197,252,93,195 // vminps %ymm3,%ymm0,%ymm0 .byte 197,244,93,203 // vminps %ymm3,%ymm1,%ymm1 .byte 197,236,93,211 // vminps %ymm3,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_a_dst_avx .globl _sk_clamp_a_dst_avx FUNCTION(_sk_clamp_a_dst_avx) _sk_clamp_a_dst_avx: .byte 196,98,125,24,5,104,101,0,0 // vbroadcastss 0x6568(%rip),%ymm8 # 7c74 <_sk_callback_avx+0x204> .byte 196,193,68,93,248 // vminps %ymm8,%ymm7,%ymm7 .byte 197,220,93,231 // vminps %ymm7,%ymm4,%ymm4 .byte 197,212,93,239 // vminps %ymm7,%ymm5,%ymm5 .byte 197,204,93,247 // vminps %ymm7,%ymm6,%ymm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_set_rgb_avx .globl _sk_set_rgb_avx FUNCTION(_sk_set_rgb_avx) _sk_set_rgb_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,0 // vbroadcastss (%rax),%ymm0 .byte 196,226,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm1 .byte 196,226,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_swap_rb_avx .globl _sk_swap_rb_avx FUNCTION(_sk_swap_rb_avx) _sk_swap_rb_avx: .byte 197,124,40,192 // vmovaps %ymm0,%ymm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,194 // vmovaps %ymm2,%ymm0 .byte 197,124,41,194 // vmovaps %ymm8,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_invert_avx .globl _sk_invert_avx FUNCTION(_sk_invert_avx) _sk_invert_avx: .byte 196,98,125,24,5,39,101,0,0 // vbroadcastss 0x6527(%rip),%ymm8 # 7c78 <_sk_callback_avx+0x208> .byte 197,188,92,192 // vsubps %ymm0,%ymm8,%ymm0 .byte 197,188,92,201 // vsubps %ymm1,%ymm8,%ymm1 .byte 197,188,92,210 // vsubps %ymm2,%ymm8,%ymm2 .byte 197,188,92,219 // vsubps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_move_src_dst_avx .globl _sk_move_src_dst_avx FUNCTION(_sk_move_src_dst_avx) _sk_move_src_dst_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,224 // vmovaps %ymm0,%ymm4 .byte 197,252,40,233 // vmovaps %ymm1,%ymm5 .byte 197,252,40,242 // vmovaps %ymm2,%ymm6 .byte 197,252,40,251 // vmovaps %ymm3,%ymm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_move_dst_src_avx .globl _sk_move_dst_src_avx FUNCTION(_sk_move_dst_src_avx) _sk_move_dst_src_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,196 // vmovaps %ymm4,%ymm0 .byte 197,252,40,205 // vmovaps %ymm5,%ymm1 .byte 197,252,40,214 // vmovaps %ymm6,%ymm2 .byte 197,252,40,223 // vmovaps %ymm7,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_avx .globl _sk_premul_avx FUNCTION(_sk_premul_avx) _sk_premul_avx: .byte 197,252,89,195 // vmulps %ymm3,%ymm0,%ymm0 .byte 197,244,89,203 // vmulps %ymm3,%ymm1,%ymm1 .byte 197,236,89,211 // vmulps %ymm3,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_dst_avx .globl _sk_premul_dst_avx FUNCTION(_sk_premul_dst_avx) _sk_premul_dst_avx: .byte 197,220,89,231 // vmulps %ymm7,%ymm4,%ymm4 .byte 197,212,89,239 // vmulps %ymm7,%ymm5,%ymm5 .byte 197,204,89,247 // vmulps %ymm7,%ymm6,%ymm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_unpremul_avx .globl _sk_unpremul_avx FUNCTION(_sk_unpremul_avx) _sk_unpremul_avx: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,65,100,194,200,0 // vcmpeqps %ymm8,%ymm3,%ymm9 .byte 196,98,125,24,21,187,100,0,0 // vbroadcastss 0x64bb(%rip),%ymm10 # 7c7c <_sk_callback_avx+0x20c> .byte 197,44,94,211 // vdivps %ymm3,%ymm10,%ymm10 .byte 196,67,45,74,192,144 // vblendvps %ymm9,%ymm8,%ymm10,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_from_srgb_avx .globl _sk_from_srgb_avx FUNCTION(_sk_from_srgb_avx) _sk_from_srgb_avx: .byte 196,98,125,24,5,156,100,0,0 // vbroadcastss 0x649c(%rip),%ymm8 # 7c80 <_sk_callback_avx+0x210> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 197,124,89,208 // vmulps %ymm0,%ymm0,%ymm10 .byte 196,98,125,24,29,142,100,0,0 // vbroadcastss 0x648e(%rip),%ymm11 # 7c84 <_sk_callback_avx+0x214> .byte 196,65,124,89,227 // vmulps %ymm11,%ymm0,%ymm12 .byte 196,98,125,24,45,132,100,0,0 // vbroadcastss 0x6484(%rip),%ymm13 # 7c88 <_sk_callback_avx+0x218> .byte 196,65,28,88,229 // vaddps %ymm13,%ymm12,%ymm12 .byte 196,65,44,89,212 // vmulps %ymm12,%ymm10,%ymm10 .byte 196,98,125,24,37,117,100,0,0 // vbroadcastss 0x6475(%rip),%ymm12 # 7c8c <_sk_callback_avx+0x21c> .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,98,125,24,53,107,100,0,0 // vbroadcastss 0x646b(%rip),%ymm14 # 7c90 <_sk_callback_avx+0x220> .byte 196,193,124,194,198,1 // vcmpltps %ymm14,%ymm0,%ymm0 .byte 196,195,45,74,193,0 // vblendvps %ymm0,%ymm9,%ymm10,%ymm0 .byte 196,65,116,89,200 // vmulps %ymm8,%ymm1,%ymm9 .byte 197,116,89,209 // vmulps %ymm1,%ymm1,%ymm10 .byte 196,65,116,89,251 // vmulps %ymm11,%ymm1,%ymm15 .byte 196,65,4,88,253 // vaddps %ymm13,%ymm15,%ymm15 .byte 196,65,44,89,215 // vmulps %ymm15,%ymm10,%ymm10 .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,193,116,194,206,1 // vcmpltps %ymm14,%ymm1,%ymm1 .byte 196,195,45,74,201,16 // vblendvps %ymm1,%ymm9,%ymm10,%ymm1 .byte 196,65,108,89,192 // vmulps %ymm8,%ymm2,%ymm8 .byte 197,108,89,202 // vmulps %ymm2,%ymm2,%ymm9 .byte 196,65,108,89,211 // vmulps %ymm11,%ymm2,%ymm10 .byte 196,65,44,88,213 // vaddps %ymm13,%ymm10,%ymm10 .byte 196,65,52,89,202 // vmulps %ymm10,%ymm9,%ymm9 .byte 196,65,52,88,204 // vaddps %ymm12,%ymm9,%ymm9 .byte 196,193,108,194,214,1 // vcmpltps %ymm14,%ymm2,%ymm2 .byte 196,195,53,74,208,32 // vblendvps %ymm2,%ymm8,%ymm9,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_from_srgb_dst_avx .globl _sk_from_srgb_dst_avx FUNCTION(_sk_from_srgb_dst_avx) _sk_from_srgb_dst_avx: .byte 196,98,125,24,5,4,100,0,0 // vbroadcastss 0x6404(%rip),%ymm8 # 7c94 <_sk_callback_avx+0x224> .byte 196,65,92,89,200 // vmulps %ymm8,%ymm4,%ymm9 .byte 197,92,89,212 // vmulps %ymm4,%ymm4,%ymm10 .byte 196,98,125,24,29,246,99,0,0 // vbroadcastss 0x63f6(%rip),%ymm11 # 7c98 <_sk_callback_avx+0x228> .byte 196,65,92,89,227 // vmulps %ymm11,%ymm4,%ymm12 .byte 196,98,125,24,45,236,99,0,0 // vbroadcastss 0x63ec(%rip),%ymm13 # 7c9c <_sk_callback_avx+0x22c> .byte 196,65,28,88,229 // vaddps %ymm13,%ymm12,%ymm12 .byte 196,65,44,89,212 // vmulps %ymm12,%ymm10,%ymm10 .byte 196,98,125,24,37,221,99,0,0 // vbroadcastss 0x63dd(%rip),%ymm12 # 7ca0 <_sk_callback_avx+0x230> .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,98,125,24,53,211,99,0,0 // vbroadcastss 0x63d3(%rip),%ymm14 # 7ca4 <_sk_callback_avx+0x234> .byte 196,193,92,194,230,1 // vcmpltps %ymm14,%ymm4,%ymm4 .byte 196,195,45,74,225,64 // vblendvps %ymm4,%ymm9,%ymm10,%ymm4 .byte 196,65,84,89,200 // vmulps %ymm8,%ymm5,%ymm9 .byte 197,84,89,213 // vmulps %ymm5,%ymm5,%ymm10 .byte 196,65,84,89,251 // vmulps %ymm11,%ymm5,%ymm15 .byte 196,65,4,88,253 // vaddps %ymm13,%ymm15,%ymm15 .byte 196,65,44,89,215 // vmulps %ymm15,%ymm10,%ymm10 .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 .byte 196,193,84,194,238,1 // vcmpltps %ymm14,%ymm5,%ymm5 .byte 196,195,45,74,233,80 // vblendvps %ymm5,%ymm9,%ymm10,%ymm5 .byte 196,65,76,89,192 // vmulps %ymm8,%ymm6,%ymm8 .byte 197,76,89,206 // vmulps %ymm6,%ymm6,%ymm9 .byte 196,65,76,89,211 // vmulps %ymm11,%ymm6,%ymm10 .byte 196,65,44,88,213 // vaddps %ymm13,%ymm10,%ymm10 .byte 196,65,52,89,202 // vmulps %ymm10,%ymm9,%ymm9 .byte 196,65,52,88,204 // vaddps %ymm12,%ymm9,%ymm9 .byte 196,193,76,194,246,1 // vcmpltps %ymm14,%ymm6,%ymm6 .byte 196,195,53,74,240,96 // vblendvps %ymm6,%ymm8,%ymm9,%ymm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_to_srgb_avx .globl _sk_to_srgb_avx FUNCTION(_sk_to_srgb_avx) _sk_to_srgb_avx: .byte 197,124,82,200 // vrsqrtps %ymm0,%ymm9 .byte 196,98,125,24,5,104,99,0,0 // vbroadcastss 0x6368(%rip),%ymm8 # 7ca8 <_sk_callback_avx+0x238> .byte 196,65,124,89,208 // vmulps %ymm8,%ymm0,%ymm10 .byte 196,98,125,24,29,94,99,0,0 // vbroadcastss 0x635e(%rip),%ymm11 # 7cac <_sk_callback_avx+0x23c> .byte 196,65,52,89,227 // vmulps %ymm11,%ymm9,%ymm12 .byte 196,98,125,24,45,84,99,0,0 // vbroadcastss 0x6354(%rip),%ymm13 # 7cb0 <_sk_callback_avx+0x240> .byte 196,65,28,88,229 // vaddps %ymm13,%ymm12,%ymm12 .byte 196,65,52,89,228 // vmulps %ymm12,%ymm9,%ymm12 .byte 196,98,125,24,53,69,99,0,0 // vbroadcastss 0x6345(%rip),%ymm14 # 7cb4 <_sk_callback_avx+0x244> .byte 196,65,28,88,230 // vaddps %ymm14,%ymm12,%ymm12 .byte 196,98,125,24,61,59,99,0,0 // vbroadcastss 0x633b(%rip),%ymm15 # 7cb8 <_sk_callback_avx+0x248> .byte 196,65,52,88,207 // vaddps %ymm15,%ymm9,%ymm9 .byte 196,65,124,83,201 // vrcpps %ymm9,%ymm9 .byte 196,65,52,89,204 // vmulps %ymm12,%ymm9,%ymm9 .byte 196,98,125,24,37,39,99,0,0 // vbroadcastss 0x6327(%rip),%ymm12 # 7cbc <_sk_callback_avx+0x24c> .byte 196,193,124,194,196,1 // vcmpltps %ymm12,%ymm0,%ymm0 .byte 196,195,53,74,194,0 // vblendvps %ymm0,%ymm10,%ymm9,%ymm0 .byte 197,124,82,201 // vrsqrtps %ymm1,%ymm9 .byte 196,65,52,89,211 // vmulps %ymm11,%ymm9,%ymm10 .byte 196,65,44,88,213 // vaddps %ymm13,%ymm10,%ymm10 .byte 196,65,52,89,210 // vmulps %ymm10,%ymm9,%ymm10 .byte 196,65,44,88,214 // vaddps %ymm14,%ymm10,%ymm10 .byte 196,65,52,88,207 // vaddps %ymm15,%ymm9,%ymm9 .byte 196,65,124,83,201 // vrcpps %ymm9,%ymm9 .byte 196,65,52,89,202 // vmulps %ymm10,%ymm9,%ymm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,193,116,194,204,1 // vcmpltps %ymm12,%ymm1,%ymm1 .byte 196,195,53,74,202,16 // vblendvps %ymm1,%ymm10,%ymm9,%ymm1 .byte 197,124,82,202 // vrsqrtps %ymm2,%ymm9 .byte 196,65,52,89,211 // vmulps %ymm11,%ymm9,%ymm10 .byte 196,65,44,88,213 // vaddps %ymm13,%ymm10,%ymm10 .byte 196,65,52,89,210 // vmulps %ymm10,%ymm9,%ymm10 .byte 196,65,44,88,214 // vaddps %ymm14,%ymm10,%ymm10 .byte 196,65,52,88,207 // vaddps %ymm15,%ymm9,%ymm9 .byte 196,65,124,83,201 // vrcpps %ymm9,%ymm9 .byte 196,65,52,89,202 // vmulps %ymm10,%ymm9,%ymm9 .byte 196,65,108,89,192 // vmulps %ymm8,%ymm2,%ymm8 .byte 196,193,108,194,212,1 // vcmpltps %ymm12,%ymm2,%ymm2 .byte 196,195,53,74,208,32 // vblendvps %ymm2,%ymm8,%ymm9,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_rgb_to_hsl_avx .globl _sk_rgb_to_hsl_avx FUNCTION(_sk_rgb_to_hsl_avx) _sk_rgb_to_hsl_avx: .byte 197,124,95,193 // vmaxps %ymm1,%ymm0,%ymm8 .byte 197,60,95,194 // vmaxps %ymm2,%ymm8,%ymm8 .byte 197,124,93,201 // vminps %ymm1,%ymm0,%ymm9 .byte 197,52,93,202 // vminps %ymm2,%ymm9,%ymm9 .byte 196,65,60,92,209 // vsubps %ymm9,%ymm8,%ymm10 .byte 196,98,125,24,29,141,98,0,0 // vbroadcastss 0x628d(%rip),%ymm11 # 7cc0 <_sk_callback_avx+0x250> .byte 196,65,36,94,218 // vdivps %ymm10,%ymm11,%ymm11 .byte 197,116,92,226 // vsubps %ymm2,%ymm1,%ymm12 .byte 196,65,28,89,227 // vmulps %ymm11,%ymm12,%ymm12 .byte 197,116,194,234,1 // vcmpltps %ymm2,%ymm1,%ymm13 .byte 197,60,194,241,0 // vcmpeqps %ymm1,%ymm8,%ymm14 .byte 197,236,92,208 // vsubps %ymm0,%ymm2,%ymm2 .byte 196,193,108,89,211 // vmulps %ymm11,%ymm2,%ymm2 .byte 197,252,92,201 // vsubps %ymm1,%ymm0,%ymm1 .byte 196,193,116,89,203 // vmulps %ymm11,%ymm1,%ymm1 .byte 196,98,125,24,29,102,98,0,0 // vbroadcastss 0x6266(%rip),%ymm11 # 7ccc <_sk_callback_avx+0x25c> .byte 196,193,116,88,203 // vaddps %ymm11,%ymm1,%ymm1 .byte 196,98,125,24,29,84,98,0,0 // vbroadcastss 0x6254(%rip),%ymm11 # 7cc8 <_sk_callback_avx+0x258> .byte 196,193,108,88,211 // vaddps %ymm11,%ymm2,%ymm2 .byte 196,227,117,74,202,224 // vblendvps %ymm14,%ymm2,%ymm1,%ymm1 .byte 196,226,125,24,21,60,98,0,0 // vbroadcastss 0x623c(%rip),%ymm2 # 7cc4 <_sk_callback_avx+0x254> .byte 196,65,12,87,246 // vxorps %ymm14,%ymm14,%ymm14 .byte 196,227,13,74,210,208 // vblendvps %ymm13,%ymm2,%ymm14,%ymm2 .byte 197,188,194,192,0 // vcmpeqps %ymm0,%ymm8,%ymm0 .byte 196,193,108,88,212 // vaddps %ymm12,%ymm2,%ymm2 .byte 196,227,117,74,194,0 // vblendvps %ymm0,%ymm2,%ymm1,%ymm0 .byte 196,193,60,88,201 // vaddps %ymm9,%ymm8,%ymm1 .byte 196,98,125,24,37,35,98,0,0 // vbroadcastss 0x6223(%rip),%ymm12 # 7cd4 <_sk_callback_avx+0x264> .byte 196,193,116,89,212 // vmulps %ymm12,%ymm1,%ymm2 .byte 197,28,194,226,1 // vcmpltps %ymm2,%ymm12,%ymm12 .byte 196,65,36,92,216 // vsubps %ymm8,%ymm11,%ymm11 .byte 196,65,36,92,217 // vsubps %ymm9,%ymm11,%ymm11 .byte 196,195,117,74,203,192 // vblendvps %ymm12,%ymm11,%ymm1,%ymm1 .byte 196,65,60,194,193,0 // vcmpeqps %ymm9,%ymm8,%ymm8 .byte 197,172,94,201 // vdivps %ymm1,%ymm10,%ymm1 .byte 196,195,125,74,198,128 // vblendvps %ymm8,%ymm14,%ymm0,%ymm0 .byte 196,195,117,74,206,128 // vblendvps %ymm8,%ymm14,%ymm1,%ymm1 .byte 196,98,125,24,5,230,97,0,0 // vbroadcastss 0x61e6(%rip),%ymm8 # 7cd0 <_sk_callback_avx+0x260> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_hsl_to_rgb_avx .globl _sk_hsl_to_rgb_avx FUNCTION(_sk_hsl_to_rgb_avx) _sk_hsl_to_rgb_avx: .byte 72,131,236,56 // sub $0x38,%rsp .byte 197,252,17,60,36 // vmovups %ymm7,(%rsp) .byte 197,252,17,116,36,224 // vmovups %ymm6,-0x20(%rsp) .byte 197,252,17,108,36,192 // vmovups %ymm5,-0x40(%rsp) .byte 197,252,17,100,36,160 // vmovups %ymm4,-0x60(%rsp) .byte 197,252,17,92,36,128 // vmovups %ymm3,-0x80(%rsp) .byte 197,252,40,225 // vmovaps %ymm1,%ymm4 .byte 197,252,40,216 // vmovaps %ymm0,%ymm3 .byte 196,98,125,24,5,179,97,0,0 // vbroadcastss 0x61b3(%rip),%ymm8 # 7cd8 <_sk_callback_avx+0x268> .byte 197,60,194,202,2 // vcmpleps %ymm2,%ymm8,%ymm9 .byte 197,92,89,210 // vmulps %ymm2,%ymm4,%ymm10 .byte 196,65,92,92,218 // vsubps %ymm10,%ymm4,%ymm11 .byte 196,67,45,74,203,144 // vblendvps %ymm9,%ymm11,%ymm10,%ymm9 .byte 197,52,88,210 // vaddps %ymm2,%ymm9,%ymm10 .byte 197,108,88,202 // vaddps %ymm2,%ymm2,%ymm9 .byte 196,65,52,92,202 // vsubps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,29,141,97,0,0 // vbroadcastss 0x618d(%rip),%ymm11 # 7cdc <_sk_callback_avx+0x26c> .byte 196,65,100,88,219 // vaddps %ymm11,%ymm3,%ymm11 .byte 196,67,125,8,227,1 // vroundps $0x1,%ymm11,%ymm12 .byte 196,65,36,92,252 // vsubps %ymm12,%ymm11,%ymm15 .byte 196,65,44,92,217 // vsubps %ymm9,%ymm10,%ymm11 .byte 196,98,125,24,37,119,97,0,0 // vbroadcastss 0x6177(%rip),%ymm12 # 7ce4 <_sk_callback_avx+0x274> .byte 196,193,4,89,196 // vmulps %ymm12,%ymm15,%ymm0 .byte 196,98,125,24,45,109,97,0,0 // vbroadcastss 0x616d(%rip),%ymm13 # 7ce8 <_sk_callback_avx+0x278> .byte 197,20,92,240 // vsubps %ymm0,%ymm13,%ymm14 .byte 196,65,36,89,246 // vmulps %ymm14,%ymm11,%ymm14 .byte 196,65,52,88,246 // vaddps %ymm14,%ymm9,%ymm14 .byte 196,226,125,24,13,78,97,0,0 // vbroadcastss 0x614e(%rip),%ymm1 # 7ce0 <_sk_callback_avx+0x270> .byte 196,193,116,194,255,2 // vcmpleps %ymm15,%ymm1,%ymm7 .byte 196,195,13,74,249,112 // vblendvps %ymm7,%ymm9,%ymm14,%ymm7 .byte 196,65,60,194,247,2 // vcmpleps %ymm15,%ymm8,%ymm14 .byte 196,227,45,74,255,224 // vblendvps %ymm14,%ymm7,%ymm10,%ymm7 .byte 196,98,125,24,53,57,97,0,0 // vbroadcastss 0x6139(%rip),%ymm14 # 7cec <_sk_callback_avx+0x27c> .byte 196,65,12,194,255,2 // vcmpleps %ymm15,%ymm14,%ymm15 .byte 196,193,124,89,195 // vmulps %ymm11,%ymm0,%ymm0 .byte 197,180,88,192 // vaddps %ymm0,%ymm9,%ymm0 .byte 196,99,125,74,255,240 // vblendvps %ymm15,%ymm7,%ymm0,%ymm15 .byte 196,227,125,8,195,1 // vroundps $0x1,%ymm3,%ymm0 .byte 197,228,92,192 // vsubps %ymm0,%ymm3,%ymm0 .byte 196,193,124,89,252 // vmulps %ymm12,%ymm0,%ymm7 .byte 197,148,92,247 // vsubps %ymm7,%ymm13,%ymm6 .byte 197,164,89,246 // vmulps %ymm6,%ymm11,%ymm6 .byte 197,180,88,246 // vaddps %ymm6,%ymm9,%ymm6 .byte 197,244,194,232,2 // vcmpleps %ymm0,%ymm1,%ymm5 .byte 196,195,77,74,233,80 // vblendvps %ymm5,%ymm9,%ymm6,%ymm5 .byte 197,188,194,240,2 // vcmpleps %ymm0,%ymm8,%ymm6 .byte 196,227,45,74,237,96 // vblendvps %ymm6,%ymm5,%ymm10,%ymm5 .byte 197,140,194,192,2 // vcmpleps %ymm0,%ymm14,%ymm0 .byte 197,164,89,247 // vmulps %ymm7,%ymm11,%ymm6 .byte 197,180,88,246 // vaddps %ymm6,%ymm9,%ymm6 .byte 196,227,77,74,237,0 // vblendvps %ymm0,%ymm5,%ymm6,%ymm5 .byte 196,226,125,24,5,219,96,0,0 // vbroadcastss 0x60db(%rip),%ymm0 # 7cf0 <_sk_callback_avx+0x280> .byte 197,228,88,192 // vaddps %ymm0,%ymm3,%ymm0 .byte 196,227,125,8,216,1 // vroundps $0x1,%ymm0,%ymm3 .byte 197,252,92,195 // vsubps %ymm3,%ymm0,%ymm0 .byte 197,244,194,200,2 // vcmpleps %ymm0,%ymm1,%ymm1 .byte 196,193,124,89,220 // vmulps %ymm12,%ymm0,%ymm3 .byte 197,148,92,243 // vsubps %ymm3,%ymm13,%ymm6 .byte 197,164,89,246 // vmulps %ymm6,%ymm11,%ymm6 .byte 197,180,88,246 // vaddps %ymm6,%ymm9,%ymm6 .byte 196,195,77,74,201,16 // vblendvps %ymm1,%ymm9,%ymm6,%ymm1 .byte 197,188,194,240,2 // vcmpleps %ymm0,%ymm8,%ymm6 .byte 196,227,45,74,201,96 // vblendvps %ymm6,%ymm1,%ymm10,%ymm1 .byte 197,140,194,192,2 // vcmpleps %ymm0,%ymm14,%ymm0 .byte 197,164,89,219 // vmulps %ymm3,%ymm11,%ymm3 .byte 197,180,88,219 // vaddps %ymm3,%ymm9,%ymm3 .byte 196,227,101,74,217,0 // vblendvps %ymm0,%ymm1,%ymm3,%ymm3 .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,220,194,224,0 // vcmpeqps %ymm0,%ymm4,%ymm4 .byte 196,227,5,74,194,64 // vblendvps %ymm4,%ymm2,%ymm15,%ymm0 .byte 196,227,85,74,202,64 // vblendvps %ymm4,%ymm2,%ymm5,%ymm1 .byte 196,227,101,74,210,64 // vblendvps %ymm4,%ymm2,%ymm3,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,92,36,128 // vmovups -0x80(%rsp),%ymm3 .byte 197,252,16,100,36,160 // vmovups -0x60(%rsp),%ymm4 .byte 197,252,16,108,36,192 // vmovups -0x40(%rsp),%ymm5 .byte 197,252,16,116,36,224 // vmovups -0x20(%rsp),%ymm6 .byte 197,252,16,60,36 // vmovups (%rsp),%ymm7 .byte 72,131,196,56 // add $0x38,%rsp .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_1_float_avx .globl _sk_scale_1_float_avx FUNCTION(_sk_scale_1_float_avx) _sk_scale_1_float_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 197,188,89,219 // vmulps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_u8_avx .globl _sk_scale_u8_avx FUNCTION(_sk_scale_u8_avx) _sk_scale_u8_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,75 // jne 1d1c <_sk_scale_u8_avx+0x64> .byte 196,66,121,48,4,25 // vpmovzxbw (%r9,%rbx,1),%xmm8 .byte 197,57,219,5,17,100,0,0 // vpand 0x6411(%rip),%xmm8,%xmm8 # 80f0 <_sk_callback_avx+0x680> .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 196,65,57,105,201 // vpunpckhwd %xmm9,%xmm8,%xmm9 .byte 196,66,121,51,192 // vpmovzxwd %xmm8,%xmm8 .byte 196,67,61,24,193,1 // vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 196,98,125,24,13,242,95,0,0 // vbroadcastss 0x5ff2(%rip),%ymm9 # 7cf4 <_sk_callback_avx+0x284> .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 197,188,89,219 // vmulps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,166 // ja 1cd7 <_sk_scale_u8_avx+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,124,0,0,0 // lea 0x7c(%rip),%r11 # 1db8 <_sk_scale_u8_avx+0x100> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 235,135 // jmp 1cd7 <_sk_scale_u8_avx+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 197,57,196,192,2 // vpinsrw $0x2,%eax,%xmm8,%xmm8 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,121,110,200 // vmovd %eax,%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,67,57,14,193,3 // vpblendw $0x3,%xmm9,%xmm8,%xmm8 .byte 233,94,255,255,255 // jmpq 1cd7 <_sk_scale_u8_avx+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 197,57,196,192,6 // vpinsrw $0x6,%eax,%xmm8,%xmm8 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,57,196,192,5 // vpinsrw $0x5,%eax,%xmm8,%xmm8 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,57,196,192,4 // vpinsrw $0x4,%eax,%xmm8,%xmm8 .byte 196,65,121,110,12,25 // vmovd (%r9,%rbx,1),%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,67,49,14,192,240 // vpblendw $0xf0,%xmm8,%xmm9,%xmm8 .byte 233,34,255,255,255 // jmpq 1cd7 <_sk_scale_u8_avx+0x1f> .byte 15,31,0 // nopl (%rax) .byte 141 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,168,255,255,255,152 // ljmp *-0x67000001(%rax) .byte 255 // (bad) .byte 255 // (bad) .byte 255,231 // jmpq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 220,255 // fdivr %st,%st(7) .byte 255 // (bad) .byte 255,209 // callq *%rcx .byte 255 // (bad) .byte 255 // (bad) .byte 255,193 // inc %ecx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_lerp_1_float_avx .globl _sk_lerp_1_float_avx FUNCTION(_sk_lerp_1_float_avx) _sk_lerp_1_float_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 197,252,92,196 // vsubps %ymm4,%ymm0,%ymm0 .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,252,88,196 // vaddps %ymm4,%ymm0,%ymm0 .byte 197,244,92,205 // vsubps %ymm5,%ymm1,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 197,244,88,205 // vaddps %ymm5,%ymm1,%ymm1 .byte 197,236,92,214 // vsubps %ymm6,%ymm2,%ymm2 .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 197,236,88,214 // vaddps %ymm6,%ymm2,%ymm2 .byte 197,228,92,223 // vsubps %ymm7,%ymm3,%ymm3 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_lerp_u8_avx .globl _sk_lerp_u8_avx FUNCTION(_sk_lerp_u8_avx) _sk_lerp_u8_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,111 // jne 1e9b <_sk_lerp_u8_avx+0x88> .byte 196,66,121,48,4,25 // vpmovzxbw (%r9,%rbx,1),%xmm8 .byte 197,57,219,5,198,98,0,0 // vpand 0x62c6(%rip),%xmm8,%xmm8 # 8100 <_sk_callback_avx+0x690> .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 196,65,57,105,201 // vpunpckhwd %xmm9,%xmm8,%xmm9 .byte 196,66,121,51,192 // vpmovzxwd %xmm8,%xmm8 .byte 196,67,61,24,193,1 // vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 196,98,125,24,13,155,94,0,0 // vbroadcastss 0x5e9b(%rip),%ymm9 # 7cf8 <_sk_callback_avx+0x288> .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 197,252,92,196 // vsubps %ymm4,%ymm0,%ymm0 .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,252,88,196 // vaddps %ymm4,%ymm0,%ymm0 .byte 197,244,92,205 // vsubps %ymm5,%ymm1,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 197,244,88,205 // vaddps %ymm5,%ymm1,%ymm1 .byte 197,236,92,214 // vsubps %ymm6,%ymm2,%ymm2 .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 197,236,88,214 // vaddps %ymm6,%ymm2,%ymm2 .byte 197,228,92,223 // vsubps %ymm7,%ymm3,%ymm3 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,130 // ja 1e32 <_sk_lerp_u8_avx+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,125,0,0,0 // lea 0x7d(%rip),%r11 # 1f38 <_sk_lerp_u8_avx+0x125> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 233,96,255,255,255 // jmpq 1e32 <_sk_lerp_u8_avx+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 197,57,196,192,2 // vpinsrw $0x2,%eax,%xmm8,%xmm8 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,121,110,200 // vmovd %eax,%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,67,57,14,193,3 // vpblendw $0x3,%xmm9,%xmm8,%xmm8 .byte 233,55,255,255,255 // jmpq 1e32 <_sk_lerp_u8_avx+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 197,57,196,192,6 // vpinsrw $0x6,%eax,%xmm8,%xmm8 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,57,196,192,5 // vpinsrw $0x5,%eax,%xmm8,%xmm8 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,57,196,192,4 // vpinsrw $0x4,%eax,%xmm8,%xmm8 .byte 196,65,121,110,12,25 // vmovd (%r9,%rbx,1),%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,67,49,14,192,240 // vpblendw $0xf0,%xmm8,%xmm9,%xmm8 .byte 233,251,254,255,255 // jmpq 1e32 <_sk_lerp_u8_avx+0x1f> .byte 144 // nop .byte 140,255 // mov %?,%edi .byte 255 // (bad) .byte 255,170,255,255,255,154 // ljmp *-0x65000001(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 233,255,255,255,222 // jmpq ffffffffdf001f48 <_sk_callback_avx+0xffffffffdeffa4d8> .byte 255 // (bad) .byte 255 // (bad) .byte 255,211 // callq *%rbx .byte 255 // (bad) .byte 255 // (bad) .byte 255,195 // inc %ebx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_lerp_565_avx .globl _sk_lerp_565_avx FUNCTION(_sk_lerp_565_avx) _sk_lerp_565_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 15,133,209,0,0,0 // jne 2045 <_sk_lerp_565_avx+0xf1> .byte 196,65,122,111,4,89 // vmovdqu (%r9,%rbx,2),%xmm8 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 196,65,57,105,201 // vpunpckhwd %xmm9,%xmm8,%xmm9 .byte 196,66,121,51,192 // vpmovzxwd %xmm8,%xmm8 .byte 196,67,61,24,193,1 // vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 .byte 196,98,125,24,13,100,93,0,0 // vbroadcastss 0x5d64(%rip),%ymm9 # 7cfc <_sk_callback_avx+0x28c> .byte 196,65,60,84,201 // vandps %ymm9,%ymm8,%ymm9 .byte 196,65,124,91,201 // vcvtdq2ps %ymm9,%ymm9 .byte 196,98,125,24,21,85,93,0,0 // vbroadcastss 0x5d55(%rip),%ymm10 # 7d00 <_sk_callback_avx+0x290> .byte 196,65,52,89,202 // vmulps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,21,75,93,0,0 // vbroadcastss 0x5d4b(%rip),%ymm10 # 7d04 <_sk_callback_avx+0x294> .byte 196,65,60,84,210 // vandps %ymm10,%ymm8,%ymm10 .byte 196,65,124,91,210 // vcvtdq2ps %ymm10,%ymm10 .byte 196,98,125,24,29,60,93,0,0 // vbroadcastss 0x5d3c(%rip),%ymm11 # 7d08 <_sk_callback_avx+0x298> .byte 196,65,44,89,211 // vmulps %ymm11,%ymm10,%ymm10 .byte 196,98,125,24,29,50,93,0,0 // vbroadcastss 0x5d32(%rip),%ymm11 # 7d0c <_sk_callback_avx+0x29c> .byte 196,65,60,84,195 // vandps %ymm11,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 196,98,125,24,29,35,93,0,0 // vbroadcastss 0x5d23(%rip),%ymm11 # 7d10 <_sk_callback_avx+0x2a0> .byte 196,65,60,89,195 // vmulps %ymm11,%ymm8,%ymm8 .byte 197,252,92,196 // vsubps %ymm4,%ymm0,%ymm0 .byte 196,193,124,89,193 // vmulps %ymm9,%ymm0,%ymm0 .byte 197,252,88,196 // vaddps %ymm4,%ymm0,%ymm0 .byte 197,244,92,205 // vsubps %ymm5,%ymm1,%ymm1 .byte 196,193,116,89,202 // vmulps %ymm10,%ymm1,%ymm1 .byte 197,244,88,205 // vaddps %ymm5,%ymm1,%ymm1 .byte 197,236,92,214 // vsubps %ymm6,%ymm2,%ymm2 .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 197,236,88,214 // vaddps %ymm6,%ymm2,%ymm2 .byte 197,228,92,223 // vsubps %ymm7,%ymm3,%ymm3 .byte 196,65,100,89,201 // vmulps %ymm9,%ymm3,%ymm9 .byte 197,52,88,207 // vaddps %ymm7,%ymm9,%ymm9 .byte 196,65,100,89,210 // vmulps %ymm10,%ymm3,%ymm10 .byte 197,44,88,215 // vaddps %ymm7,%ymm10,%ymm10 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 197,228,88,223 // vaddps %ymm7,%ymm3,%ymm3 .byte 197,172,95,219 // vmaxps %ymm3,%ymm10,%ymm3 .byte 197,180,95,219 // vmaxps %ymm3,%ymm9,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,28,255,255,255 // ja 1f7a <_sk_lerp_565_avx+0x26> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,99,0,0,0 // lea 0x63(%rip),%r11 # 20cc <_sk_lerp_565_avx+0x178> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 233,250,254,255,255 // jmpq 1f7a <_sk_lerp_565_avx+0x26> .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 196,65,57,196,68,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm8,%xmm8 .byte 196,65,121,110,12,89 // vmovd (%r9,%rbx,2),%xmm9 .byte 196,67,57,14,193,3 // vpblendw $0x3,%xmm9,%xmm8,%xmm8 .byte 233,220,254,255,255 // jmpq 1f7a <_sk_lerp_565_avx+0x26> .byte 196,65,57,239,192 // vpxor %xmm8,%xmm8,%xmm8 .byte 196,65,57,196,68,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm8,%xmm8 .byte 196,65,57,196,68,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm8,%xmm8 .byte 196,65,57,196,68,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm8,%xmm8 .byte 196,65,122,126,12,89 // vmovq (%r9,%rbx,2),%xmm9 .byte 196,67,49,14,192,240 // vpblendw $0xf0,%xmm8,%xmm9,%xmm8 .byte 233,174,254,255,255 // jmpq 1f7a <_sk_lerp_565_avx+0x26> .byte 166 // cmpsb %es:(%rdi),%ds:(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,193 // inc %ecx .byte 255 // (bad) .byte 255 // (bad) .byte 255,180,255,255,255,239,255 // pushq -0x100001(%rdi,%rdi,8) .byte 255 // (bad) .byte 255,231 // jmpq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 223,255 // (bad) .byte 255 // (bad) .byte 255,210 // callq *%rdx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_tables_avx .globl _sk_load_tables_avx FUNCTION(_sk_load_tables_avx) _sk_load_tables_avx: .byte 83 // push %rbx .byte 197,252,17,124,36,208 // vmovups %ymm7,-0x30(%rsp) .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10 .byte 76,3,16 // add (%rax),%r10 .byte 77,133,192 // test %r8,%r8 .byte 15,133,248,1,0,0 // jne 2300 <_sk_load_tables_avx+0x218> .byte 196,65,124,16,18 // vmovups (%r10),%ymm10 .byte 197,124,40,13,139,97,0,0 // vmovaps 0x618b(%rip),%ymm9 # 82a0 <_sk_callback_avx+0x830> .byte 196,193,44,84,201 // vandps %ymm9,%ymm10,%ymm1 .byte 196,227,125,25,200,1 // vextractf128 $0x1,%ymm1,%xmm0 .byte 196,193,249,126,195 // vmovq %xmm0,%r11 .byte 69,137,218 // mov %r11d,%r10d .byte 72,139,88,8 // mov 0x8(%rax),%rbx .byte 196,161,122,16,20,147 // vmovss (%rbx,%r10,4),%xmm2 .byte 196,195,249,22,194,1 // vpextrq $0x1,%xmm0,%r10 .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,163,105,33,4,155,16 // vinsertps $0x10,(%rbx,%r11,4),%xmm2,%xmm0 .byte 68,137,209 // mov %r10d,%ecx .byte 196,227,121,33,4,139,32 // vinsertps $0x20,(%rbx,%rcx,4),%xmm0,%xmm0 .byte 196,193,249,126,203 // vmovq %xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,35,121,33,44,147,48 // vinsertps $0x30,(%rbx,%r10,4),%xmm0,%xmm13 .byte 68,137,217 // mov %r11d,%ecx .byte 197,250,16,20,139 // vmovss (%rbx,%rcx,4),%xmm2 .byte 196,227,249,22,201,1 // vpextrq $0x1,%xmm1,%rcx .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,163,105,33,12,155,16 // vinsertps $0x10,(%rbx,%r11,4),%xmm2,%xmm1 .byte 65,137,202 // mov %ecx,%r10d .byte 72,193,233,32 // shr $0x20,%rcx .byte 196,163,113,33,12,147,32 // vinsertps $0x20,(%rbx,%r10,4),%xmm1,%xmm1 .byte 76,139,80,16 // mov 0x10(%rax),%r10 .byte 196,99,113,33,36,139,48 // vinsertps $0x30,(%rbx,%rcx,4),%xmm1,%xmm12 .byte 196,193,105,114,210,8 // vpsrld $0x8,%xmm10,%xmm2 .byte 196,67,125,25,208,1 // vextractf128 $0x1,%ymm10,%xmm8 .byte 196,193,121,114,208,8 // vpsrld $0x8,%xmm8,%xmm0 .byte 196,227,109,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm2,%ymm0 .byte 196,193,124,84,209 // vandps %ymm9,%ymm0,%ymm2 .byte 196,227,125,25,208,1 // vextractf128 $0x1,%ymm2,%xmm0 .byte 196,225,249,126,193 // vmovq %xmm0,%rcx .byte 137,203 // mov %ecx,%ebx .byte 196,193,122,16,12,154 // vmovss (%r10,%rbx,4),%xmm1 .byte 196,227,249,22,195,1 // vpextrq $0x1,%xmm0,%rbx .byte 72,193,233,32 // shr $0x20,%rcx .byte 196,67,113,33,52,138,16 // vinsertps $0x10,(%r10,%rcx,4),%xmm1,%xmm14 .byte 137,217 // mov %ebx,%ecx .byte 196,193,122,16,28,138 // vmovss (%r10,%rcx,4),%xmm3 .byte 196,225,249,126,209 // vmovq %xmm2,%rcx .byte 72,193,235,32 // shr $0x20,%rbx .byte 196,193,122,16,12,154 // vmovss (%r10,%rbx,4),%xmm1 .byte 137,203 // mov %ecx,%ebx .byte 196,193,122,16,4,154 // vmovss (%r10,%rbx,4),%xmm0 .byte 196,227,249,22,211,1 // vpextrq $0x1,%xmm2,%rbx .byte 72,193,233,32 // shr $0x20,%rcx .byte 196,67,121,33,28,138,16 // vinsertps $0x10,(%r10,%rcx,4),%xmm0,%xmm11 .byte 137,217 // mov %ebx,%ecx .byte 196,65,122,16,60,138 // vmovss (%r10,%rcx,4),%xmm15 .byte 196,195,29,24,197,1 // vinsertf128 $0x1,%xmm13,%ymm12,%ymm0 .byte 72,193,235,32 // shr $0x20,%rbx .byte 196,227,9,33,219,32 // vinsertps $0x20,%xmm3,%xmm14,%xmm3 .byte 196,227,97,33,249,48 // vinsertps $0x30,%xmm1,%xmm3,%xmm7 .byte 196,65,122,16,52,154 // vmovss (%r10,%rbx,4),%xmm14 .byte 72,139,64,24 // mov 0x18(%rax),%rax .byte 196,193,97,114,210,16 // vpsrld $0x10,%xmm10,%xmm3 .byte 196,193,105,114,208,16 // vpsrld $0x10,%xmm8,%xmm2 .byte 196,227,101,24,210,1 // vinsertf128 $0x1,%xmm2,%ymm3,%ymm2 .byte 196,65,108,84,201 // vandps %ymm9,%ymm2,%ymm9 .byte 196,99,125,25,202,1 // vextractf128 $0x1,%ymm9,%xmm2 .byte 196,225,249,126,209 // vmovq %xmm2,%rcx .byte 137,203 // mov %ecx,%ebx .byte 197,250,16,28,152 // vmovss (%rax,%rbx,4),%xmm3 .byte 196,227,249,22,211,1 // vpextrq $0x1,%xmm2,%rbx .byte 72,193,233,32 // shr $0x20,%rcx .byte 196,99,97,33,36,136,16 // vinsertps $0x10,(%rax,%rcx,4),%xmm3,%xmm12 .byte 137,217 // mov %ebx,%ecx .byte 197,250,16,28,136 // vmovss (%rax,%rcx,4),%xmm3 .byte 196,97,249,126,201 // vmovq %xmm9,%rcx .byte 72,193,235,32 // shr $0x20,%rbx .byte 197,250,16,20,152 // vmovss (%rax,%rbx,4),%xmm2 .byte 137,203 // mov %ecx,%ebx .byte 197,250,16,12,152 // vmovss (%rax,%rbx,4),%xmm1 .byte 196,99,249,22,203,1 // vpextrq $0x1,%xmm9,%rbx .byte 72,193,233,32 // shr $0x20,%rcx .byte 196,99,113,33,12,136,16 // vinsertps $0x10,(%rax,%rcx,4),%xmm1,%xmm9 .byte 137,217 // mov %ebx,%ecx .byte 197,122,16,44,136 // vmovss (%rax,%rcx,4),%xmm13 .byte 196,195,33,33,207,32 // vinsertps $0x20,%xmm15,%xmm11,%xmm1 .byte 72,193,235,32 // shr $0x20,%rbx .byte 197,122,16,28,152 // vmovss (%rax,%rbx,4),%xmm11 .byte 196,195,113,33,206,48 // vinsertps $0x30,%xmm14,%xmm1,%xmm1 .byte 196,227,117,24,207,1 // vinsertf128 $0x1,%xmm7,%ymm1,%ymm1 .byte 196,227,25,33,219,32 // vinsertps $0x20,%xmm3,%xmm12,%xmm3 .byte 196,227,97,33,210,48 // vinsertps $0x30,%xmm2,%xmm3,%xmm2 .byte 196,195,49,33,221,32 // vinsertps $0x20,%xmm13,%xmm9,%xmm3 .byte 196,195,97,33,219,48 // vinsertps $0x30,%xmm11,%xmm3,%xmm3 .byte 196,227,101,24,210,1 // vinsertf128 $0x1,%xmm2,%ymm3,%ymm2 .byte 196,193,97,114,210,24 // vpsrld $0x18,%xmm10,%xmm3 .byte 196,193,65,114,208,24 // vpsrld $0x18,%xmm8,%xmm7 .byte 196,227,101,24,223,1 // vinsertf128 $0x1,%xmm7,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,226,125,24,61,38,90,0,0 // vbroadcastss 0x5a26(%rip),%ymm7 # 7d14 <_sk_callback_avx+0x2a4> .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 197,252,16,124,36,208 // vmovups -0x30(%rsp),%ymm7 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,195,255,255,255,255 // mov $0xffffffffffffffff,%r11 .byte 73,211,235 // shr %cl,%r11 .byte 196,193,249,110,195 // vmovq %r11,%xmm0 .byte 196,226,121,48,192 // vpmovzxbw %xmm0,%xmm0 .byte 196,226,121,0,13,232,93,0,0 // vpshufb 0x5de8(%rip),%xmm0,%xmm1 # 8110 <_sk_callback_avx+0x6a0> .byte 196,226,121,33,201 // vpmovsxbd %xmm1,%xmm1 .byte 196,226,121,0,5,234,93,0,0 // vpshufb 0x5dea(%rip),%xmm0,%xmm0 # 8120 <_sk_callback_avx+0x6b0> .byte 196,226,121,33,192 // vpmovsxbd %xmm0,%xmm0 .byte 196,227,117,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 .byte 196,66,125,44,18 // vmaskmovps (%r10),%ymm0,%ymm10 .byte 233,194,253,255,255 // jmpq 210d <_sk_load_tables_avx+0x25> HIDDEN _sk_load_tables_u16_be_avx .globl _sk_load_tables_u16_be_avx FUNCTION(_sk_load_tables_u16_be_avx) _sk_load_tables_u16_be_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 76,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10 .byte 77,133,192 // test %r8,%r8 .byte 197,252,17,124,36,200 // vmovups %ymm7,-0x38(%rsp) .byte 15,133,84,2,0,0 // jne 25bb <_sk_load_tables_u16_be_avx+0x270> .byte 196,1,121,16,4,81 // vmovupd (%r9,%r10,2),%xmm8 .byte 196,129,121,16,84,81,16 // vmovupd 0x10(%r9,%r10,2),%xmm2 .byte 196,129,121,16,92,81,32 // vmovupd 0x20(%r9,%r10,2),%xmm3 .byte 196,1,122,111,76,81,48 // vmovdqu 0x30(%r9,%r10,2),%xmm9 .byte 197,185,97,194 // vpunpcklwd %xmm2,%xmm8,%xmm0 .byte 197,185,105,210 // vpunpckhwd %xmm2,%xmm8,%xmm2 .byte 196,193,97,97,201 // vpunpcklwd %xmm9,%xmm3,%xmm1 .byte 196,193,97,105,217 // vpunpckhwd %xmm9,%xmm3,%xmm3 .byte 197,121,97,202 // vpunpcklwd %xmm2,%xmm0,%xmm9 .byte 197,121,105,194 // vpunpckhwd %xmm2,%xmm0,%xmm8 .byte 197,241,97,195 // vpunpcklwd %xmm3,%xmm1,%xmm0 .byte 197,113,105,219 // vpunpckhwd %xmm3,%xmm1,%xmm11 .byte 197,177,108,200 // vpunpcklqdq %xmm0,%xmm9,%xmm1 .byte 197,49,109,224 // vpunpckhqdq %xmm0,%xmm9,%xmm12 .byte 197,121,111,21,124,93,0,0 // vmovdqa 0x5d7c(%rip),%xmm10 # 8130 <_sk_callback_avx+0x6c0> .byte 196,193,113,219,202 // vpand %xmm10,%xmm1,%xmm1 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 196,193,113,105,209 // vpunpckhwd %xmm9,%xmm1,%xmm2 .byte 196,193,249,126,209 // vmovq %xmm2,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 76,139,88,8 // mov 0x8(%rax),%r11 .byte 196,129,122,16,28,147 // vmovss (%r11,%r10,4),%xmm3 .byte 196,195,249,22,210,1 // vpextrq $0x1,%xmm2,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,3,97,33,44,139,16 // vinsertps $0x10,(%r11,%r9,4),%xmm3,%xmm13 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,226,121,51,201 // vpmovzxwd %xmm1,%xmm1 .byte 196,129,122,16,28,139 // vmovss (%r11,%r9,4),%xmm3 .byte 196,193,249,126,201 // vmovq %xmm1,%r9 .byte 196,129,122,16,4,147 // vmovss (%r11,%r10,4),%xmm0 .byte 69,137,202 // mov %r9d,%r10d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 196,129,122,16,20,147 // vmovss (%r11,%r10,4),%xmm2 .byte 196,195,249,22,202,1 // vpextrq $0x1,%xmm1,%r10 .byte 196,131,105,33,12,11,16 // vinsertps $0x10,(%r11,%r9,1),%xmm2,%xmm1 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 196,129,122,16,20,139 // vmovss (%r11,%r9,4),%xmm2 .byte 76,139,72,16 // mov 0x10(%rax),%r9 .byte 196,227,17,33,219,32 // vinsertps $0x20,%xmm3,%xmm13,%xmm3 .byte 196,99,97,33,232,48 // vinsertps $0x30,%xmm0,%xmm3,%xmm13 .byte 196,99,113,33,242,32 // vinsertps $0x20,%xmm2,%xmm1,%xmm14 .byte 196,1,122,16,60,19 // vmovss (%r11,%r10,1),%xmm15 .byte 196,193,25,219,210 // vpand %xmm10,%xmm12,%xmm2 .byte 196,193,105,105,193 // vpunpckhwd %xmm9,%xmm2,%xmm0 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 69,137,211 // mov %r10d,%r11d .byte 196,129,122,16,12,153 // vmovss (%r9,%r11,4),%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,113,33,36,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm1,%xmm12 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,226,121,51,194 // vpmovzxwd %xmm2,%xmm0 .byte 196,129,122,16,20,145 // vmovss (%r9,%r10,4),%xmm2 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 196,129,122,16,28,153 // vmovss (%r9,%r11,4),%xmm3 .byte 69,137,211 // mov %r10d,%r11d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 196,129,122,16,12,153 // vmovss (%r9,%r11,4),%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 196,131,113,33,12,17,16 // vinsertps $0x10,(%r9,%r10,1),%xmm1,%xmm1 .byte 69,137,218 // mov %r11d,%r10d .byte 196,129,122,16,60,145 // vmovss (%r9,%r10,4),%xmm7 .byte 196,195,9,33,199,48 // vinsertps $0x30,%xmm15,%xmm14,%xmm0 .byte 196,65,57,108,243 // vpunpcklqdq %xmm11,%xmm8,%xmm14 .byte 196,195,125,24,197,1 // vinsertf128 $0x1,%xmm13,%ymm0,%ymm0 .byte 73,193,235,30 // shr $0x1e,%r11 .byte 196,227,25,33,210,32 // vinsertps $0x20,%xmm2,%xmm12,%xmm2 .byte 196,227,105,33,219,48 // vinsertps $0x30,%xmm3,%xmm2,%xmm3 .byte 196,99,113,33,239,32 // vinsertps $0x20,%xmm7,%xmm1,%xmm13 .byte 196,1,122,16,60,25 // vmovss (%r9,%r11,1),%xmm15 .byte 76,139,80,24 // mov 0x18(%rax),%r10 .byte 196,193,9,219,250 // vpand %xmm10,%xmm14,%xmm7 .byte 196,193,65,105,209 // vpunpckhwd %xmm9,%xmm7,%xmm2 .byte 196,193,249,126,209 // vmovq %xmm2,%r9 .byte 68,137,200 // mov %r9d,%eax .byte 196,193,122,16,12,130 // vmovss (%r10,%rax,4),%xmm1 .byte 196,227,249,22,208,1 // vpextrq $0x1,%xmm2,%rax .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,3,113,33,20,138,16 // vinsertps $0x10,(%r10,%r9,4),%xmm1,%xmm10 .byte 65,137,193 // mov %eax,%r9d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,226,121,51,207 // vpmovzxwd %xmm7,%xmm1 .byte 196,1,122,16,52,138 // vmovss (%r10,%r9,4),%xmm14 .byte 196,193,249,126,201 // vmovq %xmm1,%r9 .byte 196,65,122,16,36,130 // vmovss (%r10,%rax,4),%xmm12 .byte 68,137,200 // mov %r9d,%eax .byte 73,193,233,30 // shr $0x1e,%r9 .byte 196,193,122,16,20,130 // vmovss (%r10,%rax,4),%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 196,131,105,33,20,10,16 // vinsertps $0x10,(%r10,%r9,1),%xmm2,%xmm2 .byte 68,137,216 // mov %r11d,%eax .byte 196,193,122,16,60,130 // vmovss (%r10,%rax,4),%xmm7 .byte 196,195,17,33,207,48 // vinsertps $0x30,%xmm15,%xmm13,%xmm1 .byte 73,193,235,30 // shr $0x1e,%r11 .byte 196,1,122,16,44,26 // vmovss (%r10,%r11,1),%xmm13 .byte 196,227,117,24,203,1 // vinsertf128 $0x1,%xmm3,%ymm1,%ymm1 .byte 196,195,41,33,222,32 // vinsertps $0x20,%xmm14,%xmm10,%xmm3 .byte 196,195,97,33,220,48 // vinsertps $0x30,%xmm12,%xmm3,%xmm3 .byte 196,227,105,33,215,32 // vinsertps $0x20,%xmm7,%xmm2,%xmm2 .byte 196,195,105,33,213,48 // vinsertps $0x30,%xmm13,%xmm2,%xmm2 .byte 196,227,109,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 .byte 196,193,57,109,219 // vpunpckhqdq %xmm11,%xmm8,%xmm3 .byte 197,193,113,243,8 // vpsllw $0x8,%xmm3,%xmm7 .byte 197,225,113,211,8 // vpsrlw $0x8,%xmm3,%xmm3 .byte 197,193,235,219 // vpor %xmm3,%xmm7,%xmm3 .byte 196,193,97,105,249 // vpunpckhwd %xmm9,%xmm3,%xmm7 .byte 196,226,121,51,219 // vpmovzxwd %xmm3,%xmm3 .byte 196,227,101,24,223,1 // vinsertf128 $0x1,%xmm7,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,226,125,24,61,107,87,0,0 // vbroadcastss 0x576b(%rip),%ymm7 # 7d18 <_sk_callback_avx+0x2a8> .byte 197,228,89,223 // vmulps %ymm7,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,124,36,200 // vmovups -0x38(%rsp),%ymm7 .byte 255,224 // jmpq *%rax .byte 196,1,123,16,4,81 // vmovsd (%r9,%r10,2),%xmm8 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,85 // je 2621 <_sk_load_tables_u16_be_avx+0x2d6> .byte 196,1,57,22,68,81,8 // vmovhpd 0x8(%r9,%r10,2),%xmm8,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,72 // jb 2621 <_sk_load_tables_u16_be_avx+0x2d6> .byte 196,129,123,16,84,81,16 // vmovsd 0x10(%r9,%r10,2),%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 116,72 // je 262e <_sk_load_tables_u16_be_avx+0x2e3> .byte 196,129,105,22,84,81,24 // vmovhpd 0x18(%r9,%r10,2),%xmm2,%xmm2 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,59 // jb 262e <_sk_load_tables_u16_be_avx+0x2e3> .byte 196,129,123,16,92,81,32 // vmovsd 0x20(%r9,%r10,2),%xmm3 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 15,132,126,253,255,255 // je 2382 <_sk_load_tables_u16_be_avx+0x37> .byte 196,129,97,22,92,81,40 // vmovhpd 0x28(%r9,%r10,2),%xmm3,%xmm3 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,130,109,253,255,255 // jb 2382 <_sk_load_tables_u16_be_avx+0x37> .byte 196,1,122,126,76,81,48 // vmovq 0x30(%r9,%r10,2),%xmm9 .byte 233,97,253,255,255 // jmpq 2382 <_sk_load_tables_u16_be_avx+0x37> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 197,233,87,210 // vxorpd %xmm2,%xmm2,%xmm2 .byte 233,84,253,255,255 // jmpq 2382 <_sk_load_tables_u16_be_avx+0x37> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 233,75,253,255,255 // jmpq 2382 <_sk_load_tables_u16_be_avx+0x37> HIDDEN _sk_load_tables_rgb_u16_be_avx .globl _sk_load_tables_rgb_u16_be_avx FUNCTION(_sk_load_tables_rgb_u16_be_avx) _sk_load_tables_rgb_u16_be_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 76,141,20,82 // lea (%rdx,%rdx,2),%r10 .byte 77,133,192 // test %r8,%r8 .byte 197,252,17,124,36,200 // vmovups %ymm7,-0x38(%rsp) .byte 197,252,17,116,36,168 // vmovups %ymm6,-0x58(%rsp) .byte 15,133,71,2,0,0 // jne 289c <_sk_load_tables_rgb_u16_be_avx+0x265> .byte 196,129,122,111,4,81 // vmovdqu (%r9,%r10,2),%xmm0 .byte 196,129,122,111,84,81,12 // vmovdqu 0xc(%r9,%r10,2),%xmm2 .byte 196,129,122,111,76,81,24 // vmovdqu 0x18(%r9,%r10,2),%xmm1 .byte 196,129,122,111,92,81,32 // vmovdqu 0x20(%r9,%r10,2),%xmm3 .byte 197,225,115,219,4 // vpsrldq $0x4,%xmm3,%xmm3 .byte 197,185,115,216,6 // vpsrldq $0x6,%xmm0,%xmm8 .byte 197,177,115,218,6 // vpsrldq $0x6,%xmm2,%xmm9 .byte 197,161,115,217,6 // vpsrldq $0x6,%xmm1,%xmm11 .byte 197,169,115,219,6 // vpsrldq $0x6,%xmm3,%xmm10 .byte 197,249,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm0 .byte 196,193,57,97,209 // vpunpcklwd %xmm9,%xmm8,%xmm2 .byte 197,241,97,203 // vpunpcklwd %xmm3,%xmm1,%xmm1 .byte 196,193,33,97,218 // vpunpcklwd %xmm10,%xmm11,%xmm3 .byte 197,121,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm8 .byte 197,249,105,194 // vpunpckhwd %xmm2,%xmm0,%xmm0 .byte 197,241,97,211 // vpunpcklwd %xmm3,%xmm1,%xmm2 .byte 197,241,105,203 // vpunpckhwd %xmm3,%xmm1,%xmm1 .byte 197,185,108,218 // vpunpcklqdq %xmm2,%xmm8,%xmm3 .byte 197,57,109,218 // vpunpckhqdq %xmm2,%xmm8,%xmm11 .byte 197,121,108,193 // vpunpcklqdq %xmm1,%xmm0,%xmm8 .byte 197,121,111,13,129,90,0,0 // vmovdqa 0x5a81(%rip),%xmm9 # 8140 <_sk_callback_avx+0x6d0> .byte 196,193,97,219,193 // vpand %xmm9,%xmm3,%xmm0 .byte 196,65,41,239,210 // vpxor %xmm10,%xmm10,%xmm10 .byte 196,193,121,105,202 // vpunpckhwd %xmm10,%xmm0,%xmm1 .byte 196,193,249,126,201 // vmovq %xmm1,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 76,139,88,8 // mov 0x8(%rax),%r11 .byte 196,129,122,16,20,147 // vmovss (%r11,%r10,4),%xmm2 .byte 196,195,249,22,202,1 // vpextrq $0x1,%xmm1,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,3,105,33,36,139,16 // vinsertps $0x10,(%r11,%r9,4),%xmm2,%xmm12 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,129,122,16,20,139 // vmovss (%r11,%r9,4),%xmm2 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 196,129,122,16,12,147 // vmovss (%r11,%r10,4),%xmm1 .byte 69,137,202 // mov %r9d,%r10d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 196,129,122,16,28,147 // vmovss (%r11,%r10,4),%xmm3 .byte 196,195,249,22,194,1 // vpextrq $0x1,%xmm0,%r10 .byte 196,131,97,33,28,11,16 // vinsertps $0x10,(%r11,%r9,1),%xmm3,%xmm3 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 196,129,122,16,4,139 // vmovss (%r11,%r9,4),%xmm0 .byte 76,139,72,16 // mov 0x10(%rax),%r9 .byte 196,227,25,33,210,32 // vinsertps $0x20,%xmm2,%xmm12,%xmm2 .byte 196,227,105,33,201,48 // vinsertps $0x30,%xmm1,%xmm2,%xmm1 .byte 196,129,122,16,20,19 // vmovss (%r11,%r10,1),%xmm2 .byte 196,65,33,219,225 // vpand %xmm9,%xmm11,%xmm12 .byte 196,65,25,105,218 // vpunpckhwd %xmm10,%xmm12,%xmm11 .byte 196,65,249,126,218 // vmovq %xmm11,%r10 .byte 69,137,211 // mov %r10d,%r11d .byte 196,1,122,16,44,153 // vmovss (%r9,%r11,4),%xmm13 .byte 196,67,249,22,219,1 // vpextrq $0x1,%xmm11,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,17,33,28,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm13,%xmm11 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,66,121,51,244 // vpmovzxwd %xmm12,%xmm14 .byte 196,1,122,16,44,145 // vmovss (%r9,%r10,4),%xmm13 .byte 196,65,249,126,242 // vmovq %xmm14,%r10 .byte 196,1,122,16,36,153 // vmovss (%r9,%r11,4),%xmm12 .byte 69,137,211 // mov %r10d,%r11d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 196,1,122,16,60,153 // vmovss (%r9,%r11,4),%xmm15 .byte 196,67,249,22,243,1 // vpextrq $0x1,%xmm14,%r11 .byte 196,3,1,33,52,17,16 // vinsertps $0x10,(%r9,%r10,1),%xmm15,%xmm14 .byte 69,137,218 // mov %r11d,%r10d .byte 196,1,122,16,60,145 // vmovss (%r9,%r10,4),%xmm15 .byte 196,227,97,33,192,32 // vinsertps $0x20,%xmm0,%xmm3,%xmm0 .byte 196,227,121,33,194,48 // vinsertps $0x30,%xmm2,%xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 73,193,235,30 // shr $0x1e,%r11 .byte 196,129,122,16,52,25 // vmovss (%r9,%r11,1),%xmm6 .byte 76,139,80,24 // mov 0x18(%rax),%r10 .byte 196,65,57,219,193 // vpand %xmm9,%xmm8,%xmm8 .byte 196,193,57,105,210 // vpunpckhwd %xmm10,%xmm8,%xmm2 .byte 196,193,249,126,209 // vmovq %xmm2,%r9 .byte 68,137,200 // mov %r9d,%eax .byte 196,193,122,16,12,130 // vmovss (%r10,%rax,4),%xmm1 .byte 196,227,249,22,208,1 // vpextrq $0x1,%xmm2,%rax .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,3,113,33,12,138,16 // vinsertps $0x10,(%r10,%r9,4),%xmm1,%xmm9 .byte 65,137,193 // mov %eax,%r9d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,194,121,51,200 // vpmovzxwd %xmm8,%xmm1 .byte 196,1,122,16,4,138 // vmovss (%r10,%r9,4),%xmm8 .byte 196,193,249,126,201 // vmovq %xmm1,%r9 .byte 196,65,122,16,20,130 // vmovss (%r10,%rax,4),%xmm10 .byte 68,137,200 // mov %r9d,%eax .byte 73,193,233,30 // shr $0x1e,%r9 .byte 196,193,122,16,20,130 // vmovss (%r10,%rax,4),%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 196,131,105,33,20,10,16 // vinsertps $0x10,(%r10,%r9,1),%xmm2,%xmm2 .byte 68,137,216 // mov %r11d,%eax .byte 196,193,122,16,60,130 // vmovss (%r10,%rax,4),%xmm7 .byte 196,195,33,33,205,32 // vinsertps $0x20,%xmm13,%xmm11,%xmm1 .byte 73,193,235,30 // shr $0x1e,%r11 .byte 196,1,122,16,28,26 // vmovss (%r10,%r11,1),%xmm11 .byte 196,195,113,33,204,48 // vinsertps $0x30,%xmm12,%xmm1,%xmm1 .byte 196,195,9,33,223,32 // vinsertps $0x20,%xmm15,%xmm14,%xmm3 .byte 196,227,97,33,222,48 // vinsertps $0x30,%xmm6,%xmm3,%xmm3 .byte 196,227,101,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm3,%ymm1 .byte 196,195,49,33,216,32 // vinsertps $0x20,%xmm8,%xmm9,%xmm3 .byte 196,195,97,33,218,48 // vinsertps $0x30,%xmm10,%xmm3,%xmm3 .byte 196,227,105,33,215,32 // vinsertps $0x20,%xmm7,%xmm2,%xmm2 .byte 196,195,105,33,211,48 // vinsertps $0x30,%xmm11,%xmm2,%xmm2 .byte 196,227,109,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,142,84,0,0 // vbroadcastss 0x548e(%rip),%ymm3 # 7d1c <_sk_callback_avx+0x2ac> .byte 197,252,16,116,36,168 // vmovups -0x58(%rsp),%ymm6 .byte 197,252,16,124,36,200 // vmovups -0x38(%rsp),%ymm7 .byte 255,224 // jmpq *%rax .byte 196,129,121,110,4,81 // vmovd (%r9,%r10,2),%xmm0 .byte 196,129,121,196,68,81,4,2 // vpinsrw $0x2,0x4(%r9,%r10,2),%xmm0,%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,5 // jne 28b5 <_sk_load_tables_rgb_u16_be_avx+0x27e> .byte 233,212,253,255,255 // jmpq 2689 <_sk_load_tables_rgb_u16_be_avx+0x52> .byte 196,129,121,110,76,81,6 // vmovd 0x6(%r9,%r10,2),%xmm1 .byte 196,1,113,196,68,81,10,2 // vpinsrw $0x2,0xa(%r9,%r10,2),%xmm1,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,26 // jb 28e4 <_sk_load_tables_rgb_u16_be_avx+0x2ad> .byte 196,129,121,110,76,81,12 // vmovd 0xc(%r9,%r10,2),%xmm1 .byte 196,129,113,196,84,81,16,2 // vpinsrw $0x2,0x10(%r9,%r10,2),%xmm1,%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 117,10 // jne 28e9 <_sk_load_tables_rgb_u16_be_avx+0x2b2> .byte 233,165,253,255,255 // jmpq 2689 <_sk_load_tables_rgb_u16_be_avx+0x52> .byte 233,160,253,255,255 // jmpq 2689 <_sk_load_tables_rgb_u16_be_avx+0x52> .byte 196,129,121,110,76,81,18 // vmovd 0x12(%r9,%r10,2),%xmm1 .byte 196,1,113,196,76,81,22,2 // vpinsrw $0x2,0x16(%r9,%r10,2),%xmm1,%xmm9 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,26 // jb 2918 <_sk_load_tables_rgb_u16_be_avx+0x2e1> .byte 196,129,121,110,76,81,24 // vmovd 0x18(%r9,%r10,2),%xmm1 .byte 196,129,113,196,76,81,28,2 // vpinsrw $0x2,0x1c(%r9,%r10,2),%xmm1,%xmm1 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 117,10 // jne 291d <_sk_load_tables_rgb_u16_be_avx+0x2e6> .byte 233,113,253,255,255 // jmpq 2689 <_sk_load_tables_rgb_u16_be_avx+0x52> .byte 233,108,253,255,255 // jmpq 2689 <_sk_load_tables_rgb_u16_be_avx+0x52> .byte 196,129,121,110,92,81,30 // vmovd 0x1e(%r9,%r10,2),%xmm3 .byte 196,1,97,196,92,81,34,2 // vpinsrw $0x2,0x22(%r9,%r10,2),%xmm3,%xmm11 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,20 // jb 2946 <_sk_load_tables_rgb_u16_be_avx+0x30f> .byte 196,129,121,110,92,81,36 // vmovd 0x24(%r9,%r10,2),%xmm3 .byte 196,129,97,196,92,81,40,2 // vpinsrw $0x2,0x28(%r9,%r10,2),%xmm3,%xmm3 .byte 233,67,253,255,255 // jmpq 2689 <_sk_load_tables_rgb_u16_be_avx+0x52> .byte 233,62,253,255,255 // jmpq 2689 <_sk_load_tables_rgb_u16_be_avx+0x52> HIDDEN _sk_byte_tables_avx .globl _sk_byte_tables_avx FUNCTION(_sk_byte_tables_avx) _sk_byte_tables_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,5,202,83,0,0 // vbroadcastss 0x53ca(%rip),%ymm8 # 7d20 <_sk_callback_avx+0x2b0> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,125,91,200 // vcvtps2dq %ymm0,%ymm9 .byte 196,65,249,126,201 // vmovq %xmm9,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 76,139,24 // mov (%rax),%r11 .byte 196,131,121,32,4,19,0 // vpinsrb $0x0,(%r11,%r10,1),%xmm0,%xmm0 .byte 196,67,249,22,202,1 // vpextrq $0x1,%xmm9,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,3,121,32,20,11,1 // vpinsrb $0x1,(%r11,%r9,1),%xmm0,%xmm10 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,99,125,25,200,1 // vextractf128 $0x1,%ymm9,%xmm0 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,67,41,32,201,2 // vpinsrb $0x2,%r9d,%xmm10,%xmm9 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,49,32,202,3 // vpinsrb $0x3,%r10d,%xmm9,%xmm9 .byte 69,137,202 // mov %r9d,%r10d .byte 196,3,121,32,20,19,0 // vpinsrb $0x0,(%r11,%r10,1),%xmm0,%xmm10 .byte 196,195,249,22,194,1 // vpextrq $0x1,%xmm0,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,131,41,32,4,11,1 // vpinsrb $0x1,(%r11,%r9,1),%xmm10,%xmm0 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,195,121,32,193,2 // vpinsrb $0x2,%r9d,%xmm0,%xmm0 .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,121,32,210,3 // vpinsrb $0x3,%r10d,%xmm0,%xmm10 .byte 196,193,116,89,192 // vmulps %ymm8,%ymm1,%ymm0 .byte 197,253,91,192 // vcvtps2dq %ymm0,%ymm0 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 69,137,211 // mov %r10d,%r11d .byte 196,131,121,32,12,25,0 // vpinsrb $0x0,(%r9,%r11,1),%xmm0,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,113,32,12,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm1,%xmm1 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,25,192,1 // vextractf128 $0x1,%ymm0,%xmm0 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,113,32,202,2 // vpinsrb $0x2,%r10d,%xmm1,%xmm1 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 196,67,113,32,227,3 // vpinsrb $0x3,%r11d,%xmm1,%xmm12 .byte 69,137,211 // mov %r10d,%r11d .byte 196,131,121,32,12,25,0 // vpinsrb $0x0,(%r9,%r11,1),%xmm0,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,113,32,4,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm1,%xmm0 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,2 // vpinsrb $0x2,%r10d,%xmm0,%xmm0 .byte 71,15,182,12,25 // movzbl (%r9,%r11,1),%r9d .byte 196,67,121,32,233,3 // vpinsrb $0x3,%r9d,%xmm0,%xmm13 .byte 76,139,72,16 // mov 0x10(%rax),%r9 .byte 196,193,108,89,200 // vmulps %ymm8,%ymm2,%ymm1 .byte 197,253,91,201 // vcvtps2dq %ymm1,%ymm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 69,137,211 // mov %r10d,%r11d .byte 196,131,121,32,20,25,0 // vpinsrb $0x0,(%r9,%r11,1),%xmm0,%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,105,32,20,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm2,%xmm2 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,105,32,210,2 // vpinsrb $0x2,%r10d,%xmm2,%xmm2 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 196,67,105,32,219,3 // vpinsrb $0x3,%r11d,%xmm2,%xmm11 .byte 69,137,211 // mov %r10d,%r11d .byte 196,131,121,32,20,25,0 // vpinsrb $0x0,(%r9,%r11,1),%xmm0,%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,105,32,12,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm2,%xmm1 .byte 69,137,218 // mov %r11d,%r10d .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,113,32,202,2 // vpinsrb $0x2,%r10d,%xmm1,%xmm1 .byte 73,193,235,32 // shr $0x20,%r11 .byte 71,15,182,12,25 // movzbl (%r9,%r11,1),%r9d .byte 196,67,113,32,241,3 // vpinsrb $0x3,%r9d,%xmm1,%xmm14 .byte 76,139,80,24 // mov 0x18(%rax),%r10 .byte 196,193,100,89,200 // vmulps %ymm8,%ymm3,%ymm1 .byte 197,253,91,201 // vcvtps2dq %ymm1,%ymm1 .byte 196,193,249,126,201 // vmovq %xmm1,%r9 .byte 68,137,200 // mov %r9d,%eax .byte 196,195,121,32,28,2,0 // vpinsrb $0x0,(%r10,%rax,1),%xmm0,%xmm3 .byte 196,227,249,22,200,1 // vpextrq $0x1,%xmm1,%rax .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,131,97,32,28,10,1 // vpinsrb $0x1,(%r10,%r9,1),%xmm3,%xmm3 .byte 65,137,193 // mov %eax,%r9d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 71,15,182,12,10 // movzbl (%r10,%r9,1),%r9d .byte 196,195,97,32,217,2 // vpinsrb $0x2,%r9d,%xmm3,%xmm3 .byte 196,193,249,126,201 // vmovq %xmm1,%r9 .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,99,97,32,192,3 // vpinsrb $0x3,%eax,%xmm3,%xmm8 .byte 68,137,200 // mov %r9d,%eax .byte 196,195,121,32,4,2,0 // vpinsrb $0x0,(%r10,%rax,1),%xmm0,%xmm0 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,131,121,32,4,10,1 // vpinsrb $0x1,(%r10,%r9,1),%xmm0,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,99,121,32,248,2 // vpinsrb $0x2,%eax,%xmm0,%xmm15 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,26 // movzbl (%r10,%r11,1),%eax .byte 196,194,121,49,193 // vpmovzxbd %xmm9,%xmm0 .byte 196,194,121,49,202 // vpmovzxbd %xmm10,%xmm1 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,194,121,49,204 // vpmovzxbd %xmm12,%xmm1 .byte 196,194,121,49,213 // vpmovzxbd %xmm13,%xmm2 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 196,98,125,24,13,116,81,0,0 // vbroadcastss 0x5174(%rip),%ymm9 # 7d24 <_sk_callback_avx+0x2b4> .byte 196,193,124,89,193 // vmulps %ymm9,%ymm0,%ymm0 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,201 // vmulps %ymm9,%ymm1,%ymm1 .byte 196,194,121,49,211 // vpmovzxbd %xmm11,%xmm2 .byte 196,194,121,49,222 // vpmovzxbd %xmm14,%xmm3 .byte 196,227,109,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,209 // vmulps %ymm9,%ymm2,%ymm2 .byte 196,66,121,49,192 // vpmovzxbd %xmm8,%xmm8 .byte 196,227,1,32,216,3 // vpinsrb $0x3,%eax,%xmm15,%xmm3 .byte 196,226,121,49,219 // vpmovzxbd %xmm3,%xmm3 .byte 196,227,61,24,219,1 // vinsertf128 $0x1,%xmm3,%ymm8,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,217 // vmulps %ymm9,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_byte_tables_rgb_avx .globl _sk_byte_tables_rgb_avx FUNCTION(_sk_byte_tables_rgb_avx) _sk_byte_tables_rgb_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,139,72,24 // mov 0x18(%rax),%r9d .byte 65,255,201 // dec %r9d .byte 196,65,121,110,193 // vmovd %r9d,%xmm8 .byte 196,65,121,112,192,0 // vpshufd $0x0,%xmm8,%xmm8 .byte 196,67,61,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,125,91,200 // vcvtps2dq %ymm0,%ymm9 .byte 196,65,249,126,201 // vmovq %xmm9,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 76,139,24 // mov (%rax),%r11 .byte 196,131,121,32,4,19,0 // vpinsrb $0x0,(%r11,%r10,1),%xmm0,%xmm0 .byte 196,67,249,22,202,1 // vpextrq $0x1,%xmm9,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,3,121,32,20,11,1 // vpinsrb $0x1,(%r11,%r9,1),%xmm0,%xmm10 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,99,125,25,200,1 // vextractf128 $0x1,%ymm9,%xmm0 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,67,41,32,201,2 // vpinsrb $0x2,%r9d,%xmm10,%xmm9 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,49,32,202,3 // vpinsrb $0x3,%r10d,%xmm9,%xmm9 .byte 69,137,202 // mov %r9d,%r10d .byte 196,3,121,32,20,19,0 // vpinsrb $0x0,(%r11,%r10,1),%xmm0,%xmm10 .byte 196,195,249,22,194,1 // vpextrq $0x1,%xmm0,%r10 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,131,41,32,4,11,1 // vpinsrb $0x1,(%r11,%r9,1),%xmm10,%xmm0 .byte 69,137,209 // mov %r10d,%r9d .byte 73,193,234,32 // shr $0x20,%r10 .byte 71,15,182,12,11 // movzbl (%r11,%r9,1),%r9d .byte 196,195,121,32,193,2 // vpinsrb $0x2,%r9d,%xmm0,%xmm0 .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 71,15,182,20,19 // movzbl (%r11,%r10,1),%r10d .byte 196,67,121,32,218,3 // vpinsrb $0x3,%r10d,%xmm0,%xmm11 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,253,91,201 // vcvtps2dq %ymm1,%ymm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 69,137,211 // mov %r10d,%r11d .byte 196,131,121,32,4,25,0 // vpinsrb $0x0,(%r9,%r11,1),%xmm0,%xmm0 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,121,32,4,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm0,%xmm0 .byte 69,137,218 // mov %r11d,%r10d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,2 // vpinsrb $0x2,%r10d,%xmm0,%xmm0 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 196,67,121,32,211,3 // vpinsrb $0x3,%r11d,%xmm0,%xmm10 .byte 69,137,211 // mov %r10d,%r11d .byte 196,131,121,32,4,25,0 // vpinsrb $0x0,(%r9,%r11,1),%xmm0,%xmm0 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,121,32,4,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm0,%xmm0 .byte 69,137,218 // mov %r11d,%r10d .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 196,195,121,32,194,2 // vpinsrb $0x2,%r10d,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 71,15,182,12,25 // movzbl (%r9,%r11,1),%r9d .byte 196,67,121,32,225,3 // vpinsrb $0x3,%r9d,%xmm0,%xmm12 .byte 76,139,80,16 // mov 0x10(%rax),%r10 .byte 197,188,89,194 // vmulps %ymm2,%ymm8,%ymm0 .byte 197,253,91,192 // vcvtps2dq %ymm0,%ymm0 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 68,137,200 // mov %r9d,%eax .byte 196,195,121,32,20,2,0 // vpinsrb $0x0,(%r10,%rax,1),%xmm0,%xmm2 .byte 196,227,249,22,192,1 // vpextrq $0x1,%xmm0,%rax .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,131,105,32,20,10,1 // vpinsrb $0x1,(%r10,%r9,1),%xmm2,%xmm2 .byte 65,137,193 // mov %eax,%r9d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,227,125,25,192,1 // vextractf128 $0x1,%ymm0,%xmm0 .byte 71,15,182,12,10 // movzbl (%r10,%r9,1),%r9d .byte 196,195,105,32,209,2 // vpinsrb $0x2,%r9d,%xmm2,%xmm2 .byte 196,193,249,126,193 // vmovq %xmm0,%r9 .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,99,105,32,192,3 // vpinsrb $0x3,%eax,%xmm2,%xmm8 .byte 68,137,200 // mov %r9d,%eax .byte 196,195,121,32,12,2,0 // vpinsrb $0x0,(%r10,%rax,1),%xmm0,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,131,113,32,4,10,1 // vpinsrb $0x1,(%r10,%r9,1),%xmm1,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,2 // movzbl (%r10,%rax,1),%eax .byte 196,99,121,32,232,2 // vpinsrb $0x2,%eax,%xmm0,%xmm13 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,26 // movzbl (%r10,%r11,1),%eax .byte 196,194,121,49,193 // vpmovzxbd %xmm9,%xmm0 .byte 196,194,121,49,203 // vpmovzxbd %xmm11,%xmm1 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,13,85,79,0,0 // vbroadcastss 0x4f55(%rip),%ymm9 # 7d28 <_sk_callback_avx+0x2b8> .byte 196,193,124,89,193 // vmulps %ymm9,%ymm0,%ymm0 .byte 196,194,121,49,202 // vpmovzxbd %xmm10,%xmm1 .byte 196,194,121,49,212 // vpmovzxbd %xmm12,%xmm2 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,201 // vmulps %ymm9,%ymm1,%ymm1 .byte 196,66,121,49,192 // vpmovzxbd %xmm8,%xmm8 .byte 196,227,17,32,208,3 // vpinsrb $0x3,%eax,%xmm13,%xmm2 .byte 196,226,121,49,210 // vpmovzxbd %xmm2,%xmm2 .byte 196,227,61,24,210,1 // vinsertf128 $0x1,%xmm2,%ymm8,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,209 // vmulps %ymm9,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_table_r_avx .globl _sk_table_r_avx FUNCTION(_sk_table_r_avx) _sk_table_r_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 196,65,121,112,192,0 // vpshufd $0x0,%xmm8,%xmm8 .byte 196,67,61,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,125,91,192 // vcvtps2dq %ymm0,%ymm8 .byte 196,99,125,25,192,1 // vextractf128 $0x1,%ymm8,%xmm0 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,65,122,16,12,129 // vmovss (%r9,%rax,4),%xmm9 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,49,33,12,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm9,%xmm9 .byte 68,137,216 // mov %r11d,%eax .byte 196,65,122,16,20,129 // vmovss (%r9,%rax,4),%xmm10 .byte 196,65,249,126,194 // vmovq %xmm8,%r10 .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,1,122,16,28,153 // vmovss (%r9,%r11,4),%xmm11 .byte 68,137,208 // mov %r10d,%eax .byte 196,193,122,16,4,129 // vmovss (%r9,%rax,4),%xmm0 .byte 196,67,249,22,195,1 // vpextrq $0x1,%xmm8,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,121,33,4,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm0,%xmm8 .byte 68,137,216 // mov %r11d,%eax .byte 196,65,122,16,36,129 // vmovss (%r9,%rax,4),%xmm12 .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,1,122,16,44,153 // vmovss (%r9,%r11,4),%xmm13 .byte 196,195,49,33,194,32 // vinsertps $0x20,%xmm10,%xmm9,%xmm0 .byte 196,67,121,33,203,48 // vinsertps $0x30,%xmm11,%xmm0,%xmm9 .byte 196,195,57,33,196,32 // vinsertps $0x20,%xmm12,%xmm8,%xmm0 .byte 196,195,121,33,197,48 // vinsertps $0x30,%xmm13,%xmm0,%xmm0 .byte 196,195,125,24,193,1 // vinsertf128 $0x1,%xmm9,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_table_g_avx .globl _sk_table_g_avx FUNCTION(_sk_table_g_avx) _sk_table_g_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 196,65,121,112,192,0 // vpshufd $0x0,%xmm8,%xmm8 .byte 196,67,61,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 197,125,91,193 // vcvtps2dq %ymm1,%ymm8 .byte 196,99,125,25,193,1 // vextractf128 $0x1,%ymm8,%xmm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,65,122,16,12,129 // vmovss (%r9,%rax,4),%xmm9 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,49,33,12,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm9,%xmm9 .byte 68,137,216 // mov %r11d,%eax .byte 196,65,122,16,20,129 // vmovss (%r9,%rax,4),%xmm10 .byte 196,65,249,126,194 // vmovq %xmm8,%r10 .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,1,122,16,28,153 // vmovss (%r9,%r11,4),%xmm11 .byte 68,137,208 // mov %r10d,%eax .byte 196,193,122,16,12,129 // vmovss (%r9,%rax,4),%xmm1 .byte 196,67,249,22,195,1 // vpextrq $0x1,%xmm8,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,113,33,4,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm1,%xmm8 .byte 68,137,216 // mov %r11d,%eax .byte 196,65,122,16,36,129 // vmovss (%r9,%rax,4),%xmm12 .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,1,122,16,44,153 // vmovss (%r9,%r11,4),%xmm13 .byte 196,195,49,33,202,32 // vinsertps $0x20,%xmm10,%xmm9,%xmm1 .byte 196,67,113,33,203,48 // vinsertps $0x30,%xmm11,%xmm1,%xmm9 .byte 196,195,57,33,204,32 // vinsertps $0x20,%xmm12,%xmm8,%xmm1 .byte 196,195,113,33,205,48 // vinsertps $0x30,%xmm13,%xmm1,%xmm1 .byte 196,195,117,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm1,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_table_b_avx .globl _sk_table_b_avx FUNCTION(_sk_table_b_avx) _sk_table_b_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 196,65,121,112,192,0 // vpshufd $0x0,%xmm8,%xmm8 .byte 196,67,61,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%ymm2 .byte 197,125,91,194 // vcvtps2dq %ymm2,%ymm8 .byte 196,99,125,25,194,1 // vextractf128 $0x1,%ymm8,%xmm2 .byte 196,193,249,126,210 // vmovq %xmm2,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,65,122,16,12,129 // vmovss (%r9,%rax,4),%xmm9 .byte 196,195,249,22,211,1 // vpextrq $0x1,%xmm2,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,49,33,12,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm9,%xmm9 .byte 68,137,216 // mov %r11d,%eax .byte 196,65,122,16,20,129 // vmovss (%r9,%rax,4),%xmm10 .byte 196,65,249,126,194 // vmovq %xmm8,%r10 .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,1,122,16,28,153 // vmovss (%r9,%r11,4),%xmm11 .byte 68,137,208 // mov %r10d,%eax .byte 196,193,122,16,20,129 // vmovss (%r9,%rax,4),%xmm2 .byte 196,67,249,22,195,1 // vpextrq $0x1,%xmm8,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,105,33,4,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm2,%xmm8 .byte 68,137,216 // mov %r11d,%eax .byte 196,65,122,16,36,129 // vmovss (%r9,%rax,4),%xmm12 .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,1,122,16,44,153 // vmovss (%r9,%r11,4),%xmm13 .byte 196,195,49,33,210,32 // vinsertps $0x20,%xmm10,%xmm9,%xmm2 .byte 196,67,105,33,203,48 // vinsertps $0x30,%xmm11,%xmm2,%xmm9 .byte 196,195,57,33,212,32 // vinsertps $0x20,%xmm12,%xmm8,%xmm2 .byte 196,195,105,33,213,48 // vinsertps $0x30,%xmm13,%xmm2,%xmm2 .byte 196,195,109,24,209,1 // vinsertf128 $0x1,%xmm9,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_table_a_avx .globl _sk_table_a_avx FUNCTION(_sk_table_a_avx) _sk_table_a_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 197,121,110,192 // vmovd %eax,%xmm8 .byte 196,65,121,112,192,0 // vpshufd $0x0,%xmm8,%xmm8 .byte 196,67,61,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm8,%ymm8 .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 .byte 197,188,89,219 // vmulps %ymm3,%ymm8,%ymm3 .byte 197,125,91,195 // vcvtps2dq %ymm3,%ymm8 .byte 196,99,125,25,195,1 // vextractf128 $0x1,%ymm8,%xmm3 .byte 196,193,249,126,218 // vmovq %xmm3,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,65,122,16,12,129 // vmovss (%r9,%rax,4),%xmm9 .byte 196,195,249,22,219,1 // vpextrq $0x1,%xmm3,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,49,33,12,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm9,%xmm9 .byte 68,137,216 // mov %r11d,%eax .byte 196,65,122,16,20,129 // vmovss (%r9,%rax,4),%xmm10 .byte 196,65,249,126,194 // vmovq %xmm8,%r10 .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,1,122,16,28,153 // vmovss (%r9,%r11,4),%xmm11 .byte 68,137,208 // mov %r10d,%eax .byte 196,193,122,16,28,129 // vmovss (%r9,%rax,4),%xmm3 .byte 196,67,249,22,195,1 // vpextrq $0x1,%xmm8,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,3,97,33,4,145,16 // vinsertps $0x10,(%r9,%r10,4),%xmm3,%xmm8 .byte 68,137,216 // mov %r11d,%eax .byte 196,65,122,16,36,129 // vmovss (%r9,%rax,4),%xmm12 .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,1,122,16,44,153 // vmovss (%r9,%r11,4),%xmm13 .byte 196,195,49,33,218,32 // vinsertps $0x20,%xmm10,%xmm9,%xmm3 .byte 196,67,97,33,203,48 // vinsertps $0x30,%xmm11,%xmm3,%xmm9 .byte 196,195,57,33,220,32 // vinsertps $0x20,%xmm12,%xmm8,%xmm3 .byte 196,195,97,33,221,48 // vinsertps $0x30,%xmm13,%xmm3,%xmm3 .byte 196,195,101,24,217,1 // vinsertf128 $0x1,%xmm9,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_r_avx .globl _sk_parametric_r_avx FUNCTION(_sk_parametric_r_avx) _sk_parametric_r_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,65,124,194,192,2 // vcmpleps %ymm8,%ymm0,%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 197,52,89,200 // vmulps %ymm0,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 197,172,89,192 // vmulps %ymm0,%ymm10,%ymm0 .byte 196,193,124,88,195 // vaddps %ymm11,%ymm0,%ymm0 .byte 196,98,125,24,16 // vbroadcastss (%rax),%ymm10 .byte 197,124,91,216 // vcvtdq2ps %ymm0,%ymm11 .byte 196,98,125,24,37,2,76,0,0 // vbroadcastss 0x4c02(%rip),%ymm12 # 7d2c <_sk_callback_avx+0x2bc> .byte 196,65,36,89,220 // vmulps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,248,75,0,0 // vbroadcastss 0x4bf8(%rip),%ymm12 # 7d30 <_sk_callback_avx+0x2c0> .byte 196,193,124,84,196 // vandps %ymm12,%ymm0,%ymm0 .byte 196,98,125,24,37,238,75,0,0 // vbroadcastss 0x4bee(%rip),%ymm12 # 7d34 <_sk_callback_avx+0x2c4> .byte 196,193,124,86,196 // vorps %ymm12,%ymm0,%ymm0 .byte 196,98,125,24,37,228,75,0,0 // vbroadcastss 0x4be4(%rip),%ymm12 # 7d38 <_sk_callback_avx+0x2c8> .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,218,75,0,0 // vbroadcastss 0x4bda(%rip),%ymm12 # 7d3c <_sk_callback_avx+0x2cc> .byte 196,65,124,89,228 // vmulps %ymm12,%ymm0,%ymm12 .byte 196,65,36,92,220 // vsubps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,203,75,0,0 // vbroadcastss 0x4bcb(%rip),%ymm12 # 7d40 <_sk_callback_avx+0x2d0> .byte 196,193,124,88,196 // vaddps %ymm12,%ymm0,%ymm0 .byte 196,98,125,24,37,193,75,0,0 // vbroadcastss 0x4bc1(%rip),%ymm12 # 7d44 <_sk_callback_avx+0x2d4> .byte 197,156,94,192 // vdivps %ymm0,%ymm12,%ymm0 .byte 197,164,92,192 // vsubps %ymm0,%ymm11,%ymm0 .byte 197,172,89,192 // vmulps %ymm0,%ymm10,%ymm0 .byte 196,99,125,8,208,1 // vroundps $0x1,%ymm0,%ymm10 .byte 196,65,124,92,210 // vsubps %ymm10,%ymm0,%ymm10 .byte 196,98,125,24,29,165,75,0,0 // vbroadcastss 0x4ba5(%rip),%ymm11 # 7d48 <_sk_callback_avx+0x2d8> .byte 196,193,124,88,195 // vaddps %ymm11,%ymm0,%ymm0 .byte 196,98,125,24,29,155,75,0,0 // vbroadcastss 0x4b9b(%rip),%ymm11 # 7d4c <_sk_callback_avx+0x2dc> .byte 196,65,44,89,219 // vmulps %ymm11,%ymm10,%ymm11 .byte 196,193,124,92,195 // vsubps %ymm11,%ymm0,%ymm0 .byte 196,98,125,24,29,140,75,0,0 // vbroadcastss 0x4b8c(%rip),%ymm11 # 7d50 <_sk_callback_avx+0x2e0> .byte 196,65,36,92,210 // vsubps %ymm10,%ymm11,%ymm10 .byte 196,98,125,24,29,130,75,0,0 // vbroadcastss 0x4b82(%rip),%ymm11 # 7d54 <_sk_callback_avx+0x2e4> .byte 196,65,36,94,210 // vdivps %ymm10,%ymm11,%ymm10 .byte 196,193,124,88,194 // vaddps %ymm10,%ymm0,%ymm0 .byte 196,98,125,24,21,115,75,0,0 // vbroadcastss 0x4b73(%rip),%ymm10 # 7d58 <_sk_callback_avx+0x2e8> .byte 196,193,124,89,194 // vmulps %ymm10,%ymm0,%ymm0 .byte 197,253,91,192 // vcvtps2dq %ymm0,%ymm0 .byte 196,98,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm10 .byte 196,193,124,88,194 // vaddps %ymm10,%ymm0,%ymm0 .byte 196,195,125,74,193,128 // vblendvps %ymm8,%ymm9,%ymm0,%ymm0 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,124,95,192 // vmaxps %ymm8,%ymm0,%ymm0 .byte 196,98,125,24,5,74,75,0,0 // vbroadcastss 0x4b4a(%rip),%ymm8 # 7d5c <_sk_callback_avx+0x2ec> .byte 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_g_avx .globl _sk_parametric_g_avx FUNCTION(_sk_parametric_g_avx) _sk_parametric_g_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,65,116,194,192,2 // vcmpleps %ymm8,%ymm1,%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 197,52,89,201 // vmulps %ymm1,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 197,172,89,201 // vmulps %ymm1,%ymm10,%ymm1 .byte 196,193,116,88,203 // vaddps %ymm11,%ymm1,%ymm1 .byte 196,98,125,24,16 // vbroadcastss (%rax),%ymm10 .byte 197,124,91,217 // vcvtdq2ps %ymm1,%ymm11 .byte 196,98,125,24,37,251,74,0,0 // vbroadcastss 0x4afb(%rip),%ymm12 # 7d60 <_sk_callback_avx+0x2f0> .byte 196,65,36,89,220 // vmulps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,241,74,0,0 // vbroadcastss 0x4af1(%rip),%ymm12 # 7d64 <_sk_callback_avx+0x2f4> .byte 196,193,116,84,204 // vandps %ymm12,%ymm1,%ymm1 .byte 196,98,125,24,37,231,74,0,0 // vbroadcastss 0x4ae7(%rip),%ymm12 # 7d68 <_sk_callback_avx+0x2f8> .byte 196,193,116,86,204 // vorps %ymm12,%ymm1,%ymm1 .byte 196,98,125,24,37,221,74,0,0 // vbroadcastss 0x4add(%rip),%ymm12 # 7d6c <_sk_callback_avx+0x2fc> .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,211,74,0,0 // vbroadcastss 0x4ad3(%rip),%ymm12 # 7d70 <_sk_callback_avx+0x300> .byte 196,65,116,89,228 // vmulps %ymm12,%ymm1,%ymm12 .byte 196,65,36,92,220 // vsubps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,196,74,0,0 // vbroadcastss 0x4ac4(%rip),%ymm12 # 7d74 <_sk_callback_avx+0x304> .byte 196,193,116,88,204 // vaddps %ymm12,%ymm1,%ymm1 .byte 196,98,125,24,37,186,74,0,0 // vbroadcastss 0x4aba(%rip),%ymm12 # 7d78 <_sk_callback_avx+0x308> .byte 197,156,94,201 // vdivps %ymm1,%ymm12,%ymm1 .byte 197,164,92,201 // vsubps %ymm1,%ymm11,%ymm1 .byte 197,172,89,201 // vmulps %ymm1,%ymm10,%ymm1 .byte 196,99,125,8,209,1 // vroundps $0x1,%ymm1,%ymm10 .byte 196,65,116,92,210 // vsubps %ymm10,%ymm1,%ymm10 .byte 196,98,125,24,29,158,74,0,0 // vbroadcastss 0x4a9e(%rip),%ymm11 # 7d7c <_sk_callback_avx+0x30c> .byte 196,193,116,88,203 // vaddps %ymm11,%ymm1,%ymm1 .byte 196,98,125,24,29,148,74,0,0 // vbroadcastss 0x4a94(%rip),%ymm11 # 7d80 <_sk_callback_avx+0x310> .byte 196,65,44,89,219 // vmulps %ymm11,%ymm10,%ymm11 .byte 196,193,116,92,203 // vsubps %ymm11,%ymm1,%ymm1 .byte 196,98,125,24,29,133,74,0,0 // vbroadcastss 0x4a85(%rip),%ymm11 # 7d84 <_sk_callback_avx+0x314> .byte 196,65,36,92,210 // vsubps %ymm10,%ymm11,%ymm10 .byte 196,98,125,24,29,123,74,0,0 // vbroadcastss 0x4a7b(%rip),%ymm11 # 7d88 <_sk_callback_avx+0x318> .byte 196,65,36,94,210 // vdivps %ymm10,%ymm11,%ymm10 .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 196,98,125,24,21,108,74,0,0 // vbroadcastss 0x4a6c(%rip),%ymm10 # 7d8c <_sk_callback_avx+0x31c> .byte 196,193,116,89,202 // vmulps %ymm10,%ymm1,%ymm1 .byte 197,253,91,201 // vcvtps2dq %ymm1,%ymm1 .byte 196,98,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm10 .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 196,195,117,74,201,128 // vblendvps %ymm8,%ymm9,%ymm1,%ymm1 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,116,95,200 // vmaxps %ymm8,%ymm1,%ymm1 .byte 196,98,125,24,5,67,74,0,0 // vbroadcastss 0x4a43(%rip),%ymm8 # 7d90 <_sk_callback_avx+0x320> .byte 196,193,116,93,200 // vminps %ymm8,%ymm1,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_b_avx .globl _sk_parametric_b_avx FUNCTION(_sk_parametric_b_avx) _sk_parametric_b_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,65,108,194,192,2 // vcmpleps %ymm8,%ymm2,%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 197,52,89,202 // vmulps %ymm2,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 197,172,89,210 // vmulps %ymm2,%ymm10,%ymm2 .byte 196,193,108,88,211 // vaddps %ymm11,%ymm2,%ymm2 .byte 196,98,125,24,16 // vbroadcastss (%rax),%ymm10 .byte 197,124,91,218 // vcvtdq2ps %ymm2,%ymm11 .byte 196,98,125,24,37,244,73,0,0 // vbroadcastss 0x49f4(%rip),%ymm12 # 7d94 <_sk_callback_avx+0x324> .byte 196,65,36,89,220 // vmulps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,234,73,0,0 // vbroadcastss 0x49ea(%rip),%ymm12 # 7d98 <_sk_callback_avx+0x328> .byte 196,193,108,84,212 // vandps %ymm12,%ymm2,%ymm2 .byte 196,98,125,24,37,224,73,0,0 // vbroadcastss 0x49e0(%rip),%ymm12 # 7d9c <_sk_callback_avx+0x32c> .byte 196,193,108,86,212 // vorps %ymm12,%ymm2,%ymm2 .byte 196,98,125,24,37,214,73,0,0 // vbroadcastss 0x49d6(%rip),%ymm12 # 7da0 <_sk_callback_avx+0x330> .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,204,73,0,0 // vbroadcastss 0x49cc(%rip),%ymm12 # 7da4 <_sk_callback_avx+0x334> .byte 196,65,108,89,228 // vmulps %ymm12,%ymm2,%ymm12 .byte 196,65,36,92,220 // vsubps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,189,73,0,0 // vbroadcastss 0x49bd(%rip),%ymm12 # 7da8 <_sk_callback_avx+0x338> .byte 196,193,108,88,212 // vaddps %ymm12,%ymm2,%ymm2 .byte 196,98,125,24,37,179,73,0,0 // vbroadcastss 0x49b3(%rip),%ymm12 # 7dac <_sk_callback_avx+0x33c> .byte 197,156,94,210 // vdivps %ymm2,%ymm12,%ymm2 .byte 197,164,92,210 // vsubps %ymm2,%ymm11,%ymm2 .byte 197,172,89,210 // vmulps %ymm2,%ymm10,%ymm2 .byte 196,99,125,8,210,1 // vroundps $0x1,%ymm2,%ymm10 .byte 196,65,108,92,210 // vsubps %ymm10,%ymm2,%ymm10 .byte 196,98,125,24,29,151,73,0,0 // vbroadcastss 0x4997(%rip),%ymm11 # 7db0 <_sk_callback_avx+0x340> .byte 196,193,108,88,211 // vaddps %ymm11,%ymm2,%ymm2 .byte 196,98,125,24,29,141,73,0,0 // vbroadcastss 0x498d(%rip),%ymm11 # 7db4 <_sk_callback_avx+0x344> .byte 196,65,44,89,219 // vmulps %ymm11,%ymm10,%ymm11 .byte 196,193,108,92,211 // vsubps %ymm11,%ymm2,%ymm2 .byte 196,98,125,24,29,126,73,0,0 // vbroadcastss 0x497e(%rip),%ymm11 # 7db8 <_sk_callback_avx+0x348> .byte 196,65,36,92,210 // vsubps %ymm10,%ymm11,%ymm10 .byte 196,98,125,24,29,116,73,0,0 // vbroadcastss 0x4974(%rip),%ymm11 # 7dbc <_sk_callback_avx+0x34c> .byte 196,65,36,94,210 // vdivps %ymm10,%ymm11,%ymm10 .byte 196,193,108,88,210 // vaddps %ymm10,%ymm2,%ymm2 .byte 196,98,125,24,21,101,73,0,0 // vbroadcastss 0x4965(%rip),%ymm10 # 7dc0 <_sk_callback_avx+0x350> .byte 196,193,108,89,210 // vmulps %ymm10,%ymm2,%ymm2 .byte 197,253,91,210 // vcvtps2dq %ymm2,%ymm2 .byte 196,98,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm10 .byte 196,193,108,88,210 // vaddps %ymm10,%ymm2,%ymm2 .byte 196,195,109,74,209,128 // vblendvps %ymm8,%ymm9,%ymm2,%ymm2 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,108,95,208 // vmaxps %ymm8,%ymm2,%ymm2 .byte 196,98,125,24,5,60,73,0,0 // vbroadcastss 0x493c(%rip),%ymm8 # 7dc4 <_sk_callback_avx+0x354> .byte 196,193,108,93,208 // vminps %ymm8,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_a_avx .globl _sk_parametric_a_avx FUNCTION(_sk_parametric_a_avx) _sk_parametric_a_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm8 .byte 196,65,100,194,192,2 // vcmpleps %ymm8,%ymm3,%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 197,52,89,203 // vmulps %ymm3,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm10 .byte 196,98,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm11 .byte 197,172,89,219 // vmulps %ymm3,%ymm10,%ymm3 .byte 196,193,100,88,219 // vaddps %ymm11,%ymm3,%ymm3 .byte 196,98,125,24,16 // vbroadcastss (%rax),%ymm10 .byte 197,124,91,219 // vcvtdq2ps %ymm3,%ymm11 .byte 196,98,125,24,37,237,72,0,0 // vbroadcastss 0x48ed(%rip),%ymm12 # 7dc8 <_sk_callback_avx+0x358> .byte 196,65,36,89,220 // vmulps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,227,72,0,0 // vbroadcastss 0x48e3(%rip),%ymm12 # 7dcc <_sk_callback_avx+0x35c> .byte 196,193,100,84,220 // vandps %ymm12,%ymm3,%ymm3 .byte 196,98,125,24,37,217,72,0,0 // vbroadcastss 0x48d9(%rip),%ymm12 # 7dd0 <_sk_callback_avx+0x360> .byte 196,193,100,86,220 // vorps %ymm12,%ymm3,%ymm3 .byte 196,98,125,24,37,207,72,0,0 // vbroadcastss 0x48cf(%rip),%ymm12 # 7dd4 <_sk_callback_avx+0x364> .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,197,72,0,0 // vbroadcastss 0x48c5(%rip),%ymm12 # 7dd8 <_sk_callback_avx+0x368> .byte 196,65,100,89,228 // vmulps %ymm12,%ymm3,%ymm12 .byte 196,65,36,92,220 // vsubps %ymm12,%ymm11,%ymm11 .byte 196,98,125,24,37,182,72,0,0 // vbroadcastss 0x48b6(%rip),%ymm12 # 7ddc <_sk_callback_avx+0x36c> .byte 196,193,100,88,220 // vaddps %ymm12,%ymm3,%ymm3 .byte 196,98,125,24,37,172,72,0,0 // vbroadcastss 0x48ac(%rip),%ymm12 # 7de0 <_sk_callback_avx+0x370> .byte 197,156,94,219 // vdivps %ymm3,%ymm12,%ymm3 .byte 197,164,92,219 // vsubps %ymm3,%ymm11,%ymm3 .byte 197,172,89,219 // vmulps %ymm3,%ymm10,%ymm3 .byte 196,99,125,8,211,1 // vroundps $0x1,%ymm3,%ymm10 .byte 196,65,100,92,210 // vsubps %ymm10,%ymm3,%ymm10 .byte 196,98,125,24,29,144,72,0,0 // vbroadcastss 0x4890(%rip),%ymm11 # 7de4 <_sk_callback_avx+0x374> .byte 196,193,100,88,219 // vaddps %ymm11,%ymm3,%ymm3 .byte 196,98,125,24,29,134,72,0,0 // vbroadcastss 0x4886(%rip),%ymm11 # 7de8 <_sk_callback_avx+0x378> .byte 196,65,44,89,219 // vmulps %ymm11,%ymm10,%ymm11 .byte 196,193,100,92,219 // vsubps %ymm11,%ymm3,%ymm3 .byte 196,98,125,24,29,119,72,0,0 // vbroadcastss 0x4877(%rip),%ymm11 # 7dec <_sk_callback_avx+0x37c> .byte 196,65,36,92,210 // vsubps %ymm10,%ymm11,%ymm10 .byte 196,98,125,24,29,109,72,0,0 // vbroadcastss 0x486d(%rip),%ymm11 # 7df0 <_sk_callback_avx+0x380> .byte 196,65,36,94,210 // vdivps %ymm10,%ymm11,%ymm10 .byte 196,193,100,88,218 // vaddps %ymm10,%ymm3,%ymm3 .byte 196,98,125,24,21,94,72,0,0 // vbroadcastss 0x485e(%rip),%ymm10 # 7df4 <_sk_callback_avx+0x384> .byte 196,193,100,89,218 // vmulps %ymm10,%ymm3,%ymm3 .byte 197,253,91,219 // vcvtps2dq %ymm3,%ymm3 .byte 196,98,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm10 .byte 196,193,100,88,218 // vaddps %ymm10,%ymm3,%ymm3 .byte 196,195,101,74,217,128 // vblendvps %ymm8,%ymm9,%ymm3,%ymm3 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 196,193,100,95,216 // vmaxps %ymm8,%ymm3,%ymm3 .byte 196,98,125,24,5,53,72,0,0 // vbroadcastss 0x4835(%rip),%ymm8 # 7df8 <_sk_callback_avx+0x388> .byte 196,193,100,93,216 // vminps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_gamma_avx .globl _sk_gamma_avx FUNCTION(_sk_gamma_avx) _sk_gamma_avx: .byte 72,131,236,88 // sub $0x58,%rsp .byte 197,252,17,124,36,32 // vmovups %ymm7,0x20(%rsp) .byte 197,252,17,52,36 // vmovups %ymm6,(%rsp) .byte 197,252,17,108,36,224 // vmovups %ymm5,-0x20(%rsp) .byte 197,252,17,100,36,192 // vmovups %ymm4,-0x40(%rsp) .byte 197,252,17,92,36,160 // vmovups %ymm3,-0x60(%rsp) .byte 197,252,40,250 // vmovaps %ymm2,%ymm7 .byte 197,252,40,233 // vmovaps %ymm1,%ymm5 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,91,200 // vcvtdq2ps %ymm0,%ymm1 .byte 196,98,125,24,5,248,71,0,0 // vbroadcastss 0x47f8(%rip),%ymm8 # 7dfc <_sk_callback_avx+0x38c> .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 196,98,125,24,13,238,71,0,0 // vbroadcastss 0x47ee(%rip),%ymm9 # 7e00 <_sk_callback_avx+0x390> .byte 196,193,124,84,193 // vandps %ymm9,%ymm0,%ymm0 .byte 196,226,125,24,37,228,71,0,0 // vbroadcastss 0x47e4(%rip),%ymm4 # 7e04 <_sk_callback_avx+0x394> .byte 197,252,86,196 // vorps %ymm4,%ymm0,%ymm0 .byte 196,98,125,24,21,219,71,0,0 // vbroadcastss 0x47db(%rip),%ymm10 # 7e08 <_sk_callback_avx+0x398> .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 196,98,125,24,29,209,71,0,0 // vbroadcastss 0x47d1(%rip),%ymm11 # 7e0c <_sk_callback_avx+0x39c> .byte 196,193,124,89,211 // vmulps %ymm11,%ymm0,%ymm2 .byte 197,244,92,202 // vsubps %ymm2,%ymm1,%ymm1 .byte 196,98,125,24,37,195,71,0,0 // vbroadcastss 0x47c3(%rip),%ymm12 # 7e10 <_sk_callback_avx+0x3a0> .byte 196,193,124,88,196 // vaddps %ymm12,%ymm0,%ymm0 .byte 196,98,125,24,45,185,71,0,0 // vbroadcastss 0x47b9(%rip),%ymm13 # 7e14 <_sk_callback_avx+0x3a4> .byte 197,148,94,192 // vdivps %ymm0,%ymm13,%ymm0 .byte 197,244,92,192 // vsubps %ymm0,%ymm1,%ymm0 .byte 196,98,125,24,48 // vbroadcastss (%rax),%ymm14 .byte 196,193,124,89,198 // vmulps %ymm14,%ymm0,%ymm0 .byte 196,227,125,8,200,1 // vroundps $0x1,%ymm0,%ymm1 .byte 197,252,92,241 // vsubps %ymm1,%ymm0,%ymm6 .byte 196,98,125,24,61,152,71,0,0 // vbroadcastss 0x4798(%rip),%ymm15 # 7e18 <_sk_callback_avx+0x3a8> .byte 196,193,124,88,199 // vaddps %ymm15,%ymm0,%ymm0 .byte 196,226,125,24,29,142,71,0,0 // vbroadcastss 0x478e(%rip),%ymm3 # 7e1c <_sk_callback_avx+0x3ac> .byte 197,204,89,203 // vmulps %ymm3,%ymm6,%ymm1 .byte 197,252,92,201 // vsubps %ymm1,%ymm0,%ymm1 .byte 196,226,125,24,21,129,71,0,0 // vbroadcastss 0x4781(%rip),%ymm2 # 7e20 <_sk_callback_avx+0x3b0> .byte 197,236,92,198 // vsubps %ymm6,%ymm2,%ymm0 .byte 196,226,125,24,53,120,71,0,0 // vbroadcastss 0x4778(%rip),%ymm6 # 7e24 <_sk_callback_avx+0x3b4> .byte 197,204,94,192 // vdivps %ymm0,%ymm6,%ymm0 .byte 197,244,88,192 // vaddps %ymm0,%ymm1,%ymm0 .byte 197,252,17,68,36,128 // vmovups %ymm0,-0x80(%rsp) .byte 197,252,91,205 // vcvtdq2ps %ymm5,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 196,193,84,84,233 // vandps %ymm9,%ymm5,%ymm5 .byte 197,212,86,236 // vorps %ymm4,%ymm5,%ymm5 .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 196,193,84,89,195 // vmulps %ymm11,%ymm5,%ymm0 .byte 197,244,92,192 // vsubps %ymm0,%ymm1,%ymm0 .byte 196,193,84,88,204 // vaddps %ymm12,%ymm5,%ymm1 .byte 197,148,94,201 // vdivps %ymm1,%ymm13,%ymm1 .byte 197,252,92,193 // vsubps %ymm1,%ymm0,%ymm0 .byte 196,193,124,89,198 // vmulps %ymm14,%ymm0,%ymm0 .byte 196,227,125,8,200,1 // vroundps $0x1,%ymm0,%ymm1 .byte 197,252,92,201 // vsubps %ymm1,%ymm0,%ymm1 .byte 196,193,124,88,199 // vaddps %ymm15,%ymm0,%ymm0 .byte 197,244,89,235 // vmulps %ymm3,%ymm1,%ymm5 .byte 197,252,92,197 // vsubps %ymm5,%ymm0,%ymm0 .byte 197,236,92,201 // vsubps %ymm1,%ymm2,%ymm1 .byte 197,204,94,201 // vdivps %ymm1,%ymm6,%ymm1 .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 197,252,91,207 // vcvtdq2ps %ymm7,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 196,193,68,84,233 // vandps %ymm9,%ymm7,%ymm5 .byte 197,212,86,228 // vorps %ymm4,%ymm5,%ymm4 .byte 196,193,116,88,202 // vaddps %ymm10,%ymm1,%ymm1 .byte 196,193,92,89,235 // vmulps %ymm11,%ymm4,%ymm5 .byte 197,244,92,205 // vsubps %ymm5,%ymm1,%ymm1 .byte 196,193,92,88,228 // vaddps %ymm12,%ymm4,%ymm4 .byte 197,148,94,228 // vdivps %ymm4,%ymm13,%ymm4 .byte 197,244,92,204 // vsubps %ymm4,%ymm1,%ymm1 .byte 196,193,116,89,206 // vmulps %ymm14,%ymm1,%ymm1 .byte 196,227,125,8,225,1 // vroundps $0x1,%ymm1,%ymm4 .byte 197,244,92,228 // vsubps %ymm4,%ymm1,%ymm4 .byte 196,193,116,88,207 // vaddps %ymm15,%ymm1,%ymm1 .byte 197,220,89,219 // vmulps %ymm3,%ymm4,%ymm3 .byte 197,244,92,203 // vsubps %ymm3,%ymm1,%ymm1 .byte 197,236,92,212 // vsubps %ymm4,%ymm2,%ymm2 .byte 197,204,94,210 // vdivps %ymm2,%ymm6,%ymm2 .byte 197,244,88,202 // vaddps %ymm2,%ymm1,%ymm1 .byte 196,226,125,24,21,187,70,0,0 // vbroadcastss 0x46bb(%rip),%ymm2 # 7e28 <_sk_callback_avx+0x3b8> .byte 197,236,89,92,36,128 // vmulps -0x80(%rsp),%ymm2,%ymm3 .byte 197,252,89,226 // vmulps %ymm2,%ymm0,%ymm4 .byte 197,244,89,210 // vmulps %ymm2,%ymm1,%ymm2 .byte 197,253,91,195 // vcvtps2dq %ymm3,%ymm0 .byte 197,253,91,204 // vcvtps2dq %ymm4,%ymm1 .byte 197,253,91,210 // vcvtps2dq %ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,92,36,160 // vmovups -0x60(%rsp),%ymm3 .byte 197,252,16,100,36,192 // vmovups -0x40(%rsp),%ymm4 .byte 197,252,16,108,36,224 // vmovups -0x20(%rsp),%ymm5 .byte 197,252,16,52,36 // vmovups (%rsp),%ymm6 .byte 197,252,16,124,36,32 // vmovups 0x20(%rsp),%ymm7 .byte 72,131,196,88 // add $0x58,%rsp .byte 255,224 // jmpq *%rax HIDDEN _sk_lab_to_xyz_avx .globl _sk_lab_to_xyz_avx FUNCTION(_sk_lab_to_xyz_avx) _sk_lab_to_xyz_avx: .byte 196,98,125,24,5,119,70,0,0 // vbroadcastss 0x4677(%rip),%ymm8 # 7e2c <_sk_callback_avx+0x3bc> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 196,98,125,24,5,109,70,0,0 // vbroadcastss 0x466d(%rip),%ymm8 # 7e30 <_sk_callback_avx+0x3c0> .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 196,98,125,24,13,99,70,0,0 // vbroadcastss 0x4663(%rip),%ymm9 # 7e34 <_sk_callback_avx+0x3c4> .byte 196,193,116,88,201 // vaddps %ymm9,%ymm1,%ymm1 .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 196,193,108,88,209 // vaddps %ymm9,%ymm2,%ymm2 .byte 196,98,125,24,5,79,70,0,0 // vbroadcastss 0x464f(%rip),%ymm8 # 7e38 <_sk_callback_avx+0x3c8> .byte 196,193,124,88,192 // vaddps %ymm8,%ymm0,%ymm0 .byte 196,98,125,24,5,69,70,0,0 // vbroadcastss 0x4645(%rip),%ymm8 # 7e3c <_sk_callback_avx+0x3cc> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 196,98,125,24,5,59,70,0,0 // vbroadcastss 0x463b(%rip),%ymm8 # 7e40 <_sk_callback_avx+0x3d0> .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 197,252,88,201 // vaddps %ymm1,%ymm0,%ymm1 .byte 196,98,125,24,5,45,70,0,0 // vbroadcastss 0x462d(%rip),%ymm8 # 7e44 <_sk_callback_avx+0x3d4> .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 197,252,92,210 // vsubps %ymm2,%ymm0,%ymm2 .byte 197,116,89,193 // vmulps %ymm1,%ymm1,%ymm8 .byte 196,65,116,89,192 // vmulps %ymm8,%ymm1,%ymm8 .byte 196,98,125,24,13,22,70,0,0 // vbroadcastss 0x4616(%rip),%ymm9 # 7e48 <_sk_callback_avx+0x3d8> .byte 196,65,52,194,208,1 // vcmpltps %ymm8,%ymm9,%ymm10 .byte 196,98,125,24,29,11,70,0,0 // vbroadcastss 0x460b(%rip),%ymm11 # 7e4c <_sk_callback_avx+0x3dc> .byte 196,193,116,88,203 // vaddps %ymm11,%ymm1,%ymm1 .byte 196,98,125,24,37,1,70,0,0 // vbroadcastss 0x4601(%rip),%ymm12 # 7e50 <_sk_callback_avx+0x3e0> .byte 196,193,116,89,204 // vmulps %ymm12,%ymm1,%ymm1 .byte 196,67,117,74,192,160 // vblendvps %ymm10,%ymm8,%ymm1,%ymm8 .byte 197,252,89,200 // vmulps %ymm0,%ymm0,%ymm1 .byte 197,252,89,201 // vmulps %ymm1,%ymm0,%ymm1 .byte 197,52,194,209,1 // vcmpltps %ymm1,%ymm9,%ymm10 .byte 196,193,124,88,195 // vaddps %ymm11,%ymm0,%ymm0 .byte 196,193,124,89,196 // vmulps %ymm12,%ymm0,%ymm0 .byte 196,227,125,74,201,160 // vblendvps %ymm10,%ymm1,%ymm0,%ymm1 .byte 197,236,89,194 // vmulps %ymm2,%ymm2,%ymm0 .byte 197,236,89,192 // vmulps %ymm0,%ymm2,%ymm0 .byte 197,52,194,200,1 // vcmpltps %ymm0,%ymm9,%ymm9 .byte 196,193,108,88,211 // vaddps %ymm11,%ymm2,%ymm2 .byte 196,193,108,89,212 // vmulps %ymm12,%ymm2,%ymm2 .byte 196,227,109,74,208,144 // vblendvps %ymm9,%ymm0,%ymm2,%ymm2 .byte 196,226,125,24,5,183,69,0,0 // vbroadcastss 0x45b7(%rip),%ymm0 # 7e54 <_sk_callback_avx+0x3e4> .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 196,98,125,24,5,174,69,0,0 // vbroadcastss 0x45ae(%rip),%ymm8 # 7e58 <_sk_callback_avx+0x3e8> .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_load_a8_avx .globl _sk_load_a8_avx FUNCTION(_sk_load_a8_avx) _sk_load_a8_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,67 // jne 390f <_sk_load_a8_avx+0x5c> .byte 196,194,121,48,4,25 // vpmovzxbw (%r9,%rbx,1),%xmm0 .byte 197,249,219,5,118,72,0,0 // vpand 0x4876(%rip),%xmm0,%xmm0 # 8150 <_sk_callback_avx+0x6e0> .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,249,105,201 // vpunpckhwd %xmm1,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,98,69,0,0 // vbroadcastss 0x4562(%rip),%ymm1 # 7e5c <_sk_callback_avx+0x3ec> .byte 197,252,89,217 // vmulps %ymm1,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,236,87,210 // vxorps %ymm2,%ymm2,%ymm2 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,175 // ja 38d2 <_sk_load_a8_avx+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,122,0,0,0 // lea 0x7a(%rip),%r11 # 39a8 <_sk_load_a8_avx+0xf5> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 235,144 // jmp 38d2 <_sk_load_a8_avx+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,2 // vpinsrw $0x2,%eax,%xmm0,%xmm0 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,249,110,200 // vmovd %eax,%xmm1 .byte 196,226,121,48,201 // vpmovzxbw %xmm1,%xmm1 .byte 196,227,121,14,193,3 // vpblendw $0x3,%xmm1,%xmm0,%xmm0 .byte 233,104,255,255,255 // jmpq 38d2 <_sk_load_a8_avx+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,249,196,192,5 // vpinsrw $0x5,%eax,%xmm0,%xmm0 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,249,196,192,4 // vpinsrw $0x4,%eax,%xmm0,%xmm0 .byte 196,193,121,110,12,25 // vmovd (%r9,%rbx,1),%xmm1 .byte 196,226,121,48,201 // vpmovzxbw %xmm1,%xmm1 .byte 196,227,113,14,192,240 // vpblendw $0xf0,%xmm0,%xmm1,%xmm0 .byte 233,45,255,255,255 // jmpq 38d2 <_sk_load_a8_avx+0x1f> .byte 15,31,0 // nopl (%rax) .byte 143 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,169,255,255,255,154 // ljmp *-0x65000001(%rcx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,231 // jmpq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 220,255 // fdivr %st,%st(7) .byte 255 // (bad) .byte 255,209 // callq *%rcx .byte 255 // (bad) .byte 255 // (bad) .byte 255,194 // inc %edx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_a8_dst_avx .globl _sk_load_a8_dst_avx FUNCTION(_sk_load_a8_dst_avx) _sk_load_a8_dst_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,67 // jne 3a20 <_sk_load_a8_dst_avx+0x5c> .byte 196,194,121,48,36,25 // vpmovzxbw (%r9,%rbx,1),%xmm4 .byte 197,217,219,37,117,71,0,0 // vpand 0x4775(%rip),%xmm4,%xmm4 # 8160 <_sk_callback_avx+0x6f0> .byte 197,209,239,237 // vpxor %xmm5,%xmm5,%xmm5 .byte 197,217,105,237 // vpunpckhwd %xmm5,%xmm4,%xmm5 .byte 196,226,121,51,228 // vpmovzxwd %xmm4,%xmm4 .byte 196,227,93,24,229,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,226,125,24,45,85,68,0,0 // vbroadcastss 0x4455(%rip),%ymm5 # 7e60 <_sk_callback_avx+0x3f0> .byte 197,220,89,253 // vmulps %ymm5,%ymm4,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,220,87,228 // vxorps %ymm4,%ymm4,%ymm4 .byte 197,212,87,237 // vxorps %ymm5,%ymm5,%ymm5 .byte 197,204,87,246 // vxorps %ymm6,%ymm6,%ymm6 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,175 // ja 39e3 <_sk_load_a8_dst_avx+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,121,0,0,0 // lea 0x79(%rip),%r11 # 3ab8 <_sk_load_a8_dst_avx+0xf4> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,249,110,224 // vmovd %eax,%xmm4 .byte 235,144 // jmp 39e3 <_sk_load_a8_dst_avx+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,217,196,224,2 // vpinsrw $0x2,%eax,%xmm4,%xmm4 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,249,110,232 // vmovd %eax,%xmm5 .byte 196,226,121,48,237 // vpmovzxbw %xmm5,%xmm5 .byte 196,227,89,14,229,3 // vpblendw $0x3,%xmm5,%xmm4,%xmm4 .byte 233,104,255,255,255 // jmpq 39e3 <_sk_load_a8_dst_avx+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,217,196,224,6 // vpinsrw $0x6,%eax,%xmm4,%xmm4 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,217,196,224,5 // vpinsrw $0x5,%eax,%xmm4,%xmm4 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,217,196,224,4 // vpinsrw $0x4,%eax,%xmm4,%xmm4 .byte 196,193,121,110,44,25 // vmovd (%r9,%rbx,1),%xmm5 .byte 196,226,121,48,237 // vpmovzxbw %xmm5,%xmm5 .byte 196,227,81,14,228,240 // vpblendw $0xf0,%xmm4,%xmm5,%xmm4 .byte 233,45,255,255,255 // jmpq 39e3 <_sk_load_a8_dst_avx+0x1f> .byte 102,144 // xchg %ax,%ax .byte 144 // nop .byte 255 // (bad) .byte 255 // (bad) .byte 255,170,255,255,255,155 // ljmp *-0x64000001(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 232,255,255,255,221 // callq ffffffffde003ac8 <_sk_callback_avx+0xffffffffddffc058> .byte 255 // (bad) .byte 255 // (bad) .byte 255,210 // callq *%rdx .byte 255 // (bad) .byte 255 // (bad) .byte 255,195 // inc %ebx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_gather_a8_avx .globl _sk_gather_a8_avx FUNCTION(_sk_gather_a8_avx) _sk_gather_a8_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 197,249,110,80,8 // vmovd 0x8(%rax),%xmm2 .byte 197,249,112,210,0 // vpshufd $0x0,%xmm2,%xmm2 .byte 196,226,105,64,217 // vpmulld %xmm1,%xmm2,%xmm3 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 196,226,105,64,201 // vpmulld %xmm1,%xmm2,%xmm1 .byte 197,254,91,208 // vcvttps2dq %ymm0,%ymm2 .byte 196,227,125,25,208,1 // vextractf128 $0x1,%ymm2,%xmm0 .byte 197,241,254,192 // vpaddd %xmm0,%xmm1,%xmm0 .byte 197,225,254,202 // vpaddd %xmm2,%xmm3,%xmm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,195,121,32,20,1,0 // vpinsrb $0x0,(%r9,%rax,1),%xmm0,%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,105,32,12,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm2,%xmm1 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,113,32,200,2 // vpinsrb $0x2,%eax,%xmm1,%xmm1 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 196,227,113,32,200,3 // vpinsrb $0x3,%eax,%xmm1,%xmm1 .byte 68,137,208 // mov %r10d,%eax .byte 196,195,121,32,20,1,0 // vpinsrb $0x0,(%r9,%rax,1),%xmm0,%xmm2 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,105,32,4,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm2,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,121,32,192,2 // vpinsrb $0x2,%eax,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 196,226,121,49,201 // vpmovzxbd %xmm1,%xmm1 .byte 196,227,121,32,192,3 // vpinsrb $0x3,%eax,%xmm0,%xmm0 .byte 196,226,121,49,192 // vpmovzxbd %xmm0,%xmm0 .byte 196,227,117,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,196,66,0,0 // vbroadcastss 0x42c4(%rip),%ymm1 # 7e64 <_sk_callback_avx+0x3f4> .byte 197,252,89,217 // vmulps %ymm1,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,236,87,210 // vxorps %ymm2,%ymm2,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_store_a8_avx .globl _sk_store_a8_avx FUNCTION(_sk_store_a8_avx) _sk_store_a8_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 196,98,125,24,5,151,66,0,0 // vbroadcastss 0x4297(%rip),%ymm8 # 7e68 <_sk_callback_avx+0x3f8> .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,67,125,25,193,1 // vextractf128 $0x1,%ymm8,%xmm9 .byte 196,66,57,43,193 // vpackusdw %xmm9,%xmm8,%xmm8 .byte 196,65,57,103,192 // vpackuswb %xmm8,%xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 3bfb <_sk_store_a8_avx+0x47> .byte 196,65,123,17,4,25 // vmovsd %xmm8,(%r9,%rbx,1) .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,235 // ja 3bf6 <_sk_store_a8_avx+0x42> .byte 196,66,121,48,192 // vpmovzxbw %xmm8,%xmm8 .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,85,0,0,0 // lea 0x55(%rip),%r11 # 3c70 <_sk_store_a8_avx+0xbc> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,67,121,20,4,25,0 // vpextrb $0x0,%xmm8,(%r9,%rbx,1) .byte 235,201 // jmp 3bf6 <_sk_store_a8_avx+0x42> .byte 196,67,121,20,68,25,2,4 // vpextrb $0x4,%xmm8,0x2(%r9,%rbx,1) .byte 196,98,57,0,5,50,69,0,0 // vpshufb 0x4532(%rip),%xmm8,%xmm8 # 8170 <_sk_callback_avx+0x700> .byte 196,67,121,21,4,25,0 // vpextrw $0x0,%xmm8,(%r9,%rbx,1) .byte 235,175 // jmp 3bf6 <_sk_store_a8_avx+0x42> .byte 196,67,121,20,68,25,6,12 // vpextrb $0xc,%xmm8,0x6(%r9,%rbx,1) .byte 196,67,121,20,68,25,5,10 // vpextrb $0xa,%xmm8,0x5(%r9,%rbx,1) .byte 196,67,121,20,68,25,4,8 // vpextrb $0x8,%xmm8,0x4(%r9,%rbx,1) .byte 196,98,57,0,5,24,69,0,0 // vpshufb 0x4518(%rip),%xmm8,%xmm8 # 8180 <_sk_callback_avx+0x710> .byte 196,65,121,126,4,25 // vmovd %xmm8,(%r9,%rbx,1) .byte 235,134 // jmp 3bf6 <_sk_store_a8_avx+0x42> .byte 180,255 // mov $0xff,%ah .byte 255 // (bad) .byte 255,197 // inc %ebp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 189,255,255,255,239 // mov $0xefffffff,%ebp .byte 255 // (bad) .byte 255 // (bad) .byte 255,231 // jmpq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 223,255 // (bad) .byte 255 // (bad) .byte 255,215 // callq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_g8_avx .globl _sk_load_g8_avx FUNCTION(_sk_load_g8_avx) _sk_load_g8_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,72 // jne 3ced <_sk_load_g8_avx+0x61> .byte 196,194,121,48,4,25 // vpmovzxbw (%r9,%rbx,1),%xmm0 .byte 197,249,219,5,221,68,0,0 // vpand 0x44dd(%rip),%xmm0,%xmm0 # 8190 <_sk_callback_avx+0x720> .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,249,105,201 // vpunpckhwd %xmm1,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,153,65,0,0 // vbroadcastss 0x4199(%rip),%ymm1 # 7e6c <_sk_callback_avx+0x3fc> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,142,65,0,0 // vbroadcastss 0x418e(%rip),%ymm3 # 7e70 <_sk_callback_avx+0x400> .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,170 // ja 3cab <_sk_load_g8_avx+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,120,0,0,0 // lea 0x78(%rip),%r11 # 3d84 <_sk_load_g8_avx+0xf8> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 235,139 // jmp 3cab <_sk_load_g8_avx+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,2 // vpinsrw $0x2,%eax,%xmm0,%xmm0 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,249,110,200 // vmovd %eax,%xmm1 .byte 196,226,121,48,201 // vpmovzxbw %xmm1,%xmm1 .byte 196,227,121,14,193,3 // vpblendw $0x3,%xmm1,%xmm0,%xmm0 .byte 233,99,255,255,255 // jmpq 3cab <_sk_load_g8_avx+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,249,196,192,5 // vpinsrw $0x5,%eax,%xmm0,%xmm0 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,249,196,192,4 // vpinsrw $0x4,%eax,%xmm0,%xmm0 .byte 196,193,121,110,12,25 // vmovd (%r9,%rbx,1),%xmm1 .byte 196,226,121,48,201 // vpmovzxbw %xmm1,%xmm1 .byte 196,227,113,14,192,240 // vpblendw $0xf0,%xmm0,%xmm1,%xmm0 .byte 233,40,255,255,255 // jmpq 3cab <_sk_load_g8_avx+0x1f> .byte 144 // nop .byte 145 // xchg %eax,%ecx .byte 255 // (bad) .byte 255 // (bad) .byte 255,171,255,255,255,156 // ljmp *-0x63000001(%rbx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 233,255,255,255,222 // jmpq ffffffffdf003d94 <_sk_callback_avx+0xffffffffdeffc324> .byte 255 // (bad) .byte 255 // (bad) .byte 255,211 // callq *%rbx .byte 255 // (bad) .byte 255 // (bad) .byte 255,196 // inc %esp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_g8_dst_avx .globl _sk_load_g8_dst_avx FUNCTION(_sk_load_g8_dst_avx) _sk_load_g8_dst_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 117,72 // jne 3e01 <_sk_load_g8_dst_avx+0x61> .byte 196,194,121,48,36,25 // vpmovzxbw (%r9,%rbx,1),%xmm4 .byte 197,217,219,37,217,67,0,0 // vpand 0x43d9(%rip),%xmm4,%xmm4 # 81a0 <_sk_callback_avx+0x730> .byte 197,209,239,237 // vpxor %xmm5,%xmm5,%xmm5 .byte 197,217,105,237 // vpunpckhwd %xmm5,%xmm4,%xmm5 .byte 196,226,121,51,228 // vpmovzxwd %xmm4,%xmm4 .byte 196,227,93,24,229,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,226,125,24,45,141,64,0,0 // vbroadcastss 0x408d(%rip),%ymm5 # 7e74 <_sk_callback_avx+0x404> .byte 197,220,89,229 // vmulps %ymm5,%ymm4,%ymm4 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,61,130,64,0,0 // vbroadcastss 0x4082(%rip),%ymm7 # 7e78 <_sk_callback_avx+0x408> .byte 197,252,40,236 // vmovaps %ymm4,%ymm5 .byte 197,252,40,244 // vmovaps %ymm4,%ymm6 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,170 // ja 3dbf <_sk_load_g8_dst_avx+0x1f> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,120,0,0,0 // lea 0x78(%rip),%r11 # 3e98 <_sk_load_g8_dst_avx+0xf8> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,182,4,25 // movzbl (%r9,%rbx,1),%eax .byte 197,249,110,224 // vmovd %eax,%xmm4 .byte 235,139 // jmp 3dbf <_sk_load_g8_dst_avx+0x1f> .byte 65,15,182,68,25,2 // movzbl 0x2(%r9,%rbx,1),%eax .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,217,196,224,2 // vpinsrw $0x2,%eax,%xmm4,%xmm4 .byte 65,15,183,4,25 // movzwl (%r9,%rbx,1),%eax .byte 197,249,110,232 // vmovd %eax,%xmm5 .byte 196,226,121,48,237 // vpmovzxbw %xmm5,%xmm5 .byte 196,227,89,14,229,3 // vpblendw $0x3,%xmm5,%xmm4,%xmm4 .byte 233,99,255,255,255 // jmpq 3dbf <_sk_load_g8_dst_avx+0x1f> .byte 65,15,182,68,25,6 // movzbl 0x6(%r9,%rbx,1),%eax .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,217,196,224,6 // vpinsrw $0x6,%eax,%xmm4,%xmm4 .byte 65,15,182,68,25,5 // movzbl 0x5(%r9,%rbx,1),%eax .byte 197,217,196,224,5 // vpinsrw $0x5,%eax,%xmm4,%xmm4 .byte 65,15,182,68,25,4 // movzbl 0x4(%r9,%rbx,1),%eax .byte 197,217,196,224,4 // vpinsrw $0x4,%eax,%xmm4,%xmm4 .byte 196,193,121,110,44,25 // vmovd (%r9,%rbx,1),%xmm5 .byte 196,226,121,48,237 // vpmovzxbw %xmm5,%xmm5 .byte 196,227,81,14,228,240 // vpblendw $0xf0,%xmm4,%xmm5,%xmm4 .byte 233,40,255,255,255 // jmpq 3dbf <_sk_load_g8_dst_avx+0x1f> .byte 144 // nop .byte 145 // xchg %eax,%ecx .byte 255 // (bad) .byte 255 // (bad) .byte 255,171,255,255,255,156 // ljmp *-0x63000001(%rbx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 233,255,255,255,222 // jmpq ffffffffdf003ea8 <_sk_callback_avx+0xffffffffdeffc438> .byte 255 // (bad) .byte 255 // (bad) .byte 255,211 // callq *%rbx .byte 255 // (bad) .byte 255 // (bad) .byte 255,196 // inc %esp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_gather_g8_avx .globl _sk_gather_g8_avx FUNCTION(_sk_gather_g8_avx) _sk_gather_g8_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 197,249,110,80,8 // vmovd 0x8(%rax),%xmm2 .byte 197,249,112,210,0 // vpshufd $0x0,%xmm2,%xmm2 .byte 196,226,105,64,217 // vpmulld %xmm1,%xmm2,%xmm3 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 196,226,105,64,201 // vpmulld %xmm1,%xmm2,%xmm1 .byte 197,254,91,208 // vcvttps2dq %ymm0,%ymm2 .byte 196,227,125,25,208,1 // vextractf128 $0x1,%ymm2,%xmm0 .byte 197,241,254,192 // vpaddd %xmm0,%xmm1,%xmm0 .byte 197,225,254,202 // vpaddd %xmm2,%xmm3,%xmm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,195,121,32,20,1,0 // vpinsrb $0x0,(%r9,%rax,1),%xmm0,%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,105,32,12,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm2,%xmm1 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,113,32,200,2 // vpinsrb $0x2,%eax,%xmm1,%xmm1 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 196,227,113,32,200,3 // vpinsrb $0x3,%eax,%xmm1,%xmm1 .byte 68,137,208 // mov %r10d,%eax .byte 196,195,121,32,20,1,0 // vpinsrb $0x0,(%r9,%rax,1),%xmm0,%xmm2 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,105,32,4,17,1 // vpinsrb $0x1,(%r9,%r10,1),%xmm2,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 196,227,121,32,192,2 // vpinsrb $0x2,%eax,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 196,226,121,49,201 // vpmovzxbd %xmm1,%xmm1 .byte 196,227,121,32,192,3 // vpinsrb $0x3,%eax,%xmm0,%xmm0 .byte 196,226,121,49,192 // vpmovzxbd %xmm0,%xmm0 .byte 196,227,117,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,252,62,0,0 // vbroadcastss 0x3efc(%rip),%ymm1 # 7e7c <_sk_callback_avx+0x40c> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,241,62,0,0 // vbroadcastss 0x3ef1(%rip),%ymm3 # 7e80 <_sk_callback_avx+0x410> .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_load_565_avx .globl _sk_load_565_avx FUNCTION(_sk_load_565_avx) _sk_load_565_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 15,133,129,0,0,0 // jne 403a <_sk_load_565_avx+0xa1> .byte 196,193,122,111,4,89 // vmovdqu (%r9,%rbx,2),%xmm0 .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,249,105,201 // vpunpckhwd %xmm1,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,209,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm2 .byte 196,226,125,24,5,169,62,0,0 // vbroadcastss 0x3ea9(%rip),%ymm0 # 7e84 <_sk_callback_avx+0x414> .byte 197,236,84,192 // vandps %ymm0,%ymm2,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,156,62,0,0 // vbroadcastss 0x3e9c(%rip),%ymm1 # 7e88 <_sk_callback_avx+0x418> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 196,226,125,24,13,147,62,0,0 // vbroadcastss 0x3e93(%rip),%ymm1 # 7e8c <_sk_callback_avx+0x41c> .byte 197,236,84,201 // vandps %ymm1,%ymm2,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,226,125,24,29,134,62,0,0 // vbroadcastss 0x3e86(%rip),%ymm3 # 7e90 <_sk_callback_avx+0x420> .byte 197,244,89,203 // vmulps %ymm3,%ymm1,%ymm1 .byte 196,226,125,24,29,125,62,0,0 // vbroadcastss 0x3e7d(%rip),%ymm3 # 7e94 <_sk_callback_avx+0x424> .byte 197,236,84,211 // vandps %ymm3,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,226,125,24,29,112,62,0,0 // vbroadcastss 0x3e70(%rip),%ymm3 # 7e98 <_sk_callback_avx+0x428> .byte 197,236,89,211 // vmulps %ymm3,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,101,62,0,0 // vbroadcastss 0x3e65(%rip),%ymm3 # 7e9c <_sk_callback_avx+0x42c> .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,109,255,255,255 // ja 3fbf <_sk_load_565_avx+0x26> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,99,0,0,0 // lea 0x63(%rip),%r11 # 40c0 <_sk_load_565_avx+0x127> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 233,75,255,255,255 // jmpq 3fbf <_sk_load_565_avx+0x26> .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 196,193,121,196,68,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,110,12,89 // vmovd (%r9,%rbx,2),%xmm1 .byte 196,227,121,14,193,3 // vpblendw $0x3,%xmm1,%xmm0,%xmm0 .byte 233,46,255,255,255 // jmpq 3fbf <_sk_load_565_avx+0x26> .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 196,193,121,196,68,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,196,68,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,196,68,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,122,126,12,89 // vmovq (%r9,%rbx,2),%xmm1 .byte 196,227,113,14,192,240 // vpblendw $0xf0,%xmm0,%xmm1,%xmm0 .byte 233,1,255,255,255 // jmpq 3fbf <_sk_load_565_avx+0x26> .byte 102,144 // xchg %ax,%ax .byte 166 // cmpsb %es:(%rdi),%ds:(%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,192 // inc %eax .byte 255 // (bad) .byte 255 // (bad) .byte 255,180,255,255,255,237,255 // pushq -0x120001(%rdi,%rdi,8) .byte 255 // (bad) .byte 255,229 // jmpq *%rbp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 221,255 // (bad) .byte 255 // (bad) .byte 255,209 // callq *%rcx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_565_dst_avx .globl _sk_load_565_dst_avx FUNCTION(_sk_load_565_dst_avx) _sk_load_565_dst_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 15,133,129,0,0,0 // jne 417d <_sk_load_565_dst_avx+0xa1> .byte 196,193,122,111,36,89 // vmovdqu (%r9,%rbx,2),%xmm4 .byte 197,209,239,237 // vpxor %xmm5,%xmm5,%xmm5 .byte 197,217,105,237 // vpunpckhwd %xmm5,%xmm4,%xmm5 .byte 196,226,121,51,228 // vpmovzxwd %xmm4,%xmm4 .byte 196,227,93,24,245,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm6 .byte 196,226,125,24,37,130,61,0,0 // vbroadcastss 0x3d82(%rip),%ymm4 # 7ea0 <_sk_callback_avx+0x430> .byte 197,204,84,228 // vandps %ymm4,%ymm6,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,226,125,24,45,117,61,0,0 // vbroadcastss 0x3d75(%rip),%ymm5 # 7ea4 <_sk_callback_avx+0x434> .byte 197,220,89,229 // vmulps %ymm5,%ymm4,%ymm4 .byte 196,226,125,24,45,108,61,0,0 // vbroadcastss 0x3d6c(%rip),%ymm5 # 7ea8 <_sk_callback_avx+0x438> .byte 197,204,84,237 // vandps %ymm5,%ymm6,%ymm5 .byte 197,252,91,237 // vcvtdq2ps %ymm5,%ymm5 .byte 196,226,125,24,61,95,61,0,0 // vbroadcastss 0x3d5f(%rip),%ymm7 # 7eac <_sk_callback_avx+0x43c> .byte 197,212,89,239 // vmulps %ymm7,%ymm5,%ymm5 .byte 196,226,125,24,61,86,61,0,0 // vbroadcastss 0x3d56(%rip),%ymm7 # 7eb0 <_sk_callback_avx+0x440> .byte 197,204,84,247 // vandps %ymm7,%ymm6,%ymm6 .byte 197,252,91,246 // vcvtdq2ps %ymm6,%ymm6 .byte 196,226,125,24,61,73,61,0,0 // vbroadcastss 0x3d49(%rip),%ymm7 # 7eb4 <_sk_callback_avx+0x444> .byte 197,204,89,247 // vmulps %ymm7,%ymm6,%ymm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,61,62,61,0,0 // vbroadcastss 0x3d3e(%rip),%ymm7 # 7eb8 <_sk_callback_avx+0x448> .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,109,255,255,255 // ja 4102 <_sk_load_565_dst_avx+0x26> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,100,0,0,0 // lea 0x64(%rip),%r11 # 4204 <_sk_load_565_dst_avx+0x128> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,249,110,224 // vmovd %eax,%xmm4 .byte 233,75,255,255,255 // jmpq 4102 <_sk_load_565_dst_avx+0x26> .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 196,193,89,196,100,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,121,110,44,89 // vmovd (%r9,%rbx,2),%xmm5 .byte 196,227,89,14,229,3 // vpblendw $0x3,%xmm5,%xmm4,%xmm4 .byte 233,46,255,255,255 // jmpq 4102 <_sk_load_565_dst_avx+0x26> .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 196,193,89,196,100,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,89,196,100,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,89,196,100,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,122,126,44,89 // vmovq (%r9,%rbx,2),%xmm5 .byte 196,227,81,14,228,240 // vpblendw $0xf0,%xmm4,%xmm5,%xmm4 .byte 233,1,255,255,255 // jmpq 4102 <_sk_load_565_dst_avx+0x26> .byte 15,31,0 // nopl (%rax) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 191,255,255,255,179 // mov $0xb3ffffff,%edi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 236 // in (%dx),%al .byte 255 // (bad) .byte 255 // (bad) .byte 255,228 // jmpq *%rsp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 220,255 // fdivr %st,%st(7) .byte 255 // (bad) .byte 255,208 // callq *%rax .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_gather_565_avx .globl _sk_gather_565_avx FUNCTION(_sk_gather_565_avx) _sk_gather_565_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 197,249,110,80,8 // vmovd 0x8(%rax),%xmm2 .byte 197,249,112,210,0 // vpshufd $0x0,%xmm2,%xmm2 .byte 196,226,105,64,217 // vpmulld %xmm1,%xmm2,%xmm3 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 196,226,105,64,201 // vpmulld %xmm1,%xmm2,%xmm1 .byte 197,254,91,208 // vcvttps2dq %ymm0,%ymm2 .byte 196,227,125,25,208,1 // vextractf128 $0x1,%ymm2,%xmm0 .byte 197,241,254,192 // vpaddd %xmm0,%xmm1,%xmm0 .byte 197,225,254,202 // vpaddd %xmm2,%xmm3,%xmm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,183,4,81 // movzwl (%r9,%r10,2),%eax .byte 197,233,196,200,1 // vpinsrw $0x1,%eax,%xmm2,%xmm1 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,241,196,200,2 // vpinsrw $0x2,%eax,%xmm1,%xmm1 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 197,241,196,200,3 // vpinsrw $0x3,%eax,%xmm1,%xmm1 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,241,196,200,4 // vpinsrw $0x4,%eax,%xmm1,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,183,4,81 // movzwl (%r9,%r10,2),%eax .byte 197,241,196,192,5 // vpinsrw $0x5,%eax,%xmm1,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 197,249,196,192,7 // vpinsrw $0x7,%eax,%xmm0,%xmm0 .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,249,105,201 // vpunpckhwd %xmm1,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,209,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm2 .byte 196,226,125,24,5,202,59,0,0 // vbroadcastss 0x3bca(%rip),%ymm0 # 7ebc <_sk_callback_avx+0x44c> .byte 197,236,84,192 // vandps %ymm0,%ymm2,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,189,59,0,0 // vbroadcastss 0x3bbd(%rip),%ymm1 # 7ec0 <_sk_callback_avx+0x450> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 196,226,125,24,13,180,59,0,0 // vbroadcastss 0x3bb4(%rip),%ymm1 # 7ec4 <_sk_callback_avx+0x454> .byte 197,236,84,201 // vandps %ymm1,%ymm2,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,226,125,24,29,167,59,0,0 // vbroadcastss 0x3ba7(%rip),%ymm3 # 7ec8 <_sk_callback_avx+0x458> .byte 197,244,89,203 // vmulps %ymm3,%ymm1,%ymm1 .byte 196,226,125,24,29,158,59,0,0 // vbroadcastss 0x3b9e(%rip),%ymm3 # 7ecc <_sk_callback_avx+0x45c> .byte 197,236,84,211 // vandps %ymm3,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,226,125,24,29,145,59,0,0 // vbroadcastss 0x3b91(%rip),%ymm3 # 7ed0 <_sk_callback_avx+0x460> .byte 197,236,89,211 // vmulps %ymm3,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,134,59,0,0 // vbroadcastss 0x3b86(%rip),%ymm3 # 7ed4 <_sk_callback_avx+0x464> .byte 255,224 // jmpq *%rax HIDDEN _sk_store_565_avx .globl _sk_store_565_avx FUNCTION(_sk_store_565_avx) _sk_store_565_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 196,98,125,24,5,104,59,0,0 // vbroadcastss 0x3b68(%rip),%ymm8 # 7ed8 <_sk_callback_avx+0x468> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,193,41,114,241,11 // vpslld $0xb,%xmm9,%xmm10 .byte 196,67,125,25,201,1 // vextractf128 $0x1,%ymm9,%xmm9 .byte 196,193,49,114,241,11 // vpslld $0xb,%xmm9,%xmm9 .byte 196,67,45,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm9 .byte 196,98,125,24,21,65,59,0,0 // vbroadcastss 0x3b41(%rip),%ymm10 # 7edc <_sk_callback_avx+0x46c> .byte 196,65,116,89,210 // vmulps %ymm10,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,33,114,242,5 // vpslld $0x5,%xmm10,%xmm11 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,242,5 // vpslld $0x5,%xmm10,%xmm10 .byte 196,67,37,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 .byte 196,65,45,86,201 // vorpd %ymm9,%ymm10,%ymm9 .byte 196,65,108,89,192 // vmulps %ymm8,%ymm2,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,65,53,86,192 // vorpd %ymm8,%ymm9,%ymm8 .byte 196,67,125,25,193,1 // vextractf128 $0x1,%ymm8,%xmm9 .byte 196,66,57,43,193 // vpackusdw %xmm9,%xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 43ec <_sk_store_565_avx+0x9c> .byte 196,65,122,127,4,89 // vmovdqu %xmm8,(%r9,%rbx,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,235 // ja 43e7 <_sk_store_565_avx+0x97> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,69,0,0,0 // lea 0x45(%rip),%r11 # 444c <_sk_store_565_avx+0xfc> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,67,121,21,4,89,0 // vpextrw $0x0,%xmm8,(%r9,%rbx,2) .byte 235,206 // jmp 43e7 <_sk_store_565_avx+0x97> .byte 196,67,121,21,68,89,4,2 // vpextrw $0x2,%xmm8,0x4(%r9,%rbx,2) .byte 196,65,121,126,4,89 // vmovd %xmm8,(%r9,%rbx,2) .byte 235,190 // jmp 43e7 <_sk_store_565_avx+0x97> .byte 196,67,121,21,68,89,12,6 // vpextrw $0x6,%xmm8,0xc(%r9,%rbx,2) .byte 196,67,121,21,68,89,10,5 // vpextrw $0x5,%xmm8,0xa(%r9,%rbx,2) .byte 196,67,121,21,68,89,8,4 // vpextrw $0x4,%xmm8,0x8(%r9,%rbx,2) .byte 196,65,121,214,4,89 // vmovq %xmm8,(%r9,%rbx,2) .byte 235,158 // jmp 43e7 <_sk_store_565_avx+0x97> .byte 15,31,0 // nopl (%rax) .byte 196 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,213 // callq *%rbp .byte 255 // (bad) .byte 255 // (bad) .byte 255,205 // dec %ebp .byte 255 // (bad) .byte 255 // (bad) .byte 255,245 // push %rbp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 237 // in (%dx),%eax .byte 255 // (bad) .byte 255 // (bad) .byte 255,229 // jmpq *%rbp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 221,255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_4444_avx .globl _sk_load_4444_avx FUNCTION(_sk_load_4444_avx) _sk_load_4444_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 15,133,153,0,0,0 // jne 4521 <_sk_load_4444_avx+0xb9> .byte 196,193,122,111,4,89 // vmovdqu (%r9,%rbx,2),%xmm0 .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,249,105,201 // vpunpckhwd %xmm1,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,217,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm3 .byte 196,226,125,24,5,54,58,0,0 // vbroadcastss 0x3a36(%rip),%ymm0 # 7ee0 <_sk_callback_avx+0x470> .byte 197,228,84,192 // vandps %ymm0,%ymm3,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,41,58,0,0 // vbroadcastss 0x3a29(%rip),%ymm1 # 7ee4 <_sk_callback_avx+0x474> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 196,226,125,24,13,32,58,0,0 // vbroadcastss 0x3a20(%rip),%ymm1 # 7ee8 <_sk_callback_avx+0x478> .byte 197,228,84,201 // vandps %ymm1,%ymm3,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,226,125,24,21,19,58,0,0 // vbroadcastss 0x3a13(%rip),%ymm2 # 7eec <_sk_callback_avx+0x47c> .byte 197,244,89,202 // vmulps %ymm2,%ymm1,%ymm1 .byte 196,226,125,24,21,10,58,0,0 // vbroadcastss 0x3a0a(%rip),%ymm2 # 7ef0 <_sk_callback_avx+0x480> .byte 197,228,84,210 // vandps %ymm2,%ymm3,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,98,125,24,5,253,57,0,0 // vbroadcastss 0x39fd(%rip),%ymm8 # 7ef4 <_sk_callback_avx+0x484> .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 196,98,125,24,5,243,57,0,0 // vbroadcastss 0x39f3(%rip),%ymm8 # 7ef8 <_sk_callback_avx+0x488> .byte 196,193,100,84,216 // vandps %ymm8,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,98,125,24,5,229,57,0,0 // vbroadcastss 0x39e5(%rip),%ymm8 # 7efc <_sk_callback_avx+0x48c> .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,85,255,255,255 // ja 448e <_sk_load_4444_avx+0x26> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,100,0,0,0 // lea 0x64(%rip),%r11 # 45a8 <_sk_load_4444_avx+0x140> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 233,51,255,255,255 // jmpq 448e <_sk_load_4444_avx+0x26> .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 196,193,121,196,68,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,110,12,89 // vmovd (%r9,%rbx,2),%xmm1 .byte 196,227,121,14,193,3 // vpblendw $0x3,%xmm1,%xmm0,%xmm0 .byte 233,22,255,255,255 // jmpq 448e <_sk_load_4444_avx+0x26> .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 196,193,121,196,68,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,196,68,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,121,196,68,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm0,%xmm0 .byte 196,193,122,126,12,89 // vmovq (%r9,%rbx,2),%xmm1 .byte 196,227,113,14,192,240 // vpblendw $0xf0,%xmm0,%xmm1,%xmm0 .byte 233,233,254,255,255 // jmpq 448e <_sk_load_4444_avx+0x26> .byte 15,31,0 // nopl (%rax) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 191,255,255,255,179 // mov $0xb3ffffff,%edi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 236 // in (%dx),%al .byte 255 // (bad) .byte 255 // (bad) .byte 255,228 // jmpq *%rsp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 220,255 // fdivr %st,%st(7) .byte 255 // (bad) .byte 255,208 // callq *%rax .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_4444_dst_avx .globl _sk_load_4444_dst_avx FUNCTION(_sk_load_4444_dst_avx) _sk_load_4444_dst_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 77,133,192 // test %r8,%r8 .byte 15,133,153,0,0,0 // jne 467d <_sk_load_4444_dst_avx+0xb9> .byte 196,193,122,111,36,89 // vmovdqu (%r9,%rbx,2),%xmm4 .byte 197,209,239,237 // vpxor %xmm5,%xmm5,%xmm5 .byte 197,217,105,237 // vpunpckhwd %xmm5,%xmm4,%xmm5 .byte 196,226,121,51,228 // vpmovzxwd %xmm4,%xmm4 .byte 196,227,93,24,253,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm7 .byte 196,226,125,24,37,250,56,0,0 // vbroadcastss 0x38fa(%rip),%ymm4 # 7f00 <_sk_callback_avx+0x490> .byte 197,196,84,228 // vandps %ymm4,%ymm7,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,226,125,24,45,237,56,0,0 // vbroadcastss 0x38ed(%rip),%ymm5 # 7f04 <_sk_callback_avx+0x494> .byte 197,220,89,229 // vmulps %ymm5,%ymm4,%ymm4 .byte 196,226,125,24,45,228,56,0,0 // vbroadcastss 0x38e4(%rip),%ymm5 # 7f08 <_sk_callback_avx+0x498> .byte 197,196,84,237 // vandps %ymm5,%ymm7,%ymm5 .byte 197,252,91,237 // vcvtdq2ps %ymm5,%ymm5 .byte 196,226,125,24,53,215,56,0,0 // vbroadcastss 0x38d7(%rip),%ymm6 # 7f0c <_sk_callback_avx+0x49c> .byte 197,212,89,238 // vmulps %ymm6,%ymm5,%ymm5 .byte 196,226,125,24,53,206,56,0,0 // vbroadcastss 0x38ce(%rip),%ymm6 # 7f10 <_sk_callback_avx+0x4a0> .byte 197,196,84,246 // vandps %ymm6,%ymm7,%ymm6 .byte 197,252,91,246 // vcvtdq2ps %ymm6,%ymm6 .byte 196,98,125,24,5,193,56,0,0 // vbroadcastss 0x38c1(%rip),%ymm8 # 7f14 <_sk_callback_avx+0x4a4> .byte 196,193,76,89,240 // vmulps %ymm8,%ymm6,%ymm6 .byte 196,98,125,24,5,183,56,0,0 // vbroadcastss 0x38b7(%rip),%ymm8 # 7f18 <_sk_callback_avx+0x4a8> .byte 196,193,68,84,248 // vandps %ymm8,%ymm7,%ymm7 .byte 197,252,91,255 // vcvtdq2ps %ymm7,%ymm7 .byte 196,98,125,24,5,169,56,0,0 // vbroadcastss 0x38a9(%rip),%ymm8 # 7f1c <_sk_callback_avx+0x4ac> .byte 196,193,68,89,248 // vmulps %ymm8,%ymm7,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 15,135,85,255,255,255 // ja 45ea <_sk_load_4444_dst_avx+0x26> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,100,0,0,0 // lea 0x64(%rip),%r11 # 4704 <_sk_load_4444_dst_avx+0x140> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 65,15,183,4,89 // movzwl (%r9,%rbx,2),%eax .byte 197,249,110,224 // vmovd %eax,%xmm4 .byte 233,51,255,255,255 // jmpq 45ea <_sk_load_4444_dst_avx+0x26> .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 196,193,89,196,100,89,4,2 // vpinsrw $0x2,0x4(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,121,110,44,89 // vmovd (%r9,%rbx,2),%xmm5 .byte 196,227,89,14,229,3 // vpblendw $0x3,%xmm5,%xmm4,%xmm4 .byte 233,22,255,255,255 // jmpq 45ea <_sk_load_4444_dst_avx+0x26> .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 196,193,89,196,100,89,12,6 // vpinsrw $0x6,0xc(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,89,196,100,89,10,5 // vpinsrw $0x5,0xa(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,89,196,100,89,8,4 // vpinsrw $0x4,0x8(%r9,%rbx,2),%xmm4,%xmm4 .byte 196,193,122,126,44,89 // vmovq (%r9,%rbx,2),%xmm5 .byte 196,227,81,14,228,240 // vpblendw $0xf0,%xmm4,%xmm5,%xmm4 .byte 233,233,254,255,255 // jmpq 45ea <_sk_load_4444_dst_avx+0x26> .byte 15,31,0 // nopl (%rax) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 191,255,255,255,179 // mov $0xb3ffffff,%edi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 236 // in (%dx),%al .byte 255 // (bad) .byte 255 // (bad) .byte 255,228 // jmpq *%rsp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 220,255 // fdivr %st,%st(7) .byte 255 // (bad) .byte 255,208 // callq *%rax .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_gather_4444_avx .globl _sk_gather_4444_avx FUNCTION(_sk_gather_4444_avx) _sk_gather_4444_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 197,249,110,80,8 // vmovd 0x8(%rax),%xmm2 .byte 197,249,112,210,0 // vpshufd $0x0,%xmm2,%xmm2 .byte 196,226,105,64,217 // vpmulld %xmm1,%xmm2,%xmm3 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 196,226,105,64,201 // vpmulld %xmm1,%xmm2,%xmm1 .byte 197,254,91,208 // vcvttps2dq %ymm0,%ymm2 .byte 196,227,125,25,208,1 // vextractf128 $0x1,%ymm2,%xmm0 .byte 197,241,254,192 // vpaddd %xmm0,%xmm1,%xmm0 .byte 197,225,254,202 // vpaddd %xmm2,%xmm3,%xmm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,183,4,81 // movzwl (%r9,%r10,2),%eax .byte 197,233,196,200,1 // vpinsrw $0x1,%eax,%xmm2,%xmm1 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,241,196,200,2 // vpinsrw $0x2,%eax,%xmm1,%xmm1 .byte 196,193,249,126,194 // vmovq %xmm0,%r10 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 197,241,196,200,3 // vpinsrw $0x3,%eax,%xmm1,%xmm1 .byte 68,137,208 // mov %r10d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,241,196,200,4 // vpinsrw $0x4,%eax,%xmm1,%xmm1 .byte 196,195,249,22,195,1 // vpextrq $0x1,%xmm0,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 67,15,183,4,81 // movzwl (%r9,%r10,2),%eax .byte 197,241,196,192,5 // vpinsrw $0x5,%eax,%xmm1,%xmm0 .byte 68,137,216 // mov %r11d,%eax .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 73,193,235,32 // shr $0x20,%r11 .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 197,249,196,192,7 // vpinsrw $0x7,%eax,%xmm0,%xmm0 .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,249,105,201 // vpunpckhwd %xmm1,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,217,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm3 .byte 196,226,125,24,5,46,55,0,0 // vbroadcastss 0x372e(%rip),%ymm0 # 7f20 <_sk_callback_avx+0x4b0> .byte 197,228,84,192 // vandps %ymm0,%ymm3,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,226,125,24,13,33,55,0,0 // vbroadcastss 0x3721(%rip),%ymm1 # 7f24 <_sk_callback_avx+0x4b4> .byte 197,252,89,193 // vmulps %ymm1,%ymm0,%ymm0 .byte 196,226,125,24,13,24,55,0,0 // vbroadcastss 0x3718(%rip),%ymm1 # 7f28 <_sk_callback_avx+0x4b8> .byte 197,228,84,201 // vandps %ymm1,%ymm3,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,226,125,24,21,11,55,0,0 // vbroadcastss 0x370b(%rip),%ymm2 # 7f2c <_sk_callback_avx+0x4bc> .byte 197,244,89,202 // vmulps %ymm2,%ymm1,%ymm1 .byte 196,226,125,24,21,2,55,0,0 // vbroadcastss 0x3702(%rip),%ymm2 # 7f30 <_sk_callback_avx+0x4c0> .byte 197,228,84,210 // vandps %ymm2,%ymm3,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,98,125,24,5,245,54,0,0 // vbroadcastss 0x36f5(%rip),%ymm8 # 7f34 <_sk_callback_avx+0x4c4> .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 196,98,125,24,5,235,54,0,0 // vbroadcastss 0x36eb(%rip),%ymm8 # 7f38 <_sk_callback_avx+0x4c8> .byte 196,193,100,84,216 // vandps %ymm8,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,98,125,24,5,221,54,0,0 // vbroadcastss 0x36dd(%rip),%ymm8 # 7f3c <_sk_callback_avx+0x4cc> .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_4444_avx .globl _sk_store_4444_avx FUNCTION(_sk_store_4444_avx) _sk_store_4444_avx: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,218 // movslq %edx,%rbx .byte 196,98,125,24,5,184,54,0,0 // vbroadcastss 0x36b8(%rip),%ymm8 # 7f40 <_sk_callback_avx+0x4d0> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,193,41,114,241,12 // vpslld $0xc,%xmm9,%xmm10 .byte 196,67,125,25,201,1 // vextractf128 $0x1,%ymm9,%xmm9 .byte 196,193,49,114,241,12 // vpslld $0xc,%xmm9,%xmm9 .byte 196,67,45,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,33,114,242,8 // vpslld $0x8,%xmm10,%xmm11 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,242,8 // vpslld $0x8,%xmm10,%xmm10 .byte 196,67,37,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 .byte 196,65,45,86,201 // vorpd %ymm9,%ymm10,%ymm9 .byte 196,65,108,89,208 // vmulps %ymm8,%ymm2,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,33,114,242,4 // vpslld $0x4,%xmm10,%xmm11 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,242,4 // vpslld $0x4,%xmm10,%xmm10 .byte 196,67,37,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,65,45,86,192 // vorpd %ymm8,%ymm10,%ymm8 .byte 196,65,53,86,192 // vorpd %ymm8,%ymm9,%ymm8 .byte 196,67,125,25,193,1 // vextractf128 $0x1,%ymm8,%xmm9 .byte 196,66,57,43,193 // vpackusdw %xmm9,%xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 4922 <_sk_store_4444_avx+0xba> .byte 196,65,122,127,4,89 // vmovdqu %xmm8,(%r9,%rbx,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,7 // and $0x7,%r10b .byte 65,254,202 // dec %r10b .byte 65,128,250,6 // cmp $0x6,%r10b .byte 119,235 // ja 491d <_sk_store_4444_avx+0xb5> .byte 69,15,182,210 // movzbl %r10b,%r10d .byte 76,141,29,67,0,0,0 // lea 0x43(%rip),%r11 # 4980 <_sk_store_4444_avx+0x118> .byte 75,99,4,147 // movslq (%r11,%r10,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,67,121,21,4,89,0 // vpextrw $0x0,%xmm8,(%r9,%rbx,2) .byte 235,206 // jmp 491d <_sk_store_4444_avx+0xb5> .byte 196,67,121,21,68,89,4,2 // vpextrw $0x2,%xmm8,0x4(%r9,%rbx,2) .byte 196,65,121,126,4,89 // vmovd %xmm8,(%r9,%rbx,2) .byte 235,190 // jmp 491d <_sk_store_4444_avx+0xb5> .byte 196,67,121,21,68,89,12,6 // vpextrw $0x6,%xmm8,0xc(%r9,%rbx,2) .byte 196,67,121,21,68,89,10,5 // vpextrw $0x5,%xmm8,0xa(%r9,%rbx,2) .byte 196,67,121,21,68,89,8,4 // vpextrw $0x4,%xmm8,0x8(%r9,%rbx,2) .byte 196,65,121,214,4,89 // vmovq %xmm8,(%r9,%rbx,2) .byte 235,158 // jmp 491d <_sk_store_4444_avx+0xb5> .byte 144 // nop .byte 198 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,215 // callq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255,207 // dec %edi .byte 255 // (bad) .byte 255 // (bad) .byte 255,247 // push %rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 239 // out %eax,(%dx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,231 // jmpq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 223,255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_8888_avx .globl _sk_load_8888_avx FUNCTION(_sk_load_8888_avx) _sk_load_8888_avx: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,136,0,0,0 // jne 4a4b <_sk_load_8888_avx+0xaf> .byte 197,252,16,24 // vmovups (%rax),%ymm3 .byte 197,124,40,21,241,56,0,0 // vmovaps 0x38f1(%rip),%ymm10 # 82c0 <_sk_callback_avx+0x850> .byte 196,193,100,84,194 // vandps %ymm10,%ymm3,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,5,99,53,0,0 // vbroadcastss 0x3563(%rip),%ymm8 # 7f44 <_sk_callback_avx+0x4d4> .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,241,114,211,8 // vpsrld $0x8,%xmm3,%xmm1 .byte 196,195,125,25,217,1 // vextractf128 $0x1,%ymm3,%xmm9 .byte 196,193,105,114,209,8 // vpsrld $0x8,%xmm9,%xmm2 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 196,193,116,84,202 // vandps %ymm10,%ymm1,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 197,161,114,211,16 // vpsrld $0x10,%xmm3,%xmm11 .byte 196,193,105,114,209,16 // vpsrld $0x10,%xmm9,%xmm2 .byte 196,227,37,24,210,1 // vinsertf128 $0x1,%xmm2,%ymm11,%ymm2 .byte 196,193,108,84,210 // vandps %ymm10,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,208 // vmulps %ymm8,%ymm2,%ymm2 .byte 197,169,114,211,24 // vpsrld $0x18,%xmm3,%xmm10 .byte 196,193,97,114,209,24 // vpsrld $0x18,%xmm9,%xmm3 .byte 196,227,45,24,219,1 // vinsertf128 $0x1,%xmm3,%ymm10,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,194 // vmovq %r10,%xmm0 .byte 196,226,121,48,192 // vpmovzxbw %xmm0,%xmm0 .byte 196,226,121,0,13,61,55,0,0 // vpshufb 0x373d(%rip),%xmm0,%xmm1 # 81b0 <_sk_callback_avx+0x740> .byte 196,226,121,33,201 // vpmovsxbd %xmm1,%xmm1 .byte 196,226,121,0,5,63,55,0,0 // vpshufb 0x373f(%rip),%xmm0,%xmm0 # 81c0 <_sk_callback_avx+0x750> .byte 196,226,121,33,192 // vpmovsxbd %xmm0,%xmm0 .byte 196,227,117,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 .byte 196,226,125,44,24 // vmaskmovps (%rax),%ymm0,%ymm3 .byte 233,49,255,255,255 // jmpq 49c7 <_sk_load_8888_avx+0x2b> HIDDEN _sk_load_8888_dst_avx .globl _sk_load_8888_dst_avx FUNCTION(_sk_load_8888_dst_avx) _sk_load_8888_dst_avx: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,136,0,0,0 // jne 4b45 <_sk_load_8888_dst_avx+0xaf> .byte 197,252,16,56 // vmovups (%rax),%ymm7 .byte 197,124,40,21,23,56,0,0 // vmovaps 0x3817(%rip),%ymm10 # 82e0 <_sk_callback_avx+0x870> .byte 196,193,68,84,226 // vandps %ymm10,%ymm7,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,98,125,24,5,109,52,0,0 // vbroadcastss 0x346d(%rip),%ymm8 # 7f48 <_sk_callback_avx+0x4d8> .byte 196,193,92,89,224 // vmulps %ymm8,%ymm4,%ymm4 .byte 197,209,114,215,8 // vpsrld $0x8,%xmm7,%xmm5 .byte 196,195,125,25,249,1 // vextractf128 $0x1,%ymm7,%xmm9 .byte 196,193,73,114,209,8 // vpsrld $0x8,%xmm9,%xmm6 .byte 196,227,85,24,238,1 // vinsertf128 $0x1,%xmm6,%ymm5,%ymm5 .byte 196,193,84,84,234 // vandps %ymm10,%ymm5,%ymm5 .byte 197,252,91,237 // vcvtdq2ps %ymm5,%ymm5 .byte 196,193,84,89,232 // vmulps %ymm8,%ymm5,%ymm5 .byte 197,161,114,215,16 // vpsrld $0x10,%xmm7,%xmm11 .byte 196,193,73,114,209,16 // vpsrld $0x10,%xmm9,%xmm6 .byte 196,227,37,24,246,1 // vinsertf128 $0x1,%xmm6,%ymm11,%ymm6 .byte 196,193,76,84,242 // vandps %ymm10,%ymm6,%ymm6 .byte 197,252,91,246 // vcvtdq2ps %ymm6,%ymm6 .byte 196,193,76,89,240 // vmulps %ymm8,%ymm6,%ymm6 .byte 197,169,114,215,24 // vpsrld $0x18,%xmm7,%xmm10 .byte 196,193,65,114,209,24 // vpsrld $0x18,%xmm9,%xmm7 .byte 196,227,45,24,255,1 // vinsertf128 $0x1,%xmm7,%ymm10,%ymm7 .byte 197,252,91,255 // vcvtdq2ps %ymm7,%ymm7 .byte 196,193,68,89,248 // vmulps %ymm8,%ymm7,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,226 // vmovq %r10,%xmm4 .byte 196,226,121,48,228 // vpmovzxbw %xmm4,%xmm4 .byte 196,226,89,0,45,99,54,0,0 // vpshufb 0x3663(%rip),%xmm4,%xmm5 # 81d0 <_sk_callback_avx+0x760> .byte 196,226,121,33,237 // vpmovsxbd %xmm5,%xmm5 .byte 196,226,89,0,37,101,54,0,0 // vpshufb 0x3665(%rip),%xmm4,%xmm4 # 81e0 <_sk_callback_avx+0x770> .byte 196,226,121,33,228 // vpmovsxbd %xmm4,%xmm4 .byte 196,227,85,24,228,1 // vinsertf128 $0x1,%xmm4,%ymm5,%ymm4 .byte 196,226,93,44,56 // vmaskmovps (%rax),%ymm4,%ymm7 .byte 233,49,255,255,255 // jmpq 4ac1 <_sk_load_8888_dst_avx+0x2b> HIDDEN _sk_gather_8888_avx .globl _sk_gather_8888_avx FUNCTION(_sk_gather_8888_avx) _sk_gather_8888_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 197,249,110,80,8 // vmovd 0x8(%rax),%xmm2 .byte 197,249,112,210,0 // vpshufd $0x0,%xmm2,%xmm2 .byte 196,226,105,64,217 // vpmulld %xmm1,%xmm2,%xmm3 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 196,226,105,64,201 // vpmulld %xmm1,%xmm2,%xmm1 .byte 197,254,91,208 // vcvttps2dq %ymm0,%ymm2 .byte 196,227,125,25,208,1 // vextractf128 $0x1,%ymm2,%xmm0 .byte 197,241,254,192 // vpaddd %xmm0,%xmm1,%xmm0 .byte 197,225,254,202 // vpaddd %xmm2,%xmm3,%xmm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,193,121,110,20,129 // vmovd (%r9,%rax,4),%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,105,34,12,145,1 // vpinsrd $0x1,(%r9,%r10,4),%xmm2,%xmm1 .byte 68,137,216 // mov %r11d,%eax .byte 196,195,113,34,12,129,2 // vpinsrd $0x2,(%r9,%rax,4),%xmm1,%xmm1 .byte 196,225,249,126,192 // vmovq %xmm0,%rax .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,3,113,34,4,153,3 // vpinsrd $0x3,(%r9,%r11,4),%xmm1,%xmm8 .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,129,121,110,12,145 // vmovd (%r9,%r10,4),%xmm1 .byte 196,195,249,22,194,1 // vpextrq $0x1,%xmm0,%r10 .byte 196,195,113,34,4,129,1 // vpinsrd $0x1,(%r9,%rax,4),%xmm1,%xmm0 .byte 68,137,208 // mov %r10d,%eax .byte 196,195,121,34,4,129,2 // vpinsrd $0x2,(%r9,%rax,4),%xmm0,%xmm0 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,121,34,28,145,3 // vpinsrd $0x3,(%r9,%r10,4),%xmm0,%xmm3 .byte 196,227,61,24,195,1 // vinsertf128 $0x1,%xmm3,%ymm8,%ymm0 .byte 197,124,40,21,197,54,0,0 // vmovaps 0x36c5(%rip),%ymm10 # 8300 <_sk_callback_avx+0x890> .byte 196,193,124,84,194 // vandps %ymm10,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,13,255,50,0,0 // vbroadcastss 0x32ff(%rip),%ymm9 # 7f4c <_sk_callback_avx+0x4dc> .byte 196,193,124,89,193 // vmulps %ymm9,%ymm0,%ymm0 .byte 196,193,113,114,208,8 // vpsrld $0x8,%xmm8,%xmm1 .byte 197,233,114,211,8 // vpsrld $0x8,%xmm3,%xmm2 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 196,193,116,84,202 // vandps %ymm10,%ymm1,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,201 // vmulps %ymm9,%ymm1,%ymm1 .byte 196,193,33,114,208,16 // vpsrld $0x10,%xmm8,%xmm11 .byte 197,233,114,211,16 // vpsrld $0x10,%xmm3,%xmm2 .byte 196,227,37,24,210,1 // vinsertf128 $0x1,%xmm2,%ymm11,%ymm2 .byte 196,193,108,84,210 // vandps %ymm10,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,209 // vmulps %ymm9,%ymm2,%ymm2 .byte 196,193,57,114,208,24 // vpsrld $0x18,%xmm8,%xmm8 .byte 197,225,114,211,24 // vpsrld $0x18,%xmm3,%xmm3 .byte 196,227,61,24,219,1 // vinsertf128 $0x1,%xmm3,%ymm8,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,217 // vmulps %ymm9,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_8888_avx .globl _sk_store_8888_avx FUNCTION(_sk_store_8888_avx) _sk_store_8888_avx: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 196,98,125,24,5,123,50,0,0 // vbroadcastss 0x327b(%rip),%ymm8 # 7f50 <_sk_callback_avx+0x4e0> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,33,114,242,8 // vpslld $0x8,%xmm10,%xmm11 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,242,8 // vpslld $0x8,%xmm10,%xmm10 .byte 196,67,37,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 .byte 196,65,45,86,201 // vorpd %ymm9,%ymm10,%ymm9 .byte 196,65,108,89,208 // vmulps %ymm8,%ymm2,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,33,114,242,16 // vpslld $0x10,%xmm10,%xmm11 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,242,16 // vpslld $0x10,%xmm10,%xmm10 .byte 196,67,37,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,193,33,114,240,24 // vpslld $0x18,%xmm8,%xmm11 .byte 196,67,125,25,192,1 // vextractf128 $0x1,%ymm8,%xmm8 .byte 196,193,57,114,240,24 // vpslld $0x18,%xmm8,%xmm8 .byte 196,67,37,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm11,%ymm8 .byte 196,65,45,86,192 // vorpd %ymm8,%ymm10,%ymm8 .byte 196,65,53,86,192 // vorpd %ymm8,%ymm9,%ymm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 4d64 <_sk_store_8888_avx+0xb6> .byte 197,124,17,0 // vmovups %ymm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,65,249,110,202 // vmovq %r10,%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,98,49,0,21,100,52,0,0 // vpshufb 0x3464(%rip),%xmm9,%xmm10 # 81f0 <_sk_callback_avx+0x780> .byte 196,66,121,33,210 // vpmovsxbd %xmm10,%xmm10 .byte 196,98,49,0,13,102,52,0,0 // vpshufb 0x3466(%rip),%xmm9,%xmm9 # 8200 <_sk_callback_avx+0x790> .byte 196,66,121,33,201 // vpmovsxbd %xmm9,%xmm9 .byte 196,67,45,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm9 .byte 196,98,53,46,0 // vmaskmovps %ymm8,%ymm9,(%rax) .byte 235,177 // jmp 4d5d <_sk_store_8888_avx+0xaf> HIDDEN _sk_load_bgra_avx .globl _sk_load_bgra_avx FUNCTION(_sk_load_bgra_avx) _sk_load_bgra_avx: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,136,0,0,0 // jne 4e5b <_sk_load_bgra_avx+0xaf> .byte 197,252,16,24 // vmovups (%rax),%ymm3 .byte 197,124,40,21,65,53,0,0 // vmovaps 0x3541(%rip),%ymm10 # 8320 <_sk_callback_avx+0x8b0> .byte 196,193,100,84,202 // vandps %ymm10,%ymm3,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,98,125,24,5,99,49,0,0 // vbroadcastss 0x3163(%rip),%ymm8 # 7f54 <_sk_callback_avx+0x4e4> .byte 196,193,116,89,208 // vmulps %ymm8,%ymm1,%ymm2 .byte 197,241,114,211,8 // vpsrld $0x8,%xmm3,%xmm1 .byte 196,195,125,25,217,1 // vextractf128 $0x1,%ymm3,%xmm9 .byte 196,193,121,114,209,8 // vpsrld $0x8,%xmm9,%xmm0 .byte 196,227,117,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 .byte 196,193,124,84,194 // vandps %ymm10,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,193,124,89,200 // vmulps %ymm8,%ymm0,%ymm1 .byte 197,161,114,211,16 // vpsrld $0x10,%xmm3,%xmm11 .byte 196,193,121,114,209,16 // vpsrld $0x10,%xmm9,%xmm0 .byte 196,227,37,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm11,%ymm0 .byte 196,193,124,84,194 // vandps %ymm10,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,169,114,211,24 // vpsrld $0x18,%xmm3,%xmm10 .byte 196,193,97,114,209,24 // vpsrld $0x18,%xmm9,%xmm3 .byte 196,227,45,24,219,1 // vinsertf128 $0x1,%xmm3,%ymm10,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,194 // vmovq %r10,%xmm0 .byte 196,226,121,48,192 // vpmovzxbw %xmm0,%xmm0 .byte 196,226,121,0,13,141,51,0,0 // vpshufb 0x338d(%rip),%xmm0,%xmm1 # 8210 <_sk_callback_avx+0x7a0> .byte 196,226,121,33,201 // vpmovsxbd %xmm1,%xmm1 .byte 196,226,121,0,5,143,51,0,0 // vpshufb 0x338f(%rip),%xmm0,%xmm0 # 8220 <_sk_callback_avx+0x7b0> .byte 196,226,121,33,192 // vpmovsxbd %xmm0,%xmm0 .byte 196,227,117,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 .byte 196,226,125,44,24 // vmaskmovps (%rax),%ymm0,%ymm3 .byte 233,49,255,255,255 // jmpq 4dd7 <_sk_load_bgra_avx+0x2b> HIDDEN _sk_load_bgra_dst_avx .globl _sk_load_bgra_dst_avx FUNCTION(_sk_load_bgra_dst_avx) _sk_load_bgra_dst_avx: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,136,0,0,0 // jne 4f55 <_sk_load_bgra_dst_avx+0xaf> .byte 197,252,16,56 // vmovups (%rax),%ymm7 .byte 197,124,40,21,103,52,0,0 // vmovaps 0x3467(%rip),%ymm10 # 8340 <_sk_callback_avx+0x8d0> .byte 196,193,68,84,234 // vandps %ymm10,%ymm7,%ymm5 .byte 197,252,91,237 // vcvtdq2ps %ymm5,%ymm5 .byte 196,98,125,24,5,109,48,0,0 // vbroadcastss 0x306d(%rip),%ymm8 # 7f58 <_sk_callback_avx+0x4e8> .byte 196,193,84,89,240 // vmulps %ymm8,%ymm5,%ymm6 .byte 197,209,114,215,8 // vpsrld $0x8,%xmm7,%xmm5 .byte 196,195,125,25,249,1 // vextractf128 $0x1,%ymm7,%xmm9 .byte 196,193,89,114,209,8 // vpsrld $0x8,%xmm9,%xmm4 .byte 196,227,85,24,228,1 // vinsertf128 $0x1,%xmm4,%ymm5,%ymm4 .byte 196,193,92,84,226 // vandps %ymm10,%ymm4,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,193,92,89,232 // vmulps %ymm8,%ymm4,%ymm5 .byte 197,161,114,215,16 // vpsrld $0x10,%xmm7,%xmm11 .byte 196,193,89,114,209,16 // vpsrld $0x10,%xmm9,%xmm4 .byte 196,227,37,24,228,1 // vinsertf128 $0x1,%xmm4,%ymm11,%ymm4 .byte 196,193,92,84,226 // vandps %ymm10,%ymm4,%ymm4 .byte 197,252,91,228 // vcvtdq2ps %ymm4,%ymm4 .byte 196,193,92,89,224 // vmulps %ymm8,%ymm4,%ymm4 .byte 197,169,114,215,24 // vpsrld $0x18,%xmm7,%xmm10 .byte 196,193,65,114,209,24 // vpsrld $0x18,%xmm9,%xmm7 .byte 196,227,45,24,255,1 // vinsertf128 $0x1,%xmm7,%ymm10,%ymm7 .byte 197,252,91,255 // vcvtdq2ps %ymm7,%ymm7 .byte 196,193,68,89,248 // vmulps %ymm8,%ymm7,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,193,249,110,226 // vmovq %r10,%xmm4 .byte 196,226,121,48,228 // vpmovzxbw %xmm4,%xmm4 .byte 196,226,89,0,45,179,50,0,0 // vpshufb 0x32b3(%rip),%xmm4,%xmm5 # 8230 <_sk_callback_avx+0x7c0> .byte 196,226,121,33,237 // vpmovsxbd %xmm5,%xmm5 .byte 196,226,89,0,37,181,50,0,0 // vpshufb 0x32b5(%rip),%xmm4,%xmm4 # 8240 <_sk_callback_avx+0x7d0> .byte 196,226,121,33,228 // vpmovsxbd %xmm4,%xmm4 .byte 196,227,85,24,228,1 // vinsertf128 $0x1,%xmm4,%ymm5,%ymm4 .byte 196,226,93,44,56 // vmaskmovps (%rax),%ymm4,%ymm7 .byte 233,49,255,255,255 // jmpq 4ed1 <_sk_load_bgra_dst_avx+0x2b> HIDDEN _sk_gather_bgra_avx .globl _sk_gather_bgra_avx FUNCTION(_sk_gather_bgra_avx) _sk_gather_bgra_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 197,249,110,80,8 // vmovd 0x8(%rax),%xmm2 .byte 197,249,112,210,0 // vpshufd $0x0,%xmm2,%xmm2 .byte 196,226,105,64,217 // vpmulld %xmm1,%xmm2,%xmm3 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 196,226,105,64,201 // vpmulld %xmm1,%xmm2,%xmm1 .byte 197,254,91,208 // vcvttps2dq %ymm0,%ymm2 .byte 196,227,125,25,208,1 // vextractf128 $0x1,%ymm2,%xmm0 .byte 197,241,254,192 // vpaddd %xmm0,%xmm1,%xmm0 .byte 197,225,254,202 // vpaddd %xmm2,%xmm3,%xmm1 .byte 196,193,249,126,202 // vmovq %xmm1,%r10 .byte 68,137,208 // mov %r10d,%eax .byte 196,193,121,110,20,129 // vmovd (%r9,%rax,4),%xmm2 .byte 196,195,249,22,203,1 // vpextrq $0x1,%xmm1,%r11 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,105,34,12,145,1 // vpinsrd $0x1,(%r9,%r10,4),%xmm2,%xmm1 .byte 68,137,216 // mov %r11d,%eax .byte 196,195,113,34,12,129,2 // vpinsrd $0x2,(%r9,%rax,4),%xmm1,%xmm1 .byte 196,225,249,126,192 // vmovq %xmm0,%rax .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,3,113,34,4,153,3 // vpinsrd $0x3,(%r9,%r11,4),%xmm1,%xmm8 .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,129,121,110,12,145 // vmovd (%r9,%r10,4),%xmm1 .byte 196,195,249,22,194,1 // vpextrq $0x1,%xmm0,%r10 .byte 196,195,113,34,4,129,1 // vpinsrd $0x1,(%r9,%rax,4),%xmm1,%xmm0 .byte 68,137,208 // mov %r10d,%eax .byte 196,195,121,34,4,129,2 // vpinsrd $0x2,(%r9,%rax,4),%xmm0,%xmm0 .byte 73,193,234,32 // shr $0x20,%r10 .byte 196,131,121,34,28,145,3 // vpinsrd $0x3,(%r9,%r10,4),%xmm0,%xmm3 .byte 196,227,61,24,195,1 // vinsertf128 $0x1,%xmm3,%ymm8,%ymm0 .byte 197,124,40,13,21,51,0,0 // vmovaps 0x3315(%rip),%ymm9 # 8360 <_sk_callback_avx+0x8f0> .byte 196,193,124,84,193 // vandps %ymm9,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,21,255,46,0,0 // vbroadcastss 0x2eff(%rip),%ymm10 # 7f5c <_sk_callback_avx+0x4ec> .byte 196,193,124,89,210 // vmulps %ymm10,%ymm0,%ymm2 .byte 196,193,121,114,208,8 // vpsrld $0x8,%xmm8,%xmm0 .byte 197,241,114,211,8 // vpsrld $0x8,%xmm3,%xmm1 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 196,193,124,84,193 // vandps %ymm9,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,193,124,89,202 // vmulps %ymm10,%ymm0,%ymm1 .byte 196,193,33,114,208,16 // vpsrld $0x10,%xmm8,%xmm11 .byte 197,249,114,211,16 // vpsrld $0x10,%xmm3,%xmm0 .byte 196,227,37,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm11,%ymm0 .byte 196,193,124,84,193 // vandps %ymm9,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,193,124,89,194 // vmulps %ymm10,%ymm0,%ymm0 .byte 196,193,57,114,208,24 // vpsrld $0x18,%xmm8,%xmm8 .byte 197,225,114,211,24 // vpsrld $0x18,%xmm3,%xmm3 .byte 196,227,61,24,219,1 // vinsertf128 $0x1,%xmm3,%ymm8,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,218 // vmulps %ymm10,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_bgra_avx .globl _sk_store_bgra_avx FUNCTION(_sk_store_bgra_avx) _sk_store_bgra_avx: .byte 73,137,201 // mov %rcx,%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 73,99,201 // movslq %r9d,%rcx .byte 73,15,175,202 // imul %r10,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 72,99,194 // movslq %edx,%rax .byte 72,141,4,129 // lea (%rcx,%rax,4),%rax .byte 196,98,125,24,5,123,46,0,0 // vbroadcastss 0x2e7b(%rip),%ymm8 # 7f60 <_sk_callback_avx+0x4f0> .byte 196,65,108,89,200 // vmulps %ymm8,%ymm2,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,33,114,242,8 // vpslld $0x8,%xmm10,%xmm11 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,242,8 // vpslld $0x8,%xmm10,%xmm10 .byte 196,67,37,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 .byte 196,65,45,86,201 // vorpd %ymm9,%ymm10,%ymm9 .byte 196,65,124,89,208 // vmulps %ymm8,%ymm0,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,193,33,114,242,16 // vpslld $0x10,%xmm10,%xmm11 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,242,16 // vpslld $0x10,%xmm10,%xmm10 .byte 196,67,37,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,193,33,114,240,24 // vpslld $0x18,%xmm8,%xmm11 .byte 196,67,125,25,192,1 // vextractf128 $0x1,%ymm8,%xmm8 .byte 196,193,57,114,240,24 // vpslld $0x18,%xmm8,%xmm8 .byte 196,67,37,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm11,%ymm8 .byte 196,65,45,86,192 // vorpd %ymm8,%ymm10,%ymm8 .byte 196,65,53,86,192 // vorpd %ymm8,%ymm9,%ymm8 .byte 77,133,192 // test %r8,%r8 .byte 117,11 // jne 5174 <_sk_store_bgra_avx+0xb6> .byte 197,124,17,0 // vmovups %ymm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,201 // mov %r9,%rcx .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 73,199,194,255,255,255,255 // mov $0xffffffffffffffff,%r10 .byte 73,211,234 // shr %cl,%r10 .byte 196,65,249,110,202 // vmovq %r10,%xmm9 .byte 196,66,121,48,201 // vpmovzxbw %xmm9,%xmm9 .byte 196,98,49,0,21,180,48,0,0 // vpshufb 0x30b4(%rip),%xmm9,%xmm10 # 8250 <_sk_callback_avx+0x7e0> .byte 196,66,121,33,210 // vpmovsxbd %xmm10,%xmm10 .byte 196,98,49,0,13,182,48,0,0 // vpshufb 0x30b6(%rip),%xmm9,%xmm9 # 8260 <_sk_callback_avx+0x7f0> .byte 196,66,121,33,201 // vpmovsxbd %xmm9,%xmm9 .byte 196,67,45,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm9 .byte 196,98,53,46,0 // vmaskmovps %ymm8,%ymm9,(%rax) .byte 235,177 // jmp 516d <_sk_store_bgra_avx+0xaf> HIDDEN _sk_load_f16_avx .globl _sk_load_f16_avx FUNCTION(_sk_load_f16_avx) _sk_load_f16_avx: .byte 72,131,236,24 // sub $0x18,%rsp .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 197,252,17,124,36,224 // vmovups %ymm7,-0x20(%rsp) .byte 197,252,17,116,36,192 // vmovups %ymm6,-0x40(%rsp) .byte 197,252,17,108,36,160 // vmovups %ymm5,-0x60(%rsp) .byte 197,254,127,100,36,128 // vmovdqu %ymm4,-0x80(%rsp) .byte 15,133,145,2,0,0 // jne 5489 <_sk_load_f16_avx+0x2cd> .byte 196,65,121,16,4,193 // vmovupd (%r9,%rax,8),%xmm8 .byte 196,193,121,16,84,193,16 // vmovupd 0x10(%r9,%rax,8),%xmm2 .byte 196,193,121,16,76,193,32 // vmovupd 0x20(%r9,%rax,8),%xmm1 .byte 196,65,122,111,76,193,48 // vmovdqu 0x30(%r9,%rax,8),%xmm9 .byte 197,185,97,194 // vpunpcklwd %xmm2,%xmm8,%xmm0 .byte 197,185,105,210 // vpunpckhwd %xmm2,%xmm8,%xmm2 .byte 196,193,113,97,217 // vpunpcklwd %xmm9,%xmm1,%xmm3 .byte 196,193,113,105,201 // vpunpckhwd %xmm9,%xmm1,%xmm1 .byte 197,121,97,250 // vpunpcklwd %xmm2,%xmm0,%xmm15 .byte 197,121,105,194 // vpunpckhwd %xmm2,%xmm0,%xmm8 .byte 197,225,97,209 // vpunpcklwd %xmm1,%xmm3,%xmm2 .byte 197,97,105,201 // vpunpckhwd %xmm1,%xmm3,%xmm9 .byte 197,129,108,194 // vpunpcklqdq %xmm2,%xmm15,%xmm0 .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,249,105,201 // vpunpckhwd %xmm1,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 196,98,125,24,37,15,45,0,0 // vbroadcastss 0x2d0f(%rip),%ymm12 # 7f64 <_sk_callback_avx+0x4f4> .byte 196,193,124,84,204 // vandps %ymm12,%ymm0,%ymm1 .byte 197,252,87,193 // vxorps %ymm1,%ymm0,%ymm0 .byte 196,195,125,25,198,1 // vextractf128 $0x1,%ymm0,%xmm14 .byte 196,98,121,24,29,251,44,0,0 // vbroadcastss 0x2cfb(%rip),%xmm11 # 7f68 <_sk_callback_avx+0x4f8> .byte 196,193,8,87,219 // vxorps %xmm11,%xmm14,%xmm3 .byte 196,98,121,24,45,241,44,0,0 // vbroadcastss 0x2cf1(%rip),%xmm13 # 7f6c <_sk_callback_avx+0x4fc> .byte 197,145,102,219 // vpcmpgtd %xmm3,%xmm13,%xmm3 .byte 196,65,120,87,211 // vxorps %xmm11,%xmm0,%xmm10 .byte 196,65,17,102,210 // vpcmpgtd %xmm10,%xmm13,%xmm10 .byte 196,99,45,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm10,%ymm10 .byte 197,225,114,241,16 // vpslld $0x10,%xmm1,%xmm3 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 197,241,114,241,16 // vpslld $0x10,%xmm1,%xmm1 .byte 196,227,101,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm3,%ymm1 .byte 197,249,114,240,13 // vpslld $0xd,%xmm0,%xmm0 .byte 196,193,97,114,246,13 // vpslld $0xd,%xmm14,%xmm3 .byte 196,227,125,24,195,1 // vinsertf128 $0x1,%xmm3,%ymm0,%ymm0 .byte 197,252,86,193 // vorps %ymm1,%ymm0,%ymm0 .byte 196,227,125,25,193,1 // vextractf128 $0x1,%ymm0,%xmm1 .byte 196,226,121,24,29,167,44,0,0 // vbroadcastss 0x2ca7(%rip),%xmm3 # 7f70 <_sk_callback_avx+0x500> .byte 197,241,254,203 // vpaddd %xmm3,%xmm1,%xmm1 .byte 197,249,254,195 // vpaddd %xmm3,%xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 196,65,12,87,246 // vxorps %ymm14,%ymm14,%ymm14 .byte 196,195,125,74,198,160 // vblendvps %ymm10,%ymm14,%ymm0,%ymm0 .byte 197,129,109,202 // vpunpckhqdq %xmm2,%xmm15,%xmm1 .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,241,105,212 // vpunpckhwd %xmm4,%xmm1,%xmm2 .byte 196,226,121,51,201 // vpmovzxwd %xmm1,%xmm1 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 196,193,116,84,212 // vandps %ymm12,%ymm1,%ymm2 .byte 197,244,87,202 // vxorps %ymm2,%ymm1,%ymm1 .byte 196,195,125,25,202,1 // vextractf128 $0x1,%ymm1,%xmm10 .byte 196,193,40,87,251 // vxorps %xmm11,%xmm10,%xmm7 .byte 197,145,102,255 // vpcmpgtd %xmm7,%xmm13,%xmm7 .byte 196,193,112,87,243 // vxorps %xmm11,%xmm1,%xmm6 .byte 197,145,102,246 // vpcmpgtd %xmm6,%xmm13,%xmm6 .byte 196,227,77,24,247,1 // vinsertf128 $0x1,%xmm7,%ymm6,%ymm6 .byte 197,193,114,242,16 // vpslld $0x10,%xmm2,%xmm7 .byte 196,227,125,25,210,1 // vextractf128 $0x1,%ymm2,%xmm2 .byte 197,233,114,242,16 // vpslld $0x10,%xmm2,%xmm2 .byte 196,227,69,24,210,1 // vinsertf128 $0x1,%xmm2,%ymm7,%ymm2 .byte 197,241,114,241,13 // vpslld $0xd,%xmm1,%xmm1 .byte 196,193,65,114,242,13 // vpslld $0xd,%xmm10,%xmm7 .byte 196,227,117,24,207,1 // vinsertf128 $0x1,%xmm7,%ymm1,%ymm1 .byte 197,244,86,202 // vorps %ymm2,%ymm1,%ymm1 .byte 196,227,125,25,202,1 // vextractf128 $0x1,%ymm1,%xmm2 .byte 197,233,254,211 // vpaddd %xmm3,%xmm2,%xmm2 .byte 197,241,254,203 // vpaddd %xmm3,%xmm1,%xmm1 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 196,195,117,74,206,96 // vblendvps %ymm6,%ymm14,%ymm1,%ymm1 .byte 196,193,57,108,209 // vpunpcklqdq %xmm9,%xmm8,%xmm2 .byte 197,233,105,244 // vpunpckhwd %xmm4,%xmm2,%xmm6 .byte 196,65,41,239,210 // vpxor %xmm10,%xmm10,%xmm10 .byte 196,226,121,51,210 // vpmovzxwd %xmm2,%xmm2 .byte 196,227,109,24,214,1 // vinsertf128 $0x1,%xmm6,%ymm2,%ymm2 .byte 196,193,108,84,244 // vandps %ymm12,%ymm2,%ymm6 .byte 197,236,87,214 // vxorps %ymm6,%ymm2,%ymm2 .byte 196,227,125,25,215,1 // vextractf128 $0x1,%ymm2,%xmm7 .byte 196,193,64,87,235 // vxorps %xmm11,%xmm7,%xmm5 .byte 197,145,102,237 // vpcmpgtd %xmm5,%xmm13,%xmm5 .byte 196,193,104,87,227 // vxorps %xmm11,%xmm2,%xmm4 .byte 197,145,102,228 // vpcmpgtd %xmm4,%xmm13,%xmm4 .byte 196,227,93,24,229,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm4 .byte 197,209,114,246,16 // vpslld $0x10,%xmm6,%xmm5 .byte 196,227,125,25,246,1 // vextractf128 $0x1,%ymm6,%xmm6 .byte 197,201,114,246,16 // vpslld $0x10,%xmm6,%xmm6 .byte 196,227,85,24,238,1 // vinsertf128 $0x1,%xmm6,%ymm5,%ymm5 .byte 197,233,114,242,13 // vpslld $0xd,%xmm2,%xmm2 .byte 197,201,114,247,13 // vpslld $0xd,%xmm7,%xmm6 .byte 196,227,109,24,214,1 // vinsertf128 $0x1,%xmm6,%ymm2,%ymm2 .byte 197,236,86,213 // vorps %ymm5,%ymm2,%ymm2 .byte 196,227,125,25,213,1 // vextractf128 $0x1,%ymm2,%xmm5 .byte 197,209,254,235 // vpaddd %xmm3,%xmm5,%xmm5 .byte 197,233,254,211 // vpaddd %xmm3,%xmm2,%xmm2 .byte 196,227,109,24,213,1 // vinsertf128 $0x1,%xmm5,%ymm2,%ymm2 .byte 196,195,109,74,214,64 // vblendvps %ymm4,%ymm14,%ymm2,%ymm2 .byte 196,193,57,109,225 // vpunpckhqdq %xmm9,%xmm8,%xmm4 .byte 196,193,89,105,234 // vpunpckhwd %xmm10,%xmm4,%xmm5 .byte 196,226,121,51,228 // vpmovzxwd %xmm4,%xmm4 .byte 196,227,93,24,229,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm4 .byte 196,193,92,84,236 // vandps %ymm12,%ymm4,%ymm5 .byte 197,220,87,229 // vxorps %ymm5,%ymm4,%ymm4 .byte 196,227,125,25,230,1 // vextractf128 $0x1,%ymm4,%xmm6 .byte 196,193,72,87,251 // vxorps %xmm11,%xmm6,%xmm7 .byte 197,17,102,199 // vpcmpgtd %xmm7,%xmm13,%xmm8 .byte 196,193,88,87,251 // vxorps %xmm11,%xmm4,%xmm7 .byte 197,145,102,255 // vpcmpgtd %xmm7,%xmm13,%xmm7 .byte 196,195,69,24,248,1 // vinsertf128 $0x1,%xmm8,%ymm7,%ymm7 .byte 197,185,114,245,16 // vpslld $0x10,%xmm5,%xmm8 .byte 196,227,125,25,237,1 // vextractf128 $0x1,%ymm5,%xmm5 .byte 197,209,114,245,16 // vpslld $0x10,%xmm5,%xmm5 .byte 196,227,61,24,237,1 // vinsertf128 $0x1,%xmm5,%ymm8,%ymm5 .byte 197,217,114,244,13 // vpslld $0xd,%xmm4,%xmm4 .byte 197,201,114,246,13 // vpslld $0xd,%xmm6,%xmm6 .byte 196,227,93,24,230,1 // vinsertf128 $0x1,%xmm6,%ymm4,%ymm4 .byte 197,220,86,229 // vorps %ymm5,%ymm4,%ymm4 .byte 196,227,125,25,229,1 // vextractf128 $0x1,%ymm4,%xmm5 .byte 197,209,254,235 // vpaddd %xmm3,%xmm5,%xmm5 .byte 197,217,254,219 // vpaddd %xmm3,%xmm4,%xmm3 .byte 196,227,101,24,221,1 // vinsertf128 $0x1,%xmm5,%ymm3,%ymm3 .byte 196,195,101,74,222,112 // vblendvps %ymm7,%ymm14,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,100,36,128 // vmovups -0x80(%rsp),%ymm4 .byte 197,252,16,108,36,160 // vmovups -0x60(%rsp),%ymm5 .byte 197,252,16,116,36,192 // vmovups -0x40(%rsp),%ymm6 .byte 197,252,16,124,36,224 // vmovups -0x20(%rsp),%ymm7 .byte 72,131,196,24 // add $0x18,%rsp .byte 255,224 // jmpq *%rax .byte 196,65,123,16,4,193 // vmovsd (%r9,%rax,8),%xmm8 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,85 // je 54ef <_sk_load_f16_avx+0x333> .byte 196,65,57,22,68,193,8 // vmovhpd 0x8(%r9,%rax,8),%xmm8,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,72 // jb 54ef <_sk_load_f16_avx+0x333> .byte 196,193,123,16,84,193,16 // vmovsd 0x10(%r9,%rax,8),%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 116,72 // je 54fc <_sk_load_f16_avx+0x340> .byte 196,193,105,22,84,193,24 // vmovhpd 0x18(%r9,%rax,8),%xmm2,%xmm2 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,59 // jb 54fc <_sk_load_f16_avx+0x340> .byte 196,193,123,16,76,193,32 // vmovsd 0x20(%r9,%rax,8),%xmm1 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 15,132,65,253,255,255 // je 5213 <_sk_load_f16_avx+0x57> .byte 196,193,113,22,76,193,40 // vmovhpd 0x28(%r9,%rax,8),%xmm1,%xmm1 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,130,48,253,255,255 // jb 5213 <_sk_load_f16_avx+0x57> .byte 196,65,122,126,76,193,48 // vmovq 0x30(%r9,%rax,8),%xmm9 .byte 233,36,253,255,255 // jmpq 5213 <_sk_load_f16_avx+0x57> .byte 197,241,87,201 // vxorpd %xmm1,%xmm1,%xmm1 .byte 197,233,87,210 // vxorpd %xmm2,%xmm2,%xmm2 .byte 233,23,253,255,255 // jmpq 5213 <_sk_load_f16_avx+0x57> .byte 197,241,87,201 // vxorpd %xmm1,%xmm1,%xmm1 .byte 233,14,253,255,255 // jmpq 5213 <_sk_load_f16_avx+0x57> HIDDEN _sk_load_f16_dst_avx .globl _sk_load_f16_dst_avx FUNCTION(_sk_load_f16_dst_avx) _sk_load_f16_dst_avx: .byte 72,131,236,24 // sub $0x18,%rsp .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 197,252,17,92,36,224 // vmovups %ymm3,-0x20(%rsp) .byte 197,252,17,84,36,192 // vmovups %ymm2,-0x40(%rsp) .byte 197,252,17,76,36,160 // vmovups %ymm1,-0x60(%rsp) .byte 197,254,127,68,36,128 // vmovdqu %ymm0,-0x80(%rsp) .byte 15,133,145,2,0,0 // jne 57d2 <_sk_load_f16_dst_avx+0x2cd> .byte 196,65,121,16,4,193 // vmovupd (%r9,%rax,8),%xmm8 .byte 196,193,121,16,116,193,16 // vmovupd 0x10(%r9,%rax,8),%xmm6 .byte 196,193,121,16,108,193,32 // vmovupd 0x20(%r9,%rax,8),%xmm5 .byte 196,65,122,111,76,193,48 // vmovdqu 0x30(%r9,%rax,8),%xmm9 .byte 197,185,97,230 // vpunpcklwd %xmm6,%xmm8,%xmm4 .byte 197,185,105,246 // vpunpckhwd %xmm6,%xmm8,%xmm6 .byte 196,193,81,97,249 // vpunpcklwd %xmm9,%xmm5,%xmm7 .byte 196,193,81,105,233 // vpunpckhwd %xmm9,%xmm5,%xmm5 .byte 197,89,97,254 // vpunpcklwd %xmm6,%xmm4,%xmm15 .byte 197,89,105,198 // vpunpckhwd %xmm6,%xmm4,%xmm8 .byte 197,193,97,245 // vpunpcklwd %xmm5,%xmm7,%xmm6 .byte 197,65,105,205 // vpunpckhwd %xmm5,%xmm7,%xmm9 .byte 197,129,108,230 // vpunpcklqdq %xmm6,%xmm15,%xmm4 .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,217,105,232 // vpunpckhwd %xmm0,%xmm4,%xmm5 .byte 196,226,121,51,228 // vpmovzxwd %xmm4,%xmm4 .byte 196,227,93,24,229,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm4 .byte 196,98,125,24,37,214,41,0,0 // vbroadcastss 0x29d6(%rip),%ymm12 # 7f74 <_sk_callback_avx+0x504> .byte 196,193,92,84,236 // vandps %ymm12,%ymm4,%ymm5 .byte 197,220,87,229 // vxorps %ymm5,%ymm4,%ymm4 .byte 196,195,125,25,230,1 // vextractf128 $0x1,%ymm4,%xmm14 .byte 196,98,121,24,29,194,41,0,0 // vbroadcastss 0x29c2(%rip),%xmm11 # 7f78 <_sk_callback_avx+0x508> .byte 196,193,8,87,251 // vxorps %xmm11,%xmm14,%xmm7 .byte 196,98,121,24,45,184,41,0,0 // vbroadcastss 0x29b8(%rip),%xmm13 # 7f7c <_sk_callback_avx+0x50c> .byte 197,145,102,255 // vpcmpgtd %xmm7,%xmm13,%xmm7 .byte 196,65,88,87,211 // vxorps %xmm11,%xmm4,%xmm10 .byte 196,65,17,102,210 // vpcmpgtd %xmm10,%xmm13,%xmm10 .byte 196,99,45,24,215,1 // vinsertf128 $0x1,%xmm7,%ymm10,%ymm10 .byte 197,193,114,245,16 // vpslld $0x10,%xmm5,%xmm7 .byte 196,227,125,25,237,1 // vextractf128 $0x1,%ymm5,%xmm5 .byte 197,209,114,245,16 // vpslld $0x10,%xmm5,%xmm5 .byte 196,227,69,24,237,1 // vinsertf128 $0x1,%xmm5,%ymm7,%ymm5 .byte 197,217,114,244,13 // vpslld $0xd,%xmm4,%xmm4 .byte 196,193,65,114,246,13 // vpslld $0xd,%xmm14,%xmm7 .byte 196,227,93,24,231,1 // vinsertf128 $0x1,%xmm7,%ymm4,%ymm4 .byte 197,220,86,229 // vorps %ymm5,%ymm4,%ymm4 .byte 196,227,125,25,229,1 // vextractf128 $0x1,%ymm4,%xmm5 .byte 196,226,121,24,61,110,41,0,0 // vbroadcastss 0x296e(%rip),%xmm7 # 7f80 <_sk_callback_avx+0x510> .byte 197,209,254,239 // vpaddd %xmm7,%xmm5,%xmm5 .byte 197,217,254,231 // vpaddd %xmm7,%xmm4,%xmm4 .byte 196,227,93,24,229,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm4 .byte 196,65,12,87,246 // vxorps %ymm14,%ymm14,%ymm14 .byte 196,195,93,74,230,160 // vblendvps %ymm10,%ymm14,%ymm4,%ymm4 .byte 197,129,109,238 // vpunpckhqdq %xmm6,%xmm15,%xmm5 .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,209,105,240 // vpunpckhwd %xmm0,%xmm5,%xmm6 .byte 196,226,121,51,237 // vpmovzxwd %xmm5,%xmm5 .byte 196,227,85,24,238,1 // vinsertf128 $0x1,%xmm6,%ymm5,%ymm5 .byte 196,193,84,84,244 // vandps %ymm12,%ymm5,%ymm6 .byte 197,212,87,238 // vxorps %ymm6,%ymm5,%ymm5 .byte 196,195,125,25,234,1 // vextractf128 $0x1,%ymm5,%xmm10 .byte 196,193,40,87,219 // vxorps %xmm11,%xmm10,%xmm3 .byte 197,145,102,219 // vpcmpgtd %xmm3,%xmm13,%xmm3 .byte 196,193,80,87,211 // vxorps %xmm11,%xmm5,%xmm2 .byte 197,145,102,210 // vpcmpgtd %xmm2,%xmm13,%xmm2 .byte 196,227,109,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 .byte 197,225,114,246,16 // vpslld $0x10,%xmm6,%xmm3 .byte 196,227,125,25,246,1 // vextractf128 $0x1,%ymm6,%xmm6 .byte 197,201,114,246,16 // vpslld $0x10,%xmm6,%xmm6 .byte 196,227,101,24,222,1 // vinsertf128 $0x1,%xmm6,%ymm3,%ymm3 .byte 197,209,114,245,13 // vpslld $0xd,%xmm5,%xmm5 .byte 196,193,73,114,242,13 // vpslld $0xd,%xmm10,%xmm6 .byte 196,227,85,24,238,1 // vinsertf128 $0x1,%xmm6,%ymm5,%ymm5 .byte 197,212,86,219 // vorps %ymm3,%ymm5,%ymm3 .byte 196,227,125,25,221,1 // vextractf128 $0x1,%ymm3,%xmm5 .byte 197,209,254,239 // vpaddd %xmm7,%xmm5,%xmm5 .byte 197,225,254,223 // vpaddd %xmm7,%xmm3,%xmm3 .byte 196,227,101,24,221,1 // vinsertf128 $0x1,%xmm5,%ymm3,%ymm3 .byte 196,195,101,74,238,32 // vblendvps %ymm2,%ymm14,%ymm3,%ymm5 .byte 196,193,57,108,209 // vpunpcklqdq %xmm9,%xmm8,%xmm2 .byte 197,233,105,216 // vpunpckhwd %xmm0,%xmm2,%xmm3 .byte 196,65,41,239,210 // vpxor %xmm10,%xmm10,%xmm10 .byte 196,226,121,51,210 // vpmovzxwd %xmm2,%xmm2 .byte 196,227,109,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 .byte 196,193,108,84,220 // vandps %ymm12,%ymm2,%ymm3 .byte 197,236,87,211 // vxorps %ymm3,%ymm2,%ymm2 .byte 196,227,125,25,214,1 // vextractf128 $0x1,%ymm2,%xmm6 .byte 196,193,72,87,203 // vxorps %xmm11,%xmm6,%xmm1 .byte 197,145,102,201 // vpcmpgtd %xmm1,%xmm13,%xmm1 .byte 196,193,104,87,195 // vxorps %xmm11,%xmm2,%xmm0 .byte 197,145,102,192 // vpcmpgtd %xmm0,%xmm13,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 197,241,114,243,16 // vpslld $0x10,%xmm3,%xmm1 .byte 196,227,125,25,219,1 // vextractf128 $0x1,%ymm3,%xmm3 .byte 197,225,114,243,16 // vpslld $0x10,%xmm3,%xmm3 .byte 196,227,117,24,203,1 // vinsertf128 $0x1,%xmm3,%ymm1,%ymm1 .byte 197,233,114,242,13 // vpslld $0xd,%xmm2,%xmm2 .byte 197,225,114,246,13 // vpslld $0xd,%xmm6,%xmm3 .byte 196,227,109,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 .byte 197,236,86,201 // vorps %ymm1,%ymm2,%ymm1 .byte 196,227,125,25,202,1 // vextractf128 $0x1,%ymm1,%xmm2 .byte 197,233,254,215 // vpaddd %xmm7,%xmm2,%xmm2 .byte 197,241,254,207 // vpaddd %xmm7,%xmm1,%xmm1 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 196,195,117,74,246,0 // vblendvps %ymm0,%ymm14,%ymm1,%ymm6 .byte 196,193,57,109,193 // vpunpckhqdq %xmm9,%xmm8,%xmm0 .byte 196,193,121,105,202 // vpunpckhwd %xmm10,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 196,193,124,84,204 // vandps %ymm12,%ymm0,%ymm1 .byte 197,252,87,193 // vxorps %ymm1,%ymm0,%ymm0 .byte 196,227,125,25,194,1 // vextractf128 $0x1,%ymm0,%xmm2 .byte 196,193,104,87,219 // vxorps %xmm11,%xmm2,%xmm3 .byte 197,17,102,195 // vpcmpgtd %xmm3,%xmm13,%xmm8 .byte 196,193,120,87,219 // vxorps %xmm11,%xmm0,%xmm3 .byte 197,145,102,219 // vpcmpgtd %xmm3,%xmm13,%xmm3 .byte 196,195,101,24,216,1 // vinsertf128 $0x1,%xmm8,%ymm3,%ymm3 .byte 197,185,114,241,16 // vpslld $0x10,%xmm1,%xmm8 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 197,241,114,241,16 // vpslld $0x10,%xmm1,%xmm1 .byte 196,227,61,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm8,%ymm1 .byte 197,249,114,240,13 // vpslld $0xd,%xmm0,%xmm0 .byte 197,233,114,242,13 // vpslld $0xd,%xmm2,%xmm2 .byte 196,227,125,24,194,1 // vinsertf128 $0x1,%xmm2,%ymm0,%ymm0 .byte 197,252,86,193 // vorps %ymm1,%ymm0,%ymm0 .byte 196,227,125,25,193,1 // vextractf128 $0x1,%ymm0,%xmm1 .byte 197,241,254,207 // vpaddd %xmm7,%xmm1,%xmm1 .byte 197,249,254,199 // vpaddd %xmm7,%xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 196,195,125,74,254,48 // vblendvps %ymm3,%ymm14,%ymm0,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,68,36,128 // vmovups -0x80(%rsp),%ymm0 .byte 197,252,16,76,36,160 // vmovups -0x60(%rsp),%ymm1 .byte 197,252,16,84,36,192 // vmovups -0x40(%rsp),%ymm2 .byte 197,252,16,92,36,224 // vmovups -0x20(%rsp),%ymm3 .byte 72,131,196,24 // add $0x18,%rsp .byte 255,224 // jmpq *%rax .byte 196,65,123,16,4,193 // vmovsd (%r9,%rax,8),%xmm8 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,85 // je 5838 <_sk_load_f16_dst_avx+0x333> .byte 196,65,57,22,68,193,8 // vmovhpd 0x8(%r9,%rax,8),%xmm8,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,72 // jb 5838 <_sk_load_f16_dst_avx+0x333> .byte 196,193,123,16,116,193,16 // vmovsd 0x10(%r9,%rax,8),%xmm6 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 116,72 // je 5845 <_sk_load_f16_dst_avx+0x340> .byte 196,193,73,22,116,193,24 // vmovhpd 0x18(%r9,%rax,8),%xmm6,%xmm6 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,59 // jb 5845 <_sk_load_f16_dst_avx+0x340> .byte 196,193,123,16,108,193,32 // vmovsd 0x20(%r9,%rax,8),%xmm5 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 15,132,65,253,255,255 // je 555c <_sk_load_f16_dst_avx+0x57> .byte 196,193,81,22,108,193,40 // vmovhpd 0x28(%r9,%rax,8),%xmm5,%xmm5 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,130,48,253,255,255 // jb 555c <_sk_load_f16_dst_avx+0x57> .byte 196,65,122,126,76,193,48 // vmovq 0x30(%r9,%rax,8),%xmm9 .byte 233,36,253,255,255 // jmpq 555c <_sk_load_f16_dst_avx+0x57> .byte 197,209,87,237 // vxorpd %xmm5,%xmm5,%xmm5 .byte 197,201,87,246 // vxorpd %xmm6,%xmm6,%xmm6 .byte 233,23,253,255,255 // jmpq 555c <_sk_load_f16_dst_avx+0x57> .byte 197,209,87,237 // vxorpd %xmm5,%xmm5,%xmm5 .byte 233,14,253,255,255 // jmpq 555c <_sk_load_f16_dst_avx+0x57> HIDDEN _sk_gather_f16_avx .globl _sk_gather_f16_avx FUNCTION(_sk_gather_f16_avx) _sk_gather_f16_avx: .byte 72,131,236,24 // sub $0x18,%rsp .byte 197,252,17,124,36,224 // vmovups %ymm7,-0x20(%rsp) .byte 197,252,17,116,36,192 // vmovups %ymm6,-0x40(%rsp) .byte 197,252,17,108,36,160 // vmovups %ymm5,-0x60(%rsp) .byte 197,254,127,100,36,128 // vmovdqu %ymm4,-0x80(%rsp) .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 197,249,110,80,8 // vmovd 0x8(%rax),%xmm2 .byte 197,249,112,210,0 // vpshufd $0x0,%xmm2,%xmm2 .byte 196,226,105,64,217 // vpmulld %xmm1,%xmm2,%xmm3 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 196,226,105,64,201 // vpmulld %xmm1,%xmm2,%xmm1 .byte 197,254,91,208 // vcvttps2dq %ymm0,%ymm2 .byte 196,227,125,25,208,1 // vextractf128 $0x1,%ymm2,%xmm0 .byte 197,113,254,192 // vpaddd %xmm0,%xmm1,%xmm8 .byte 197,225,254,202 // vpaddd %xmm2,%xmm3,%xmm1 .byte 196,225,249,126,200 // vmovq %xmm1,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,65,122,126,12,193 // vmovq (%r9,%rax,8),%xmm9 .byte 196,227,249,22,200,1 // vpextrq $0x1,%xmm1,%rax .byte 196,1,122,126,20,209 // vmovq (%r9,%r10,8),%xmm10 .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,65,122,126,28,193 // vmovq (%r9,%rax,8),%xmm11 .byte 196,97,249,126,192 // vmovq %xmm8,%rax .byte 196,1,122,126,36,209 // vmovq (%r9,%r10,8),%xmm12 .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 196,65,122,126,44,193 // vmovq (%r9,%rax,8),%xmm13 .byte 196,67,249,22,195,1 // vpextrq $0x1,%xmm8,%r11 .byte 196,1,122,126,4,209 // vmovq (%r9,%r10,8),%xmm8 .byte 76,137,216 // mov %r11,%rax .byte 72,193,232,32 // shr $0x20,%rax .byte 196,65,122,126,52,193 // vmovq (%r9,%rax,8),%xmm14 .byte 68,137,216 // mov %r11d,%eax .byte 196,193,122,126,4,193 // vmovq (%r9,%rax,8),%xmm0 .byte 196,193,41,108,209 // vpunpcklqdq %xmm9,%xmm10,%xmm2 .byte 196,193,25,108,203 // vpunpcklqdq %xmm11,%xmm12,%xmm1 .byte 196,193,57,108,221 // vpunpcklqdq %xmm13,%xmm8,%xmm3 .byte 196,193,121,108,198 // vpunpcklqdq %xmm14,%xmm0,%xmm0 .byte 197,105,97,193 // vpunpcklwd %xmm1,%xmm2,%xmm8 .byte 197,233,105,209 // vpunpckhwd %xmm1,%xmm2,%xmm2 .byte 197,225,97,200 // vpunpcklwd %xmm0,%xmm3,%xmm1 .byte 197,225,105,192 // vpunpckhwd %xmm0,%xmm3,%xmm0 .byte 197,57,97,250 // vpunpcklwd %xmm2,%xmm8,%xmm15 .byte 197,57,105,194 // vpunpckhwd %xmm2,%xmm8,%xmm8 .byte 197,241,97,208 // vpunpcklwd %xmm0,%xmm1,%xmm2 .byte 197,113,105,200 // vpunpckhwd %xmm0,%xmm1,%xmm9 .byte 197,129,108,194 // vpunpcklqdq %xmm2,%xmm15,%xmm0 .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,249,105,201 // vpunpckhwd %xmm1,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 196,98,125,24,37,44,38,0,0 // vbroadcastss 0x262c(%rip),%ymm12 # 7f84 <_sk_callback_avx+0x514> .byte 196,193,124,84,204 // vandps %ymm12,%ymm0,%ymm1 .byte 197,252,87,193 // vxorps %ymm1,%ymm0,%ymm0 .byte 196,195,125,25,198,1 // vextractf128 $0x1,%ymm0,%xmm14 .byte 196,98,121,24,29,24,38,0,0 // vbroadcastss 0x2618(%rip),%xmm11 # 7f88 <_sk_callback_avx+0x518> .byte 196,193,8,87,219 // vxorps %xmm11,%xmm14,%xmm3 .byte 196,98,121,24,45,14,38,0,0 // vbroadcastss 0x260e(%rip),%xmm13 # 7f8c <_sk_callback_avx+0x51c> .byte 197,145,102,219 // vpcmpgtd %xmm3,%xmm13,%xmm3 .byte 196,65,120,87,211 // vxorps %xmm11,%xmm0,%xmm10 .byte 196,65,17,102,210 // vpcmpgtd %xmm10,%xmm13,%xmm10 .byte 196,99,45,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm10,%ymm10 .byte 197,225,114,241,16 // vpslld $0x10,%xmm1,%xmm3 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 197,241,114,241,16 // vpslld $0x10,%xmm1,%xmm1 .byte 196,227,101,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm3,%ymm1 .byte 197,249,114,240,13 // vpslld $0xd,%xmm0,%xmm0 .byte 196,193,97,114,246,13 // vpslld $0xd,%xmm14,%xmm3 .byte 196,227,125,24,195,1 // vinsertf128 $0x1,%xmm3,%ymm0,%ymm0 .byte 197,252,86,193 // vorps %ymm1,%ymm0,%ymm0 .byte 196,227,125,25,193,1 // vextractf128 $0x1,%ymm0,%xmm1 .byte 196,226,121,24,29,196,37,0,0 // vbroadcastss 0x25c4(%rip),%xmm3 # 7f90 <_sk_callback_avx+0x520> .byte 197,241,254,203 // vpaddd %xmm3,%xmm1,%xmm1 .byte 197,249,254,195 // vpaddd %xmm3,%xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 196,65,12,87,246 // vxorps %ymm14,%ymm14,%ymm14 .byte 196,195,125,74,198,160 // vblendvps %ymm10,%ymm14,%ymm0,%ymm0 .byte 197,129,109,202 // vpunpckhqdq %xmm2,%xmm15,%xmm1 .byte 197,217,239,228 // vpxor %xmm4,%xmm4,%xmm4 .byte 197,241,105,212 // vpunpckhwd %xmm4,%xmm1,%xmm2 .byte 196,226,121,51,201 // vpmovzxwd %xmm1,%xmm1 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 196,193,116,84,212 // vandps %ymm12,%ymm1,%ymm2 .byte 197,244,87,202 // vxorps %ymm2,%ymm1,%ymm1 .byte 196,195,125,25,202,1 // vextractf128 $0x1,%ymm1,%xmm10 .byte 196,193,40,87,251 // vxorps %xmm11,%xmm10,%xmm7 .byte 197,145,102,255 // vpcmpgtd %xmm7,%xmm13,%xmm7 .byte 196,193,112,87,243 // vxorps %xmm11,%xmm1,%xmm6 .byte 197,145,102,246 // vpcmpgtd %xmm6,%xmm13,%xmm6 .byte 196,227,77,24,247,1 // vinsertf128 $0x1,%xmm7,%ymm6,%ymm6 .byte 197,193,114,242,16 // vpslld $0x10,%xmm2,%xmm7 .byte 196,227,125,25,210,1 // vextractf128 $0x1,%ymm2,%xmm2 .byte 197,233,114,242,16 // vpslld $0x10,%xmm2,%xmm2 .byte 196,227,69,24,210,1 // vinsertf128 $0x1,%xmm2,%ymm7,%ymm2 .byte 197,241,114,241,13 // vpslld $0xd,%xmm1,%xmm1 .byte 196,193,65,114,242,13 // vpslld $0xd,%xmm10,%xmm7 .byte 196,227,117,24,207,1 // vinsertf128 $0x1,%xmm7,%ymm1,%ymm1 .byte 197,244,86,202 // vorps %ymm2,%ymm1,%ymm1 .byte 196,227,125,25,202,1 // vextractf128 $0x1,%ymm1,%xmm2 .byte 197,233,254,211 // vpaddd %xmm3,%xmm2,%xmm2 .byte 197,241,254,203 // vpaddd %xmm3,%xmm1,%xmm1 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 196,195,117,74,206,96 // vblendvps %ymm6,%ymm14,%ymm1,%ymm1 .byte 196,193,57,108,209 // vpunpcklqdq %xmm9,%xmm8,%xmm2 .byte 197,233,105,244 // vpunpckhwd %xmm4,%xmm2,%xmm6 .byte 196,65,41,239,210 // vpxor %xmm10,%xmm10,%xmm10 .byte 196,226,121,51,210 // vpmovzxwd %xmm2,%xmm2 .byte 196,227,109,24,214,1 // vinsertf128 $0x1,%xmm6,%ymm2,%ymm2 .byte 196,193,108,84,244 // vandps %ymm12,%ymm2,%ymm6 .byte 197,236,87,214 // vxorps %ymm6,%ymm2,%ymm2 .byte 196,227,125,25,215,1 // vextractf128 $0x1,%ymm2,%xmm7 .byte 196,193,64,87,235 // vxorps %xmm11,%xmm7,%xmm5 .byte 197,145,102,237 // vpcmpgtd %xmm5,%xmm13,%xmm5 .byte 196,193,104,87,227 // vxorps %xmm11,%xmm2,%xmm4 .byte 197,145,102,228 // vpcmpgtd %xmm4,%xmm13,%xmm4 .byte 196,227,93,24,229,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm4 .byte 197,209,114,246,16 // vpslld $0x10,%xmm6,%xmm5 .byte 196,227,125,25,246,1 // vextractf128 $0x1,%ymm6,%xmm6 .byte 197,201,114,246,16 // vpslld $0x10,%xmm6,%xmm6 .byte 196,227,85,24,238,1 // vinsertf128 $0x1,%xmm6,%ymm5,%ymm5 .byte 197,233,114,242,13 // vpslld $0xd,%xmm2,%xmm2 .byte 197,201,114,247,13 // vpslld $0xd,%xmm7,%xmm6 .byte 196,227,109,24,214,1 // vinsertf128 $0x1,%xmm6,%ymm2,%ymm2 .byte 197,236,86,213 // vorps %ymm5,%ymm2,%ymm2 .byte 196,227,125,25,213,1 // vextractf128 $0x1,%ymm2,%xmm5 .byte 197,209,254,235 // vpaddd %xmm3,%xmm5,%xmm5 .byte 197,233,254,211 // vpaddd %xmm3,%xmm2,%xmm2 .byte 196,227,109,24,213,1 // vinsertf128 $0x1,%xmm5,%ymm2,%ymm2 .byte 196,195,109,74,214,64 // vblendvps %ymm4,%ymm14,%ymm2,%ymm2 .byte 196,193,57,109,225 // vpunpckhqdq %xmm9,%xmm8,%xmm4 .byte 196,193,89,105,234 // vpunpckhwd %xmm10,%xmm4,%xmm5 .byte 196,226,121,51,228 // vpmovzxwd %xmm4,%xmm4 .byte 196,227,93,24,229,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm4 .byte 196,193,92,84,236 // vandps %ymm12,%ymm4,%ymm5 .byte 197,220,87,229 // vxorps %ymm5,%ymm4,%ymm4 .byte 196,227,125,25,230,1 // vextractf128 $0x1,%ymm4,%xmm6 .byte 196,193,72,87,251 // vxorps %xmm11,%xmm6,%xmm7 .byte 197,17,102,199 // vpcmpgtd %xmm7,%xmm13,%xmm8 .byte 196,193,88,87,251 // vxorps %xmm11,%xmm4,%xmm7 .byte 197,145,102,255 // vpcmpgtd %xmm7,%xmm13,%xmm7 .byte 196,195,69,24,248,1 // vinsertf128 $0x1,%xmm8,%ymm7,%ymm7 .byte 197,185,114,245,16 // vpslld $0x10,%xmm5,%xmm8 .byte 196,227,125,25,237,1 // vextractf128 $0x1,%ymm5,%xmm5 .byte 197,209,114,245,16 // vpslld $0x10,%xmm5,%xmm5 .byte 196,227,61,24,237,1 // vinsertf128 $0x1,%xmm5,%ymm8,%ymm5 .byte 197,217,114,244,13 // vpslld $0xd,%xmm4,%xmm4 .byte 197,201,114,246,13 // vpslld $0xd,%xmm6,%xmm6 .byte 196,227,93,24,230,1 // vinsertf128 $0x1,%xmm6,%ymm4,%ymm4 .byte 197,220,86,229 // vorps %ymm5,%ymm4,%ymm4 .byte 196,227,125,25,229,1 // vextractf128 $0x1,%ymm4,%xmm5 .byte 197,209,254,235 // vpaddd %xmm3,%xmm5,%xmm5 .byte 197,217,254,219 // vpaddd %xmm3,%xmm4,%xmm3 .byte 196,227,101,24,221,1 // vinsertf128 $0x1,%xmm5,%ymm3,%ymm3 .byte 196,195,101,74,222,112 // vblendvps %ymm7,%ymm14,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,100,36,128 // vmovups -0x80(%rsp),%ymm4 .byte 197,252,16,108,36,160 // vmovups -0x60(%rsp),%ymm5 .byte 197,252,16,116,36,192 // vmovups -0x40(%rsp),%ymm6 .byte 197,252,16,124,36,224 // vmovups -0x20(%rsp),%ymm7 .byte 72,131,196,24 // add $0x18,%rsp .byte 255,224 // jmpq *%rax HIDDEN _sk_store_f16_avx .globl _sk_store_f16_avx FUNCTION(_sk_store_f16_avx) _sk_store_f16_avx: .byte 72,131,236,88 // sub $0x58,%rsp .byte 197,252,17,124,36,32 // vmovups %ymm7,0x20(%rsp) .byte 197,252,17,52,36 // vmovups %ymm6,(%rsp) .byte 197,252,17,108,36,224 // vmovups %ymm5,-0x20(%rsp) .byte 197,252,17,100,36,192 // vmovups %ymm4,-0x40(%rsp) .byte 196,98,125,24,13,228,35,0,0 // vbroadcastss 0x23e4(%rip),%ymm9 # 7f94 <_sk_callback_avx+0x524> .byte 196,65,124,84,209 // vandps %ymm9,%ymm0,%ymm10 .byte 197,252,17,68,36,128 // vmovups %ymm0,-0x80(%rsp) .byte 196,65,124,87,218 // vxorps %ymm10,%ymm0,%ymm11 .byte 196,67,125,25,220,1 // vextractf128 $0x1,%ymm11,%xmm12 .byte 196,98,121,24,5,201,35,0,0 // vbroadcastss 0x23c9(%rip),%xmm8 # 7f98 <_sk_callback_avx+0x528> .byte 196,65,57,102,236 // vpcmpgtd %xmm12,%xmm8,%xmm13 .byte 196,65,57,102,243 // vpcmpgtd %xmm11,%xmm8,%xmm14 .byte 196,67,13,24,237,1 // vinsertf128 $0x1,%xmm13,%ymm14,%ymm13 .byte 196,193,9,114,210,16 // vpsrld $0x10,%xmm10,%xmm14 .byte 196,67,125,25,210,1 // vextractf128 $0x1,%ymm10,%xmm10 .byte 196,193,41,114,210,16 // vpsrld $0x10,%xmm10,%xmm10 .byte 196,67,13,24,242,1 // vinsertf128 $0x1,%xmm10,%ymm14,%ymm14 .byte 196,193,33,114,211,13 // vpsrld $0xd,%xmm11,%xmm11 .byte 196,193,25,114,212,13 // vpsrld $0xd,%xmm12,%xmm12 .byte 196,98,125,24,21,144,35,0,0 // vbroadcastss 0x2390(%rip),%ymm10 # 7f9c <_sk_callback_avx+0x52c> .byte 196,65,12,86,242 // vorps %ymm10,%ymm14,%ymm14 .byte 196,67,125,25,247,1 // vextractf128 $0x1,%ymm14,%xmm15 .byte 196,65,1,254,228 // vpaddd %xmm12,%xmm15,%xmm12 .byte 196,65,9,254,219 // vpaddd %xmm11,%xmm14,%xmm11 .byte 196,67,37,24,228,1 // vinsertf128 $0x1,%xmm12,%ymm11,%ymm12 .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 196,99,29,74,224,208 // vblendvps %ymm13,%ymm0,%ymm12,%ymm12 .byte 196,65,116,84,233 // vandps %ymm9,%ymm1,%ymm13 .byte 197,252,17,76,36,160 // vmovups %ymm1,-0x60(%rsp) .byte 196,65,116,87,245 // vxorps %ymm13,%ymm1,%ymm14 .byte 196,67,125,25,247,1 // vextractf128 $0x1,%ymm14,%xmm15 .byte 196,193,57,102,255 // vpcmpgtd %xmm15,%xmm8,%xmm7 .byte 196,65,57,102,222 // vpcmpgtd %xmm14,%xmm8,%xmm11 .byte 196,227,37,24,255,1 // vinsertf128 $0x1,%xmm7,%ymm11,%ymm7 .byte 196,193,33,114,213,16 // vpsrld $0x10,%xmm13,%xmm11 .byte 196,99,125,25,238,1 // vextractf128 $0x1,%ymm13,%xmm6 .byte 197,201,114,214,16 // vpsrld $0x10,%xmm6,%xmm6 .byte 196,227,37,24,246,1 // vinsertf128 $0x1,%xmm6,%ymm11,%ymm6 .byte 196,193,33,114,215,13 // vpsrld $0xd,%xmm15,%xmm11 .byte 196,193,76,86,242 // vorps %ymm10,%ymm6,%ymm6 .byte 196,227,125,25,245,1 // vextractf128 $0x1,%ymm6,%xmm5 .byte 196,193,81,254,235 // vpaddd %xmm11,%xmm5,%xmm5 .byte 196,193,89,114,214,13 // vpsrld $0xd,%xmm14,%xmm4 .byte 197,201,254,228 // vpaddd %xmm4,%xmm6,%xmm4 .byte 196,227,93,24,229,1 // vinsertf128 $0x1,%xmm5,%ymm4,%ymm4 .byte 196,99,93,74,232,112 // vblendvps %ymm7,%ymm0,%ymm4,%ymm13 .byte 196,193,108,84,225 // vandps %ymm9,%ymm2,%ymm4 .byte 197,236,87,236 // vxorps %ymm4,%ymm2,%ymm5 .byte 196,227,125,25,238,1 // vextractf128 $0x1,%ymm5,%xmm6 .byte 197,185,102,254 // vpcmpgtd %xmm6,%xmm8,%xmm7 .byte 197,57,102,221 // vpcmpgtd %xmm5,%xmm8,%xmm11 .byte 196,227,37,24,255,1 // vinsertf128 $0x1,%xmm7,%ymm11,%ymm7 .byte 197,161,114,212,16 // vpsrld $0x10,%xmm4,%xmm11 .byte 196,227,125,25,228,1 // vextractf128 $0x1,%ymm4,%xmm4 .byte 197,217,114,212,16 // vpsrld $0x10,%xmm4,%xmm4 .byte 196,227,37,24,228,1 // vinsertf128 $0x1,%xmm4,%ymm11,%ymm4 .byte 197,201,114,214,13 // vpsrld $0xd,%xmm6,%xmm6 .byte 196,193,92,86,226 // vorps %ymm10,%ymm4,%ymm4 .byte 196,227,125,25,225,1 // vextractf128 $0x1,%ymm4,%xmm1 .byte 197,241,254,206 // vpaddd %xmm6,%xmm1,%xmm1 .byte 197,209,114,213,13 // vpsrld $0xd,%xmm5,%xmm5 .byte 197,217,254,229 // vpaddd %xmm5,%xmm4,%xmm4 .byte 196,227,93,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm4,%ymm1 .byte 196,99,117,74,216,112 // vblendvps %ymm7,%ymm0,%ymm1,%ymm11 .byte 196,193,100,84,225 // vandps %ymm9,%ymm3,%ymm4 .byte 197,228,87,236 // vxorps %ymm4,%ymm3,%ymm5 .byte 196,227,125,25,238,1 // vextractf128 $0x1,%ymm5,%xmm6 .byte 197,185,102,254 // vpcmpgtd %xmm6,%xmm8,%xmm7 .byte 197,57,102,197 // vpcmpgtd %xmm5,%xmm8,%xmm8 .byte 196,227,61,24,255,1 // vinsertf128 $0x1,%xmm7,%ymm8,%ymm7 .byte 197,185,114,212,16 // vpsrld $0x10,%xmm4,%xmm8 .byte 196,227,125,25,228,1 // vextractf128 $0x1,%ymm4,%xmm4 .byte 197,217,114,212,16 // vpsrld $0x10,%xmm4,%xmm4 .byte 196,227,61,24,228,1 // vinsertf128 $0x1,%xmm4,%ymm8,%ymm4 .byte 196,193,92,86,226 // vorps %ymm10,%ymm4,%ymm4 .byte 197,201,114,214,13 // vpsrld $0xd,%xmm6,%xmm6 .byte 196,227,125,25,225,1 // vextractf128 $0x1,%ymm4,%xmm1 .byte 197,241,254,206 // vpaddd %xmm6,%xmm1,%xmm1 .byte 197,209,114,213,13 // vpsrld $0xd,%xmm5,%xmm5 .byte 197,217,254,229 // vpaddd %xmm5,%xmm4,%xmm4 .byte 196,227,93,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm4,%ymm1 .byte 196,227,117,74,200,112 // vblendvps %ymm7,%ymm0,%ymm1,%ymm1 .byte 196,99,125,25,224,1 // vextractf128 $0x1,%ymm12,%xmm0 .byte 196,226,25,43,192 // vpackusdw %xmm0,%xmm12,%xmm0 .byte 196,99,125,25,236,1 // vextractf128 $0x1,%ymm13,%xmm4 .byte 196,226,17,43,228 // vpackusdw %xmm4,%xmm13,%xmm4 .byte 196,99,125,25,221,1 // vextractf128 $0x1,%ymm11,%xmm5 .byte 196,226,33,43,245 // vpackusdw %xmm5,%xmm11,%xmm6 .byte 196,227,125,25,205,1 // vextractf128 $0x1,%ymm1,%xmm5 .byte 196,226,113,43,205 // vpackusdw %xmm5,%xmm1,%xmm1 .byte 197,249,97,236 // vpunpcklwd %xmm4,%xmm0,%xmm5 .byte 197,249,105,196 // vpunpckhwd %xmm4,%xmm0,%xmm0 .byte 197,201,97,225 // vpunpcklwd %xmm1,%xmm6,%xmm4 .byte 197,201,105,201 // vpunpckhwd %xmm1,%xmm6,%xmm1 .byte 197,81,98,220 // vpunpckldq %xmm4,%xmm5,%xmm11 .byte 197,81,106,212 // vpunpckhdq %xmm4,%xmm5,%xmm10 .byte 197,121,98,201 // vpunpckldq %xmm1,%xmm0,%xmm9 .byte 197,121,106,193 // vpunpckhdq %xmm1,%xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,70 // jne 5e00 <_sk_store_f16_avx+0x274> .byte 196,65,120,17,28,193 // vmovups %xmm11,(%r9,%rax,8) .byte 196,65,120,17,84,193,16 // vmovups %xmm10,0x10(%r9,%rax,8) .byte 196,65,120,17,76,193,32 // vmovups %xmm9,0x20(%r9,%rax,8) .byte 196,65,122,127,68,193,48 // vmovdqu %xmm8,0x30(%r9,%rax,8) .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,16,68,36,128 // vmovups -0x80(%rsp),%ymm0 .byte 197,252,16,76,36,160 // vmovups -0x60(%rsp),%ymm1 .byte 197,252,16,100,36,192 // vmovups -0x40(%rsp),%ymm4 .byte 197,252,16,108,36,224 // vmovups -0x20(%rsp),%ymm5 .byte 197,252,16,52,36 // vmovups (%rsp),%ymm6 .byte 197,252,16,124,36,32 // vmovups 0x20(%rsp),%ymm7 .byte 72,131,196,88 // add $0x58,%rsp .byte 255,224 // jmpq *%rax .byte 196,65,121,214,28,193 // vmovq %xmm11,(%r9,%rax,8) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,201 // je 5dd5 <_sk_store_f16_avx+0x249> .byte 196,65,121,23,92,193,8 // vmovhpd %xmm11,0x8(%r9,%rax,8) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,188 // jb 5dd5 <_sk_store_f16_avx+0x249> .byte 196,65,121,214,84,193,16 // vmovq %xmm10,0x10(%r9,%rax,8) .byte 116,179 // je 5dd5 <_sk_store_f16_avx+0x249> .byte 196,65,121,23,84,193,24 // vmovhpd %xmm10,0x18(%r9,%rax,8) .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,166 // jb 5dd5 <_sk_store_f16_avx+0x249> .byte 196,65,121,214,76,193,32 // vmovq %xmm9,0x20(%r9,%rax,8) .byte 116,157 // je 5dd5 <_sk_store_f16_avx+0x249> .byte 196,65,121,23,76,193,40 // vmovhpd %xmm9,0x28(%r9,%rax,8) .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,144 // jb 5dd5 <_sk_store_f16_avx+0x249> .byte 196,65,121,214,68,193,48 // vmovq %xmm8,0x30(%r9,%rax,8) .byte 235,135 // jmp 5dd5 <_sk_store_f16_avx+0x249> HIDDEN _sk_load_u16_be_avx .globl _sk_load_u16_be_avx FUNCTION(_sk_load_u16_be_avx) _sk_load_u16_be_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,253,0,0,0 // jne 5f72 <_sk_load_u16_be_avx+0x124> .byte 196,65,121,16,4,65 // vmovupd (%r9,%rax,2),%xmm8 .byte 196,193,121,16,84,65,16 // vmovupd 0x10(%r9,%rax,2),%xmm2 .byte 196,193,121,16,92,65,32 // vmovupd 0x20(%r9,%rax,2),%xmm3 .byte 196,65,122,111,76,65,48 // vmovdqu 0x30(%r9,%rax,2),%xmm9 .byte 197,185,97,194 // vpunpcklwd %xmm2,%xmm8,%xmm0 .byte 197,185,105,210 // vpunpckhwd %xmm2,%xmm8,%xmm2 .byte 196,193,97,97,201 // vpunpcklwd %xmm9,%xmm3,%xmm1 .byte 196,193,97,105,217 // vpunpckhwd %xmm9,%xmm3,%xmm3 .byte 197,121,97,202 // vpunpcklwd %xmm2,%xmm0,%xmm9 .byte 197,121,105,194 // vpunpckhwd %xmm2,%xmm0,%xmm8 .byte 197,241,97,211 // vpunpcklwd %xmm3,%xmm1,%xmm2 .byte 197,113,105,227 // vpunpckhwd %xmm3,%xmm1,%xmm12 .byte 197,177,108,194 // vpunpcklqdq %xmm2,%xmm9,%xmm0 .byte 197,241,113,240,8 // vpsllw $0x8,%xmm0,%xmm1 .byte 197,249,113,208,8 // vpsrlw $0x8,%xmm0,%xmm0 .byte 197,241,235,192 // vpor %xmm0,%xmm1,%xmm0 .byte 196,65,41,239,210 // vpxor %xmm10,%xmm10,%xmm10 .byte 196,193,121,105,202 // vpunpckhwd %xmm10,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,29,186,32,0,0 // vbroadcastss 0x20ba(%rip),%ymm11 # 7fa0 <_sk_callback_avx+0x530> .byte 196,193,124,89,195 // vmulps %ymm11,%ymm0,%ymm0 .byte 197,177,109,202 // vpunpckhqdq %xmm2,%xmm9,%xmm1 .byte 197,233,113,241,8 // vpsllw $0x8,%xmm1,%xmm2 .byte 197,241,113,209,8 // vpsrlw $0x8,%xmm1,%xmm1 .byte 197,233,235,201 // vpor %xmm1,%xmm2,%xmm1 .byte 196,193,113,105,210 // vpunpckhwd %xmm10,%xmm1,%xmm2 .byte 196,226,121,51,201 // vpmovzxwd %xmm1,%xmm1 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,203 // vmulps %ymm11,%ymm1,%ymm1 .byte 196,193,57,108,212 // vpunpcklqdq %xmm12,%xmm8,%xmm2 .byte 197,225,113,242,8 // vpsllw $0x8,%xmm2,%xmm3 .byte 197,233,113,210,8 // vpsrlw $0x8,%xmm2,%xmm2 .byte 197,225,235,210 // vpor %xmm2,%xmm3,%xmm2 .byte 196,193,105,105,218 // vpunpckhwd %xmm10,%xmm2,%xmm3 .byte 196,226,121,51,210 // vpmovzxwd %xmm2,%xmm2 .byte 196,227,109,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,211 // vmulps %ymm11,%ymm2,%ymm2 .byte 196,193,57,109,220 // vpunpckhqdq %xmm12,%xmm8,%xmm3 .byte 197,185,113,243,8 // vpsllw $0x8,%xmm3,%xmm8 .byte 197,225,113,211,8 // vpsrlw $0x8,%xmm3,%xmm3 .byte 197,185,235,219 // vpor %xmm3,%xmm8,%xmm3 .byte 196,65,97,105,194 // vpunpckhwd %xmm10,%xmm3,%xmm8 .byte 196,226,121,51,219 // vpmovzxwd %xmm3,%xmm3 .byte 196,195,101,24,216,1 // vinsertf128 $0x1,%xmm8,%ymm3,%ymm3 .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 .byte 196,193,100,89,219 // vmulps %ymm11,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,65,123,16,4,65 // vmovsd (%r9,%rax,2),%xmm8 .byte 196,65,49,239,201 // vpxor %xmm9,%xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,85 // je 5fd8 <_sk_load_u16_be_avx+0x18a> .byte 196,65,57,22,68,65,8 // vmovhpd 0x8(%r9,%rax,2),%xmm8,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,72 // jb 5fd8 <_sk_load_u16_be_avx+0x18a> .byte 196,193,123,16,84,65,16 // vmovsd 0x10(%r9,%rax,2),%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 116,72 // je 5fe5 <_sk_load_u16_be_avx+0x197> .byte 196,193,105,22,84,65,24 // vmovhpd 0x18(%r9,%rax,2),%xmm2,%xmm2 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,59 // jb 5fe5 <_sk_load_u16_be_avx+0x197> .byte 196,193,123,16,92,65,32 // vmovsd 0x20(%r9,%rax,2),%xmm3 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 15,132,213,254,255,255 // je 5e90 <_sk_load_u16_be_avx+0x42> .byte 196,193,97,22,92,65,40 // vmovhpd 0x28(%r9,%rax,2),%xmm3,%xmm3 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,130,196,254,255,255 // jb 5e90 <_sk_load_u16_be_avx+0x42> .byte 196,65,122,126,76,65,48 // vmovq 0x30(%r9,%rax,2),%xmm9 .byte 233,184,254,255,255 // jmpq 5e90 <_sk_load_u16_be_avx+0x42> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 197,233,87,210 // vxorpd %xmm2,%xmm2,%xmm2 .byte 233,171,254,255,255 // jmpq 5e90 <_sk_load_u16_be_avx+0x42> .byte 197,225,87,219 // vxorpd %xmm3,%xmm3,%xmm3 .byte 233,162,254,255,255 // jmpq 5e90 <_sk_load_u16_be_avx+0x42> HIDDEN _sk_load_rgb_u16_be_avx .globl _sk_load_rgb_u16_be_avx FUNCTION(_sk_load_rgb_u16_be_avx) _sk_load_rgb_u16_be_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,137,208 // mov %rdx,%rax .byte 72,193,224,32 // shl $0x20,%rax .byte 72,141,4,64 // lea (%rax,%rax,2),%rax .byte 72,193,248,32 // sar $0x20,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,243,0,0,0 // jne 610c <_sk_load_rgb_u16_be_avx+0x11e> .byte 196,193,122,111,4,65 // vmovdqu (%r9,%rax,2),%xmm0 .byte 196,193,122,111,84,65,12 // vmovdqu 0xc(%r9,%rax,2),%xmm2 .byte 196,193,122,111,76,65,24 // vmovdqu 0x18(%r9,%rax,2),%xmm1 .byte 196,193,122,111,92,65,32 // vmovdqu 0x20(%r9,%rax,2),%xmm3 .byte 197,225,115,219,4 // vpsrldq $0x4,%xmm3,%xmm3 .byte 197,185,115,216,6 // vpsrldq $0x6,%xmm0,%xmm8 .byte 197,177,115,218,6 // vpsrldq $0x6,%xmm2,%xmm9 .byte 197,161,115,217,6 // vpsrldq $0x6,%xmm1,%xmm11 .byte 197,169,115,219,6 // vpsrldq $0x6,%xmm3,%xmm10 .byte 197,249,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm0 .byte 196,193,57,97,209 // vpunpcklwd %xmm9,%xmm8,%xmm2 .byte 197,241,97,203 // vpunpcklwd %xmm3,%xmm1,%xmm1 .byte 196,193,33,97,218 // vpunpcklwd %xmm10,%xmm11,%xmm3 .byte 197,121,97,194 // vpunpcklwd %xmm2,%xmm0,%xmm8 .byte 197,121,105,202 // vpunpckhwd %xmm2,%xmm0,%xmm9 .byte 197,241,97,211 // vpunpcklwd %xmm3,%xmm1,%xmm2 .byte 197,113,105,211 // vpunpckhwd %xmm3,%xmm1,%xmm10 .byte 197,185,108,194 // vpunpcklqdq %xmm2,%xmm8,%xmm0 .byte 197,241,113,240,8 // vpsllw $0x8,%xmm0,%xmm1 .byte 197,249,113,208,8 // vpsrlw $0x8,%xmm0,%xmm0 .byte 197,241,235,192 // vpor %xmm0,%xmm1,%xmm0 .byte 196,65,25,239,228 // vpxor %xmm12,%xmm12,%xmm12 .byte 196,193,121,105,204 // vpunpckhwd %xmm12,%xmm0,%xmm1 .byte 196,226,121,51,192 // vpmovzxwd %xmm0,%xmm0 .byte 196,227,125,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm0,%ymm0 .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 .byte 196,98,125,24,29,1,31,0,0 // vbroadcastss 0x1f01(%rip),%ymm11 # 7fa4 <_sk_callback_avx+0x534> .byte 196,193,124,89,195 // vmulps %ymm11,%ymm0,%ymm0 .byte 197,185,109,202 // vpunpckhqdq %xmm2,%xmm8,%xmm1 .byte 197,233,113,241,8 // vpsllw $0x8,%xmm1,%xmm2 .byte 197,241,113,209,8 // vpsrlw $0x8,%xmm1,%xmm1 .byte 197,233,235,201 // vpor %xmm1,%xmm2,%xmm1 .byte 196,193,113,105,212 // vpunpckhwd %xmm12,%xmm1,%xmm2 .byte 196,226,121,51,201 // vpmovzxwd %xmm1,%xmm1 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 .byte 196,193,116,89,203 // vmulps %ymm11,%ymm1,%ymm1 .byte 196,193,49,108,210 // vpunpcklqdq %xmm10,%xmm9,%xmm2 .byte 197,225,113,242,8 // vpsllw $0x8,%xmm2,%xmm3 .byte 197,233,113,210,8 // vpsrlw $0x8,%xmm2,%xmm2 .byte 197,225,235,210 // vpor %xmm2,%xmm3,%xmm2 .byte 196,193,105,105,220 // vpunpckhwd %xmm12,%xmm2,%xmm3 .byte 196,226,121,51,210 // vpmovzxwd %xmm2,%xmm2 .byte 196,227,109,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 .byte 196,193,108,89,211 // vmulps %ymm11,%ymm2,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,29,158,30,0,0 // vbroadcastss 0x1e9e(%rip),%ymm3 # 7fa8 <_sk_callback_avx+0x538> .byte 255,224 // jmpq *%rax .byte 196,193,121,110,4,65 // vmovd (%r9,%rax,2),%xmm0 .byte 196,193,121,196,68,65,4,2 // vpinsrw $0x2,0x4(%r9,%rax,2),%xmm0,%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,5 // jne 6125 <_sk_load_rgb_u16_be_avx+0x137> .byte 233,40,255,255,255 // jmpq 604d <_sk_load_rgb_u16_be_avx+0x5f> .byte 196,193,121,110,76,65,6 // vmovd 0x6(%r9,%rax,2),%xmm1 .byte 196,65,113,196,68,65,10,2 // vpinsrw $0x2,0xa(%r9,%rax,2),%xmm1,%xmm8 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,26 // jb 6154 <_sk_load_rgb_u16_be_avx+0x166> .byte 196,193,121,110,76,65,12 // vmovd 0xc(%r9,%rax,2),%xmm1 .byte 196,193,113,196,84,65,16,2 // vpinsrw $0x2,0x10(%r9,%rax,2),%xmm1,%xmm2 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 117,10 // jne 6159 <_sk_load_rgb_u16_be_avx+0x16b> .byte 233,249,254,255,255 // jmpq 604d <_sk_load_rgb_u16_be_avx+0x5f> .byte 233,244,254,255,255 // jmpq 604d <_sk_load_rgb_u16_be_avx+0x5f> .byte 196,193,121,110,76,65,18 // vmovd 0x12(%r9,%rax,2),%xmm1 .byte 196,65,113,196,76,65,22,2 // vpinsrw $0x2,0x16(%r9,%rax,2),%xmm1,%xmm9 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,26 // jb 6188 <_sk_load_rgb_u16_be_avx+0x19a> .byte 196,193,121,110,76,65,24 // vmovd 0x18(%r9,%rax,2),%xmm1 .byte 196,193,113,196,76,65,28,2 // vpinsrw $0x2,0x1c(%r9,%rax,2),%xmm1,%xmm1 .byte 73,131,248,5 // cmp $0x5,%r8 .byte 117,10 // jne 618d <_sk_load_rgb_u16_be_avx+0x19f> .byte 233,197,254,255,255 // jmpq 604d <_sk_load_rgb_u16_be_avx+0x5f> .byte 233,192,254,255,255 // jmpq 604d <_sk_load_rgb_u16_be_avx+0x5f> .byte 196,193,121,110,92,65,30 // vmovd 0x1e(%r9,%rax,2),%xmm3 .byte 196,65,97,196,92,65,34,2 // vpinsrw $0x2,0x22(%r9,%rax,2),%xmm3,%xmm11 .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,20 // jb 61b6 <_sk_load_rgb_u16_be_avx+0x1c8> .byte 196,193,121,110,92,65,36 // vmovd 0x24(%r9,%rax,2),%xmm3 .byte 196,193,97,196,92,65,40,2 // vpinsrw $0x2,0x28(%r9,%rax,2),%xmm3,%xmm3 .byte 233,151,254,255,255 // jmpq 604d <_sk_load_rgb_u16_be_avx+0x5f> .byte 233,146,254,255,255 // jmpq 604d <_sk_load_rgb_u16_be_avx+0x5f> HIDDEN _sk_store_u16_be_avx .globl _sk_store_u16_be_avx FUNCTION(_sk_store_u16_be_avx) _sk_store_u16_be_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 196,98,125,24,5,202,29,0,0 // vbroadcastss 0x1dca(%rip),%ymm8 # 7fac <_sk_callback_avx+0x53c> .byte 196,65,124,89,200 // vmulps %ymm8,%ymm0,%ymm9 .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 .byte 196,67,125,25,202,1 // vextractf128 $0x1,%ymm9,%xmm10 .byte 196,66,49,43,202 // vpackusdw %xmm10,%xmm9,%xmm9 .byte 196,193,41,113,241,8 // vpsllw $0x8,%xmm9,%xmm10 .byte 196,193,49,113,209,8 // vpsrlw $0x8,%xmm9,%xmm9 .byte 196,65,41,235,201 // vpor %xmm9,%xmm10,%xmm9 .byte 196,65,116,89,208 // vmulps %ymm8,%ymm1,%ymm10 .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 .byte 196,67,125,25,211,1 // vextractf128 $0x1,%ymm10,%xmm11 .byte 196,66,41,43,211 // vpackusdw %xmm11,%xmm10,%xmm10 .byte 196,193,33,113,242,8 // vpsllw $0x8,%xmm10,%xmm11 .byte 196,193,41,113,210,8 // vpsrlw $0x8,%xmm10,%xmm10 .byte 196,65,33,235,210 // vpor %xmm10,%xmm11,%xmm10 .byte 196,65,108,89,216 // vmulps %ymm8,%ymm2,%ymm11 .byte 196,65,125,91,219 // vcvtps2dq %ymm11,%ymm11 .byte 196,67,125,25,220,1 // vextractf128 $0x1,%ymm11,%xmm12 .byte 196,66,33,43,220 // vpackusdw %xmm12,%xmm11,%xmm11 .byte 196,193,25,113,243,8 // vpsllw $0x8,%xmm11,%xmm12 .byte 196,193,33,113,211,8 // vpsrlw $0x8,%xmm11,%xmm11 .byte 196,65,25,235,219 // vpor %xmm11,%xmm12,%xmm11 .byte 196,65,100,89,192 // vmulps %ymm8,%ymm3,%ymm8 .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 .byte 196,67,125,25,196,1 // vextractf128 $0x1,%ymm8,%xmm12 .byte 196,66,57,43,196 // vpackusdw %xmm12,%xmm8,%xmm8 .byte 196,193,25,113,240,8 // vpsllw $0x8,%xmm8,%xmm12 .byte 196,193,57,113,208,8 // vpsrlw $0x8,%xmm8,%xmm8 .byte 196,65,25,235,192 // vpor %xmm8,%xmm12,%xmm8 .byte 196,65,49,97,226 // vpunpcklwd %xmm10,%xmm9,%xmm12 .byte 196,65,49,105,234 // vpunpckhwd %xmm10,%xmm9,%xmm13 .byte 196,65,33,97,200 // vpunpcklwd %xmm8,%xmm11,%xmm9 .byte 196,65,33,105,192 // vpunpckhwd %xmm8,%xmm11,%xmm8 .byte 196,65,25,98,217 // vpunpckldq %xmm9,%xmm12,%xmm11 .byte 196,65,25,106,209 // vpunpckhdq %xmm9,%xmm12,%xmm10 .byte 196,65,17,98,200 // vpunpckldq %xmm8,%xmm13,%xmm9 .byte 196,65,17,106,192 // vpunpckhdq %xmm8,%xmm13,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,31 // jne 62c6 <_sk_store_u16_be_avx+0x10b> .byte 196,65,120,17,28,65 // vmovups %xmm11,(%r9,%rax,2) .byte 196,65,120,17,84,65,16 // vmovups %xmm10,0x10(%r9,%rax,2) .byte 196,65,120,17,76,65,32 // vmovups %xmm9,0x20(%r9,%rax,2) .byte 196,65,122,127,68,65,48 // vmovdqu %xmm8,0x30(%r9,%rax,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,65,121,214,28,65 // vmovq %xmm11,(%r9,%rax,2) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,240 // je 62c2 <_sk_store_u16_be_avx+0x107> .byte 196,65,121,23,92,65,8 // vmovhpd %xmm11,0x8(%r9,%rax,2) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,227 // jb 62c2 <_sk_store_u16_be_avx+0x107> .byte 196,65,121,214,84,65,16 // vmovq %xmm10,0x10(%r9,%rax,2) .byte 116,218 // je 62c2 <_sk_store_u16_be_avx+0x107> .byte 196,65,121,23,84,65,24 // vmovhpd %xmm10,0x18(%r9,%rax,2) .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,205 // jb 62c2 <_sk_store_u16_be_avx+0x107> .byte 196,65,121,214,76,65,32 // vmovq %xmm9,0x20(%r9,%rax,2) .byte 116,196 // je 62c2 <_sk_store_u16_be_avx+0x107> .byte 196,65,121,23,76,65,40 // vmovhpd %xmm9,0x28(%r9,%rax,2) .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,183 // jb 62c2 <_sk_store_u16_be_avx+0x107> .byte 196,65,121,214,68,65,48 // vmovq %xmm8,0x30(%r9,%rax,2) .byte 235,174 // jmp 62c2 <_sk_store_u16_be_avx+0x107> HIDDEN _sk_load_f32_avx .globl _sk_load_f32_avx FUNCTION(_sk_load_f32_avx) _sk_load_f32_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,135,128,0,0,0 // ja 63a0 <_sk_load_f32_avx+0x8c> .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 77,99,210 // movslq %r10d,%r10 .byte 76,141,29,132,0,0,0 // lea 0x84(%rip),%r11 # 63c8 <_sk_load_f32_avx+0xb4> .byte 75,99,4,131 // movslq (%r11,%r8,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,3,125,24,68,145,112,1 // vinsertf128 $0x1,0x70(%r9,%r10,4),%ymm0,%ymm8 .byte 196,131,125,24,92,145,96,1 // vinsertf128 $0x1,0x60(%r9,%r10,4),%ymm0,%ymm3 .byte 196,131,125,24,76,145,80,1 // vinsertf128 $0x1,0x50(%r9,%r10,4),%ymm0,%ymm1 .byte 196,131,125,24,84,145,64,1 // vinsertf128 $0x1,0x40(%r9,%r10,4),%ymm0,%ymm2 .byte 196,129,121,16,68,145,48 // vmovupd 0x30(%r9,%r10,4),%xmm0 .byte 196,195,125,13,192,12 // vblendpd $0xc,%ymm8,%ymm0,%ymm0 .byte 196,1,121,16,68,145,32 // vmovupd 0x20(%r9,%r10,4),%xmm8 .byte 196,99,61,13,203,12 // vblendpd $0xc,%ymm3,%ymm8,%ymm9 .byte 196,129,121,16,92,145,16 // vmovupd 0x10(%r9,%r10,4),%xmm3 .byte 196,99,101,13,209,12 // vblendpd $0xc,%ymm1,%ymm3,%ymm10 .byte 196,129,121,16,12,145 // vmovupd (%r9,%r10,4),%xmm1 .byte 196,227,117,13,202,12 // vblendpd $0xc,%ymm2,%ymm1,%ymm1 .byte 196,193,116,20,210 // vunpcklps %ymm10,%ymm1,%ymm2 .byte 196,193,116,21,218 // vunpckhps %ymm10,%ymm1,%ymm3 .byte 197,180,20,200 // vunpcklps %ymm0,%ymm9,%ymm1 .byte 197,52,21,192 // vunpckhps %ymm0,%ymm9,%ymm8 .byte 197,237,20,193 // vunpcklpd %ymm1,%ymm2,%ymm0 .byte 197,237,21,201 // vunpckhpd %ymm1,%ymm2,%ymm1 .byte 196,193,101,20,208 // vunpcklpd %ymm8,%ymm3,%ymm2 .byte 196,193,101,21,216 // vunpckhpd %ymm8,%ymm3,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 133,255 // test %edi,%edi .byte 255 // (bad) .byte 255,204 // dec %esp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 191,255,255,255,178 // mov $0xb2ffffff,%edi .byte 255 // (bad) .byte 255 // (bad) .byte 255,165,255,255,255,157 // jmpq *-0x62000001(%rbp) .byte 255 // (bad) .byte 255 // (bad) .byte 255,149,255,255,255,141 // callq *-0x72000001(%rbp) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_f32_dst_avx .globl _sk_load_f32_dst_avx FUNCTION(_sk_load_f32_dst_avx) _sk_load_f32_dst_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,131,248,7 // cmp $0x7,%r8 .byte 15,135,128,0,0,0 // ja 6474 <_sk_load_f32_dst_avx+0x8c> .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 77,99,210 // movslq %r10d,%r10 .byte 76,141,29,132,0,0,0 // lea 0x84(%rip),%r11 # 649c <_sk_load_f32_dst_avx+0xb4> .byte 75,99,4,131 // movslq (%r11,%r8,4),%rax .byte 76,1,216 // add %r11,%rax .byte 255,224 // jmpq *%rax .byte 196,3,125,24,68,145,112,1 // vinsertf128 $0x1,0x70(%r9,%r10,4),%ymm0,%ymm8 .byte 196,131,125,24,124,145,96,1 // vinsertf128 $0x1,0x60(%r9,%r10,4),%ymm0,%ymm7 .byte 196,131,125,24,108,145,80,1 // vinsertf128 $0x1,0x50(%r9,%r10,4),%ymm0,%ymm5 .byte 196,131,125,24,116,145,64,1 // vinsertf128 $0x1,0x40(%r9,%r10,4),%ymm0,%ymm6 .byte 196,129,121,16,100,145,48 // vmovupd 0x30(%r9,%r10,4),%xmm4 .byte 196,195,93,13,224,12 // vblendpd $0xc,%ymm8,%ymm4,%ymm4 .byte 196,1,121,16,68,145,32 // vmovupd 0x20(%r9,%r10,4),%xmm8 .byte 196,99,61,13,207,12 // vblendpd $0xc,%ymm7,%ymm8,%ymm9 .byte 196,129,121,16,124,145,16 // vmovupd 0x10(%r9,%r10,4),%xmm7 .byte 196,99,69,13,213,12 // vblendpd $0xc,%ymm5,%ymm7,%ymm10 .byte 196,129,121,16,44,145 // vmovupd (%r9,%r10,4),%xmm5 .byte 196,227,85,13,238,12 // vblendpd $0xc,%ymm6,%ymm5,%ymm5 .byte 196,193,84,20,242 // vunpcklps %ymm10,%ymm5,%ymm6 .byte 196,193,84,21,250 // vunpckhps %ymm10,%ymm5,%ymm7 .byte 197,180,20,236 // vunpcklps %ymm4,%ymm9,%ymm5 .byte 197,52,21,196 // vunpckhps %ymm4,%ymm9,%ymm8 .byte 197,205,20,229 // vunpcklpd %ymm5,%ymm6,%ymm4 .byte 197,205,21,237 // vunpckhpd %ymm5,%ymm6,%ymm5 .byte 196,193,69,20,240 // vunpcklpd %ymm8,%ymm7,%ymm6 .byte 196,193,69,21,248 // vunpckhpd %ymm8,%ymm7,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 133,255 // test %edi,%edi .byte 255 // (bad) .byte 255,204 // dec %esp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 191,255,255,255,178 // mov $0xb2ffffff,%edi .byte 255 // (bad) .byte 255 // (bad) .byte 255,165,255,255,255,157 // jmpq *-0x62000001(%rbp) .byte 255 // (bad) .byte 255 // (bad) .byte 255,149,255,255,255,141 // callq *-0x72000001(%rbp) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_store_f32_avx .globl _sk_store_f32_avx FUNCTION(_sk_store_f32_avx) _sk_store_f32_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 197,124,20,193 // vunpcklps %ymm1,%ymm0,%ymm8 .byte 197,124,21,217 // vunpckhps %ymm1,%ymm0,%ymm11 .byte 197,108,20,203 // vunpcklps %ymm3,%ymm2,%ymm9 .byte 197,108,21,227 // vunpckhps %ymm3,%ymm2,%ymm12 .byte 196,65,61,20,209 // vunpcklpd %ymm9,%ymm8,%ymm10 .byte 196,65,61,21,201 // vunpckhpd %ymm9,%ymm8,%ymm9 .byte 196,65,37,20,196 // vunpcklpd %ymm12,%ymm11,%ymm8 .byte 196,65,37,21,220 // vunpckhpd %ymm12,%ymm11,%ymm11 .byte 77,133,192 // test %r8,%r8 .byte 117,55 // jne 653b <_sk_store_f32_avx+0x7f> .byte 196,67,45,24,225,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm12 .byte 196,67,61,24,235,1 // vinsertf128 $0x1,%xmm11,%ymm8,%ymm13 .byte 196,67,45,6,201,49 // vperm2f128 $0x31,%ymm9,%ymm10,%ymm9 .byte 196,67,61,6,195,49 // vperm2f128 $0x31,%ymm11,%ymm8,%ymm8 .byte 196,65,125,17,36,129 // vmovupd %ymm12,(%r9,%rax,4) .byte 196,65,125,17,108,129,32 // vmovupd %ymm13,0x20(%r9,%rax,4) .byte 196,65,125,17,76,129,64 // vmovupd %ymm9,0x40(%r9,%rax,4) .byte 196,65,125,17,68,129,96 // vmovupd %ymm8,0x60(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 196,65,121,17,20,129 // vmovupd %xmm10,(%r9,%rax,4) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,240 // je 6537 <_sk_store_f32_avx+0x7b> .byte 196,65,121,17,76,129,16 // vmovupd %xmm9,0x10(%r9,%rax,4) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,227 // jb 6537 <_sk_store_f32_avx+0x7b> .byte 196,65,121,17,68,129,32 // vmovupd %xmm8,0x20(%r9,%rax,4) .byte 116,218 // je 6537 <_sk_store_f32_avx+0x7b> .byte 196,65,121,17,92,129,48 // vmovupd %xmm11,0x30(%r9,%rax,4) .byte 73,131,248,5 // cmp $0x5,%r8 .byte 114,205 // jb 6537 <_sk_store_f32_avx+0x7b> .byte 196,67,125,25,84,129,64,1 // vextractf128 $0x1,%ymm10,0x40(%r9,%rax,4) .byte 116,195 // je 6537 <_sk_store_f32_avx+0x7b> .byte 196,67,125,25,76,129,80,1 // vextractf128 $0x1,%ymm9,0x50(%r9,%rax,4) .byte 73,131,248,7 // cmp $0x7,%r8 .byte 114,181 // jb 6537 <_sk_store_f32_avx+0x7b> .byte 196,67,125,25,68,129,96,1 // vextractf128 $0x1,%ymm8,0x60(%r9,%rax,4) .byte 235,171 // jmp 6537 <_sk_store_f32_avx+0x7b> HIDDEN _sk_clamp_x_avx .globl _sk_clamp_x_avx FUNCTION(_sk_clamp_x_avx) _sk_clamp_x_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,95,200 // vmaxps %ymm0,%ymm8,%ymm9 .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 196,99,125,25,192,1 // vextractf128 $0x1,%ymm8,%xmm0 .byte 196,65,41,118,210 // vpcmpeqd %xmm10,%xmm10,%xmm10 .byte 196,193,121,254,194 // vpaddd %xmm10,%xmm0,%xmm0 .byte 196,65,57,254,194 // vpaddd %xmm10,%xmm8,%xmm8 .byte 196,227,61,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm8,%ymm0 .byte 197,180,93,192 // vminps %ymm0,%ymm9,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_y_avx .globl _sk_clamp_y_avx FUNCTION(_sk_clamp_y_avx) _sk_clamp_y_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,95,201 // vmaxps %ymm1,%ymm8,%ymm9 .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 196,99,125,25,193,1 // vextractf128 $0x1,%ymm8,%xmm1 .byte 196,65,41,118,210 // vpcmpeqd %xmm10,%xmm10,%xmm10 .byte 196,193,113,254,202 // vpaddd %xmm10,%xmm1,%xmm1 .byte 196,65,57,254,194 // vpaddd %xmm10,%xmm8,%xmm8 .byte 196,227,61,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm8,%ymm1 .byte 197,180,93,201 // vminps %ymm1,%ymm9,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_x_avx .globl _sk_repeat_x_avx FUNCTION(_sk_repeat_x_avx) _sk_repeat_x_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,4 // vbroadcastss 0x4(%rax),%ymm8 .byte 197,60,89,192 // vmulps %ymm0,%ymm8,%ymm8 .byte 196,67,125,8,192,1 // vroundps $0x1,%ymm8,%ymm8 .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 196,193,124,92,192 // vsubps %ymm8,%ymm0,%ymm0 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,95,192 // vmaxps %ymm0,%ymm8,%ymm8 .byte 196,99,125,25,200,1 // vextractf128 $0x1,%ymm9,%xmm0 .byte 196,65,41,118,210 // vpcmpeqd %xmm10,%xmm10,%xmm10 .byte 196,193,121,254,194 // vpaddd %xmm10,%xmm0,%xmm0 .byte 196,65,49,254,202 // vpaddd %xmm10,%xmm9,%xmm9 .byte 196,227,53,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm9,%ymm0 .byte 197,188,93,192 // vminps %ymm0,%ymm8,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_y_avx .globl _sk_repeat_y_avx FUNCTION(_sk_repeat_y_avx) _sk_repeat_y_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,4 // vbroadcastss 0x4(%rax),%ymm8 .byte 197,60,89,193 // vmulps %ymm1,%ymm8,%ymm8 .byte 196,67,125,8,192,1 // vroundps $0x1,%ymm8,%ymm8 .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 196,193,116,92,200 // vsubps %ymm8,%ymm1,%ymm1 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,95,193 // vmaxps %ymm1,%ymm8,%ymm8 .byte 196,99,125,25,201,1 // vextractf128 $0x1,%ymm9,%xmm1 .byte 196,65,41,118,210 // vpcmpeqd %xmm10,%xmm10,%xmm10 .byte 196,193,113,254,202 // vpaddd %xmm10,%xmm1,%xmm1 .byte 196,65,49,254,202 // vpaddd %xmm10,%xmm9,%xmm9 .byte 196,227,53,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm9,%ymm1 .byte 197,188,93,201 // vminps %ymm1,%ymm8,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_x_avx .globl _sk_mirror_x_avx FUNCTION(_sk_mirror_x_avx) _sk_mirror_x_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,121,110,0 // vmovd (%rax),%xmm8 .byte 197,122,16,72,4 // vmovss 0x4(%rax),%xmm9 .byte 196,65,121,112,208,0 // vpshufd $0x0,%xmm8,%xmm10 .byte 196,67,45,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm10,%ymm10 .byte 196,65,124,92,218 // vsubps %ymm10,%ymm0,%ymm11 .byte 196,193,58,88,192 // vaddss %xmm8,%xmm8,%xmm0 .byte 196,227,121,4,192,0 // vpermilps $0x0,%xmm0,%xmm0 .byte 196,99,125,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm8 .byte 197,178,89,5,239,24,0,0 // vmulss 0x18ef(%rip),%xmm9,%xmm0 # 7fb0 <_sk_callback_avx+0x540> .byte 196,227,121,4,192,0 // vpermilps $0x0,%xmm0,%xmm0 .byte 196,227,125,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm0 .byte 197,164,89,192 // vmulps %ymm0,%ymm11,%ymm0 .byte 196,227,125,8,192,1 // vroundps $0x1,%ymm0,%ymm0 .byte 196,193,124,89,192 // vmulps %ymm8,%ymm0,%ymm0 .byte 197,164,92,192 // vsubps %ymm0,%ymm11,%ymm0 .byte 196,193,124,92,194 // vsubps %ymm10,%ymm0,%ymm0 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,92,200 // vsubps %ymm0,%ymm8,%ymm9 .byte 197,180,84,192 // vandps %ymm0,%ymm9,%ymm0 .byte 197,60,95,192 // vmaxps %ymm0,%ymm8,%ymm8 .byte 196,99,125,25,208,1 // vextractf128 $0x1,%ymm10,%xmm0 .byte 196,65,49,118,201 // vpcmpeqd %xmm9,%xmm9,%xmm9 .byte 196,193,121,254,193 // vpaddd %xmm9,%xmm0,%xmm0 .byte 196,65,41,254,201 // vpaddd %xmm9,%xmm10,%xmm9 .byte 196,227,53,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm9,%ymm0 .byte 197,188,93,192 // vminps %ymm0,%ymm8,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_y_avx .globl _sk_mirror_y_avx FUNCTION(_sk_mirror_y_avx) _sk_mirror_y_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,121,110,0 // vmovd (%rax),%xmm8 .byte 197,122,16,72,4 // vmovss 0x4(%rax),%xmm9 .byte 196,65,121,112,208,0 // vpshufd $0x0,%xmm8,%xmm10 .byte 196,67,45,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm10,%ymm10 .byte 196,65,116,92,218 // vsubps %ymm10,%ymm1,%ymm11 .byte 196,193,58,88,200 // vaddss %xmm8,%xmm8,%xmm1 .byte 196,227,121,4,201,0 // vpermilps $0x0,%xmm1,%xmm1 .byte 196,99,117,24,193,1 // vinsertf128 $0x1,%xmm1,%ymm1,%ymm8 .byte 197,178,89,13,102,24,0,0 // vmulss 0x1866(%rip),%xmm9,%xmm1 # 7fb4 <_sk_callback_avx+0x544> .byte 196,227,121,4,201,0 // vpermilps $0x0,%xmm1,%xmm1 .byte 196,227,117,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm1,%ymm1 .byte 197,164,89,201 // vmulps %ymm1,%ymm11,%ymm1 .byte 196,227,125,8,201,1 // vroundps $0x1,%ymm1,%ymm1 .byte 196,193,116,89,200 // vmulps %ymm8,%ymm1,%ymm1 .byte 197,164,92,201 // vsubps %ymm1,%ymm11,%ymm1 .byte 196,193,116,92,202 // vsubps %ymm10,%ymm1,%ymm1 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,92,201 // vsubps %ymm1,%ymm8,%ymm9 .byte 197,180,84,201 // vandps %ymm1,%ymm9,%ymm1 .byte 197,60,95,193 // vmaxps %ymm1,%ymm8,%ymm8 .byte 196,99,125,25,209,1 // vextractf128 $0x1,%ymm10,%xmm1 .byte 196,65,49,118,201 // vpcmpeqd %xmm9,%xmm9,%xmm9 .byte 196,193,113,254,201 // vpaddd %xmm9,%xmm1,%xmm1 .byte 196,65,41,254,201 // vpaddd %xmm9,%xmm10,%xmm9 .byte 196,227,53,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm9,%ymm1 .byte 197,188,93,201 // vminps %ymm1,%ymm8,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_x_1_avx .globl _sk_clamp_x_1_avx FUNCTION(_sk_clamp_x_1_avx) _sk_clamp_x_1_avx: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,188,95,192 // vmaxps %ymm0,%ymm8,%ymm0 .byte 196,98,125,24,5,0,24,0,0 // vbroadcastss 0x1800(%rip),%ymm8 # 7fb8 <_sk_callback_avx+0x548> .byte 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_x_1_avx .globl _sk_repeat_x_1_avx FUNCTION(_sk_repeat_x_1_avx) _sk_repeat_x_1_avx: .byte 196,99,125,8,192,1 // vroundps $0x1,%ymm0,%ymm8 .byte 196,193,124,92,192 // vsubps %ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_x_1_avx .globl _sk_mirror_x_1_avx FUNCTION(_sk_mirror_x_1_avx) _sk_mirror_x_1_avx: .byte 196,98,125,24,5,227,23,0,0 // vbroadcastss 0x17e3(%rip),%ymm8 # 7fbc <_sk_callback_avx+0x54c> .byte 196,193,124,88,192 // vaddps %ymm8,%ymm0,%ymm0 .byte 196,98,125,24,13,217,23,0,0 // vbroadcastss 0x17d9(%rip),%ymm9 # 7fc0 <_sk_callback_avx+0x550> .byte 196,65,124,89,201 // vmulps %ymm9,%ymm0,%ymm9 .byte 196,67,125,8,201,1 // vroundps $0x1,%ymm9,%ymm9 .byte 196,65,52,88,201 // vaddps %ymm9,%ymm9,%ymm9 .byte 196,193,124,92,193 // vsubps %ymm9,%ymm0,%ymm0 .byte 196,193,124,88,192 // vaddps %ymm8,%ymm0,%ymm0 .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,92,192 // vsubps %ymm0,%ymm8,%ymm8 .byte 197,188,84,192 // vandps %ymm0,%ymm8,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_luminance_to_alpha_avx .globl _sk_luminance_to_alpha_avx FUNCTION(_sk_luminance_to_alpha_avx) _sk_luminance_to_alpha_avx: .byte 196,226,125,24,29,169,23,0,0 // vbroadcastss 0x17a9(%rip),%ymm3 # 7fc4 <_sk_callback_avx+0x554> .byte 197,252,89,195 // vmulps %ymm3,%ymm0,%ymm0 .byte 196,226,125,24,29,160,23,0,0 // vbroadcastss 0x17a0(%rip),%ymm3 # 7fc8 <_sk_callback_avx+0x558> .byte 197,244,89,203 // vmulps %ymm3,%ymm1,%ymm1 .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 196,226,125,24,13,147,23,0,0 // vbroadcastss 0x1793(%rip),%ymm1 # 7fcc <_sk_callback_avx+0x55c> .byte 197,236,89,201 // vmulps %ymm1,%ymm2,%ymm1 .byte 197,252,88,217 // vaddps %ymm1,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 197,236,87,210 // vxorps %ymm2,%ymm2,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_translate_avx .globl _sk_matrix_translate_avx FUNCTION(_sk_matrix_translate_avx) _sk_matrix_translate_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 197,188,88,192 // vaddps %ymm0,%ymm8,%ymm0 .byte 196,98,125,24,64,4 // vbroadcastss 0x4(%rax),%ymm8 .byte 197,188,88,201 // vaddps %ymm1,%ymm8,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_scale_translate_avx .globl _sk_matrix_scale_translate_avx FUNCTION(_sk_matrix_scale_translate_avx) _sk_matrix_scale_translate_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,8 // vbroadcastss 0x8(%rax),%ymm8 .byte 196,98,125,24,8 // vbroadcastss (%rax),%ymm9 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 196,193,124,88,193 // vaddps %ymm9,%ymm0,%ymm0 .byte 196,98,125,24,64,12 // vbroadcastss 0xc(%rax),%ymm8 .byte 196,98,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm9 .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 .byte 196,193,116,88,201 // vaddps %ymm9,%ymm1,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_2x3_avx .globl _sk_matrix_2x3_avx FUNCTION(_sk_matrix_2x3_avx) _sk_matrix_2x3_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 196,98,125,24,72,8 // vbroadcastss 0x8(%rax),%ymm9 .byte 196,98,125,24,80,16 // vbroadcastss 0x10(%rax),%ymm10 .byte 197,52,89,201 // vmulps %ymm1,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 197,60,89,192 // vmulps %ymm0,%ymm8,%ymm8 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 196,98,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm9 .byte 196,98,125,24,80,12 // vbroadcastss 0xc(%rax),%ymm10 .byte 196,98,125,24,88,20 // vbroadcastss 0x14(%rax),%ymm11 .byte 197,172,89,201 // vmulps %ymm1,%ymm10,%ymm1 .byte 196,193,116,88,203 // vaddps %ymm11,%ymm1,%ymm1 .byte 197,180,89,192 // vmulps %ymm0,%ymm9,%ymm0 .byte 197,252,88,201 // vaddps %ymm1,%ymm0,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_3x4_avx .globl _sk_matrix_3x4_avx FUNCTION(_sk_matrix_3x4_avx) _sk_matrix_3x4_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 196,98,125,24,88,36 // vbroadcastss 0x24(%rax),%ymm11 .byte 197,44,89,210 // vmulps %ymm2,%ymm10,%ymm10 .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 197,52,89,201 // vmulps %ymm1,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 197,60,89,192 // vmulps %ymm0,%ymm8,%ymm8 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 196,98,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm9 .byte 196,98,125,24,80,16 // vbroadcastss 0x10(%rax),%ymm10 .byte 196,98,125,24,88,28 // vbroadcastss 0x1c(%rax),%ymm11 .byte 196,98,125,24,96,40 // vbroadcastss 0x28(%rax),%ymm12 .byte 197,36,89,218 // vmulps %ymm2,%ymm11,%ymm11 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 197,44,89,209 // vmulps %ymm1,%ymm10,%ymm10 .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 197,52,89,200 // vmulps %ymm0,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm10 .byte 196,98,125,24,88,20 // vbroadcastss 0x14(%rax),%ymm11 .byte 196,98,125,24,96,32 // vbroadcastss 0x20(%rax),%ymm12 .byte 196,98,125,24,104,44 // vbroadcastss 0x2c(%rax),%ymm13 .byte 197,156,89,210 // vmulps %ymm2,%ymm12,%ymm2 .byte 196,193,108,88,213 // vaddps %ymm13,%ymm2,%ymm2 .byte 197,164,89,201 // vmulps %ymm1,%ymm11,%ymm1 .byte 197,244,88,202 // vaddps %ymm2,%ymm1,%ymm1 .byte 197,172,89,192 // vmulps %ymm0,%ymm10,%ymm0 .byte 197,252,88,209 // vaddps %ymm1,%ymm0,%ymm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,124,41,201 // vmovaps %ymm9,%ymm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_4x5_avx .globl _sk_matrix_4x5_avx FUNCTION(_sk_matrix_4x5_avx) _sk_matrix_4x5_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 196,98,125,24,72,16 // vbroadcastss 0x10(%rax),%ymm9 .byte 196,98,125,24,80,32 // vbroadcastss 0x20(%rax),%ymm10 .byte 196,98,125,24,88,48 // vbroadcastss 0x30(%rax),%ymm11 .byte 196,98,125,24,96,64 // vbroadcastss 0x40(%rax),%ymm12 .byte 197,36,89,219 // vmulps %ymm3,%ymm11,%ymm11 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 197,44,89,210 // vmulps %ymm2,%ymm10,%ymm10 .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 197,52,89,201 // vmulps %ymm1,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 197,60,89,192 // vmulps %ymm0,%ymm8,%ymm8 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 196,98,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm9 .byte 196,98,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm10 .byte 196,98,125,24,88,36 // vbroadcastss 0x24(%rax),%ymm11 .byte 196,98,125,24,96,52 // vbroadcastss 0x34(%rax),%ymm12 .byte 196,98,125,24,104,68 // vbroadcastss 0x44(%rax),%ymm13 .byte 197,28,89,227 // vmulps %ymm3,%ymm12,%ymm12 .byte 196,65,28,88,229 // vaddps %ymm13,%ymm12,%ymm12 .byte 197,36,89,218 // vmulps %ymm2,%ymm11,%ymm11 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 197,44,89,209 // vmulps %ymm1,%ymm10,%ymm10 .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 197,52,89,200 // vmulps %ymm0,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm10 .byte 196,98,125,24,88,24 // vbroadcastss 0x18(%rax),%ymm11 .byte 196,98,125,24,96,40 // vbroadcastss 0x28(%rax),%ymm12 .byte 196,98,125,24,104,56 // vbroadcastss 0x38(%rax),%ymm13 .byte 196,98,125,24,112,72 // vbroadcastss 0x48(%rax),%ymm14 .byte 197,20,89,235 // vmulps %ymm3,%ymm13,%ymm13 .byte 196,65,20,88,238 // vaddps %ymm14,%ymm13,%ymm13 .byte 197,28,89,226 // vmulps %ymm2,%ymm12,%ymm12 .byte 196,65,28,88,229 // vaddps %ymm13,%ymm12,%ymm12 .byte 197,36,89,217 // vmulps %ymm1,%ymm11,%ymm11 .byte 196,65,36,88,220 // vaddps %ymm12,%ymm11,%ymm11 .byte 197,44,89,208 // vmulps %ymm0,%ymm10,%ymm10 .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 196,98,125,24,88,12 // vbroadcastss 0xc(%rax),%ymm11 .byte 196,98,125,24,96,28 // vbroadcastss 0x1c(%rax),%ymm12 .byte 196,98,125,24,104,44 // vbroadcastss 0x2c(%rax),%ymm13 .byte 196,98,125,24,112,60 // vbroadcastss 0x3c(%rax),%ymm14 .byte 196,98,125,24,120,76 // vbroadcastss 0x4c(%rax),%ymm15 .byte 197,140,89,219 // vmulps %ymm3,%ymm14,%ymm3 .byte 196,193,100,88,223 // vaddps %ymm15,%ymm3,%ymm3 .byte 197,148,89,210 // vmulps %ymm2,%ymm13,%ymm2 .byte 197,236,88,211 // vaddps %ymm3,%ymm2,%ymm2 .byte 197,156,89,201 // vmulps %ymm1,%ymm12,%ymm1 .byte 197,244,88,202 // vaddps %ymm2,%ymm1,%ymm1 .byte 197,164,89,192 // vmulps %ymm0,%ymm11,%ymm0 .byte 197,252,88,217 // vaddps %ymm1,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,124,41,201 // vmovaps %ymm9,%ymm1 .byte 197,124,41,210 // vmovaps %ymm10,%ymm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_4x3_avx .globl _sk_matrix_4x3_avx FUNCTION(_sk_matrix_4x3_avx) _sk_matrix_4x3_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,16 // vbroadcastss (%rax),%ymm2 .byte 196,226,125,24,88,16 // vbroadcastss 0x10(%rax),%ymm3 .byte 196,98,125,24,64,32 // vbroadcastss 0x20(%rax),%ymm8 .byte 197,228,89,217 // vmulps %ymm1,%ymm3,%ymm3 .byte 196,193,100,88,216 // vaddps %ymm8,%ymm3,%ymm3 .byte 197,236,89,208 // vmulps %ymm0,%ymm2,%ymm2 .byte 197,108,88,195 // vaddps %ymm3,%ymm2,%ymm8 .byte 196,226,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm2 .byte 196,226,125,24,88,20 // vbroadcastss 0x14(%rax),%ymm3 .byte 196,98,125,24,72,36 // vbroadcastss 0x24(%rax),%ymm9 .byte 197,228,89,217 // vmulps %ymm1,%ymm3,%ymm3 .byte 196,193,100,88,217 // vaddps %ymm9,%ymm3,%ymm3 .byte 197,236,89,208 // vmulps %ymm0,%ymm2,%ymm2 .byte 197,108,88,203 // vaddps %ymm3,%ymm2,%ymm9 .byte 196,226,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm2 .byte 196,226,125,24,88,24 // vbroadcastss 0x18(%rax),%ymm3 .byte 196,98,125,24,80,40 // vbroadcastss 0x28(%rax),%ymm10 .byte 197,228,89,217 // vmulps %ymm1,%ymm3,%ymm3 .byte 196,193,100,88,218 // vaddps %ymm10,%ymm3,%ymm3 .byte 197,236,89,208 // vmulps %ymm0,%ymm2,%ymm2 .byte 197,236,88,211 // vaddps %ymm3,%ymm2,%ymm2 .byte 196,226,125,24,88,12 // vbroadcastss 0xc(%rax),%ymm3 .byte 196,98,125,24,80,28 // vbroadcastss 0x1c(%rax),%ymm10 .byte 196,98,125,24,88,44 // vbroadcastss 0x2c(%rax),%ymm11 .byte 197,172,89,201 // vmulps %ymm1,%ymm10,%ymm1 .byte 196,193,116,88,203 // vaddps %ymm11,%ymm1,%ymm1 .byte 197,228,89,192 // vmulps %ymm0,%ymm3,%ymm0 .byte 197,252,88,217 // vaddps %ymm1,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,124,41,201 // vmovaps %ymm9,%ymm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_perspective_avx .globl _sk_matrix_perspective_avx FUNCTION(_sk_matrix_perspective_avx) _sk_matrix_perspective_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 .byte 196,98,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm9 .byte 196,98,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm10 .byte 197,52,89,201 // vmulps %ymm1,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 197,60,89,192 // vmulps %ymm0,%ymm8,%ymm8 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 .byte 196,98,125,24,80,16 // vbroadcastss 0x10(%rax),%ymm10 .byte 196,98,125,24,88,20 // vbroadcastss 0x14(%rax),%ymm11 .byte 197,44,89,209 // vmulps %ymm1,%ymm10,%ymm10 .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 197,52,89,200 // vmulps %ymm0,%ymm9,%ymm9 .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm10 .byte 196,98,125,24,88,28 // vbroadcastss 0x1c(%rax),%ymm11 .byte 196,98,125,24,96,32 // vbroadcastss 0x20(%rax),%ymm12 .byte 197,164,89,201 // vmulps %ymm1,%ymm11,%ymm1 .byte 196,193,116,88,204 // vaddps %ymm12,%ymm1,%ymm1 .byte 197,172,89,192 // vmulps %ymm0,%ymm10,%ymm0 .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 197,252,83,200 // vrcpps %ymm0,%ymm1 .byte 197,188,89,193 // vmulps %ymm1,%ymm8,%ymm0 .byte 197,180,89,201 // vmulps %ymm1,%ymm9,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_evenly_spaced_gradient_avx .globl _sk_evenly_spaced_gradient_avx FUNCTION(_sk_evenly_spaced_gradient_avx) _sk_evenly_spaced_gradient_avx: .byte 85 // push %rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 197,252,17,124,36,216 // vmovups %ymm7,-0x28(%rsp) .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,139,24 // mov (%rax),%rbx .byte 72,139,104,8 // mov 0x8(%rax),%rbp .byte 72,255,203 // dec %rbx .byte 120,7 // js 6bdd <_sk_evenly_spaced_gradient_avx+0x25> .byte 196,225,242,42,203 // vcvtsi2ss %rbx,%xmm1,%xmm1 .byte 235,21 // jmp 6bf2 <_sk_evenly_spaced_gradient_avx+0x3a> .byte 73,137,217 // mov %rbx,%r9 .byte 73,209,233 // shr %r9 .byte 131,227,1 // and $0x1,%ebx .byte 76,9,203 // or %r9,%rbx .byte 196,225,242,42,203 // vcvtsi2ss %rbx,%xmm1,%xmm1 .byte 197,242,88,201 // vaddss %xmm1,%xmm1,%xmm1 .byte 196,227,121,4,201,0 // vpermilps $0x0,%xmm1,%xmm1 .byte 196,227,117,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm1,%ymm1 .byte 197,244,89,200 // vmulps %ymm0,%ymm1,%ymm1 .byte 197,254,91,201 // vcvttps2dq %ymm1,%ymm1 .byte 196,195,249,22,201,1 // vpextrq $0x1,%xmm1,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,193,249,126,203 // vmovq %xmm1,%r11 .byte 69,137,222 // mov %r11d,%r14d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 196,195,249,22,204,1 // vpextrq $0x1,%xmm1,%r12 .byte 69,137,231 // mov %r12d,%r15d .byte 73,193,236,32 // shr $0x20,%r12 .byte 196,225,249,126,203 // vmovq %xmm1,%rbx .byte 65,137,221 // mov %ebx,%r13d .byte 72,193,235,32 // shr $0x20,%rbx .byte 196,161,122,16,76,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm1 .byte 196,227,113,33,76,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm1,%xmm1 .byte 196,161,122,16,84,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm2 .byte 196,33,122,16,68,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm8 .byte 196,161,122,16,92,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm3 .byte 196,35,97,33,76,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm3,%xmm9 .byte 196,161,122,16,124,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm7 .byte 196,33,122,16,92,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm11 .byte 196,99,113,33,226,32 // vinsertps $0x20,%xmm2,%xmm1,%xmm12 .byte 72,139,104,40 // mov 0x28(%rax),%rbp .byte 196,161,122,16,84,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm2 .byte 196,99,105,33,108,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm2,%xmm13 .byte 196,161,122,16,92,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm3 .byte 196,161,122,16,76,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm1 .byte 196,161,122,16,84,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm2 .byte 196,35,105,33,116,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm2,%xmm14 .byte 196,33,122,16,124,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm15 .byte 196,33,122,16,84,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm10 .byte 196,67,25,33,192,48 // vinsertps $0x30,%xmm8,%xmm12,%xmm8 .byte 196,227,49,33,215,32 // vinsertps $0x20,%xmm7,%xmm9,%xmm2 .byte 196,195,105,33,211,48 // vinsertps $0x30,%xmm11,%xmm2,%xmm2 .byte 196,67,109,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm2,%ymm8 .byte 196,227,17,33,211,32 // vinsertps $0x20,%xmm3,%xmm13,%xmm2 .byte 196,99,105,33,201,48 // vinsertps $0x30,%xmm1,%xmm2,%xmm9 .byte 72,139,104,16 // mov 0x10(%rax),%rbp .byte 196,161,122,16,84,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm2 .byte 196,99,105,33,92,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm2,%xmm11 .byte 196,33,122,16,100,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm12 .byte 196,161,122,16,76,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm1 .byte 196,161,122,16,124,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm7 .byte 196,163,65,33,124,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm7,%xmm7 .byte 196,161,122,16,92,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm3 .byte 196,33,122,16,108,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm13 .byte 196,195,9,33,215,32 // vinsertps $0x20,%xmm15,%xmm14,%xmm2 .byte 196,195,105,33,210,48 // vinsertps $0x30,%xmm10,%xmm2,%xmm2 .byte 196,67,109,24,241,1 // vinsertf128 $0x1,%xmm9,%ymm2,%ymm14 .byte 196,195,33,33,212,32 // vinsertps $0x20,%xmm12,%xmm11,%xmm2 .byte 196,99,105,33,201,48 // vinsertps $0x30,%xmm1,%xmm2,%xmm9 .byte 196,99,65,33,211,32 // vinsertps $0x20,%xmm3,%xmm7,%xmm10 .byte 72,139,104,48 // mov 0x30(%rax),%rbp .byte 196,161,122,16,92,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm3 .byte 196,99,97,33,92,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm3,%xmm11 .byte 196,33,122,16,124,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm15 .byte 196,33,122,16,100,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm12 .byte 196,161,122,16,84,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm2 .byte 196,163,105,33,84,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm2,%xmm2 .byte 196,161,122,16,124,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm7 .byte 196,161,122,16,92,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm3 .byte 196,67,41,33,213,48 // vinsertps $0x30,%xmm13,%xmm10,%xmm10 .byte 196,67,45,24,233,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm13 .byte 196,195,33,33,207,32 // vinsertps $0x20,%xmm15,%xmm11,%xmm1 .byte 196,67,113,33,204,48 // vinsertps $0x30,%xmm12,%xmm1,%xmm9 .byte 196,227,105,33,215,32 // vinsertps $0x20,%xmm7,%xmm2,%xmm2 .byte 196,99,105,33,211,48 // vinsertps $0x30,%xmm3,%xmm2,%xmm10 .byte 72,139,104,24 // mov 0x18(%rax),%rbp .byte 196,161,122,16,92,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm3 .byte 196,99,97,33,92,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm3,%xmm11 .byte 196,33,122,16,100,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm12 .byte 196,33,122,16,124,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm15 .byte 196,161,122,16,84,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm2 .byte 196,163,105,33,84,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm2,%xmm2 .byte 196,161,122,16,92,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm3 .byte 196,161,122,16,124,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm7 .byte 196,67,45,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm9 .byte 196,195,33,33,204,32 // vinsertps $0x20,%xmm12,%xmm11,%xmm1 .byte 196,195,113,33,207,48 // vinsertps $0x30,%xmm15,%xmm1,%xmm1 .byte 196,227,105,33,211,32 // vinsertps $0x20,%xmm3,%xmm2,%xmm2 .byte 196,227,105,33,215,48 // vinsertps $0x30,%xmm7,%xmm2,%xmm2 .byte 196,99,109,24,209,1 // vinsertf128 $0x1,%xmm1,%ymm2,%ymm10 .byte 72,139,104,56 // mov 0x38(%rax),%rbp .byte 196,161,122,16,76,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm1 .byte 196,99,113,33,92,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm1,%xmm11 .byte 196,33,122,16,100,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm12 .byte 196,33,122,16,124,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm15 .byte 196,161,122,16,124,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm7 .byte 196,163,65,33,124,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm7,%xmm7 .byte 196,161,122,16,76,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm1 .byte 196,161,122,16,84,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm2 .byte 196,195,33,33,220,32 // vinsertps $0x20,%xmm12,%xmm11,%xmm3 .byte 196,195,97,33,223,48 // vinsertps $0x30,%xmm15,%xmm3,%xmm3 .byte 196,227,65,33,201,32 // vinsertps $0x20,%xmm1,%xmm7,%xmm1 .byte 196,227,113,33,202,48 // vinsertps $0x30,%xmm2,%xmm1,%xmm1 .byte 196,99,117,24,219,1 // vinsertf128 $0x1,%xmm3,%ymm1,%ymm11 .byte 72,139,104,32 // mov 0x20(%rax),%rbp .byte 196,161,122,16,76,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm1 .byte 196,227,113,33,76,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm1,%xmm1 .byte 196,161,122,16,84,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm2 .byte 196,227,113,33,202,32 // vinsertps $0x20,%xmm2,%xmm1,%xmm1 .byte 196,161,122,16,84,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm2 .byte 196,161,122,16,92,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm3 .byte 196,35,97,33,100,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm3,%xmm12 .byte 196,161,122,16,124,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm7 .byte 196,161,122,16,92,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm3 .byte 196,99,113,33,250,48 // vinsertps $0x30,%xmm2,%xmm1,%xmm15 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 196,161,122,16,20,168 // vmovss (%rax,%r13,4),%xmm2 .byte 196,227,105,33,20,152,16 // vinsertps $0x10,(%rax,%rbx,4),%xmm2,%xmm2 .byte 196,227,25,33,255,32 // vinsertps $0x20,%xmm7,%xmm12,%xmm7 .byte 196,161,122,16,12,184 // vmovss (%rax,%r15,4),%xmm1 .byte 196,227,65,33,219,48 // vinsertps $0x30,%xmm3,%xmm7,%xmm3 .byte 196,161,122,16,60,160 // vmovss (%rax,%r12,4),%xmm7 .byte 196,67,101,24,231,1 // vinsertf128 $0x1,%xmm15,%ymm3,%ymm12 .byte 196,161,122,16,28,176 // vmovss (%rax,%r14,4),%xmm3 .byte 196,163,97,33,28,152,16 // vinsertps $0x10,(%rax,%r11,4),%xmm3,%xmm3 .byte 196,227,105,33,201,32 // vinsertps $0x20,%xmm1,%xmm2,%xmm1 .byte 196,161,122,16,20,144 // vmovss (%rax,%r10,4),%xmm2 .byte 196,227,113,33,207,48 // vinsertps $0x30,%xmm7,%xmm1,%xmm1 .byte 196,161,122,16,60,136 // vmovss (%rax,%r9,4),%xmm7 .byte 196,227,97,33,210,32 // vinsertps $0x20,%xmm2,%xmm3,%xmm2 .byte 196,227,105,33,215,48 // vinsertps $0x30,%xmm7,%xmm2,%xmm2 .byte 196,227,109,24,217,1 // vinsertf128 $0x1,%xmm1,%ymm2,%ymm3 .byte 197,188,89,200 // vmulps %ymm0,%ymm8,%ymm1 .byte 196,65,116,88,198 // vaddps %ymm14,%ymm1,%ymm8 .byte 197,148,89,200 // vmulps %ymm0,%ymm13,%ymm1 .byte 196,193,116,88,201 // vaddps %ymm9,%ymm1,%ymm1 .byte 197,172,89,208 // vmulps %ymm0,%ymm10,%ymm2 .byte 196,193,108,88,211 // vaddps %ymm11,%ymm2,%ymm2 .byte 197,156,89,192 // vmulps %ymm0,%ymm12,%ymm0 .byte 197,252,88,219 // vaddps %ymm3,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,252,16,124,36,216 // vmovups -0x28(%rsp),%ymm7 .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax HIDDEN _sk_gauss_a_to_rgba_avx .globl _sk_gauss_a_to_rgba_avx FUNCTION(_sk_gauss_a_to_rgba_avx) _sk_gauss_a_to_rgba_avx: .byte 196,226,125,24,5,122,16,0,0 // vbroadcastss 0x107a(%rip),%ymm0 # 7fd0 <_sk_callback_avx+0x560> .byte 197,228,89,192 // vmulps %ymm0,%ymm3,%ymm0 .byte 196,226,125,24,13,113,16,0,0 // vbroadcastss 0x1071(%rip),%ymm1 # 7fd4 <_sk_callback_avx+0x564> .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 197,252,89,195 // vmulps %ymm3,%ymm0,%ymm0 .byte 196,226,125,24,13,100,16,0,0 // vbroadcastss 0x1064(%rip),%ymm1 # 7fd8 <_sk_callback_avx+0x568> .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 197,252,89,195 // vmulps %ymm3,%ymm0,%ymm0 .byte 196,226,125,24,13,87,16,0,0 // vbroadcastss 0x1057(%rip),%ymm1 # 7fdc <_sk_callback_avx+0x56c> .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 197,252,89,195 // vmulps %ymm3,%ymm0,%ymm0 .byte 196,226,125,24,13,74,16,0,0 // vbroadcastss 0x104a(%rip),%ymm1 # 7fe0 <_sk_callback_avx+0x570> .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 197,252,40,208 // vmovaps %ymm0,%ymm2 .byte 197,252,40,216 // vmovaps %ymm0,%ymm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_gradient_avx .globl _sk_gradient_avx FUNCTION(_sk_gradient_avx) _sk_gradient_avx: .byte 85 // push %rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 197,252,17,124,36,216 // vmovups %ymm7,-0x28(%rsp) .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 73,131,249,2 // cmp $0x2,%r9 .byte 114,80 // jb 7019 <_sk_gradient_avx+0x6f> .byte 72,139,88,72 // mov 0x48(%rax),%rbx .byte 73,255,201 // dec %r9 .byte 72,131,195,4 // add $0x4,%rbx .byte 196,65,52,87,201 // vxorps %ymm9,%ymm9,%ymm9 .byte 196,98,125,24,21,2,16,0,0 // vbroadcastss 0x1002(%rip),%ymm10 # 7fe4 <_sk_callback_avx+0x574> .byte 197,244,87,201 // vxorps %ymm1,%ymm1,%ymm1 .byte 196,98,125,24,3 // vbroadcastss (%rbx),%ymm8 .byte 197,60,194,192,2 // vcmpleps %ymm0,%ymm8,%ymm8 .byte 196,67,53,74,194,128 // vblendvps %ymm8,%ymm10,%ymm9,%ymm8 .byte 196,99,125,25,194,1 // vextractf128 $0x1,%ymm8,%xmm2 .byte 196,227,125,25,203,1 // vextractf128 $0x1,%ymm1,%xmm3 .byte 197,233,254,211 // vpaddd %xmm3,%xmm2,%xmm2 .byte 197,185,254,201 // vpaddd %xmm1,%xmm8,%xmm1 .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 .byte 72,131,195,4 // add $0x4,%rbx .byte 73,255,201 // dec %r9 .byte 117,205 // jne 6fe6 <_sk_gradient_avx+0x3c> .byte 196,195,249,22,201,1 // vpextrq $0x1,%xmm1,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 73,193,233,32 // shr $0x20,%r9 .byte 196,193,249,126,203 // vmovq %xmm1,%r11 .byte 69,137,222 // mov %r11d,%r14d .byte 73,193,235,32 // shr $0x20,%r11 .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 .byte 196,195,249,22,204,1 // vpextrq $0x1,%xmm1,%r12 .byte 69,137,231 // mov %r12d,%r15d .byte 73,193,236,32 // shr $0x20,%r12 .byte 196,225,249,126,203 // vmovq %xmm1,%rbx .byte 65,137,221 // mov %ebx,%r13d .byte 72,193,235,32 // shr $0x20,%rbx .byte 72,139,104,8 // mov 0x8(%rax),%rbp .byte 196,161,122,16,76,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm1 .byte 196,227,113,33,76,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm1,%xmm1 .byte 196,161,122,16,84,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm2 .byte 196,33,122,16,68,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm8 .byte 196,161,122,16,92,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm3 .byte 196,35,97,33,76,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm3,%xmm9 .byte 196,161,122,16,124,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm7 .byte 196,33,122,16,92,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm11 .byte 196,99,113,33,226,32 // vinsertps $0x20,%xmm2,%xmm1,%xmm12 .byte 72,139,104,40 // mov 0x28(%rax),%rbp .byte 196,161,122,16,84,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm2 .byte 196,99,105,33,108,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm2,%xmm13 .byte 196,161,122,16,92,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm3 .byte 196,161,122,16,76,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm1 .byte 196,161,122,16,84,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm2 .byte 196,35,105,33,116,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm2,%xmm14 .byte 196,33,122,16,124,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm15 .byte 196,33,122,16,84,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm10 .byte 196,67,25,33,192,48 // vinsertps $0x30,%xmm8,%xmm12,%xmm8 .byte 196,227,49,33,215,32 // vinsertps $0x20,%xmm7,%xmm9,%xmm2 .byte 196,195,105,33,211,48 // vinsertps $0x30,%xmm11,%xmm2,%xmm2 .byte 196,67,109,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm2,%ymm8 .byte 196,227,17,33,211,32 // vinsertps $0x20,%xmm3,%xmm13,%xmm2 .byte 196,99,105,33,201,48 // vinsertps $0x30,%xmm1,%xmm2,%xmm9 .byte 72,139,104,16 // mov 0x10(%rax),%rbp .byte 196,161,122,16,84,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm2 .byte 196,99,105,33,92,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm2,%xmm11 .byte 196,33,122,16,100,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm12 .byte 196,161,122,16,76,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm1 .byte 196,161,122,16,124,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm7 .byte 196,163,65,33,124,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm7,%xmm7 .byte 196,161,122,16,92,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm3 .byte 196,33,122,16,108,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm13 .byte 196,195,9,33,215,32 // vinsertps $0x20,%xmm15,%xmm14,%xmm2 .byte 196,195,105,33,210,48 // vinsertps $0x30,%xmm10,%xmm2,%xmm2 .byte 196,67,109,24,241,1 // vinsertf128 $0x1,%xmm9,%ymm2,%ymm14 .byte 196,195,33,33,212,32 // vinsertps $0x20,%xmm12,%xmm11,%xmm2 .byte 196,99,105,33,201,48 // vinsertps $0x30,%xmm1,%xmm2,%xmm9 .byte 196,99,65,33,211,32 // vinsertps $0x20,%xmm3,%xmm7,%xmm10 .byte 72,139,104,48 // mov 0x30(%rax),%rbp .byte 196,161,122,16,92,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm3 .byte 196,99,97,33,92,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm3,%xmm11 .byte 196,33,122,16,124,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm15 .byte 196,33,122,16,100,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm12 .byte 196,161,122,16,84,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm2 .byte 196,163,105,33,84,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm2,%xmm2 .byte 196,161,122,16,124,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm7 .byte 196,161,122,16,92,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm3 .byte 196,67,41,33,213,48 // vinsertps $0x30,%xmm13,%xmm10,%xmm10 .byte 196,67,45,24,233,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm13 .byte 196,195,33,33,207,32 // vinsertps $0x20,%xmm15,%xmm11,%xmm1 .byte 196,67,113,33,204,48 // vinsertps $0x30,%xmm12,%xmm1,%xmm9 .byte 196,227,105,33,215,32 // vinsertps $0x20,%xmm7,%xmm2,%xmm2 .byte 196,99,105,33,211,48 // vinsertps $0x30,%xmm3,%xmm2,%xmm10 .byte 72,139,104,24 // mov 0x18(%rax),%rbp .byte 196,161,122,16,92,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm3 .byte 196,99,97,33,92,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm3,%xmm11 .byte 196,33,122,16,100,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm12 .byte 196,33,122,16,124,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm15 .byte 196,161,122,16,84,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm2 .byte 196,163,105,33,84,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm2,%xmm2 .byte 196,161,122,16,92,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm3 .byte 196,161,122,16,124,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm7 .byte 196,67,45,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm10,%ymm9 .byte 196,195,33,33,204,32 // vinsertps $0x20,%xmm12,%xmm11,%xmm1 .byte 196,195,113,33,207,48 // vinsertps $0x30,%xmm15,%xmm1,%xmm1 .byte 196,227,105,33,211,32 // vinsertps $0x20,%xmm3,%xmm2,%xmm2 .byte 196,227,105,33,215,48 // vinsertps $0x30,%xmm7,%xmm2,%xmm2 .byte 196,99,109,24,209,1 // vinsertf128 $0x1,%xmm1,%ymm2,%ymm10 .byte 72,139,104,56 // mov 0x38(%rax),%rbp .byte 196,161,122,16,76,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm1 .byte 196,99,113,33,92,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm1,%xmm11 .byte 196,33,122,16,100,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm12 .byte 196,33,122,16,124,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm15 .byte 196,161,122,16,124,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm7 .byte 196,163,65,33,124,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm7,%xmm7 .byte 196,161,122,16,76,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm1 .byte 196,161,122,16,84,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm2 .byte 196,195,33,33,220,32 // vinsertps $0x20,%xmm12,%xmm11,%xmm3 .byte 196,195,97,33,223,48 // vinsertps $0x30,%xmm15,%xmm3,%xmm3 .byte 196,227,65,33,201,32 // vinsertps $0x20,%xmm1,%xmm7,%xmm1 .byte 196,227,113,33,202,48 // vinsertps $0x30,%xmm2,%xmm1,%xmm1 .byte 196,99,117,24,219,1 // vinsertf128 $0x1,%xmm3,%ymm1,%ymm11 .byte 72,139,104,32 // mov 0x20(%rax),%rbp .byte 196,161,122,16,76,173,0 // vmovss 0x0(%rbp,%r13,4),%xmm1 .byte 196,227,113,33,76,157,0,16 // vinsertps $0x10,0x0(%rbp,%rbx,4),%xmm1,%xmm1 .byte 196,161,122,16,84,189,0 // vmovss 0x0(%rbp,%r15,4),%xmm2 .byte 196,227,113,33,202,32 // vinsertps $0x20,%xmm2,%xmm1,%xmm1 .byte 196,161,122,16,84,165,0 // vmovss 0x0(%rbp,%r12,4),%xmm2 .byte 196,161,122,16,92,181,0 // vmovss 0x0(%rbp,%r14,4),%xmm3 .byte 196,35,97,33,100,157,0,16 // vinsertps $0x10,0x0(%rbp,%r11,4),%xmm3,%xmm12 .byte 196,161,122,16,124,149,0 // vmovss 0x0(%rbp,%r10,4),%xmm7 .byte 196,161,122,16,92,141,0 // vmovss 0x0(%rbp,%r9,4),%xmm3 .byte 196,99,113,33,250,48 // vinsertps $0x30,%xmm2,%xmm1,%xmm15 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 196,161,122,16,20,168 // vmovss (%rax,%r13,4),%xmm2 .byte 196,227,105,33,20,152,16 // vinsertps $0x10,(%rax,%rbx,4),%xmm2,%xmm2 .byte 196,227,25,33,255,32 // vinsertps $0x20,%xmm7,%xmm12,%xmm7 .byte 196,161,122,16,12,184 // vmovss (%rax,%r15,4),%xmm1 .byte 196,227,65,33,219,48 // vinsertps $0x30,%xmm3,%xmm7,%xmm3 .byte 196,161,122,16,60,160 // vmovss (%rax,%r12,4),%xmm7 .byte 196,67,101,24,231,1 // vinsertf128 $0x1,%xmm15,%ymm3,%ymm12 .byte 196,161,122,16,28,176 // vmovss (%rax,%r14,4),%xmm3 .byte 196,163,97,33,28,152,16 // vinsertps $0x10,(%rax,%r11,4),%xmm3,%xmm3 .byte 196,227,105,33,201,32 // vinsertps $0x20,%xmm1,%xmm2,%xmm1 .byte 196,161,122,16,20,144 // vmovss (%rax,%r10,4),%xmm2 .byte 196,227,113,33,207,48 // vinsertps $0x30,%xmm7,%xmm1,%xmm1 .byte 196,161,122,16,60,136 // vmovss (%rax,%r9,4),%xmm7 .byte 196,227,97,33,210,32 // vinsertps $0x20,%xmm2,%xmm3,%xmm2 .byte 196,227,105,33,215,48 // vinsertps $0x30,%xmm7,%xmm2,%xmm2 .byte 196,227,109,24,217,1 // vinsertf128 $0x1,%xmm1,%ymm2,%ymm3 .byte 197,188,89,200 // vmulps %ymm0,%ymm8,%ymm1 .byte 196,65,116,88,198 // vaddps %ymm14,%ymm1,%ymm8 .byte 197,148,89,200 // vmulps %ymm0,%ymm13,%ymm1 .byte 196,193,116,88,201 // vaddps %ymm9,%ymm1,%ymm1 .byte 197,172,89,208 // vmulps %ymm0,%ymm10,%ymm2 .byte 196,193,108,88,211 // vaddps %ymm11,%ymm2,%ymm2 .byte 197,156,89,192 // vmulps %ymm0,%ymm12,%ymm0 .byte 197,252,88,219 // vaddps %ymm3,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 197,252,16,124,36,216 // vmovups -0x28(%rsp),%ymm7 .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax HIDDEN _sk_evenly_spaced_2_stop_gradient_avx .globl _sk_evenly_spaced_2_stop_gradient_avx FUNCTION(_sk_evenly_spaced_2_stop_gradient_avx) _sk_evenly_spaced_2_stop_gradient_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,8 // vbroadcastss (%rax),%ymm1 .byte 196,226,125,24,80,16 // vbroadcastss 0x10(%rax),%ymm2 .byte 197,244,89,200 // vmulps %ymm0,%ymm1,%ymm1 .byte 197,116,88,194 // vaddps %ymm2,%ymm1,%ymm8 .byte 196,226,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm1 .byte 196,226,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm2 .byte 197,244,89,200 // vmulps %ymm0,%ymm1,%ymm1 .byte 197,244,88,202 // vaddps %ymm2,%ymm1,%ymm1 .byte 196,226,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm2 .byte 196,226,125,24,88,24 // vbroadcastss 0x18(%rax),%ymm3 .byte 197,236,89,208 // vmulps %ymm0,%ymm2,%ymm2 .byte 197,236,88,211 // vaddps %ymm3,%ymm2,%ymm2 .byte 196,226,125,24,88,12 // vbroadcastss 0xc(%rax),%ymm3 .byte 196,98,125,24,72,28 // vbroadcastss 0x1c(%rax),%ymm9 .byte 197,228,89,192 // vmulps %ymm0,%ymm3,%ymm0 .byte 196,193,124,88,217 // vaddps %ymm9,%ymm0,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_unit_angle_avx .globl _sk_xy_to_unit_angle_avx FUNCTION(_sk_xy_to_unit_angle_avx) _sk_xy_to_unit_angle_avx: .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 .byte 197,60,92,200 // vsubps %ymm0,%ymm8,%ymm9 .byte 197,52,84,200 // vandps %ymm0,%ymm9,%ymm9 .byte 197,60,92,209 // vsubps %ymm1,%ymm8,%ymm10 .byte 197,44,84,209 // vandps %ymm1,%ymm10,%ymm10 .byte 196,65,52,93,218 // vminps %ymm10,%ymm9,%ymm11 .byte 196,65,52,95,226 // vmaxps %ymm10,%ymm9,%ymm12 .byte 196,65,36,94,220 // vdivps %ymm12,%ymm11,%ymm11 .byte 196,65,36,89,227 // vmulps %ymm11,%ymm11,%ymm12 .byte 196,98,125,24,45,248,11,0,0 // vbroadcastss 0xbf8(%rip),%ymm13 # 7fe8 <_sk_callback_avx+0x578> .byte 196,65,28,89,237 // vmulps %ymm13,%ymm12,%ymm13 .byte 196,98,125,24,53,238,11,0,0 // vbroadcastss 0xbee(%rip),%ymm14 # 7fec <_sk_callback_avx+0x57c> .byte 196,65,20,88,238 // vaddps %ymm14,%ymm13,%ymm13 .byte 196,65,28,89,237 // vmulps %ymm13,%ymm12,%ymm13 .byte 196,98,125,24,53,223,11,0,0 // vbroadcastss 0xbdf(%rip),%ymm14 # 7ff0 <_sk_callback_avx+0x580> .byte 196,65,20,88,238 // vaddps %ymm14,%ymm13,%ymm13 .byte 196,65,28,89,229 // vmulps %ymm13,%ymm12,%ymm12 .byte 196,98,125,24,45,208,11,0,0 // vbroadcastss 0xbd0(%rip),%ymm13 # 7ff4 <_sk_callback_avx+0x584> .byte 196,65,28,88,229 // vaddps %ymm13,%ymm12,%ymm12 .byte 196,65,36,89,220 // vmulps %ymm12,%ymm11,%ymm11 .byte 196,65,52,194,202,1 // vcmpltps %ymm10,%ymm9,%ymm9 .byte 196,98,125,24,21,187,11,0,0 // vbroadcastss 0xbbb(%rip),%ymm10 # 7ff8 <_sk_callback_avx+0x588> .byte 196,65,44,92,211 // vsubps %ymm11,%ymm10,%ymm10 .byte 196,67,37,74,202,144 // vblendvps %ymm9,%ymm10,%ymm11,%ymm9 .byte 196,193,124,194,192,1 // vcmpltps %ymm8,%ymm0,%ymm0 .byte 196,98,125,24,21,165,11,0,0 // vbroadcastss 0xba5(%rip),%ymm10 # 7ffc <_sk_callback_avx+0x58c> .byte 196,65,44,92,209 // vsubps %ymm9,%ymm10,%ymm10 .byte 196,195,53,74,194,0 // vblendvps %ymm0,%ymm10,%ymm9,%ymm0 .byte 196,65,116,194,200,1 // vcmpltps %ymm8,%ymm1,%ymm9 .byte 196,98,125,24,21,143,11,0,0 // vbroadcastss 0xb8f(%rip),%ymm10 # 8000 <_sk_callback_avx+0x590> .byte 197,44,92,208 // vsubps %ymm0,%ymm10,%ymm10 .byte 196,195,125,74,194,144 // vblendvps %ymm9,%ymm10,%ymm0,%ymm0 .byte 196,65,124,194,200,3 // vcmpunordps %ymm8,%ymm0,%ymm9 .byte 196,195,125,74,192,144 // vblendvps %ymm9,%ymm8,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_radius_avx .globl _sk_xy_to_radius_avx FUNCTION(_sk_xy_to_radius_avx) _sk_xy_to_radius_avx: .byte 197,252,89,192 // vmulps %ymm0,%ymm0,%ymm0 .byte 197,116,89,193 // vmulps %ymm1,%ymm1,%ymm8 .byte 196,193,124,88,192 // vaddps %ymm8,%ymm0,%ymm0 .byte 197,252,81,192 // vsqrtps %ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_quadratic_max_avx .globl _sk_xy_to_2pt_conical_quadratic_max_avx FUNCTION(_sk_xy_to_2pt_conical_quadratic_max_avx) _sk_xy_to_2pt_conical_quadratic_max_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,32 // vbroadcastss 0x20(%rax),%ymm8 .byte 197,122,16,72,40 // vmovss 0x28(%rax),%xmm9 .byte 197,50,89,80,44 // vmulss 0x2c(%rax),%xmm9,%xmm10 .byte 196,67,121,4,210,0 // vpermilps $0x0,%xmm10,%xmm10 .byte 196,67,45,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm10,%ymm10 .byte 197,44,88,208 // vaddps %ymm0,%ymm10,%ymm10 .byte 196,98,125,24,29,57,11,0,0 // vbroadcastss 0xb39(%rip),%ymm11 # 8004 <_sk_callback_avx+0x594> .byte 196,65,44,89,211 // vmulps %ymm11,%ymm10,%ymm10 .byte 197,252,89,192 // vmulps %ymm0,%ymm0,%ymm0 .byte 197,116,89,217 // vmulps %ymm1,%ymm1,%ymm11 .byte 196,65,124,88,219 // vaddps %ymm11,%ymm0,%ymm11 .byte 196,193,50,89,193 // vmulss %xmm9,%xmm9,%xmm0 .byte 196,227,121,4,192,0 // vpermilps $0x0,%xmm0,%xmm0 .byte 196,227,125,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm0 .byte 197,164,92,192 // vsubps %ymm0,%ymm11,%ymm0 .byte 196,98,125,24,13,13,11,0,0 // vbroadcastss 0xb0d(%rip),%ymm9 # 8008 <_sk_callback_avx+0x598> .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 196,65,44,89,194 // vmulps %ymm10,%ymm10,%ymm8 .byte 196,193,124,88,192 // vaddps %ymm8,%ymm0,%ymm0 .byte 197,252,81,192 // vsqrtps %ymm0,%ymm0 .byte 196,98,125,24,64,36 // vbroadcastss 0x24(%rax),%ymm8 .byte 196,98,125,24,13,235,10,0,0 // vbroadcastss 0xaeb(%rip),%ymm9 # 800c <_sk_callback_avx+0x59c> .byte 196,65,44,87,201 // vxorps %ymm9,%ymm10,%ymm9 .byte 196,65,124,92,210 // vsubps %ymm10,%ymm0,%ymm10 .byte 196,98,125,24,29,220,10,0,0 // vbroadcastss 0xadc(%rip),%ymm11 # 8010 <_sk_callback_avx+0x5a0> .byte 196,65,60,89,195 // vmulps %ymm11,%ymm8,%ymm8 .byte 196,65,60,89,210 // vmulps %ymm10,%ymm8,%ymm10 .byte 197,180,92,192 // vsubps %ymm0,%ymm9,%ymm0 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,172,95,192 // vmaxps %ymm0,%ymm10,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_quadratic_min_avx .globl _sk_xy_to_2pt_conical_quadratic_min_avx FUNCTION(_sk_xy_to_2pt_conical_quadratic_min_avx) _sk_xy_to_2pt_conical_quadratic_min_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,32 // vbroadcastss 0x20(%rax),%ymm8 .byte 197,122,16,72,40 // vmovss 0x28(%rax),%xmm9 .byte 197,50,89,80,44 // vmulss 0x2c(%rax),%xmm9,%xmm10 .byte 196,67,121,4,210,0 // vpermilps $0x0,%xmm10,%xmm10 .byte 196,67,45,24,210,1 // vinsertf128 $0x1,%xmm10,%ymm10,%ymm10 .byte 197,44,88,208 // vaddps %ymm0,%ymm10,%ymm10 .byte 196,98,125,24,29,155,10,0,0 // vbroadcastss 0xa9b(%rip),%ymm11 # 8014 <_sk_callback_avx+0x5a4> .byte 196,65,44,89,211 // vmulps %ymm11,%ymm10,%ymm10 .byte 197,252,89,192 // vmulps %ymm0,%ymm0,%ymm0 .byte 197,116,89,217 // vmulps %ymm1,%ymm1,%ymm11 .byte 196,65,124,88,219 // vaddps %ymm11,%ymm0,%ymm11 .byte 196,193,50,89,193 // vmulss %xmm9,%xmm9,%xmm0 .byte 196,227,121,4,192,0 // vpermilps $0x0,%xmm0,%xmm0 .byte 196,227,125,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm0 .byte 197,164,92,192 // vsubps %ymm0,%ymm11,%ymm0 .byte 196,98,125,24,13,111,10,0,0 // vbroadcastss 0xa6f(%rip),%ymm9 # 8018 <_sk_callback_avx+0x5a8> .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 196,65,44,89,194 // vmulps %ymm10,%ymm10,%ymm8 .byte 196,193,124,88,192 // vaddps %ymm8,%ymm0,%ymm0 .byte 197,252,81,192 // vsqrtps %ymm0,%ymm0 .byte 196,98,125,24,64,36 // vbroadcastss 0x24(%rax),%ymm8 .byte 196,98,125,24,13,77,10,0,0 // vbroadcastss 0xa4d(%rip),%ymm9 # 801c <_sk_callback_avx+0x5ac> .byte 196,65,44,87,201 // vxorps %ymm9,%ymm10,%ymm9 .byte 196,65,124,92,210 // vsubps %ymm10,%ymm0,%ymm10 .byte 196,98,125,24,29,62,10,0,0 // vbroadcastss 0xa3e(%rip),%ymm11 # 8020 <_sk_callback_avx+0x5b0> .byte 196,65,60,89,195 // vmulps %ymm11,%ymm8,%ymm8 .byte 196,65,60,89,210 // vmulps %ymm10,%ymm8,%ymm10 .byte 197,180,92,192 // vsubps %ymm0,%ymm9,%ymm0 .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 .byte 197,172,93,192 // vminps %ymm0,%ymm10,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_linear_avx .globl _sk_xy_to_2pt_conical_linear_avx FUNCTION(_sk_xy_to_2pt_conical_linear_avx) _sk_xy_to_2pt_conical_linear_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,122,16,64,40 // vmovss 0x28(%rax),%xmm8 .byte 197,58,89,72,44 // vmulss 0x2c(%rax),%xmm8,%xmm9 .byte 196,67,121,4,201,0 // vpermilps $0x0,%xmm9,%xmm9 .byte 196,67,53,24,201,1 // vinsertf128 $0x1,%xmm9,%ymm9,%ymm9 .byte 197,52,88,200 // vaddps %ymm0,%ymm9,%ymm9 .byte 196,98,125,24,21,3,10,0,0 // vbroadcastss 0xa03(%rip),%ymm10 # 8024 <_sk_callback_avx+0x5b4> .byte 196,65,52,89,202 // vmulps %ymm10,%ymm9,%ymm9 .byte 197,252,89,192 // vmulps %ymm0,%ymm0,%ymm0 .byte 197,116,89,209 // vmulps %ymm1,%ymm1,%ymm10 .byte 196,65,124,88,210 // vaddps %ymm10,%ymm0,%ymm10 .byte 196,193,58,89,192 // vmulss %xmm8,%xmm8,%xmm0 .byte 196,227,121,4,192,0 // vpermilps $0x0,%xmm0,%xmm0 .byte 196,227,125,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm0 .byte 197,172,92,192 // vsubps %ymm0,%ymm10,%ymm0 .byte 196,98,125,24,5,215,9,0,0 // vbroadcastss 0x9d7(%rip),%ymm8 # 8028 <_sk_callback_avx+0x5b8> .byte 196,193,124,87,192 // vxorps %ymm8,%ymm0,%ymm0 .byte 196,193,124,94,193 // vdivps %ymm9,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mask_2pt_conical_degenerates_avx .globl _sk_mask_2pt_conical_degenerates_avx FUNCTION(_sk_mask_2pt_conical_degenerates_avx) _sk_mask_2pt_conical_degenerates_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,64,44 // vbroadcastss 0x2c(%rax),%ymm8 .byte 196,98,125,24,72,40 // vbroadcastss 0x28(%rax),%ymm9 .byte 197,60,89,192 // vmulps %ymm0,%ymm8,%ymm8 .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 196,65,52,87,201 // vxorps %ymm9,%ymm9,%ymm9 .byte 196,65,52,194,192,2 // vcmpleps %ymm8,%ymm9,%ymm8 .byte 196,65,124,194,201,7 // vcmpordps %ymm9,%ymm0,%ymm9 .byte 196,65,60,84,193 // vandps %ymm9,%ymm8,%ymm8 .byte 197,124,17,0 // vmovups %ymm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_apply_vector_mask_avx .globl _sk_apply_vector_mask_avx FUNCTION(_sk_apply_vector_mask_avx) _sk_apply_vector_mask_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,16,0 // vmovups (%rax),%ymm8 .byte 197,188,84,192 // vandps %ymm0,%ymm8,%ymm0 .byte 197,188,84,201 // vandps %ymm1,%ymm8,%ymm1 .byte 197,188,84,210 // vandps %ymm2,%ymm8,%ymm2 .byte 197,188,84,219 // vandps %ymm3,%ymm8,%ymm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_save_xy_avx .globl _sk_save_xy_avx FUNCTION(_sk_save_xy_avx) _sk_save_xy_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,5,115,9,0,0 // vbroadcastss 0x973(%rip),%ymm8 # 802c <_sk_callback_avx+0x5bc> .byte 196,65,124,88,200 // vaddps %ymm8,%ymm0,%ymm9 .byte 196,67,125,8,209,1 // vroundps $0x1,%ymm9,%ymm10 .byte 196,65,52,92,202 // vsubps %ymm10,%ymm9,%ymm9 .byte 196,65,116,88,192 // vaddps %ymm8,%ymm1,%ymm8 .byte 196,67,125,8,208,1 // vroundps $0x1,%ymm8,%ymm10 .byte 196,65,60,92,194 // vsubps %ymm10,%ymm8,%ymm8 .byte 197,252,17,0 // vmovups %ymm0,(%rax) .byte 197,252,17,72,32 // vmovups %ymm1,0x20(%rax) .byte 197,124,17,72,64 // vmovups %ymm9,0x40(%rax) .byte 197,124,17,64,96 // vmovups %ymm8,0x60(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_accumulate_avx .globl _sk_accumulate_avx FUNCTION(_sk_accumulate_avx) _sk_accumulate_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,124,16,128,128,0,0,0 // vmovups 0x80(%rax),%ymm8 .byte 197,60,89,128,160,0,0,0 // vmulps 0xa0(%rax),%ymm8,%ymm8 .byte 197,60,89,200 // vmulps %ymm0,%ymm8,%ymm9 .byte 197,180,88,228 // vaddps %ymm4,%ymm9,%ymm4 .byte 197,60,89,201 // vmulps %ymm1,%ymm8,%ymm9 .byte 197,180,88,237 // vaddps %ymm5,%ymm9,%ymm5 .byte 197,60,89,202 // vmulps %ymm2,%ymm8,%ymm9 .byte 197,180,88,246 // vaddps %ymm6,%ymm9,%ymm6 .byte 197,60,89,195 // vmulps %ymm3,%ymm8,%ymm8 .byte 197,188,88,255 // vaddps %ymm7,%ymm8,%ymm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_nx_avx .globl _sk_bilinear_nx_avx FUNCTION(_sk_bilinear_nx_avx) _sk_bilinear_nx_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,255,8,0,0 // vbroadcastss 0x8ff(%rip),%ymm0 # 8030 <_sk_callback_avx+0x5c0> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 196,98,125,24,5,246,8,0,0 // vbroadcastss 0x8f6(%rip),%ymm8 # 8034 <_sk_callback_avx+0x5c4> .byte 197,60,92,64,64 // vsubps 0x40(%rax),%ymm8,%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_px_avx .globl _sk_bilinear_px_avx FUNCTION(_sk_bilinear_px_avx) _sk_bilinear_px_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,222,8,0,0 // vbroadcastss 0x8de(%rip),%ymm0 # 8038 <_sk_callback_avx+0x5c8> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 197,124,16,64,64 // vmovups 0x40(%rax),%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_ny_avx .globl _sk_bilinear_ny_avx FUNCTION(_sk_bilinear_ny_avx) _sk_bilinear_ny_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,194,8,0,0 // vbroadcastss 0x8c2(%rip),%ymm1 # 803c <_sk_callback_avx+0x5cc> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 196,98,125,24,5,184,8,0,0 // vbroadcastss 0x8b8(%rip),%ymm8 # 8040 <_sk_callback_avx+0x5d0> .byte 197,60,92,64,96 // vsubps 0x60(%rax),%ymm8,%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_py_avx .globl _sk_bilinear_py_avx FUNCTION(_sk_bilinear_py_avx) _sk_bilinear_py_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,160,8,0,0 // vbroadcastss 0x8a0(%rip),%ymm1 # 8044 <_sk_callback_avx+0x5d4> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 197,124,16,64,96 // vmovups 0x60(%rax),%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n3x_avx .globl _sk_bicubic_n3x_avx FUNCTION(_sk_bicubic_n3x_avx) _sk_bicubic_n3x_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,131,8,0,0 // vbroadcastss 0x883(%rip),%ymm0 # 8048 <_sk_callback_avx+0x5d8> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 196,98,125,24,5,122,8,0,0 // vbroadcastss 0x87a(%rip),%ymm8 # 804c <_sk_callback_avx+0x5dc> .byte 197,60,92,64,64 // vsubps 0x40(%rax),%ymm8,%ymm8 .byte 196,65,60,89,200 // vmulps %ymm8,%ymm8,%ymm9 .byte 196,98,125,24,21,107,8,0,0 // vbroadcastss 0x86b(%rip),%ymm10 # 8050 <_sk_callback_avx+0x5e0> .byte 196,65,60,89,194 // vmulps %ymm10,%ymm8,%ymm8 .byte 196,98,125,24,21,97,8,0,0 // vbroadcastss 0x861(%rip),%ymm10 # 8054 <_sk_callback_avx+0x5e4> .byte 196,65,60,88,194 // vaddps %ymm10,%ymm8,%ymm8 .byte 196,65,52,89,192 // vmulps %ymm8,%ymm9,%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n1x_avx .globl _sk_bicubic_n1x_avx FUNCTION(_sk_bicubic_n1x_avx) _sk_bicubic_n1x_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,68,8,0,0 // vbroadcastss 0x844(%rip),%ymm0 # 8058 <_sk_callback_avx+0x5e8> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 196,98,125,24,5,59,8,0,0 // vbroadcastss 0x83b(%rip),%ymm8 # 805c <_sk_callback_avx+0x5ec> .byte 197,60,92,64,64 // vsubps 0x40(%rax),%ymm8,%ymm8 .byte 196,98,125,24,13,49,8,0,0 // vbroadcastss 0x831(%rip),%ymm9 # 8060 <_sk_callback_avx+0x5f0> .byte 196,65,60,89,201 // vmulps %ymm9,%ymm8,%ymm9 .byte 196,98,125,24,21,39,8,0,0 // vbroadcastss 0x827(%rip),%ymm10 # 8064 <_sk_callback_avx+0x5f4> .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,65,60,89,201 // vmulps %ymm9,%ymm8,%ymm9 .byte 196,98,125,24,21,24,8,0,0 // vbroadcastss 0x818(%rip),%ymm10 # 8068 <_sk_callback_avx+0x5f8> .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 196,98,125,24,13,9,8,0,0 // vbroadcastss 0x809(%rip),%ymm9 # 806c <_sk_callback_avx+0x5fc> .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p1x_avx .globl _sk_bicubic_p1x_avx FUNCTION(_sk_bicubic_p1x_avx) _sk_bicubic_p1x_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,5,241,7,0,0 // vbroadcastss 0x7f1(%rip),%ymm8 # 8070 <_sk_callback_avx+0x600> .byte 197,188,88,0 // vaddps (%rax),%ymm8,%ymm0 .byte 197,124,16,72,64 // vmovups 0x40(%rax),%ymm9 .byte 196,98,125,24,21,227,7,0,0 // vbroadcastss 0x7e3(%rip),%ymm10 # 8074 <_sk_callback_avx+0x604> .byte 196,65,52,89,210 // vmulps %ymm10,%ymm9,%ymm10 .byte 196,98,125,24,29,217,7,0,0 // vbroadcastss 0x7d9(%rip),%ymm11 # 8078 <_sk_callback_avx+0x608> .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 196,65,52,89,210 // vmulps %ymm10,%ymm9,%ymm10 .byte 196,65,44,88,192 // vaddps %ymm8,%ymm10,%ymm8 .byte 196,65,52,89,192 // vmulps %ymm8,%ymm9,%ymm8 .byte 196,98,125,24,13,192,7,0,0 // vbroadcastss 0x7c0(%rip),%ymm9 # 807c <_sk_callback_avx+0x60c> .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p3x_avx .globl _sk_bicubic_p3x_avx FUNCTION(_sk_bicubic_p3x_avx) _sk_bicubic_p3x_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,5,168,7,0,0 // vbroadcastss 0x7a8(%rip),%ymm0 # 8080 <_sk_callback_avx+0x610> .byte 197,252,88,0 // vaddps (%rax),%ymm0,%ymm0 .byte 197,124,16,64,64 // vmovups 0x40(%rax),%ymm8 .byte 196,65,60,89,200 // vmulps %ymm8,%ymm8,%ymm9 .byte 196,98,125,24,21,149,7,0,0 // vbroadcastss 0x795(%rip),%ymm10 # 8084 <_sk_callback_avx+0x614> .byte 196,65,60,89,194 // vmulps %ymm10,%ymm8,%ymm8 .byte 196,98,125,24,21,139,7,0,0 // vbroadcastss 0x78b(%rip),%ymm10 # 8088 <_sk_callback_avx+0x618> .byte 196,65,60,88,194 // vaddps %ymm10,%ymm8,%ymm8 .byte 196,65,52,89,192 // vmulps %ymm8,%ymm9,%ymm8 .byte 197,124,17,128,128,0,0,0 // vmovups %ymm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n3y_avx .globl _sk_bicubic_n3y_avx FUNCTION(_sk_bicubic_n3y_avx) _sk_bicubic_n3y_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,110,7,0,0 // vbroadcastss 0x76e(%rip),%ymm1 # 808c <_sk_callback_avx+0x61c> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 196,98,125,24,5,100,7,0,0 // vbroadcastss 0x764(%rip),%ymm8 # 8090 <_sk_callback_avx+0x620> .byte 197,60,92,64,96 // vsubps 0x60(%rax),%ymm8,%ymm8 .byte 196,65,60,89,200 // vmulps %ymm8,%ymm8,%ymm9 .byte 196,98,125,24,21,85,7,0,0 // vbroadcastss 0x755(%rip),%ymm10 # 8094 <_sk_callback_avx+0x624> .byte 196,65,60,89,194 // vmulps %ymm10,%ymm8,%ymm8 .byte 196,98,125,24,21,75,7,0,0 // vbroadcastss 0x74b(%rip),%ymm10 # 8098 <_sk_callback_avx+0x628> .byte 196,65,60,88,194 // vaddps %ymm10,%ymm8,%ymm8 .byte 196,65,52,89,192 // vmulps %ymm8,%ymm9,%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n1y_avx .globl _sk_bicubic_n1y_avx FUNCTION(_sk_bicubic_n1y_avx) _sk_bicubic_n1y_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,46,7,0,0 // vbroadcastss 0x72e(%rip),%ymm1 # 809c <_sk_callback_avx+0x62c> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 196,98,125,24,5,36,7,0,0 // vbroadcastss 0x724(%rip),%ymm8 # 80a0 <_sk_callback_avx+0x630> .byte 197,60,92,64,96 // vsubps 0x60(%rax),%ymm8,%ymm8 .byte 196,98,125,24,13,26,7,0,0 // vbroadcastss 0x71a(%rip),%ymm9 # 80a4 <_sk_callback_avx+0x634> .byte 196,65,60,89,201 // vmulps %ymm9,%ymm8,%ymm9 .byte 196,98,125,24,21,16,7,0,0 // vbroadcastss 0x710(%rip),%ymm10 # 80a8 <_sk_callback_avx+0x638> .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,65,60,89,201 // vmulps %ymm9,%ymm8,%ymm9 .byte 196,98,125,24,21,1,7,0,0 // vbroadcastss 0x701(%rip),%ymm10 # 80ac <_sk_callback_avx+0x63c> .byte 196,65,52,88,202 // vaddps %ymm10,%ymm9,%ymm9 .byte 196,65,60,89,193 // vmulps %ymm9,%ymm8,%ymm8 .byte 196,98,125,24,13,242,6,0,0 // vbroadcastss 0x6f2(%rip),%ymm9 # 80b0 <_sk_callback_avx+0x640> .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p1y_avx .globl _sk_bicubic_p1y_avx FUNCTION(_sk_bicubic_p1y_avx) _sk_bicubic_p1y_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,98,125,24,5,218,6,0,0 // vbroadcastss 0x6da(%rip),%ymm8 # 80b4 <_sk_callback_avx+0x644> .byte 197,188,88,72,32 // vaddps 0x20(%rax),%ymm8,%ymm1 .byte 197,124,16,72,96 // vmovups 0x60(%rax),%ymm9 .byte 196,98,125,24,21,203,6,0,0 // vbroadcastss 0x6cb(%rip),%ymm10 # 80b8 <_sk_callback_avx+0x648> .byte 196,65,52,89,210 // vmulps %ymm10,%ymm9,%ymm10 .byte 196,98,125,24,29,193,6,0,0 // vbroadcastss 0x6c1(%rip),%ymm11 # 80bc <_sk_callback_avx+0x64c> .byte 196,65,44,88,211 // vaddps %ymm11,%ymm10,%ymm10 .byte 196,65,52,89,210 // vmulps %ymm10,%ymm9,%ymm10 .byte 196,65,44,88,192 // vaddps %ymm8,%ymm10,%ymm8 .byte 196,65,52,89,192 // vmulps %ymm8,%ymm9,%ymm8 .byte 196,98,125,24,13,168,6,0,0 // vbroadcastss 0x6a8(%rip),%ymm9 # 80c0 <_sk_callback_avx+0x650> .byte 196,65,60,88,193 // vaddps %ymm9,%ymm8,%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p3y_avx .globl _sk_bicubic_p3y_avx FUNCTION(_sk_bicubic_p3y_avx) _sk_bicubic_p3y_avx: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,13,144,6,0,0 // vbroadcastss 0x690(%rip),%ymm1 # 80c4 <_sk_callback_avx+0x654> .byte 197,244,88,72,32 // vaddps 0x20(%rax),%ymm1,%ymm1 .byte 197,124,16,64,96 // vmovups 0x60(%rax),%ymm8 .byte 196,65,60,89,200 // vmulps %ymm8,%ymm8,%ymm9 .byte 196,98,125,24,21,124,6,0,0 // vbroadcastss 0x67c(%rip),%ymm10 # 80c8 <_sk_callback_avx+0x658> .byte 196,65,60,89,194 // vmulps %ymm10,%ymm8,%ymm8 .byte 196,98,125,24,21,114,6,0,0 // vbroadcastss 0x672(%rip),%ymm10 # 80cc <_sk_callback_avx+0x65c> .byte 196,65,60,88,194 // vaddps %ymm10,%ymm8,%ymm8 .byte 196,65,52,89,192 // vmulps %ymm8,%ymm9,%ymm8 .byte 197,124,17,128,160,0,0,0 // vmovups %ymm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_callback_avx .globl _sk_callback_avx FUNCTION(_sk_callback_avx) _sk_callback_avx: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,228,224 // and $0xffffffffffffffe0,%rsp .byte 72,129,236,192,0,0,0 // sub $0xc0,%rsp .byte 197,252,41,188,36,128,0,0,0 // vmovaps %ymm7,0x80(%rsp) .byte 197,252,41,116,36,96 // vmovaps %ymm6,0x60(%rsp) .byte 197,252,41,108,36,64 // vmovaps %ymm5,0x40(%rsp) .byte 197,252,41,100,36,32 // vmovaps %ymm4,0x20(%rsp) .byte 76,137,195 // mov %r8,%rbx .byte 72,137,76,36,24 // mov %rcx,0x18(%rsp) .byte 73,137,215 // mov %rdx,%r15 .byte 73,137,252 // mov %rdi,%r12 .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,137,198 // mov %rax,%r14 .byte 73,137,245 // mov %rsi,%r13 .byte 197,252,20,225 // vunpcklps %ymm1,%ymm0,%ymm4 .byte 197,252,21,193 // vunpckhps %ymm1,%ymm0,%ymm0 .byte 197,236,20,203 // vunpcklps %ymm3,%ymm2,%ymm1 .byte 197,236,21,211 // vunpckhps %ymm3,%ymm2,%ymm2 .byte 197,221,20,217 // vunpcklpd %ymm1,%ymm4,%ymm3 .byte 197,221,21,201 // vunpckhpd %ymm1,%ymm4,%ymm1 .byte 197,253,20,226 // vunpcklpd %ymm2,%ymm0,%ymm4 .byte 197,253,21,194 // vunpckhpd %ymm2,%ymm0,%ymm0 .byte 196,227,101,24,209,1 // vinsertf128 $0x1,%xmm1,%ymm3,%ymm2 .byte 196,227,93,24,232,1 // vinsertf128 $0x1,%xmm0,%ymm4,%ymm5 .byte 196,227,101,6,201,49 // vperm2f128 $0x31,%ymm1,%ymm3,%ymm1 .byte 196,227,93,6,192,49 // vperm2f128 $0x31,%ymm0,%ymm4,%ymm0 .byte 196,193,125,17,86,8 // vmovupd %ymm2,0x8(%r14) .byte 196,193,125,17,110,40 // vmovupd %ymm5,0x28(%r14) .byte 196,193,125,17,78,72 // vmovupd %ymm1,0x48(%r14) .byte 196,193,125,17,70,104 // vmovupd %ymm0,0x68(%r14) .byte 72,133,219 // test %rbx,%rbx .byte 190,8,0,0,0 // mov $0x8,%esi .byte 15,69,243 // cmovne %ebx,%esi .byte 76,137,247 // mov %r14,%rdi .byte 197,248,119 // vzeroupper .byte 65,255,22 // callq *(%r14) .byte 73,139,134,136,0,0,0 // mov 0x88(%r14),%rax .byte 197,248,16,0 // vmovups (%rax),%xmm0 .byte 197,248,16,72,16 // vmovups 0x10(%rax),%xmm1 .byte 197,248,16,80,32 // vmovups 0x20(%rax),%xmm2 .byte 197,248,16,88,48 // vmovups 0x30(%rax),%xmm3 .byte 196,227,101,24,88,112,1 // vinsertf128 $0x1,0x70(%rax),%ymm3,%ymm3 .byte 196,227,109,24,80,96,1 // vinsertf128 $0x1,0x60(%rax),%ymm2,%ymm2 .byte 196,227,117,24,72,80,1 // vinsertf128 $0x1,0x50(%rax),%ymm1,%ymm1 .byte 196,227,125,24,64,64,1 // vinsertf128 $0x1,0x40(%rax),%ymm0,%ymm0 .byte 197,252,20,225 // vunpcklps %ymm1,%ymm0,%ymm4 .byte 197,252,21,233 // vunpckhps %ymm1,%ymm0,%ymm5 .byte 197,236,20,203 // vunpcklps %ymm3,%ymm2,%ymm1 .byte 197,236,21,219 // vunpckhps %ymm3,%ymm2,%ymm3 .byte 197,221,20,193 // vunpcklpd %ymm1,%ymm4,%ymm0 .byte 197,221,21,201 // vunpckhpd %ymm1,%ymm4,%ymm1 .byte 197,213,20,211 // vunpcklpd %ymm3,%ymm5,%ymm2 .byte 197,213,21,219 // vunpckhpd %ymm3,%ymm5,%ymm3 .byte 76,137,238 // mov %r13,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,231 // mov %r12,%rdi .byte 76,137,250 // mov %r15,%rdx .byte 72,139,76,36,24 // mov 0x18(%rsp),%rcx .byte 73,137,216 // mov %rbx,%r8 .byte 197,252,40,100,36,32 // vmovaps 0x20(%rsp),%ymm4 .byte 197,252,40,108,36,64 // vmovaps 0x40(%rsp),%ymm5 .byte 197,252,40,116,36,96 // vmovaps 0x60(%rsp),%ymm6 .byte 197,252,40,188,36,128,0,0,0 // vmovaps 0x80(%rsp),%ymm7 .byte 72,141,101,216 // lea -0x28(%rbp),%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax BALIGN4 .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,1 // cmpb $0x1,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 252 // cld .byte 190,0,0,128,63 // mov $0x3f800000,%esi .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,191,0,0,224,64,154 // cmpb $0x9a,0x40e00000(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,174 // ds cmp $0xae3f170a,%eax .byte 71,225,61 // rex.RXB loope 7c6d <.literal4+0xb9> .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,174 // ds cmp $0xae3f170a,%eax .byte 71,225,61 // rex.RXB loope 7c7d <.literal4+0xc9> .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,174 // ds cmp $0xae3f170a,%eax .byte 71,225,61 // rex.RXB loope 7c8d <.literal4+0xd9> .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,174 // ds cmp $0xae3f170a,%eax .byte 71,225,61 // rex.RXB loope 7c9d <.literal4+0xe9> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,127 // add %al,0x7f00003f(%rax) .byte 67,0,0 // rex.XB add %al,(%r8) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,145,131,158 // add %al,-0x617c6ec1(%rax) .byte 61,154,153,153,62 // cmp $0x3e99999a,%eax .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,145,131,158,61 // cmp $0x3d9e8391,%eax .byte 154 // (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,92 // ds pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,82,184,78,65 // cmp $0x414eb852,%eax .byte 57,215 // cmp %edx,%edi .byte 32,187,186,159,98,60 // and %bh,0x3c629fba(%rbx) .byte 109 // insl (%dx),%es:(%rdi) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 144 // nop .byte 63 // (bad) .byte 252 // cld .byte 191,16,62,168,177 // mov $0xb1a83e10,%edi .byte 152 // cwtl .byte 59,0 // cmp (%rax),%eax .byte 0,128,63,0,0,192 // add %al,-0x3fffffc1(%rax) .byte 64,0,0 // add %al,(%rax) .byte 0,64,0 // add %al,0x0(%rax) .byte 0,128,64,171,170,42 // add %al,0x2aaaab40(%rax) .byte 62,0,0 // add %al,%ds:(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 0,0 // add %al,(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 128,64,171,170 // addb $0xaa,-0x55(%rax) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,129,128,128,59 // mov $0x3b808081,%esi .byte 129,128,128,59,0,248,0,0,8,33 // addl $0x21080000,-0x7ffc480(%rax) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 7d0d <.literal4+0x159> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,129,128,128,59 // and %eax,0x3b808081(,%rdi,1) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 129,128,128,59,129,128,128,59,0,0 // addl $0x3b80,-0x7f7ec480(%rax) .byte 0,52,255 // add %dh,(%rdi,%rdi,8) .byte 255 // (bad) .byte 127,0 // jg 7d34 <.literal4+0x180> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 7dad <.literal4+0x1f9> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,128,63,0,0,0 // add %al,0x3f(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 7d68 <.literal4+0x1b4> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 7de1 <.literal4+0x22d> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,128,63,0,0,0 // add %al,0x3f(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 7d9c <.literal4+0x1e8> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 7e15 <.literal4+0x261> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,128,63,0,0,0 // add %al,0x3f(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 7dd0 <.literal4+0x21c> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 7e49 <.literal4+0x295> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,128,63,0,0,0 // add %al,0x3f(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 7e04 <.literal4+0x250> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 7e7d <.literal4+0x2c9> .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,249,68,180 // mov $0xb444f93f,%edi .byte 62,163,233,220,63,81,140,242,66,141 // movabs %eax,%ds:0x8d42f28c513fdce9 .byte 188,190,63,248,245 // mov $0xf5f83fbe,%esp .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,200 // add %cl,%al .byte 66,0,0 // rex.X add %al,(%rax) .byte 127,67 // jg 7e77 <.literal4+0x2c3> .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 128,65,203,61 // addb $0x3d,-0x35(%rcx) .byte 13,60,111,18,3 // or $0x3126f3c,%eax .byte 59,10 // cmp (%rdx),%ecx .byte 215 // xlat %ds:(%rbx) .byte 163,59,194,24,17,60,203,61,13 // movabs %eax,0xd3dcb3c1118c23b .byte 190,80,128,3,62 // mov $0x3e038050,%esi .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 7e97 <.literal4+0x2e3> .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 129,128,128,59,0,0,128,63,129,128 // addl $0x80813f80,0x3b80(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,128,63,129,128,128 // add %al,-0x7f7f7ec1(%rax) .byte 59,0 // cmp (%rax),%eax .byte 0,128,63,0,248,0 // add %al,0xf8003f(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,132,55,224,7,0,0 // and %eax,0x7e0(%rdi,%rsi,1) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,0,0,128,63 // and %eax,0x3f800000(,%rdi,1) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 7eb1 <.literal4+0x2fd> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,0,0,128,63 // and %eax,0x3f800000(,%rdi,1) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 7ecd <.literal4+0x319> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,0,0,128,63 // and %eax,0x3f800000(,%rdi,1) .byte 0,0 // add %al,(%rax) .byte 248 // clc .byte 65,0,0 // add %al,(%r8) .byte 124,66 // jl 7f22 <.literal4+0x36e> .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,0,15 // mov %ecx,0xf003788(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,240,0 // mov %ecx,0xf03988(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,59,15,0 // mov %ecx,0xf3b88(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,61,0,240 // mov %ecx,-0xfffc278(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,0,15 // mov %ecx,0xf003788(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,240,0 // mov %ecx,0xf03988(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,59,15,0 // mov %ecx,0xf3b88(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,61,0,240 // mov %ecx,-0xfffc278(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,0,15 // mov %ecx,0xf003788(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,240,0 // mov %ecx,0xf03988(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,59,15,0 // mov %ecx,0xf3b88(%rax) .byte 0,0 // add %al,(%rax) .byte 137,136,136,61,0,0 // mov %ecx,0x3d88(%rax) .byte 112,65 // jo 7f85 <.literal4+0x3d1> .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 0,128,0,0,0,0 // add %al,0x0(%rax) .byte 0,128,0,4,0,128 // add %al,-0x7ffffc00(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,128,0,0,0,0 // add %al,0x0(%rax) .byte 0,128,0,4,0,128 // add %al,-0x7ffffc00(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,128,0,0,0,0 // add %al,0x0(%rax) .byte 0,128,0,4,0,128 // add %al,-0x7ffffc00(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,128,56 // add %al,0x38800000(%rax) .byte 0,64,254 // add %al,-0x2(%rax) .byte 255,128,0,128,55,128 // incl -0x7fc88000(%rax) .byte 0,128,55,0,0,128 // add %al,-0x7fffffc9(%rax) .byte 63 // (bad) .byte 0,255 // add %bh,%bh .byte 127,71 // jg 7ff7 <.literal4+0x443> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,191,0,0,0 // add %al,0xbf(%rax) .byte 63 // (bad) .byte 208 // (bad) .byte 179,89 // mov $0x59,%bl .byte 62,89 // ds pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 152 // cwtl .byte 221,147,61,45,16,17 // fstl 0x11102d3d(%rbx) .byte 192,18,120 // rclb $0x78,(%rdx) .byte 57,64,32 // cmp %eax,0x20(%rax) .byte 148 // xchg %eax,%esp .byte 90 // pop %rdx .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,0,24 // add %bl,%ds:(%rax) .byte 161,57,1,0,0,0,111,43,231 // movabs 0xe72b6f0000000139,%eax .byte 187,159,215,202,60 // mov $0x3ccad79f,%ebx .byte 212 // (bad) .byte 100,84 // fs push %rsp .byte 189,169,240,34,62 // mov $0x3e22f0a9,%ebp .byte 0,0 // add %al,(%rax) .byte 128,62,0 // cmpb $0x0,(%rsi) .byte 0,0 // add %al,(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,0,0 // rolb $0x0,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,63 // add %al,0x3f000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,128,63 // add %bh,0x3f800000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,128,63 // add %bh,0x3f800000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,191,0,0,128,63,114 // sarb $0x72,0x3f800000(%rdi) .byte 28,199 // sbb $0xc7,%al .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,0,0,0,191 // mov $0xbf000000,%esi .byte 0,0 // add %al,(%rax) .byte 128,63,85 // cmpb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,0,0,192,63 // mov $0x3fc00000,%edi .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 0,63 // add %bh,(%rdi) .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,0,0,192,63 // mov $0x3fc00000,%edi .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 192,63,114 // sarb $0x72,(%rdi) .byte 28,199 // sbb $0xc7,%al .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,0,0,192,191 // mov $0xbfc00000,%esi .byte 0,0 // add %al,(%rax) .byte 128,63,114 // cmpb $0x72,(%rdi) .byte 28,199 // sbb $0xc7,%al .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,0,0,0,191 // mov $0xbf000000,%esi .byte 0,0 // add %al,(%rax) .byte 128,63,85 // cmpb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,0,0,192,63 // mov $0x3fc00000,%edi .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 0,63 // add %bh,(%rdi) .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,0,0,192,63 // mov $0x3fc00000,%edi .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 192,63,114 // sarb $0x72,(%rdi) .byte 28,199 // sbb $0xc7,%al .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190 // .byte 0xbe BALIGN16 .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,10 // or %cl,(%rdx) .byte 12,14 // or $0xe,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,10 // or %cl,(%rdx) .byte 12,14 // or $0xe,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,2 // add %al,(%rdx) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,10 // or %cl,(%rdx) .byte 12,14 // or $0xe,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,10 // or %cl,(%rdx) .byte 12,14 // or $0xe,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,10 // or %cl,(%rdx) .byte 12,14 // or $0xe,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,10 // or %cl,(%rdx) .byte 12,14 // or $0xe,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,10 // or %cl,(%rdx) .byte 12,14 // or $0xe,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,10 // or %cl,(%rdx) .byte 12,14 // or $0xe,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) BALIGN32 .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) BALIGN32 HIDDEN _sk_start_pipeline_sse41 .globl _sk_start_pipeline_sse41 FUNCTION(_sk_start_pipeline_sse41) _sk_start_pipeline_sse41: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,236,40 // sub $0x28,%rsp .byte 72,137,211 // mov %rdx,%rbx .byte 73,137,246 // mov %rsi,%r14 .byte 72,137,125,208 // mov %rdi,-0x30(%rbp) .byte 76,137,198 // mov %r8,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,137,194 // mov %rax,%rdx .byte 72,137,77,176 // mov %rcx,-0x50(%rbp) .byte 73,57,206 // cmp %rcx,%r14 .byte 115,117 // jae a1 <_sk_start_pipeline_sse41+0xa1> .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,141,64,4 // lea 0x4(%rax),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 76,137,77,192 // mov %r9,-0x40(%rbp) .byte 72,137,85,200 // mov %rdx,-0x38(%rbp) .byte 73,137,221 // mov %rbx,%r13 .byte 73,137,244 // mov %rsi,%r12 .byte 72,57,93,184 // cmp %rbx,-0x48(%rbp) .byte 72,139,85,208 // mov -0x30(%rbp),%rdx .byte 119,45 // ja 7d <_sk_start_pipeline_sse41+0x7d> .byte 76,139,125,208 // mov -0x30(%rbp),%r15 .byte 69,49,192 // xor %r8d,%r8d .byte 76,137,207 // mov %r9,%rdi .byte 76,137,230 // mov %r12,%rsi .byte 76,137,250 // mov %r15,%rdx .byte 76,137,241 // mov %r14,%rcx .byte 255,85,200 // callq *-0x38(%rbp) .byte 76,137,235 // mov %r13,%rbx .byte 76,139,77,192 // mov -0x40(%rbp),%r9 .byte 73,141,87,4 // lea 0x4(%r15),%rdx .byte 73,131,199,8 // add $0x8,%r15 .byte 73,57,223 // cmp %rbx,%r15 .byte 73,137,215 // mov %rdx,%r15 .byte 118,215 // jbe 54 <_sk_start_pipeline_sse41+0x54> .byte 73,137,216 // mov %rbx,%r8 .byte 73,41,208 // sub %rdx,%r8 .byte 116,19 // je 98 <_sk_start_pipeline_sse41+0x98> .byte 76,137,207 // mov %r9,%rdi .byte 76,137,230 // mov %r12,%rsi .byte 76,137,241 // mov %r14,%rcx .byte 255,85,200 // callq *-0x38(%rbp) .byte 76,137,235 // mov %r13,%rbx .byte 76,139,77,192 // mov -0x40(%rbp),%r9 .byte 73,255,198 // inc %r14 .byte 76,59,117,176 // cmp -0x50(%rbp),%r14 .byte 117,165 // jne 46 <_sk_start_pipeline_sse41+0x46> .byte 72,131,196,40 // add $0x28,%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 195 // retq HIDDEN _sk_just_return_sse41 .globl _sk_just_return_sse41 FUNCTION(_sk_just_return_sse41) _sk_just_return_sse41: .byte 195 // retq HIDDEN _sk_seed_shader_sse41 .globl _sk_seed_shader_sse41 FUNCTION(_sk_seed_shader_sse41) _sk_seed_shader_sse41: .byte 102,15,110,194 // movd %edx,%xmm0 .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 .byte 15,91,200 // cvtdq2ps %xmm0,%xmm1 .byte 15,40,21,220,94,0,0 // movaps 0x5edc(%rip),%xmm2 # 5fa0 <_sk_callback_sse41+0xf4> .byte 15,88,202 // addps %xmm2,%xmm1 .byte 15,16,7 // movups (%rdi),%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 102,15,110,201 // movd %ecx,%xmm1 .byte 102,15,112,201,0 // pshufd $0x0,%xmm1,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,21,203,94,0,0 // movaps 0x5ecb(%rip),%xmm2 # 5fb0 <_sk_callback_sse41+0x104> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,87,237 // xorps %xmm5,%xmm5 .byte 15,87,246 // xorps %xmm6,%xmm6 .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_dither_sse41 .globl _sk_dither_sse41 FUNCTION(_sk_dither_sse41) _sk_dither_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,68,15,110,194 // movd %edx,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 243,68,15,111,79,32 // movdqu 0x20(%rdi),%xmm9 .byte 102,69,15,254,200 // paddd %xmm8,%xmm9 .byte 102,68,15,110,193 // movd %ecx,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 102,69,15,239,193 // pxor %xmm9,%xmm8 .byte 102,68,15,111,21,153,94,0,0 // movdqa 0x5e99(%rip),%xmm10 # 5fc0 <_sk_callback_sse41+0x114> .byte 102,69,15,111,216 // movdqa %xmm8,%xmm11 .byte 102,69,15,219,218 // pand %xmm10,%xmm11 .byte 102,65,15,114,243,5 // pslld $0x5,%xmm11 .byte 102,69,15,219,209 // pand %xmm9,%xmm10 .byte 102,65,15,114,242,4 // pslld $0x4,%xmm10 .byte 102,68,15,111,37,133,94,0,0 // movdqa 0x5e85(%rip),%xmm12 # 5fd0 <_sk_callback_sse41+0x124> .byte 102,68,15,111,45,140,94,0,0 // movdqa 0x5e8c(%rip),%xmm13 # 5fe0 <_sk_callback_sse41+0x134> .byte 102,69,15,111,240 // movdqa %xmm8,%xmm14 .byte 102,69,15,219,245 // pand %xmm13,%xmm14 .byte 102,65,15,114,246,2 // pslld $0x2,%xmm14 .byte 102,69,15,219,233 // pand %xmm9,%xmm13 .byte 102,69,15,254,237 // paddd %xmm13,%xmm13 .byte 102,69,15,219,196 // pand %xmm12,%xmm8 .byte 102,65,15,114,208,1 // psrld $0x1,%xmm8 .byte 102,69,15,219,204 // pand %xmm12,%xmm9 .byte 102,65,15,114,209,2 // psrld $0x2,%xmm9 .byte 102,69,15,235,234 // por %xmm10,%xmm13 .byte 102,69,15,235,233 // por %xmm9,%xmm13 .byte 102,69,15,235,243 // por %xmm11,%xmm14 .byte 102,69,15,235,245 // por %xmm13,%xmm14 .byte 102,69,15,235,240 // por %xmm8,%xmm14 .byte 69,15,91,198 // cvtdq2ps %xmm14,%xmm8 .byte 68,15,89,5,71,94,0,0 // mulps 0x5e47(%rip),%xmm8 # 5ff0 <_sk_callback_sse41+0x144> .byte 68,15,88,5,79,94,0,0 // addps 0x5e4f(%rip),%xmm8 # 6000 <_sk_callback_sse41+0x154> .byte 243,68,15,16,16 // movss (%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 68,15,88,210 // addps %xmm2,%xmm10 .byte 15,93,195 // minps %xmm3,%xmm0 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,192 // maxps %xmm0,%xmm8 .byte 15,93,203 // minps %xmm3,%xmm1 .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 68,15,95,201 // maxps %xmm1,%xmm9 .byte 68,15,93,211 // minps %xmm3,%xmm10 .byte 65,15,95,210 // maxps %xmm10,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_uniform_color_sse41 .globl _sk_uniform_color_sse41 FUNCTION(_sk_uniform_color_sse41) _sk_uniform_color_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,80,8 // movss 0x8(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,12 // movss 0xc(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_black_color_sse41 .globl _sk_black_color_sse41 FUNCTION(_sk_black_color_sse41) _sk_black_color_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,229,93,0,0 // movaps 0x5de5(%rip),%xmm3 # 6010 <_sk_callback_sse41+0x164> .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_white_color_sse41 .globl _sk_white_color_sse41 FUNCTION(_sk_white_color_sse41) _sk_white_color_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,5,225,93,0,0 // movaps 0x5de1(%rip),%xmm0 # 6020 <_sk_callback_sse41+0x174> .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_load_rgba_sse41 .globl _sk_load_rgba_sse41 FUNCTION(_sk_load_rgba_sse41) _sk_load_rgba_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 15,16,72,16 // movups 0x10(%rax),%xmm1 .byte 15,16,80,32 // movups 0x20(%rax),%xmm2 .byte 15,16,88,48 // movups 0x30(%rax),%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_rgba_sse41 .globl _sk_store_rgba_sse41 FUNCTION(_sk_store_rgba_sse41) _sk_store_rgba_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,17,0 // movups %xmm0,(%rax) .byte 15,17,72,16 // movups %xmm1,0x10(%rax) .byte 15,17,80,32 // movups %xmm2,0x20(%rax) .byte 15,17,88,48 // movups %xmm3,0x30(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clear_sse41 .globl _sk_clear_sse41 FUNCTION(_sk_clear_sse41) _sk_clear_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcatop_sse41 .globl _sk_srcatop_sse41 FUNCTION(_sk_srcatop_sse41) _sk_srcatop_sse41: .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 68,15,40,5,161,93,0,0 // movaps 0x5da1(%rip),%xmm8 # 6030 <_sk_callback_sse41+0x184> .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 65,15,88,193 // addps %xmm9,%xmm0 .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,88,209 // addps %xmm9,%xmm2 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 65,15,88,216 // addps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstatop_sse41 .globl _sk_dstatop_sse41 FUNCTION(_sk_dstatop_sse41) _sk_dstatop_sse41: .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 68,15,89,196 // mulps %xmm4,%xmm8 .byte 68,15,40,13,100,93,0,0 // movaps 0x5d64(%rip),%xmm9 # 6040 <_sk_callback_sse41+0x194> .byte 68,15,92,207 // subps %xmm7,%xmm9 .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 68,15,89,197 // mulps %xmm5,%xmm8 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 65,15,88,200 // addps %xmm8,%xmm1 .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 68,15,89,198 // mulps %xmm6,%xmm8 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 65,15,88,208 // addps %xmm8,%xmm2 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 65,15,88,217 // addps %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcin_sse41 .globl _sk_srcin_sse41 FUNCTION(_sk_srcin_sse41) _sk_srcin_sse41: .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstin_sse41 .globl _sk_dstin_sse41 FUNCTION(_sk_dstin_sse41) _sk_dstin_sse41: .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcout_sse41 .globl _sk_srcout_sse41 FUNCTION(_sk_srcout_sse41) _sk_srcout_sse41: .byte 68,15,40,5,8,93,0,0 // movaps 0x5d08(%rip),%xmm8 # 6050 <_sk_callback_sse41+0x1a4> .byte 68,15,92,199 // subps %xmm7,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstout_sse41 .globl _sk_dstout_sse41 FUNCTION(_sk_dstout_sse41) _sk_dstout_sse41: .byte 68,15,40,5,248,92,0,0 // movaps 0x5cf8(%rip),%xmm8 # 6060 <_sk_callback_sse41+0x1b4> .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_sse41 .globl _sk_srcover_sse41 FUNCTION(_sk_srcover_sse41) _sk_srcover_sse41: .byte 68,15,40,5,219,92,0,0 // movaps 0x5cdb(%rip),%xmm8 # 6070 <_sk_callback_sse41+0x1c4> .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 65,15,88,193 // addps %xmm9,%xmm0 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,88,209 // addps %xmm9,%xmm2 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 65,15,88,216 // addps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstover_sse41 .globl _sk_dstover_sse41 FUNCTION(_sk_dstover_sse41) _sk_dstover_sse41: .byte 68,15,40,5,175,92,0,0 // movaps 0x5caf(%rip),%xmm8 # 6080 <_sk_callback_sse41+0x1d4> .byte 68,15,92,199 // subps %xmm7,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_modulate_sse41 .globl _sk_modulate_sse41 FUNCTION(_sk_modulate_sse41) _sk_modulate_sse41: .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_multiply_sse41 .globl _sk_multiply_sse41 FUNCTION(_sk_multiply_sse41) _sk_multiply_sse41: .byte 68,15,40,5,131,92,0,0 // movaps 0x5c83(%rip),%xmm8 # 6090 <_sk_callback_sse41+0x1e4> .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,92,207 // subps %xmm7,%xmm9 .byte 69,15,40,209 // movaps %xmm9,%xmm10 .byte 68,15,89,208 // mulps %xmm0,%xmm10 .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,89,220 // mulps %xmm4,%xmm11 .byte 69,15,88,218 // addps %xmm10,%xmm11 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 65,15,88,195 // addps %xmm11,%xmm0 .byte 69,15,40,209 // movaps %xmm9,%xmm10 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,89,221 // mulps %xmm5,%xmm11 .byte 69,15,88,218 // addps %xmm10,%xmm11 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 65,15,88,203 // addps %xmm11,%xmm1 .byte 69,15,40,209 // movaps %xmm9,%xmm10 .byte 68,15,89,210 // mulps %xmm2,%xmm10 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,89,222 // mulps %xmm6,%xmm11 .byte 69,15,88,218 // addps %xmm10,%xmm11 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 65,15,88,211 // addps %xmm11,%xmm2 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 65,15,88,216 // addps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_plus__sse41 .globl _sk_plus__sse41 FUNCTION(_sk_plus__sse41) _sk_plus__sse41: .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_screen_sse41 .globl _sk_screen_sse41 FUNCTION(_sk_screen_sse41) _sk_screen_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 68,15,89,196 // mulps %xmm4,%xmm8 .byte 65,15,92,192 // subps %xmm8,%xmm0 .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 68,15,88,197 // addps %xmm5,%xmm8 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 68,15,92,193 // subps %xmm1,%xmm8 .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 68,15,88,206 // addps %xmm6,%xmm9 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 68,15,92,202 // subps %xmm2,%xmm9 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,88,215 // addps %xmm7,%xmm10 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 65,15,40,218 // movaps %xmm10,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_xor__sse41 .globl _sk_xor__sse41 FUNCTION(_sk_xor__sse41) _sk_xor__sse41: .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 15,40,29,184,91,0,0 // movaps 0x5bb8(%rip),%xmm3 # 60a0 <_sk_callback_sse41+0x1f4> .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,92,207 // subps %xmm7,%xmm9 .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 65,15,92,216 // subps %xmm8,%xmm3 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,89,212 // mulps %xmm4,%xmm10 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,89,213 // mulps %xmm5,%xmm10 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,89,214 // mulps %xmm6,%xmm10 .byte 65,15,88,210 // addps %xmm10,%xmm2 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 65,15,88,217 // addps %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_darken_sse41 .globl _sk_darken_sse41 FUNCTION(_sk_darken_sse41) _sk_darken_sse41: .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 68,15,89,207 // mulps %xmm7,%xmm9 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 68,15,95,201 // maxps %xmm1,%xmm9 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 69,15,95,193 // maxps %xmm9,%xmm8 .byte 65,15,92,200 // subps %xmm8,%xmm1 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,88,198 // addps %xmm6,%xmm8 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,95,209 // maxps %xmm9,%xmm2 .byte 68,15,92,194 // subps %xmm2,%xmm8 .byte 15,40,21,35,91,0,0 // movaps 0x5b23(%rip),%xmm2 # 60b0 <_sk_callback_sse41+0x204> .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_lighten_sse41 .globl _sk_lighten_sse41 FUNCTION(_sk_lighten_sse41) _sk_lighten_sse41: .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 68,15,89,207 // mulps %xmm7,%xmm9 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 68,15,93,201 // minps %xmm1,%xmm9 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 69,15,93,193 // minps %xmm9,%xmm8 .byte 65,15,92,200 // subps %xmm8,%xmm1 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,88,198 // addps %xmm6,%xmm8 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,93,209 // minps %xmm9,%xmm2 .byte 68,15,92,194 // subps %xmm2,%xmm8 .byte 15,40,21,200,90,0,0 // movaps 0x5ac8(%rip),%xmm2 # 60c0 <_sk_callback_sse41+0x214> .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_difference_sse41 .globl _sk_difference_sse41 FUNCTION(_sk_difference_sse41) _sk_difference_sse41: .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 68,15,89,207 // mulps %xmm7,%xmm9 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 68,15,93,201 // minps %xmm1,%xmm9 .byte 69,15,88,201 // addps %xmm9,%xmm9 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 69,15,93,193 // minps %xmm9,%xmm8 .byte 69,15,88,192 // addps %xmm8,%xmm8 .byte 65,15,92,200 // subps %xmm8,%xmm1 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,88,198 // addps %xmm6,%xmm8 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,93,209 // minps %xmm9,%xmm2 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 68,15,92,194 // subps %xmm2,%xmm8 .byte 15,40,21,98,90,0,0 // movaps 0x5a62(%rip),%xmm2 # 60d0 <_sk_callback_sse41+0x224> .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_exclusion_sse41 .globl _sk_exclusion_sse41 FUNCTION(_sk_exclusion_sse41) _sk_exclusion_sse41: .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 68,15,89,197 // mulps %xmm5,%xmm8 .byte 69,15,88,192 // addps %xmm8,%xmm8 .byte 65,15,92,200 // subps %xmm8,%xmm1 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,88,198 // addps %xmm6,%xmm8 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 68,15,92,194 // subps %xmm2,%xmm8 .byte 15,40,21,34,90,0,0 // movaps 0x5a22(%rip),%xmm2 # 60e0 <_sk_callback_sse41+0x234> .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_colorburn_sse41 .globl _sk_colorburn_sse41 FUNCTION(_sk_colorburn_sse41) _sk_colorburn_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 68,15,40,21,21,90,0,0 // movaps 0x5a15(%rip),%xmm10 # 60f0 <_sk_callback_sse41+0x244> .byte 69,15,40,218 // movaps %xmm10,%xmm11 .byte 68,15,92,223 // subps %xmm7,%xmm11 .byte 69,15,40,203 // movaps %xmm11,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 65,15,94,192 // divps %xmm8,%xmm0 .byte 68,15,40,231 // movaps %xmm7,%xmm12 .byte 68,15,93,224 // minps %xmm0,%xmm12 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 69,15,92,236 // subps %xmm12,%xmm13 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,233 // addps %xmm9,%xmm13 .byte 69,15,40,225 // movaps %xmm9,%xmm12 .byte 68,15,88,228 // addps %xmm4,%xmm12 .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,194,193,0 // cmpeqps %xmm9,%xmm0 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 102,69,15,56,20,232 // blendvps %xmm0,%xmm8,%xmm13 .byte 69,15,40,194 // movaps %xmm10,%xmm8 .byte 68,15,89,196 // mulps %xmm4,%xmm8 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,194,199,0 // cmpeqps %xmm7,%xmm0 .byte 69,15,88,197 // addps %xmm13,%xmm8 .byte 102,69,15,56,20,196 // blendvps %xmm0,%xmm12,%xmm8 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 68,15,89,225 // mulps %xmm1,%xmm12 .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,94,193 // divps %xmm1,%xmm0 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 68,15,93,232 // minps %xmm0,%xmm13 .byte 68,15,40,247 // movaps %xmm7,%xmm14 .byte 69,15,92,245 // subps %xmm13,%xmm14 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 65,15,194,193,0 // cmpeqps %xmm9,%xmm0 .byte 68,15,89,243 // mulps %xmm3,%xmm14 .byte 69,15,88,244 // addps %xmm12,%xmm14 .byte 102,68,15,56,20,241 // blendvps %xmm0,%xmm1,%xmm14 .byte 68,15,88,229 // addps %xmm5,%xmm12 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 65,15,88,206 // addps %xmm14,%xmm1 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,194,199,0 // cmpeqps %xmm7,%xmm0 .byte 102,65,15,56,20,204 // blendvps %xmm0,%xmm12,%xmm1 .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 15,92,198 // subps %xmm6,%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,94,194 // divps %xmm2,%xmm0 .byte 68,15,40,231 // movaps %xmm7,%xmm12 .byte 68,15,93,224 // minps %xmm0,%xmm12 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 69,15,92,236 // subps %xmm12,%xmm13 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 68,15,194,202,0 // cmpeqps %xmm2,%xmm9 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,235 // addps %xmm11,%xmm13 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,68,15,56,20,234 // blendvps %xmm0,%xmm2,%xmm13 .byte 68,15,88,222 // addps %xmm6,%xmm11 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 65,15,88,213 // addps %xmm13,%xmm2 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 15,194,199,0 // cmpeqps %xmm7,%xmm0 .byte 102,65,15,56,20,211 // blendvps %xmm0,%xmm11,%xmm2 .byte 68,15,89,215 // mulps %xmm7,%xmm10 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_colordodge_sse41 .globl _sk_colordodge_sse41 FUNCTION(_sk_colordodge_sse41) _sk_colordodge_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 68,15,40,21,243,88,0,0 // movaps 0x58f3(%rip),%xmm10 # 6100 <_sk_callback_sse41+0x254> .byte 69,15,40,218 // movaps %xmm10,%xmm11 .byte 68,15,92,223 // subps %xmm7,%xmm11 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 69,15,89,224 // mulps %xmm8,%xmm12 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 65,15,92,192 // subps %xmm8,%xmm0 .byte 68,15,94,200 // divps %xmm0,%xmm9 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 68,15,40,247 // movaps %xmm7,%xmm14 .byte 69,15,93,241 // minps %xmm9,%xmm14 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,194,195,0 // cmpeqps %xmm3,%xmm0 .byte 68,15,89,243 // mulps %xmm3,%xmm14 .byte 69,15,88,244 // addps %xmm12,%xmm14 .byte 102,69,15,56,20,240 // blendvps %xmm0,%xmm8,%xmm14 .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 68,15,88,228 // addps %xmm4,%xmm12 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 69,15,40,194 // movaps %xmm10,%xmm8 .byte 68,15,89,196 // mulps %xmm4,%xmm8 .byte 69,15,88,198 // addps %xmm14,%xmm8 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 65,15,194,193,0 // cmpeqps %xmm9,%xmm0 .byte 102,69,15,56,20,196 // blendvps %xmm0,%xmm12,%xmm8 .byte 68,15,40,227 // movaps %xmm3,%xmm12 .byte 68,15,89,229 // mulps %xmm5,%xmm12 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 68,15,94,224 // divps %xmm0,%xmm12 .byte 69,15,40,243 // movaps %xmm11,%xmm14 .byte 68,15,89,241 // mulps %xmm1,%xmm14 .byte 69,15,93,236 // minps %xmm12,%xmm13 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,194,195,0 // cmpeqps %xmm3,%xmm0 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,238 // addps %xmm14,%xmm13 .byte 102,68,15,56,20,233 // blendvps %xmm0,%xmm1,%xmm13 .byte 68,15,88,245 // addps %xmm5,%xmm14 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 65,15,88,205 // addps %xmm13,%xmm1 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 65,15,194,193,0 // cmpeqps %xmm9,%xmm0 .byte 102,65,15,56,20,206 // blendvps %xmm0,%xmm14,%xmm1 .byte 68,15,40,227 // movaps %xmm3,%xmm12 .byte 68,15,89,230 // mulps %xmm6,%xmm12 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,92,194 // subps %xmm2,%xmm0 .byte 68,15,94,224 // divps %xmm0,%xmm12 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,93,236 // minps %xmm12,%xmm13 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,194,195,0 // cmpeqps %xmm3,%xmm0 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,235 // addps %xmm11,%xmm13 .byte 102,68,15,56,20,234 // blendvps %xmm0,%xmm2,%xmm13 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 65,15,88,213 // addps %xmm13,%xmm2 .byte 68,15,194,206,0 // cmpeqps %xmm6,%xmm9 .byte 68,15,88,222 // addps %xmm6,%xmm11 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,65,15,56,20,211 // blendvps %xmm0,%xmm11,%xmm2 .byte 68,15,89,215 // mulps %xmm7,%xmm10 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_hardlight_sse41 .globl _sk_hardlight_sse41 FUNCTION(_sk_hardlight_sse41) _sk_hardlight_sse41: .byte 15,41,116,36,232 // movaps %xmm6,-0x18(%rsp) .byte 68,15,40,229 // movaps %xmm5,%xmm12 .byte 15,40,244 // movaps %xmm4,%xmm6 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 68,15,40,21,204,87,0,0 // movaps 0x57cc(%rip),%xmm10 # 6110 <_sk_callback_sse41+0x264> .byte 65,15,40,234 // movaps %xmm10,%xmm5 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 68,15,92,212 // subps %xmm4,%xmm10 .byte 69,15,40,194 // movaps %xmm10,%xmm8 .byte 68,15,89,198 // mulps %xmm6,%xmm8 .byte 68,15,88,192 // addps %xmm0,%xmm8 .byte 68,15,40,252 // movaps %xmm4,%xmm15 .byte 69,15,92,249 // subps %xmm9,%xmm15 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 68,15,40,247 // movaps %xmm7,%xmm14 .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 15,92,198 // subps %xmm6,%xmm0 .byte 65,15,89,199 // mulps %xmm15,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 68,15,40,251 // movaps %xmm3,%xmm15 .byte 68,15,92,248 // subps %xmm0,%xmm15 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,196,2 // cmpleps %xmm4,%xmm0 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 69,15,88,201 // addps %xmm9,%xmm9 .byte 102,69,15,56,20,249 // blendvps %xmm0,%xmm9,%xmm15 .byte 68,15,40,221 // movaps %xmm5,%xmm11 .byte 68,15,89,217 // mulps %xmm1,%xmm11 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 69,15,40,204 // movaps %xmm12,%xmm9 .byte 69,15,92,233 // subps %xmm9,%xmm13 .byte 68,15,89,232 // mulps %xmm0,%xmm13 .byte 69,15,88,237 // addps %xmm13,%xmm13 .byte 68,15,40,227 // movaps %xmm3,%xmm12 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,196,2 // cmpleps %xmm4,%xmm0 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 102,68,15,56,20,225 // blendvps %xmm0,%xmm1,%xmm12 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 69,15,40,202 // movaps %xmm10,%xmm9 .byte 68,15,89,215 // mulps %xmm7,%xmm10 .byte 69,15,88,199 // addps %xmm15,%xmm8 .byte 65,15,89,205 // mulps %xmm13,%xmm1 .byte 65,15,88,203 // addps %xmm11,%xmm1 .byte 65,15,88,204 // addps %xmm12,%xmm1 .byte 15,89,234 // mulps %xmm2,%xmm5 .byte 68,15,40,92,36,232 // movaps -0x18(%rsp),%xmm11 .byte 69,15,89,203 // mulps %xmm11,%xmm9 .byte 68,15,88,205 // addps %xmm5,%xmm9 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,196,2 // cmpleps %xmm4,%xmm0 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,92,234 // subps %xmm2,%xmm5 .byte 65,15,89,211 // mulps %xmm11,%xmm2 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 69,15,92,243 // subps %xmm11,%xmm14 .byte 68,15,89,245 // mulps %xmm5,%xmm14 .byte 69,15,88,246 // addps %xmm14,%xmm14 .byte 65,15,92,222 // subps %xmm14,%xmm3 .byte 102,15,56,20,218 // blendvps %xmm0,%xmm2,%xmm3 .byte 68,15,88,203 // addps %xmm3,%xmm9 .byte 65,15,88,226 // addps %xmm10,%xmm4 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 65,15,40,237 // movaps %xmm13,%xmm5 .byte 65,15,40,243 // movaps %xmm11,%xmm6 .byte 255,224 // jmpq *%rax HIDDEN _sk_overlay_sse41 .globl _sk_overlay_sse41 FUNCTION(_sk_overlay_sse41) _sk_overlay_sse41: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,240 // movaps %xmm0,%xmm14 .byte 68,15,40,21,177,86,0,0 // movaps 0x56b1(%rip),%xmm10 # 6120 <_sk_callback_sse41+0x274> .byte 69,15,40,218 // movaps %xmm10,%xmm11 .byte 68,15,92,223 // subps %xmm7,%xmm11 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,89,198 // mulps %xmm14,%xmm0 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 69,15,40,194 // movaps %xmm10,%xmm8 .byte 68,15,89,196 // mulps %xmm4,%xmm8 .byte 68,15,88,192 // addps %xmm0,%xmm8 .byte 68,15,40,235 // movaps %xmm3,%xmm13 .byte 69,15,92,238 // subps %xmm14,%xmm13 .byte 68,15,89,244 // mulps %xmm4,%xmm14 .byte 15,40,207 // movaps %xmm7,%xmm1 .byte 15,92,204 // subps %xmm4,%xmm1 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,199,2 // cmpleps %xmm7,%xmm0 .byte 69,15,88,246 // addps %xmm14,%xmm14 .byte 68,15,40,227 // movaps %xmm3,%xmm12 .byte 68,15,89,231 // mulps %xmm7,%xmm12 .byte 65,15,89,205 // mulps %xmm13,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 69,15,40,236 // movaps %xmm12,%xmm13 .byte 68,15,92,233 // subps %xmm1,%xmm13 .byte 102,69,15,56,20,238 // blendvps %xmm0,%xmm14,%xmm13 .byte 69,15,88,197 // addps %xmm13,%xmm8 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 68,15,40,235 // movaps %xmm3,%xmm13 .byte 69,15,92,233 // subps %xmm9,%xmm13 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 68,15,40,247 // movaps %xmm7,%xmm14 .byte 68,15,92,245 // subps %xmm5,%xmm14 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,199,2 // cmpleps %xmm7,%xmm0 .byte 69,15,88,201 // addps %xmm9,%xmm9 .byte 69,15,89,245 // mulps %xmm13,%xmm14 .byte 69,15,88,246 // addps %xmm14,%xmm14 .byte 69,15,40,236 // movaps %xmm12,%xmm13 .byte 69,15,92,238 // subps %xmm14,%xmm13 .byte 102,69,15,56,20,233 // blendvps %xmm0,%xmm9,%xmm13 .byte 65,15,88,205 // addps %xmm13,%xmm1 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,40,202 // movaps %xmm10,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 69,15,88,203 // addps %xmm11,%xmm9 .byte 68,15,40,219 // movaps %xmm3,%xmm11 .byte 68,15,92,218 // subps %xmm2,%xmm11 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 68,15,92,238 // subps %xmm6,%xmm13 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,199,2 // cmpleps %xmm7,%xmm0 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 69,15,89,235 // mulps %xmm11,%xmm13 .byte 69,15,88,237 // addps %xmm13,%xmm13 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 102,68,15,56,20,226 // blendvps %xmm0,%xmm2,%xmm12 .byte 69,15,88,204 // addps %xmm12,%xmm9 .byte 68,15,89,215 // mulps %xmm7,%xmm10 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_softlight_sse41 .globl _sk_softlight_sse41 FUNCTION(_sk_softlight_sse41) _sk_softlight_sse41: .byte 15,41,116,36,216 // movaps %xmm6,-0x28(%rsp) .byte 15,40,244 // movaps %xmm4,%xmm6 .byte 15,41,84,36,232 // movaps %xmm2,-0x18(%rsp) .byte 15,41,76,36,200 // movaps %xmm1,-0x38(%rsp) .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 68,15,194,207,1 // cmpltps %xmm7,%xmm9 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 15,94,199 // divps %xmm7,%xmm0 .byte 65,15,84,193 // andps %xmm9,%xmm0 .byte 15,40,13,136,85,0,0 // movaps 0x5588(%rip),%xmm1 # 6130 <_sk_callback_sse41+0x284> .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 68,15,92,208 // subps %xmm0,%xmm10 .byte 68,15,40,240 // movaps %xmm0,%xmm14 .byte 68,15,40,248 // movaps %xmm0,%xmm15 .byte 15,82,208 // rsqrtps %xmm0,%xmm2 .byte 68,15,83,218 // rcpps %xmm2,%xmm11 .byte 68,15,92,216 // subps %xmm0,%xmm11 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,89,210 // mulps %xmm2,%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 68,15,40,45,102,85,0,0 // movaps 0x5566(%rip),%xmm13 # 6140 <_sk_callback_sse41+0x294> .byte 69,15,88,245 // addps %xmm13,%xmm14 .byte 68,15,89,242 // mulps %xmm2,%xmm14 .byte 68,15,40,37,102,85,0,0 // movaps 0x5566(%rip),%xmm12 # 6150 <_sk_callback_sse41+0x2a4> .byte 69,15,89,252 // mulps %xmm12,%xmm15 .byte 69,15,88,254 // addps %xmm14,%xmm15 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,199,2 // cmpleps %xmm7,%xmm0 .byte 102,69,15,56,20,223 // blendvps %xmm0,%xmm15,%xmm11 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,92,211 // subps %xmm3,%xmm2 .byte 68,15,89,210 // mulps %xmm2,%xmm10 .byte 68,15,88,211 // addps %xmm3,%xmm10 .byte 68,15,89,214 // mulps %xmm6,%xmm10 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 68,15,88,218 // addps %xmm2,%xmm11 .byte 15,194,195,2 // cmpleps %xmm3,%xmm0 .byte 102,69,15,56,20,218 // blendvps %xmm0,%xmm10,%xmm11 .byte 68,15,40,213 // movaps %xmm5,%xmm10 .byte 68,15,94,215 // divps %xmm7,%xmm10 .byte 69,15,84,209 // andps %xmm9,%xmm10 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,89,210 // mulps %xmm2,%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 65,15,88,197 // addps %xmm13,%xmm0 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 65,15,89,212 // mulps %xmm12,%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 65,15,82,194 // rsqrtps %xmm10,%xmm0 .byte 68,15,83,240 // rcpps %xmm0,%xmm14 .byte 69,15,92,242 // subps %xmm10,%xmm14 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,199,2 // cmpleps %xmm7,%xmm0 .byte 102,68,15,56,20,242 // blendvps %xmm0,%xmm2,%xmm14 .byte 68,15,40,249 // movaps %xmm1,%xmm15 .byte 69,15,92,250 // subps %xmm10,%xmm15 .byte 15,40,108,36,200 // movaps -0x38(%rsp),%xmm5 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,92,211 // subps %xmm3,%xmm2 .byte 68,15,89,250 // mulps %xmm2,%xmm15 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,89,242 // mulps %xmm2,%xmm14 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,41,100,36,184 // movaps %xmm4,-0x48(%rsp) .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 68,15,88,242 // addps %xmm2,%xmm14 .byte 68,15,88,251 // addps %xmm3,%xmm15 .byte 68,15,89,252 // mulps %xmm4,%xmm15 .byte 15,194,195,2 // cmpleps %xmm3,%xmm0 .byte 102,69,15,56,20,247 // blendvps %xmm0,%xmm15,%xmm14 .byte 68,15,40,249 // movaps %xmm1,%xmm15 .byte 15,40,100,36,216 // movaps -0x28(%rsp),%xmm4 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,94,199 // divps %xmm7,%xmm0 .byte 65,15,84,193 // andps %xmm9,%xmm0 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 15,92,200 // subps %xmm0,%xmm1 .byte 68,15,88,232 // addps %xmm0,%xmm13 .byte 68,15,89,224 // mulps %xmm0,%xmm12 .byte 15,82,208 // rsqrtps %xmm0,%xmm2 .byte 68,15,83,202 // rcpps %xmm2,%xmm9 .byte 68,15,92,200 // subps %xmm0,%xmm9 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,89,210 // mulps %xmm2,%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 68,15,89,234 // mulps %xmm2,%xmm13 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,199,2 // cmpleps %xmm7,%xmm0 .byte 102,69,15,56,20,204 // blendvps %xmm0,%xmm12,%xmm9 .byte 68,15,40,100,36,232 // movaps -0x18(%rsp),%xmm12 .byte 65,15,40,196 // movaps %xmm12,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,89,202 // mulps %xmm2,%xmm9 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 68,15,88,202 // addps %xmm2,%xmm9 .byte 15,88,203 // addps %xmm3,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,194,195,2 // cmpleps %xmm3,%xmm0 .byte 102,68,15,56,20,201 // blendvps %xmm0,%xmm1,%xmm9 .byte 68,15,92,255 // subps %xmm7,%xmm15 .byte 69,15,89,199 // mulps %xmm15,%xmm8 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 65,15,89,207 // mulps %xmm15,%xmm1 .byte 69,15,89,252 // mulps %xmm12,%xmm15 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 68,15,88,192 // addps %xmm0,%xmm8 .byte 69,15,88,195 // addps %xmm11,%xmm8 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 15,40,108,36,184 // movaps -0x48(%rsp),%xmm5 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 65,15,88,206 // addps %xmm14,%xmm1 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 65,15,88,199 // addps %xmm15,%xmm0 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 68,15,89,215 // mulps %xmm7,%xmm10 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,40,242 // movaps %xmm2,%xmm6 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_hue_sse41 .globl _sk_hue_sse41 FUNCTION(_sk_hue_sse41) _sk_hue_sse41: .byte 15,41,124,36,152 // movaps %xmm7,-0x68(%rsp) .byte 68,15,40,246 // movaps %xmm6,%xmm14 .byte 15,40,244 // movaps %xmm4,%xmm6 .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 15,41,84,36,232 // movaps %xmm2,-0x18(%rsp) .byte 15,41,76,36,216 // movaps %xmm1,-0x28(%rsp) .byte 68,15,40,208 // movaps %xmm0,%xmm10 .byte 68,15,41,84,36,200 // movaps %xmm10,-0x38(%rsp) .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 68,15,40,234 // movaps %xmm2,%xmm13 .byte 69,15,89,232 // mulps %xmm8,%xmm13 .byte 68,15,40,205 // movaps %xmm5,%xmm9 .byte 68,15,40,221 // movaps %xmm5,%xmm11 .byte 15,41,108,36,184 // movaps %xmm5,-0x48(%rsp) .byte 69,15,95,222 // maxps %xmm14,%xmm11 .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 68,15,40,230 // movaps %xmm6,%xmm12 .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 65,15,95,211 // maxps %xmm11,%xmm2 .byte 65,15,40,230 // movaps %xmm14,%xmm4 .byte 15,41,100,36,168 // movaps %xmm4,-0x58(%rsp) .byte 68,15,93,204 // minps %xmm4,%xmm9 .byte 65,15,93,249 // minps %xmm9,%xmm7 .byte 15,92,215 // subps %xmm7,%xmm2 .byte 15,40,249 // movaps %xmm1,%xmm7 .byte 65,15,93,253 // minps %xmm13,%xmm7 .byte 65,15,40,218 // movaps %xmm10,%xmm3 .byte 15,93,223 // minps %xmm7,%xmm3 .byte 15,40,249 // movaps %xmm1,%xmm7 .byte 65,15,95,253 // maxps %xmm13,%xmm7 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 15,95,199 // maxps %xmm7,%xmm0 .byte 15,40,253 // movaps %xmm5,%xmm7 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,92,195 // subps %xmm3,%xmm0 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 15,92,203 // subps %xmm3,%xmm1 .byte 68,15,92,235 // subps %xmm3,%xmm13 .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 68,15,89,210 // mulps %xmm2,%xmm10 .byte 68,15,94,208 // divps %xmm0,%xmm10 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,94,200 // divps %xmm0,%xmm1 .byte 68,15,89,234 // mulps %xmm2,%xmm13 .byte 68,15,94,232 // divps %xmm0,%xmm13 .byte 15,194,195,4 // cmpneqps %xmm3,%xmm0 .byte 68,15,84,208 // andps %xmm0,%xmm10 .byte 15,84,200 // andps %xmm0,%xmm1 .byte 68,15,84,232 // andps %xmm0,%xmm13 .byte 15,40,5,209,82,0,0 // movaps 0x52d1(%rip),%xmm0 # 6160 <_sk_callback_sse41+0x2b4> .byte 68,15,89,224 // mulps %xmm0,%xmm12 .byte 15,40,21,214,82,0,0 // movaps 0x52d6(%rip),%xmm2 # 6170 <_sk_callback_sse41+0x2c4> .byte 15,89,250 // mulps %xmm2,%xmm7 .byte 65,15,88,252 // addps %xmm12,%xmm7 .byte 68,15,40,53,215,82,0,0 // movaps 0x52d7(%rip),%xmm14 # 6180 <_sk_callback_sse41+0x2d4> .byte 68,15,40,252 // movaps %xmm4,%xmm15 .byte 69,15,89,254 // mulps %xmm14,%xmm15 .byte 68,15,88,255 // addps %xmm7,%xmm15 .byte 65,15,40,218 // movaps %xmm10,%xmm3 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,40,249 // movaps %xmm1,%xmm7 .byte 15,89,250 // mulps %xmm2,%xmm7 .byte 15,88,251 // addps %xmm3,%xmm7 .byte 65,15,40,221 // movaps %xmm13,%xmm3 .byte 65,15,89,222 // mulps %xmm14,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 69,15,89,248 // mulps %xmm8,%xmm15 .byte 68,15,92,251 // subps %xmm3,%xmm15 .byte 69,15,88,215 // addps %xmm15,%xmm10 .byte 65,15,88,207 // addps %xmm15,%xmm1 .byte 69,15,88,253 // addps %xmm13,%xmm15 .byte 15,40,217 // movaps %xmm1,%xmm3 .byte 65,15,93,223 // minps %xmm15,%xmm3 .byte 65,15,40,250 // movaps %xmm10,%xmm7 .byte 15,93,251 // minps %xmm3,%xmm7 .byte 65,15,89,194 // mulps %xmm10,%xmm0 .byte 15,89,209 // mulps %xmm1,%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 69,15,89,247 // mulps %xmm15,%xmm14 .byte 68,15,88,242 // addps %xmm2,%xmm14 .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 68,15,194,207,2 // cmpleps %xmm7,%xmm9 .byte 65,15,40,222 // movaps %xmm14,%xmm3 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 69,15,40,234 // movaps %xmm10,%xmm13 .byte 69,15,92,238 // subps %xmm14,%xmm13 .byte 69,15,89,238 // mulps %xmm14,%xmm13 .byte 68,15,94,235 // divps %xmm3,%xmm13 .byte 69,15,88,238 // addps %xmm14,%xmm13 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,69,15,56,20,234 // blendvps %xmm0,%xmm10,%xmm13 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 65,15,95,199 // maxps %xmm15,%xmm0 .byte 68,15,95,208 // maxps %xmm0,%xmm10 .byte 65,15,40,248 // movaps %xmm8,%xmm7 .byte 15,40,108,36,152 // movaps -0x68(%rsp),%xmm5 .byte 15,89,253 // mulps %xmm5,%xmm7 .byte 15,40,231 // movaps %xmm7,%xmm4 .byte 65,15,194,226,1 // cmpltps %xmm10,%xmm4 .byte 65,15,40,213 // movaps %xmm13,%xmm2 .byte 65,15,92,214 // subps %xmm14,%xmm2 .byte 68,15,40,223 // movaps %xmm7,%xmm11 .byte 69,15,92,222 // subps %xmm14,%xmm11 .byte 65,15,89,211 // mulps %xmm11,%xmm2 .byte 69,15,92,214 // subps %xmm14,%xmm10 .byte 65,15,94,210 // divps %xmm10,%xmm2 .byte 65,15,88,214 // addps %xmm14,%xmm2 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 102,68,15,56,20,234 // blendvps %xmm0,%xmm2,%xmm13 .byte 68,15,40,225 // movaps %xmm1,%xmm12 .byte 69,15,92,230 // subps %xmm14,%xmm12 .byte 69,15,89,230 // mulps %xmm14,%xmm12 .byte 68,15,94,227 // divps %xmm3,%xmm12 .byte 69,15,88,230 // addps %xmm14,%xmm12 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,68,15,56,20,225 // blendvps %xmm0,%xmm1,%xmm12 .byte 65,15,40,204 // movaps %xmm12,%xmm1 .byte 65,15,92,206 // subps %xmm14,%xmm1 .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 65,15,94,202 // divps %xmm10,%xmm1 .byte 65,15,88,206 // addps %xmm14,%xmm1 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 102,68,15,56,20,225 // blendvps %xmm0,%xmm1,%xmm12 .byte 65,15,40,207 // movaps %xmm15,%xmm1 .byte 65,15,92,206 // subps %xmm14,%xmm1 .byte 65,15,89,206 // mulps %xmm14,%xmm1 .byte 15,94,203 // divps %xmm3,%xmm1 .byte 65,15,88,206 // addps %xmm14,%xmm1 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,65,15,56,20,207 // blendvps %xmm0,%xmm15,%xmm1 .byte 15,40,209 // movaps %xmm1,%xmm2 .byte 65,15,92,214 // subps %xmm14,%xmm2 .byte 65,15,89,211 // mulps %xmm11,%xmm2 .byte 65,15,94,210 // divps %xmm10,%xmm2 .byte 65,15,88,214 // addps %xmm14,%xmm2 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 102,15,56,20,202 // blendvps %xmm0,%xmm2,%xmm1 .byte 68,15,40,13,155,81,0,0 // movaps 0x519b(%rip),%xmm9 # 6190 <_sk_callback_sse41+0x2e4> .byte 65,15,40,225 // movaps %xmm9,%xmm4 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 15,40,68,36,200 // movaps -0x38(%rsp),%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,40,92,36,216 // movaps -0x28(%rsp),%xmm3 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 15,89,100,36,232 // mulps -0x18(%rsp),%xmm4 .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,88,197 // addps %xmm5,%xmm8 .byte 68,15,40,213 // movaps %xmm5,%xmm10 .byte 68,15,92,199 // subps %xmm7,%xmm8 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 68,15,95,234 // maxps %xmm2,%xmm13 .byte 68,15,95,226 // maxps %xmm2,%xmm12 .byte 15,95,202 // maxps %xmm2,%xmm1 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 65,15,88,197 // addps %xmm13,%xmm0 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 15,40,108,36,184 // movaps -0x48(%rsp),%xmm5 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 65,15,88,220 // addps %xmm12,%xmm3 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,40,92,36,168 // movaps -0x58(%rsp),%xmm3 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 68,15,88,204 // addps %xmm4,%xmm9 .byte 68,15,88,201 // addps %xmm1,%xmm9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,40,243 // movaps %xmm3,%xmm6 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 65,15,40,250 // movaps %xmm10,%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_saturation_sse41 .globl _sk_saturation_sse41 FUNCTION(_sk_saturation_sse41) _sk_saturation_sse41: .byte 68,15,40,206 // movaps %xmm6,%xmm9 .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,41,76,36,216 // movaps %xmm1,-0x28(%rsp) .byte 15,41,68,36,200 // movaps %xmm0,-0x38(%rsp) .byte 68,15,40,212 // movaps %xmm4,%xmm10 .byte 68,15,89,213 // mulps %xmm5,%xmm10 .byte 68,15,40,220 // movaps %xmm4,%xmm11 .byte 68,15,89,222 // mulps %xmm6,%xmm11 .byte 68,15,40,196 // movaps %xmm4,%xmm8 .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 69,15,40,241 // movaps %xmm9,%xmm14 .byte 68,15,41,116,36,184 // movaps %xmm14,-0x48(%rsp) .byte 15,40,217 // movaps %xmm1,%xmm3 .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 68,15,41,76,36,232 // movaps %xmm9,-0x18(%rsp) .byte 65,15,95,217 // maxps %xmm9,%xmm3 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,95,211 // maxps %xmm3,%xmm2 .byte 68,15,40,225 // movaps %xmm1,%xmm12 .byte 69,15,93,225 // minps %xmm9,%xmm12 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 65,15,93,220 // minps %xmm12,%xmm3 .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,40,231 // movaps %xmm7,%xmm12 .byte 68,15,41,100,36,168 // movaps %xmm12,-0x58(%rsp) .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,93,192 // minps %xmm8,%xmm0 .byte 65,15,40,218 // movaps %xmm10,%xmm3 .byte 15,93,216 // minps %xmm0,%xmm3 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,95,192 // maxps %xmm8,%xmm0 .byte 65,15,40,250 // movaps %xmm10,%xmm7 .byte 15,95,248 // maxps %xmm0,%xmm7 .byte 15,92,251 // subps %xmm3,%xmm7 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 68,15,89,210 // mulps %xmm2,%xmm10 .byte 68,15,94,215 // divps %xmm7,%xmm10 .byte 68,15,92,219 // subps %xmm3,%xmm11 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 68,15,94,223 // divps %xmm7,%xmm11 .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 68,15,94,199 // divps %xmm7,%xmm8 .byte 15,194,248,4 // cmpneqps %xmm0,%xmm7 .byte 68,15,84,215 // andps %xmm7,%xmm10 .byte 68,15,84,223 // andps %xmm7,%xmm11 .byte 68,15,84,199 // andps %xmm7,%xmm8 .byte 15,40,21,85,80,0,0 // movaps 0x5055(%rip),%xmm2 # 61a0 <_sk_callback_sse41+0x2f4> .byte 15,40,221 // movaps %xmm5,%xmm3 .byte 15,89,218 // mulps %xmm2,%xmm3 .byte 15,40,13,88,80,0,0 // movaps 0x5058(%rip),%xmm1 # 61b0 <_sk_callback_sse41+0x304> .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 15,89,249 // mulps %xmm1,%xmm7 .byte 15,88,251 // addps %xmm3,%xmm7 .byte 68,15,40,45,87,80,0,0 // movaps 0x5057(%rip),%xmm13 # 61c0 <_sk_callback_sse41+0x314> .byte 69,15,89,245 // mulps %xmm13,%xmm14 .byte 68,15,88,247 // addps %xmm7,%xmm14 .byte 65,15,40,218 // movaps %xmm10,%xmm3 .byte 15,89,218 // mulps %xmm2,%xmm3 .byte 65,15,40,251 // movaps %xmm11,%xmm7 .byte 15,89,249 // mulps %xmm1,%xmm7 .byte 15,88,251 // addps %xmm3,%xmm7 .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 65,15,89,221 // mulps %xmm13,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 68,15,89,244 // mulps %xmm4,%xmm14 .byte 68,15,92,243 // subps %xmm3,%xmm14 .byte 69,15,88,214 // addps %xmm14,%xmm10 .byte 69,15,88,222 // addps %xmm14,%xmm11 .byte 69,15,88,240 // addps %xmm8,%xmm14 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,93,198 // minps %xmm14,%xmm0 .byte 65,15,40,218 // movaps %xmm10,%xmm3 .byte 15,93,216 // minps %xmm0,%xmm3 .byte 65,15,89,210 // mulps %xmm10,%xmm2 .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 69,15,89,238 // mulps %xmm14,%xmm13 .byte 68,15,88,233 // addps %xmm1,%xmm13 .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 68,15,194,203,2 // cmpleps %xmm3,%xmm9 .byte 65,15,40,253 // movaps %xmm13,%xmm7 .byte 15,92,251 // subps %xmm3,%xmm7 .byte 69,15,40,250 // movaps %xmm10,%xmm15 .byte 69,15,92,253 // subps %xmm13,%xmm15 .byte 69,15,89,253 // mulps %xmm13,%xmm15 .byte 68,15,94,255 // divps %xmm7,%xmm15 .byte 69,15,88,253 // addps %xmm13,%xmm15 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,69,15,56,20,250 // blendvps %xmm0,%xmm10,%xmm15 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,95,198 // maxps %xmm14,%xmm0 .byte 68,15,95,208 // maxps %xmm0,%xmm10 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 65,15,89,212 // mulps %xmm12,%xmm2 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 69,15,194,194,1 // cmpltps %xmm10,%xmm8 .byte 65,15,40,223 // movaps %xmm15,%xmm3 .byte 65,15,92,221 // subps %xmm13,%xmm3 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 65,15,92,205 // subps %xmm13,%xmm1 .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 69,15,92,213 // subps %xmm13,%xmm10 .byte 65,15,94,218 // divps %xmm10,%xmm3 .byte 65,15,88,221 // addps %xmm13,%xmm3 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 102,68,15,56,20,251 // blendvps %xmm0,%xmm3,%xmm15 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 69,15,89,229 // mulps %xmm13,%xmm12 .byte 68,15,94,231 // divps %xmm7,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,69,15,56,20,227 // blendvps %xmm0,%xmm11,%xmm12 .byte 65,15,40,220 // movaps %xmm12,%xmm3 .byte 65,15,92,221 // subps %xmm13,%xmm3 .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 65,15,94,218 // divps %xmm10,%xmm3 .byte 65,15,88,221 // addps %xmm13,%xmm3 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 102,68,15,56,20,227 // blendvps %xmm0,%xmm3,%xmm12 .byte 69,15,40,222 // movaps %xmm14,%xmm11 .byte 69,15,92,221 // subps %xmm13,%xmm11 .byte 69,15,89,221 // mulps %xmm13,%xmm11 .byte 68,15,94,223 // divps %xmm7,%xmm11 .byte 69,15,88,221 // addps %xmm13,%xmm11 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,69,15,56,20,222 // blendvps %xmm0,%xmm14,%xmm11 .byte 65,15,40,251 // movaps %xmm11,%xmm7 .byte 65,15,92,253 // subps %xmm13,%xmm7 .byte 15,89,249 // mulps %xmm1,%xmm7 .byte 65,15,94,250 // divps %xmm10,%xmm7 .byte 65,15,88,253 // addps %xmm13,%xmm7 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 102,68,15,56,20,223 // blendvps %xmm0,%xmm7,%xmm11 .byte 68,15,40,13,29,79,0,0 // movaps 0x4f1d(%rip),%xmm9 # 61d0 <_sk_callback_sse41+0x324> .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 68,15,92,204 // subps %xmm4,%xmm9 .byte 15,40,124,36,168 // movaps -0x58(%rsp),%xmm7 .byte 15,88,231 // addps %xmm7,%xmm4 .byte 15,92,226 // subps %xmm2,%xmm4 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 68,15,95,248 // maxps %xmm0,%xmm15 .byte 68,15,95,224 // maxps %xmm0,%xmm12 .byte 68,15,95,216 // maxps %xmm0,%xmm11 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 68,15,92,199 // subps %xmm7,%xmm8 .byte 15,40,68,36,200 // movaps -0x38(%rsp),%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 65,15,88,199 // addps %xmm15,%xmm0 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,40,84,36,216 // movaps -0x28(%rsp),%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,209 // addps %xmm1,%xmm2 .byte 65,15,88,212 // addps %xmm12,%xmm2 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 68,15,89,68,36,232 // mulps -0x18(%rsp),%xmm8 .byte 15,40,84,36,184 // movaps -0x48(%rsp),%xmm2 .byte 68,15,89,202 // mulps %xmm2,%xmm9 .byte 69,15,88,200 // addps %xmm8,%xmm9 .byte 69,15,88,203 // addps %xmm11,%xmm9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,40,238 // movaps %xmm6,%xmm5 .byte 15,40,242 // movaps %xmm2,%xmm6 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_color_sse41 .globl _sk_color_sse41 FUNCTION(_sk_color_sse41) _sk_color_sse41: .byte 68,15,40,230 // movaps %xmm6,%xmm12 .byte 68,15,41,100,36,200 // movaps %xmm12,-0x38(%rsp) .byte 68,15,40,221 // movaps %xmm5,%xmm11 .byte 68,15,41,92,36,216 // movaps %xmm11,-0x28(%rsp) .byte 68,15,40,212 // movaps %xmm4,%xmm10 .byte 68,15,41,84,36,232 // movaps %xmm10,-0x18(%rsp) .byte 15,40,243 // movaps %xmm3,%xmm6 .byte 15,41,84,36,184 // movaps %xmm2,-0x48(%rsp) .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 69,15,40,240 // movaps %xmm8,%xmm14 .byte 15,40,231 // movaps %xmm7,%xmm4 .byte 68,15,89,244 // mulps %xmm4,%xmm14 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 68,15,40,13,104,78,0,0 // movaps 0x4e68(%rip),%xmm9 # 61e0 <_sk_callback_sse41+0x334> .byte 65,15,40,250 // movaps %xmm10,%xmm7 .byte 65,15,89,249 // mulps %xmm9,%xmm7 .byte 68,15,40,21,104,78,0,0 // movaps 0x4e68(%rip),%xmm10 # 61f0 <_sk_callback_sse41+0x344> .byte 65,15,40,219 // movaps %xmm11,%xmm3 .byte 65,15,89,218 // mulps %xmm10,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 68,15,40,29,101,78,0,0 // movaps 0x4e65(%rip),%xmm11 # 6200 <_sk_callback_sse41+0x354> .byte 69,15,40,236 // movaps %xmm12,%xmm13 .byte 69,15,89,235 // mulps %xmm11,%xmm13 .byte 68,15,88,235 // addps %xmm3,%xmm13 .byte 65,15,40,222 // movaps %xmm14,%xmm3 .byte 65,15,89,217 // mulps %xmm9,%xmm3 .byte 15,40,249 // movaps %xmm1,%xmm7 .byte 65,15,89,250 // mulps %xmm10,%xmm7 .byte 15,88,251 // addps %xmm3,%xmm7 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 65,15,89,219 // mulps %xmm11,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 68,15,89,238 // mulps %xmm6,%xmm13 .byte 68,15,92,235 // subps %xmm3,%xmm13 .byte 69,15,88,245 // addps %xmm13,%xmm14 .byte 65,15,88,205 // addps %xmm13,%xmm1 .byte 68,15,88,232 // addps %xmm0,%xmm13 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 65,15,93,197 // minps %xmm13,%xmm0 .byte 65,15,40,222 // movaps %xmm14,%xmm3 .byte 15,93,216 // minps %xmm0,%xmm3 .byte 69,15,89,206 // mulps %xmm14,%xmm9 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 69,15,88,209 // addps %xmm9,%xmm10 .byte 69,15,89,221 // mulps %xmm13,%xmm11 .byte 69,15,88,218 // addps %xmm10,%xmm11 .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 68,15,194,203,2 // cmpleps %xmm3,%xmm9 .byte 69,15,40,230 // movaps %xmm14,%xmm12 .byte 69,15,92,227 // subps %xmm11,%xmm12 .byte 69,15,89,227 // mulps %xmm11,%xmm12 .byte 65,15,40,251 // movaps %xmm11,%xmm7 .byte 15,92,251 // subps %xmm3,%xmm7 .byte 68,15,94,231 // divps %xmm7,%xmm12 .byte 69,15,88,227 // addps %xmm11,%xmm12 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,69,15,56,20,230 // blendvps %xmm0,%xmm14,%xmm12 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 65,15,95,197 // maxps %xmm13,%xmm0 .byte 65,15,40,214 // movaps %xmm14,%xmm2 .byte 15,95,208 // maxps %xmm0,%xmm2 .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,194,210,1 // cmpltps %xmm2,%xmm10 .byte 69,15,40,244 // movaps %xmm12,%xmm14 .byte 69,15,92,243 // subps %xmm11,%xmm14 .byte 68,15,40,251 // movaps %xmm3,%xmm15 .byte 69,15,92,251 // subps %xmm11,%xmm15 .byte 69,15,89,247 // mulps %xmm15,%xmm14 .byte 65,15,92,211 // subps %xmm11,%xmm2 .byte 68,15,94,242 // divps %xmm2,%xmm14 .byte 69,15,88,243 // addps %xmm11,%xmm14 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 102,69,15,56,20,230 // blendvps %xmm0,%xmm14,%xmm12 .byte 68,15,40,241 // movaps %xmm1,%xmm14 .byte 69,15,92,243 // subps %xmm11,%xmm14 .byte 69,15,89,243 // mulps %xmm11,%xmm14 .byte 68,15,94,247 // divps %xmm7,%xmm14 .byte 69,15,88,243 // addps %xmm11,%xmm14 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,68,15,56,20,241 // blendvps %xmm0,%xmm1,%xmm14 .byte 65,15,40,206 // movaps %xmm14,%xmm1 .byte 65,15,92,203 // subps %xmm11,%xmm1 .byte 65,15,89,207 // mulps %xmm15,%xmm1 .byte 15,94,202 // divps %xmm2,%xmm1 .byte 65,15,88,203 // addps %xmm11,%xmm1 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 102,68,15,56,20,241 // blendvps %xmm0,%xmm1,%xmm14 .byte 65,15,40,205 // movaps %xmm13,%xmm1 .byte 65,15,92,203 // subps %xmm11,%xmm1 .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 15,94,207 // divps %xmm7,%xmm1 .byte 65,15,88,203 // addps %xmm11,%xmm1 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,65,15,56,20,205 // blendvps %xmm0,%xmm13,%xmm1 .byte 15,40,249 // movaps %xmm1,%xmm7 .byte 65,15,92,251 // subps %xmm11,%xmm7 .byte 65,15,89,255 // mulps %xmm15,%xmm7 .byte 15,94,250 // divps %xmm2,%xmm7 .byte 65,15,88,251 // addps %xmm11,%xmm7 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 102,15,56,20,207 // blendvps %xmm0,%xmm7,%xmm1 .byte 68,15,40,13,33,77,0,0 // movaps 0x4d21(%rip),%xmm9 # 6210 <_sk_callback_sse41+0x364> .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 15,89,232 // mulps %xmm0,%xmm5 .byte 15,89,68,36,184 // mulps -0x48(%rsp),%xmm0 .byte 68,15,92,206 // subps %xmm6,%xmm9 .byte 15,88,244 // addps %xmm4,%xmm6 .byte 15,40,252 // movaps %xmm4,%xmm7 .byte 15,92,243 // subps %xmm3,%xmm6 .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 68,15,95,226 // maxps %xmm2,%xmm12 .byte 68,15,95,242 // maxps %xmm2,%xmm14 .byte 15,95,202 // maxps %xmm2,%xmm1 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 15,40,100,36,232 // movaps -0x18(%rsp),%xmm4 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 68,15,88,194 // addps %xmm2,%xmm8 .byte 69,15,88,196 // addps %xmm12,%xmm8 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 15,40,116,36,216 // movaps -0x28(%rsp),%xmm6 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 68,15,40,213 // movaps %xmm5,%xmm10 .byte 68,15,88,210 // addps %xmm2,%xmm10 .byte 69,15,88,214 // addps %xmm14,%xmm10 .byte 15,40,84,36,200 // movaps -0x38(%rsp),%xmm2 .byte 68,15,89,202 // mulps %xmm2,%xmm9 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 68,15,88,201 // addps %xmm1,%xmm9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,238 // movaps %xmm6,%xmm5 .byte 15,40,242 // movaps %xmm2,%xmm6 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_luminosity_sse41 .globl _sk_luminosity_sse41 FUNCTION(_sk_luminosity_sse41) _sk_luminosity_sse41: .byte 15,41,116,36,200 // movaps %xmm6,-0x38(%rsp) .byte 15,41,108,36,232 // movaps %xmm5,-0x18(%rsp) .byte 68,15,40,196 // movaps %xmm4,%xmm8 .byte 68,15,41,68,36,216 // movaps %xmm8,-0x28(%rsp) .byte 15,41,84,36,184 // movaps %xmm2,-0x48(%rsp) .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 68,15,40,219 // movaps %xmm3,%xmm11 .byte 69,15,89,216 // mulps %xmm8,%xmm11 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 68,15,40,5,121,76,0,0 // movaps 0x4c79(%rip),%xmm8 # 6220 <_sk_callback_sse41+0x374> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 68,15,40,21,125,76,0,0 // movaps 0x4c7d(%rip),%xmm10 # 6230 <_sk_callback_sse41+0x384> .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 65,15,89,234 // mulps %xmm10,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 68,15,40,37,123,76,0,0 // movaps 0x4c7b(%rip),%xmm12 # 6240 <_sk_callback_sse41+0x394> .byte 68,15,40,242 // movaps %xmm2,%xmm14 .byte 69,15,89,244 // mulps %xmm12,%xmm14 .byte 68,15,88,245 // addps %xmm5,%xmm14 .byte 65,15,40,235 // movaps %xmm11,%xmm5 .byte 65,15,89,232 // mulps %xmm8,%xmm5 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 65,15,89,210 // mulps %xmm10,%xmm2 .byte 15,88,213 // addps %xmm5,%xmm2 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 65,15,89,236 // mulps %xmm12,%xmm5 .byte 15,88,234 // addps %xmm2,%xmm5 .byte 68,15,89,247 // mulps %xmm7,%xmm14 .byte 68,15,92,245 // subps %xmm5,%xmm14 .byte 69,15,88,222 // addps %xmm14,%xmm11 .byte 69,15,88,206 // addps %xmm14,%xmm9 .byte 68,15,88,240 // addps %xmm0,%xmm14 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,93,198 // minps %xmm14,%xmm0 .byte 65,15,40,235 // movaps %xmm11,%xmm5 .byte 15,93,232 // minps %xmm0,%xmm5 .byte 69,15,89,195 // mulps %xmm11,%xmm8 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,208 // addps %xmm8,%xmm10 .byte 69,15,89,230 // mulps %xmm14,%xmm12 .byte 69,15,88,226 // addps %xmm10,%xmm12 .byte 69,15,87,210 // xorps %xmm10,%xmm10 .byte 68,15,194,213,2 // cmpleps %xmm5,%xmm10 .byte 69,15,40,235 // movaps %xmm11,%xmm13 .byte 69,15,92,236 // subps %xmm12,%xmm13 .byte 69,15,89,236 // mulps %xmm12,%xmm13 .byte 65,15,40,244 // movaps %xmm12,%xmm6 .byte 15,92,245 // subps %xmm5,%xmm6 .byte 68,15,94,238 // divps %xmm6,%xmm13 .byte 69,15,88,236 // addps %xmm12,%xmm13 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 102,69,15,56,20,235 // blendvps %xmm0,%xmm11,%xmm13 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,95,198 // maxps %xmm14,%xmm0 .byte 65,15,40,211 // movaps %xmm11,%xmm2 .byte 15,95,208 // maxps %xmm0,%xmm2 .byte 15,40,235 // movaps %xmm3,%xmm5 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 68,15,40,221 // movaps %xmm5,%xmm11 .byte 68,15,194,218,1 // cmpltps %xmm2,%xmm11 .byte 69,15,40,197 // movaps %xmm13,%xmm8 .byte 69,15,92,196 // subps %xmm12,%xmm8 .byte 68,15,40,253 // movaps %xmm5,%xmm15 .byte 69,15,92,252 // subps %xmm12,%xmm15 .byte 69,15,89,199 // mulps %xmm15,%xmm8 .byte 65,15,92,212 // subps %xmm12,%xmm2 .byte 68,15,94,194 // divps %xmm2,%xmm8 .byte 69,15,88,196 // addps %xmm12,%xmm8 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 102,69,15,56,20,232 // blendvps %xmm0,%xmm8,%xmm13 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 69,15,92,196 // subps %xmm12,%xmm8 .byte 69,15,89,196 // mulps %xmm12,%xmm8 .byte 68,15,94,198 // divps %xmm6,%xmm8 .byte 69,15,88,196 // addps %xmm12,%xmm8 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 102,69,15,56,20,193 // blendvps %xmm0,%xmm9,%xmm8 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 69,15,89,207 // mulps %xmm15,%xmm9 .byte 68,15,94,202 // divps %xmm2,%xmm9 .byte 69,15,88,204 // addps %xmm12,%xmm9 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 102,69,15,56,20,193 // blendvps %xmm0,%xmm9,%xmm8 .byte 69,15,40,206 // movaps %xmm14,%xmm9 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 69,15,89,204 // mulps %xmm12,%xmm9 .byte 68,15,94,206 // divps %xmm6,%xmm9 .byte 69,15,88,204 // addps %xmm12,%xmm9 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 102,69,15,56,20,206 // blendvps %xmm0,%xmm14,%xmm9 .byte 65,15,40,241 // movaps %xmm9,%xmm6 .byte 65,15,92,244 // subps %xmm12,%xmm6 .byte 65,15,89,247 // mulps %xmm15,%xmm6 .byte 15,94,242 // divps %xmm2,%xmm6 .byte 65,15,88,244 // addps %xmm12,%xmm6 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 102,68,15,56,20,206 // blendvps %xmm0,%xmm6,%xmm9 .byte 15,40,5,49,75,0,0 // movaps 0x4b31(%rip),%xmm0 # 6250 <_sk_callback_sse41+0x3a4> .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,92,215 // subps %xmm7,%xmm2 .byte 15,89,226 // mulps %xmm2,%xmm4 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,89,84,36,184 // mulps -0x48(%rsp),%xmm2 .byte 15,92,195 // subps %xmm3,%xmm0 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 15,92,221 // subps %xmm5,%xmm3 .byte 15,87,237 // xorps %xmm5,%xmm5 .byte 68,15,95,237 // maxps %xmm5,%xmm13 .byte 68,15,95,197 // maxps %xmm5,%xmm8 .byte 68,15,95,205 // maxps %xmm5,%xmm9 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 68,15,40,84,36,216 // movaps -0x28(%rsp),%xmm10 .byte 65,15,89,234 // mulps %xmm10,%xmm5 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 65,15,88,229 // addps %xmm13,%xmm4 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,40,108,36,232 // movaps -0x18(%rsp),%xmm5 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 65,15,88,200 // addps %xmm8,%xmm1 .byte 15,40,116,36,200 // movaps -0x38(%rsp),%xmm6 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 65,15,40,226 // movaps %xmm10,%xmm4 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_rgba_8888_sse41 .globl _sk_srcover_rgba_8888_sse41 FUNCTION(_sk_srcover_rgba_8888_sse41) _sk_srcover_rgba_8888_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,219,0,0,0 // jne 1887 <_sk_srcover_rgba_8888_sse41+0xfb> .byte 243,65,15,111,60,129 // movdqu (%r9,%rax,4),%xmm7 .byte 77,133,192 // test %r8,%r8 .byte 102,15,111,37,163,74,0,0 // movdqa 0x4aa3(%rip),%xmm4 # 6260 <_sk_callback_sse41+0x3b4> .byte 102,15,219,231 // pand %xmm7,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 102,15,111,239 // movdqa %xmm7,%xmm5 .byte 102,15,56,0,45,159,74,0,0 // pshufb 0x4a9f(%rip),%xmm5 # 6270 <_sk_callback_sse41+0x3c4> .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 102,15,111,247 // movdqa %xmm7,%xmm6 .byte 102,15,56,0,53,159,74,0,0 // pshufb 0x4a9f(%rip),%xmm6 # 6280 <_sk_callback_sse41+0x3d4> .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 102,15,114,215,24 // psrld $0x18,%xmm7 .byte 15,91,255 // cvtdq2ps %xmm7,%xmm7 .byte 68,15,40,5,156,74,0,0 // movaps 0x4a9c(%rip),%xmm8 # 6290 <_sk_callback_sse41+0x3e4> .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 68,15,40,37,160,74,0,0 // movaps 0x4aa0(%rip),%xmm12 # 62a0 <_sk_callback_sse41+0x3f4> .byte 65,15,89,196 // mulps %xmm12,%xmm0 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 65,15,89,204 // mulps %xmm12,%xmm1 .byte 69,15,40,208 // movaps %xmm8,%xmm10 .byte 68,15,89,213 // mulps %xmm5,%xmm10 .byte 68,15,88,209 // addps %xmm1,%xmm10 .byte 65,15,89,212 // mulps %xmm12,%xmm2 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,89,222 // mulps %xmm6,%xmm11 .byte 68,15,88,218 // addps %xmm2,%xmm11 .byte 65,15,89,220 // mulps %xmm12,%xmm3 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 68,15,88,195 // addps %xmm3,%xmm8 .byte 102,65,15,91,193 // cvtps2dq %xmm9,%xmm0 .byte 102,65,15,91,202 // cvtps2dq %xmm10,%xmm1 .byte 102,15,114,241,8 // pslld $0x8,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,65,15,91,211 // cvtps2dq %xmm11,%xmm2 .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,65,15,91,192 // cvtps2dq %xmm8,%xmm0 .byte 102,15,114,240,24 // pslld $0x18,%xmm0 .byte 102,15,235,194 // por %xmm2,%xmm0 .byte 102,15,235,193 // por %xmm1,%xmm0 .byte 117,88 // jne 18c5 <_sk_srcover_rgba_8888_sse41+0x139> .byte 243,65,15,127,4,129 // movdqu %xmm0,(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 65,15,40,211 // movaps %xmm11,%xmm2 .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,91 // je 18ef <_sk_srcover_rgba_8888_sse41+0x163> .byte 102,15,239,255 // pxor %xmm7,%xmm7 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,22 // je 18b4 <_sk_srcover_rgba_8888_sse41+0x128> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 15,133,10,255,255,255 // jne 17b2 <_sk_srcover_rgba_8888_sse41+0x26> .byte 102,65,15,110,100,129,8 // movd 0x8(%r9,%rax,4),%xmm4 .byte 102,15,112,252,69 // pshufd $0x45,%xmm4,%xmm7 .byte 243,65,15,126,36,129 // movq (%r9,%rax,4),%xmm4 .byte 102,15,58,14,252,15 // pblendw $0xf,%xmm4,%xmm7 .byte 233,237,254,255,255 // jmpq 17b2 <_sk_srcover_rgba_8888_sse41+0x26> .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,40 // je 18fa <_sk_srcover_rgba_8888_sse41+0x16e> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,15 // je 18e7 <_sk_srcover_rgba_8888_sse41+0x15b> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,149 // jne 1873 <_sk_srcover_rgba_8888_sse41+0xe7> .byte 102,65,15,58,22,68,129,8,2 // pextrd $0x2,%xmm0,0x8(%r9,%rax,4) .byte 102,65,15,214,4,129 // movq %xmm0,(%r9,%rax,4) .byte 235,132 // jmp 1873 <_sk_srcover_rgba_8888_sse41+0xe7> .byte 102,65,15,110,60,129 // movd (%r9,%rax,4),%xmm7 .byte 233,184,254,255,255 // jmpq 17b2 <_sk_srcover_rgba_8888_sse41+0x26> .byte 102,65,15,126,4,129 // movd %xmm0,(%r9,%rax,4) .byte 233,110,255,255,255 // jmpq 1873 <_sk_srcover_rgba_8888_sse41+0xe7> HIDDEN _sk_clamp_0_sse41 .globl _sk_clamp_0_sse41 FUNCTION(_sk_clamp_0_sse41) _sk_clamp_0_sse41: .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 65,15,95,192 // maxps %xmm8,%xmm0 .byte 65,15,95,200 // maxps %xmm8,%xmm1 .byte 65,15,95,208 // maxps %xmm8,%xmm2 .byte 65,15,95,216 // maxps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_1_sse41 .globl _sk_clamp_1_sse41 FUNCTION(_sk_clamp_1_sse41) _sk_clamp_1_sse41: .byte 68,15,40,5,139,73,0,0 // movaps 0x498b(%rip),%xmm8 # 62b0 <_sk_callback_sse41+0x404> .byte 65,15,93,192 // minps %xmm8,%xmm0 .byte 65,15,93,200 // minps %xmm8,%xmm1 .byte 65,15,93,208 // minps %xmm8,%xmm2 .byte 65,15,93,216 // minps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_a_sse41 .globl _sk_clamp_a_sse41 FUNCTION(_sk_clamp_a_sse41) _sk_clamp_a_sse41: .byte 15,93,29,128,73,0,0 // minps 0x4980(%rip),%xmm3 # 62c0 <_sk_callback_sse41+0x414> .byte 15,93,195 // minps %xmm3,%xmm0 .byte 15,93,203 // minps %xmm3,%xmm1 .byte 15,93,211 // minps %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_a_dst_sse41 .globl _sk_clamp_a_dst_sse41 FUNCTION(_sk_clamp_a_dst_sse41) _sk_clamp_a_dst_sse41: .byte 15,93,61,124,73,0,0 // minps 0x497c(%rip),%xmm7 # 62d0 <_sk_callback_sse41+0x424> .byte 15,93,231 // minps %xmm7,%xmm4 .byte 15,93,239 // minps %xmm7,%xmm5 .byte 15,93,247 // minps %xmm7,%xmm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_set_rgb_sse41 .globl _sk_set_rgb_sse41 FUNCTION(_sk_set_rgb_sse41) _sk_set_rgb_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,80,8 // movss 0x8(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_swap_rb_sse41 .globl _sk_swap_rb_sse41 FUNCTION(_sk_swap_rb_sse41) _sk_swap_rb_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_invert_sse41 .globl _sk_invert_sse41 FUNCTION(_sk_invert_sse41) _sk_invert_sse41: .byte 68,15,40,5,72,73,0,0 // movaps 0x4948(%rip),%xmm8 # 62e0 <_sk_callback_sse41+0x434> .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,92,200 // subps %xmm0,%xmm9 .byte 69,15,40,208 // movaps %xmm8,%xmm10 .byte 68,15,92,209 // subps %xmm1,%xmm10 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,92,218 // subps %xmm2,%xmm11 .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 65,15,40,211 // movaps %xmm11,%xmm2 .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_move_src_dst_sse41 .globl _sk_move_src_dst_sse41 FUNCTION(_sk_move_src_dst_sse41) _sk_move_src_dst_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,40,242 // movaps %xmm2,%xmm6 .byte 15,40,251 // movaps %xmm3,%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_move_dst_src_sse41 .globl _sk_move_dst_src_sse41 FUNCTION(_sk_move_dst_src_sse41) _sk_move_dst_src_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 15,40,223 // movaps %xmm7,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_sse41 .globl _sk_premul_sse41 FUNCTION(_sk_premul_sse41) _sk_premul_sse41: .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_dst_sse41 .globl _sk_premul_dst_sse41 FUNCTION(_sk_premul_dst_sse41) _sk_premul_dst_sse41: .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,89,247 // mulps %xmm7,%xmm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_unpremul_sse41 .globl _sk_unpremul_sse41 FUNCTION(_sk_unpremul_sse41) _sk_unpremul_sse41: .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,40,13,226,72,0,0 // movaps 0x48e2(%rip),%xmm9 # 62f0 <_sk_callback_sse41+0x444> .byte 68,15,94,203 // divps %xmm3,%xmm9 .byte 68,15,194,195,4 // cmpneqps %xmm3,%xmm8 .byte 69,15,84,193 // andps %xmm9,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_from_srgb_sse41 .globl _sk_from_srgb_sse41 FUNCTION(_sk_from_srgb_sse41) _sk_from_srgb_sse41: .byte 68,15,40,29,205,72,0,0 // movaps 0x48cd(%rip),%xmm11 # 6300 <_sk_callback_sse41+0x454> .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,203 // mulps %xmm11,%xmm9 .byte 68,15,40,208 // movaps %xmm0,%xmm10 .byte 69,15,89,210 // mulps %xmm10,%xmm10 .byte 68,15,40,37,197,72,0,0 // movaps 0x48c5(%rip),%xmm12 # 6310 <_sk_callback_sse41+0x464> .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 69,15,89,196 // mulps %xmm12,%xmm8 .byte 68,15,40,45,197,72,0,0 // movaps 0x48c5(%rip),%xmm13 # 6320 <_sk_callback_sse41+0x474> .byte 69,15,88,197 // addps %xmm13,%xmm8 .byte 69,15,89,194 // mulps %xmm10,%xmm8 .byte 68,15,40,53,197,72,0,0 // movaps 0x48c5(%rip),%xmm14 # 6330 <_sk_callback_sse41+0x484> .byte 69,15,88,198 // addps %xmm14,%xmm8 .byte 68,15,40,61,201,72,0,0 // movaps 0x48c9(%rip),%xmm15 # 6340 <_sk_callback_sse41+0x494> .byte 65,15,194,199,1 // cmpltps %xmm15,%xmm0 .byte 102,69,15,56,20,193 // blendvps %xmm0,%xmm9,%xmm8 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 69,15,89,211 // mulps %xmm11,%xmm10 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 69,15,89,204 // mulps %xmm12,%xmm9 .byte 69,15,88,205 // addps %xmm13,%xmm9 .byte 68,15,89,200 // mulps %xmm0,%xmm9 .byte 69,15,88,206 // addps %xmm14,%xmm9 .byte 65,15,194,207,1 // cmpltps %xmm15,%xmm1 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 102,69,15,56,20,202 // blendvps %xmm0,%xmm10,%xmm9 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 68,15,40,210 // movaps %xmm2,%xmm10 .byte 69,15,89,210 // mulps %xmm10,%xmm10 .byte 68,15,89,226 // mulps %xmm2,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 69,15,89,212 // mulps %xmm12,%xmm10 .byte 69,15,88,214 // addps %xmm14,%xmm10 .byte 65,15,194,215,1 // cmpltps %xmm15,%xmm2 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 102,69,15,56,20,211 // blendvps %xmm0,%xmm11,%xmm10 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_from_srgb_dst_sse41 .globl _sk_from_srgb_dst_sse41 FUNCTION(_sk_from_srgb_dst_sse41) _sk_from_srgb_dst_sse41: .byte 68,15,40,204 // movaps %xmm4,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 68,15,40,29,84,72,0,0 // movaps 0x4854(%rip),%xmm11 # 6350 <_sk_callback_sse41+0x4a4> .byte 69,15,40,209 // movaps %xmm9,%xmm10 .byte 69,15,89,211 // mulps %xmm11,%xmm10 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,37,77,72,0,0 // movaps 0x484d(%rip),%xmm12 # 6360 <_sk_callback_sse41+0x4b4> .byte 65,15,89,228 // mulps %xmm12,%xmm4 .byte 68,15,40,45,81,72,0,0 // movaps 0x4851(%rip),%xmm13 # 6370 <_sk_callback_sse41+0x4c4> .byte 65,15,88,229 // addps %xmm13,%xmm4 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 68,15,40,53,82,72,0,0 // movaps 0x4852(%rip),%xmm14 # 6380 <_sk_callback_sse41+0x4d4> .byte 65,15,88,230 // addps %xmm14,%xmm4 .byte 68,15,40,61,86,72,0,0 // movaps 0x4856(%rip),%xmm15 # 6390 <_sk_callback_sse41+0x4e4> .byte 69,15,194,207,1 // cmpltps %xmm15,%xmm9 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,65,15,56,20,226 // blendvps %xmm0,%xmm10,%xmm4 .byte 68,15,40,213 // movaps %xmm5,%xmm10 .byte 69,15,89,211 // mulps %xmm11,%xmm10 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,205 // movaps %xmm5,%xmm9 .byte 69,15,89,204 // mulps %xmm12,%xmm9 .byte 69,15,88,205 // addps %xmm13,%xmm9 .byte 68,15,89,200 // mulps %xmm0,%xmm9 .byte 69,15,88,206 // addps %xmm14,%xmm9 .byte 65,15,194,239,1 // cmpltps %xmm15,%xmm5 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 102,69,15,56,20,202 // blendvps %xmm0,%xmm10,%xmm9 .byte 68,15,89,222 // mulps %xmm6,%xmm11 .byte 68,15,40,214 // movaps %xmm6,%xmm10 .byte 69,15,89,210 // mulps %xmm10,%xmm10 .byte 68,15,89,230 // mulps %xmm6,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 69,15,89,212 // mulps %xmm12,%xmm10 .byte 69,15,88,214 // addps %xmm14,%xmm10 .byte 65,15,194,247,1 // cmpltps %xmm15,%xmm6 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 102,69,15,56,20,211 // blendvps %xmm0,%xmm11,%xmm10 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,233 // movaps %xmm9,%xmm5 .byte 65,15,40,242 // movaps %xmm10,%xmm6 .byte 255,224 // jmpq *%rax HIDDEN _sk_to_srgb_sse41 .globl _sk_to_srgb_sse41 FUNCTION(_sk_to_srgb_sse41) _sk_to_srgb_sse41: .byte 15,41,124,36,232 // movaps %xmm7,-0x18(%rsp) .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,40,209 // movaps %xmm1,%xmm2 .byte 68,15,82,192 // rsqrtps %xmm0,%xmm8 .byte 68,15,40,29,202,71,0,0 // movaps 0x47ca(%rip),%xmm11 # 63a0 <_sk_callback_sse41+0x4f4> .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,203 // mulps %xmm11,%xmm9 .byte 68,15,40,37,202,71,0,0 // movaps 0x47ca(%rip),%xmm12 # 63b0 <_sk_callback_sse41+0x504> .byte 69,15,40,248 // movaps %xmm8,%xmm15 .byte 69,15,89,252 // mulps %xmm12,%xmm15 .byte 68,15,40,21,202,71,0,0 // movaps 0x47ca(%rip),%xmm10 # 63c0 <_sk_callback_sse41+0x514> .byte 69,15,88,250 // addps %xmm10,%xmm15 .byte 69,15,89,248 // mulps %xmm8,%xmm15 .byte 68,15,40,45,202,71,0,0 // movaps 0x47ca(%rip),%xmm13 # 63d0 <_sk_callback_sse41+0x524> .byte 69,15,88,253 // addps %xmm13,%xmm15 .byte 68,15,40,53,206,71,0,0 // movaps 0x47ce(%rip),%xmm14 # 63e0 <_sk_callback_sse41+0x534> .byte 69,15,88,198 // addps %xmm14,%xmm8 .byte 69,15,83,192 // rcpps %xmm8,%xmm8 .byte 69,15,89,199 // mulps %xmm15,%xmm8 .byte 68,15,40,61,202,71,0,0 // movaps 0x47ca(%rip),%xmm15 # 63f0 <_sk_callback_sse41+0x544> .byte 65,15,194,199,1 // cmpltps %xmm15,%xmm0 .byte 102,69,15,56,20,193 // blendvps %xmm0,%xmm9,%xmm8 .byte 68,15,82,202 // rsqrtps %xmm2,%xmm9 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,89,196 // mulps %xmm12,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 65,15,88,197 // addps %xmm13,%xmm0 .byte 69,15,88,206 // addps %xmm14,%xmm9 .byte 69,15,83,201 // rcpps %xmm9,%xmm9 .byte 68,15,89,200 // mulps %xmm0,%xmm9 .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 65,15,194,215,1 // cmpltps %xmm15,%xmm2 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 102,68,15,56,20,201 // blendvps %xmm0,%xmm1,%xmm9 .byte 15,82,195 // rsqrtps %xmm3,%xmm0 .byte 68,15,89,224 // mulps %xmm0,%xmm12 .byte 69,15,88,226 // addps %xmm10,%xmm12 .byte 68,15,89,224 // mulps %xmm0,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 65,15,88,198 // addps %xmm14,%xmm0 .byte 68,15,83,208 // rcpps %xmm0,%xmm10 .byte 69,15,89,212 // mulps %xmm12,%xmm10 .byte 68,15,89,219 // mulps %xmm3,%xmm11 .byte 65,15,194,223,1 // cmpltps %xmm15,%xmm3 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 102,69,15,56,20,211 // blendvps %xmm0,%xmm11,%xmm10 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,40,238 // movaps %xmm6,%xmm5 .byte 15,40,247 // movaps %xmm7,%xmm6 .byte 15,40,124,36,232 // movaps -0x18(%rsp),%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_rgb_to_hsl_sse41 .globl _sk_rgb_to_hsl_sse41 FUNCTION(_sk_rgb_to_hsl_sse41) _sk_rgb_to_hsl_sse41: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 69,15,95,217 // maxps %xmm9,%xmm11 .byte 68,15,95,218 // maxps %xmm2,%xmm11 .byte 69,15,40,224 // movaps %xmm8,%xmm12 .byte 69,15,93,225 // minps %xmm9,%xmm12 .byte 68,15,93,226 // minps %xmm2,%xmm12 .byte 65,15,40,203 // movaps %xmm11,%xmm1 .byte 65,15,92,204 // subps %xmm12,%xmm1 .byte 68,15,40,53,23,71,0,0 // movaps 0x4717(%rip),%xmm14 # 6400 <_sk_callback_sse41+0x554> .byte 68,15,94,241 // divps %xmm1,%xmm14 .byte 69,15,40,211 // movaps %xmm11,%xmm10 .byte 69,15,194,208,0 // cmpeqps %xmm8,%xmm10 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,92,194 // subps %xmm2,%xmm0 .byte 65,15,89,198 // mulps %xmm14,%xmm0 .byte 69,15,40,249 // movaps %xmm9,%xmm15 .byte 68,15,194,250,1 // cmpltps %xmm2,%xmm15 .byte 68,15,84,61,254,70,0,0 // andps 0x46fe(%rip),%xmm15 # 6410 <_sk_callback_sse41+0x564> .byte 68,15,88,248 // addps %xmm0,%xmm15 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,194,193,0 // cmpeqps %xmm9,%xmm0 .byte 65,15,92,208 // subps %xmm8,%xmm2 .byte 65,15,89,214 // mulps %xmm14,%xmm2 .byte 68,15,40,45,241,70,0,0 // movaps 0x46f1(%rip),%xmm13 # 6420 <_sk_callback_sse41+0x574> .byte 65,15,88,213 // addps %xmm13,%xmm2 .byte 69,15,92,193 // subps %xmm9,%xmm8 .byte 69,15,89,198 // mulps %xmm14,%xmm8 .byte 68,15,88,5,237,70,0,0 // addps 0x46ed(%rip),%xmm8 # 6430 <_sk_callback_sse41+0x584> .byte 102,68,15,56,20,194 // blendvps %xmm0,%xmm2,%xmm8 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 102,69,15,56,20,199 // blendvps %xmm0,%xmm15,%xmm8 .byte 68,15,89,5,229,70,0,0 // mulps 0x46e5(%rip),%xmm8 # 6440 <_sk_callback_sse41+0x594> .byte 69,15,40,203 // movaps %xmm11,%xmm9 .byte 69,15,194,204,4 // cmpneqps %xmm12,%xmm9 .byte 69,15,84,193 // andps %xmm9,%xmm8 .byte 69,15,92,235 // subps %xmm11,%xmm13 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 15,40,5,217,70,0,0 // movaps 0x46d9(%rip),%xmm0 # 6450 <_sk_callback_sse41+0x5a4> .byte 65,15,40,211 // movaps %xmm11,%xmm2 .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 15,194,194,1 // cmpltps %xmm2,%xmm0 .byte 69,15,92,236 // subps %xmm12,%xmm13 .byte 102,69,15,56,20,221 // blendvps %xmm0,%xmm13,%xmm11 .byte 65,15,94,203 // divps %xmm11,%xmm1 .byte 65,15,84,201 // andps %xmm9,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_hsl_to_rgb_sse41 .globl _sk_hsl_to_rgb_sse41 FUNCTION(_sk_hsl_to_rgb_sse41) _sk_hsl_to_rgb_sse41: .byte 15,41,124,36,232 // movaps %xmm7,-0x18(%rsp) .byte 15,41,116,36,216 // movaps %xmm6,-0x28(%rsp) .byte 15,41,108,36,200 // movaps %xmm5,-0x38(%rsp) .byte 15,41,100,36,184 // movaps %xmm4,-0x48(%rsp) .byte 15,41,92,36,168 // movaps %xmm3,-0x58(%rsp) .byte 68,15,40,208 // movaps %xmm0,%xmm10 .byte 68,15,40,13,159,70,0,0 // movaps 0x469f(%rip),%xmm9 # 6460 <_sk_callback_sse41+0x5b4> .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,194,194,2 // cmpleps %xmm2,%xmm0 .byte 15,40,217 // movaps %xmm1,%xmm3 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,89,234 // mulps %xmm2,%xmm5 .byte 15,92,221 // subps %xmm5,%xmm3 .byte 102,15,56,20,235 // blendvps %xmm0,%xmm3,%xmm5 .byte 15,88,234 // addps %xmm2,%xmm5 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 15,41,84,36,152 // movaps %xmm2,-0x68(%rsp) .byte 69,15,88,192 // addps %xmm8,%xmm8 .byte 68,15,92,197 // subps %xmm5,%xmm8 .byte 68,15,40,53,122,70,0,0 // movaps 0x467a(%rip),%xmm14 # 6470 <_sk_callback_sse41+0x5c4> .byte 69,15,88,242 // addps %xmm10,%xmm14 .byte 102,65,15,58,8,198,1 // roundps $0x1,%xmm14,%xmm0 .byte 68,15,92,240 // subps %xmm0,%xmm14 .byte 68,15,40,29,115,70,0,0 // movaps 0x4673(%rip),%xmm11 # 6480 <_sk_callback_sse41+0x5d4> .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,194,198,2 // cmpleps %xmm14,%xmm0 .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 65,15,92,240 // subps %xmm8,%xmm6 .byte 15,40,61,108,70,0,0 // movaps 0x466c(%rip),%xmm7 # 6490 <_sk_callback_sse41+0x5e4> .byte 69,15,40,238 // movaps %xmm14,%xmm13 .byte 68,15,89,239 // mulps %xmm7,%xmm13 .byte 15,40,29,109,70,0,0 // movaps 0x466d(%rip),%xmm3 # 64a0 <_sk_callback_sse41+0x5f4> .byte 68,15,40,227 // movaps %xmm3,%xmm12 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 68,15,89,230 // mulps %xmm6,%xmm12 .byte 69,15,88,224 // addps %xmm8,%xmm12 .byte 102,69,15,56,20,224 // blendvps %xmm0,%xmm8,%xmm12 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,194,198,2 // cmpleps %xmm14,%xmm0 .byte 68,15,40,253 // movaps %xmm5,%xmm15 .byte 102,69,15,56,20,252 // blendvps %xmm0,%xmm12,%xmm15 .byte 68,15,40,37,76,70,0,0 // movaps 0x464c(%rip),%xmm12 # 64b0 <_sk_callback_sse41+0x604> .byte 65,15,40,196 // movaps %xmm12,%xmm0 .byte 65,15,194,198,2 // cmpleps %xmm14,%xmm0 .byte 68,15,89,238 // mulps %xmm6,%xmm13 .byte 69,15,88,232 // addps %xmm8,%xmm13 .byte 102,69,15,56,20,239 // blendvps %xmm0,%xmm15,%xmm13 .byte 69,15,87,246 // xorps %xmm14,%xmm14 .byte 68,15,194,241,0 // cmpeqps %xmm1,%xmm14 .byte 65,15,40,198 // movaps %xmm14,%xmm0 .byte 102,68,15,56,20,234 // blendvps %xmm0,%xmm2,%xmm13 .byte 102,65,15,58,8,194,1 // roundps $0x1,%xmm10,%xmm0 .byte 69,15,40,250 // movaps %xmm10,%xmm15 .byte 68,15,92,248 // subps %xmm0,%xmm15 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,194,199,2 // cmpleps %xmm15,%xmm0 .byte 65,15,40,207 // movaps %xmm15,%xmm1 .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,92,209 // subps %xmm1,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 65,15,88,208 // addps %xmm8,%xmm2 .byte 102,65,15,56,20,208 // blendvps %xmm0,%xmm8,%xmm2 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,194,199,2 // cmpleps %xmm15,%xmm0 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 102,15,56,20,226 // blendvps %xmm0,%xmm2,%xmm4 .byte 65,15,40,196 // movaps %xmm12,%xmm0 .byte 65,15,194,199,2 // cmpleps %xmm15,%xmm0 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 65,15,88,200 // addps %xmm8,%xmm1 .byte 102,15,56,20,204 // blendvps %xmm0,%xmm4,%xmm1 .byte 65,15,40,198 // movaps %xmm14,%xmm0 .byte 15,40,84,36,152 // movaps -0x68(%rsp),%xmm2 .byte 102,15,56,20,202 // blendvps %xmm0,%xmm2,%xmm1 .byte 68,15,88,21,196,69,0,0 // addps 0x45c4(%rip),%xmm10 # 64c0 <_sk_callback_sse41+0x614> .byte 102,65,15,58,8,194,1 // roundps $0x1,%xmm10,%xmm0 .byte 68,15,92,208 // subps %xmm0,%xmm10 .byte 69,15,194,218,2 // cmpleps %xmm10,%xmm11 .byte 65,15,89,250 // mulps %xmm10,%xmm7 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 15,89,222 // mulps %xmm6,%xmm3 .byte 65,15,88,216 // addps %xmm8,%xmm3 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 102,65,15,56,20,216 // blendvps %xmm0,%xmm8,%xmm3 .byte 69,15,194,202,2 // cmpleps %xmm10,%xmm9 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,15,56,20,235 // blendvps %xmm0,%xmm3,%xmm5 .byte 69,15,194,226,2 // cmpleps %xmm10,%xmm12 .byte 15,89,254 // mulps %xmm6,%xmm7 .byte 68,15,88,199 // addps %xmm7,%xmm8 .byte 65,15,40,196 // movaps %xmm12,%xmm0 .byte 102,68,15,56,20,197 // blendvps %xmm0,%xmm5,%xmm8 .byte 65,15,40,198 // movaps %xmm14,%xmm0 .byte 102,68,15,56,20,194 // blendvps %xmm0,%xmm2,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,197 // movaps %xmm13,%xmm0 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 15,40,92,36,168 // movaps -0x58(%rsp),%xmm3 .byte 15,40,100,36,184 // movaps -0x48(%rsp),%xmm4 .byte 15,40,108,36,200 // movaps -0x38(%rsp),%xmm5 .byte 15,40,116,36,216 // movaps -0x28(%rsp),%xmm6 .byte 15,40,124,36,232 // movaps -0x18(%rsp),%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_1_float_sse41 .globl _sk_scale_1_float_sse41 FUNCTION(_sk_scale_1_float_sse41) _sk_scale_1_float_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_u8_sse41 .globl _sk_scale_u8_sse41 FUNCTION(_sk_scale_u8_sse41) _sk_scale_u8_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,52 // jne 1fe3 <_sk_scale_u8_sse41+0x4c> .byte 102,71,15,56,49,4,25 // pmovzxbd (%r9,%r11,1),%xmm8 .byte 102,68,15,219,5,17,69,0,0 // pand 0x4511(%rip),%xmm8 # 64d0 <_sk_callback_sse41+0x624> .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,5,21,69,0,0 // mulps 0x4515(%rip),%xmm8 # 64e0 <_sk_callback_sse41+0x634> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,59 // je 202b <_sk_scale_u8_sse41+0x94> .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,23 // je 2012 <_sk_scale_u8_sse41+0x7b> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,181 // jne 1fb6 <_sk_scale_u8_sse41+0x1f> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,69 // pshufd $0x45,%xmm8,%xmm8 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,68,15,110,200 // movd %eax,%xmm9 .byte 102,69,15,56,49,201 // pmovzxbd %xmm9,%xmm9 .byte 102,69,15,58,14,193,15 // pblendw $0xf,%xmm9,%xmm8 .byte 235,139 // jmp 1fb6 <_sk_scale_u8_sse41+0x1f> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 233,124,255,255,255 // jmpq 1fb6 <_sk_scale_u8_sse41+0x1f> HIDDEN _sk_lerp_1_float_sse41 .globl _sk_lerp_1_float_sse41 FUNCTION(_sk_lerp_1_float_sse41) _sk_lerp_1_float_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,92,205 // subps %xmm5,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_lerp_u8_sse41 .globl _sk_lerp_u8_sse41 FUNCTION(_sk_lerp_u8_sse41) _sk_lerp_u8_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,72 // jne 20d2 <_sk_lerp_u8_sse41+0x60> .byte 102,71,15,56,49,4,25 // pmovzxbd (%r9,%r11,1),%xmm8 .byte 102,68,15,219,5,86,68,0,0 // pand 0x4456(%rip),%xmm8 # 64f0 <_sk_callback_sse41+0x644> .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,5,90,68,0,0 // mulps 0x445a(%rip),%xmm8 # 6500 <_sk_callback_sse41+0x654> .byte 15,92,196 // subps %xmm4,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,92,205 // subps %xmm5,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,62 // je 211d <_sk_lerp_u8_sse41+0xab> .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,23 // je 2101 <_sk_lerp_u8_sse41+0x8f> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,161 // jne 2091 <_sk_lerp_u8_sse41+0x1f> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,69 // pshufd $0x45,%xmm8,%xmm8 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,68,15,110,200 // movd %eax,%xmm9 .byte 102,69,15,56,49,201 // pmovzxbd %xmm9,%xmm9 .byte 102,69,15,58,14,193,15 // pblendw $0xf,%xmm9,%xmm8 .byte 233,116,255,255,255 // jmpq 2091 <_sk_lerp_u8_sse41+0x1f> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 233,101,255,255,255 // jmpq 2091 <_sk_lerp_u8_sse41+0x1f> HIDDEN _sk_lerp_565_sse41 .globl _sk_lerp_565_sse41 FUNCTION(_sk_lerp_565_sse41) _sk_lerp_565_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 15,133,152,0,0,0 // jne 21e3 <_sk_lerp_565_sse41+0xb7> .byte 102,71,15,56,51,20,89 // pmovzxwd (%r9,%r11,2),%xmm10 .byte 102,68,15,111,5,181,67,0,0 // movdqa 0x43b5(%rip),%xmm8 # 6510 <_sk_callback_sse41+0x664> .byte 102,69,15,219,194 // pand %xmm10,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,5,180,67,0,0 // mulps 0x43b4(%rip),%xmm8 # 6520 <_sk_callback_sse41+0x674> .byte 102,68,15,111,13,187,67,0,0 // movdqa 0x43bb(%rip),%xmm9 # 6530 <_sk_callback_sse41+0x684> .byte 102,69,15,219,202 // pand %xmm10,%xmm9 .byte 69,15,91,201 // cvtdq2ps %xmm9,%xmm9 .byte 68,15,89,13,186,67,0,0 // mulps 0x43ba(%rip),%xmm9 # 6540 <_sk_callback_sse41+0x694> .byte 102,68,15,219,21,193,67,0,0 // pand 0x43c1(%rip),%xmm10 # 6550 <_sk_callback_sse41+0x6a4> .byte 69,15,91,210 // cvtdq2ps %xmm10,%xmm10 .byte 68,15,89,21,197,67,0,0 // mulps 0x43c5(%rip),%xmm10 # 6560 <_sk_callback_sse41+0x6b4> .byte 15,92,196 // subps %xmm4,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,92,205 // subps %xmm5,%xmm1 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 65,15,89,210 // mulps %xmm10,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 68,15,88,199 // addps %xmm7,%xmm8 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 68,15,88,207 // addps %xmm7,%xmm9 .byte 65,15,89,218 // mulps %xmm10,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 68,15,95,203 // maxps %xmm3,%xmm9 .byte 69,15,95,193 // maxps %xmm9,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,62 // je 222e <_sk_lerp_565_sse41+0x102> .byte 102,69,15,239,210 // pxor %xmm10,%xmm10 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,27 // je 2216 <_sk_lerp_565_sse41+0xea> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 15,133,77,255,255,255 // jne 2152 <_sk_lerp_565_sse41+0x26> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,208,69 // pshufd $0x45,%xmm8,%xmm10 .byte 102,71,15,110,4,89 // movd (%r9,%r11,2),%xmm8 .byte 102,69,15,56,51,192 // pmovzxwd %xmm8,%xmm8 .byte 102,69,15,58,14,208,15 // pblendw $0xf,%xmm8,%xmm10 .byte 233,36,255,255,255 // jmpq 2152 <_sk_lerp_565_sse41+0x26> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,68,15,110,208 // movd %eax,%xmm10 .byte 233,21,255,255,255 // jmpq 2152 <_sk_lerp_565_sse41+0x26> HIDDEN _sk_load_tables_sse41 .globl _sk_load_tables_sse41 FUNCTION(_sk_load_tables_sse41) _sk_load_tables_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 77,133,192 // test %r8,%r8 .byte 15,133,24,1,0,0 // jne 2363 <_sk_load_tables_sse41+0x126> .byte 243,69,15,111,4,145 // movdqu (%r9,%rdx,4),%xmm8 .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 102,15,111,5,18,67,0,0 // movdqa 0x4312(%rip),%xmm0 # 6570 <_sk_callback_sse41+0x6c4> .byte 102,65,15,219,192 // pand %xmm8,%xmm0 .byte 102,73,15,58,22,193,1 // pextrq $0x1,%xmm0,%r9 .byte 102,73,15,126,194 // movq %xmm0,%r10 .byte 69,15,182,218 // movzbl %r10b,%r11d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 69,15,182,241 // movzbl %r9b,%r14d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 72,139,88,8 // mov 0x8(%rax),%rbx .byte 76,139,120,16 // mov 0x10(%rax),%r15 .byte 243,66,15,16,4,155 // movss (%rbx,%r11,4),%xmm0 .byte 102,66,15,58,33,4,19,16 // insertps $0x10,(%rbx,%r10,1),%xmm0 .byte 102,66,15,58,33,4,179,32 // insertps $0x20,(%rbx,%r14,4),%xmm0 .byte 102,66,15,58,33,4,11,48 // insertps $0x30,(%rbx,%r9,1),%xmm0 .byte 102,65,15,111,200 // movdqa %xmm8,%xmm1 .byte 102,15,56,0,13,205,66,0,0 // pshufb 0x42cd(%rip),%xmm1 # 6580 <_sk_callback_sse41+0x6d4> .byte 102,73,15,58,22,201,1 // pextrq $0x1,%xmm1,%r9 .byte 102,72,15,126,203 // movq %xmm1,%rbx .byte 68,15,182,211 // movzbl %bl,%r10d .byte 72,193,235,30 // shr $0x1e,%rbx .byte 69,15,182,217 // movzbl %r9b,%r11d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 243,67,15,16,12,151 // movss (%r15,%r10,4),%xmm1 .byte 102,65,15,58,33,12,31,16 // insertps $0x10,(%r15,%rbx,1),%xmm1 .byte 243,67,15,16,20,159 // movss (%r15,%r11,4),%xmm2 .byte 102,15,58,33,202,32 // insertps $0x20,%xmm2,%xmm1 .byte 243,67,15,16,20,15 // movss (%r15,%r9,1),%xmm2 .byte 102,15,58,33,202,48 // insertps $0x30,%xmm2,%xmm1 .byte 76,139,72,24 // mov 0x18(%rax),%r9 .byte 102,65,15,111,208 // movdqa %xmm8,%xmm2 .byte 102,15,56,0,21,137,66,0,0 // pshufb 0x4289(%rip),%xmm2 # 6590 <_sk_callback_sse41+0x6e4> .byte 102,72,15,58,22,211,1 // pextrq $0x1,%xmm2,%rbx .byte 102,72,15,126,208 // movq %xmm2,%rax .byte 68,15,182,208 // movzbl %al,%r10d .byte 72,193,232,30 // shr $0x1e,%rax .byte 68,15,182,219 // movzbl %bl,%r11d .byte 72,193,235,30 // shr $0x1e,%rbx .byte 243,67,15,16,20,145 // movss (%r9,%r10,4),%xmm2 .byte 102,65,15,58,33,20,1,16 // insertps $0x10,(%r9,%rax,1),%xmm2 .byte 243,67,15,16,28,153 // movss (%r9,%r11,4),%xmm3 .byte 102,15,58,33,211,32 // insertps $0x20,%xmm3,%xmm2 .byte 243,65,15,16,28,25 // movss (%r9,%rbx,1),%xmm3 .byte 102,15,58,33,211,48 // insertps $0x30,%xmm3,%xmm2 .byte 102,65,15,114,208,24 // psrld $0x18,%xmm8 .byte 65,15,91,216 // cvtdq2ps %xmm8,%xmm3 .byte 15,89,29,70,66,0,0 // mulps 0x4246(%rip),%xmm3 # 65a0 <_sk_callback_sse41+0x6f4> .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,52 // je 23a4 <_sk_load_tables_sse41+0x167> .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,23 // je 2392 <_sk_load_tables_sse41+0x155> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 15,133,204,254,255,255 // jne 2251 <_sk_load_tables_sse41+0x14> .byte 102,65,15,110,68,145,8 // movd 0x8(%r9,%rdx,4),%xmm0 .byte 102,68,15,112,192,69 // pshufd $0x45,%xmm0,%xmm8 .byte 243,65,15,126,4,145 // movq (%r9,%rdx,4),%xmm0 .byte 102,68,15,58,14,192,15 // pblendw $0xf,%xmm0,%xmm8 .byte 233,173,254,255,255 // jmpq 2251 <_sk_load_tables_sse41+0x14> .byte 102,69,15,110,4,145 // movd (%r9,%rdx,4),%xmm8 .byte 233,162,254,255,255 // jmpq 2251 <_sk_load_tables_sse41+0x14> HIDDEN _sk_load_tables_u16_be_sse41 .globl _sk_load_tables_u16_be_sse41 FUNCTION(_sk_load_tables_u16_be_sse41) _sk_load_tables_u16_be_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 76,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10 .byte 77,133,192 // test %r8,%r8 .byte 15,133,99,1,0,0 // jne 2528 <_sk_load_tables_u16_be_sse41+0x179> .byte 102,67,15,16,4,81 // movupd (%r9,%r10,2),%xmm0 .byte 243,67,15,111,76,81,16 // movdqu 0x10(%r9,%r10,2),%xmm1 .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 102,68,15,40,200 // movapd %xmm0,%xmm9 .byte 102,68,15,97,201 // punpcklwd %xmm1,%xmm9 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,65,15,111,201 // movdqa %xmm9,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,68,15,105,200 // punpckhwd %xmm0,%xmm9 .byte 102,68,15,111,5,180,65,0,0 // movdqa 0x41b4(%rip),%xmm8 # 65b0 <_sk_callback_sse41+0x704> .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,65,15,219,192 // pand %xmm8,%xmm0 .byte 102,15,56,51,192 // pmovzxwd %xmm0,%xmm0 .byte 102,73,15,58,22,193,1 // pextrq $0x1,%xmm0,%r9 .byte 102,73,15,126,194 // movq %xmm0,%r10 .byte 69,15,182,218 // movzbl %r10b,%r11d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 69,15,182,241 // movzbl %r9b,%r14d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 72,139,88,8 // mov 0x8(%rax),%rbx .byte 76,139,120,16 // mov 0x10(%rax),%r15 .byte 243,66,15,16,4,155 // movss (%rbx,%r11,4),%xmm0 .byte 102,66,15,58,33,4,19,16 // insertps $0x10,(%rbx,%r10,1),%xmm0 .byte 243,66,15,16,20,179 // movss (%rbx,%r14,4),%xmm2 .byte 102,15,58,33,194,32 // insertps $0x20,%xmm2,%xmm0 .byte 243,66,15,16,20,11 // movss (%rbx,%r9,1),%xmm2 .byte 102,15,58,33,194,48 // insertps $0x30,%xmm2,%xmm0 .byte 102,15,56,0,13,99,65,0,0 // pshufb 0x4163(%rip),%xmm1 # 65c0 <_sk_callback_sse41+0x714> .byte 102,15,56,51,201 // pmovzxwd %xmm1,%xmm1 .byte 102,73,15,58,22,201,1 // pextrq $0x1,%xmm1,%r9 .byte 102,72,15,126,203 // movq %xmm1,%rbx .byte 68,15,182,211 // movzbl %bl,%r10d .byte 72,193,235,30 // shr $0x1e,%rbx .byte 69,15,182,217 // movzbl %r9b,%r11d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 243,67,15,16,12,151 // movss (%r15,%r10,4),%xmm1 .byte 102,65,15,58,33,12,31,16 // insertps $0x10,(%r15,%rbx,1),%xmm1 .byte 243,67,15,16,20,159 // movss (%r15,%r11,4),%xmm2 .byte 102,15,58,33,202,32 // insertps $0x20,%xmm2,%xmm1 .byte 243,67,15,16,20,15 // movss (%r15,%r9,1),%xmm2 .byte 102,15,58,33,202,48 // insertps $0x30,%xmm2,%xmm1 .byte 76,139,72,24 // mov 0x18(%rax),%r9 .byte 102,69,15,219,193 // pand %xmm9,%xmm8 .byte 102,65,15,56,51,208 // pmovzxwd %xmm8,%xmm2 .byte 102,72,15,58,22,211,1 // pextrq $0x1,%xmm2,%rbx .byte 102,72,15,126,208 // movq %xmm2,%rax .byte 68,15,182,208 // movzbl %al,%r10d .byte 72,193,232,30 // shr $0x1e,%rax .byte 68,15,182,219 // movzbl %bl,%r11d .byte 72,193,235,30 // shr $0x1e,%rbx .byte 243,67,15,16,20,145 // movss (%r9,%r10,4),%xmm2 .byte 102,65,15,58,33,20,1,16 // insertps $0x10,(%r9,%rax,1),%xmm2 .byte 243,67,15,16,28,153 // movss (%r9,%r11,4),%xmm3 .byte 102,15,58,33,211,32 // insertps $0x20,%xmm3,%xmm2 .byte 243,65,15,16,28,25 // movss (%r9,%rbx,1),%xmm3 .byte 102,15,58,33,211,48 // insertps $0x30,%xmm3,%xmm2 .byte 102,65,15,112,217,78 // pshufd $0x4e,%xmm9,%xmm3 .byte 102,68,15,111,195 // movdqa %xmm3,%xmm8 .byte 102,65,15,113,240,8 // psllw $0x8,%xmm8 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,65,15,235,216 // por %xmm8,%xmm3 .byte 102,15,56,51,219 // pmovzxwd %xmm3,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,29,177,64,0,0 // mulps 0x40b1(%rip),%xmm3 # 65d0 <_sk_callback_sse41+0x724> .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax .byte 242,67,15,16,4,81 // movsd (%r9,%r10,2),%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,13 // jne 2541 <_sk_load_tables_u16_be_sse41+0x192> .byte 243,15,126,192 // movq %xmm0,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 233,145,254,255,255 // jmpq 23d2 <_sk_load_tables_u16_be_sse41+0x23> .byte 102,67,15,22,68,81,8 // movhpd 0x8(%r9,%r10,2),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 15,130,124,254,255,255 // jb 23d2 <_sk_load_tables_u16_be_sse41+0x23> .byte 243,67,15,126,76,81,16 // movq 0x10(%r9,%r10,2),%xmm1 .byte 233,112,254,255,255 // jmpq 23d2 <_sk_load_tables_u16_be_sse41+0x23> HIDDEN _sk_load_tables_rgb_u16_be_sse41 .globl _sk_load_tables_rgb_u16_be_sse41 FUNCTION(_sk_load_tables_rgb_u16_be_sse41) _sk_load_tables_rgb_u16_be_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 76,141,20,82 // lea (%rdx,%rdx,2),%r10 .byte 77,133,192 // test %r8,%r8 .byte 15,133,83,1,0,0 // jne 26c7 <_sk_load_tables_rgb_u16_be_sse41+0x165> .byte 243,67,15,111,20,81 // movdqu (%r9,%r10,2),%xmm2 .byte 243,67,15,111,76,81,8 // movdqu 0x8(%r9,%r10,2),%xmm1 .byte 102,15,115,217,4 // psrldq $0x4,%xmm1 .byte 102,68,15,111,202 // movdqa %xmm2,%xmm9 .byte 102,65,15,115,217,6 // psrldq $0x6,%xmm9 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,115,216,6 // psrldq $0x6,%xmm0 .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 102,15,97,209 // punpcklwd %xmm1,%xmm2 .byte 102,68,15,97,200 // punpcklwd %xmm0,%xmm9 .byte 102,15,111,202 // movdqa %xmm2,%xmm1 .byte 102,65,15,97,201 // punpcklwd %xmm9,%xmm1 .byte 102,68,15,111,5,38,64,0,0 // movdqa 0x4026(%rip),%xmm8 # 65e0 <_sk_callback_sse41+0x734> .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,65,15,219,192 // pand %xmm8,%xmm0 .byte 102,15,56,51,192 // pmovzxwd %xmm0,%xmm0 .byte 102,73,15,58,22,193,1 // pextrq $0x1,%xmm0,%r9 .byte 102,73,15,126,194 // movq %xmm0,%r10 .byte 69,15,182,218 // movzbl %r10b,%r11d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 69,15,182,241 // movzbl %r9b,%r14d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 72,139,88,8 // mov 0x8(%rax),%rbx .byte 76,139,120,16 // mov 0x10(%rax),%r15 .byte 243,66,15,16,4,155 // movss (%rbx,%r11,4),%xmm0 .byte 102,66,15,58,33,4,19,16 // insertps $0x10,(%rbx,%r10,1),%xmm0 .byte 243,66,15,16,28,179 // movss (%rbx,%r14,4),%xmm3 .byte 102,15,58,33,195,32 // insertps $0x20,%xmm3,%xmm0 .byte 243,66,15,16,28,11 // movss (%rbx,%r9,1),%xmm3 .byte 102,15,58,33,195,48 // insertps $0x30,%xmm3,%xmm0 .byte 102,15,56,0,13,213,63,0,0 // pshufb 0x3fd5(%rip),%xmm1 # 65f0 <_sk_callback_sse41+0x744> .byte 102,15,56,51,201 // pmovzxwd %xmm1,%xmm1 .byte 102,73,15,58,22,201,1 // pextrq $0x1,%xmm1,%r9 .byte 102,72,15,126,203 // movq %xmm1,%rbx .byte 68,15,182,211 // movzbl %bl,%r10d .byte 72,193,235,30 // shr $0x1e,%rbx .byte 69,15,182,217 // movzbl %r9b,%r11d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 243,67,15,16,12,151 // movss (%r15,%r10,4),%xmm1 .byte 102,65,15,58,33,12,31,16 // insertps $0x10,(%r15,%rbx,1),%xmm1 .byte 243,67,15,16,28,159 // movss (%r15,%r11,4),%xmm3 .byte 102,15,58,33,203,32 // insertps $0x20,%xmm3,%xmm1 .byte 243,67,15,16,28,15 // movss (%r15,%r9,1),%xmm3 .byte 102,15,58,33,203,48 // insertps $0x30,%xmm3,%xmm1 .byte 76,139,72,24 // mov 0x18(%rax),%r9 .byte 102,65,15,105,209 // punpckhwd %xmm9,%xmm2 .byte 102,65,15,219,208 // pand %xmm8,%xmm2 .byte 102,15,56,51,210 // pmovzxwd %xmm2,%xmm2 .byte 102,72,15,58,22,211,1 // pextrq $0x1,%xmm2,%rbx .byte 102,72,15,126,208 // movq %xmm2,%rax .byte 68,15,182,208 // movzbl %al,%r10d .byte 72,193,232,30 // shr $0x1e,%rax .byte 68,15,182,219 // movzbl %bl,%r11d .byte 72,193,235,30 // shr $0x1e,%rbx .byte 243,67,15,16,20,145 // movss (%r9,%r10,4),%xmm2 .byte 102,65,15,58,33,20,1,16 // insertps $0x10,(%r9,%rax,1),%xmm2 .byte 243,67,15,16,28,153 // movss (%r9,%r11,4),%xmm3 .byte 102,15,58,33,211,32 // insertps $0x20,%xmm3,%xmm2 .byte 243,65,15,16,28,25 // movss (%r9,%rbx,1),%xmm3 .byte 102,15,58,33,211,48 // insertps $0x30,%xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,64,63,0,0 // movaps 0x3f40(%rip),%xmm3 # 6600 <_sk_callback_sse41+0x754> .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax .byte 102,67,15,110,20,81 // movd (%r9,%r10,2),%xmm2 .byte 102,67,15,196,84,81,4,2 // pinsrw $0x2,0x4(%r9,%r10,2),%xmm2 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,14 // jne 26ed <_sk_load_tables_rgb_u16_be_sse41+0x18b> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 233,173,254,255,255 // jmpq 259a <_sk_load_tables_rgb_u16_be_sse41+0x38> .byte 102,71,15,110,76,81,6 // movd 0x6(%r9,%r10,2),%xmm9 .byte 102,71,15,196,76,81,10,2 // pinsrw $0x2,0xa(%r9,%r10,2),%xmm9 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,24 // jb 271e <_sk_load_tables_rgb_u16_be_sse41+0x1bc> .byte 102,67,15,110,76,81,12 // movd 0xc(%r9,%r10,2),%xmm1 .byte 102,67,15,196,76,81,16,2 // pinsrw $0x2,0x10(%r9,%r10,2),%xmm1 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 233,124,254,255,255 // jmpq 259a <_sk_load_tables_rgb_u16_be_sse41+0x38> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 233,115,254,255,255 // jmpq 259a <_sk_load_tables_rgb_u16_be_sse41+0x38> HIDDEN _sk_byte_tables_sse41 .globl _sk_byte_tables_sse41 FUNCTION(_sk_byte_tables_sse41) _sk_byte_tables_sse41: .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,40,5,216,62,0,0 // movaps 0x3ed8(%rip),%xmm8 # 6610 <_sk_callback_sse41+0x764> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 102,73,15,58,22,193,1 // pextrq $0x1,%xmm0,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 73,193,233,32 // shr $0x20,%r9 .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 69,137,222 // mov %r11d,%r14d .byte 73,193,235,32 // shr $0x20,%r11 .byte 76,139,32 // mov (%rax),%r12 .byte 76,139,120,8 // mov 0x8(%rax),%r15 .byte 102,67,15,58,32,4,52,0 // pinsrb $0x0,(%r12,%r14,1),%xmm0 .byte 102,67,15,58,32,4,28,1 // pinsrb $0x1,(%r12,%r11,1),%xmm0 .byte 67,15,182,28,20 // movzbl (%r12,%r10,1),%ebx .byte 102,15,58,32,195,2 // pinsrb $0x2,%ebx,%xmm0 .byte 67,15,182,28,12 // movzbl (%r12,%r9,1),%ebx .byte 102,15,58,32,195,3 // pinsrb $0x3,%ebx,%xmm0 .byte 102,15,56,49,192 // pmovzxbd %xmm0,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,13,137,62,0,0 // movaps 0x3e89(%rip),%xmm9 # 6620 <_sk_callback_sse41+0x774> .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,15,91,201 // cvtps2dq %xmm1,%xmm1 .byte 102,72,15,58,22,203,1 // pextrq $0x1,%xmm1,%rbx .byte 65,137,217 // mov %ebx,%r9d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,73,15,126,202 // movq %xmm1,%r10 .byte 69,137,211 // mov %r10d,%r11d .byte 73,193,234,32 // shr $0x20,%r10 .byte 102,67,15,58,32,12,31,0 // pinsrb $0x0,(%r15,%r11,1),%xmm1 .byte 102,67,15,58,32,12,23,1 // pinsrb $0x1,(%r15,%r10,1),%xmm1 .byte 71,15,182,12,15 // movzbl (%r15,%r9,1),%r9d .byte 102,65,15,58,32,201,2 // pinsrb $0x2,%r9d,%xmm1 .byte 65,15,182,28,31 // movzbl (%r15,%rbx,1),%ebx .byte 102,15,58,32,203,3 // pinsrb $0x3,%ebx,%xmm1 .byte 102,15,56,49,201 // pmovzxbd %xmm1,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 76,139,88,16 // mov 0x10(%rax),%r11 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,15,91,210 // cvtps2dq %xmm2,%xmm2 .byte 102,73,15,58,22,209,1 // pextrq $0x1,%xmm2,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 73,193,233,32 // shr $0x20,%r9 .byte 102,72,15,126,211 // movq %xmm2,%rbx .byte 65,137,222 // mov %ebx,%r14d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,67,15,58,32,20,51,0 // pinsrb $0x0,(%r11,%r14,1),%xmm2 .byte 102,65,15,58,32,20,27,1 // pinsrb $0x1,(%r11,%rbx,1),%xmm2 .byte 67,15,182,28,19 // movzbl (%r11,%r10,1),%ebx .byte 102,15,58,32,211,2 // pinsrb $0x2,%ebx,%xmm2 .byte 67,15,182,28,11 // movzbl (%r11,%r9,1),%ebx .byte 102,15,58,32,211,3 // pinsrb $0x3,%ebx,%xmm2 .byte 102,15,56,49,210 // pmovzxbd %xmm2,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 76,139,80,24 // mov 0x18(%rax),%r10 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 102,15,91,219 // cvtps2dq %xmm3,%xmm3 .byte 102,72,15,58,22,219,1 // pextrq $0x1,%xmm3,%rbx .byte 65,137,217 // mov %ebx,%r9d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,72,15,126,216 // movq %xmm3,%rax .byte 65,137,195 // mov %eax,%r11d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,67,15,58,32,28,26,0 // pinsrb $0x0,(%r10,%r11,1),%xmm3 .byte 102,65,15,58,32,28,2,1 // pinsrb $0x1,(%r10,%rax,1),%xmm3 .byte 67,15,182,4,10 // movzbl (%r10,%r9,1),%eax .byte 102,15,58,32,216,2 // pinsrb $0x2,%eax,%xmm3 .byte 65,15,182,4,26 // movzbl (%r10,%rbx,1),%eax .byte 102,15,58,32,216,3 // pinsrb $0x3,%eax,%xmm3 .byte 102,15,56,49,219 // pmovzxbd %xmm3,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 65,15,89,217 // mulps %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax HIDDEN _sk_byte_tables_rgb_sse41 .globl _sk_byte_tables_rgb_sse41 FUNCTION(_sk_byte_tables_rgb_sse41) _sk_byte_tables_rgb_sse41: .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,139,72,24 // mov 0x18(%rax),%r9d .byte 65,255,201 // dec %r9d .byte 102,69,15,110,193 // movd %r9d,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 102,73,15,58,22,193,1 // pextrq $0x1,%xmm0,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 77,137,203 // mov %r9,%r11 .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,73,15,126,193 // movq %xmm0,%r9 .byte 69,137,206 // mov %r9d,%r14d .byte 77,137,207 // mov %r9,%r15 .byte 73,193,239,32 // shr $0x20,%r15 .byte 76,139,32 // mov (%rax),%r12 .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 102,67,15,58,32,4,52,0 // pinsrb $0x0,(%r12,%r14,1),%xmm0 .byte 102,67,15,58,32,4,60,1 // pinsrb $0x1,(%r12,%r15,1),%xmm0 .byte 67,15,182,28,20 // movzbl (%r12,%r10,1),%ebx .byte 102,15,58,32,195,2 // pinsrb $0x2,%ebx,%xmm0 .byte 67,15,182,28,28 // movzbl (%r12,%r11,1),%ebx .byte 102,15,58,32,195,3 // pinsrb $0x3,%ebx,%xmm0 .byte 102,15,56,49,192 // pmovzxbd %xmm0,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,13,1,61,0,0 // movaps 0x3d01(%rip),%xmm9 # 6630 <_sk_callback_sse41+0x784> .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,15,91,201 // cvtps2dq %xmm1,%xmm1 .byte 102,72,15,58,22,203,1 // pextrq $0x1,%xmm1,%rbx .byte 65,137,218 // mov %ebx,%r10d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,73,15,126,203 // movq %xmm1,%r11 .byte 69,137,222 // mov %r11d,%r14d .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,67,15,58,32,12,49,0 // pinsrb $0x0,(%r9,%r14,1),%xmm1 .byte 102,67,15,58,32,12,25,1 // pinsrb $0x1,(%r9,%r11,1),%xmm1 .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 102,65,15,58,32,202,2 // pinsrb $0x2,%r10d,%xmm1 .byte 65,15,182,28,25 // movzbl (%r9,%rbx,1),%ebx .byte 102,15,58,32,203,3 // pinsrb $0x3,%ebx,%xmm1 .byte 102,15,56,49,201 // pmovzxbd %xmm1,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 76,139,80,16 // mov 0x10(%rax),%r10 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,15,91,210 // cvtps2dq %xmm2,%xmm2 .byte 102,72,15,58,22,211,1 // pextrq $0x1,%xmm2,%rbx .byte 65,137,217 // mov %ebx,%r9d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,72,15,126,208 // movq %xmm2,%rax .byte 65,137,195 // mov %eax,%r11d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,67,15,58,32,20,26,0 // pinsrb $0x0,(%r10,%r11,1),%xmm2 .byte 102,65,15,58,32,20,2,1 // pinsrb $0x1,(%r10,%rax,1),%xmm2 .byte 67,15,182,4,10 // movzbl (%r10,%r9,1),%eax .byte 102,15,58,32,208,2 // pinsrb $0x2,%eax,%xmm2 .byte 65,15,182,4,26 // movzbl (%r10,%rbx,1),%eax .byte 102,15,58,32,208,3 // pinsrb $0x3,%eax,%xmm2 .byte 102,15,56,49,210 // pmovzxbd %xmm2,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax HIDDEN _sk_table_r_sse41 .globl _sk_table_r_sse41 FUNCTION(_sk_table_r_sse41) _sk_table_r_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 102,65,15,91,192 // cvtps2dq %xmm8,%xmm0 .byte 102,72,15,58,22,192,1 // pextrq $0x1,%xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,65,15,16,4,153 // movss (%r9,%rbx,4),%xmm0 .byte 102,67,15,58,33,4,153,16 // insertps $0x10,(%r9,%r11,4),%xmm0 .byte 243,71,15,16,4,145 // movss (%r9,%r10,4),%xmm8 .byte 102,65,15,58,33,192,32 // insertps $0x20,%xmm8,%xmm0 .byte 243,69,15,16,4,129 // movss (%r9,%rax,4),%xmm8 .byte 102,65,15,58,33,192,48 // insertps $0x30,%xmm8,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_table_g_sse41 .globl _sk_table_g_sse41 FUNCTION(_sk_table_g_sse41) _sk_table_g_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,193 // mulps %xmm1,%xmm8 .byte 102,65,15,91,200 // cvtps2dq %xmm8,%xmm1 .byte 102,72,15,58,22,200,1 // pextrq $0x1,%xmm1,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,203 // movq %xmm1,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,65,15,16,12,153 // movss (%r9,%rbx,4),%xmm1 .byte 102,67,15,58,33,12,153,16 // insertps $0x10,(%r9,%r11,4),%xmm1 .byte 243,71,15,16,4,145 // movss (%r9,%r10,4),%xmm8 .byte 102,65,15,58,33,200,32 // insertps $0x20,%xmm8,%xmm1 .byte 243,69,15,16,4,129 // movss (%r9,%rax,4),%xmm8 .byte 102,65,15,58,33,200,48 // insertps $0x30,%xmm8,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_table_b_sse41 .globl _sk_table_b_sse41 FUNCTION(_sk_table_b_sse41) _sk_table_b_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 102,65,15,91,208 // cvtps2dq %xmm8,%xmm2 .byte 102,72,15,58,22,208,1 // pextrq $0x1,%xmm2,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,211 // movq %xmm2,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,65,15,16,20,153 // movss (%r9,%rbx,4),%xmm2 .byte 102,67,15,58,33,20,153,16 // insertps $0x10,(%r9,%r11,4),%xmm2 .byte 243,71,15,16,4,145 // movss (%r9,%r10,4),%xmm8 .byte 102,65,15,58,33,208,32 // insertps $0x20,%xmm8,%xmm2 .byte 243,69,15,16,4,129 // movss (%r9,%rax,4),%xmm8 .byte 102,65,15,58,33,208,48 // insertps $0x30,%xmm8,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_table_a_sse41 .globl _sk_table_a_sse41 FUNCTION(_sk_table_a_sse41) _sk_table_a_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,65,15,91,216 // cvtps2dq %xmm8,%xmm3 .byte 102,72,15,58,22,216,1 // pextrq $0x1,%xmm3,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,219 // movq %xmm3,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,65,15,16,28,153 // movss (%r9,%rbx,4),%xmm3 .byte 102,67,15,58,33,28,153,16 // insertps $0x10,(%r9,%r11,4),%xmm3 .byte 243,71,15,16,4,145 // movss (%r9,%r10,4),%xmm8 .byte 102,65,15,58,33,216,32 // insertps $0x20,%xmm8,%xmm3 .byte 243,69,15,16,4,129 // movss (%r9,%rax,4),%xmm8 .byte 102,65,15,58,33,216,48 // insertps $0x30,%xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_r_sse41 .globl _sk_parametric_r_sse41 FUNCTION(_sk_parametric_r_sse41) _sk_parametric_r_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,64,16 // movss 0x10(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 243,68,15,16,72,12 // movss 0xc(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,89,200 // mulps %xmm0,%xmm9 .byte 243,68,15,16,80,4 // movss 0x4(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 68,15,89,208 // mulps %xmm0,%xmm10 .byte 65,15,194,192,2 // cmpleps %xmm8,%xmm0 .byte 243,68,15,16,64,24 // movss 0x18(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 69,15,88,200 // addps %xmm8,%xmm9 .byte 243,68,15,16,24 // movss (%rax),%xmm11 .byte 243,68,15,16,64,8 // movss 0x8(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 69,15,88,208 // addps %xmm8,%xmm10 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,91,194 // cvtdq2ps %xmm10,%xmm8 .byte 68,15,89,5,73,58,0,0 // mulps 0x3a49(%rip),%xmm8 # 6640 <_sk_callback_sse41+0x794> .byte 68,15,84,21,81,58,0,0 // andps 0x3a51(%rip),%xmm10 # 6650 <_sk_callback_sse41+0x7a4> .byte 68,15,86,21,89,58,0,0 // orps 0x3a59(%rip),%xmm10 # 6660 <_sk_callback_sse41+0x7b4> .byte 68,15,88,5,97,58,0,0 // addps 0x3a61(%rip),%xmm8 # 6670 <_sk_callback_sse41+0x7c4> .byte 68,15,40,37,105,58,0,0 // movaps 0x3a69(%rip),%xmm12 # 6680 <_sk_callback_sse41+0x7d4> .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 69,15,92,196 // subps %xmm12,%xmm8 .byte 68,15,88,21,105,58,0,0 // addps 0x3a69(%rip),%xmm10 # 6690 <_sk_callback_sse41+0x7e4> .byte 68,15,40,37,113,58,0,0 // movaps 0x3a71(%rip),%xmm12 # 66a0 <_sk_callback_sse41+0x7f4> .byte 69,15,94,226 // divps %xmm10,%xmm12 .byte 69,15,92,196 // subps %xmm12,%xmm8 .byte 69,15,89,195 // mulps %xmm11,%xmm8 .byte 102,69,15,58,8,208,1 // roundps $0x1,%xmm8,%xmm10 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 69,15,92,218 // subps %xmm10,%xmm11 .byte 68,15,88,5,94,58,0,0 // addps 0x3a5e(%rip),%xmm8 # 66b0 <_sk_callback_sse41+0x804> .byte 68,15,40,21,102,58,0,0 // movaps 0x3a66(%rip),%xmm10 # 66c0 <_sk_callback_sse41+0x814> .byte 69,15,89,211 // mulps %xmm11,%xmm10 .byte 69,15,92,194 // subps %xmm10,%xmm8 .byte 68,15,40,21,102,58,0,0 // movaps 0x3a66(%rip),%xmm10 # 66d0 <_sk_callback_sse41+0x824> .byte 69,15,92,211 // subps %xmm11,%xmm10 .byte 68,15,40,29,106,58,0,0 // movaps 0x3a6a(%rip),%xmm11 # 66e0 <_sk_callback_sse41+0x834> .byte 69,15,94,218 // divps %xmm10,%xmm11 .byte 69,15,88,216 // addps %xmm8,%xmm11 .byte 68,15,89,29,106,58,0,0 // mulps 0x3a6a(%rip),%xmm11 # 66f0 <_sk_callback_sse41+0x844> .byte 102,69,15,91,211 // cvtps2dq %xmm11,%xmm10 .byte 243,68,15,16,64,20 // movss 0x14(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 69,15,88,194 // addps %xmm10,%xmm8 .byte 102,69,15,56,20,193 // blendvps %xmm0,%xmm9,%xmm8 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 68,15,95,192 // maxps %xmm0,%xmm8 .byte 68,15,93,5,81,58,0,0 // minps 0x3a51(%rip),%xmm8 # 6700 <_sk_callback_sse41+0x854> .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_g_sse41 .globl _sk_parametric_g_sse41 FUNCTION(_sk_parametric_g_sse41) _sk_parametric_g_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,80,16 // movss 0x10(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,72,12 // movss 0xc(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,89,201 // mulps %xmm1,%xmm9 .byte 243,68,15,16,88,4 // movss 0x4(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 68,15,89,217 // mulps %xmm1,%xmm11 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 65,15,194,194,2 // cmpleps %xmm10,%xmm0 .byte 243,15,16,72,24 // movss 0x18(%rax),%xmm1 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 68,15,88,201 // addps %xmm1,%xmm9 .byte 243,68,15,16,16 // movss (%rax),%xmm10 .byte 243,15,16,72,8 // movss 0x8(%rax),%xmm1 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 68,15,88,217 // addps %xmm1,%xmm11 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 69,15,91,227 // cvtdq2ps %xmm11,%xmm12 .byte 68,15,89,37,242,57,0,0 // mulps 0x39f2(%rip),%xmm12 # 6710 <_sk_callback_sse41+0x864> .byte 68,15,84,29,250,57,0,0 // andps 0x39fa(%rip),%xmm11 # 6720 <_sk_callback_sse41+0x874> .byte 68,15,86,29,2,58,0,0 // orps 0x3a02(%rip),%xmm11 # 6730 <_sk_callback_sse41+0x884> .byte 68,15,88,37,10,58,0,0 // addps 0x3a0a(%rip),%xmm12 # 6740 <_sk_callback_sse41+0x894> .byte 15,40,13,19,58,0,0 // movaps 0x3a13(%rip),%xmm1 # 6750 <_sk_callback_sse41+0x8a4> .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 68,15,92,225 // subps %xmm1,%xmm12 .byte 68,15,88,29,19,58,0,0 // addps 0x3a13(%rip),%xmm11 # 6760 <_sk_callback_sse41+0x8b4> .byte 15,40,13,28,58,0,0 // movaps 0x3a1c(%rip),%xmm1 # 6770 <_sk_callback_sse41+0x8c4> .byte 65,15,94,203 // divps %xmm11,%xmm1 .byte 68,15,92,225 // subps %xmm1,%xmm12 .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 102,69,15,58,8,212,1 // roundps $0x1,%xmm12,%xmm10 .byte 69,15,40,220 // movaps %xmm12,%xmm11 .byte 69,15,92,218 // subps %xmm10,%xmm11 .byte 68,15,88,37,9,58,0,0 // addps 0x3a09(%rip),%xmm12 # 6780 <_sk_callback_sse41+0x8d4> .byte 15,40,13,18,58,0,0 // movaps 0x3a12(%rip),%xmm1 # 6790 <_sk_callback_sse41+0x8e4> .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 68,15,92,225 // subps %xmm1,%xmm12 .byte 68,15,40,21,18,58,0,0 // movaps 0x3a12(%rip),%xmm10 # 67a0 <_sk_callback_sse41+0x8f4> .byte 69,15,92,211 // subps %xmm11,%xmm10 .byte 15,40,13,23,58,0,0 // movaps 0x3a17(%rip),%xmm1 # 67b0 <_sk_callback_sse41+0x904> .byte 65,15,94,202 // divps %xmm10,%xmm1 .byte 65,15,88,204 // addps %xmm12,%xmm1 .byte 15,89,13,24,58,0,0 // mulps 0x3a18(%rip),%xmm1 # 67c0 <_sk_callback_sse41+0x914> .byte 102,68,15,91,209 // cvtps2dq %xmm1,%xmm10 .byte 243,15,16,72,20 // movss 0x14(%rax),%xmm1 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 102,65,15,56,20,201 // blendvps %xmm0,%xmm9,%xmm1 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,95,200 // maxps %xmm0,%xmm1 .byte 15,93,13,3,58,0,0 // minps 0x3a03(%rip),%xmm1 # 67d0 <_sk_callback_sse41+0x924> .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_b_sse41 .globl _sk_parametric_b_sse41 FUNCTION(_sk_parametric_b_sse41) _sk_parametric_b_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,80,16 // movss 0x10(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,72,12 // movss 0xc(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,89,202 // mulps %xmm2,%xmm9 .byte 243,68,15,16,88,4 // movss 0x4(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 65,15,194,194,2 // cmpleps %xmm10,%xmm0 .byte 243,15,16,80,24 // movss 0x18(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 68,15,88,202 // addps %xmm2,%xmm9 .byte 243,68,15,16,16 // movss (%rax),%xmm10 .byte 243,15,16,80,8 // movss 0x8(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 68,15,88,218 // addps %xmm2,%xmm11 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 69,15,91,227 // cvtdq2ps %xmm11,%xmm12 .byte 68,15,89,37,164,57,0,0 // mulps 0x39a4(%rip),%xmm12 # 67e0 <_sk_callback_sse41+0x934> .byte 68,15,84,29,172,57,0,0 // andps 0x39ac(%rip),%xmm11 # 67f0 <_sk_callback_sse41+0x944> .byte 68,15,86,29,180,57,0,0 // orps 0x39b4(%rip),%xmm11 # 6800 <_sk_callback_sse41+0x954> .byte 68,15,88,37,188,57,0,0 // addps 0x39bc(%rip),%xmm12 # 6810 <_sk_callback_sse41+0x964> .byte 15,40,21,197,57,0,0 // movaps 0x39c5(%rip),%xmm2 # 6820 <_sk_callback_sse41+0x974> .byte 65,15,89,211 // mulps %xmm11,%xmm2 .byte 68,15,92,226 // subps %xmm2,%xmm12 .byte 68,15,88,29,197,57,0,0 // addps 0x39c5(%rip),%xmm11 # 6830 <_sk_callback_sse41+0x984> .byte 15,40,21,206,57,0,0 // movaps 0x39ce(%rip),%xmm2 # 6840 <_sk_callback_sse41+0x994> .byte 65,15,94,211 // divps %xmm11,%xmm2 .byte 68,15,92,226 // subps %xmm2,%xmm12 .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 102,69,15,58,8,212,1 // roundps $0x1,%xmm12,%xmm10 .byte 69,15,40,220 // movaps %xmm12,%xmm11 .byte 69,15,92,218 // subps %xmm10,%xmm11 .byte 68,15,88,37,187,57,0,0 // addps 0x39bb(%rip),%xmm12 # 6850 <_sk_callback_sse41+0x9a4> .byte 15,40,21,196,57,0,0 // movaps 0x39c4(%rip),%xmm2 # 6860 <_sk_callback_sse41+0x9b4> .byte 65,15,89,211 // mulps %xmm11,%xmm2 .byte 68,15,92,226 // subps %xmm2,%xmm12 .byte 68,15,40,21,196,57,0,0 // movaps 0x39c4(%rip),%xmm10 # 6870 <_sk_callback_sse41+0x9c4> .byte 69,15,92,211 // subps %xmm11,%xmm10 .byte 15,40,21,201,57,0,0 // movaps 0x39c9(%rip),%xmm2 # 6880 <_sk_callback_sse41+0x9d4> .byte 65,15,94,210 // divps %xmm10,%xmm2 .byte 65,15,88,212 // addps %xmm12,%xmm2 .byte 15,89,21,202,57,0,0 // mulps 0x39ca(%rip),%xmm2 # 6890 <_sk_callback_sse41+0x9e4> .byte 102,68,15,91,210 // cvtps2dq %xmm2,%xmm10 .byte 243,15,16,80,20 // movss 0x14(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 65,15,88,210 // addps %xmm10,%xmm2 .byte 102,65,15,56,20,209 // blendvps %xmm0,%xmm9,%xmm2 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,95,208 // maxps %xmm0,%xmm2 .byte 15,93,21,181,57,0,0 // minps 0x39b5(%rip),%xmm2 # 68a0 <_sk_callback_sse41+0x9f4> .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_a_sse41 .globl _sk_parametric_a_sse41 FUNCTION(_sk_parametric_a_sse41) _sk_parametric_a_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,80,16 // movss 0x10(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,72,12 // movss 0xc(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 243,68,15,16,88,4 // movss 0x4(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 68,15,89,219 // mulps %xmm3,%xmm11 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 65,15,194,194,2 // cmpleps %xmm10,%xmm0 .byte 243,15,16,88,24 // movss 0x18(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 68,15,88,203 // addps %xmm3,%xmm9 .byte 243,68,15,16,16 // movss (%rax),%xmm10 .byte 243,15,16,88,8 // movss 0x8(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 68,15,88,219 // addps %xmm3,%xmm11 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 69,15,91,227 // cvtdq2ps %xmm11,%xmm12 .byte 68,15,89,37,86,57,0,0 // mulps 0x3956(%rip),%xmm12 # 68b0 <_sk_callback_sse41+0xa04> .byte 68,15,84,29,94,57,0,0 // andps 0x395e(%rip),%xmm11 # 68c0 <_sk_callback_sse41+0xa14> .byte 68,15,86,29,102,57,0,0 // orps 0x3966(%rip),%xmm11 # 68d0 <_sk_callback_sse41+0xa24> .byte 68,15,88,37,110,57,0,0 // addps 0x396e(%rip),%xmm12 # 68e0 <_sk_callback_sse41+0xa34> .byte 15,40,29,119,57,0,0 // movaps 0x3977(%rip),%xmm3 # 68f0 <_sk_callback_sse41+0xa44> .byte 65,15,89,219 // mulps %xmm11,%xmm3 .byte 68,15,92,227 // subps %xmm3,%xmm12 .byte 68,15,88,29,119,57,0,0 // addps 0x3977(%rip),%xmm11 # 6900 <_sk_callback_sse41+0xa54> .byte 15,40,29,128,57,0,0 // movaps 0x3980(%rip),%xmm3 # 6910 <_sk_callback_sse41+0xa64> .byte 65,15,94,219 // divps %xmm11,%xmm3 .byte 68,15,92,227 // subps %xmm3,%xmm12 .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 102,69,15,58,8,212,1 // roundps $0x1,%xmm12,%xmm10 .byte 69,15,40,220 // movaps %xmm12,%xmm11 .byte 69,15,92,218 // subps %xmm10,%xmm11 .byte 68,15,88,37,109,57,0,0 // addps 0x396d(%rip),%xmm12 # 6920 <_sk_callback_sse41+0xa74> .byte 15,40,29,118,57,0,0 // movaps 0x3976(%rip),%xmm3 # 6930 <_sk_callback_sse41+0xa84> .byte 65,15,89,219 // mulps %xmm11,%xmm3 .byte 68,15,92,227 // subps %xmm3,%xmm12 .byte 68,15,40,21,118,57,0,0 // movaps 0x3976(%rip),%xmm10 # 6940 <_sk_callback_sse41+0xa94> .byte 69,15,92,211 // subps %xmm11,%xmm10 .byte 15,40,29,123,57,0,0 // movaps 0x397b(%rip),%xmm3 # 6950 <_sk_callback_sse41+0xaa4> .byte 65,15,94,218 // divps %xmm10,%xmm3 .byte 65,15,88,220 // addps %xmm12,%xmm3 .byte 15,89,29,124,57,0,0 // mulps 0x397c(%rip),%xmm3 # 6960 <_sk_callback_sse41+0xab4> .byte 102,68,15,91,211 // cvtps2dq %xmm3,%xmm10 .byte 243,15,16,88,20 // movss 0x14(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 102,65,15,56,20,217 // blendvps %xmm0,%xmm9,%xmm3 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,95,216 // maxps %xmm0,%xmm3 .byte 15,93,29,103,57,0,0 // minps 0x3967(%rip),%xmm3 # 6970 <_sk_callback_sse41+0xac4> .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_gamma_sse41 .globl _sk_gamma_sse41 FUNCTION(_sk_gamma_sse41) _sk_gamma_sse41: .byte 15,41,124,36,232 // movaps %xmm7,-0x18(%rsp) .byte 15,41,116,36,216 // movaps %xmm6,-0x28(%rsp) .byte 15,41,108,36,200 // movaps %xmm5,-0x38(%rsp) .byte 15,41,100,36,184 // movaps %xmm4,-0x48(%rsp) .byte 15,41,92,36,168 // movaps %xmm3,-0x58(%rsp) .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,91,194 // cvtdq2ps %xmm2,%xmm0 .byte 15,89,5,70,57,0,0 // mulps 0x3946(%rip),%xmm0 # 6980 <_sk_callback_sse41+0xad4> .byte 68,15,40,53,78,57,0,0 // movaps 0x394e(%rip),%xmm14 # 6990 <_sk_callback_sse41+0xae4> .byte 65,15,84,214 // andps %xmm14,%xmm2 .byte 68,15,40,37,82,57,0,0 // movaps 0x3952(%rip),%xmm12 # 69a0 <_sk_callback_sse41+0xaf4> .byte 65,15,86,212 // orps %xmm12,%xmm2 .byte 68,15,40,21,86,57,0,0 // movaps 0x3956(%rip),%xmm10 # 69b0 <_sk_callback_sse41+0xb04> .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 68,15,40,29,90,57,0,0 // movaps 0x395a(%rip),%xmm11 # 69c0 <_sk_callback_sse41+0xb14> .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 65,15,89,227 // mulps %xmm11,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 68,15,40,13,88,57,0,0 // movaps 0x3958(%rip),%xmm9 # 69d0 <_sk_callback_sse41+0xb24> .byte 65,15,88,209 // addps %xmm9,%xmm2 .byte 68,15,40,45,92,57,0,0 // movaps 0x395c(%rip),%xmm13 # 69e0 <_sk_callback_sse41+0xb34> .byte 65,15,40,229 // movaps %xmm13,%xmm4 .byte 15,94,226 // divps %xmm2,%xmm4 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,92,196 // subps %xmm4,%xmm0 .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,58,8,208,1 // roundps $0x1,%xmm0,%xmm2 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,92,226 // subps %xmm2,%xmm4 .byte 15,40,53,63,57,0,0 // movaps 0x393f(%rip),%xmm6 # 69f0 <_sk_callback_sse41+0xb44> .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,40,61,85,57,0,0 // movaps 0x3955(%rip),%xmm7 # 6a10 <_sk_callback_sse41+0xb64> .byte 15,40,239 // movaps %xmm7,%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 15,40,37,53,57,0,0 // movaps 0x3935(%rip),%xmm4 # 6a00 <_sk_callback_sse41+0xb54> .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,92,194 // subps %xmm2,%xmm0 .byte 68,15,40,61,71,57,0,0 // movaps 0x3947(%rip),%xmm15 # 6a20 <_sk_callback_sse41+0xb74> .byte 65,15,40,215 // movaps %xmm15,%xmm2 .byte 15,94,213 // divps %xmm5,%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 15,91,193 // cvtdq2ps %xmm1,%xmm0 .byte 15,89,5,147,56,0,0 // mulps 0x3893(%rip),%xmm0 # 6980 <_sk_callback_sse41+0xad4> .byte 65,15,84,206 // andps %xmm14,%xmm1 .byte 65,15,86,204 // orps %xmm12,%xmm1 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 65,15,89,235 // mulps %xmm11,%xmm5 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 69,15,40,241 // movaps %xmm9,%xmm14 .byte 65,15,40,237 // movaps %xmm13,%xmm5 .byte 15,94,233 // divps %xmm1,%xmm5 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,58,8,200,1 // roundps $0x1,%xmm0,%xmm1 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 68,15,40,206 // movaps %xmm6,%xmm9 .byte 15,40,247 // movaps %xmm7,%xmm6 .byte 15,92,245 // subps %xmm5,%xmm6 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 65,15,40,207 // movaps %xmm15,%xmm1 .byte 15,94,206 // divps %xmm6,%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,91,195 // cvtdq2ps %xmm3,%xmm0 .byte 15,89,5,52,56,0,0 // mulps 0x3834(%rip),%xmm0 # 6980 <_sk_callback_sse41+0xad4> .byte 15,84,29,61,56,0,0 // andps 0x383d(%rip),%xmm3 # 6990 <_sk_callback_sse41+0xae4> .byte 65,15,86,220 // orps %xmm12,%xmm3 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 68,15,89,219 // mulps %xmm3,%xmm11 .byte 65,15,92,195 // subps %xmm11,%xmm0 .byte 65,15,88,222 // addps %xmm14,%xmm3 .byte 68,15,94,235 // divps %xmm3,%xmm13 .byte 65,15,92,197 // subps %xmm13,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,58,8,216,1 // roundps $0x1,%xmm0,%xmm3 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,92,235 // subps %xmm3,%xmm5 .byte 65,15,88,193 // addps %xmm9,%xmm0 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,92,253 // subps %xmm5,%xmm7 .byte 68,15,94,255 // divps %xmm7,%xmm15 .byte 68,15,88,248 // addps %xmm0,%xmm15 .byte 15,40,5,149,56,0,0 // movaps 0x3895(%rip),%xmm0 # 6a30 <_sk_callback_sse41+0xb84> .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 68,15,89,248 // mulps %xmm0,%xmm15 .byte 102,15,91,194 // cvtps2dq %xmm2,%xmm0 .byte 102,15,91,201 // cvtps2dq %xmm1,%xmm1 .byte 102,65,15,91,215 // cvtps2dq %xmm15,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,92,36,168 // movaps -0x58(%rsp),%xmm3 .byte 15,40,100,36,184 // movaps -0x48(%rsp),%xmm4 .byte 15,40,108,36,200 // movaps -0x38(%rsp),%xmm5 .byte 15,40,116,36,216 // movaps -0x28(%rsp),%xmm6 .byte 15,40,124,36,232 // movaps -0x18(%rsp),%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_lab_to_xyz_sse41 .globl _sk_lab_to_xyz_sse41 FUNCTION(_sk_lab_to_xyz_sse41) _sk_lab_to_xyz_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 68,15,89,5,101,56,0,0 // mulps 0x3865(%rip),%xmm8 # 6a40 <_sk_callback_sse41+0xb94> .byte 68,15,40,13,109,56,0,0 // movaps 0x386d(%rip),%xmm9 # 6a50 <_sk_callback_sse41+0xba4> .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 15,40,5,114,56,0,0 // movaps 0x3872(%rip),%xmm0 # 6a60 <_sk_callback_sse41+0xbb4> .byte 15,88,200 // addps %xmm0,%xmm1 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 68,15,88,5,112,56,0,0 // addps 0x3870(%rip),%xmm8 # 6a70 <_sk_callback_sse41+0xbc4> .byte 68,15,89,5,120,56,0,0 // mulps 0x3878(%rip),%xmm8 # 6a80 <_sk_callback_sse41+0xbd4> .byte 15,89,13,129,56,0,0 // mulps 0x3881(%rip),%xmm1 # 6a90 <_sk_callback_sse41+0xbe4> .byte 65,15,88,200 // addps %xmm8,%xmm1 .byte 15,89,21,134,56,0,0 // mulps 0x3886(%rip),%xmm2 # 6aa0 <_sk_callback_sse41+0xbf4> .byte 69,15,40,208 // movaps %xmm8,%xmm10 .byte 68,15,92,210 // subps %xmm2,%xmm10 .byte 68,15,40,217 // movaps %xmm1,%xmm11 .byte 69,15,89,219 // mulps %xmm11,%xmm11 .byte 68,15,89,217 // mulps %xmm1,%xmm11 .byte 68,15,40,13,122,56,0,0 // movaps 0x387a(%rip),%xmm9 # 6ab0 <_sk_callback_sse41+0xc04> .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,194,195,1 // cmpltps %xmm11,%xmm0 .byte 15,40,21,122,56,0,0 // movaps 0x387a(%rip),%xmm2 # 6ac0 <_sk_callback_sse41+0xc14> .byte 15,88,202 // addps %xmm2,%xmm1 .byte 68,15,40,37,127,56,0,0 // movaps 0x387f(%rip),%xmm12 # 6ad0 <_sk_callback_sse41+0xc24> .byte 65,15,89,204 // mulps %xmm12,%xmm1 .byte 102,65,15,56,20,203 // blendvps %xmm0,%xmm11,%xmm1 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 69,15,89,219 // mulps %xmm11,%xmm11 .byte 69,15,89,216 // mulps %xmm8,%xmm11 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,194,195,1 // cmpltps %xmm11,%xmm0 .byte 68,15,88,194 // addps %xmm2,%xmm8 .byte 69,15,89,196 // mulps %xmm12,%xmm8 .byte 102,69,15,56,20,195 // blendvps %xmm0,%xmm11,%xmm8 .byte 69,15,40,218 // movaps %xmm10,%xmm11 .byte 69,15,89,219 // mulps %xmm11,%xmm11 .byte 69,15,89,218 // mulps %xmm10,%xmm11 .byte 69,15,194,203,1 // cmpltps %xmm11,%xmm9 .byte 65,15,88,210 // addps %xmm10,%xmm2 .byte 65,15,89,212 // mulps %xmm12,%xmm2 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,65,15,56,20,211 // blendvps %xmm0,%xmm11,%xmm2 .byte 15,89,13,56,56,0,0 // mulps 0x3838(%rip),%xmm1 # 6ae0 <_sk_callback_sse41+0xc34> .byte 15,89,21,65,56,0,0 // mulps 0x3841(%rip),%xmm2 # 6af0 <_sk_callback_sse41+0xc44> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_load_a8_sse41 .globl _sk_load_a8_sse41 FUNCTION(_sk_load_a8_sse41) _sk_load_a8_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,39 // jne 32f9 <_sk_load_a8_sse41+0x3f> .byte 102,67,15,56,49,4,25 // pmovzxbd (%r9,%r11,1),%xmm0 .byte 102,15,219,5,31,56,0,0 // pand 0x381f(%rip),%xmm0 # 6b00 <_sk_callback_sse41+0xc54> .byte 15,91,216 // cvtdq2ps %xmm0,%xmm3 .byte 15,89,29,37,56,0,0 // mulps 0x3825(%rip),%xmm3 # 6b10 <_sk_callback_sse41+0xc64> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,53 // je 333b <_sk_load_a8_sse41+0x81> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3325 <_sk_load_a8_sse41+0x6b> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,195 // jne 32d9 <_sk_load_a8_sse41+0x1f> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 102,15,56,49,201 // pmovzxbd %xmm1,%xmm1 .byte 102,15,58,14,193,15 // pblendw $0xf,%xmm1,%xmm0 .byte 235,158 // jmp 32d9 <_sk_load_a8_sse41+0x1f> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 235,147 // jmp 32d9 <_sk_load_a8_sse41+0x1f> HIDDEN _sk_load_a8_dst_sse41 .globl _sk_load_a8_dst_sse41 FUNCTION(_sk_load_a8_dst_sse41) _sk_load_a8_dst_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,39 // jne 3385 <_sk_load_a8_dst_sse41+0x3f> .byte 102,67,15,56,49,36,25 // pmovzxbd (%r9,%r11,1),%xmm4 .byte 102,15,219,37,179,55,0,0 // pand 0x37b3(%rip),%xmm4 # 6b20 <_sk_callback_sse41+0xc74> .byte 15,91,252 // cvtdq2ps %xmm4,%xmm7 .byte 15,89,61,185,55,0,0 // mulps 0x37b9(%rip),%xmm7 # 6b30 <_sk_callback_sse41+0xc84> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 102,15,239,237 // pxor %xmm5,%xmm5 .byte 15,87,246 // xorps %xmm6,%xmm6 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,53 // je 33c7 <_sk_load_a8_dst_sse41+0x81> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 33b1 <_sk_load_a8_dst_sse41+0x6b> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,195 // jne 3365 <_sk_load_a8_dst_sse41+0x1f> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,15,110,232 // movd %eax,%xmm5 .byte 102,15,56,49,237 // pmovzxbd %xmm5,%xmm5 .byte 102,15,58,14,229,15 // pblendw $0xf,%xmm5,%xmm4 .byte 235,158 // jmp 3365 <_sk_load_a8_dst_sse41+0x1f> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 235,147 // jmp 3365 <_sk_load_a8_dst_sse41+0x1f> HIDDEN _sk_gather_a8_sse41 .globl _sk_gather_a8_sse41 FUNCTION(_sk_gather_a8_sse41) _sk_gather_a8_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,56,64,209 // pmulld %xmm1,%xmm2 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,194 // paddd %xmm2,%xmm0 .byte 102,72,15,58,22,192,1 // pextrq $0x1,%xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,65,15,58,32,4,25,0 // pinsrb $0x0,(%r9,%rbx,1),%xmm0 .byte 102,67,15,58,32,4,25,1 // pinsrb $0x1,(%r9,%r11,1),%xmm0 .byte 67,15,182,28,17 // movzbl (%r9,%r10,1),%ebx .byte 102,15,58,32,195,2 // pinsrb $0x2,%ebx,%xmm0 .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 102,15,58,32,192,3 // pinsrb $0x3,%eax,%xmm0 .byte 102,15,56,49,192 // pmovzxbd %xmm0,%xmm0 .byte 15,91,216 // cvtdq2ps %xmm0,%xmm3 .byte 15,89,29,254,54,0,0 // mulps 0x36fe(%rip),%xmm3 # 6b40 <_sk_callback_sse41+0xc94> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_a8_sse41 .globl _sk_store_a8_sse41 FUNCTION(_sk_store_a8_sse41) _sk_store_a8_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 68,15,40,5,227,54,0,0 // movaps 0x36e3(%rip),%xmm8 # 6b50 <_sk_callback_sse41+0xca4> .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,69,15,56,43,192 // packusdw %xmm8,%xmm8 .byte 102,69,15,103,192 // packuswb %xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,13 // jne 3493 <_sk_store_a8_sse41+0x41> .byte 102,68,15,126,192 // movd %xmm8,%eax .byte 67,137,4,25 // mov %eax,(%r9,%r11,1) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,69,15,56,49,192 // pmovzxbd %xmm8,%xmm8 .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,41 // je 34cf <_sk_store_a8_sse41+0x7d> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,15 // je 34bb <_sk_store_a8_sse41+0x69> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,221 // jne 348f <_sk_store_a8_sse41+0x3d> .byte 102,71,15,58,20,68,25,2,8 // pextrb $0x8,%xmm8,0x2(%r9,%r11,1) .byte 102,68,15,56,0,5,155,54,0,0 // pshufb 0x369b(%rip),%xmm8 # 6b60 <_sk_callback_sse41+0xcb4> .byte 102,71,15,58,21,4,25,0 // pextrw $0x0,%xmm8,(%r9,%r11,1) .byte 235,192 // jmp 348f <_sk_store_a8_sse41+0x3d> .byte 102,71,15,58,20,4,25,0 // pextrb $0x0,%xmm8,(%r9,%r11,1) .byte 235,182 // jmp 348f <_sk_store_a8_sse41+0x3d> HIDDEN _sk_load_g8_sse41 .globl _sk_load_g8_sse41 FUNCTION(_sk_load_g8_sse41) _sk_load_g8_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,42 // jne 351b <_sk_load_g8_sse41+0x42> .byte 102,67,15,56,49,4,25 // pmovzxbd (%r9,%r11,1),%xmm0 .byte 102,15,219,5,112,54,0,0 // pand 0x3670(%rip),%xmm0 # 6b70 <_sk_callback_sse41+0xcc4> .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,118,54,0,0 // mulps 0x3676(%rip),%xmm0 # 6b80 <_sk_callback_sse41+0xcd4> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,125,54,0,0 // movaps 0x367d(%rip),%xmm3 # 6b90 <_sk_callback_sse41+0xce4> .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,53 // je 355d <_sk_load_g8_sse41+0x84> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3547 <_sk_load_g8_sse41+0x6e> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,192 // jne 34f8 <_sk_load_g8_sse41+0x1f> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 102,15,56,49,201 // pmovzxbd %xmm1,%xmm1 .byte 102,15,58,14,193,15 // pblendw $0xf,%xmm1,%xmm0 .byte 235,155 // jmp 34f8 <_sk_load_g8_sse41+0x1f> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 235,144 // jmp 34f8 <_sk_load_g8_sse41+0x1f> HIDDEN _sk_load_g8_dst_sse41 .globl _sk_load_g8_dst_sse41 FUNCTION(_sk_load_g8_dst_sse41) _sk_load_g8_dst_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,42 // jne 35aa <_sk_load_g8_dst_sse41+0x42> .byte 102,67,15,56,49,36,25 // pmovzxbd (%r9,%r11,1),%xmm4 .byte 102,15,219,37,17,54,0,0 // pand 0x3611(%rip),%xmm4 # 6ba0 <_sk_callback_sse41+0xcf4> .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,37,23,54,0,0 // mulps 0x3617(%rip),%xmm4 # 6bb0 <_sk_callback_sse41+0xd04> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,61,30,54,0,0 // movaps 0x361e(%rip),%xmm7 # 6bc0 <_sk_callback_sse41+0xd14> .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,40,244 // movaps %xmm4,%xmm6 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,53 // je 35ec <_sk_load_g8_dst_sse41+0x84> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 35d6 <_sk_load_g8_dst_sse41+0x6e> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,192 // jne 3587 <_sk_load_g8_dst_sse41+0x1f> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,15,110,232 // movd %eax,%xmm5 .byte 102,15,56,49,237 // pmovzxbd %xmm5,%xmm5 .byte 102,15,58,14,229,15 // pblendw $0xf,%xmm5,%xmm4 .byte 235,155 // jmp 3587 <_sk_load_g8_dst_sse41+0x1f> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 235,144 // jmp 3587 <_sk_load_g8_dst_sse41+0x1f> HIDDEN _sk_gather_g8_sse41 .globl _sk_gather_g8_sse41 FUNCTION(_sk_gather_g8_sse41) _sk_gather_g8_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,56,64,209 // pmulld %xmm1,%xmm2 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,194 // paddd %xmm2,%xmm0 .byte 102,72,15,58,22,192,1 // pextrq $0x1,%xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,65,15,58,32,4,25,0 // pinsrb $0x0,(%r9,%rbx,1),%xmm0 .byte 102,67,15,58,32,4,25,1 // pinsrb $0x1,(%r9,%r11,1),%xmm0 .byte 67,15,182,28,17 // movzbl (%r9,%r10,1),%ebx .byte 102,15,58,32,195,2 // pinsrb $0x2,%ebx,%xmm0 .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 102,15,58,32,192,3 // pinsrb $0x3,%eax,%xmm0 .byte 102,15,56,49,192 // pmovzxbd %xmm0,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,105,53,0,0 // mulps 0x3569(%rip),%xmm0 # 6bd0 <_sk_callback_sse41+0xd24> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,112,53,0,0 // movaps 0x3570(%rip),%xmm3 # 6be0 <_sk_callback_sse41+0xd34> .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_load_565_sse41 .globl _sk_load_565_sse41 FUNCTION(_sk_load_565_sse41) _sk_load_565_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,80 // jne 36e4 <_sk_load_565_sse41+0x6b> .byte 102,67,15,56,51,20,89 // pmovzxwd (%r9,%r11,2),%xmm2 .byte 102,15,111,5,77,53,0,0 // movdqa 0x354d(%rip),%xmm0 # 6bf0 <_sk_callback_sse41+0xd44> .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,79,53,0,0 // mulps 0x354f(%rip),%xmm0 # 6c00 <_sk_callback_sse41+0xd54> .byte 102,15,111,13,87,53,0,0 // movdqa 0x3557(%rip),%xmm1 # 6c10 <_sk_callback_sse41+0xd64> .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,13,89,53,0,0 // mulps 0x3559(%rip),%xmm1 # 6c20 <_sk_callback_sse41+0xd74> .byte 102,15,219,21,97,53,0,0 // pand 0x3561(%rip),%xmm2 # 6c30 <_sk_callback_sse41+0xd84> .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,21,103,53,0,0 // mulps 0x3567(%rip),%xmm2 # 6c40 <_sk_callback_sse41+0xd94> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,110,53,0,0 // movaps 0x356e(%rip),%xmm3 # 6c50 <_sk_callback_sse41+0xda4> .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,53 // je 3726 <_sk_load_565_sse41+0xad> .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3710 <_sk_load_565_sse41+0x97> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,154 // jne 369b <_sk_load_565_sse41+0x22> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,208,69 // pshufd $0x45,%xmm0,%xmm2 .byte 102,67,15,110,4,89 // movd (%r9,%r11,2),%xmm0 .byte 102,15,56,51,192 // pmovzxwd %xmm0,%xmm0 .byte 102,15,58,14,208,15 // pblendw $0xf,%xmm0,%xmm2 .byte 233,117,255,255,255 // jmpq 369b <_sk_load_565_sse41+0x22> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 233,103,255,255,255 // jmpq 369b <_sk_load_565_sse41+0x22> HIDDEN _sk_load_565_dst_sse41 .globl _sk_load_565_dst_sse41 FUNCTION(_sk_load_565_dst_sse41) _sk_load_565_dst_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,80 // jne 379f <_sk_load_565_dst_sse41+0x6b> .byte 102,67,15,56,51,52,89 // pmovzxwd (%r9,%r11,2),%xmm6 .byte 102,15,111,37,2,53,0,0 // movdqa 0x3502(%rip),%xmm4 # 6c60 <_sk_callback_sse41+0xdb4> .byte 102,15,219,230 // pand %xmm6,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,37,4,53,0,0 // mulps 0x3504(%rip),%xmm4 # 6c70 <_sk_callback_sse41+0xdc4> .byte 102,15,111,45,12,53,0,0 // movdqa 0x350c(%rip),%xmm5 # 6c80 <_sk_callback_sse41+0xdd4> .byte 102,15,219,238 // pand %xmm6,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,45,14,53,0,0 // mulps 0x350e(%rip),%xmm5 # 6c90 <_sk_callback_sse41+0xde4> .byte 102,15,219,53,22,53,0,0 // pand 0x3516(%rip),%xmm6 # 6ca0 <_sk_callback_sse41+0xdf4> .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,89,53,28,53,0,0 // mulps 0x351c(%rip),%xmm6 # 6cb0 <_sk_callback_sse41+0xe04> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,61,35,53,0,0 // movaps 0x3523(%rip),%xmm7 # 6cc0 <_sk_callback_sse41+0xe14> .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,53 // je 37e1 <_sk_load_565_dst_sse41+0xad> .byte 102,15,239,246 // pxor %xmm6,%xmm6 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 37cb <_sk_load_565_dst_sse41+0x97> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,154 // jne 3756 <_sk_load_565_dst_sse41+0x22> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 102,15,112,244,69 // pshufd $0x45,%xmm4,%xmm6 .byte 102,67,15,110,36,89 // movd (%r9,%r11,2),%xmm4 .byte 102,15,56,51,228 // pmovzxwd %xmm4,%xmm4 .byte 102,15,58,14,244,15 // pblendw $0xf,%xmm4,%xmm6 .byte 233,117,255,255,255 // jmpq 3756 <_sk_load_565_dst_sse41+0x22> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,15,110,240 // movd %eax,%xmm6 .byte 233,103,255,255,255 // jmpq 3756 <_sk_load_565_dst_sse41+0x22> HIDDEN _sk_gather_565_sse41 .globl _sk_gather_565_sse41 FUNCTION(_sk_gather_565_sse41) _sk_gather_565_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,56,64,209 // pmulld %xmm1,%xmm2 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,194 // paddd %xmm2,%xmm0 .byte 102,72,15,58,22,192,1 // pextrq $0x1,%xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,65,15,196,4,89,0 // pinsrw $0x0,(%r9,%rbx,2),%xmm0 .byte 102,67,15,196,4,89,1 // pinsrw $0x1,(%r9,%r11,2),%xmm0 .byte 67,15,183,28,81 // movzwl (%r9,%r10,2),%ebx .byte 102,15,196,195,2 // pinsrw $0x2,%ebx,%xmm0 .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 102,15,196,192,3 // pinsrw $0x3,%eax,%xmm0 .byte 102,15,56,51,208 // pmovzxwd %xmm0,%xmm2 .byte 102,15,111,5,119,52,0,0 // movdqa 0x3477(%rip),%xmm0 # 6cd0 <_sk_callback_sse41+0xe24> .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,121,52,0,0 // mulps 0x3479(%rip),%xmm0 # 6ce0 <_sk_callback_sse41+0xe34> .byte 102,15,111,13,129,52,0,0 // movdqa 0x3481(%rip),%xmm1 # 6cf0 <_sk_callback_sse41+0xe44> .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,13,131,52,0,0 // mulps 0x3483(%rip),%xmm1 # 6d00 <_sk_callback_sse41+0xe54> .byte 102,15,219,21,139,52,0,0 // pand 0x348b(%rip),%xmm2 # 6d10 <_sk_callback_sse41+0xe64> .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,21,145,52,0,0 // mulps 0x3491(%rip),%xmm2 # 6d20 <_sk_callback_sse41+0xe74> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,152,52,0,0 // movaps 0x3498(%rip),%xmm3 # 6d30 <_sk_callback_sse41+0xe84> .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_565_sse41 .globl _sk_store_565_sse41 FUNCTION(_sk_store_565_sse41) _sk_store_565_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 68,15,40,5,135,52,0,0 // movaps 0x3487(%rip),%xmm8 # 6d40 <_sk_callback_sse41+0xe94> .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,11 // pslld $0xb,%xmm9 .byte 68,15,40,21,124,52,0,0 // movaps 0x347c(%rip),%xmm10 # 6d50 <_sk_callback_sse41+0xea4> .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,65,15,114,242,5 // pslld $0x5,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,69,15,86,194 // orpd %xmm10,%xmm8 .byte 102,69,15,56,43,192 // packusdw %xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,10 // jne 390b <_sk_store_565_sse41+0x70> .byte 242,69,15,17,4,65 // movsd %xmm8,(%r9,%rax,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,69,15,56,51,192 // pmovzxwd %xmm8,%xmm8 .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,35 // je 3941 <_sk_store_565_sse41+0xa6> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,15 // je 3933 <_sk_store_565_sse41+0x98> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,221 // jne 3907 <_sk_store_565_sse41+0x6c> .byte 102,69,15,58,21,68,65,4,4 // pextrw $0x4,%xmm8,0x4(%r9,%rax,2) .byte 242,69,15,112,192,232 // pshuflw $0xe8,%xmm8,%xmm8 .byte 102,69,15,126,4,65 // movd %xmm8,(%r9,%rax,2) .byte 235,198 // jmp 3907 <_sk_store_565_sse41+0x6c> .byte 102,69,15,58,21,4,65,0 // pextrw $0x0,%xmm8,(%r9,%rax,2) .byte 235,188 // jmp 3907 <_sk_store_565_sse41+0x6c> HIDDEN _sk_load_4444_sse41 .globl _sk_load_4444_sse41 FUNCTION(_sk_load_4444_sse41) _sk_load_4444_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,95 // jne 39c5 <_sk_load_4444_sse41+0x7a> .byte 102,67,15,56,51,28,89 // pmovzxwd (%r9,%r11,2),%xmm3 .byte 102,15,111,5,235,51,0,0 // movdqa 0x33eb(%rip),%xmm0 # 6d60 <_sk_callback_sse41+0xeb4> .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,237,51,0,0 // mulps 0x33ed(%rip),%xmm0 # 6d70 <_sk_callback_sse41+0xec4> .byte 102,15,111,13,245,51,0,0 // movdqa 0x33f5(%rip),%xmm1 # 6d80 <_sk_callback_sse41+0xed4> .byte 102,15,219,203 // pand %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,13,247,51,0,0 // mulps 0x33f7(%rip),%xmm1 # 6d90 <_sk_callback_sse41+0xee4> .byte 102,15,111,21,255,51,0,0 // movdqa 0x33ff(%rip),%xmm2 # 6da0 <_sk_callback_sse41+0xef4> .byte 102,15,219,211 // pand %xmm3,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,21,1,52,0,0 // mulps 0x3401(%rip),%xmm2 # 6db0 <_sk_callback_sse41+0xf04> .byte 102,15,219,29,9,52,0,0 // pand 0x3409(%rip),%xmm3 # 6dc0 <_sk_callback_sse41+0xf14> .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,29,15,52,0,0 // mulps 0x340f(%rip),%xmm3 # 6dd0 <_sk_callback_sse41+0xf24> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,53 // je 3a07 <_sk_load_4444_sse41+0xbc> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 39f1 <_sk_load_4444_sse41+0xa6> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,139 // jne 396d <_sk_load_4444_sse41+0x22> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,216,69 // pshufd $0x45,%xmm0,%xmm3 .byte 102,67,15,110,4,89 // movd (%r9,%r11,2),%xmm0 .byte 102,15,56,51,192 // pmovzxwd %xmm0,%xmm0 .byte 102,15,58,14,216,15 // pblendw $0xf,%xmm0,%xmm3 .byte 233,102,255,255,255 // jmpq 396d <_sk_load_4444_sse41+0x22> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,15,110,216 // movd %eax,%xmm3 .byte 233,88,255,255,255 // jmpq 396d <_sk_load_4444_sse41+0x22> HIDDEN _sk_load_4444_dst_sse41 .globl _sk_load_4444_dst_sse41 FUNCTION(_sk_load_4444_dst_sse41) _sk_load_4444_dst_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,95 // jne 3a8f <_sk_load_4444_dst_sse41+0x7a> .byte 102,67,15,56,51,60,89 // pmovzxwd (%r9,%r11,2),%xmm7 .byte 102,15,111,37,161,51,0,0 // movdqa 0x33a1(%rip),%xmm4 # 6de0 <_sk_callback_sse41+0xf34> .byte 102,15,219,231 // pand %xmm7,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,37,163,51,0,0 // mulps 0x33a3(%rip),%xmm4 # 6df0 <_sk_callback_sse41+0xf44> .byte 102,15,111,45,171,51,0,0 // movdqa 0x33ab(%rip),%xmm5 # 6e00 <_sk_callback_sse41+0xf54> .byte 102,15,219,239 // pand %xmm7,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,45,173,51,0,0 // mulps 0x33ad(%rip),%xmm5 # 6e10 <_sk_callback_sse41+0xf64> .byte 102,15,111,53,181,51,0,0 // movdqa 0x33b5(%rip),%xmm6 # 6e20 <_sk_callback_sse41+0xf74> .byte 102,15,219,247 // pand %xmm7,%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,89,53,183,51,0,0 // mulps 0x33b7(%rip),%xmm6 # 6e30 <_sk_callback_sse41+0xf84> .byte 102,15,219,61,191,51,0,0 // pand 0x33bf(%rip),%xmm7 # 6e40 <_sk_callback_sse41+0xf94> .byte 15,91,255 // cvtdq2ps %xmm7,%xmm7 .byte 15,89,61,197,51,0,0 // mulps 0x33c5(%rip),%xmm7 # 6e50 <_sk_callback_sse41+0xfa4> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,53 // je 3ad1 <_sk_load_4444_dst_sse41+0xbc> .byte 102,15,239,255 // pxor %xmm7,%xmm7 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3abb <_sk_load_4444_dst_sse41+0xa6> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,139 // jne 3a37 <_sk_load_4444_dst_sse41+0x22> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 102,15,112,252,69 // pshufd $0x45,%xmm4,%xmm7 .byte 102,67,15,110,36,89 // movd (%r9,%r11,2),%xmm4 .byte 102,15,56,51,228 // pmovzxwd %xmm4,%xmm4 .byte 102,15,58,14,252,15 // pblendw $0xf,%xmm4,%xmm7 .byte 233,102,255,255,255 // jmpq 3a37 <_sk_load_4444_dst_sse41+0x22> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,15,110,248 // movd %eax,%xmm7 .byte 233,88,255,255,255 // jmpq 3a37 <_sk_load_4444_dst_sse41+0x22> HIDDEN _sk_gather_4444_sse41 .globl _sk_gather_4444_sse41 FUNCTION(_sk_gather_4444_sse41) _sk_gather_4444_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,56,64,209 // pmulld %xmm1,%xmm2 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,194 // paddd %xmm2,%xmm0 .byte 102,72,15,58,22,192,1 // pextrq $0x1,%xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,65,15,196,4,89,0 // pinsrw $0x0,(%r9,%rbx,2),%xmm0 .byte 102,67,15,196,4,89,1 // pinsrw $0x1,(%r9,%r11,2),%xmm0 .byte 67,15,183,28,81 // movzwl (%r9,%r10,2),%ebx .byte 102,15,196,195,2 // pinsrw $0x2,%ebx,%xmm0 .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 102,15,196,192,3 // pinsrw $0x3,%eax,%xmm0 .byte 102,15,56,51,216 // pmovzxwd %xmm0,%xmm3 .byte 102,15,111,5,23,51,0,0 // movdqa 0x3317(%rip),%xmm0 # 6e60 <_sk_callback_sse41+0xfb4> .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,25,51,0,0 // mulps 0x3319(%rip),%xmm0 # 6e70 <_sk_callback_sse41+0xfc4> .byte 102,15,111,13,33,51,0,0 // movdqa 0x3321(%rip),%xmm1 # 6e80 <_sk_callback_sse41+0xfd4> .byte 102,15,219,203 // pand %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,13,35,51,0,0 // mulps 0x3323(%rip),%xmm1 # 6e90 <_sk_callback_sse41+0xfe4> .byte 102,15,111,21,43,51,0,0 // movdqa 0x332b(%rip),%xmm2 # 6ea0 <_sk_callback_sse41+0xff4> .byte 102,15,219,211 // pand %xmm3,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,21,45,51,0,0 // mulps 0x332d(%rip),%xmm2 # 6eb0 <_sk_callback_sse41+0x1004> .byte 102,15,219,29,53,51,0,0 // pand 0x3335(%rip),%xmm3 # 6ec0 <_sk_callback_sse41+0x1014> .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,29,59,51,0,0 // mulps 0x333b(%rip),%xmm3 # 6ed0 <_sk_callback_sse41+0x1024> .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_4444_sse41 .globl _sk_store_4444_sse41 FUNCTION(_sk_store_4444_sse41) _sk_store_4444_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 68,15,40,5,40,51,0,0 // movaps 0x3328(%rip),%xmm8 # 6ee0 <_sk_callback_sse41+0x1034> .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,12 // pslld $0xc,%xmm9 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,65,15,114,242,8 // pslld $0x8,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,4 // pslld $0x4,%xmm9 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,69,15,86,193 // orpd %xmm9,%xmm8 .byte 102,69,15,86,194 // orpd %xmm10,%xmm8 .byte 102,69,15,56,43,192 // packusdw %xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,10 // jne 3c1e <_sk_store_4444_sse41+0x84> .byte 242,69,15,17,4,65 // movsd %xmm8,(%r9,%rax,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,69,15,56,51,192 // pmovzxwd %xmm8,%xmm8 .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,35 // je 3c54 <_sk_store_4444_sse41+0xba> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,15 // je 3c46 <_sk_store_4444_sse41+0xac> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,221 // jne 3c1a <_sk_store_4444_sse41+0x80> .byte 102,69,15,58,21,68,65,4,4 // pextrw $0x4,%xmm8,0x4(%r9,%rax,2) .byte 242,69,15,112,192,232 // pshuflw $0xe8,%xmm8,%xmm8 .byte 102,69,15,126,4,65 // movd %xmm8,(%r9,%rax,2) .byte 235,198 // jmp 3c1a <_sk_store_4444_sse41+0x80> .byte 102,69,15,58,21,4,65,0 // pextrw $0x0,%xmm8,(%r9,%rax,2) .byte 235,188 // jmp 3c1a <_sk_store_4444_sse41+0x80> HIDDEN _sk_load_8888_sse41 .globl _sk_load_8888_sse41 FUNCTION(_sk_load_8888_sse41) _sk_load_8888_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,89 // jne 3cd3 <_sk_load_8888_sse41+0x75> .byte 243,65,15,111,28,129 // movdqu (%r9,%rax,4),%xmm3 .byte 102,15,111,5,104,50,0,0 // movdqa 0x3268(%rip),%xmm0 # 6ef0 <_sk_callback_sse41+0x1044> .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,5,105,50,0,0 // movaps 0x3269(%rip),%xmm8 # 6f00 <_sk_callback_sse41+0x1054> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,56,0,13,104,50,0,0 // pshufb 0x3268(%rip),%xmm1 # 6f10 <_sk_callback_sse41+0x1064> .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,15,56,0,21,100,50,0,0 // pshufb 0x3264(%rip),%xmm2 # 6f20 <_sk_callback_sse41+0x1074> .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,15,114,211,24 // psrld $0x18,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,45 // je 3d0d <_sk_load_8888_sse41+0xaf> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,18 // je 3cfc <_sk_load_8888_sse41+0x9e> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,144 // jne 3c80 <_sk_load_8888_sse41+0x22> .byte 102,65,15,110,68,129,8 // movd 0x8(%r9,%rax,4),%xmm0 .byte 102,15,112,216,69 // pshufd $0x45,%xmm0,%xmm3 .byte 243,65,15,126,4,129 // movq (%r9,%rax,4),%xmm0 .byte 102,15,58,14,216,15 // pblendw $0xf,%xmm0,%xmm3 .byte 233,115,255,255,255 // jmpq 3c80 <_sk_load_8888_sse41+0x22> .byte 102,65,15,110,28,129 // movd (%r9,%rax,4),%xmm3 .byte 233,104,255,255,255 // jmpq 3c80 <_sk_load_8888_sse41+0x22> HIDDEN _sk_load_8888_dst_sse41 .globl _sk_load_8888_dst_sse41 FUNCTION(_sk_load_8888_dst_sse41) _sk_load_8888_dst_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,89 // jne 3d8d <_sk_load_8888_dst_sse41+0x75> .byte 243,65,15,111,60,129 // movdqu (%r9,%rax,4),%xmm7 .byte 102,15,111,37,238,49,0,0 // movdqa 0x31ee(%rip),%xmm4 # 6f30 <_sk_callback_sse41+0x1084> .byte 102,15,219,231 // pand %xmm7,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 68,15,40,5,239,49,0,0 // movaps 0x31ef(%rip),%xmm8 # 6f40 <_sk_callback_sse41+0x1094> .byte 65,15,89,224 // mulps %xmm8,%xmm4 .byte 102,15,111,239 // movdqa %xmm7,%xmm5 .byte 102,15,56,0,45,238,49,0,0 // pshufb 0x31ee(%rip),%xmm5 # 6f50 <_sk_callback_sse41+0x10a4> .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 65,15,89,232 // mulps %xmm8,%xmm5 .byte 102,15,111,247 // movdqa %xmm7,%xmm6 .byte 102,15,56,0,53,234,49,0,0 // pshufb 0x31ea(%rip),%xmm6 # 6f60 <_sk_callback_sse41+0x10b4> .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 65,15,89,240 // mulps %xmm8,%xmm6 .byte 102,15,114,215,24 // psrld $0x18,%xmm7 .byte 15,91,255 // cvtdq2ps %xmm7,%xmm7 .byte 65,15,89,248 // mulps %xmm8,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,45 // je 3dc7 <_sk_load_8888_dst_sse41+0xaf> .byte 102,15,239,255 // pxor %xmm7,%xmm7 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,18 // je 3db6 <_sk_load_8888_dst_sse41+0x9e> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,144 // jne 3d3a <_sk_load_8888_dst_sse41+0x22> .byte 102,65,15,110,100,129,8 // movd 0x8(%r9,%rax,4),%xmm4 .byte 102,15,112,252,69 // pshufd $0x45,%xmm4,%xmm7 .byte 243,65,15,126,36,129 // movq (%r9,%rax,4),%xmm4 .byte 102,15,58,14,252,15 // pblendw $0xf,%xmm4,%xmm7 .byte 233,115,255,255,255 // jmpq 3d3a <_sk_load_8888_dst_sse41+0x22> .byte 102,65,15,110,60,129 // movd (%r9,%rax,4),%xmm7 .byte 233,104,255,255,255 // jmpq 3d3a <_sk_load_8888_dst_sse41+0x22> HIDDEN _sk_gather_8888_sse41 .globl _sk_gather_8888_sse41 FUNCTION(_sk_gather_8888_sse41) _sk_gather_8888_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,56,64,209 // pmulld %xmm1,%xmm2 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,194 // paddd %xmm2,%xmm0 .byte 102,72,15,126,192 // movq %xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,58,22,195,1 // pextrq $0x1,%xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,67,15,110,28,145 // movd (%r9,%r10,4),%xmm3 .byte 102,65,15,58,34,28,129,1 // pinsrd $0x1,(%r9,%rax,4),%xmm3 .byte 102,65,15,58,34,28,153,2 // pinsrd $0x2,(%r9,%rbx,4),%xmm3 .byte 102,67,15,58,34,28,153,3 // pinsrd $0x3,(%r9,%r11,4),%xmm3 .byte 102,15,111,5,61,49,0,0 // movdqa 0x313d(%rip),%xmm0 # 6f70 <_sk_callback_sse41+0x10c4> .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,5,62,49,0,0 // movaps 0x313e(%rip),%xmm8 # 6f80 <_sk_callback_sse41+0x10d4> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,56,0,13,61,49,0,0 // pshufb 0x313d(%rip),%xmm1 # 6f90 <_sk_callback_sse41+0x10e4> .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,15,56,0,21,57,49,0,0 // pshufb 0x3139(%rip),%xmm2 # 6fa0 <_sk_callback_sse41+0x10f4> .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,15,114,211,24 // psrld $0x18,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_8888_sse41 .globl _sk_store_8888_sse41 FUNCTION(_sk_store_8888_sse41) _sk_store_8888_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 68,15,40,5,18,49,0,0 // movaps 0x3112(%rip),%xmm8 # 6fb0 <_sk_callback_sse41+0x1104> .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,65,15,114,242,8 // pslld $0x8,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,16 // pslld $0x10,%xmm9 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,114,240,24 // pslld $0x18,%xmm8 .byte 102,69,15,235,193 // por %xmm9,%xmm8 .byte 102,69,15,235,194 // por %xmm10,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,10 // jne 3efe <_sk_store_8888_sse41+0x7f> .byte 243,69,15,127,4,129 // movdqu %xmm8,(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,29 // je 3f28 <_sk_store_8888_sse41+0xa9> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,15 // je 3f20 <_sk_store_8888_sse41+0xa1> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,227 // jne 3efa <_sk_store_8888_sse41+0x7b> .byte 102,69,15,58,22,68,129,8,2 // pextrd $0x2,%xmm8,0x8(%r9,%rax,4) .byte 102,69,15,214,4,129 // movq %xmm8,(%r9,%rax,4) .byte 235,210 // jmp 3efa <_sk_store_8888_sse41+0x7b> .byte 102,69,15,126,4,129 // movd %xmm8,(%r9,%rax,4) .byte 235,202 // jmp 3efa <_sk_store_8888_sse41+0x7b> HIDDEN _sk_load_bgra_sse41 .globl _sk_load_bgra_sse41 FUNCTION(_sk_load_bgra_sse41) _sk_load_bgra_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,89 // jne 3fa5 <_sk_load_bgra_sse41+0x75> .byte 243,65,15,111,28,129 // movdqu (%r9,%rax,4),%xmm3 .byte 102,15,111,5,102,48,0,0 // movdqa 0x3066(%rip),%xmm0 # 6fc0 <_sk_callback_sse41+0x1114> .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,208 // cvtdq2ps %xmm0,%xmm2 .byte 68,15,40,5,103,48,0,0 // movaps 0x3067(%rip),%xmm8 # 6fd0 <_sk_callback_sse41+0x1124> .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,15,111,195 // movdqa %xmm3,%xmm0 .byte 102,15,56,0,5,102,48,0,0 // pshufb 0x3066(%rip),%xmm0 # 6fe0 <_sk_callback_sse41+0x1134> .byte 15,91,200 // cvtdq2ps %xmm0,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,15,111,195 // movdqa %xmm3,%xmm0 .byte 102,15,56,0,5,98,48,0,0 // pshufb 0x3062(%rip),%xmm0 # 6ff0 <_sk_callback_sse41+0x1144> .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,114,211,24 // psrld $0x18,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,45 // je 3fdf <_sk_load_bgra_sse41+0xaf> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,18 // je 3fce <_sk_load_bgra_sse41+0x9e> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,144 // jne 3f52 <_sk_load_bgra_sse41+0x22> .byte 102,65,15,110,68,129,8 // movd 0x8(%r9,%rax,4),%xmm0 .byte 102,15,112,216,69 // pshufd $0x45,%xmm0,%xmm3 .byte 243,65,15,126,4,129 // movq (%r9,%rax,4),%xmm0 .byte 102,15,58,14,216,15 // pblendw $0xf,%xmm0,%xmm3 .byte 233,115,255,255,255 // jmpq 3f52 <_sk_load_bgra_sse41+0x22> .byte 102,65,15,110,28,129 // movd (%r9,%rax,4),%xmm3 .byte 233,104,255,255,255 // jmpq 3f52 <_sk_load_bgra_sse41+0x22> HIDDEN _sk_load_bgra_dst_sse41 .globl _sk_load_bgra_dst_sse41 FUNCTION(_sk_load_bgra_dst_sse41) _sk_load_bgra_dst_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,89 // jne 405f <_sk_load_bgra_dst_sse41+0x75> .byte 243,65,15,111,60,129 // movdqu (%r9,%rax,4),%xmm7 .byte 102,15,111,37,236,47,0,0 // movdqa 0x2fec(%rip),%xmm4 # 7000 <_sk_callback_sse41+0x1154> .byte 102,15,219,231 // pand %xmm7,%xmm4 .byte 15,91,244 // cvtdq2ps %xmm4,%xmm6 .byte 68,15,40,5,237,47,0,0 // movaps 0x2fed(%rip),%xmm8 # 7010 <_sk_callback_sse41+0x1164> .byte 65,15,89,240 // mulps %xmm8,%xmm6 .byte 102,15,111,231 // movdqa %xmm7,%xmm4 .byte 102,15,56,0,37,236,47,0,0 // pshufb 0x2fec(%rip),%xmm4 # 7020 <_sk_callback_sse41+0x1174> .byte 15,91,236 // cvtdq2ps %xmm4,%xmm5 .byte 65,15,89,232 // mulps %xmm8,%xmm5 .byte 102,15,111,231 // movdqa %xmm7,%xmm4 .byte 102,15,56,0,37,232,47,0,0 // pshufb 0x2fe8(%rip),%xmm4 # 7030 <_sk_callback_sse41+0x1184> .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 65,15,89,224 // mulps %xmm8,%xmm4 .byte 102,15,114,215,24 // psrld $0x18,%xmm7 .byte 15,91,255 // cvtdq2ps %xmm7,%xmm7 .byte 65,15,89,248 // mulps %xmm8,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,45 // je 4099 <_sk_load_bgra_dst_sse41+0xaf> .byte 102,15,239,255 // pxor %xmm7,%xmm7 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,18 // je 4088 <_sk_load_bgra_dst_sse41+0x9e> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,144 // jne 400c <_sk_load_bgra_dst_sse41+0x22> .byte 102,65,15,110,100,129,8 // movd 0x8(%r9,%rax,4),%xmm4 .byte 102,15,112,252,69 // pshufd $0x45,%xmm4,%xmm7 .byte 243,65,15,126,36,129 // movq (%r9,%rax,4),%xmm4 .byte 102,15,58,14,252,15 // pblendw $0xf,%xmm4,%xmm7 .byte 233,115,255,255,255 // jmpq 400c <_sk_load_bgra_dst_sse41+0x22> .byte 102,65,15,110,60,129 // movd (%r9,%rax,4),%xmm7 .byte 233,104,255,255,255 // jmpq 400c <_sk_load_bgra_dst_sse41+0x22> HIDDEN _sk_gather_bgra_sse41 .globl _sk_gather_bgra_sse41 FUNCTION(_sk_gather_bgra_sse41) _sk_gather_bgra_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,56,64,209 // pmulld %xmm1,%xmm2 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,194 // paddd %xmm2,%xmm0 .byte 102,72,15,126,192 // movq %xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,58,22,195,1 // pextrq $0x1,%xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,67,15,110,28,145 // movd (%r9,%r10,4),%xmm3 .byte 102,65,15,58,34,28,129,1 // pinsrd $0x1,(%r9,%rax,4),%xmm3 .byte 102,65,15,58,34,28,153,2 // pinsrd $0x2,(%r9,%rbx,4),%xmm3 .byte 102,67,15,58,34,28,153,3 // pinsrd $0x3,(%r9,%r11,4),%xmm3 .byte 102,15,111,5,59,47,0,0 // movdqa 0x2f3b(%rip),%xmm0 # 7040 <_sk_callback_sse41+0x1194> .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,208 // cvtdq2ps %xmm0,%xmm2 .byte 68,15,40,5,60,47,0,0 // movaps 0x2f3c(%rip),%xmm8 # 7050 <_sk_callback_sse41+0x11a4> .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,15,111,195 // movdqa %xmm3,%xmm0 .byte 102,15,56,0,5,59,47,0,0 // pshufb 0x2f3b(%rip),%xmm0 # 7060 <_sk_callback_sse41+0x11b4> .byte 15,91,200 // cvtdq2ps %xmm0,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,15,111,195 // movdqa %xmm3,%xmm0 .byte 102,15,56,0,5,55,47,0,0 // pshufb 0x2f37(%rip),%xmm0 # 7070 <_sk_callback_sse41+0x11c4> .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,114,211,24 // psrld $0x18,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_bgra_sse41 .globl _sk_store_bgra_sse41 FUNCTION(_sk_store_bgra_sse41) _sk_store_bgra_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 68,15,40,5,16,47,0,0 // movaps 0x2f10(%rip),%xmm8 # 7080 <_sk_callback_sse41+0x11d4> .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,65,15,114,242,8 // pslld $0x8,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,16 // pslld $0x10,%xmm9 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,114,240,24 // pslld $0x18,%xmm8 .byte 102,69,15,235,193 // por %xmm9,%xmm8 .byte 102,69,15,235,194 // por %xmm10,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,10 // jne 41d0 <_sk_store_bgra_sse41+0x7f> .byte 243,69,15,127,4,129 // movdqu %xmm8,(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,29 // je 41fa <_sk_store_bgra_sse41+0xa9> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,15 // je 41f2 <_sk_store_bgra_sse41+0xa1> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,227 // jne 41cc <_sk_store_bgra_sse41+0x7b> .byte 102,69,15,58,22,68,129,8,2 // pextrd $0x2,%xmm8,0x8(%r9,%rax,4) .byte 102,69,15,214,4,129 // movq %xmm8,(%r9,%rax,4) .byte 235,210 // jmp 41cc <_sk_store_bgra_sse41+0x7b> .byte 102,69,15,126,4,129 // movd %xmm8,(%r9,%rax,4) .byte 235,202 // jmp 41cc <_sk_store_bgra_sse41+0x7b> HIDDEN _sk_load_f16_sse41 .globl _sk_load_f16_sse41 FUNCTION(_sk_load_f16_sse41) _sk_load_f16_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,62,1,0,0 // jne 4360 <_sk_load_f16_sse41+0x15e> .byte 102,65,15,16,4,193 // movupd (%r9,%rax,8),%xmm0 .byte 243,65,15,111,76,193,16 // movdqu 0x10(%r9,%rax,8),%xmm1 .byte 102,68,15,40,200 // movapd %xmm0,%xmm9 .byte 102,68,15,97,201 // punpcklwd %xmm1,%xmm9 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,69,15,111,217 // movdqa %xmm9,%xmm11 .byte 102,68,15,97,216 // punpcklwd %xmm0,%xmm11 .byte 102,68,15,105,200 // punpckhwd %xmm0,%xmm9 .byte 102,65,15,56,51,203 // pmovzxwd %xmm11,%xmm1 .byte 102,68,15,111,5,53,46,0,0 // movdqa 0x2e35(%rip),%xmm8 # 7090 <_sk_callback_sse41+0x11e4> .byte 102,15,111,209 // movdqa %xmm1,%xmm2 .byte 102,65,15,219,208 // pand %xmm8,%xmm2 .byte 102,15,239,202 // pxor %xmm2,%xmm1 .byte 102,15,111,29,48,46,0,0 // movdqa 0x2e30(%rip),%xmm3 # 70a0 <_sk_callback_sse41+0x11f4> .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,56,63,195 // pmaxud %xmm3,%xmm0 .byte 102,15,118,193 // pcmpeqd %xmm1,%xmm0 .byte 102,15,114,241,13 // pslld $0xd,%xmm1 .byte 102,15,235,202 // por %xmm2,%xmm1 .byte 102,68,15,111,21,28,46,0,0 // movdqa 0x2e1c(%rip),%xmm10 # 70b0 <_sk_callback_sse41+0x1204> .byte 102,65,15,254,202 // paddd %xmm10,%xmm1 .byte 102,15,219,193 // pand %xmm1,%xmm0 .byte 102,65,15,115,219,8 // psrldq $0x8,%xmm11 .byte 102,69,15,56,51,219 // pmovzxwd %xmm11,%xmm11 .byte 102,65,15,111,211 // movdqa %xmm11,%xmm2 .byte 102,65,15,219,208 // pand %xmm8,%xmm2 .byte 102,68,15,239,218 // pxor %xmm2,%xmm11 .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,65,15,111,203 // movdqa %xmm11,%xmm1 .byte 102,15,56,63,203 // pmaxud %xmm3,%xmm1 .byte 102,65,15,118,203 // pcmpeqd %xmm11,%xmm1 .byte 102,65,15,114,243,13 // pslld $0xd,%xmm11 .byte 102,68,15,235,218 // por %xmm2,%xmm11 .byte 102,69,15,254,218 // paddd %xmm10,%xmm11 .byte 102,65,15,219,203 // pand %xmm11,%xmm1 .byte 102,69,15,56,51,217 // pmovzxwd %xmm9,%xmm11 .byte 102,69,15,111,227 // movdqa %xmm11,%xmm12 .byte 102,69,15,219,224 // pand %xmm8,%xmm12 .byte 102,69,15,239,220 // pxor %xmm12,%xmm11 .byte 102,65,15,114,244,16 // pslld $0x10,%xmm12 .byte 102,65,15,111,211 // movdqa %xmm11,%xmm2 .byte 102,15,56,63,211 // pmaxud %xmm3,%xmm2 .byte 102,65,15,118,211 // pcmpeqd %xmm11,%xmm2 .byte 102,65,15,114,243,13 // pslld $0xd,%xmm11 .byte 102,69,15,235,220 // por %xmm12,%xmm11 .byte 102,69,15,254,218 // paddd %xmm10,%xmm11 .byte 102,65,15,219,211 // pand %xmm11,%xmm2 .byte 102,65,15,115,217,8 // psrldq $0x8,%xmm9 .byte 102,69,15,56,51,201 // pmovzxwd %xmm9,%xmm9 .byte 102,69,15,219,193 // pand %xmm9,%xmm8 .byte 102,69,15,239,200 // pxor %xmm8,%xmm9 .byte 102,65,15,114,240,16 // pslld $0x10,%xmm8 .byte 102,65,15,56,63,217 // pmaxud %xmm9,%xmm3 .byte 102,65,15,118,217 // pcmpeqd %xmm9,%xmm3 .byte 102,65,15,114,241,13 // pslld $0xd,%xmm9 .byte 102,69,15,235,200 // por %xmm8,%xmm9 .byte 102,69,15,254,202 // paddd %xmm10,%xmm9 .byte 102,65,15,219,217 // pand %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 242,65,15,16,4,193 // movsd (%r9,%rax,8),%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,13 // jne 4379 <_sk_load_f16_sse41+0x177> .byte 243,15,126,192 // movq %xmm0,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 233,182,254,255,255 // jmpq 422f <_sk_load_f16_sse41+0x2d> .byte 102,65,15,22,68,193,8 // movhpd 0x8(%r9,%rax,8),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 15,130,161,254,255,255 // jb 422f <_sk_load_f16_sse41+0x2d> .byte 243,65,15,126,76,193,16 // movq 0x10(%r9,%rax,8),%xmm1 .byte 233,149,254,255,255 // jmpq 422f <_sk_load_f16_sse41+0x2d> HIDDEN _sk_load_f16_dst_sse41 .globl _sk_load_f16_dst_sse41 FUNCTION(_sk_load_f16_dst_sse41) _sk_load_f16_dst_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,62,1,0,0 // jne 44f8 <_sk_load_f16_dst_sse41+0x15e> .byte 102,65,15,16,36,193 // movupd (%r9,%rax,8),%xmm4 .byte 243,65,15,111,108,193,16 // movdqu 0x10(%r9,%rax,8),%xmm5 .byte 102,68,15,40,204 // movapd %xmm4,%xmm9 .byte 102,68,15,97,205 // punpcklwd %xmm5,%xmm9 .byte 102,15,105,229 // punpckhwd %xmm5,%xmm4 .byte 102,69,15,111,217 // movdqa %xmm9,%xmm11 .byte 102,68,15,97,220 // punpcklwd %xmm4,%xmm11 .byte 102,68,15,105,204 // punpckhwd %xmm4,%xmm9 .byte 102,65,15,56,51,235 // pmovzxwd %xmm11,%xmm5 .byte 102,68,15,111,5,205,44,0,0 // movdqa 0x2ccd(%rip),%xmm8 # 70c0 <_sk_callback_sse41+0x1214> .byte 102,15,111,245 // movdqa %xmm5,%xmm6 .byte 102,65,15,219,240 // pand %xmm8,%xmm6 .byte 102,15,239,238 // pxor %xmm6,%xmm5 .byte 102,15,111,61,200,44,0,0 // movdqa 0x2cc8(%rip),%xmm7 # 70d0 <_sk_callback_sse41+0x1224> .byte 102,15,114,246,16 // pslld $0x10,%xmm6 .byte 102,15,111,229 // movdqa %xmm5,%xmm4 .byte 102,15,56,63,231 // pmaxud %xmm7,%xmm4 .byte 102,15,118,229 // pcmpeqd %xmm5,%xmm4 .byte 102,15,114,245,13 // pslld $0xd,%xmm5 .byte 102,15,235,238 // por %xmm6,%xmm5 .byte 102,68,15,111,21,180,44,0,0 // movdqa 0x2cb4(%rip),%xmm10 # 70e0 <_sk_callback_sse41+0x1234> .byte 102,65,15,254,234 // paddd %xmm10,%xmm5 .byte 102,15,219,229 // pand %xmm5,%xmm4 .byte 102,65,15,115,219,8 // psrldq $0x8,%xmm11 .byte 102,69,15,56,51,219 // pmovzxwd %xmm11,%xmm11 .byte 102,65,15,111,243 // movdqa %xmm11,%xmm6 .byte 102,65,15,219,240 // pand %xmm8,%xmm6 .byte 102,68,15,239,222 // pxor %xmm6,%xmm11 .byte 102,15,114,246,16 // pslld $0x10,%xmm6 .byte 102,65,15,111,235 // movdqa %xmm11,%xmm5 .byte 102,15,56,63,239 // pmaxud %xmm7,%xmm5 .byte 102,65,15,118,235 // pcmpeqd %xmm11,%xmm5 .byte 102,65,15,114,243,13 // pslld $0xd,%xmm11 .byte 102,68,15,235,222 // por %xmm6,%xmm11 .byte 102,69,15,254,218 // paddd %xmm10,%xmm11 .byte 102,65,15,219,235 // pand %xmm11,%xmm5 .byte 102,69,15,56,51,217 // pmovzxwd %xmm9,%xmm11 .byte 102,69,15,111,227 // movdqa %xmm11,%xmm12 .byte 102,69,15,219,224 // pand %xmm8,%xmm12 .byte 102,69,15,239,220 // pxor %xmm12,%xmm11 .byte 102,65,15,114,244,16 // pslld $0x10,%xmm12 .byte 102,65,15,111,243 // movdqa %xmm11,%xmm6 .byte 102,15,56,63,247 // pmaxud %xmm7,%xmm6 .byte 102,65,15,118,243 // pcmpeqd %xmm11,%xmm6 .byte 102,65,15,114,243,13 // pslld $0xd,%xmm11 .byte 102,69,15,235,220 // por %xmm12,%xmm11 .byte 102,69,15,254,218 // paddd %xmm10,%xmm11 .byte 102,65,15,219,243 // pand %xmm11,%xmm6 .byte 102,65,15,115,217,8 // psrldq $0x8,%xmm9 .byte 102,69,15,56,51,201 // pmovzxwd %xmm9,%xmm9 .byte 102,69,15,219,193 // pand %xmm9,%xmm8 .byte 102,69,15,239,200 // pxor %xmm8,%xmm9 .byte 102,65,15,114,240,16 // pslld $0x10,%xmm8 .byte 102,65,15,56,63,249 // pmaxud %xmm9,%xmm7 .byte 102,65,15,118,249 // pcmpeqd %xmm9,%xmm7 .byte 102,65,15,114,241,13 // pslld $0xd,%xmm9 .byte 102,69,15,235,200 // por %xmm8,%xmm9 .byte 102,69,15,254,202 // paddd %xmm10,%xmm9 .byte 102,65,15,219,249 // pand %xmm9,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 242,65,15,16,36,193 // movsd (%r9,%rax,8),%xmm4 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,13 // jne 4511 <_sk_load_f16_dst_sse41+0x177> .byte 243,15,126,228 // movq %xmm4,%xmm4 .byte 102,15,239,237 // pxor %xmm5,%xmm5 .byte 233,182,254,255,255 // jmpq 43c7 <_sk_load_f16_dst_sse41+0x2d> .byte 102,65,15,22,100,193,8 // movhpd 0x8(%r9,%rax,8),%xmm4 .byte 102,15,239,237 // pxor %xmm5,%xmm5 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 15,130,161,254,255,255 // jb 43c7 <_sk_load_f16_dst_sse41+0x2d> .byte 243,65,15,126,108,193,16 // movq 0x10(%r9,%rax,8),%xmm5 .byte 233,149,254,255,255 // jmpq 43c7 <_sk_load_f16_dst_sse41+0x2d> HIDDEN _sk_gather_f16_sse41 .globl _sk_gather_f16_sse41 FUNCTION(_sk_gather_f16_sse41) _sk_gather_f16_sse41: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,56,64,209 // pmulld %xmm1,%xmm2 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,194 // paddd %xmm2,%xmm0 .byte 102,72,15,126,192 // movq %xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,58,22,195,1 // pextrq $0x1,%xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,67,15,126,4,217 // movq (%r9,%r11,8),%xmm0 .byte 243,65,15,126,12,217 // movq (%r9,%rbx,8),%xmm1 .byte 102,15,108,200 // punpcklqdq %xmm0,%xmm1 .byte 243,65,15,126,4,193 // movq (%r9,%rax,8),%xmm0 .byte 243,67,15,126,20,209 // movq (%r9,%r10,8),%xmm2 .byte 102,15,108,208 // punpcklqdq %xmm0,%xmm2 .byte 102,68,15,111,202 // movdqa %xmm2,%xmm9 .byte 102,68,15,97,201 // punpcklwd %xmm1,%xmm9 .byte 102,15,105,209 // punpckhwd %xmm1,%xmm2 .byte 102,69,15,111,217 // movdqa %xmm9,%xmm11 .byte 102,68,15,97,218 // punpcklwd %xmm2,%xmm11 .byte 102,68,15,105,202 // punpckhwd %xmm2,%xmm9 .byte 102,65,15,56,51,203 // pmovzxwd %xmm11,%xmm1 .byte 102,68,15,111,5,55,43,0,0 // movdqa 0x2b37(%rip),%xmm8 # 70f0 <_sk_callback_sse41+0x1244> .byte 102,15,111,209 // movdqa %xmm1,%xmm2 .byte 102,65,15,219,208 // pand %xmm8,%xmm2 .byte 102,15,239,202 // pxor %xmm2,%xmm1 .byte 102,15,111,29,50,43,0,0 // movdqa 0x2b32(%rip),%xmm3 # 7100 <_sk_callback_sse41+0x1254> .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,56,63,195 // pmaxud %xmm3,%xmm0 .byte 102,15,118,193 // pcmpeqd %xmm1,%xmm0 .byte 102,15,114,241,13 // pslld $0xd,%xmm1 .byte 102,15,235,202 // por %xmm2,%xmm1 .byte 102,68,15,111,21,30,43,0,0 // movdqa 0x2b1e(%rip),%xmm10 # 7110 <_sk_callback_sse41+0x1264> .byte 102,65,15,254,202 // paddd %xmm10,%xmm1 .byte 102,15,219,193 // pand %xmm1,%xmm0 .byte 102,65,15,115,219,8 // psrldq $0x8,%xmm11 .byte 102,69,15,56,51,219 // pmovzxwd %xmm11,%xmm11 .byte 102,65,15,111,211 // movdqa %xmm11,%xmm2 .byte 102,65,15,219,208 // pand %xmm8,%xmm2 .byte 102,68,15,239,218 // pxor %xmm2,%xmm11 .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,65,15,111,203 // movdqa %xmm11,%xmm1 .byte 102,15,56,63,203 // pmaxud %xmm3,%xmm1 .byte 102,65,15,118,203 // pcmpeqd %xmm11,%xmm1 .byte 102,65,15,114,243,13 // pslld $0xd,%xmm11 .byte 102,68,15,235,218 // por %xmm2,%xmm11 .byte 102,69,15,254,218 // paddd %xmm10,%xmm11 .byte 102,65,15,219,203 // pand %xmm11,%xmm1 .byte 102,69,15,56,51,217 // pmovzxwd %xmm9,%xmm11 .byte 102,69,15,111,227 // movdqa %xmm11,%xmm12 .byte 102,69,15,219,224 // pand %xmm8,%xmm12 .byte 102,69,15,239,220 // pxor %xmm12,%xmm11 .byte 102,65,15,114,244,16 // pslld $0x10,%xmm12 .byte 102,65,15,111,211 // movdqa %xmm11,%xmm2 .byte 102,15,56,63,211 // pmaxud %xmm3,%xmm2 .byte 102,65,15,118,211 // pcmpeqd %xmm11,%xmm2 .byte 102,65,15,114,243,13 // pslld $0xd,%xmm11 .byte 102,69,15,235,220 // por %xmm12,%xmm11 .byte 102,69,15,254,218 // paddd %xmm10,%xmm11 .byte 102,65,15,219,211 // pand %xmm11,%xmm2 .byte 102,65,15,115,217,8 // psrldq $0x8,%xmm9 .byte 102,69,15,56,51,201 // pmovzxwd %xmm9,%xmm9 .byte 102,69,15,219,193 // pand %xmm9,%xmm8 .byte 102,69,15,239,200 // pxor %xmm8,%xmm9 .byte 102,65,15,114,240,16 // pslld $0x10,%xmm8 .byte 102,65,15,56,63,217 // pmaxud %xmm9,%xmm3 .byte 102,65,15,118,217 // pcmpeqd %xmm9,%xmm3 .byte 102,65,15,114,241,13 // pslld $0xd,%xmm9 .byte 102,69,15,235,200 // por %xmm8,%xmm9 .byte 102,69,15,254,202 // paddd %xmm10,%xmm9 .byte 102,65,15,219,217 // pand %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_f16_sse41 .globl _sk_store_f16_sse41 FUNCTION(_sk_store_f16_sse41) _sk_store_f16_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 102,68,15,111,21,65,42,0,0 // movdqa 0x2a41(%rip),%xmm10 # 7120 <_sk_callback_sse41+0x1274> .byte 102,68,15,111,216 // movdqa %xmm0,%xmm11 .byte 102,69,15,219,218 // pand %xmm10,%xmm11 .byte 102,68,15,111,232 // movdqa %xmm0,%xmm13 .byte 102,69,15,239,235 // pxor %xmm11,%xmm13 .byte 102,68,15,111,13,52,42,0,0 // movdqa 0x2a34(%rip),%xmm9 # 7130 <_sk_callback_sse41+0x1284> .byte 102,65,15,114,211,16 // psrld $0x10,%xmm11 .byte 102,69,15,111,193 // movdqa %xmm9,%xmm8 .byte 102,69,15,102,197 // pcmpgtd %xmm13,%xmm8 .byte 102,65,15,114,213,13 // psrld $0xd,%xmm13 .byte 102,68,15,111,37,37,42,0,0 // movdqa 0x2a25(%rip),%xmm12 # 7140 <_sk_callback_sse41+0x1294> .byte 102,69,15,235,220 // por %xmm12,%xmm11 .byte 102,69,15,254,221 // paddd %xmm13,%xmm11 .byte 102,69,15,223,195 // pandn %xmm11,%xmm8 .byte 102,69,15,56,43,192 // packusdw %xmm8,%xmm8 .byte 102,68,15,111,217 // movdqa %xmm1,%xmm11 .byte 102,69,15,219,218 // pand %xmm10,%xmm11 .byte 102,68,15,111,241 // movdqa %xmm1,%xmm14 .byte 102,69,15,239,243 // pxor %xmm11,%xmm14 .byte 102,65,15,114,211,16 // psrld $0x10,%xmm11 .byte 102,69,15,111,233 // movdqa %xmm9,%xmm13 .byte 102,69,15,102,238 // pcmpgtd %xmm14,%xmm13 .byte 102,65,15,114,214,13 // psrld $0xd,%xmm14 .byte 102,69,15,235,220 // por %xmm12,%xmm11 .byte 102,69,15,254,222 // paddd %xmm14,%xmm11 .byte 102,69,15,223,235 // pandn %xmm11,%xmm13 .byte 102,69,15,56,43,237 // packusdw %xmm13,%xmm13 .byte 102,68,15,111,242 // movdqa %xmm2,%xmm14 .byte 102,69,15,219,242 // pand %xmm10,%xmm14 .byte 102,68,15,111,250 // movdqa %xmm2,%xmm15 .byte 102,69,15,239,254 // pxor %xmm14,%xmm15 .byte 102,65,15,114,214,16 // psrld $0x10,%xmm14 .byte 102,69,15,111,217 // movdqa %xmm9,%xmm11 .byte 102,69,15,102,223 // pcmpgtd %xmm15,%xmm11 .byte 102,65,15,114,215,13 // psrld $0xd,%xmm15 .byte 102,69,15,235,244 // por %xmm12,%xmm14 .byte 102,69,15,254,247 // paddd %xmm15,%xmm14 .byte 102,69,15,223,222 // pandn %xmm14,%xmm11 .byte 102,69,15,56,43,219 // packusdw %xmm11,%xmm11 .byte 102,68,15,219,211 // pand %xmm3,%xmm10 .byte 102,68,15,111,243 // movdqa %xmm3,%xmm14 .byte 102,69,15,239,242 // pxor %xmm10,%xmm14 .byte 102,65,15,114,210,16 // psrld $0x10,%xmm10 .byte 102,69,15,102,206 // pcmpgtd %xmm14,%xmm9 .byte 102,65,15,114,214,13 // psrld $0xd,%xmm14 .byte 102,69,15,235,212 // por %xmm12,%xmm10 .byte 102,69,15,254,214 // paddd %xmm14,%xmm10 .byte 102,69,15,223,202 // pandn %xmm10,%xmm9 .byte 102,69,15,56,43,201 // packusdw %xmm9,%xmm9 .byte 102,69,15,97,197 // punpcklwd %xmm13,%xmm8 .byte 102,69,15,97,217 // punpcklwd %xmm9,%xmm11 .byte 102,69,15,111,200 // movdqa %xmm8,%xmm9 .byte 102,69,15,98,203 // punpckldq %xmm11,%xmm9 .byte 77,133,192 // test %r8,%r8 .byte 117,21 // jne 4811 <_sk_store_f16_sse41+0x152> .byte 69,15,17,12,193 // movups %xmm9,(%r9,%rax,8) .byte 102,69,15,106,195 // punpckhdq %xmm11,%xmm8 .byte 243,69,15,127,68,193,16 // movdqu %xmm8,0x10(%r9,%rax,8) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,69,15,214,12,193 // movq %xmm9,(%r9,%rax,8) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,240 // je 480d <_sk_store_f16_sse41+0x14e> .byte 102,69,15,23,76,193,8 // movhpd %xmm9,0x8(%r9,%rax,8) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,227 // jb 480d <_sk_store_f16_sse41+0x14e> .byte 102,69,15,106,195 // punpckhdq %xmm11,%xmm8 .byte 102,69,15,214,68,193,16 // movq %xmm8,0x10(%r9,%rax,8) .byte 235,213 // jmp 480d <_sk_store_f16_sse41+0x14e> HIDDEN _sk_load_u16_be_sse41 .globl _sk_load_u16_be_sse41 FUNCTION(_sk_load_u16_be_sse41) _sk_load_u16_be_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,185,0,0,0 // jne 4918 <_sk_load_u16_be_sse41+0xe0> .byte 102,65,15,16,4,65 // movupd (%r9,%rax,2),%xmm0 .byte 243,65,15,111,76,65,16 // movdqu 0x10(%r9,%rax,2),%xmm1 .byte 102,15,40,208 // movapd %xmm0,%xmm2 .byte 102,15,97,209 // punpcklwd %xmm1,%xmm2 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,15,111,202 // movdqa %xmm2,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,105,208 // punpckhwd %xmm0,%xmm2 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,113,240,8 // psllw $0x8,%xmm0 .byte 102,15,112,217,78 // pshufd $0x4e,%xmm1,%xmm3 .byte 102,15,113,209,8 // psrlw $0x8,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,15,56,51,193 // pmovzxwd %xmm1,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,5,165,40,0,0 // movaps 0x28a5(%rip),%xmm8 # 7150 <_sk_callback_sse41+0x12a4> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,113,241,8 // psllw $0x8,%xmm1 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,235,217 // por %xmm1,%xmm3 .byte 102,15,56,51,203 // pmovzxwd %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,68,15,111,202 // movdqa %xmm2,%xmm9 .byte 102,65,15,113,241,8 // psllw $0x8,%xmm9 .byte 102,15,112,218,78 // pshufd $0x4e,%xmm2,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,65,15,235,209 // por %xmm9,%xmm2 .byte 102,15,56,51,210 // pmovzxwd %xmm2,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,68,15,111,203 // movdqa %xmm3,%xmm9 .byte 102,65,15,113,241,8 // psllw $0x8,%xmm9 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,65,15,235,217 // por %xmm9,%xmm3 .byte 102,15,56,51,219 // pmovzxwd %xmm3,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 242,65,15,16,4,65 // movsd (%r9,%rax,2),%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,13 // jne 4931 <_sk_load_u16_be_sse41+0xf9> .byte 243,15,126,192 // movq %xmm0,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 233,59,255,255,255 // jmpq 486c <_sk_load_u16_be_sse41+0x34> .byte 102,65,15,22,68,65,8 // movhpd 0x8(%r9,%rax,2),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 15,130,38,255,255,255 // jb 486c <_sk_load_u16_be_sse41+0x34> .byte 243,65,15,126,76,65,16 // movq 0x10(%r9,%rax,2),%xmm1 .byte 233,26,255,255,255 // jmpq 486c <_sk_load_u16_be_sse41+0x34> HIDDEN _sk_load_rgb_u16_be_sse41 .globl _sk_load_rgb_u16_be_sse41 FUNCTION(_sk_load_rgb_u16_be_sse41) _sk_load_rgb_u16_be_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,137,208 // mov %rdx,%rax .byte 72,193,224,32 // shl $0x20,%rax .byte 72,141,4,64 // lea (%rax,%rax,2),%rax .byte 72,193,248,32 // sar $0x20,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,170,0,0,0 // jne 4a27 <_sk_load_rgb_u16_be_sse41+0xd5> .byte 243,65,15,111,20,65 // movdqu (%r9,%rax,2),%xmm2 .byte 243,65,15,111,92,65,8 // movdqu 0x8(%r9,%rax,2),%xmm3 .byte 102,15,115,219,4 // psrldq $0x4,%xmm3 .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 102,15,115,216,6 // psrldq $0x6,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,115,217,6 // psrldq $0x6,%xmm1 .byte 102,15,97,211 // punpcklwd %xmm3,%xmm2 .byte 102,15,97,193 // punpcklwd %xmm1,%xmm0 .byte 102,15,111,202 // movdqa %xmm2,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,112,217,78 // pshufd $0x4e,%xmm1,%xmm3 .byte 102,15,105,208 // punpckhwd %xmm0,%xmm2 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,113,240,8 // psllw $0x8,%xmm0 .byte 102,15,113,209,8 // psrlw $0x8,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,15,56,51,193 // pmovzxwd %xmm1,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,5,132,39,0,0 // movaps 0x2784(%rip),%xmm8 # 7160 <_sk_callback_sse41+0x12b4> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,113,241,8 // psllw $0x8,%xmm1 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,235,217 // por %xmm1,%xmm3 .byte 102,15,56,51,203 // pmovzxwd %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,15,111,218 // movdqa %xmm2,%xmm3 .byte 102,15,113,243,8 // psllw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,235,211 // por %xmm3,%xmm2 .byte 102,15,56,51,210 // pmovzxwd %xmm2,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,75,39,0,0 // movaps 0x274b(%rip),%xmm3 # 7170 <_sk_callback_sse41+0x12c4> .byte 255,224 // jmpq *%rax .byte 102,65,15,110,20,65 // movd (%r9,%rax,2),%xmm2 .byte 102,65,15,196,84,65,4,2 // pinsrw $0x2,0x4(%r9,%rax,2),%xmm2 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,13 // jne 4a4c <_sk_load_rgb_u16_be_sse41+0xfa> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 233,85,255,255,255 // jmpq 49a1 <_sk_load_rgb_u16_be_sse41+0x4f> .byte 102,65,15,110,68,65,6 // movd 0x6(%r9,%rax,2),%xmm0 .byte 102,65,15,196,68,65,10,2 // pinsrw $0x2,0xa(%r9,%rax,2),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,24 // jb 4a7d <_sk_load_rgb_u16_be_sse41+0x12b> .byte 102,65,15,110,92,65,12 // movd 0xc(%r9,%rax,2),%xmm3 .byte 102,65,15,196,92,65,16,2 // pinsrw $0x2,0x10(%r9,%rax,2),%xmm3 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 233,36,255,255,255 // jmpq 49a1 <_sk_load_rgb_u16_be_sse41+0x4f> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 233,27,255,255,255 // jmpq 49a1 <_sk_load_rgb_u16_be_sse41+0x4f> HIDDEN _sk_store_u16_be_sse41 .globl _sk_store_u16_be_sse41 FUNCTION(_sk_store_u16_be_sse41) _sk_store_u16_be_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 68,15,40,21,212,38,0,0 // movaps 0x26d4(%rip),%xmm10 # 7180 <_sk_callback_sse41+0x12d4> .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 69,15,89,194 // mulps %xmm10,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,69,15,56,43,192 // packusdw %xmm8,%xmm8 .byte 102,69,15,111,200 // movdqa %xmm8,%xmm9 .byte 102,65,15,113,241,8 // psllw $0x8,%xmm9 .byte 102,65,15,113,208,8 // psrlw $0x8,%xmm8 .byte 102,69,15,235,193 // por %xmm9,%xmm8 .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 69,15,89,202 // mulps %xmm10,%xmm9 .byte 102,69,15,91,217 // cvtps2dq %xmm9,%xmm11 .byte 102,69,15,56,43,219 // packusdw %xmm11,%xmm11 .byte 102,69,15,111,203 // movdqa %xmm11,%xmm9 .byte 102,65,15,113,241,8 // psllw $0x8,%xmm9 .byte 102,65,15,113,211,8 // psrlw $0x8,%xmm11 .byte 102,69,15,235,217 // por %xmm9,%xmm11 .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 69,15,89,202 // mulps %xmm10,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,69,15,56,43,201 // packusdw %xmm9,%xmm9 .byte 102,69,15,111,225 // movdqa %xmm9,%xmm12 .byte 102,65,15,113,244,8 // psllw $0x8,%xmm12 .byte 102,65,15,113,209,8 // psrlw $0x8,%xmm9 .byte 102,69,15,235,204 // por %xmm12,%xmm9 .byte 68,15,89,211 // mulps %xmm3,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,69,15,56,43,210 // packusdw %xmm10,%xmm10 .byte 102,69,15,111,226 // movdqa %xmm10,%xmm12 .byte 102,65,15,113,244,8 // psllw $0x8,%xmm12 .byte 102,65,15,113,210,8 // psrlw $0x8,%xmm10 .byte 102,69,15,235,212 // por %xmm12,%xmm10 .byte 102,69,15,97,195 // punpcklwd %xmm11,%xmm8 .byte 102,69,15,97,202 // punpcklwd %xmm10,%xmm9 .byte 102,69,15,111,208 // movdqa %xmm8,%xmm10 .byte 102,69,15,98,209 // punpckldq %xmm9,%xmm10 .byte 77,133,192 // test %r8,%r8 .byte 117,21 // jne 4b7a <_sk_store_u16_be_sse41+0xf4> .byte 69,15,17,20,65 // movups %xmm10,(%r9,%rax,2) .byte 102,69,15,106,193 // punpckhdq %xmm9,%xmm8 .byte 243,69,15,127,68,65,16 // movdqu %xmm8,0x10(%r9,%rax,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,69,15,214,20,65 // movq %xmm10,(%r9,%rax,2) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,240 // je 4b76 <_sk_store_u16_be_sse41+0xf0> .byte 102,69,15,23,84,65,8 // movhpd %xmm10,0x8(%r9,%rax,2) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,227 // jb 4b76 <_sk_store_u16_be_sse41+0xf0> .byte 102,69,15,106,193 // punpckhdq %xmm9,%xmm8 .byte 102,69,15,214,68,65,16 // movq %xmm8,0x10(%r9,%rax,2) .byte 235,213 // jmp 4b76 <_sk_store_u16_be_sse41+0xf0> HIDDEN _sk_load_f32_sse41 .globl _sk_load_f32_sse41 FUNCTION(_sk_load_f32_sse41) _sk_load_f32_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 69,15,16,4,129 // movups (%r9,%rax,4),%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,66 // jne 4c0c <_sk_load_f32_sse41+0x6b> .byte 65,15,16,68,129,16 // movups 0x10(%r9,%rax,4),%xmm0 .byte 65,15,16,92,129,32 // movups 0x20(%r9,%rax,4),%xmm3 .byte 69,15,16,76,129,48 // movups 0x30(%r9,%rax,4),%xmm9 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 15,20,208 // unpcklps %xmm0,%xmm2 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 65,15,20,201 // unpcklps %xmm9,%xmm1 .byte 68,15,21,192 // unpckhps %xmm0,%xmm8 .byte 65,15,21,217 // unpckhps %xmm9,%xmm3 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 102,15,20,193 // unpcklpd %xmm1,%xmm0 .byte 15,18,202 // movhlps %xmm2,%xmm1 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 102,15,20,211 // unpcklpd %xmm3,%xmm2 .byte 65,15,18,216 // movhlps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,8 // jne 4c1e <_sk_load_f32_sse41+0x7d> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 235,190 // jmp 4bdc <_sk_load_f32_sse41+0x3b> .byte 65,15,16,68,129,16 // movups 0x10(%r9,%rax,4),%xmm0 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,8 // jb 4c32 <_sk_load_f32_sse41+0x91> .byte 65,15,16,92,129,32 // movups 0x20(%r9,%rax,4),%xmm3 .byte 235,170 // jmp 4bdc <_sk_load_f32_sse41+0x3b> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 235,165 // jmp 4bdc <_sk_load_f32_sse41+0x3b> HIDDEN _sk_load_f32_dst_sse41 .globl _sk_load_f32_dst_sse41 FUNCTION(_sk_load_f32_dst_sse41) _sk_load_f32_dst_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 69,15,16,4,129 // movups (%r9,%rax,4),%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,66 // jne 4ca2 <_sk_load_f32_dst_sse41+0x6b> .byte 65,15,16,100,129,16 // movups 0x10(%r9,%rax,4),%xmm4 .byte 65,15,16,124,129,32 // movups 0x20(%r9,%rax,4),%xmm7 .byte 69,15,16,76,129,48 // movups 0x30(%r9,%rax,4),%xmm9 .byte 65,15,40,240 // movaps %xmm8,%xmm6 .byte 15,20,244 // unpcklps %xmm4,%xmm6 .byte 15,40,239 // movaps %xmm7,%xmm5 .byte 65,15,20,233 // unpcklps %xmm9,%xmm5 .byte 68,15,21,196 // unpckhps %xmm4,%xmm8 .byte 65,15,21,249 // unpckhps %xmm9,%xmm7 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 102,15,20,229 // unpcklpd %xmm5,%xmm4 .byte 15,18,238 // movhlps %xmm6,%xmm5 .byte 65,15,40,240 // movaps %xmm8,%xmm6 .byte 102,15,20,247 // unpcklpd %xmm7,%xmm6 .byte 65,15,18,248 // movhlps %xmm8,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,8 // jne 4cb4 <_sk_load_f32_dst_sse41+0x7d> .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 235,190 // jmp 4c72 <_sk_load_f32_dst_sse41+0x3b> .byte 65,15,16,100,129,16 // movups 0x10(%r9,%rax,4),%xmm4 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,8 // jb 4cc8 <_sk_load_f32_dst_sse41+0x91> .byte 65,15,16,124,129,32 // movups 0x20(%r9,%rax,4),%xmm7 .byte 235,170 // jmp 4c72 <_sk_load_f32_dst_sse41+0x3b> .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 235,165 // jmp 4c72 <_sk_load_f32_dst_sse41+0x3b> HIDDEN _sk_store_f32_sse41 .globl _sk_store_f32_sse41 FUNCTION(_sk_store_f32_sse41) _sk_store_f32_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 68,15,20,201 // unpcklps %xmm1,%xmm9 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,20,195 // unpcklps %xmm3,%xmm8 .byte 68,15,40,208 // movaps %xmm0,%xmm10 .byte 68,15,21,209 // unpckhps %xmm1,%xmm10 .byte 68,15,40,218 // movaps %xmm2,%xmm11 .byte 68,15,21,219 // unpckhps %xmm3,%xmm11 .byte 69,15,40,225 // movaps %xmm9,%xmm12 .byte 102,69,15,20,224 // unpcklpd %xmm8,%xmm12 .byte 69,15,18,193 // movhlps %xmm9,%xmm8 .byte 69,15,40,202 // movaps %xmm10,%xmm9 .byte 102,69,15,20,203 // unpcklpd %xmm11,%xmm9 .byte 102,69,15,17,36,129 // movupd %xmm12,(%r9,%rax,4) .byte 77,133,192 // test %r8,%r8 .byte 117,29 // jne 4d4a <_sk_store_f32_sse41+0x7d> .byte 102,69,15,21,211 // unpckhpd %xmm11,%xmm10 .byte 69,15,17,68,129,16 // movups %xmm8,0x10(%r9,%rax,4) .byte 102,69,15,17,76,129,32 // movupd %xmm9,0x20(%r9,%rax,4) .byte 102,69,15,17,84,129,48 // movupd %xmm10,0x30(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,246 // je 4d46 <_sk_store_f32_sse41+0x79> .byte 69,15,17,68,129,16 // movups %xmm8,0x10(%r9,%rax,4) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,234 // jb 4d46 <_sk_store_f32_sse41+0x79> .byte 102,69,15,17,76,129,32 // movupd %xmm9,0x20(%r9,%rax,4) .byte 235,225 // jmp 4d46 <_sk_store_f32_sse41+0x79> HIDDEN _sk_clamp_x_sse41 .globl _sk_clamp_x_sse41 FUNCTION(_sk_clamp_x_sse41) _sk_clamp_x_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,192 // maxps %xmm0,%xmm8 .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 102,15,118,192 // pcmpeqd %xmm0,%xmm0 .byte 102,65,15,254,193 // paddd %xmm9,%xmm0 .byte 68,15,93,192 // minps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_y_sse41 .globl _sk_clamp_y_sse41 FUNCTION(_sk_clamp_y_sse41) _sk_clamp_y_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,193 // maxps %xmm1,%xmm8 .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 102,15,118,201 // pcmpeqd %xmm1,%xmm1 .byte 102,65,15,254,201 // paddd %xmm9,%xmm1 .byte 68,15,93,193 // minps %xmm1,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_x_sse41 .globl _sk_repeat_x_sse41 FUNCTION(_sk_repeat_x_sse41) _sk_repeat_x_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 243,68,15,16,64,4 // movss 0x4(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 102,69,15,58,8,192,1 // roundps $0x1,%xmm8,%xmm8 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 65,15,92,192 // subps %xmm8,%xmm0 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,192 // maxps %xmm0,%xmm8 .byte 102,15,118,192 // pcmpeqd %xmm0,%xmm0 .byte 102,65,15,254,193 // paddd %xmm9,%xmm0 .byte 68,15,93,192 // minps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_y_sse41 .globl _sk_repeat_y_sse41 FUNCTION(_sk_repeat_y_sse41) _sk_repeat_y_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 243,68,15,16,64,4 // movss 0x4(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 68,15,89,193 // mulps %xmm1,%xmm8 .byte 102,69,15,58,8,192,1 // roundps $0x1,%xmm8,%xmm8 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 65,15,92,200 // subps %xmm8,%xmm1 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,193 // maxps %xmm1,%xmm8 .byte 102,15,118,201 // pcmpeqd %xmm1,%xmm1 .byte 102,65,15,254,201 // paddd %xmm9,%xmm1 .byte 68,15,93,193 // minps %xmm1,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_x_sse41 .globl _sk_mirror_x_sse41 FUNCTION(_sk_mirror_x_sse41) _sk_mirror_x_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 243,68,15,16,72,4 // movss 0x4(%rax),%xmm9 .byte 69,15,40,208 // movaps %xmm8,%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 65,15,92,194 // subps %xmm10,%xmm0 .byte 243,69,15,88,192 // addss %xmm8,%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 243,68,15,89,13,126,39,0,0 // mulss 0x277e(%rip),%xmm9 # 75f0 <_sk_callback_sse41+0x1744> .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,89,200 // mulps %xmm0,%xmm9 .byte 102,69,15,58,8,201,1 // roundps $0x1,%xmm9,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 65,15,92,194 // subps %xmm10,%xmm0 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 68,15,92,200 // subps %xmm0,%xmm9 .byte 68,15,84,200 // andps %xmm0,%xmm9 .byte 69,15,95,193 // maxps %xmm9,%xmm8 .byte 102,15,118,192 // pcmpeqd %xmm0,%xmm0 .byte 102,65,15,254,194 // paddd %xmm10,%xmm0 .byte 68,15,93,192 // minps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_y_sse41 .globl _sk_mirror_y_sse41 FUNCTION(_sk_mirror_y_sse41) _sk_mirror_y_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 243,68,15,16,72,4 // movss 0x4(%rax),%xmm9 .byte 69,15,40,208 // movaps %xmm8,%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 65,15,92,202 // subps %xmm10,%xmm1 .byte 243,69,15,88,192 // addss %xmm8,%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 243,68,15,89,13,16,39,0,0 // mulss 0x2710(%rip),%xmm9 # 75f4 <_sk_callback_sse41+0x1748> .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,89,201 // mulps %xmm1,%xmm9 .byte 102,69,15,58,8,201,1 // roundps $0x1,%xmm9,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 65,15,92,201 // subps %xmm9,%xmm1 .byte 65,15,92,202 // subps %xmm10,%xmm1 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 68,15,92,201 // subps %xmm1,%xmm9 .byte 68,15,84,201 // andps %xmm1,%xmm9 .byte 69,15,95,193 // maxps %xmm9,%xmm8 .byte 102,15,118,201 // pcmpeqd %xmm1,%xmm1 .byte 102,65,15,254,202 // paddd %xmm10,%xmm1 .byte 68,15,93,193 // minps %xmm1,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_x_1_sse41 .globl _sk_clamp_x_1_sse41 FUNCTION(_sk_clamp_x_1_sse41) _sk_clamp_x_1_sse41: .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,192 // maxps %xmm0,%xmm8 .byte 68,15,93,5,87,34,0,0 // minps 0x2257(%rip),%xmm8 # 7190 <_sk_callback_sse41+0x12e4> .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_x_1_sse41 .globl _sk_repeat_x_1_sse41 FUNCTION(_sk_repeat_x_1_sse41) _sk_repeat_x_1_sse41: .byte 102,68,15,58,8,192,1 // roundps $0x1,%xmm0,%xmm8 .byte 65,15,92,192 // subps %xmm8,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_x_1_sse41 .globl _sk_mirror_x_1_sse41 FUNCTION(_sk_mirror_x_1_sse41) _sk_mirror_x_1_sse41: .byte 68,15,40,5,72,34,0,0 // movaps 0x2248(%rip),%xmm8 # 71a0 <_sk_callback_sse41+0x12f4> .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 68,15,40,13,76,34,0,0 // movaps 0x224c(%rip),%xmm9 # 71b0 <_sk_callback_sse41+0x1304> .byte 68,15,89,200 // mulps %xmm0,%xmm9 .byte 102,69,15,58,8,201,1 // roundps $0x1,%xmm9,%xmm9 .byte 69,15,88,201 // addps %xmm9,%xmm9 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,92,192 // subps %xmm0,%xmm8 .byte 65,15,84,192 // andps %xmm8,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_luminance_to_alpha_sse41 .globl _sk_luminance_to_alpha_sse41 FUNCTION(_sk_luminance_to_alpha_sse41) _sk_luminance_to_alpha_sse41: .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,89,5,43,34,0,0 // mulps 0x222b(%rip),%xmm0 # 71c0 <_sk_callback_sse41+0x1314> .byte 15,89,13,52,34,0,0 // mulps 0x2234(%rip),%xmm1 # 71d0 <_sk_callback_sse41+0x1324> .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,89,29,58,34,0,0 // mulps 0x223a(%rip),%xmm3 # 71e0 <_sk_callback_sse41+0x1334> .byte 15,88,217 // addps %xmm1,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_translate_sse41 .globl _sk_matrix_translate_sse41 FUNCTION(_sk_matrix_translate_sse41) _sk_matrix_translate_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 243,68,15,16,72,4 // movss 0x4(%rax),%xmm9 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_scale_translate_sse41 .globl _sk_matrix_scale_translate_sse41 FUNCTION(_sk_matrix_scale_translate_sse41) _sk_matrix_scale_translate_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,64,8 // movss 0x8(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 243,68,15,16,80,4 // movss 0x4(%rax),%xmm10 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,193 // addps %xmm9,%xmm0 .byte 243,68,15,16,64,12 // movss 0xc(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_2x3_sse41 .globl _sk_matrix_2x3_sse41 FUNCTION(_sk_matrix_2x3_sse41) _sk_matrix_2x3_sse41: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,68,15,16,80,8 // movss 0x8(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,16 // movss 0x10(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,68,15,16,80,12 // movss 0xc(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,20 // movss 0x14(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_3x4_sse41 .globl _sk_matrix_3x4_sse41 FUNCTION(_sk_matrix_3x4_sse41) _sk_matrix_3x4_sse41: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,68,15,16,80,12 // movss 0xc(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,24 // movss 0x18(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,36 // movss 0x24(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,68,15,16,80,16 // movss 0x10(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,28 // movss 0x1c(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,40 // movss 0x28(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 243,68,15,16,80,8 // movss 0x8(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,20 // movss 0x14(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,32 // movss 0x20(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,44 // movss 0x2c(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 68,15,89,226 // mulps %xmm2,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 69,15,89,217 // mulps %xmm9,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_4x5_sse41 .globl _sk_matrix_4x5_sse41 FUNCTION(_sk_matrix_4x5_sse41) _sk_matrix_4x5_sse41: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,68,15,16,80,16 // movss 0x10(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,32 // movss 0x20(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,48 // movss 0x30(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,64 // movss 0x40(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 68,15,89,227 // mulps %xmm3,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,68,15,16,80,20 // movss 0x14(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,36 // movss 0x24(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,52 // movss 0x34(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,68 // movss 0x44(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 68,15,89,227 // mulps %xmm3,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 243,68,15,16,80,8 // movss 0x8(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,24 // movss 0x18(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,40 // movss 0x28(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,56 // movss 0x38(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 243,68,15,16,112,72 // movss 0x48(%rax),%xmm14 .byte 69,15,198,246,0 // shufps $0x0,%xmm14,%xmm14 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,238 // addps %xmm14,%xmm13 .byte 68,15,89,226 // mulps %xmm2,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 69,15,89,217 // mulps %xmm9,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 243,68,15,16,88,12 // movss 0xc(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,28 // movss 0x1c(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,44 // movss 0x2c(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 243,68,15,16,112,60 // movss 0x3c(%rax),%xmm14 .byte 69,15,198,246,0 // shufps $0x0,%xmm14,%xmm14 .byte 243,68,15,16,120,76 // movss 0x4c(%rax),%xmm15 .byte 69,15,198,255,0 // shufps $0x0,%xmm15,%xmm15 .byte 68,15,89,243 // mulps %xmm3,%xmm14 .byte 69,15,88,247 // addps %xmm15,%xmm14 .byte 68,15,89,234 // mulps %xmm2,%xmm13 .byte 69,15,88,238 // addps %xmm14,%xmm13 .byte 69,15,89,225 // mulps %xmm9,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 69,15,89,216 // mulps %xmm8,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 65,15,40,219 // movaps %xmm11,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_4x3_sse41 .globl _sk_matrix_4x3_sse41 FUNCTION(_sk_matrix_4x3_sse41) _sk_matrix_4x3_sse41: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,15,16,80,16 // movss 0x10(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,32 // movss 0x20(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,80,20 // movss 0x14(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,36 // movss 0x24(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 243,15,16,80,8 // movss 0x8(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,24 // movss 0x18(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 243,68,15,16,80,40 // movss 0x28(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 65,15,89,217 // mulps %xmm9,%xmm3 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 243,15,16,88,12 // movss 0xc(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 243,68,15,16,80,28 // movss 0x1c(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,44 // movss 0x2c(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_perspective_sse41 .globl _sk_matrix_perspective_sse41 FUNCTION(_sk_matrix_perspective_sse41) _sk_matrix_perspective_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,68,15,16,72,4 // movss 0x4(%rax),%xmm9 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 243,68,15,16,80,8 // movss 0x8(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 68,15,89,201 // mulps %xmm1,%xmm9 .byte 69,15,88,202 // addps %xmm10,%xmm9 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,193 // addps %xmm9,%xmm0 .byte 243,68,15,16,72,12 // movss 0xc(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 243,68,15,16,80,16 // movss 0x10(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,20 // movss 0x14(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 69,15,88,202 // addps %xmm10,%xmm9 .byte 243,68,15,16,80,24 // movss 0x18(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,28 // movss 0x1c(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,32 // movss 0x20(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 68,15,89,217 // mulps %xmm1,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,83,202 // rcpps %xmm10,%xmm1 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 68,15,89,201 // mulps %xmm1,%xmm9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_evenly_spaced_gradient_sse41 .globl _sk_evenly_spaced_gradient_sse41 FUNCTION(_sk_evenly_spaced_gradient_sse41) _sk_evenly_spaced_gradient_sse41: .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,139,24 // mov (%rax),%rbx .byte 76,139,112,8 // mov 0x8(%rax),%r14 .byte 72,255,203 // dec %rbx .byte 120,7 // js 5448 <_sk_evenly_spaced_gradient_sse41+0x1a> .byte 243,72,15,42,203 // cvtsi2ss %rbx,%xmm1 .byte 235,21 // jmp 545d <_sk_evenly_spaced_gradient_sse41+0x2f> .byte 73,137,217 // mov %rbx,%r9 .byte 73,209,233 // shr %r9 .byte 131,227,1 // and $0x1,%ebx .byte 76,9,203 // or %r9,%rbx .byte 243,72,15,42,203 // cvtsi2ss %rbx,%xmm1 .byte 243,15,88,201 // addss %xmm1,%xmm1 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,73,15,58,22,201,1 // pextrq $0x1,%xmm1,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 73,193,233,32 // shr $0x20,%r9 .byte 102,73,15,126,203 // movq %xmm1,%r11 .byte 69,137,223 // mov %r11d,%r15d .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,71,15,16,4,190 // movss (%r14,%r15,4),%xmm8 .byte 102,71,15,58,33,4,158,16 // insertps $0x10,(%r14,%r11,4),%xmm8 .byte 243,67,15,16,12,150 // movss (%r14,%r10,4),%xmm1 .byte 102,68,15,58,33,193,32 // insertps $0x20,%xmm1,%xmm8 .byte 243,67,15,16,12,142 // movss (%r14,%r9,4),%xmm1 .byte 102,68,15,58,33,193,48 // insertps $0x30,%xmm1,%xmm8 .byte 72,139,88,40 // mov 0x28(%rax),%rbx .byte 243,70,15,16,12,187 // movss (%rbx,%r15,4),%xmm9 .byte 102,70,15,58,33,12,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm9 .byte 243,66,15,16,12,147 // movss (%rbx,%r10,4),%xmm1 .byte 102,68,15,58,33,201,32 // insertps $0x20,%xmm1,%xmm9 .byte 243,66,15,16,12,139 // movss (%rbx,%r9,4),%xmm1 .byte 102,68,15,58,33,201,48 // insertps $0x30,%xmm1,%xmm9 .byte 72,139,88,16 // mov 0x10(%rax),%rbx .byte 243,66,15,16,12,187 // movss (%rbx,%r15,4),%xmm1 .byte 102,66,15,58,33,12,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm1 .byte 243,66,15,16,20,147 // movss (%rbx,%r10,4),%xmm2 .byte 102,15,58,33,202,32 // insertps $0x20,%xmm2,%xmm1 .byte 243,66,15,16,20,139 // movss (%rbx,%r9,4),%xmm2 .byte 102,15,58,33,202,48 // insertps $0x30,%xmm2,%xmm1 .byte 72,139,88,48 // mov 0x30(%rax),%rbx .byte 243,70,15,16,20,187 // movss (%rbx,%r15,4),%xmm10 .byte 102,70,15,58,33,20,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm10 .byte 243,66,15,16,20,147 // movss (%rbx,%r10,4),%xmm2 .byte 102,68,15,58,33,210,32 // insertps $0x20,%xmm2,%xmm10 .byte 243,66,15,16,20,139 // movss (%rbx,%r9,4),%xmm2 .byte 102,68,15,58,33,210,48 // insertps $0x30,%xmm2,%xmm10 .byte 72,139,88,24 // mov 0x18(%rax),%rbx .byte 243,66,15,16,20,187 // movss (%rbx,%r15,4),%xmm2 .byte 102,66,15,58,33,20,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm2 .byte 243,66,15,16,28,147 // movss (%rbx,%r10,4),%xmm3 .byte 102,15,58,33,211,32 // insertps $0x20,%xmm3,%xmm2 .byte 243,66,15,16,28,139 // movss (%rbx,%r9,4),%xmm3 .byte 102,15,58,33,211,48 // insertps $0x30,%xmm3,%xmm2 .byte 72,139,88,56 // mov 0x38(%rax),%rbx .byte 243,70,15,16,28,187 // movss (%rbx,%r15,4),%xmm11 .byte 102,70,15,58,33,28,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm11 .byte 243,66,15,16,28,147 // movss (%rbx,%r10,4),%xmm3 .byte 102,68,15,58,33,219,32 // insertps $0x20,%xmm3,%xmm11 .byte 243,66,15,16,28,139 // movss (%rbx,%r9,4),%xmm3 .byte 102,68,15,58,33,219,48 // insertps $0x30,%xmm3,%xmm11 .byte 72,139,88,32 // mov 0x20(%rax),%rbx .byte 243,66,15,16,28,187 // movss (%rbx,%r15,4),%xmm3 .byte 102,66,15,58,33,28,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm3 .byte 243,70,15,16,36,147 // movss (%rbx,%r10,4),%xmm12 .byte 102,65,15,58,33,220,32 // insertps $0x20,%xmm12,%xmm3 .byte 243,70,15,16,36,139 // movss (%rbx,%r9,4),%xmm12 .byte 102,65,15,58,33,220,48 // insertps $0x30,%xmm12,%xmm3 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 243,70,15,16,36,184 // movss (%rax,%r15,4),%xmm12 .byte 102,70,15,58,33,36,152,16 // insertps $0x10,(%rax,%r11,4),%xmm12 .byte 243,70,15,16,44,144 // movss (%rax,%r10,4),%xmm13 .byte 102,69,15,58,33,229,32 // insertps $0x20,%xmm13,%xmm12 .byte 243,70,15,16,44,136 // movss (%rax,%r9,4),%xmm13 .byte 102,69,15,58,33,229,48 // insertps $0x30,%xmm13,%xmm12 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 65,15,88,211 // addps %xmm11,%xmm2 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 65,15,88,220 // addps %xmm12,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax HIDDEN _sk_gauss_a_to_rgba_sse41 .globl _sk_gauss_a_to_rgba_sse41 FUNCTION(_sk_gauss_a_to_rgba_sse41) _sk_gauss_a_to_rgba_sse41: .byte 15,40,5,229,27,0,0 // movaps 0x1be5(%rip),%xmm0 # 71f0 <_sk_callback_sse41+0x1344> .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,5,235,27,0,0 // addps 0x1beb(%rip),%xmm0 # 7200 <_sk_callback_sse41+0x1354> .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,5,241,27,0,0 // addps 0x1bf1(%rip),%xmm0 # 7210 <_sk_callback_sse41+0x1364> .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,5,247,27,0,0 // addps 0x1bf7(%rip),%xmm0 # 7220 <_sk_callback_sse41+0x1374> .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,5,253,27,0,0 // addps 0x1bfd(%rip),%xmm0 # 7230 <_sk_callback_sse41+0x1384> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_gradient_sse41 .globl _sk_gradient_sse41 FUNCTION(_sk_gradient_sse41) _sk_gradient_sse41: .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 73,131,249,2 // cmp $0x2,%r9 .byte 114,50 // jb 5686 <_sk_gradient_sse41+0x46> .byte 72,139,88,72 // mov 0x48(%rax),%rbx .byte 73,255,201 // dec %r9 .byte 72,131,195,4 // add $0x4,%rbx .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 15,40,21,214,27,0,0 // movaps 0x1bd6(%rip),%xmm2 # 7240 <_sk_callback_sse41+0x1394> .byte 243,15,16,27 // movss (%rbx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 15,194,216,2 // cmpleps %xmm0,%xmm3 .byte 15,84,218 // andps %xmm2,%xmm3 .byte 102,15,254,203 // paddd %xmm3,%xmm1 .byte 72,131,195,4 // add $0x4,%rbx .byte 73,255,201 // dec %r9 .byte 117,228 // jne 566a <_sk_gradient_sse41+0x2a> .byte 102,73,15,58,22,201,1 // pextrq $0x1,%xmm1,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 73,193,233,32 // shr $0x20,%r9 .byte 102,73,15,126,203 // movq %xmm1,%r11 .byte 69,137,222 // mov %r11d,%r14d .byte 73,193,235,32 // shr $0x20,%r11 .byte 72,139,88,8 // mov 0x8(%rax),%rbx .byte 76,139,120,16 // mov 0x10(%rax),%r15 .byte 243,70,15,16,4,179 // movss (%rbx,%r14,4),%xmm8 .byte 102,70,15,58,33,4,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm8 .byte 243,66,15,16,12,147 // movss (%rbx,%r10,4),%xmm1 .byte 102,68,15,58,33,193,32 // insertps $0x20,%xmm1,%xmm8 .byte 243,66,15,16,12,139 // movss (%rbx,%r9,4),%xmm1 .byte 102,68,15,58,33,193,48 // insertps $0x30,%xmm1,%xmm8 .byte 72,139,88,40 // mov 0x28(%rax),%rbx .byte 243,70,15,16,12,179 // movss (%rbx,%r14,4),%xmm9 .byte 102,70,15,58,33,12,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm9 .byte 243,66,15,16,12,147 // movss (%rbx,%r10,4),%xmm1 .byte 102,68,15,58,33,201,32 // insertps $0x20,%xmm1,%xmm9 .byte 243,66,15,16,12,139 // movss (%rbx,%r9,4),%xmm1 .byte 102,68,15,58,33,201,48 // insertps $0x30,%xmm1,%xmm9 .byte 243,67,15,16,12,183 // movss (%r15,%r14,4),%xmm1 .byte 102,67,15,58,33,12,159,16 // insertps $0x10,(%r15,%r11,4),%xmm1 .byte 243,67,15,16,20,151 // movss (%r15,%r10,4),%xmm2 .byte 102,15,58,33,202,32 // insertps $0x20,%xmm2,%xmm1 .byte 243,67,15,16,20,143 // movss (%r15,%r9,4),%xmm2 .byte 102,15,58,33,202,48 // insertps $0x30,%xmm2,%xmm1 .byte 72,139,88,48 // mov 0x30(%rax),%rbx .byte 243,70,15,16,20,179 // movss (%rbx,%r14,4),%xmm10 .byte 102,70,15,58,33,20,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm10 .byte 243,66,15,16,20,147 // movss (%rbx,%r10,4),%xmm2 .byte 102,68,15,58,33,210,32 // insertps $0x20,%xmm2,%xmm10 .byte 243,66,15,16,20,139 // movss (%rbx,%r9,4),%xmm2 .byte 102,68,15,58,33,210,48 // insertps $0x30,%xmm2,%xmm10 .byte 72,139,88,24 // mov 0x18(%rax),%rbx .byte 243,66,15,16,20,179 // movss (%rbx,%r14,4),%xmm2 .byte 102,66,15,58,33,20,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm2 .byte 243,66,15,16,28,147 // movss (%rbx,%r10,4),%xmm3 .byte 102,15,58,33,211,32 // insertps $0x20,%xmm3,%xmm2 .byte 243,66,15,16,28,139 // movss (%rbx,%r9,4),%xmm3 .byte 102,15,58,33,211,48 // insertps $0x30,%xmm3,%xmm2 .byte 72,139,88,56 // mov 0x38(%rax),%rbx .byte 243,70,15,16,28,179 // movss (%rbx,%r14,4),%xmm11 .byte 102,70,15,58,33,28,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm11 .byte 243,66,15,16,28,147 // movss (%rbx,%r10,4),%xmm3 .byte 102,68,15,58,33,219,32 // insertps $0x20,%xmm3,%xmm11 .byte 243,66,15,16,28,139 // movss (%rbx,%r9,4),%xmm3 .byte 102,68,15,58,33,219,48 // insertps $0x30,%xmm3,%xmm11 .byte 72,139,88,32 // mov 0x20(%rax),%rbx .byte 243,66,15,16,28,179 // movss (%rbx,%r14,4),%xmm3 .byte 102,66,15,58,33,28,155,16 // insertps $0x10,(%rbx,%r11,4),%xmm3 .byte 243,70,15,16,36,147 // movss (%rbx,%r10,4),%xmm12 .byte 102,65,15,58,33,220,32 // insertps $0x20,%xmm12,%xmm3 .byte 243,70,15,16,36,139 // movss (%rbx,%r9,4),%xmm12 .byte 102,65,15,58,33,220,48 // insertps $0x30,%xmm12,%xmm3 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 243,70,15,16,36,176 // movss (%rax,%r14,4),%xmm12 .byte 102,70,15,58,33,36,152,16 // insertps $0x10,(%rax,%r11,4),%xmm12 .byte 243,70,15,16,44,144 // movss (%rax,%r10,4),%xmm13 .byte 102,69,15,58,33,229,32 // insertps $0x20,%xmm13,%xmm12 .byte 243,70,15,16,44,136 // movss (%rax,%r9,4),%xmm13 .byte 102,69,15,58,33,229,48 // insertps $0x30,%xmm13,%xmm12 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 65,15,88,211 // addps %xmm11,%xmm2 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 65,15,88,220 // addps %xmm12,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax HIDDEN _sk_evenly_spaced_2_stop_gradient_sse41 .globl _sk_evenly_spaced_2_stop_gradient_sse41 FUNCTION(_sk_evenly_spaced_2_stop_gradient_sse41) _sk_evenly_spaced_2_stop_gradient_sse41: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,15,16,80,16 // movss 0x10(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,80,20 // movss 0x14(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 243,15,16,80,8 // movss 0x8(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,24 // movss 0x18(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 243,15,16,88,12 // movss 0xc(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 243,68,15,16,72,28 // movss 0x1c(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 65,15,88,217 // addps %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_unit_angle_sse41 .globl _sk_xy_to_unit_angle_sse41 FUNCTION(_sk_xy_to_unit_angle_sse41) _sk_xy_to_unit_angle_sse41: .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 65,15,84,193 // andps %xmm9,%xmm0 .byte 69,15,87,219 // xorps %xmm11,%xmm11 .byte 68,15,92,217 // subps %xmm1,%xmm11 .byte 68,15,84,217 // andps %xmm1,%xmm11 .byte 68,15,40,224 // movaps %xmm0,%xmm12 .byte 69,15,93,227 // minps %xmm11,%xmm12 .byte 68,15,40,208 // movaps %xmm0,%xmm10 .byte 69,15,95,211 // maxps %xmm11,%xmm10 .byte 69,15,94,226 // divps %xmm10,%xmm12 .byte 69,15,40,236 // movaps %xmm12,%xmm13 .byte 69,15,89,237 // mulps %xmm13,%xmm13 .byte 68,15,40,21,119,25,0,0 // movaps 0x1977(%rip),%xmm10 # 7250 <_sk_callback_sse41+0x13a4> .byte 69,15,89,213 // mulps %xmm13,%xmm10 .byte 68,15,88,21,123,25,0,0 // addps 0x197b(%rip),%xmm10 # 7260 <_sk_callback_sse41+0x13b4> .byte 69,15,89,213 // mulps %xmm13,%xmm10 .byte 68,15,88,21,127,25,0,0 // addps 0x197f(%rip),%xmm10 # 7270 <_sk_callback_sse41+0x13c4> .byte 69,15,89,213 // mulps %xmm13,%xmm10 .byte 68,15,88,21,131,25,0,0 // addps 0x1983(%rip),%xmm10 # 7280 <_sk_callback_sse41+0x13d4> .byte 69,15,89,212 // mulps %xmm12,%xmm10 .byte 65,15,194,195,1 // cmpltps %xmm11,%xmm0 .byte 68,15,40,29,130,25,0,0 // movaps 0x1982(%rip),%xmm11 # 7290 <_sk_callback_sse41+0x13e4> .byte 69,15,92,218 // subps %xmm10,%xmm11 .byte 102,69,15,56,20,211 // blendvps %xmm0,%xmm11,%xmm10 .byte 69,15,194,200,1 // cmpltps %xmm8,%xmm9 .byte 68,15,40,29,123,25,0,0 // movaps 0x197b(%rip),%xmm11 # 72a0 <_sk_callback_sse41+0x13f4> .byte 69,15,92,218 // subps %xmm10,%xmm11 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 102,69,15,56,20,211 // blendvps %xmm0,%xmm11,%xmm10 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 65,15,194,192,1 // cmpltps %xmm8,%xmm0 .byte 68,15,40,13,109,25,0,0 // movaps 0x196d(%rip),%xmm9 # 72b0 <_sk_callback_sse41+0x1404> .byte 69,15,92,202 // subps %xmm10,%xmm9 .byte 102,69,15,56,20,209 // blendvps %xmm0,%xmm9,%xmm10 .byte 69,15,194,194,7 // cmpordps %xmm10,%xmm8 .byte 69,15,84,194 // andps %xmm10,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_radius_sse41 .globl _sk_xy_to_radius_sse41 FUNCTION(_sk_xy_to_radius_sse41) _sk_xy_to_radius_sse41: .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 69,15,89,192 // mulps %xmm8,%xmm8 .byte 68,15,88,192 // addps %xmm0,%xmm8 .byte 65,15,81,192 // sqrtps %xmm8,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_quadratic_max_sse41 .globl _sk_xy_to_2pt_conical_quadratic_max_sse41 FUNCTION(_sk_xy_to_2pt_conical_quadratic_max_sse41) _sk_xy_to_2pt_conical_quadratic_max_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,80,32 // movss 0x20(%rax),%xmm10 .byte 243,68,15,16,64,36 // movss 0x24(%rax),%xmm8 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,40 // movss 0x28(%rax),%xmm11 .byte 243,68,15,16,72,44 // movss 0x2c(%rax),%xmm9 .byte 243,69,15,89,203 // mulss %xmm11,%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 68,15,89,13,22,25,0,0 // mulps 0x1916(%rip),%xmm9 # 72c0 <_sk_callback_sse41+0x1414> .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,225 // movaps %xmm1,%xmm12 .byte 69,15,89,228 // mulps %xmm12,%xmm12 .byte 68,15,88,224 // addps %xmm0,%xmm12 .byte 243,69,15,89,219 // mulss %xmm11,%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,92,227 // subps %xmm11,%xmm12 .byte 68,15,89,21,1,25,0,0 // mulps 0x1901(%rip),%xmm10 # 72d0 <_sk_callback_sse41+0x1424> .byte 69,15,89,212 // mulps %xmm12,%xmm10 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 68,15,81,208 // sqrtps %xmm0,%xmm10 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 68,15,87,13,233,24,0,0 // xorps 0x18e9(%rip),%xmm9 # 72e0 <_sk_callback_sse41+0x1434> .byte 68,15,89,5,241,24,0,0 // mulps 0x18f1(%rip),%xmm8 # 72f0 <_sk_callback_sse41+0x1444> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 69,15,92,202 // subps %xmm10,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 65,15,95,193 // maxps %xmm9,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_quadratic_min_sse41 .globl _sk_xy_to_2pt_conical_quadratic_min_sse41 FUNCTION(_sk_xy_to_2pt_conical_quadratic_min_sse41) _sk_xy_to_2pt_conical_quadratic_min_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,80,32 // movss 0x20(%rax),%xmm10 .byte 243,68,15,16,64,36 // movss 0x24(%rax),%xmm8 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,40 // movss 0x28(%rax),%xmm11 .byte 243,68,15,16,72,44 // movss 0x2c(%rax),%xmm9 .byte 243,69,15,89,203 // mulss %xmm11,%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 68,15,89,13,184,24,0,0 // mulps 0x18b8(%rip),%xmm9 # 7300 <_sk_callback_sse41+0x1454> .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,225 // movaps %xmm1,%xmm12 .byte 69,15,89,228 // mulps %xmm12,%xmm12 .byte 68,15,88,224 // addps %xmm0,%xmm12 .byte 243,69,15,89,219 // mulss %xmm11,%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,92,227 // subps %xmm11,%xmm12 .byte 68,15,89,21,163,24,0,0 // mulps 0x18a3(%rip),%xmm10 # 7310 <_sk_callback_sse41+0x1464> .byte 69,15,89,212 // mulps %xmm12,%xmm10 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 68,15,81,208 // sqrtps %xmm0,%xmm10 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 68,15,87,13,139,24,0,0 // xorps 0x188b(%rip),%xmm9 # 7320 <_sk_callback_sse41+0x1474> .byte 68,15,89,5,147,24,0,0 // mulps 0x1893(%rip),%xmm8 # 7330 <_sk_callback_sse41+0x1484> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 69,15,92,202 // subps %xmm10,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 65,15,93,193 // minps %xmm9,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_linear_sse41 .globl _sk_xy_to_2pt_conical_linear_sse41 FUNCTION(_sk_xy_to_2pt_conical_linear_sse41) _sk_xy_to_2pt_conical_linear_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,64,40 // movss 0x28(%rax),%xmm8 .byte 243,68,15,16,72,44 // movss 0x2c(%rax),%xmm9 .byte 243,69,15,89,200 // mulss %xmm8,%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 68,15,89,13,107,24,0,0 // mulps 0x186b(%rip),%xmm9 # 7340 <_sk_callback_sse41+0x1494> .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 69,15,89,210 // mulps %xmm10,%xmm10 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 243,69,15,89,192 // mulss %xmm8,%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,92,192 // subps %xmm8,%xmm0 .byte 15,87,5,87,24,0,0 // xorps 0x1857(%rip),%xmm0 # 7350 <_sk_callback_sse41+0x14a4> .byte 65,15,94,193 // divps %xmm9,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mask_2pt_conical_degenerates_sse41 .globl _sk_mask_2pt_conical_degenerates_sse41 FUNCTION(_sk_mask_2pt_conical_degenerates_sse41) _sk_mask_2pt_conical_degenerates_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,64,40 // movss 0x28(%rax),%xmm8 .byte 243,68,15,16,72,44 // movss 0x2c(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 68,15,89,200 // mulps %xmm0,%xmm9 .byte 69,15,88,200 // addps %xmm8,%xmm9 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,40,208 // movaps %xmm0,%xmm10 .byte 69,15,194,208,7 // cmpordps %xmm8,%xmm10 .byte 69,15,194,193,2 // cmpleps %xmm9,%xmm8 .byte 69,15,84,194 // andps %xmm10,%xmm8 .byte 68,15,17,0 // movups %xmm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_apply_vector_mask_sse41 .globl _sk_apply_vector_mask_sse41 FUNCTION(_sk_apply_vector_mask_sse41) _sk_apply_vector_mask_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,16,0 // movups (%rax),%xmm8 .byte 65,15,84,192 // andps %xmm8,%xmm0 .byte 65,15,84,200 // andps %xmm8,%xmm1 .byte 65,15,84,208 // andps %xmm8,%xmm2 .byte 65,15,84,216 // andps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_save_xy_sse41 .globl _sk_save_xy_sse41 FUNCTION(_sk_save_xy_sse41) _sk_save_xy_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,40,5,253,23,0,0 // movaps 0x17fd(%rip),%xmm8 # 7360 <_sk_callback_sse41+0x14b4> .byte 15,17,0 // movups %xmm0,(%rax) .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,88,200 // addps %xmm8,%xmm9 .byte 102,69,15,58,8,209,1 // roundps $0x1,%xmm9,%xmm10 .byte 69,15,92,202 // subps %xmm10,%xmm9 .byte 68,15,88,193 // addps %xmm1,%xmm8 .byte 102,69,15,58,8,208,1 // roundps $0x1,%xmm8,%xmm10 .byte 69,15,92,194 // subps %xmm10,%xmm8 .byte 15,17,72,32 // movups %xmm1,0x20(%rax) .byte 68,15,17,72,64 // movups %xmm9,0x40(%rax) .byte 68,15,17,64,96 // movups %xmm8,0x60(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_accumulate_sse41 .globl _sk_accumulate_sse41 FUNCTION(_sk_accumulate_sse41) _sk_accumulate_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,16,128,128,0,0,0 // movups 0x80(%rax),%xmm8 .byte 68,15,16,136,160,0,0,0 // movups 0xa0(%rax),%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 65,15,88,224 // addps %xmm8,%xmm4 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 68,15,89,193 // mulps %xmm1,%xmm8 .byte 65,15,88,232 // addps %xmm8,%xmm5 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 65,15,88,240 // addps %xmm8,%xmm6 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 65,15,88,249 // addps %xmm9,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_nx_sse41 .globl _sk_bilinear_nx_sse41 FUNCTION(_sk_bilinear_nx_sse41) _sk_bilinear_nx_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,127,23,0,0 // addps 0x177f(%rip),%xmm0 # 7370 <_sk_callback_sse41+0x14c4> .byte 68,15,40,13,135,23,0,0 // movaps 0x1787(%rip),%xmm9 # 7380 <_sk_callback_sse41+0x14d4> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,17,136,128,0,0,0 // movups %xmm9,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_px_sse41 .globl _sk_bilinear_px_sse41 FUNCTION(_sk_bilinear_px_sse41) _sk_bilinear_px_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,118,23,0,0 // addps 0x1776(%rip),%xmm0 # 7390 <_sk_callback_sse41+0x14e4> .byte 68,15,17,128,128,0,0,0 // movups %xmm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_ny_sse41 .globl _sk_bilinear_ny_sse41 FUNCTION(_sk_bilinear_ny_sse41) _sk_bilinear_ny_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,104,23,0,0 // addps 0x1768(%rip),%xmm1 # 73a0 <_sk_callback_sse41+0x14f4> .byte 68,15,40,13,112,23,0,0 // movaps 0x1770(%rip),%xmm9 # 73b0 <_sk_callback_sse41+0x1504> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,17,136,160,0,0,0 // movups %xmm9,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_py_sse41 .globl _sk_bilinear_py_sse41 FUNCTION(_sk_bilinear_py_sse41) _sk_bilinear_py_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,94,23,0,0 // addps 0x175e(%rip),%xmm1 # 73c0 <_sk_callback_sse41+0x1514> .byte 68,15,17,128,160,0,0,0 // movups %xmm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n3x_sse41 .globl _sk_bicubic_n3x_sse41 FUNCTION(_sk_bicubic_n3x_sse41) _sk_bicubic_n3x_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,81,23,0,0 // addps 0x1751(%rip),%xmm0 # 73d0 <_sk_callback_sse41+0x1524> .byte 68,15,40,13,89,23,0,0 // movaps 0x1759(%rip),%xmm9 # 73e0 <_sk_callback_sse41+0x1534> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 69,15,89,192 // mulps %xmm8,%xmm8 .byte 68,15,89,13,85,23,0,0 // mulps 0x1755(%rip),%xmm9 # 73f0 <_sk_callback_sse41+0x1544> .byte 68,15,88,13,93,23,0,0 // addps 0x175d(%rip),%xmm9 # 7400 <_sk_callback_sse41+0x1554> .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 68,15,17,136,128,0,0,0 // movups %xmm9,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n1x_sse41 .globl _sk_bicubic_n1x_sse41 FUNCTION(_sk_bicubic_n1x_sse41) _sk_bicubic_n1x_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,76,23,0,0 // addps 0x174c(%rip),%xmm0 # 7410 <_sk_callback_sse41+0x1564> .byte 68,15,40,13,84,23,0,0 // movaps 0x1754(%rip),%xmm9 # 7420 <_sk_callback_sse41+0x1574> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,40,5,88,23,0,0 // movaps 0x1758(%rip),%xmm8 # 7430 <_sk_callback_sse41+0x1584> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,92,23,0,0 // addps 0x175c(%rip),%xmm8 # 7440 <_sk_callback_sse41+0x1594> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,96,23,0,0 // addps 0x1760(%rip),%xmm8 # 7450 <_sk_callback_sse41+0x15a4> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,100,23,0,0 // addps 0x1764(%rip),%xmm8 # 7460 <_sk_callback_sse41+0x15b4> .byte 68,15,17,128,128,0,0,0 // movups %xmm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p1x_sse41 .globl _sk_bicubic_p1x_sse41 FUNCTION(_sk_bicubic_p1x_sse41) _sk_bicubic_p1x_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,40,5,94,23,0,0 // movaps 0x175e(%rip),%xmm8 # 7470 <_sk_callback_sse41+0x15c4> .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,72,64 // movups 0x40(%rax),%xmm9 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 68,15,40,21,90,23,0,0 // movaps 0x175a(%rip),%xmm10 # 7480 <_sk_callback_sse41+0x15d4> .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 68,15,88,21,94,23,0,0 // addps 0x175e(%rip),%xmm10 # 7490 <_sk_callback_sse41+0x15e4> .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,208 // addps %xmm8,%xmm10 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 68,15,88,21,90,23,0,0 // addps 0x175a(%rip),%xmm10 # 74a0 <_sk_callback_sse41+0x15f4> .byte 68,15,17,144,128,0,0,0 // movups %xmm10,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p3x_sse41 .globl _sk_bicubic_p3x_sse41 FUNCTION(_sk_bicubic_p3x_sse41) _sk_bicubic_p3x_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,77,23,0,0 // addps 0x174d(%rip),%xmm0 # 74b0 <_sk_callback_sse41+0x1604> .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 69,15,89,201 // mulps %xmm9,%xmm9 .byte 68,15,89,5,77,23,0,0 // mulps 0x174d(%rip),%xmm8 # 74c0 <_sk_callback_sse41+0x1614> .byte 68,15,88,5,85,23,0,0 // addps 0x1755(%rip),%xmm8 # 74d0 <_sk_callback_sse41+0x1624> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,17,128,128,0,0,0 // movups %xmm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n3y_sse41 .globl _sk_bicubic_n3y_sse41 FUNCTION(_sk_bicubic_n3y_sse41) _sk_bicubic_n3y_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,67,23,0,0 // addps 0x1743(%rip),%xmm1 # 74e0 <_sk_callback_sse41+0x1634> .byte 68,15,40,13,75,23,0,0 // movaps 0x174b(%rip),%xmm9 # 74f0 <_sk_callback_sse41+0x1644> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 69,15,89,192 // mulps %xmm8,%xmm8 .byte 68,15,89,13,71,23,0,0 // mulps 0x1747(%rip),%xmm9 # 7500 <_sk_callback_sse41+0x1654> .byte 68,15,88,13,79,23,0,0 // addps 0x174f(%rip),%xmm9 # 7510 <_sk_callback_sse41+0x1664> .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 68,15,17,136,160,0,0,0 // movups %xmm9,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n1y_sse41 .globl _sk_bicubic_n1y_sse41 FUNCTION(_sk_bicubic_n1y_sse41) _sk_bicubic_n1y_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,61,23,0,0 // addps 0x173d(%rip),%xmm1 # 7520 <_sk_callback_sse41+0x1674> .byte 68,15,40,13,69,23,0,0 // movaps 0x1745(%rip),%xmm9 # 7530 <_sk_callback_sse41+0x1684> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,40,5,73,23,0,0 // movaps 0x1749(%rip),%xmm8 # 7540 <_sk_callback_sse41+0x1694> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,77,23,0,0 // addps 0x174d(%rip),%xmm8 # 7550 <_sk_callback_sse41+0x16a4> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,81,23,0,0 // addps 0x1751(%rip),%xmm8 # 7560 <_sk_callback_sse41+0x16b4> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,85,23,0,0 // addps 0x1755(%rip),%xmm8 # 7570 <_sk_callback_sse41+0x16c4> .byte 68,15,17,128,160,0,0,0 // movups %xmm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p1y_sse41 .globl _sk_bicubic_p1y_sse41 FUNCTION(_sk_bicubic_p1y_sse41) _sk_bicubic_p1y_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,40,5,79,23,0,0 // movaps 0x174f(%rip),%xmm8 # 7580 <_sk_callback_sse41+0x16d4> .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,72,96 // movups 0x60(%rax),%xmm9 .byte 65,15,88,200 // addps %xmm8,%xmm1 .byte 68,15,40,21,74,23,0,0 // movaps 0x174a(%rip),%xmm10 # 7590 <_sk_callback_sse41+0x16e4> .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 68,15,88,21,78,23,0,0 // addps 0x174e(%rip),%xmm10 # 75a0 <_sk_callback_sse41+0x16f4> .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,208 // addps %xmm8,%xmm10 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 68,15,88,21,74,23,0,0 // addps 0x174a(%rip),%xmm10 # 75b0 <_sk_callback_sse41+0x1704> .byte 68,15,17,144,160,0,0,0 // movups %xmm10,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p3y_sse41 .globl _sk_bicubic_p3y_sse41 FUNCTION(_sk_bicubic_p3y_sse41) _sk_bicubic_p3y_sse41: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,60,23,0,0 // addps 0x173c(%rip),%xmm1 # 75c0 <_sk_callback_sse41+0x1714> .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 69,15,89,201 // mulps %xmm9,%xmm9 .byte 68,15,89,5,60,23,0,0 // mulps 0x173c(%rip),%xmm8 # 75d0 <_sk_callback_sse41+0x1724> .byte 68,15,88,5,68,23,0,0 // addps 0x1744(%rip),%xmm8 # 75e0 <_sk_callback_sse41+0x1734> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,17,128,160,0,0,0 // movups %xmm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_callback_sse41 .globl _sk_callback_sse41 FUNCTION(_sk_callback_sse41) _sk_callback_sse41: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,236,72 // sub $0x48,%rsp .byte 15,41,125,144 // movaps %xmm7,-0x70(%rbp) .byte 15,41,117,160 // movaps %xmm6,-0x60(%rbp) .byte 15,41,109,176 // movaps %xmm5,-0x50(%rbp) .byte 15,41,101,192 // movaps %xmm4,-0x40(%rbp) .byte 76,137,195 // mov %r8,%rbx .byte 72,137,77,208 // mov %rcx,-0x30(%rbp) .byte 73,137,215 // mov %rdx,%r15 .byte 73,137,252 // mov %rdi,%r12 .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,137,198 // mov %rax,%r14 .byte 73,137,245 // mov %rsi,%r13 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,20,225 // unpcklps %xmm1,%xmm4 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,20,235 // unpcklps %xmm3,%xmm5 .byte 15,21,193 // unpckhps %xmm1,%xmm0 .byte 15,21,211 // unpckhps %xmm3,%xmm2 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 102,15,20,205 // unpcklpd %xmm5,%xmm1 .byte 15,18,236 // movhlps %xmm4,%xmm5 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 102,15,20,218 // unpcklpd %xmm2,%xmm3 .byte 102,65,15,17,78,8 // movupd %xmm1,0x8(%r14) .byte 15,18,208 // movhlps %xmm0,%xmm2 .byte 65,15,17,110,24 // movups %xmm5,0x18(%r14) .byte 102,65,15,17,94,40 // movupd %xmm3,0x28(%r14) .byte 65,15,17,86,56 // movups %xmm2,0x38(%r14) .byte 72,133,219 // test %rbx,%rbx .byte 190,4,0,0,0 // mov $0x4,%esi .byte 15,69,243 // cmovne %ebx,%esi .byte 76,137,247 // mov %r14,%rdi .byte 65,255,22 // callq *(%r14) .byte 73,139,134,136,0,0,0 // mov 0x88(%r14),%rax .byte 15,16,32 // movups (%rax),%xmm4 .byte 15,16,64,16 // movups 0x10(%rax),%xmm0 .byte 15,16,88,32 // movups 0x20(%rax),%xmm3 .byte 15,16,80,48 // movups 0x30(%rax),%xmm2 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,20,232 // unpcklps %xmm0,%xmm5 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 15,21,224 // unpckhps %xmm0,%xmm4 .byte 15,21,218 // unpckhps %xmm2,%xmm3 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 102,15,20,193 // unpcklpd %xmm1,%xmm0 .byte 15,18,205 // movhlps %xmm5,%xmm1 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 102,15,20,211 // unpcklpd %xmm3,%xmm2 .byte 15,18,220 // movhlps %xmm4,%xmm3 .byte 76,137,238 // mov %r13,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,231 // mov %r12,%rdi .byte 76,137,250 // mov %r15,%rdx .byte 72,139,77,208 // mov -0x30(%rbp),%rcx .byte 73,137,216 // mov %rbx,%r8 .byte 15,40,101,192 // movaps -0x40(%rbp),%xmm4 .byte 15,40,109,176 // movaps -0x50(%rbp),%xmm5 .byte 15,40,117,160 // movaps -0x60(%rbp),%xmm6 .byte 15,40,125,144 // movaps -0x70(%rbp),%xmm7 .byte 72,131,196,72 // add $0x48,%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax BALIGN16 .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,1 // cmpb $0x1,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 252 // cld .byte 190,0,0,252,190 // mov $0xbefc0000,%esi .byte 0,0 // add %al,(%rax) .byte 252 // cld .byte 190,0,0,252,190 // mov $0xbefc0000,%esi .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,191,0,0,128 // add %al,-0x7fffff41(%rax) .byte 191,0,0,128,191 // mov $0xbf800000,%edi .byte 0,0 // add %al,(%rax) .byte 128,191,0,0,224,64,0 // cmpb $0x0,0x40e00000(%rdi) .byte 0,224 // add %ah,%al .byte 64,0,0 // add %al,(%rax) .byte 224,64 // loopne 619c <.literal16+0x1fc> .byte 0,0 // add %al,(%rax) .byte 224,64 // loopne 61a0 <.literal16+0x200> .byte 154 // (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,61 // ds cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 61c1 <.literal16+0x221> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 61c5 <.literal16+0x225> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 61c9 <.literal16+0x229> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 61cd <.literal16+0x22d> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,61 // ds cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6201 <.literal16+0x261> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6205 <.literal16+0x265> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6209 <.literal16+0x269> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 620d <.literal16+0x26d> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,61 // ds cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6241 <.literal16+0x2a1> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6245 <.literal16+0x2a5> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6249 <.literal16+0x2a9> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 624d <.literal16+0x2ad> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,61 // ds cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6281 <.literal16+0x2e1> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6285 <.literal16+0x2e5> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6289 <.literal16+0x2e9> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 628d <.literal16+0x2ed> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,255 // cmpb $0xff,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a006278 <_sk_callback_sse41+0xa0003cc> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,2 // decl 0x2ffffff(%rip) # 3006280 <_sk_callback_sse41+0x30003d4> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,127 // add %al,0x7f00003f(%rax) .byte 67,0,0 // rex.XB add %al,(%r8) .byte 127,67 // jg 62eb <.literal16+0x34b> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 62ef <.literal16+0x34f> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 62f3 <.literal16+0x353> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,145,131,158 // add %al,-0x617c6ec1(%rax) .byte 61,145,131,158,61 // cmp $0x3d9e8391,%eax .byte 145 // xchg %eax,%ecx .byte 131,158,61,145,131,158,61 // sbbl $0x3d,-0x617c6ec3(%rsi) .byte 154 // (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,92 // ds pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 145 // xchg %eax,%ecx .byte 131,158,61,145,131,158,61 // sbbl $0x3d,-0x617c6ec3(%rsi) .byte 145 // xchg %eax,%ecx .byte 131,158,61,145,131,158,61 // sbbl $0x3d,-0x617c6ec3(%rsi) .byte 154 // (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,92 // ds pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 82 // push %rdx .byte 184,78,65,82,184 // mov $0xb852414e,%eax .byte 78 // rex.WRX .byte 65,82 // push %r10 .byte 184,78,65,82,184 // mov $0xb852414e,%eax .byte 78 // rex.WRX .byte 65,57,215 // cmp %edx,%r15d .byte 32,187,57,215,32,187 // and %bh,-0x44df28c7(%rbx) .byte 57,215 // cmp %edx,%edi .byte 32,187,57,215,32,187 // and %bh,-0x44df28c7(%rbx) .byte 186,159,98,60,186 // mov $0xba3c629f,%edx .byte 159 // lahf .byte 98 // (bad) .byte 60,186 // cmp $0xba,%al .byte 159 // lahf .byte 98 // (bad) .byte 60,186 // cmp $0xba,%al .byte 159 // lahf .byte 98 // (bad) .byte 60,109 // cmp $0x6d,%al .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 144 // nop .byte 63 // (bad) .byte 109 // insl (%dx),%es:(%rdi) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 144 // nop .byte 63 // (bad) .byte 109 // insl (%dx),%es:(%rdi) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 144 // nop .byte 63 // (bad) .byte 109 // insl (%dx),%es:(%rdi) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 144 // nop .byte 63 // (bad) .byte 252 // cld .byte 191,16,62,252,191 // mov $0xbffc3e10,%edi .byte 16,62 // adc %bh,(%rsi) .byte 252 // cld .byte 191,16,62,252,191 // mov $0xbffc3e10,%edi .byte 16,62 // adc %bh,(%rsi) .byte 168,177 // test $0xb1,%al .byte 152 // cwtl .byte 59,168,177,152,59,168 // cmp -0x57c4674f(%rax),%ebp .byte 177,152 // mov $0x98,%cl .byte 59,168,177,152,59,0 // cmp 0x3b98b1(%rax),%ebp .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,192 // add %al,-0x3fffffc1(%rax) .byte 64,0,0 // add %al,(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 0,64,0 // add %al,0x0(%rax) .byte 0,0 // add %al,(%rax) .byte 64,0,0 // add %al,(%rax) .byte 0,64,0 // add %al,0x0(%rax) .byte 0,0 // add %al,(%rax) .byte 64,0,0 // add %al,(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,171,170 // addb $0xaa,-0x55(%rax) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 0,0 // add %al,(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,171,170 // addb $0xaa,-0x55(%rax) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,0,248,0,0 // addb $0x0,0xf8003b(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 6539 <.literal16+0x599> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 653d <.literal16+0x59d> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6541 <.literal16+0x5a1> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6545 <.literal16+0x5a5> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%rdi,1) .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,255 // add %edi,%edi .byte 255 // (bad) .byte 255,5,255,255,255,9 // incl 0x9ffffff(%rip) # a006588 <_sk_callback_sse41+0xa0006dc> .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,2 // decl 0x2ffffff(%rip) # 3006590 <_sk_callback_sse41+0x30006e4> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,129,128,128,59,129 // incl -0x7ec47f80(%rcx) .byte 128,128,59,129,128,128,59 // addb $0x3b,-0x7f7f7ec5(%rax) .byte 129,128,128,59,255,0,255,0,255,0 // addl $0xff00ff,0xff3b80(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,255 // or %bh,%bh .byte 10,255 // or %bh,%bh .byte 12,255 // or $0xff,%al .byte 14 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,128,55,128 // add %al,-0x7fc88000(%rax) .byte 0,128,55,128,0,128 // add %al,-0x7fff7fc9(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 8,128,10,128,12,128 // or %al,-0x7ff37ff6(%rax) .byte 14 // (bad) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 665b <.literal16+0x6bb> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 665f <.literal16+0x6bf> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6663 <.literal16+0x6c3> .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,129,128,128,59 // addb $0x3b,-0x7f7f7ec5(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 6654 <.literal16+0x6b4> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6658 <.literal16+0x6b8> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 665c <.literal16+0x6bc> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6660 <.literal16+0x6c0> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 66e5 <.literal16+0x745> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 6649 <.literal16+0x6a9> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3a68a <_sk_callback_sse41+0xffffffffe9a347de> .byte 220,63 // fdivrl (%rdi) .byte 81 // push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 6724 <.literal16+0x784> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6728 <.literal16+0x788> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 672c <.literal16+0x78c> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6730 <.literal16+0x790> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 67b5 <.literal16+0x815> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 6719 <.literal16+0x779> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3a75a <_sk_callback_sse41+0xffffffffe9a348ae> .byte 220,63 // fdivrl (%rdi) .byte 81 // push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 67f4 <.literal16+0x854> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 67f8 <.literal16+0x858> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 67fc <.literal16+0x85c> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6800 <.literal16+0x860> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 6885 <.literal16+0x8e5> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 67e9 <.literal16+0x849> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3a82a <_sk_callback_sse41+0xffffffffe9a3497e> .byte 220,63 // fdivrl (%rdi) .byte 81 // push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 68c4 <.literal16+0x924> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 68c8 <.literal16+0x928> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 68cc <.literal16+0x92c> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 68d0 <.literal16+0x930> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 6955 <.literal16+0x9b5> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 68b9 <.literal16+0x919> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3a8fa <_sk_callback_sse41+0xffffffffe9a34a4e> .byte 220,63 // fdivrl (%rdi) .byte 81 // push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 6994 <.literal16+0x9f4> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6998 <.literal16+0x9f8> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 699c <.literal16+0x9fc> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 69a0 <.literal16+0xa00> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 6a25 <.literal16+0xa85> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 6989 <.literal16+0x9e9> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3a9ca <_sk_callback_sse41+0xffffffffe9a34b1e> .byte 220,63 // fdivrl (%rdi) .byte 81 // push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 200,66,0,0 // enterq $0x42,$0x0 .byte 200,66,0,0 // enterq $0x42,$0x0 .byte 200,66,0,0 // enterq $0x42,$0x0 .byte 200,66,0,0 // enterq $0x42,$0x0 .byte 127,67 // jg 6a97 <.literal16+0xaf7> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6a9b <.literal16+0xafb> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6a9f <.literal16+0xaff> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6aa3 <.literal16+0xb03> .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 128,65,0,0 // addb $0x0,0x0(%rcx) .byte 128,65,0,0 // addb $0x0,0x0(%rcx) .byte 128,65,0,0 // addb $0x0,0x0(%rcx) .byte 128,65,203,61 // addb $0x3d,-0x35(%rcx) .byte 13,60,203,61,13 // or $0xd3dcb3c,%eax .byte 60,203 // cmp $0xcb,%al .byte 61,13,60,203,61 // cmp $0x3dcb3c0d,%eax .byte 13,60,111,18,3 // or $0x3126f3c,%eax .byte 59,111,18 // cmp 0x12(%rdi),%ebp .byte 3,59 // add (%rbx),%edi .byte 111 // outsl %ds:(%rsi),(%dx) .byte 18,3 // adc (%rbx),%al .byte 59,111,18 // cmp 0x12(%rdi),%ebp .byte 3,59 // add (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 163,59,10,215,163,59,10,215,163 // movabs %eax,0xa3d70a3ba3d70a3b .byte 59,10 // cmp (%rdx),%ecx .byte 215 // xlat %ds:(%rbx) .byte 163,59,194,24,17,60,194,24,17 // movabs %eax,0x1118c23c1118c23b .byte 60,194 // cmp $0xc2,%al .byte 24,17 // sbb %dl,(%rcx) .byte 60,194 // cmp $0xc2,%al .byte 24,17 // sbb %dl,(%rcx) .byte 60,203 // cmp $0xcb,%al .byte 61,13,190,203,61 // cmp $0x3dcbbe0d,%eax .byte 13,190,203,61,13 // or $0xd3dcbbe,%eax .byte 190,203,61,13,190 // mov $0xbe0d3dcb,%esi .byte 80 // push %rax .byte 128,3,62 // addb $0x3e,(%rbx) .byte 80 // push %rax .byte 128,3,62 // addb $0x3e,(%rbx) .byte 80 // push %rax .byte 128,3,62 // addb $0x3e,(%rbx) .byte 80 // push %rax .byte 128,3,62 // addb $0x3e,(%rbx) .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 6b23 <.literal16+0xb83> .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 6b27 <.literal16+0xb87> .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 6b2b <.literal16+0xb8b> .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 6b2f <.literal16+0xb8f> .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,129,128,128,59 // addb $0x3b,-0x7f7f7ec5(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6b9b <.literal16+0xbfb> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6b9f <.literal16+0xbff> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6ba3 <.literal16+0xc03> .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,129,128,128,59,129 // add %al,-0x7ec47f80(%rcx) .byte 128,128,59,129,128,128,59 // addb $0x3b,-0x7f7f7ec5(%rax) .byte 129,128,128,59,0,0,128,63,0,0 // addl $0x3f80,0x3b80(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,0,0,128,63 // addb $0x3f,-0x7fffffc5(%rax) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,0,0,128,63 // addb $0x3f,-0x7fffffc5(%rax) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 6c19 <.literal16+0xc79> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6c1d <.literal16+0xc7d> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6c21 <.literal16+0xc81> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6c25 <.literal16+0xc85> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%rdi,1) .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 248 // clc .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 6c89 <.literal16+0xce9> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6c8d <.literal16+0xced> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6c91 <.literal16+0xcf1> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6c95 <.literal16+0xcf5> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%rdi,1) .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 248 // clc .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 6cf9 <.literal16+0xd59> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6cfd <.literal16+0xd5d> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6d01 <.literal16+0xd61> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6d05 <.literal16+0xd65> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%rdi,1) .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,248 // add %bh,%al .byte 65,0,0 // add %al,(%r8) .byte 248 // clc .byte 65,0,0 // add %al,(%r8) .byte 248 // clc .byte 65,0,0 // add %al,(%r8) .byte 248 // clc .byte 65,0,0 // add %al,(%r8) .byte 124,66 // jl 6d96 <.literal16+0xdf6> .byte 0,0 // add %al,(%rax) .byte 124,66 // jl 6d9a <.literal16+0xdfa> .byte 0,0 // add %al,(%rax) .byte 124,66 // jl 6d9e <.literal16+0xdfe> .byte 0,0 // add %al,(%rax) .byte 124,66 // jl 6da2 <.literal16+0xe02> .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 240,0,0 // lock add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,59,137 // add %cl,-0x76c47778(%rcx) .byte 136,136,59,137,136,136 // mov %cl,-0x777776c5(%rax) .byte 59,137,136,136,59,15 // cmp 0xf3b8888(%rcx),%ecx .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,61,137 // add %cl,-0x76c27778(%rcx) .byte 136,136,61,137,136,136 // mov %cl,-0x777776c3(%rax) .byte 61,137,136,136,61 // cmp $0x3d888889,%eax .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 240,0,0 // lock add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,59,137 // add %cl,-0x76c47778(%rcx) .byte 136,136,59,137,136,136 // mov %cl,-0x777776c5(%rax) .byte 59,137,136,136,59,15 // cmp 0xf3b8888(%rcx),%ecx .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,61,137 // add %cl,-0x76c27778(%rcx) .byte 136,136,61,137,136,136 // mov %cl,-0x777776c3(%rax) .byte 61,137,136,136,61 // cmp $0x3d888889,%eax .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 240,0,0 // lock add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,59,137 // add %cl,-0x76c47778(%rcx) .byte 136,136,59,137,136,136 // mov %cl,-0x777776c5(%rax) .byte 59,137,136,136,59,15 // cmp 0xf3b8888(%rcx),%ecx .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,61,137 // add %cl,-0x76c27778(%rcx) .byte 136,136,61,137,136,136 // mov %cl,-0x777776c3(%rax) .byte 61,137,136,136,61 // cmp $0x3d888889,%eax .byte 0,0 // add %al,(%rax) .byte 112,65 // jo 6f25 <.literal16+0xf85> .byte 0,0 // add %al,(%rax) .byte 112,65 // jo 6f29 <.literal16+0xf89> .byte 0,0 // add %al,(%rax) .byte 112,65 // jo 6f2d <.literal16+0xf8d> .byte 0,0 // add %al,(%rax) .byte 112,65 // jo 6f31 <.literal16+0xf91> .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,1,255,255,255 // addb $0xff,-0xfec5(%rax) .byte 5,255,255,255,9 // add $0x9ffffff,%eax .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,2 // decl 0x2ffffff(%rip) # 3006f20 <_sk_callback_sse41+0x3001074> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,1,255,255,255 // addb $0xff,-0xfec5(%rax) .byte 5,255,255,255,9 // add $0x9ffffff,%eax .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,2 // decl 0x2ffffff(%rip) # 3006f60 <_sk_callback_sse41+0x30010b4> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,1,255,255,255 // addb $0xff,-0xfec5(%rax) .byte 5,255,255,255,9 // add $0x9ffffff,%eax .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,2 // decl 0x2ffffff(%rip) # 3006fa0 <_sk_callback_sse41+0x30010f4> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6ffb <.literal16+0x105b> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6fff <.literal16+0x105f> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 7003 <.literal16+0x1063> .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,1,255,255,255 // addb $0xff,-0xfec5(%rax) .byte 5,255,255,255,9 // add $0x9ffffff,%eax .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,2 // decl 0x2ffffff(%rip) # 3006ff0 <_sk_callback_sse41+0x3001144> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,1,255,255,255 // addb $0xff,-0xfec5(%rax) .byte 5,255,255,255,9 // add $0x9ffffff,%eax .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,2 // decl 0x2ffffff(%rip) # 3007030 <_sk_callback_sse41+0x3001184> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,1,255,255,255 // addb $0xff,-0xfec5(%rax) .byte 5,255,255,255,9 // add $0x9ffffff,%eax .byte 255 // (bad) .byte 255 // (bad) .byte 255,13,255,255,255,2 // decl 0x2ffffff(%rip) # 3007070 <_sk_callback_sse41+0x30011c4> .byte 255 // (bad) .byte 255 // (bad) .byte 255,6 // incl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,10 // decl (%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255,14 // decl (%rsi) .byte 255 // (bad) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 70cb <.literal16+0x112b> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 70cf <.literal16+0x112f> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 70d3 <.literal16+0x1133> .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,4 // add %al,0x4000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,4 // add %al,0x4000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,128,56 // add %al,0x38800000(%rax) .byte 0,0 // add %al,(%rax) .byte 128,56,0 // cmpb $0x0,(%rax) .byte 0,128,56,0,0,128 // add %al,-0x7fffffc8(%rax) .byte 56,0 // cmp %al,(%rax) .byte 64,254 // rex (bad) .byte 255,0 // incl (%rax) .byte 64,254 // rex (bad) .byte 255,0 // incl (%rax) .byte 64,254 // rex (bad) .byte 255,0 // incl (%rax) .byte 64,254 // rex (bad) .byte 255,128,0,128,55,128 // incl -0x7fc88000(%rax) .byte 0,128,55,128,0,128 // add %al,-0x7fff7fc9(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 255 // (bad) .byte 127,71 // jg 71cb <.literal16+0x122b> .byte 0,255 // add %bh,%bh .byte 127,71 // jg 71cf <.literal16+0x122f> .byte 0,255 // add %bh,%bh .byte 127,71 // jg 71d3 <.literal16+0x1233> .byte 0,255 // add %bh,%bh .byte 127,71 // jg 71d7 <.literal16+0x1237> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,191,0,0,128 // add %al,-0x7fffff41(%rax) .byte 191,0,0,128,191 // mov $0xbf800000,%edi .byte 0,0 // add %al,(%rax) .byte 128,191,0,0,0,63,0 // cmpb $0x0,0x3f000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 208 // (bad) .byte 179,89 // mov $0x59,%bl .byte 62,208 // ds (bad) .byte 179,89 // mov $0x59,%bl .byte 62,208 // ds (bad) .byte 179,89 // mov $0x59,%bl .byte 62,208 // ds (bad) .byte 179,89 // mov $0x59,%bl .byte 62,89 // ds pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 89 // pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 89 // pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 89 // pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 152 // cwtl .byte 221,147,61,152,221,147 // fstl -0x6c2267c3(%rbx) .byte 61,152,221,147,61 // cmp $0x3d93dd98,%eax .byte 152 // cwtl .byte 221,147,61,45,16,17 // fstl 0x11102d3d(%rbx) .byte 192,45,16,17,192,45,16 // shrb $0x10,0x2dc01110(%rip) # 2dc0830a <_sk_callback_sse41+0x2dc0245e> .byte 17,192 // adc %eax,%eax .byte 45,16,17,192,18 // sub $0x12c01110,%eax .byte 120,57 // js 723c <.literal16+0x129c> .byte 64,18,120,57 // adc 0x39(%rax),%dil .byte 64,18,120,57 // adc 0x39(%rax),%dil .byte 64,18,120,57 // adc 0x39(%rax),%dil .byte 64,32,148,90,62,32,148,90 // and %dl,0x5a94203e(%rdx,%rbx,2) .byte 62,32,148,90,62,32,148,90 // and %dl,%ds:0x5a94203e(%rdx,%rbx,2) .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,0,24 // add %bl,%ds:(%rax) .byte 161,57,0,24,161,57,0,24,161 // movabs 0xa1180039a1180039,%eax .byte 57,0 // cmp %eax,(%rax) .byte 24,161,57,1,0,0 // sbb %ah,0x139(%rcx) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,111,43 // add %ch,0x2b(%rdi) .byte 231,187 // out %eax,$0xbb .byte 111 // outsl %ds:(%rsi),(%dx) .byte 43,231 // sub %edi,%esp .byte 187,111,43,231,187 // mov $0xbbe72b6f,%ebx .byte 111 // outsl %ds:(%rsi),(%dx) .byte 43,231 // sub %edi,%esp .byte 187,159,215,202,60 // mov $0x3ccad79f,%ebx .byte 159 // lahf .byte 215 // xlat %ds:(%rbx) .byte 202,60,159 // lret $0x9f3c .byte 215 // xlat %ds:(%rbx) .byte 202,60,159 // lret $0x9f3c .byte 215 // xlat %ds:(%rbx) .byte 202,60,212 // lret $0xd43c .byte 100,84 // fs push %rsp .byte 189,212,100,84,189 // mov $0xbd5464d4,%ebp .byte 212 // (bad) .byte 100,84 // fs push %rsp .byte 189,212,100,84,189 // mov $0xbd5464d4,%ebp .byte 169,240,34,62,169 // test $0xa93e22f0,%eax .byte 240,34,62 // lock and (%rsi),%bh .byte 169,240,34,62,169 // test $0xa93e22f0,%eax .byte 240,34,62 // lock and (%rsi),%bh .byte 0,0 // add %al,(%rax) .byte 128,62,0 // cmpb $0x0,(%rsi) .byte 0,128,62,0,0,128 // add %al,-0x7fffffc2(%rax) .byte 62,0,0 // add %al,%ds:(%rax) .byte 128,62,0 // cmpb $0x0,(%rsi) .byte 0,0 // add %al,(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,0,0 // rolb $0x0,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,128,192,0,0,128 // add %al,-0x7fffff40(%rax) .byte 192,0,0 // rolb $0x0,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,63 // add %al,0x3f000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,128,192,0,0,128 // add %al,-0x7fffff40(%rax) .byte 192,0,0 // rolb $0x0,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,63 // add %al,0x3f000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,191,0,0,192,191,0 // sarb $0x0,-0x40400000(%rdi) .byte 0,192 // add %al,%al .byte 191,0,0,192,191 // mov $0xbfc00000,%edi .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,114 // cmpb $0x72,(%rdi) .byte 28,199 // sbb $0xc7,%al .byte 62,114,28 // jb,pt 7412 <.literal16+0x1472> .byte 199 // (bad) .byte 62,114,28 // jb,pt 7416 <.literal16+0x1476> .byte 199 // (bad) .byte 62,114,28 // jb,pt 741a <.literal16+0x147a> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,85 // cmpb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%rsi) .byte 99,61,57,142,99,61 // movslq 0x3d638e39(%rip),%edi # 3d6402a5 <_sk_callback_sse41+0x3d63a3f9> .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%rsi) .byte 99,61,57,142,99,61 // movslq 0x3d638e39(%rip),%edi # 3d6402e5 <_sk_callback_sse41+0x3d63a439> .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 114,28 // jb 74de <.literal16+0x153e> .byte 199 // (bad) .byte 62,114,28 // jb,pt 74e2 <.literal16+0x1542> .byte 199 // (bad) .byte 62,114,28 // jb,pt 74e6 <.literal16+0x1546> .byte 199 // (bad) .byte 62,114,28 // jb,pt 74ea <.literal16+0x154a> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 0,0 // add %al,(%rax) .byte 192,191,0,0,192,191,0 // sarb $0x0,-0x40400000(%rdi) .byte 0,192 // add %al,%al .byte 191,0,0,192,191 // mov $0xbfc00000,%edi .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,114 // cmpb $0x72,(%rdi) .byte 28,199 // sbb $0xc7,%al .byte 62,114,28 // jb,pt 7522 <.literal16+0x1582> .byte 199 // (bad) .byte 62,114,28 // jb,pt 7526 <.literal16+0x1586> .byte 199 // (bad) .byte 62,114,28 // jb,pt 752a <.literal16+0x158a> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,85 // cmpb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%rsi) .byte 99,61,57,142,99,61 // movslq 0x3d638e39(%rip),%edi # 3d6403b5 <_sk_callback_sse41+0x3d63a509> .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%rsi) .byte 99,61,57,142,99,61 // movslq 0x3d638e39(%rip),%edi # 3d6403f5 <_sk_callback_sse41+0x3d63a549> .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 114,28 // jb 75ee <.literal16+0x164e> .byte 199 // (bad) .byte 62,114,28 // jb,pt 75f2 <_sk_callback_sse41+0x1746> .byte 199 // (bad) .byte 62,114,28 // jb,pt 75f6 <_sk_callback_sse41+0x174a> .byte 199 // (bad) .byte 62,114,28 // jb,pt 75fa <_sk_callback_sse41+0x174e> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi BALIGN4 .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) BALIGN32 HIDDEN _sk_start_pipeline_sse2 .globl _sk_start_pipeline_sse2 FUNCTION(_sk_start_pipeline_sse2) _sk_start_pipeline_sse2: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,236,40 // sub $0x28,%rsp .byte 72,137,211 // mov %rdx,%rbx .byte 73,137,246 // mov %rsi,%r14 .byte 72,137,125,208 // mov %rdi,-0x30(%rbp) .byte 76,137,198 // mov %r8,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,137,194 // mov %rax,%rdx .byte 72,137,77,176 // mov %rcx,-0x50(%rbp) .byte 73,57,206 // cmp %rcx,%r14 .byte 115,117 // jae a1 <_sk_start_pipeline_sse2+0xa1> .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,141,64,4 // lea 0x4(%rax),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 76,137,77,192 // mov %r9,-0x40(%rbp) .byte 72,137,85,200 // mov %rdx,-0x38(%rbp) .byte 73,137,221 // mov %rbx,%r13 .byte 73,137,244 // mov %rsi,%r12 .byte 72,57,93,184 // cmp %rbx,-0x48(%rbp) .byte 72,139,85,208 // mov -0x30(%rbp),%rdx .byte 119,45 // ja 7d <_sk_start_pipeline_sse2+0x7d> .byte 76,139,125,208 // mov -0x30(%rbp),%r15 .byte 69,49,192 // xor %r8d,%r8d .byte 76,137,207 // mov %r9,%rdi .byte 76,137,230 // mov %r12,%rsi .byte 76,137,250 // mov %r15,%rdx .byte 76,137,241 // mov %r14,%rcx .byte 255,85,200 // callq *-0x38(%rbp) .byte 76,137,235 // mov %r13,%rbx .byte 76,139,77,192 // mov -0x40(%rbp),%r9 .byte 73,141,87,4 // lea 0x4(%r15),%rdx .byte 73,131,199,8 // add $0x8,%r15 .byte 73,57,223 // cmp %rbx,%r15 .byte 73,137,215 // mov %rdx,%r15 .byte 118,215 // jbe 54 <_sk_start_pipeline_sse2+0x54> .byte 73,137,216 // mov %rbx,%r8 .byte 73,41,208 // sub %rdx,%r8 .byte 116,19 // je 98 <_sk_start_pipeline_sse2+0x98> .byte 76,137,207 // mov %r9,%rdi .byte 76,137,230 // mov %r12,%rsi .byte 76,137,241 // mov %r14,%rcx .byte 255,85,200 // callq *-0x38(%rbp) .byte 76,137,235 // mov %r13,%rbx .byte 76,139,77,192 // mov -0x40(%rbp),%r9 .byte 73,255,198 // inc %r14 .byte 76,59,117,176 // cmp -0x50(%rbp),%r14 .byte 117,165 // jne 46 <_sk_start_pipeline_sse2+0x46> .byte 72,131,196,40 // add $0x28,%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 195 // retq HIDDEN _sk_just_return_sse2 .globl _sk_just_return_sse2 FUNCTION(_sk_just_return_sse2) _sk_just_return_sse2: .byte 195 // retq HIDDEN _sk_seed_shader_sse2 .globl _sk_seed_shader_sse2 FUNCTION(_sk_seed_shader_sse2) _sk_seed_shader_sse2: .byte 102,15,110,194 // movd %edx,%xmm0 .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 .byte 15,91,200 // cvtdq2ps %xmm0,%xmm1 .byte 15,40,21,236,99,0,0 // movaps 0x63ec(%rip),%xmm2 # 64b0 <_sk_callback_sse2+0xf3> .byte 15,88,202 // addps %xmm2,%xmm1 .byte 15,16,7 // movups (%rdi),%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 102,15,110,201 // movd %ecx,%xmm1 .byte 102,15,112,201,0 // pshufd $0x0,%xmm1,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,21,219,99,0,0 // movaps 0x63db(%rip),%xmm2 # 64c0 <_sk_callback_sse2+0x103> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,87,237 // xorps %xmm5,%xmm5 .byte 15,87,246 // xorps %xmm6,%xmm6 .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_dither_sse2 .globl _sk_dither_sse2 FUNCTION(_sk_dither_sse2) _sk_dither_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,68,15,110,194 // movd %edx,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 243,68,15,111,79,32 // movdqu 0x20(%rdi),%xmm9 .byte 102,69,15,254,200 // paddd %xmm8,%xmm9 .byte 102,68,15,110,193 // movd %ecx,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 102,69,15,239,193 // pxor %xmm9,%xmm8 .byte 102,68,15,111,21,169,99,0,0 // movdqa 0x63a9(%rip),%xmm10 # 64d0 <_sk_callback_sse2+0x113> .byte 102,69,15,111,216 // movdqa %xmm8,%xmm11 .byte 102,69,15,219,218 // pand %xmm10,%xmm11 .byte 102,65,15,114,243,5 // pslld $0x5,%xmm11 .byte 102,69,15,219,209 // pand %xmm9,%xmm10 .byte 102,65,15,114,242,4 // pslld $0x4,%xmm10 .byte 102,68,15,111,37,149,99,0,0 // movdqa 0x6395(%rip),%xmm12 # 64e0 <_sk_callback_sse2+0x123> .byte 102,68,15,111,45,156,99,0,0 // movdqa 0x639c(%rip),%xmm13 # 64f0 <_sk_callback_sse2+0x133> .byte 102,69,15,111,240 // movdqa %xmm8,%xmm14 .byte 102,69,15,219,245 // pand %xmm13,%xmm14 .byte 102,65,15,114,246,2 // pslld $0x2,%xmm14 .byte 102,69,15,219,233 // pand %xmm9,%xmm13 .byte 102,69,15,254,237 // paddd %xmm13,%xmm13 .byte 102,69,15,219,196 // pand %xmm12,%xmm8 .byte 102,65,15,114,208,1 // psrld $0x1,%xmm8 .byte 102,69,15,219,204 // pand %xmm12,%xmm9 .byte 102,65,15,114,209,2 // psrld $0x2,%xmm9 .byte 102,69,15,235,234 // por %xmm10,%xmm13 .byte 102,69,15,235,233 // por %xmm9,%xmm13 .byte 102,69,15,235,243 // por %xmm11,%xmm14 .byte 102,69,15,235,245 // por %xmm13,%xmm14 .byte 102,69,15,235,240 // por %xmm8,%xmm14 .byte 69,15,91,198 // cvtdq2ps %xmm14,%xmm8 .byte 68,15,89,5,87,99,0,0 // mulps 0x6357(%rip),%xmm8 # 6500 <_sk_callback_sse2+0x143> .byte 68,15,88,5,95,99,0,0 // addps 0x635f(%rip),%xmm8 # 6510 <_sk_callback_sse2+0x153> .byte 243,68,15,16,16 // movss (%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 68,15,88,210 // addps %xmm2,%xmm10 .byte 15,93,195 // minps %xmm3,%xmm0 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,192 // maxps %xmm0,%xmm8 .byte 15,93,203 // minps %xmm3,%xmm1 .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 68,15,95,201 // maxps %xmm1,%xmm9 .byte 68,15,93,211 // minps %xmm3,%xmm10 .byte 65,15,95,210 // maxps %xmm10,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_uniform_color_sse2 .globl _sk_uniform_color_sse2 FUNCTION(_sk_uniform_color_sse2) _sk_uniform_color_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,80,8 // movss 0x8(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,12 // movss 0xc(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_black_color_sse2 .globl _sk_black_color_sse2 FUNCTION(_sk_black_color_sse2) _sk_black_color_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,245,98,0,0 // movaps 0x62f5(%rip),%xmm3 # 6520 <_sk_callback_sse2+0x163> .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_white_color_sse2 .globl _sk_white_color_sse2 FUNCTION(_sk_white_color_sse2) _sk_white_color_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,5,241,98,0,0 // movaps 0x62f1(%rip),%xmm0 # 6530 <_sk_callback_sse2+0x173> .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_load_rgba_sse2 .globl _sk_load_rgba_sse2 FUNCTION(_sk_load_rgba_sse2) _sk_load_rgba_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 15,16,72,16 // movups 0x10(%rax),%xmm1 .byte 15,16,80,32 // movups 0x20(%rax),%xmm2 .byte 15,16,88,48 // movups 0x30(%rax),%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_store_rgba_sse2 .globl _sk_store_rgba_sse2 FUNCTION(_sk_store_rgba_sse2) _sk_store_rgba_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,17,0 // movups %xmm0,(%rax) .byte 15,17,72,16 // movups %xmm1,0x10(%rax) .byte 15,17,80,32 // movups %xmm2,0x20(%rax) .byte 15,17,88,48 // movups %xmm3,0x30(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clear_sse2 .globl _sk_clear_sse2 FUNCTION(_sk_clear_sse2) _sk_clear_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcatop_sse2 .globl _sk_srcatop_sse2 FUNCTION(_sk_srcatop_sse2) _sk_srcatop_sse2: .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 68,15,40,5,177,98,0,0 // movaps 0x62b1(%rip),%xmm8 # 6540 <_sk_callback_sse2+0x183> .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 65,15,88,193 // addps %xmm9,%xmm0 .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,88,209 // addps %xmm9,%xmm2 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 65,15,88,216 // addps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstatop_sse2 .globl _sk_dstatop_sse2 FUNCTION(_sk_dstatop_sse2) _sk_dstatop_sse2: .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 68,15,89,196 // mulps %xmm4,%xmm8 .byte 68,15,40,13,116,98,0,0 // movaps 0x6274(%rip),%xmm9 # 6550 <_sk_callback_sse2+0x193> .byte 68,15,92,207 // subps %xmm7,%xmm9 .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 68,15,89,197 // mulps %xmm5,%xmm8 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 65,15,88,200 // addps %xmm8,%xmm1 .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 68,15,89,198 // mulps %xmm6,%xmm8 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 65,15,88,208 // addps %xmm8,%xmm2 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 65,15,88,217 // addps %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcin_sse2 .globl _sk_srcin_sse2 FUNCTION(_sk_srcin_sse2) _sk_srcin_sse2: .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstin_sse2 .globl _sk_dstin_sse2 FUNCTION(_sk_dstin_sse2) _sk_dstin_sse2: .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcout_sse2 .globl _sk_srcout_sse2 FUNCTION(_sk_srcout_sse2) _sk_srcout_sse2: .byte 68,15,40,5,24,98,0,0 // movaps 0x6218(%rip),%xmm8 # 6560 <_sk_callback_sse2+0x1a3> .byte 68,15,92,199 // subps %xmm7,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstout_sse2 .globl _sk_dstout_sse2 FUNCTION(_sk_dstout_sse2) _sk_dstout_sse2: .byte 68,15,40,5,8,98,0,0 // movaps 0x6208(%rip),%xmm8 # 6570 <_sk_callback_sse2+0x1b3> .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_sse2 .globl _sk_srcover_sse2 FUNCTION(_sk_srcover_sse2) _sk_srcover_sse2: .byte 68,15,40,5,235,97,0,0 // movaps 0x61eb(%rip),%xmm8 # 6580 <_sk_callback_sse2+0x1c3> .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 65,15,88,193 // addps %xmm9,%xmm0 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,88,209 // addps %xmm9,%xmm2 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 65,15,88,216 // addps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstover_sse2 .globl _sk_dstover_sse2 FUNCTION(_sk_dstover_sse2) _sk_dstover_sse2: .byte 68,15,40,5,191,97,0,0 // movaps 0x61bf(%rip),%xmm8 # 6590 <_sk_callback_sse2+0x1d3> .byte 68,15,92,199 // subps %xmm7,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_modulate_sse2 .globl _sk_modulate_sse2 FUNCTION(_sk_modulate_sse2) _sk_modulate_sse2: .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_multiply_sse2 .globl _sk_multiply_sse2 FUNCTION(_sk_multiply_sse2) _sk_multiply_sse2: .byte 68,15,40,5,147,97,0,0 // movaps 0x6193(%rip),%xmm8 # 65a0 <_sk_callback_sse2+0x1e3> .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,92,207 // subps %xmm7,%xmm9 .byte 69,15,40,209 // movaps %xmm9,%xmm10 .byte 68,15,89,208 // mulps %xmm0,%xmm10 .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,89,220 // mulps %xmm4,%xmm11 .byte 69,15,88,218 // addps %xmm10,%xmm11 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 65,15,88,195 // addps %xmm11,%xmm0 .byte 69,15,40,209 // movaps %xmm9,%xmm10 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,89,221 // mulps %xmm5,%xmm11 .byte 69,15,88,218 // addps %xmm10,%xmm11 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 65,15,88,203 // addps %xmm11,%xmm1 .byte 69,15,40,209 // movaps %xmm9,%xmm10 .byte 68,15,89,210 // mulps %xmm2,%xmm10 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,89,222 // mulps %xmm6,%xmm11 .byte 69,15,88,218 // addps %xmm10,%xmm11 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 65,15,88,211 // addps %xmm11,%xmm2 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 65,15,88,216 // addps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_plus__sse2 .globl _sk_plus__sse2 FUNCTION(_sk_plus__sse2) _sk_plus__sse2: .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_screen_sse2 .globl _sk_screen_sse2 FUNCTION(_sk_screen_sse2) _sk_screen_sse2: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 68,15,89,196 // mulps %xmm4,%xmm8 .byte 65,15,92,192 // subps %xmm8,%xmm0 .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 68,15,88,197 // addps %xmm5,%xmm8 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 68,15,92,193 // subps %xmm1,%xmm8 .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 68,15,88,206 // addps %xmm6,%xmm9 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 68,15,92,202 // subps %xmm2,%xmm9 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,88,215 // addps %xmm7,%xmm10 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 65,15,40,218 // movaps %xmm10,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_xor__sse2 .globl _sk_xor__sse2 FUNCTION(_sk_xor__sse2) _sk_xor__sse2: .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 15,40,29,200,96,0,0 // movaps 0x60c8(%rip),%xmm3 # 65b0 <_sk_callback_sse2+0x1f3> .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,92,207 // subps %xmm7,%xmm9 .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 65,15,92,216 // subps %xmm8,%xmm3 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,89,212 // mulps %xmm4,%xmm10 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,89,213 // mulps %xmm5,%xmm10 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,89,214 // mulps %xmm6,%xmm10 .byte 65,15,88,210 // addps %xmm10,%xmm2 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 65,15,88,217 // addps %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_darken_sse2 .globl _sk_darken_sse2 FUNCTION(_sk_darken_sse2) _sk_darken_sse2: .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 68,15,89,207 // mulps %xmm7,%xmm9 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 68,15,95,201 // maxps %xmm1,%xmm9 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 69,15,95,193 // maxps %xmm9,%xmm8 .byte 65,15,92,200 // subps %xmm8,%xmm1 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,88,198 // addps %xmm6,%xmm8 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,95,209 // maxps %xmm9,%xmm2 .byte 68,15,92,194 // subps %xmm2,%xmm8 .byte 15,40,21,51,96,0,0 // movaps 0x6033(%rip),%xmm2 # 65c0 <_sk_callback_sse2+0x203> .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_lighten_sse2 .globl _sk_lighten_sse2 FUNCTION(_sk_lighten_sse2) _sk_lighten_sse2: .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 68,15,89,207 // mulps %xmm7,%xmm9 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 68,15,93,201 // minps %xmm1,%xmm9 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 69,15,93,193 // minps %xmm9,%xmm8 .byte 65,15,92,200 // subps %xmm8,%xmm1 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,88,198 // addps %xmm6,%xmm8 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,93,209 // minps %xmm9,%xmm2 .byte 68,15,92,194 // subps %xmm2,%xmm8 .byte 15,40,21,216,95,0,0 // movaps 0x5fd8(%rip),%xmm2 # 65d0 <_sk_callback_sse2+0x213> .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_difference_sse2 .globl _sk_difference_sse2 FUNCTION(_sk_difference_sse2) _sk_difference_sse2: .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 68,15,89,207 // mulps %xmm7,%xmm9 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 68,15,93,201 // minps %xmm1,%xmm9 .byte 69,15,88,201 // addps %xmm9,%xmm9 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 69,15,93,193 // minps %xmm9,%xmm8 .byte 69,15,88,192 // addps %xmm8,%xmm8 .byte 65,15,92,200 // subps %xmm8,%xmm1 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,88,198 // addps %xmm6,%xmm8 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,93,209 // minps %xmm9,%xmm2 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 68,15,92,194 // subps %xmm2,%xmm8 .byte 15,40,21,114,95,0,0 // movaps 0x5f72(%rip),%xmm2 # 65e0 <_sk_callback_sse2+0x223> .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_exclusion_sse2 .globl _sk_exclusion_sse2 FUNCTION(_sk_exclusion_sse2) _sk_exclusion_sse2: .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 68,15,89,197 // mulps %xmm5,%xmm8 .byte 69,15,88,192 // addps %xmm8,%xmm8 .byte 65,15,92,200 // subps %xmm8,%xmm1 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,88,198 // addps %xmm6,%xmm8 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 68,15,92,194 // subps %xmm2,%xmm8 .byte 15,40,21,50,95,0,0 // movaps 0x5f32(%rip),%xmm2 # 65f0 <_sk_callback_sse2+0x233> .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_colorburn_sse2 .globl _sk_colorburn_sse2 FUNCTION(_sk_colorburn_sse2) _sk_colorburn_sse2: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 68,15,40,21,37,95,0,0 // movaps 0x5f25(%rip),%xmm10 # 6600 <_sk_callback_sse2+0x243> .byte 69,15,40,202 // movaps %xmm10,%xmm9 .byte 68,15,92,207 // subps %xmm7,%xmm9 .byte 69,15,40,217 // movaps %xmm9,%xmm11 .byte 69,15,89,216 // mulps %xmm8,%xmm11 .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 65,15,94,192 // divps %xmm8,%xmm0 .byte 68,15,40,231 // movaps %xmm7,%xmm12 .byte 68,15,93,224 // minps %xmm0,%xmm12 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 69,15,92,236 // subps %xmm12,%xmm13 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,235 // addps %xmm11,%xmm13 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 69,15,87,219 // xorps %xmm11,%xmm11 .byte 69,15,40,224 // movaps %xmm8,%xmm12 .byte 69,15,194,227,0 // cmpeqps %xmm11,%xmm12 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 69,15,84,196 // andps %xmm12,%xmm8 .byte 69,15,85,229 // andnps %xmm13,%xmm12 .byte 69,15,40,234 // movaps %xmm10,%xmm13 .byte 68,15,89,236 // mulps %xmm4,%xmm13 .byte 69,15,86,224 // orps %xmm8,%xmm12 .byte 68,15,40,196 // movaps %xmm4,%xmm8 .byte 68,15,194,199,0 // cmpeqps %xmm7,%xmm8 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 65,15,84,192 // andps %xmm8,%xmm0 .byte 69,15,85,196 // andnps %xmm12,%xmm8 .byte 65,15,86,192 // orps %xmm8,%xmm0 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 68,15,89,193 // mulps %xmm1,%xmm8 .byte 68,15,40,231 // movaps %xmm7,%xmm12 .byte 68,15,92,229 // subps %xmm5,%xmm12 .byte 68,15,89,227 // mulps %xmm3,%xmm12 .byte 68,15,94,225 // divps %xmm1,%xmm12 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 69,15,93,236 // minps %xmm12,%xmm13 .byte 68,15,40,231 // movaps %xmm7,%xmm12 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 68,15,40,233 // movaps %xmm1,%xmm13 .byte 69,15,194,235,0 // cmpeqps %xmm11,%xmm13 .byte 68,15,89,227 // mulps %xmm3,%xmm12 .byte 69,15,88,224 // addps %xmm8,%xmm12 .byte 65,15,84,205 // andps %xmm13,%xmm1 .byte 69,15,85,236 // andnps %xmm12,%xmm13 .byte 68,15,88,197 // addps %xmm5,%xmm8 .byte 68,15,86,233 // orps %xmm1,%xmm13 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 68,15,88,233 // addps %xmm1,%xmm13 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,194,207,0 // cmpeqps %xmm7,%xmm1 .byte 68,15,84,193 // andps %xmm1,%xmm8 .byte 65,15,85,205 // andnps %xmm13,%xmm1 .byte 68,15,86,193 // orps %xmm1,%xmm8 .byte 15,40,207 // movaps %xmm7,%xmm1 .byte 15,92,206 // subps %xmm6,%xmm1 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,94,202 // divps %xmm2,%xmm1 .byte 68,15,40,231 // movaps %xmm7,%xmm12 .byte 68,15,93,225 // minps %xmm1,%xmm12 .byte 15,40,207 // movaps %xmm7,%xmm1 .byte 65,15,92,204 // subps %xmm12,%xmm1 .byte 68,15,89,202 // mulps %xmm2,%xmm9 .byte 68,15,194,218,0 // cmpeqps %xmm2,%xmm11 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 65,15,84,211 // andps %xmm11,%xmm2 .byte 68,15,85,217 // andnps %xmm1,%xmm11 .byte 68,15,88,206 // addps %xmm6,%xmm9 .byte 68,15,86,218 // orps %xmm2,%xmm11 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 68,15,88,217 // addps %xmm1,%xmm11 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,194,207,0 // cmpeqps %xmm7,%xmm1 .byte 68,15,84,201 // andps %xmm1,%xmm9 .byte 65,15,85,203 // andnps %xmm11,%xmm1 .byte 68,15,86,201 // orps %xmm1,%xmm9 .byte 68,15,89,215 // mulps %xmm7,%xmm10 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_colordodge_sse2 .globl _sk_colordodge_sse2 FUNCTION(_sk_colordodge_sse2) _sk_colordodge_sse2: .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 68,15,40,21,219,93,0,0 // movaps 0x5ddb(%rip),%xmm10 # 6610 <_sk_callback_sse2+0x253> .byte 69,15,40,218 // movaps %xmm10,%xmm11 .byte 68,15,92,223 // subps %xmm7,%xmm11 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 69,15,89,225 // mulps %xmm9,%xmm12 .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 68,15,89,196 // mulps %xmm4,%xmm8 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 68,15,94,192 // divps %xmm0,%xmm8 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 65,15,93,192 // minps %xmm8,%xmm0 .byte 69,15,40,241 // movaps %xmm9,%xmm14 .byte 68,15,194,243,0 // cmpeqps %xmm3,%xmm14 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 65,15,88,196 // addps %xmm12,%xmm0 .byte 69,15,84,206 // andps %xmm14,%xmm9 .byte 68,15,85,240 // andnps %xmm0,%xmm14 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 65,15,40,196 // movaps %xmm12,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 68,15,92,211 // subps %xmm3,%xmm10 .byte 69,15,86,241 // orps %xmm9,%xmm14 .byte 69,15,40,202 // movaps %xmm10,%xmm9 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 69,15,88,241 // addps %xmm9,%xmm14 .byte 68,15,40,204 // movaps %xmm4,%xmm9 .byte 69,15,194,200,0 // cmpeqps %xmm8,%xmm9 .byte 65,15,84,193 // andps %xmm9,%xmm0 .byte 69,15,85,206 // andnps %xmm14,%xmm9 .byte 65,15,86,193 // orps %xmm9,%xmm0 .byte 68,15,40,203 // movaps %xmm3,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 68,15,40,227 // movaps %xmm3,%xmm12 .byte 68,15,92,225 // subps %xmm1,%xmm12 .byte 69,15,94,204 // divps %xmm12,%xmm9 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 68,15,89,225 // mulps %xmm1,%xmm12 .byte 69,15,93,233 // minps %xmm9,%xmm13 .byte 68,15,40,241 // movaps %xmm1,%xmm14 .byte 68,15,194,243,0 // cmpeqps %xmm3,%xmm14 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,236 // addps %xmm12,%xmm13 .byte 65,15,84,206 // andps %xmm14,%xmm1 .byte 69,15,85,245 // andnps %xmm13,%xmm14 .byte 69,15,40,204 // movaps %xmm12,%xmm9 .byte 68,15,88,205 // addps %xmm5,%xmm9 .byte 68,15,86,241 // orps %xmm1,%xmm14 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 68,15,88,241 // addps %xmm1,%xmm14 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 65,15,194,200,0 // cmpeqps %xmm8,%xmm1 .byte 68,15,84,201 // andps %xmm1,%xmm9 .byte 65,15,85,206 // andnps %xmm14,%xmm1 .byte 68,15,86,201 // orps %xmm1,%xmm9 .byte 68,15,40,227 // movaps %xmm3,%xmm12 .byte 68,15,89,230 // mulps %xmm6,%xmm12 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,92,202 // subps %xmm2,%xmm1 .byte 68,15,94,225 // divps %xmm1,%xmm12 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,93,236 // minps %xmm12,%xmm13 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,194,203,0 // cmpeqps %xmm3,%xmm1 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,235 // addps %xmm11,%xmm13 .byte 15,84,209 // andps %xmm1,%xmm2 .byte 65,15,85,205 // andnps %xmm13,%xmm1 .byte 15,86,202 // orps %xmm2,%xmm1 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 68,15,194,198,0 // cmpeqps %xmm6,%xmm8 .byte 68,15,88,222 // addps %xmm6,%xmm11 .byte 69,15,84,216 // andps %xmm8,%xmm11 .byte 68,15,85,193 // andnps %xmm1,%xmm8 .byte 69,15,86,195 // orps %xmm11,%xmm8 .byte 68,15,89,215 // mulps %xmm7,%xmm10 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_hardlight_sse2 .globl _sk_hardlight_sse2 FUNCTION(_sk_hardlight_sse2) _sk_hardlight_sse2: .byte 15,41,116,36,232 // movaps %xmm6,-0x18(%rsp) .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 68,15,40,29,144,92,0,0 // movaps 0x5c90(%rip),%xmm11 # 6620 <_sk_callback_sse2+0x263> .byte 69,15,40,211 // movaps %xmm11,%xmm10 .byte 68,15,92,215 // subps %xmm7,%xmm10 .byte 69,15,40,194 // movaps %xmm10,%xmm8 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 68,15,92,219 // subps %xmm3,%xmm11 .byte 69,15,40,203 // movaps %xmm11,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 69,15,88,200 // addps %xmm8,%xmm9 .byte 68,15,40,195 // movaps %xmm3,%xmm8 .byte 68,15,92,192 // subps %xmm0,%xmm8 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 68,15,40,247 // movaps %xmm7,%xmm14 .byte 68,15,40,255 // movaps %xmm7,%xmm15 .byte 68,15,92,253 // subps %xmm5,%xmm15 .byte 69,15,89,248 // mulps %xmm8,%xmm15 .byte 69,15,88,255 // addps %xmm15,%xmm15 .byte 68,15,40,228 // movaps %xmm4,%xmm12 .byte 69,15,92,231 // subps %xmm15,%xmm12 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 69,15,88,192 // addps %xmm8,%xmm8 .byte 68,15,194,195,2 // cmpleps %xmm3,%xmm8 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 65,15,84,192 // andps %xmm8,%xmm0 .byte 69,15,85,196 // andnps %xmm12,%xmm8 .byte 68,15,86,192 // orps %xmm0,%xmm8 .byte 69,15,40,251 // movaps %xmm11,%xmm15 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 68,15,89,223 // mulps %xmm7,%xmm11 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 68,15,89,254 // mulps %xmm6,%xmm15 .byte 68,15,88,248 // addps %xmm0,%xmm15 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 68,15,92,238 // subps %xmm6,%xmm13 .byte 68,15,89,232 // mulps %xmm0,%xmm13 .byte 69,15,88,237 // addps %xmm13,%xmm13 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 65,15,92,197 // subps %xmm13,%xmm0 .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 69,15,88,201 // addps %xmm9,%xmm9 .byte 68,15,194,203,2 // cmpleps %xmm3,%xmm9 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 65,15,84,201 // andps %xmm9,%xmm1 .byte 68,15,85,200 // andnps %xmm0,%xmm9 .byte 68,15,86,201 // orps %xmm1,%xmm9 .byte 69,15,88,207 // addps %xmm15,%xmm9 .byte 68,15,89,210 // mulps %xmm2,%xmm10 .byte 68,15,40,108,36,232 // movaps -0x18(%rsp),%xmm13 .byte 69,15,89,229 // mulps %xmm13,%xmm12 .byte 69,15,88,226 // addps %xmm10,%xmm12 .byte 68,15,40,210 // movaps %xmm2,%xmm10 .byte 69,15,88,210 // addps %xmm10,%xmm10 .byte 68,15,194,211,2 // cmpleps %xmm3,%xmm10 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,92,194 // subps %xmm2,%xmm0 .byte 65,15,89,213 // mulps %xmm13,%xmm2 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 69,15,92,245 // subps %xmm13,%xmm14 .byte 68,15,89,240 // mulps %xmm0,%xmm14 .byte 69,15,88,246 // addps %xmm14,%xmm14 .byte 65,15,92,230 // subps %xmm14,%xmm4 .byte 65,15,84,210 // andps %xmm10,%xmm2 .byte 68,15,85,212 // andnps %xmm4,%xmm10 .byte 68,15,86,210 // orps %xmm2,%xmm10 .byte 69,15,88,212 // addps %xmm12,%xmm10 .byte 65,15,88,219 // addps %xmm11,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,40,238 // movaps %xmm6,%xmm5 .byte 65,15,40,245 // movaps %xmm13,%xmm6 .byte 255,224 // jmpq *%rax HIDDEN _sk_overlay_sse2 .globl _sk_overlay_sse2 FUNCTION(_sk_overlay_sse2) _sk_overlay_sse2: .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 68,15,40,232 // movaps %xmm0,%xmm13 .byte 68,15,40,13,94,91,0,0 // movaps 0x5b5e(%rip),%xmm9 # 6630 <_sk_callback_sse2+0x273> .byte 69,15,40,209 // movaps %xmm9,%xmm10 .byte 68,15,92,215 // subps %xmm7,%xmm10 .byte 69,15,40,218 // movaps %xmm10,%xmm11 .byte 69,15,89,221 // mulps %xmm13,%xmm11 .byte 68,15,92,203 // subps %xmm3,%xmm9 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 65,15,88,195 // addps %xmm11,%xmm0 .byte 68,15,40,227 // movaps %xmm3,%xmm12 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 68,15,89,236 // mulps %xmm4,%xmm13 .byte 68,15,40,247 // movaps %xmm7,%xmm14 .byte 68,15,92,244 // subps %xmm4,%xmm14 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,194,207,2 // cmpleps %xmm7,%xmm1 .byte 69,15,88,237 // addps %xmm13,%xmm13 .byte 68,15,40,219 // movaps %xmm3,%xmm11 .byte 68,15,89,223 // mulps %xmm7,%xmm11 .byte 69,15,89,244 // mulps %xmm12,%xmm14 .byte 69,15,88,246 // addps %xmm14,%xmm14 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 69,15,92,230 // subps %xmm14,%xmm12 .byte 68,15,84,233 // andps %xmm1,%xmm13 .byte 65,15,85,204 // andnps %xmm12,%xmm1 .byte 65,15,86,205 // orps %xmm13,%xmm1 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 69,15,40,226 // movaps %xmm10,%xmm12 .byte 69,15,89,224 // mulps %xmm8,%xmm12 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 65,15,88,204 // addps %xmm12,%xmm1 .byte 68,15,40,227 // movaps %xmm3,%xmm12 .byte 69,15,92,224 // subps %xmm8,%xmm12 .byte 68,15,89,197 // mulps %xmm5,%xmm8 .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 68,15,92,237 // subps %xmm5,%xmm13 .byte 68,15,40,245 // movaps %xmm5,%xmm14 .byte 69,15,88,246 // addps %xmm14,%xmm14 .byte 68,15,194,247,2 // cmpleps %xmm7,%xmm14 .byte 69,15,88,192 // addps %xmm8,%xmm8 .byte 69,15,89,236 // mulps %xmm12,%xmm13 .byte 69,15,88,237 // addps %xmm13,%xmm13 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 69,15,84,198 // andps %xmm14,%xmm8 .byte 69,15,85,244 // andnps %xmm12,%xmm14 .byte 69,15,86,240 // orps %xmm8,%xmm14 .byte 65,15,88,206 // addps %xmm14,%xmm1 .byte 68,15,89,210 // mulps %xmm2,%xmm10 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 68,15,89,198 // mulps %xmm6,%xmm8 .byte 69,15,88,194 // addps %xmm10,%xmm8 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,92,210 // subps %xmm2,%xmm10 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 68,15,40,231 // movaps %xmm7,%xmm12 .byte 68,15,92,230 // subps %xmm6,%xmm12 .byte 68,15,40,238 // movaps %xmm6,%xmm13 .byte 69,15,88,237 // addps %xmm13,%xmm13 .byte 68,15,194,239,2 // cmpleps %xmm7,%xmm13 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 69,15,88,228 // addps %xmm12,%xmm12 .byte 69,15,92,220 // subps %xmm12,%xmm11 .byte 65,15,84,213 // andps %xmm13,%xmm2 .byte 69,15,85,235 // andnps %xmm11,%xmm13 .byte 68,15,86,234 // orps %xmm2,%xmm13 .byte 69,15,88,197 // addps %xmm13,%xmm8 .byte 68,15,89,207 // mulps %xmm7,%xmm9 .byte 65,15,88,217 // addps %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_softlight_sse2 .globl _sk_softlight_sse2 FUNCTION(_sk_softlight_sse2) _sk_softlight_sse2: .byte 15,41,116,36,216 // movaps %xmm6,-0x28(%rsp) .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,41,84,36,232 // movaps %xmm2,-0x18(%rsp) .byte 15,40,209 // movaps %xmm1,%xmm2 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 69,15,87,228 // xorps %xmm12,%xmm12 .byte 68,15,194,231,1 // cmpltps %xmm7,%xmm12 .byte 68,15,40,213 // movaps %xmm5,%xmm10 .byte 68,15,94,215 // divps %xmm7,%xmm10 .byte 69,15,84,212 // andps %xmm12,%xmm10 .byte 68,15,40,13,27,90,0,0 // movaps 0x5a1b(%rip),%xmm9 # 6640 <_sk_callback_sse2+0x283> .byte 69,15,40,249 // movaps %xmm9,%xmm15 .byte 69,15,92,250 // subps %xmm10,%xmm15 .byte 69,15,40,218 // movaps %xmm10,%xmm11 .byte 69,15,40,234 // movaps %xmm10,%xmm13 .byte 65,15,82,194 // rsqrtps %xmm10,%xmm0 .byte 15,83,200 // rcpps %xmm0,%xmm1 .byte 65,15,92,202 // subps %xmm10,%xmm1 .byte 69,15,88,210 // addps %xmm10,%xmm10 .byte 69,15,88,210 // addps %xmm10,%xmm10 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 68,15,40,53,245,89,0,0 // movaps 0x59f5(%rip),%xmm14 # 6650 <_sk_callback_sse2+0x293> .byte 69,15,88,222 // addps %xmm14,%xmm11 .byte 68,15,89,216 // mulps %xmm0,%xmm11 .byte 68,15,40,21,245,89,0,0 // movaps 0x59f5(%rip),%xmm10 # 6660 <_sk_callback_sse2+0x2a3> .byte 69,15,89,234 // mulps %xmm10,%xmm13 .byte 69,15,88,235 // addps %xmm11,%xmm13 .byte 15,88,228 // addps %xmm4,%xmm4 .byte 15,88,228 // addps %xmm4,%xmm4 .byte 15,194,231,2 // cmpleps %xmm7,%xmm4 .byte 68,15,84,236 // andps %xmm4,%xmm13 .byte 15,85,225 // andnps %xmm1,%xmm4 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 65,15,86,229 // orps %xmm13,%xmm4 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,92,203 // subps %xmm3,%xmm1 .byte 68,15,89,249 // mulps %xmm1,%xmm15 .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 69,15,40,217 // movaps %xmm9,%xmm11 .byte 68,15,92,219 // subps %xmm3,%xmm11 .byte 65,15,40,203 // movaps %xmm11,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 68,15,92,239 // subps %xmm7,%xmm13 .byte 69,15,89,197 // mulps %xmm13,%xmm8 .byte 68,15,88,193 // addps %xmm1,%xmm8 .byte 68,15,88,251 // addps %xmm3,%xmm15 .byte 68,15,89,253 // mulps %xmm5,%xmm15 .byte 15,194,195,2 // cmpleps %xmm3,%xmm0 .byte 68,15,84,248 // andps %xmm0,%xmm15 .byte 15,85,196 // andnps %xmm4,%xmm0 .byte 65,15,86,199 // orps %xmm15,%xmm0 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 68,15,40,198 // movaps %xmm6,%xmm8 .byte 68,15,94,199 // divps %xmm7,%xmm8 .byte 69,15,84,196 // andps %xmm12,%xmm8 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,89,228 // mulps %xmm4,%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 65,15,88,206 // addps %xmm14,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 69,15,40,249 // movaps %xmm9,%xmm15 .byte 69,15,92,248 // subps %xmm8,%xmm15 .byte 65,15,82,224 // rsqrtps %xmm8,%xmm4 .byte 15,83,228 // rcpps %xmm4,%xmm4 .byte 65,15,92,224 // subps %xmm8,%xmm4 .byte 69,15,89,194 // mulps %xmm10,%xmm8 .byte 68,15,88,193 // addps %xmm1,%xmm8 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,194,207,2 // cmpleps %xmm7,%xmm1 .byte 68,15,84,193 // andps %xmm1,%xmm8 .byte 15,85,204 // andnps %xmm4,%xmm1 .byte 65,15,86,200 // orps %xmm8,%xmm1 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 69,15,88,192 // addps %xmm8,%xmm8 .byte 65,15,40,224 // movaps %xmm8,%xmm4 .byte 15,92,227 // subps %xmm3,%xmm4 .byte 68,15,89,252 // mulps %xmm4,%xmm15 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,89,230 // mulps %xmm6,%xmm4 .byte 15,88,204 // addps %xmm4,%xmm1 .byte 65,15,40,227 // movaps %xmm11,%xmm4 .byte 15,89,230 // mulps %xmm6,%xmm4 .byte 65,15,89,213 // mulps %xmm13,%xmm2 .byte 15,88,212 // addps %xmm4,%xmm2 .byte 68,15,88,251 // addps %xmm3,%xmm15 .byte 68,15,89,254 // mulps %xmm6,%xmm15 .byte 68,15,194,195,2 // cmpleps %xmm3,%xmm8 .byte 69,15,84,248 // andps %xmm8,%xmm15 .byte 68,15,85,193 // andnps %xmm1,%xmm8 .byte 69,15,86,199 // orps %xmm15,%xmm8 .byte 68,15,88,194 // addps %xmm2,%xmm8 .byte 68,15,40,124,36,216 // movaps -0x28(%rsp),%xmm15 .byte 65,15,40,207 // movaps %xmm15,%xmm1 .byte 15,94,207 // divps %xmm7,%xmm1 .byte 65,15,84,204 // andps %xmm12,%xmm1 .byte 68,15,92,201 // subps %xmm1,%xmm9 .byte 68,15,88,241 // addps %xmm1,%xmm14 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 15,82,209 // rsqrtps %xmm1,%xmm2 .byte 15,83,210 // rcpps %xmm2,%xmm2 .byte 15,92,209 // subps %xmm1,%xmm2 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,89,228 // mulps %xmm4,%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 68,15,89,244 // mulps %xmm4,%xmm14 .byte 69,15,88,214 // addps %xmm14,%xmm10 .byte 65,15,40,207 // movaps %xmm15,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,194,207,2 // cmpleps %xmm7,%xmm1 .byte 68,15,84,209 // andps %xmm1,%xmm10 .byte 15,85,202 // andnps %xmm2,%xmm1 .byte 15,40,84,36,232 // movaps -0x18(%rsp),%xmm2 .byte 68,15,89,234 // mulps %xmm2,%xmm13 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 65,15,86,202 // orps %xmm10,%xmm1 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,92,227 // subps %xmm3,%xmm4 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 65,15,89,231 // mulps %xmm15,%xmm4 .byte 15,88,204 // addps %xmm4,%xmm1 .byte 65,15,40,227 // movaps %xmm11,%xmm4 .byte 65,15,89,231 // mulps %xmm15,%xmm4 .byte 65,15,88,229 // addps %xmm13,%xmm4 .byte 68,15,88,203 // addps %xmm3,%xmm9 .byte 69,15,89,207 // mulps %xmm15,%xmm9 .byte 69,15,40,215 // movaps %xmm15,%xmm10 .byte 15,194,211,2 // cmpleps %xmm3,%xmm2 .byte 68,15,84,202 // andps %xmm2,%xmm9 .byte 15,85,209 // andnps %xmm1,%xmm2 .byte 65,15,86,209 // orps %xmm9,%xmm2 .byte 15,88,212 // addps %xmm4,%xmm2 .byte 68,15,89,223 // mulps %xmm7,%xmm11 .byte 65,15,88,219 // addps %xmm11,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,40,238 // movaps %xmm6,%xmm5 .byte 65,15,40,242 // movaps %xmm10,%xmm6 .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_hue_sse2 .globl _sk_hue_sse2 FUNCTION(_sk_hue_sse2) _sk_hue_sse2: .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 68,15,40,225 // movaps %xmm1,%xmm12 .byte 68,15,89,211 // mulps %xmm3,%xmm10 .byte 68,15,40,5,56,88,0,0 // movaps 0x5838(%rip),%xmm8 # 66a0 <_sk_callback_sse2+0x2e3> .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 15,40,207 // movaps %xmm7,%xmm1 .byte 68,15,92,217 // subps %xmm1,%xmm11 .byte 65,15,89,195 // mulps %xmm11,%xmm0 .byte 15,41,68,36,232 // movaps %xmm0,-0x18(%rsp) .byte 69,15,89,227 // mulps %xmm11,%xmm12 .byte 68,15,41,100,36,216 // movaps %xmm12,-0x28(%rsp) .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 68,15,40,229 // movaps %xmm5,%xmm12 .byte 68,15,40,237 // movaps %xmm5,%xmm13 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,41,68,36,200 // movaps %xmm0,-0x38(%rsp) .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 68,15,95,239 // maxps %xmm7,%xmm13 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 68,15,40,245 // movaps %xmm5,%xmm14 .byte 68,15,40,253 // movaps %xmm5,%xmm15 .byte 69,15,95,253 // maxps %xmm13,%xmm15 .byte 68,15,93,231 // minps %xmm7,%xmm12 .byte 69,15,93,244 // minps %xmm12,%xmm14 .byte 69,15,92,254 // subps %xmm14,%xmm15 .byte 69,15,40,226 // movaps %xmm10,%xmm12 .byte 68,15,93,226 // minps %xmm2,%xmm12 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 69,15,93,236 // minps %xmm12,%xmm13 .byte 69,15,40,226 // movaps %xmm10,%xmm12 .byte 68,15,95,226 // maxps %xmm2,%xmm12 .byte 69,15,40,241 // movaps %xmm9,%xmm14 .byte 69,15,95,244 // maxps %xmm12,%xmm14 .byte 69,15,92,245 // subps %xmm13,%xmm14 .byte 69,15,92,205 // subps %xmm13,%xmm9 .byte 69,15,92,213 // subps %xmm13,%xmm10 .byte 65,15,92,213 // subps %xmm13,%xmm2 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 68,15,89,251 // mulps %xmm3,%xmm15 .byte 69,15,89,207 // mulps %xmm15,%xmm9 .byte 69,15,89,215 // mulps %xmm15,%xmm10 .byte 65,15,89,215 // mulps %xmm15,%xmm2 .byte 69,15,87,228 // xorps %xmm12,%xmm12 .byte 69,15,94,206 // divps %xmm14,%xmm9 .byte 69,15,94,214 // divps %xmm14,%xmm10 .byte 65,15,94,214 // divps %xmm14,%xmm2 .byte 69,15,194,244,4 // cmpneqps %xmm12,%xmm14 .byte 69,15,84,206 // andps %xmm14,%xmm9 .byte 69,15,84,214 // andps %xmm14,%xmm10 .byte 65,15,84,214 // andps %xmm14,%xmm2 .byte 68,15,40,61,69,87,0,0 // movaps 0x5745(%rip),%xmm15 # 6670 <_sk_callback_sse2+0x2b3> .byte 65,15,89,231 // mulps %xmm15,%xmm4 .byte 15,40,5,74,87,0,0 // movaps 0x574a(%rip),%xmm0 # 6680 <_sk_callback_sse2+0x2c3> .byte 15,89,240 // mulps %xmm0,%xmm6 .byte 15,88,244 // addps %xmm4,%xmm6 .byte 68,15,40,53,76,87,0,0 // movaps 0x574c(%rip),%xmm14 # 6690 <_sk_callback_sse2+0x2d3> .byte 68,15,40,239 // movaps %xmm7,%xmm13 .byte 69,15,89,238 // mulps %xmm14,%xmm13 .byte 68,15,88,238 // addps %xmm6,%xmm13 .byte 65,15,40,225 // movaps %xmm9,%xmm4 .byte 65,15,89,231 // mulps %xmm15,%xmm4 .byte 65,15,40,242 // movaps %xmm10,%xmm6 .byte 15,89,240 // mulps %xmm0,%xmm6 .byte 15,88,244 // addps %xmm4,%xmm6 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 65,15,89,230 // mulps %xmm14,%xmm4 .byte 15,88,230 // addps %xmm6,%xmm4 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 68,15,92,236 // subps %xmm4,%xmm13 .byte 69,15,88,205 // addps %xmm13,%xmm9 .byte 69,15,88,213 // addps %xmm13,%xmm10 .byte 68,15,88,234 // addps %xmm2,%xmm13 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 65,15,93,213 // minps %xmm13,%xmm2 .byte 65,15,40,241 // movaps %xmm9,%xmm6 .byte 15,93,242 // minps %xmm2,%xmm6 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 65,15,95,213 // maxps %xmm13,%xmm2 .byte 65,15,40,225 // movaps %xmm9,%xmm4 .byte 15,95,226 // maxps %xmm2,%xmm4 .byte 69,15,89,249 // mulps %xmm9,%xmm15 .byte 65,15,89,194 // mulps %xmm10,%xmm0 .byte 65,15,88,199 // addps %xmm15,%xmm0 .byte 69,15,89,245 // mulps %xmm13,%xmm14 .byte 68,15,88,240 // addps %xmm0,%xmm14 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 15,194,214,2 // cmpleps %xmm6,%xmm2 .byte 69,15,40,254 // movaps %xmm14,%xmm15 .byte 68,15,92,254 // subps %xmm6,%xmm15 .byte 65,15,40,241 // movaps %xmm9,%xmm6 .byte 65,15,92,246 // subps %xmm14,%xmm6 .byte 65,15,89,246 // mulps %xmm14,%xmm6 .byte 65,15,94,247 // divps %xmm15,%xmm6 .byte 65,15,88,246 // addps %xmm14,%xmm6 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,85,198 // andnps %xmm6,%xmm0 .byte 68,15,84,202 // andps %xmm2,%xmm9 .byte 68,15,86,200 // orps %xmm0,%xmm9 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,41,76,36,184 // movaps %xmm1,-0x48(%rsp) .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 15,92,216 // subps %xmm0,%xmm3 .byte 15,41,92,36,168 // movaps %xmm3,-0x58(%rsp) .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,194,196,1 // cmpltps %xmm4,%xmm0 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 65,15,85,201 // andnps %xmm9,%xmm1 .byte 69,15,92,206 // subps %xmm14,%xmm9 .byte 65,15,92,246 // subps %xmm14,%xmm6 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 65,15,92,230 // subps %xmm14,%xmm4 .byte 68,15,94,204 // divps %xmm4,%xmm9 .byte 69,15,88,206 // addps %xmm14,%xmm9 .byte 68,15,84,200 // andps %xmm0,%xmm9 .byte 68,15,86,201 // orps %xmm1,%xmm9 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 65,15,92,206 // subps %xmm14,%xmm1 .byte 65,15,89,206 // mulps %xmm14,%xmm1 .byte 65,15,94,207 // divps %xmm15,%xmm1 .byte 65,15,88,206 // addps %xmm14,%xmm1 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,85,217 // andnps %xmm1,%xmm3 .byte 68,15,84,210 // andps %xmm2,%xmm10 .byte 68,15,86,211 // orps %xmm3,%xmm10 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 65,15,85,202 // andnps %xmm10,%xmm1 .byte 69,15,92,214 // subps %xmm14,%xmm10 .byte 68,15,89,214 // mulps %xmm6,%xmm10 .byte 68,15,94,212 // divps %xmm4,%xmm10 .byte 69,15,88,214 // addps %xmm14,%xmm10 .byte 68,15,84,208 // andps %xmm0,%xmm10 .byte 68,15,86,209 // orps %xmm1,%xmm10 .byte 65,15,40,205 // movaps %xmm13,%xmm1 .byte 65,15,92,206 // subps %xmm14,%xmm1 .byte 65,15,89,206 // mulps %xmm14,%xmm1 .byte 65,15,94,207 // divps %xmm15,%xmm1 .byte 65,15,88,206 // addps %xmm14,%xmm1 .byte 68,15,84,234 // andps %xmm2,%xmm13 .byte 15,85,209 // andnps %xmm1,%xmm2 .byte 65,15,86,213 // orps %xmm13,%xmm2 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,85,202 // andnps %xmm2,%xmm1 .byte 65,15,92,214 // subps %xmm14,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,94,212 // divps %xmm4,%xmm2 .byte 65,15,88,214 // addps %xmm14,%xmm2 .byte 15,84,208 // andps %xmm0,%xmm2 .byte 15,86,209 // orps %xmm1,%xmm2 .byte 69,15,95,204 // maxps %xmm12,%xmm9 .byte 69,15,95,212 // maxps %xmm12,%xmm10 .byte 65,15,95,212 // maxps %xmm12,%xmm2 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,40,76,36,232 // movaps -0x18(%rsp),%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 15,40,116,36,200 // movaps -0x38(%rsp),%xmm6 .byte 15,89,222 // mulps %xmm6,%xmm3 .byte 15,40,76,36,216 // movaps -0x28(%rsp),%xmm1 .byte 15,88,203 // addps %xmm3,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 69,15,88,195 // addps %xmm11,%xmm8 .byte 68,15,88,194 // addps %xmm2,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,40,238 // movaps %xmm6,%xmm5 .byte 15,40,247 // movaps %xmm7,%xmm6 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 15,40,92,36,168 // movaps -0x58(%rsp),%xmm3 .byte 15,40,124,36,184 // movaps -0x48(%rsp),%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_saturation_sse2 .globl _sk_saturation_sse2 FUNCTION(_sk_saturation_sse2) _sk_saturation_sse2: .byte 68,15,40,231 // movaps %xmm7,%xmm12 .byte 68,15,40,198 // movaps %xmm6,%xmm8 .byte 15,40,251 // movaps %xmm3,%xmm7 .byte 68,15,40,216 // movaps %xmm0,%xmm11 .byte 68,15,40,215 // movaps %xmm7,%xmm10 .byte 68,15,89,212 // mulps %xmm4,%xmm10 .byte 15,40,244 // movaps %xmm4,%xmm6 .byte 15,41,116,36,184 // movaps %xmm6,-0x48(%rsp) .byte 68,15,40,207 // movaps %xmm7,%xmm9 .byte 68,15,89,205 // mulps %xmm5,%xmm9 .byte 15,41,108,36,200 // movaps %xmm5,-0x38(%rsp) .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 69,15,40,232 // movaps %xmm8,%xmm13 .byte 68,15,41,108,36,168 // movaps %xmm13,-0x58(%rsp) .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,41,100,36,216 // movaps %xmm4,-0x28(%rsp) .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,41,84,36,232 // movaps %xmm2,-0x18(%rsp) .byte 15,95,218 // maxps %xmm2,%xmm3 .byte 65,15,40,203 // movaps %xmm11,%xmm1 .byte 15,95,203 // maxps %xmm3,%xmm1 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,93,218 // minps %xmm2,%xmm3 .byte 65,15,40,211 // movaps %xmm11,%xmm2 .byte 15,93,211 // minps %xmm3,%xmm2 .byte 15,92,202 // subps %xmm2,%xmm1 .byte 65,15,89,204 // mulps %xmm12,%xmm1 .byte 65,15,40,228 // movaps %xmm12,%xmm4 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 15,93,208 // minps %xmm0,%xmm2 .byte 69,15,40,194 // movaps %xmm10,%xmm8 .byte 68,15,93,194 // minps %xmm2,%xmm8 .byte 65,15,40,209 // movaps %xmm9,%xmm2 .byte 15,95,208 // maxps %xmm0,%xmm2 .byte 65,15,40,218 // movaps %xmm10,%xmm3 .byte 15,95,218 // maxps %xmm2,%xmm3 .byte 65,15,92,216 // subps %xmm8,%xmm3 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 69,15,92,208 // subps %xmm8,%xmm10 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 68,15,94,211 // divps %xmm3,%xmm10 .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,89,201 // mulps %xmm1,%xmm9 .byte 68,15,94,203 // divps %xmm3,%xmm9 .byte 65,15,92,192 // subps %xmm8,%xmm0 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,94,195 // divps %xmm3,%xmm0 .byte 15,194,218,4 // cmpneqps %xmm2,%xmm3 .byte 68,15,84,211 // andps %xmm3,%xmm10 .byte 68,15,84,203 // andps %xmm3,%xmm9 .byte 15,84,195 // andps %xmm3,%xmm0 .byte 68,15,40,5,222,84,0,0 // movaps 0x54de(%rip),%xmm8 # 66b0 <_sk_callback_sse2+0x2f3> .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,40,13,224,84,0,0 // movaps 0x54e0(%rip),%xmm1 # 66c0 <_sk_callback_sse2+0x303> .byte 15,40,221 // movaps %xmm5,%xmm3 .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 68,15,40,37,223,84,0,0 // movaps 0x54df(%rip),%xmm12 # 66d0 <_sk_callback_sse2+0x313> .byte 69,15,89,236 // mulps %xmm12,%xmm13 .byte 68,15,88,235 // addps %xmm3,%xmm13 .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 65,15,40,217 // movaps %xmm9,%xmm3 .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 65,15,89,212 // mulps %xmm12,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 68,15,89,239 // mulps %xmm7,%xmm13 .byte 68,15,92,234 // subps %xmm2,%xmm13 .byte 69,15,88,213 // addps %xmm13,%xmm10 .byte 69,15,88,205 // addps %xmm13,%xmm9 .byte 68,15,88,232 // addps %xmm0,%xmm13 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,93,197 // minps %xmm13,%xmm0 .byte 65,15,40,218 // movaps %xmm10,%xmm3 .byte 15,93,216 // minps %xmm0,%xmm3 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,95,197 // maxps %xmm13,%xmm0 .byte 69,15,40,242 // movaps %xmm10,%xmm14 .byte 68,15,95,240 // maxps %xmm0,%xmm14 .byte 69,15,89,194 // mulps %xmm10,%xmm8 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 65,15,88,200 // addps %xmm8,%xmm1 .byte 69,15,89,229 // mulps %xmm13,%xmm12 .byte 68,15,88,225 // addps %xmm1,%xmm12 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 15,194,211,2 // cmpleps %xmm3,%xmm2 .byte 65,15,40,244 // movaps %xmm12,%xmm6 .byte 15,92,243 // subps %xmm3,%xmm6 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 65,15,92,196 // subps %xmm12,%xmm0 .byte 65,15,89,196 // mulps %xmm12,%xmm0 .byte 15,94,198 // divps %xmm6,%xmm0 .byte 65,15,88,196 // addps %xmm12,%xmm0 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,85,200 // andnps %xmm0,%xmm1 .byte 68,15,84,210 // andps %xmm2,%xmm10 .byte 68,15,86,209 // orps %xmm1,%xmm10 .byte 15,40,223 // movaps %xmm7,%xmm3 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 68,15,40,5,68,84,0,0 // movaps 0x5444(%rip),%xmm8 # 66e0 <_sk_callback_sse2+0x323> .byte 65,15,40,224 // movaps %xmm8,%xmm4 .byte 68,15,92,199 // subps %xmm7,%xmm8 .byte 15,88,253 // addps %xmm5,%xmm7 .byte 15,92,251 // subps %xmm3,%xmm7 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 65,15,194,222,1 // cmpltps %xmm14,%xmm3 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 65,15,85,194 // andnps %xmm10,%xmm0 .byte 69,15,92,212 // subps %xmm12,%xmm10 .byte 65,15,92,204 // subps %xmm12,%xmm1 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 69,15,92,244 // subps %xmm12,%xmm14 .byte 69,15,94,214 // divps %xmm14,%xmm10 .byte 69,15,88,212 // addps %xmm12,%xmm10 .byte 68,15,84,211 // andps %xmm3,%xmm10 .byte 68,15,86,208 // orps %xmm0,%xmm10 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,92,196 // subps %xmm12,%xmm0 .byte 65,15,89,196 // mulps %xmm12,%xmm0 .byte 15,94,198 // divps %xmm6,%xmm0 .byte 65,15,88,196 // addps %xmm12,%xmm0 .byte 68,15,40,250 // movaps %xmm2,%xmm15 .byte 68,15,85,248 // andnps %xmm0,%xmm15 .byte 68,15,84,202 // andps %xmm2,%xmm9 .byte 69,15,86,207 // orps %xmm15,%xmm9 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 65,15,85,193 // andnps %xmm9,%xmm0 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 68,15,89,201 // mulps %xmm1,%xmm9 .byte 69,15,94,206 // divps %xmm14,%xmm9 .byte 69,15,88,204 // addps %xmm12,%xmm9 .byte 68,15,84,203 // andps %xmm3,%xmm9 .byte 68,15,86,200 // orps %xmm0,%xmm9 .byte 65,15,40,197 // movaps %xmm13,%xmm0 .byte 65,15,92,196 // subps %xmm12,%xmm0 .byte 65,15,89,196 // mulps %xmm12,%xmm0 .byte 15,94,198 // divps %xmm6,%xmm0 .byte 65,15,88,196 // addps %xmm12,%xmm0 .byte 68,15,84,234 // andps %xmm2,%xmm13 .byte 15,85,208 // andnps %xmm0,%xmm2 .byte 65,15,86,213 // orps %xmm13,%xmm2 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,85,194 // andnps %xmm2,%xmm0 .byte 65,15,92,212 // subps %xmm12,%xmm2 .byte 15,89,209 // mulps %xmm1,%xmm2 .byte 65,15,94,214 // divps %xmm14,%xmm2 .byte 65,15,88,212 // addps %xmm12,%xmm2 .byte 15,84,211 // andps %xmm3,%xmm2 .byte 15,86,208 // orps %xmm0,%xmm2 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 68,15,95,208 // maxps %xmm0,%xmm10 .byte 68,15,95,200 // maxps %xmm0,%xmm9 .byte 15,95,208 // maxps %xmm0,%xmm2 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,40,92,36,184 // movaps -0x48(%rsp),%xmm3 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 68,15,40,229 // movaps %xmm5,%xmm12 .byte 65,15,92,228 // subps %xmm12,%xmm4 .byte 68,15,89,220 // mulps %xmm4,%xmm11 .byte 68,15,88,216 // addps %xmm0,%xmm11 .byte 69,15,88,218 // addps %xmm10,%xmm11 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,40,108,36,200 // movaps -0x38(%rsp),%xmm5 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,40,76,36,216 // movaps -0x28(%rsp),%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 15,89,100,36,232 // mulps -0x18(%rsp),%xmm4 .byte 15,40,68,36,168 // movaps -0x58(%rsp),%xmm0 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 68,15,88,196 // addps %xmm4,%xmm8 .byte 68,15,88,194 // addps %xmm2,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 15,40,223 // movaps %xmm7,%xmm3 .byte 65,15,40,252 // movaps %xmm12,%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_color_sse2 .globl _sk_color_sse2 FUNCTION(_sk_color_sse2) _sk_color_sse2: .byte 68,15,40,199 // movaps %xmm7,%xmm8 .byte 68,15,40,230 // movaps %xmm6,%xmm12 .byte 68,15,41,100,36,216 // movaps %xmm12,-0x28(%rsp) .byte 68,15,40,221 // movaps %xmm5,%xmm11 .byte 68,15,41,92,36,232 // movaps %xmm11,-0x18(%rsp) .byte 15,40,244 // movaps %xmm4,%xmm6 .byte 15,41,84,36,184 // movaps %xmm2,-0x48(%rsp) .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,40,248 // movaps %xmm0,%xmm7 .byte 68,15,40,207 // movaps %xmm7,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 68,15,40,213 // movaps %xmm5,%xmm10 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 68,15,40,45,226,82,0,0 // movaps 0x52e2(%rip),%xmm13 # 66f0 <_sk_callback_sse2+0x333> .byte 68,15,40,198 // movaps %xmm6,%xmm8 .byte 69,15,89,197 // mulps %xmm13,%xmm8 .byte 68,15,40,53,226,82,0,0 // movaps 0x52e2(%rip),%xmm14 # 6700 <_sk_callback_sse2+0x343> .byte 65,15,40,195 // movaps %xmm11,%xmm0 .byte 65,15,89,198 // mulps %xmm14,%xmm0 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 68,15,40,29,222,82,0,0 // movaps 0x52de(%rip),%xmm11 # 6710 <_sk_callback_sse2+0x353> .byte 69,15,89,227 // mulps %xmm11,%xmm12 .byte 68,15,88,224 // addps %xmm0,%xmm12 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,89,197 // mulps %xmm13,%xmm0 .byte 69,15,40,250 // movaps %xmm10,%xmm15 .byte 69,15,89,254 // mulps %xmm14,%xmm15 .byte 68,15,88,248 // addps %xmm0,%xmm15 .byte 68,15,40,5,202,82,0,0 // movaps 0x52ca(%rip),%xmm8 # 6720 <_sk_callback_sse2+0x363> .byte 65,15,40,224 // movaps %xmm8,%xmm4 .byte 15,92,226 // subps %xmm2,%xmm4 .byte 15,89,252 // mulps %xmm4,%xmm7 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,40,76,36,184 // movaps -0x48(%rsp),%xmm1 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 65,15,89,195 // mulps %xmm11,%xmm0 .byte 65,15,88,199 // addps %xmm15,%xmm0 .byte 68,15,89,227 // mulps %xmm3,%xmm12 .byte 68,15,92,224 // subps %xmm0,%xmm12 .byte 69,15,88,204 // addps %xmm12,%xmm9 .byte 69,15,88,212 // addps %xmm12,%xmm10 .byte 68,15,88,225 // addps %xmm1,%xmm12 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 65,15,93,196 // minps %xmm12,%xmm0 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 15,93,200 // minps %xmm0,%xmm1 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 65,15,95,196 // maxps %xmm12,%xmm0 .byte 69,15,40,249 // movaps %xmm9,%xmm15 .byte 68,15,95,248 // maxps %xmm0,%xmm15 .byte 69,15,89,233 // mulps %xmm9,%xmm13 .byte 69,15,89,242 // mulps %xmm10,%xmm14 .byte 69,15,88,245 // addps %xmm13,%xmm14 .byte 69,15,89,220 // mulps %xmm12,%xmm11 .byte 69,15,88,222 // addps %xmm14,%xmm11 .byte 69,15,87,237 // xorps %xmm13,%xmm13 .byte 68,15,194,233,2 // cmpleps %xmm1,%xmm13 .byte 69,15,40,243 // movaps %xmm11,%xmm14 .byte 68,15,92,241 // subps %xmm1,%xmm14 .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 65,15,92,203 // subps %xmm11,%xmm1 .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 65,15,94,206 // divps %xmm14,%xmm1 .byte 65,15,88,203 // addps %xmm11,%xmm1 .byte 65,15,40,197 // movaps %xmm13,%xmm0 .byte 15,85,193 // andnps %xmm1,%xmm0 .byte 69,15,84,205 // andps %xmm13,%xmm9 .byte 68,15,86,200 // orps %xmm0,%xmm9 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,41,84,36,200 // movaps %xmm2,-0x38(%rsp) .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 15,92,216 // subps %xmm0,%xmm3 .byte 15,41,92,36,184 // movaps %xmm3,-0x48(%rsp) .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 65,15,194,199,1 // cmpltps %xmm15,%xmm0 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 65,15,85,201 // andnps %xmm9,%xmm1 .byte 69,15,92,203 // subps %xmm11,%xmm9 .byte 65,15,92,219 // subps %xmm11,%xmm3 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 69,15,92,251 // subps %xmm11,%xmm15 .byte 69,15,94,207 // divps %xmm15,%xmm9 .byte 69,15,88,203 // addps %xmm11,%xmm9 .byte 68,15,84,200 // andps %xmm0,%xmm9 .byte 68,15,86,201 // orps %xmm1,%xmm9 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 65,15,92,203 // subps %xmm11,%xmm1 .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 65,15,94,206 // divps %xmm14,%xmm1 .byte 65,15,88,203 // addps %xmm11,%xmm1 .byte 65,15,40,213 // movaps %xmm13,%xmm2 .byte 15,85,209 // andnps %xmm1,%xmm2 .byte 69,15,84,213 // andps %xmm13,%xmm10 .byte 68,15,86,210 // orps %xmm2,%xmm10 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 65,15,85,202 // andnps %xmm10,%xmm1 .byte 69,15,92,211 // subps %xmm11,%xmm10 .byte 68,15,89,211 // mulps %xmm3,%xmm10 .byte 69,15,94,215 // divps %xmm15,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 68,15,84,208 // andps %xmm0,%xmm10 .byte 68,15,86,209 // orps %xmm1,%xmm10 .byte 65,15,40,204 // movaps %xmm12,%xmm1 .byte 65,15,92,203 // subps %xmm11,%xmm1 .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 65,15,94,206 // divps %xmm14,%xmm1 .byte 65,15,88,203 // addps %xmm11,%xmm1 .byte 69,15,84,229 // andps %xmm13,%xmm12 .byte 68,15,85,233 // andnps %xmm1,%xmm13 .byte 69,15,86,236 // orps %xmm12,%xmm13 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 65,15,85,205 // andnps %xmm13,%xmm1 .byte 69,15,92,235 // subps %xmm11,%xmm13 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,94,239 // divps %xmm15,%xmm13 .byte 69,15,88,235 // addps %xmm11,%xmm13 .byte 68,15,84,232 // andps %xmm0,%xmm13 .byte 68,15,86,233 // orps %xmm1,%xmm13 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 68,15,95,200 // maxps %xmm0,%xmm9 .byte 68,15,95,208 // maxps %xmm0,%xmm10 .byte 68,15,95,232 // maxps %xmm0,%xmm13 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,88,248 // addps %xmm0,%xmm7 .byte 65,15,88,249 // addps %xmm9,%xmm7 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,40,84,36,232 // movaps -0x18(%rsp),%xmm2 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 65,15,88,234 // addps %xmm10,%xmm5 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,40,68,36,216 // movaps -0x28(%rsp),%xmm0 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 68,15,88,196 // addps %xmm4,%xmm8 .byte 69,15,88,197 // addps %xmm13,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 15,40,92,36,184 // movaps -0x48(%rsp),%xmm3 .byte 15,40,124,36,200 // movaps -0x38(%rsp),%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_luminosity_sse2 .globl _sk_luminosity_sse2 FUNCTION(_sk_luminosity_sse2) _sk_luminosity_sse2: .byte 68,15,40,215 // movaps %xmm7,%xmm10 .byte 15,41,116,36,200 // movaps %xmm6,-0x38(%rsp) .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 15,41,116,36,232 // movaps %xmm6,-0x18(%rsp) .byte 15,41,100,36,216 // movaps %xmm4,-0x28(%rsp) .byte 15,40,235 // movaps %xmm3,%xmm5 .byte 15,40,248 // movaps %xmm0,%xmm7 .byte 68,15,40,205 // movaps %xmm5,%xmm9 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 15,89,222 // mulps %xmm6,%xmm3 .byte 68,15,40,37,225,80,0,0 // movaps 0x50e1(%rip),%xmm12 # 6730 <_sk_callback_sse2+0x373> .byte 68,15,40,199 // movaps %xmm7,%xmm8 .byte 69,15,89,196 // mulps %xmm12,%xmm8 .byte 68,15,40,45,225,80,0,0 // movaps 0x50e1(%rip),%xmm13 # 6740 <_sk_callback_sse2+0x383> .byte 68,15,40,241 // movaps %xmm1,%xmm14 .byte 69,15,89,245 // mulps %xmm13,%xmm14 .byte 69,15,88,240 // addps %xmm8,%xmm14 .byte 68,15,40,29,221,80,0,0 // movaps 0x50dd(%rip),%xmm11 # 6750 <_sk_callback_sse2+0x393> .byte 68,15,40,5,229,80,0,0 // movaps 0x50e5(%rip),%xmm8 # 6760 <_sk_callback_sse2+0x3a3> .byte 69,15,40,248 // movaps %xmm8,%xmm15 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 68,15,92,248 // subps %xmm0,%xmm15 .byte 65,15,89,255 // mulps %xmm15,%xmm7 .byte 65,15,89,207 // mulps %xmm15,%xmm1 .byte 15,41,76,36,184 // movaps %xmm1,-0x48(%rsp) .byte 68,15,89,250 // mulps %xmm2,%xmm15 .byte 65,15,89,211 // mulps %xmm11,%xmm2 .byte 65,15,88,214 // addps %xmm14,%xmm2 .byte 69,15,40,241 // movaps %xmm9,%xmm14 .byte 69,15,89,244 // mulps %xmm12,%xmm14 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 69,15,89,213 // mulps %xmm13,%xmm10 .byte 69,15,88,214 // addps %xmm14,%xmm10 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,40,116,36,200 // movaps -0x38(%rsp),%xmm6 .byte 15,89,230 // mulps %xmm6,%xmm4 .byte 68,15,40,244 // movaps %xmm4,%xmm14 .byte 69,15,89,243 // mulps %xmm11,%xmm14 .byte 69,15,88,242 // addps %xmm10,%xmm14 .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 65,15,92,214 // subps %xmm14,%xmm2 .byte 68,15,88,202 // addps %xmm2,%xmm9 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 15,88,212 // addps %xmm4,%xmm2 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,93,210 // minps %xmm2,%xmm10 .byte 65,15,40,225 // movaps %xmm9,%xmm4 .byte 65,15,93,226 // minps %xmm10,%xmm4 .byte 68,15,40,211 // movaps %xmm3,%xmm10 .byte 68,15,95,210 // maxps %xmm2,%xmm10 .byte 69,15,40,241 // movaps %xmm9,%xmm14 .byte 69,15,95,242 // maxps %xmm10,%xmm14 .byte 69,15,89,225 // mulps %xmm9,%xmm12 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,236 // addps %xmm12,%xmm13 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,88,221 // addps %xmm13,%xmm11 .byte 69,15,87,228 // xorps %xmm12,%xmm12 .byte 68,15,194,228,2 // cmpleps %xmm4,%xmm12 .byte 69,15,40,211 // movaps %xmm11,%xmm10 .byte 68,15,92,212 // subps %xmm4,%xmm10 .byte 65,15,40,225 // movaps %xmm9,%xmm4 .byte 65,15,92,227 // subps %xmm11,%xmm4 .byte 65,15,89,227 // mulps %xmm11,%xmm4 .byte 65,15,94,226 // divps %xmm10,%xmm4 .byte 65,15,88,227 // addps %xmm11,%xmm4 .byte 69,15,40,236 // movaps %xmm12,%xmm13 .byte 68,15,85,236 // andnps %xmm4,%xmm13 .byte 69,15,84,204 // andps %xmm12,%xmm9 .byte 69,15,86,205 // orps %xmm13,%xmm9 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,41,68,36,168 // movaps %xmm0,-0x58(%rsp) .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 68,15,92,197 // subps %xmm5,%xmm8 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 68,15,40,236 // movaps %xmm4,%xmm13 .byte 65,15,194,230,1 // cmpltps %xmm14,%xmm4 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 65,15,85,193 // andnps %xmm9,%xmm0 .byte 69,15,92,203 // subps %xmm11,%xmm9 .byte 69,15,92,235 // subps %xmm11,%xmm13 .byte 69,15,89,205 // mulps %xmm13,%xmm9 .byte 69,15,92,243 // subps %xmm11,%xmm14 .byte 69,15,94,206 // divps %xmm14,%xmm9 .byte 69,15,88,203 // addps %xmm11,%xmm9 .byte 68,15,84,204 // andps %xmm4,%xmm9 .byte 68,15,86,200 // orps %xmm0,%xmm9 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 65,15,92,195 // subps %xmm11,%xmm0 .byte 65,15,89,195 // mulps %xmm11,%xmm0 .byte 65,15,94,194 // divps %xmm10,%xmm0 .byte 65,15,88,195 // addps %xmm11,%xmm0 .byte 65,15,40,204 // movaps %xmm12,%xmm1 .byte 15,85,200 // andnps %xmm0,%xmm1 .byte 65,15,84,220 // andps %xmm12,%xmm3 .byte 15,86,217 // orps %xmm1,%xmm3 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,85,195 // andnps %xmm3,%xmm0 .byte 65,15,92,219 // subps %xmm11,%xmm3 .byte 65,15,89,221 // mulps %xmm13,%xmm3 .byte 65,15,94,222 // divps %xmm14,%xmm3 .byte 65,15,88,219 // addps %xmm11,%xmm3 .byte 15,84,220 // andps %xmm4,%xmm3 .byte 15,86,216 // orps %xmm0,%xmm3 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 65,15,92,195 // subps %xmm11,%xmm0 .byte 65,15,89,195 // mulps %xmm11,%xmm0 .byte 65,15,94,194 // divps %xmm10,%xmm0 .byte 65,15,88,195 // addps %xmm11,%xmm0 .byte 65,15,84,212 // andps %xmm12,%xmm2 .byte 68,15,85,224 // andnps %xmm0,%xmm12 .byte 68,15,86,226 // orps %xmm2,%xmm12 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 65,15,85,196 // andnps %xmm12,%xmm0 .byte 69,15,92,227 // subps %xmm11,%xmm12 .byte 69,15,89,229 // mulps %xmm13,%xmm12 .byte 69,15,94,230 // divps %xmm14,%xmm12 .byte 69,15,88,227 // addps %xmm11,%xmm12 .byte 68,15,84,228 // andps %xmm4,%xmm12 .byte 68,15,86,224 // orps %xmm0,%xmm12 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 68,15,95,200 // maxps %xmm0,%xmm9 .byte 15,95,216 // maxps %xmm0,%xmm3 .byte 68,15,95,224 // maxps %xmm0,%xmm12 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,40,100,36,216 // movaps -0x28(%rsp),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,248 // addps %xmm0,%xmm7 .byte 65,15,88,249 // addps %xmm9,%xmm7 .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 68,15,40,84,36,232 // movaps -0x18(%rsp),%xmm10 .byte 65,15,89,194 // mulps %xmm10,%xmm0 .byte 15,40,76,36,184 // movaps -0x48(%rsp),%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,88,203 // addps %xmm3,%xmm1 .byte 68,15,89,198 // mulps %xmm6,%xmm8 .byte 69,15,88,199 // addps %xmm15,%xmm8 .byte 69,15,88,196 // addps %xmm12,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 15,40,221 // movaps %xmm5,%xmm3 .byte 65,15,40,234 // movaps %xmm10,%xmm5 .byte 15,40,124,36,168 // movaps -0x58(%rsp),%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_rgba_8888_sse2 .globl _sk_srcover_rgba_8888_sse2 FUNCTION(_sk_srcover_rgba_8888_sse2) _sk_srcover_rgba_8888_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,228,0,0,0 // jne 1966 <_sk_srcover_rgba_8888_sse2+0x104> .byte 243,69,15,111,4,129 // movdqu (%r9,%rax,4),%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 102,15,111,53,221,78,0,0 // movdqa 0x4edd(%rip),%xmm6 # 6770 <_sk_callback_sse2+0x3b3> .byte 102,65,15,111,224 // movdqa %xmm8,%xmm4 .byte 102,15,219,230 // pand %xmm6,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 102,65,15,111,232 // movdqa %xmm8,%xmm5 .byte 102,15,114,213,8 // psrld $0x8,%xmm5 .byte 102,15,219,238 // pand %xmm6,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 102,65,15,111,248 // movdqa %xmm8,%xmm7 .byte 102,15,114,215,16 // psrld $0x10,%xmm7 .byte 102,15,219,254 // pand %xmm6,%xmm7 .byte 15,91,247 // cvtdq2ps %xmm7,%xmm6 .byte 102,65,15,114,208,24 // psrld $0x18,%xmm8 .byte 65,15,91,248 // cvtdq2ps %xmm8,%xmm7 .byte 68,15,40,5,173,78,0,0 // movaps 0x4ead(%rip),%xmm8 # 6780 <_sk_callback_sse2+0x3c3> .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 68,15,40,37,177,78,0,0 // movaps 0x4eb1(%rip),%xmm12 # 6790 <_sk_callback_sse2+0x3d3> .byte 65,15,89,196 // mulps %xmm12,%xmm0 .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,89,204 // mulps %xmm4,%xmm9 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 65,15,89,204 // mulps %xmm12,%xmm1 .byte 69,15,40,208 // movaps %xmm8,%xmm10 .byte 68,15,89,213 // mulps %xmm5,%xmm10 .byte 68,15,88,209 // addps %xmm1,%xmm10 .byte 65,15,89,212 // mulps %xmm12,%xmm2 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,89,222 // mulps %xmm6,%xmm11 .byte 68,15,88,218 // addps %xmm2,%xmm11 .byte 65,15,89,220 // mulps %xmm12,%xmm3 .byte 68,15,89,199 // mulps %xmm7,%xmm8 .byte 68,15,88,195 // addps %xmm3,%xmm8 .byte 102,65,15,91,193 // cvtps2dq %xmm9,%xmm0 .byte 102,65,15,91,202 // cvtps2dq %xmm10,%xmm1 .byte 102,15,114,241,8 // pslld $0x8,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,65,15,91,211 // cvtps2dq %xmm11,%xmm2 .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,65,15,91,192 // cvtps2dq %xmm8,%xmm0 .byte 102,15,114,240,24 // pslld $0x18,%xmm0 .byte 102,15,235,194 // por %xmm2,%xmm0 .byte 102,15,235,193 // por %xmm1,%xmm0 .byte 117,84 // jne 19a0 <_sk_srcover_rgba_8888_sse2+0x13e> .byte 243,65,15,127,4,129 // movdqu %xmm0,(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 65,15,40,211 // movaps %xmm11,%xmm2 .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,90 // je 19cd <_sk_srcover_rgba_8888_sse2+0x16b> .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,23 // je 1995 <_sk_srcover_rgba_8888_sse2+0x133> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 15,133,0,255,255,255 // jne 1888 <_sk_srcover_rgba_8888_sse2+0x26> .byte 102,65,15,110,100,129,8 // movd 0x8(%r9,%rax,4),%xmm4 .byte 102,68,15,112,196,69 // pshufd $0x45,%xmm4,%xmm8 .byte 102,69,15,18,4,129 // movlpd (%r9,%rax,4),%xmm8 .byte 233,232,254,255,255 // jmpq 1888 <_sk_srcover_rgba_8888_sse2+0x26> .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,43 // je 19d8 <_sk_srcover_rgba_8888_sse2+0x176> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,18 // je 19c5 <_sk_srcover_rgba_8888_sse2+0x163> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,153 // jne 1952 <_sk_srcover_rgba_8888_sse2+0xf0> .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,65,15,126,76,129,8 // movd %xmm1,0x8(%r9,%rax,4) .byte 102,65,15,214,4,129 // movq %xmm0,(%r9,%rax,4) .byte 235,133 // jmp 1952 <_sk_srcover_rgba_8888_sse2+0xf0> .byte 102,69,15,110,4,129 // movd (%r9,%rax,4),%xmm8 .byte 233,176,254,255,255 // jmpq 1888 <_sk_srcover_rgba_8888_sse2+0x26> .byte 102,65,15,126,4,129 // movd %xmm0,(%r9,%rax,4) .byte 233,111,255,255,255 // jmpq 1952 <_sk_srcover_rgba_8888_sse2+0xf0> HIDDEN _sk_clamp_0_sse2 .globl _sk_clamp_0_sse2 FUNCTION(_sk_clamp_0_sse2) _sk_clamp_0_sse2: .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 65,15,95,192 // maxps %xmm8,%xmm0 .byte 65,15,95,200 // maxps %xmm8,%xmm1 .byte 65,15,95,208 // maxps %xmm8,%xmm2 .byte 65,15,95,216 // maxps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_1_sse2 .globl _sk_clamp_1_sse2 FUNCTION(_sk_clamp_1_sse2) _sk_clamp_1_sse2: .byte 68,15,40,5,157,77,0,0 // movaps 0x4d9d(%rip),%xmm8 # 67a0 <_sk_callback_sse2+0x3e3> .byte 65,15,93,192 // minps %xmm8,%xmm0 .byte 65,15,93,200 // minps %xmm8,%xmm1 .byte 65,15,93,208 // minps %xmm8,%xmm2 .byte 65,15,93,216 // minps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_a_sse2 .globl _sk_clamp_a_sse2 FUNCTION(_sk_clamp_a_sse2) _sk_clamp_a_sse2: .byte 15,93,29,146,77,0,0 // minps 0x4d92(%rip),%xmm3 # 67b0 <_sk_callback_sse2+0x3f3> .byte 15,93,195 // minps %xmm3,%xmm0 .byte 15,93,203 // minps %xmm3,%xmm1 .byte 15,93,211 // minps %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_a_dst_sse2 .globl _sk_clamp_a_dst_sse2 FUNCTION(_sk_clamp_a_dst_sse2) _sk_clamp_a_dst_sse2: .byte 15,93,61,142,77,0,0 // minps 0x4d8e(%rip),%xmm7 # 67c0 <_sk_callback_sse2+0x403> .byte 15,93,231 // minps %xmm7,%xmm4 .byte 15,93,239 // minps %xmm7,%xmm5 .byte 15,93,247 // minps %xmm7,%xmm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_set_rgb_sse2 .globl _sk_set_rgb_sse2 FUNCTION(_sk_set_rgb_sse2) _sk_set_rgb_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,80,8 // movss 0x8(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_swap_rb_sse2 .globl _sk_swap_rb_sse2 FUNCTION(_sk_swap_rb_sse2) _sk_swap_rb_sse2: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_invert_sse2 .globl _sk_invert_sse2 FUNCTION(_sk_invert_sse2) _sk_invert_sse2: .byte 68,15,40,5,90,77,0,0 // movaps 0x4d5a(%rip),%xmm8 # 67d0 <_sk_callback_sse2+0x413> .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 68,15,92,200 // subps %xmm0,%xmm9 .byte 69,15,40,208 // movaps %xmm8,%xmm10 .byte 68,15,92,209 // subps %xmm1,%xmm10 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 68,15,92,218 // subps %xmm2,%xmm11 .byte 68,15,92,195 // subps %xmm3,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 65,15,40,211 // movaps %xmm11,%xmm2 .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_move_src_dst_sse2 .globl _sk_move_src_dst_sse2 FUNCTION(_sk_move_src_dst_sse2) _sk_move_src_dst_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,40,242 // movaps %xmm2,%xmm6 .byte 15,40,251 // movaps %xmm3,%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_move_dst_src_sse2 .globl _sk_move_dst_src_sse2 FUNCTION(_sk_move_dst_src_sse2) _sk_move_dst_src_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 15,40,223 // movaps %xmm7,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_sse2 .globl _sk_premul_sse2 FUNCTION(_sk_premul_sse2) _sk_premul_sse2: .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_dst_sse2 .globl _sk_premul_dst_sse2 FUNCTION(_sk_premul_dst_sse2) _sk_premul_dst_sse2: .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,89,247 // mulps %xmm7,%xmm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_unpremul_sse2 .globl _sk_unpremul_sse2 FUNCTION(_sk_unpremul_sse2) _sk_unpremul_sse2: .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,40,13,244,76,0,0 // movaps 0x4cf4(%rip),%xmm9 # 67e0 <_sk_callback_sse2+0x423> .byte 68,15,94,203 // divps %xmm3,%xmm9 .byte 68,15,194,195,4 // cmpneqps %xmm3,%xmm8 .byte 69,15,84,193 // andps %xmm9,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_from_srgb_sse2 .globl _sk_from_srgb_sse2 FUNCTION(_sk_from_srgb_sse2) _sk_from_srgb_sse2: .byte 68,15,40,5,223,76,0,0 // movaps 0x4cdf(%rip),%xmm8 # 67f0 <_sk_callback_sse2+0x433> .byte 68,15,40,232 // movaps %xmm0,%xmm13 .byte 69,15,89,232 // mulps %xmm8,%xmm13 .byte 68,15,40,216 // movaps %xmm0,%xmm11 .byte 69,15,89,219 // mulps %xmm11,%xmm11 .byte 68,15,40,13,215,76,0,0 // movaps 0x4cd7(%rip),%xmm9 # 6800 <_sk_callback_sse2+0x443> .byte 68,15,40,240 // movaps %xmm0,%xmm14 .byte 69,15,89,241 // mulps %xmm9,%xmm14 .byte 68,15,40,21,215,76,0,0 // movaps 0x4cd7(%rip),%xmm10 # 6810 <_sk_callback_sse2+0x453> .byte 69,15,88,242 // addps %xmm10,%xmm14 .byte 69,15,89,243 // mulps %xmm11,%xmm14 .byte 68,15,40,29,215,76,0,0 // movaps 0x4cd7(%rip),%xmm11 # 6820 <_sk_callback_sse2+0x463> .byte 69,15,88,243 // addps %xmm11,%xmm14 .byte 68,15,40,37,219,76,0,0 // movaps 0x4cdb(%rip),%xmm12 # 6830 <_sk_callback_sse2+0x473> .byte 65,15,194,196,1 // cmpltps %xmm12,%xmm0 .byte 68,15,84,232 // andps %xmm0,%xmm13 .byte 65,15,85,198 // andnps %xmm14,%xmm0 .byte 65,15,86,197 // orps %xmm13,%xmm0 .byte 68,15,40,233 // movaps %xmm1,%xmm13 .byte 69,15,89,232 // mulps %xmm8,%xmm13 .byte 68,15,40,241 // movaps %xmm1,%xmm14 .byte 69,15,89,246 // mulps %xmm14,%xmm14 .byte 68,15,40,249 // movaps %xmm1,%xmm15 .byte 69,15,89,249 // mulps %xmm9,%xmm15 .byte 69,15,88,250 // addps %xmm10,%xmm15 .byte 69,15,89,254 // mulps %xmm14,%xmm15 .byte 69,15,88,251 // addps %xmm11,%xmm15 .byte 65,15,194,204,1 // cmpltps %xmm12,%xmm1 .byte 68,15,84,233 // andps %xmm1,%xmm13 .byte 65,15,85,207 // andnps %xmm15,%xmm1 .byte 65,15,86,205 // orps %xmm13,%xmm1 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 68,15,40,234 // movaps %xmm2,%xmm13 .byte 69,15,89,237 // mulps %xmm13,%xmm13 .byte 68,15,89,202 // mulps %xmm2,%xmm9 .byte 69,15,88,202 // addps %xmm10,%xmm9 .byte 69,15,89,205 // mulps %xmm13,%xmm9 .byte 69,15,88,203 // addps %xmm11,%xmm9 .byte 65,15,194,212,1 // cmpltps %xmm12,%xmm2 .byte 68,15,84,194 // andps %xmm2,%xmm8 .byte 65,15,85,209 // andnps %xmm9,%xmm2 .byte 65,15,86,208 // orps %xmm8,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_from_srgb_dst_sse2 .globl _sk_from_srgb_dst_sse2 FUNCTION(_sk_from_srgb_dst_sse2) _sk_from_srgb_dst_sse2: .byte 68,15,40,5,108,76,0,0 // movaps 0x4c6c(%rip),%xmm8 # 6840 <_sk_callback_sse2+0x483> .byte 68,15,40,236 // movaps %xmm4,%xmm13 .byte 69,15,89,232 // mulps %xmm8,%xmm13 .byte 68,15,40,220 // movaps %xmm4,%xmm11 .byte 69,15,89,219 // mulps %xmm11,%xmm11 .byte 68,15,40,13,100,76,0,0 // movaps 0x4c64(%rip),%xmm9 # 6850 <_sk_callback_sse2+0x493> .byte 68,15,40,244 // movaps %xmm4,%xmm14 .byte 69,15,89,241 // mulps %xmm9,%xmm14 .byte 68,15,40,21,100,76,0,0 // movaps 0x4c64(%rip),%xmm10 # 6860 <_sk_callback_sse2+0x4a3> .byte 69,15,88,242 // addps %xmm10,%xmm14 .byte 69,15,89,243 // mulps %xmm11,%xmm14 .byte 68,15,40,29,100,76,0,0 // movaps 0x4c64(%rip),%xmm11 # 6870 <_sk_callback_sse2+0x4b3> .byte 69,15,88,243 // addps %xmm11,%xmm14 .byte 68,15,40,37,104,76,0,0 // movaps 0x4c68(%rip),%xmm12 # 6880 <_sk_callback_sse2+0x4c3> .byte 65,15,194,228,1 // cmpltps %xmm12,%xmm4 .byte 68,15,84,236 // andps %xmm4,%xmm13 .byte 65,15,85,230 // andnps %xmm14,%xmm4 .byte 65,15,86,229 // orps %xmm13,%xmm4 .byte 68,15,40,237 // movaps %xmm5,%xmm13 .byte 69,15,89,232 // mulps %xmm8,%xmm13 .byte 68,15,40,245 // movaps %xmm5,%xmm14 .byte 69,15,89,246 // mulps %xmm14,%xmm14 .byte 68,15,40,253 // movaps %xmm5,%xmm15 .byte 69,15,89,249 // mulps %xmm9,%xmm15 .byte 69,15,88,250 // addps %xmm10,%xmm15 .byte 69,15,89,254 // mulps %xmm14,%xmm15 .byte 69,15,88,251 // addps %xmm11,%xmm15 .byte 65,15,194,236,1 // cmpltps %xmm12,%xmm5 .byte 68,15,84,237 // andps %xmm5,%xmm13 .byte 65,15,85,239 // andnps %xmm15,%xmm5 .byte 65,15,86,237 // orps %xmm13,%xmm5 .byte 68,15,89,198 // mulps %xmm6,%xmm8 .byte 68,15,40,238 // movaps %xmm6,%xmm13 .byte 69,15,89,237 // mulps %xmm13,%xmm13 .byte 68,15,89,206 // mulps %xmm6,%xmm9 .byte 69,15,88,202 // addps %xmm10,%xmm9 .byte 69,15,89,205 // mulps %xmm13,%xmm9 .byte 69,15,88,203 // addps %xmm11,%xmm9 .byte 65,15,194,244,1 // cmpltps %xmm12,%xmm6 .byte 68,15,84,198 // andps %xmm6,%xmm8 .byte 65,15,85,241 // andnps %xmm9,%xmm6 .byte 65,15,86,240 // orps %xmm8,%xmm6 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_to_srgb_sse2 .globl _sk_to_srgb_sse2 FUNCTION(_sk_to_srgb_sse2) _sk_to_srgb_sse2: .byte 68,15,82,232 // rsqrtps %xmm0,%xmm13 .byte 68,15,40,5,245,75,0,0 // movaps 0x4bf5(%rip),%xmm8 # 6890 <_sk_callback_sse2+0x4d3> .byte 68,15,40,240 // movaps %xmm0,%xmm14 .byte 69,15,89,240 // mulps %xmm8,%xmm14 .byte 68,15,40,13,245,75,0,0 // movaps 0x4bf5(%rip),%xmm9 # 68a0 <_sk_callback_sse2+0x4e3> .byte 69,15,40,253 // movaps %xmm13,%xmm15 .byte 69,15,89,249 // mulps %xmm9,%xmm15 .byte 68,15,40,21,245,75,0,0 // movaps 0x4bf5(%rip),%xmm10 # 68b0 <_sk_callback_sse2+0x4f3> .byte 69,15,88,250 // addps %xmm10,%xmm15 .byte 69,15,89,253 // mulps %xmm13,%xmm15 .byte 68,15,40,29,245,75,0,0 // movaps 0x4bf5(%rip),%xmm11 # 68c0 <_sk_callback_sse2+0x503> .byte 69,15,88,251 // addps %xmm11,%xmm15 .byte 68,15,40,37,249,75,0,0 // movaps 0x4bf9(%rip),%xmm12 # 68d0 <_sk_callback_sse2+0x513> .byte 69,15,88,236 // addps %xmm12,%xmm13 .byte 69,15,83,237 // rcpps %xmm13,%xmm13 .byte 69,15,89,239 // mulps %xmm15,%xmm13 .byte 68,15,40,61,245,75,0,0 // movaps 0x4bf5(%rip),%xmm15 # 68e0 <_sk_callback_sse2+0x523> .byte 65,15,194,199,1 // cmpltps %xmm15,%xmm0 .byte 68,15,84,240 // andps %xmm0,%xmm14 .byte 65,15,85,197 // andnps %xmm13,%xmm0 .byte 65,15,86,198 // orps %xmm14,%xmm0 .byte 68,15,82,233 // rsqrtps %xmm1,%xmm13 .byte 69,15,40,245 // movaps %xmm13,%xmm14 .byte 69,15,89,241 // mulps %xmm9,%xmm14 .byte 69,15,88,242 // addps %xmm10,%xmm14 .byte 69,15,89,245 // mulps %xmm13,%xmm14 .byte 69,15,88,243 // addps %xmm11,%xmm14 .byte 69,15,88,236 // addps %xmm12,%xmm13 .byte 69,15,83,237 // rcpps %xmm13,%xmm13 .byte 69,15,89,238 // mulps %xmm14,%xmm13 .byte 68,15,40,241 // movaps %xmm1,%xmm14 .byte 69,15,89,240 // mulps %xmm8,%xmm14 .byte 65,15,194,207,1 // cmpltps %xmm15,%xmm1 .byte 68,15,84,241 // andps %xmm1,%xmm14 .byte 65,15,85,205 // andnps %xmm13,%xmm1 .byte 65,15,86,206 // orps %xmm14,%xmm1 .byte 68,15,82,234 // rsqrtps %xmm2,%xmm13 .byte 69,15,89,205 // mulps %xmm13,%xmm9 .byte 69,15,88,202 // addps %xmm10,%xmm9 .byte 69,15,89,205 // mulps %xmm13,%xmm9 .byte 69,15,88,203 // addps %xmm11,%xmm9 .byte 69,15,88,236 // addps %xmm12,%xmm13 .byte 69,15,83,213 // rcpps %xmm13,%xmm10 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 65,15,194,215,1 // cmpltps %xmm15,%xmm2 .byte 68,15,84,194 // andps %xmm2,%xmm8 .byte 65,15,85,210 // andnps %xmm10,%xmm2 .byte 65,15,86,208 // orps %xmm8,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_rgb_to_hsl_sse2 .globl _sk_rgb_to_hsl_sse2 FUNCTION(_sk_rgb_to_hsl_sse2) _sk_rgb_to_hsl_sse2: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 69,15,40,208 // movaps %xmm8,%xmm10 .byte 69,15,95,209 // maxps %xmm9,%xmm10 .byte 68,15,95,210 // maxps %xmm2,%xmm10 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 69,15,93,217 // minps %xmm9,%xmm11 .byte 68,15,93,218 // minps %xmm2,%xmm11 .byte 65,15,40,202 // movaps %xmm10,%xmm1 .byte 65,15,92,203 // subps %xmm11,%xmm1 .byte 68,15,40,45,78,75,0,0 // movaps 0x4b4e(%rip),%xmm13 # 68f0 <_sk_callback_sse2+0x533> .byte 68,15,94,233 // divps %xmm1,%xmm13 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 65,15,194,192,0 // cmpeqps %xmm8,%xmm0 .byte 69,15,40,225 // movaps %xmm9,%xmm12 .byte 68,15,92,226 // subps %xmm2,%xmm12 .byte 69,15,89,229 // mulps %xmm13,%xmm12 .byte 69,15,40,241 // movaps %xmm9,%xmm14 .byte 68,15,194,242,1 // cmpltps %xmm2,%xmm14 .byte 68,15,84,53,52,75,0,0 // andps 0x4b34(%rip),%xmm14 # 6900 <_sk_callback_sse2+0x543> .byte 69,15,88,244 // addps %xmm12,%xmm14 .byte 69,15,40,250 // movaps %xmm10,%xmm15 .byte 69,15,194,249,0 // cmpeqps %xmm9,%xmm15 .byte 65,15,92,208 // subps %xmm8,%xmm2 .byte 65,15,89,213 // mulps %xmm13,%xmm2 .byte 68,15,40,37,39,75,0,0 // movaps 0x4b27(%rip),%xmm12 # 6910 <_sk_callback_sse2+0x553> .byte 65,15,88,212 // addps %xmm12,%xmm2 .byte 69,15,92,193 // subps %xmm9,%xmm8 .byte 69,15,89,197 // mulps %xmm13,%xmm8 .byte 68,15,88,5,35,75,0,0 // addps 0x4b23(%rip),%xmm8 # 6920 <_sk_callback_sse2+0x563> .byte 65,15,84,215 // andps %xmm15,%xmm2 .byte 69,15,85,248 // andnps %xmm8,%xmm15 .byte 68,15,86,250 // orps %xmm2,%xmm15 .byte 68,15,84,240 // andps %xmm0,%xmm14 .byte 65,15,85,199 // andnps %xmm15,%xmm0 .byte 65,15,86,198 // orps %xmm14,%xmm0 .byte 15,89,5,20,75,0,0 // mulps 0x4b14(%rip),%xmm0 # 6930 <_sk_callback_sse2+0x573> .byte 69,15,40,194 // movaps %xmm10,%xmm8 .byte 69,15,194,195,4 // cmpneqps %xmm11,%xmm8 .byte 65,15,84,192 // andps %xmm8,%xmm0 .byte 69,15,92,226 // subps %xmm10,%xmm12 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 68,15,40,13,7,75,0,0 // movaps 0x4b07(%rip),%xmm9 # 6940 <_sk_callback_sse2+0x583> .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 68,15,194,202,1 // cmpltps %xmm2,%xmm9 .byte 69,15,92,227 // subps %xmm11,%xmm12 .byte 69,15,84,225 // andps %xmm9,%xmm12 .byte 69,15,85,202 // andnps %xmm10,%xmm9 .byte 69,15,86,204 // orps %xmm12,%xmm9 .byte 65,15,94,201 // divps %xmm9,%xmm1 .byte 65,15,84,200 // andps %xmm8,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_hsl_to_rgb_sse2 .globl _sk_hsl_to_rgb_sse2 FUNCTION(_sk_hsl_to_rgb_sse2) _sk_hsl_to_rgb_sse2: .byte 15,41,124,36,232 // movaps %xmm7,-0x18(%rsp) .byte 15,41,116,36,216 // movaps %xmm6,-0x28(%rsp) .byte 15,41,108,36,200 // movaps %xmm5,-0x38(%rsp) .byte 15,41,100,36,184 // movaps %xmm4,-0x48(%rsp) .byte 15,41,92,36,168 // movaps %xmm3,-0x58(%rsp) .byte 68,15,40,218 // movaps %xmm2,%xmm11 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 68,15,40,13,198,74,0,0 // movaps 0x4ac6(%rip),%xmm9 # 6950 <_sk_callback_sse2+0x593> .byte 69,15,40,209 // movaps %xmm9,%xmm10 .byte 69,15,194,211,2 // cmpleps %xmm11,%xmm10 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 15,194,217,0 // cmpeqps %xmm1,%xmm3 .byte 15,40,251 // movaps %xmm3,%xmm7 .byte 15,41,124,36,136 // movaps %xmm7,-0x78(%rsp) .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 65,15,84,194 // andps %xmm10,%xmm0 .byte 68,15,85,209 // andnps %xmm1,%xmm10 .byte 68,15,86,208 // orps %xmm0,%xmm10 .byte 68,15,41,92,36,152 // movaps %xmm11,-0x68(%rsp) .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 69,15,88,219 // addps %xmm11,%xmm11 .byte 69,15,92,218 // subps %xmm10,%xmm11 .byte 15,40,5,143,74,0,0 // movaps 0x4a8f(%rip),%xmm0 # 6960 <_sk_callback_sse2+0x5a3> .byte 15,88,198 // addps %xmm6,%xmm0 .byte 243,15,91,200 // cvttps2dq %xmm0,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 15,194,217,1 // cmpltps %xmm1,%xmm3 .byte 15,84,29,135,74,0,0 // andps 0x4a87(%rip),%xmm3 # 6970 <_sk_callback_sse2+0x5b3> .byte 15,92,203 // subps %xmm3,%xmm1 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 68,15,40,45,137,74,0,0 // movaps 0x4a89(%rip),%xmm13 # 6980 <_sk_callback_sse2+0x5c3> .byte 69,15,40,197 // movaps %xmm13,%xmm8 .byte 68,15,194,192,2 // cmpleps %xmm0,%xmm8 .byte 69,15,40,242 // movaps %xmm10,%xmm14 .byte 69,15,92,243 // subps %xmm11,%xmm14 .byte 65,15,40,217 // movaps %xmm9,%xmm3 .byte 15,194,216,2 // cmpleps %xmm0,%xmm3 .byte 15,40,21,153,74,0,0 // movaps 0x4a99(%rip),%xmm2 # 69b0 <_sk_callback_sse2+0x5f3> .byte 68,15,40,250 // movaps %xmm2,%xmm15 .byte 68,15,194,248,2 // cmpleps %xmm0,%xmm15 .byte 15,40,13,105,74,0,0 // movaps 0x4a69(%rip),%xmm1 # 6990 <_sk_callback_sse2+0x5d3> .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,40,45,111,74,0,0 // movaps 0x4a6f(%rip),%xmm5 # 69a0 <_sk_callback_sse2+0x5e3> .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,92,224 // subps %xmm0,%xmm4 .byte 65,15,89,230 // mulps %xmm14,%xmm4 .byte 65,15,88,227 // addps %xmm11,%xmm4 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 69,15,84,224 // andps %xmm8,%xmm12 .byte 68,15,85,196 // andnps %xmm4,%xmm8 .byte 69,15,86,196 // orps %xmm12,%xmm8 .byte 68,15,84,195 // andps %xmm3,%xmm8 .byte 65,15,85,218 // andnps %xmm10,%xmm3 .byte 65,15,86,216 // orps %xmm8,%xmm3 .byte 65,15,89,198 // mulps %xmm14,%xmm0 .byte 65,15,88,195 // addps %xmm11,%xmm0 .byte 65,15,84,223 // andps %xmm15,%xmm3 .byte 68,15,85,248 // andnps %xmm0,%xmm15 .byte 68,15,86,251 // orps %xmm3,%xmm15 .byte 68,15,40,199 // movaps %xmm7,%xmm8 .byte 69,15,85,199 // andnps %xmm15,%xmm8 .byte 243,15,91,198 // cvttps2dq %xmm6,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,194,216,1 // cmpltps %xmm0,%xmm3 .byte 15,84,29,228,73,0,0 // andps 0x49e4(%rip),%xmm3 # 6970 <_sk_callback_sse2+0x5b3> .byte 15,92,195 // subps %xmm3,%xmm0 .byte 68,15,40,230 // movaps %xmm6,%xmm12 .byte 68,15,92,224 // subps %xmm0,%xmm12 .byte 69,15,40,253 // movaps %xmm13,%xmm15 .byte 69,15,194,252,2 // cmpleps %xmm12,%xmm15 .byte 65,15,40,225 // movaps %xmm9,%xmm4 .byte 65,15,194,228,2 // cmpleps %xmm12,%xmm4 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 65,15,194,220,2 // cmpleps %xmm12,%xmm3 .byte 68,15,89,225 // mulps %xmm1,%xmm12 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 65,15,92,196 // subps %xmm12,%xmm0 .byte 65,15,89,198 // mulps %xmm14,%xmm0 .byte 65,15,88,195 // addps %xmm11,%xmm0 .byte 65,15,40,251 // movaps %xmm11,%xmm7 .byte 65,15,84,255 // andps %xmm15,%xmm7 .byte 68,15,85,248 // andnps %xmm0,%xmm15 .byte 68,15,86,255 // orps %xmm7,%xmm15 .byte 68,15,84,252 // andps %xmm4,%xmm15 .byte 65,15,85,226 // andnps %xmm10,%xmm4 .byte 65,15,86,231 // orps %xmm15,%xmm4 .byte 69,15,89,230 // mulps %xmm14,%xmm12 .byte 69,15,88,227 // addps %xmm11,%xmm12 .byte 15,84,227 // andps %xmm3,%xmm4 .byte 65,15,85,220 // andnps %xmm12,%xmm3 .byte 15,86,220 // orps %xmm4,%xmm3 .byte 15,40,124,36,136 // movaps -0x78(%rsp),%xmm7 .byte 15,40,231 // movaps %xmm7,%xmm4 .byte 15,85,227 // andnps %xmm3,%xmm4 .byte 15,88,53,188,73,0,0 // addps 0x49bc(%rip),%xmm6 # 69c0 <_sk_callback_sse2+0x603> .byte 243,15,91,198 // cvttps2dq %xmm6,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,194,216,1 // cmpltps %xmm0,%xmm3 .byte 15,84,29,87,73,0,0 // andps 0x4957(%rip),%xmm3 # 6970 <_sk_callback_sse2+0x5b3> .byte 15,92,195 // subps %xmm3,%xmm0 .byte 15,92,240 // subps %xmm0,%xmm6 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 65,15,89,238 // mulps %xmm14,%xmm5 .byte 65,15,89,206 // mulps %xmm14,%xmm1 .byte 65,15,88,235 // addps %xmm11,%xmm5 .byte 65,15,88,203 // addps %xmm11,%xmm1 .byte 68,15,194,238,2 // cmpleps %xmm6,%xmm13 .byte 69,15,84,221 // andps %xmm13,%xmm11 .byte 68,15,85,237 // andnps %xmm5,%xmm13 .byte 69,15,86,235 // orps %xmm11,%xmm13 .byte 68,15,194,206,2 // cmpleps %xmm6,%xmm9 .byte 69,15,84,233 // andps %xmm9,%xmm13 .byte 69,15,85,202 // andnps %xmm10,%xmm9 .byte 69,15,86,205 // orps %xmm13,%xmm9 .byte 15,194,214,2 // cmpleps %xmm6,%xmm2 .byte 68,15,84,202 // andps %xmm2,%xmm9 .byte 15,85,209 // andnps %xmm1,%xmm2 .byte 65,15,86,209 // orps %xmm9,%xmm2 .byte 15,40,68,36,152 // movaps -0x68(%rsp),%xmm0 .byte 15,40,207 // movaps %xmm7,%xmm1 .byte 15,84,193 // andps %xmm1,%xmm0 .byte 15,85,202 // andnps %xmm2,%xmm1 .byte 68,15,86,192 // orps %xmm0,%xmm8 .byte 15,86,224 // orps %xmm0,%xmm4 .byte 15,86,193 // orps %xmm1,%xmm0 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,40,92,36,168 // movaps -0x58(%rsp),%xmm3 .byte 15,40,100,36,184 // movaps -0x48(%rsp),%xmm4 .byte 15,40,108,36,200 // movaps -0x38(%rsp),%xmm5 .byte 15,40,116,36,216 // movaps -0x28(%rsp),%xmm6 .byte 15,40,124,36,232 // movaps -0x18(%rsp),%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_1_float_sse2 .globl _sk_scale_1_float_sse2 FUNCTION(_sk_scale_1_float_sse2) _sk_scale_1_float_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_u8_sse2 .globl _sk_scale_u8_sse2 FUNCTION(_sk_scale_u8_sse2) _sk_scale_u8_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,61 // jne 211a <_sk_scale_u8_sse2+0x55> .byte 102,71,15,110,4,25 // movd (%r9,%r11,1),%xmm8 .byte 102,68,15,96,192 // punpcklbw %xmm0,%xmm8 .byte 102,68,15,97,192 // punpcklwd %xmm0,%xmm8 .byte 102,68,15,219,5,218,72,0,0 // pand 0x48da(%rip),%xmm8 # 69d0 <_sk_callback_sse2+0x613> .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,5,222,72,0,0 // mulps 0x48de(%rip),%xmm8 # 69e0 <_sk_callback_sse2+0x623> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,61 // je 2164 <_sk_scale_u8_sse2+0x9f> .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,23 // je 2149 <_sk_scale_u8_sse2+0x84> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,181 // jne 20ed <_sk_scale_u8_sse2+0x28> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,69 // pshufd $0x45,%xmm8,%xmm8 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,68,15,110,200 // movd %eax,%xmm9 .byte 102,68,15,96,200 // punpcklbw %xmm0,%xmm9 .byte 102,68,15,97,200 // punpcklwd %xmm0,%xmm9 .byte 242,69,15,16,193 // movsd %xmm9,%xmm8 .byte 235,137 // jmp 20ed <_sk_scale_u8_sse2+0x28> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 233,122,255,255,255 // jmpq 20ed <_sk_scale_u8_sse2+0x28> HIDDEN _sk_lerp_1_float_sse2 .globl _sk_lerp_1_float_sse2 FUNCTION(_sk_lerp_1_float_sse2) _sk_lerp_1_float_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,92,205 // subps %xmm5,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_lerp_u8_sse2 .globl _sk_lerp_u8_sse2 FUNCTION(_sk_lerp_u8_sse2) _sk_lerp_u8_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,81 // jne 2214 <_sk_lerp_u8_sse2+0x69> .byte 102,71,15,110,4,25 // movd (%r9,%r11,1),%xmm8 .byte 102,68,15,96,192 // punpcklbw %xmm0,%xmm8 .byte 102,68,15,97,192 // punpcklwd %xmm0,%xmm8 .byte 102,68,15,219,5,20,72,0,0 // pand 0x4814(%rip),%xmm8 # 69f0 <_sk_callback_sse2+0x633> .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,5,24,72,0,0 // mulps 0x4818(%rip),%xmm8 # 6a00 <_sk_callback_sse2+0x643> .byte 15,92,196 // subps %xmm4,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,92,205 // subps %xmm5,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,64 // je 2261 <_sk_lerp_u8_sse2+0xb6> .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,23 // je 2243 <_sk_lerp_u8_sse2+0x98> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,161 // jne 21d3 <_sk_lerp_u8_sse2+0x28> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,69 // pshufd $0x45,%xmm8,%xmm8 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,68,15,110,200 // movd %eax,%xmm9 .byte 102,68,15,96,200 // punpcklbw %xmm0,%xmm9 .byte 102,68,15,97,200 // punpcklwd %xmm0,%xmm9 .byte 242,69,15,16,193 // movsd %xmm9,%xmm8 .byte 233,114,255,255,255 // jmpq 21d3 <_sk_lerp_u8_sse2+0x28> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 233,99,255,255,255 // jmpq 21d3 <_sk_lerp_u8_sse2+0x28> HIDDEN _sk_lerp_565_sse2 .globl _sk_lerp_565_sse2 FUNCTION(_sk_lerp_565_sse2) _sk_lerp_565_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 15,133,156,0,0,0 // jne 232b <_sk_lerp_565_sse2+0xbb> .byte 243,71,15,126,12,89 // movq (%r9,%r11,2),%xmm9 .byte 102,68,15,97,200 // punpcklwd %xmm0,%xmm9 .byte 102,68,15,111,5,109,71,0,0 // movdqa 0x476d(%rip),%xmm8 # 6a10 <_sk_callback_sse2+0x653> .byte 102,69,15,219,193 // pand %xmm9,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,5,108,71,0,0 // mulps 0x476c(%rip),%xmm8 # 6a20 <_sk_callback_sse2+0x663> .byte 102,68,15,111,21,115,71,0,0 // movdqa 0x4773(%rip),%xmm10 # 6a30 <_sk_callback_sse2+0x673> .byte 102,69,15,219,209 // pand %xmm9,%xmm10 .byte 69,15,91,210 // cvtdq2ps %xmm10,%xmm10 .byte 68,15,89,21,114,71,0,0 // mulps 0x4772(%rip),%xmm10 # 6a40 <_sk_callback_sse2+0x683> .byte 102,68,15,219,13,121,71,0,0 // pand 0x4779(%rip),%xmm9 # 6a50 <_sk_callback_sse2+0x693> .byte 69,15,91,201 // cvtdq2ps %xmm9,%xmm9 .byte 68,15,89,13,125,71,0,0 // mulps 0x477d(%rip),%xmm9 # 6a60 <_sk_callback_sse2+0x6a3> .byte 15,92,196 // subps %xmm4,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,92,205 // subps %xmm5,%xmm1 .byte 65,15,89,202 // mulps %xmm10,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 68,15,88,199 // addps %xmm7,%xmm8 .byte 68,15,89,211 // mulps %xmm3,%xmm10 .byte 68,15,88,215 // addps %xmm7,%xmm10 .byte 65,15,89,217 // mulps %xmm9,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 68,15,95,211 // maxps %xmm3,%xmm10 .byte 69,15,95,194 // maxps %xmm10,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,216 // movaps %xmm8,%xmm3 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,59 // je 2373 <_sk_lerp_565_sse2+0x103> .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,27 // je 235e <_sk_lerp_565_sse2+0xee> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 15,133,77,255,255,255 // jne 229a <_sk_lerp_565_sse2+0x2a> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,200,69 // pshufd $0x45,%xmm8,%xmm9 .byte 102,71,15,110,4,89 // movd (%r9,%r11,2),%xmm8 .byte 102,68,15,97,192 // punpcklwd %xmm0,%xmm8 .byte 242,69,15,16,200 // movsd %xmm8,%xmm9 .byte 233,39,255,255,255 // jmpq 229a <_sk_lerp_565_sse2+0x2a> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,68,15,110,200 // movd %eax,%xmm9 .byte 233,24,255,255,255 // jmpq 229a <_sk_lerp_565_sse2+0x2a> HIDDEN _sk_load_tables_sse2 .globl _sk_load_tables_sse2 FUNCTION(_sk_load_tables_sse2) _sk_load_tables_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 77,133,192 // test %r8,%r8 .byte 15,133,36,1,0,0 // jne 24b4 <_sk_load_tables_sse2+0x132> .byte 243,69,15,111,12,145 // movdqu (%r9,%rdx,4),%xmm9 .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 102,68,15,111,5,204,70,0,0 // movdqa 0x46cc(%rip),%xmm8 # 6a70 <_sk_callback_sse2+0x6b3> .byte 102,65,15,111,193 // movdqa %xmm9,%xmm0 .byte 102,65,15,219,192 // pand %xmm8,%xmm0 .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,73,15,126,201 // movq %xmm1,%r9 .byte 102,73,15,126,194 // movq %xmm0,%r10 .byte 69,15,182,218 // movzbl %r10b,%r11d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 69,15,182,241 // movzbl %r9b,%r14d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 72,139,88,8 // mov 0x8(%rax),%rbx .byte 76,139,120,16 // mov 0x10(%rax),%r15 .byte 243,66,15,16,12,19 // movss (%rbx,%r10,1),%xmm1 .byte 243,66,15,16,4,11 // movss (%rbx,%r9,1),%xmm0 .byte 15,20,200 // unpcklps %xmm0,%xmm1 .byte 243,66,15,16,4,155 // movss (%rbx,%r11,4),%xmm0 .byte 243,66,15,16,20,179 // movss (%rbx,%r14,4),%xmm2 .byte 15,20,194 // unpcklps %xmm2,%xmm0 .byte 15,20,193 // unpcklps %xmm1,%xmm0 .byte 102,65,15,111,201 // movdqa %xmm9,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,65,15,219,200 // pand %xmm8,%xmm1 .byte 102,15,112,209,78 // pshufd $0x4e,%xmm1,%xmm2 .byte 102,73,15,126,209 // movq %xmm2,%r9 .byte 102,72,15,126,203 // movq %xmm1,%rbx .byte 68,15,182,211 // movzbl %bl,%r10d .byte 72,193,235,30 // shr $0x1e,%rbx .byte 69,15,182,217 // movzbl %r9b,%r11d .byte 73,193,233,30 // shr $0x1e,%r9 .byte 243,65,15,16,20,31 // movss (%r15,%rbx,1),%xmm2 .byte 243,67,15,16,12,15 // movss (%r15,%r9,1),%xmm1 .byte 15,20,209 // unpcklps %xmm1,%xmm2 .byte 243,67,15,16,12,151 // movss (%r15,%r10,4),%xmm1 .byte 243,67,15,16,28,159 // movss (%r15,%r11,4),%xmm3 .byte 15,20,203 // unpcklps %xmm3,%xmm1 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 76,139,72,24 // mov 0x18(%rax),%r9 .byte 102,65,15,111,209 // movdqa %xmm9,%xmm2 .byte 102,15,114,210,16 // psrld $0x10,%xmm2 .byte 102,65,15,219,208 // pand %xmm8,%xmm2 .byte 102,15,112,218,78 // pshufd $0x4e,%xmm2,%xmm3 .byte 102,72,15,126,219 // movq %xmm3,%rbx .byte 102,72,15,126,208 // movq %xmm2,%rax .byte 68,15,182,208 // movzbl %al,%r10d .byte 72,193,232,30 // shr $0x1e,%rax .byte 68,15,182,219 // movzbl %bl,%r11d .byte 72,193,235,30 // shr $0x1e,%rbx .byte 243,69,15,16,4,1 // movss (%r9,%rax,1),%xmm8 .byte 243,65,15,16,20,25 // movss (%r9,%rbx,1),%xmm2 .byte 68,15,20,194 // unpcklps %xmm2,%xmm8 .byte 243,67,15,16,20,145 // movss (%r9,%r10,4),%xmm2 .byte 243,67,15,16,28,153 // movss (%r9,%r11,4),%xmm3 .byte 15,20,211 // unpcklps %xmm3,%xmm2 .byte 65,15,20,208 // unpcklps %xmm8,%xmm2 .byte 102,65,15,114,209,24 // psrld $0x18,%xmm9 .byte 65,15,91,217 // cvtdq2ps %xmm9,%xmm3 .byte 15,89,29,213,69,0,0 // mulps 0x45d5(%rip),%xmm3 # 6a80 <_sk_callback_sse2+0x6c3> .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,45 // je 24ee <_sk_load_tables_sse2+0x16c> .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,23 // je 24e3 <_sk_load_tables_sse2+0x161> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 15,133,192,254,255,255 // jne 2396 <_sk_load_tables_sse2+0x14> .byte 102,65,15,110,68,145,8 // movd 0x8(%r9,%rdx,4),%xmm0 .byte 102,68,15,112,200,69 // pshufd $0x45,%xmm0,%xmm9 .byte 102,69,15,18,12,145 // movlpd (%r9,%rdx,4),%xmm9 .byte 233,168,254,255,255 // jmpq 2396 <_sk_load_tables_sse2+0x14> .byte 102,69,15,110,12,145 // movd (%r9,%rdx,4),%xmm9 .byte 233,157,254,255,255 // jmpq 2396 <_sk_load_tables_sse2+0x14> HIDDEN _sk_load_tables_u16_be_sse2 .globl _sk_load_tables_u16_be_sse2 FUNCTION(_sk_load_tables_u16_be_sse2) _sk_load_tables_u16_be_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 76,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10 .byte 77,133,192 // test %r8,%r8 .byte 15,133,101,1,0,0 // jne 2674 <_sk_load_tables_u16_be_sse2+0x17b> .byte 102,67,15,16,4,81 // movupd (%r9,%r10,2),%xmm0 .byte 102,67,15,16,76,81,16 // movupd 0x10(%r9,%r10,2),%xmm1 .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 102,68,15,40,200 // movapd %xmm0,%xmm9 .byte 102,68,15,97,201 // punpcklwd %xmm1,%xmm9 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,65,15,111,201 // movdqa %xmm9,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,68,15,105,200 // punpckhwd %xmm0,%xmm9 .byte 102,68,15,111,21,74,69,0,0 // movdqa 0x454a(%rip),%xmm10 # 6a90 <_sk_callback_sse2+0x6d3> .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,65,15,219,194 // pand %xmm10,%xmm0 .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 102,65,15,97,192 // punpcklwd %xmm8,%xmm0 .byte 102,15,112,216,78 // pshufd $0x4e,%xmm0,%xmm3 .byte 102,73,15,126,217 // movq %xmm3,%r9 .byte 69,15,182,209 // movzbl %r9b,%r10d .byte 73,193,233,32 // shr $0x20,%r9 .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 69,15,182,243 // movzbl %r11b,%r14d .byte 73,193,235,30 // shr $0x1e,%r11 .byte 72,139,88,8 // mov 0x8(%rax),%rbx .byte 76,139,120,16 // mov 0x10(%rax),%r15 .byte 243,66,15,16,28,27 // movss (%rbx,%r11,1),%xmm3 .byte 243,66,15,16,4,139 // movss (%rbx,%r9,4),%xmm0 .byte 15,20,216 // unpcklps %xmm0,%xmm3 .byte 243,66,15,16,4,179 // movss (%rbx,%r14,4),%xmm0 .byte 243,66,15,16,20,147 // movss (%rbx,%r10,4),%xmm2 .byte 15,20,194 // unpcklps %xmm2,%xmm0 .byte 15,20,195 // unpcklps %xmm3,%xmm0 .byte 102,15,115,217,8 // psrldq $0x8,%xmm1 .byte 102,65,15,219,202 // pand %xmm10,%xmm1 .byte 102,65,15,97,200 // punpcklwd %xmm8,%xmm1 .byte 102,15,112,209,78 // pshufd $0x4e,%xmm1,%xmm2 .byte 102,72,15,126,211 // movq %xmm2,%rbx .byte 68,15,182,203 // movzbl %bl,%r9d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,73,15,126,202 // movq %xmm1,%r10 .byte 69,15,182,218 // movzbl %r10b,%r11d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 243,67,15,16,20,23 // movss (%r15,%r10,1),%xmm2 .byte 243,65,15,16,12,159 // movss (%r15,%rbx,4),%xmm1 .byte 15,20,209 // unpcklps %xmm1,%xmm2 .byte 243,67,15,16,12,159 // movss (%r15,%r11,4),%xmm1 .byte 243,67,15,16,28,143 // movss (%r15,%r9,4),%xmm3 .byte 15,20,203 // unpcklps %xmm3,%xmm1 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 76,139,80,24 // mov 0x18(%rax),%r10 .byte 102,69,15,219,209 // pand %xmm9,%xmm10 .byte 102,69,15,97,208 // punpcklwd %xmm8,%xmm10 .byte 102,65,15,112,210,78 // pshufd $0x4e,%xmm10,%xmm2 .byte 102,72,15,126,211 // movq %xmm2,%rbx .byte 68,15,182,203 // movzbl %bl,%r9d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,76,15,126,208 // movq %xmm10,%rax .byte 68,15,182,216 // movzbl %al,%r11d .byte 72,193,232,30 // shr $0x1e,%rax .byte 243,69,15,16,20,2 // movss (%r10,%rax,1),%xmm10 .byte 243,65,15,16,20,154 // movss (%r10,%rbx,4),%xmm2 .byte 68,15,20,210 // unpcklps %xmm2,%xmm10 .byte 243,67,15,16,20,154 // movss (%r10,%r11,4),%xmm2 .byte 243,67,15,16,28,138 // movss (%r10,%r9,4),%xmm3 .byte 15,20,211 // unpcklps %xmm3,%xmm2 .byte 65,15,20,210 // unpcklps %xmm10,%xmm2 .byte 102,65,15,112,217,78 // pshufd $0x4e,%xmm9,%xmm3 .byte 102,68,15,111,203 // movdqa %xmm3,%xmm9 .byte 102,65,15,113,241,8 // psllw $0x8,%xmm9 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,65,15,235,217 // por %xmm9,%xmm3 .byte 102,65,15,97,216 // punpcklwd %xmm8,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,29,53,68,0,0 // mulps 0x4435(%rip),%xmm3 # 6aa0 <_sk_callback_sse2+0x6e3> .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax .byte 242,67,15,16,4,81 // movsd (%r9,%r10,2),%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,17 // jne 2691 <_sk_load_tables_u16_be_sse2+0x198> .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 102,15,20,193 // unpcklpd %xmm1,%xmm0 .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 233,139,254,255,255 // jmpq 251c <_sk_load_tables_u16_be_sse2+0x23> .byte 102,67,15,22,68,81,8 // movhpd 0x8(%r9,%r10,2),%xmm0 .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 15,130,118,254,255,255 // jb 251c <_sk_load_tables_u16_be_sse2+0x23> .byte 242,67,15,16,76,81,16 // movsd 0x10(%r9,%r10,2),%xmm1 .byte 233,106,254,255,255 // jmpq 251c <_sk_load_tables_u16_be_sse2+0x23> HIDDEN _sk_load_tables_rgb_u16_be_sse2 .globl _sk_load_tables_rgb_u16_be_sse2 FUNCTION(_sk_load_tables_rgb_u16_be_sse2) _sk_load_tables_rgb_u16_be_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 76,141,20,82 // lea (%rdx,%rdx,2),%r10 .byte 77,133,192 // test %r8,%r8 .byte 15,133,84,1,0,0 // jne 2818 <_sk_load_tables_rgb_u16_be_sse2+0x166> .byte 243,71,15,111,28,81 // movdqu (%r9,%r10,2),%xmm11 .byte 243,67,15,111,76,81,8 // movdqu 0x8(%r9,%r10,2),%xmm1 .byte 102,15,115,217,4 // psrldq $0x4,%xmm1 .byte 102,69,15,111,211 // movdqa %xmm11,%xmm10 .byte 102,65,15,115,218,6 // psrldq $0x6,%xmm10 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,115,216,6 // psrldq $0x6,%xmm0 .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 102,68,15,97,217 // punpcklwd %xmm1,%xmm11 .byte 102,68,15,97,208 // punpcklwd %xmm0,%xmm10 .byte 102,65,15,111,195 // movdqa %xmm11,%xmm0 .byte 102,65,15,97,194 // punpcklwd %xmm10,%xmm0 .byte 102,68,15,111,5,164,67,0,0 // movdqa 0x43a4(%rip),%xmm8 # 6ab0 <_sk_callback_sse2+0x6f3> .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,65,15,219,192 // pand %xmm8,%xmm0 .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 102,65,15,97,193 // punpcklwd %xmm9,%xmm0 .byte 102,15,112,216,78 // pshufd $0x4e,%xmm0,%xmm3 .byte 102,73,15,126,217 // movq %xmm3,%r9 .byte 69,15,182,209 // movzbl %r9b,%r10d .byte 73,193,233,32 // shr $0x20,%r9 .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 69,15,182,243 // movzbl %r11b,%r14d .byte 73,193,235,30 // shr $0x1e,%r11 .byte 72,139,88,8 // mov 0x8(%rax),%rbx .byte 76,139,120,16 // mov 0x10(%rax),%r15 .byte 243,66,15,16,28,27 // movss (%rbx,%r11,1),%xmm3 .byte 243,66,15,16,4,139 // movss (%rbx,%r9,4),%xmm0 .byte 15,20,216 // unpcklps %xmm0,%xmm3 .byte 243,66,15,16,4,179 // movss (%rbx,%r14,4),%xmm0 .byte 243,66,15,16,20,147 // movss (%rbx,%r10,4),%xmm2 .byte 15,20,194 // unpcklps %xmm2,%xmm0 .byte 15,20,195 // unpcklps %xmm3,%xmm0 .byte 102,65,15,219,200 // pand %xmm8,%xmm1 .byte 102,65,15,97,201 // punpcklwd %xmm9,%xmm1 .byte 102,15,112,209,78 // pshufd $0x4e,%xmm1,%xmm2 .byte 102,72,15,126,211 // movq %xmm2,%rbx .byte 68,15,182,203 // movzbl %bl,%r9d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,73,15,126,202 // movq %xmm1,%r10 .byte 69,15,182,218 // movzbl %r10b,%r11d .byte 73,193,234,30 // shr $0x1e,%r10 .byte 243,67,15,16,20,23 // movss (%r15,%r10,1),%xmm2 .byte 243,65,15,16,12,159 // movss (%r15,%rbx,4),%xmm1 .byte 15,20,209 // unpcklps %xmm1,%xmm2 .byte 243,67,15,16,12,159 // movss (%r15,%r11,4),%xmm1 .byte 243,67,15,16,28,143 // movss (%r15,%r9,4),%xmm3 .byte 15,20,203 // unpcklps %xmm3,%xmm1 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 76,139,80,24 // mov 0x18(%rax),%r10 .byte 102,69,15,105,218 // punpckhwd %xmm10,%xmm11 .byte 102,69,15,219,216 // pand %xmm8,%xmm11 .byte 102,69,15,97,217 // punpcklwd %xmm9,%xmm11 .byte 102,65,15,112,211,78 // pshufd $0x4e,%xmm11,%xmm2 .byte 102,72,15,126,211 // movq %xmm2,%rbx .byte 68,15,182,203 // movzbl %bl,%r9d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,76,15,126,216 // movq %xmm11,%rax .byte 68,15,182,216 // movzbl %al,%r11d .byte 72,193,232,30 // shr $0x1e,%rax .byte 243,69,15,16,4,2 // movss (%r10,%rax,1),%xmm8 .byte 243,65,15,16,20,154 // movss (%r10,%rbx,4),%xmm2 .byte 68,15,20,194 // unpcklps %xmm2,%xmm8 .byte 243,67,15,16,20,154 // movss (%r10,%r11,4),%xmm2 .byte 243,67,15,16,28,138 // movss (%r10,%r9,4),%xmm3 .byte 15,20,211 // unpcklps %xmm3,%xmm2 .byte 65,15,20,208 // unpcklps %xmm8,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,175,66,0,0 // movaps 0x42af(%rip),%xmm3 # 6ac0 <_sk_callback_sse2+0x703> .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax .byte 102,71,15,110,28,81 // movd (%r9,%r10,2),%xmm11 .byte 102,71,15,196,92,81,4,2 // pinsrw $0x2,0x4(%r9,%r10,2),%xmm11 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,14 // jne 283e <_sk_load_tables_rgb_u16_be_sse2+0x18c> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,69,15,239,210 // pxor %xmm10,%xmm10 .byte 233,172,254,255,255 // jmpq 26ea <_sk_load_tables_rgb_u16_be_sse2+0x38> .byte 102,71,15,110,84,81,6 // movd 0x6(%r9,%r10,2),%xmm10 .byte 102,71,15,196,84,81,10,2 // pinsrw $0x2,0xa(%r9,%r10,2),%xmm10 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,24 // jb 286f <_sk_load_tables_rgb_u16_be_sse2+0x1bd> .byte 102,67,15,110,76,81,12 // movd 0xc(%r9,%r10,2),%xmm1 .byte 102,67,15,196,76,81,16,2 // pinsrw $0x2,0x10(%r9,%r10,2),%xmm1 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 233,123,254,255,255 // jmpq 26ea <_sk_load_tables_rgb_u16_be_sse2+0x38> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 233,114,254,255,255 // jmpq 26ea <_sk_load_tables_rgb_u16_be_sse2+0x38> HIDDEN _sk_byte_tables_sse2 .globl _sk_byte_tables_sse2 FUNCTION(_sk_byte_tables_sse2) _sk_byte_tables_sse2: .byte 85 // push %rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,40,5,72,66,0,0 // movaps 0x4248(%rip),%xmm8 # 6ad0 <_sk_callback_sse2+0x713> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 102,73,15,126,193 // movq %xmm0,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 77,137,203 // mov %r9,%r11 .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,15,112,192,78 // pshufd $0x4e,%xmm0,%xmm0 .byte 102,73,15,126,193 // movq %xmm0,%r9 .byte 69,137,206 // mov %r9d,%r14d .byte 77,137,207 // mov %r9,%r15 .byte 73,193,239,32 // shr $0x20,%r15 .byte 72,139,24 // mov (%rax),%rbx .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 70,15,182,52,51 // movzbl (%rbx,%r14,1),%r14d .byte 66,15,182,44,59 // movzbl (%rbx,%r15,1),%ebp .byte 193,229,8 // shl $0x8,%ebp .byte 68,9,245 // or %r14d,%ebp .byte 70,15,182,20,19 // movzbl (%rbx,%r10,1),%r10d .byte 66,15,182,28,27 // movzbl (%rbx,%r11,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 68,9,211 // or %r10d,%ebx .byte 102,15,196,195,0 // pinsrw $0x0,%ebx,%xmm0 .byte 102,15,196,197,1 // pinsrw $0x1,%ebp,%xmm0 .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 102,65,15,96,193 // punpcklbw %xmm9,%xmm0 .byte 102,65,15,97,193 // punpcklwd %xmm9,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,21,226,65,0,0 // movaps 0x41e2(%rip),%xmm10 # 6ae0 <_sk_callback_sse2+0x723> .byte 65,15,89,194 // mulps %xmm10,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,15,91,201 // cvtps2dq %xmm1,%xmm1 .byte 102,72,15,126,205 // movq %xmm1,%rbp .byte 65,137,234 // mov %ebp,%r10d .byte 72,193,237,32 // shr $0x20,%rbp .byte 102,15,112,201,78 // pshufd $0x4e,%xmm1,%xmm1 .byte 102,72,15,126,203 // movq %xmm1,%rbx .byte 65,137,219 // mov %ebx,%r11d .byte 72,193,235,32 // shr $0x20,%rbx .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 65,15,182,28,25 // movzbl (%r9,%rbx,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 68,9,219 // or %r11d,%ebx .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 65,15,182,44,41 // movzbl (%r9,%rbp,1),%ebp .byte 193,229,8 // shl $0x8,%ebp .byte 68,9,213 // or %r10d,%ebp .byte 102,15,196,205,0 // pinsrw $0x0,%ebp,%xmm1 .byte 102,15,196,203,1 // pinsrw $0x1,%ebx,%xmm1 .byte 102,65,15,96,201 // punpcklbw %xmm9,%xmm1 .byte 102,65,15,97,201 // punpcklwd %xmm9,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,202 // mulps %xmm10,%xmm1 .byte 76,139,80,16 // mov 0x10(%rax),%r10 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,15,91,210 // cvtps2dq %xmm2,%xmm2 .byte 102,72,15,126,211 // movq %xmm2,%rbx .byte 65,137,217 // mov %ebx,%r9d .byte 72,193,235,32 // shr $0x20,%rbx .byte 102,15,112,210,78 // pshufd $0x4e,%xmm2,%xmm2 .byte 102,72,15,126,213 // movq %xmm2,%rbp .byte 65,137,235 // mov %ebp,%r11d .byte 72,193,237,32 // shr $0x20,%rbp .byte 71,15,182,28,26 // movzbl (%r10,%r11,1),%r11d .byte 65,15,182,44,42 // movzbl (%r10,%rbp,1),%ebp .byte 193,229,8 // shl $0x8,%ebp .byte 68,9,221 // or %r11d,%ebp .byte 71,15,182,12,10 // movzbl (%r10,%r9,1),%r9d .byte 65,15,182,28,26 // movzbl (%r10,%rbx,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 68,9,203 // or %r9d,%ebx .byte 102,15,196,211,0 // pinsrw $0x0,%ebx,%xmm2 .byte 102,15,196,213,1 // pinsrw $0x1,%ebp,%xmm2 .byte 102,65,15,96,209 // punpcklbw %xmm9,%xmm2 .byte 102,65,15,97,209 // punpcklwd %xmm9,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,210 // mulps %xmm10,%xmm2 .byte 72,139,64,24 // mov 0x18(%rax),%rax .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 102,15,91,219 // cvtps2dq %xmm3,%xmm3 .byte 102,72,15,126,221 // movq %xmm3,%rbp .byte 65,137,233 // mov %ebp,%r9d .byte 72,193,237,32 // shr $0x20,%rbp .byte 102,15,112,219,78 // pshufd $0x4e,%xmm3,%xmm3 .byte 102,72,15,126,219 // movq %xmm3,%rbx .byte 65,137,218 // mov %ebx,%r10d .byte 72,193,235,32 // shr $0x20,%rbx .byte 70,15,182,20,16 // movzbl (%rax,%r10,1),%r10d .byte 15,182,28,24 // movzbl (%rax,%rbx,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 68,9,211 // or %r10d,%ebx .byte 70,15,182,12,8 // movzbl (%rax,%r9,1),%r9d .byte 15,182,4,40 // movzbl (%rax,%rbp,1),%eax .byte 193,224,8 // shl $0x8,%eax .byte 68,9,200 // or %r9d,%eax .byte 102,15,196,216,0 // pinsrw $0x0,%eax,%xmm3 .byte 102,15,196,219,1 // pinsrw $0x1,%ebx,%xmm3 .byte 102,65,15,96,217 // punpcklbw %xmm9,%xmm3 .byte 102,65,15,97,217 // punpcklwd %xmm9,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 65,15,89,218 // mulps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax HIDDEN _sk_byte_tables_rgb_sse2 .globl _sk_byte_tables_rgb_sse2 FUNCTION(_sk_byte_tables_rgb_sse2) _sk_byte_tables_rgb_sse2: .byte 85 // push %rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,139,72,24 // mov 0x18(%rax),%r9d .byte 65,255,201 // dec %r9d .byte 102,69,15,110,193 // movd %r9d,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 102,73,15,126,193 // movq %xmm0,%r9 .byte 69,137,202 // mov %r9d,%r10d .byte 77,137,203 // mov %r9,%r11 .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,15,112,192,78 // pshufd $0x4e,%xmm0,%xmm0 .byte 102,73,15,126,193 // movq %xmm0,%r9 .byte 69,137,206 // mov %r9d,%r14d .byte 77,137,207 // mov %r9,%r15 .byte 73,193,239,32 // shr $0x20,%r15 .byte 72,139,24 // mov (%rax),%rbx .byte 76,139,72,8 // mov 0x8(%rax),%r9 .byte 70,15,182,52,51 // movzbl (%rbx,%r14,1),%r14d .byte 66,15,182,44,59 // movzbl (%rbx,%r15,1),%ebp .byte 193,229,8 // shl $0x8,%ebp .byte 68,9,245 // or %r14d,%ebp .byte 70,15,182,20,19 // movzbl (%rbx,%r10,1),%r10d .byte 66,15,182,28,27 // movzbl (%rbx,%r11,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 68,9,211 // or %r10d,%ebx .byte 102,15,196,195,0 // pinsrw $0x0,%ebx,%xmm0 .byte 102,15,196,197,1 // pinsrw $0x1,%ebp,%xmm0 .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 102,65,15,96,193 // punpcklbw %xmm9,%xmm0 .byte 102,65,15,97,193 // punpcklwd %xmm9,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,21,42,64,0,0 // movaps 0x402a(%rip),%xmm10 # 6af0 <_sk_callback_sse2+0x733> .byte 65,15,89,194 // mulps %xmm10,%xmm0 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,15,91,201 // cvtps2dq %xmm1,%xmm1 .byte 102,72,15,126,205 // movq %xmm1,%rbp .byte 65,137,234 // mov %ebp,%r10d .byte 72,193,237,32 // shr $0x20,%rbp .byte 102,15,112,201,78 // pshufd $0x4e,%xmm1,%xmm1 .byte 102,72,15,126,203 // movq %xmm1,%rbx .byte 65,137,219 // mov %ebx,%r11d .byte 72,193,235,32 // shr $0x20,%rbx .byte 71,15,182,28,25 // movzbl (%r9,%r11,1),%r11d .byte 65,15,182,28,25 // movzbl (%r9,%rbx,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 68,9,219 // or %r11d,%ebx .byte 71,15,182,20,17 // movzbl (%r9,%r10,1),%r10d .byte 65,15,182,44,41 // movzbl (%r9,%rbp,1),%ebp .byte 193,229,8 // shl $0x8,%ebp .byte 68,9,213 // or %r10d,%ebp .byte 102,15,196,205,0 // pinsrw $0x0,%ebp,%xmm1 .byte 102,15,196,203,1 // pinsrw $0x1,%ebx,%xmm1 .byte 102,65,15,96,201 // punpcklbw %xmm9,%xmm1 .byte 102,65,15,97,201 // punpcklwd %xmm9,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,202 // mulps %xmm10,%xmm1 .byte 72,139,64,16 // mov 0x10(%rax),%rax .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,15,91,210 // cvtps2dq %xmm2,%xmm2 .byte 102,72,15,126,213 // movq %xmm2,%rbp .byte 65,137,233 // mov %ebp,%r9d .byte 72,193,237,32 // shr $0x20,%rbp .byte 102,15,112,210,78 // pshufd $0x4e,%xmm2,%xmm2 .byte 102,72,15,126,211 // movq %xmm2,%rbx .byte 65,137,218 // mov %ebx,%r10d .byte 72,193,235,32 // shr $0x20,%rbx .byte 70,15,182,20,16 // movzbl (%rax,%r10,1),%r10d .byte 15,182,28,24 // movzbl (%rax,%rbx,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 68,9,211 // or %r10d,%ebx .byte 70,15,182,12,8 // movzbl (%rax,%r9,1),%r9d .byte 15,182,4,40 // movzbl (%rax,%rbp,1),%eax .byte 193,224,8 // shl $0x8,%eax .byte 68,9,200 // or %r9d,%eax .byte 102,15,196,208,0 // pinsrw $0x0,%eax,%xmm2 .byte 102,15,196,211,1 // pinsrw $0x1,%ebx,%xmm2 .byte 102,65,15,96,209 // punpcklbw %xmm9,%xmm2 .byte 102,65,15,97,209 // punpcklwd %xmm9,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,210 // mulps %xmm10,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax HIDDEN _sk_table_r_sse2 .globl _sk_table_r_sse2 FUNCTION(_sk_table_r_sse2) _sk_table_r_sse2: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,112,192,78 // pshufd $0x4e,%xmm8,%xmm0 .byte 102,72,15,126,192 // movq %xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,77,15,126,195 // movq %xmm8,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,71,15,16,4,153 // movss (%r9,%r11,4),%xmm8 .byte 243,65,15,16,4,129 // movss (%r9,%rax,4),%xmm0 .byte 68,15,20,192 // unpcklps %xmm0,%xmm8 .byte 243,65,15,16,4,153 // movss (%r9,%rbx,4),%xmm0 .byte 243,71,15,16,12,145 // movss (%r9,%r10,4),%xmm9 .byte 65,15,20,193 // unpcklps %xmm9,%xmm0 .byte 65,15,20,192 // unpcklps %xmm8,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_table_g_sse2 .globl _sk_table_g_sse2 FUNCTION(_sk_table_g_sse2) _sk_table_g_sse2: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,193 // mulps %xmm1,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,112,200,78 // pshufd $0x4e,%xmm8,%xmm1 .byte 102,72,15,126,200 // movq %xmm1,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,77,15,126,195 // movq %xmm8,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,71,15,16,4,153 // movss (%r9,%r11,4),%xmm8 .byte 243,65,15,16,12,129 // movss (%r9,%rax,4),%xmm1 .byte 68,15,20,193 // unpcklps %xmm1,%xmm8 .byte 243,65,15,16,12,153 // movss (%r9,%rbx,4),%xmm1 .byte 243,71,15,16,12,145 // movss (%r9,%r10,4),%xmm9 .byte 65,15,20,201 // unpcklps %xmm9,%xmm1 .byte 65,15,20,200 // unpcklps %xmm8,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_table_b_sse2 .globl _sk_table_b_sse2 FUNCTION(_sk_table_b_sse2) _sk_table_b_sse2: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,112,208,78 // pshufd $0x4e,%xmm8,%xmm2 .byte 102,72,15,126,208 // movq %xmm2,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,77,15,126,195 // movq %xmm8,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,71,15,16,4,153 // movss (%r9,%r11,4),%xmm8 .byte 243,65,15,16,20,129 // movss (%r9,%rax,4),%xmm2 .byte 68,15,20,194 // unpcklps %xmm2,%xmm8 .byte 243,65,15,16,20,153 // movss (%r9,%rbx,4),%xmm2 .byte 243,71,15,16,12,145 // movss (%r9,%r10,4),%xmm9 .byte 65,15,20,209 // unpcklps %xmm9,%xmm2 .byte 65,15,20,208 // unpcklps %xmm8,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_table_a_sse2 .globl _sk_table_a_sse2 FUNCTION(_sk_table_a_sse2) _sk_table_a_sse2: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 139,64,8 // mov 0x8(%rax),%eax .byte 255,200 // dec %eax .byte 102,68,15,110,192 // movd %eax,%xmm8 .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,112,216,78 // pshufd $0x4e,%xmm8,%xmm3 .byte 102,72,15,126,216 // movq %xmm3,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,77,15,126,195 // movq %xmm8,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,71,15,16,4,153 // movss (%r9,%r11,4),%xmm8 .byte 243,65,15,16,28,129 // movss (%r9,%rax,4),%xmm3 .byte 68,15,20,195 // unpcklps %xmm3,%xmm8 .byte 243,65,15,16,28,153 // movss (%r9,%rbx,4),%xmm3 .byte 243,71,15,16,12,145 // movss (%r9,%r10,4),%xmm9 .byte 65,15,20,217 // unpcklps %xmm9,%xmm3 .byte 65,15,20,216 // unpcklps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_r_sse2 .globl _sk_parametric_r_sse2 FUNCTION(_sk_parametric_r_sse2) _sk_parametric_r_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,72,16 // movss 0x10(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 243,68,15,16,64,12 // movss 0xc(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 243,68,15,16,80,4 // movss 0x4(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 68,15,89,208 // mulps %xmm0,%xmm10 .byte 65,15,194,193,2 // cmpleps %xmm9,%xmm0 .byte 243,68,15,16,72,24 // movss 0x18(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 243,68,15,16,24 // movss (%rax),%xmm11 .byte 243,68,15,16,72,8 // movss 0x8(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,88,209 // addps %xmm9,%xmm10 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,91,202 // cvtdq2ps %xmm10,%xmm9 .byte 68,15,89,13,94,61,0,0 // mulps 0x3d5e(%rip),%xmm9 # 6b00 <_sk_callback_sse2+0x743> .byte 68,15,84,21,102,61,0,0 // andps 0x3d66(%rip),%xmm10 # 6b10 <_sk_callback_sse2+0x753> .byte 68,15,86,21,110,61,0,0 // orps 0x3d6e(%rip),%xmm10 # 6b20 <_sk_callback_sse2+0x763> .byte 68,15,88,13,118,61,0,0 // addps 0x3d76(%rip),%xmm9 # 6b30 <_sk_callback_sse2+0x773> .byte 68,15,40,37,126,61,0,0 // movaps 0x3d7e(%rip),%xmm12 # 6b40 <_sk_callback_sse2+0x783> .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 68,15,88,21,126,61,0,0 // addps 0x3d7e(%rip),%xmm10 # 6b50 <_sk_callback_sse2+0x793> .byte 68,15,40,37,134,61,0,0 // movaps 0x3d86(%rip),%xmm12 # 6b60 <_sk_callback_sse2+0x7a3> .byte 69,15,94,226 // divps %xmm10,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 69,15,89,203 // mulps %xmm11,%xmm9 .byte 243,69,15,91,209 // cvttps2dq %xmm9,%xmm10 .byte 69,15,91,226 // cvtdq2ps %xmm10,%xmm12 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 69,15,194,236,1 // cmpltps %xmm12,%xmm13 .byte 68,15,40,21,112,61,0,0 // movaps 0x3d70(%rip),%xmm10 # 6b70 <_sk_callback_sse2+0x7b3> .byte 69,15,84,234 // andps %xmm10,%xmm13 .byte 69,15,87,219 // xorps %xmm11,%xmm11 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 69,15,92,236 // subps %xmm12,%xmm13 .byte 68,15,88,13,100,61,0,0 // addps 0x3d64(%rip),%xmm9 # 6b80 <_sk_callback_sse2+0x7c3> .byte 68,15,40,37,108,61,0,0 // movaps 0x3d6c(%rip),%xmm12 # 6b90 <_sk_callback_sse2+0x7d3> .byte 69,15,89,229 // mulps %xmm13,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 68,15,40,37,108,61,0,0 // movaps 0x3d6c(%rip),%xmm12 # 6ba0 <_sk_callback_sse2+0x7e3> .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 68,15,40,45,112,61,0,0 // movaps 0x3d70(%rip),%xmm13 # 6bb0 <_sk_callback_sse2+0x7f3> .byte 69,15,94,236 // divps %xmm12,%xmm13 .byte 69,15,88,233 // addps %xmm9,%xmm13 .byte 68,15,89,45,112,61,0,0 // mulps 0x3d70(%rip),%xmm13 # 6bc0 <_sk_callback_sse2+0x803> .byte 102,69,15,91,205 // cvtps2dq %xmm13,%xmm9 .byte 243,68,15,16,96,20 // movss 0x14(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 69,15,88,225 // addps %xmm9,%xmm12 .byte 68,15,84,192 // andps %xmm0,%xmm8 .byte 65,15,85,196 // andnps %xmm12,%xmm0 .byte 65,15,86,192 // orps %xmm8,%xmm0 .byte 65,15,95,195 // maxps %xmm11,%xmm0 .byte 65,15,93,194 // minps %xmm10,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_g_sse2 .globl _sk_parametric_g_sse2 FUNCTION(_sk_parametric_g_sse2) _sk_parametric_g_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,72,16 // movss 0x10(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 243,68,15,16,64,12 // movss 0xc(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 68,15,89,193 // mulps %xmm1,%xmm8 .byte 243,68,15,16,80,4 // movss 0x4(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 65,15,194,201,2 // cmpleps %xmm9,%xmm1 .byte 243,68,15,16,72,24 // movss 0x18(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 243,68,15,16,24 // movss (%rax),%xmm11 .byte 243,68,15,16,72,8 // movss 0x8(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,88,209 // addps %xmm9,%xmm10 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,91,202 // cvtdq2ps %xmm10,%xmm9 .byte 68,15,89,13,240,60,0,0 // mulps 0x3cf0(%rip),%xmm9 # 6bd0 <_sk_callback_sse2+0x813> .byte 68,15,84,21,248,60,0,0 // andps 0x3cf8(%rip),%xmm10 # 6be0 <_sk_callback_sse2+0x823> .byte 68,15,86,21,0,61,0,0 // orps 0x3d00(%rip),%xmm10 # 6bf0 <_sk_callback_sse2+0x833> .byte 68,15,88,13,8,61,0,0 // addps 0x3d08(%rip),%xmm9 # 6c00 <_sk_callback_sse2+0x843> .byte 68,15,40,37,16,61,0,0 // movaps 0x3d10(%rip),%xmm12 # 6c10 <_sk_callback_sse2+0x853> .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 68,15,88,21,16,61,0,0 // addps 0x3d10(%rip),%xmm10 # 6c20 <_sk_callback_sse2+0x863> .byte 68,15,40,37,24,61,0,0 // movaps 0x3d18(%rip),%xmm12 # 6c30 <_sk_callback_sse2+0x873> .byte 69,15,94,226 // divps %xmm10,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 69,15,89,203 // mulps %xmm11,%xmm9 .byte 243,69,15,91,209 // cvttps2dq %xmm9,%xmm10 .byte 69,15,91,226 // cvtdq2ps %xmm10,%xmm12 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 69,15,194,236,1 // cmpltps %xmm12,%xmm13 .byte 68,15,40,21,2,61,0,0 // movaps 0x3d02(%rip),%xmm10 # 6c40 <_sk_callback_sse2+0x883> .byte 69,15,84,234 // andps %xmm10,%xmm13 .byte 69,15,87,219 // xorps %xmm11,%xmm11 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 69,15,92,236 // subps %xmm12,%xmm13 .byte 68,15,88,13,246,60,0,0 // addps 0x3cf6(%rip),%xmm9 # 6c50 <_sk_callback_sse2+0x893> .byte 68,15,40,37,254,60,0,0 // movaps 0x3cfe(%rip),%xmm12 # 6c60 <_sk_callback_sse2+0x8a3> .byte 69,15,89,229 // mulps %xmm13,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 68,15,40,37,254,60,0,0 // movaps 0x3cfe(%rip),%xmm12 # 6c70 <_sk_callback_sse2+0x8b3> .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 68,15,40,45,2,61,0,0 // movaps 0x3d02(%rip),%xmm13 # 6c80 <_sk_callback_sse2+0x8c3> .byte 69,15,94,236 // divps %xmm12,%xmm13 .byte 69,15,88,233 // addps %xmm9,%xmm13 .byte 68,15,89,45,2,61,0,0 // mulps 0x3d02(%rip),%xmm13 # 6c90 <_sk_callback_sse2+0x8d3> .byte 102,69,15,91,205 // cvtps2dq %xmm13,%xmm9 .byte 243,68,15,16,96,20 // movss 0x14(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 69,15,88,225 // addps %xmm9,%xmm12 .byte 68,15,84,193 // andps %xmm1,%xmm8 .byte 65,15,85,204 // andnps %xmm12,%xmm1 .byte 65,15,86,200 // orps %xmm8,%xmm1 .byte 65,15,95,203 // maxps %xmm11,%xmm1 .byte 65,15,93,202 // minps %xmm10,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_b_sse2 .globl _sk_parametric_b_sse2 FUNCTION(_sk_parametric_b_sse2) _sk_parametric_b_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,72,16 // movss 0x10(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 243,68,15,16,64,12 // movss 0xc(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 243,68,15,16,80,4 // movss 0x4(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 68,15,89,210 // mulps %xmm2,%xmm10 .byte 65,15,194,209,2 // cmpleps %xmm9,%xmm2 .byte 243,68,15,16,72,24 // movss 0x18(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 243,68,15,16,24 // movss (%rax),%xmm11 .byte 243,68,15,16,72,8 // movss 0x8(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,88,209 // addps %xmm9,%xmm10 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,91,202 // cvtdq2ps %xmm10,%xmm9 .byte 68,15,89,13,130,60,0,0 // mulps 0x3c82(%rip),%xmm9 # 6ca0 <_sk_callback_sse2+0x8e3> .byte 68,15,84,21,138,60,0,0 // andps 0x3c8a(%rip),%xmm10 # 6cb0 <_sk_callback_sse2+0x8f3> .byte 68,15,86,21,146,60,0,0 // orps 0x3c92(%rip),%xmm10 # 6cc0 <_sk_callback_sse2+0x903> .byte 68,15,88,13,154,60,0,0 // addps 0x3c9a(%rip),%xmm9 # 6cd0 <_sk_callback_sse2+0x913> .byte 68,15,40,37,162,60,0,0 // movaps 0x3ca2(%rip),%xmm12 # 6ce0 <_sk_callback_sse2+0x923> .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 68,15,88,21,162,60,0,0 // addps 0x3ca2(%rip),%xmm10 # 6cf0 <_sk_callback_sse2+0x933> .byte 68,15,40,37,170,60,0,0 // movaps 0x3caa(%rip),%xmm12 # 6d00 <_sk_callback_sse2+0x943> .byte 69,15,94,226 // divps %xmm10,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 69,15,89,203 // mulps %xmm11,%xmm9 .byte 243,69,15,91,209 // cvttps2dq %xmm9,%xmm10 .byte 69,15,91,226 // cvtdq2ps %xmm10,%xmm12 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 69,15,194,236,1 // cmpltps %xmm12,%xmm13 .byte 68,15,40,21,148,60,0,0 // movaps 0x3c94(%rip),%xmm10 # 6d10 <_sk_callback_sse2+0x953> .byte 69,15,84,234 // andps %xmm10,%xmm13 .byte 69,15,87,219 // xorps %xmm11,%xmm11 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 69,15,92,236 // subps %xmm12,%xmm13 .byte 68,15,88,13,136,60,0,0 // addps 0x3c88(%rip),%xmm9 # 6d20 <_sk_callback_sse2+0x963> .byte 68,15,40,37,144,60,0,0 // movaps 0x3c90(%rip),%xmm12 # 6d30 <_sk_callback_sse2+0x973> .byte 69,15,89,229 // mulps %xmm13,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 68,15,40,37,144,60,0,0 // movaps 0x3c90(%rip),%xmm12 # 6d40 <_sk_callback_sse2+0x983> .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 68,15,40,45,148,60,0,0 // movaps 0x3c94(%rip),%xmm13 # 6d50 <_sk_callback_sse2+0x993> .byte 69,15,94,236 // divps %xmm12,%xmm13 .byte 69,15,88,233 // addps %xmm9,%xmm13 .byte 68,15,89,45,148,60,0,0 // mulps 0x3c94(%rip),%xmm13 # 6d60 <_sk_callback_sse2+0x9a3> .byte 102,69,15,91,205 // cvtps2dq %xmm13,%xmm9 .byte 243,68,15,16,96,20 // movss 0x14(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 69,15,88,225 // addps %xmm9,%xmm12 .byte 68,15,84,194 // andps %xmm2,%xmm8 .byte 65,15,85,212 // andnps %xmm12,%xmm2 .byte 65,15,86,208 // orps %xmm8,%xmm2 .byte 65,15,95,211 // maxps %xmm11,%xmm2 .byte 65,15,93,210 // minps %xmm10,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_parametric_a_sse2 .globl _sk_parametric_a_sse2 FUNCTION(_sk_parametric_a_sse2) _sk_parametric_a_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,72,16 // movss 0x10(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 243,68,15,16,64,12 // movss 0xc(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 243,68,15,16,80,4 // movss 0x4(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 68,15,89,211 // mulps %xmm3,%xmm10 .byte 65,15,194,217,2 // cmpleps %xmm9,%xmm3 .byte 243,68,15,16,72,24 // movss 0x18(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 243,68,15,16,24 // movss (%rax),%xmm11 .byte 243,68,15,16,72,8 // movss 0x8(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,88,209 // addps %xmm9,%xmm10 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,91,202 // cvtdq2ps %xmm10,%xmm9 .byte 68,15,89,13,20,60,0,0 // mulps 0x3c14(%rip),%xmm9 # 6d70 <_sk_callback_sse2+0x9b3> .byte 68,15,84,21,28,60,0,0 // andps 0x3c1c(%rip),%xmm10 # 6d80 <_sk_callback_sse2+0x9c3> .byte 68,15,86,21,36,60,0,0 // orps 0x3c24(%rip),%xmm10 # 6d90 <_sk_callback_sse2+0x9d3> .byte 68,15,88,13,44,60,0,0 // addps 0x3c2c(%rip),%xmm9 # 6da0 <_sk_callback_sse2+0x9e3> .byte 68,15,40,37,52,60,0,0 // movaps 0x3c34(%rip),%xmm12 # 6db0 <_sk_callback_sse2+0x9f3> .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 68,15,88,21,52,60,0,0 // addps 0x3c34(%rip),%xmm10 # 6dc0 <_sk_callback_sse2+0xa03> .byte 68,15,40,37,60,60,0,0 // movaps 0x3c3c(%rip),%xmm12 # 6dd0 <_sk_callback_sse2+0xa13> .byte 69,15,94,226 // divps %xmm10,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 69,15,89,203 // mulps %xmm11,%xmm9 .byte 243,69,15,91,209 // cvttps2dq %xmm9,%xmm10 .byte 69,15,91,226 // cvtdq2ps %xmm10,%xmm12 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 69,15,194,236,1 // cmpltps %xmm12,%xmm13 .byte 68,15,40,21,38,60,0,0 // movaps 0x3c26(%rip),%xmm10 # 6de0 <_sk_callback_sse2+0xa23> .byte 69,15,84,234 // andps %xmm10,%xmm13 .byte 69,15,87,219 // xorps %xmm11,%xmm11 .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 69,15,40,233 // movaps %xmm9,%xmm13 .byte 69,15,92,236 // subps %xmm12,%xmm13 .byte 68,15,88,13,26,60,0,0 // addps 0x3c1a(%rip),%xmm9 # 6df0 <_sk_callback_sse2+0xa33> .byte 68,15,40,37,34,60,0,0 // movaps 0x3c22(%rip),%xmm12 # 6e00 <_sk_callback_sse2+0xa43> .byte 69,15,89,229 // mulps %xmm13,%xmm12 .byte 69,15,92,204 // subps %xmm12,%xmm9 .byte 68,15,40,37,34,60,0,0 // movaps 0x3c22(%rip),%xmm12 # 6e10 <_sk_callback_sse2+0xa53> .byte 69,15,92,229 // subps %xmm13,%xmm12 .byte 68,15,40,45,38,60,0,0 // movaps 0x3c26(%rip),%xmm13 # 6e20 <_sk_callback_sse2+0xa63> .byte 69,15,94,236 // divps %xmm12,%xmm13 .byte 69,15,88,233 // addps %xmm9,%xmm13 .byte 68,15,89,45,38,60,0,0 // mulps 0x3c26(%rip),%xmm13 # 6e30 <_sk_callback_sse2+0xa73> .byte 102,69,15,91,205 // cvtps2dq %xmm13,%xmm9 .byte 243,68,15,16,96,20 // movss 0x14(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 69,15,88,225 // addps %xmm9,%xmm12 .byte 68,15,84,195 // andps %xmm3,%xmm8 .byte 65,15,85,220 // andnps %xmm12,%xmm3 .byte 65,15,86,216 // orps %xmm8,%xmm3 .byte 65,15,95,219 // maxps %xmm11,%xmm3 .byte 65,15,93,218 // minps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_gamma_sse2 .globl _sk_gamma_sse2 FUNCTION(_sk_gamma_sse2) _sk_gamma_sse2: .byte 15,41,124,36,232 // movaps %xmm7,-0x18(%rsp) .byte 15,41,116,36,216 // movaps %xmm6,-0x28(%rsp) .byte 15,41,108,36,200 // movaps %xmm5,-0x38(%rsp) .byte 15,41,100,36,184 // movaps %xmm4,-0x48(%rsp) .byte 15,41,92,36,168 // movaps %xmm3,-0x58(%rsp) .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,91,194 // cvtdq2ps %xmm2,%xmm0 .byte 15,89,5,225,59,0,0 // mulps 0x3be1(%rip),%xmm0 # 6e40 <_sk_callback_sse2+0xa83> .byte 15,84,21,234,59,0,0 // andps 0x3bea(%rip),%xmm2 # 6e50 <_sk_callback_sse2+0xa93> .byte 68,15,40,53,242,59,0,0 // movaps 0x3bf2(%rip),%xmm14 # 6e60 <_sk_callback_sse2+0xaa3> .byte 65,15,86,214 // orps %xmm14,%xmm2 .byte 68,15,40,37,246,59,0,0 // movaps 0x3bf6(%rip),%xmm12 # 6e70 <_sk_callback_sse2+0xab3> .byte 65,15,88,196 // addps %xmm12,%xmm0 .byte 68,15,40,29,250,59,0,0 // movaps 0x3bfa(%rip),%xmm11 # 6e80 <_sk_callback_sse2+0xac3> .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 65,15,89,227 // mulps %xmm11,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 68,15,40,21,248,59,0,0 // movaps 0x3bf8(%rip),%xmm10 # 6e90 <_sk_callback_sse2+0xad3> .byte 65,15,88,210 // addps %xmm10,%xmm2 .byte 68,15,40,45,252,59,0,0 // movaps 0x3bfc(%rip),%xmm13 # 6ea0 <_sk_callback_sse2+0xae3> .byte 65,15,40,229 // movaps %xmm13,%xmm4 .byte 15,94,226 // divps %xmm2,%xmm4 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,92,196 // subps %xmm4,%xmm0 .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 243,15,91,208 // cvttps2dq %xmm0,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,194,226,1 // cmpltps %xmm2,%xmm4 .byte 68,15,40,13,220,59,0,0 // movaps 0x3bdc(%rip),%xmm9 # 6eb0 <_sk_callback_sse2+0xaf3> .byte 65,15,84,225 // andps %xmm9,%xmm4 .byte 15,92,212 // subps %xmm4,%xmm2 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,92,226 // subps %xmm2,%xmm4 .byte 15,40,53,216,59,0,0 // movaps 0x3bd8(%rip),%xmm6 # 6ec0 <_sk_callback_sse2+0xb03> .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,40,61,238,59,0,0 // movaps 0x3bee(%rip),%xmm7 # 6ee0 <_sk_callback_sse2+0xb23> .byte 15,40,239 // movaps %xmm7,%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 15,40,37,206,59,0,0 // movaps 0x3bce(%rip),%xmm4 # 6ed0 <_sk_callback_sse2+0xb13> .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,92,194 // subps %xmm2,%xmm0 .byte 68,15,40,61,224,59,0,0 // movaps 0x3be0(%rip),%xmm15 # 6ef0 <_sk_callback_sse2+0xb33> .byte 65,15,40,215 // movaps %xmm15,%xmm2 .byte 15,94,213 // divps %xmm5,%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 15,91,193 // cvtdq2ps %xmm1,%xmm0 .byte 15,89,5,28,59,0,0 // mulps 0x3b1c(%rip),%xmm0 # 6e40 <_sk_callback_sse2+0xa83> .byte 15,84,13,37,59,0,0 // andps 0x3b25(%rip),%xmm1 # 6e50 <_sk_callback_sse2+0xa93> .byte 65,15,86,206 // orps %xmm14,%xmm1 .byte 65,15,88,196 // addps %xmm12,%xmm0 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 65,15,89,235 // mulps %xmm11,%xmm5 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 69,15,40,242 // movaps %xmm10,%xmm14 .byte 65,15,40,237 // movaps %xmm13,%xmm5 .byte 15,94,233 // divps %xmm1,%xmm5 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 243,15,91,200 // cvttps2dq %xmm0,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,194,233,1 // cmpltps %xmm1,%xmm5 .byte 65,15,84,233 // andps %xmm9,%xmm5 .byte 15,92,205 // subps %xmm5,%xmm1 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 68,15,40,214 // movaps %xmm6,%xmm10 .byte 15,40,247 // movaps %xmm7,%xmm6 .byte 15,92,245 // subps %xmm5,%xmm6 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 65,15,40,207 // movaps %xmm15,%xmm1 .byte 15,94,206 // divps %xmm6,%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,91,195 // cvtdq2ps %xmm3,%xmm0 .byte 15,89,5,171,58,0,0 // mulps 0x3aab(%rip),%xmm0 # 6e40 <_sk_callback_sse2+0xa83> .byte 15,84,29,180,58,0,0 // andps 0x3ab4(%rip),%xmm3 # 6e50 <_sk_callback_sse2+0xa93> .byte 15,86,29,189,58,0,0 // orps 0x3abd(%rip),%xmm3 # 6e60 <_sk_callback_sse2+0xaa3> .byte 65,15,88,196 // addps %xmm12,%xmm0 .byte 68,15,89,219 // mulps %xmm3,%xmm11 .byte 65,15,92,195 // subps %xmm11,%xmm0 .byte 65,15,88,222 // addps %xmm14,%xmm3 .byte 68,15,94,235 // divps %xmm3,%xmm13 .byte 65,15,92,197 // subps %xmm13,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 243,15,91,216 // cvttps2dq %xmm0,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,194,235,1 // cmpltps %xmm3,%xmm5 .byte 65,15,84,233 // andps %xmm9,%xmm5 .byte 15,92,221 // subps %xmm5,%xmm3 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,92,235 // subps %xmm3,%xmm5 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,92,253 // subps %xmm5,%xmm7 .byte 68,15,94,255 // divps %xmm7,%xmm15 .byte 68,15,88,248 // addps %xmm0,%xmm15 .byte 15,40,5,10,59,0,0 // movaps 0x3b0a(%rip),%xmm0 # 6f00 <_sk_callback_sse2+0xb43> .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 68,15,89,248 // mulps %xmm0,%xmm15 .byte 102,15,91,194 // cvtps2dq %xmm2,%xmm0 .byte 102,15,91,201 // cvtps2dq %xmm1,%xmm1 .byte 102,65,15,91,215 // cvtps2dq %xmm15,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,92,36,168 // movaps -0x58(%rsp),%xmm3 .byte 15,40,100,36,184 // movaps -0x48(%rsp),%xmm4 .byte 15,40,108,36,200 // movaps -0x38(%rsp),%xmm5 .byte 15,40,116,36,216 // movaps -0x28(%rsp),%xmm6 .byte 15,40,124,36,232 // movaps -0x18(%rsp),%xmm7 .byte 255,224 // jmpq *%rax HIDDEN _sk_lab_to_xyz_sse2 .globl _sk_lab_to_xyz_sse2 FUNCTION(_sk_lab_to_xyz_sse2) _sk_lab_to_xyz_sse2: .byte 15,89,5,223,58,0,0 // mulps 0x3adf(%rip),%xmm0 # 6f10 <_sk_callback_sse2+0xb53> .byte 68,15,40,5,231,58,0,0 // movaps 0x3ae7(%rip),%xmm8 # 6f20 <_sk_callback_sse2+0xb63> .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 68,15,40,13,235,58,0,0 // movaps 0x3aeb(%rip),%xmm9 # 6f30 <_sk_callback_sse2+0xb73> .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 65,15,88,209 // addps %xmm9,%xmm2 .byte 15,88,5,232,58,0,0 // addps 0x3ae8(%rip),%xmm0 # 6f40 <_sk_callback_sse2+0xb83> .byte 15,89,5,241,58,0,0 // mulps 0x3af1(%rip),%xmm0 # 6f50 <_sk_callback_sse2+0xb93> .byte 15,89,13,250,58,0,0 // mulps 0x3afa(%rip),%xmm1 # 6f60 <_sk_callback_sse2+0xba3> .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,89,21,0,59,0,0 // mulps 0x3b00(%rip),%xmm2 # 6f70 <_sk_callback_sse2+0xbb3> .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 68,15,92,202 // subps %xmm2,%xmm9 .byte 68,15,40,225 // movaps %xmm1,%xmm12 .byte 69,15,89,228 // mulps %xmm12,%xmm12 .byte 68,15,89,225 // mulps %xmm1,%xmm12 .byte 15,40,21,245,58,0,0 // movaps 0x3af5(%rip),%xmm2 # 6f80 <_sk_callback_sse2+0xbc3> .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 69,15,194,196,1 // cmpltps %xmm12,%xmm8 .byte 68,15,40,21,244,58,0,0 // movaps 0x3af4(%rip),%xmm10 # 6f90 <_sk_callback_sse2+0xbd3> .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 68,15,40,29,248,58,0,0 // movaps 0x3af8(%rip),%xmm11 # 6fa0 <_sk_callback_sse2+0xbe3> .byte 65,15,89,203 // mulps %xmm11,%xmm1 .byte 69,15,84,224 // andps %xmm8,%xmm12 .byte 68,15,85,193 // andnps %xmm1,%xmm8 .byte 69,15,86,196 // orps %xmm12,%xmm8 .byte 68,15,40,224 // movaps %xmm0,%xmm12 .byte 69,15,89,228 // mulps %xmm12,%xmm12 .byte 68,15,89,224 // mulps %xmm0,%xmm12 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 65,15,194,204,1 // cmpltps %xmm12,%xmm1 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 65,15,89,195 // mulps %xmm11,%xmm0 .byte 68,15,84,225 // andps %xmm1,%xmm12 .byte 15,85,200 // andnps %xmm0,%xmm1 .byte 65,15,86,204 // orps %xmm12,%xmm1 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 15,194,208,1 // cmpltps %xmm0,%xmm2 .byte 69,15,88,202 // addps %xmm10,%xmm9 .byte 69,15,89,203 // mulps %xmm11,%xmm9 .byte 15,84,194 // andps %xmm2,%xmm0 .byte 65,15,85,209 // andnps %xmm9,%xmm2 .byte 15,86,208 // orps %xmm0,%xmm2 .byte 68,15,89,5,168,58,0,0 // mulps 0x3aa8(%rip),%xmm8 # 6fb0 <_sk_callback_sse2+0xbf3> .byte 15,89,21,177,58,0,0 // mulps 0x3ab1(%rip),%xmm2 # 6fc0 <_sk_callback_sse2+0xc03> .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_load_a8_sse2 .globl _sk_load_a8_sse2 FUNCTION(_sk_load_a8_sse2) _sk_load_a8_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,46 // jne 355d <_sk_load_a8_sse2+0x46> .byte 102,67,15,110,4,25 // movd (%r9,%r11,1),%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 102,15,219,5,139,58,0,0 // pand 0x3a8b(%rip),%xmm0 # 6fd0 <_sk_callback_sse2+0xc13> .byte 15,91,216 // cvtdq2ps %xmm0,%xmm3 .byte 15,89,29,145,58,0,0 // mulps 0x3a91(%rip),%xmm3 # 6fe0 <_sk_callback_sse2+0xc23> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,54 // je 35a0 <_sk_load_a8_sse2+0x89> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3589 <_sk_load_a8_sse2+0x72> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,195 // jne 353d <_sk_load_a8_sse2+0x26> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 102,15,96,200 // punpcklbw %xmm0,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 242,15,16,193 // movsd %xmm1,%xmm0 .byte 235,157 // jmp 353d <_sk_load_a8_sse2+0x26> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 235,146 // jmp 353d <_sk_load_a8_sse2+0x26> HIDDEN _sk_load_a8_dst_sse2 .globl _sk_load_a8_dst_sse2 FUNCTION(_sk_load_a8_dst_sse2) _sk_load_a8_dst_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,46 // jne 35f1 <_sk_load_a8_dst_sse2+0x46> .byte 102,67,15,110,36,25 // movd (%r9,%r11,1),%xmm4 .byte 102,15,96,224 // punpcklbw %xmm0,%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 102,15,219,37,23,58,0,0 // pand 0x3a17(%rip),%xmm4 # 6ff0 <_sk_callback_sse2+0xc33> .byte 15,91,252 // cvtdq2ps %xmm4,%xmm7 .byte 15,89,61,29,58,0,0 // mulps 0x3a1d(%rip),%xmm7 # 7000 <_sk_callback_sse2+0xc43> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 102,15,87,237 // xorpd %xmm5,%xmm5 .byte 15,87,246 // xorps %xmm6,%xmm6 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,54 // je 3634 <_sk_load_a8_dst_sse2+0x89> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 361d <_sk_load_a8_dst_sse2+0x72> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,195 // jne 35d1 <_sk_load_a8_dst_sse2+0x26> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,15,110,232 // movd %eax,%xmm5 .byte 102,15,96,232 // punpcklbw %xmm0,%xmm5 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 242,15,16,229 // movsd %xmm5,%xmm4 .byte 235,157 // jmp 35d1 <_sk_load_a8_dst_sse2+0x26> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 235,146 // jmp 35d1 <_sk_load_a8_dst_sse2+0x26> HIDDEN _sk_gather_a8_sse2 .globl _sk_gather_a8_sse2 FUNCTION(_sk_gather_a8_sse2) _sk_gather_a8_sse2: .byte 85 // push %rbp .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,72,15,126,192 // movq %xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,15,112,192,78 // pshufd $0x4e,%xmm0,%xmm0 .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 65,15,182,44,25 // movzbl (%r9,%rbx,1),%ebp .byte 67,15,182,28,25 // movzbl (%r9,%r11,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 9,235 // or %ebp,%ebx .byte 67,15,182,44,17 // movzbl (%r9,%r10,1),%ebp .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 193,224,8 // shl $0x8,%eax .byte 9,232 // or %ebp,%eax .byte 102,15,196,192,0 // pinsrw $0x0,%eax,%xmm0 .byte 102,15,196,195,1 // pinsrw $0x1,%ebx,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,15,96,193 // punpcklbw %xmm1,%xmm0 .byte 102,15,97,193 // punpcklwd %xmm1,%xmm0 .byte 15,91,216 // cvtdq2ps %xmm0,%xmm3 .byte 15,89,29,62,57,0,0 // mulps 0x393e(%rip),%xmm3 # 7010 <_sk_callback_sse2+0xc53> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 91 // pop %rbx .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax HIDDEN _sk_store_a8_sse2 .globl _sk_store_a8_sse2 FUNCTION(_sk_store_a8_sse2) _sk_store_a8_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 68,15,40,5,34,57,0,0 // movaps 0x3922(%rip),%xmm8 # 7020 <_sk_callback_sse2+0xc63> .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,114,240,16 // pslld $0x10,%xmm8 .byte 102,65,15,114,224,16 // psrad $0x10,%xmm8 .byte 102,69,15,107,192 // packssdw %xmm8,%xmm8 .byte 102,69,15,103,192 // packuswb %xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,13 // jne 372f <_sk_store_a8_sse2+0x4c> .byte 102,68,15,126,192 // movd %xmm8,%eax .byte 67,137,4,25 // mov %eax,(%r9,%r11,1) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,68,15,96,192 // punpcklbw %xmm0,%xmm8 .byte 102,68,15,97,192 // punpcklwd %xmm0,%xmm8 .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,59 // je 3781 <_sk_store_a8_sse2+0x9e> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,22 // je 3762 <_sk_store_a8_sse2+0x7f> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,217 // jne 372b <_sk_store_a8_sse2+0x48> .byte 102,68,15,127,68,36,232 // movdqa %xmm8,-0x18(%rsp) .byte 138,68,36,240 // mov -0x10(%rsp),%al .byte 67,136,68,25,2 // mov %al,0x2(%r9,%r11,1) .byte 102,68,15,219,5,197,56,0,0 // pand 0x38c5(%rip),%xmm8 # 7030 <_sk_callback_sse2+0xc73> .byte 102,69,15,103,192 // packuswb %xmm8,%xmm8 .byte 102,69,15,103,192 // packuswb %xmm8,%xmm8 .byte 102,68,15,126,192 // movd %xmm8,%eax .byte 102,67,137,4,25 // mov %ax,(%r9,%r11,1) .byte 235,170 // jmp 372b <_sk_store_a8_sse2+0x48> .byte 102,68,15,127,68,36,216 // movdqa %xmm8,-0x28(%rsp) .byte 138,68,36,216 // mov -0x28(%rsp),%al .byte 67,136,4,25 // mov %al,(%r9,%r11,1) .byte 235,153 // jmp 372b <_sk_store_a8_sse2+0x48> HIDDEN _sk_load_g8_sse2 .globl _sk_load_g8_sse2 FUNCTION(_sk_load_g8_sse2) _sk_load_g8_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,49 // jne 37db <_sk_load_g8_sse2+0x49> .byte 102,67,15,110,4,25 // movd (%r9,%r11,1),%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 102,15,219,5,128,56,0,0 // pand 0x3880(%rip),%xmm0 # 7040 <_sk_callback_sse2+0xc83> .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,134,56,0,0 // mulps 0x3886(%rip),%xmm0 # 7050 <_sk_callback_sse2+0xc93> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,141,56,0,0 // movaps 0x388d(%rip),%xmm3 # 7060 <_sk_callback_sse2+0xca3> .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,54 // je 381e <_sk_load_g8_sse2+0x8c> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3807 <_sk_load_g8_sse2+0x75> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,192 // jne 37b8 <_sk_load_g8_sse2+0x26> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 102,15,96,200 // punpcklbw %xmm0,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 242,15,16,193 // movsd %xmm1,%xmm0 .byte 235,154 // jmp 37b8 <_sk_load_g8_sse2+0x26> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 235,143 // jmp 37b8 <_sk_load_g8_sse2+0x26> HIDDEN _sk_load_g8_dst_sse2 .globl _sk_load_g8_dst_sse2 FUNCTION(_sk_load_g8_dst_sse2) _sk_load_g8_dst_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,49 // jne 3872 <_sk_load_g8_dst_sse2+0x49> .byte 102,67,15,110,36,25 // movd (%r9,%r11,1),%xmm4 .byte 102,15,96,224 // punpcklbw %xmm0,%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 102,15,219,37,25,56,0,0 // pand 0x3819(%rip),%xmm4 # 7070 <_sk_callback_sse2+0xcb3> .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,37,31,56,0,0 // mulps 0x381f(%rip),%xmm4 # 7080 <_sk_callback_sse2+0xcc3> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,61,38,56,0,0 // movaps 0x3826(%rip),%xmm7 # 7090 <_sk_callback_sse2+0xcd3> .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,40,244 // movaps %xmm4,%xmm6 .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,54 // je 38b5 <_sk_load_g8_dst_sse2+0x8c> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 389e <_sk_load_g8_dst_sse2+0x75> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,192 // jne 384f <_sk_load_g8_dst_sse2+0x26> .byte 67,15,182,68,25,2 // movzbl 0x2(%r9,%r11,1),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 67,15,183,4,25 // movzwl (%r9,%r11,1),%eax .byte 102,15,110,232 // movd %eax,%xmm5 .byte 102,15,96,232 // punpcklbw %xmm0,%xmm5 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 242,15,16,229 // movsd %xmm5,%xmm4 .byte 235,154 // jmp 384f <_sk_load_g8_dst_sse2+0x26> .byte 67,15,182,4,25 // movzbl (%r9,%r11,1),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 235,143 // jmp 384f <_sk_load_g8_dst_sse2+0x26> HIDDEN _sk_gather_g8_sse2 .globl _sk_gather_g8_sse2 FUNCTION(_sk_gather_g8_sse2) _sk_gather_g8_sse2: .byte 85 // push %rbp .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,72,15,126,192 // movq %xmm0,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,15,112,192,78 // pshufd $0x4e,%xmm0,%xmm0 .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 65,15,182,44,25 // movzbl (%r9,%rbx,1),%ebp .byte 67,15,182,28,25 // movzbl (%r9,%r11,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 9,235 // or %ebp,%ebx .byte 67,15,182,44,17 // movzbl (%r9,%r10,1),%ebp .byte 65,15,182,4,1 // movzbl (%r9,%rax,1),%eax .byte 193,224,8 // shl $0x8,%eax .byte 9,232 // or %ebp,%eax .byte 102,15,196,192,0 // pinsrw $0x0,%eax,%xmm0 .byte 102,15,196,195,1 // pinsrw $0x1,%ebx,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,15,96,193 // punpcklbw %xmm1,%xmm0 .byte 102,15,97,193 // punpcklwd %xmm1,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,77,55,0,0 // mulps 0x374d(%rip),%xmm0 # 70a0 <_sk_callback_sse2+0xce3> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,84,55,0,0 // movaps 0x3754(%rip),%xmm3 # 70b0 <_sk_callback_sse2+0xcf3> .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 91 // pop %rbx .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax HIDDEN _sk_load_565_sse2 .globl _sk_load_565_sse2 FUNCTION(_sk_load_565_sse2) _sk_load_565_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,83 // jne 39d4 <_sk_load_565_sse2+0x6e> .byte 243,67,15,126,20,89 // movq (%r9,%r11,2),%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 102,15,111,5,45,55,0,0 // movdqa 0x372d(%rip),%xmm0 # 70c0 <_sk_callback_sse2+0xd03> .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,47,55,0,0 // mulps 0x372f(%rip),%xmm0 # 70d0 <_sk_callback_sse2+0xd13> .byte 102,15,111,13,55,55,0,0 // movdqa 0x3737(%rip),%xmm1 # 70e0 <_sk_callback_sse2+0xd23> .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,13,57,55,0,0 // mulps 0x3739(%rip),%xmm1 # 70f0 <_sk_callback_sse2+0xd33> .byte 102,15,219,21,65,55,0,0 // pand 0x3741(%rip),%xmm2 # 7100 <_sk_callback_sse2+0xd43> .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,21,71,55,0,0 // mulps 0x3747(%rip),%xmm2 # 7110 <_sk_callback_sse2+0xd53> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,78,55,0,0 // movaps 0x374e(%rip),%xmm3 # 7120 <_sk_callback_sse2+0xd63> .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,50 // je 3a13 <_sk_load_565_sse2+0xad> .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3a00 <_sk_load_565_sse2+0x9a> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,154 // jne 398b <_sk_load_565_sse2+0x25> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,208,69 // pshufd $0x45,%xmm0,%xmm2 .byte 102,67,15,110,4,89 // movd (%r9,%r11,2),%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 242,15,16,208 // movsd %xmm0,%xmm2 .byte 233,120,255,255,255 // jmpq 398b <_sk_load_565_sse2+0x25> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 233,106,255,255,255 // jmpq 398b <_sk_load_565_sse2+0x25> HIDDEN _sk_load_565_dst_sse2 .globl _sk_load_565_dst_sse2 FUNCTION(_sk_load_565_dst_sse2) _sk_load_565_dst_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,83 // jne 3a8f <_sk_load_565_dst_sse2+0x6e> .byte 243,67,15,126,52,89 // movq (%r9,%r11,2),%xmm6 .byte 102,15,97,240 // punpcklwd %xmm0,%xmm6 .byte 102,15,111,37,226,54,0,0 // movdqa 0x36e2(%rip),%xmm4 # 7130 <_sk_callback_sse2+0xd73> .byte 102,15,219,230 // pand %xmm6,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,37,228,54,0,0 // mulps 0x36e4(%rip),%xmm4 # 7140 <_sk_callback_sse2+0xd83> .byte 102,15,111,45,236,54,0,0 // movdqa 0x36ec(%rip),%xmm5 # 7150 <_sk_callback_sse2+0xd93> .byte 102,15,219,238 // pand %xmm6,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,45,238,54,0,0 // mulps 0x36ee(%rip),%xmm5 # 7160 <_sk_callback_sse2+0xda3> .byte 102,15,219,53,246,54,0,0 // pand 0x36f6(%rip),%xmm6 # 7170 <_sk_callback_sse2+0xdb3> .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,89,53,252,54,0,0 // mulps 0x36fc(%rip),%xmm6 # 7180 <_sk_callback_sse2+0xdc3> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,61,3,55,0,0 // movaps 0x3703(%rip),%xmm7 # 7190 <_sk_callback_sse2+0xdd3> .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,50 // je 3ace <_sk_load_565_dst_sse2+0xad> .byte 102,15,239,246 // pxor %xmm6,%xmm6 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3abb <_sk_load_565_dst_sse2+0x9a> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,154 // jne 3a46 <_sk_load_565_dst_sse2+0x25> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 102,15,112,244,69 // pshufd $0x45,%xmm4,%xmm6 .byte 102,67,15,110,36,89 // movd (%r9,%r11,2),%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 242,15,16,244 // movsd %xmm4,%xmm6 .byte 233,120,255,255,255 // jmpq 3a46 <_sk_load_565_dst_sse2+0x25> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,15,110,240 // movd %eax,%xmm6 .byte 233,106,255,255,255 // jmpq 3a46 <_sk_load_565_dst_sse2+0x25> HIDDEN _sk_gather_565_sse2 .globl _sk_gather_565_sse2 FUNCTION(_sk_gather_565_sse2) _sk_gather_565_sse2: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,72,15,126,200 // movq %xmm1,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,65,15,196,20,89,0 // pinsrw $0x0,(%r9,%rbx,2),%xmm2 .byte 102,67,15,196,20,89,1 // pinsrw $0x1,(%r9,%r11,2),%xmm2 .byte 67,15,183,28,81 // movzwl (%r9,%r10,2),%ebx .byte 102,15,196,211,2 // pinsrw $0x2,%ebx,%xmm2 .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 102,15,196,208,3 // pinsrw $0x3,%eax,%xmm2 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 102,15,111,5,62,54,0,0 // movdqa 0x363e(%rip),%xmm0 # 71a0 <_sk_callback_sse2+0xde3> .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,64,54,0,0 // mulps 0x3640(%rip),%xmm0 # 71b0 <_sk_callback_sse2+0xdf3> .byte 102,15,111,13,72,54,0,0 // movdqa 0x3648(%rip),%xmm1 # 71c0 <_sk_callback_sse2+0xe03> .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,13,74,54,0,0 // mulps 0x364a(%rip),%xmm1 # 71d0 <_sk_callback_sse2+0xe13> .byte 102,15,219,21,82,54,0,0 // pand 0x3652(%rip),%xmm2 # 71e0 <_sk_callback_sse2+0xe23> .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,21,88,54,0,0 // mulps 0x3658(%rip),%xmm2 # 71f0 <_sk_callback_sse2+0xe33> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,95,54,0,0 // movaps 0x365f(%rip),%xmm3 # 7200 <_sk_callback_sse2+0xe43> .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_565_sse2 .globl _sk_store_565_sse2 FUNCTION(_sk_store_565_sse2) _sk_store_565_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 68,15,40,5,78,54,0,0 // movaps 0x364e(%rip),%xmm8 # 7210 <_sk_callback_sse2+0xe53> .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,11 // pslld $0xb,%xmm9 .byte 68,15,40,21,67,54,0,0 // movaps 0x3643(%rip),%xmm10 # 7220 <_sk_callback_sse2+0xe63> .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,65,15,114,242,5 // pslld $0x5,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,69,15,86,194 // orpd %xmm10,%xmm8 .byte 102,65,15,114,240,16 // pslld $0x10,%xmm8 .byte 102,65,15,114,224,16 // psrad $0x10,%xmm8 .byte 102,69,15,107,192 // packssdw %xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,10 // jne 3c1f <_sk_store_565_sse2+0x7b> .byte 242,71,15,17,4,89 // movsd %xmm8,(%r9,%r11,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,68,15,97,192 // punpcklwd %xmm0,%xmm8 .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,38 // je 3c57 <_sk_store_565_sse2+0xb3> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,18 // je 3c49 <_sk_store_565_sse2+0xa5> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,222 // jne 3c1b <_sk_store_565_sse2+0x77> .byte 102,65,15,197,192,4 // pextrw $0x4,%xmm8,%eax .byte 102,67,137,68,89,4 // mov %ax,0x4(%r9,%r11,2) .byte 242,69,15,112,192,232 // pshuflw $0xe8,%xmm8,%xmm8 .byte 102,71,15,126,4,89 // movd %xmm8,(%r9,%r11,2) .byte 235,196 // jmp 3c1b <_sk_store_565_sse2+0x77> .byte 102,68,15,126,192 // movd %xmm8,%eax .byte 102,67,137,4,89 // mov %ax,(%r9,%r11,2) .byte 235,184 // jmp 3c1b <_sk_store_565_sse2+0x77> HIDDEN _sk_load_4444_sse2 .globl _sk_load_4444_sse2 FUNCTION(_sk_load_4444_sse2) _sk_load_4444_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,98 // jne 3ce0 <_sk_load_4444_sse2+0x7d> .byte 243,67,15,126,28,89 // movq (%r9,%r11,2),%xmm3 .byte 102,15,97,216 // punpcklwd %xmm0,%xmm3 .byte 102,15,111,5,160,53,0,0 // movdqa 0x35a0(%rip),%xmm0 # 7230 <_sk_callback_sse2+0xe73> .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,162,53,0,0 // mulps 0x35a2(%rip),%xmm0 # 7240 <_sk_callback_sse2+0xe83> .byte 102,15,111,13,170,53,0,0 // movdqa 0x35aa(%rip),%xmm1 # 7250 <_sk_callback_sse2+0xe93> .byte 102,15,219,203 // pand %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,13,172,53,0,0 // mulps 0x35ac(%rip),%xmm1 # 7260 <_sk_callback_sse2+0xea3> .byte 102,15,111,21,180,53,0,0 // movdqa 0x35b4(%rip),%xmm2 # 7270 <_sk_callback_sse2+0xeb3> .byte 102,15,219,211 // pand %xmm3,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,21,182,53,0,0 // mulps 0x35b6(%rip),%xmm2 # 7280 <_sk_callback_sse2+0xec3> .byte 102,15,219,29,190,53,0,0 // pand 0x35be(%rip),%xmm3 # 7290 <_sk_callback_sse2+0xed3> .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,29,196,53,0,0 // mulps 0x35c4(%rip),%xmm3 # 72a0 <_sk_callback_sse2+0xee3> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,50 // je 3d1f <_sk_load_4444_sse2+0xbc> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3d0c <_sk_load_4444_sse2+0xa9> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,139 // jne 3c88 <_sk_load_4444_sse2+0x25> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,216,69 // pshufd $0x45,%xmm0,%xmm3 .byte 102,67,15,110,4,89 // movd (%r9,%r11,2),%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 242,15,16,216 // movsd %xmm0,%xmm3 .byte 233,105,255,255,255 // jmpq 3c88 <_sk_load_4444_sse2+0x25> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,15,110,216 // movd %eax,%xmm3 .byte 233,91,255,255,255 // jmpq 3c88 <_sk_load_4444_sse2+0x25> HIDDEN _sk_load_4444_dst_sse2 .globl _sk_load_4444_dst_sse2 FUNCTION(_sk_load_4444_dst_sse2) _sk_load_4444_dst_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 77,133,192 // test %r8,%r8 .byte 117,98 // jne 3daa <_sk_load_4444_dst_sse2+0x7d> .byte 243,67,15,126,60,89 // movq (%r9,%r11,2),%xmm7 .byte 102,15,97,248 // punpcklwd %xmm0,%xmm7 .byte 102,15,111,37,86,53,0,0 // movdqa 0x3556(%rip),%xmm4 # 72b0 <_sk_callback_sse2+0xef3> .byte 102,15,219,231 // pand %xmm7,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,37,88,53,0,0 // mulps 0x3558(%rip),%xmm4 # 72c0 <_sk_callback_sse2+0xf03> .byte 102,15,111,45,96,53,0,0 // movdqa 0x3560(%rip),%xmm5 # 72d0 <_sk_callback_sse2+0xf13> .byte 102,15,219,239 // pand %xmm7,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,45,98,53,0,0 // mulps 0x3562(%rip),%xmm5 # 72e0 <_sk_callback_sse2+0xf23> .byte 102,15,111,53,106,53,0,0 // movdqa 0x356a(%rip),%xmm6 # 72f0 <_sk_callback_sse2+0xf33> .byte 102,15,219,247 // pand %xmm7,%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,89,53,108,53,0,0 // mulps 0x356c(%rip),%xmm6 # 7300 <_sk_callback_sse2+0xf43> .byte 102,15,219,61,116,53,0,0 // pand 0x3574(%rip),%xmm7 # 7310 <_sk_callback_sse2+0xf53> .byte 15,91,255 // cvtdq2ps %xmm7,%xmm7 .byte 15,89,61,122,53,0,0 // mulps 0x357a(%rip),%xmm7 # 7320 <_sk_callback_sse2+0xf63> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,50 // je 3de9 <_sk_load_4444_dst_sse2+0xbc> .byte 102,15,239,255 // pxor %xmm7,%xmm7 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,21 // je 3dd6 <_sk_load_4444_dst_sse2+0xa9> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,139 // jne 3d52 <_sk_load_4444_dst_sse2+0x25> .byte 67,15,183,68,89,4 // movzwl 0x4(%r9,%r11,2),%eax .byte 102,15,110,224 // movd %eax,%xmm4 .byte 102,15,112,252,69 // pshufd $0x45,%xmm4,%xmm7 .byte 102,67,15,110,36,89 // movd (%r9,%r11,2),%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 242,15,16,252 // movsd %xmm4,%xmm7 .byte 233,105,255,255,255 // jmpq 3d52 <_sk_load_4444_dst_sse2+0x25> .byte 67,15,183,4,89 // movzwl (%r9,%r11,2),%eax .byte 102,15,110,248 // movd %eax,%xmm7 .byte 233,91,255,255,255 // jmpq 3d52 <_sk_load_4444_dst_sse2+0x25> HIDDEN _sk_gather_4444_sse2 .globl _sk_gather_4444_sse2 FUNCTION(_sk_gather_4444_sse2) _sk_gather_4444_sse2: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,72,15,126,200 // movq %xmm1,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,65,15,196,28,89,0 // pinsrw $0x0,(%r9,%rbx,2),%xmm3 .byte 102,67,15,196,28,89,1 // pinsrw $0x1,(%r9,%r11,2),%xmm3 .byte 67,15,183,28,81 // movzwl (%r9,%r10,2),%ebx .byte 102,15,196,219,2 // pinsrw $0x2,%ebx,%xmm3 .byte 65,15,183,4,65 // movzwl (%r9,%rax,2),%eax .byte 102,15,196,216,3 // pinsrw $0x3,%eax,%xmm3 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 102,15,97,216 // punpcklwd %xmm0,%xmm3 .byte 102,15,111,5,179,52,0,0 // movdqa 0x34b3(%rip),%xmm0 # 7330 <_sk_callback_sse2+0xf73> .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,5,181,52,0,0 // mulps 0x34b5(%rip),%xmm0 # 7340 <_sk_callback_sse2+0xf83> .byte 102,15,111,13,189,52,0,0 // movdqa 0x34bd(%rip),%xmm1 # 7350 <_sk_callback_sse2+0xf93> .byte 102,15,219,203 // pand %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,13,191,52,0,0 // mulps 0x34bf(%rip),%xmm1 # 7360 <_sk_callback_sse2+0xfa3> .byte 102,15,111,21,199,52,0,0 // movdqa 0x34c7(%rip),%xmm2 # 7370 <_sk_callback_sse2+0xfb3> .byte 102,15,219,211 // pand %xmm3,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,21,201,52,0,0 // mulps 0x34c9(%rip),%xmm2 # 7380 <_sk_callback_sse2+0xfc3> .byte 102,15,219,29,209,52,0,0 // pand 0x34d1(%rip),%xmm3 # 7390 <_sk_callback_sse2+0xfd3> .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,29,215,52,0,0 // mulps 0x34d7(%rip),%xmm3 # 73a0 <_sk_callback_sse2+0xfe3> .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_4444_sse2 .globl _sk_store_4444_sse2 FUNCTION(_sk_store_4444_sse2) _sk_store_4444_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 76,99,218 // movslq %edx,%r11 .byte 68,15,40,5,196,52,0,0 // movaps 0x34c4(%rip),%xmm8 # 73b0 <_sk_callback_sse2+0xff3> .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,12 // pslld $0xc,%xmm9 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,65,15,114,242,8 // pslld $0x8,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,4 // pslld $0x4,%xmm9 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,69,15,86,193 // orpd %xmm9,%xmm8 .byte 102,69,15,86,194 // orpd %xmm10,%xmm8 .byte 102,65,15,114,240,16 // pslld $0x10,%xmm8 .byte 102,65,15,114,224,16 // psrad $0x10,%xmm8 .byte 102,69,15,107,192 // packssdw %xmm8,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,10 // jne 3f5d <_sk_store_4444_sse2+0x8f> .byte 242,71,15,17,4,89 // movsd %xmm8,(%r9,%r11,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,68,15,97,192 // punpcklwd %xmm0,%xmm8 .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,38 // je 3f95 <_sk_store_4444_sse2+0xc7> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,18 // je 3f87 <_sk_store_4444_sse2+0xb9> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,222 // jne 3f59 <_sk_store_4444_sse2+0x8b> .byte 102,65,15,197,192,4 // pextrw $0x4,%xmm8,%eax .byte 102,67,137,68,89,4 // mov %ax,0x4(%r9,%r11,2) .byte 242,69,15,112,192,232 // pshuflw $0xe8,%xmm8,%xmm8 .byte 102,71,15,126,4,89 // movd %xmm8,(%r9,%r11,2) .byte 235,196 // jmp 3f59 <_sk_store_4444_sse2+0x8b> .byte 102,68,15,126,192 // movd %xmm8,%eax .byte 102,67,137,4,89 // mov %ax,(%r9,%r11,2) .byte 235,184 // jmp 3f59 <_sk_store_4444_sse2+0x8b> HIDDEN _sk_load_8888_sse2 .globl _sk_load_8888_sse2 FUNCTION(_sk_load_8888_sse2) _sk_load_8888_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,98 // jne 401f <_sk_load_8888_sse2+0x7e> .byte 243,69,15,111,12,129 // movdqu (%r9,%rax,4),%xmm9 .byte 102,15,111,21,245,51,0,0 // movdqa 0x33f5(%rip),%xmm2 # 73c0 <_sk_callback_sse2+0x1003> .byte 102,65,15,111,193 // movdqa %xmm9,%xmm0 .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,5,241,51,0,0 // movaps 0x33f1(%rip),%xmm8 # 73d0 <_sk_callback_sse2+0x1013> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,65,15,111,201 // movdqa %xmm9,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,65,15,111,217 // movdqa %xmm9,%xmm3 .byte 102,15,114,211,16 // psrld $0x10,%xmm3 .byte 102,15,219,218 // pand %xmm2,%xmm3 .byte 15,91,211 // cvtdq2ps %xmm3,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,65,15,114,209,24 // psrld $0x18,%xmm9 .byte 65,15,91,217 // cvtdq2ps %xmm9,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,41 // je 4055 <_sk_load_8888_sse2+0xb4> .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,19 // je 404a <_sk_load_8888_sse2+0xa9> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,134 // jne 3fc3 <_sk_load_8888_sse2+0x22> .byte 102,65,15,110,68,129,8 // movd 0x8(%r9,%rax,4),%xmm0 .byte 102,68,15,112,200,69 // pshufd $0x45,%xmm0,%xmm9 .byte 102,69,15,18,12,129 // movlpd (%r9,%rax,4),%xmm9 .byte 233,110,255,255,255 // jmpq 3fc3 <_sk_load_8888_sse2+0x22> .byte 102,69,15,110,12,129 // movd (%r9,%rax,4),%xmm9 .byte 233,99,255,255,255 // jmpq 3fc3 <_sk_load_8888_sse2+0x22> HIDDEN _sk_load_8888_dst_sse2 .globl _sk_load_8888_dst_sse2 FUNCTION(_sk_load_8888_dst_sse2) _sk_load_8888_dst_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,98 // jne 40de <_sk_load_8888_dst_sse2+0x7e> .byte 243,69,15,111,12,129 // movdqu (%r9,%rax,4),%xmm9 .byte 102,15,111,53,86,51,0,0 // movdqa 0x3356(%rip),%xmm6 # 73e0 <_sk_callback_sse2+0x1023> .byte 102,65,15,111,225 // movdqa %xmm9,%xmm4 .byte 102,15,219,230 // pand %xmm6,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 68,15,40,5,82,51,0,0 // movaps 0x3352(%rip),%xmm8 # 73f0 <_sk_callback_sse2+0x1033> .byte 65,15,89,224 // mulps %xmm8,%xmm4 .byte 102,65,15,111,233 // movdqa %xmm9,%xmm5 .byte 102,15,114,213,8 // psrld $0x8,%xmm5 .byte 102,15,219,238 // pand %xmm6,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 65,15,89,232 // mulps %xmm8,%xmm5 .byte 102,65,15,111,249 // movdqa %xmm9,%xmm7 .byte 102,15,114,215,16 // psrld $0x10,%xmm7 .byte 102,15,219,254 // pand %xmm6,%xmm7 .byte 15,91,247 // cvtdq2ps %xmm7,%xmm6 .byte 65,15,89,240 // mulps %xmm8,%xmm6 .byte 102,65,15,114,209,24 // psrld $0x18,%xmm9 .byte 65,15,91,249 // cvtdq2ps %xmm9,%xmm7 .byte 65,15,89,248 // mulps %xmm8,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,41 // je 4114 <_sk_load_8888_dst_sse2+0xb4> .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,19 // je 4109 <_sk_load_8888_dst_sse2+0xa9> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,134 // jne 4082 <_sk_load_8888_dst_sse2+0x22> .byte 102,65,15,110,100,129,8 // movd 0x8(%r9,%rax,4),%xmm4 .byte 102,68,15,112,204,69 // pshufd $0x45,%xmm4,%xmm9 .byte 102,69,15,18,12,129 // movlpd (%r9,%rax,4),%xmm9 .byte 233,110,255,255,255 // jmpq 4082 <_sk_load_8888_dst_sse2+0x22> .byte 102,69,15,110,12,129 // movd (%r9,%rax,4),%xmm9 .byte 233,99,255,255,255 // jmpq 4082 <_sk_load_8888_dst_sse2+0x22> HIDDEN _sk_gather_8888_sse2 .globl _sk_gather_8888_sse2 FUNCTION(_sk_gather_8888_sse2) _sk_gather_8888_sse2: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,72,15,126,200 // movq %xmm1,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,67,15,110,4,153 // movd (%r9,%r11,4),%xmm0 .byte 102,65,15,110,12,129 // movd (%r9,%rax,4),%xmm1 .byte 102,15,98,193 // punpckldq %xmm1,%xmm0 .byte 102,69,15,110,12,153 // movd (%r9,%rbx,4),%xmm9 .byte 102,67,15,110,12,145 // movd (%r9,%r10,4),%xmm1 .byte 102,68,15,98,201 // punpckldq %xmm1,%xmm9 .byte 102,68,15,98,200 // punpckldq %xmm0,%xmm9 .byte 102,15,111,21,95,50,0,0 // movdqa 0x325f(%rip),%xmm2 # 7400 <_sk_callback_sse2+0x1043> .byte 102,65,15,111,193 // movdqa %xmm9,%xmm0 .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 68,15,40,5,91,50,0,0 // movaps 0x325b(%rip),%xmm8 # 7410 <_sk_callback_sse2+0x1053> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,65,15,111,201 // movdqa %xmm9,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,65,15,111,217 // movdqa %xmm9,%xmm3 .byte 102,15,114,211,16 // psrld $0x10,%xmm3 .byte 102,15,219,218 // pand %xmm2,%xmm3 .byte 15,91,211 // cvtdq2ps %xmm3,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,65,15,114,209,24 // psrld $0x18,%xmm9 .byte 65,15,91,217 // cvtdq2ps %xmm9,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_8888_sse2 .globl _sk_store_8888_sse2 FUNCTION(_sk_store_8888_sse2) _sk_store_8888_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 68,15,40,5,11,50,0,0 // movaps 0x320b(%rip),%xmm8 # 7420 <_sk_callback_sse2+0x1063> .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,65,15,114,242,8 // pslld $0x8,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,16 // pslld $0x10,%xmm9 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,114,240,24 // pslld $0x18,%xmm8 .byte 102,69,15,235,193 // por %xmm9,%xmm8 .byte 102,69,15,235,194 // por %xmm10,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,10 // jne 4275 <_sk_store_8888_sse2+0x7f> .byte 243,69,15,127,4,129 // movdqu %xmm8,(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,33 // je 42a3 <_sk_store_8888_sse2+0xad> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,19 // je 429b <_sk_store_8888_sse2+0xa5> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,227 // jne 4271 <_sk_store_8888_sse2+0x7b> .byte 102,69,15,112,200,78 // pshufd $0x4e,%xmm8,%xmm9 .byte 102,69,15,126,76,129,8 // movd %xmm9,0x8(%r9,%rax,4) .byte 102,69,15,214,4,129 // movq %xmm8,(%r9,%rax,4) .byte 235,206 // jmp 4271 <_sk_store_8888_sse2+0x7b> .byte 102,69,15,126,4,129 // movd %xmm8,(%r9,%rax,4) .byte 235,198 // jmp 4271 <_sk_store_8888_sse2+0x7b> HIDDEN _sk_load_bgra_sse2 .globl _sk_load_bgra_sse2 FUNCTION(_sk_load_bgra_sse2) _sk_load_bgra_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,98 // jne 4329 <_sk_load_bgra_sse2+0x7e> .byte 243,69,15,111,12,129 // movdqu (%r9,%rax,4),%xmm9 .byte 102,15,111,5,91,49,0,0 // movdqa 0x315b(%rip),%xmm0 # 7430 <_sk_callback_sse2+0x1073> .byte 102,65,15,111,201 // movdqa %xmm9,%xmm1 .byte 102,15,219,200 // pand %xmm0,%xmm1 .byte 15,91,209 // cvtdq2ps %xmm1,%xmm2 .byte 68,15,40,5,87,49,0,0 // movaps 0x3157(%rip),%xmm8 # 7440 <_sk_callback_sse2+0x1083> .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,65,15,111,201 // movdqa %xmm9,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,15,219,200 // pand %xmm0,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,65,15,111,217 // movdqa %xmm9,%xmm3 .byte 102,15,114,211,16 // psrld $0x10,%xmm3 .byte 102,15,219,216 // pand %xmm0,%xmm3 .byte 15,91,195 // cvtdq2ps %xmm3,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,65,15,114,209,24 // psrld $0x18,%xmm9 .byte 65,15,91,217 // cvtdq2ps %xmm9,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,41 // je 435f <_sk_load_bgra_sse2+0xb4> .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,19 // je 4354 <_sk_load_bgra_sse2+0xa9> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,134 // jne 42cd <_sk_load_bgra_sse2+0x22> .byte 102,65,15,110,68,129,8 // movd 0x8(%r9,%rax,4),%xmm0 .byte 102,68,15,112,200,69 // pshufd $0x45,%xmm0,%xmm9 .byte 102,69,15,18,12,129 // movlpd (%r9,%rax,4),%xmm9 .byte 233,110,255,255,255 // jmpq 42cd <_sk_load_bgra_sse2+0x22> .byte 102,69,15,110,12,129 // movd (%r9,%rax,4),%xmm9 .byte 233,99,255,255,255 // jmpq 42cd <_sk_load_bgra_sse2+0x22> HIDDEN _sk_load_bgra_dst_sse2 .globl _sk_load_bgra_dst_sse2 FUNCTION(_sk_load_bgra_dst_sse2) _sk_load_bgra_dst_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 117,98 // jne 43e8 <_sk_load_bgra_dst_sse2+0x7e> .byte 243,69,15,111,12,129 // movdqu (%r9,%rax,4),%xmm9 .byte 102,15,111,37,188,48,0,0 // movdqa 0x30bc(%rip),%xmm4 # 7450 <_sk_callback_sse2+0x1093> .byte 102,65,15,111,233 // movdqa %xmm9,%xmm5 .byte 102,15,219,236 // pand %xmm4,%xmm5 .byte 15,91,245 // cvtdq2ps %xmm5,%xmm6 .byte 68,15,40,5,184,48,0,0 // movaps 0x30b8(%rip),%xmm8 # 7460 <_sk_callback_sse2+0x10a3> .byte 65,15,89,240 // mulps %xmm8,%xmm6 .byte 102,65,15,111,233 // movdqa %xmm9,%xmm5 .byte 102,15,114,213,8 // psrld $0x8,%xmm5 .byte 102,15,219,236 // pand %xmm4,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 65,15,89,232 // mulps %xmm8,%xmm5 .byte 102,65,15,111,249 // movdqa %xmm9,%xmm7 .byte 102,15,114,215,16 // psrld $0x10,%xmm7 .byte 102,15,219,252 // pand %xmm4,%xmm7 .byte 15,91,231 // cvtdq2ps %xmm7,%xmm4 .byte 65,15,89,224 // mulps %xmm8,%xmm4 .byte 102,65,15,114,209,24 // psrld $0x18,%xmm9 .byte 65,15,91,249 // cvtdq2ps %xmm9,%xmm7 .byte 65,15,89,248 // mulps %xmm8,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,41 // je 441e <_sk_load_bgra_dst_sse2+0xb4> .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,19 // je 4413 <_sk_load_bgra_dst_sse2+0xa9> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,134 // jne 438c <_sk_load_bgra_dst_sse2+0x22> .byte 102,65,15,110,100,129,8 // movd 0x8(%r9,%rax,4),%xmm4 .byte 102,68,15,112,204,69 // pshufd $0x45,%xmm4,%xmm9 .byte 102,69,15,18,12,129 // movlpd (%r9,%rax,4),%xmm9 .byte 233,110,255,255,255 // jmpq 438c <_sk_load_bgra_dst_sse2+0x22> .byte 102,69,15,110,12,129 // movd (%r9,%rax,4),%xmm9 .byte 233,99,255,255,255 // jmpq 438c <_sk_load_bgra_dst_sse2+0x22> HIDDEN _sk_gather_bgra_sse2 .globl _sk_gather_bgra_sse2 FUNCTION(_sk_gather_bgra_sse2) _sk_gather_bgra_sse2: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,72,15,126,200 // movq %xmm1,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,67,15,110,4,153 // movd (%r9,%r11,4),%xmm0 .byte 102,65,15,110,12,129 // movd (%r9,%rax,4),%xmm1 .byte 102,15,98,193 // punpckldq %xmm1,%xmm0 .byte 102,69,15,110,12,153 // movd (%r9,%rbx,4),%xmm9 .byte 102,67,15,110,12,145 // movd (%r9,%r10,4),%xmm1 .byte 102,68,15,98,201 // punpckldq %xmm1,%xmm9 .byte 102,68,15,98,200 // punpckldq %xmm0,%xmm9 .byte 102,15,111,5,197,47,0,0 // movdqa 0x2fc5(%rip),%xmm0 # 7470 <_sk_callback_sse2+0x10b3> .byte 102,65,15,111,201 // movdqa %xmm9,%xmm1 .byte 102,15,219,200 // pand %xmm0,%xmm1 .byte 15,91,209 // cvtdq2ps %xmm1,%xmm2 .byte 68,15,40,5,193,47,0,0 // movaps 0x2fc1(%rip),%xmm8 # 7480 <_sk_callback_sse2+0x10c3> .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,65,15,111,201 // movdqa %xmm9,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,15,219,200 // pand %xmm0,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,65,15,111,217 // movdqa %xmm9,%xmm3 .byte 102,15,114,211,16 // psrld $0x10,%xmm3 .byte 102,15,219,216 // pand %xmm0,%xmm3 .byte 15,91,195 // cvtdq2ps %xmm3,%xmm0 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,65,15,114,209,24 // psrld $0x18,%xmm9 .byte 65,15,91,217 // cvtdq2ps %xmm9,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_bgra_sse2 .globl _sk_store_bgra_sse2 FUNCTION(_sk_store_bgra_sse2) _sk_store_bgra_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 68,15,40,5,113,47,0,0 // movaps 0x2f71(%rip),%xmm8 # 7490 <_sk_callback_sse2+0x10d3> .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,65,15,114,242,8 // pslld $0x8,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,16 // pslld $0x10,%xmm9 .byte 68,15,89,195 // mulps %xmm3,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,114,240,24 // pslld $0x18,%xmm8 .byte 102,69,15,235,193 // por %xmm9,%xmm8 .byte 102,69,15,235,194 // por %xmm10,%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,10 // jne 457f <_sk_store_bgra_sse2+0x7f> .byte 243,69,15,127,4,129 // movdqu %xmm8,(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,137,194 // mov %r8d,%r10d .byte 65,128,226,3 // and $0x3,%r10b .byte 65,128,250,1 // cmp $0x1,%r10b .byte 116,33 // je 45ad <_sk_store_bgra_sse2+0xad> .byte 65,128,250,2 // cmp $0x2,%r10b .byte 116,19 // je 45a5 <_sk_store_bgra_sse2+0xa5> .byte 65,128,250,3 // cmp $0x3,%r10b .byte 117,227 // jne 457b <_sk_store_bgra_sse2+0x7b> .byte 102,69,15,112,200,78 // pshufd $0x4e,%xmm8,%xmm9 .byte 102,69,15,126,76,129,8 // movd %xmm9,0x8(%r9,%rax,4) .byte 102,69,15,214,4,129 // movq %xmm8,(%r9,%rax,4) .byte 235,206 // jmp 457b <_sk_store_bgra_sse2+0x7b> .byte 102,69,15,126,4,129 // movd %xmm8,(%r9,%rax,4) .byte 235,198 // jmp 457b <_sk_store_bgra_sse2+0x7b> HIDDEN _sk_load_f16_sse2 .globl _sk_load_f16_sse2 FUNCTION(_sk_load_f16_sse2) _sk_load_f16_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,98,1,0,0 // jne 4737 <_sk_load_f16_sse2+0x182> .byte 102,65,15,16,4,193 // movupd (%r9,%rax,8),%xmm0 .byte 102,65,15,16,76,193,16 // movupd 0x10(%r9,%rax,8),%xmm1 .byte 102,68,15,40,192 // movapd %xmm0,%xmm8 .byte 102,68,15,97,193 // punpcklwd %xmm1,%xmm8 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,69,15,111,240 // movdqa %xmm8,%xmm14 .byte 102,68,15,97,240 // punpcklwd %xmm0,%xmm14 .byte 102,68,15,105,192 // punpckhwd %xmm0,%xmm8 .byte 102,69,15,239,210 // pxor %xmm10,%xmm10 .byte 102,65,15,111,206 // movdqa %xmm14,%xmm1 .byte 102,65,15,97,202 // punpcklwd %xmm10,%xmm1 .byte 102,68,15,111,13,137,46,0,0 // movdqa 0x2e89(%rip),%xmm9 # 74a0 <_sk_callback_sse2+0x10e3> .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,65,15,219,193 // pand %xmm9,%xmm0 .byte 102,15,239,200 // pxor %xmm0,%xmm1 .byte 102,15,114,240,16 // pslld $0x10,%xmm0 .byte 102,68,15,111,233 // movdqa %xmm1,%xmm13 .byte 102,65,15,114,245,13 // pslld $0xd,%xmm13 .byte 102,68,15,235,232 // por %xmm0,%xmm13 .byte 102,68,15,111,29,110,46,0,0 // movdqa 0x2e6e(%rip),%xmm11 # 74b0 <_sk_callback_sse2+0x10f3> .byte 102,69,15,254,235 // paddd %xmm11,%xmm13 .byte 102,68,15,111,37,112,46,0,0 // movdqa 0x2e70(%rip),%xmm12 # 74c0 <_sk_callback_sse2+0x1103> .byte 102,65,15,239,204 // pxor %xmm12,%xmm1 .byte 102,15,111,29,115,46,0,0 // movdqa 0x2e73(%rip),%xmm3 # 74d0 <_sk_callback_sse2+0x1113> .byte 102,15,111,195 // movdqa %xmm3,%xmm0 .byte 102,15,102,193 // pcmpgtd %xmm1,%xmm0 .byte 102,65,15,223,197 // pandn %xmm13,%xmm0 .byte 102,65,15,115,222,8 // psrldq $0x8,%xmm14 .byte 102,69,15,97,242 // punpcklwd %xmm10,%xmm14 .byte 102,65,15,111,206 // movdqa %xmm14,%xmm1 .byte 102,65,15,219,201 // pand %xmm9,%xmm1 .byte 102,68,15,239,241 // pxor %xmm1,%xmm14 .byte 102,15,114,241,16 // pslld $0x10,%xmm1 .byte 102,65,15,111,214 // movdqa %xmm14,%xmm2 .byte 102,15,114,242,13 // pslld $0xd,%xmm2 .byte 102,15,235,209 // por %xmm1,%xmm2 .byte 102,65,15,254,211 // paddd %xmm11,%xmm2 .byte 102,69,15,239,244 // pxor %xmm12,%xmm14 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,65,15,102,206 // pcmpgtd %xmm14,%xmm1 .byte 102,15,223,202 // pandn %xmm2,%xmm1 .byte 102,69,15,111,232 // movdqa %xmm8,%xmm13 .byte 102,69,15,97,234 // punpcklwd %xmm10,%xmm13 .byte 102,65,15,111,213 // movdqa %xmm13,%xmm2 .byte 102,65,15,219,209 // pand %xmm9,%xmm2 .byte 102,68,15,239,234 // pxor %xmm2,%xmm13 .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,69,15,111,245 // movdqa %xmm13,%xmm14 .byte 102,65,15,114,246,13 // pslld $0xd,%xmm14 .byte 102,68,15,235,242 // por %xmm2,%xmm14 .byte 102,69,15,254,243 // paddd %xmm11,%xmm14 .byte 102,69,15,239,236 // pxor %xmm12,%xmm13 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,65,15,102,213 // pcmpgtd %xmm13,%xmm2 .byte 102,65,15,223,214 // pandn %xmm14,%xmm2 .byte 102,65,15,115,216,8 // psrldq $0x8,%xmm8 .byte 102,69,15,97,194 // punpcklwd %xmm10,%xmm8 .byte 102,69,15,219,200 // pand %xmm8,%xmm9 .byte 102,69,15,239,193 // pxor %xmm9,%xmm8 .byte 102,65,15,114,241,16 // pslld $0x10,%xmm9 .byte 102,69,15,111,208 // movdqa %xmm8,%xmm10 .byte 102,65,15,114,242,13 // pslld $0xd,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 102,69,15,254,211 // paddd %xmm11,%xmm10 .byte 102,69,15,239,196 // pxor %xmm12,%xmm8 .byte 102,65,15,102,216 // pcmpgtd %xmm8,%xmm3 .byte 102,65,15,223,218 // pandn %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 242,65,15,16,4,193 // movsd (%r9,%rax,8),%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,17 // jne 4754 <_sk_load_f16_sse2+0x19f> .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 102,15,20,193 // unpcklpd %xmm1,%xmm0 .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 233,142,254,255,255 // jmpq 45e2 <_sk_load_f16_sse2+0x2d> .byte 102,65,15,22,68,193,8 // movhpd 0x8(%r9,%rax,8),%xmm0 .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 15,130,121,254,255,255 // jb 45e2 <_sk_load_f16_sse2+0x2d> .byte 242,65,15,16,76,193,16 // movsd 0x10(%r9,%rax,8),%xmm1 .byte 233,109,254,255,255 // jmpq 45e2 <_sk_load_f16_sse2+0x2d> HIDDEN _sk_load_f16_dst_sse2 .globl _sk_load_f16_dst_sse2 FUNCTION(_sk_load_f16_dst_sse2) _sk_load_f16_dst_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,98,1,0,0 // jne 48f7 <_sk_load_f16_dst_sse2+0x182> .byte 102,65,15,16,36,193 // movupd (%r9,%rax,8),%xmm4 .byte 102,65,15,16,108,193,16 // movupd 0x10(%r9,%rax,8),%xmm5 .byte 102,68,15,40,196 // movapd %xmm4,%xmm8 .byte 102,68,15,97,197 // punpcklwd %xmm5,%xmm8 .byte 102,15,105,229 // punpckhwd %xmm5,%xmm4 .byte 102,69,15,111,240 // movdqa %xmm8,%xmm14 .byte 102,68,15,97,244 // punpcklwd %xmm4,%xmm14 .byte 102,68,15,105,196 // punpckhwd %xmm4,%xmm8 .byte 102,69,15,239,210 // pxor %xmm10,%xmm10 .byte 102,65,15,111,238 // movdqa %xmm14,%xmm5 .byte 102,65,15,97,234 // punpcklwd %xmm10,%xmm5 .byte 102,68,15,111,13,9,45,0,0 // movdqa 0x2d09(%rip),%xmm9 # 74e0 <_sk_callback_sse2+0x1123> .byte 102,15,111,229 // movdqa %xmm5,%xmm4 .byte 102,65,15,219,225 // pand %xmm9,%xmm4 .byte 102,15,239,236 // pxor %xmm4,%xmm5 .byte 102,15,114,244,16 // pslld $0x10,%xmm4 .byte 102,68,15,111,237 // movdqa %xmm5,%xmm13 .byte 102,65,15,114,245,13 // pslld $0xd,%xmm13 .byte 102,68,15,235,236 // por %xmm4,%xmm13 .byte 102,68,15,111,29,238,44,0,0 // movdqa 0x2cee(%rip),%xmm11 # 74f0 <_sk_callback_sse2+0x1133> .byte 102,69,15,254,235 // paddd %xmm11,%xmm13 .byte 102,68,15,111,37,240,44,0,0 // movdqa 0x2cf0(%rip),%xmm12 # 7500 <_sk_callback_sse2+0x1143> .byte 102,65,15,239,236 // pxor %xmm12,%xmm5 .byte 102,15,111,61,243,44,0,0 // movdqa 0x2cf3(%rip),%xmm7 # 7510 <_sk_callback_sse2+0x1153> .byte 102,15,111,231 // movdqa %xmm7,%xmm4 .byte 102,15,102,229 // pcmpgtd %xmm5,%xmm4 .byte 102,65,15,223,229 // pandn %xmm13,%xmm4 .byte 102,65,15,115,222,8 // psrldq $0x8,%xmm14 .byte 102,69,15,97,242 // punpcklwd %xmm10,%xmm14 .byte 102,65,15,111,238 // movdqa %xmm14,%xmm5 .byte 102,65,15,219,233 // pand %xmm9,%xmm5 .byte 102,68,15,239,245 // pxor %xmm5,%xmm14 .byte 102,15,114,245,16 // pslld $0x10,%xmm5 .byte 102,65,15,111,246 // movdqa %xmm14,%xmm6 .byte 102,15,114,246,13 // pslld $0xd,%xmm6 .byte 102,15,235,245 // por %xmm5,%xmm6 .byte 102,65,15,254,243 // paddd %xmm11,%xmm6 .byte 102,69,15,239,244 // pxor %xmm12,%xmm14 .byte 102,15,111,239 // movdqa %xmm7,%xmm5 .byte 102,65,15,102,238 // pcmpgtd %xmm14,%xmm5 .byte 102,15,223,238 // pandn %xmm6,%xmm5 .byte 102,69,15,111,232 // movdqa %xmm8,%xmm13 .byte 102,69,15,97,234 // punpcklwd %xmm10,%xmm13 .byte 102,65,15,111,245 // movdqa %xmm13,%xmm6 .byte 102,65,15,219,241 // pand %xmm9,%xmm6 .byte 102,68,15,239,238 // pxor %xmm6,%xmm13 .byte 102,15,114,246,16 // pslld $0x10,%xmm6 .byte 102,69,15,111,245 // movdqa %xmm13,%xmm14 .byte 102,65,15,114,246,13 // pslld $0xd,%xmm14 .byte 102,68,15,235,246 // por %xmm6,%xmm14 .byte 102,69,15,254,243 // paddd %xmm11,%xmm14 .byte 102,69,15,239,236 // pxor %xmm12,%xmm13 .byte 102,15,111,247 // movdqa %xmm7,%xmm6 .byte 102,65,15,102,245 // pcmpgtd %xmm13,%xmm6 .byte 102,65,15,223,246 // pandn %xmm14,%xmm6 .byte 102,65,15,115,216,8 // psrldq $0x8,%xmm8 .byte 102,69,15,97,194 // punpcklwd %xmm10,%xmm8 .byte 102,69,15,219,200 // pand %xmm8,%xmm9 .byte 102,69,15,239,193 // pxor %xmm9,%xmm8 .byte 102,65,15,114,241,16 // pslld $0x10,%xmm9 .byte 102,69,15,111,208 // movdqa %xmm8,%xmm10 .byte 102,65,15,114,242,13 // pslld $0xd,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 102,69,15,254,211 // paddd %xmm11,%xmm10 .byte 102,69,15,239,196 // pxor %xmm12,%xmm8 .byte 102,65,15,102,248 // pcmpgtd %xmm8,%xmm7 .byte 102,65,15,223,250 // pandn %xmm10,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 242,65,15,16,36,193 // movsd (%r9,%rax,8),%xmm4 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,17 // jne 4914 <_sk_load_f16_dst_sse2+0x19f> .byte 102,15,87,237 // xorpd %xmm5,%xmm5 .byte 102,15,20,229 // unpcklpd %xmm5,%xmm4 .byte 102,15,87,237 // xorpd %xmm5,%xmm5 .byte 233,142,254,255,255 // jmpq 47a2 <_sk_load_f16_dst_sse2+0x2d> .byte 102,65,15,22,100,193,8 // movhpd 0x8(%r9,%rax,8),%xmm4 .byte 102,15,87,237 // xorpd %xmm5,%xmm5 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 15,130,121,254,255,255 // jb 47a2 <_sk_load_f16_dst_sse2+0x2d> .byte 242,65,15,16,108,193,16 // movsd 0x10(%r9,%rax,8),%xmm5 .byte 233,109,254,255,255 // jmpq 47a2 <_sk_load_f16_dst_sse2+0x2d> HIDDEN _sk_gather_f16_sse2 .globl _sk_gather_f16_sse2 FUNCTION(_sk_gather_f16_sse2) _sk_gather_f16_sse2: .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,80,8 // movd 0x8(%rax),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,72,15,126,200 // movq %xmm1,%rax .byte 65,137,194 // mov %eax,%r10d .byte 72,193,232,32 // shr $0x20,%rax .byte 102,73,15,126,195 // movq %xmm0,%r11 .byte 68,137,219 // mov %r11d,%ebx .byte 73,193,235,32 // shr $0x20,%r11 .byte 243,67,15,126,4,217 // movq (%r9,%r11,8),%xmm0 .byte 243,65,15,126,12,217 // movq (%r9,%rbx,8),%xmm1 .byte 102,15,108,200 // punpcklqdq %xmm0,%xmm1 .byte 243,65,15,126,4,193 // movq (%r9,%rax,8),%xmm0 .byte 243,67,15,126,20,209 // movq (%r9,%r10,8),%xmm2 .byte 102,15,108,208 // punpcklqdq %xmm0,%xmm2 .byte 102,68,15,111,193 // movdqa %xmm1,%xmm8 .byte 102,68,15,97,194 // punpcklwd %xmm2,%xmm8 .byte 102,15,105,202 // punpckhwd %xmm2,%xmm1 .byte 102,69,15,111,240 // movdqa %xmm8,%xmm14 .byte 102,68,15,97,241 // punpcklwd %xmm1,%xmm14 .byte 102,68,15,105,193 // punpckhwd %xmm1,%xmm8 .byte 102,69,15,239,210 // pxor %xmm10,%xmm10 .byte 102,65,15,111,206 // movdqa %xmm14,%xmm1 .byte 102,65,15,97,202 // punpcklwd %xmm10,%xmm1 .byte 102,68,15,111,13,66,43,0,0 // movdqa 0x2b42(%rip),%xmm9 # 7520 <_sk_callback_sse2+0x1163> .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,65,15,219,193 // pand %xmm9,%xmm0 .byte 102,15,239,200 // pxor %xmm0,%xmm1 .byte 102,15,114,240,16 // pslld $0x10,%xmm0 .byte 102,68,15,111,233 // movdqa %xmm1,%xmm13 .byte 102,65,15,114,245,13 // pslld $0xd,%xmm13 .byte 102,68,15,235,232 // por %xmm0,%xmm13 .byte 102,68,15,111,29,39,43,0,0 // movdqa 0x2b27(%rip),%xmm11 # 7530 <_sk_callback_sse2+0x1173> .byte 102,69,15,254,235 // paddd %xmm11,%xmm13 .byte 102,68,15,111,37,41,43,0,0 // movdqa 0x2b29(%rip),%xmm12 # 7540 <_sk_callback_sse2+0x1183> .byte 102,65,15,239,204 // pxor %xmm12,%xmm1 .byte 102,15,111,29,44,43,0,0 // movdqa 0x2b2c(%rip),%xmm3 # 7550 <_sk_callback_sse2+0x1193> .byte 102,15,111,195 // movdqa %xmm3,%xmm0 .byte 102,15,102,193 // pcmpgtd %xmm1,%xmm0 .byte 102,65,15,223,197 // pandn %xmm13,%xmm0 .byte 102,65,15,115,222,8 // psrldq $0x8,%xmm14 .byte 102,69,15,97,242 // punpcklwd %xmm10,%xmm14 .byte 102,65,15,111,206 // movdqa %xmm14,%xmm1 .byte 102,65,15,219,201 // pand %xmm9,%xmm1 .byte 102,68,15,239,241 // pxor %xmm1,%xmm14 .byte 102,15,114,241,16 // pslld $0x10,%xmm1 .byte 102,65,15,111,214 // movdqa %xmm14,%xmm2 .byte 102,15,114,242,13 // pslld $0xd,%xmm2 .byte 102,15,235,209 // por %xmm1,%xmm2 .byte 102,65,15,254,211 // paddd %xmm11,%xmm2 .byte 102,69,15,239,244 // pxor %xmm12,%xmm14 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,65,15,102,206 // pcmpgtd %xmm14,%xmm1 .byte 102,15,223,202 // pandn %xmm2,%xmm1 .byte 102,69,15,111,232 // movdqa %xmm8,%xmm13 .byte 102,69,15,97,234 // punpcklwd %xmm10,%xmm13 .byte 102,65,15,111,213 // movdqa %xmm13,%xmm2 .byte 102,65,15,219,209 // pand %xmm9,%xmm2 .byte 102,68,15,239,234 // pxor %xmm2,%xmm13 .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,69,15,111,245 // movdqa %xmm13,%xmm14 .byte 102,65,15,114,246,13 // pslld $0xd,%xmm14 .byte 102,68,15,235,242 // por %xmm2,%xmm14 .byte 102,69,15,254,243 // paddd %xmm11,%xmm14 .byte 102,69,15,239,236 // pxor %xmm12,%xmm13 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,65,15,102,213 // pcmpgtd %xmm13,%xmm2 .byte 102,65,15,223,214 // pandn %xmm14,%xmm2 .byte 102,65,15,115,216,8 // psrldq $0x8,%xmm8 .byte 102,69,15,97,194 // punpcklwd %xmm10,%xmm8 .byte 102,69,15,219,200 // pand %xmm8,%xmm9 .byte 102,69,15,239,193 // pxor %xmm9,%xmm8 .byte 102,65,15,114,241,16 // pslld $0x10,%xmm9 .byte 102,69,15,111,208 // movdqa %xmm8,%xmm10 .byte 102,65,15,114,242,13 // pslld $0xd,%xmm10 .byte 102,69,15,235,209 // por %xmm9,%xmm10 .byte 102,69,15,254,211 // paddd %xmm11,%xmm10 .byte 102,69,15,239,196 // pxor %xmm12,%xmm8 .byte 102,65,15,102,216 // pcmpgtd %xmm8,%xmm3 .byte 102,65,15,223,218 // pandn %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 91 // pop %rbx .byte 255,224 // jmpq *%rax HIDDEN _sk_store_f16_sse2 .globl _sk_store_f16_sse2 FUNCTION(_sk_store_f16_sse2) _sk_store_f16_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 73,193,225,3 // shl $0x3,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,99,194 // movslq %edx,%rax .byte 102,68,15,111,21,65,42,0,0 // movdqa 0x2a41(%rip),%xmm10 # 7560 <_sk_callback_sse2+0x11a3> .byte 102,68,15,111,224 // movdqa %xmm0,%xmm12 .byte 102,69,15,219,226 // pand %xmm10,%xmm12 .byte 102,68,15,111,232 // movdqa %xmm0,%xmm13 .byte 102,69,15,239,236 // pxor %xmm12,%xmm13 .byte 102,68,15,111,13,52,42,0,0 // movdqa 0x2a34(%rip),%xmm9 # 7570 <_sk_callback_sse2+0x11b3> .byte 102,65,15,114,212,16 // psrld $0x10,%xmm12 .byte 102,69,15,111,193 // movdqa %xmm9,%xmm8 .byte 102,69,15,102,197 // pcmpgtd %xmm13,%xmm8 .byte 102,65,15,114,213,13 // psrld $0xd,%xmm13 .byte 102,68,15,111,29,37,42,0,0 // movdqa 0x2a25(%rip),%xmm11 # 7580 <_sk_callback_sse2+0x11c3> .byte 102,69,15,235,227 // por %xmm11,%xmm12 .byte 102,69,15,254,229 // paddd %xmm13,%xmm12 .byte 102,65,15,114,244,16 // pslld $0x10,%xmm12 .byte 102,65,15,114,228,16 // psrad $0x10,%xmm12 .byte 102,69,15,223,196 // pandn %xmm12,%xmm8 .byte 102,69,15,107,192 // packssdw %xmm8,%xmm8 .byte 102,68,15,111,225 // movdqa %xmm1,%xmm12 .byte 102,69,15,219,226 // pand %xmm10,%xmm12 .byte 102,68,15,111,241 // movdqa %xmm1,%xmm14 .byte 102,69,15,239,244 // pxor %xmm12,%xmm14 .byte 102,65,15,114,212,16 // psrld $0x10,%xmm12 .byte 102,69,15,111,233 // movdqa %xmm9,%xmm13 .byte 102,69,15,102,238 // pcmpgtd %xmm14,%xmm13 .byte 102,65,15,114,214,13 // psrld $0xd,%xmm14 .byte 102,69,15,235,227 // por %xmm11,%xmm12 .byte 102,69,15,254,230 // paddd %xmm14,%xmm12 .byte 102,65,15,114,244,16 // pslld $0x10,%xmm12 .byte 102,65,15,114,228,16 // psrad $0x10,%xmm12 .byte 102,69,15,223,236 // pandn %xmm12,%xmm13 .byte 102,69,15,107,237 // packssdw %xmm13,%xmm13 .byte 102,68,15,111,242 // movdqa %xmm2,%xmm14 .byte 102,69,15,219,242 // pand %xmm10,%xmm14 .byte 102,68,15,111,250 // movdqa %xmm2,%xmm15 .byte 102,69,15,239,254 // pxor %xmm14,%xmm15 .byte 102,65,15,114,214,16 // psrld $0x10,%xmm14 .byte 102,69,15,111,225 // movdqa %xmm9,%xmm12 .byte 102,69,15,102,231 // pcmpgtd %xmm15,%xmm12 .byte 102,65,15,114,215,13 // psrld $0xd,%xmm15 .byte 102,69,15,235,243 // por %xmm11,%xmm14 .byte 102,69,15,254,247 // paddd %xmm15,%xmm14 .byte 102,65,15,114,246,16 // pslld $0x10,%xmm14 .byte 102,65,15,114,230,16 // psrad $0x10,%xmm14 .byte 102,69,15,223,230 // pandn %xmm14,%xmm12 .byte 102,69,15,107,228 // packssdw %xmm12,%xmm12 .byte 102,68,15,219,211 // pand %xmm3,%xmm10 .byte 102,68,15,111,243 // movdqa %xmm3,%xmm14 .byte 102,69,15,239,242 // pxor %xmm10,%xmm14 .byte 102,65,15,114,210,16 // psrld $0x10,%xmm10 .byte 102,69,15,102,206 // pcmpgtd %xmm14,%xmm9 .byte 102,65,15,114,214,13 // psrld $0xd,%xmm14 .byte 102,69,15,235,211 // por %xmm11,%xmm10 .byte 102,69,15,254,214 // paddd %xmm14,%xmm10 .byte 102,65,15,114,242,16 // pslld $0x10,%xmm10 .byte 102,65,15,114,226,16 // psrad $0x10,%xmm10 .byte 102,69,15,223,202 // pandn %xmm10,%xmm9 .byte 102,69,15,107,201 // packssdw %xmm9,%xmm9 .byte 102,69,15,97,197 // punpcklwd %xmm13,%xmm8 .byte 102,69,15,97,225 // punpcklwd %xmm9,%xmm12 .byte 102,69,15,111,200 // movdqa %xmm8,%xmm9 .byte 102,69,15,98,204 // punpckldq %xmm12,%xmm9 .byte 77,133,192 // test %r8,%r8 .byte 117,21 // jne 4c7d <_sk_store_f16_sse2+0x17e> .byte 69,15,17,12,193 // movups %xmm9,(%r9,%rax,8) .byte 102,69,15,106,196 // punpckhdq %xmm12,%xmm8 .byte 243,69,15,127,68,193,16 // movdqu %xmm8,0x10(%r9,%rax,8) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,69,15,214,12,193 // movq %xmm9,(%r9,%rax,8) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,240 // je 4c79 <_sk_store_f16_sse2+0x17a> .byte 102,69,15,23,76,193,8 // movhpd %xmm9,0x8(%r9,%rax,8) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,227 // jb 4c79 <_sk_store_f16_sse2+0x17a> .byte 102,69,15,106,196 // punpckhdq %xmm12,%xmm8 .byte 102,69,15,214,68,193,16 // movq %xmm8,0x10(%r9,%rax,8) .byte 235,213 // jmp 4c79 <_sk_store_f16_sse2+0x17a> HIDDEN _sk_load_u16_be_sse2 .globl _sk_load_u16_be_sse2 FUNCTION(_sk_load_u16_be_sse2) _sk_load_u16_be_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,190,0,0,0 // jne 4d89 <_sk_load_u16_be_sse2+0xe5> .byte 102,65,15,16,4,65 // movupd (%r9,%rax,2),%xmm0 .byte 102,65,15,16,76,65,16 // movupd 0x10(%r9,%rax,2),%xmm1 .byte 102,15,40,208 // movapd %xmm0,%xmm2 .byte 102,15,97,209 // punpcklwd %xmm1,%xmm2 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,15,111,202 // movdqa %xmm2,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,105,208 // punpckhwd %xmm0,%xmm2 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,113,240,8 // psllw $0x8,%xmm0 .byte 102,15,112,217,78 // pshufd $0x4e,%xmm1,%xmm3 .byte 102,15,113,209,8 // psrlw $0x8,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 .byte 102,65,15,97,201 // punpcklwd %xmm9,%xmm1 .byte 15,91,193 // cvtdq2ps %xmm1,%xmm0 .byte 68,15,40,5,116,40,0,0 // movaps 0x2874(%rip),%xmm8 # 7590 <_sk_callback_sse2+0x11d3> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,113,241,8 // psllw $0x8,%xmm1 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,235,217 // por %xmm1,%xmm3 .byte 102,65,15,97,217 // punpcklwd %xmm9,%xmm3 .byte 15,91,203 // cvtdq2ps %xmm3,%xmm1 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 102,68,15,111,210 // movdqa %xmm2,%xmm10 .byte 102,65,15,113,242,8 // psllw $0x8,%xmm10 .byte 102,15,112,218,78 // pshufd $0x4e,%xmm2,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,65,15,235,210 // por %xmm10,%xmm2 .byte 102,65,15,97,209 // punpcklwd %xmm9,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 102,68,15,111,211 // movdqa %xmm3,%xmm10 .byte 102,65,15,113,242,8 // psllw $0x8,%xmm10 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,65,15,235,218 // por %xmm10,%xmm3 .byte 102,65,15,97,217 // punpcklwd %xmm9,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 242,65,15,16,4,65 // movsd (%r9,%rax,2),%xmm0 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,17 // jne 4da6 <_sk_load_u16_be_sse2+0x102> .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 102,15,20,193 // unpcklpd %xmm1,%xmm0 .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 233,50,255,255,255 // jmpq 4cd8 <_sk_load_u16_be_sse2+0x34> .byte 102,65,15,22,68,65,8 // movhpd 0x8(%r9,%rax,2),%xmm0 .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 15,130,29,255,255,255 // jb 4cd8 <_sk_load_u16_be_sse2+0x34> .byte 242,65,15,16,76,65,16 // movsd 0x10(%r9,%rax,2),%xmm1 .byte 233,17,255,255,255 // jmpq 4cd8 <_sk_load_u16_be_sse2+0x34> HIDDEN _sk_load_rgb_u16_be_sse2 .globl _sk_load_rgb_u16_be_sse2 FUNCTION(_sk_load_rgb_u16_be_sse2) _sk_load_rgb_u16_be_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,99,80,8 // movslq 0x8(%rax),%r10 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,202 // imul %r10,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 72,137,208 // mov %rdx,%rax .byte 72,193,224,32 // shl $0x20,%rax .byte 72,141,4,64 // lea (%rax,%rax,2),%rax .byte 72,193,248,32 // sar $0x20,%rax .byte 77,133,192 // test %r8,%r8 .byte 15,133,175,0,0,0 // jne 4ea1 <_sk_load_rgb_u16_be_sse2+0xda> .byte 243,65,15,111,20,65 // movdqu (%r9,%rax,2),%xmm2 .byte 243,65,15,111,92,65,8 // movdqu 0x8(%r9,%rax,2),%xmm3 .byte 102,15,115,219,4 // psrldq $0x4,%xmm3 .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 102,15,115,216,6 // psrldq $0x6,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,115,217,6 // psrldq $0x6,%xmm1 .byte 102,15,97,211 // punpcklwd %xmm3,%xmm2 .byte 102,15,97,193 // punpcklwd %xmm1,%xmm0 .byte 102,15,111,202 // movdqa %xmm2,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,112,217,78 // pshufd $0x4e,%xmm1,%xmm3 .byte 102,15,105,208 // punpckhwd %xmm0,%xmm2 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,113,240,8 // psllw $0x8,%xmm0 .byte 102,15,113,209,8 // psrlw $0x8,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 102,65,15,97,200 // punpcklwd %xmm8,%xmm1 .byte 15,91,193 // cvtdq2ps %xmm1,%xmm0 .byte 68,15,40,13,74,39,0,0 // movaps 0x274a(%rip),%xmm9 # 75a0 <_sk_callback_sse2+0x11e3> .byte 65,15,89,193 // mulps %xmm9,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,113,241,8 // psllw $0x8,%xmm1 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,235,217 // por %xmm1,%xmm3 .byte 102,65,15,97,216 // punpcklwd %xmm8,%xmm3 .byte 15,91,203 // cvtdq2ps %xmm3,%xmm1 .byte 65,15,89,201 // mulps %xmm9,%xmm1 .byte 102,15,111,218 // movdqa %xmm2,%xmm3 .byte 102,15,113,243,8 // psllw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,235,211 // por %xmm3,%xmm2 .byte 102,65,15,97,208 // punpcklwd %xmm8,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,29,17,39,0,0 // movaps 0x2711(%rip),%xmm3 # 75b0 <_sk_callback_sse2+0x11f3> .byte 255,224 // jmpq *%rax .byte 102,65,15,110,20,65 // movd (%r9,%rax,2),%xmm2 .byte 102,65,15,196,84,65,4,2 // pinsrw $0x2,0x4(%r9,%rax,2),%xmm2 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,13 // jne 4ec6 <_sk_load_rgb_u16_be_sse2+0xff> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 233,80,255,255,255 // jmpq 4e16 <_sk_load_rgb_u16_be_sse2+0x4f> .byte 102,65,15,110,68,65,6 // movd 0x6(%r9,%rax,2),%xmm0 .byte 102,65,15,196,68,65,10,2 // pinsrw $0x2,0xa(%r9,%rax,2),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,24 // jb 4ef7 <_sk_load_rgb_u16_be_sse2+0x130> .byte 102,65,15,110,92,65,12 // movd 0xc(%r9,%rax,2),%xmm3 .byte 102,65,15,196,92,65,16,2 // pinsrw $0x2,0x10(%r9,%rax,2),%xmm3 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 233,31,255,255,255 // jmpq 4e16 <_sk_load_rgb_u16_be_sse2+0x4f> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 233,22,255,255,255 // jmpq 4e16 <_sk_load_rgb_u16_be_sse2+0x4f> HIDDEN _sk_store_u16_be_sse2 .globl _sk_store_u16_be_sse2 FUNCTION(_sk_store_u16_be_sse2) _sk_store_u16_be_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 77,1,201 // add %r9,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 68,15,40,21,154,38,0,0 // movaps 0x269a(%rip),%xmm10 # 75c0 <_sk_callback_sse2+0x1203> .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 69,15,89,194 // mulps %xmm10,%xmm8 .byte 102,69,15,91,192 // cvtps2dq %xmm8,%xmm8 .byte 102,65,15,114,240,16 // pslld $0x10,%xmm8 .byte 102,65,15,114,224,16 // psrad $0x10,%xmm8 .byte 102,69,15,107,192 // packssdw %xmm8,%xmm8 .byte 102,69,15,111,200 // movdqa %xmm8,%xmm9 .byte 102,65,15,113,241,8 // psllw $0x8,%xmm9 .byte 102,65,15,113,208,8 // psrlw $0x8,%xmm8 .byte 102,69,15,235,193 // por %xmm9,%xmm8 .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 69,15,89,202 // mulps %xmm10,%xmm9 .byte 102,69,15,91,217 // cvtps2dq %xmm9,%xmm11 .byte 102,65,15,114,243,16 // pslld $0x10,%xmm11 .byte 102,65,15,114,227,16 // psrad $0x10,%xmm11 .byte 102,69,15,107,219 // packssdw %xmm11,%xmm11 .byte 102,69,15,111,203 // movdqa %xmm11,%xmm9 .byte 102,65,15,113,241,8 // psllw $0x8,%xmm9 .byte 102,65,15,113,211,8 // psrlw $0x8,%xmm11 .byte 102,69,15,235,217 // por %xmm9,%xmm11 .byte 68,15,40,202 // movaps %xmm2,%xmm9 .byte 69,15,89,202 // mulps %xmm10,%xmm9 .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 .byte 102,65,15,114,241,16 // pslld $0x10,%xmm9 .byte 102,65,15,114,225,16 // psrad $0x10,%xmm9 .byte 102,69,15,107,201 // packssdw %xmm9,%xmm9 .byte 102,69,15,111,225 // movdqa %xmm9,%xmm12 .byte 102,65,15,113,244,8 // psllw $0x8,%xmm12 .byte 102,65,15,113,209,8 // psrlw $0x8,%xmm9 .byte 102,69,15,235,204 // por %xmm12,%xmm9 .byte 68,15,89,211 // mulps %xmm3,%xmm10 .byte 102,69,15,91,210 // cvtps2dq %xmm10,%xmm10 .byte 102,65,15,114,242,16 // pslld $0x10,%xmm10 .byte 102,65,15,114,226,16 // psrad $0x10,%xmm10 .byte 102,69,15,107,210 // packssdw %xmm10,%xmm10 .byte 102,69,15,111,226 // movdqa %xmm10,%xmm12 .byte 102,65,15,113,244,8 // psllw $0x8,%xmm12 .byte 102,65,15,113,210,8 // psrlw $0x8,%xmm10 .byte 102,69,15,235,212 // por %xmm12,%xmm10 .byte 102,69,15,97,195 // punpcklwd %xmm11,%xmm8 .byte 102,69,15,97,202 // punpcklwd %xmm10,%xmm9 .byte 102,69,15,111,208 // movdqa %xmm8,%xmm10 .byte 102,69,15,98,209 // punpckldq %xmm9,%xmm10 .byte 77,133,192 // test %r8,%r8 .byte 117,21 // jne 5020 <_sk_store_u16_be_sse2+0x120> .byte 69,15,17,20,65 // movups %xmm10,(%r9,%rax,2) .byte 102,69,15,106,193 // punpckhdq %xmm9,%xmm8 .byte 243,69,15,127,68,65,16 // movdqu %xmm8,0x10(%r9,%rax,2) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 102,69,15,214,20,65 // movq %xmm10,(%r9,%rax,2) .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,240 // je 501c <_sk_store_u16_be_sse2+0x11c> .byte 102,69,15,23,84,65,8 // movhpd %xmm10,0x8(%r9,%rax,2) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,227 // jb 501c <_sk_store_u16_be_sse2+0x11c> .byte 102,69,15,106,193 // punpckhdq %xmm9,%xmm8 .byte 102,69,15,214,68,65,16 // movq %xmm8,0x10(%r9,%rax,2) .byte 235,213 // jmp 501c <_sk_store_u16_be_sse2+0x11c> HIDDEN _sk_load_f32_sse2 .globl _sk_load_f32_sse2 FUNCTION(_sk_load_f32_sse2) _sk_load_f32_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 69,15,16,4,129 // movups (%r9,%rax,4),%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,66 // jne 50b2 <_sk_load_f32_sse2+0x6b> .byte 65,15,16,68,129,16 // movups 0x10(%r9,%rax,4),%xmm0 .byte 65,15,16,92,129,32 // movups 0x20(%r9,%rax,4),%xmm3 .byte 69,15,16,76,129,48 // movups 0x30(%r9,%rax,4),%xmm9 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 15,20,208 // unpcklps %xmm0,%xmm2 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 65,15,20,201 // unpcklps %xmm9,%xmm1 .byte 68,15,21,192 // unpckhps %xmm0,%xmm8 .byte 65,15,21,217 // unpckhps %xmm9,%xmm3 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 102,15,20,193 // unpcklpd %xmm1,%xmm0 .byte 15,18,202 // movhlps %xmm2,%xmm1 .byte 65,15,40,208 // movaps %xmm8,%xmm2 .byte 102,15,20,211 // unpcklpd %xmm3,%xmm2 .byte 65,15,18,216 // movhlps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,8 // jne 50c4 <_sk_load_f32_sse2+0x7d> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 235,190 // jmp 5082 <_sk_load_f32_sse2+0x3b> .byte 65,15,16,68,129,16 // movups 0x10(%r9,%rax,4),%xmm0 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,8 // jb 50d8 <_sk_load_f32_sse2+0x91> .byte 65,15,16,92,129,32 // movups 0x20(%r9,%rax,4),%xmm3 .byte 235,170 // jmp 5082 <_sk_load_f32_sse2+0x3b> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 235,165 // jmp 5082 <_sk_load_f32_sse2+0x3b> HIDDEN _sk_load_f32_dst_sse2 .globl _sk_load_f32_dst_sse2 FUNCTION(_sk_load_f32_dst_sse2) _sk_load_f32_dst_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 69,15,16,4,129 // movups (%r9,%rax,4),%xmm8 .byte 77,133,192 // test %r8,%r8 .byte 117,66 // jne 5148 <_sk_load_f32_dst_sse2+0x6b> .byte 65,15,16,100,129,16 // movups 0x10(%r9,%rax,4),%xmm4 .byte 65,15,16,124,129,32 // movups 0x20(%r9,%rax,4),%xmm7 .byte 69,15,16,76,129,48 // movups 0x30(%r9,%rax,4),%xmm9 .byte 65,15,40,240 // movaps %xmm8,%xmm6 .byte 15,20,244 // unpcklps %xmm4,%xmm6 .byte 15,40,239 // movaps %xmm7,%xmm5 .byte 65,15,20,233 // unpcklps %xmm9,%xmm5 .byte 68,15,21,196 // unpckhps %xmm4,%xmm8 .byte 65,15,21,249 // unpckhps %xmm9,%xmm7 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 102,15,20,229 // unpcklpd %xmm5,%xmm4 .byte 15,18,238 // movhlps %xmm6,%xmm5 .byte 65,15,40,240 // movaps %xmm8,%xmm6 .byte 102,15,20,247 // unpcklpd %xmm7,%xmm6 .byte 65,15,18,248 // movhlps %xmm8,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 73,131,248,1 // cmp $0x1,%r8 .byte 117,8 // jne 515a <_sk_load_f32_dst_sse2+0x7d> .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 235,190 // jmp 5118 <_sk_load_f32_dst_sse2+0x3b> .byte 65,15,16,100,129,16 // movups 0x10(%r9,%rax,4),%xmm4 .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,8 // jb 516e <_sk_load_f32_dst_sse2+0x91> .byte 65,15,16,124,129,32 // movups 0x20(%r9,%rax,4),%xmm7 .byte 235,170 // jmp 5118 <_sk_load_f32_dst_sse2+0x3b> .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 235,165 // jmp 5118 <_sk_load_f32_dst_sse2+0x3b> HIDDEN _sk_store_f32_sse2 .globl _sk_store_f32_sse2 FUNCTION(_sk_store_f32_sse2) _sk_store_f32_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,141,20,149,0,0,0,0 // lea 0x0(,%rdx,4),%r10d .byte 76,99,88,8 // movslq 0x8(%rax),%r11 .byte 76,99,201 // movslq %ecx,%r9 .byte 77,15,175,203 // imul %r11,%r9 .byte 73,193,225,2 // shl $0x2,%r9 .byte 76,3,8 // add (%rax),%r9 .byte 73,99,194 // movslq %r10d,%rax .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 68,15,20,201 // unpcklps %xmm1,%xmm9 .byte 68,15,40,194 // movaps %xmm2,%xmm8 .byte 68,15,20,195 // unpcklps %xmm3,%xmm8 .byte 68,15,40,208 // movaps %xmm0,%xmm10 .byte 68,15,21,209 // unpckhps %xmm1,%xmm10 .byte 68,15,40,218 // movaps %xmm2,%xmm11 .byte 68,15,21,219 // unpckhps %xmm3,%xmm11 .byte 69,15,40,225 // movaps %xmm9,%xmm12 .byte 102,69,15,20,224 // unpcklpd %xmm8,%xmm12 .byte 69,15,18,193 // movhlps %xmm9,%xmm8 .byte 69,15,40,202 // movaps %xmm10,%xmm9 .byte 102,69,15,20,203 // unpcklpd %xmm11,%xmm9 .byte 102,69,15,17,36,129 // movupd %xmm12,(%r9,%rax,4) .byte 77,133,192 // test %r8,%r8 .byte 117,29 // jne 51f0 <_sk_store_f32_sse2+0x7d> .byte 102,69,15,21,211 // unpckhpd %xmm11,%xmm10 .byte 69,15,17,68,129,16 // movups %xmm8,0x10(%r9,%rax,4) .byte 102,69,15,17,76,129,32 // movupd %xmm9,0x20(%r9,%rax,4) .byte 102,69,15,17,84,129,48 // movupd %xmm10,0x30(%r9,%rax,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 73,131,248,1 // cmp $0x1,%r8 .byte 116,246 // je 51ec <_sk_store_f32_sse2+0x79> .byte 69,15,17,68,129,16 // movups %xmm8,0x10(%r9,%rax,4) .byte 73,131,248,3 // cmp $0x3,%r8 .byte 114,234 // jb 51ec <_sk_store_f32_sse2+0x79> .byte 102,69,15,17,76,129,32 // movupd %xmm9,0x20(%r9,%rax,4) .byte 235,225 // jmp 51ec <_sk_store_f32_sse2+0x79> HIDDEN _sk_clamp_x_sse2 .globl _sk_clamp_x_sse2 FUNCTION(_sk_clamp_x_sse2) _sk_clamp_x_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,192 // maxps %xmm0,%xmm8 .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 102,15,118,192 // pcmpeqd %xmm0,%xmm0 .byte 102,65,15,254,193 // paddd %xmm9,%xmm0 .byte 68,15,93,192 // minps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_y_sse2 .globl _sk_clamp_y_sse2 FUNCTION(_sk_clamp_y_sse2) _sk_clamp_y_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,193 // maxps %xmm1,%xmm8 .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 102,15,118,201 // pcmpeqd %xmm1,%xmm1 .byte 102,65,15,254,201 // paddd %xmm9,%xmm1 .byte 68,15,93,193 // minps %xmm1,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_x_sse2 .globl _sk_repeat_x_sse2 FUNCTION(_sk_repeat_x_sse2) _sk_repeat_x_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 243,68,15,16,80,4 // movss 0x4(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 68,15,89,208 // mulps %xmm0,%xmm10 .byte 243,69,15,91,194 // cvttps2dq %xmm10,%xmm8 .byte 69,15,91,216 // cvtdq2ps %xmm8,%xmm11 .byte 69,15,194,211,1 // cmpltps %xmm11,%xmm10 .byte 68,15,84,21,71,35,0,0 // andps 0x2347(%rip),%xmm10 # 75d0 <_sk_callback_sse2+0x1213> .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 69,15,92,218 // subps %xmm10,%xmm11 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,89,217 // mulps %xmm9,%xmm11 .byte 65,15,92,195 // subps %xmm11,%xmm0 .byte 68,15,95,192 // maxps %xmm0,%xmm8 .byte 102,15,118,192 // pcmpeqd %xmm0,%xmm0 .byte 102,65,15,254,193 // paddd %xmm9,%xmm0 .byte 68,15,93,192 // minps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_y_sse2 .globl _sk_repeat_y_sse2 FUNCTION(_sk_repeat_y_sse2) _sk_repeat_y_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 243,68,15,16,80,4 // movss 0x4(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 243,69,15,91,194 // cvttps2dq %xmm10,%xmm8 .byte 69,15,91,216 // cvtdq2ps %xmm8,%xmm11 .byte 69,15,194,211,1 // cmpltps %xmm11,%xmm10 .byte 68,15,84,21,253,34,0,0 // andps 0x22fd(%rip),%xmm10 # 75e0 <_sk_callback_sse2+0x1223> .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 69,15,92,218 // subps %xmm10,%xmm11 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,89,217 // mulps %xmm9,%xmm11 .byte 65,15,92,203 // subps %xmm11,%xmm1 .byte 68,15,95,193 // maxps %xmm1,%xmm8 .byte 102,15,118,201 // pcmpeqd %xmm1,%xmm1 .byte 102,65,15,254,201 // paddd %xmm9,%xmm1 .byte 68,15,93,193 // minps %xmm1,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_x_sse2 .globl _sk_mirror_x_sse2 FUNCTION(_sk_mirror_x_sse2) _sk_mirror_x_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,16 // movss (%rax),%xmm10 .byte 243,68,15,16,88,4 // movss 0x4(%rax),%xmm11 .byte 69,15,40,202 // movaps %xmm10,%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 243,69,15,88,210 // addss %xmm10,%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,89,29,98,39,0,0 // mulss 0x2762(%rip),%xmm11 # 7aa0 <_sk_callback_sse2+0x16e3> .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 68,15,89,216 // mulps %xmm0,%xmm11 .byte 243,69,15,91,195 // cvttps2dq %xmm11,%xmm8 .byte 69,15,91,224 // cvtdq2ps %xmm8,%xmm12 .byte 69,15,194,220,1 // cmpltps %xmm12,%xmm11 .byte 68,15,84,29,147,34,0,0 // andps 0x2293(%rip),%xmm11 # 75f0 <_sk_callback_sse2+0x1233> .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 69,15,92,227 // subps %xmm11,%xmm12 .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 65,15,92,196 // subps %xmm12,%xmm0 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 69,15,87,210 // xorps %xmm10,%xmm10 .byte 68,15,92,208 // subps %xmm0,%xmm10 .byte 68,15,84,208 // andps %xmm0,%xmm10 .byte 69,15,95,194 // maxps %xmm10,%xmm8 .byte 102,15,118,192 // pcmpeqd %xmm0,%xmm0 .byte 102,65,15,254,193 // paddd %xmm9,%xmm0 .byte 68,15,93,192 // minps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_y_sse2 .globl _sk_mirror_y_sse2 FUNCTION(_sk_mirror_y_sse2) _sk_mirror_y_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,16 // movss (%rax),%xmm10 .byte 243,68,15,16,88,4 // movss 0x4(%rax),%xmm11 .byte 69,15,40,202 // movaps %xmm10,%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 65,15,92,201 // subps %xmm9,%xmm1 .byte 243,69,15,88,210 // addss %xmm10,%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,89,29,225,38,0,0 // mulss 0x26e1(%rip),%xmm11 # 7aa4 <_sk_callback_sse2+0x16e7> .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 68,15,89,217 // mulps %xmm1,%xmm11 .byte 243,69,15,91,195 // cvttps2dq %xmm11,%xmm8 .byte 69,15,91,224 // cvtdq2ps %xmm8,%xmm12 .byte 69,15,194,220,1 // cmpltps %xmm12,%xmm11 .byte 68,15,84,29,30,34,0,0 // andps 0x221e(%rip),%xmm11 # 7600 <_sk_callback_sse2+0x1243> .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 69,15,92,227 // subps %xmm11,%xmm12 .byte 69,15,89,226 // mulps %xmm10,%xmm12 .byte 65,15,92,204 // subps %xmm12,%xmm1 .byte 65,15,92,201 // subps %xmm9,%xmm1 .byte 69,15,87,210 // xorps %xmm10,%xmm10 .byte 68,15,92,209 // subps %xmm1,%xmm10 .byte 68,15,84,209 // andps %xmm1,%xmm10 .byte 69,15,95,194 // maxps %xmm10,%xmm8 .byte 102,15,118,201 // pcmpeqd %xmm1,%xmm1 .byte 102,65,15,254,201 // paddd %xmm9,%xmm1 .byte 68,15,93,193 // minps %xmm1,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,200 // movaps %xmm8,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_clamp_x_1_sse2 .globl _sk_clamp_x_1_sse2 FUNCTION(_sk_clamp_x_1_sse2) _sk_clamp_x_1_sse2: .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,95,192 // maxps %xmm0,%xmm8 .byte 68,15,93,5,229,33,0,0 // minps 0x21e5(%rip),%xmm8 # 7610 <_sk_callback_sse2+0x1253> .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_repeat_x_1_sse2 .globl _sk_repeat_x_1_sse2 FUNCTION(_sk_repeat_x_1_sse2) _sk_repeat_x_1_sse2: .byte 243,68,15,91,192 // cvttps2dq %xmm0,%xmm8 .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,194,200,1 // cmpltps %xmm8,%xmm9 .byte 68,15,84,13,211,33,0,0 // andps 0x21d3(%rip),%xmm9 # 7620 <_sk_callback_sse2+0x1263> .byte 69,15,92,193 // subps %xmm9,%xmm8 .byte 65,15,92,192 // subps %xmm8,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mirror_x_1_sse2 .globl _sk_mirror_x_1_sse2 FUNCTION(_sk_mirror_x_1_sse2) _sk_mirror_x_1_sse2: .byte 68,15,40,5,207,33,0,0 // movaps 0x21cf(%rip),%xmm8 # 7630 <_sk_callback_sse2+0x1273> .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 68,15,40,13,211,33,0,0 // movaps 0x21d3(%rip),%xmm9 # 7640 <_sk_callback_sse2+0x1283> .byte 68,15,89,200 // mulps %xmm0,%xmm9 .byte 243,69,15,91,209 // cvttps2dq %xmm9,%xmm10 .byte 69,15,91,210 // cvtdq2ps %xmm10,%xmm10 .byte 69,15,194,202,1 // cmpltps %xmm10,%xmm9 .byte 68,15,84,13,201,33,0,0 // andps 0x21c9(%rip),%xmm9 # 7650 <_sk_callback_sse2+0x1293> .byte 69,15,87,219 // xorps %xmm11,%xmm11 .byte 69,15,92,209 // subps %xmm9,%xmm10 .byte 69,15,88,210 // addps %xmm10,%xmm10 .byte 65,15,92,194 // subps %xmm10,%xmm0 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 68,15,92,216 // subps %xmm0,%xmm11 .byte 65,15,84,195 // andps %xmm11,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_luminance_to_alpha_sse2 .globl _sk_luminance_to_alpha_sse2 FUNCTION(_sk_luminance_to_alpha_sse2) _sk_luminance_to_alpha_sse2: .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,89,5,175,33,0,0 // mulps 0x21af(%rip),%xmm0 # 7660 <_sk_callback_sse2+0x12a3> .byte 15,89,13,184,33,0,0 // mulps 0x21b8(%rip),%xmm1 # 7670 <_sk_callback_sse2+0x12b3> .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,89,29,190,33,0,0 // mulps 0x21be(%rip),%xmm3 # 7680 <_sk_callback_sse2+0x12c3> .byte 15,88,217 // addps %xmm1,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_translate_sse2 .globl _sk_matrix_translate_sse2 FUNCTION(_sk_matrix_translate_sse2) _sk_matrix_translate_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,0 // movss (%rax),%xmm8 .byte 243,68,15,16,72,4 // movss 0x4(%rax),%xmm9 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 65,15,88,201 // addps %xmm9,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_scale_translate_sse2 .globl _sk_matrix_scale_translate_sse2 FUNCTION(_sk_matrix_scale_translate_sse2) _sk_matrix_scale_translate_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,64,8 // movss 0x8(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 243,68,15,16,8 // movss (%rax),%xmm9 .byte 243,68,15,16,80,4 // movss 0x4(%rax),%xmm10 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,193 // addps %xmm9,%xmm0 .byte 243,68,15,16,64,12 // movss 0xc(%rax),%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_2x3_sse2 .globl _sk_matrix_2x3_sse2 FUNCTION(_sk_matrix_2x3_sse2) _sk_matrix_2x3_sse2: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,68,15,16,80,8 // movss 0x8(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,16 // movss 0x10(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,68,15,16,80,12 // movss 0xc(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,20 // movss 0x14(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_3x4_sse2 .globl _sk_matrix_3x4_sse2 FUNCTION(_sk_matrix_3x4_sse2) _sk_matrix_3x4_sse2: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,68,15,16,80,12 // movss 0xc(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,24 // movss 0x18(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,36 // movss 0x24(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,68,15,16,80,16 // movss 0x10(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,28 // movss 0x1c(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,40 // movss 0x28(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 243,68,15,16,80,8 // movss 0x8(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,20 // movss 0x14(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,32 // movss 0x20(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,44 // movss 0x2c(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 68,15,89,226 // mulps %xmm2,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 69,15,89,217 // mulps %xmm9,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_4x5_sse2 .globl _sk_matrix_4x5_sse2 FUNCTION(_sk_matrix_4x5_sse2) _sk_matrix_4x5_sse2: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,68,15,16,80,16 // movss 0x10(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,32 // movss 0x20(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,48 // movss 0x30(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,64 // movss 0x40(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 68,15,89,227 // mulps %xmm3,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,68,15,16,80,20 // movss 0x14(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,36 // movss 0x24(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,52 // movss 0x34(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,68 // movss 0x44(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 68,15,89,227 // mulps %xmm3,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 68,15,89,218 // mulps %xmm2,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 243,68,15,16,80,8 // movss 0x8(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,24 // movss 0x18(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,40 // movss 0x28(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,56 // movss 0x38(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 243,68,15,16,112,72 // movss 0x48(%rax),%xmm14 .byte 69,15,198,246,0 // shufps $0x0,%xmm14,%xmm14 .byte 68,15,89,235 // mulps %xmm3,%xmm13 .byte 69,15,88,238 // addps %xmm14,%xmm13 .byte 68,15,89,226 // mulps %xmm2,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 69,15,89,217 // mulps %xmm9,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 243,68,15,16,88,12 // movss 0xc(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,28 // movss 0x1c(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 243,68,15,16,104,44 // movss 0x2c(%rax),%xmm13 .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 .byte 243,68,15,16,112,60 // movss 0x3c(%rax),%xmm14 .byte 69,15,198,246,0 // shufps $0x0,%xmm14,%xmm14 .byte 243,68,15,16,120,76 // movss 0x4c(%rax),%xmm15 .byte 69,15,198,255,0 // shufps $0x0,%xmm15,%xmm15 .byte 68,15,89,243 // mulps %xmm3,%xmm14 .byte 69,15,88,247 // addps %xmm15,%xmm14 .byte 68,15,89,234 // mulps %xmm2,%xmm13 .byte 69,15,88,238 // addps %xmm14,%xmm13 .byte 69,15,89,225 // mulps %xmm9,%xmm12 .byte 69,15,88,229 // addps %xmm13,%xmm12 .byte 69,15,89,216 // mulps %xmm8,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,210 // movaps %xmm10,%xmm2 .byte 65,15,40,219 // movaps %xmm11,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_4x3_sse2 .globl _sk_matrix_4x3_sse2 FUNCTION(_sk_matrix_4x3_sse2) _sk_matrix_4x3_sse2: .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,15,16,80,16 // movss 0x10(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,32 // movss 0x20(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,80,20 // movss 0x14(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,36 // movss 0x24(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 65,15,89,209 // mulps %xmm9,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 243,15,16,80,8 // movss 0x8(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,24 // movss 0x18(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 243,68,15,16,80,40 // movss 0x28(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 65,15,89,217 // mulps %xmm9,%xmm3 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 243,15,16,88,12 // movss 0xc(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 243,68,15,16,80,28 // movss 0x1c(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,44 // movss 0x2c(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 65,15,88,218 // addps %xmm10,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_matrix_perspective_sse2 .globl _sk_matrix_perspective_sse2 FUNCTION(_sk_matrix_perspective_sse2) _sk_matrix_perspective_sse2: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,68,15,16,72,4 // movss 0x4(%rax),%xmm9 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 243,68,15,16,80,8 // movss 0x8(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 68,15,89,201 // mulps %xmm1,%xmm9 .byte 69,15,88,202 // addps %xmm10,%xmm9 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 65,15,88,193 // addps %xmm9,%xmm0 .byte 243,68,15,16,72,12 // movss 0xc(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 243,68,15,16,80,16 // movss 0x10(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,20 // movss 0x14(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 68,15,89,209 // mulps %xmm1,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 69,15,88,202 // addps %xmm10,%xmm9 .byte 243,68,15,16,80,24 // movss 0x18(%rax),%xmm10 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,28 // movss 0x1c(%rax),%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 243,68,15,16,96,32 // movss 0x20(%rax),%xmm12 .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 .byte 68,15,89,217 // mulps %xmm1,%xmm11 .byte 69,15,88,220 // addps %xmm12,%xmm11 .byte 69,15,89,208 // mulps %xmm8,%xmm10 .byte 69,15,88,211 // addps %xmm11,%xmm10 .byte 65,15,83,202 // rcpps %xmm10,%xmm1 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 68,15,89,201 // mulps %xmm1,%xmm9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,201 // movaps %xmm9,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_evenly_spaced_gradient_sse2 .globl _sk_evenly_spaced_gradient_sse2 FUNCTION(_sk_evenly_spaced_gradient_sse2) _sk_evenly_spaced_gradient_sse2: .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,139,24 // mov (%rax),%rbx .byte 76,139,112,8 // mov 0x8(%rax),%r14 .byte 72,255,203 // dec %rbx .byte 120,7 // js 5962 <_sk_evenly_spaced_gradient_sse2+0x18> .byte 243,72,15,42,203 // cvtsi2ss %rbx,%xmm1 .byte 235,21 // jmp 5977 <_sk_evenly_spaced_gradient_sse2+0x2d> .byte 73,137,217 // mov %rbx,%r9 .byte 73,209,233 // shr %r9 .byte 131,227,1 // and $0x1,%ebx .byte 76,9,203 // or %r9,%rbx .byte 243,72,15,42,203 // cvtsi2ss %rbx,%xmm1 .byte 243,15,88,201 // addss %xmm1,%xmm1 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,112,209,78 // pshufd $0x4e,%xmm1,%xmm2 .byte 102,73,15,126,211 // movq %xmm2,%r11 .byte 69,137,217 // mov %r11d,%r9d .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,72,15,126,203 // movq %xmm1,%rbx .byte 65,137,218 // mov %ebx,%r10d .byte 72,193,235,32 // shr $0x20,%rbx .byte 243,65,15,16,12,158 // movss (%r14,%rbx,4),%xmm1 .byte 243,67,15,16,20,158 // movss (%r14,%r11,4),%xmm2 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 243,71,15,16,4,150 // movss (%r14,%r10,4),%xmm8 .byte 243,67,15,16,20,142 // movss (%r14,%r9,4),%xmm2 .byte 68,15,20,194 // unpcklps %xmm2,%xmm8 .byte 68,15,20,193 // unpcklps %xmm1,%xmm8 .byte 76,139,112,40 // mov 0x28(%rax),%r14 .byte 243,65,15,16,12,158 // movss (%r14,%rbx,4),%xmm1 .byte 243,67,15,16,20,158 // movss (%r14,%r11,4),%xmm2 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 243,71,15,16,12,150 // movss (%r14,%r10,4),%xmm9 .byte 243,67,15,16,20,142 // movss (%r14,%r9,4),%xmm2 .byte 68,15,20,202 // unpcklps %xmm2,%xmm9 .byte 68,15,20,201 // unpcklps %xmm1,%xmm9 .byte 76,139,112,16 // mov 0x10(%rax),%r14 .byte 243,65,15,16,20,158 // movss (%r14,%rbx,4),%xmm2 .byte 243,67,15,16,12,158 // movss (%r14,%r11,4),%xmm1 .byte 15,20,209 // unpcklps %xmm1,%xmm2 .byte 243,67,15,16,12,150 // movss (%r14,%r10,4),%xmm1 .byte 243,67,15,16,28,142 // movss (%r14,%r9,4),%xmm3 .byte 15,20,203 // unpcklps %xmm3,%xmm1 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 76,139,112,48 // mov 0x30(%rax),%r14 .byte 243,65,15,16,20,158 // movss (%r14,%rbx,4),%xmm2 .byte 243,67,15,16,28,158 // movss (%r14,%r11,4),%xmm3 .byte 15,20,211 // unpcklps %xmm3,%xmm2 .byte 243,71,15,16,20,150 // movss (%r14,%r10,4),%xmm10 .byte 243,67,15,16,28,142 // movss (%r14,%r9,4),%xmm3 .byte 68,15,20,211 // unpcklps %xmm3,%xmm10 .byte 68,15,20,210 // unpcklps %xmm2,%xmm10 .byte 76,139,112,24 // mov 0x18(%rax),%r14 .byte 243,69,15,16,28,158 // movss (%r14,%rbx,4),%xmm11 .byte 243,67,15,16,20,158 // movss (%r14,%r11,4),%xmm2 .byte 68,15,20,218 // unpcklps %xmm2,%xmm11 .byte 243,67,15,16,20,150 // movss (%r14,%r10,4),%xmm2 .byte 243,67,15,16,28,142 // movss (%r14,%r9,4),%xmm3 .byte 15,20,211 // unpcklps %xmm3,%xmm2 .byte 65,15,20,211 // unpcklps %xmm11,%xmm2 .byte 76,139,112,56 // mov 0x38(%rax),%r14 .byte 243,69,15,16,36,158 // movss (%r14,%rbx,4),%xmm12 .byte 243,67,15,16,28,158 // movss (%r14,%r11,4),%xmm3 .byte 68,15,20,227 // unpcklps %xmm3,%xmm12 .byte 243,71,15,16,28,150 // movss (%r14,%r10,4),%xmm11 .byte 243,67,15,16,28,142 // movss (%r14,%r9,4),%xmm3 .byte 68,15,20,219 // unpcklps %xmm3,%xmm11 .byte 69,15,20,220 // unpcklps %xmm12,%xmm11 .byte 76,139,112,32 // mov 0x20(%rax),%r14 .byte 243,69,15,16,36,158 // movss (%r14,%rbx,4),%xmm12 .byte 243,67,15,16,28,158 // movss (%r14,%r11,4),%xmm3 .byte 68,15,20,227 // unpcklps %xmm3,%xmm12 .byte 243,67,15,16,28,150 // movss (%r14,%r10,4),%xmm3 .byte 243,71,15,16,44,142 // movss (%r14,%r9,4),%xmm13 .byte 65,15,20,221 // unpcklps %xmm13,%xmm3 .byte 65,15,20,220 // unpcklps %xmm12,%xmm3 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 243,68,15,16,36,152 // movss (%rax,%rbx,4),%xmm12 .byte 243,70,15,16,44,152 // movss (%rax,%r11,4),%xmm13 .byte 69,15,20,229 // unpcklps %xmm13,%xmm12 .byte 243,70,15,16,44,144 // movss (%rax,%r10,4),%xmm13 .byte 243,70,15,16,52,136 // movss (%rax,%r9,4),%xmm14 .byte 69,15,20,238 // unpcklps %xmm14,%xmm13 .byte 69,15,20,236 // unpcklps %xmm12,%xmm13 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 65,15,88,211 // addps %xmm11,%xmm2 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 65,15,88,221 // addps %xmm13,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 255,224 // jmpq *%rax HIDDEN _sk_gauss_a_to_rgba_sse2 .globl _sk_gauss_a_to_rgba_sse2 FUNCTION(_sk_gauss_a_to_rgba_sse2) _sk_gauss_a_to_rgba_sse2: .byte 15,40,5,141,27,0,0 // movaps 0x1b8d(%rip),%xmm0 # 7690 <_sk_callback_sse2+0x12d3> .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,5,147,27,0,0 // addps 0x1b93(%rip),%xmm0 # 76a0 <_sk_callback_sse2+0x12e3> .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,5,153,27,0,0 // addps 0x1b99(%rip),%xmm0 # 76b0 <_sk_callback_sse2+0x12f3> .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,5,159,27,0,0 // addps 0x1b9f(%rip),%xmm0 # 76c0 <_sk_callback_sse2+0x1303> .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,5,165,27,0,0 // addps 0x1ba5(%rip),%xmm0 # 76d0 <_sk_callback_sse2+0x1313> .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 255,224 // jmpq *%rax HIDDEN _sk_gradient_sse2 .globl _sk_gradient_sse2 FUNCTION(_sk_gradient_sse2) _sk_gradient_sse2: .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 83 // push %rbx .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,139,8 // mov (%rax),%r9 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 73,131,249,2 // cmp $0x2,%r9 .byte 114,50 // jb 5b7e <_sk_gradient_sse2+0x46> .byte 72,139,88,72 // mov 0x48(%rax),%rbx .byte 73,255,201 // dec %r9 .byte 72,131,195,4 // add $0x4,%rbx .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 15,40,21,126,27,0,0 // movaps 0x1b7e(%rip),%xmm2 # 76e0 <_sk_callback_sse2+0x1323> .byte 243,15,16,27 // movss (%rbx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 15,194,216,2 // cmpleps %xmm0,%xmm3 .byte 15,84,218 // andps %xmm2,%xmm3 .byte 102,15,254,203 // paddd %xmm3,%xmm1 .byte 72,131,195,4 // add $0x4,%rbx .byte 73,255,201 // dec %r9 .byte 117,228 // jne 5b62 <_sk_gradient_sse2+0x2a> .byte 102,15,112,209,78 // pshufd $0x4e,%xmm1,%xmm2 .byte 102,73,15,126,211 // movq %xmm2,%r11 .byte 69,137,217 // mov %r11d,%r9d .byte 73,193,235,32 // shr $0x20,%r11 .byte 102,72,15,126,203 // movq %xmm1,%rbx .byte 65,137,218 // mov %ebx,%r10d .byte 72,193,235,32 // shr $0x20,%rbx .byte 76,139,112,8 // mov 0x8(%rax),%r14 .byte 76,139,120,16 // mov 0x10(%rax),%r15 .byte 243,65,15,16,12,158 // movss (%r14,%rbx,4),%xmm1 .byte 243,67,15,16,20,158 // movss (%r14,%r11,4),%xmm2 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 243,71,15,16,4,150 // movss (%r14,%r10,4),%xmm8 .byte 243,67,15,16,20,142 // movss (%r14,%r9,4),%xmm2 .byte 68,15,20,194 // unpcklps %xmm2,%xmm8 .byte 68,15,20,193 // unpcklps %xmm1,%xmm8 .byte 76,139,112,40 // mov 0x28(%rax),%r14 .byte 243,65,15,16,12,158 // movss (%r14,%rbx,4),%xmm1 .byte 243,67,15,16,20,158 // movss (%r14,%r11,4),%xmm2 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 243,71,15,16,12,150 // movss (%r14,%r10,4),%xmm9 .byte 243,67,15,16,20,142 // movss (%r14,%r9,4),%xmm2 .byte 68,15,20,202 // unpcklps %xmm2,%xmm9 .byte 68,15,20,201 // unpcklps %xmm1,%xmm9 .byte 243,65,15,16,20,159 // movss (%r15,%rbx,4),%xmm2 .byte 243,67,15,16,12,159 // movss (%r15,%r11,4),%xmm1 .byte 15,20,209 // unpcklps %xmm1,%xmm2 .byte 243,67,15,16,12,151 // movss (%r15,%r10,4),%xmm1 .byte 243,67,15,16,28,143 // movss (%r15,%r9,4),%xmm3 .byte 15,20,203 // unpcklps %xmm3,%xmm1 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 76,139,112,48 // mov 0x30(%rax),%r14 .byte 243,65,15,16,20,158 // movss (%r14,%rbx,4),%xmm2 .byte 243,67,15,16,28,158 // movss (%r14,%r11,4),%xmm3 .byte 15,20,211 // unpcklps %xmm3,%xmm2 .byte 243,71,15,16,20,150 // movss (%r14,%r10,4),%xmm10 .byte 243,67,15,16,28,142 // movss (%r14,%r9,4),%xmm3 .byte 68,15,20,211 // unpcklps %xmm3,%xmm10 .byte 68,15,20,210 // unpcklps %xmm2,%xmm10 .byte 76,139,112,24 // mov 0x18(%rax),%r14 .byte 243,69,15,16,28,158 // movss (%r14,%rbx,4),%xmm11 .byte 243,67,15,16,20,158 // movss (%r14,%r11,4),%xmm2 .byte 68,15,20,218 // unpcklps %xmm2,%xmm11 .byte 243,67,15,16,20,150 // movss (%r14,%r10,4),%xmm2 .byte 243,67,15,16,28,142 // movss (%r14,%r9,4),%xmm3 .byte 15,20,211 // unpcklps %xmm3,%xmm2 .byte 65,15,20,211 // unpcklps %xmm11,%xmm2 .byte 76,139,112,56 // mov 0x38(%rax),%r14 .byte 243,69,15,16,36,158 // movss (%r14,%rbx,4),%xmm12 .byte 243,67,15,16,28,158 // movss (%r14,%r11,4),%xmm3 .byte 68,15,20,227 // unpcklps %xmm3,%xmm12 .byte 243,71,15,16,28,150 // movss (%r14,%r10,4),%xmm11 .byte 243,67,15,16,28,142 // movss (%r14,%r9,4),%xmm3 .byte 68,15,20,219 // unpcklps %xmm3,%xmm11 .byte 69,15,20,220 // unpcklps %xmm12,%xmm11 .byte 76,139,112,32 // mov 0x20(%rax),%r14 .byte 243,69,15,16,36,158 // movss (%r14,%rbx,4),%xmm12 .byte 243,67,15,16,28,158 // movss (%r14,%r11,4),%xmm3 .byte 68,15,20,227 // unpcklps %xmm3,%xmm12 .byte 243,67,15,16,28,150 // movss (%r14,%r10,4),%xmm3 .byte 243,71,15,16,44,142 // movss (%r14,%r9,4),%xmm13 .byte 65,15,20,221 // unpcklps %xmm13,%xmm3 .byte 65,15,20,220 // unpcklps %xmm12,%xmm3 .byte 72,139,64,64 // mov 0x40(%rax),%rax .byte 243,68,15,16,36,152 // movss (%rax,%rbx,4),%xmm12 .byte 243,70,15,16,44,152 // movss (%rax,%r11,4),%xmm13 .byte 69,15,20,229 // unpcklps %xmm13,%xmm12 .byte 243,70,15,16,44,144 // movss (%rax,%r10,4),%xmm13 .byte 243,70,15,16,52,136 // movss (%rax,%r9,4),%xmm14 .byte 69,15,20,238 // unpcklps %xmm14,%xmm13 .byte 69,15,20,236 // unpcklps %xmm12,%xmm13 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 69,15,88,193 // addps %xmm9,%xmm8 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 65,15,88,202 // addps %xmm10,%xmm1 .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 65,15,88,211 // addps %xmm11,%xmm2 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 65,15,88,221 // addps %xmm13,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 65,15,40,192 // movaps %xmm8,%xmm0 .byte 91 // pop %rbx .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 255,224 // jmpq *%rax HIDDEN _sk_evenly_spaced_2_stop_gradient_sse2 .globl _sk_evenly_spaced_2_stop_gradient_sse2 FUNCTION(_sk_evenly_spaced_2_stop_gradient_sse2) _sk_evenly_spaced_2_stop_gradient_sse2: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,0 // movss (%rax),%xmm0 .byte 243,15,16,72,4 // movss 0x4(%rax),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,15,16,80,16 // movss 0x10(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,80,20 // movss 0x14(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 65,15,89,200 // mulps %xmm8,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 243,15,16,80,8 // movss 0x8(%rax),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,88,24 // movss 0x18(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 65,15,89,208 // mulps %xmm8,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 243,15,16,88,12 // movss 0xc(%rax),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 243,68,15,16,72,28 // movss 0x1c(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 65,15,89,216 // mulps %xmm8,%xmm3 .byte 65,15,88,217 // addps %xmm9,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_unit_angle_sse2 .globl _sk_xy_to_unit_angle_sse2 FUNCTION(_sk_xy_to_unit_angle_sse2) _sk_xy_to_unit_angle_sse2: .byte 68,15,40,192 // movaps %xmm0,%xmm8 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 69,15,87,201 // xorps %xmm9,%xmm9 .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 69,15,84,200 // andps %xmm8,%xmm9 .byte 69,15,87,210 // xorps %xmm10,%xmm10 .byte 68,15,92,209 // subps %xmm1,%xmm10 .byte 68,15,84,209 // andps %xmm1,%xmm10 .byte 69,15,40,217 // movaps %xmm9,%xmm11 .byte 69,15,93,218 // minps %xmm10,%xmm11 .byte 69,15,40,225 // movaps %xmm9,%xmm12 .byte 69,15,95,226 // maxps %xmm10,%xmm12 .byte 69,15,94,220 // divps %xmm12,%xmm11 .byte 69,15,40,227 // movaps %xmm11,%xmm12 .byte 69,15,89,228 // mulps %xmm12,%xmm12 .byte 68,15,40,45,63,25,0,0 // movaps 0x193f(%rip),%xmm13 # 76f0 <_sk_callback_sse2+0x1333> .byte 69,15,89,236 // mulps %xmm12,%xmm13 .byte 68,15,88,45,67,25,0,0 // addps 0x1943(%rip),%xmm13 # 7700 <_sk_callback_sse2+0x1343> .byte 69,15,89,236 // mulps %xmm12,%xmm13 .byte 68,15,88,45,71,25,0,0 // addps 0x1947(%rip),%xmm13 # 7710 <_sk_callback_sse2+0x1353> .byte 69,15,89,236 // mulps %xmm12,%xmm13 .byte 68,15,88,45,75,25,0,0 // addps 0x194b(%rip),%xmm13 # 7720 <_sk_callback_sse2+0x1363> .byte 69,15,89,235 // mulps %xmm11,%xmm13 .byte 69,15,194,202,1 // cmpltps %xmm10,%xmm9 .byte 68,15,40,21,74,25,0,0 // movaps 0x194a(%rip),%xmm10 # 7730 <_sk_callback_sse2+0x1373> .byte 69,15,92,213 // subps %xmm13,%xmm10 .byte 69,15,84,209 // andps %xmm9,%xmm10 .byte 69,15,85,205 // andnps %xmm13,%xmm9 .byte 69,15,86,202 // orps %xmm10,%xmm9 .byte 68,15,194,192,1 // cmpltps %xmm0,%xmm8 .byte 68,15,40,21,61,25,0,0 // movaps 0x193d(%rip),%xmm10 # 7740 <_sk_callback_sse2+0x1383> .byte 69,15,92,209 // subps %xmm9,%xmm10 .byte 69,15,84,208 // andps %xmm8,%xmm10 .byte 69,15,85,193 // andnps %xmm9,%xmm8 .byte 69,15,86,194 // orps %xmm10,%xmm8 .byte 68,15,40,201 // movaps %xmm1,%xmm9 .byte 68,15,194,200,1 // cmpltps %xmm0,%xmm9 .byte 68,15,40,21,44,25,0,0 // movaps 0x192c(%rip),%xmm10 # 7750 <_sk_callback_sse2+0x1393> .byte 69,15,92,208 // subps %xmm8,%xmm10 .byte 69,15,84,209 // andps %xmm9,%xmm10 .byte 69,15,85,200 // andnps %xmm8,%xmm9 .byte 69,15,86,202 // orps %xmm10,%xmm9 .byte 65,15,194,193,7 // cmpordps %xmm9,%xmm0 .byte 65,15,84,193 // andps %xmm9,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_radius_sse2 .globl _sk_xy_to_radius_sse2 FUNCTION(_sk_xy_to_radius_sse2) _sk_xy_to_radius_sse2: .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,193 // movaps %xmm1,%xmm8 .byte 69,15,89,192 // mulps %xmm8,%xmm8 .byte 68,15,88,192 // addps %xmm0,%xmm8 .byte 65,15,81,192 // sqrtps %xmm8,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_quadratic_max_sse2 .globl _sk_xy_to_2pt_conical_quadratic_max_sse2 FUNCTION(_sk_xy_to_2pt_conical_quadratic_max_sse2) _sk_xy_to_2pt_conical_quadratic_max_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,80,32 // movss 0x20(%rax),%xmm10 .byte 243,68,15,16,64,36 // movss 0x24(%rax),%xmm8 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,40 // movss 0x28(%rax),%xmm11 .byte 243,68,15,16,72,44 // movss 0x2c(%rax),%xmm9 .byte 243,69,15,89,203 // mulss %xmm11,%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 68,15,89,13,211,24,0,0 // mulps 0x18d3(%rip),%xmm9 # 7760 <_sk_callback_sse2+0x13a3> .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,225 // movaps %xmm1,%xmm12 .byte 69,15,89,228 // mulps %xmm12,%xmm12 .byte 68,15,88,224 // addps %xmm0,%xmm12 .byte 243,69,15,89,219 // mulss %xmm11,%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,92,227 // subps %xmm11,%xmm12 .byte 68,15,89,21,190,24,0,0 // mulps 0x18be(%rip),%xmm10 # 7770 <_sk_callback_sse2+0x13b3> .byte 69,15,89,212 // mulps %xmm12,%xmm10 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 68,15,81,208 // sqrtps %xmm0,%xmm10 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 68,15,87,13,166,24,0,0 // xorps 0x18a6(%rip),%xmm9 # 7780 <_sk_callback_sse2+0x13c3> .byte 68,15,89,5,174,24,0,0 // mulps 0x18ae(%rip),%xmm8 # 7790 <_sk_callback_sse2+0x13d3> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 69,15,92,202 // subps %xmm10,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 65,15,95,193 // maxps %xmm9,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_quadratic_min_sse2 .globl _sk_xy_to_2pt_conical_quadratic_min_sse2 FUNCTION(_sk_xy_to_2pt_conical_quadratic_min_sse2) _sk_xy_to_2pt_conical_quadratic_min_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,80,32 // movss 0x20(%rax),%xmm10 .byte 243,68,15,16,64,36 // movss 0x24(%rax),%xmm8 .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 .byte 243,68,15,16,88,40 // movss 0x28(%rax),%xmm11 .byte 243,68,15,16,72,44 // movss 0x2c(%rax),%xmm9 .byte 243,69,15,89,203 // mulss %xmm11,%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 68,15,89,13,117,24,0,0 // mulps 0x1875(%rip),%xmm9 # 77a0 <_sk_callback_sse2+0x13e3> .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,225 // movaps %xmm1,%xmm12 .byte 69,15,89,228 // mulps %xmm12,%xmm12 .byte 68,15,88,224 // addps %xmm0,%xmm12 .byte 243,69,15,89,219 // mulss %xmm11,%xmm11 .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 .byte 69,15,92,227 // subps %xmm11,%xmm12 .byte 68,15,89,21,96,24,0,0 // mulps 0x1860(%rip),%xmm10 # 77b0 <_sk_callback_sse2+0x13f3> .byte 69,15,89,212 // mulps %xmm12,%xmm10 .byte 65,15,40,193 // movaps %xmm9,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 68,15,81,208 // sqrtps %xmm0,%xmm10 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,40,194 // movaps %xmm10,%xmm0 .byte 65,15,92,193 // subps %xmm9,%xmm0 .byte 68,15,87,13,72,24,0,0 // xorps 0x1848(%rip),%xmm9 # 77c0 <_sk_callback_sse2+0x1403> .byte 68,15,89,5,80,24,0,0 // mulps 0x1850(%rip),%xmm8 # 77d0 <_sk_callback_sse2+0x1413> .byte 65,15,89,192 // mulps %xmm8,%xmm0 .byte 69,15,92,202 // subps %xmm10,%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 65,15,93,193 // minps %xmm9,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xy_to_2pt_conical_linear_sse2 .globl _sk_xy_to_2pt_conical_linear_sse2 FUNCTION(_sk_xy_to_2pt_conical_linear_sse2) _sk_xy_to_2pt_conical_linear_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,64,40 // movss 0x28(%rax),%xmm8 .byte 243,68,15,16,72,44 // movss 0x2c(%rax),%xmm9 .byte 243,69,15,89,200 // mulss %xmm8,%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 68,15,88,200 // addps %xmm0,%xmm9 .byte 68,15,89,13,40,24,0,0 // mulps 0x1828(%rip),%xmm9 # 77e0 <_sk_callback_sse2+0x1423> .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 68,15,40,209 // movaps %xmm1,%xmm10 .byte 69,15,89,210 // mulps %xmm10,%xmm10 .byte 65,15,88,194 // addps %xmm10,%xmm0 .byte 243,69,15,89,192 // mulss %xmm8,%xmm8 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 65,15,92,192 // subps %xmm8,%xmm0 .byte 15,87,5,20,24,0,0 // xorps 0x1814(%rip),%xmm0 # 77f0 <_sk_callback_sse2+0x1433> .byte 65,15,94,193 // divps %xmm9,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_mask_2pt_conical_degenerates_sse2 .globl _sk_mask_2pt_conical_degenerates_sse2 FUNCTION(_sk_mask_2pt_conical_degenerates_sse2) _sk_mask_2pt_conical_degenerates_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,68,15,16,64,40 // movss 0x28(%rax),%xmm8 .byte 243,68,15,16,72,44 // movss 0x2c(%rax),%xmm9 .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 .byte 68,15,89,200 // mulps %xmm0,%xmm9 .byte 69,15,88,200 // addps %xmm8,%xmm9 .byte 69,15,87,192 // xorps %xmm8,%xmm8 .byte 68,15,40,208 // movaps %xmm0,%xmm10 .byte 69,15,194,208,7 // cmpordps %xmm8,%xmm10 .byte 69,15,194,193,2 // cmpleps %xmm9,%xmm8 .byte 69,15,84,194 // andps %xmm10,%xmm8 .byte 68,15,17,0 // movups %xmm8,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_apply_vector_mask_sse2 .globl _sk_apply_vector_mask_sse2 FUNCTION(_sk_apply_vector_mask_sse2) _sk_apply_vector_mask_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,16,0 // movups (%rax),%xmm8 .byte 65,15,84,192 // andps %xmm8,%xmm0 .byte 65,15,84,200 // andps %xmm8,%xmm1 .byte 65,15,84,208 // andps %xmm8,%xmm2 .byte 65,15,84,216 // andps %xmm8,%xmm3 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_save_xy_sse2 .globl _sk_save_xy_sse2 FUNCTION(_sk_save_xy_sse2) _sk_save_xy_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,40,5,186,23,0,0 // movaps 0x17ba(%rip),%xmm8 # 7800 <_sk_callback_sse2+0x1443> .byte 15,17,0 // movups %xmm0,(%rax) .byte 68,15,40,200 // movaps %xmm0,%xmm9 .byte 69,15,88,200 // addps %xmm8,%xmm9 .byte 243,69,15,91,209 // cvttps2dq %xmm9,%xmm10 .byte 69,15,91,210 // cvtdq2ps %xmm10,%xmm10 .byte 69,15,40,217 // movaps %xmm9,%xmm11 .byte 69,15,194,218,1 // cmpltps %xmm10,%xmm11 .byte 68,15,40,37,165,23,0,0 // movaps 0x17a5(%rip),%xmm12 # 7810 <_sk_callback_sse2+0x1453> .byte 69,15,84,220 // andps %xmm12,%xmm11 .byte 69,15,92,211 // subps %xmm11,%xmm10 .byte 69,15,92,202 // subps %xmm10,%xmm9 .byte 68,15,88,193 // addps %xmm1,%xmm8 .byte 243,69,15,91,208 // cvttps2dq %xmm8,%xmm10 .byte 69,15,91,210 // cvtdq2ps %xmm10,%xmm10 .byte 69,15,40,216 // movaps %xmm8,%xmm11 .byte 69,15,194,218,1 // cmpltps %xmm10,%xmm11 .byte 69,15,84,220 // andps %xmm12,%xmm11 .byte 69,15,92,211 // subps %xmm11,%xmm10 .byte 69,15,92,194 // subps %xmm10,%xmm8 .byte 15,17,72,32 // movups %xmm1,0x20(%rax) .byte 68,15,17,72,64 // movups %xmm9,0x40(%rax) .byte 68,15,17,64,96 // movups %xmm8,0x60(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_accumulate_sse2 .globl _sk_accumulate_sse2 FUNCTION(_sk_accumulate_sse2) _sk_accumulate_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,16,128,128,0,0,0 // movups 0x80(%rax),%xmm8 .byte 68,15,16,136,160,0,0,0 // movups 0xa0(%rax),%xmm9 .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 68,15,89,192 // mulps %xmm0,%xmm8 .byte 65,15,88,224 // addps %xmm8,%xmm4 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 68,15,89,193 // mulps %xmm1,%xmm8 .byte 65,15,88,232 // addps %xmm8,%xmm5 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 68,15,89,194 // mulps %xmm2,%xmm8 .byte 65,15,88,240 // addps %xmm8,%xmm6 .byte 68,15,89,203 // mulps %xmm3,%xmm9 .byte 65,15,88,249 // addps %xmm9,%xmm7 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_nx_sse2 .globl _sk_bilinear_nx_sse2 FUNCTION(_sk_bilinear_nx_sse2) _sk_bilinear_nx_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,30,23,0,0 // addps 0x171e(%rip),%xmm0 # 7820 <_sk_callback_sse2+0x1463> .byte 68,15,40,13,38,23,0,0 // movaps 0x1726(%rip),%xmm9 # 7830 <_sk_callback_sse2+0x1473> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,17,136,128,0,0,0 // movups %xmm9,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_px_sse2 .globl _sk_bilinear_px_sse2 FUNCTION(_sk_bilinear_px_sse2) _sk_bilinear_px_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,21,23,0,0 // addps 0x1715(%rip),%xmm0 # 7840 <_sk_callback_sse2+0x1483> .byte 68,15,17,128,128,0,0,0 // movups %xmm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_ny_sse2 .globl _sk_bilinear_ny_sse2 FUNCTION(_sk_bilinear_ny_sse2) _sk_bilinear_ny_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,7,23,0,0 // addps 0x1707(%rip),%xmm1 # 7850 <_sk_callback_sse2+0x1493> .byte 68,15,40,13,15,23,0,0 // movaps 0x170f(%rip),%xmm9 # 7860 <_sk_callback_sse2+0x14a3> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,17,136,160,0,0,0 // movups %xmm9,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bilinear_py_sse2 .globl _sk_bilinear_py_sse2 FUNCTION(_sk_bilinear_py_sse2) _sk_bilinear_py_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,253,22,0,0 // addps 0x16fd(%rip),%xmm1 # 7870 <_sk_callback_sse2+0x14b3> .byte 68,15,17,128,160,0,0,0 // movups %xmm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n3x_sse2 .globl _sk_bicubic_n3x_sse2 FUNCTION(_sk_bicubic_n3x_sse2) _sk_bicubic_n3x_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,240,22,0,0 // addps 0x16f0(%rip),%xmm0 # 7880 <_sk_callback_sse2+0x14c3> .byte 68,15,40,13,248,22,0,0 // movaps 0x16f8(%rip),%xmm9 # 7890 <_sk_callback_sse2+0x14d3> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 69,15,89,192 // mulps %xmm8,%xmm8 .byte 68,15,89,13,244,22,0,0 // mulps 0x16f4(%rip),%xmm9 # 78a0 <_sk_callback_sse2+0x14e3> .byte 68,15,88,13,252,22,0,0 // addps 0x16fc(%rip),%xmm9 # 78b0 <_sk_callback_sse2+0x14f3> .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 68,15,17,136,128,0,0,0 // movups %xmm9,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n1x_sse2 .globl _sk_bicubic_n1x_sse2 FUNCTION(_sk_bicubic_n1x_sse2) _sk_bicubic_n1x_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,235,22,0,0 // addps 0x16eb(%rip),%xmm0 # 78c0 <_sk_callback_sse2+0x1503> .byte 68,15,40,13,243,22,0,0 // movaps 0x16f3(%rip),%xmm9 # 78d0 <_sk_callback_sse2+0x1513> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,40,5,247,22,0,0 // movaps 0x16f7(%rip),%xmm8 # 78e0 <_sk_callback_sse2+0x1523> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,251,22,0,0 // addps 0x16fb(%rip),%xmm8 # 78f0 <_sk_callback_sse2+0x1533> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,255,22,0,0 // addps 0x16ff(%rip),%xmm8 # 7900 <_sk_callback_sse2+0x1543> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,3,23,0,0 // addps 0x1703(%rip),%xmm8 # 7910 <_sk_callback_sse2+0x1553> .byte 68,15,17,128,128,0,0,0 // movups %xmm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p1x_sse2 .globl _sk_bicubic_p1x_sse2 FUNCTION(_sk_bicubic_p1x_sse2) _sk_bicubic_p1x_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,40,5,253,22,0,0 // movaps 0x16fd(%rip),%xmm8 # 7920 <_sk_callback_sse2+0x1563> .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,72,64 // movups 0x40(%rax),%xmm9 .byte 65,15,88,192 // addps %xmm8,%xmm0 .byte 68,15,40,21,249,22,0,0 // movaps 0x16f9(%rip),%xmm10 # 7930 <_sk_callback_sse2+0x1573> .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 68,15,88,21,253,22,0,0 // addps 0x16fd(%rip),%xmm10 # 7940 <_sk_callback_sse2+0x1583> .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,208 // addps %xmm8,%xmm10 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 68,15,88,21,249,22,0,0 // addps 0x16f9(%rip),%xmm10 # 7950 <_sk_callback_sse2+0x1593> .byte 68,15,17,144,128,0,0,0 // movups %xmm10,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p3x_sse2 .globl _sk_bicubic_p3x_sse2 FUNCTION(_sk_bicubic_p3x_sse2) _sk_bicubic_p3x_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,0 // movups (%rax),%xmm0 .byte 68,15,16,64,64 // movups 0x40(%rax),%xmm8 .byte 15,88,5,236,22,0,0 // addps 0x16ec(%rip),%xmm0 # 7960 <_sk_callback_sse2+0x15a3> .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 69,15,89,201 // mulps %xmm9,%xmm9 .byte 68,15,89,5,236,22,0,0 // mulps 0x16ec(%rip),%xmm8 # 7970 <_sk_callback_sse2+0x15b3> .byte 68,15,88,5,244,22,0,0 // addps 0x16f4(%rip),%xmm8 # 7980 <_sk_callback_sse2+0x15c3> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,17,128,128,0,0,0 // movups %xmm8,0x80(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n3y_sse2 .globl _sk_bicubic_n3y_sse2 FUNCTION(_sk_bicubic_n3y_sse2) _sk_bicubic_n3y_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,226,22,0,0 // addps 0x16e2(%rip),%xmm1 # 7990 <_sk_callback_sse2+0x15d3> .byte 68,15,40,13,234,22,0,0 // movaps 0x16ea(%rip),%xmm9 # 79a0 <_sk_callback_sse2+0x15e3> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 69,15,40,193 // movaps %xmm9,%xmm8 .byte 69,15,89,192 // mulps %xmm8,%xmm8 .byte 68,15,89,13,230,22,0,0 // mulps 0x16e6(%rip),%xmm9 # 79b0 <_sk_callback_sse2+0x15f3> .byte 68,15,88,13,238,22,0,0 // addps 0x16ee(%rip),%xmm9 # 79c0 <_sk_callback_sse2+0x1603> .byte 69,15,89,200 // mulps %xmm8,%xmm9 .byte 68,15,17,136,160,0,0,0 // movups %xmm9,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_n1y_sse2 .globl _sk_bicubic_n1y_sse2 FUNCTION(_sk_bicubic_n1y_sse2) _sk_bicubic_n1y_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,220,22,0,0 // addps 0x16dc(%rip),%xmm1 # 79d0 <_sk_callback_sse2+0x1613> .byte 68,15,40,13,228,22,0,0 // movaps 0x16e4(%rip),%xmm9 # 79e0 <_sk_callback_sse2+0x1623> .byte 69,15,92,200 // subps %xmm8,%xmm9 .byte 68,15,40,5,232,22,0,0 // movaps 0x16e8(%rip),%xmm8 # 79f0 <_sk_callback_sse2+0x1633> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,236,22,0,0 // addps 0x16ec(%rip),%xmm8 # 7a00 <_sk_callback_sse2+0x1643> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,240,22,0,0 // addps 0x16f0(%rip),%xmm8 # 7a10 <_sk_callback_sse2+0x1653> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,88,5,244,22,0,0 // addps 0x16f4(%rip),%xmm8 # 7a20 <_sk_callback_sse2+0x1663> .byte 68,15,17,128,160,0,0,0 // movups %xmm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p1y_sse2 .globl _sk_bicubic_p1y_sse2 FUNCTION(_sk_bicubic_p1y_sse2) _sk_bicubic_p1y_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 68,15,40,5,238,22,0,0 // movaps 0x16ee(%rip),%xmm8 # 7a30 <_sk_callback_sse2+0x1673> .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,72,96 // movups 0x60(%rax),%xmm9 .byte 65,15,88,200 // addps %xmm8,%xmm1 .byte 68,15,40,21,233,22,0,0 // movaps 0x16e9(%rip),%xmm10 # 7a40 <_sk_callback_sse2+0x1683> .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 68,15,88,21,237,22,0,0 // addps 0x16ed(%rip),%xmm10 # 7a50 <_sk_callback_sse2+0x1693> .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 69,15,88,208 // addps %xmm8,%xmm10 .byte 69,15,89,209 // mulps %xmm9,%xmm10 .byte 68,15,88,21,233,22,0,0 // addps 0x16e9(%rip),%xmm10 # 7a60 <_sk_callback_sse2+0x16a3> .byte 68,15,17,144,160,0,0,0 // movups %xmm10,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_bicubic_p3y_sse2 .globl _sk_bicubic_p3y_sse2 FUNCTION(_sk_bicubic_p3y_sse2) _sk_bicubic_p3y_sse2: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,16,72,32 // movups 0x20(%rax),%xmm1 .byte 68,15,16,64,96 // movups 0x60(%rax),%xmm8 .byte 15,88,13,219,22,0,0 // addps 0x16db(%rip),%xmm1 # 7a70 <_sk_callback_sse2+0x16b3> .byte 69,15,40,200 // movaps %xmm8,%xmm9 .byte 69,15,89,201 // mulps %xmm9,%xmm9 .byte 68,15,89,5,219,22,0,0 // mulps 0x16db(%rip),%xmm8 # 7a80 <_sk_callback_sse2+0x16c3> .byte 68,15,88,5,227,22,0,0 // addps 0x16e3(%rip),%xmm8 # 7a90 <_sk_callback_sse2+0x16d3> .byte 69,15,89,193 // mulps %xmm9,%xmm8 .byte 68,15,17,128,160,0,0,0 // movups %xmm8,0xa0(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_callback_sse2 .globl _sk_callback_sse2 FUNCTION(_sk_callback_sse2) _sk_callback_sse2: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,236,72 // sub $0x48,%rsp .byte 15,41,125,144 // movaps %xmm7,-0x70(%rbp) .byte 15,41,117,160 // movaps %xmm6,-0x60(%rbp) .byte 15,41,109,176 // movaps %xmm5,-0x50(%rbp) .byte 15,41,101,192 // movaps %xmm4,-0x40(%rbp) .byte 76,137,195 // mov %r8,%rbx .byte 72,137,77,208 // mov %rcx,-0x30(%rbp) .byte 73,137,215 // mov %rdx,%r15 .byte 73,137,252 // mov %rdi,%r12 .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,137,198 // mov %rax,%r14 .byte 73,137,245 // mov %rsi,%r13 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,20,225 // unpcklps %xmm1,%xmm4 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,20,235 // unpcklps %xmm3,%xmm5 .byte 15,21,193 // unpckhps %xmm1,%xmm0 .byte 15,21,211 // unpckhps %xmm3,%xmm2 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 102,15,20,205 // unpcklpd %xmm5,%xmm1 .byte 15,18,236 // movhlps %xmm4,%xmm5 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 102,15,20,218 // unpcklpd %xmm2,%xmm3 .byte 102,65,15,17,78,8 // movupd %xmm1,0x8(%r14) .byte 15,18,208 // movhlps %xmm0,%xmm2 .byte 65,15,17,110,24 // movups %xmm5,0x18(%r14) .byte 102,65,15,17,94,40 // movupd %xmm3,0x28(%r14) .byte 65,15,17,86,56 // movups %xmm2,0x38(%r14) .byte 72,133,219 // test %rbx,%rbx .byte 190,4,0,0,0 // mov $0x4,%esi .byte 15,69,243 // cmovne %ebx,%esi .byte 76,137,247 // mov %r14,%rdi .byte 65,255,22 // callq *(%r14) .byte 73,139,134,136,0,0,0 // mov 0x88(%r14),%rax .byte 15,16,32 // movups (%rax),%xmm4 .byte 15,16,64,16 // movups 0x10(%rax),%xmm0 .byte 15,16,88,32 // movups 0x20(%rax),%xmm3 .byte 15,16,80,48 // movups 0x30(%rax),%xmm2 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,20,232 // unpcklps %xmm0,%xmm5 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 15,21,224 // unpckhps %xmm0,%xmm4 .byte 15,21,218 // unpckhps %xmm2,%xmm3 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 102,15,20,193 // unpcklpd %xmm1,%xmm0 .byte 15,18,205 // movhlps %xmm5,%xmm1 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 102,15,20,211 // unpcklpd %xmm3,%xmm2 .byte 15,18,220 // movhlps %xmm4,%xmm3 .byte 76,137,238 // mov %r13,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 76,137,231 // mov %r12,%rdi .byte 76,137,250 // mov %r15,%rdx .byte 72,139,77,208 // mov -0x30(%rbp),%rcx .byte 73,137,216 // mov %rbx,%r8 .byte 15,40,101,192 // movaps -0x40(%rbp),%xmm4 .byte 15,40,109,176 // movaps -0x50(%rbp),%xmm5 .byte 15,40,117,160 // movaps -0x60(%rbp),%xmm6 .byte 15,40,125,144 // movaps -0x70(%rbp),%xmm7 .byte 72,131,196,72 // add $0x48,%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 255,224 // jmpq *%rax BALIGN16 .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,1 // cmpb $0x1,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 2,0 // add (%rax),%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 128,60,0,0 // cmpb $0x0,(%rax,%rax,1) .byte 252 // cld .byte 190,0,0,252,190 // mov $0xbefc0000,%esi .byte 0,0 // add %al,(%rax) .byte 252 // cld .byte 190,0,0,252,190 // mov $0xbefc0000,%esi .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,191,0,0,128 // add %al,-0x7fffff41(%rax) .byte 191,0,0,128,191 // mov $0xbf800000,%edi .byte 0,0 // add %al,(%rax) .byte 128,191,0,0,224,64,0 // cmpb $0x0,0x40e00000(%rdi) .byte 0,224 // add %ah,%al .byte 64,0,0 // add %al,(%rax) .byte 224,64 // loopne 66ac <.literal16+0x1fc> .byte 0,0 // add %al,(%rax) .byte 224,64 // loopne 66b0 <.literal16+0x200> .byte 154 // (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,61 // ds cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 66d1 <.literal16+0x221> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 66d5 <.literal16+0x225> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 66d9 <.literal16+0x229> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 66dd <.literal16+0x22d> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,61 // ds cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6711 <.literal16+0x261> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6715 <.literal16+0x265> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6719 <.literal16+0x269> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 671d <.literal16+0x26d> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,61 // ds cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6751 <.literal16+0x2a1> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6755 <.literal16+0x2a5> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6759 <.literal16+0x2a9> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 675d <.literal16+0x2ad> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,154 // cmpb $0x9a,(%rdi) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,61,10,23,63,61 // ds cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%rdi),%dl .byte 63 // (bad) .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6791 <.literal16+0x2e1> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6795 <.literal16+0x2e5> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 6799 <.literal16+0x2e9> .byte 174 // scas %es:(%rdi),%al .byte 71,225,61 // rex.RXB loope 679d <.literal16+0x2ed> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,255 // cmpb $0xff,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,127 // add %al,0x7f00003f(%rax) .byte 67,0,0 // rex.XB add %al,(%r8) .byte 127,67 // jg 67db <.literal16+0x32b> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 67df <.literal16+0x32f> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 67e3 <.literal16+0x333> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,145,131,158 // add %al,-0x617c6ec1(%rax) .byte 61,145,131,158,61 // cmp $0x3d9e8391,%eax .byte 145 // xchg %eax,%ecx .byte 131,158,61,145,131,158,61 // sbbl $0x3d,-0x617c6ec3(%rsi) .byte 154 // (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,92 // ds pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 145 // xchg %eax,%ecx .byte 131,158,61,145,131,158,61 // sbbl $0x3d,-0x617c6ec3(%rsi) .byte 145 // xchg %eax,%ecx .byte 131,158,61,145,131,158,61 // sbbl $0x3d,-0x617c6ec3(%rsi) .byte 154 // (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,154 // ds (bad) .byte 153 // cltd .byte 153 // cltd .byte 62,92 // ds pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 92 // pop %rsp .byte 143 // (bad) .byte 50,63 // xor (%rdi),%bh .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%rbx),%edi .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 174 // scas %es:(%rdi),%al .byte 71,97 // rex.RXB (bad) .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 82 // push %rdx .byte 184,78,65,82,184 // mov $0xb852414e,%eax .byte 78 // rex.WRX .byte 65,82 // push %r10 .byte 184,78,65,82,184 // mov $0xb852414e,%eax .byte 78 // rex.WRX .byte 65,57,215 // cmp %edx,%r15d .byte 32,187,57,215,32,187 // and %bh,-0x44df28c7(%rbx) .byte 57,215 // cmp %edx,%edi .byte 32,187,57,215,32,187 // and %bh,-0x44df28c7(%rbx) .byte 186,159,98,60,186 // mov $0xba3c629f,%edx .byte 159 // lahf .byte 98 // (bad) .byte 60,186 // cmp $0xba,%al .byte 159 // lahf .byte 98 // (bad) .byte 60,186 // cmp $0xba,%al .byte 159 // lahf .byte 98 // (bad) .byte 60,109 // cmp $0x6d,%al .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 144 // nop .byte 63 // (bad) .byte 109 // insl (%dx),%es:(%rdi) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 144 // nop .byte 63 // (bad) .byte 109 // insl (%dx),%es:(%rdi) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 144 // nop .byte 63 // (bad) .byte 109 // insl (%dx),%es:(%rdi) .byte 165 // movsl %ds:(%rsi),%es:(%rdi) .byte 144 // nop .byte 63 // (bad) .byte 252 // cld .byte 191,16,62,252,191 // mov $0xbffc3e10,%edi .byte 16,62 // adc %bh,(%rsi) .byte 252 // cld .byte 191,16,62,252,191 // mov $0xbffc3e10,%edi .byte 16,62 // adc %bh,(%rsi) .byte 168,177 // test $0xb1,%al .byte 152 // cwtl .byte 59,168,177,152,59,168 // cmp -0x57c4674f(%rax),%ebp .byte 177,152 // mov $0x98,%cl .byte 59,168,177,152,59,0 // cmp 0x3b98b1(%rax),%ebp .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,192 // add %al,-0x3fffffc1(%rax) .byte 64,0,0 // add %al,(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 0,64,0 // add %al,0x0(%rax) .byte 0,0 // add %al,(%rax) .byte 64,0,0 // add %al,(%rax) .byte 0,64,0 // add %al,0x0(%rax) .byte 0,0 // add %al,(%rax) .byte 64,0,0 // add %al,(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,171,170 // addb $0xaa,-0x55(%rax) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 62,0,0 // add %al,%ds:(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,171 // cmpb $0xab,(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,63 // sub (%rdi),%bh .byte 0,0 // add %al,(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 192,64,0,0 // rolb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,0,0 // addb $0x0,0x0(%rax) .byte 128,64,171,170 // addb $0xaa,-0x55(%rax) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 42,62 // sub (%rsi),%bh .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,0,248,0,0 // addb $0x0,0xf8003b(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 6a39 <.literal16+0x589> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6a3d <.literal16+0x58d> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6a41 <.literal16+0x591> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 6a45 <.literal16+0x595> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%rdi,1) .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,255,0,255,0 // addb $0x0,-0xff00c5(%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6b1b <.literal16+0x66b> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6b1f <.literal16+0x66f> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6b23 <.literal16+0x673> .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,129,128,128,59 // addb $0x3b,-0x7f7f7ec5(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 6b14 <.literal16+0x664> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6b18 <.literal16+0x668> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6b1c <.literal16+0x66c> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6b20 <.literal16+0x670> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 6ba5 <.literal16+0x6f5> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 6b09 <.literal16+0x659> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3ab4a <_sk_callback_sse2+0xffffffffe9a3478d> .byte 220,63 // fdivrl (%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,81 // cmpb $0x51,(%rdi) .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,52,0 // add %dh,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 6be4 <.literal16+0x734> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6be8 <.literal16+0x738> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6bec <.literal16+0x73c> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6bf0 <.literal16+0x740> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 6c75 <.literal16+0x7c5> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 6bd9 <.literal16+0x729> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3ac1a <_sk_callback_sse2+0xffffffffe9a3485d> .byte 220,63 // fdivrl (%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,81 // cmpb $0x51,(%rdi) .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,52,0 // add %dh,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 6cb4 <.literal16+0x804> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6cb8 <.literal16+0x808> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6cbc <.literal16+0x80c> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6cc0 <.literal16+0x810> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 6d45 <.literal16+0x895> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 6ca9 <.literal16+0x7f9> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3acea <_sk_callback_sse2+0xffffffffe9a3492d> .byte 220,63 // fdivrl (%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,81 // cmpb $0x51,(%rdi) .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,52,0 // add %dh,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 6d84 <.literal16+0x8d4> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6d88 <.literal16+0x8d8> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6d8c <.literal16+0x8dc> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6d90 <.literal16+0x8e0> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 6e15 <.literal16+0x965> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 6d79 <.literal16+0x8c9> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3adba <_sk_callback_sse2+0xffffffffe9a349fd> .byte 220,63 // fdivrl (%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,81 // cmpb $0x51,(%rdi) .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,52,0 // add %dh,(%rax,%rax,1) .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%rax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 6e54 <.literal16+0x9a4> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6e58 <.literal16+0x9a8> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6e5c <.literal16+0x9ac> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 6e60 <.literal16+0x9b0> .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 119,115 // ja 6ee5 <.literal16+0xa35> .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,119,115 // retq $0x7377 .byte 248 // clc .byte 194,117,191 // retq $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 117,191 // jne 6e49 <.literal16+0x999> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // (bad) .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 249 // stc .byte 68,180,62 // rex.R mov $0x3e,%spl .byte 163,233,220,63,163,233,220,63,163 // movabs %eax,0xa33fdce9a33fdce9 .byte 233,220,63,163,233 // jmpq ffffffffe9a3ae8a <_sk_callback_sse2+0xffffffffe9a34acd> .byte 220,63 // fdivrl (%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,81 // cmpb $0x51,(%rdi) .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,81 // rex.X push %rcx .byte 140,242 // mov %?,%edx .byte 66,141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%r15,4),%edi .byte 63 // (bad) .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%rsi,%rdi,4),%edi .byte 63 // (bad) .byte 248 // clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,248 // rex clc .byte 245 // cmc .byte 154 // (bad) .byte 64,254 // rex (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,254 // rex.B (bad) .byte 210,221 // rcr %cl,%ch .byte 65,0,0 // add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 0,75,0 // add %cl,0x0(%rbx) .byte 0,0 // add %al,(%rax) .byte 75,0,0 // rex.WXB add %al,(%r8) .byte 200,66,0,0 // enterq $0x42,$0x0 .byte 200,66,0,0 // enterq $0x42,$0x0 .byte 200,66,0,0 // enterq $0x42,$0x0 .byte 200,66,0,0 // enterq $0x42,$0x0 .byte 127,67 // jg 6f67 <.literal16+0xab7> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6f6b <.literal16+0xabb> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6f6f <.literal16+0xabf> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 6f73 <.literal16+0xac3> .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%rax) .byte 128,65,0,0 // addb $0x0,0x0(%rcx) .byte 128,65,0,0 // addb $0x0,0x0(%rcx) .byte 128,65,0,0 // addb $0x0,0x0(%rcx) .byte 128,65,203,61 // addb $0x3d,-0x35(%rcx) .byte 13,60,203,61,13 // or $0xd3dcb3c,%eax .byte 60,203 // cmp $0xcb,%al .byte 61,13,60,203,61 // cmp $0x3dcb3c0d,%eax .byte 13,60,111,18,3 // or $0x3126f3c,%eax .byte 59,111,18 // cmp 0x12(%rdi),%ebp .byte 3,59 // add (%rbx),%edi .byte 111 // outsl %ds:(%rsi),(%dx) .byte 18,3 // adc (%rbx),%al .byte 59,111,18 // cmp 0x12(%rdi),%ebp .byte 3,59 // add (%rbx),%edi .byte 10,215 // or %bh,%dl .byte 163,59,10,215,163,59,10,215,163 // movabs %eax,0xa3d70a3ba3d70a3b .byte 59,10 // cmp (%rdx),%ecx .byte 215 // xlat %ds:(%rbx) .byte 163,59,194,24,17,60,194,24,17 // movabs %eax,0x1118c23c1118c23b .byte 60,194 // cmp $0xc2,%al .byte 24,17 // sbb %dl,(%rcx) .byte 60,194 // cmp $0xc2,%al .byte 24,17 // sbb %dl,(%rcx) .byte 60,203 // cmp $0xcb,%al .byte 61,13,190,203,61 // cmp $0x3dcbbe0d,%eax .byte 13,190,203,61,13 // or $0xd3dcbbe,%eax .byte 190,203,61,13,190 // mov $0xbe0d3dcb,%esi .byte 80 // push %rax .byte 128,3,62 // addb $0x3e,(%rbx) .byte 80 // push %rax .byte 128,3,62 // addb $0x3e,(%rbx) .byte 80 // push %rax .byte 128,3,62 // addb $0x3e,(%rbx) .byte 80 // push %rax .byte 128,3,62 // addb $0x3e,(%rbx) .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 6ff3 <.literal16+0xb43> .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 6ff7 <.literal16+0xb47> .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 6ffb <.literal16+0xb4b> .byte 31 // (bad) .byte 215 // xlat %ds:(%rbx) .byte 118,63 // jbe 6fff <.literal16+0xb4f> .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 246,64,83,63 // testb $0x3f,0x53(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,129,128,128,59 // addb $0x3b,-0x7f7f7ec5(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,0 // cmpb $0x0,(%rbx) .byte 0,127,67 // add %bh,0x43(%rdi) .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 706b <.literal16+0xbbb> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 706f <.literal16+0xbbf> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 7073 <.literal16+0xbc3> .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,0,0,128,63 // addb $0x3f,-0x7fffffc5(%rax) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,0,0,128,63 // addb $0x3f,-0x7fffffc5(%rax) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,0,0,128,63 // addb $0x3f,-0x7fffffc5(%rax) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 70e9 <.literal16+0xc39> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 70ed <.literal16+0xc3d> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 70f1 <.literal16+0xc41> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 70f5 <.literal16+0xc45> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%rdi,1) .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 248 // clc .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 7159 <.literal16+0xca9> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 715d <.literal16+0xcad> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 7161 <.literal16+0xcb1> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 7165 <.literal16+0xcb5> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%rdi,1) .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 248 // clc .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%rax) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 8,33 // or %ah,(%rcx) .byte 132,55 // test %dh,(%rdi) .byte 224,7 // loopne 71c9 <.literal16+0xd19> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 71cd <.literal16+0xd1d> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 71d1 <.literal16+0xd21> .byte 0,0 // add %al,(%rax) .byte 224,7 // loopne 71d5 <.literal16+0xd25> .byte 0,0 // add %al,(%rax) .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 33,8 // and %ecx,(%rax) .byte 2,58 // add (%rdx),%bh .byte 31 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,31 // add %bl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,8 // add %cl,(%rax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%rdi,1) .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%rcx) .byte 4,61 // add $0x3d,%al .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,248 // add %bh,%al .byte 65,0,0 // add %al,(%r8) .byte 248 // clc .byte 65,0,0 // add %al,(%r8) .byte 248 // clc .byte 65,0,0 // add %al,(%r8) .byte 248 // clc .byte 65,0,0 // add %al,(%r8) .byte 124,66 // jl 7266 <.literal16+0xdb6> .byte 0,0 // add %al,(%rax) .byte 124,66 // jl 726a <.literal16+0xdba> .byte 0,0 // add %al,(%rax) .byte 124,66 // jl 726e <.literal16+0xdbe> .byte 0,0 // add %al,(%rax) .byte 124,66 // jl 7272 <.literal16+0xdc2> .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 240,0,0 // lock add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,59,137 // add %cl,-0x76c47778(%rcx) .byte 136,136,59,137,136,136 // mov %cl,-0x777776c5(%rax) .byte 59,137,136,136,59,15 // cmp 0xf3b8888(%rcx),%ecx .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,61,137 // add %cl,-0x76c27778(%rcx) .byte 136,136,61,137,136,136 // mov %cl,-0x777776c3(%rax) .byte 61,137,136,136,61 // cmp $0x3d888889,%eax .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 240,0,0 // lock add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,59,137 // add %cl,-0x76c47778(%rcx) .byte 136,136,59,137,136,136 // mov %cl,-0x777776c5(%rax) .byte 59,137,136,136,59,15 // cmp 0xf3b8888(%rcx),%ecx .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,61,137 // add %cl,-0x76c27778(%rcx) .byte 136,136,61,137,136,136 // mov %cl,-0x777776c3(%rax) .byte 61,137,136,136,61 // cmp $0x3d888889,%eax .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%rax) .byte 136,55 // mov %dh,(%rdi) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%rax) .byte 136,57 // mov %bh,(%rcx) .byte 240,0,0 // lock add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,59,137 // add %cl,-0x76c47778(%rcx) .byte 136,136,59,137,136,136 // mov %cl,-0x777776c5(%rax) .byte 59,137,136,136,59,15 // cmp 0xf3b8888(%rcx),%ecx .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,15 // add %cl,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,137,136,136,61,137 // add %cl,-0x76c27778(%rcx) .byte 136,136,61,137,136,136 // mov %cl,-0x777776c3(%rax) .byte 61,137,136,136,61 // cmp $0x3d888889,%eax .byte 0,0 // add %al,(%rax) .byte 112,65 // jo 73f5 <.literal16+0xf45> .byte 0,0 // add %al,(%rax) .byte 112,65 // jo 73f9 <.literal16+0xf49> .byte 0,0 // add %al,(%rax) .byte 112,65 // jo 73fd <.literal16+0xf4d> .byte 0,0 // add %al,(%rax) .byte 112,65 // jo 7401 <.literal16+0xf51> .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,0,0,127,67 // addb $0x43,0x7f00003b(%rax) .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 746b <.literal16+0xfbb> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 746f <.literal16+0xfbf> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 7473 <.literal16+0xfc3> .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%rax) .byte 128,59,129 // cmpb $0x81,(%rbx) .byte 128,128,59,0,0,127,67 // addb $0x43,0x7f00003b(%rax) .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 74db <.literal16+0x102b> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 74df <.literal16+0x102f> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 74e3 <.literal16+0x1033> .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 128,0,4 // addb $0x4,(%rax) .byte 0,128,0,4,0,128 // add %al,-0x7ffffc00(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 128,0,128 // addb $0x80,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,0 // add %al,0x0(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 128,0,4 // addb $0x4,(%rax) .byte 0,128,0,4,0,128 // add %al,-0x7ffffc00(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 128,0,128 // addb $0x80,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,0 // add %al,0x0(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,56 // add %bh,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 128,0,4 // addb $0x4,(%rax) .byte 0,128,0,4,0,128 // add %al,-0x7ffffc00(%rax) .byte 0,4,0 // add %al,(%rax,%rax,1) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 128,56,0 // cmpb $0x0,(%rax) .byte 0,128,56,0,0,128 // add %al,-0x7fffffc8(%rax) .byte 56,0 // cmp %al,(%rax) .byte 0,128,56,0,64,254 // add %al,-0x1bfffc8(%rax) .byte 255,0 // incl (%rax) .byte 64,254 // rex (bad) .byte 255,0 // incl (%rax) .byte 64,254 // rex (bad) .byte 255,0 // incl (%rax) .byte 64,254 // rex (bad) .byte 255,128,0,128,55,128 // incl -0x7fc88000(%rax) .byte 0,128,55,128,0,128 // add %al,-0x7fff7fc9(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 128,0,128 // addb $0x80,(%rax) .byte 55 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 255 // (bad) .byte 127,71 // jg 760b <.literal16+0x115b> .byte 0,255 // add %bh,%bh .byte 127,71 // jg 760f <.literal16+0x115f> .byte 0,255 // add %bh,%bh .byte 127,71 // jg 7613 <.literal16+0x1163> .byte 0,255 // add %bh,%bh .byte 127,71 // jg 7617 <.literal16+0x1167> .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,191,0,0,128,191,0 // cmpb $0x0,-0x40800000(%rdi) .byte 0,128,191,0,0,128 // add %al,-0x7fffff41(%rax) .byte 191,0,0,0,63 // mov $0x3f000000,%edi .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,208 // cmpb $0xd0,(%rdi) .byte 179,89 // mov $0x59,%bl .byte 62,208 // ds (bad) .byte 179,89 // mov $0x59,%bl .byte 62,208 // ds (bad) .byte 179,89 // mov $0x59,%bl .byte 62,208 // ds (bad) .byte 179,89 // mov $0x59,%bl .byte 62,89 // ds pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 89 // pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 89 // pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 89 // pop %rcx .byte 23 // (bad) .byte 55 // (bad) .byte 63 // (bad) .byte 152 // cwtl .byte 221,147,61,152,221,147 // fstl -0x6c2267c3(%rbx) .byte 61,152,221,147,61 // cmp $0x3d93dd98,%eax .byte 152 // cwtl .byte 221,147,61,45,16,17 // fstl 0x11102d3d(%rbx) .byte 192,45,16,17,192,45,16 // shrb $0x10,0x2dc01110(%rip) # 2dc087aa <_sk_callback_sse2+0x2dc023ed> .byte 17,192 // adc %eax,%eax .byte 45,16,17,192,18 // sub $0x12c01110,%eax .byte 120,57 // js 76dc <.literal16+0x122c> .byte 64,18,120,57 // adc 0x39(%rax),%dil .byte 64,18,120,57 // adc 0x39(%rax),%dil .byte 64,18,120,57 // adc 0x39(%rax),%dil .byte 64,32,148,90,62,32,148,90 // and %dl,0x5a94203e(%rdx,%rbx,2) .byte 62,32,148,90,62,32,148,90 // and %dl,%ds:0x5a94203e(%rdx,%rbx,2) .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,4,157 // ds add $0x9d,%al .byte 30 // (bad) .byte 62,0,24 // add %bl,%ds:(%rax) .byte 161,57,0,24,161,57,0,24,161 // movabs 0xa1180039a1180039,%eax .byte 57,0 // cmp %eax,(%rax) .byte 24,161,57,1,0,0 // sbb %ah,0x139(%rcx) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,111,43 // add %ch,0x2b(%rdi) .byte 231,187 // out %eax,$0xbb .byte 111 // outsl %ds:(%rsi),(%dx) .byte 43,231 // sub %edi,%esp .byte 187,111,43,231,187 // mov $0xbbe72b6f,%ebx .byte 111 // outsl %ds:(%rsi),(%dx) .byte 43,231 // sub %edi,%esp .byte 187,159,215,202,60 // mov $0x3ccad79f,%ebx .byte 159 // lahf .byte 215 // xlat %ds:(%rbx) .byte 202,60,159 // lret $0x9f3c .byte 215 // xlat %ds:(%rbx) .byte 202,60,159 // lret $0x9f3c .byte 215 // xlat %ds:(%rbx) .byte 202,60,212 // lret $0xd43c .byte 100,84 // fs push %rsp .byte 189,212,100,84,189 // mov $0xbd5464d4,%ebp .byte 212 // (bad) .byte 100,84 // fs push %rsp .byte 189,212,100,84,189 // mov $0xbd5464d4,%ebp .byte 169,240,34,62,169 // test $0xa93e22f0,%eax .byte 240,34,62 // lock and (%rsi),%bh .byte 169,240,34,62,169 // test $0xa93e22f0,%eax .byte 240,34,62 // lock and (%rsi),%bh .byte 0,0 // add %al,(%rax) .byte 128,62,0 // cmpb $0x0,(%rsi) .byte 0,128,62,0,0,128 // add %al,-0x7fffffc2(%rax) .byte 62,0,0 // add %al,%ds:(%rax) .byte 128,62,0 // cmpb $0x0,(%rsi) .byte 0,0 // add %al,(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,0,0 // rolb $0x0,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,128,192,0,0,128 // add %al,-0x7fffff40(%rax) .byte 192,0,0 // rolb $0x0,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,63 // add %al,0x3f000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,128,192,0,0,128 // add %al,-0x7fffff40(%rax) .byte 192,0,0 // rolb $0x0,(%rax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%rax) .byte 128,0,0 // addb $0x0,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,63 // add %al,0x3f000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%rax) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 191,0,0,0,191 // mov $0xbf000000,%edi .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,0 // add %al,(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 192,191,0,0,192,191,0 // sarb $0x0,-0x40400000(%rdi) .byte 0,192 // add %al,%al .byte 191,0,0,192,191 // mov $0xbfc00000,%edi .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,114 // cmpb $0x72,(%rdi) .byte 28,199 // sbb $0xc7,%al .byte 62,114,28 // jb,pt 78c2 <.literal16+0x1412> .byte 199 // (bad) .byte 62,114,28 // jb,pt 78c6 <.literal16+0x1416> .byte 199 // (bad) .byte 62,114,28 // jb,pt 78ca <.literal16+0x141a> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,85 // cmpb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%rsi) .byte 99,61,57,142,99,61 // movslq 0x3d638e39(%rip),%edi # 3d640755 <_sk_callback_sse2+0x3d63a398> .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%rsi) .byte 99,61,57,142,99,61 // movslq 0x3d638e39(%rip),%edi # 3d640795 <_sk_callback_sse2+0x3d63a3d8> .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 114,28 // jb 798e <.literal16+0x14de> .byte 199 // (bad) .byte 62,114,28 // jb,pt 7992 <.literal16+0x14e2> .byte 199 // (bad) .byte 62,114,28 // jb,pt 7996 <.literal16+0x14e6> .byte 199 // (bad) .byte 62,114,28 // jb,pt 799a <.literal16+0x14ea> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 0,0 // add %al,(%rax) .byte 192,191,0,0,192,191,0 // sarb $0x0,-0x40400000(%rdi) .byte 0,192 // add %al,%al .byte 191,0,0,192,191 // mov $0xbfc00000,%edi .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,114 // cmpb $0x72,(%rdi) .byte 28,199 // sbb $0xc7,%al .byte 62,114,28 // jb,pt 79d2 <.literal16+0x1522> .byte 199 // (bad) .byte 62,114,28 // jb,pt 79d6 <.literal16+0x1526> .byte 199 // (bad) .byte 62,114,28 // jb,pt 79da <.literal16+0x152a> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%rdi) .byte 0,0 // add %al,(%rax) .byte 128,63,0 // cmpb $0x0,(%rdi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%rax) .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 128,63,85 // cmpb $0x55,(%rdi) .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%rsi) .byte 99,61,57,142,99,61 // movslq 0x3d638e39(%rip),%edi # 3d640865 <_sk_callback_sse2+0x3d63a4a8> .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %rbp .byte 85 // push %rbp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%rsi) .byte 99,61,57,142,99,61 // movslq 0x3d638e39(%rip),%edi # 3d6408a5 <_sk_callback_sse2+0x3d63a4e8> .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%rsi) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 0,0 // add %al,(%rax) .byte 192,63,0 // sarb $0x0,(%rdi) .byte 0,192 // add %al,%al .byte 63 // (bad) .byte 114,28 // jb 7a9e <.literal16+0x15ee> .byte 199 // (bad) .byte 62,114,28 // jb,pt 7aa2 <_sk_callback_sse2+0x16e5> .byte 199 // (bad) .byte 62,114,28 // jb,pt 7aa6 <_sk_callback_sse2+0x16e9> .byte 199 // (bad) .byte 62,114,28 // jb,pt 7aaa <_sk_callback_sse2+0x16ed> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 170 // stos %al,%es:(%rdi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi BALIGN4 .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) .byte 0,0 // add %al,(%rax) .byte 0,63 // add %bh,(%rdi) BALIGN32 HIDDEN _sk_start_pipeline_hsw_8bit .globl _sk_start_pipeline_hsw_8bit FUNCTION(_sk_start_pipeline_hsw_8bit) _sk_start_pipeline_hsw_8bit: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,236,56 // sub $0x38,%rsp .byte 72,137,211 // mov %rdx,%rbx .byte 73,137,247 // mov %rsi,%r15 .byte 72,137,125,208 // mov %rdi,-0x30(%rbp) .byte 76,137,198 // mov %r8,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,137,197 // mov %rax,%r13 .byte 73,137,246 // mov %rsi,%r14 .byte 72,137,77,168 // mov %rcx,-0x58(%rbp) .byte 73,57,207 // cmp %rcx,%r15 .byte 115,102 // jae 95 <_sk_start_pipeline_hsw_8bit+0x95> .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,141,64,8 // lea 0x8(%rax),%rax .byte 72,137,69,176 // mov %rax,-0x50(%rbp) .byte 76,141,101,184 // lea -0x48(%rbp),%r12 .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 76,137,125,192 // mov %r15,-0x40(%rbp) .byte 72,199,69,200,0,0,0,0 // movq $0x0,-0x38(%rbp) .byte 72,57,93,176 // cmp %rbx,-0x50(%rbp) .byte 119,30 // ja 77 <_sk_start_pipeline_hsw_8bit+0x77> .byte 76,137,231 // mov %r12,%rdi .byte 76,137,246 // mov %r14,%rsi .byte 65,255,213 // callq *%r13 .byte 72,139,77,184 // mov -0x48(%rbp),%rcx .byte 72,141,65,8 // lea 0x8(%rcx),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 72,131,193,16 // add $0x10,%rcx .byte 72,57,217 // cmp %rbx,%rcx .byte 118,226 // jbe 59 <_sk_start_pipeline_hsw_8bit+0x59> .byte 72,137,217 // mov %rbx,%rcx .byte 72,41,193 // sub %rax,%rcx .byte 116,13 // je 8c <_sk_start_pipeline_hsw_8bit+0x8c> .byte 72,137,77,200 // mov %rcx,-0x38(%rbp) .byte 76,137,231 // mov %r12,%rdi .byte 76,137,246 // mov %r14,%rsi .byte 65,255,213 // callq *%r13 .byte 73,255,199 // inc %r15 .byte 76,59,125,168 // cmp -0x58(%rbp),%r15 .byte 117,170 // jne 3f <_sk_start_pipeline_hsw_8bit+0x3f> .byte 72,131,196,56 // add $0x38,%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 197,248,119 // vzeroupper .byte 195 // retq HIDDEN _sk_just_return_hsw_8bit .globl _sk_just_return_hsw_8bit FUNCTION(_sk_just_return_hsw_8bit) _sk_just_return_hsw_8bit: .byte 195 // retq HIDDEN _sk_uniform_color_hsw_8bit .globl _sk_uniform_color_hsw_8bit FUNCTION(_sk_uniform_color_hsw_8bit) _sk_uniform_color_hsw_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,24,64,16 // vbroadcastss 0x10(%rax),%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_set_rgb_hsw_8bit .globl _sk_set_rgb_hsw_8bit FUNCTION(_sk_set_rgb_hsw_8bit) _sk_set_rgb_hsw_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,250,16,21,54,18,0,0 // vmovss 0x1236(%rip),%xmm2 # 12f4 <_sk_xor__hsw_8bit+0xbd> .byte 197,234,89,24 // vmulss (%rax),%xmm2,%xmm3 .byte 196,225,250,44,203 // vcvttss2si %xmm3,%rcx .byte 197,234,89,88,4 // vmulss 0x4(%rax),%xmm2,%xmm3 .byte 196,225,250,44,211 // vcvttss2si %xmm3,%rdx .byte 193,226,8 // shl $0x8,%edx .byte 9,202 // or %ecx,%edx .byte 197,234,89,80,8 // vmulss 0x8(%rax),%xmm2,%xmm2 .byte 196,225,250,44,194 // vcvttss2si %xmm2,%rax .byte 193,224,16 // shl $0x10,%eax .byte 9,208 // or %edx,%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 196,226,125,88,210 // vpbroadcastd %xmm2,%ymm2 .byte 197,253,219,5,42,18,0,0 // vpand 0x122a(%rip),%ymm0,%ymm0 # 1320 <_sk_xor__hsw_8bit+0xe9> .byte 197,237,235,192 // vpor %ymm0,%ymm2,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_hsw_8bit .globl _sk_premul_hsw_8bit FUNCTION(_sk_premul_hsw_8bit) _sk_premul_hsw_8bit: .byte 196,226,125,0,21,57,18,0,0 // vpshufb 0x1239(%rip),%ymm0,%ymm2 # 1340 <_sk_xor__hsw_8bit+0x109> .byte 197,237,235,21,81,18,0,0 // vpor 0x1251(%rip),%ymm2,%ymm2 # 1360 <_sk_xor__hsw_8bit+0x129> .byte 196,226,125,48,216 // vpmovzxbw %xmm0,%ymm3 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 196,226,125,48,226 // vpmovzxbw %xmm2,%ymm4 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 197,237,213,208 // vpmullw %ymm0,%ymm2,%ymm2 .byte 197,221,213,227 // vpmullw %ymm3,%ymm4,%ymm4 .byte 197,221,253,219 // vpaddw %ymm3,%ymm4,%ymm3 .byte 197,237,253,192 // vpaddw %ymm0,%ymm2,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,211,8 // vpsrlw $0x8,%ymm3,%ymm2 .byte 196,227,109,56,216,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm3 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,229,103,192 // vpackuswb %ymm0,%ymm3,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_swap_rb_hsw_8bit .globl _sk_swap_rb_hsw_8bit FUNCTION(_sk_swap_rb_hsw_8bit) _sk_swap_rb_hsw_8bit: .byte 196,226,125,0,5,26,18,0,0 // vpshufb 0x121a(%rip),%ymm0,%ymm0 # 1380 <_sk_xor__hsw_8bit+0x149> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_invert_hsw_8bit .globl _sk_invert_hsw_8bit FUNCTION(_sk_invert_hsw_8bit) _sk_invert_hsw_8bit: .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 197,253,239,194 // vpxor %ymm2,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_load_8888_hsw_8bit .globl _sk_load_8888_hsw_8bit FUNCTION(_sk_load_8888_hsw_8bit) _sk_load_8888_hsw_8bit: .byte 76,99,15 // movslq (%rdi),%r9 .byte 76,139,71,16 // mov 0x10(%rdi),%r8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,80,8 // movslq 0x8(%rax),%rdx .byte 72,99,79,8 // movslq 0x8(%rdi),%rcx .byte 72,15,175,202 // imul %rdx,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 74,141,4,137 // lea (%rcx,%r9,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,8 // jne 1a3 <_sk_load_8888_hsw_8bit+0x2d> .byte 197,254,111,0 // vmovdqu (%rax),%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 72,199,194,255,255,255,255 // mov $0xffffffffffffffff,%rdx .byte 72,211,234 // shr %cl,%rdx .byte 196,225,249,110,194 // vmovq %rdx,%xmm0 .byte 196,226,125,33,192 // vpmovsxbd %xmm0,%ymm0 .byte 196,226,125,140,0 // vpmaskmovd (%rax),%ymm0,%ymm0 .byte 235,214 // jmp 19f <_sk_load_8888_hsw_8bit+0x29> HIDDEN _sk_load_8888_dst_hsw_8bit .globl _sk_load_8888_dst_hsw_8bit FUNCTION(_sk_load_8888_dst_hsw_8bit) _sk_load_8888_dst_hsw_8bit: .byte 76,99,15 // movslq (%rdi),%r9 .byte 76,139,71,16 // mov 0x10(%rdi),%r8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,80,8 // movslq 0x8(%rax),%rdx .byte 72,99,79,8 // movslq 0x8(%rdi),%rcx .byte 72,15,175,202 // imul %rdx,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 74,141,4,137 // lea (%rcx,%r9,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,8 // jne 1f6 <_sk_load_8888_dst_hsw_8bit+0x2d> .byte 197,254,111,8 // vmovdqu (%rax),%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 72,199,194,255,255,255,255 // mov $0xffffffffffffffff,%rdx .byte 72,211,234 // shr %cl,%rdx .byte 196,225,249,110,202 // vmovq %rdx,%xmm1 .byte 196,226,125,33,201 // vpmovsxbd %xmm1,%ymm1 .byte 196,226,117,140,8 // vpmaskmovd (%rax),%ymm1,%ymm1 .byte 235,214 // jmp 1f2 <_sk_load_8888_dst_hsw_8bit+0x29> HIDDEN _sk_store_8888_hsw_8bit .globl _sk_store_8888_hsw_8bit FUNCTION(_sk_store_8888_hsw_8bit) _sk_store_8888_hsw_8bit: .byte 76,99,15 // movslq (%rdi),%r9 .byte 76,139,71,16 // mov 0x10(%rdi),%r8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,80,8 // movslq 0x8(%rax),%rdx .byte 72,99,79,8 // movslq 0x8(%rdi),%rcx .byte 72,15,175,202 // imul %rdx,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 74,141,4,137 // lea (%rcx,%r9,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,8 // jne 249 <_sk_store_8888_hsw_8bit+0x2d> .byte 197,254,127,0 // vmovdqu %ymm0,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 72,199,194,255,255,255,255 // mov $0xffffffffffffffff,%rdx .byte 72,211,234 // shr %cl,%rdx .byte 196,225,249,110,210 // vmovq %rdx,%xmm2 .byte 196,226,125,33,210 // vpmovsxbd %xmm2,%ymm2 .byte 196,226,109,142,0 // vpmaskmovd %ymm0,%ymm2,(%rax) .byte 235,214 // jmp 245 <_sk_store_8888_hsw_8bit+0x29> HIDDEN _sk_load_bgra_hsw_8bit .globl _sk_load_bgra_hsw_8bit FUNCTION(_sk_load_bgra_hsw_8bit) _sk_load_bgra_hsw_8bit: .byte 76,99,15 // movslq (%rdi),%r9 .byte 76,139,71,16 // mov 0x10(%rdi),%r8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,80,8 // movslq 0x8(%rax),%rdx .byte 72,99,79,8 // movslq 0x8(%rdi),%rcx .byte 72,15,175,202 // imul %rdx,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 74,141,4,137 // lea (%rcx,%r9,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,17 // jne 2a5 <_sk_load_bgra_hsw_8bit+0x36> .byte 197,254,111,0 // vmovdqu (%rax),%ymm0 .byte 196,226,125,0,5,255,16,0,0 // vpshufb 0x10ff(%rip),%ymm0,%ymm0 # 13a0 <_sk_xor__hsw_8bit+0x169> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 72,199,194,255,255,255,255 // mov $0xffffffffffffffff,%rdx .byte 72,211,234 // shr %cl,%rdx .byte 196,225,249,110,194 // vmovq %rdx,%xmm0 .byte 196,226,125,33,192 // vpmovsxbd %xmm0,%ymm0 .byte 196,226,125,140,0 // vpmaskmovd (%rax),%ymm0,%ymm0 .byte 235,205 // jmp 298 <_sk_load_bgra_hsw_8bit+0x29> HIDDEN _sk_load_bgra_dst_hsw_8bit .globl _sk_load_bgra_dst_hsw_8bit FUNCTION(_sk_load_bgra_dst_hsw_8bit) _sk_load_bgra_dst_hsw_8bit: .byte 76,99,15 // movslq (%rdi),%r9 .byte 76,139,71,16 // mov 0x10(%rdi),%r8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,80,8 // movslq 0x8(%rax),%rdx .byte 72,99,79,8 // movslq 0x8(%rdi),%rcx .byte 72,15,175,202 // imul %rdx,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 74,141,4,137 // lea (%rcx,%r9,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,17 // jne 301 <_sk_load_bgra_dst_hsw_8bit+0x36> .byte 197,254,111,8 // vmovdqu (%rax),%ymm1 .byte 196,226,117,0,13,195,16,0,0 // vpshufb 0x10c3(%rip),%ymm1,%ymm1 # 13c0 <_sk_xor__hsw_8bit+0x189> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 72,199,194,255,255,255,255 // mov $0xffffffffffffffff,%rdx .byte 72,211,234 // shr %cl,%rdx .byte 196,225,249,110,202 // vmovq %rdx,%xmm1 .byte 196,226,125,33,201 // vpmovsxbd %xmm1,%ymm1 .byte 196,226,117,140,8 // vpmaskmovd (%rax),%ymm1,%ymm1 .byte 235,205 // jmp 2f4 <_sk_load_bgra_dst_hsw_8bit+0x29> HIDDEN _sk_store_bgra_hsw_8bit .globl _sk_store_bgra_hsw_8bit FUNCTION(_sk_store_bgra_hsw_8bit) _sk_store_bgra_hsw_8bit: .byte 76,99,15 // movslq (%rdi),%r9 .byte 76,139,71,16 // mov 0x10(%rdi),%r8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,80,8 // movslq 0x8(%rax),%rdx .byte 72,99,79,8 // movslq 0x8(%rdi),%rcx .byte 72,15,175,202 // imul %rdx,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 74,141,4,137 // lea (%rcx,%r9,4),%rax .byte 196,226,125,0,21,144,16,0,0 // vpshufb 0x1090(%rip),%ymm0,%ymm2 # 13e0 <_sk_xor__hsw_8bit+0x1a9> .byte 77,133,192 // test %r8,%r8 .byte 117,8 // jne 35d <_sk_store_bgra_hsw_8bit+0x36> .byte 197,254,127,16 // vmovdqu %ymm2,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 72,199,194,255,255,255,255 // mov $0xffffffffffffffff,%rdx .byte 72,211,234 // shr %cl,%rdx .byte 196,225,249,110,218 // vmovq %rdx,%xmm3 .byte 196,226,125,33,219 // vpmovsxbd %xmm3,%ymm3 .byte 196,226,101,142,16 // vpmaskmovd %ymm2,%ymm3,(%rax) .byte 235,214 // jmp 359 <_sk_store_bgra_hsw_8bit+0x32> HIDDEN _sk_load_a8_hsw_8bit .globl _sk_load_a8_hsw_8bit FUNCTION(_sk_load_a8_hsw_8bit) _sk_load_a8_hsw_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,28 // jne 3bc <_sk_load_a8_hsw_8bit+0x39> .byte 196,162,121,48,4,2 // vpmovzxbw (%rdx,%r8,1),%xmm0 .byte 197,249,219,5,82,18,0,0 // vpand 0x1252(%rip),%xmm0,%xmm0 # 1600 <_sk_xor__hsw_8bit+0x3c9> .byte 196,226,125,51,192 // vpmovzxwd %xmm0,%ymm0 .byte 197,253,114,240,24 // vpslld $0x18,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,7 // and $0x7,%r9b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,201 // dec %r9b .byte 65,128,249,6 // cmp $0x6,%r9b .byte 119,217 // ja 3a6 <_sk_load_a8_hsw_8bit+0x23> .byte 65,15,182,193 // movzbl %r9b,%eax .byte 72,141,13,116,0,0,0 // lea 0x74(%rip),%rcx # 44c <_sk_load_a8_hsw_8bit+0xc9> .byte 72,99,4,129 // movslq (%rcx,%rax,4),%rax .byte 72,1,200 // add %rcx,%rax .byte 255,224 // jmpq *%rax .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 235,186 // jmp 3a6 <_sk_load_a8_hsw_8bit+0x23> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,2 // vpinsrw $0x2,%eax,%xmm0,%xmm0 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 196,226,121,48,210 // vpmovzxbw %xmm2,%xmm2 .byte 196,227,121,2,194,1 // vpblendd $0x1,%xmm2,%xmm0,%xmm0 .byte 235,149 // jmp 3a6 <_sk_load_a8_hsw_8bit+0x23> .byte 66,15,182,68,2,6 // movzbl 0x6(%rdx,%r8,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 66,15,182,68,2,5 // movzbl 0x5(%rdx,%r8,1),%eax .byte 197,249,196,192,5 // vpinsrw $0x5,%eax,%xmm0,%xmm0 .byte 66,15,182,68,2,4 // movzbl 0x4(%rdx,%r8,1),%eax .byte 197,249,196,192,4 // vpinsrw $0x4,%eax,%xmm0,%xmm0 .byte 196,161,121,110,20,2 // vmovd (%rdx,%r8,1),%xmm2 .byte 196,226,121,48,210 // vpmovzxbw %xmm2,%xmm2 .byte 196,227,105,2,192,12 // vpblendd $0xc,%xmm0,%xmm2,%xmm0 .byte 233,90,255,255,255 // jmpq 3a6 <_sk_load_a8_hsw_8bit+0x23> .byte 149 // xchg %eax,%ebp .byte 255 // (bad) .byte 255 // (bad) .byte 255,175,255,255,255,160 // ljmp *-0x5f000001(%rdi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 234 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 223,255 // (bad) .byte 255 // (bad) .byte 255,212 // callq *%rsp .byte 255 // (bad) .byte 255 // (bad) .byte 255,197 // inc %ebp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_a8_dst_hsw_8bit .globl _sk_load_a8_dst_hsw_8bit FUNCTION(_sk_load_a8_dst_hsw_8bit) _sk_load_a8_dst_hsw_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,28 // jne 4a1 <_sk_load_a8_dst_hsw_8bit+0x39> .byte 196,162,121,48,12,2 // vpmovzxbw (%rdx,%r8,1),%xmm1 .byte 197,241,219,13,125,17,0,0 // vpand 0x117d(%rip),%xmm1,%xmm1 # 1610 <_sk_xor__hsw_8bit+0x3d9> .byte 196,226,125,51,201 // vpmovzxwd %xmm1,%ymm1 .byte 197,245,114,241,24 // vpslld $0x18,%ymm1,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,7 // and $0x7,%r9b .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 65,254,201 // dec %r9b .byte 65,128,249,6 // cmp $0x6,%r9b .byte 119,217 // ja 48b <_sk_load_a8_dst_hsw_8bit+0x23> .byte 65,15,182,193 // movzbl %r9b,%eax .byte 72,141,13,119,0,0,0 // lea 0x77(%rip),%rcx # 534 <_sk_load_a8_dst_hsw_8bit+0xcc> .byte 72,99,4,129 // movslq (%rcx,%rax,4),%rax .byte 72,1,200 // add %rcx,%rax .byte 255,224 // jmpq *%rax .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 197,249,110,200 // vmovd %eax,%xmm1 .byte 235,186 // jmp 48b <_sk_load_a8_dst_hsw_8bit+0x23> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,241,196,200,2 // vpinsrw $0x2,%eax,%xmm1,%xmm1 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 196,226,121,48,210 // vpmovzxbw %xmm2,%xmm2 .byte 196,227,113,2,202,1 // vpblendd $0x1,%xmm2,%xmm1,%xmm1 .byte 235,149 // jmp 48b <_sk_load_a8_dst_hsw_8bit+0x23> .byte 66,15,182,68,2,6 // movzbl 0x6(%rdx,%r8,1),%eax .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,241,196,200,6 // vpinsrw $0x6,%eax,%xmm1,%xmm1 .byte 66,15,182,68,2,5 // movzbl 0x5(%rdx,%r8,1),%eax .byte 197,241,196,200,5 // vpinsrw $0x5,%eax,%xmm1,%xmm1 .byte 66,15,182,68,2,4 // movzbl 0x4(%rdx,%r8,1),%eax .byte 197,241,196,200,4 // vpinsrw $0x4,%eax,%xmm1,%xmm1 .byte 196,161,121,110,20,2 // vmovd (%rdx,%r8,1),%xmm2 .byte 196,226,121,48,210 // vpmovzxbw %xmm2,%xmm2 .byte 196,227,105,2,201,12 // vpblendd $0xc,%xmm1,%xmm2,%xmm1 .byte 233,90,255,255,255 // jmpq 48b <_sk_load_a8_dst_hsw_8bit+0x23> .byte 15,31,0 // nopl (%rax) .byte 146 // xchg %eax,%edx .byte 255 // (bad) .byte 255 // (bad) .byte 255,172,255,255,255,157,255 // ljmp *-0x620001(%rdi,%rdi,8) .byte 255 // (bad) .byte 255,231 // jmpq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 220,255 // fdivr %st,%st(7) .byte 255 // (bad) .byte 255,209 // callq *%rcx .byte 255 // (bad) .byte 255 // (bad) .byte 255,194 // inc %edx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_store_a8_hsw_8bit .globl _sk_store_a8_hsw_8bit FUNCTION(_sk_store_a8_hsw_8bit) _sk_store_a8_hsw_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 196,226,125,0,21,143,14,0,0 // vpshufb 0xe8f(%rip),%ymm0,%ymm2 # 1400 <_sk_xor__hsw_8bit+0x1c9> .byte 196,227,253,0,210,232 // vpermq $0xe8,%ymm2,%ymm2 .byte 77,133,201 // test %r9,%r9 .byte 117,19 // jne 58f <_sk_store_a8_hsw_8bit+0x3f> .byte 196,226,105,0,21,187,16,0,0 // vpshufb 0x10bb(%rip),%xmm2,%xmm2 # 1640 <_sk_xor__hsw_8bit+0x409> .byte 196,161,121,214,20,2 // vmovq %xmm2,(%rdx,%r8,1) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,7 // and $0x7,%r9b .byte 65,254,201 // dec %r9b .byte 65,128,249,6 // cmp $0x6,%r9b .byte 119,239 // ja 58b <_sk_store_a8_hsw_8bit+0x3b> .byte 65,15,182,193 // movzbl %r9b,%eax .byte 72,141,13,85,0,0,0 // lea 0x55(%rip),%rcx # 5fc <_sk_store_a8_hsw_8bit+0xac> .byte 72,99,4,129 // movslq (%rcx,%rax,4),%rax .byte 72,1,200 // add %rcx,%rax .byte 255,224 // jmpq *%rax .byte 196,163,121,20,20,2,0 // vpextrb $0x0,%xmm2,(%rdx,%r8,1) .byte 235,210 // jmp 58b <_sk_store_a8_hsw_8bit+0x3b> .byte 196,163,121,20,84,2,2,4 // vpextrb $0x4,%xmm2,0x2(%rdx,%r8,1) .byte 196,226,105,0,21,86,16,0,0 // vpshufb 0x1056(%rip),%xmm2,%xmm2 # 1620 <_sk_xor__hsw_8bit+0x3e9> .byte 196,163,121,21,20,2,0 // vpextrw $0x0,%xmm2,(%rdx,%r8,1) .byte 235,184 // jmp 58b <_sk_store_a8_hsw_8bit+0x3b> .byte 196,163,121,20,84,2,6,12 // vpextrb $0xc,%xmm2,0x6(%rdx,%r8,1) .byte 196,163,121,20,84,2,5,10 // vpextrb $0xa,%xmm2,0x5(%rdx,%r8,1) .byte 196,163,121,20,84,2,4,8 // vpextrb $0x8,%xmm2,0x4(%rdx,%r8,1) .byte 196,226,105,0,21,60,16,0,0 // vpshufb 0x103c(%rip),%xmm2,%xmm2 # 1630 <_sk_xor__hsw_8bit+0x3f9> .byte 196,161,121,126,20,2 // vmovd %xmm2,(%rdx,%r8,1) .byte 235,143 // jmp 58b <_sk_store_a8_hsw_8bit+0x3b> .byte 180,255 // mov $0xff,%ah .byte 255 // (bad) .byte 255,197 // inc %ebp .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 189,255,255,255,239 // mov $0xefffffff,%ebp .byte 255 // (bad) .byte 255 // (bad) .byte 255,231 // jmpq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 223,255 // (bad) .byte 255 // (bad) .byte 255,215 // callq *%rdi .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_g8_hsw_8bit .globl _sk_load_g8_hsw_8bit FUNCTION(_sk_load_g8_hsw_8bit) _sk_load_g8_hsw_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,50 // jne 667 <_sk_load_g8_hsw_8bit+0x4f> .byte 196,162,121,48,4,2 // vpmovzxbw (%rdx,%r8,1),%xmm0 .byte 197,249,219,5,13,16,0,0 // vpand 0x100d(%rip),%xmm0,%xmm0 # 1650 <_sk_xor__hsw_8bit+0x419> .byte 196,226,125,51,192 // vpmovzxwd %xmm0,%ymm0 .byte 196,226,125,88,21,167,12,0,0 // vpbroadcastd 0xca7(%rip),%ymm2 # 12f8 <_sk_xor__hsw_8bit+0xc1> .byte 196,226,125,64,194 // vpmulld %ymm2,%ymm0,%ymm0 .byte 196,226,125,88,21,157,12,0,0 // vpbroadcastd 0xc9d(%rip),%ymm2 # 12fc <_sk_xor__hsw_8bit+0xc5> .byte 197,253,235,194 // vpor %ymm2,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,7 // and $0x7,%r9b .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 65,254,201 // dec %r9b .byte 65,128,249,6 // cmp $0x6,%r9b .byte 119,195 // ja 63b <_sk_load_g8_hsw_8bit+0x23> .byte 65,15,182,193 // movzbl %r9b,%eax .byte 72,141,13,121,0,0,0 // lea 0x79(%rip),%rcx # 6fc <_sk_load_g8_hsw_8bit+0xe4> .byte 72,99,4,129 // movslq (%rcx,%rax,4),%rax .byte 72,1,200 // add %rcx,%rax .byte 255,224 // jmpq *%rax .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 197,249,110,192 // vmovd %eax,%xmm0 .byte 235,164 // jmp 63b <_sk_load_g8_hsw_8bit+0x23> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,2 // vpinsrw $0x2,%eax,%xmm0,%xmm0 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 196,226,121,48,210 // vpmovzxbw %xmm2,%xmm2 .byte 196,227,121,2,194,1 // vpblendd $0x1,%xmm2,%xmm0,%xmm0 .byte 233,124,255,255,255 // jmpq 63b <_sk_load_g8_hsw_8bit+0x23> .byte 66,15,182,68,2,6 // movzbl 0x6(%rdx,%r8,1),%eax .byte 197,249,239,192 // vpxor %xmm0,%xmm0,%xmm0 .byte 197,249,196,192,6 // vpinsrw $0x6,%eax,%xmm0,%xmm0 .byte 66,15,182,68,2,5 // movzbl 0x5(%rdx,%r8,1),%eax .byte 197,249,196,192,5 // vpinsrw $0x5,%eax,%xmm0,%xmm0 .byte 66,15,182,68,2,4 // movzbl 0x4(%rdx,%r8,1),%eax .byte 197,249,196,192,4 // vpinsrw $0x4,%eax,%xmm0,%xmm0 .byte 196,161,121,110,20,2 // vmovd (%rdx,%r8,1),%xmm2 .byte 196,226,121,48,210 // vpmovzxbw %xmm2,%xmm2 .byte 196,227,105,2,192,12 // vpblendd $0xc,%xmm0,%xmm2,%xmm0 .byte 233,65,255,255,255 // jmpq 63b <_sk_load_g8_hsw_8bit+0x23> .byte 102,144 // xchg %ax,%ax .byte 144 // nop .byte 255 // (bad) .byte 255 // (bad) .byte 255,170,255,255,255,155 // ljmp *-0x64000001(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 232,255,255,255,221 // callq ffffffffde00070c <_sk_xor__hsw_8bit+0xffffffffddfff4d5> .byte 255 // (bad) .byte 255 // (bad) .byte 255,210 // callq *%rdx .byte 255 // (bad) .byte 255 // (bad) .byte 255,195 // inc %ebx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_load_g8_dst_hsw_8bit .globl _sk_load_g8_dst_hsw_8bit FUNCTION(_sk_load_g8_dst_hsw_8bit) _sk_load_g8_dst_hsw_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,50 // jne 767 <_sk_load_g8_dst_hsw_8bit+0x4f> .byte 196,162,121,48,12,2 // vpmovzxbw (%rdx,%r8,1),%xmm1 .byte 197,241,219,13,29,15,0,0 // vpand 0xf1d(%rip),%xmm1,%xmm1 # 1660 <_sk_xor__hsw_8bit+0x429> .byte 196,226,125,51,201 // vpmovzxwd %xmm1,%ymm1 .byte 196,226,125,88,21,175,11,0,0 // vpbroadcastd 0xbaf(%rip),%ymm2 # 1300 <_sk_xor__hsw_8bit+0xc9> .byte 196,226,117,64,202 // vpmulld %ymm2,%ymm1,%ymm1 .byte 196,226,125,88,21,165,11,0,0 // vpbroadcastd 0xba5(%rip),%ymm2 # 1304 <_sk_xor__hsw_8bit+0xcd> .byte 197,245,235,202 // vpor %ymm2,%ymm1,%ymm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,7 // and $0x7,%r9b .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 65,254,201 // dec %r9b .byte 65,128,249,6 // cmp $0x6,%r9b .byte 119,195 // ja 73b <_sk_load_g8_dst_hsw_8bit+0x23> .byte 65,15,182,193 // movzbl %r9b,%eax .byte 72,141,13,121,0,0,0 // lea 0x79(%rip),%rcx # 7fc <_sk_load_g8_dst_hsw_8bit+0xe4> .byte 72,99,4,129 // movslq (%rcx,%rax,4),%rax .byte 72,1,200 // add %rcx,%rax .byte 255,224 // jmpq *%rax .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 197,249,110,200 // vmovd %eax,%xmm1 .byte 235,164 // jmp 73b <_sk_load_g8_dst_hsw_8bit+0x23> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,241,196,200,2 // vpinsrw $0x2,%eax,%xmm1,%xmm1 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 196,226,121,48,210 // vpmovzxbw %xmm2,%xmm2 .byte 196,227,113,2,202,1 // vpblendd $0x1,%xmm2,%xmm1,%xmm1 .byte 233,124,255,255,255 // jmpq 73b <_sk_load_g8_dst_hsw_8bit+0x23> .byte 66,15,182,68,2,6 // movzbl 0x6(%rdx,%r8,1),%eax .byte 197,241,239,201 // vpxor %xmm1,%xmm1,%xmm1 .byte 197,241,196,200,6 // vpinsrw $0x6,%eax,%xmm1,%xmm1 .byte 66,15,182,68,2,5 // movzbl 0x5(%rdx,%r8,1),%eax .byte 197,241,196,200,5 // vpinsrw $0x5,%eax,%xmm1,%xmm1 .byte 66,15,182,68,2,4 // movzbl 0x4(%rdx,%r8,1),%eax .byte 197,241,196,200,4 // vpinsrw $0x4,%eax,%xmm1,%xmm1 .byte 196,161,121,110,20,2 // vmovd (%rdx,%r8,1),%xmm2 .byte 196,226,121,48,210 // vpmovzxbw %xmm2,%xmm2 .byte 196,227,105,2,201,12 // vpblendd $0xc,%xmm1,%xmm2,%xmm1 .byte 233,65,255,255,255 // jmpq 73b <_sk_load_g8_dst_hsw_8bit+0x23> .byte 102,144 // xchg %ax,%ax .byte 144 // nop .byte 255 // (bad) .byte 255 // (bad) .byte 255,170,255,255,255,155 // ljmp *-0x64000001(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 232,255,255,255,221 // callq ffffffffde00080c <_sk_xor__hsw_8bit+0xffffffffddfff5d5> .byte 255 // (bad) .byte 255 // (bad) .byte 255,210 // callq *%rdx .byte 255 // (bad) .byte 255 // (bad) .byte 255,195 // inc %ebx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_srcover_rgba_8888_hsw_8bit .globl _sk_srcover_rgba_8888_hsw_8bit FUNCTION(_sk_srcover_rgba_8888_hsw_8bit) _sk_srcover_rgba_8888_hsw_8bit: .byte 76,99,15 // movslq (%rdi),%r9 .byte 76,139,71,16 // mov 0x10(%rdi),%r8 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,80,8 // movslq 0x8(%rax),%rdx .byte 72,99,79,8 // movslq 0x8(%rdi),%rcx .byte 72,15,175,202 // imul %rdx,%rcx .byte 72,193,225,2 // shl $0x2,%rcx .byte 72,3,8 // add (%rax),%rcx .byte 74,141,4,137 // lea (%rcx,%r9,4),%rax .byte 77,133,192 // test %r8,%r8 .byte 117,108 // jne 8a9 <_sk_srcover_rgba_8888_hsw_8bit+0x91> .byte 197,254,111,16 // vmovdqu (%rax),%ymm2 .byte 196,226,125,0,29,214,11,0,0 // vpshufb 0xbd6(%rip),%ymm0,%ymm3 # 1420 <_sk_xor__hsw_8bit+0x1e9> .byte 196,226,125,48,226 // vpmovzxbw %xmm2,%ymm4 .byte 196,227,125,57,213,1 // vextracti128 $0x1,%ymm2,%xmm5 .byte 196,226,125,48,237 // vpmovzxbw %xmm5,%ymm5 .byte 196,226,125,48,243 // vpmovzxbw %xmm3,%ymm6 .byte 196,227,125,57,219,1 // vextracti128 $0x1,%ymm3,%xmm3 .byte 196,226,125,48,219 // vpmovzxbw %xmm3,%ymm3 .byte 197,213,213,219 // vpmullw %ymm3,%ymm5,%ymm3 .byte 197,221,213,246 // vpmullw %ymm6,%ymm4,%ymm6 .byte 197,205,253,228 // vpaddw %ymm4,%ymm6,%ymm4 .byte 197,229,253,221 // vpaddw %ymm5,%ymm3,%ymm3 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 197,221,113,212,8 // vpsrlw $0x8,%ymm4,%ymm4 .byte 196,227,93,56,235,1 // vinserti128 $0x1,%xmm3,%ymm4,%ymm5 .byte 196,227,93,70,219,49 // vperm2i128 $0x31,%ymm3,%ymm4,%ymm3 .byte 197,213,103,219 // vpackuswb %ymm3,%ymm5,%ymm3 .byte 197,237,248,211 // vpsubb %ymm3,%ymm2,%ymm2 .byte 197,237,252,208 // vpaddb %ymm0,%ymm2,%ymm2 .byte 77,133,192 // test %r8,%r8 .byte 117,49 // jne 8d2 <_sk_srcover_rgba_8888_hsw_8bit+0xba> .byte 197,254,127,16 // vmovdqu %ymm2,(%rax) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 72,199,194,255,255,255,255 // mov $0xffffffffffffffff,%rdx .byte 72,211,234 // shr %cl,%rdx .byte 196,225,249,110,210 // vmovq %rdx,%xmm2 .byte 196,226,125,33,210 // vpmovsxbd %xmm2,%ymm2 .byte 196,226,109,140,16 // vpmaskmovd (%rax),%ymm2,%ymm2 .byte 233,111,255,255,255 // jmpq 841 <_sk_srcover_rgba_8888_hsw_8bit+0x29> .byte 185,8,0,0,0 // mov $0x8,%ecx .byte 68,41,193 // sub %r8d,%ecx .byte 192,225,3 // shl $0x3,%cl .byte 72,199,194,255,255,255,255 // mov $0xffffffffffffffff,%rdx .byte 72,211,234 // shr %cl,%rdx .byte 196,225,249,110,218 // vmovq %rdx,%xmm3 .byte 196,226,125,33,219 // vpmovsxbd %xmm3,%ymm3 .byte 196,226,101,142,16 // vpmaskmovd %ymm2,%ymm3,(%rax) .byte 235,173 // jmp 8a5 <_sk_srcover_rgba_8888_hsw_8bit+0x8d> HIDDEN _sk_scale_1_float_hsw_8bit .globl _sk_scale_1_float_hsw_8bit FUNCTION(_sk_scale_1_float_hsw_8bit) _sk_scale_1_float_hsw_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,250,16,16 // vmovss (%rax),%xmm2 .byte 197,234,89,21,2,10,0,0 // vmulss 0xa02(%rip),%xmm2,%xmm2 # 1308 <_sk_xor__hsw_8bit+0xd1> .byte 197,250,44,194 // vcvttss2si %xmm2,%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 196,226,125,120,210 // vpbroadcastb %xmm2,%ymm2 .byte 196,226,125,48,216 // vpmovzxbw %xmm0,%ymm3 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 197,237,219,21,21,11,0,0 // vpand 0xb15(%rip),%ymm2,%ymm2 # 1440 <_sk_xor__hsw_8bit+0x209> .byte 197,237,213,224 // vpmullw %ymm0,%ymm2,%ymm4 .byte 197,237,213,211 // vpmullw %ymm3,%ymm2,%ymm2 .byte 197,237,253,211 // vpaddw %ymm3,%ymm2,%ymm2 .byte 197,221,253,192 // vpaddw %ymm0,%ymm4,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 196,227,109,56,216,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm3 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,229,103,192 // vpackuswb %ymm0,%ymm3,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_u8_hsw_8bit .globl _sk_scale_u8_hsw_8bit FUNCTION(_sk_scale_u8_hsw_8bit) _sk_scale_u8_hsw_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,106 // jne 9e0 <_sk_scale_u8_hsw_8bit+0x87> .byte 196,162,121,48,20,2 // vpmovzxbw (%rdx,%r8,1),%xmm2 .byte 197,233,219,21,236,12,0,0 // vpand 0xcec(%rip),%xmm2,%xmm2 # 1670 <_sk_xor__hsw_8bit+0x439> .byte 196,226,125,51,210 // vpmovzxwd %xmm2,%ymm2 .byte 196,226,109,0,21,206,10,0,0 // vpshufb 0xace(%rip),%ymm2,%ymm2 # 1460 <_sk_xor__hsw_8bit+0x229> .byte 196,226,125,48,216 // vpmovzxbw %xmm0,%ymm3 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 196,226,125,48,226 // vpmovzxbw %xmm2,%ymm4 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 197,237,213,208 // vpmullw %ymm0,%ymm2,%ymm2 .byte 197,221,213,227 // vpmullw %ymm3,%ymm4,%ymm4 .byte 197,221,253,219 // vpaddw %ymm3,%ymm4,%ymm3 .byte 197,237,253,192 // vpaddw %ymm0,%ymm2,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,211,8 // vpsrlw $0x8,%ymm3,%ymm2 .byte 196,227,109,56,216,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm3 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,229,103,192 // vpackuswb %ymm0,%ymm3,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,7 // and $0x7,%r9b .byte 197,233,239,210 // vpxor %xmm2,%xmm2,%xmm2 .byte 65,254,201 // dec %r9b .byte 65,128,249,6 // cmp $0x6,%r9b .byte 119,139 // ja 97c <_sk_scale_u8_hsw_8bit+0x23> .byte 65,15,182,193 // movzbl %r9b,%eax .byte 72,141,13,124,0,0,0 // lea 0x7c(%rip),%rcx # a78 <_sk_scale_u8_hsw_8bit+0x11f> .byte 72,99,4,129 // movslq (%rcx,%rax,4),%rax .byte 72,1,200 // add %rcx,%rax .byte 255,224 // jmpq *%rax .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 233,105,255,255,255 // jmpq 97c <_sk_scale_u8_hsw_8bit+0x23> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 197,233,239,210 // vpxor %xmm2,%xmm2,%xmm2 .byte 197,233,196,208,2 // vpinsrw $0x2,%eax,%xmm2,%xmm2 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 197,249,110,216 // vmovd %eax,%xmm3 .byte 196,226,121,48,219 // vpmovzxbw %xmm3,%xmm3 .byte 196,227,105,2,211,1 // vpblendd $0x1,%xmm3,%xmm2,%xmm2 .byte 233,65,255,255,255 // jmpq 97c <_sk_scale_u8_hsw_8bit+0x23> .byte 66,15,182,68,2,6 // movzbl 0x6(%rdx,%r8,1),%eax .byte 197,233,239,210 // vpxor %xmm2,%xmm2,%xmm2 .byte 197,233,196,208,6 // vpinsrw $0x6,%eax,%xmm2,%xmm2 .byte 66,15,182,68,2,5 // movzbl 0x5(%rdx,%r8,1),%eax .byte 197,233,196,208,5 // vpinsrw $0x5,%eax,%xmm2,%xmm2 .byte 66,15,182,68,2,4 // movzbl 0x4(%rdx,%r8,1),%eax .byte 197,233,196,208,4 // vpinsrw $0x4,%eax,%xmm2,%xmm2 .byte 196,161,121,110,28,2 // vmovd (%rdx,%r8,1),%xmm3 .byte 196,226,121,48,219 // vpmovzxbw %xmm3,%xmm3 .byte 196,227,97,2,210,12 // vpblendd $0xc,%xmm2,%xmm3,%xmm2 .byte 233,6,255,255,255 // jmpq 97c <_sk_scale_u8_hsw_8bit+0x23> .byte 102,144 // xchg %ax,%ax .byte 141 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,170,255,255,255,155 // ljmp *-0x64000001(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 232,255,255,255,221 // callq ffffffffde000a88 <_sk_xor__hsw_8bit+0xffffffffddfff851> .byte 255 // (bad) .byte 255 // (bad) .byte 255,210 // callq *%rdx .byte 255 // (bad) .byte 255 // (bad) .byte 255,195 // inc %ebx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_lerp_1_float_hsw_8bit .globl _sk_lerp_1_float_hsw_8bit FUNCTION(_sk_lerp_1_float_hsw_8bit) _sk_lerp_1_float_hsw_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,250,16,16 // vmovss (%rax),%xmm2 .byte 197,234,89,21,106,8,0,0 // vmulss 0x86a(%rip),%xmm2,%xmm2 # 130c <_sk_xor__hsw_8bit+0xd5> .byte 197,250,44,194 // vcvttss2si %xmm2,%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 196,226,125,120,210 // vpbroadcastb %xmm2,%ymm2 .byte 196,226,125,48,216 // vpmovzxbw %xmm0,%ymm3 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 197,237,219,37,185,9,0,0 // vpand 0x9b9(%rip),%ymm2,%ymm4 # 1480 <_sk_xor__hsw_8bit+0x249> .byte 197,221,213,232 // vpmullw %ymm0,%ymm4,%ymm5 .byte 197,221,213,227 // vpmullw %ymm3,%ymm4,%ymm4 .byte 197,221,253,219 // vpaddw %ymm3,%ymm4,%ymm3 .byte 197,213,253,192 // vpaddw %ymm0,%ymm5,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 196,227,101,56,224,1 // vinserti128 $0x1,%xmm0,%ymm3,%ymm4 .byte 196,227,101,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm3,%ymm0 .byte 197,221,103,192 // vpackuswb %ymm0,%ymm4,%ymm0 .byte 197,229,118,219 // vpcmpeqd %ymm3,%ymm3,%ymm3 .byte 197,237,239,211 // vpxor %ymm3,%ymm2,%ymm2 .byte 196,226,125,48,217 // vpmovzxbw %xmm1,%ymm3 .byte 196,227,125,57,204,1 // vextracti128 $0x1,%ymm1,%xmm4 .byte 196,226,125,48,228 // vpmovzxbw %xmm4,%ymm4 .byte 196,226,125,48,234 // vpmovzxbw %xmm2,%ymm5 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 197,237,213,212 // vpmullw %ymm4,%ymm2,%ymm2 .byte 197,213,213,235 // vpmullw %ymm3,%ymm5,%ymm5 .byte 197,213,253,219 // vpaddw %ymm3,%ymm5,%ymm3 .byte 197,237,253,212 // vpaddw %ymm4,%ymm2,%ymm2 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 196,227,101,56,226,1 // vinserti128 $0x1,%xmm2,%ymm3,%ymm4 .byte 196,227,101,70,210,49 // vperm2i128 $0x31,%ymm2,%ymm3,%ymm2 .byte 197,221,103,210 // vpackuswb %ymm2,%ymm4,%ymm2 .byte 197,237,252,192 // vpaddb %ymm0,%ymm2,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_lerp_u8_hsw_8bit .globl _sk_lerp_u8_hsw_8bit FUNCTION(_sk_lerp_u8_hsw_8bit) _sk_lerp_u8_hsw_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 15,133,192,0,0,0 // jne c2c <_sk_lerp_u8_hsw_8bit+0xe1> .byte 196,162,121,48,20,2 // vpmovzxbw (%rdx,%r8,1),%xmm2 .byte 197,233,219,21,6,11,0,0 // vpand 0xb06(%rip),%xmm2,%xmm2 # 1680 <_sk_xor__hsw_8bit+0x449> .byte 196,226,125,51,210 // vpmovzxwd %xmm2,%ymm2 .byte 196,226,109,0,21,24,9,0,0 // vpshufb 0x918(%rip),%ymm2,%ymm2 # 14a0 <_sk_xor__hsw_8bit+0x269> .byte 196,226,125,48,216 // vpmovzxbw %xmm0,%ymm3 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 196,226,125,48,226 // vpmovzxbw %xmm2,%ymm4 .byte 196,227,125,57,213,1 // vextracti128 $0x1,%ymm2,%xmm5 .byte 196,226,125,48,237 // vpmovzxbw %xmm5,%ymm5 .byte 197,213,213,232 // vpmullw %ymm0,%ymm5,%ymm5 .byte 197,221,213,227 // vpmullw %ymm3,%ymm4,%ymm4 .byte 197,221,253,219 // vpaddw %ymm3,%ymm4,%ymm3 .byte 197,213,253,192 // vpaddw %ymm0,%ymm5,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 196,227,101,56,224,1 // vinserti128 $0x1,%xmm0,%ymm3,%ymm4 .byte 196,227,101,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm3,%ymm0 .byte 197,221,103,192 // vpackuswb %ymm0,%ymm4,%ymm0 .byte 197,229,118,219 // vpcmpeqd %ymm3,%ymm3,%ymm3 .byte 197,237,239,211 // vpxor %ymm3,%ymm2,%ymm2 .byte 196,226,125,48,217 // vpmovzxbw %xmm1,%ymm3 .byte 196,227,125,57,204,1 // vextracti128 $0x1,%ymm1,%xmm4 .byte 196,226,125,48,228 // vpmovzxbw %xmm4,%ymm4 .byte 196,226,125,48,234 // vpmovzxbw %xmm2,%ymm5 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 197,237,213,212 // vpmullw %ymm4,%ymm2,%ymm2 .byte 197,213,213,235 // vpmullw %ymm3,%ymm5,%ymm5 .byte 197,213,253,219 // vpaddw %ymm3,%ymm5,%ymm3 .byte 197,237,253,212 // vpaddw %ymm4,%ymm2,%ymm2 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 196,227,101,56,226,1 // vinserti128 $0x1,%xmm2,%ymm3,%ymm4 .byte 196,227,101,70,210,49 // vperm2i128 $0x31,%ymm2,%ymm3,%ymm2 .byte 197,221,103,210 // vpackuswb %ymm2,%ymm4,%ymm2 .byte 197,237,252,192 // vpaddb %ymm0,%ymm2,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,7 // and $0x7,%r9b .byte 197,233,239,210 // vpxor %xmm2,%xmm2,%xmm2 .byte 65,254,201 // dec %r9b .byte 65,128,249,6 // cmp $0x6,%r9b .byte 15,135,49,255,255,255 // ja b72 <_sk_lerp_u8_hsw_8bit+0x27> .byte 65,15,182,193 // movzbl %r9b,%eax .byte 72,141,13,124,0,0,0 // lea 0x7c(%rip),%rcx # cc8 <_sk_lerp_u8_hsw_8bit+0x17d> .byte 72,99,4,129 // movslq (%rcx,%rax,4),%rax .byte 72,1,200 // add %rcx,%rax .byte 255,224 // jmpq *%rax .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 197,249,110,208 // vmovd %eax,%xmm2 .byte 233,15,255,255,255 // jmpq b72 <_sk_lerp_u8_hsw_8bit+0x27> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 197,233,239,210 // vpxor %xmm2,%xmm2,%xmm2 .byte 197,233,196,208,2 // vpinsrw $0x2,%eax,%xmm2,%xmm2 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 197,249,110,216 // vmovd %eax,%xmm3 .byte 196,226,121,48,219 // vpmovzxbw %xmm3,%xmm3 .byte 196,227,105,2,211,1 // vpblendd $0x1,%xmm3,%xmm2,%xmm2 .byte 233,231,254,255,255 // jmpq b72 <_sk_lerp_u8_hsw_8bit+0x27> .byte 66,15,182,68,2,6 // movzbl 0x6(%rdx,%r8,1),%eax .byte 197,233,239,210 // vpxor %xmm2,%xmm2,%xmm2 .byte 197,233,196,208,6 // vpinsrw $0x6,%eax,%xmm2,%xmm2 .byte 66,15,182,68,2,5 // movzbl 0x5(%rdx,%r8,1),%eax .byte 197,233,196,208,5 // vpinsrw $0x5,%eax,%xmm2,%xmm2 .byte 66,15,182,68,2,4 // movzbl 0x4(%rdx,%r8,1),%eax .byte 197,233,196,208,4 // vpinsrw $0x4,%eax,%xmm2,%xmm2 .byte 196,161,121,110,28,2 // vmovd (%rdx,%r8,1),%xmm3 .byte 196,226,121,48,219 // vpmovzxbw %xmm3,%xmm3 .byte 196,227,97,2,210,12 // vpblendd $0xc,%xmm2,%xmm3,%xmm2 .byte 233,172,254,255,255 // jmpq b72 <_sk_lerp_u8_hsw_8bit+0x27> .byte 102,144 // xchg %ax,%ax .byte 141 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,170,255,255,255,155 // ljmp *-0x64000001(%rdx) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 232,255,255,255,221 // callq ffffffffde000cd8 <_sk_xor__hsw_8bit+0xffffffffddfffaa1> .byte 255 // (bad) .byte 255 // (bad) .byte 255,210 // callq *%rdx .byte 255 // (bad) .byte 255 // (bad) .byte 255,195 // inc %ebx .byte 255 // (bad) .byte 255 // (bad) .byte 255 // .byte 0xff HIDDEN _sk_move_src_dst_hsw_8bit .globl _sk_move_src_dst_hsw_8bit FUNCTION(_sk_move_src_dst_hsw_8bit) _sk_move_src_dst_hsw_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,200 // vmovaps %ymm0,%ymm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_move_dst_src_hsw_8bit .globl _sk_move_dst_src_hsw_8bit FUNCTION(_sk_move_dst_src_hsw_8bit) _sk_move_dst_src_hsw_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,40,193 // vmovaps %ymm1,%ymm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_black_color_hsw_8bit .globl _sk_black_color_hsw_8bit FUNCTION(_sk_black_color_hsw_8bit) _sk_black_color_hsw_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 196,226,125,25,5,145,9,0,0 // vbroadcastsd 0x991(%rip),%ymm0 # 1690 <_sk_xor__hsw_8bit+0x459> .byte 255,224 // jmpq *%rax HIDDEN _sk_white_color_hsw_8bit .globl _sk_white_color_hsw_8bit FUNCTION(_sk_white_color_hsw_8bit) _sk_white_color_hsw_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,253,118,192 // vpcmpeqd %ymm0,%ymm0,%ymm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_clear_hsw_8bit .globl _sk_clear_hsw_8bit FUNCTION(_sk_clear_hsw_8bit) _sk_clear_hsw_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcatop_hsw_8bit .globl _sk_srcatop_hsw_8bit FUNCTION(_sk_srcatop_hsw_8bit) _sk_srcatop_hsw_8bit: .byte 197,253,111,21,167,7,0,0 // vmovdqa 0x7a7(%rip),%ymm2 # 14c0 <_sk_xor__hsw_8bit+0x289> .byte 196,226,117,0,218 // vpshufb %ymm2,%ymm1,%ymm3 .byte 196,226,125,48,224 // vpmovzxbw %xmm0,%ymm4 .byte 196,227,125,57,197,1 // vextracti128 $0x1,%ymm0,%xmm5 .byte 196,226,125,48,237 // vpmovzxbw %xmm5,%ymm5 .byte 196,226,125,48,243 // vpmovzxbw %xmm3,%ymm6 .byte 196,227,125,57,219,1 // vextracti128 $0x1,%ymm3,%xmm3 .byte 196,226,125,48,219 // vpmovzxbw %xmm3,%ymm3 .byte 197,229,213,221 // vpmullw %ymm5,%ymm3,%ymm3 .byte 197,205,213,244 // vpmullw %ymm4,%ymm6,%ymm6 .byte 197,205,253,228 // vpaddw %ymm4,%ymm6,%ymm4 .byte 197,229,253,221 // vpaddw %ymm5,%ymm3,%ymm3 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 197,221,113,212,8 // vpsrlw $0x8,%ymm4,%ymm4 .byte 196,227,93,56,235,1 // vinserti128 $0x1,%xmm3,%ymm4,%ymm5 .byte 196,227,93,70,219,49 // vperm2i128 $0x31,%ymm3,%ymm4,%ymm3 .byte 197,213,103,219 // vpackuswb %ymm3,%ymm5,%ymm3 .byte 196,226,125,0,194 // vpshufb %ymm2,%ymm0,%ymm0 .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 197,253,239,194 // vpxor %ymm2,%ymm0,%ymm0 .byte 196,226,125,48,209 // vpmovzxbw %xmm1,%ymm2 .byte 196,227,125,57,204,1 // vextracti128 $0x1,%ymm1,%xmm4 .byte 196,226,125,48,228 // vpmovzxbw %xmm4,%ymm4 .byte 196,226,125,48,232 // vpmovzxbw %xmm0,%ymm5 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 197,253,213,196 // vpmullw %ymm4,%ymm0,%ymm0 .byte 197,213,213,234 // vpmullw %ymm2,%ymm5,%ymm5 .byte 197,213,253,210 // vpaddw %ymm2,%ymm5,%ymm2 .byte 197,253,253,196 // vpaddw %ymm4,%ymm0,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 196,227,109,56,224,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm4 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,221,103,192 // vpackuswb %ymm0,%ymm4,%ymm0 .byte 197,253,252,195 // vpaddb %ymm3,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstatop_hsw_8bit .globl _sk_dstatop_hsw_8bit FUNCTION(_sk_dstatop_hsw_8bit) _sk_dstatop_hsw_8bit: .byte 197,253,111,21,17,7,0,0 // vmovdqa 0x711(%rip),%ymm2 # 14e0 <_sk_xor__hsw_8bit+0x2a9> .byte 196,226,125,0,218 // vpshufb %ymm2,%ymm0,%ymm3 .byte 196,226,125,48,225 // vpmovzxbw %xmm1,%ymm4 .byte 196,227,125,57,205,1 // vextracti128 $0x1,%ymm1,%xmm5 .byte 196,226,125,48,237 // vpmovzxbw %xmm5,%ymm5 .byte 196,226,125,48,243 // vpmovzxbw %xmm3,%ymm6 .byte 196,227,125,57,219,1 // vextracti128 $0x1,%ymm3,%xmm3 .byte 196,226,125,48,219 // vpmovzxbw %xmm3,%ymm3 .byte 197,229,213,221 // vpmullw %ymm5,%ymm3,%ymm3 .byte 197,205,213,244 // vpmullw %ymm4,%ymm6,%ymm6 .byte 197,205,253,228 // vpaddw %ymm4,%ymm6,%ymm4 .byte 197,229,253,221 // vpaddw %ymm5,%ymm3,%ymm3 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 197,221,113,212,8 // vpsrlw $0x8,%ymm4,%ymm4 .byte 196,227,93,56,235,1 // vinserti128 $0x1,%xmm3,%ymm4,%ymm5 .byte 196,227,93,70,219,49 // vperm2i128 $0x31,%ymm3,%ymm4,%ymm3 .byte 197,213,103,219 // vpackuswb %ymm3,%ymm5,%ymm3 .byte 196,226,117,0,210 // vpshufb %ymm2,%ymm1,%ymm2 .byte 197,221,118,228 // vpcmpeqd %ymm4,%ymm4,%ymm4 .byte 197,237,239,212 // vpxor %ymm4,%ymm2,%ymm2 .byte 196,226,125,48,224 // vpmovzxbw %xmm0,%ymm4 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 196,226,125,48,234 // vpmovzxbw %xmm2,%ymm5 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 197,237,213,208 // vpmullw %ymm0,%ymm2,%ymm2 .byte 197,213,213,236 // vpmullw %ymm4,%ymm5,%ymm5 .byte 197,213,253,228 // vpaddw %ymm4,%ymm5,%ymm4 .byte 197,237,253,192 // vpaddw %ymm0,%ymm2,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,212,8 // vpsrlw $0x8,%ymm4,%ymm2 .byte 196,227,109,56,224,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm4 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,221,103,192 // vpackuswb %ymm0,%ymm4,%ymm0 .byte 197,253,252,195 // vpaddb %ymm3,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcin_hsw_8bit .globl _sk_srcin_hsw_8bit FUNCTION(_sk_srcin_hsw_8bit) _sk_srcin_hsw_8bit: .byte 196,226,117,0,21,122,6,0,0 // vpshufb 0x67a(%rip),%ymm1,%ymm2 # 1500 <_sk_xor__hsw_8bit+0x2c9> .byte 196,226,125,48,216 // vpmovzxbw %xmm0,%ymm3 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 196,226,125,48,226 // vpmovzxbw %xmm2,%ymm4 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 197,237,213,208 // vpmullw %ymm0,%ymm2,%ymm2 .byte 197,221,213,227 // vpmullw %ymm3,%ymm4,%ymm4 .byte 197,221,253,219 // vpaddw %ymm3,%ymm4,%ymm3 .byte 197,237,253,192 // vpaddw %ymm0,%ymm2,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,211,8 // vpsrlw $0x8,%ymm3,%ymm2 .byte 196,227,109,56,216,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm3 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,229,103,192 // vpackuswb %ymm0,%ymm3,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstin_hsw_8bit .globl _sk_dstin_hsw_8bit FUNCTION(_sk_dstin_hsw_8bit) _sk_dstin_hsw_8bit: .byte 196,226,125,0,5,67,6,0,0 // vpshufb 0x643(%rip),%ymm0,%ymm0 # 1520 <_sk_xor__hsw_8bit+0x2e9> .byte 196,226,125,48,209 // vpmovzxbw %xmm1,%ymm2 .byte 196,227,125,57,203,1 // vextracti128 $0x1,%ymm1,%xmm3 .byte 196,226,125,48,219 // vpmovzxbw %xmm3,%ymm3 .byte 196,226,125,48,224 // vpmovzxbw %xmm0,%ymm4 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 197,253,213,195 // vpmullw %ymm3,%ymm0,%ymm0 .byte 197,221,213,226 // vpmullw %ymm2,%ymm4,%ymm4 .byte 197,221,253,210 // vpaddw %ymm2,%ymm4,%ymm2 .byte 197,253,253,195 // vpaddw %ymm3,%ymm0,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 196,227,109,56,216,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm3 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,229,103,192 // vpackuswb %ymm0,%ymm3,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcout_hsw_8bit .globl _sk_srcout_hsw_8bit FUNCTION(_sk_srcout_hsw_8bit) _sk_srcout_hsw_8bit: .byte 196,226,117,0,21,12,6,0,0 // vpshufb 0x60c(%rip),%ymm1,%ymm2 # 1540 <_sk_xor__hsw_8bit+0x309> .byte 197,229,118,219 // vpcmpeqd %ymm3,%ymm3,%ymm3 .byte 197,237,239,211 // vpxor %ymm3,%ymm2,%ymm2 .byte 196,226,125,48,216 // vpmovzxbw %xmm0,%ymm3 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 196,226,125,48,226 // vpmovzxbw %xmm2,%ymm4 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 197,237,213,208 // vpmullw %ymm0,%ymm2,%ymm2 .byte 197,221,213,227 // vpmullw %ymm3,%ymm4,%ymm4 .byte 197,221,253,219 // vpaddw %ymm3,%ymm4,%ymm3 .byte 197,237,253,192 // vpaddw %ymm0,%ymm2,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,211,8 // vpsrlw $0x8,%ymm3,%ymm2 .byte 196,227,109,56,216,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm3 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,229,103,192 // vpackuswb %ymm0,%ymm3,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstout_hsw_8bit .globl _sk_dstout_hsw_8bit FUNCTION(_sk_dstout_hsw_8bit) _sk_dstout_hsw_8bit: .byte 196,226,125,0,5,205,5,0,0 // vpshufb 0x5cd(%rip),%ymm0,%ymm0 # 1560 <_sk_xor__hsw_8bit+0x329> .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 197,253,239,194 // vpxor %ymm2,%ymm0,%ymm0 .byte 196,226,125,48,209 // vpmovzxbw %xmm1,%ymm2 .byte 196,227,125,57,203,1 // vextracti128 $0x1,%ymm1,%xmm3 .byte 196,226,125,48,219 // vpmovzxbw %xmm3,%ymm3 .byte 196,226,125,48,224 // vpmovzxbw %xmm0,%ymm4 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 197,253,213,195 // vpmullw %ymm3,%ymm0,%ymm0 .byte 197,221,213,226 // vpmullw %ymm2,%ymm4,%ymm4 .byte 197,221,253,210 // vpaddw %ymm2,%ymm4,%ymm2 .byte 197,253,253,195 // vpaddw %ymm3,%ymm0,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 196,227,109,56,216,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm3 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,229,103,192 // vpackuswb %ymm0,%ymm3,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_hsw_8bit .globl _sk_srcover_hsw_8bit FUNCTION(_sk_srcover_hsw_8bit) _sk_srcover_hsw_8bit: .byte 196,226,125,0,21,142,5,0,0 // vpshufb 0x58e(%rip),%ymm0,%ymm2 # 1580 <_sk_xor__hsw_8bit+0x349> .byte 196,226,125,48,217 // vpmovzxbw %xmm1,%ymm3 .byte 196,227,125,57,204,1 // vextracti128 $0x1,%ymm1,%xmm4 .byte 196,226,125,48,228 // vpmovzxbw %xmm4,%ymm4 .byte 196,226,125,48,234 // vpmovzxbw %xmm2,%ymm5 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 197,237,213,212 // vpmullw %ymm4,%ymm2,%ymm2 .byte 197,213,213,235 // vpmullw %ymm3,%ymm5,%ymm5 .byte 197,213,253,219 // vpaddw %ymm3,%ymm5,%ymm3 .byte 197,237,253,212 // vpaddw %ymm4,%ymm2,%ymm2 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 196,227,101,56,226,1 // vinserti128 $0x1,%xmm2,%ymm3,%ymm4 .byte 196,227,101,70,210,49 // vperm2i128 $0x31,%ymm2,%ymm3,%ymm2 .byte 197,221,103,210 // vpackuswb %ymm2,%ymm4,%ymm2 .byte 197,245,252,192 // vpaddb %ymm0,%ymm1,%ymm0 .byte 197,253,248,194 // vpsubb %ymm2,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstover_hsw_8bit .globl _sk_dstover_hsw_8bit FUNCTION(_sk_dstover_hsw_8bit) _sk_dstover_hsw_8bit: .byte 196,226,117,0,21,79,5,0,0 // vpshufb 0x54f(%rip),%ymm1,%ymm2 # 15a0 <_sk_xor__hsw_8bit+0x369> .byte 196,226,125,48,216 // vpmovzxbw %xmm0,%ymm3 .byte 196,227,125,57,196,1 // vextracti128 $0x1,%ymm0,%xmm4 .byte 196,226,125,48,228 // vpmovzxbw %xmm4,%ymm4 .byte 196,226,125,48,234 // vpmovzxbw %xmm2,%ymm5 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 197,237,213,212 // vpmullw %ymm4,%ymm2,%ymm2 .byte 197,213,213,235 // vpmullw %ymm3,%ymm5,%ymm5 .byte 197,213,253,219 // vpaddw %ymm3,%ymm5,%ymm3 .byte 197,237,253,212 // vpaddw %ymm4,%ymm2,%ymm2 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 196,227,101,56,226,1 // vinserti128 $0x1,%xmm2,%ymm3,%ymm4 .byte 196,227,101,70,210,49 // vperm2i128 $0x31,%ymm2,%ymm3,%ymm2 .byte 197,221,103,210 // vpackuswb %ymm2,%ymm4,%ymm2 .byte 197,245,252,192 // vpaddb %ymm0,%ymm1,%ymm0 .byte 197,253,248,194 // vpsubb %ymm2,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_modulate_hsw_8bit .globl _sk_modulate_hsw_8bit FUNCTION(_sk_modulate_hsw_8bit) _sk_modulate_hsw_8bit: .byte 196,226,125,48,208 // vpmovzxbw %xmm0,%ymm2 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 196,226,125,48,217 // vpmovzxbw %xmm1,%ymm3 .byte 196,227,125,57,204,1 // vextracti128 $0x1,%ymm1,%xmm4 .byte 196,226,125,48,228 // vpmovzxbw %xmm4,%ymm4 .byte 197,221,213,224 // vpmullw %ymm0,%ymm4,%ymm4 .byte 197,229,213,218 // vpmullw %ymm2,%ymm3,%ymm3 .byte 197,229,253,210 // vpaddw %ymm2,%ymm3,%ymm2 .byte 197,221,253,192 // vpaddw %ymm0,%ymm4,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 196,227,109,56,216,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm3 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,229,103,192 // vpackuswb %ymm0,%ymm3,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_multiply_hsw_8bit .globl _sk_multiply_hsw_8bit FUNCTION(_sk_multiply_hsw_8bit) _sk_multiply_hsw_8bit: .byte 197,253,111,37,195,4,0,0 // vmovdqa 0x4c3(%rip),%ymm4 # 15c0 <_sk_xor__hsw_8bit+0x389> .byte 196,226,117,0,212 // vpshufb %ymm4,%ymm1,%ymm2 .byte 197,213,118,237 // vpcmpeqd %ymm5,%ymm5,%ymm5 .byte 197,237,239,245 // vpxor %ymm5,%ymm2,%ymm6 .byte 196,226,125,48,208 // vpmovzxbw %xmm0,%ymm2 .byte 196,227,125,57,195,1 // vextracti128 $0x1,%ymm0,%xmm3 .byte 196,226,125,48,219 // vpmovzxbw %xmm3,%ymm3 .byte 196,226,125,48,254 // vpmovzxbw %xmm6,%ymm7 .byte 196,227,125,57,246,1 // vextracti128 $0x1,%ymm6,%xmm6 .byte 196,226,125,48,246 // vpmovzxbw %xmm6,%ymm6 .byte 197,205,213,243 // vpmullw %ymm3,%ymm6,%ymm6 .byte 197,197,213,250 // vpmullw %ymm2,%ymm7,%ymm7 .byte 197,197,253,250 // vpaddw %ymm2,%ymm7,%ymm7 .byte 197,205,253,243 // vpaddw %ymm3,%ymm6,%ymm6 .byte 197,205,113,214,8 // vpsrlw $0x8,%ymm6,%ymm6 .byte 197,197,113,215,8 // vpsrlw $0x8,%ymm7,%ymm7 .byte 196,99,69,56,198,1 // vinserti128 $0x1,%xmm6,%ymm7,%ymm8 .byte 196,227,69,70,246,49 // vperm2i128 $0x31,%ymm6,%ymm7,%ymm6 .byte 197,189,103,246 // vpackuswb %ymm6,%ymm8,%ymm6 .byte 196,226,125,0,196 // vpshufb %ymm4,%ymm0,%ymm0 .byte 197,253,239,197 // vpxor %ymm5,%ymm0,%ymm0 .byte 196,226,125,48,225 // vpmovzxbw %xmm1,%ymm4 .byte 196,227,125,57,205,1 // vextracti128 $0x1,%ymm1,%xmm5 .byte 196,226,125,48,237 // vpmovzxbw %xmm5,%ymm5 .byte 196,226,125,48,248 // vpmovzxbw %xmm0,%ymm7 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 197,253,213,197 // vpmullw %ymm5,%ymm0,%ymm0 .byte 197,197,213,252 // vpmullw %ymm4,%ymm7,%ymm7 .byte 197,197,253,252 // vpaddw %ymm4,%ymm7,%ymm7 .byte 197,253,253,197 // vpaddw %ymm5,%ymm0,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,197,113,215,8 // vpsrlw $0x8,%ymm7,%ymm7 .byte 196,99,69,56,192,1 // vinserti128 $0x1,%xmm0,%ymm7,%ymm8 .byte 196,227,69,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm7,%ymm0 .byte 197,189,103,192 // vpackuswb %ymm0,%ymm8,%ymm0 .byte 197,253,252,198 // vpaddb %ymm6,%ymm0,%ymm0 .byte 197,213,213,235 // vpmullw %ymm3,%ymm5,%ymm5 .byte 197,221,213,226 // vpmullw %ymm2,%ymm4,%ymm4 .byte 197,221,253,210 // vpaddw %ymm2,%ymm4,%ymm2 .byte 197,213,253,219 // vpaddw %ymm3,%ymm5,%ymm3 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 196,227,109,56,227,1 // vinserti128 $0x1,%xmm3,%ymm2,%ymm4 .byte 196,227,109,70,211,49 // vperm2i128 $0x31,%ymm3,%ymm2,%ymm2 .byte 197,221,103,210 // vpackuswb %ymm2,%ymm4,%ymm2 .byte 197,253,252,194 // vpaddb %ymm2,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_screen_hsw_8bit .globl _sk_screen_hsw_8bit FUNCTION(_sk_screen_hsw_8bit) _sk_screen_hsw_8bit: .byte 197,237,118,210 // vpcmpeqd %ymm2,%ymm2,%ymm2 .byte 197,253,239,210 // vpxor %ymm2,%ymm0,%ymm2 .byte 196,226,125,48,218 // vpmovzxbw %xmm2,%ymm3 .byte 196,227,125,57,210,1 // vextracti128 $0x1,%ymm2,%xmm2 .byte 196,226,125,48,210 // vpmovzxbw %xmm2,%ymm2 .byte 196,226,125,48,225 // vpmovzxbw %xmm1,%ymm4 .byte 196,227,125,57,205,1 // vextracti128 $0x1,%ymm1,%xmm5 .byte 196,226,125,48,237 // vpmovzxbw %xmm5,%ymm5 .byte 197,213,213,234 // vpmullw %ymm2,%ymm5,%ymm5 .byte 197,221,213,227 // vpmullw %ymm3,%ymm4,%ymm4 .byte 197,221,253,219 // vpaddw %ymm3,%ymm4,%ymm3 .byte 197,213,253,210 // vpaddw %ymm2,%ymm5,%ymm2 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 196,227,101,56,226,1 // vinserti128 $0x1,%xmm2,%ymm3,%ymm4 .byte 196,227,101,70,210,49 // vperm2i128 $0x31,%ymm2,%ymm3,%ymm2 .byte 197,221,103,210 // vpackuswb %ymm2,%ymm4,%ymm2 .byte 197,237,252,192 // vpaddb %ymm0,%ymm2,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xor__hsw_8bit .globl _sk_xor__hsw_8bit FUNCTION(_sk_xor__hsw_8bit) _sk_xor__hsw_8bit: .byte 197,253,111,21,161,3,0,0 // vmovdqa 0x3a1(%rip),%ymm2 # 15e0 <_sk_xor__hsw_8bit+0x3a9> .byte 196,226,117,0,218 // vpshufb %ymm2,%ymm1,%ymm3 .byte 197,221,118,228 // vpcmpeqd %ymm4,%ymm4,%ymm4 .byte 197,229,239,220 // vpxor %ymm4,%ymm3,%ymm3 .byte 196,226,125,48,232 // vpmovzxbw %xmm0,%ymm5 .byte 196,227,125,57,198,1 // vextracti128 $0x1,%ymm0,%xmm6 .byte 196,226,125,48,246 // vpmovzxbw %xmm6,%ymm6 .byte 196,226,125,48,251 // vpmovzxbw %xmm3,%ymm7 .byte 196,227,125,57,219,1 // vextracti128 $0x1,%ymm3,%xmm3 .byte 196,226,125,48,219 // vpmovzxbw %xmm3,%ymm3 .byte 197,229,213,222 // vpmullw %ymm6,%ymm3,%ymm3 .byte 197,197,213,253 // vpmullw %ymm5,%ymm7,%ymm7 .byte 197,197,253,237 // vpaddw %ymm5,%ymm7,%ymm5 .byte 197,229,253,222 // vpaddw %ymm6,%ymm3,%ymm3 .byte 197,229,113,211,8 // vpsrlw $0x8,%ymm3,%ymm3 .byte 197,213,113,213,8 // vpsrlw $0x8,%ymm5,%ymm5 .byte 196,227,85,56,243,1 // vinserti128 $0x1,%xmm3,%ymm5,%ymm6 .byte 196,227,85,70,219,49 // vperm2i128 $0x31,%ymm3,%ymm5,%ymm3 .byte 197,205,103,219 // vpackuswb %ymm3,%ymm6,%ymm3 .byte 196,226,125,0,194 // vpshufb %ymm2,%ymm0,%ymm0 .byte 197,253,239,196 // vpxor %ymm4,%ymm0,%ymm0 .byte 196,226,125,48,209 // vpmovzxbw %xmm1,%ymm2 .byte 196,227,125,57,204,1 // vextracti128 $0x1,%ymm1,%xmm4 .byte 196,226,125,48,228 // vpmovzxbw %xmm4,%ymm4 .byte 196,226,125,48,232 // vpmovzxbw %xmm0,%ymm5 .byte 196,227,125,57,192,1 // vextracti128 $0x1,%ymm0,%xmm0 .byte 196,226,125,48,192 // vpmovzxbw %xmm0,%ymm0 .byte 197,253,213,196 // vpmullw %ymm4,%ymm0,%ymm0 .byte 197,213,213,234 // vpmullw %ymm2,%ymm5,%ymm5 .byte 197,213,253,210 // vpaddw %ymm2,%ymm5,%ymm2 .byte 197,253,253,196 // vpaddw %ymm4,%ymm0,%ymm0 .byte 197,253,113,208,8 // vpsrlw $0x8,%ymm0,%ymm0 .byte 197,237,113,210,8 // vpsrlw $0x8,%ymm2,%ymm2 .byte 196,227,109,56,224,1 // vinserti128 $0x1,%xmm0,%ymm2,%ymm4 .byte 196,227,109,70,192,49 // vperm2i128 $0x31,%ymm0,%ymm2,%ymm0 .byte 197,221,103,192 // vpackuswb %ymm0,%ymm4,%ymm0 .byte 197,253,252,195 // vpaddb %ymm3,%ymm0,%ymm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax BALIGN4 .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 133b <_sk_xor__hsw_8bit+0x104> .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 134f <_sk_xor__hsw_8bit+0x118> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 1353 <_sk_xor__hsw_8bit+0x11c> BALIGN32 .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 3,3 // add (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,0,0 // sldt (%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 2,1 // add (%rcx),%al .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,3,255 // or $0xff030f0c,%eax .byte 7 // (bad) .byte 255,11 // decl (%rbx) .byte 255,15 // decl (%rdi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,19 // callq *(%rbx) .byte 255,23 // callq *(%rdi) .byte 255,27 // lcall *(%rbx) .byte 255,31 // lcall *(%rdi) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255 // (bad) .byte 255,3 // incl (%rbx) .byte 3,3 // add (%rbx),%eax .byte 3,7 // add (%rdi),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,255 // (bad) .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,4,4 // add %al,(%rsp,%rax,1) .byte 4,4 // add $0x4,%al .byte 8,8 // or %cl,(%rax) .byte 8,8 // or %cl,(%rax) .byte 12,12 // or $0xc,%al .byte 12,12 // or $0xc,%al .byte 16,16 // adc %dl,(%rax) .byte 16,16 // adc %dl,(%rax) .byte 20,20 // adc $0x14,%al .byte 20,20 // adc $0x14,%al .byte 24,24 // sbb %bl,(%rax) .byte 24,24 // sbb %bl,(%rax) .byte 28,28 // sbb $0x1c,%al .byte 28,28 // sbb $0x1c,%al .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 4,4 // add $0x4,%al .byte 4,4 // add $0x4,%al .byte 8,8 // or %cl,(%rax) .byte 8,8 // or %cl,(%rax) .byte 12,12 // or $0xc,%al .byte 12,12 // or $0xc,%al .byte 16,16 // adc %dl,(%rax) .byte 16,16 // adc %dl,(%rax) .byte 20,20 // adc $0x14,%al .byte 20,20 // adc $0x14,%al .byte 24,24 // sbb %bl,(%rax) .byte 24,24 // sbb %bl,(%rax) .byte 28,28 // sbb $0x1c,%al .byte 28,28 // sbb $0x1c,%al .byte 3,3 // add (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // .byte 0xf .byte 15 // .byte 0xf .byte 15 // .byte 0xf BALIGN16 .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,2 // add %al,(%rdx) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,2 // add %al,(%rdx) .byte 4,6 // add $0x6,%al .byte 8,10 // or %cl,(%rdx) .byte 12,14 // or $0xe,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) BALIGN8 .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh BALIGN32 HIDDEN _sk_start_pipeline_sse41_8bit .globl _sk_start_pipeline_sse41_8bit FUNCTION(_sk_start_pipeline_sse41_8bit) _sk_start_pipeline_sse41_8bit: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,236,56 // sub $0x38,%rsp .byte 72,137,211 // mov %rdx,%rbx .byte 73,137,247 // mov %rsi,%r15 .byte 72,137,125,208 // mov %rdi,-0x30(%rbp) .byte 76,137,198 // mov %r8,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,137,197 // mov %rax,%r13 .byte 73,137,246 // mov %rsi,%r14 .byte 72,137,77,168 // mov %rcx,-0x58(%rbp) .byte 73,57,207 // cmp %rcx,%r15 .byte 115,102 // jae 95 <_sk_start_pipeline_sse41_8bit+0x95> .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,141,64,4 // lea 0x4(%rax),%rax .byte 72,137,69,176 // mov %rax,-0x50(%rbp) .byte 76,141,101,184 // lea -0x48(%rbp),%r12 .byte 72,57,93,176 // cmp %rbx,-0x50(%rbp) .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 76,137,125,192 // mov %r15,-0x40(%rbp) .byte 72,199,69,200,0,0,0,0 // movq $0x0,-0x38(%rbp) .byte 119,30 // ja 77 <_sk_start_pipeline_sse41_8bit+0x77> .byte 76,137,231 // mov %r12,%rdi .byte 76,137,246 // mov %r14,%rsi .byte 65,255,213 // callq *%r13 .byte 72,139,77,184 // mov -0x48(%rbp),%rcx .byte 72,141,65,4 // lea 0x4(%rcx),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 72,131,193,8 // add $0x8,%rcx .byte 72,57,217 // cmp %rbx,%rcx .byte 118,226 // jbe 59 <_sk_start_pipeline_sse41_8bit+0x59> .byte 72,137,217 // mov %rbx,%rcx .byte 72,41,193 // sub %rax,%rcx .byte 116,13 // je 8c <_sk_start_pipeline_sse41_8bit+0x8c> .byte 72,137,77,200 // mov %rcx,-0x38(%rbp) .byte 76,137,231 // mov %r12,%rdi .byte 76,137,246 // mov %r14,%rsi .byte 65,255,213 // callq *%r13 .byte 73,255,199 // inc %r15 .byte 76,59,125,168 // cmp -0x58(%rbp),%r15 .byte 117,170 // jne 3f <_sk_start_pipeline_sse41_8bit+0x3f> .byte 72,131,196,56 // add $0x38,%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 195 // retq HIDDEN _sk_just_return_sse41_8bit .globl _sk_just_return_sse41_8bit FUNCTION(_sk_just_return_sse41_8bit) _sk_just_return_sse41_8bit: .byte 195 // retq HIDDEN _sk_uniform_color_sse41_8bit .globl _sk_uniform_color_sse41_8bit FUNCTION(_sk_uniform_color_sse41_8bit) _sk_uniform_color_sse41_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,110,64,16 // movd 0x10(%rax),%xmm0 .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_set_rgb_sse41_8bit .globl _sk_set_rgb_sse41_8bit FUNCTION(_sk_set_rgb_sse41_8bit) _sk_set_rgb_sse41_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,21,77,14,0,0 // movss 0xe4d(%rip),%xmm2 # f0c <_sk_xor__sse41_8bit+0xa2> .byte 243,15,16,24 // movss (%rax),%xmm3 .byte 243,15,89,218 // mulss %xmm2,%xmm3 .byte 243,72,15,44,203 // cvttss2si %xmm3,%rcx .byte 243,15,16,88,4 // movss 0x4(%rax),%xmm3 .byte 243,15,89,218 // mulss %xmm2,%xmm3 .byte 243,72,15,44,211 // cvttss2si %xmm3,%rdx .byte 193,226,8 // shl $0x8,%edx .byte 9,202 // or %ecx,%edx .byte 243,15,89,80,8 // mulss 0x8(%rax),%xmm2 .byte 243,72,15,44,194 // cvttss2si %xmm2,%rax .byte 193,224,16 // shl $0x10,%eax .byte 9,208 // or %edx,%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,219,5,33,14,0,0 // pand 0xe21(%rip),%xmm0 # f20 <_sk_xor__sse41_8bit+0xb6> .byte 102,15,235,194 // por %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_sse41_8bit .globl _sk_premul_sse41_8bit FUNCTION(_sk_premul_sse41_8bit) _sk_premul_sse41_8bit: .byte 102,15,111,216 // movdqa %xmm0,%xmm3 .byte 102,15,56,0,29,28,14,0,0 // pshufb 0xe1c(%rip),%xmm3 # f30 <_sk_xor__sse41_8bit+0xc6> .byte 102,15,235,29,36,14,0,0 // por 0xe24(%rip),%xmm3 # f40 <_sk_xor__sse41_8bit+0xd6> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,56,48,232 // pmovzxbw %xmm0,%xmm5 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,56,48,211 // pmovzxbw %xmm3,%xmm2 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_swap_rb_sse41_8bit .globl _sk_swap_rb_sse41_8bit FUNCTION(_sk_swap_rb_sse41_8bit) _sk_swap_rb_sse41_8bit: .byte 102,15,56,0,5,239,13,0,0 // pshufb 0xdef(%rip),%xmm0 # f50 <_sk_xor__sse41_8bit+0xe6> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_invert_sse41_8bit .globl _sk_invert_sse41_8bit FUNCTION(_sk_invert_sse41_8bit) _sk_invert_sse41_8bit: .byte 102,15,118,210 // pcmpeqd %xmm2,%xmm2 .byte 102,15,239,194 // pxor %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_load_8888_sse41_8bit .globl _sk_load_8888_sse41_8bit FUNCTION(_sk_load_8888_sse41_8bit) _sk_load_8888_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,10 // jne 19c <_sk_load_8888_sse41_8bit+0x2b> .byte 243,66,15,111,4,130 // movdqu (%rdx,%r8,4),%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,42 // je 1d0 <_sk_load_8888_sse41_8bit+0x5f> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 1c2 <_sk_load_8888_sse41_8bit+0x51> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,226 // jne 198 <_sk_load_8888_sse41_8bit+0x27> .byte 102,66,15,110,68,130,8 // movd 0x8(%rdx,%r8,4),%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 243,66,15,126,20,130 // movq (%rdx,%r8,4),%xmm2 .byte 102,15,58,14,194,15 // pblendw $0xf,%xmm2,%xmm0 .byte 235,200 // jmp 198 <_sk_load_8888_sse41_8bit+0x27> .byte 102,66,15,110,4,130 // movd (%rdx,%r8,4),%xmm0 .byte 235,192 // jmp 198 <_sk_load_8888_sse41_8bit+0x27> HIDDEN _sk_load_8888_dst_sse41_8bit .globl _sk_load_8888_dst_sse41_8bit FUNCTION(_sk_load_8888_dst_sse41_8bit) _sk_load_8888_dst_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,10 // jne 203 <_sk_load_8888_dst_sse41_8bit+0x2b> .byte 243,66,15,111,12,130 // movdqu (%rdx,%r8,4),%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,42 // je 237 <_sk_load_8888_dst_sse41_8bit+0x5f> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 229 <_sk_load_8888_dst_sse41_8bit+0x51> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,226 // jne 1ff <_sk_load_8888_dst_sse41_8bit+0x27> .byte 102,66,15,110,76,130,8 // movd 0x8(%rdx,%r8,4),%xmm1 .byte 102,15,112,201,69 // pshufd $0x45,%xmm1,%xmm1 .byte 243,66,15,126,20,130 // movq (%rdx,%r8,4),%xmm2 .byte 102,15,58,14,202,15 // pblendw $0xf,%xmm2,%xmm1 .byte 235,200 // jmp 1ff <_sk_load_8888_dst_sse41_8bit+0x27> .byte 102,66,15,110,12,130 // movd (%rdx,%r8,4),%xmm1 .byte 235,192 // jmp 1ff <_sk_load_8888_dst_sse41_8bit+0x27> HIDDEN _sk_store_8888_sse41_8bit .globl _sk_store_8888_sse41_8bit FUNCTION(_sk_store_8888_sse41_8bit) _sk_store_8888_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,10 // jne 26a <_sk_store_8888_sse41_8bit+0x2b> .byte 243,66,15,127,4,130 // movdqu %xmm0,(%rdx,%r8,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,29 // je 291 <_sk_store_8888_sse41_8bit+0x52> .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,15 // je 289 <_sk_store_8888_sse41_8bit+0x4a> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,230 // jne 266 <_sk_store_8888_sse41_8bit+0x27> .byte 102,66,15,58,22,68,130,8,2 // pextrd $0x2,%xmm0,0x8(%rdx,%r8,4) .byte 102,66,15,214,4,130 // movq %xmm0,(%rdx,%r8,4) .byte 235,213 // jmp 266 <_sk_store_8888_sse41_8bit+0x27> .byte 102,66,15,126,4,130 // movd %xmm0,(%rdx,%r8,4) .byte 235,205 // jmp 266 <_sk_store_8888_sse41_8bit+0x27> HIDDEN _sk_load_bgra_sse41_8bit .globl _sk_load_bgra_sse41_8bit FUNCTION(_sk_load_bgra_sse41_8bit) _sk_load_bgra_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,19 // jne 2cd <_sk_load_bgra_sse41_8bit+0x34> .byte 243,66,15,111,4,130 // movdqu (%rdx,%r8,4),%xmm0 .byte 102,15,56,0,5,151,12,0,0 // pshufb 0xc97(%rip),%xmm0 # f60 <_sk_xor__sse41_8bit+0xf6> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,42 // je 301 <_sk_load_bgra_sse41_8bit+0x68> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 2f3 <_sk_load_bgra_sse41_8bit+0x5a> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,217 // jne 2c0 <_sk_load_bgra_sse41_8bit+0x27> .byte 102,66,15,110,68,130,8 // movd 0x8(%rdx,%r8,4),%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 243,66,15,126,20,130 // movq (%rdx,%r8,4),%xmm2 .byte 102,15,58,14,194,15 // pblendw $0xf,%xmm2,%xmm0 .byte 235,191 // jmp 2c0 <_sk_load_bgra_sse41_8bit+0x27> .byte 102,66,15,110,4,130 // movd (%rdx,%r8,4),%xmm0 .byte 235,183 // jmp 2c0 <_sk_load_bgra_sse41_8bit+0x27> HIDDEN _sk_load_bgra_dst_sse41_8bit .globl _sk_load_bgra_dst_sse41_8bit FUNCTION(_sk_load_bgra_dst_sse41_8bit) _sk_load_bgra_dst_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,19 // jne 33d <_sk_load_bgra_dst_sse41_8bit+0x34> .byte 243,66,15,111,12,130 // movdqu (%rdx,%r8,4),%xmm1 .byte 102,15,56,0,13,55,12,0,0 // pshufb 0xc37(%rip),%xmm1 # f70 <_sk_xor__sse41_8bit+0x106> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,42 // je 371 <_sk_load_bgra_dst_sse41_8bit+0x68> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 363 <_sk_load_bgra_dst_sse41_8bit+0x5a> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,217 // jne 330 <_sk_load_bgra_dst_sse41_8bit+0x27> .byte 102,66,15,110,76,130,8 // movd 0x8(%rdx,%r8,4),%xmm1 .byte 102,15,112,201,69 // pshufd $0x45,%xmm1,%xmm1 .byte 243,66,15,126,20,130 // movq (%rdx,%r8,4),%xmm2 .byte 102,15,58,14,202,15 // pblendw $0xf,%xmm2,%xmm1 .byte 235,191 // jmp 330 <_sk_load_bgra_dst_sse41_8bit+0x27> .byte 102,66,15,110,12,130 // movd (%rdx,%r8,4),%xmm1 .byte 235,183 // jmp 330 <_sk_load_bgra_dst_sse41_8bit+0x27> HIDDEN _sk_store_bgra_sse41_8bit .globl _sk_store_bgra_sse41_8bit FUNCTION(_sk_store_bgra_sse41_8bit) _sk_store_bgra_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,56,0,21,222,11,0,0 // pshufb 0xbde(%rip),%xmm2 # f80 <_sk_xor__sse41_8bit+0x116> .byte 77,133,201 // test %r9,%r9 .byte 117,10 // jne 3b1 <_sk_store_bgra_sse41_8bit+0x38> .byte 243,66,15,127,20,130 // movdqu %xmm2,(%rdx,%r8,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,29 // je 3d8 <_sk_store_bgra_sse41_8bit+0x5f> .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,15 // je 3d0 <_sk_store_bgra_sse41_8bit+0x57> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,230 // jne 3ad <_sk_store_bgra_sse41_8bit+0x34> .byte 102,66,15,58,22,84,130,8,2 // pextrd $0x2,%xmm2,0x8(%rdx,%r8,4) .byte 102,66,15,214,20,130 // movq %xmm2,(%rdx,%r8,4) .byte 235,213 // jmp 3ad <_sk_store_bgra_sse41_8bit+0x34> .byte 102,66,15,126,20,130 // movd %xmm2,(%rdx,%r8,4) .byte 235,205 // jmp 3ad <_sk_store_bgra_sse41_8bit+0x34> HIDDEN _sk_load_a8_sse41_8bit .globl _sk_load_a8_sse41_8bit FUNCTION(_sk_load_a8_sse41_8bit) _sk_load_a8_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,16 // jne 40d <_sk_load_a8_sse41_8bit+0x2d> .byte 102,66,15,56,49,4,2 // pmovzxbd (%rdx,%r8,1),%xmm0 .byte 102,15,114,240,24 // pslld $0x18,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,53 // je 44c <_sk_load_a8_sse41_8bit+0x6c> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 436 <_sk_load_a8_sse41_8bit+0x56> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,221 // jne 404 <_sk_load_a8_sse41_8bit+0x24> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,56,49,210 // pmovzxbd %xmm2,%xmm2 .byte 102,15,58,14,194,15 // pblendw $0xf,%xmm2,%xmm0 .byte 235,184 // jmp 404 <_sk_load_a8_sse41_8bit+0x24> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 235,173 // jmp 404 <_sk_load_a8_sse41_8bit+0x24> HIDDEN _sk_load_a8_dst_sse41_8bit .globl _sk_load_a8_dst_sse41_8bit FUNCTION(_sk_load_a8_dst_sse41_8bit) _sk_load_a8_dst_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,16 // jne 484 <_sk_load_a8_dst_sse41_8bit+0x2d> .byte 102,66,15,56,49,12,2 // pmovzxbd (%rdx,%r8,1),%xmm1 .byte 102,15,114,241,24 // pslld $0x18,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,53 // je 4c3 <_sk_load_a8_dst_sse41_8bit+0x6c> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 4ad <_sk_load_a8_dst_sse41_8bit+0x56> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,221 // jne 47b <_sk_load_a8_dst_sse41_8bit+0x24> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 102,15,112,201,69 // pshufd $0x45,%xmm1,%xmm1 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,56,49,210 // pmovzxbd %xmm2,%xmm2 .byte 102,15,58,14,202,15 // pblendw $0xf,%xmm2,%xmm1 .byte 235,184 // jmp 47b <_sk_load_a8_dst_sse41_8bit+0x24> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 235,173 // jmp 47b <_sk_load_a8_dst_sse41_8bit+0x24> HIDDEN _sk_store_a8_sse41_8bit .globl _sk_store_a8_sse41_8bit FUNCTION(_sk_store_a8_sse41_8bit) _sk_store_a8_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,114,210,24 // psrld $0x18,%xmm2 .byte 77,133,201 // test %r9,%r9 .byte 117,19 // jne 507 <_sk_store_a8_sse41_8bit+0x39> .byte 102,15,56,0,21,163,10,0,0 // pshufb 0xaa3(%rip),%xmm2 # fa0 <_sk_xor__sse41_8bit+0x136> .byte 102,66,15,126,20,2 // movd %xmm2,(%rdx,%r8,1) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,40 // je 539 <_sk_store_a8_sse41_8bit+0x6b> .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,15 // je 526 <_sk_store_a8_sse41_8bit+0x58> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,230 // jne 503 <_sk_store_a8_sse41_8bit+0x35> .byte 102,66,15,58,20,84,2,2,8 // pextrb $0x8,%xmm2,0x2(%rdx,%r8,1) .byte 102,15,56,0,21,97,10,0,0 // pshufb 0xa61(%rip),%xmm2 # f90 <_sk_xor__sse41_8bit+0x126> .byte 102,66,15,58,21,20,2,0 // pextrw $0x0,%xmm2,(%rdx,%r8,1) .byte 235,202 // jmp 503 <_sk_store_a8_sse41_8bit+0x35> .byte 102,66,15,58,20,20,2,0 // pextrb $0x0,%xmm2,(%rdx,%r8,1) .byte 235,192 // jmp 503 <_sk_store_a8_sse41_8bit+0x35> HIDDEN _sk_load_g8_sse41_8bit .globl _sk_load_g8_sse41_8bit FUNCTION(_sk_load_g8_sse41_8bit) _sk_load_g8_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,36 // jne 584 <_sk_load_g8_sse41_8bit+0x41> .byte 102,66,15,56,49,4,2 // pmovzxbd (%rdx,%r8,1),%xmm0 .byte 102,15,219,5,65,10,0,0 // pand 0xa41(%rip),%xmm0 # fb0 <_sk_xor__sse41_8bit+0x146> .byte 102,15,56,64,5,72,10,0,0 // pmulld 0xa48(%rip),%xmm0 # fc0 <_sk_xor__sse41_8bit+0x156> .byte 102,15,235,5,80,10,0,0 // por 0xa50(%rip),%xmm0 # fd0 <_sk_xor__sse41_8bit+0x166> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,53 // je 5c3 <_sk_load_g8_sse41_8bit+0x80> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 5ad <_sk_load_g8_sse41_8bit+0x6a> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,201 // jne 567 <_sk_load_g8_sse41_8bit+0x24> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,56,49,210 // pmovzxbd %xmm2,%xmm2 .byte 102,15,58,14,194,15 // pblendw $0xf,%xmm2,%xmm0 .byte 235,164 // jmp 567 <_sk_load_g8_sse41_8bit+0x24> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 235,153 // jmp 567 <_sk_load_g8_sse41_8bit+0x24> HIDDEN _sk_load_g8_dst_sse41_8bit .globl _sk_load_g8_dst_sse41_8bit FUNCTION(_sk_load_g8_dst_sse41_8bit) _sk_load_g8_dst_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,36 // jne 60f <_sk_load_g8_dst_sse41_8bit+0x41> .byte 102,66,15,56,49,12,2 // pmovzxbd (%rdx,%r8,1),%xmm1 .byte 102,15,219,13,230,9,0,0 // pand 0x9e6(%rip),%xmm1 # fe0 <_sk_xor__sse41_8bit+0x176> .byte 102,15,56,64,13,237,9,0,0 // pmulld 0x9ed(%rip),%xmm1 # ff0 <_sk_xor__sse41_8bit+0x186> .byte 102,15,235,13,245,9,0,0 // por 0x9f5(%rip),%xmm1 # 1000 <_sk_xor__sse41_8bit+0x196> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,53 // je 64e <_sk_load_g8_dst_sse41_8bit+0x80> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 638 <_sk_load_g8_dst_sse41_8bit+0x6a> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,201 // jne 5f2 <_sk_load_g8_dst_sse41_8bit+0x24> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 102,15,112,201,69 // pshufd $0x45,%xmm1,%xmm1 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,56,49,210 // pmovzxbd %xmm2,%xmm2 .byte 102,15,58,14,202,15 // pblendw $0xf,%xmm2,%xmm1 .byte 235,164 // jmp 5f2 <_sk_load_g8_dst_sse41_8bit+0x24> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 235,153 // jmp 5f2 <_sk_load_g8_dst_sse41_8bit+0x24> HIDDEN _sk_srcover_rgba_8888_sse41_8bit .globl _sk_srcover_rgba_8888_sse41_8bit FUNCTION(_sk_srcover_rgba_8888_sse41_8bit) _sk_srcover_rgba_8888_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,98 // jne 6dc <_sk_srcover_rgba_8888_sse41_8bit+0x83> .byte 243,66,15,111,20,130 // movdqu (%rdx,%r8,4),%xmm2 .byte 77,133,201 // test %r9,%r9 .byte 102,15,111,216 // movdqa %xmm0,%xmm3 .byte 102,15,56,0,29,128,9,0,0 // pshufb 0x980(%rip),%xmm3 # 1010 <_sk_xor__sse41_8bit+0x1a6> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,111,234 // movdqa %xmm2,%xmm5 .byte 102,15,104,236 // punpckhbw %xmm4,%xmm5 .byte 102,15,56,48,242 // pmovzxbw %xmm2,%xmm6 .byte 102,15,56,48,251 // pmovzxbw %xmm3,%xmm7 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,221 // pmullw %xmm5,%xmm3 .byte 102,15,213,254 // pmullw %xmm6,%xmm7 .byte 102,15,253,221 // paddw %xmm5,%xmm3 .byte 102,15,253,254 // paddw %xmm6,%xmm7 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,215,8 // psrlw $0x8,%xmm7 .byte 102,15,103,251 // packuswb %xmm3,%xmm7 .byte 102,15,248,215 // psubb %xmm7,%xmm2 .byte 102,15,252,208 // paddb %xmm0,%xmm2 .byte 117,60 // jne 70e <_sk_srcover_rgba_8888_sse41_8bit+0xb5> .byte 243,66,15,127,20,130 // movdqu %xmm2,(%rdx,%r8,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 68,137,200 // mov %r9d,%eax .byte 36,3 // and $0x3,%al .byte 60,1 // cmp $0x1,%al .byte 116,80 // je 735 <_sk_srcover_rgba_8888_sse41_8bit+0xdc> .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 60,2 // cmp $0x2,%al .byte 116,16 // je 6fd <_sk_srcover_rgba_8888_sse41_8bit+0xa4> .byte 60,3 // cmp $0x3,%al .byte 117,143 // jne 680 <_sk_srcover_rgba_8888_sse41_8bit+0x27> .byte 102,66,15,110,84,130,8 // movd 0x8(%rdx,%r8,4),%xmm2 .byte 102,15,112,210,69 // pshufd $0x45,%xmm2,%xmm2 .byte 243,66,15,126,28,130 // movq (%rdx,%r8,4),%xmm3 .byte 102,15,58,14,211,15 // pblendw $0xf,%xmm3,%xmm2 .byte 233,114,255,255,255 // jmpq 680 <_sk_srcover_rgba_8888_sse41_8bit+0x27> .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,40 // je 740 <_sk_srcover_rgba_8888_sse41_8bit+0xe7> .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,15 // je 72d <_sk_srcover_rgba_8888_sse41_8bit+0xd4> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,180 // jne 6d8 <_sk_srcover_rgba_8888_sse41_8bit+0x7f> .byte 102,66,15,58,22,84,130,8,2 // pextrd $0x2,%xmm2,0x8(%rdx,%r8,4) .byte 102,66,15,214,20,130 // movq %xmm2,(%rdx,%r8,4) .byte 235,163 // jmp 6d8 <_sk_srcover_rgba_8888_sse41_8bit+0x7f> .byte 102,66,15,110,20,130 // movd (%rdx,%r8,4),%xmm2 .byte 233,64,255,255,255 // jmpq 680 <_sk_srcover_rgba_8888_sse41_8bit+0x27> .byte 102,66,15,126,20,130 // movd %xmm2,(%rdx,%r8,4) .byte 235,144 // jmp 6d8 <_sk_srcover_rgba_8888_sse41_8bit+0x7f> HIDDEN _sk_scale_1_float_sse41_8bit .globl _sk_scale_1_float_sse41_8bit FUNCTION(_sk_scale_1_float_sse41_8bit) _sk_scale_1_float_sse41_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,16 // movss (%rax),%xmm2 .byte 243,15,89,21,186,7,0,0 // mulss 0x7ba(%rip),%xmm2 # f10 <_sk_xor__sse41_8bit+0xa6> .byte 243,15,44,194 // cvttss2si %xmm2,%eax .byte 102,15,110,216 // movd %eax,%xmm3 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 102,15,56,48,224 // pmovzxbw %xmm0,%xmm4 .byte 102,15,104,194 // punpckhbw %xmm2,%xmm0 .byte 102,15,56,0,29,173,8,0,0 // pshufb 0x8ad(%rip),%xmm3 # 1020 <_sk_xor__sse41_8bit+0x1b6> .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,15,213,212 // pmullw %xmm4,%xmm2 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,253,212 // paddw %xmm4,%xmm2 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_u8_sse41_8bit .globl _sk_scale_u8_sse41_8bit FUNCTION(_sk_scale_u8_sse41_8bit) _sk_scale_u8_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,76 // jne 806 <_sk_scale_u8_sse41_8bit+0x69> .byte 102,66,15,56,49,28,2 // pmovzxbd (%rdx,%r8,1),%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,56,0,29,98,8,0,0 // pshufb 0x862(%rip),%xmm3 # 1030 <_sk_xor__sse41_8bit+0x1c6> .byte 102,15,56,48,232 // pmovzxbw %xmm0,%xmm5 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,56,48,211 // pmovzxbw %xmm3,%xmm2 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,56 // je 848 <_sk_scale_u8_sse41_8bit+0xab> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 82f <_sk_scale_u8_sse41_8bit+0x92> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,161 // jne 7c1 <_sk_scale_u8_sse41_8bit+0x24> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,112,218,69 // pshufd $0x45,%xmm2,%xmm3 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,56,49,210 // pmovzxbd %xmm2,%xmm2 .byte 102,15,58,14,218,15 // pblendw $0xf,%xmm2,%xmm3 .byte 233,121,255,255,255 // jmpq 7c1 <_sk_scale_u8_sse41_8bit+0x24> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,216 // movd %eax,%xmm3 .byte 233,107,255,255,255 // jmpq 7c1 <_sk_scale_u8_sse41_8bit+0x24> HIDDEN _sk_lerp_1_float_sse41_8bit .globl _sk_lerp_1_float_sse41_8bit FUNCTION(_sk_lerp_1_float_sse41_8bit) _sk_lerp_1_float_sse41_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,16 // movss (%rax),%xmm2 .byte 243,15,89,21,176,6,0,0 // mulss 0x6b0(%rip),%xmm2 # f14 <_sk_xor__sse41_8bit+0xaa> .byte 243,15,44,194 // cvttss2si %xmm2,%eax .byte 102,15,110,216 // movd %eax,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,56,0,220 // pshufb %xmm4,%xmm3 .byte 102,15,56,48,232 // pmovzxbw %xmm0,%xmm5 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,111,21,186,7,0,0 // movdqa 0x7ba(%rip),%xmm2 # 1040 <_sk_xor__sse41_8bit+0x1d6> .byte 102,15,219,211 // pand %xmm3,%xmm2 .byte 102,15,111,242 // movdqa %xmm2,%xmm6 .byte 102,15,213,240 // pmullw %xmm0,%xmm6 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,253,240 // paddw %xmm0,%xmm6 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,214 // packuswb %xmm6,%xmm2 .byte 102,15,118,237 // pcmpeqd %xmm5,%xmm5 .byte 102,15,239,235 // pxor %xmm3,%xmm5 .byte 102,15,56,48,217 // pmovzxbw %xmm1,%xmm3 .byte 102,15,111,241 // movdqa %xmm1,%xmm6 .byte 102,15,104,244 // punpckhbw %xmm4,%xmm6 .byte 102,15,56,48,197 // pmovzxbw %xmm5,%xmm0 .byte 102,15,104,236 // punpckhbw %xmm4,%xmm5 .byte 102,15,213,238 // pmullw %xmm6,%xmm5 .byte 102,15,213,195 // pmullw %xmm3,%xmm0 .byte 102,15,253,238 // paddw %xmm6,%xmm5 .byte 102,15,253,195 // paddw %xmm3,%xmm0 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,197 // packuswb %xmm5,%xmm0 .byte 102,15,252,194 // paddb %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_lerp_u8_sse41_8bit .globl _sk_lerp_u8_sse41_8bit FUNCTION(_sk_lerp_u8_sse41_8bit) _sk_lerp_u8_sse41_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 15,133,140,0,0,0 // jne 99d <_sk_lerp_u8_sse41_8bit+0xad> .byte 102,66,15,56,49,20,2 // pmovzxbd (%rdx,%r8,1),%xmm2 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,56,0,21,43,7,0,0 // pshufb 0x72b(%rip),%xmm2 # 1050 <_sk_xor__sse41_8bit+0x1e6> .byte 102,15,56,48,232 // pmovzxbw %xmm0,%xmm5 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,111,242 // movdqa %xmm2,%xmm6 .byte 102,15,104,244 // punpckhbw %xmm4,%xmm6 .byte 102,15,56,48,218 // pmovzxbw %xmm2,%xmm3 .byte 102,15,213,240 // pmullw %xmm0,%xmm6 .byte 102,15,213,221 // pmullw %xmm5,%xmm3 .byte 102,15,253,240 // paddw %xmm0,%xmm6 .byte 102,15,253,221 // paddw %xmm5,%xmm3 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,103,222 // packuswb %xmm6,%xmm3 .byte 102,15,118,237 // pcmpeqd %xmm5,%xmm5 .byte 102,15,239,234 // pxor %xmm2,%xmm5 .byte 102,15,111,209 // movdqa %xmm1,%xmm2 .byte 102,15,104,212 // punpckhbw %xmm4,%xmm2 .byte 102,15,56,48,241 // pmovzxbw %xmm1,%xmm6 .byte 102,15,56,48,197 // pmovzxbw %xmm5,%xmm0 .byte 102,15,104,236 // punpckhbw %xmm4,%xmm5 .byte 102,15,213,234 // pmullw %xmm2,%xmm5 .byte 102,15,213,198 // pmullw %xmm6,%xmm0 .byte 102,15,253,234 // paddw %xmm2,%xmm5 .byte 102,15,253,198 // paddw %xmm6,%xmm0 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,197 // packuswb %xmm5,%xmm0 .byte 102,15,252,195 // paddb %xmm3,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,60 // je 9e3 <_sk_lerp_u8_sse41_8bit+0xf3> .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,25 // je 9ca <_sk_lerp_u8_sse41_8bit+0xda> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 15,133,93,255,255,255 // jne 918 <_sk_lerp_u8_sse41_8bit+0x28> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,112,210,69 // pshufd $0x45,%xmm2,%xmm2 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,216 // movd %eax,%xmm3 .byte 102,15,56,49,219 // pmovzxbd %xmm3,%xmm3 .byte 102,15,58,14,211,15 // pblendw $0xf,%xmm3,%xmm2 .byte 233,53,255,255,255 // jmpq 918 <_sk_lerp_u8_sse41_8bit+0x28> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 233,39,255,255,255 // jmpq 918 <_sk_lerp_u8_sse41_8bit+0x28> HIDDEN _sk_move_src_dst_sse41_8bit .globl _sk_move_src_dst_sse41_8bit FUNCTION(_sk_move_src_dst_sse41_8bit) _sk_move_src_dst_sse41_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_move_dst_src_sse41_8bit .globl _sk_move_dst_src_sse41_8bit FUNCTION(_sk_move_dst_src_sse41_8bit) _sk_move_dst_src_sse41_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_black_color_sse41_8bit .globl _sk_black_color_sse41_8bit FUNCTION(_sk_black_color_sse41_8bit) _sk_black_color_sse41_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,5,88,6,0,0 // movaps 0x658(%rip),%xmm0 # 1060 <_sk_xor__sse41_8bit+0x1f6> .byte 255,224 // jmpq *%rax HIDDEN _sk_white_color_sse41_8bit .globl _sk_white_color_sse41_8bit FUNCTION(_sk_white_color_sse41_8bit) _sk_white_color_sse41_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,118,192 // pcmpeqd %xmm0,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_clear_sse41_8bit .globl _sk_clear_sse41_8bit FUNCTION(_sk_clear_sse41_8bit) _sk_clear_sse41_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcatop_sse41_8bit .globl _sk_srcatop_sse41_8bit FUNCTION(_sk_srcatop_sse41_8bit) _sk_srcatop_sse41_8bit: .byte 102,68,15,111,5,78,6,0,0 // movdqa 0x64e(%rip),%xmm8 # 1070 <_sk_xor__sse41_8bit+0x206> .byte 102,15,111,217 // movdqa %xmm1,%xmm3 .byte 102,15,56,48,225 // pmovzxbw %xmm1,%xmm4 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,65,15,56,0,232 // pshufb %xmm8,%xmm5 .byte 102,15,239,246 // pxor %xmm6,%xmm6 .byte 102,15,111,248 // movdqa %xmm0,%xmm7 .byte 102,15,104,254 // punpckhbw %xmm6,%xmm7 .byte 102,15,56,48,213 // pmovzxbw %xmm5,%xmm2 .byte 102,15,104,238 // punpckhbw %xmm6,%xmm5 .byte 102,15,213,239 // pmullw %xmm7,%xmm5 .byte 102,15,253,239 // paddw %xmm7,%xmm5 .byte 102,15,56,48,248 // pmovzxbw %xmm0,%xmm7 .byte 102,15,213,215 // pmullw %xmm7,%xmm2 .byte 102,15,253,215 // paddw %xmm7,%xmm2 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,213 // packuswb %xmm5,%xmm2 .byte 102,65,15,56,0,192 // pshufb %xmm8,%xmm0 .byte 102,15,118,237 // pcmpeqd %xmm5,%xmm5 .byte 102,15,239,232 // pxor %xmm0,%xmm5 .byte 102,15,104,222 // punpckhbw %xmm6,%xmm3 .byte 102,15,56,48,197 // pmovzxbw %xmm5,%xmm0 .byte 102,15,104,238 // punpckhbw %xmm6,%xmm5 .byte 102,15,213,235 // pmullw %xmm3,%xmm5 .byte 102,15,213,196 // pmullw %xmm4,%xmm0 .byte 102,15,253,235 // paddw %xmm3,%xmm5 .byte 102,15,253,196 // paddw %xmm4,%xmm0 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,197 // packuswb %xmm5,%xmm0 .byte 102,15,252,194 // paddb %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstatop_sse41_8bit .globl _sk_dstatop_sse41_8bit FUNCTION(_sk_dstatop_sse41_8bit) _sk_dstatop_sse41_8bit: .byte 102,15,111,21,202,5,0,0 // movdqa 0x5ca(%rip),%xmm2 # 1080 <_sk_xor__sse41_8bit+0x216> .byte 102,15,111,216 // movdqa %xmm0,%xmm3 .byte 102,15,56,0,218 // pshufb %xmm2,%xmm3 .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 102,15,56,48,233 // pmovzxbw %xmm1,%xmm5 .byte 102,15,111,241 // movdqa %xmm1,%xmm6 .byte 102,15,111,249 // movdqa %xmm1,%xmm7 .byte 102,65,15,104,248 // punpckhbw %xmm8,%xmm7 .byte 102,15,56,48,227 // pmovzxbw %xmm3,%xmm4 .byte 102,65,15,104,216 // punpckhbw %xmm8,%xmm3 .byte 102,15,213,223 // pmullw %xmm7,%xmm3 .byte 102,15,253,223 // paddw %xmm7,%xmm3 .byte 102,15,213,229 // pmullw %xmm5,%xmm4 .byte 102,15,253,229 // paddw %xmm5,%xmm4 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,103,227 // packuswb %xmm3,%xmm4 .byte 102,15,56,0,242 // pshufb %xmm2,%xmm6 .byte 102,15,118,219 // pcmpeqd %xmm3,%xmm3 .byte 102,15,239,222 // pxor %xmm6,%xmm3 .byte 102,15,56,48,232 // pmovzxbw %xmm0,%xmm5 .byte 102,65,15,104,192 // punpckhbw %xmm8,%xmm0 .byte 102,15,56,48,211 // pmovzxbw %xmm3,%xmm2 .byte 102,65,15,104,216 // punpckhbw %xmm8,%xmm3 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 102,15,252,212 // paddb %xmm4,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcin_sse41_8bit .globl _sk_srcin_sse41_8bit FUNCTION(_sk_srcin_sse41_8bit) _sk_srcin_sse41_8bit: .byte 102,15,111,217 // movdqa %xmm1,%xmm3 .byte 102,15,56,0,29,58,5,0,0 // pshufb 0x53a(%rip),%xmm3 # 1090 <_sk_xor__sse41_8bit+0x226> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,56,48,232 // pmovzxbw %xmm0,%xmm5 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,56,48,211 // pmovzxbw %xmm3,%xmm2 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_dstin_sse41_8bit .globl _sk_dstin_sse41_8bit FUNCTION(_sk_dstin_sse41_8bit) _sk_dstin_sse41_8bit: .byte 102,15,56,0,5,5,5,0,0 // pshufb 0x505(%rip),%xmm0 # 10a0 <_sk_xor__sse41_8bit+0x236> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,56,48,225 // pmovzxbw %xmm1,%xmm4 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,104,235 // punpckhbw %xmm3,%xmm5 .byte 102,15,56,48,208 // pmovzxbw %xmm0,%xmm2 .byte 102,15,104,195 // punpckhbw %xmm3,%xmm0 .byte 102,15,213,197 // pmullw %xmm5,%xmm0 .byte 102,15,213,212 // pmullw %xmm4,%xmm2 .byte 102,15,253,197 // paddw %xmm5,%xmm0 .byte 102,15,253,212 // paddw %xmm4,%xmm2 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,208 // packuswb %xmm0,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcout_sse41_8bit .globl _sk_srcout_sse41_8bit FUNCTION(_sk_srcout_sse41_8bit) _sk_srcout_sse41_8bit: .byte 102,15,111,209 // movdqa %xmm1,%xmm2 .byte 102,15,56,0,21,200,4,0,0 // pshufb 0x4c8(%rip),%xmm2 # 10b0 <_sk_xor__sse41_8bit+0x246> .byte 102,15,118,219 // pcmpeqd %xmm3,%xmm3 .byte 102,15,239,218 // pxor %xmm2,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,56,48,232 // pmovzxbw %xmm0,%xmm5 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,56,48,211 // pmovzxbw %xmm3,%xmm2 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_dstout_sse41_8bit .globl _sk_dstout_sse41_8bit FUNCTION(_sk_dstout_sse41_8bit) _sk_dstout_sse41_8bit: .byte 102,15,56,0,5,139,4,0,0 // pshufb 0x48b(%rip),%xmm0 # 10c0 <_sk_xor__sse41_8bit+0x256> .byte 102,15,118,210 // pcmpeqd %xmm2,%xmm2 .byte 102,15,239,208 // pxor %xmm0,%xmm2 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,56,48,225 // pmovzxbw %xmm1,%xmm4 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,104,235 // punpckhbw %xmm3,%xmm5 .byte 102,15,56,48,194 // pmovzxbw %xmm2,%xmm0 .byte 102,15,104,211 // punpckhbw %xmm3,%xmm2 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,213,196 // pmullw %xmm4,%xmm0 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,196 // paddw %xmm4,%xmm0 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,194 // packuswb %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_sse41_8bit .globl _sk_srcover_sse41_8bit FUNCTION(_sk_srcover_sse41_8bit) _sk_srcover_sse41_8bit: .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,56,0,21,74,4,0,0 // pshufb 0x44a(%rip),%xmm2 # 10d0 <_sk_xor__sse41_8bit+0x266> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,56,48,225 // pmovzxbw %xmm1,%xmm4 .byte 102,15,252,193 // paddb %xmm1,%xmm0 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,104,235 // punpckhbw %xmm3,%xmm5 .byte 102,15,56,48,242 // pmovzxbw %xmm2,%xmm6 .byte 102,15,104,211 // punpckhbw %xmm3,%xmm2 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,213,244 // pmullw %xmm4,%xmm6 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,244 // paddw %xmm4,%xmm6 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,103,242 // packuswb %xmm2,%xmm6 .byte 102,15,248,198 // psubb %xmm6,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstover_sse41_8bit .globl _sk_dstover_sse41_8bit FUNCTION(_sk_dstover_sse41_8bit) _sk_dstover_sse41_8bit: .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,56,48,216 // pmovzxbw %xmm0,%xmm3 .byte 102,15,252,193 // paddb %xmm1,%xmm0 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,56,0,37,252,3,0,0 // pshufb 0x3fc(%rip),%xmm4 # 10e0 <_sk_xor__sse41_8bit+0x276> .byte 102,15,239,237 // pxor %xmm5,%xmm5 .byte 102,15,104,213 // punpckhbw %xmm5,%xmm2 .byte 102,15,56,48,244 // pmovzxbw %xmm4,%xmm6 .byte 102,15,104,229 // punpckhbw %xmm5,%xmm4 .byte 102,15,213,226 // pmullw %xmm2,%xmm4 .byte 102,15,213,243 // pmullw %xmm3,%xmm6 .byte 102,15,253,226 // paddw %xmm2,%xmm4 .byte 102,15,253,243 // paddw %xmm3,%xmm6 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,103,244 // packuswb %xmm4,%xmm6 .byte 102,15,248,198 // psubb %xmm6,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_modulate_sse41_8bit .globl _sk_modulate_sse41_8bit FUNCTION(_sk_modulate_sse41_8bit) _sk_modulate_sse41_8bit: .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,56,48,224 // pmovzxbw %xmm0,%xmm4 .byte 102,15,104,195 // punpckhbw %xmm3,%xmm0 .byte 102,15,56,48,209 // pmovzxbw %xmm1,%xmm2 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,104,235 // punpckhbw %xmm3,%xmm5 .byte 102,15,213,232 // pmullw %xmm0,%xmm5 .byte 102,15,213,212 // pmullw %xmm4,%xmm2 .byte 102,15,253,232 // paddw %xmm0,%xmm5 .byte 102,15,253,212 // paddw %xmm4,%xmm2 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,213 // packuswb %xmm5,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_multiply_sse41_8bit .globl _sk_multiply_sse41_8bit FUNCTION(_sk_multiply_sse41_8bit) _sk_multiply_sse41_8bit: .byte 102,68,15,111,5,140,3,0,0 // movdqa 0x38c(%rip),%xmm8 # 10f0 <_sk_xor__sse41_8bit+0x286> .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,56,48,209 // pmovzxbw %xmm1,%xmm2 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,65,15,56,0,232 // pshufb %xmm8,%xmm5 .byte 102,69,15,118,201 // pcmpeqd %xmm9,%xmm9 .byte 102,65,15,239,233 // pxor %xmm9,%xmm5 .byte 102,69,15,239,210 // pxor %xmm10,%xmm10 .byte 102,15,111,216 // movdqa %xmm0,%xmm3 .byte 102,65,15,104,218 // punpckhbw %xmm10,%xmm3 .byte 102,15,56,48,240 // pmovzxbw %xmm0,%xmm6 .byte 102,15,56,48,253 // pmovzxbw %xmm5,%xmm7 .byte 102,65,15,104,234 // punpckhbw %xmm10,%xmm5 .byte 102,15,213,235 // pmullw %xmm3,%xmm5 .byte 102,15,213,254 // pmullw %xmm6,%xmm7 .byte 102,15,253,235 // paddw %xmm3,%xmm5 .byte 102,15,253,254 // paddw %xmm6,%xmm7 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,215,8 // psrlw $0x8,%xmm7 .byte 102,15,103,253 // packuswb %xmm5,%xmm7 .byte 102,65,15,56,0,192 // pshufb %xmm8,%xmm0 .byte 102,65,15,239,193 // pxor %xmm9,%xmm0 .byte 102,65,15,104,226 // punpckhbw %xmm10,%xmm4 .byte 102,15,56,48,232 // pmovzxbw %xmm0,%xmm5 .byte 102,65,15,104,194 // punpckhbw %xmm10,%xmm0 .byte 102,15,213,196 // pmullw %xmm4,%xmm0 .byte 102,15,213,234 // pmullw %xmm2,%xmm5 .byte 102,15,253,196 // paddw %xmm4,%xmm0 .byte 102,15,253,234 // paddw %xmm2,%xmm5 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,103,232 // packuswb %xmm0,%xmm5 .byte 102,15,252,239 // paddb %xmm7,%xmm5 .byte 102,15,213,227 // pmullw %xmm3,%xmm4 .byte 102,15,213,214 // pmullw %xmm6,%xmm2 .byte 102,15,253,227 // paddw %xmm3,%xmm4 .byte 102,15,253,214 // paddw %xmm6,%xmm2 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,212 // packuswb %xmm4,%xmm2 .byte 102,15,252,213 // paddb %xmm5,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_screen_sse41_8bit .globl _sk_screen_sse41_8bit FUNCTION(_sk_screen_sse41_8bit) _sk_screen_sse41_8bit: .byte 102,15,118,210 // pcmpeqd %xmm2,%xmm2 .byte 102,15,239,208 // pxor %xmm0,%xmm2 .byte 102,15,56,48,218 // pmovzxbw %xmm2,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,104,212 // punpckhbw %xmm4,%xmm2 .byte 102,15,56,48,233 // pmovzxbw %xmm1,%xmm5 .byte 102,15,111,241 // movdqa %xmm1,%xmm6 .byte 102,15,104,244 // punpckhbw %xmm4,%xmm6 .byte 102,15,213,242 // pmullw %xmm2,%xmm6 .byte 102,15,213,235 // pmullw %xmm3,%xmm5 .byte 102,15,253,235 // paddw %xmm3,%xmm5 .byte 102,15,253,242 // paddw %xmm2,%xmm6 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,103,238 // packuswb %xmm6,%xmm5 .byte 102,15,252,197 // paddb %xmm5,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xor__sse41_8bit .globl _sk_xor__sse41_8bit FUNCTION(_sk_xor__sse41_8bit) _sk_xor__sse41_8bit: .byte 102,68,15,111,5,141,2,0,0 // movdqa 0x28d(%rip),%xmm8 # 1100 <_sk_xor__sse41_8bit+0x296> .byte 102,15,111,217 // movdqa %xmm1,%xmm3 .byte 102,15,56,48,225 // pmovzxbw %xmm1,%xmm4 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,65,15,56,0,232 // pshufb %xmm8,%xmm5 .byte 102,69,15,118,201 // pcmpeqd %xmm9,%xmm9 .byte 102,65,15,239,233 // pxor %xmm9,%xmm5 .byte 102,15,239,255 // pxor %xmm7,%xmm7 .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,104,215 // punpckhbw %xmm7,%xmm2 .byte 102,15,56,48,245 // pmovzxbw %xmm5,%xmm6 .byte 102,15,104,239 // punpckhbw %xmm7,%xmm5 .byte 102,15,213,234 // pmullw %xmm2,%xmm5 .byte 102,15,253,234 // paddw %xmm2,%xmm5 .byte 102,15,56,48,208 // pmovzxbw %xmm0,%xmm2 .byte 102,15,213,242 // pmullw %xmm2,%xmm6 .byte 102,15,253,242 // paddw %xmm2,%xmm6 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,103,245 // packuswb %xmm5,%xmm6 .byte 102,65,15,56,0,192 // pshufb %xmm8,%xmm0 .byte 102,65,15,239,193 // pxor %xmm9,%xmm0 .byte 102,15,104,223 // punpckhbw %xmm7,%xmm3 .byte 102,15,56,48,208 // pmovzxbw %xmm0,%xmm2 .byte 102,15,104,199 // punpckhbw %xmm7,%xmm0 .byte 102,15,213,195 // pmullw %xmm3,%xmm0 .byte 102,15,213,212 // pmullw %xmm4,%xmm2 .byte 102,15,253,195 // paddw %xmm3,%xmm0 .byte 102,15,253,212 // paddw %xmm4,%xmm2 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,208 // packuswb %xmm0,%xmm2 .byte 102,15,252,214 // paddb %xmm6,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax BALIGN4 .byte 0,0 // add %al,(%rax) .byte 127,67 // jg f53 <_sk_xor__sse41_8bit+0xe9> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg f57 <_sk_xor__sse41_8bit+0xed> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg f5b <_sk_xor__sse41_8bit+0xf1> BALIGN16 .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 3,3 // add (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,0,0 // sldt (%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 2,1 // add (%rcx),%al .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,2,1 // or $0x1020f0c,%eax .byte 0,3 // add %al,(%rbx) .byte 6 // (bad) .byte 5,4,7,10,9 // add $0x90a0704,%eax .byte 8,11 // or %cl,(%rbx) .byte 14 // (bad) .byte 13,12,15,0,4 // or $0x4000f0c,%eax .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,4,8 // add %al,(%rax,%rcx,1) .byte 12,0 // or $0x0,%al .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,1 // add %al,(%rcx) .byte 1,1 // add %eax,(%rcx) .byte 0,1 // add %al,(%rcx) .byte 1,1 // add %eax,(%rcx) .byte 0,1 // add %al,(%rcx) .byte 1,1 // add %eax,(%rcx) .byte 0,1 // add %al,(%rcx) .byte 1,1 // add %eax,(%rcx) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255 // (bad) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 3,3 // add (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,0 // (bad) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 0,4,4 // add %al,(%rsp,%rax,1) .byte 4,4 // add $0x4,%al .byte 8,8 // or %cl,(%rax) .byte 8,8 // or %cl,(%rax) .byte 12,12 // or $0xc,%al .byte 12,12 // or $0xc,%al .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 0,0 // add %al,(%rax) .byte 4,4 // add $0x4,%al .byte 4,4 // add $0x4,%al .byte 8,8 // or %cl,(%rax) .byte 8,8 // or %cl,(%rax) .byte 12,12 // or $0xc,%al .byte 12,12 // or $0xc,%al .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 3,3 // add (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // (bad) .byte 15 // (bad) .byte 15,3,3 // lsl (%rbx),%eax .byte 3,3 // add (%rbx),%eax .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 7 // (bad) .byte 11,11 // or (%rbx),%ecx .byte 11,11 // or (%rbx),%ecx .byte 15 // (bad) .byte 15 // .byte 0xf .byte 15 // .byte 0xf .byte 15 // .byte 0xf BALIGN32 HIDDEN _sk_start_pipeline_sse2_8bit .globl _sk_start_pipeline_sse2_8bit FUNCTION(_sk_start_pipeline_sse2_8bit) _sk_start_pipeline_sse2_8bit: .byte 85 // push %rbp .byte 72,137,229 // mov %rsp,%rbp .byte 65,87 // push %r15 .byte 65,86 // push %r14 .byte 65,85 // push %r13 .byte 65,84 // push %r12 .byte 83 // push %rbx .byte 72,131,236,56 // sub $0x38,%rsp .byte 72,137,211 // mov %rdx,%rbx .byte 73,137,247 // mov %rsi,%r15 .byte 72,137,125,208 // mov %rdi,-0x30(%rbp) .byte 76,137,198 // mov %r8,%rsi .byte 72,173 // lods %ds:(%rsi),%rax .byte 73,137,197 // mov %rax,%r13 .byte 73,137,246 // mov %rsi,%r14 .byte 72,137,77,168 // mov %rcx,-0x58(%rbp) .byte 73,57,207 // cmp %rcx,%r15 .byte 115,102 // jae 95 <_sk_start_pipeline_sse2_8bit+0x95> .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,141,64,4 // lea 0x4(%rax),%rax .byte 72,137,69,176 // mov %rax,-0x50(%rbp) .byte 76,141,101,184 // lea -0x48(%rbp),%r12 .byte 72,57,93,176 // cmp %rbx,-0x50(%rbp) .byte 72,139,69,208 // mov -0x30(%rbp),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 76,137,125,192 // mov %r15,-0x40(%rbp) .byte 72,199,69,200,0,0,0,0 // movq $0x0,-0x38(%rbp) .byte 119,30 // ja 77 <_sk_start_pipeline_sse2_8bit+0x77> .byte 76,137,231 // mov %r12,%rdi .byte 76,137,246 // mov %r14,%rsi .byte 65,255,213 // callq *%r13 .byte 72,139,77,184 // mov -0x48(%rbp),%rcx .byte 72,141,65,4 // lea 0x4(%rcx),%rax .byte 72,137,69,184 // mov %rax,-0x48(%rbp) .byte 72,131,193,8 // add $0x8,%rcx .byte 72,57,217 // cmp %rbx,%rcx .byte 118,226 // jbe 59 <_sk_start_pipeline_sse2_8bit+0x59> .byte 72,137,217 // mov %rbx,%rcx .byte 72,41,193 // sub %rax,%rcx .byte 116,13 // je 8c <_sk_start_pipeline_sse2_8bit+0x8c> .byte 72,137,77,200 // mov %rcx,-0x38(%rbp) .byte 76,137,231 // mov %r12,%rdi .byte 76,137,246 // mov %r14,%rsi .byte 65,255,213 // callq *%r13 .byte 73,255,199 // inc %r15 .byte 76,59,125,168 // cmp -0x58(%rbp),%r15 .byte 117,170 // jne 3f <_sk_start_pipeline_sse2_8bit+0x3f> .byte 72,131,196,56 // add $0x38,%rsp .byte 91 // pop %rbx .byte 65,92 // pop %r12 .byte 65,93 // pop %r13 .byte 65,94 // pop %r14 .byte 65,95 // pop %r15 .byte 93 // pop %rbp .byte 195 // retq HIDDEN _sk_just_return_sse2_8bit .globl _sk_just_return_sse2_8bit FUNCTION(_sk_just_return_sse2_8bit) _sk_just_return_sse2_8bit: .byte 195 // retq HIDDEN _sk_uniform_color_sse2_8bit .globl _sk_uniform_color_sse2_8bit FUNCTION(_sk_uniform_color_sse2_8bit) _sk_uniform_color_sse2_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,110,64,16 // movd 0x10(%rax),%xmm0 .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_set_rgb_sse2_8bit .globl _sk_set_rgb_sse2_8bit FUNCTION(_sk_set_rgb_sse2_8bit) _sk_set_rgb_sse2_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,21,1,17,0,0 // movss 0x1101(%rip),%xmm2 # 11c0 <_sk_xor__sse2_8bit+0xc5> .byte 243,15,16,24 // movss (%rax),%xmm3 .byte 243,15,89,218 // mulss %xmm2,%xmm3 .byte 243,72,15,44,203 // cvttss2si %xmm3,%rcx .byte 243,15,16,88,4 // movss 0x4(%rax),%xmm3 .byte 243,15,89,218 // mulss %xmm2,%xmm3 .byte 243,72,15,44,211 // cvttss2si %xmm3,%rdx .byte 193,226,8 // shl $0x8,%edx .byte 9,202 // or %ecx,%edx .byte 243,15,89,80,8 // mulss 0x8(%rax),%xmm2 .byte 243,72,15,44,194 // cvttss2si %xmm2,%rax .byte 193,224,16 // shl $0x10,%eax .byte 9,208 // or %edx,%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,219,5,209,16,0,0 // pand 0x10d1(%rip),%xmm0 # 11d0 <_sk_xor__sse2_8bit+0xd5> .byte 102,15,235,194 // por %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_premul_sse2_8bit .globl _sk_premul_sse2_8bit FUNCTION(_sk_premul_sse2_8bit) _sk_premul_sse2_8bit: .byte 242,15,112,208,231 // pshuflw $0xe7,%xmm0,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,218,95 // pshufhw $0x5f,%xmm2,%xmm3 .byte 102,15,235,29,180,16,0,0 // por 0x10b4(%rip),%xmm3 # 11e0 <_sk_xor__sse2_8bit+0xe5> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,96,212 // punpcklbw %xmm4,%xmm2 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,111,235 // movdqa %xmm3,%xmm5 .byte 102,15,96,236 // punpcklbw %xmm4,%xmm5 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,213,234 // pmullw %xmm2,%xmm5 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_swap_rb_sse2_8bit .globl _sk_swap_rb_sse2_8bit FUNCTION(_sk_swap_rb_sse2_8bit) _sk_swap_rb_sse2_8bit: .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 102,15,111,216 // movdqa %xmm0,%xmm3 .byte 102,15,104,218 // punpckhbw %xmm2,%xmm3 .byte 242,15,112,219,198 // pshuflw $0xc6,%xmm3,%xmm3 .byte 243,15,112,219,198 // pshufhw $0xc6,%xmm3,%xmm3 .byte 102,15,96,194 // punpcklbw %xmm2,%xmm0 .byte 242,15,112,192,198 // pshuflw $0xc6,%xmm0,%xmm0 .byte 243,15,112,192,198 // pshufhw $0xc6,%xmm0,%xmm0 .byte 102,15,103,195 // packuswb %xmm3,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_invert_sse2_8bit .globl _sk_invert_sse2_8bit FUNCTION(_sk_invert_sse2_8bit) _sk_invert_sse2_8bit: .byte 102,15,118,210 // pcmpeqd %xmm2,%xmm2 .byte 102,15,239,194 // pxor %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_load_8888_sse2_8bit .globl _sk_load_8888_sse2_8bit FUNCTION(_sk_load_8888_sse2_8bit) _sk_load_8888_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,10 // jne 1d1 <_sk_load_8888_sse2_8bit+0x2b> .byte 243,66,15,111,4,130 // movdqu (%rdx,%r8,4),%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,36 // je 1ff <_sk_load_8888_sse2_8bit+0x59> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 1f7 <_sk_load_8888_sse2_8bit+0x51> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,226 // jne 1cd <_sk_load_8888_sse2_8bit+0x27> .byte 102,66,15,110,68,130,8 // movd 0x8(%rdx,%r8,4),%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 102,66,15,18,4,130 // movlpd (%rdx,%r8,4),%xmm0 .byte 235,206 // jmp 1cd <_sk_load_8888_sse2_8bit+0x27> .byte 102,66,15,110,4,130 // movd (%rdx,%r8,4),%xmm0 .byte 235,198 // jmp 1cd <_sk_load_8888_sse2_8bit+0x27> HIDDEN _sk_load_8888_dst_sse2_8bit .globl _sk_load_8888_dst_sse2_8bit FUNCTION(_sk_load_8888_dst_sse2_8bit) _sk_load_8888_dst_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,10 // jne 232 <_sk_load_8888_dst_sse2_8bit+0x2b> .byte 243,66,15,111,12,130 // movdqu (%rdx,%r8,4),%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,36 // je 260 <_sk_load_8888_dst_sse2_8bit+0x59> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 258 <_sk_load_8888_dst_sse2_8bit+0x51> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,226 // jne 22e <_sk_load_8888_dst_sse2_8bit+0x27> .byte 102,66,15,110,76,130,8 // movd 0x8(%rdx,%r8,4),%xmm1 .byte 102,15,112,201,69 // pshufd $0x45,%xmm1,%xmm1 .byte 102,66,15,18,12,130 // movlpd (%rdx,%r8,4),%xmm1 .byte 235,206 // jmp 22e <_sk_load_8888_dst_sse2_8bit+0x27> .byte 102,66,15,110,12,130 // movd (%rdx,%r8,4),%xmm1 .byte 235,198 // jmp 22e <_sk_load_8888_dst_sse2_8bit+0x27> HIDDEN _sk_store_8888_sse2_8bit .globl _sk_store_8888_sse2_8bit FUNCTION(_sk_store_8888_sse2_8bit) _sk_store_8888_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,10 // jne 293 <_sk_store_8888_sse2_8bit+0x2b> .byte 243,66,15,127,4,130 // movdqu %xmm0,(%rdx,%r8,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,32 // je 2bd <_sk_store_8888_sse2_8bit+0x55> .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 2b5 <_sk_store_8888_sse2_8bit+0x4d> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,230 // jne 28f <_sk_store_8888_sse2_8bit+0x27> .byte 102,15,112,208,78 // pshufd $0x4e,%xmm0,%xmm2 .byte 102,66,15,126,84,130,8 // movd %xmm2,0x8(%rdx,%r8,4) .byte 102,66,15,214,4,130 // movq %xmm0,(%rdx,%r8,4) .byte 235,210 // jmp 28f <_sk_store_8888_sse2_8bit+0x27> .byte 102,66,15,126,4,130 // movd %xmm0,(%rdx,%r8,4) .byte 235,202 // jmp 28f <_sk_store_8888_sse2_8bit+0x27> HIDDEN _sk_load_bgra_sse2_8bit .globl _sk_load_bgra_sse2_8bit FUNCTION(_sk_load_bgra_sse2_8bit) _sk_load_bgra_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,50 // jne 318 <_sk_load_bgra_sse2_8bit+0x53> .byte 243,66,15,111,4,130 // movdqu (%rdx,%r8,4),%xmm0 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 102,15,111,216 // movdqa %xmm0,%xmm3 .byte 102,15,104,218 // punpckhbw %xmm2,%xmm3 .byte 242,15,112,219,198 // pshuflw $0xc6,%xmm3,%xmm3 .byte 243,15,112,219,198 // pshufhw $0xc6,%xmm3,%xmm3 .byte 102,15,96,194 // punpcklbw %xmm2,%xmm0 .byte 242,15,112,192,198 // pshuflw $0xc6,%xmm0,%xmm0 .byte 243,15,112,192,198 // pshufhw $0xc6,%xmm0,%xmm0 .byte 102,15,103,195 // packuswb %xmm3,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,36 // je 346 <_sk_load_bgra_sse2_8bit+0x81> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 33e <_sk_load_bgra_sse2_8bit+0x79> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,186 // jne 2ec <_sk_load_bgra_sse2_8bit+0x27> .byte 102,66,15,110,68,130,8 // movd 0x8(%rdx,%r8,4),%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 102,66,15,18,4,130 // movlpd (%rdx,%r8,4),%xmm0 .byte 235,166 // jmp 2ec <_sk_load_bgra_sse2_8bit+0x27> .byte 102,66,15,110,4,130 // movd (%rdx,%r8,4),%xmm0 .byte 235,158 // jmp 2ec <_sk_load_bgra_sse2_8bit+0x27> HIDDEN _sk_load_bgra_dst_sse2_8bit .globl _sk_load_bgra_dst_sse2_8bit FUNCTION(_sk_load_bgra_dst_sse2_8bit) _sk_load_bgra_dst_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,50 // jne 3a1 <_sk_load_bgra_dst_sse2_8bit+0x53> .byte 243,66,15,111,12,130 // movdqu (%rdx,%r8,4),%xmm1 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 102,15,111,217 // movdqa %xmm1,%xmm3 .byte 102,15,104,218 // punpckhbw %xmm2,%xmm3 .byte 242,15,112,219,198 // pshuflw $0xc6,%xmm3,%xmm3 .byte 243,15,112,219,198 // pshufhw $0xc6,%xmm3,%xmm3 .byte 102,15,96,202 // punpcklbw %xmm2,%xmm1 .byte 242,15,112,201,198 // pshuflw $0xc6,%xmm1,%xmm1 .byte 243,15,112,201,198 // pshufhw $0xc6,%xmm1,%xmm1 .byte 102,15,103,203 // packuswb %xmm3,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,36 // je 3cf <_sk_load_bgra_dst_sse2_8bit+0x81> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 3c7 <_sk_load_bgra_dst_sse2_8bit+0x79> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,186 // jne 375 <_sk_load_bgra_dst_sse2_8bit+0x27> .byte 102,66,15,110,76,130,8 // movd 0x8(%rdx,%r8,4),%xmm1 .byte 102,15,112,201,69 // pshufd $0x45,%xmm1,%xmm1 .byte 102,66,15,18,12,130 // movlpd (%rdx,%r8,4),%xmm1 .byte 235,166 // jmp 375 <_sk_load_bgra_dst_sse2_8bit+0x27> .byte 102,66,15,110,12,130 // movd (%rdx,%r8,4),%xmm1 .byte 235,158 // jmp 375 <_sk_load_bgra_dst_sse2_8bit+0x27> HIDDEN _sk_store_bgra_sse2_8bit .globl _sk_store_bgra_sse2_8bit FUNCTION(_sk_store_bgra_sse2_8bit) _sk_store_bgra_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 102,15,111,216 // movdqa %xmm0,%xmm3 .byte 102,15,104,218 // punpckhbw %xmm2,%xmm3 .byte 242,15,112,219,198 // pshuflw $0xc6,%xmm3,%xmm3 .byte 243,15,112,219,198 // pshufhw $0xc6,%xmm3,%xmm3 .byte 102,15,111,224 // movdqa %xmm0,%xmm4 .byte 102,15,96,226 // punpcklbw %xmm2,%xmm4 .byte 242,15,112,212,198 // pshuflw $0xc6,%xmm4,%xmm2 .byte 243,15,112,210,198 // pshufhw $0xc6,%xmm2,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 77,133,201 // test %r9,%r9 .byte 117,10 // jne 42e <_sk_store_bgra_sse2_8bit+0x57> .byte 243,66,15,127,20,130 // movdqu %xmm2,(%rdx,%r8,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,32 // je 458 <_sk_store_bgra_sse2_8bit+0x81> .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 450 <_sk_store_bgra_sse2_8bit+0x79> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,230 // jne 42a <_sk_store_bgra_sse2_8bit+0x53> .byte 102,15,112,218,78 // pshufd $0x4e,%xmm2,%xmm3 .byte 102,66,15,126,92,130,8 // movd %xmm3,0x8(%rdx,%r8,4) .byte 102,66,15,214,20,130 // movq %xmm2,(%rdx,%r8,4) .byte 235,210 // jmp 42a <_sk_store_bgra_sse2_8bit+0x53> .byte 102,66,15,126,20,130 // movd %xmm2,(%rdx,%r8,4) .byte 235,202 // jmp 42a <_sk_store_bgra_sse2_8bit+0x53> HIDDEN _sk_load_a8_sse2_8bit .globl _sk_load_a8_sse2_8bit FUNCTION(_sk_load_a8_sse2_8bit) _sk_load_a8_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,23 // jne 494 <_sk_load_a8_sse2_8bit+0x34> .byte 102,66,15,110,4,2 // movd (%rdx,%r8,1),%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 102,15,114,240,24 // pslld $0x18,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,54 // je 4d4 <_sk_load_a8_sse2_8bit+0x74> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 4bd <_sk_load_a8_sse2_8bit+0x5d> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,221 // jne 48b <_sk_load_a8_sse2_8bit+0x2b> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,96,208 // punpcklbw %xmm0,%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 242,15,16,194 // movsd %xmm2,%xmm0 .byte 235,183 // jmp 48b <_sk_load_a8_sse2_8bit+0x2b> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 235,172 // jmp 48b <_sk_load_a8_sse2_8bit+0x2b> HIDDEN _sk_load_a8_dst_sse2_8bit .globl _sk_load_a8_dst_sse2_8bit FUNCTION(_sk_load_a8_dst_sse2_8bit) _sk_load_a8_dst_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,23 // jne 513 <_sk_load_a8_dst_sse2_8bit+0x34> .byte 102,66,15,110,12,2 // movd (%rdx,%r8,1),%xmm1 .byte 102,15,96,200 // punpcklbw %xmm0,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,114,241,24 // pslld $0x18,%xmm1 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,54 // je 553 <_sk_load_a8_dst_sse2_8bit+0x74> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 53c <_sk_load_a8_dst_sse2_8bit+0x5d> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,221 // jne 50a <_sk_load_a8_dst_sse2_8bit+0x2b> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 102,15,112,201,69 // pshufd $0x45,%xmm1,%xmm1 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,96,208 // punpcklbw %xmm0,%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 242,15,16,202 // movsd %xmm2,%xmm1 .byte 235,183 // jmp 50a <_sk_load_a8_dst_sse2_8bit+0x2b> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 235,172 // jmp 50a <_sk_load_a8_dst_sse2_8bit+0x2b> HIDDEN _sk_store_a8_sse2_8bit .globl _sk_store_a8_sse2_8bit FUNCTION(_sk_store_a8_sse2_8bit) _sk_store_a8_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,114,210,24 // psrld $0x18,%xmm2 .byte 77,133,201 // test %r9,%r9 .byte 117,26 // jne 59e <_sk_store_a8_sse2_8bit+0x40> .byte 102,15,219,21,100,12,0,0 // pand 0xc64(%rip),%xmm2 # 11f0 <_sk_xor__sse2_8bit+0xf5> .byte 102,15,103,210 // packuswb %xmm2,%xmm2 .byte 102,15,103,210 // packuswb %xmm2,%xmm2 .byte 102,66,15,126,20,2 // movd %xmm2,(%rdx,%r8,1) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,54 // je 5de <_sk_store_a8_sse2_8bit+0x80> .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 5c3 <_sk_store_a8_sse2_8bit+0x65> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,230 // jne 59a <_sk_store_a8_sse2_8bit+0x3c> .byte 102,15,127,84,36,232 // movdqa %xmm2,-0x18(%rsp) .byte 138,68,36,240 // mov -0x10(%rsp),%al .byte 66,136,68,2,2 // mov %al,0x2(%rdx,%r8,1) .byte 102,15,219,21,37,12,0,0 // pand 0xc25(%rip),%xmm2 # 11f0 <_sk_xor__sse2_8bit+0xf5> .byte 102,15,103,210 // packuswb %xmm2,%xmm2 .byte 102,15,103,210 // packuswb %xmm2,%xmm2 .byte 102,15,126,208 // movd %xmm2,%eax .byte 102,66,137,4,2 // mov %ax,(%rdx,%r8,1) .byte 235,188 // jmp 59a <_sk_store_a8_sse2_8bit+0x3c> .byte 102,15,127,84,36,216 // movdqa %xmm2,-0x28(%rsp) .byte 138,68,36,216 // mov -0x28(%rsp),%al .byte 66,136,4,2 // mov %al,(%rdx,%r8,1) .byte 235,172 // jmp 59a <_sk_store_a8_sse2_8bit+0x3c> HIDDEN _sk_load_g8_sse2_8bit .globl _sk_load_g8_sse2_8bit FUNCTION(_sk_load_g8_sse2_8bit) _sk_load_g8_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,69 // jne 650 <_sk_load_g8_sse2_8bit+0x62> .byte 102,66,15,110,4,2 // movd (%rdx,%r8,1),%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 102,15,219,5,223,11,0,0 // pand 0xbdf(%rip),%xmm0 # 1200 <_sk_xor__sse2_8bit+0x105> .byte 102,15,111,21,231,11,0,0 // movdqa 0xbe7(%rip),%xmm2 # 1210 <_sk_xor__sse2_8bit+0x115> .byte 102,15,112,216,245 // pshufd $0xf5,%xmm0,%xmm3 .byte 102,15,244,194 // pmuludq %xmm2,%xmm0 .byte 102,15,112,192,232 // pshufd $0xe8,%xmm0,%xmm0 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,211,232 // pshufd $0xe8,%xmm3,%xmm2 .byte 102,15,98,194 // punpckldq %xmm2,%xmm0 .byte 102,15,235,5,212,11,0,0 // por 0xbd4(%rip),%xmm0 # 1220 <_sk_xor__sse2_8bit+0x125> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,54 // je 690 <_sk_load_g8_sse2_8bit+0xa2> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 679 <_sk_load_g8_sse2_8bit+0x8b> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,175 // jne 619 <_sk_load_g8_sse2_8bit+0x2b> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,96,208 // punpcklbw %xmm0,%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 242,15,16,194 // movsd %xmm2,%xmm0 .byte 235,137 // jmp 619 <_sk_load_g8_sse2_8bit+0x2b> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,192 // movd %eax,%xmm0 .byte 233,123,255,255,255 // jmpq 619 <_sk_load_g8_sse2_8bit+0x2b> HIDDEN _sk_load_g8_dst_sse2_8bit .globl _sk_load_g8_dst_sse2_8bit FUNCTION(_sk_load_g8_dst_sse2_8bit) _sk_load_g8_dst_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,69 // jne 700 <_sk_load_g8_dst_sse2_8bit+0x62> .byte 102,66,15,110,12,2 // movd (%rdx,%r8,1),%xmm1 .byte 102,15,96,200 // punpcklbw %xmm0,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,219,13,95,11,0,0 // pand 0xb5f(%rip),%xmm1 # 1230 <_sk_xor__sse2_8bit+0x135> .byte 102,15,111,21,103,11,0,0 // movdqa 0xb67(%rip),%xmm2 # 1240 <_sk_xor__sse2_8bit+0x145> .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,202 // pmuludq %xmm2,%xmm1 .byte 102,15,112,201,232 // pshufd $0xe8,%xmm1,%xmm1 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,211,232 // pshufd $0xe8,%xmm3,%xmm2 .byte 102,15,98,202 // punpckldq %xmm2,%xmm1 .byte 102,15,235,13,84,11,0,0 // por 0xb54(%rip),%xmm1 # 1250 <_sk_xor__sse2_8bit+0x155> .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,54 // je 740 <_sk_load_g8_dst_sse2_8bit+0xa2> .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 729 <_sk_load_g8_dst_sse2_8bit+0x8b> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,175 // jne 6c9 <_sk_load_g8_dst_sse2_8bit+0x2b> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 102,15,112,201,69 // pshufd $0x45,%xmm1,%xmm1 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,96,208 // punpcklbw %xmm0,%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 242,15,16,202 // movsd %xmm2,%xmm1 .byte 235,137 // jmp 6c9 <_sk_load_g8_dst_sse2_8bit+0x2b> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,200 // movd %eax,%xmm1 .byte 233,123,255,255,255 // jmpq 6c9 <_sk_load_g8_dst_sse2_8bit+0x2b> HIDDEN _sk_srcover_rgba_8888_sse2_8bit .globl _sk_srcover_rgba_8888_sse2_8bit FUNCTION(_sk_srcover_rgba_8888_sse2_8bit) _sk_srcover_rgba_8888_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,193,226,2 // shl $0x2,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,120 // jne 7e7 <_sk_srcover_rgba_8888_sse2_8bit+0x99> .byte 243,66,15,111,20,130 // movdqu (%rdx,%r8,4),%xmm2 .byte 77,133,201 // test %r9,%r9 .byte 242,15,112,216,231 // pshuflw $0xe7,%xmm0,%xmm3 .byte 243,15,112,219,231 // pshufhw $0xe7,%xmm3,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,96,219 // punpcklbw %xmm3,%xmm3 .byte 242,15,112,219,95 // pshuflw $0x5f,%xmm3,%xmm3 .byte 243,15,112,219,95 // pshufhw $0x5f,%xmm3,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,111,234 // movdqa %xmm2,%xmm5 .byte 102,15,96,236 // punpcklbw %xmm4,%xmm5 .byte 102,15,111,242 // movdqa %xmm2,%xmm6 .byte 102,15,104,244 // punpckhbw %xmm4,%xmm6 .byte 102,15,111,251 // movdqa %xmm3,%xmm7 .byte 102,15,96,252 // punpcklbw %xmm4,%xmm7 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,222 // pmullw %xmm6,%xmm3 .byte 102,15,213,253 // pmullw %xmm5,%xmm7 .byte 102,15,253,253 // paddw %xmm5,%xmm7 .byte 102,15,253,222 // paddw %xmm6,%xmm3 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,215,8 // psrlw $0x8,%xmm7 .byte 102,15,103,251 // packuswb %xmm3,%xmm7 .byte 102,15,248,215 // psubb %xmm7,%xmm2 .byte 102,15,252,208 // paddb %xmm0,%xmm2 .byte 117,58 // jne 817 <_sk_srcover_rgba_8888_sse2_8bit+0xc9> .byte 243,66,15,127,20,130 // movdqu %xmm2,(%rdx,%r8,4) .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 68,137,200 // mov %r9d,%eax .byte 36,3 // and $0x3,%al .byte 60,1 // cmp $0x1,%al .byte 116,81 // je 841 <_sk_srcover_rgba_8888_sse2_8bit+0xf3> .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 60,2 // cmp $0x2,%al .byte 116,20 // je 80c <_sk_srcover_rgba_8888_sse2_8bit+0xbe> .byte 60,3 // cmp $0x3,%al .byte 15,133,117,255,255,255 // jne 775 <_sk_srcover_rgba_8888_sse2_8bit+0x27> .byte 102,66,15,110,84,130,8 // movd 0x8(%rdx,%r8,4),%xmm2 .byte 102,15,112,210,69 // pshufd $0x45,%xmm2,%xmm2 .byte 102,66,15,18,20,130 // movlpd (%rdx,%r8,4),%xmm2 .byte 233,94,255,255,255 // jmpq 775 <_sk_srcover_rgba_8888_sse2_8bit+0x27> .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,43 // je 84c <_sk_srcover_rgba_8888_sse2_8bit+0xfe> .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,18 // je 839 <_sk_srcover_rgba_8888_sse2_8bit+0xeb> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,182 // jne 7e3 <_sk_srcover_rgba_8888_sse2_8bit+0x95> .byte 102,15,112,218,78 // pshufd $0x4e,%xmm2,%xmm3 .byte 102,66,15,126,92,130,8 // movd %xmm3,0x8(%rdx,%r8,4) .byte 102,66,15,214,20,130 // movq %xmm2,(%rdx,%r8,4) .byte 235,162 // jmp 7e3 <_sk_srcover_rgba_8888_sse2_8bit+0x95> .byte 102,66,15,110,20,130 // movd (%rdx,%r8,4),%xmm2 .byte 233,41,255,255,255 // jmpq 775 <_sk_srcover_rgba_8888_sse2_8bit+0x27> .byte 102,66,15,126,20,130 // movd %xmm2,(%rdx,%r8,4) .byte 235,143 // jmp 7e3 <_sk_srcover_rgba_8888_sse2_8bit+0x95> HIDDEN _sk_scale_1_float_sse2_8bit .globl _sk_scale_1_float_sse2_8bit FUNCTION(_sk_scale_1_float_sse2_8bit) _sk_scale_1_float_sse2_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,16 // movss (%rax),%xmm2 .byte 243,15,89,21,98,9,0,0 // mulss 0x962(%rip),%xmm2 # 11c4 <_sk_xor__sse2_8bit+0xc9> .byte 243,15,44,194 // cvttss2si %xmm2,%eax .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,96,211 // punpcklbw %xmm3,%xmm2 .byte 102,15,104,195 // punpckhbw %xmm3,%xmm0 .byte 102,15,110,216 // movd %eax,%xmm3 .byte 102,15,96,219 // punpcklbw %xmm3,%xmm3 .byte 242,15,112,219,0 // pshuflw $0x0,%xmm3,%xmm3 .byte 102,15,112,219,80 // pshufd $0x50,%xmm3,%xmm3 .byte 102,15,219,29,208,9,0,0 // pand 0x9d0(%rip),%xmm3 # 1260 <_sk_xor__sse2_8bit+0x165> .byte 102,15,111,227 // movdqa %xmm3,%xmm4 .byte 102,15,213,224 // pmullw %xmm0,%xmm4 .byte 102,15,213,218 // pmullw %xmm2,%xmm3 .byte 102,15,253,211 // paddw %xmm3,%xmm2 .byte 102,15,253,224 // paddw %xmm0,%xmm4 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,212 // packuswb %xmm4,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_scale_u8_sse2_8bit .globl _sk_scale_u8_sse2_8bit FUNCTION(_sk_scale_u8_sse2_8bit) _sk_scale_u8_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 117,114 // jne 949 <_sk_scale_u8_sse2_8bit+0x8f> .byte 102,66,15,110,20,2 // movd (%rdx,%r8,1),%xmm2 .byte 102,15,96,208 // punpcklbw %xmm0,%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 102,15,114,242,24 // pslld $0x18,%xmm2 .byte 242,15,112,210,231 // pshuflw $0xe7,%xmm2,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,218,95 // pshufhw $0x5f,%xmm2,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,111,232 // movdqa %xmm0,%xmm5 .byte 102,15,96,236 // punpcklbw %xmm4,%xmm5 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,15,96,212 // punpcklbw %xmm4,%xmm2 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,57 // je 98c <_sk_scale_u8_sse2_8bit+0xd2> .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,21 // je 972 <_sk_scale_u8_sse2_8bit+0xb8> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 117,130 // jne 8e5 <_sk_scale_u8_sse2_8bit+0x2b> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,112,210,69 // pshufd $0x45,%xmm2,%xmm2 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,216 // movd %eax,%xmm3 .byte 102,15,96,216 // punpcklbw %xmm0,%xmm3 .byte 102,15,97,216 // punpcklwd %xmm0,%xmm3 .byte 242,15,16,211 // movsd %xmm3,%xmm2 .byte 233,89,255,255,255 // jmpq 8e5 <_sk_scale_u8_sse2_8bit+0x2b> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 233,75,255,255,255 // jmpq 8e5 <_sk_scale_u8_sse2_8bit+0x2b> HIDDEN _sk_lerp_1_float_sse2_8bit .globl _sk_lerp_1_float_sse2_8bit FUNCTION(_sk_lerp_1_float_sse2_8bit) _sk_lerp_1_float_sse2_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 243,15,16,16 // movss (%rax),%xmm2 .byte 243,15,89,21,32,8,0,0 // mulss 0x820(%rip),%xmm2 # 11c8 <_sk_xor__sse2_8bit+0xcd> .byte 243,15,44,194 // cvttss2si %xmm2,%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,0 // pshuflw $0x0,%xmm2,%xmm2 .byte 102,15,112,218,80 // pshufd $0x50,%xmm2,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,111,232 // movdqa %xmm0,%xmm5 .byte 102,15,96,236 // punpcklbw %xmm4,%xmm5 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,111,21,154,8,0,0 // movdqa 0x89a(%rip),%xmm2 # 1270 <_sk_xor__sse2_8bit+0x175> .byte 102,15,219,211 // pand %xmm3,%xmm2 .byte 102,15,111,242 // movdqa %xmm2,%xmm6 .byte 102,15,213,240 // pmullw %xmm0,%xmm6 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,240 // paddw %xmm0,%xmm6 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,214 // packuswb %xmm6,%xmm2 .byte 102,15,118,237 // pcmpeqd %xmm5,%xmm5 .byte 102,15,239,235 // pxor %xmm3,%xmm5 .byte 102,15,111,217 // movdqa %xmm1,%xmm3 .byte 102,15,111,241 // movdqa %xmm1,%xmm6 .byte 102,15,96,244 // punpcklbw %xmm4,%xmm6 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,111,197 // movdqa %xmm5,%xmm0 .byte 102,15,96,196 // punpcklbw %xmm4,%xmm0 .byte 102,15,104,236 // punpckhbw %xmm4,%xmm5 .byte 102,15,213,235 // pmullw %xmm3,%xmm5 .byte 102,15,213,198 // pmullw %xmm6,%xmm0 .byte 102,15,253,198 // paddw %xmm6,%xmm0 .byte 102,15,253,235 // paddw %xmm3,%xmm5 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,197 // packuswb %xmm5,%xmm0 .byte 102,15,252,194 // paddb %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_lerp_u8_sse2_8bit .globl _sk_lerp_u8_sse2_8bit FUNCTION(_sk_lerp_u8_sse2_8bit) _sk_lerp_u8_sse2_8bit: .byte 76,99,7 // movslq (%rdi),%r8 .byte 76,139,79,16 // mov 0x10(%rdi),%r9 .byte 72,173 // lods %ds:(%rsi),%rax .byte 72,99,72,8 // movslq 0x8(%rax),%rcx .byte 72,99,87,8 // movslq 0x8(%rdi),%rdx .byte 72,15,175,209 // imul %rcx,%rdx .byte 72,3,16 // add (%rax),%rdx .byte 77,133,201 // test %r9,%r9 .byte 15,133,180,0,0,0 // jne b1b <_sk_lerp_u8_sse2_8bit+0xd5> .byte 102,66,15,110,20,2 // movd (%rdx,%r8,1),%xmm2 .byte 102,15,96,208 // punpcklbw %xmm0,%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 102,15,114,242,24 // pslld $0x18,%xmm2 .byte 242,15,112,210,231 // pshuflw $0xe7,%xmm2,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,218,95 // pshufhw $0x5f,%xmm2,%xmm3 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 102,15,111,224 // movdqa %xmm0,%xmm4 .byte 102,15,96,226 // punpcklbw %xmm2,%xmm4 .byte 102,15,104,194 // punpckhbw %xmm2,%xmm0 .byte 102,15,111,235 // movdqa %xmm3,%xmm5 .byte 102,15,118,246 // pcmpeqd %xmm6,%xmm6 .byte 102,15,239,243 // pxor %xmm3,%xmm6 .byte 102,15,96,218 // punpcklbw %xmm2,%xmm3 .byte 102,15,104,234 // punpckhbw %xmm2,%xmm5 .byte 102,15,213,232 // pmullw %xmm0,%xmm5 .byte 102,15,213,220 // pmullw %xmm4,%xmm3 .byte 102,15,253,220 // paddw %xmm4,%xmm3 .byte 102,15,253,232 // paddw %xmm0,%xmm5 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,103,221 // packuswb %xmm5,%xmm3 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,96,226 // punpcklbw %xmm2,%xmm4 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,104,234 // punpckhbw %xmm2,%xmm5 .byte 102,15,111,198 // movdqa %xmm6,%xmm0 .byte 102,15,96,194 // punpcklbw %xmm2,%xmm0 .byte 102,15,104,242 // punpckhbw %xmm2,%xmm6 .byte 102,15,213,245 // pmullw %xmm5,%xmm6 .byte 102,15,213,196 // pmullw %xmm4,%xmm0 .byte 102,15,253,196 // paddw %xmm4,%xmm0 .byte 102,15,253,245 // paddw %xmm5,%xmm6 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,198 // packuswb %xmm6,%xmm0 .byte 102,15,252,195 // paddb %xmm3,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax .byte 65,128,225,3 // and $0x3,%r9b .byte 65,128,249,1 // cmp $0x1,%r9b .byte 116,61 // je b62 <_sk_lerp_u8_sse2_8bit+0x11c> .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 65,128,249,2 // cmp $0x2,%r9b .byte 116,25 // je b48 <_sk_lerp_u8_sse2_8bit+0x102> .byte 65,128,249,3 // cmp $0x3,%r9b .byte 15,133,60,255,255,255 // jne a75 <_sk_lerp_u8_sse2_8bit+0x2f> .byte 66,15,182,68,2,2 // movzbl 0x2(%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 102,15,112,210,69 // pshufd $0x45,%xmm2,%xmm2 .byte 66,15,183,4,2 // movzwl (%rdx,%r8,1),%eax .byte 102,15,110,216 // movd %eax,%xmm3 .byte 102,15,96,216 // punpcklbw %xmm0,%xmm3 .byte 102,15,97,216 // punpcklwd %xmm0,%xmm3 .byte 242,15,16,211 // movsd %xmm3,%xmm2 .byte 233,19,255,255,255 // jmpq a75 <_sk_lerp_u8_sse2_8bit+0x2f> .byte 66,15,182,4,2 // movzbl (%rdx,%r8,1),%eax .byte 102,15,110,208 // movd %eax,%xmm2 .byte 233,5,255,255,255 // jmpq a75 <_sk_lerp_u8_sse2_8bit+0x2f> HIDDEN _sk_move_src_dst_sse2_8bit .globl _sk_move_src_dst_sse2_8bit FUNCTION(_sk_move_src_dst_sse2_8bit) _sk_move_src_dst_sse2_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 255,224 // jmpq *%rax HIDDEN _sk_move_dst_src_sse2_8bit .globl _sk_move_dst_src_sse2_8bit FUNCTION(_sk_move_dst_src_sse2_8bit) _sk_move_dst_src_sse2_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_black_color_sse2_8bit .globl _sk_black_color_sse2_8bit FUNCTION(_sk_black_color_sse2_8bit) _sk_black_color_sse2_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,40,5,249,6,0,0 // movaps 0x6f9(%rip),%xmm0 # 1280 <_sk_xor__sse2_8bit+0x185> .byte 255,224 // jmpq *%rax HIDDEN _sk_white_color_sse2_8bit .globl _sk_white_color_sse2_8bit FUNCTION(_sk_white_color_sse2_8bit) _sk_white_color_sse2_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,118,192 // pcmpeqd %xmm0,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_clear_sse2_8bit .globl _sk_clear_sse2_8bit FUNCTION(_sk_clear_sse2_8bit) _sk_clear_sse2_8bit: .byte 72,173 // lods %ds:(%rsi),%rax .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcatop_sse2_8bit .globl _sk_srcatop_sse2_8bit FUNCTION(_sk_srcatop_sse2_8bit) _sk_srcatop_sse2_8bit: .byte 242,15,112,209,231 // pshuflw $0xe7,%xmm1,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,226,95 // pshufhw $0x5f,%xmm2,%xmm4 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,111,232 // movdqa %xmm0,%xmm5 .byte 102,15,96,235 // punpcklbw %xmm3,%xmm5 .byte 242,15,112,240,231 // pshuflw $0xe7,%xmm0,%xmm6 .byte 102,15,104,195 // punpckhbw %xmm3,%xmm0 .byte 102,15,111,212 // movdqa %xmm4,%xmm2 .byte 102,15,96,211 // punpcklbw %xmm3,%xmm2 .byte 102,15,104,227 // punpckhbw %xmm3,%xmm4 .byte 102,15,213,224 // pmullw %xmm0,%xmm4 .byte 102,15,213,213 // pmullw %xmm5,%xmm2 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,224 // paddw %xmm0,%xmm4 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,212 // packuswb %xmm4,%xmm2 .byte 243,15,112,198,231 // pshufhw $0xe7,%xmm6,%xmm0 .byte 102,15,112,192,232 // pshufd $0xe8,%xmm0,%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 242,15,112,192,95 // pshuflw $0x5f,%xmm0,%xmm0 .byte 243,15,112,192,95 // pshufhw $0x5f,%xmm0,%xmm0 .byte 102,15,118,228 // pcmpeqd %xmm4,%xmm4 .byte 102,15,239,224 // pxor %xmm0,%xmm4 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,111,241 // movdqa %xmm1,%xmm6 .byte 102,15,96,243 // punpcklbw %xmm3,%xmm6 .byte 102,15,104,235 // punpckhbw %xmm3,%xmm5 .byte 102,15,111,196 // movdqa %xmm4,%xmm0 .byte 102,15,96,195 // punpcklbw %xmm3,%xmm0 .byte 102,15,104,227 // punpckhbw %xmm3,%xmm4 .byte 102,15,213,229 // pmullw %xmm5,%xmm4 .byte 102,15,213,198 // pmullw %xmm6,%xmm0 .byte 102,15,253,198 // paddw %xmm6,%xmm0 .byte 102,15,253,229 // paddw %xmm5,%xmm4 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,196 // packuswb %xmm4,%xmm0 .byte 102,15,252,194 // paddb %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstatop_sse2_8bit .globl _sk_dstatop_sse2_8bit FUNCTION(_sk_dstatop_sse2_8bit) _sk_dstatop_sse2_8bit: .byte 242,15,112,208,231 // pshuflw $0xe7,%xmm0,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,210,95 // pshufhw $0x5f,%xmm2,%xmm2 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 242,15,112,233,231 // pshuflw $0xe7,%xmm1,%xmm5 .byte 102,15,111,241 // movdqa %xmm1,%xmm6 .byte 102,15,96,243 // punpcklbw %xmm3,%xmm6 .byte 102,15,111,250 // movdqa %xmm2,%xmm7 .byte 102,15,96,251 // punpcklbw %xmm3,%xmm7 .byte 102,15,213,254 // pmullw %xmm6,%xmm7 .byte 102,15,253,254 // paddw %xmm6,%xmm7 .byte 102,15,104,227 // punpckhbw %xmm3,%xmm4 .byte 102,15,104,211 // punpckhbw %xmm3,%xmm2 .byte 102,15,213,212 // pmullw %xmm4,%xmm2 .byte 102,15,253,212 // paddw %xmm4,%xmm2 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,113,215,8 // psrlw $0x8,%xmm7 .byte 102,15,103,250 // packuswb %xmm2,%xmm7 .byte 243,15,112,213,231 // pshufhw $0xe7,%xmm5,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,210,95 // pshufhw $0x5f,%xmm2,%xmm2 .byte 102,15,118,228 // pcmpeqd %xmm4,%xmm4 .byte 102,15,239,226 // pxor %xmm2,%xmm4 .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,96,211 // punpcklbw %xmm3,%xmm2 .byte 102,15,104,195 // punpckhbw %xmm3,%xmm0 .byte 102,15,111,236 // movdqa %xmm4,%xmm5 .byte 102,15,96,235 // punpcklbw %xmm3,%xmm5 .byte 102,15,104,227 // punpckhbw %xmm3,%xmm4 .byte 102,15,213,224 // pmullw %xmm0,%xmm4 .byte 102,15,213,234 // pmullw %xmm2,%xmm5 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,224 // paddw %xmm0,%xmm4 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,212 // packuswb %xmm4,%xmm2 .byte 102,15,252,215 // paddb %xmm7,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_srcin_sse2_8bit .globl _sk_srcin_sse2_8bit FUNCTION(_sk_srcin_sse2_8bit) _sk_srcin_sse2_8bit: .byte 242,15,112,209,231 // pshuflw $0xe7,%xmm1,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,218,95 // pshufhw $0x5f,%xmm2,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,96,212 // punpcklbw %xmm4,%xmm2 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,111,235 // movdqa %xmm3,%xmm5 .byte 102,15,96,236 // punpcklbw %xmm4,%xmm5 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,213,234 // pmullw %xmm2,%xmm5 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_dstin_sse2_8bit .globl _sk_dstin_sse2_8bit FUNCTION(_sk_dstin_sse2_8bit) _sk_dstin_sse2_8bit: .byte 242,15,112,192,231 // pshuflw $0xe7,%xmm0,%xmm0 .byte 243,15,112,192,231 // pshufhw $0xe7,%xmm0,%xmm0 .byte 102,15,112,192,232 // pshufd $0xe8,%xmm0,%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 242,15,112,192,95 // pshuflw $0x5f,%xmm0,%xmm0 .byte 243,15,112,208,95 // pshufhw $0x5f,%xmm0,%xmm2 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,96,235 // punpcklbw %xmm3,%xmm5 .byte 102,15,104,227 // punpckhbw %xmm3,%xmm4 .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 102,15,96,195 // punpcklbw %xmm3,%xmm0 .byte 102,15,104,211 // punpckhbw %xmm3,%xmm2 .byte 102,15,213,212 // pmullw %xmm4,%xmm2 .byte 102,15,213,197 // pmullw %xmm5,%xmm0 .byte 102,15,253,197 // paddw %xmm5,%xmm0 .byte 102,15,253,212 // paddw %xmm4,%xmm2 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,194 // packuswb %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcout_sse2_8bit .globl _sk_srcout_sse2_8bit FUNCTION(_sk_srcout_sse2_8bit) _sk_srcout_sse2_8bit: .byte 242,15,112,209,231 // pshuflw $0xe7,%xmm1,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,210,95 // pshufhw $0x5f,%xmm2,%xmm2 .byte 102,15,118,219 // pcmpeqd %xmm3,%xmm3 .byte 102,15,239,218 // pxor %xmm2,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,96,212 // punpcklbw %xmm4,%xmm2 .byte 102,15,104,196 // punpckhbw %xmm4,%xmm0 .byte 102,15,111,235 // movdqa %xmm3,%xmm5 .byte 102,15,96,236 // punpcklbw %xmm4,%xmm5 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,216 // pmullw %xmm0,%xmm3 .byte 102,15,213,234 // pmullw %xmm2,%xmm5 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,216 // paddw %xmm0,%xmm3 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,211 // packuswb %xmm3,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_dstout_sse2_8bit .globl _sk_dstout_sse2_8bit FUNCTION(_sk_dstout_sse2_8bit) _sk_dstout_sse2_8bit: .byte 242,15,112,192,231 // pshuflw $0xe7,%xmm0,%xmm0 .byte 243,15,112,192,231 // pshufhw $0xe7,%xmm0,%xmm0 .byte 102,15,112,192,232 // pshufd $0xe8,%xmm0,%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 242,15,112,192,95 // pshuflw $0x5f,%xmm0,%xmm0 .byte 243,15,112,192,95 // pshufhw $0x5f,%xmm0,%xmm0 .byte 102,15,118,210 // pcmpeqd %xmm2,%xmm2 .byte 102,15,239,208 // pxor %xmm0,%xmm2 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,96,235 // punpcklbw %xmm3,%xmm5 .byte 102,15,104,227 // punpckhbw %xmm3,%xmm4 .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 102,15,96,195 // punpcklbw %xmm3,%xmm0 .byte 102,15,104,211 // punpckhbw %xmm3,%xmm2 .byte 102,15,213,212 // pmullw %xmm4,%xmm2 .byte 102,15,213,197 // pmullw %xmm5,%xmm0 .byte 102,15,253,197 // paddw %xmm5,%xmm0 .byte 102,15,253,212 // paddw %xmm4,%xmm2 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,194 // packuswb %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_srcover_sse2_8bit .globl _sk_srcover_sse2_8bit FUNCTION(_sk_srcover_sse2_8bit) _sk_srcover_sse2_8bit: .byte 242,15,112,208,231 // pshuflw $0xe7,%xmm0,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,210,95 // pshufhw $0x5f,%xmm2,%xmm2 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,252,193 // paddb %xmm1,%xmm0 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,96,235 // punpcklbw %xmm3,%xmm5 .byte 102,15,104,227 // punpckhbw %xmm3,%xmm4 .byte 102,15,111,242 // movdqa %xmm2,%xmm6 .byte 102,15,96,243 // punpcklbw %xmm3,%xmm6 .byte 102,15,104,211 // punpckhbw %xmm3,%xmm2 .byte 102,15,213,212 // pmullw %xmm4,%xmm2 .byte 102,15,213,245 // pmullw %xmm5,%xmm6 .byte 102,15,253,245 // paddw %xmm5,%xmm6 .byte 102,15,253,212 // paddw %xmm4,%xmm2 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,103,242 // packuswb %xmm2,%xmm6 .byte 102,15,248,198 // psubb %xmm6,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_dstover_sse2_8bit .globl _sk_dstover_sse2_8bit FUNCTION(_sk_dstover_sse2_8bit) _sk_dstover_sse2_8bit: .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 242,15,112,193,231 // pshuflw $0xe7,%xmm1,%xmm0 .byte 243,15,112,192,231 // pshufhw $0xe7,%xmm0,%xmm0 .byte 102,15,112,192,232 // pshufd $0xe8,%xmm0,%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 242,15,112,192,95 // pshuflw $0x5f,%xmm0,%xmm0 .byte 243,15,112,216,95 // pshufhw $0x5f,%xmm0,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,111,234 // movdqa %xmm2,%xmm5 .byte 102,15,96,236 // punpcklbw %xmm4,%xmm5 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,252,194 // paddb %xmm2,%xmm0 .byte 102,15,104,212 // punpckhbw %xmm4,%xmm2 .byte 102,15,111,243 // movdqa %xmm3,%xmm6 .byte 102,15,96,244 // punpcklbw %xmm4,%xmm6 .byte 102,15,104,220 // punpckhbw %xmm4,%xmm3 .byte 102,15,213,218 // pmullw %xmm2,%xmm3 .byte 102,15,213,245 // pmullw %xmm5,%xmm6 .byte 102,15,253,245 // paddw %xmm5,%xmm6 .byte 102,15,253,218 // paddw %xmm2,%xmm3 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,103,243 // packuswb %xmm3,%xmm6 .byte 102,15,248,198 // psubb %xmm6,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_modulate_sse2_8bit .globl _sk_modulate_sse2_8bit FUNCTION(_sk_modulate_sse2_8bit) _sk_modulate_sse2_8bit: .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,96,211 // punpcklbw %xmm3,%xmm2 .byte 102,15,104,195 // punpckhbw %xmm3,%xmm0 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,96,235 // punpcklbw %xmm3,%xmm5 .byte 102,15,104,227 // punpckhbw %xmm3,%xmm4 .byte 102,15,213,224 // pmullw %xmm0,%xmm4 .byte 102,15,213,234 // pmullw %xmm2,%xmm5 .byte 102,15,253,213 // paddw %xmm5,%xmm2 .byte 102,15,253,224 // paddw %xmm0,%xmm4 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,212 // packuswb %xmm4,%xmm2 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_multiply_sse2_8bit .globl _sk_multiply_sse2_8bit FUNCTION(_sk_multiply_sse2_8bit) _sk_multiply_sse2_8bit: .byte 242,15,112,209,231 // pshuflw $0xe7,%xmm1,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,242,95 // pshufhw $0x5f,%xmm2,%xmm6 .byte 102,15,118,237 // pcmpeqd %xmm5,%xmm5 .byte 102,15,239,245 // pxor %xmm5,%xmm6 .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 .byte 102,15,111,216 // movdqa %xmm0,%xmm3 .byte 102,65,15,96,216 // punpcklbw %xmm8,%xmm3 .byte 242,15,112,248,231 // pshuflw $0xe7,%xmm0,%xmm7 .byte 102,65,15,104,192 // punpckhbw %xmm8,%xmm0 .byte 102,15,111,230 // movdqa %xmm6,%xmm4 .byte 102,65,15,96,224 // punpcklbw %xmm8,%xmm4 .byte 102,65,15,104,240 // punpckhbw %xmm8,%xmm6 .byte 102,15,213,240 // pmullw %xmm0,%xmm6 .byte 102,15,213,227 // pmullw %xmm3,%xmm4 .byte 102,15,253,227 // paddw %xmm3,%xmm4 .byte 102,15,253,240 // paddw %xmm0,%xmm6 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,103,230 // packuswb %xmm6,%xmm4 .byte 243,15,112,247,231 // pshufhw $0xe7,%xmm7,%xmm6 .byte 102,15,112,246,232 // pshufd $0xe8,%xmm6,%xmm6 .byte 102,15,96,246 // punpcklbw %xmm6,%xmm6 .byte 242,15,112,246,95 // pshuflw $0x5f,%xmm6,%xmm6 .byte 243,15,112,214,95 // pshufhw $0x5f,%xmm6,%xmm2 .byte 102,15,239,213 // pxor %xmm5,%xmm2 .byte 102,15,111,249 // movdqa %xmm1,%xmm7 .byte 102,15,111,241 // movdqa %xmm1,%xmm6 .byte 102,65,15,96,240 // punpcklbw %xmm8,%xmm6 .byte 102,65,15,104,248 // punpckhbw %xmm8,%xmm7 .byte 102,15,111,234 // movdqa %xmm2,%xmm5 .byte 102,65,15,96,232 // punpcklbw %xmm8,%xmm5 .byte 102,65,15,104,208 // punpckhbw %xmm8,%xmm2 .byte 102,15,213,215 // pmullw %xmm7,%xmm2 .byte 102,15,213,238 // pmullw %xmm6,%xmm5 .byte 102,15,253,238 // paddw %xmm6,%xmm5 .byte 102,15,253,215 // paddw %xmm7,%xmm2 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,103,234 // packuswb %xmm2,%xmm5 .byte 102,15,252,236 // paddb %xmm4,%xmm5 .byte 102,15,213,248 // pmullw %xmm0,%xmm7 .byte 102,15,213,243 // pmullw %xmm3,%xmm6 .byte 102,15,253,243 // paddw %xmm3,%xmm6 .byte 102,15,253,248 // paddw %xmm0,%xmm7 .byte 102,15,113,215,8 // psrlw $0x8,%xmm7 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,103,247 // packuswb %xmm7,%xmm6 .byte 102,15,252,238 // paddb %xmm6,%xmm5 .byte 72,173 // lods %ds:(%rsi),%rax .byte 102,15,111,197 // movdqa %xmm5,%xmm0 .byte 255,224 // jmpq *%rax HIDDEN _sk_screen_sse2_8bit .globl _sk_screen_sse2_8bit FUNCTION(_sk_screen_sse2_8bit) _sk_screen_sse2_8bit: .byte 102,15,118,210 // pcmpeqd %xmm2,%xmm2 .byte 102,15,239,208 // pxor %xmm0,%xmm2 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,111,226 // movdqa %xmm2,%xmm4 .byte 102,15,96,227 // punpcklbw %xmm3,%xmm4 .byte 102,15,104,211 // punpckhbw %xmm3,%xmm2 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,111,241 // movdqa %xmm1,%xmm6 .byte 102,15,96,243 // punpcklbw %xmm3,%xmm6 .byte 102,15,104,235 // punpckhbw %xmm3,%xmm5 .byte 102,15,213,234 // pmullw %xmm2,%xmm5 .byte 102,15,213,244 // pmullw %xmm4,%xmm6 .byte 102,15,253,230 // paddw %xmm6,%xmm4 .byte 102,15,253,234 // paddw %xmm2,%xmm5 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,103,229 // packuswb %xmm5,%xmm4 .byte 102,15,252,196 // paddb %xmm4,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax HIDDEN _sk_xor__sse2_8bit .globl _sk_xor__sse2_8bit FUNCTION(_sk_xor__sse2_8bit) _sk_xor__sse2_8bit: .byte 242,15,112,209,231 // pshuflw $0xe7,%xmm1,%xmm2 .byte 243,15,112,210,231 // pshufhw $0xe7,%xmm2,%xmm2 .byte 102,15,112,210,232 // pshufd $0xe8,%xmm2,%xmm2 .byte 102,15,96,210 // punpcklbw %xmm2,%xmm2 .byte 242,15,112,210,95 // pshuflw $0x5f,%xmm2,%xmm2 .byte 243,15,112,234,95 // pshufhw $0x5f,%xmm2,%xmm5 .byte 102,15,118,228 // pcmpeqd %xmm4,%xmm4 .byte 102,15,239,236 // pxor %xmm4,%xmm5 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,111,240 // movdqa %xmm0,%xmm6 .byte 102,15,96,243 // punpcklbw %xmm3,%xmm6 .byte 242,15,112,248,231 // pshuflw $0xe7,%xmm0,%xmm7 .byte 102,15,104,195 // punpckhbw %xmm3,%xmm0 .byte 102,15,111,213 // movdqa %xmm5,%xmm2 .byte 102,15,96,211 // punpcklbw %xmm3,%xmm2 .byte 102,15,104,235 // punpckhbw %xmm3,%xmm5 .byte 102,15,213,232 // pmullw %xmm0,%xmm5 .byte 102,15,213,214 // pmullw %xmm6,%xmm2 .byte 102,15,253,214 // paddw %xmm6,%xmm2 .byte 102,15,253,232 // paddw %xmm0,%xmm5 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,103,213 // packuswb %xmm5,%xmm2 .byte 243,15,112,199,231 // pshufhw $0xe7,%xmm7,%xmm0 .byte 102,15,112,192,232 // pshufd $0xe8,%xmm0,%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 242,15,112,192,95 // pshuflw $0x5f,%xmm0,%xmm0 .byte 243,15,112,232,95 // pshufhw $0x5f,%xmm0,%xmm5 .byte 102,15,239,236 // pxor %xmm4,%xmm5 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,111,241 // movdqa %xmm1,%xmm6 .byte 102,15,96,243 // punpcklbw %xmm3,%xmm6 .byte 102,15,104,227 // punpckhbw %xmm3,%xmm4 .byte 102,15,111,197 // movdqa %xmm5,%xmm0 .byte 102,15,96,195 // punpcklbw %xmm3,%xmm0 .byte 102,15,104,235 // punpckhbw %xmm3,%xmm5 .byte 102,15,213,236 // pmullw %xmm4,%xmm5 .byte 102,15,213,198 // pmullw %xmm6,%xmm0 .byte 102,15,253,198 // paddw %xmm6,%xmm0 .byte 102,15,253,236 // paddw %xmm4,%xmm5 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,113,208,8 // psrlw $0x8,%xmm0 .byte 102,15,103,197 // packuswb %xmm5,%xmm0 .byte 102,15,252,194 // paddb %xmm2,%xmm0 .byte 72,173 // lods %ds:(%rsi),%rax .byte 255,224 // jmpq *%rax BALIGN4 .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 1207 <_sk_xor__sse2_8bit+0x10c> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 120b <_sk_xor__sse2_8bit+0x110> .byte 0,0 // add %al,(%rax) .byte 127,67 // jg 120f <_sk_xor__sse2_8bit+0x114> BALIGN16 .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 1,1 // add %eax,(%rcx) .byte 1,0 // add %eax,(%rax) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 255,0 // incl (%rax) .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%rax) .byte 0,255 // add %bh,%bh #elif defined(__i386__) BALIGN32 HIDDEN _sk_start_pipeline_sse2 .globl _sk_start_pipeline_sse2 FUNCTION(_sk_start_pipeline_sse2) _sk_start_pipeline_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,92 // sub $0x5c,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 59,69,20 // cmp 0x14(%ebp),%eax .byte 115,118 // jae 87 <_sk_start_pipeline_sse2+0x87> .byte 139,85,16 // mov 0x10(%ebp),%edx .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,117,24 // mov 0x18(%ebp),%esi .byte 139,62 // mov (%esi),%edi .byte 131,198,4 // add $0x4,%esi .byte 141,73,4 // lea 0x4(%ecx),%ecx .byte 137,77,240 // mov %ecx,-0x10(%ebp) .byte 57,85,240 // cmp %edx,-0x10(%ebp) .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 137,77,152 // mov %ecx,-0x68(%ebp) .byte 137,69,236 // mov %eax,-0x14(%ebp) .byte 137,69,156 // mov %eax,-0x64(%ebp) .byte 199,69,160,0,0,0,0 // movl $0x0,-0x60(%ebp) .byte 139,69,28 // mov 0x1c(%ebp),%eax .byte 137,69,164 // mov %eax,-0x5c(%ebp) .byte 137,200 // mov %ecx,%eax .byte 141,93,152 // lea -0x68(%ebp),%ebx .byte 119,29 // ja 65 <_sk_start_pipeline_sse2+0x65> .byte 131,236,8 // sub $0x8,%esp .byte 86 // push %esi .byte 83 // push %ebx .byte 255,215 // call *%edi .byte 139,85,16 // mov 0x10(%ebp),%edx .byte 131,196,16 // add $0x10,%esp .byte 139,77,152 // mov -0x68(%ebp),%ecx .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 137,69,152 // mov %eax,-0x68(%ebp) .byte 131,193,8 // add $0x8,%ecx .byte 57,209 // cmp %edx,%ecx .byte 118,227 // jbe 48 <_sk_start_pipeline_sse2+0x48> .byte 137,209 // mov %edx,%ecx .byte 41,193 // sub %eax,%ecx .byte 116,19 // je 7e <_sk_start_pipeline_sse2+0x7e> .byte 137,77,160 // mov %ecx,-0x60(%ebp) .byte 131,236,8 // sub $0x8,%esp .byte 86 // push %esi .byte 141,69,152 // lea -0x68(%ebp),%eax .byte 80 // push %eax .byte 255,215 // call *%edi .byte 139,85,16 // mov 0x10(%ebp),%edx .byte 131,196,16 // add $0x10,%esp .byte 139,69,236 // mov -0x14(%ebp),%eax .byte 64 // inc %eax .byte 59,69,20 // cmp 0x14(%ebp),%eax .byte 117,158 // jne 25 <_sk_start_pipeline_sse2+0x25> .byte 131,196,92 // add $0x5c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_just_return_sse2 .globl _sk_just_return_sse2 FUNCTION(_sk_just_return_sse2) _sk_just_return_sse2: .byte 195 // ret HIDDEN _sk_seed_shader_sse2 .globl _sk_seed_shader_sse2 FUNCTION(_sk_seed_shader_sse2) _sk_seed_shader_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 9a <_sk_seed_shader_sse2+0xa> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,85,8 // mov 0x8(%ebp),%edx .byte 139,114,12 // mov 0xc(%edx),%esi .byte 102,15,110,2 // movd (%edx),%xmm0 .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 .byte 15,91,200 // cvtdq2ps %xmm0,%xmm1 .byte 15,40,144,38,112,0,0 // movaps 0x7026(%eax),%xmm2 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 15,16,6 // movups (%esi),%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 102,15,110,74,4 // movd 0x4(%edx),%xmm1 .byte 102,15,112,201,0 // pshufd $0x0,%xmm1,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 141,113,4 // lea 0x4(%ecx),%esi .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 15,41,82,64 // movaps %xmm2,0x40(%edx) .byte 15,41,82,48 // movaps %xmm2,0x30(%edx) .byte 15,41,82,32 // movaps %xmm2,0x20(%edx) .byte 15,41,82,16 // movaps %xmm2,0x10(%edx) .byte 131,236,8 // sub $0x8,%esp .byte 15,40,144,54,112,0,0 // movaps 0x7036(%eax),%xmm2 .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 86 // push %esi .byte 82 // push %edx .byte 255,17 // call *(%ecx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_dither_sse2 .globl _sk_dither_sse2 FUNCTION(_sk_dither_sse2) _sk_dither_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 131,236,36 // sub $0x24,%esp .byte 15,41,93,216 // movaps %xmm3,-0x28(%ebp) .byte 15,41,85,232 // movaps %xmm2,-0x18(%ebp) .byte 15,40,217 // movaps %xmm1,%xmm3 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 232,0,0,0,0 // call 117 <_sk_dither_sse2+0x1a> .byte 89 // pop %ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 139,80,12 // mov 0xc(%eax),%edx .byte 102,15,110,32 // movd (%eax),%xmm4 .byte 102,15,112,228,0 // pshufd $0x0,%xmm4,%xmm4 .byte 243,15,111,106,32 // movdqu 0x20(%edx),%xmm5 .byte 102,15,254,236 // paddd %xmm4,%xmm5 .byte 102,15,110,96,4 // movd 0x4(%eax),%xmm4 .byte 102,15,112,252,0 // pshufd $0x0,%xmm4,%xmm7 .byte 102,15,239,253 // pxor %xmm5,%xmm7 .byte 102,15,111,177,201,111,0,0 // movdqa 0x6fc9(%ecx),%xmm6 .byte 102,15,111,207 // movdqa %xmm7,%xmm1 .byte 102,15,219,206 // pand %xmm6,%xmm1 .byte 102,15,219,245 // pand %xmm5,%xmm6 .byte 102,15,111,129,233,111,0,0 // movdqa 0x6fe9(%ecx),%xmm0 .byte 102,15,111,231 // movdqa %xmm7,%xmm4 .byte 102,15,219,224 // pand %xmm0,%xmm4 .byte 102,15,219,197 // pand %xmm5,%xmm0 .byte 102,15,219,185,217,111,0,0 // pand 0x6fd9(%ecx),%xmm7 .byte 102,15,219,169,217,111,0,0 // pand 0x6fd9(%ecx),%xmm5 .byte 102,15,114,246,4 // pslld $0x4,%xmm6 .byte 102,15,254,192 // paddd %xmm0,%xmm0 .byte 102,15,235,198 // por %xmm6,%xmm0 .byte 102,15,114,213,2 // psrld $0x2,%xmm5 .byte 102,15,235,197 // por %xmm5,%xmm0 .byte 102,15,114,241,5 // pslld $0x5,%xmm1 .byte 102,15,114,244,2 // pslld $0x2,%xmm4 .byte 102,15,235,225 // por %xmm1,%xmm4 .byte 102,15,235,224 // por %xmm0,%xmm4 .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 102,15,114,215,1 // psrld $0x1,%xmm7 .byte 102,15,235,231 // por %xmm7,%xmm4 .byte 15,91,196 // cvtdq2ps %xmm4,%xmm0 .byte 15,89,129,249,111,0,0 // mulps 0x6ff9(%ecx),%xmm0 .byte 15,88,129,9,112,0,0 // addps 0x7009(%ecx),%xmm0 .byte 243,15,16,14 // movss (%esi),%xmm1 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,88,209 // addps %xmm1,%xmm2 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 15,88,77,232 // addps -0x18(%ebp),%xmm1 .byte 15,40,69,216 // movaps -0x28(%ebp),%xmm0 .byte 15,93,208 // minps %xmm0,%xmm2 .byte 102,15,239,237 // pxor %xmm5,%xmm5 .byte 15,95,234 // maxps %xmm2,%xmm5 .byte 15,93,216 // minps %xmm0,%xmm3 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,95,227 // maxps %xmm3,%xmm4 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 15,93,200 // minps %xmm0,%xmm1 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 15,95,209 // maxps %xmm1,%xmm2 .byte 141,74,8 // lea 0x8(%edx),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 81 // push %ecx .byte 80 // push %eax .byte 255,82,4 // call *0x4(%edx) .byte 131,196,52 // add $0x34,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_uniform_color_sse2 .globl _sk_uniform_color_sse2 FUNCTION(_sk_uniform_color_sse2) _sk_uniform_color_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,1 // movss (%ecx),%xmm0 .byte 243,15,16,73,4 // movss 0x4(%ecx),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,81,8 // movss 0x8(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,89,12 // movss 0xc(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_black_color_sse2 .globl _sk_black_color_sse2 FUNCTION(_sk_black_color_sse2) _sk_black_color_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 257 <_sk_black_color_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,152,217,110,0,0 // movaps 0x6ed9(%eax),%xmm3 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 82 // push %edx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_white_color_sse2 .globl _sk_white_color_sse2 FUNCTION(_sk_white_color_sse2) _sk_white_color_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 287 <_sk_white_color_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,128,185,110,0,0 // movaps 0x6eb9(%eax),%xmm0 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 82 // push %edx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_load_rgba_sse2 .globl _sk_load_rgba_sse2 FUNCTION(_sk_load_rgba_sse2) _sk_load_rgba_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 15,16,1 // movups (%ecx),%xmm0 .byte 15,16,73,16 // movups 0x10(%ecx),%xmm1 .byte 15,16,81,32 // movups 0x20(%ecx),%xmm2 .byte 15,16,89,48 // movups 0x30(%ecx),%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_store_rgba_sse2 .globl _sk_store_rgba_sse2 FUNCTION(_sk_store_rgba_sse2) _sk_store_rgba_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,17 // mov (%ecx),%edx .byte 15,17,2 // movups %xmm0,(%edx) .byte 15,17,74,16 // movups %xmm1,0x10(%edx) .byte 15,17,82,32 // movups %xmm2,0x20(%edx) .byte 15,17,90,48 // movups %xmm3,0x30(%edx) .byte 141,81,8 // lea 0x8(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 80 // push %eax .byte 255,81,4 // call *0x4(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_clear_sse2 .globl _sk_clear_sse2 FUNCTION(_sk_clear_sse2) _sk_clear_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_srcatop_sse2 .globl _sk_srcatop_sse2 FUNCTION(_sk_srcatop_sse2) _sk_srcatop_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 336 <_sk_srcatop_sse2+0xb> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,97,64 // movaps 0x40(%ecx),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,40,170,26,110,0,0 // movaps 0x6e1a(%edx),%xmm5 .byte 15,92,235 // subps %xmm3,%xmm5 .byte 15,40,113,16 // movaps 0x10(%ecx),%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,40,113,32 // movaps 0x20(%ecx),%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,40,113,48 // movaps 0x30(%ecx),%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,88,221 // addps %xmm5,%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_dstatop_sse2 .globl _sk_dstatop_sse2 FUNCTION(_sk_dstatop_sse2) _sk_dstatop_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 395 <_sk_dstatop_sse2+0xb> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,105,64 // movaps 0x40(%ecx),%xmm5 .byte 15,40,113,16 // movaps 0x10(%ecx),%xmm6 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,40,162,203,109,0,0 // movaps 0x6dcb(%edx),%xmm4 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,40,113,32 // movaps 0x20(%ecx),%xmm6 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 15,40,113,48 // movaps 0x30(%ecx),%xmm6 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,89,235 // mulps %xmm3,%xmm5 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_srcin_sse2 .globl _sk_srcin_sse2 FUNCTION(_sk_srcin_sse2) _sk_srcin_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,97,64 // movaps 0x40(%ecx),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_dstin_sse2 .globl _sk_dstin_sse2 FUNCTION(_sk_dstin_sse2) _sk_dstin_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,65,16 // movaps 0x10(%ecx),%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,40,73,32 // movaps 0x20(%ecx),%xmm1 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,40,81,48 // movaps 0x30(%ecx),%xmm2 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 15,89,89,64 // mulps 0x40(%ecx),%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_srcout_sse2 .globl _sk_srcout_sse2 FUNCTION(_sk_srcout_sse2) _sk_srcout_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 456 <_sk_srcout_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,85,8 // mov 0x8(%ebp),%edx .byte 15,40,160,26,109,0,0 // movaps 0x6d1a(%eax),%xmm4 .byte 15,92,98,64 // subps 0x40(%edx),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 82 // push %edx .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_dstout_sse2 .globl _sk_dstout_sse2 FUNCTION(_sk_dstout_sse2) _sk_dstout_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 48e <_sk_dstout_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,85,8 // mov 0x8(%ebp),%edx .byte 15,40,160,242,108,0,0 // movaps 0x6cf2(%eax),%xmm4 .byte 15,92,227 // subps %xmm3,%xmm4 .byte 15,40,66,16 // movaps 0x10(%edx),%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,40,74,32 // movaps 0x20(%edx),%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,40,82,48 // movaps 0x30(%edx),%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,89,98,64 // mulps 0x40(%edx),%xmm4 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 80 // push %eax .byte 82 // push %edx .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_srcover_sse2 .globl _sk_srcover_sse2 FUNCTION(_sk_srcover_sse2) _sk_srcover_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 4d5 <_sk_srcover_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,85,8 // mov 0x8(%ebp),%edx .byte 15,40,160,187,108,0,0 // movaps 0x6cbb(%eax),%xmm4 .byte 15,92,227 // subps %xmm3,%xmm4 .byte 15,40,106,16 // movaps 0x10(%edx),%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 15,40,106,32 // movaps 0x20(%edx),%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,40,106,48 // movaps 0x30(%edx),%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,88,213 // addps %xmm5,%xmm2 .byte 15,89,98,64 // mulps 0x40(%edx),%xmm4 .byte 15,88,220 // addps %xmm4,%xmm3 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 82 // push %edx .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_dstover_sse2 .globl _sk_dstover_sse2 FUNCTION(_sk_dstover_sse2) _sk_dstover_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 525 <_sk_dstover_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,85,8 // mov 0x8(%ebp),%edx .byte 15,40,106,64 // movaps 0x40(%edx),%xmm5 .byte 15,40,160,123,108,0,0 // movaps 0x6c7b(%eax),%xmm4 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,66,16 // addps 0x10(%edx),%xmm0 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,74,32 // addps 0x20(%edx),%xmm1 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,82,48 // addps 0x30(%edx),%xmm2 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 80 // push %eax .byte 82 // push %edx .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_modulate_sse2 .globl _sk_modulate_sse2 FUNCTION(_sk_modulate_sse2) _sk_modulate_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,89,65,16 // mulps 0x10(%ecx),%xmm0 .byte 15,89,73,32 // mulps 0x20(%ecx),%xmm1 .byte 15,89,81,48 // mulps 0x30(%ecx),%xmm2 .byte 15,89,89,64 // mulps 0x40(%ecx),%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_multiply_sse2 .globl _sk_multiply_sse2 FUNCTION(_sk_multiply_sse2) _sk_multiply_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,56 // sub $0x38,%esp .byte 15,41,85,216 // movaps %xmm2,-0x28(%ebp) .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 232,0,0,0,0 // call 5a4 <_sk_multiply_sse2+0x12> .byte 89 // pop %ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,80,64 // movaps 0x40(%eax),%xmm2 .byte 15,41,85,200 // movaps %xmm2,-0x38(%ebp) .byte 15,40,129,12,108,0,0 // movaps 0x6c0c(%ecx),%xmm0 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,92,242 // subps %xmm2,%xmm6 .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 15,89,253 // mulps %xmm5,%xmm7 .byte 15,92,195 // subps %xmm3,%xmm0 .byte 15,40,80,16 // movaps 0x10(%eax),%xmm2 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,89,226 // mulps %xmm2,%xmm4 .byte 15,88,231 // addps %xmm7,%xmm4 .byte 15,89,234 // mulps %xmm2,%xmm5 .byte 15,88,236 // addps %xmm4,%xmm5 .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 15,89,209 // mulps %xmm1,%xmm2 .byte 15,40,96,32 // movaps 0x20(%eax),%xmm4 .byte 15,40,248 // movaps %xmm0,%xmm7 .byte 15,89,252 // mulps %xmm4,%xmm7 .byte 15,88,250 // addps %xmm2,%xmm7 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,207 // addps %xmm7,%xmm1 .byte 15,41,77,232 // movaps %xmm1,-0x18(%ebp) .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,40,85,216 // movaps -0x28(%ebp),%xmm2 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,40,96,48 // movaps 0x30(%eax),%xmm4 .byte 15,40,248 // movaps %xmm0,%xmm7 .byte 15,89,252 // mulps %xmm4,%xmm7 .byte 15,88,249 // addps %xmm1,%xmm7 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,215 // addps %xmm7,%xmm2 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,40,77,200 // movaps -0x38(%ebp),%xmm1 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 15,88,216 // addps %xmm0,%xmm3 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,40,77,232 // movaps -0x18(%ebp),%xmm1 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 131,196,72 // add $0x48,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_plus__sse2 .globl _sk_plus__sse2 FUNCTION(_sk_plus__sse2) _sk_plus__sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,88,65,16 // addps 0x10(%ecx),%xmm0 .byte 15,88,73,32 // addps 0x20(%ecx),%xmm1 .byte 15,88,81,48 // addps 0x30(%ecx),%xmm2 .byte 15,88,89,64 // addps 0x40(%ecx),%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_screen_sse2 .globl _sk_screen_sse2 FUNCTION(_sk_screen_sse2) _sk_screen_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,105,16 // movaps 0x10(%ecx),%xmm5 .byte 15,40,113,32 // movaps 0x20(%ecx),%xmm6 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 15,89,232 // mulps %xmm0,%xmm5 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 15,40,238 // movaps %xmm6,%xmm5 .byte 15,88,233 // addps %xmm1,%xmm5 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,92,238 // subps %xmm6,%xmm5 .byte 15,40,65,48 // movaps 0x30(%ecx),%xmm0 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,88,242 // addps %xmm2,%xmm6 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,92,240 // subps %xmm0,%xmm6 .byte 15,40,65,64 // movaps 0x40(%ecx),%xmm0 .byte 15,40,248 // movaps %xmm0,%xmm7 .byte 15,88,251 // addps %xmm3,%xmm7 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 15,40,223 // movaps %xmm7,%xmm3 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_xor__sse2 .globl _sk_xor__sse2 FUNCTION(_sk_xor__sse2) _sk_xor__sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 232,0,0,0,0 // call 6df <_sk_xor__sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,105,64 // movaps 0x40(%ecx),%xmm5 .byte 15,40,154,225,106,0,0 // movaps 0x6ae1(%edx),%xmm3 .byte 15,40,243 // movaps %xmm3,%xmm6 .byte 15,92,245 // subps %xmm5,%xmm6 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,92,220 // subps %xmm4,%xmm3 .byte 15,40,121,16 // movaps 0x10(%ecx),%xmm7 .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,88,199 // addps %xmm7,%xmm0 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,40,121,32 // movaps 0x20(%ecx),%xmm7 .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,88,207 // addps %xmm7,%xmm1 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,40,121,48 // movaps 0x30(%ecx),%xmm7 .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,88,215 // addps %xmm7,%xmm2 .byte 15,89,244 // mulps %xmm4,%xmm6 .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 15,88,222 // addps %xmm6,%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_darken_sse2 .globl _sk_darken_sse2 FUNCTION(_sk_darken_sse2) _sk_darken_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 232,0,0,0,0 // call 747 <_sk_darken_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,113,64 // movaps 0x40(%ecx),%xmm6 .byte 15,40,105,16 // movaps 0x10(%ecx),%xmm5 .byte 15,40,121,32 // movaps 0x20(%ecx),%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,89,230 // mulps %xmm6,%xmm4 .byte 15,89,235 // mulps %xmm3,%xmm5 .byte 15,95,229 // maxps %xmm5,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,40,231 // movaps %xmm7,%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,95,207 // maxps %xmm7,%xmm1 .byte 15,92,225 // subps %xmm1,%xmm4 .byte 15,40,73,48 // movaps 0x30(%ecx),%xmm1 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,88,234 // addps %xmm2,%xmm5 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,95,209 // maxps %xmm1,%xmm2 .byte 15,92,234 // subps %xmm2,%xmm5 .byte 15,40,138,137,106,0,0 // movaps 0x6a89(%edx),%xmm1 .byte 15,92,203 // subps %xmm3,%xmm1 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,40,213 // movaps %xmm5,%xmm2 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_lighten_sse2 .globl _sk_lighten_sse2 FUNCTION(_sk_lighten_sse2) _sk_lighten_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 232,0,0,0,0 // call 7c7 <_sk_lighten_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,113,64 // movaps 0x40(%ecx),%xmm6 .byte 15,40,105,16 // movaps 0x10(%ecx),%xmm5 .byte 15,40,121,32 // movaps 0x20(%ecx),%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,89,230 // mulps %xmm6,%xmm4 .byte 15,89,235 // mulps %xmm3,%xmm5 .byte 15,93,229 // minps %xmm5,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,40,231 // movaps %xmm7,%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,93,207 // minps %xmm7,%xmm1 .byte 15,92,225 // subps %xmm1,%xmm4 .byte 15,40,73,48 // movaps 0x30(%ecx),%xmm1 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,88,234 // addps %xmm2,%xmm5 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,93,209 // minps %xmm1,%xmm2 .byte 15,92,234 // subps %xmm2,%xmm5 .byte 15,40,138,25,106,0,0 // movaps 0x6a19(%edx),%xmm1 .byte 15,92,203 // subps %xmm3,%xmm1 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,40,213 // movaps %xmm5,%xmm2 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_difference_sse2 .globl _sk_difference_sse2 FUNCTION(_sk_difference_sse2) _sk_difference_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 232,0,0,0,0 // call 84a <_sk_difference_sse2+0x11> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,105,64 // movaps 0x40(%ecx),%xmm5 .byte 15,40,113,16 // movaps 0x10(%ecx),%xmm6 .byte 15,40,121,32 // movaps 0x20(%ecx),%xmm7 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,93,206 // minps %xmm6,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 15,40,207 // movaps %xmm7,%xmm1 .byte 15,88,204 // addps %xmm4,%xmm1 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,93,231 // minps %xmm7,%xmm4 .byte 15,88,228 // addps %xmm4,%xmm4 .byte 15,92,204 // subps %xmm4,%xmm1 .byte 15,40,113,48 // movaps 0x30(%ecx),%xmm6 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,88,226 // addps %xmm2,%xmm4 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,93,214 // minps %xmm6,%xmm2 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 15,92,226 // subps %xmm2,%xmm4 .byte 15,40,146,166,105,0,0 // movaps 0x69a6(%edx),%xmm2 .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_exclusion_sse2 .globl _sk_exclusion_sse2 FUNCTION(_sk_exclusion_sse2) _sk_exclusion_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 232,0,0,0,0 // call 8d0 <_sk_exclusion_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,105,16 // movaps 0x10(%ecx),%xmm5 .byte 15,40,113,32 // movaps 0x20(%ecx),%xmm6 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,88,237 // addps %xmm5,%xmm5 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,88,246 // addps %xmm6,%xmm6 .byte 15,92,230 // subps %xmm6,%xmm4 .byte 15,40,73,48 // movaps 0x30(%ecx),%xmm1 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,88,234 // addps %xmm2,%xmm5 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,40,138,48,105,0,0 // movaps 0x6930(%edx),%xmm1 .byte 15,92,203 // subps %xmm3,%xmm1 .byte 15,89,73,64 // mulps 0x40(%ecx),%xmm1 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,40,213 // movaps %xmm5,%xmm2 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_colorburn_sse2 .globl _sk_colorburn_sse2 FUNCTION(_sk_colorburn_sse2) _sk_colorburn_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,120 // sub $0x78,%esp .byte 15,40,235 // movaps %xmm3,%xmm5 .byte 15,41,109,200 // movaps %xmm5,-0x38(%ebp) .byte 15,41,85,136 // movaps %xmm2,-0x78(%ebp) .byte 15,41,77,168 // movaps %xmm1,-0x58(%ebp) .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 232,0,0,0,0 // call 953 <_sk_colorburn_sse2+0x1d> .byte 89 // pop %ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,64,64 // movaps 0x40(%eax),%xmm0 .byte 15,40,96,16 // movaps 0x10(%eax),%xmm4 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,92,212 // subps %xmm4,%xmm2 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,94,211 // divps %xmm3,%xmm2 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,93,242 // minps %xmm2,%xmm6 .byte 15,41,69,184 // movaps %xmm0,-0x48(%ebp) .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,92,238 // subps %xmm6,%xmm5 .byte 15,40,177,189,104,0,0 // movaps 0x68bd(%ecx),%xmm6 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,92,200 // subps %xmm0,%xmm1 .byte 15,41,77,216 // movaps %xmm1,-0x28(%ebp) .byte 15,40,249 // movaps %xmm1,%xmm7 .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,88,231 // addps %xmm7,%xmm4 .byte 15,40,85,200 // movaps -0x38(%ebp),%xmm2 .byte 15,89,234 // mulps %xmm2,%xmm5 .byte 15,88,239 // addps %xmm7,%xmm5 .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,194,207,0 // cmpeqps %xmm7,%xmm1 .byte 15,84,217 // andps %xmm1,%xmm3 .byte 15,85,205 // andnps %xmm5,%xmm1 .byte 15,86,203 // orps %xmm3,%xmm1 .byte 15,92,242 // subps %xmm2,%xmm6 .byte 15,41,117,232 // movaps %xmm6,-0x18(%ebp) .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,88,203 // addps %xmm3,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,40,93,184 // movaps -0x48(%ebp),%xmm3 .byte 15,194,211,0 // cmpeqps %xmm3,%xmm2 .byte 15,84,226 // andps %xmm2,%xmm4 .byte 15,85,209 // andnps %xmm1,%xmm2 .byte 15,86,212 // orps %xmm4,%xmm2 .byte 15,41,85,152 // movaps %xmm2,-0x68(%ebp) .byte 15,40,64,32 // movaps 0x20(%eax),%xmm0 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,92,216 // subps %xmm0,%xmm3 .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 15,40,77,168 // movaps -0x58(%ebp),%xmm1 .byte 15,94,217 // divps %xmm1,%xmm3 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,93,227 // minps %xmm3,%xmm4 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,92,220 // subps %xmm4,%xmm3 .byte 15,40,101,216 // movaps -0x28(%ebp),%xmm4 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,88,244 // addps %xmm4,%xmm6 .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 15,88,220 // addps %xmm4,%xmm3 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 15,194,231,0 // cmpeqps %xmm7,%xmm4 .byte 15,84,204 // andps %xmm4,%xmm1 .byte 15,85,227 // andnps %xmm3,%xmm4 .byte 15,86,225 // orps %xmm1,%xmm4 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,88,227 // addps %xmm3,%xmm4 .byte 15,40,248 // movaps %xmm0,%xmm7 .byte 15,194,250,0 // cmpeqps %xmm2,%xmm7 .byte 15,84,247 // andps %xmm7,%xmm6 .byte 15,85,252 // andnps %xmm4,%xmm7 .byte 15,86,254 // orps %xmm6,%xmm7 .byte 15,40,96,48 // movaps 0x30(%eax),%xmm4 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,92,204 // subps %xmm4,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,40,109,136 // movaps -0x78(%ebp),%xmm5 .byte 15,94,205 // divps %xmm5,%xmm1 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,93,217 // minps %xmm1,%xmm3 .byte 15,40,69,216 // movaps -0x28(%ebp),%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,41,69,216 // movaps %xmm0,-0x28(%ebp) .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,88,204 // addps %xmm4,%xmm1 .byte 15,40,69,232 // movaps -0x18(%ebp),%xmm0 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,89,244 // mulps %xmm4,%xmm6 .byte 15,194,226,0 // cmpeqps %xmm2,%xmm4 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,41,69,232 // movaps %xmm0,-0x18(%ebp) .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,40,93,200 // movaps -0x38(%ebp),%xmm3 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 15,88,85,216 // addps -0x28(%ebp),%xmm2 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,194,197,0 // cmpeqps %xmm5,%xmm0 .byte 15,84,232 // andps %xmm0,%xmm5 .byte 15,85,194 // andnps %xmm2,%xmm0 .byte 15,86,197 // orps %xmm5,%xmm0 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,84,204 // andps %xmm4,%xmm1 .byte 15,85,224 // andnps %xmm0,%xmm4 .byte 15,86,225 // orps %xmm1,%xmm4 .byte 15,40,235 // movaps %xmm3,%xmm5 .byte 15,88,109,232 // addps -0x18(%ebp),%xmm5 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,69,152 // movaps -0x68(%ebp),%xmm0 .byte 15,40,207 // movaps %xmm7,%xmm1 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 15,40,221 // movaps %xmm5,%xmm3 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 129,196,136,0,0,0 // add $0x88,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_colordodge_sse2 .globl _sk_colordodge_sse2 FUNCTION(_sk_colordodge_sse2) _sk_colordodge_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,104 // sub $0x68,%esp .byte 15,40,251 // movaps %xmm3,%xmm7 .byte 15,41,85,152 // movaps %xmm2,-0x68(%ebp) .byte 15,41,77,216 // movaps %xmm1,-0x28(%ebp) .byte 232,0,0,0,0 // call ae9 <_sk_colordodge_sse2+0x16> .byte 89 // pop %ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,104,16 // movaps 0x10(%eax),%xmm5 .byte 15,40,177,55,103,0,0 // movaps 0x6737(%ecx),%xmm6 .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,92,247 // subps %xmm7,%xmm6 .byte 15,41,117,184 // movaps %xmm6,-0x48(%ebp) .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,41,109,200 // movaps %xmm5,-0x38(%ebp) .byte 15,40,213 // movaps %xmm5,%xmm2 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,40,207 // movaps %xmm7,%xmm1 .byte 15,92,200 // subps %xmm0,%xmm1 .byte 15,94,233 // divps %xmm1,%xmm5 .byte 15,40,96,64 // movaps 0x40(%eax),%xmm4 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,93,205 // minps %xmm5,%xmm1 .byte 15,92,220 // subps %xmm4,%xmm3 .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 15,88,203 // addps %xmm3,%xmm1 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,194,239,0 // cmpeqps %xmm7,%xmm5 .byte 15,84,197 // andps %xmm5,%xmm0 .byte 15,85,233 // andnps %xmm1,%xmm5 .byte 15,86,232 // orps %xmm0,%xmm5 .byte 15,88,238 // addps %xmm6,%xmm5 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,40,93,200 // movaps -0x38(%ebp),%xmm3 .byte 15,194,216,0 // cmpeqps %xmm0,%xmm3 .byte 15,84,211 // andps %xmm3,%xmm2 .byte 15,85,221 // andnps %xmm5,%xmm3 .byte 15,86,218 // orps %xmm2,%xmm3 .byte 15,41,93,200 // movaps %xmm3,-0x38(%ebp) .byte 15,40,64,32 // movaps 0x20(%eax),%xmm0 .byte 15,40,77,184 // movaps -0x48(%ebp),%xmm1 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,40,223 // movaps %xmm7,%xmm3 .byte 15,40,85,216 // movaps -0x28(%ebp),%xmm2 .byte 15,92,218 // subps %xmm2,%xmm3 .byte 15,94,195 // divps %xmm3,%xmm0 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,93,216 // minps %xmm0,%xmm3 .byte 15,40,69,232 // movaps -0x18(%ebp),%xmm0 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,88,240 // addps %xmm0,%xmm6 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 15,88,216 // addps %xmm0,%xmm3 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,194,199,0 // cmpeqps %xmm7,%xmm0 .byte 15,84,208 // andps %xmm0,%xmm2 .byte 15,85,195 // andnps %xmm3,%xmm0 .byte 15,86,194 // orps %xmm2,%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 15,194,234,0 // cmpeqps %xmm2,%xmm5 .byte 15,84,245 // andps %xmm5,%xmm6 .byte 15,85,232 // andnps %xmm0,%xmm5 .byte 15,86,238 // orps %xmm6,%xmm5 .byte 15,40,72,48 // movaps 0x30(%eax),%xmm1 .byte 15,194,209,0 // cmpeqps %xmm1,%xmm2 .byte 15,41,85,216 // movaps %xmm2,-0x28(%ebp) .byte 15,40,85,152 // movaps -0x68(%ebp),%xmm2 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 15,89,218 // mulps %xmm2,%xmm3 .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,88,217 // addps %xmm1,%xmm3 .byte 15,40,69,184 // movaps -0x48(%ebp),%xmm0 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,41,117,168 // movaps %xmm6,-0x58(%ebp) .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 15,40,247 // movaps %xmm7,%xmm6 .byte 15,92,242 // subps %xmm2,%xmm6 .byte 15,94,206 // divps %xmm6,%xmm1 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,93,225 // minps %xmm1,%xmm4 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,88,101,232 // addps -0x18(%ebp),%xmm4 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,194,207,0 // cmpeqps %xmm7,%xmm1 .byte 15,84,209 // andps %xmm1,%xmm2 .byte 15,85,204 // andnps %xmm4,%xmm1 .byte 15,86,202 // orps %xmm2,%xmm1 .byte 15,88,77,168 // addps -0x58(%ebp),%xmm1 .byte 15,40,85,216 // movaps -0x28(%ebp),%xmm2 .byte 15,84,218 // andps %xmm2,%xmm3 .byte 15,85,209 // andnps %xmm1,%xmm2 .byte 15,86,211 // orps %xmm3,%xmm2 .byte 15,88,248 // addps %xmm0,%xmm7 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,69,200 // movaps -0x38(%ebp),%xmm0 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,40,223 // movaps %xmm7,%xmm3 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 131,196,120 // add $0x78,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_hardlight_sse2 .globl _sk_hardlight_sse2 FUNCTION(_sk_hardlight_sse2) _sk_hardlight_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,88 // sub $0x58,%esp .byte 15,40,243 // movaps %xmm3,%xmm6 .byte 15,41,85,168 // movaps %xmm2,-0x58(%ebp) .byte 15,41,77,232 // movaps %xmm1,-0x18(%ebp) .byte 232,0,0,0,0 // call c55 <_sk_hardlight_sse2+0x16> .byte 89 // pop %ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,72,64 // movaps 0x40(%eax),%xmm1 .byte 15,40,145,219,101,0,0 // movaps 0x65db(%ecx),%xmm2 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,40,253 // movaps %xmm5,%xmm7 .byte 15,89,248 // mulps %xmm0,%xmm7 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 15,41,85,200 // movaps %xmm2,-0x38(%ebp) .byte 15,40,88,16 // movaps 0x10(%eax),%xmm3 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,88,207 // addps %xmm7,%xmm1 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 15,41,85,216 // movaps %xmm2,-0x28(%ebp) .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,92,251 // subps %xmm3,%xmm7 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,92,224 // subps %xmm0,%xmm4 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,89,254 // mulps %xmm6,%xmm7 .byte 15,41,125,184 // movaps %xmm7,-0x48(%ebp) .byte 15,88,228 // addps %xmm4,%xmm4 .byte 15,92,252 // subps %xmm4,%xmm7 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,88,228 // addps %xmm4,%xmm4 .byte 15,194,230,2 // cmpleps %xmm6,%xmm4 .byte 15,88,219 // addps %xmm3,%xmm3 .byte 15,84,220 // andps %xmm4,%xmm3 .byte 15,85,231 // andnps %xmm7,%xmm4 .byte 15,86,227 // orps %xmm3,%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,40,85,232 // movaps -0x18(%ebp),%xmm2 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,40,88,32 // movaps 0x20(%eax),%xmm3 .byte 15,40,69,200 // movaps -0x38(%ebp),%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 15,40,77,216 // movaps -0x28(%ebp),%xmm1 .byte 15,92,203 // subps %xmm3,%xmm1 .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 15,92,250 // subps %xmm2,%xmm7 .byte 15,89,249 // mulps %xmm1,%xmm7 .byte 15,88,255 // addps %xmm7,%xmm7 .byte 15,40,85,184 // movaps -0x48(%ebp),%xmm2 .byte 15,92,215 // subps %xmm7,%xmm2 .byte 15,40,77,232 // movaps -0x18(%ebp),%xmm1 .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,194,206,2 // cmpleps %xmm6,%xmm1 .byte 15,88,219 // addps %xmm3,%xmm3 .byte 15,84,217 // andps %xmm1,%xmm3 .byte 15,85,202 // andnps %xmm2,%xmm1 .byte 15,86,203 // orps %xmm3,%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,40,125,168 // movaps -0x58(%ebp),%xmm7 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,40,80,48 // movaps 0x30(%eax),%xmm2 .byte 15,40,93,200 // movaps -0x38(%ebp),%xmm3 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 15,41,69,232 // movaps %xmm0,-0x18(%ebp) .byte 15,40,239 // movaps %xmm7,%xmm5 .byte 15,88,237 // addps %xmm5,%xmm5 .byte 15,194,238,2 // cmpleps %xmm6,%xmm5 .byte 15,40,69,216 // movaps -0x28(%ebp),%xmm0 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,92,194 // subps %xmm2,%xmm0 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,88,222 // addps %xmm6,%xmm3 .byte 15,92,247 // subps %xmm7,%xmm6 .byte 15,89,240 // mulps %xmm0,%xmm6 .byte 15,88,246 // addps %xmm6,%xmm6 .byte 15,40,125,184 // movaps -0x48(%ebp),%xmm7 .byte 15,92,254 // subps %xmm6,%xmm7 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 15,84,213 // andps %xmm5,%xmm2 .byte 15,85,239 // andnps %xmm7,%xmm5 .byte 15,86,234 // orps %xmm2,%xmm5 .byte 15,88,109,232 // addps -0x18(%ebp),%xmm5 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,40,213 // movaps %xmm5,%xmm2 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 131,196,104 // add $0x68,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_overlay_sse2 .globl _sk_overlay_sse2 FUNCTION(_sk_overlay_sse2) _sk_overlay_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,104 // sub $0x68,%esp .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,41,85,152 // movaps %xmm2,-0x68(%ebp) .byte 15,41,77,168 // movaps %xmm1,-0x58(%ebp) .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 232,0,0,0,0 // call da0 <_sk_overlay_sse2+0x1a> .byte 89 // pop %ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,80,64 // movaps 0x40(%eax),%xmm2 .byte 15,40,161,160,100,0,0 // movaps 0x64a0(%ecx),%xmm4 .byte 15,40,244 // movaps %xmm4,%xmm6 .byte 15,92,242 // subps %xmm2,%xmm6 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,92,227 // subps %xmm3,%xmm4 .byte 15,41,101,200 // movaps %xmm4,-0x38(%ebp) .byte 15,40,64,16 // movaps 0x10(%eax),%xmm0 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,41,69,216 // movaps %xmm0,-0x28(%ebp) .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,40,77,232 // movaps -0x18(%ebp),%xmm1 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,89,233 // mulps %xmm1,%xmm5 .byte 15,41,109,184 // movaps %xmm5,-0x48(%ebp) .byte 15,88,228 // addps %xmm4,%xmm4 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,40,77,216 // movaps -0x28(%ebp),%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,194,202,2 // cmpleps %xmm2,%xmm1 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,84,193 // andps %xmm1,%xmm0 .byte 15,85,205 // andnps %xmm5,%xmm1 .byte 15,86,200 // orps %xmm0,%xmm1 .byte 15,88,203 // addps %xmm3,%xmm1 .byte 15,41,77,216 // movaps %xmm1,-0x28(%ebp) .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,40,69,168 // movaps -0x58(%ebp),%xmm0 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,40,88,32 // movaps 0x20(%eax),%xmm3 .byte 15,40,101,200 // movaps -0x38(%ebp),%xmm4 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,92,203 // subps %xmm3,%xmm1 .byte 15,40,235 // movaps %xmm3,%xmm5 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,40,125,232 // movaps -0x18(%ebp),%xmm7 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,89,249 // mulps %xmm1,%xmm7 .byte 15,88,255 // addps %xmm7,%xmm7 .byte 15,40,77,184 // movaps -0x48(%ebp),%xmm1 .byte 15,92,207 // subps %xmm7,%xmm1 .byte 15,88,237 // addps %xmm5,%xmm5 .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,194,239,2 // cmpleps %xmm7,%xmm5 .byte 15,88,219 // addps %xmm3,%xmm3 .byte 15,84,221 // andps %xmm5,%xmm3 .byte 15,85,233 // andnps %xmm1,%xmm5 .byte 15,86,235 // orps %xmm3,%xmm5 .byte 15,88,236 // addps %xmm4,%xmm5 .byte 15,40,93,152 // movaps -0x68(%ebp),%xmm3 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,40,72,48 // movaps 0x30(%eax),%xmm1 .byte 15,40,101,200 // movaps -0x38(%ebp),%xmm4 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 15,89,209 // mulps %xmm1,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,88,246 // addps %xmm6,%xmm6 .byte 15,194,247,2 // cmpleps %xmm7,%xmm6 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,92,249 // subps %xmm1,%xmm7 .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,40,251 // movaps %xmm3,%xmm7 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 15,88,227 // addps %xmm3,%xmm4 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,88,219 // addps %xmm3,%xmm3 .byte 15,40,125,184 // movaps -0x48(%ebp),%xmm7 .byte 15,92,251 // subps %xmm3,%xmm7 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,84,206 // andps %xmm6,%xmm1 .byte 15,85,247 // andnps %xmm7,%xmm6 .byte 15,86,241 // orps %xmm1,%xmm6 .byte 15,88,242 // addps %xmm2,%xmm6 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,69,216 // movaps -0x28(%ebp),%xmm0 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 131,196,120 // add $0x78,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_softlight_sse2 .globl _sk_softlight_sse2 FUNCTION(_sk_softlight_sse2) _sk_softlight_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 129,236,184,0,0,0 // sub $0xb8,%esp .byte 15,41,93,168 // movaps %xmm3,-0x58(%ebp) .byte 15,41,149,88,255,255,255 // movaps %xmm2,-0xa8(%ebp) .byte 15,41,77,136 // movaps %xmm1,-0x78(%ebp) .byte 15,41,69,216 // movaps %xmm0,-0x28(%ebp) .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,88,64 // movaps 0x40(%eax),%xmm3 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,194,195,1 // cmpltps %xmm3,%xmm0 .byte 15,41,69,200 // movaps %xmm0,-0x38(%ebp) .byte 15,40,104,16 // movaps 0x10(%eax),%xmm5 .byte 15,40,213 // movaps %xmm5,%xmm2 .byte 15,94,211 // divps %xmm3,%xmm2 .byte 15,84,208 // andps %xmm0,%xmm2 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,89,246 // mulps %xmm6,%xmm6 .byte 15,88,241 // addps %xmm1,%xmm6 .byte 232,0,0,0,0 // call f30 <_sk_softlight_sse2+0x52> .byte 89 // pop %ecx .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,40,137,48,99,0,0 // movaps 0x6330(%ecx),%xmm1 .byte 15,41,141,104,255,255,255 // movaps %xmm1,-0x98(%ebp) .byte 15,88,193 // addps %xmm1,%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,40,185,32,99,0,0 // movaps 0x6320(%ecx),%xmm7 .byte 15,41,125,232 // movaps %xmm7,-0x18(%ebp) .byte 15,92,250 // subps %xmm2,%xmm7 .byte 15,82,242 // rsqrtps %xmm2,%xmm6 .byte 15,83,206 // rcpps %xmm6,%xmm1 .byte 15,92,202 // subps %xmm2,%xmm1 .byte 15,40,161,64,99,0,0 // movaps 0x6340(%ecx),%xmm4 .byte 15,41,101,152 // movaps %xmm4,-0x68(%ebp) .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,40,243 // movaps %xmm3,%xmm6 .byte 15,41,117,184 // movaps %xmm6,-0x48(%ebp) .byte 15,194,198,2 // cmpleps %xmm6,%xmm0 .byte 15,84,208 // andps %xmm0,%xmm2 .byte 15,85,193 // andnps %xmm1,%xmm0 .byte 15,86,194 // orps %xmm2,%xmm0 .byte 15,40,85,216 // movaps -0x28(%ebp),%xmm2 .byte 15,88,210 // addps %xmm2,%xmm2 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,40,93,168 // movaps -0x58(%ebp),%xmm3 .byte 15,92,203 // subps %xmm3,%xmm1 .byte 15,89,249 // mulps %xmm1,%xmm7 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 15,88,251 // addps %xmm3,%xmm7 .byte 15,89,253 // mulps %xmm5,%xmm7 .byte 15,40,101,232 // movaps -0x18(%ebp),%xmm4 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,92,206 // subps %xmm6,%xmm1 .byte 15,41,141,120,255,255,255 // movaps %xmm1,-0x88(%ebp) .byte 15,40,117,216 // movaps -0x28(%ebp),%xmm6 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,92,227 // subps %xmm3,%xmm4 .byte 15,41,101,216 // movaps %xmm4,-0x28(%ebp) .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,88,245 // addps %xmm5,%xmm6 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,194,211,2 // cmpleps %xmm3,%xmm2 .byte 15,40,243 // movaps %xmm3,%xmm6 .byte 15,84,250 // andps %xmm2,%xmm7 .byte 15,85,208 // andnps %xmm0,%xmm2 .byte 15,86,215 // orps %xmm7,%xmm2 .byte 15,88,209 // addps %xmm1,%xmm2 .byte 15,41,149,72,255,255,255 // movaps %xmm2,-0xb8(%ebp) .byte 15,40,64,32 // movaps 0x20(%eax),%xmm0 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,94,101,184 // divps -0x48(%ebp),%xmm4 .byte 15,84,101,200 // andps -0x38(%ebp),%xmm4 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,88,201 // addps %xmm1,%xmm1 .byte 15,40,217 // movaps %xmm1,%xmm3 .byte 15,89,219 // mulps %xmm3,%xmm3 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,88,141,104,255,255,255 // addps -0x98(%ebp),%xmm1 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,40,125,232 // movaps -0x18(%ebp),%xmm7 .byte 15,92,252 // subps %xmm4,%xmm7 .byte 15,82,220 // rsqrtps %xmm4,%xmm3 .byte 15,83,235 // rcpps %xmm3,%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,89,101,152 // mulps -0x68(%ebp),%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,40,93,136 // movaps -0x78(%ebp),%xmm3 .byte 15,88,219 // addps %xmm3,%xmm3 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,92,206 // subps %xmm6,%xmm1 .byte 15,89,249 // mulps %xmm1,%xmm7 .byte 15,88,254 // addps %xmm6,%xmm7 .byte 15,89,248 // mulps %xmm0,%xmm7 .byte 15,40,117,216 // movaps -0x28(%ebp),%xmm6 .byte 15,89,240 // mulps %xmm0,%xmm6 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,194,69,184,2 // cmpleps -0x48(%ebp),%xmm0 .byte 15,84,224 // andps %xmm0,%xmm4 .byte 15,85,197 // andnps %xmm5,%xmm0 .byte 15,86,196 // orps %xmm4,%xmm0 .byte 15,40,101,184 // movaps -0x48(%ebp),%xmm4 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,40,109,168 // movaps -0x58(%ebp),%xmm5 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 15,40,77,136 // movaps -0x78(%ebp),%xmm1 .byte 15,89,141,120,255,255,255 // mulps -0x88(%ebp),%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 15,194,221,2 // cmpleps %xmm5,%xmm3 .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 15,84,251 // andps %xmm3,%xmm7 .byte 15,85,216 // andnps %xmm0,%xmm3 .byte 15,86,223 // orps %xmm7,%xmm3 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 15,40,64,48 // movaps 0x30(%eax),%xmm0 .byte 15,40,248 // movaps %xmm0,%xmm7 .byte 15,94,252 // divps %xmm4,%xmm7 .byte 15,84,125,200 // andps -0x38(%ebp),%xmm7 .byte 15,40,77,232 // movaps -0x18(%ebp),%xmm1 .byte 15,92,207 // subps %xmm7,%xmm1 .byte 15,41,77,232 // movaps %xmm1,-0x18(%ebp) .byte 15,40,173,104,255,255,255 // movaps -0x98(%ebp),%xmm5 .byte 15,88,239 // addps %xmm7,%xmm5 .byte 15,40,101,152 // movaps -0x68(%ebp),%xmm4 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,82,207 // rsqrtps %xmm7,%xmm1 .byte 15,83,201 // rcpps %xmm1,%xmm1 .byte 15,92,207 // subps %xmm7,%xmm1 .byte 15,41,77,200 // movaps %xmm1,-0x38(%ebp) .byte 15,88,255 // addps %xmm7,%xmm7 .byte 15,88,255 // addps %xmm7,%xmm7 .byte 15,40,215 // movaps %xmm7,%xmm2 .byte 15,89,210 // mulps %xmm2,%xmm2 .byte 15,88,215 // addps %xmm7,%xmm2 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,40,173,88,255,255,255 // movaps -0xa8(%ebp),%xmm5 .byte 15,88,237 // addps %xmm5,%xmm5 .byte 15,40,213 // movaps %xmm5,%xmm2 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 15,40,101,232 // movaps -0x18(%ebp),%xmm4 .byte 15,89,226 // mulps %xmm2,%xmm4 .byte 15,88,230 // addps %xmm6,%xmm4 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,41,101,232 // movaps %xmm4,-0x18(%ebp) .byte 15,40,101,216 // movaps -0x28(%ebp),%xmm4 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,88,192 // addps %xmm0,%xmm0 .byte 15,40,125,184 // movaps -0x48(%ebp),%xmm7 .byte 15,194,199,2 // cmpleps %xmm7,%xmm0 .byte 15,84,200 // andps %xmm0,%xmm1 .byte 15,85,69,200 // andnps -0x38(%ebp),%xmm0 .byte 15,86,193 // orps %xmm1,%xmm0 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,40,85,168 // movaps -0x58(%ebp),%xmm2 .byte 15,89,242 // mulps %xmm2,%xmm6 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,40,141,88,255,255,255 // movaps -0xa8(%ebp),%xmm1 .byte 15,89,141,120,255,255,255 // mulps -0x88(%ebp),%xmm1 .byte 15,88,204 // addps %xmm4,%xmm1 .byte 15,194,234,2 // cmpleps %xmm2,%xmm5 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,40,85,232 // movaps -0x18(%ebp),%xmm2 .byte 15,84,213 // andps %xmm5,%xmm2 .byte 15,85,232 // andnps %xmm0,%xmm5 .byte 15,86,234 // orps %xmm2,%xmm5 .byte 15,88,233 // addps %xmm1,%xmm5 .byte 15,40,69,216 // movaps -0x28(%ebp),%xmm0 .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,133,72,255,255,255 // movaps -0xb8(%ebp),%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,40,213 // movaps %xmm5,%xmm2 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 129,196,200,0,0,0 // add $0xc8,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_hue_sse2 .globl _sk_hue_sse2 FUNCTION(_sk_hue_sse2) _sk_hue_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 129,236,184,0,0,0 // sub $0xb8,%esp .byte 15,40,251 // movaps %xmm3,%xmm7 .byte 15,41,85,232 // movaps %xmm2,-0x18(%ebp) .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,72,16 // movaps 0x10(%eax),%xmm1 .byte 15,40,64,32 // movaps 0x20(%eax),%xmm0 .byte 15,41,69,136 // movaps %xmm0,-0x78(%ebp) .byte 15,40,88,48 // movaps 0x30(%eax),%xmm3 .byte 15,41,93,200 // movaps %xmm3,-0x38(%ebp) .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,95,211 // maxps %xmm3,%xmm2 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,41,77,152 // movaps %xmm1,-0x68(%ebp) .byte 15,95,226 // maxps %xmm2,%xmm4 .byte 15,93,195 // minps %xmm3,%xmm0 .byte 15,93,200 // minps %xmm0,%xmm1 .byte 15,92,225 // subps %xmm1,%xmm4 .byte 15,41,101,168 // movaps %xmm4,-0x58(%ebp) .byte 232,0,0,0,0 // call 11f1 <_sk_hue_sse2+0x4f> .byte 89 // pop %ecx .byte 15,40,221 // movaps %xmm5,%xmm3 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,40,72,64 // movaps 0x40(%eax),%xmm1 .byte 15,41,77,216 // movaps %xmm1,-0x28(%ebp) .byte 15,40,169,191,96,0,0 // movaps 0x60bf(%ecx),%xmm5 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,41,133,72,255,255,255 // movaps %xmm0,-0xb8(%ebp) .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,41,181,104,255,255,255 // movaps %xmm6,-0x98(%ebp) .byte 15,40,69,232 // movaps -0x18(%ebp),%xmm0 .byte 15,89,232 // mulps %xmm0,%xmm5 .byte 15,41,173,88,255,255,255 // movaps %xmm5,-0xa8(%ebp) .byte 15,40,215 // movaps %xmm7,%xmm2 .byte 15,41,85,184 // movaps %xmm2,-0x48(%ebp) .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,93,200 // minps %xmm0,%xmm1 .byte 15,40,243 // movaps %xmm3,%xmm6 .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 15,93,249 // minps %xmm1,%xmm7 .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 15,95,200 // maxps %xmm0,%xmm1 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,95,225 // maxps %xmm1,%xmm4 .byte 15,92,231 // subps %xmm7,%xmm4 .byte 15,92,247 // subps %xmm7,%xmm6 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,92,199 // subps %xmm7,%xmm0 .byte 15,40,77,168 // movaps -0x58(%ebp),%xmm1 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 15,89,233 // mulps %xmm1,%xmm5 .byte 15,41,173,120,255,255,255 // movaps %xmm5,-0x88(%ebp) .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,40,153,143,96,0,0 // movaps 0x608f(%ecx),%xmm3 .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,117,152 // movaps -0x68(%ebp),%xmm6 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,40,153,159,96,0,0 // movaps 0x609f(%ecx),%xmm3 .byte 15,40,109,136 // movaps -0x78(%ebp),%xmm5 .byte 15,40,253 // movaps %xmm5,%xmm7 .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,88,249 // addps %xmm1,%xmm7 .byte 15,40,137,191,96,0,0 // movaps 0x60bf(%ecx),%xmm1 .byte 15,92,77,184 // subps -0x48(%ebp),%xmm1 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,41,117,152 // movaps %xmm6,-0x68(%ebp) .byte 15,89,233 // mulps %xmm1,%xmm5 .byte 15,41,109,136 // movaps %xmm5,-0x78(%ebp) .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,40,77,200 // movaps -0x38(%ebp),%xmm1 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,41,117,168 // movaps %xmm6,-0x58(%ebp) .byte 15,40,169,175,96,0,0 // movaps 0x60af(%ecx),%xmm5 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,88,207 // addps %xmm7,%xmm1 .byte 15,94,212 // divps %xmm4,%xmm2 .byte 15,40,181,120,255,255,255 // movaps -0x88(%ebp),%xmm6 .byte 15,94,244 // divps %xmm4,%xmm6 .byte 15,94,196 // divps %xmm4,%xmm0 .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 15,194,231,4 // cmpneqps %xmm7,%xmm4 .byte 15,84,212 // andps %xmm4,%xmm2 .byte 15,84,244 // andps %xmm4,%xmm6 .byte 15,84,224 // andps %xmm0,%xmm4 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,89,69,232 // mulps -0x18(%ebp),%xmm0 .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,88,248 // addps %xmm0,%xmm7 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,88,199 // addps %xmm7,%xmm0 .byte 15,89,77,184 // mulps -0x48(%ebp),%xmm1 .byte 15,92,200 // subps %xmm0,%xmm1 .byte 15,88,209 // addps %xmm1,%xmm2 .byte 15,88,241 // addps %xmm1,%xmm6 .byte 15,88,204 // addps %xmm4,%xmm1 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 15,93,193 // minps %xmm1,%xmm0 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,93,224 // minps %xmm0,%xmm4 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 15,95,193 // maxps %xmm1,%xmm0 .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,95,248 // maxps %xmm0,%xmm7 .byte 15,40,69,232 // movaps -0x18(%ebp),%xmm0 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,89,222 // mulps %xmm6,%xmm3 .byte 15,88,216 // addps %xmm0,%xmm3 .byte 15,89,233 // mulps %xmm1,%xmm5 .byte 15,88,235 // addps %xmm3,%xmm5 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,194,196,2 // cmpleps %xmm4,%xmm0 .byte 15,40,221 // movaps %xmm5,%xmm3 .byte 15,92,220 // subps %xmm4,%xmm3 .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,94,227 // divps %xmm3,%xmm4 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 15,85,220 // andnps %xmm4,%xmm3 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,84,224 // andps %xmm0,%xmm4 .byte 15,86,227 // orps %xmm3,%xmm4 .byte 15,40,85,216 // movaps -0x28(%ebp),%xmm2 .byte 15,40,93,184 // movaps -0x48(%ebp),%xmm3 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 15,88,93,216 // addps -0x28(%ebp),%xmm3 .byte 15,92,218 // subps %xmm2,%xmm3 .byte 15,41,93,184 // movaps %xmm3,-0x48(%ebp) .byte 15,41,85,216 // movaps %xmm2,-0x28(%ebp) .byte 15,194,215,1 // cmpltps %xmm7,%xmm2 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,85,220 // andnps %xmm4,%xmm3 .byte 15,41,93,200 // movaps %xmm3,-0x38(%ebp) .byte 15,92,229 // subps %xmm5,%xmm4 .byte 15,40,93,216 // movaps -0x28(%ebp),%xmm3 .byte 15,92,221 // subps %xmm5,%xmm3 .byte 15,41,93,216 // movaps %xmm3,-0x28(%ebp) .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 15,92,253 // subps %xmm5,%xmm7 .byte 15,94,231 // divps %xmm7,%xmm4 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 15,84,226 // andps %xmm2,%xmm4 .byte 15,86,101,200 // orps -0x38(%ebp),%xmm4 .byte 15,41,101,200 // movaps %xmm4,-0x38(%ebp) .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,92,221 // subps %xmm5,%xmm3 .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 15,94,93,232 // divps -0x18(%ebp),%xmm3 .byte 15,88,221 // addps %xmm5,%xmm3 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,85,227 // andnps %xmm3,%xmm4 .byte 15,84,240 // andps %xmm0,%xmm6 .byte 15,86,244 // orps %xmm4,%xmm6 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,85,220 // andnps %xmm4,%xmm3 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 15,40,117,216 // movaps -0x28(%ebp),%xmm6 .byte 15,89,230 // mulps %xmm6,%xmm4 .byte 15,94,231 // divps %xmm7,%xmm4 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 15,84,226 // andps %xmm2,%xmm4 .byte 15,86,227 // orps %xmm3,%xmm4 .byte 15,40,217 // movaps %xmm1,%xmm3 .byte 15,92,221 // subps %xmm5,%xmm3 .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 15,94,93,232 // divps -0x18(%ebp),%xmm3 .byte 15,88,221 // addps %xmm5,%xmm3 .byte 15,84,200 // andps %xmm0,%xmm1 .byte 15,85,195 // andnps %xmm3,%xmm0 .byte 15,86,193 // orps %xmm1,%xmm0 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,85,200 // andnps %xmm0,%xmm1 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,94,199 // divps %xmm7,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 15,84,194 // andps %xmm2,%xmm0 .byte 15,86,193 // orps %xmm1,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,40,85,200 // movaps -0x38(%ebp),%xmm2 .byte 15,95,209 // maxps %xmm1,%xmm2 .byte 15,95,225 // maxps %xmm1,%xmm4 .byte 15,95,193 // maxps %xmm1,%xmm0 .byte 15,40,157,72,255,255,255 // movaps -0xb8(%ebp),%xmm3 .byte 15,88,93,152 // addps -0x68(%ebp),%xmm3 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 15,40,141,104,255,255,255 // movaps -0x98(%ebp),%xmm1 .byte 15,88,77,136 // addps -0x78(%ebp),%xmm1 .byte 15,88,204 // addps %xmm4,%xmm1 .byte 15,40,85,168 // movaps -0x58(%ebp),%xmm2 .byte 15,88,149,88,255,255,255 // addps -0xa8(%ebp),%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,40,93,184 // movaps -0x48(%ebp),%xmm3 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 129,196,200,0,0,0 // add $0xc8,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_saturation_sse2 .globl _sk_saturation_sse2 FUNCTION(_sk_saturation_sse2) _sk_saturation_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 129,236,216,0,0,0 // sub $0xd8,%esp .byte 15,41,149,40,255,255,255 // movaps %xmm2,-0xd8(%ebp) .byte 15,41,141,56,255,255,255 // movaps %xmm1,-0xc8(%ebp) .byte 15,41,133,72,255,255,255 // movaps %xmm0,-0xb8(%ebp) .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,112,16 // movaps 0x10(%eax),%xmm6 .byte 15,41,117,184 // movaps %xmm6,-0x48(%ebp) .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,95,226 // maxps %xmm2,%xmm4 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,95,236 // maxps %xmm4,%xmm5 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,93,226 // minps %xmm2,%xmm4 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,93,212 // minps %xmm4,%xmm2 .byte 15,40,64,32 // movaps 0x20(%eax),%xmm0 .byte 15,92,234 // subps %xmm2,%xmm5 .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 15,41,93,216 // movaps %xmm3,-0x28(%ebp) .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 15,40,120,48 // movaps 0x30(%eax),%xmm7 .byte 15,41,125,200 // movaps %xmm7,-0x38(%ebp) .byte 15,89,251 // mulps %xmm3,%xmm7 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,93,207 // minps %xmm7,%xmm1 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,93,209 // minps %xmm1,%xmm2 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,95,207 // maxps %xmm7,%xmm1 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,95,225 // maxps %xmm1,%xmm4 .byte 15,92,226 // subps %xmm2,%xmm4 .byte 15,92,194 // subps %xmm2,%xmm0 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,92,218 // subps %xmm2,%xmm3 .byte 15,92,250 // subps %xmm2,%xmm7 .byte 15,40,64,64 // movaps 0x40(%eax),%xmm0 .byte 15,41,69,152 // movaps %xmm0,-0x68(%ebp) .byte 15,89,232 // mulps %xmm0,%xmm5 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,41,77,168 // movaps %xmm1,-0x58(%ebp) .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,89,253 // mulps %xmm5,%xmm7 .byte 232,0,0,0,0 // call 1545 <_sk_saturation_sse2+0xb0> .byte 89 // pop %ecx .byte 15,40,153,123,93,0,0 // movaps 0x5d7b(%ecx),%xmm3 .byte 15,41,157,88,255,255,255 // movaps %xmm3,-0xa8(%ebp) .byte 15,40,77,184 // movaps -0x48(%ebp),%xmm1 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,40,153,139,93,0,0 // movaps 0x5d8b(%ecx),%xmm3 .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,238 // movaps %xmm6,%xmm5 .byte 15,89,235 // mulps %xmm3,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,40,129,171,93,0,0 // movaps 0x5dab(%ecx),%xmm0 .byte 15,41,133,104,255,255,255 // movaps %xmm0,-0x98(%ebp) .byte 15,92,69,216 // subps -0x28(%ebp),%xmm0 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,41,77,184 // movaps %xmm1,-0x48(%ebp) .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,41,117,136 // movaps %xmm6,-0x78(%ebp) .byte 15,40,69,200 // movaps -0x38(%ebp),%xmm0 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,41,141,120,255,255,255 // movaps %xmm1,-0x88(%ebp) .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,129,155,93,0,0 // movaps 0x5d9b(%ecx),%xmm0 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,40,109,168 // movaps -0x58(%ebp),%xmm5 .byte 15,94,236 // divps %xmm4,%xmm5 .byte 15,94,212 // divps %xmm4,%xmm2 .byte 15,94,252 // divps %xmm4,%xmm7 .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 15,194,227,4 // cmpneqps %xmm3,%xmm4 .byte 15,84,236 // andps %xmm4,%xmm5 .byte 15,84,212 // andps %xmm4,%xmm2 .byte 15,84,231 // andps %xmm7,%xmm4 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 15,40,165,88,255,255,255 // movaps -0xa8(%ebp),%xmm4 .byte 15,89,244 // mulps %xmm4,%xmm6 .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,89,125,232 // mulps -0x18(%ebp),%xmm7 .byte 15,88,254 // addps %xmm6,%xmm7 .byte 15,40,243 // movaps %xmm3,%xmm6 .byte 15,89,240 // mulps %xmm0,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 15,89,77,216 // mulps -0x28(%ebp),%xmm1 .byte 15,92,206 // subps %xmm6,%xmm1 .byte 15,88,233 // addps %xmm1,%xmm5 .byte 15,88,209 // addps %xmm1,%xmm2 .byte 15,41,85,200 // movaps %xmm2,-0x38(%ebp) .byte 15,88,203 // addps %xmm3,%xmm1 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,93,217 // minps %xmm1,%xmm3 .byte 15,40,253 // movaps %xmm5,%xmm7 .byte 15,93,251 // minps %xmm3,%xmm7 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,95,217 // maxps %xmm1,%xmm3 .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 15,95,243 // maxps %xmm3,%xmm6 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 15,89,218 // mulps %xmm2,%xmm3 .byte 15,88,220 // addps %xmm4,%xmm3 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,88,195 // addps %xmm3,%xmm0 .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 15,194,223,2 // cmpleps %xmm7,%xmm3 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,92,215 // subps %xmm7,%xmm2 .byte 15,41,85,232 // movaps %xmm2,-0x18(%ebp) .byte 15,40,253 // movaps %xmm5,%xmm7 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,89,248 // mulps %xmm0,%xmm7 .byte 15,94,250 // divps %xmm2,%xmm7 .byte 15,88,248 // addps %xmm0,%xmm7 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,85,215 // andnps %xmm7,%xmm2 .byte 15,84,235 // andps %xmm3,%xmm5 .byte 15,86,234 // orps %xmm2,%xmm5 .byte 15,40,125,152 // movaps -0x68(%ebp),%xmm7 .byte 15,40,215 // movaps %xmm7,%xmm2 .byte 15,40,101,216 // movaps -0x28(%ebp),%xmm4 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,231 // addps %xmm7,%xmm4 .byte 15,92,226 // subps %xmm2,%xmm4 .byte 15,41,101,216 // movaps %xmm4,-0x28(%ebp) .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,194,214,1 // cmpltps %xmm6,%xmm2 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,85,229 // andnps %xmm5,%xmm4 .byte 15,92,232 // subps %xmm0,%xmm5 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,92,240 // subps %xmm0,%xmm6 .byte 15,94,238 // divps %xmm6,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,84,234 // andps %xmm2,%xmm5 .byte 15,86,236 // orps %xmm4,%xmm5 .byte 15,41,109,168 // movaps %xmm5,-0x58(%ebp) .byte 15,40,101,200 // movaps -0x38(%ebp),%xmm4 .byte 15,92,224 // subps %xmm0,%xmm4 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,94,101,232 // divps -0x18(%ebp),%xmm4 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 15,40,235 // movaps %xmm3,%xmm5 .byte 15,85,236 // andnps %xmm4,%xmm5 .byte 15,40,101,200 // movaps -0x38(%ebp),%xmm4 .byte 15,84,227 // andps %xmm3,%xmm4 .byte 15,86,229 // orps %xmm5,%xmm4 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,85,236 // andnps %xmm4,%xmm5 .byte 15,92,224 // subps %xmm0,%xmm4 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,94,230 // divps %xmm6,%xmm4 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 15,84,226 // andps %xmm2,%xmm4 .byte 15,86,229 // orps %xmm5,%xmm4 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,92,224 // subps %xmm0,%xmm4 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,94,101,232 // divps -0x18(%ebp),%xmm4 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 15,84,203 // andps %xmm3,%xmm1 .byte 15,85,220 // andnps %xmm4,%xmm3 .byte 15,86,217 // orps %xmm1,%xmm3 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,85,203 // andnps %xmm3,%xmm1 .byte 15,92,216 // subps %xmm0,%xmm3 .byte 15,89,223 // mulps %xmm7,%xmm3 .byte 15,94,222 // divps %xmm6,%xmm3 .byte 15,88,216 // addps %xmm0,%xmm3 .byte 15,84,218 // andps %xmm2,%xmm3 .byte 15,86,217 // orps %xmm1,%xmm3 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,40,77,168 // movaps -0x58(%ebp),%xmm1 .byte 15,95,200 // maxps %xmm0,%xmm1 .byte 15,95,232 // maxps %xmm0,%xmm5 .byte 15,95,216 // maxps %xmm0,%xmm3 .byte 15,40,165,104,255,255,255 // movaps -0x98(%ebp),%xmm4 .byte 15,92,101,152 // subps -0x68(%ebp),%xmm4 .byte 15,40,133,72,255,255,255 // movaps -0xb8(%ebp),%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,69,184 // addps -0x48(%ebp),%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 15,40,141,56,255,255,255 // movaps -0xc8(%ebp),%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,77,136 // addps -0x78(%ebp),%xmm1 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,89,165,40,255,255,255 // mulps -0xd8(%ebp),%xmm4 .byte 15,40,149,120,255,255,255 // movaps -0x88(%ebp),%xmm2 .byte 15,88,212 // addps %xmm4,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,93,216 // movaps -0x28(%ebp),%xmm3 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 129,196,232,0,0,0 // add $0xe8,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_color_sse2 .globl _sk_color_sse2 FUNCTION(_sk_color_sse2) _sk_color_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 129,236,200,0,0,0 // sub $0xc8,%esp .byte 15,41,93,200 // movaps %xmm3,-0x38(%ebp) .byte 15,41,85,152 // movaps %xmm2,-0x68(%ebp) .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,41,165,104,255,255,255 // movaps %xmm4,-0x98(%ebp) .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,41,173,120,255,255,255 // movaps %xmm5,-0x88(%ebp) .byte 232,0,0,0,0 // call 17a0 <_sk_color_sse2+0x2a> .byte 89 // pop %ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,80,16 // movaps 0x10(%eax),%xmm2 .byte 15,40,72,32 // movaps 0x20(%eax),%xmm1 .byte 15,40,177,96,91,0,0 // movaps 0x5b60(%ecx),%xmm6 .byte 15,41,117,216 // movaps %xmm6,-0x28(%ebp) .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,40,153,112,91,0,0 // movaps 0x5b70(%ecx),%xmm3 .byte 15,41,93,184 // movaps %xmm3,-0x48(%ebp) .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,88,240 // addps %xmm0,%xmm6 .byte 15,40,129,144,91,0,0 // movaps 0x5b90(%ecx),%xmm0 .byte 15,41,69,168 // movaps %xmm0,-0x58(%ebp) .byte 15,92,69,200 // subps -0x38(%ebp),%xmm0 .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 15,41,149,56,255,255,255 // movaps %xmm2,-0xc8(%ebp) .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,41,141,88,255,255,255 // movaps %xmm1,-0xa8(%ebp) .byte 15,40,80,48 // movaps 0x30(%eax),%xmm2 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,41,133,72,255,255,255 // movaps %xmm0,-0xb8(%ebp) .byte 15,40,137,128,91,0,0 // movaps 0x5b80(%ecx),%xmm1 .byte 15,89,209 // mulps %xmm1,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,40,88,64 // movaps 0x40(%eax),%xmm3 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,40,243 // movaps %xmm3,%xmm6 .byte 15,89,244 // mulps %xmm4,%xmm6 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,89,109,216 // mulps -0x28(%ebp),%xmm5 .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 15,89,125,184 // mulps -0x48(%ebp),%xmm7 .byte 15,88,253 // addps %xmm5,%xmm7 .byte 15,40,109,168 // movaps -0x58(%ebp),%xmm5 .byte 15,92,235 // subps %xmm3,%xmm5 .byte 15,41,109,168 // movaps %xmm5,-0x58(%ebp) .byte 15,40,109,200 // movaps -0x38(%ebp),%xmm5 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,101,232 // movaps -0x18(%ebp),%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,41,101,232 // movaps %xmm4,-0x18(%ebp) .byte 15,88,235 // addps %xmm3,%xmm5 .byte 15,41,109,200 // movaps %xmm5,-0x38(%ebp) .byte 15,40,235 // movaps %xmm3,%xmm5 .byte 15,89,109,152 // mulps -0x68(%ebp),%xmm5 .byte 15,40,221 // movaps %xmm5,%xmm3 .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 15,88,242 // addps %xmm2,%xmm6 .byte 15,88,213 // addps %xmm5,%xmm2 .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,93,218 // minps %xmm2,%xmm3 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,93,227 // minps %xmm3,%xmm4 .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,95,218 // maxps %xmm2,%xmm3 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,95,235 // maxps %xmm3,%xmm5 .byte 15,40,93,216 // movaps -0x28(%ebp),%xmm3 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,40,125,184 // movaps -0x48(%ebp),%xmm7 .byte 15,89,254 // mulps %xmm6,%xmm7 .byte 15,88,251 // addps %xmm3,%xmm7 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,88,207 // addps %xmm7,%xmm1 .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 15,194,252,2 // cmpleps %xmm4,%xmm7 .byte 15,40,217 // movaps %xmm1,%xmm3 .byte 15,92,220 // subps %xmm4,%xmm3 .byte 15,41,93,184 // movaps %xmm3,-0x48(%ebp) .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,92,225 // subps %xmm1,%xmm4 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 15,94,227 // divps %xmm3,%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,40,223 // movaps %xmm7,%xmm3 .byte 15,85,220 // andnps %xmm4,%xmm3 .byte 15,84,199 // andps %xmm7,%xmm0 .byte 15,86,195 // orps %xmm3,%xmm0 .byte 15,40,93,200 // movaps -0x38(%ebp),%xmm3 .byte 15,40,101,232 // movaps -0x18(%ebp),%xmm4 .byte 15,92,220 // subps %xmm4,%xmm3 .byte 15,41,93,200 // movaps %xmm3,-0x38(%ebp) .byte 15,41,101,216 // movaps %xmm4,-0x28(%ebp) .byte 15,194,229,1 // cmpltps %xmm5,%xmm4 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,85,216 // andnps %xmm0,%xmm3 .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,92,193 // subps %xmm1,%xmm0 .byte 15,40,93,216 // movaps -0x28(%ebp),%xmm3 .byte 15,92,217 // subps %xmm1,%xmm3 .byte 15,41,93,216 // movaps %xmm3,-0x28(%ebp) .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,41,109,136 // movaps %xmm5,-0x78(%ebp) .byte 15,94,197 // divps %xmm5,%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 15,84,196 // andps %xmm4,%xmm0 .byte 15,86,69,232 // orps -0x18(%ebp),%xmm0 .byte 15,40,222 // movaps %xmm6,%xmm3 .byte 15,92,217 // subps %xmm1,%xmm3 .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 15,94,93,184 // divps -0x48(%ebp),%xmm3 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 15,41,125,232 // movaps %xmm7,-0x18(%ebp) .byte 15,40,109,232 // movaps -0x18(%ebp),%xmm5 .byte 15,85,235 // andnps %xmm3,%xmm5 .byte 15,41,109,232 // movaps %xmm5,-0x18(%ebp) .byte 15,84,247 // andps %xmm7,%xmm6 .byte 15,86,117,232 // orps -0x18(%ebp),%xmm6 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,85,222 // andnps %xmm6,%xmm3 .byte 15,92,241 // subps %xmm1,%xmm6 .byte 15,89,117,216 // mulps -0x28(%ebp),%xmm6 .byte 15,40,109,136 // movaps -0x78(%ebp),%xmm5 .byte 15,94,245 // divps %xmm5,%xmm6 .byte 15,88,241 // addps %xmm1,%xmm6 .byte 15,84,244 // andps %xmm4,%xmm6 .byte 15,86,243 // orps %xmm3,%xmm6 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,92,217 // subps %xmm1,%xmm3 .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 15,94,93,184 // divps -0x48(%ebp),%xmm3 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 15,84,215 // andps %xmm7,%xmm2 .byte 15,85,251 // andnps %xmm3,%xmm7 .byte 15,86,250 // orps %xmm2,%xmm7 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 15,85,215 // andnps %xmm7,%xmm2 .byte 15,92,249 // subps %xmm1,%xmm7 .byte 15,89,125,216 // mulps -0x28(%ebp),%xmm7 .byte 15,94,253 // divps %xmm5,%xmm7 .byte 15,88,249 // addps %xmm1,%xmm7 .byte 15,84,252 // andps %xmm4,%xmm7 .byte 15,86,250 // orps %xmm2,%xmm7 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,95,193 // maxps %xmm1,%xmm0 .byte 15,95,241 // maxps %xmm1,%xmm6 .byte 15,95,249 // maxps %xmm1,%xmm7 .byte 15,40,141,120,255,255,255 // movaps -0x88(%ebp),%xmm1 .byte 15,40,85,168 // movaps -0x58(%ebp),%xmm2 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,88,141,56,255,255,255 // addps -0xc8(%ebp),%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,40,141,104,255,255,255 // movaps -0x98(%ebp),%xmm1 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,88,141,88,255,255,255 // addps -0xa8(%ebp),%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 15,40,85,152 // movaps -0x68(%ebp),%xmm2 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 15,88,149,72,255,255,255 // addps -0xb8(%ebp),%xmm2 .byte 15,88,215 // addps %xmm7,%xmm2 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,93,200 // movaps -0x38(%ebp),%xmm3 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 129,196,216,0,0,0 // add $0xd8,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_luminosity_sse2 .globl _sk_luminosity_sse2 FUNCTION(_sk_luminosity_sse2) _sk_luminosity_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 129,236,184,0,0,0 // sub $0xb8,%esp .byte 15,40,242 // movaps %xmm2,%xmm6 .byte 232,0,0,0,0 // call 1a03 <_sk_luminosity_sse2+0x11> .byte 89 // pop %ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,161,61,89,0,0 // movaps 0x593d(%ecx),%xmm4 .byte 15,41,101,232 // movaps %xmm4,-0x18(%ebp) .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,40,161,77,89,0,0 // movaps 0x594d(%ecx),%xmm4 .byte 15,41,101,216 // movaps %xmm4,-0x28(%ebp) .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,88,234 // addps %xmm2,%xmm5 .byte 15,40,80,64 // movaps 0x40(%eax),%xmm2 .byte 15,41,85,184 // movaps %xmm2,-0x48(%ebp) .byte 15,40,161,109,89,0,0 // movaps 0x596d(%ecx),%xmm4 .byte 15,40,252 // movaps %xmm4,%xmm7 .byte 15,92,250 // subps %xmm2,%xmm7 .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,41,133,72,255,255,255 // movaps %xmm0,-0xb8(%ebp) .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 15,41,141,88,255,255,255 // movaps %xmm1,-0xa8(%ebp) .byte 15,89,254 // mulps %xmm6,%xmm7 .byte 15,41,189,104,255,255,255 // movaps %xmm7,-0x98(%ebp) .byte 15,40,214 // movaps %xmm6,%xmm2 .byte 15,40,137,93,89,0,0 // movaps 0x595d(%ecx),%xmm1 .byte 15,89,209 // mulps %xmm1,%xmm2 .byte 15,88,213 // addps %xmm5,%xmm2 .byte 15,40,104,16 // movaps 0x10(%eax),%xmm5 .byte 15,41,109,136 // movaps %xmm5,-0x78(%ebp) .byte 15,89,235 // mulps %xmm3,%xmm5 .byte 15,40,112,32 // movaps 0x20(%eax),%xmm6 .byte 15,41,117,152 // movaps %xmm6,-0x68(%ebp) .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,89,69,232 // mulps -0x18(%ebp),%xmm0 .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 15,89,125,216 // mulps -0x28(%ebp),%xmm7 .byte 15,88,248 // addps %xmm0,%xmm7 .byte 15,92,227 // subps %xmm3,%xmm4 .byte 15,41,93,168 // movaps %xmm3,-0x58(%ebp) .byte 15,40,69,136 // movaps -0x78(%ebp),%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,41,69,136 // movaps %xmm0,-0x78(%ebp) .byte 15,40,69,152 // movaps -0x68(%ebp),%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,41,69,152 // movaps %xmm0,-0x68(%ebp) .byte 15,40,64,48 // movaps 0x30(%eax),%xmm0 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,41,165,120,255,255,255 // movaps %xmm4,-0x88(%ebp) .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,88,199 // addps %xmm7,%xmm0 .byte 15,40,93,184 // movaps -0x48(%ebp),%xmm3 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 15,92,208 // subps %xmm0,%xmm2 .byte 15,88,234 // addps %xmm2,%xmm5 .byte 15,88,242 // addps %xmm2,%xmm6 .byte 15,88,212 // addps %xmm4,%xmm2 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 15,93,194 // minps %xmm2,%xmm0 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,93,224 // minps %xmm0,%xmm4 .byte 15,40,198 // movaps %xmm6,%xmm0 .byte 15,95,194 // maxps %xmm2,%xmm0 .byte 15,40,253 // movaps %xmm5,%xmm7 .byte 15,95,248 // maxps %xmm0,%xmm7 .byte 15,41,125,200 // movaps %xmm7,-0x38(%ebp) .byte 15,40,69,232 // movaps -0x18(%ebp),%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,40,125,216 // movaps -0x28(%ebp),%xmm7 .byte 15,89,254 // mulps %xmm6,%xmm7 .byte 15,88,248 // addps %xmm0,%xmm7 .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,88,207 // addps %xmm7,%xmm1 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,194,196,2 // cmpleps %xmm4,%xmm0 .byte 15,40,249 // movaps %xmm1,%xmm7 .byte 15,92,252 // subps %xmm4,%xmm7 .byte 15,41,125,216 // movaps %xmm7,-0x28(%ebp) .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,92,225 // subps %xmm1,%xmm4 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 15,94,231 // divps %xmm7,%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,40,248 // movaps %xmm0,%xmm7 .byte 15,85,252 // andnps %xmm4,%xmm7 .byte 15,84,232 // andps %xmm0,%xmm5 .byte 15,86,239 // orps %xmm7,%xmm5 .byte 15,40,251 // movaps %xmm3,%xmm7 .byte 15,40,231 // movaps %xmm7,%xmm4 .byte 15,40,93,168 // movaps -0x58(%ebp),%xmm3 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 15,92,220 // subps %xmm4,%xmm3 .byte 15,41,93,168 // movaps %xmm3,-0x58(%ebp) .byte 15,41,101,232 // movaps %xmm4,-0x18(%ebp) .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,40,125,200 // movaps -0x38(%ebp),%xmm7 .byte 15,194,223,1 // cmpltps %xmm7,%xmm3 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,85,229 // andnps %xmm5,%xmm4 .byte 15,41,101,184 // movaps %xmm4,-0x48(%ebp) .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,40,101,232 // movaps -0x18(%ebp),%xmm4 .byte 15,92,225 // subps %xmm1,%xmm4 .byte 15,41,101,232 // movaps %xmm4,-0x18(%ebp) .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,92,249 // subps %xmm1,%xmm7 .byte 15,41,125,200 // movaps %xmm7,-0x38(%ebp) .byte 15,94,239 // divps %xmm7,%xmm5 .byte 15,88,233 // addps %xmm1,%xmm5 .byte 15,84,235 // andps %xmm3,%xmm5 .byte 15,86,109,184 // orps -0x48(%ebp),%xmm5 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,92,225 // subps %xmm1,%xmm4 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 15,94,101,216 // divps -0x28(%ebp),%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,40,248 // movaps %xmm0,%xmm7 .byte 15,85,252 // andnps %xmm4,%xmm7 .byte 15,84,240 // andps %xmm0,%xmm6 .byte 15,86,247 // orps %xmm7,%xmm6 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,85,230 // andnps %xmm6,%xmm4 .byte 15,92,241 // subps %xmm1,%xmm6 .byte 15,40,125,232 // movaps -0x18(%ebp),%xmm7 .byte 15,89,247 // mulps %xmm7,%xmm6 .byte 15,94,117,200 // divps -0x38(%ebp),%xmm6 .byte 15,88,241 // addps %xmm1,%xmm6 .byte 15,84,243 // andps %xmm3,%xmm6 .byte 15,86,244 // orps %xmm4,%xmm6 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,92,225 // subps %xmm1,%xmm4 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 15,94,101,216 // divps -0x28(%ebp),%xmm4 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 15,84,208 // andps %xmm0,%xmm2 .byte 15,85,196 // andnps %xmm4,%xmm0 .byte 15,86,194 // orps %xmm2,%xmm0 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,85,208 // andnps %xmm0,%xmm2 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,94,69,200 // divps -0x38(%ebp),%xmm0 .byte 15,88,193 // addps %xmm1,%xmm0 .byte 15,84,195 // andps %xmm3,%xmm0 .byte 15,86,194 // orps %xmm2,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,95,233 // maxps %xmm1,%xmm5 .byte 15,95,241 // maxps %xmm1,%xmm6 .byte 15,95,193 // maxps %xmm1,%xmm0 .byte 15,40,157,72,255,255,255 // movaps -0xb8(%ebp),%xmm3 .byte 15,88,93,136 // addps -0x78(%ebp),%xmm3 .byte 15,88,221 // addps %xmm5,%xmm3 .byte 15,40,141,88,255,255,255 // movaps -0xa8(%ebp),%xmm1 .byte 15,88,77,152 // addps -0x68(%ebp),%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 15,40,149,120,255,255,255 // movaps -0x88(%ebp),%xmm2 .byte 15,88,149,104,255,255,255 // addps -0x98(%ebp),%xmm2 .byte 15,88,208 // addps %xmm0,%xmm2 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,40,93,168 // movaps -0x58(%ebp),%xmm3 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 129,196,200,0,0,0 // add $0xc8,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_srcover_rgba_8888_sse2 .globl _sk_srcover_rgba_8888_sse2 FUNCTION(_sk_srcover_rgba_8888_sse2) _sk_srcover_rgba_8888_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,44 // sub $0x2c,%esp .byte 102,15,127,85,200 // movdqa %xmm2,-0x38(%ebp) .byte 15,41,77,216 // movaps %xmm1,-0x28(%ebp) .byte 232,0,0,0,0 // call 1c6e <_sk_srcover_rgba_8888_sse2+0x17> .byte 95 // pop %edi .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,48 // mov (%eax),%esi .byte 139,86,4 // mov 0x4(%esi),%edx .byte 15,175,81,4 // imul 0x4(%ecx),%edx .byte 193,226,2 // shl $0x2,%edx .byte 3,22 // add (%esi),%edx .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,49 // mov (%ecx),%esi .byte 15,133,224,0,0,0 // jne 1d70 <_sk_srcover_rgba_8888_sse2+0x119> .byte 243,15,111,20,178 // movdqu (%edx,%esi,4),%xmm2 .byte 102,15,111,167,18,87,0,0 // movdqa 0x5712(%edi),%xmm4 .byte 102,15,111,234 // movdqa %xmm2,%xmm5 .byte 102,15,219,236 // pand %xmm4,%xmm5 .byte 102,15,111,242 // movdqa %xmm2,%xmm6 .byte 102,15,114,214,8 // psrld $0x8,%xmm6 .byte 102,15,219,244 // pand %xmm4,%xmm6 .byte 102,15,111,250 // movdqa %xmm2,%xmm7 .byte 102,15,114,215,16 // psrld $0x10,%xmm7 .byte 102,15,219,252 // pand %xmm4,%xmm7 .byte 15,91,229 // cvtdq2ps %xmm5,%xmm4 .byte 15,41,97,16 // movaps %xmm4,0x10(%ecx) .byte 15,40,175,34,87,0,0 // movaps 0x5722(%edi),%xmm5 .byte 15,92,235 // subps %xmm3,%xmm5 .byte 15,40,143,50,87,0,0 // movaps 0x5732(%edi),%xmm1 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,41,113,32 // movaps %xmm6,0x20(%ecx) .byte 15,40,69,216 // movaps -0x28(%ebp),%xmm0 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,240 // addps %xmm0,%xmm6 .byte 15,91,255 // cvtdq2ps %xmm7,%xmm7 .byte 15,41,121,48 // movaps %xmm7,0x30(%ecx) .byte 15,40,69,200 // movaps -0x38(%ebp),%xmm0 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,89,253 // mulps %xmm5,%xmm7 .byte 15,88,248 // addps %xmm0,%xmm7 .byte 102,15,114,210,24 // psrld $0x18,%xmm2 .byte 15,91,194 // cvtdq2ps %xmm2,%xmm0 .byte 15,41,65,64 // movaps %xmm0,0x40(%ecx) .byte 15,89,217 // mulps %xmm1,%xmm3 .byte 15,89,232 // mulps %xmm0,%xmm5 .byte 15,88,235 // addps %xmm3,%xmm5 .byte 102,15,91,196 // cvtps2dq %xmm4,%xmm0 .byte 102,15,91,206 // cvtps2dq %xmm6,%xmm1 .byte 102,15,114,241,8 // pslld $0x8,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,15,91,215 // cvtps2dq %xmm7,%xmm2 .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,15,91,197 // cvtps2dq %xmm5,%xmm0 .byte 102,15,114,240,24 // pslld $0x18,%xmm0 .byte 102,15,235,194 // por %xmm2,%xmm0 .byte 102,15,235,193 // por %xmm1,%xmm0 .byte 133,219 // test %ebx,%ebx .byte 117,95 // jne 1dab <_sk_srcover_rgba_8888_sse2+0x154> .byte 243,15,127,4,178 // movdqu %xmm0,(%edx,%esi,4) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,40,215 // movaps %xmm7,%xmm2 .byte 15,40,221 // movaps %xmm5,%xmm3 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,60 // add $0x3c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 137,216 // mov %ebx,%eax .byte 136,69,243 // mov %al,-0xd(%ebp) .byte 128,101,243,3 // andb $0x3,-0xd(%ebp) .byte 128,125,243,1 // cmpb $0x1,-0xd(%ebp) .byte 116,80 // je 1dcf <_sk_srcover_rgba_8888_sse2+0x178> .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 128,125,243,2 // cmpb $0x2,-0xd(%ebp) .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 116,21 // je 1da1 <_sk_srcover_rgba_8888_sse2+0x14a> .byte 128,125,243,3 // cmpb $0x3,-0xd(%ebp) .byte 15,133,255,254,255,255 // jne 1c95 <_sk_srcover_rgba_8888_sse2+0x3e> .byte 102,15,110,84,178,8 // movd 0x8(%edx,%esi,4),%xmm2 .byte 102,15,112,210,69 // pshufd $0x45,%xmm2,%xmm2 .byte 102,15,18,20,178 // movlpd (%edx,%esi,4),%xmm2 .byte 233,234,254,255,255 // jmp 1c95 <_sk_srcover_rgba_8888_sse2+0x3e> .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,41 // je 1ddc <_sk_srcover_rgba_8888_sse2+0x185> .byte 128,251,2 // cmp $0x2,%bl .byte 116,16 // je 1dc8 <_sk_srcover_rgba_8888_sse2+0x171> .byte 128,251,3 // cmp $0x3,%bl .byte 117,148 // jne 1d51 <_sk_srcover_rgba_8888_sse2+0xfa> .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,15,126,76,178,8 // movd %xmm1,0x8(%edx,%esi,4) .byte 102,15,214,4,178 // movq %xmm0,(%edx,%esi,4) .byte 235,130 // jmp 1d51 <_sk_srcover_rgba_8888_sse2+0xfa> .byte 102,15,110,20,178 // movd (%edx,%esi,4),%xmm2 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 233,185,254,255,255 // jmp 1c95 <_sk_srcover_rgba_8888_sse2+0x3e> .byte 102,15,126,4,178 // movd %xmm0,(%edx,%esi,4) .byte 233,107,255,255,255 // jmp 1d51 <_sk_srcover_rgba_8888_sse2+0xfa> HIDDEN _sk_clamp_0_sse2 .globl _sk_clamp_0_sse2 FUNCTION(_sk_clamp_0_sse2) _sk_clamp_0_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,95,196 // maxps %xmm4,%xmm0 .byte 15,95,204 // maxps %xmm4,%xmm1 .byte 15,95,212 // maxps %xmm4,%xmm2 .byte 15,95,220 // maxps %xmm4,%xmm3 .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_clamp_1_sse2 .globl _sk_clamp_1_sse2 FUNCTION(_sk_clamp_1_sse2) _sk_clamp_1_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 1e1a <_sk_clamp_1_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 15,40,160,150,85,0,0 // movaps 0x5596(%eax),%xmm4 .byte 15,93,196 // minps %xmm4,%xmm0 .byte 15,93,204 // minps %xmm4,%xmm1 .byte 15,93,212 // minps %xmm4,%xmm2 .byte 15,93,220 // minps %xmm4,%xmm3 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_clamp_a_sse2 .globl _sk_clamp_a_sse2 FUNCTION(_sk_clamp_a_sse2) _sk_clamp_a_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 1e4d <_sk_clamp_a_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 15,93,152,115,85,0,0 // minps 0x5573(%eax),%xmm3 .byte 15,93,195 // minps %xmm3,%xmm0 .byte 15,93,203 // minps %xmm3,%xmm1 .byte 15,93,211 // minps %xmm3,%xmm2 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_clamp_a_dst_sse2 .globl _sk_clamp_a_dst_sse2 FUNCTION(_sk_clamp_a_dst_sse2) _sk_clamp_a_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 1e7d <_sk_clamp_a_dst_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,85,8 // mov 0x8(%ebp),%edx .byte 15,40,98,64 // movaps 0x40(%edx),%xmm4 .byte 15,93,160,83,85,0,0 // minps 0x5553(%eax),%xmm4 .byte 15,41,98,64 // movaps %xmm4,0x40(%edx) .byte 15,40,106,16 // movaps 0x10(%edx),%xmm5 .byte 15,93,236 // minps %xmm4,%xmm5 .byte 15,41,106,16 // movaps %xmm5,0x10(%edx) .byte 15,40,106,32 // movaps 0x20(%edx),%xmm5 .byte 15,93,236 // minps %xmm4,%xmm5 .byte 15,41,106,32 // movaps %xmm5,0x20(%edx) .byte 15,40,106,48 // movaps 0x30(%edx),%xmm5 .byte 15,93,236 // minps %xmm4,%xmm5 .byte 15,41,106,48 // movaps %xmm5,0x30(%edx) .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 82 // push %edx .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_set_rgb_sse2 .globl _sk_set_rgb_sse2 FUNCTION(_sk_set_rgb_sse2) _sk_set_rgb_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,1 // movss (%ecx),%xmm0 .byte 243,15,16,73,4 // movss 0x4(%ecx),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,81,8 // movss 0x8(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_swap_rb_sse2 .globl _sk_swap_rb_sse2 FUNCTION(_sk_swap_rb_sse2) _sk_swap_rb_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_invert_sse2 .globl _sk_invert_sse2 FUNCTION(_sk_invert_sse2) _sk_invert_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 1f28 <_sk_invert_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 15,40,160,184,84,0,0 // movaps 0x54b8(%eax),%xmm4 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,92,232 // subps %xmm0,%xmm5 .byte 15,40,244 // movaps %xmm4,%xmm6 .byte 15,92,241 // subps %xmm1,%xmm6 .byte 15,40,252 // movaps %xmm4,%xmm7 .byte 15,92,250 // subps %xmm2,%xmm7 .byte 15,92,227 // subps %xmm3,%xmm4 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,40,215 // movaps %xmm7,%xmm2 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_move_src_dst_sse2 .globl _sk_move_src_dst_sse2 FUNCTION(_sk_move_src_dst_sse2) _sk_move_src_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,41,65,16 // movaps %xmm0,0x10(%ecx) .byte 15,41,73,32 // movaps %xmm1,0x20(%ecx) .byte 15,41,81,48 // movaps %xmm2,0x30(%ecx) .byte 15,41,89,64 // movaps %xmm3,0x40(%ecx) .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_move_dst_src_sse2 .globl _sk_move_dst_src_sse2 FUNCTION(_sk_move_dst_src_sse2) _sk_move_dst_src_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,65,16 // movaps 0x10(%ecx),%xmm0 .byte 15,40,73,32 // movaps 0x20(%ecx),%xmm1 .byte 15,40,81,48 // movaps 0x30(%ecx),%xmm2 .byte 15,40,89,64 // movaps 0x40(%ecx),%xmm3 .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_premul_sse2 .globl _sk_premul_sse2 FUNCTION(_sk_premul_sse2) _sk_premul_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,89,203 // mulps %xmm3,%xmm1 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_premul_dst_sse2 .globl _sk_premul_dst_sse2 FUNCTION(_sk_premul_dst_sse2) _sk_premul_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 15,40,97,64 // movaps 0x40(%ecx),%xmm4 .byte 15,40,105,16 // movaps 0x10(%ecx),%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,41,105,16 // movaps %xmm5,0x10(%ecx) .byte 15,40,105,32 // movaps 0x20(%ecx),%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,41,105,32 // movaps %xmm5,0x20(%ecx) .byte 15,89,97,48 // mulps 0x30(%ecx),%xmm4 .byte 15,41,97,48 // movaps %xmm4,0x30(%ecx) .byte 141,80,4 // lea 0x4(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_unpremul_sse2 .globl _sk_unpremul_sse2 FUNCTION(_sk_unpremul_sse2) _sk_unpremul_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 2026 <_sk_unpremul_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,40,168,202,83,0,0 // movaps 0x53ca(%eax),%xmm5 .byte 15,94,235 // divps %xmm3,%xmm5 .byte 15,194,227,4 // cmpneqps %xmm3,%xmm4 .byte 15,84,229 // andps %xmm5,%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_from_srgb_sse2 .globl _sk_from_srgb_sse2 FUNCTION(_sk_from_srgb_sse2) _sk_from_srgb_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,56 // sub $0x38,%esp .byte 15,41,93,200 // movaps %xmm3,-0x38(%ebp) .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,40,217 // movaps %xmm1,%xmm3 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 232,0,0,0,0 // call 2070 <_sk_from_srgb_sse2+0x18> .byte 88 // pop %eax .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,89,201 // mulps %xmm1,%xmm1 .byte 15,40,160,160,83,0,0 // movaps 0x53a0(%eax),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,40,176,176,83,0,0 // movaps 0x53b0(%eax),%xmm6 .byte 15,41,117,216 // movaps %xmm6,-0x28(%ebp) .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,40,176,144,83,0,0 // movaps 0x5390(%eax),%xmm6 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,40,184,192,83,0,0 // movaps 0x53c0(%eax),%xmm7 .byte 15,41,125,232 // movaps %xmm7,-0x18(%ebp) .byte 15,88,199 // addps %xmm7,%xmm0 .byte 15,40,184,208,83,0,0 // movaps 0x53d0(%eax),%xmm7 .byte 15,194,215,1 // cmpltps %xmm7,%xmm2 .byte 15,84,202 // andps %xmm2,%xmm1 .byte 15,85,208 // andnps %xmm0,%xmm2 .byte 15,86,209 // orps %xmm1,%xmm2 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,77,216 // addps -0x28(%ebp),%xmm1 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,88,77,232 // addps -0x18(%ebp),%xmm1 .byte 15,194,223,1 // cmpltps %xmm7,%xmm3 .byte 15,84,195 // andps %xmm3,%xmm0 .byte 15,85,217 // andnps %xmm1,%xmm3 .byte 15,86,216 // orps %xmm0,%xmm3 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,88,101,216 // addps -0x28(%ebp),%xmm4 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,88,101,232 // addps -0x18(%ebp),%xmm4 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,194,239,1 // cmpltps %xmm7,%xmm5 .byte 15,84,245 // andps %xmm5,%xmm6 .byte 15,85,236 // andnps %xmm4,%xmm5 .byte 15,86,238 // orps %xmm6,%xmm5 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,40,213 // movaps %xmm5,%xmm2 .byte 15,40,93,200 // movaps -0x38(%ebp),%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,72 // add $0x48,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_from_srgb_dst_sse2 .globl _sk_from_srgb_dst_sse2 FUNCTION(_sk_from_srgb_dst_sse2) _sk_from_srgb_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,72 // sub $0x48,%esp .byte 15,41,93,184 // movaps %xmm3,-0x48(%ebp) .byte 15,41,85,200 // movaps %xmm2,-0x38(%ebp) .byte 15,41,77,216 // movaps %xmm1,-0x28(%ebp) .byte 15,41,69,232 // movaps %xmm0,-0x18(%ebp) .byte 232,0,0,0,0 // call 214b <_sk_from_srgb_dst_sse2+0x1b> .byte 89 // pop %ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 15,40,72,16 // movaps 0x10(%eax),%xmm1 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,89,237 // mulps %xmm5,%xmm5 .byte 15,40,161,21,83,0,0 // movaps 0x5315(%ecx),%xmm4 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,40,177,37,83,0,0 // movaps 0x5325(%ecx),%xmm6 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,40,169,5,83,0,0 // movaps 0x5305(%ecx),%xmm5 .byte 15,40,209 // movaps %xmm1,%xmm2 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,40,185,53,83,0,0 // movaps 0x5335(%ecx),%xmm7 .byte 15,88,199 // addps %xmm7,%xmm0 .byte 15,40,153,69,83,0,0 // movaps 0x5345(%ecx),%xmm3 .byte 15,194,203,1 // cmpltps %xmm3,%xmm1 .byte 15,84,209 // andps %xmm1,%xmm2 .byte 15,85,200 // andnps %xmm0,%xmm1 .byte 15,86,202 // orps %xmm2,%xmm1 .byte 15,41,72,16 // movaps %xmm1,0x10(%eax) .byte 15,40,64,32 // movaps 0x20(%eax),%xmm0 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,89,201 // mulps %xmm1,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,89,209 // mulps %xmm1,%xmm2 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,88,215 // addps %xmm7,%xmm2 .byte 15,194,195,1 // cmpltps %xmm3,%xmm0 .byte 15,84,200 // andps %xmm0,%xmm1 .byte 15,85,194 // andnps %xmm2,%xmm0 .byte 15,86,193 // orps %xmm1,%xmm0 .byte 15,41,64,32 // movaps %xmm0,0x20(%eax) .byte 15,40,64,48 // movaps 0x30(%eax),%xmm0 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,88,230 // addps %xmm6,%xmm4 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,89,201 // mulps %xmm1,%xmm1 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 15,88,231 // addps %xmm7,%xmm4 .byte 15,89,232 // mulps %xmm0,%xmm5 .byte 15,194,195,1 // cmpltps %xmm3,%xmm0 .byte 15,84,232 // andps %xmm0,%xmm5 .byte 15,85,196 // andnps %xmm4,%xmm0 .byte 15,86,197 // orps %xmm5,%xmm0 .byte 15,41,64,48 // movaps %xmm0,0x30(%eax) .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,69,232 // movaps -0x18(%ebp),%xmm0 .byte 15,40,77,216 // movaps -0x28(%ebp),%xmm1 .byte 15,40,85,200 // movaps -0x38(%ebp),%xmm2 .byte 15,40,93,184 // movaps -0x48(%ebp),%xmm3 .byte 82 // push %edx .byte 80 // push %eax .byte 255,17 // call *(%ecx) .byte 131,196,88 // add $0x58,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_to_srgb_sse2 .globl _sk_to_srgb_sse2 FUNCTION(_sk_to_srgb_sse2) _sk_to_srgb_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,72 // sub $0x48,%esp .byte 15,41,93,184 // movaps %xmm3,-0x48(%ebp) .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 232,0,0,0,0 // call 2236 <_sk_to_srgb_sse2+0x18> .byte 88 // pop %eax .byte 15,82,218 // rsqrtps %xmm2,%xmm3 .byte 15,40,160,122,82,0,0 // movaps 0x527a(%eax),%xmm4 .byte 15,40,235 // movaps %xmm3,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,40,128,138,82,0,0 // movaps 0x528a(%eax),%xmm0 .byte 15,41,69,232 // movaps %xmm0,-0x18(%ebp) .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,89,235 // mulps %xmm3,%xmm5 .byte 15,40,128,154,82,0,0 // movaps 0x529a(%eax),%xmm0 .byte 15,41,69,200 // movaps %xmm0,-0x38(%ebp) .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,40,128,170,82,0,0 // movaps 0x52aa(%eax),%xmm0 .byte 15,41,69,216 // movaps %xmm0,-0x28(%ebp) .byte 15,88,216 // addps %xmm0,%xmm3 .byte 15,83,195 // rcpps %xmm3,%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,40,168,106,82,0,0 // movaps 0x526a(%eax),%xmm5 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,40,152,186,82,0,0 // movaps 0x52ba(%eax),%xmm3 .byte 15,194,211,1 // cmpltps %xmm3,%xmm2 .byte 15,84,202 // andps %xmm2,%xmm1 .byte 15,85,208 // andnps %xmm0,%xmm2 .byte 15,86,209 // orps %xmm1,%xmm2 .byte 15,82,198 // rsqrtps %xmm6,%xmm0 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,77,232 // addps -0x18(%ebp),%xmm1 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,88,77,200 // addps -0x38(%ebp),%xmm1 .byte 15,88,69,216 // addps -0x28(%ebp),%xmm0 .byte 15,83,192 // rcpps %xmm0,%xmm0 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,194,243,1 // cmpltps %xmm3,%xmm6 .byte 15,84,206 // andps %xmm6,%xmm1 .byte 15,85,240 // andnps %xmm0,%xmm6 .byte 15,86,241 // orps %xmm1,%xmm6 .byte 15,82,199 // rsqrtps %xmm7,%xmm0 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,88,101,232 // addps -0x18(%ebp),%xmm4 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,88,101,200 // addps -0x38(%ebp),%xmm4 .byte 15,88,69,216 // addps -0x28(%ebp),%xmm0 .byte 15,83,192 // rcpps %xmm0,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,194,251,1 // cmpltps %xmm3,%xmm7 .byte 15,84,239 // andps %xmm7,%xmm5 .byte 15,85,248 // andnps %xmm0,%xmm7 .byte 15,86,253 // orps %xmm5,%xmm7 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,40,206 // movaps %xmm6,%xmm1 .byte 15,40,215 // movaps %xmm7,%xmm2 .byte 15,40,93,184 // movaps -0x48(%ebp),%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,88 // add $0x58,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_rgb_to_hsl_sse2 .globl _sk_rgb_to_hsl_sse2 FUNCTION(_sk_rgb_to_hsl_sse2) _sk_rgb_to_hsl_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,56 // sub $0x38,%esp .byte 15,41,93,200 // movaps %xmm3,-0x38(%ebp) .byte 15,40,249 // movaps %xmm1,%xmm7 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 232,0,0,0,0 // call 232d <_sk_rgb_to_hsl_sse2+0x15> .byte 88 // pop %eax .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,95,207 // maxps %xmm7,%xmm1 .byte 15,95,202 // maxps %xmm2,%xmm1 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,93,223 // minps %xmm7,%xmm3 .byte 15,93,218 // minps %xmm2,%xmm3 .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,92,195 // subps %xmm3,%xmm0 .byte 15,41,69,216 // movaps %xmm0,-0x28(%ebp) .byte 15,40,152,211,81,0,0 // movaps 0x51d3(%eax),%xmm3 .byte 15,94,216 // divps %xmm0,%xmm3 .byte 15,40,199 // movaps %xmm7,%xmm0 .byte 15,92,194 // subps %xmm2,%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,40,239 // movaps %xmm7,%xmm5 .byte 15,194,234,1 // cmpltps %xmm2,%xmm5 .byte 15,84,168,227,81,0,0 // andps 0x51e3(%eax),%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,194,196,0 // cmpeqps %xmm4,%xmm0 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,194,247,0 // cmpeqps %xmm7,%xmm6 .byte 15,92,212 // subps %xmm4,%xmm2 .byte 15,92,231 // subps %xmm7,%xmm4 .byte 15,89,211 // mulps %xmm3,%xmm2 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 15,40,152,243,81,0,0 // movaps 0x51f3(%eax),%xmm3 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 15,88,160,3,82,0,0 // addps 0x5203(%eax),%xmm4 .byte 15,84,214 // andps %xmm6,%xmm2 .byte 15,85,244 // andnps %xmm4,%xmm6 .byte 15,86,242 // orps %xmm2,%xmm6 .byte 15,84,232 // andps %xmm0,%xmm5 .byte 15,85,198 // andnps %xmm6,%xmm0 .byte 15,86,197 // orps %xmm5,%xmm0 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,40,85,232 // movaps -0x18(%ebp),%xmm2 .byte 15,194,226,4 // cmpneqps %xmm2,%xmm4 .byte 15,92,217 // subps %xmm1,%xmm3 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 15,40,168,35,82,0,0 // movaps 0x5223(%eax),%xmm5 .byte 15,92,218 // subps %xmm2,%xmm3 .byte 15,40,209 // movaps %xmm1,%xmm2 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,194,234,1 // cmpltps %xmm2,%xmm5 .byte 15,84,221 // andps %xmm5,%xmm3 .byte 15,85,233 // andnps %xmm1,%xmm5 .byte 15,86,235 // orps %xmm3,%xmm5 .byte 15,40,77,216 // movaps -0x28(%ebp),%xmm1 .byte 15,94,205 // divps %xmm5,%xmm1 .byte 15,89,128,19,82,0,0 // mulps 0x5213(%eax),%xmm0 .byte 15,84,196 // andps %xmm4,%xmm0 .byte 15,84,204 // andps %xmm4,%xmm1 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,93,200 // movaps -0x38(%ebp),%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,72 // add $0x48,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_hsl_to_rgb_sse2 .globl _sk_hsl_to_rgb_sse2 FUNCTION(_sk_hsl_to_rgb_sse2) _sk_hsl_to_rgb_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 129,236,200,0,0,0 // sub $0xc8,%esp .byte 15,41,157,56,255,255,255 // movaps %xmm3,-0xc8(%ebp) .byte 15,41,69,184 // movaps %xmm0,-0x48(%ebp) .byte 232,0,0,0,0 // call 2422 <_sk_hsl_to_rgb_sse2+0x19> .byte 88 // pop %eax .byte 15,40,160,62,81,0,0 // movaps 0x513e(%eax),%xmm4 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 15,41,165,104,255,255,255 // movaps %xmm4,-0x98(%ebp) .byte 15,194,218,2 // cmpleps %xmm2,%xmm3 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,87,237 // xorps %xmm5,%xmm5 .byte 15,194,233,0 // cmpeqps %xmm1,%xmm5 .byte 15,41,109,232 // movaps %xmm5,-0x18(%ebp) .byte 15,89,202 // mulps %xmm2,%xmm1 .byte 15,92,241 // subps %xmm1,%xmm6 .byte 15,84,243 // andps %xmm3,%xmm6 .byte 15,85,217 // andnps %xmm1,%xmm3 .byte 15,86,222 // orps %xmm6,%xmm3 .byte 15,40,168,78,81,0,0 // movaps 0x514e(%eax),%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 243,15,91,205 // cvttps2dq %xmm5,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,194,193,1 // cmpltps %xmm1,%xmm0 .byte 15,40,176,94,81,0,0 // movaps 0x515e(%eax),%xmm6 .byte 15,41,117,136 // movaps %xmm6,-0x78(%ebp) .byte 15,84,198 // andps %xmm6,%xmm0 .byte 15,92,200 // subps %xmm0,%xmm1 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,41,149,72,255,255,255 // movaps %xmm2,-0xb8(%ebp) .byte 15,88,218 // addps %xmm2,%xmm3 .byte 15,41,93,216 // movaps %xmm3,-0x28(%ebp) .byte 15,88,210 // addps %xmm2,%xmm2 .byte 15,92,211 // subps %xmm3,%xmm2 .byte 15,40,184,110,81,0,0 // movaps 0x516e(%eax),%xmm7 .byte 15,41,189,88,255,255,255 // movaps %xmm7,-0xa8(%ebp) .byte 15,194,253,2 // cmpleps %xmm5,%xmm7 .byte 15,92,218 // subps %xmm2,%xmm3 .byte 15,41,93,200 // movaps %xmm3,-0x38(%ebp) .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 15,194,205,2 // cmpleps %xmm5,%xmm1 .byte 15,40,160,158,81,0,0 // movaps 0x519e(%eax),%xmm4 .byte 15,41,165,120,255,255,255 // movaps %xmm4,-0x88(%ebp) .byte 15,194,229,2 // cmpleps %xmm5,%xmm4 .byte 15,40,176,126,81,0,0 // movaps 0x517e(%eax),%xmm6 .byte 15,89,238 // mulps %xmm6,%xmm5 .byte 15,40,128,142,81,0,0 // movaps 0x518e(%eax),%xmm0 .byte 15,41,69,168 // movaps %xmm0,-0x58(%ebp) .byte 15,92,197 // subps %xmm5,%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,84,223 // andps %xmm7,%xmm3 .byte 15,85,248 // andnps %xmm0,%xmm7 .byte 15,86,251 // orps %xmm3,%xmm7 .byte 15,84,249 // andps %xmm1,%xmm7 .byte 15,85,77,216 // andnps -0x28(%ebp),%xmm1 .byte 15,86,207 // orps %xmm7,%xmm1 .byte 15,40,125,200 // movaps -0x38(%ebp),%xmm7 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,88,234 // addps %xmm2,%xmm5 .byte 15,84,204 // andps %xmm4,%xmm1 .byte 15,85,229 // andnps %xmm5,%xmm4 .byte 15,86,225 // orps %xmm1,%xmm4 .byte 15,40,69,232 // movaps -0x18(%ebp),%xmm0 .byte 15,85,196 // andnps %xmm4,%xmm0 .byte 15,41,69,152 // movaps %xmm0,-0x68(%ebp) .byte 15,40,93,184 // movaps -0x48(%ebp),%xmm3 .byte 243,15,91,195 // cvttps2dq %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,194,200,1 // cmpltps %xmm0,%xmm1 .byte 15,84,136,94,81,0,0 // andps 0x515e(%eax),%xmm1 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,92,200 // subps %xmm0,%xmm1 .byte 15,40,128,110,81,0,0 // movaps 0x516e(%eax),%xmm0 .byte 15,194,193,2 // cmpleps %xmm1,%xmm0 .byte 15,40,152,62,81,0,0 // movaps 0x513e(%eax),%xmm3 .byte 15,194,217,2 // cmpleps %xmm1,%xmm3 .byte 15,40,160,158,81,0,0 // movaps 0x519e(%eax),%xmm4 .byte 15,194,225,2 // cmpleps %xmm1,%xmm4 .byte 15,89,206 // mulps %xmm6,%xmm1 .byte 15,40,168,142,81,0,0 // movaps 0x518e(%eax),%xmm5 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,88,234 // addps %xmm2,%xmm5 .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,84,248 // andps %xmm0,%xmm7 .byte 15,85,197 // andnps %xmm5,%xmm0 .byte 15,86,199 // orps %xmm7,%xmm0 .byte 15,84,195 // andps %xmm3,%xmm0 .byte 15,85,93,216 // andnps -0x28(%ebp),%xmm3 .byte 15,86,216 // orps %xmm0,%xmm3 .byte 15,40,109,200 // movaps -0x38(%ebp),%xmm5 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 15,84,220 // andps %xmm4,%xmm3 .byte 15,85,225 // andnps %xmm1,%xmm4 .byte 15,86,227 // orps %xmm3,%xmm4 .byte 15,40,125,232 // movaps -0x18(%ebp),%xmm7 .byte 15,85,252 // andnps %xmm4,%xmm7 .byte 15,40,93,184 // movaps -0x48(%ebp),%xmm3 .byte 15,88,152,174,81,0,0 // addps 0x51ae(%eax),%xmm3 .byte 243,15,91,195 // cvttps2dq %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,194,200,1 // cmpltps %xmm0,%xmm1 .byte 15,84,77,136 // andps -0x78(%ebp),%xmm1 .byte 15,92,193 // subps %xmm1,%xmm0 .byte 15,92,216 // subps %xmm0,%xmm3 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,40,77,168 // movaps -0x58(%ebp),%xmm1 .byte 15,92,206 // subps %xmm6,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,226 // addps %xmm2,%xmm4 .byte 15,88,242 // addps %xmm2,%xmm6 .byte 15,40,141,88,255,255,255 // movaps -0xa8(%ebp),%xmm1 .byte 15,194,203,2 // cmpleps %xmm3,%xmm1 .byte 15,84,209 // andps %xmm1,%xmm2 .byte 15,85,204 // andnps %xmm4,%xmm1 .byte 15,86,202 // orps %xmm2,%xmm1 .byte 15,40,133,104,255,255,255 // movaps -0x98(%ebp),%xmm0 .byte 15,194,195,2 // cmpleps %xmm3,%xmm0 .byte 15,84,200 // andps %xmm0,%xmm1 .byte 15,85,69,216 // andnps -0x28(%ebp),%xmm0 .byte 15,86,193 // orps %xmm1,%xmm0 .byte 15,40,141,120,255,255,255 // movaps -0x88(%ebp),%xmm1 .byte 15,194,203,2 // cmpleps %xmm3,%xmm1 .byte 15,84,193 // andps %xmm1,%xmm0 .byte 15,85,206 // andnps %xmm6,%xmm1 .byte 15,86,200 // orps %xmm0,%xmm1 .byte 15,40,209 // movaps %xmm1,%xmm2 .byte 15,40,157,72,255,255,255 // movaps -0xb8(%ebp),%xmm3 .byte 15,40,77,232 // movaps -0x18(%ebp),%xmm1 .byte 15,84,217 // andps %xmm1,%xmm3 .byte 15,85,202 // andnps %xmm2,%xmm1 .byte 15,40,69,152 // movaps -0x68(%ebp),%xmm0 .byte 15,86,195 // orps %xmm3,%xmm0 .byte 15,86,251 // orps %xmm3,%xmm7 .byte 15,86,217 // orps %xmm1,%xmm3 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,207 // movaps %xmm7,%xmm1 .byte 15,40,157,56,255,255,255 // movaps -0xc8(%ebp),%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 129,196,216,0,0,0 // add $0xd8,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_scale_1_float_sse2 .globl _sk_scale_1_float_sse2 FUNCTION(_sk_scale_1_float_sse2) _sk_scale_1_float_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,33 // movss (%ecx),%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_scale_u8_sse2 .globl _sk_scale_u8_sse2 FUNCTION(_sk_scale_u8_sse2) _sk_scale_u8_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 269c <_sk_scale_u8_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,65 // jne 26f8 <_sk_scale_u8_sse2+0x6a> .byte 102,15,110,36,62 // movd (%esi,%edi,1),%xmm4 .byte 102,15,96,224 // punpcklbw %xmm0,%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 102,15,219,162,68,79,0,0 // pand 0x4f44(%edx),%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,162,84,79,0,0 // mulps 0x4f54(%edx),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,50 // je 2732 <_sk_scale_u8_sse2+0xa4> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 128,251,2 // cmp $0x2,%bl .byte 116,19 // je 271c <_sk_scale_u8_sse2+0x8e> .byte 128,251,3 // cmp $0x3,%bl .byte 117,182 // jne 26c4 <_sk_scale_u8_sse2+0x36> .byte 15,182,92,62,2 // movzbl 0x2(%esi,%edi,1),%ebx .byte 102,15,110,227 // movd %ebx,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 15,183,52,62 // movzwl (%esi,%edi,1),%esi .byte 102,15,110,238 // movd %esi,%xmm5 .byte 102,15,96,232 // punpcklbw %xmm0,%xmm5 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 242,15,16,229 // movsd %xmm5,%xmm4 .byte 235,146 // jmp 26c4 <_sk_scale_u8_sse2+0x36> .byte 15,182,52,62 // movzbl (%esi,%edi,1),%esi .byte 102,15,110,230 // movd %esi,%xmm4 .byte 235,136 // jmp 26c4 <_sk_scale_u8_sse2+0x36> HIDDEN _sk_lerp_1_float_sse2 .globl _sk_lerp_1_float_sse2 FUNCTION(_sk_lerp_1_float_sse2) _sk_lerp_1_float_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,17 // mov (%ecx),%edx .byte 243,15,16,34 // movss (%edx),%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,40,104,16 // movaps 0x10(%eax),%xmm5 .byte 15,40,112,32 // movaps 0x20(%eax),%xmm6 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 15,92,206 // subps %xmm6,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 15,40,104,48 // movaps 0x30(%eax),%xmm5 .byte 15,92,213 // subps %xmm5,%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,213 // addps %xmm5,%xmm2 .byte 15,40,104,64 // movaps 0x40(%eax),%xmm5 .byte 15,92,221 // subps %xmm5,%xmm3 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 15,88,221 // addps %xmm5,%xmm3 .byte 141,81,8 // lea 0x8(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 80 // push %eax .byte 255,81,4 // call *0x4(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_lerp_u8_sse2 .globl _sk_lerp_u8_sse2 FUNCTION(_sk_lerp_u8_sse2) _sk_lerp_u8_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 27a4 <_sk_lerp_u8_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,102 // jne 2825 <_sk_lerp_u8_sse2+0x8f> .byte 102,15,110,36,62 // movd (%esi,%edi,1),%xmm4 .byte 102,15,96,224 // punpcklbw %xmm0,%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 102,15,219,162,92,78,0,0 // pand 0x4e5c(%edx),%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,162,108,78,0,0 // mulps 0x4e6c(%edx),%xmm4 .byte 15,40,105,16 // movaps 0x10(%ecx),%xmm5 .byte 15,40,113,32 // movaps 0x20(%ecx),%xmm6 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 15,92,206 // subps %xmm6,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 15,40,105,48 // movaps 0x30(%ecx),%xmm5 .byte 15,92,213 // subps %xmm5,%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,213 // addps %xmm5,%xmm2 .byte 15,40,105,64 // movaps 0x40(%ecx),%xmm5 .byte 15,92,221 // subps %xmm5,%xmm3 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 15,88,221 // addps %xmm5,%xmm3 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,53 // je 2862 <_sk_lerp_u8_sse2+0xcc> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 128,251,2 // cmp $0x2,%bl .byte 116,19 // je 2849 <_sk_lerp_u8_sse2+0xb3> .byte 128,251,3 // cmp $0x3,%bl .byte 117,145 // jne 27cc <_sk_lerp_u8_sse2+0x36> .byte 15,182,92,62,2 // movzbl 0x2(%esi,%edi,1),%ebx .byte 102,15,110,227 // movd %ebx,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 15,183,52,62 // movzwl (%esi,%edi,1),%esi .byte 102,15,110,238 // movd %esi,%xmm5 .byte 102,15,96,232 // punpcklbw %xmm0,%xmm5 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 242,15,16,229 // movsd %xmm5,%xmm4 .byte 233,106,255,255,255 // jmp 27cc <_sk_lerp_u8_sse2+0x36> .byte 15,182,52,62 // movzbl (%esi,%edi,1),%esi .byte 102,15,110,230 // movd %esi,%xmm4 .byte 233,93,255,255,255 // jmp 27cc <_sk_lerp_u8_sse2+0x36> HIDDEN _sk_lerp_565_sse2 .globl _sk_lerp_565_sse2 FUNCTION(_sk_lerp_565_sse2) _sk_lerp_565_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 287d <_sk_lerp_565_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 1,246 // add %esi,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 15,133,163,0,0,0 // jne 2941 <_sk_lerp_565_sse2+0xd2> .byte 243,15,126,52,126 // movq (%esi,%edi,2),%xmm6 .byte 102,15,97,240 // punpcklwd %xmm0,%xmm6 .byte 102,15,111,162,163,77,0,0 // movdqa 0x4da3(%edx),%xmm4 .byte 102,15,219,230 // pand %xmm6,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,162,179,77,0,0 // mulps 0x4db3(%edx),%xmm4 .byte 102,15,111,170,195,77,0,0 // movdqa 0x4dc3(%edx),%xmm5 .byte 102,15,219,238 // pand %xmm6,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,170,211,77,0,0 // mulps 0x4dd3(%edx),%xmm5 .byte 102,15,219,178,227,77,0,0 // pand 0x4de3(%edx),%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,89,178,243,77,0,0 // mulps 0x4df3(%edx),%xmm6 .byte 15,40,121,16 // movaps 0x10(%ecx),%xmm7 .byte 15,92,199 // subps %xmm7,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,199 // addps %xmm7,%xmm0 .byte 15,40,121,32 // movaps 0x20(%ecx),%xmm7 .byte 15,92,207 // subps %xmm7,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,88,207 // addps %xmm7,%xmm1 .byte 15,40,121,48 // movaps 0x30(%ecx),%xmm7 .byte 15,92,215 // subps %xmm7,%xmm2 .byte 15,89,214 // mulps %xmm6,%xmm2 .byte 15,88,215 // addps %xmm7,%xmm2 .byte 15,40,121,64 // movaps 0x40(%ecx),%xmm7 .byte 15,92,223 // subps %xmm7,%xmm3 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 15,89,235 // mulps %xmm3,%xmm5 .byte 15,89,222 // mulps %xmm6,%xmm3 .byte 15,88,231 // addps %xmm7,%xmm4 .byte 15,88,239 // addps %xmm7,%xmm5 .byte 15,88,223 // addps %xmm7,%xmm3 .byte 15,95,235 // maxps %xmm3,%xmm5 .byte 15,95,229 // maxps %xmm5,%xmm4 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,50 // je 297b <_sk_lerp_565_sse2+0x10c> .byte 102,15,239,246 // pxor %xmm6,%xmm6 .byte 128,251,2 // cmp $0x2,%bl .byte 116,23 // je 2969 <_sk_lerp_565_sse2+0xfa> .byte 128,251,3 // cmp $0x3,%bl .byte 15,133,76,255,255,255 // jne 28a7 <_sk_lerp_565_sse2+0x38> .byte 15,183,92,126,4 // movzwl 0x4(%esi,%edi,2),%ebx .byte 102,15,110,227 // movd %ebx,%xmm4 .byte 102,15,112,244,69 // pshufd $0x45,%xmm4,%xmm6 .byte 102,15,110,36,126 // movd (%esi,%edi,2),%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 242,15,16,244 // movsd %xmm4,%xmm6 .byte 233,44,255,255,255 // jmp 28a7 <_sk_lerp_565_sse2+0x38> .byte 15,183,52,126 // movzwl (%esi,%edi,2),%esi .byte 102,15,110,246 // movd %esi,%xmm6 .byte 233,31,255,255,255 // jmp 28a7 <_sk_lerp_565_sse2+0x38> HIDDEN _sk_load_tables_sse2 .globl _sk_load_tables_sse2 FUNCTION(_sk_load_tables_sse2) _sk_load_tables_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 2996 <_sk_load_tables_sse2+0xe> .byte 90 // pop %edx .byte 139,117,12 // mov 0xc(%ebp),%esi .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,57 // mov (%ecx),%edi .byte 139,65,8 // mov 0x8(%ecx),%eax .byte 133,192 // test %eax,%eax .byte 139,54 // mov (%esi),%esi .byte 139,30 // mov (%esi),%ebx .byte 15,133,19,1,0,0 // jne 2ac1 <_sk_load_tables_sse2+0x139> .byte 243,15,111,28,187 // movdqu (%ebx,%edi,4),%xmm3 .byte 102,15,111,146,234,76,0,0 // movdqa 0x4cea(%edx),%xmm2 .byte 102,15,111,195 // movdqa %xmm3,%xmm0 .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 102,15,112,200,229 // pshufd $0xe5,%xmm0,%xmm1 .byte 102,15,112,224,231 // pshufd $0xe7,%xmm0,%xmm4 .byte 102,15,126,224 // movd %xmm4,%eax .byte 139,126,4 // mov 0x4(%esi),%edi .byte 243,15,16,36,135 // movss (%edi,%eax,4),%xmm4 .byte 102,15,126,200 // movd %xmm1,%eax .byte 243,15,16,44,135 // movss (%edi,%eax,4),%xmm5 .byte 102,15,126,192 // movd %xmm0,%eax .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 243,15,16,4,135 // movss (%edi,%eax,4),%xmm0 .byte 102,15,126,200 // movd %xmm1,%eax .byte 243,15,16,12,135 // movss (%edi,%eax,4),%xmm1 .byte 139,70,8 // mov 0x8(%esi),%eax .byte 15,20,236 // unpcklps %xmm4,%xmm5 .byte 15,20,193 // unpcklps %xmm1,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 102,15,112,225,229 // pshufd $0xe5,%xmm1,%xmm4 .byte 102,15,112,241,231 // pshufd $0xe7,%xmm1,%xmm6 .byte 102,15,126,247 // movd %xmm6,%edi .byte 243,15,16,52,184 // movss (%eax,%edi,4),%xmm6 .byte 102,15,126,231 // movd %xmm4,%edi .byte 243,15,16,36,184 // movss (%eax,%edi,4),%xmm4 .byte 102,15,126,207 // movd %xmm1,%edi .byte 102,15,112,249,78 // pshufd $0x4e,%xmm1,%xmm7 .byte 243,15,16,12,184 // movss (%eax,%edi,4),%xmm1 .byte 102,15,126,255 // movd %xmm7,%edi .byte 243,15,16,60,184 // movss (%eax,%edi,4),%xmm7 .byte 15,20,197 // unpcklps %xmm5,%xmm0 .byte 15,20,230 // unpcklps %xmm6,%xmm4 .byte 15,20,207 // unpcklps %xmm7,%xmm1 .byte 139,70,12 // mov 0xc(%esi),%eax .byte 102,15,111,235 // movdqa %xmm3,%xmm5 .byte 102,15,114,213,16 // psrld $0x10,%xmm5 .byte 102,15,219,234 // pand %xmm2,%xmm5 .byte 102,15,112,213,229 // pshufd $0xe5,%xmm5,%xmm2 .byte 102,15,112,245,231 // pshufd $0xe7,%xmm5,%xmm6 .byte 102,15,126,246 // movd %xmm6,%esi .byte 243,15,16,52,176 // movss (%eax,%esi,4),%xmm6 .byte 102,15,126,214 // movd %xmm2,%esi .byte 243,15,16,60,176 // movss (%eax,%esi,4),%xmm7 .byte 102,15,126,238 // movd %xmm5,%esi .byte 102,15,112,237,78 // pshufd $0x4e,%xmm5,%xmm5 .byte 243,15,16,20,176 // movss (%eax,%esi,4),%xmm2 .byte 102,15,126,238 // movd %xmm5,%esi .byte 243,15,16,44,176 // movss (%eax,%esi,4),%xmm5 .byte 15,20,204 // unpcklps %xmm4,%xmm1 .byte 15,20,254 // unpcklps %xmm6,%xmm7 .byte 15,20,213 // unpcklps %xmm5,%xmm2 .byte 15,20,215 // unpcklps %xmm7,%xmm2 .byte 102,15,114,211,24 // psrld $0x18,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,154,250,76,0,0 // mulps 0x4cfa(%edx),%xmm3 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 137,194 // mov %eax,%edx .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 36,3 // and $0x3,%al .byte 60,1 // cmp $0x1,%al .byte 116,37 // je 2aec <_sk_load_tables_sse2+0x164> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 60,2 // cmp $0x2,%al .byte 116,19 // je 2ae2 <_sk_load_tables_sse2+0x15a> .byte 60,3 // cmp $0x3,%al .byte 15,133,220,254,255,255 // jne 29b3 <_sk_load_tables_sse2+0x2b> .byte 102,15,110,68,187,8 // movd 0x8(%ebx,%edi,4),%xmm0 .byte 102,15,112,216,69 // pshufd $0x45,%xmm0,%xmm3 .byte 102,15,18,28,187 // movlpd (%ebx,%edi,4),%xmm3 .byte 233,199,254,255,255 // jmp 29b3 <_sk_load_tables_sse2+0x2b> .byte 102,15,110,28,187 // movd (%ebx,%edi,4),%xmm3 .byte 233,189,254,255,255 // jmp 29b3 <_sk_load_tables_sse2+0x2b> HIDDEN _sk_load_tables_u16_be_sse2 .globl _sk_load_tables_u16_be_sse2 FUNCTION(_sk_load_tables_u16_be_sse2) _sk_load_tables_u16_be_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,44 // sub $0x2c,%esp .byte 232,0,0,0,0 // call 2b04 <_sk_load_tables_u16_be_sse2+0xe> .byte 90 // pop %edx .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 139,24 // mov (%eax),%ebx .byte 139,64,8 // mov 0x8(%eax),%eax .byte 193,227,2 // shl $0x2,%ebx .byte 133,192 // test %eax,%eax .byte 139,57 // mov (%ecx),%edi .byte 139,15 // mov (%edi),%ecx .byte 190,255,0,255,0 // mov $0xff00ff,%esi .byte 15,133,166,1,0,0 // jne 2cca <_sk_load_tables_u16_be_sse2+0x1d4> .byte 102,15,16,4,89 // movupd (%ecx,%ebx,2),%xmm0 .byte 243,15,111,76,89,16 // movdqu 0x10(%ecx,%ebx,2),%xmm1 .byte 102,15,40,216 // movapd %xmm0,%xmm3 .byte 102,15,97,217 // punpcklwd %xmm1,%xmm3 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 102,15,105,216 // punpckhwd %xmm0,%xmm3 .byte 102,15,112,194,229 // pshufd $0xe5,%xmm2,%xmm0 .byte 102,15,126,192 // movd %xmm0,%eax .byte 102,15,126,209 // movd %xmm2,%ecx .byte 102,15,112,202,78 // pshufd $0x4e,%xmm2,%xmm1 .byte 102,15,112,234,231 // pshufd $0xe7,%xmm2,%xmm5 .byte 33,241 // and %esi,%ecx .byte 137,77,216 // mov %ecx,-0x28(%ebp) .byte 33,240 // and %esi,%eax .byte 137,69,220 // mov %eax,-0x24(%ebp) .byte 243,15,126,69,216 // movq -0x28(%ebp),%xmm0 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 102,15,97,194 // punpcklwd %xmm2,%xmm0 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,112,208,229 // pshufd $0xe5,%xmm0,%xmm2 .byte 102,15,112,240,231 // pshufd $0xe7,%xmm0,%xmm6 .byte 102,15,126,240 // movd %xmm6,%eax .byte 139,79,4 // mov 0x4(%edi),%ecx .byte 243,15,16,52,129 // movss (%ecx,%eax,4),%xmm6 .byte 102,15,126,208 // movd %xmm2,%eax .byte 243,15,16,20,129 // movss (%ecx,%eax,4),%xmm2 .byte 102,15,126,192 // movd %xmm0,%eax .byte 102,15,112,248,78 // pshufd $0x4e,%xmm0,%xmm7 .byte 243,15,16,4,129 // movss (%ecx,%eax,4),%xmm0 .byte 102,15,126,248 // movd %xmm7,%eax .byte 243,15,16,60,129 // movss (%ecx,%eax,4),%xmm7 .byte 102,15,126,232 // movd %xmm5,%eax .byte 139,79,8 // mov 0x8(%edi),%ecx .byte 33,240 // and %esi,%eax .byte 137,69,228 // mov %eax,-0x1c(%ebp) .byte 102,15,126,200 // movd %xmm1,%eax .byte 102,15,112,203,229 // pshufd $0xe5,%xmm3,%xmm1 .byte 33,240 // and %esi,%eax .byte 137,69,224 // mov %eax,-0x20(%ebp) .byte 102,15,126,200 // movd %xmm1,%eax .byte 243,15,126,109,224 // movq -0x20(%ebp),%xmm5 .byte 102,15,97,236 // punpcklwd %xmm4,%xmm5 .byte 102,15,112,205,231 // pshufd $0xe7,%xmm5,%xmm1 .byte 102,15,126,203 // movd %xmm1,%ebx .byte 243,15,16,36,153 // movss (%ecx,%ebx,4),%xmm4 .byte 15,20,214 // unpcklps %xmm6,%xmm2 .byte 102,15,112,205,229 // pshufd $0xe5,%xmm5,%xmm1 .byte 102,15,126,203 // movd %xmm1,%ebx .byte 243,15,16,52,153 // movss (%ecx,%ebx,4),%xmm6 .byte 15,20,199 // unpcklps %xmm7,%xmm0 .byte 102,15,126,235 // movd %xmm5,%ebx .byte 243,15,16,12,153 // movss (%ecx,%ebx,4),%xmm1 .byte 102,15,112,237,78 // pshufd $0x4e,%xmm5,%xmm5 .byte 102,15,126,235 // movd %xmm5,%ebx .byte 243,15,16,44,153 // movss (%ecx,%ebx,4),%xmm5 .byte 102,15,126,217 // movd %xmm3,%ecx .byte 139,127,12 // mov 0xc(%edi),%edi .byte 33,241 // and %esi,%ecx .byte 137,77,232 // mov %ecx,-0x18(%ebp) .byte 33,240 // and %esi,%eax .byte 15,20,194 // unpcklps %xmm2,%xmm0 .byte 15,20,244 // unpcklps %xmm4,%xmm6 .byte 15,20,205 // unpcklps %xmm5,%xmm1 .byte 15,20,206 // unpcklps %xmm6,%xmm1 .byte 137,69,236 // mov %eax,-0x14(%ebp) .byte 243,15,126,85,232 // movq -0x18(%ebp),%xmm2 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 102,15,97,212 // punpcklwd %xmm4,%xmm2 .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 102,15,112,226,229 // pshufd $0xe5,%xmm2,%xmm4 .byte 102,15,112,234,231 // pshufd $0xe7,%xmm2,%xmm5 .byte 102,15,126,232 // movd %xmm5,%eax .byte 243,15,16,44,135 // movss (%edi,%eax,4),%xmm5 .byte 102,15,126,224 // movd %xmm4,%eax .byte 243,15,16,36,135 // movss (%edi,%eax,4),%xmm4 .byte 102,15,126,208 // movd %xmm2,%eax .byte 102,15,112,242,78 // pshufd $0x4e,%xmm2,%xmm6 .byte 243,15,16,20,135 // movss (%edi,%eax,4),%xmm2 .byte 102,15,126,240 // movd %xmm6,%eax .byte 243,15,16,52,135 // movss (%edi,%eax,4),%xmm6 .byte 15,20,229 // unpcklps %xmm5,%xmm4 .byte 15,20,214 // unpcklps %xmm6,%xmm2 .byte 15,20,212 // unpcklps %xmm4,%xmm2 .byte 102,15,112,219,78 // pshufd $0x4e,%xmm3,%xmm3 .byte 102,15,111,227 // movdqa %xmm3,%xmm4 .byte 102,15,113,244,8 // psllw $0x8,%xmm4 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,235,220 // por %xmm4,%xmm3 .byte 102,15,126,93,208 // movd %xmm3,-0x30(%ebp) .byte 102,15,112,219,229 // pshufd $0xe5,%xmm3,%xmm3 .byte 102,15,126,93,212 // movd %xmm3,-0x2c(%ebp) .byte 243,15,126,93,208 // movq -0x30(%ebp),%xmm3 .byte 102,15,97,223 // punpcklwd %xmm7,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,154,156,75,0,0 // mulps 0x4b9c(%edx),%xmm3 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 137,193 // mov %eax,%ecx .byte 141,65,8 // lea 0x8(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,81,4 // call *0x4(%ecx) .byte 131,196,60 // add $0x3c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 242,15,16,4,89 // movsd (%ecx,%ebx,2),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 131,248,1 // cmp $0x1,%eax .byte 15,132,83,254,255,255 // je 2b2f <_sk_load_tables_u16_be_sse2+0x39> .byte 102,15,22,68,89,8 // movhpd 0x8(%ecx,%ebx,2),%xmm0 .byte 131,248,3 // cmp $0x3,%eax .byte 15,130,68,254,255,255 // jb 2b2f <_sk_load_tables_u16_be_sse2+0x39> .byte 243,15,126,76,89,16 // movq 0x10(%ecx,%ebx,2),%xmm1 .byte 233,57,254,255,255 // jmp 2b2f <_sk_load_tables_u16_be_sse2+0x39> HIDDEN _sk_load_tables_rgb_u16_be_sse2 .globl _sk_load_tables_rgb_u16_be_sse2 FUNCTION(_sk_load_tables_rgb_u16_be_sse2) _sk_load_tables_rgb_u16_be_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,28 // sub $0x1c,%esp .byte 232,0,0,0,0 // call 2d04 <_sk_load_tables_rgb_u16_be_sse2+0xe> .byte 88 // pop %eax .byte 137,69,240 // mov %eax,-0x10(%ebp) .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,85,8 // mov 0x8(%ebp),%edx .byte 139,74,8 // mov 0x8(%edx),%ecx .byte 107,26,3 // imul $0x3,(%edx),%ebx .byte 133,201 // test %ecx,%ecx .byte 139,56 // mov (%eax),%edi .byte 139,7 // mov (%edi),%eax .byte 190,255,0,255,0 // mov $0xff00ff,%esi .byte 15,133,141,1,0,0 // jne 2eb2 <_sk_load_tables_rgb_u16_be_sse2+0x1bc> .byte 243,15,111,12,88 // movdqu (%eax,%ebx,2),%xmm1 .byte 243,15,111,92,88,8 // movdqu 0x8(%eax,%ebx,2),%xmm3 .byte 102,15,115,219,4 // psrldq $0x4,%xmm3 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,115,216,6 // psrldq $0x6,%xmm0 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,15,115,218,6 // psrldq $0x6,%xmm2 .byte 102,15,97,203 // punpcklwd %xmm3,%xmm1 .byte 102,15,97,194 // punpcklwd %xmm2,%xmm0 .byte 102,15,111,209 // movdqa %xmm1,%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 102,15,112,226,78 // pshufd $0x4e,%xmm2,%xmm4 .byte 102,15,105,200 // punpckhwd %xmm0,%xmm1 .byte 102,15,112,194,229 // pshufd $0xe5,%xmm2,%xmm0 .byte 102,15,126,192 // movd %xmm0,%eax .byte 102,15,126,209 // movd %xmm2,%ecx .byte 102,15,112,196,229 // pshufd $0xe5,%xmm4,%xmm0 .byte 102,15,126,195 // movd %xmm0,%ebx .byte 33,241 // and %esi,%ecx .byte 137,77,216 // mov %ecx,-0x28(%ebp) .byte 33,240 // and %esi,%eax .byte 137,69,220 // mov %eax,-0x24(%ebp) .byte 243,15,126,69,216 // movq -0x28(%ebp),%xmm0 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 102,15,97,194 // punpcklwd %xmm2,%xmm0 .byte 102,15,239,255 // pxor %xmm7,%xmm7 .byte 102,15,112,216,229 // pshufd $0xe5,%xmm0,%xmm3 .byte 102,15,112,232,231 // pshufd $0xe7,%xmm0,%xmm5 .byte 102,15,126,232 // movd %xmm5,%eax .byte 139,79,4 // mov 0x4(%edi),%ecx .byte 243,15,16,52,129 // movss (%ecx,%eax,4),%xmm6 .byte 102,15,126,216 // movd %xmm3,%eax .byte 243,15,16,20,129 // movss (%ecx,%eax,4),%xmm2 .byte 102,15,126,192 // movd %xmm0,%eax .byte 102,15,112,232,78 // pshufd $0x4e,%xmm0,%xmm5 .byte 243,15,16,28,129 // movss (%ecx,%eax,4),%xmm3 .byte 102,15,126,232 // movd %xmm5,%eax .byte 243,15,16,44,129 // movss (%ecx,%eax,4),%xmm5 .byte 102,15,126,224 // movd %xmm4,%eax .byte 102,15,112,225,229 // pshufd $0xe5,%xmm1,%xmm4 .byte 139,79,8 // mov 0x8(%edi),%ecx .byte 33,240 // and %esi,%eax .byte 137,69,224 // mov %eax,-0x20(%ebp) .byte 102,15,126,224 // movd %xmm4,%eax .byte 33,243 // and %esi,%ebx .byte 137,93,228 // mov %ebx,-0x1c(%ebp) .byte 243,15,126,101,224 // movq -0x20(%ebp),%xmm4 .byte 102,15,97,231 // punpcklwd %xmm7,%xmm4 .byte 102,15,112,252,231 // pshufd $0xe7,%xmm4,%xmm7 .byte 102,15,126,251 // movd %xmm7,%ebx .byte 243,15,16,60,153 // movss (%ecx,%ebx,4),%xmm7 .byte 102,15,126,203 // movd %xmm1,%ebx .byte 102,15,112,204,229 // pshufd $0xe5,%xmm4,%xmm1 .byte 102,15,126,202 // movd %xmm1,%edx .byte 243,15,16,4,145 // movss (%ecx,%edx,4),%xmm0 .byte 15,20,214 // unpcklps %xmm6,%xmm2 .byte 102,15,126,226 // movd %xmm4,%edx .byte 243,15,16,12,145 // movss (%ecx,%edx,4),%xmm1 .byte 102,15,112,228,78 // pshufd $0x4e,%xmm4,%xmm4 .byte 102,15,126,226 // movd %xmm4,%edx .byte 243,15,16,36,145 // movss (%ecx,%edx,4),%xmm4 .byte 139,79,12 // mov 0xc(%edi),%ecx .byte 33,243 // and %esi,%ebx .byte 137,93,232 // mov %ebx,-0x18(%ebp) .byte 33,240 // and %esi,%eax .byte 15,20,221 // unpcklps %xmm5,%xmm3 .byte 15,20,218 // unpcklps %xmm2,%xmm3 .byte 15,20,199 // unpcklps %xmm7,%xmm0 .byte 137,69,236 // mov %eax,-0x14(%ebp) .byte 243,15,126,85,232 // movq -0x18(%ebp),%xmm2 .byte 15,87,237 // xorps %xmm5,%xmm5 .byte 102,15,97,213 // punpcklwd %xmm5,%xmm2 .byte 102,15,112,234,229 // pshufd $0xe5,%xmm2,%xmm5 .byte 102,15,112,242,231 // pshufd $0xe7,%xmm2,%xmm6 .byte 102,15,126,240 // movd %xmm6,%eax .byte 243,15,16,52,129 // movss (%ecx,%eax,4),%xmm6 .byte 102,15,126,232 // movd %xmm5,%eax .byte 243,15,16,44,129 // movss (%ecx,%eax,4),%xmm5 .byte 102,15,126,208 // movd %xmm2,%eax .byte 102,15,112,250,78 // pshufd $0x4e,%xmm2,%xmm7 .byte 243,15,16,20,129 // movss (%ecx,%eax,4),%xmm2 .byte 102,15,126,248 // movd %xmm7,%eax .byte 243,15,16,60,129 // movss (%ecx,%eax,4),%xmm7 .byte 15,20,204 // unpcklps %xmm4,%xmm1 .byte 15,20,200 // unpcklps %xmm0,%xmm1 .byte 15,20,238 // unpcklps %xmm6,%xmm5 .byte 15,20,215 // unpcklps %xmm7,%xmm2 .byte 15,20,213 // unpcklps %xmm5,%xmm2 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 137,193 // mov %eax,%ecx .byte 141,65,8 // lea 0x8(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 139,85,240 // mov -0x10(%ebp),%edx .byte 15,40,162,172,73,0,0 // movaps 0x49ac(%edx),%xmm4 .byte 15,40,195 // movaps %xmm3,%xmm0 .byte 15,40,220 // movaps %xmm4,%xmm3 .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,81,4 // call *0x4(%ecx) .byte 131,196,44 // add $0x2c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 102,15,110,12,88 // movd (%eax,%ebx,2),%xmm1 .byte 102,15,196,76,88,4,2 // pinsrw $0x2,0x4(%eax,%ebx,2),%xmm1 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 131,249,1 // cmp $0x1,%ecx .byte 117,13 // jne 2ed4 <_sk_load_tables_rgb_u16_be_sse2+0x1de> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 233,115,254,255,255 // jmp 2d47 <_sk_load_tables_rgb_u16_be_sse2+0x51> .byte 102,15,110,68,88,6 // movd 0x6(%eax,%ebx,2),%xmm0 .byte 102,15,196,68,88,10,2 // pinsrw $0x2,0xa(%eax,%ebx,2),%xmm0 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 131,249,3 // cmp $0x3,%ecx .byte 114,18 // jb 2efc <_sk_load_tables_rgb_u16_be_sse2+0x206> .byte 102,15,110,92,88,12 // movd 0xc(%eax,%ebx,2),%xmm3 .byte 102,15,196,92,88,16,2 // pinsrw $0x2,0x10(%eax,%ebx,2),%xmm3 .byte 233,75,254,255,255 // jmp 2d47 <_sk_load_tables_rgb_u16_be_sse2+0x51> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 233,66,254,255,255 // jmp 2d47 <_sk_load_tables_rgb_u16_be_sse2+0x51> HIDDEN _sk_byte_tables_sse2 .globl _sk_byte_tables_sse2 FUNCTION(_sk_byte_tables_sse2) _sk_byte_tables_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 2f13 <_sk_byte_tables_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 15,40,162,173,71,0,0 // movaps 0x47ad(%edx),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 102,15,112,232,78 // pshufd $0x4e,%xmm0,%xmm5 .byte 102,15,126,238 // movd %xmm5,%esi .byte 102,15,112,232,231 // pshufd $0xe7,%xmm0,%xmm5 .byte 139,57 // mov (%ecx),%edi .byte 15,182,52,55 // movzbl (%edi,%esi,1),%esi .byte 102,15,126,235 // movd %xmm5,%ebx .byte 15,182,28,31 // movzbl (%edi,%ebx,1),%ebx .byte 193,227,8 // shl $0x8,%ebx .byte 9,243 // or %esi,%ebx .byte 102,15,112,232,229 // pshufd $0xe5,%xmm0,%xmm5 .byte 102,15,126,198 // movd %xmm0,%esi .byte 15,182,52,55 // movzbl (%edi,%esi,1),%esi .byte 102,15,126,232 // movd %xmm5,%eax .byte 15,182,4,7 // movzbl (%edi,%eax,1),%eax .byte 193,224,8 // shl $0x8,%eax .byte 9,240 // or %esi,%eax .byte 102,15,196,192,0 // pinsrw $0x0,%eax,%xmm0 .byte 139,65,4 // mov 0x4(%ecx),%eax .byte 102,15,196,195,1 // pinsrw $0x1,%ebx,%xmm0 .byte 15,40,170,189,71,0,0 // movaps 0x47bd(%edx),%xmm5 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 102,15,91,201 // cvtps2dq %xmm1,%xmm1 .byte 102,15,112,241,78 // pshufd $0x4e,%xmm1,%xmm6 .byte 102,15,126,242 // movd %xmm6,%edx .byte 102,15,112,241,231 // pshufd $0xe7,%xmm1,%xmm6 .byte 102,15,126,246 // movd %xmm6,%esi .byte 15,182,20,16 // movzbl (%eax,%edx,1),%edx .byte 15,182,52,48 // movzbl (%eax,%esi,1),%esi .byte 193,230,8 // shl $0x8,%esi .byte 9,214 // or %edx,%esi .byte 102,15,126,202 // movd %xmm1,%edx .byte 102,15,112,201,229 // pshufd $0xe5,%xmm1,%xmm1 .byte 15,182,20,16 // movzbl (%eax,%edx,1),%edx .byte 102,15,126,207 // movd %xmm1,%edi .byte 15,182,4,56 // movzbl (%eax,%edi,1),%eax .byte 193,224,8 // shl $0x8,%eax .byte 9,208 // or %edx,%eax .byte 102,15,196,200,0 // pinsrw $0x0,%eax,%xmm1 .byte 102,15,196,206,1 // pinsrw $0x1,%esi,%xmm1 .byte 139,65,8 // mov 0x8(%ecx),%eax .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 102,15,91,210 // cvtps2dq %xmm2,%xmm2 .byte 102,15,112,242,78 // pshufd $0x4e,%xmm2,%xmm6 .byte 102,15,126,242 // movd %xmm6,%edx .byte 102,15,112,242,231 // pshufd $0xe7,%xmm2,%xmm6 .byte 102,15,126,246 // movd %xmm6,%esi .byte 15,182,20,16 // movzbl (%eax,%edx,1),%edx .byte 15,182,52,48 // movzbl (%eax,%esi,1),%esi .byte 193,230,8 // shl $0x8,%esi .byte 9,214 // or %edx,%esi .byte 102,15,126,210 // movd %xmm2,%edx .byte 102,15,112,210,229 // pshufd $0xe5,%xmm2,%xmm2 .byte 15,182,20,16 // movzbl (%eax,%edx,1),%edx .byte 102,15,126,215 // movd %xmm2,%edi .byte 15,182,4,56 // movzbl (%eax,%edi,1),%eax .byte 193,224,8 // shl $0x8,%eax .byte 9,208 // or %edx,%eax .byte 102,15,196,208,0 // pinsrw $0x0,%eax,%xmm2 .byte 102,15,196,214,1 // pinsrw $0x1,%esi,%xmm2 .byte 139,65,12 // mov 0xc(%ecx),%eax .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 102,15,91,219 // cvtps2dq %xmm3,%xmm3 .byte 102,15,126,217 // movd %xmm3,%ecx .byte 102,15,112,227,229 // pshufd $0xe5,%xmm3,%xmm4 .byte 102,15,112,243,78 // pshufd $0x4e,%xmm3,%xmm6 .byte 102,15,126,242 // movd %xmm6,%edx .byte 102,15,112,219,231 // pshufd $0xe7,%xmm3,%xmm3 .byte 102,15,126,222 // movd %xmm3,%esi .byte 15,182,20,16 // movzbl (%eax,%edx,1),%edx .byte 15,182,52,48 // movzbl (%eax,%esi,1),%esi .byte 193,230,8 // shl $0x8,%esi .byte 9,214 // or %edx,%esi .byte 102,15,126,226 // movd %xmm4,%edx .byte 15,182,12,8 // movzbl (%eax,%ecx,1),%ecx .byte 15,182,4,16 // movzbl (%eax,%edx,1),%eax .byte 193,224,8 // shl $0x8,%eax .byte 9,200 // or %ecx,%eax .byte 102,15,196,216,0 // pinsrw $0x0,%eax,%xmm3 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,96,196 // punpcklbw %xmm4,%xmm0 .byte 102,15,97,196 // punpcklwd %xmm4,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 102,15,96,204 // punpcklbw %xmm4,%xmm1 .byte 102,15,97,204 // punpcklwd %xmm4,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 102,15,96,212 // punpcklbw %xmm4,%xmm2 .byte 102,15,97,212 // punpcklwd %xmm4,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 102,15,196,222,1 // pinsrw $0x1,%esi,%xmm3 .byte 102,15,96,220 // punpcklbw %xmm4,%xmm3 .byte 102,15,97,220 // punpcklwd %xmm4,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,65,8 // lea 0x8(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,81,4 // call *0x4(%ecx) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_byte_tables_rgb_sse2 .globl _sk_byte_tables_rgb_sse2 FUNCTION(_sk_byte_tables_rgb_sse2) _sk_byte_tables_rgb_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,81,12 // mov 0xc(%ecx),%edx .byte 74 // dec %edx .byte 102,15,110,226 // movd %edx,%xmm4 .byte 102,15,112,228,0 // pshufd $0x0,%xmm4,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 102,15,112,232,78 // pshufd $0x4e,%xmm0,%xmm5 .byte 102,15,126,234 // movd %xmm5,%edx .byte 102,15,112,232,231 // pshufd $0xe7,%xmm0,%xmm5 .byte 102,15,126,238 // movd %xmm5,%esi .byte 139,57 // mov (%ecx),%edi .byte 15,182,20,23 // movzbl (%edi,%edx,1),%edx .byte 15,182,52,55 // movzbl (%edi,%esi,1),%esi .byte 193,230,8 // shl $0x8,%esi .byte 9,214 // or %edx,%esi .byte 102,15,126,194 // movd %xmm0,%edx .byte 102,15,112,192,229 // pshufd $0xe5,%xmm0,%xmm0 .byte 15,182,20,23 // movzbl (%edi,%edx,1),%edx .byte 102,15,126,195 // movd %xmm0,%ebx .byte 15,182,60,31 // movzbl (%edi,%ebx,1),%edi .byte 193,231,8 // shl $0x8,%edi .byte 9,215 // or %edx,%edi .byte 232,0,0,0,0 // call 3113 <_sk_byte_tables_rgb_sse2+0x65> .byte 90 // pop %edx .byte 102,15,196,199,0 // pinsrw $0x0,%edi,%xmm0 .byte 139,121,4 // mov 0x4(%ecx),%edi .byte 102,15,196,198,1 // pinsrw $0x1,%esi,%xmm0 .byte 15,40,170,205,69,0,0 // movaps 0x45cd(%edx),%xmm5 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 102,15,91,201 // cvtps2dq %xmm1,%xmm1 .byte 102,15,112,241,78 // pshufd $0x4e,%xmm1,%xmm6 .byte 102,15,126,242 // movd %xmm6,%edx .byte 102,15,112,241,231 // pshufd $0xe7,%xmm1,%xmm6 .byte 102,15,126,246 // movd %xmm6,%esi .byte 15,182,20,23 // movzbl (%edi,%edx,1),%edx .byte 15,182,52,55 // movzbl (%edi,%esi,1),%esi .byte 193,230,8 // shl $0x8,%esi .byte 9,214 // or %edx,%esi .byte 102,15,126,202 // movd %xmm1,%edx .byte 102,15,112,201,229 // pshufd $0xe5,%xmm1,%xmm1 .byte 15,182,20,23 // movzbl (%edi,%edx,1),%edx .byte 102,15,126,203 // movd %xmm1,%ebx .byte 15,182,60,31 // movzbl (%edi,%ebx,1),%edi .byte 193,231,8 // shl $0x8,%edi .byte 9,215 // or %edx,%edi .byte 102,15,196,207,0 // pinsrw $0x0,%edi,%xmm1 .byte 102,15,196,206,1 // pinsrw $0x1,%esi,%xmm1 .byte 139,73,8 // mov 0x8(%ecx),%ecx .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 102,15,91,210 // cvtps2dq %xmm2,%xmm2 .byte 102,15,126,210 // movd %xmm2,%edx .byte 102,15,112,226,229 // pshufd $0xe5,%xmm2,%xmm4 .byte 102,15,112,242,78 // pshufd $0x4e,%xmm2,%xmm6 .byte 102,15,126,246 // movd %xmm6,%esi .byte 102,15,112,210,231 // pshufd $0xe7,%xmm2,%xmm2 .byte 102,15,126,215 // movd %xmm2,%edi .byte 15,182,52,49 // movzbl (%ecx,%esi,1),%esi .byte 15,182,60,57 // movzbl (%ecx,%edi,1),%edi .byte 193,231,8 // shl $0x8,%edi .byte 9,247 // or %esi,%edi .byte 102,15,126,230 // movd %xmm4,%esi .byte 15,182,20,17 // movzbl (%ecx,%edx,1),%edx .byte 15,182,12,49 // movzbl (%ecx,%esi,1),%ecx .byte 193,225,8 // shl $0x8,%ecx .byte 9,209 // or %edx,%ecx .byte 102,15,196,209,0 // pinsrw $0x0,%ecx,%xmm2 .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,96,196 // punpcklbw %xmm4,%xmm0 .byte 102,15,97,196 // punpcklwd %xmm4,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 102,15,96,204 // punpcklbw %xmm4,%xmm1 .byte 102,15,97,204 // punpcklwd %xmm4,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 102,15,196,215,1 // pinsrw $0x1,%edi,%xmm2 .byte 102,15,96,212 // punpcklbw %xmm4,%xmm2 .byte 102,15,97,212 // punpcklwd %xmm4,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_table_r_sse2 .globl _sk_table_r_sse2 FUNCTION(_sk_table_r_sse2) _sk_table_r_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 139,73,4 // mov 0x4(%ecx),%ecx .byte 73 // dec %ecx .byte 102,15,110,225 // movd %ecx,%xmm4 .byte 102,15,112,228,0 // pshufd $0x0,%xmm4,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 102,15,91,196 // cvtps2dq %xmm4,%xmm0 .byte 102,15,112,224,229 // pshufd $0xe5,%xmm0,%xmm4 .byte 102,15,112,232,231 // pshufd $0xe7,%xmm0,%xmm5 .byte 102,15,126,233 // movd %xmm5,%ecx .byte 243,15,16,44,138 // movss (%edx,%ecx,4),%xmm5 .byte 102,15,126,225 // movd %xmm4,%ecx .byte 243,15,16,36,138 // movss (%edx,%ecx,4),%xmm4 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 102,15,112,240,78 // pshufd $0x4e,%xmm0,%xmm6 .byte 243,15,16,4,138 // movss (%edx,%ecx,4),%xmm0 .byte 102,15,126,241 // movd %xmm6,%ecx .byte 243,15,16,52,138 // movss (%edx,%ecx,4),%xmm6 .byte 15,20,229 // unpcklps %xmm5,%xmm4 .byte 15,20,198 // unpcklps %xmm6,%xmm0 .byte 15,20,196 // unpcklps %xmm4,%xmm0 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_table_g_sse2 .globl _sk_table_g_sse2 FUNCTION(_sk_table_g_sse2) _sk_table_g_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 139,73,4 // mov 0x4(%ecx),%ecx .byte 73 // dec %ecx .byte 102,15,110,225 // movd %ecx,%xmm4 .byte 102,15,112,228,0 // pshufd $0x0,%xmm4,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 102,15,91,204 // cvtps2dq %xmm4,%xmm1 .byte 102,15,112,225,229 // pshufd $0xe5,%xmm1,%xmm4 .byte 102,15,112,233,231 // pshufd $0xe7,%xmm1,%xmm5 .byte 102,15,126,233 // movd %xmm5,%ecx .byte 243,15,16,44,138 // movss (%edx,%ecx,4),%xmm5 .byte 102,15,126,225 // movd %xmm4,%ecx .byte 243,15,16,36,138 // movss (%edx,%ecx,4),%xmm4 .byte 102,15,126,201 // movd %xmm1,%ecx .byte 102,15,112,241,78 // pshufd $0x4e,%xmm1,%xmm6 .byte 243,15,16,12,138 // movss (%edx,%ecx,4),%xmm1 .byte 102,15,126,241 // movd %xmm6,%ecx .byte 243,15,16,52,138 // movss (%edx,%ecx,4),%xmm6 .byte 15,20,229 // unpcklps %xmm5,%xmm4 .byte 15,20,206 // unpcklps %xmm6,%xmm1 .byte 15,20,204 // unpcklps %xmm4,%xmm1 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_table_b_sse2 .globl _sk_table_b_sse2 FUNCTION(_sk_table_b_sse2) _sk_table_b_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 139,73,4 // mov 0x4(%ecx),%ecx .byte 73 // dec %ecx .byte 102,15,110,225 // movd %ecx,%xmm4 .byte 102,15,112,228,0 // pshufd $0x0,%xmm4,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,226 // mulps %xmm2,%xmm4 .byte 102,15,91,212 // cvtps2dq %xmm4,%xmm2 .byte 102,15,112,226,229 // pshufd $0xe5,%xmm2,%xmm4 .byte 102,15,112,234,231 // pshufd $0xe7,%xmm2,%xmm5 .byte 102,15,126,233 // movd %xmm5,%ecx .byte 243,15,16,44,138 // movss (%edx,%ecx,4),%xmm5 .byte 102,15,126,225 // movd %xmm4,%ecx .byte 243,15,16,36,138 // movss (%edx,%ecx,4),%xmm4 .byte 102,15,126,209 // movd %xmm2,%ecx .byte 102,15,112,242,78 // pshufd $0x4e,%xmm2,%xmm6 .byte 243,15,16,20,138 // movss (%edx,%ecx,4),%xmm2 .byte 102,15,126,241 // movd %xmm6,%ecx .byte 243,15,16,52,138 // movss (%edx,%ecx,4),%xmm6 .byte 15,20,229 // unpcklps %xmm5,%xmm4 .byte 15,20,214 // unpcklps %xmm6,%xmm2 .byte 15,20,212 // unpcklps %xmm4,%xmm2 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_table_a_sse2 .globl _sk_table_a_sse2 FUNCTION(_sk_table_a_sse2) _sk_table_a_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 139,73,4 // mov 0x4(%ecx),%ecx .byte 73 // dec %ecx .byte 102,15,110,225 // movd %ecx,%xmm4 .byte 102,15,112,228,0 // pshufd $0x0,%xmm4,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 102,15,91,220 // cvtps2dq %xmm4,%xmm3 .byte 102,15,112,227,229 // pshufd $0xe5,%xmm3,%xmm4 .byte 102,15,112,235,231 // pshufd $0xe7,%xmm3,%xmm5 .byte 102,15,126,233 // movd %xmm5,%ecx .byte 243,15,16,44,138 // movss (%edx,%ecx,4),%xmm5 .byte 102,15,126,225 // movd %xmm4,%ecx .byte 243,15,16,36,138 // movss (%edx,%ecx,4),%xmm4 .byte 102,15,126,217 // movd %xmm3,%ecx .byte 102,15,112,243,78 // pshufd $0x4e,%xmm3,%xmm6 .byte 243,15,16,28,138 // movss (%edx,%ecx,4),%xmm3 .byte 102,15,126,241 // movd %xmm6,%ecx .byte 243,15,16,52,138 // movss (%edx,%ecx,4),%xmm6 .byte 15,20,229 // unpcklps %xmm5,%xmm4 .byte 15,20,222 // unpcklps %xmm6,%xmm3 .byte 15,20,220 // unpcklps %xmm4,%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_parametric_r_sse2 .globl _sk_parametric_r_sse2 FUNCTION(_sk_parametric_r_sse2) _sk_parametric_r_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,24 // sub $0x18,%esp .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,40,209 // movaps %xmm1,%xmm2 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 232,0,0,0,0 // call 33e2 <_sk_parametric_r_sse2+0x18> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,105,16 // movss 0x10(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 243,15,16,97,12 // movss 0xc(%ecx),%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 243,15,16,113,4 // movss 0x4(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,194,205,2 // cmpleps %xmm5,%xmm1 .byte 243,15,16,105,24 // movss 0x18(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 243,15,16,105,8 // movss 0x8(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,245 // addps %xmm5,%xmm6 .byte 15,91,238 // cvtdq2ps %xmm6,%xmm5 .byte 15,89,170,14,67,0,0 // mulps 0x430e(%edx),%xmm5 .byte 15,84,178,30,67,0,0 // andps 0x431e(%edx),%xmm6 .byte 15,86,178,46,67,0,0 // orps 0x432e(%edx),%xmm6 .byte 15,88,170,62,67,0,0 // addps 0x433e(%edx),%xmm5 .byte 15,40,186,78,67,0,0 // movaps 0x434e(%edx),%xmm7 .byte 15,89,254 // mulps %xmm6,%xmm7 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,88,178,94,67,0,0 // addps 0x435e(%edx),%xmm6 .byte 15,40,186,110,67,0,0 // movaps 0x436e(%edx),%xmm7 .byte 15,94,254 // divps %xmm6,%xmm7 .byte 243,15,16,49 // movss (%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,89,238 // mulps %xmm6,%xmm5 .byte 243,15,91,245 // cvttps2dq %xmm5,%xmm6 .byte 15,91,254 // cvtdq2ps %xmm6,%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,194,199,1 // cmpltps %xmm7,%xmm0 .byte 15,40,178,126,67,0,0 // movaps 0x437e(%edx),%xmm6 .byte 15,84,198 // andps %xmm6,%xmm0 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,92,199 // subps %xmm7,%xmm0 .byte 15,88,170,142,67,0,0 // addps 0x438e(%edx),%xmm5 .byte 15,40,186,158,67,0,0 // movaps 0x439e(%edx),%xmm7 .byte 15,89,248 // mulps %xmm0,%xmm7 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,40,186,174,67,0,0 // movaps 0x43ae(%edx),%xmm7 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,40,130,190,67,0,0 // movaps 0x43be(%edx),%xmm0 .byte 15,94,199 // divps %xmm7,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 15,89,130,206,67,0,0 // mulps 0x43ce(%edx),%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 243,15,16,105,20 // movss 0x14(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,84,225 // andps %xmm1,%xmm4 .byte 15,85,205 // andnps %xmm5,%xmm1 .byte 15,86,204 // orps %xmm4,%xmm1 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,95,200 // maxps %xmm0,%xmm1 .byte 15,93,206 // minps %xmm6,%xmm1 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,40 // add $0x28,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_parametric_g_sse2 .globl _sk_parametric_g_sse2 FUNCTION(_sk_parametric_g_sse2) _sk_parametric_g_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,24 // sub $0x18,%esp .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 232,0,0,0,0 // call 3519 <_sk_parametric_g_sse2+0x15> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,105,16 // movss 0x10(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 243,15,16,97,12 // movss 0xc(%ecx),%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 243,15,16,113,4 // movss 0x4(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,194,205,2 // cmpleps %xmm5,%xmm1 .byte 243,15,16,105,24 // movss 0x18(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 243,15,16,105,8 // movss 0x8(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,245 // addps %xmm5,%xmm6 .byte 15,91,238 // cvtdq2ps %xmm6,%xmm5 .byte 15,89,170,167,66,0,0 // mulps 0x42a7(%edx),%xmm5 .byte 15,84,178,183,66,0,0 // andps 0x42b7(%edx),%xmm6 .byte 15,86,178,199,66,0,0 // orps 0x42c7(%edx),%xmm6 .byte 15,88,170,215,66,0,0 // addps 0x42d7(%edx),%xmm5 .byte 15,40,186,231,66,0,0 // movaps 0x42e7(%edx),%xmm7 .byte 15,89,254 // mulps %xmm6,%xmm7 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,88,178,247,66,0,0 // addps 0x42f7(%edx),%xmm6 .byte 15,40,186,7,67,0,0 // movaps 0x4307(%edx),%xmm7 .byte 15,94,254 // divps %xmm6,%xmm7 .byte 243,15,16,49 // movss (%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,89,238 // mulps %xmm6,%xmm5 .byte 243,15,91,245 // cvttps2dq %xmm5,%xmm6 .byte 15,91,254 // cvtdq2ps %xmm6,%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,194,199,1 // cmpltps %xmm7,%xmm0 .byte 15,40,178,23,67,0,0 // movaps 0x4317(%edx),%xmm6 .byte 15,84,198 // andps %xmm6,%xmm0 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,92,199 // subps %xmm7,%xmm0 .byte 15,88,170,39,67,0,0 // addps 0x4327(%edx),%xmm5 .byte 15,40,186,55,67,0,0 // movaps 0x4337(%edx),%xmm7 .byte 15,89,248 // mulps %xmm0,%xmm7 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,40,186,71,67,0,0 // movaps 0x4347(%edx),%xmm7 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,40,130,87,67,0,0 // movaps 0x4357(%edx),%xmm0 .byte 15,94,199 // divps %xmm7,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 15,89,130,103,67,0,0 // mulps 0x4367(%edx),%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 243,15,16,105,20 // movss 0x14(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,84,225 // andps %xmm1,%xmm4 .byte 15,85,205 // andnps %xmm5,%xmm1 .byte 15,86,204 // orps %xmm4,%xmm1 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,95,200 // maxps %xmm0,%xmm1 .byte 15,93,206 // minps %xmm6,%xmm1 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,40 // add $0x28,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_parametric_b_sse2 .globl _sk_parametric_b_sse2 FUNCTION(_sk_parametric_b_sse2) _sk_parametric_b_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,24 // sub $0x18,%esp .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,217 // movaps %xmm1,%xmm3 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 232,0,0,0,0 // call 364d <_sk_parametric_b_sse2+0x15> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,105,16 // movss 0x10(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 243,15,16,97,12 // movss 0xc(%ecx),%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,89,226 // mulps %xmm2,%xmm4 .byte 243,15,16,113,4 // movss 0x4(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,242 // mulps %xmm2,%xmm6 .byte 15,194,213,2 // cmpleps %xmm5,%xmm2 .byte 243,15,16,105,24 // movss 0x18(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 243,15,16,105,8 // movss 0x8(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,245 // addps %xmm5,%xmm6 .byte 15,91,238 // cvtdq2ps %xmm6,%xmm5 .byte 15,89,170,67,66,0,0 // mulps 0x4243(%edx),%xmm5 .byte 15,84,178,83,66,0,0 // andps 0x4253(%edx),%xmm6 .byte 15,86,178,99,66,0,0 // orps 0x4263(%edx),%xmm6 .byte 15,88,170,115,66,0,0 // addps 0x4273(%edx),%xmm5 .byte 15,40,186,131,66,0,0 // movaps 0x4283(%edx),%xmm7 .byte 15,89,254 // mulps %xmm6,%xmm7 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,88,178,147,66,0,0 // addps 0x4293(%edx),%xmm6 .byte 15,40,186,163,66,0,0 // movaps 0x42a3(%edx),%xmm7 .byte 15,94,254 // divps %xmm6,%xmm7 .byte 243,15,16,49 // movss (%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,89,238 // mulps %xmm6,%xmm5 .byte 243,15,91,245 // cvttps2dq %xmm5,%xmm6 .byte 15,91,254 // cvtdq2ps %xmm6,%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,194,199,1 // cmpltps %xmm7,%xmm0 .byte 15,40,178,179,66,0,0 // movaps 0x42b3(%edx),%xmm6 .byte 15,84,198 // andps %xmm6,%xmm0 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,92,199 // subps %xmm7,%xmm0 .byte 15,88,170,195,66,0,0 // addps 0x42c3(%edx),%xmm5 .byte 15,40,186,211,66,0,0 // movaps 0x42d3(%edx),%xmm7 .byte 15,89,248 // mulps %xmm0,%xmm7 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,40,186,227,66,0,0 // movaps 0x42e3(%edx),%xmm7 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,40,130,243,66,0,0 // movaps 0x42f3(%edx),%xmm0 .byte 15,94,199 // divps %xmm7,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 15,89,130,3,67,0,0 // mulps 0x4303(%edx),%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 243,15,16,105,20 // movss 0x14(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,84,226 // andps %xmm2,%xmm4 .byte 15,85,213 // andnps %xmm5,%xmm2 .byte 15,86,212 // orps %xmm4,%xmm2 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,95,208 // maxps %xmm0,%xmm2 .byte 15,93,214 // minps %xmm6,%xmm2 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,40 // add $0x28,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_parametric_a_sse2 .globl _sk_parametric_a_sse2 FUNCTION(_sk_parametric_a_sse2) _sk_parametric_a_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,24 // sub $0x18,%esp .byte 15,41,85,232 // movaps %xmm2,-0x18(%ebp) .byte 15,40,209 // movaps %xmm1,%xmm2 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 232,0,0,0,0 // call 3781 <_sk_parametric_a_sse2+0x15> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,105,16 // movss 0x10(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 243,15,16,97,12 // movss 0xc(%ecx),%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 243,15,16,113,4 // movss 0x4(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,194,221,2 // cmpleps %xmm5,%xmm3 .byte 243,15,16,105,24 // movss 0x18(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,229 // addps %xmm5,%xmm4 .byte 243,15,16,105,8 // movss 0x8(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,245 // addps %xmm5,%xmm6 .byte 15,91,238 // cvtdq2ps %xmm6,%xmm5 .byte 15,89,170,223,65,0,0 // mulps 0x41df(%edx),%xmm5 .byte 15,84,178,239,65,0,0 // andps 0x41ef(%edx),%xmm6 .byte 15,86,178,255,65,0,0 // orps 0x41ff(%edx),%xmm6 .byte 15,88,170,15,66,0,0 // addps 0x420f(%edx),%xmm5 .byte 15,40,186,31,66,0,0 // movaps 0x421f(%edx),%xmm7 .byte 15,89,254 // mulps %xmm6,%xmm7 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,88,178,47,66,0,0 // addps 0x422f(%edx),%xmm6 .byte 15,40,186,63,66,0,0 // movaps 0x423f(%edx),%xmm7 .byte 15,94,254 // divps %xmm6,%xmm7 .byte 243,15,16,49 // movss (%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,89,238 // mulps %xmm6,%xmm5 .byte 243,15,91,245 // cvttps2dq %xmm5,%xmm6 .byte 15,91,254 // cvtdq2ps %xmm6,%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,194,199,1 // cmpltps %xmm7,%xmm0 .byte 15,40,178,79,66,0,0 // movaps 0x424f(%edx),%xmm6 .byte 15,84,198 // andps %xmm6,%xmm0 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,92,199 // subps %xmm7,%xmm0 .byte 15,88,170,95,66,0,0 // addps 0x425f(%edx),%xmm5 .byte 15,40,186,111,66,0,0 // movaps 0x426f(%edx),%xmm7 .byte 15,89,248 // mulps %xmm0,%xmm7 .byte 15,92,239 // subps %xmm7,%xmm5 .byte 15,40,186,127,66,0,0 // movaps 0x427f(%edx),%xmm7 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,40,130,143,66,0,0 // movaps 0x428f(%edx),%xmm0 .byte 15,94,199 // divps %xmm7,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 15,89,130,159,66,0,0 // mulps 0x429f(%edx),%xmm0 .byte 102,15,91,192 // cvtps2dq %xmm0,%xmm0 .byte 243,15,16,105,20 // movss 0x14(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,84,227 // andps %xmm3,%xmm4 .byte 15,85,221 // andnps %xmm5,%xmm3 .byte 15,86,220 // orps %xmm4,%xmm3 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,95,216 // maxps %xmm0,%xmm3 .byte 15,93,222 // minps %xmm6,%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,40,85,232 // movaps -0x18(%ebp),%xmm2 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,40 // add $0x28,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_gamma_sse2 .globl _sk_gamma_sse2 FUNCTION(_sk_gamma_sse2) _sk_gamma_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,40 // sub $0x28,%esp .byte 15,41,93,216 // movaps %xmm3,-0x28(%ebp) .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 232,0,0,0,0 // call 38b2 <_sk_gamma_sse2+0x12> .byte 88 // pop %eax .byte 15,91,195 // cvtdq2ps %xmm3,%xmm0 .byte 15,89,128,126,65,0,0 // mulps 0x417e(%eax),%xmm0 .byte 15,84,152,142,65,0,0 // andps 0x418e(%eax),%xmm3 .byte 15,86,152,158,65,0,0 // orps 0x419e(%eax),%xmm3 .byte 15,88,128,174,65,0,0 // addps 0x41ae(%eax),%xmm0 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,89,160,190,65,0,0 // mulps 0x41be(%eax),%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,88,152,206,65,0,0 // addps 0x41ce(%eax),%xmm3 .byte 15,40,160,222,65,0,0 // movaps 0x41de(%eax),%xmm4 .byte 15,94,227 // divps %xmm3,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,17 // mov (%ecx),%edx .byte 243,15,16,58 // movss (%edx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,41,125,232 // movaps %xmm7,-0x18(%ebp) .byte 243,15,91,216 // cvttps2dq %xmm0,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,194,227,1 // cmpltps %xmm3,%xmm4 .byte 15,84,160,238,65,0,0 // andps 0x41ee(%eax),%xmm4 .byte 15,92,220 // subps %xmm4,%xmm3 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,92,227 // subps %xmm3,%xmm4 .byte 15,88,128,254,65,0,0 // addps 0x41fe(%eax),%xmm0 .byte 15,40,176,30,66,0,0 // movaps 0x421e(%eax),%xmm6 .byte 15,92,244 // subps %xmm4,%xmm6 .byte 15,40,168,14,66,0,0 // movaps 0x420e(%eax),%xmm5 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,40,152,46,66,0,0 // movaps 0x422e(%eax),%xmm3 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,94,230 // divps %xmm6,%xmm4 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 15,91,193 // cvtdq2ps %xmm1,%xmm0 .byte 15,89,128,126,65,0,0 // mulps 0x417e(%eax),%xmm0 .byte 15,84,136,142,65,0,0 // andps 0x418e(%eax),%xmm1 .byte 15,86,136,158,65,0,0 // orps 0x419e(%eax),%xmm1 .byte 15,88,128,174,65,0,0 // addps 0x41ae(%eax),%xmm0 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,89,176,190,65,0,0 // mulps 0x41be(%eax),%xmm6 .byte 15,92,198 // subps %xmm6,%xmm0 .byte 15,88,136,206,65,0,0 // addps 0x41ce(%eax),%xmm1 .byte 15,40,176,222,65,0,0 // movaps 0x41de(%eax),%xmm6 .byte 15,94,241 // divps %xmm1,%xmm6 .byte 15,92,198 // subps %xmm6,%xmm0 .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 243,15,91,200 // cvttps2dq %xmm0,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,194,241,1 // cmpltps %xmm1,%xmm6 .byte 15,84,176,238,65,0,0 // andps 0x41ee(%eax),%xmm6 .byte 15,92,206 // subps %xmm6,%xmm1 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,92,241 // subps %xmm1,%xmm6 .byte 15,88,128,254,65,0,0 // addps 0x41fe(%eax),%xmm0 .byte 15,40,184,30,66,0,0 // movaps 0x421e(%eax),%xmm7 .byte 15,92,254 // subps %xmm6,%xmm7 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,92,198 // subps %xmm6,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,94,207 // divps %xmm7,%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,91,194 // cvtdq2ps %xmm2,%xmm0 .byte 15,89,128,126,65,0,0 // mulps 0x417e(%eax),%xmm0 .byte 15,84,144,142,65,0,0 // andps 0x418e(%eax),%xmm2 .byte 15,86,144,158,65,0,0 // orps 0x419e(%eax),%xmm2 .byte 15,88,128,174,65,0,0 // addps 0x41ae(%eax),%xmm0 .byte 15,40,176,190,65,0,0 // movaps 0x41be(%eax),%xmm6 .byte 15,89,242 // mulps %xmm2,%xmm6 .byte 15,92,198 // subps %xmm6,%xmm0 .byte 15,88,144,206,65,0,0 // addps 0x41ce(%eax),%xmm2 .byte 15,40,176,222,65,0,0 // movaps 0x41de(%eax),%xmm6 .byte 15,94,242 // divps %xmm2,%xmm6 .byte 15,92,198 // subps %xmm6,%xmm0 .byte 15,89,69,232 // mulps -0x18(%ebp),%xmm0 .byte 243,15,91,208 // cvttps2dq %xmm0,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,194,242,1 // cmpltps %xmm2,%xmm6 .byte 15,84,176,238,65,0,0 // andps 0x41ee(%eax),%xmm6 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,92,242 // subps %xmm2,%xmm6 .byte 15,88,128,254,65,0,0 // addps 0x41fe(%eax),%xmm0 .byte 15,89,238 // mulps %xmm6,%xmm5 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 15,40,144,30,66,0,0 // movaps 0x421e(%eax),%xmm2 .byte 15,92,214 // subps %xmm6,%xmm2 .byte 15,94,218 // divps %xmm2,%xmm3 .byte 15,88,216 // addps %xmm0,%xmm3 .byte 15,40,128,62,66,0,0 // movaps 0x423e(%eax),%xmm0 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 102,15,91,196 // cvtps2dq %xmm4,%xmm0 .byte 102,15,91,201 // cvtps2dq %xmm1,%xmm1 .byte 102,15,91,211 // cvtps2dq %xmm3,%xmm2 .byte 141,65,8 // lea 0x8(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 15,40,93,216 // movaps -0x28(%ebp),%xmm3 .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,81,4 // call *0x4(%ecx) .byte 131,196,56 // add $0x38,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_lab_to_xyz_sse2 .globl _sk_lab_to_xyz_sse2 FUNCTION(_sk_lab_to_xyz_sse2) _sk_lab_to_xyz_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,24 // sub $0x18,%esp .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 232,0,0,0,0 // call 3a9a <_sk_lab_to_xyz_sse2+0x15> .byte 88 // pop %eax .byte 15,89,144,102,64,0,0 // mulps 0x4066(%eax),%xmm2 .byte 15,40,160,118,64,0,0 // movaps 0x4076(%eax),%xmm4 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,40,168,134,64,0,0 // movaps 0x4086(%eax),%xmm5 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 15,88,221 // addps %xmm5,%xmm3 .byte 15,88,144,150,64,0,0 // addps 0x4096(%eax),%xmm2 .byte 15,89,144,166,64,0,0 // mulps 0x40a6(%eax),%xmm2 .byte 15,89,136,182,64,0,0 // mulps 0x40b6(%eax),%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 15,89,152,198,64,0,0 // mulps 0x40c6(%eax),%xmm3 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,92,235 // subps %xmm3,%xmm5 .byte 15,40,193 // movaps %xmm1,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,40,152,214,64,0,0 // movaps 0x40d6(%eax),%xmm3 .byte 15,40,227 // movaps %xmm3,%xmm4 .byte 15,194,224,1 // cmpltps %xmm0,%xmm4 .byte 15,40,176,230,64,0,0 // movaps 0x40e6(%eax),%xmm6 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 15,40,184,246,64,0,0 // movaps 0x40f6(%eax),%xmm7 .byte 15,89,207 // mulps %xmm7,%xmm1 .byte 15,84,196 // andps %xmm4,%xmm0 .byte 15,85,225 // andnps %xmm1,%xmm4 .byte 15,86,224 // orps %xmm0,%xmm4 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 15,89,194 // mulps %xmm2,%xmm0 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,194,200,1 // cmpltps %xmm0,%xmm1 .byte 15,88,214 // addps %xmm6,%xmm2 .byte 15,89,215 // mulps %xmm7,%xmm2 .byte 15,84,193 // andps %xmm1,%xmm0 .byte 15,85,202 // andnps %xmm2,%xmm1 .byte 15,86,200 // orps %xmm0,%xmm1 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,88,238 // addps %xmm6,%xmm5 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,194,216,1 // cmpltps %xmm0,%xmm3 .byte 15,84,195 // andps %xmm3,%xmm0 .byte 15,85,221 // andnps %xmm5,%xmm3 .byte 15,86,216 // orps %xmm0,%xmm3 .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 15,89,160,6,65,0,0 // mulps 0x4106(%eax),%xmm4 .byte 15,89,152,22,65,0,0 // mulps 0x4116(%eax),%xmm3 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,40 // add $0x28,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_load_a8_sse2 .globl _sk_load_a8_sse2 FUNCTION(_sk_load_a8_sse2) _sk_load_a8_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 3b8a <_sk_load_a8_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,60 // jne 3be1 <_sk_load_a8_sse2+0x65> .byte 102,15,110,4,62 // movd (%esi,%edi,1),%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 102,15,219,130,54,64,0,0 // pand 0x4036(%edx),%xmm0 .byte 15,91,216 // cvtdq2ps %xmm0,%xmm3 .byte 15,89,154,70,64,0,0 // mulps 0x4046(%edx),%xmm3 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 102,15,87,201 // xorpd %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,50 // je 3c1b <_sk_load_a8_sse2+0x9f> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 128,251,2 // cmp $0x2,%bl .byte 116,19 // je 3c05 <_sk_load_a8_sse2+0x89> .byte 128,251,3 // cmp $0x3,%bl .byte 117,187 // jne 3bb2 <_sk_load_a8_sse2+0x36> .byte 15,182,92,62,2 // movzbl 0x2(%esi,%edi,1),%ebx .byte 102,15,110,195 // movd %ebx,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 15,183,52,62 // movzwl (%esi,%edi,1),%esi .byte 102,15,110,206 // movd %esi,%xmm1 .byte 102,15,96,200 // punpcklbw %xmm0,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 242,15,16,193 // movsd %xmm1,%xmm0 .byte 235,151 // jmp 3bb2 <_sk_load_a8_sse2+0x36> .byte 15,182,52,62 // movzbl (%esi,%edi,1),%esi .byte 102,15,110,198 // movd %esi,%xmm0 .byte 235,141 // jmp 3bb2 <_sk_load_a8_sse2+0x36> HIDDEN _sk_load_a8_dst_sse2 .globl _sk_load_a8_dst_sse2 FUNCTION(_sk_load_a8_dst_sse2) _sk_load_a8_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,49 // mov (%ecx),%esi .byte 139,16 // mov (%eax),%edx .byte 139,122,4 // mov 0x4(%edx),%edi .byte 15,175,121,4 // imul 0x4(%ecx),%edi .byte 3,58 // add (%edx),%edi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 102,15,127,97,48 // movdqa %xmm4,0x30(%ecx) .byte 102,15,127,97,32 // movdqa %xmm4,0x20(%ecx) .byte 102,15,127,97,16 // movdqa %xmm4,0x10(%ecx) .byte 133,219 // test %ebx,%ebx .byte 232,0,0,0,0 // call 3c5e <_sk_load_a8_dst_sse2+0x39> .byte 90 // pop %edx .byte 117,54 // jne 3c97 <_sk_load_a8_dst_sse2+0x72> .byte 102,15,110,36,55 // movd (%edi,%esi,1),%xmm4 .byte 102,15,96,224 // punpcklbw %xmm0,%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 102,15,219,162,130,63,0,0 // pand 0x3f82(%edx),%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,162,146,63,0,0 // mulps 0x3f92(%edx),%xmm4 .byte 15,41,97,64 // movaps %xmm4,0x40(%ecx) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,46 // je 3ccd <_sk_load_a8_dst_sse2+0xa8> .byte 128,251,2 // cmp $0x2,%bl .byte 116,19 // je 3cb7 <_sk_load_a8_dst_sse2+0x92> .byte 128,251,3 // cmp $0x3,%bl .byte 117,197 // jne 3c6e <_sk_load_a8_dst_sse2+0x49> .byte 15,182,92,55,2 // movzbl 0x2(%edi,%esi,1),%ebx .byte 102,15,110,227 // movd %ebx,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 15,183,52,55 // movzwl (%edi,%esi,1),%esi .byte 102,15,110,238 // movd %esi,%xmm5 .byte 102,15,96,232 // punpcklbw %xmm0,%xmm5 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 242,15,16,229 // movsd %xmm5,%xmm4 .byte 235,161 // jmp 3c6e <_sk_load_a8_dst_sse2+0x49> .byte 15,182,52,55 // movzbl (%edi,%esi,1),%esi .byte 102,15,110,230 // movd %esi,%xmm4 .byte 235,151 // jmp 3c6e <_sk_load_a8_dst_sse2+0x49> HIDDEN _sk_gather_a8_sse2 .globl _sk_gather_a8_sse2 FUNCTION(_sk_gather_a8_sse2) _sk_gather_a8_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 87 // push %edi .byte 86 // push %esi .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,81,4 // movd 0x4(%ecx),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 102,15,112,200,229 // pshufd $0xe5,%xmm0,%xmm1 .byte 102,15,112,208,78 // pshufd $0x4e,%xmm0,%xmm2 .byte 102,15,126,214 // movd %xmm2,%esi .byte 102,15,112,192,231 // pshufd $0xe7,%xmm0,%xmm0 .byte 102,15,126,199 // movd %xmm0,%edi .byte 15,182,52,50 // movzbl (%edx,%esi,1),%esi .byte 15,182,60,58 // movzbl (%edx,%edi,1),%edi .byte 193,231,8 // shl $0x8,%edi .byte 9,247 // or %esi,%edi .byte 102,15,126,206 // movd %xmm1,%esi .byte 15,182,12,10 // movzbl (%edx,%ecx,1),%ecx .byte 15,182,20,50 // movzbl (%edx,%esi,1),%edx .byte 193,226,8 // shl $0x8,%edx .byte 9,202 // or %ecx,%edx .byte 102,15,196,194,0 // pinsrw $0x0,%edx,%xmm0 .byte 102,15,196,199,1 // pinsrw $0x1,%edi,%xmm0 .byte 232,0,0,0,0 // call 3d5c <_sk_gather_a8_sse2+0x85> .byte 89 // pop %ecx .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,15,96,193 // punpcklbw %xmm1,%xmm0 .byte 102,15,97,193 // punpcklwd %xmm1,%xmm0 .byte 15,91,216 // cvtdq2ps %xmm0,%xmm3 .byte 15,89,153,164,62,0,0 // mulps 0x3ea4(%ecx),%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,16 // add $0x10,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_store_a8_sse2 .globl _sk_store_a8_sse2 FUNCTION(_sk_store_a8_sse2) _sk_store_a8_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,60 // sub $0x3c,%esp .byte 232,0,0,0,0 // call 3da0 <_sk_store_a8_sse2+0xe> .byte 94 // pop %esi .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,87,4 // mov 0x4(%edi),%edx .byte 15,175,81,4 // imul 0x4(%ecx),%edx .byte 3,23 // add (%edi),%edx .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 15,40,166,112,62,0,0 // movaps 0x3e70(%esi),%xmm4 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 102,15,91,228 // cvtps2dq %xmm4,%xmm4 .byte 102,15,114,244,16 // pslld $0x10,%xmm4 .byte 102,15,114,228,16 // psrad $0x10,%xmm4 .byte 102,15,107,228 // packssdw %xmm4,%xmm4 .byte 102,15,103,228 // packuswb %xmm4,%xmm4 .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,26 // jne 3df5 <_sk_store_a8_sse2+0x63> .byte 102,15,126,230 // movd %xmm4,%esi .byte 137,52,58 // mov %esi,(%edx,%edi,1) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,76 // add $0x4c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 102,15,96,224 // punpcklbw %xmm0,%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,57 // je 3e3e <_sk_store_a8_sse2+0xac> .byte 128,251,2 // cmp $0x2,%bl .byte 116,17 // je 3e1b <_sk_store_a8_sse2+0x89> .byte 128,251,3 // cmp $0x3,%bl .byte 117,211 // jne 3de2 <_sk_store_a8_sse2+0x50> .byte 102,15,127,101,200 // movdqa %xmm4,-0x38(%ebp) .byte 138,93,208 // mov -0x30(%ebp),%bl .byte 136,92,58,2 // mov %bl,0x2(%edx,%edi,1) .byte 102,15,112,228,212 // pshufd $0xd4,%xmm4,%xmm4 .byte 102,15,219,166,128,62,0,0 // pand 0x3e80(%esi),%xmm4 .byte 102,15,103,228 // packuswb %xmm4,%xmm4 .byte 102,15,103,228 // packuswb %xmm4,%xmm4 .byte 102,15,103,228 // packuswb %xmm4,%xmm4 .byte 102,15,126,230 // movd %xmm4,%esi .byte 102,137,52,58 // mov %si,(%edx,%edi,1) .byte 235,164 // jmp 3de2 <_sk_store_a8_sse2+0x50> .byte 102,15,127,101,216 // movdqa %xmm4,-0x28(%ebp) .byte 138,93,216 // mov -0x28(%ebp),%bl .byte 136,28,58 // mov %bl,(%edx,%edi,1) .byte 235,151 // jmp 3de2 <_sk_store_a8_sse2+0x50> HIDDEN _sk_load_g8_sse2 .globl _sk_load_g8_sse2 FUNCTION(_sk_load_g8_sse2) _sk_load_g8_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 3e59 <_sk_load_g8_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,63 // jne 3eb3 <_sk_load_g8_sse2+0x68> .byte 102,15,110,4,62 // movd (%esi,%edi,1),%xmm0 .byte 102,15,96,192 // punpcklbw %xmm0,%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 102,15,219,130,215,61,0,0 // pand 0x3dd7(%edx),%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,130,231,61,0,0 // mulps 0x3de7(%edx),%xmm0 .byte 141,112,8 // lea 0x8(%eax),%esi .byte 131,236,8 // sub $0x8,%esp .byte 15,40,154,247,61,0,0 // movaps 0x3df7(%edx),%xmm3 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 86 // push %esi .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,50 // je 3eed <_sk_load_g8_sse2+0xa2> .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 128,251,2 // cmp $0x2,%bl .byte 116,19 // je 3ed7 <_sk_load_g8_sse2+0x8c> .byte 128,251,3 // cmp $0x3,%bl .byte 117,184 // jne 3e81 <_sk_load_g8_sse2+0x36> .byte 15,182,92,62,2 // movzbl 0x2(%esi,%edi,1),%ebx .byte 102,15,110,195 // movd %ebx,%xmm0 .byte 102,15,112,192,69 // pshufd $0x45,%xmm0,%xmm0 .byte 15,183,52,62 // movzwl (%esi,%edi,1),%esi .byte 102,15,110,206 // movd %esi,%xmm1 .byte 102,15,96,200 // punpcklbw %xmm0,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 242,15,16,193 // movsd %xmm1,%xmm0 .byte 235,148 // jmp 3e81 <_sk_load_g8_sse2+0x36> .byte 15,182,52,62 // movzbl (%esi,%edi,1),%esi .byte 102,15,110,198 // movd %esi,%xmm0 .byte 235,138 // jmp 3e81 <_sk_load_g8_sse2+0x36> HIDDEN _sk_load_g8_dst_sse2 .globl _sk_load_g8_dst_sse2 FUNCTION(_sk_load_g8_dst_sse2) _sk_load_g8_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 3f05 <_sk_load_g8_dst_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,73 // jne 3f69 <_sk_load_g8_dst_sse2+0x72> .byte 102,15,110,36,62 // movd (%esi,%edi,1),%xmm4 .byte 102,15,96,224 // punpcklbw %xmm0,%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 102,15,219,162,91,61,0,0 // pand 0x3d5b(%edx),%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,162,107,61,0,0 // mulps 0x3d6b(%edx),%xmm4 .byte 15,41,97,48 // movaps %xmm4,0x30(%ecx) .byte 15,41,97,32 // movaps %xmm4,0x20(%ecx) .byte 15,41,97,16 // movaps %xmm4,0x10(%ecx) .byte 15,40,162,123,61,0,0 // movaps 0x3d7b(%edx),%xmm4 .byte 15,41,97,64 // movaps %xmm4,0x40(%ecx) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,50 // je 3fa3 <_sk_load_g8_dst_sse2+0xac> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 128,251,2 // cmp $0x2,%bl .byte 116,19 // je 3f8d <_sk_load_g8_dst_sse2+0x96> .byte 128,251,3 // cmp $0x3,%bl .byte 117,174 // jne 3f2d <_sk_load_g8_dst_sse2+0x36> .byte 15,182,92,62,2 // movzbl 0x2(%esi,%edi,1),%ebx .byte 102,15,110,227 // movd %ebx,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 15,183,52,62 // movzwl (%esi,%edi,1),%esi .byte 102,15,110,238 // movd %esi,%xmm5 .byte 102,15,96,232 // punpcklbw %xmm0,%xmm5 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 242,15,16,229 // movsd %xmm5,%xmm4 .byte 235,138 // jmp 3f2d <_sk_load_g8_dst_sse2+0x36> .byte 15,182,52,62 // movzbl (%esi,%edi,1),%esi .byte 102,15,110,230 // movd %esi,%xmm4 .byte 235,128 // jmp 3f2d <_sk_load_g8_dst_sse2+0x36> HIDDEN _sk_gather_g8_sse2 .globl _sk_gather_g8_sse2 FUNCTION(_sk_gather_g8_sse2) _sk_gather_g8_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 87 // push %edi .byte 86 // push %esi .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,81,4 // movd 0x4(%ecx),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 102,15,112,200,229 // pshufd $0xe5,%xmm0,%xmm1 .byte 102,15,112,208,78 // pshufd $0x4e,%xmm0,%xmm2 .byte 102,15,126,214 // movd %xmm2,%esi .byte 102,15,112,192,231 // pshufd $0xe7,%xmm0,%xmm0 .byte 102,15,126,199 // movd %xmm0,%edi .byte 15,182,52,50 // movzbl (%edx,%esi,1),%esi .byte 15,182,60,58 // movzbl (%edx,%edi,1),%edi .byte 193,231,8 // shl $0x8,%edi .byte 9,247 // or %esi,%edi .byte 102,15,126,206 // movd %xmm1,%esi .byte 15,182,12,10 // movzbl (%edx,%ecx,1),%ecx .byte 15,182,20,50 // movzbl (%edx,%esi,1),%edx .byte 193,226,8 // shl $0x8,%edx .byte 9,202 // or %ecx,%edx .byte 102,15,196,194,0 // pinsrw $0x0,%edx,%xmm0 .byte 232,0,0,0,0 // call 402d <_sk_gather_g8_sse2+0x80> .byte 89 // pop %ecx .byte 102,15,196,199,1 // pinsrw $0x1,%edi,%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,15,96,193 // punpcklbw %xmm1,%xmm0 .byte 102,15,97,193 // punpcklwd %xmm1,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,129,99,60,0,0 // mulps 0x3c63(%ecx),%xmm0 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,153,115,60,0,0 // movaps 0x3c73(%ecx),%xmm3 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 82 // push %edx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,16 // add $0x10,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_load_565_sse2 .globl _sk_load_565_sse2 FUNCTION(_sk_load_565_sse2) _sk_load_565_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 4078 <_sk_load_565_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 1,246 // add %esi,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,97 // jne 40f6 <_sk_load_565_sse2+0x8c> .byte 243,15,126,20,126 // movq (%esi,%edi,2),%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 102,15,111,130,56,60,0,0 // movdqa 0x3c38(%edx),%xmm0 .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,130,72,60,0,0 // mulps 0x3c48(%edx),%xmm0 .byte 102,15,111,138,88,60,0,0 // movdqa 0x3c58(%edx),%xmm1 .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,138,104,60,0,0 // mulps 0x3c68(%edx),%xmm1 .byte 102,15,219,146,120,60,0,0 // pand 0x3c78(%edx),%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,146,136,60,0,0 // mulps 0x3c88(%edx),%xmm2 .byte 141,112,8 // lea 0x8(%eax),%esi .byte 131,236,8 // sub $0x8,%esp .byte 15,40,154,152,60,0,0 // movaps 0x3c98(%edx),%xmm3 .byte 86 // push %esi .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,46 // je 412c <_sk_load_565_sse2+0xc2> .byte 102,15,239,210 // pxor %xmm2,%xmm2 .byte 128,251,2 // cmp $0x2,%bl .byte 116,19 // je 411a <_sk_load_565_sse2+0xb0> .byte 128,251,3 // cmp $0x3,%bl .byte 117,146 // jne 409e <_sk_load_565_sse2+0x34> .byte 15,183,92,126,4 // movzwl 0x4(%esi,%edi,2),%ebx .byte 102,15,110,195 // movd %ebx,%xmm0 .byte 102,15,112,208,69 // pshufd $0x45,%xmm0,%xmm2 .byte 102,15,110,4,126 // movd (%esi,%edi,2),%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 242,15,16,208 // movsd %xmm0,%xmm2 .byte 233,114,255,255,255 // jmp 409e <_sk_load_565_sse2+0x34> .byte 15,183,52,126 // movzwl (%esi,%edi,2),%esi .byte 102,15,110,214 // movd %esi,%xmm2 .byte 233,101,255,255,255 // jmp 409e <_sk_load_565_sse2+0x34> HIDDEN _sk_load_565_dst_sse2 .globl _sk_load_565_dst_sse2 FUNCTION(_sk_load_565_dst_sse2) _sk_load_565_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 4147 <_sk_load_565_dst_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 1,246 // add %esi,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,113 // jne 41d5 <_sk_load_565_dst_sse2+0x9c> .byte 243,15,126,36,126 // movq (%esi,%edi,2),%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 102,15,111,170,217,59,0,0 // movdqa 0x3bd9(%edx),%xmm5 .byte 102,15,219,236 // pand %xmm4,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,170,233,59,0,0 // mulps 0x3be9(%edx),%xmm5 .byte 15,41,105,16 // movaps %xmm5,0x10(%ecx) .byte 102,15,111,170,249,59,0,0 // movdqa 0x3bf9(%edx),%xmm5 .byte 102,15,219,236 // pand %xmm4,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,170,9,60,0,0 // mulps 0x3c09(%edx),%xmm5 .byte 15,41,105,32 // movaps %xmm5,0x20(%ecx) .byte 102,15,219,162,25,60,0,0 // pand 0x3c19(%edx),%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,162,41,60,0,0 // mulps 0x3c29(%edx),%xmm4 .byte 15,41,97,48 // movaps %xmm4,0x30(%ecx) .byte 15,40,162,57,60,0,0 // movaps 0x3c39(%edx),%xmm4 .byte 15,41,97,64 // movaps %xmm4,0x40(%ecx) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,46 // je 420b <_sk_load_565_dst_sse2+0xd2> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 128,251,2 // cmp $0x2,%bl .byte 116,19 // je 41f9 <_sk_load_565_dst_sse2+0xc0> .byte 128,251,3 // cmp $0x3,%bl .byte 117,130 // jne 416d <_sk_load_565_dst_sse2+0x34> .byte 15,183,92,126,4 // movzwl 0x4(%esi,%edi,2),%ebx .byte 102,15,110,227 // movd %ebx,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 102,15,110,44,126 // movd (%esi,%edi,2),%xmm5 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 242,15,16,229 // movsd %xmm5,%xmm4 .byte 233,98,255,255,255 // jmp 416d <_sk_load_565_dst_sse2+0x34> .byte 15,183,52,126 // movzwl (%esi,%edi,2),%esi .byte 102,15,110,230 // movd %esi,%xmm4 .byte 233,85,255,255,255 // jmp 416d <_sk_load_565_dst_sse2+0x34> HIDDEN _sk_gather_565_sse2 .globl _sk_gather_565_sse2 FUNCTION(_sk_gather_565_sse2) _sk_gather_565_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,81,4 // movd 0x4(%ecx),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 102,15,112,200,229 // pshufd $0xe5,%xmm0,%xmm1 .byte 102,15,196,20,74,0 // pinsrw $0x0,(%edx,%ecx,2),%xmm2 .byte 102,15,126,201 // movd %xmm1,%ecx .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,15,196,20,74,1 // pinsrw $0x1,(%edx,%ecx,2),%xmm2 .byte 102,15,126,201 // movd %xmm1,%ecx .byte 102,15,112,192,231 // pshufd $0xe7,%xmm0,%xmm0 .byte 15,183,12,74 // movzwl (%edx,%ecx,2),%ecx .byte 102,15,196,209,2 // pinsrw $0x2,%ecx,%xmm2 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 15,183,12,74 // movzwl (%edx,%ecx,2),%ecx .byte 232,0,0,0,0 // call 4293 <_sk_gather_565_sse2+0x7b> .byte 90 // pop %edx .byte 102,15,196,209,3 // pinsrw $0x3,%ecx,%xmm2 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 102,15,111,130,253,58,0,0 // movdqa 0x3afd(%edx),%xmm0 .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,130,13,59,0,0 // mulps 0x3b0d(%edx),%xmm0 .byte 102,15,111,138,29,59,0,0 // movdqa 0x3b1d(%edx),%xmm1 .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,138,45,59,0,0 // mulps 0x3b2d(%edx),%xmm1 .byte 102,15,219,146,61,59,0,0 // pand 0x3b3d(%edx),%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,146,77,59,0,0 // mulps 0x3b4d(%edx),%xmm2 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,154,93,59,0,0 // movaps 0x3b5d(%edx),%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_store_565_sse2 .globl _sk_store_565_sse2 FUNCTION(_sk_store_565_sse2) _sk_store_565_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 4306 <_sk_store_565_sse2+0xe> .byte 95 // pop %edi .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,48 // mov (%eax),%esi .byte 139,86,4 // mov 0x4(%esi),%edx .byte 15,175,81,4 // imul 0x4(%ecx),%edx .byte 1,210 // add %edx,%edx .byte 3,22 // add (%esi),%edx .byte 139,49 // mov (%ecx),%esi .byte 15,40,167,250,58,0,0 // movaps 0x3afa(%edi),%xmm4 .byte 15,40,175,10,59,0,0 // movaps 0x3b0a(%edi),%xmm5 .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,89,244 // mulps %xmm4,%xmm6 .byte 102,15,91,246 // cvtps2dq %xmm6,%xmm6 .byte 102,15,114,246,11 // pslld $0xb,%xmm6 .byte 15,89,233 // mulps %xmm1,%xmm5 .byte 102,15,91,237 // cvtps2dq %xmm5,%xmm5 .byte 102,15,114,245,5 // pslld $0x5,%xmm5 .byte 102,15,235,238 // por %xmm6,%xmm5 .byte 15,89,226 // mulps %xmm2,%xmm4 .byte 102,15,91,228 // cvtps2dq %xmm4,%xmm4 .byte 102,15,86,229 // orpd %xmm5,%xmm4 .byte 102,15,114,244,16 // pslld $0x10,%xmm4 .byte 102,15,114,228,16 // psrad $0x10,%xmm4 .byte 102,15,107,228 // packssdw %xmm4,%xmm4 .byte 102,15,126,101,232 // movd %xmm4,-0x18(%ebp) .byte 102,15,112,236,229 // pshufd $0xe5,%xmm4,%xmm5 .byte 102,15,126,109,236 // movd %xmm5,-0x14(%ebp) .byte 133,219 // test %ebx,%ebx .byte 117,34 // jne 439a <_sk_store_565_sse2+0xa2> .byte 102,15,126,231 // movd %xmm4,%edi .byte 102,15,126,235 // movd %xmm5,%ebx .byte 137,60,114 // mov %edi,(%edx,%esi,2) .byte 137,92,114,4 // mov %ebx,0x4(%edx,%esi,2) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 243,15,126,101,232 // movq -0x18(%ebp),%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,37 // je 43d0 <_sk_store_565_sse2+0xd8> .byte 128,251,2 // cmp $0x2,%bl .byte 116,15 // je 43bf <_sk_store_565_sse2+0xc7> .byte 128,251,3 // cmp $0x3,%bl .byte 117,210 // jne 4387 <_sk_store_565_sse2+0x8f> .byte 102,15,197,252,4 // pextrw $0x4,%xmm4,%edi .byte 102,137,124,114,4 // mov %di,0x4(%edx,%esi,2) .byte 102,15,112,228,212 // pshufd $0xd4,%xmm4,%xmm4 .byte 242,15,112,228,232 // pshuflw $0xe8,%xmm4,%xmm4 .byte 102,15,126,36,114 // movd %xmm4,(%edx,%esi,2) .byte 235,183 // jmp 4387 <_sk_store_565_sse2+0x8f> .byte 102,15,126,231 // movd %xmm4,%edi .byte 102,137,60,114 // mov %di,(%edx,%esi,2) .byte 235,173 // jmp 4387 <_sk_store_565_sse2+0x8f> HIDDEN _sk_load_4444_sse2 .globl _sk_load_4444_sse2 FUNCTION(_sk_load_4444_sse2) _sk_load_4444_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 43e8 <_sk_load_4444_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 1,246 // add %esi,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,112 // jne 4475 <_sk_load_4444_sse2+0x9b> .byte 243,15,126,28,126 // movq (%esi,%edi,2),%xmm3 .byte 102,15,97,216 // punpcklwd %xmm0,%xmm3 .byte 102,15,111,130,56,58,0,0 // movdqa 0x3a38(%edx),%xmm0 .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,130,72,58,0,0 // mulps 0x3a48(%edx),%xmm0 .byte 102,15,111,138,88,58,0,0 // movdqa 0x3a58(%edx),%xmm1 .byte 102,15,219,203 // pand %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,138,104,58,0,0 // mulps 0x3a68(%edx),%xmm1 .byte 102,15,111,146,120,58,0,0 // movdqa 0x3a78(%edx),%xmm2 .byte 102,15,219,211 // pand %xmm3,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,146,136,58,0,0 // mulps 0x3a88(%edx),%xmm2 .byte 102,15,219,154,152,58,0,0 // pand 0x3a98(%edx),%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,154,168,58,0,0 // mulps 0x3aa8(%edx),%xmm3 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,46 // je 44ab <_sk_load_4444_sse2+0xd1> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 128,251,2 // cmp $0x2,%bl .byte 116,19 // je 4499 <_sk_load_4444_sse2+0xbf> .byte 128,251,3 // cmp $0x3,%bl .byte 117,131 // jne 440e <_sk_load_4444_sse2+0x34> .byte 15,183,92,126,4 // movzwl 0x4(%esi,%edi,2),%ebx .byte 102,15,110,195 // movd %ebx,%xmm0 .byte 102,15,112,216,69 // pshufd $0x45,%xmm0,%xmm3 .byte 102,15,110,4,126 // movd (%esi,%edi,2),%xmm0 .byte 102,15,97,192 // punpcklwd %xmm0,%xmm0 .byte 242,15,16,216 // movsd %xmm0,%xmm3 .byte 233,99,255,255,255 // jmp 440e <_sk_load_4444_sse2+0x34> .byte 15,183,52,126 // movzwl (%esi,%edi,2),%esi .byte 102,15,110,222 // movd %esi,%xmm3 .byte 233,86,255,255,255 // jmp 440e <_sk_load_4444_sse2+0x34> HIDDEN _sk_load_4444_dst_sse2 .globl _sk_load_4444_dst_sse2 FUNCTION(_sk_load_4444_dst_sse2) _sk_load_4444_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 44c6 <_sk_load_4444_dst_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 1,246 // add %esi,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 15,133,128,0,0,0 // jne 4567 <_sk_load_4444_dst_sse2+0xaf> .byte 243,15,126,36,126 // movq (%esi,%edi,2),%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 102,15,111,170,218,57,0,0 // movdqa 0x39da(%edx),%xmm5 .byte 102,15,219,236 // pand %xmm4,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,170,234,57,0,0 // mulps 0x39ea(%edx),%xmm5 .byte 15,41,105,16 // movaps %xmm5,0x10(%ecx) .byte 102,15,111,170,250,57,0,0 // movdqa 0x39fa(%edx),%xmm5 .byte 102,15,219,236 // pand %xmm4,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,170,10,58,0,0 // mulps 0x3a0a(%edx),%xmm5 .byte 15,41,105,32 // movaps %xmm5,0x20(%ecx) .byte 102,15,111,170,26,58,0,0 // movdqa 0x3a1a(%edx),%xmm5 .byte 102,15,219,236 // pand %xmm4,%xmm5 .byte 15,91,237 // cvtdq2ps %xmm5,%xmm5 .byte 15,89,170,42,58,0,0 // mulps 0x3a2a(%edx),%xmm5 .byte 15,41,105,48 // movaps %xmm5,0x30(%ecx) .byte 102,15,219,162,58,58,0,0 // pand 0x3a3a(%edx),%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,162,74,58,0,0 // mulps 0x3a4a(%edx),%xmm4 .byte 15,41,97,64 // movaps %xmm4,0x40(%ecx) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,50 // je 45a1 <_sk_load_4444_dst_sse2+0xe9> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 128,251,2 // cmp $0x2,%bl .byte 116,23 // je 458f <_sk_load_4444_dst_sse2+0xd7> .byte 128,251,3 // cmp $0x3,%bl .byte 15,133,111,255,255,255 // jne 44f0 <_sk_load_4444_dst_sse2+0x38> .byte 15,183,92,126,4 // movzwl 0x4(%esi,%edi,2),%ebx .byte 102,15,110,227 // movd %ebx,%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 102,15,110,44,126 // movd (%esi,%edi,2),%xmm5 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 242,15,16,229 // movsd %xmm5,%xmm4 .byte 233,79,255,255,255 // jmp 44f0 <_sk_load_4444_dst_sse2+0x38> .byte 15,183,52,126 // movzwl (%esi,%edi,2),%esi .byte 102,15,110,230 // movd %esi,%xmm4 .byte 233,66,255,255,255 // jmp 44f0 <_sk_load_4444_dst_sse2+0x38> HIDDEN _sk_gather_4444_sse2 .globl _sk_gather_4444_sse2 FUNCTION(_sk_gather_4444_sse2) _sk_gather_4444_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,81,4 // movd 0x4(%ecx),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 102,15,112,200,229 // pshufd $0xe5,%xmm0,%xmm1 .byte 102,15,196,28,74,0 // pinsrw $0x0,(%edx,%ecx,2),%xmm3 .byte 102,15,126,201 // movd %xmm1,%ecx .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,15,196,28,74,1 // pinsrw $0x1,(%edx,%ecx,2),%xmm3 .byte 102,15,126,201 // movd %xmm1,%ecx .byte 102,15,112,192,231 // pshufd $0xe7,%xmm0,%xmm0 .byte 15,183,12,74 // movzwl (%edx,%ecx,2),%ecx .byte 102,15,196,217,2 // pinsrw $0x2,%ecx,%xmm3 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 15,183,12,74 // movzwl (%edx,%ecx,2),%ecx .byte 102,15,196,217,3 // pinsrw $0x3,%ecx,%xmm3 .byte 232,0,0,0,0 // call 462e <_sk_gather_4444_sse2+0x80> .byte 89 // pop %ecx .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 102,15,97,216 // punpcklwd %xmm0,%xmm3 .byte 102,15,111,129,242,56,0,0 // movdqa 0x38f2(%ecx),%xmm0 .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,89,129,2,57,0,0 // mulps 0x3902(%ecx),%xmm0 .byte 102,15,111,137,18,57,0,0 // movdqa 0x3912(%ecx),%xmm1 .byte 102,15,219,203 // pand %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,137,34,57,0,0 // mulps 0x3922(%ecx),%xmm1 .byte 102,15,111,145,50,57,0,0 // movdqa 0x3932(%ecx),%xmm2 .byte 102,15,219,211 // pand %xmm3,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,145,66,57,0,0 // mulps 0x3942(%ecx),%xmm2 .byte 102,15,219,153,82,57,0,0 // pand 0x3952(%ecx),%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,153,98,57,0,0 // mulps 0x3962(%ecx),%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_store_4444_sse2 .globl _sk_store_4444_sse2 FUNCTION(_sk_store_4444_sse2) _sk_store_4444_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 46ab <_sk_store_4444_sse2+0xe> .byte 95 // pop %edi .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,48 // mov (%eax),%esi .byte 139,86,4 // mov 0x4(%esi),%edx .byte 15,175,81,4 // imul 0x4(%ecx),%edx .byte 1,210 // add %edx,%edx .byte 3,22 // add (%esi),%edx .byte 139,49 // mov (%ecx),%esi .byte 15,40,167,245,56,0,0 // movaps 0x38f5(%edi),%xmm4 .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 102,15,91,237 // cvtps2dq %xmm5,%xmm5 .byte 102,15,114,245,12 // pslld $0xc,%xmm5 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,89,244 // mulps %xmm4,%xmm6 .byte 102,15,91,246 // cvtps2dq %xmm6,%xmm6 .byte 102,15,114,246,8 // pslld $0x8,%xmm6 .byte 102,15,235,245 // por %xmm5,%xmm6 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 102,15,91,237 // cvtps2dq %xmm5,%xmm5 .byte 102,15,114,245,4 // pslld $0x4,%xmm5 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 102,15,91,228 // cvtps2dq %xmm4,%xmm4 .byte 102,15,86,229 // orpd %xmm5,%xmm4 .byte 102,15,86,230 // orpd %xmm6,%xmm4 .byte 102,15,114,244,16 // pslld $0x10,%xmm4 .byte 102,15,114,228,16 // psrad $0x10,%xmm4 .byte 102,15,107,228 // packssdw %xmm4,%xmm4 .byte 102,15,126,101,232 // movd %xmm4,-0x18(%ebp) .byte 102,15,112,236,229 // pshufd $0xe5,%xmm4,%xmm5 .byte 102,15,126,109,236 // movd %xmm5,-0x14(%ebp) .byte 133,219 // test %ebx,%ebx .byte 117,34 // jne 474e <_sk_store_4444_sse2+0xb1> .byte 102,15,126,231 // movd %xmm4,%edi .byte 102,15,126,235 // movd %xmm5,%ebx .byte 137,60,114 // mov %edi,(%edx,%esi,2) .byte 137,92,114,4 // mov %ebx,0x4(%edx,%esi,2) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 243,15,126,101,232 // movq -0x18(%ebp),%xmm4 .byte 102,15,97,224 // punpcklwd %xmm0,%xmm4 .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,37 // je 4784 <_sk_store_4444_sse2+0xe7> .byte 128,251,2 // cmp $0x2,%bl .byte 116,15 // je 4773 <_sk_store_4444_sse2+0xd6> .byte 128,251,3 // cmp $0x3,%bl .byte 117,210 // jne 473b <_sk_store_4444_sse2+0x9e> .byte 102,15,197,252,4 // pextrw $0x4,%xmm4,%edi .byte 102,137,124,114,4 // mov %di,0x4(%edx,%esi,2) .byte 102,15,112,228,212 // pshufd $0xd4,%xmm4,%xmm4 .byte 242,15,112,228,232 // pshuflw $0xe8,%xmm4,%xmm4 .byte 102,15,126,36,114 // movd %xmm4,(%edx,%esi,2) .byte 235,183 // jmp 473b <_sk_store_4444_sse2+0x9e> .byte 102,15,126,231 // movd %xmm4,%edi .byte 102,137,60,114 // mov %di,(%edx,%esi,2) .byte 235,173 // jmp 473b <_sk_store_4444_sse2+0x9e> HIDDEN _sk_load_8888_sse2 .globl _sk_load_8888_sse2 FUNCTION(_sk_load_8888_sse2) _sk_load_8888_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 479c <_sk_load_8888_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 193,230,2 // shl $0x2,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,102 // jne 4820 <_sk_load_8888_sse2+0x92> .byte 243,15,111,28,190 // movdqu (%esi,%edi,4),%xmm3 .byte 102,15,111,146,20,56,0,0 // movdqa 0x3814(%edx),%xmm2 .byte 102,15,111,195 // movdqa %xmm3,%xmm0 .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,40,162,36,56,0,0 // movaps 0x3824(%edx),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 102,15,111,235 // movdqa %xmm3,%xmm5 .byte 102,15,114,213,16 // psrld $0x10,%xmm5 .byte 102,15,219,234 // pand %xmm2,%xmm5 .byte 15,91,213 // cvtdq2ps %xmm5,%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 102,15,114,211,24 // psrld $0x18,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,35 // je 484b <_sk_load_8888_sse2+0xbd> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 128,251,2 // cmp $0x2,%bl .byte 116,16 // je 4841 <_sk_load_8888_sse2+0xb3> .byte 128,251,3 // cmp $0x3,%bl .byte 117,137 // jne 47bf <_sk_load_8888_sse2+0x31> .byte 102,15,110,68,190,8 // movd 0x8(%esi,%edi,4),%xmm0 .byte 102,15,112,216,69 // pshufd $0x45,%xmm0,%xmm3 .byte 102,15,18,28,190 // movlpd (%esi,%edi,4),%xmm3 .byte 233,116,255,255,255 // jmp 47bf <_sk_load_8888_sse2+0x31> .byte 102,15,110,28,190 // movd (%esi,%edi,4),%xmm3 .byte 233,106,255,255,255 // jmp 47bf <_sk_load_8888_sse2+0x31> HIDDEN _sk_load_8888_dst_sse2 .globl _sk_load_8888_dst_sse2 FUNCTION(_sk_load_8888_dst_sse2) _sk_load_8888_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 4863 <_sk_load_8888_dst_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 193,230,2 // shl $0x2,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,118 // jne 48f7 <_sk_load_8888_dst_sse2+0xa2> .byte 243,15,111,36,190 // movdqu (%esi,%edi,4),%xmm4 .byte 102,15,111,170,109,55,0,0 // movdqa 0x376d(%edx),%xmm5 .byte 102,15,111,244 // movdqa %xmm4,%xmm6 .byte 102,15,219,245 // pand %xmm5,%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,40,186,125,55,0,0 // movaps 0x377d(%edx),%xmm7 .byte 15,89,247 // mulps %xmm7,%xmm6 .byte 15,41,113,16 // movaps %xmm6,0x10(%ecx) .byte 102,15,111,244 // movdqa %xmm4,%xmm6 .byte 102,15,114,214,8 // psrld $0x8,%xmm6 .byte 102,15,219,245 // pand %xmm5,%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,89,247 // mulps %xmm7,%xmm6 .byte 15,41,113,32 // movaps %xmm6,0x20(%ecx) .byte 102,15,111,244 // movdqa %xmm4,%xmm6 .byte 102,15,114,214,16 // psrld $0x10,%xmm6 .byte 102,15,219,245 // pand %xmm5,%xmm6 .byte 15,91,238 // cvtdq2ps %xmm6,%xmm5 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,41,105,48 // movaps %xmm5,0x30(%ecx) .byte 102,15,114,212,24 // psrld $0x18,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,41,97,64 // movaps %xmm4,0x40(%ecx) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,39 // je 4926 <_sk_load_8888_dst_sse2+0xd1> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 128,251,2 // cmp $0x2,%bl .byte 116,20 // je 491c <_sk_load_8888_dst_sse2+0xc7> .byte 128,251,3 // cmp $0x3,%bl .byte 15,133,117,255,255,255 // jne 4886 <_sk_load_8888_dst_sse2+0x31> .byte 102,15,110,100,190,8 // movd 0x8(%esi,%edi,4),%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 102,15,18,36,190 // movlpd (%esi,%edi,4),%xmm4 .byte 233,96,255,255,255 // jmp 4886 <_sk_load_8888_dst_sse2+0x31> .byte 102,15,110,36,190 // movd (%esi,%edi,4),%xmm4 .byte 233,86,255,255,255 // jmp 4886 <_sk_load_8888_dst_sse2+0x31> HIDDEN _sk_gather_8888_sse2 .globl _sk_gather_8888_sse2 FUNCTION(_sk_gather_8888_sse2) _sk_gather_8888_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,81,4 // movd 0x4(%ecx),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,112,200,229 // pshufd $0xe5,%xmm0,%xmm1 .byte 102,15,112,208,231 // pshufd $0xe7,%xmm0,%xmm2 .byte 102,15,126,209 // movd %xmm2,%ecx .byte 102,15,110,20,138 // movd (%edx,%ecx,4),%xmm2 .byte 102,15,126,201 // movd %xmm1,%ecx .byte 102,15,110,12,138 // movd (%edx,%ecx,4),%xmm1 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 102,15,112,192,78 // pshufd $0x4e,%xmm0,%xmm0 .byte 102,15,110,28,138 // movd (%edx,%ecx,4),%xmm3 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 102,15,110,4,138 // movd (%edx,%ecx,4),%xmm0 .byte 232,0,0,0,0 // call 49a6 <_sk_gather_8888_sse2+0x76> .byte 89 // pop %ecx .byte 102,15,98,202 // punpckldq %xmm2,%xmm1 .byte 102,15,98,216 // punpckldq %xmm0,%xmm3 .byte 102,15,98,217 // punpckldq %xmm1,%xmm3 .byte 102,15,111,145,74,54,0,0 // movdqa 0x364a(%ecx),%xmm2 .byte 102,15,111,195 // movdqa %xmm3,%xmm0 .byte 102,15,219,194 // pand %xmm2,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,40,161,90,54,0,0 // movaps 0x365a(%ecx),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,15,219,202 // pand %xmm2,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 102,15,111,235 // movdqa %xmm3,%xmm5 .byte 102,15,114,213,16 // psrld $0x10,%xmm5 .byte 102,15,219,234 // pand %xmm2,%xmm5 .byte 15,91,213 // cvtdq2ps %xmm5,%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 102,15,114,211,24 // psrld $0x18,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_store_8888_sse2 .globl _sk_store_8888_sse2 FUNCTION(_sk_store_8888_sse2) _sk_store_8888_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 4a21 <_sk_store_8888_sse2+0xe> .byte 95 // pop %edi .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,48 // mov (%eax),%esi .byte 139,86,4 // mov 0x4(%esi),%edx .byte 15,175,81,4 // imul 0x4(%ecx),%edx .byte 193,226,2 // shl $0x2,%edx .byte 3,22 // add (%esi),%edx .byte 139,49 // mov (%ecx),%esi .byte 15,40,167,239,53,0,0 // movaps 0x35ef(%edi),%xmm4 .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 102,15,91,237 // cvtps2dq %xmm5,%xmm5 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,89,244 // mulps %xmm4,%xmm6 .byte 102,15,91,246 // cvtps2dq %xmm6,%xmm6 .byte 102,15,114,246,8 // pslld $0x8,%xmm6 .byte 102,15,235,245 // por %xmm5,%xmm6 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 102,15,91,237 // cvtps2dq %xmm5,%xmm5 .byte 102,15,114,245,16 // pslld $0x10,%xmm5 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 102,15,91,228 // cvtps2dq %xmm4,%xmm4 .byte 102,15,114,244,24 // pslld $0x18,%xmm4 .byte 102,15,235,229 // por %xmm5,%xmm4 .byte 102,15,235,230 // por %xmm6,%xmm4 .byte 133,219 // test %ebx,%ebx .byte 117,24 // jne 4a9e <_sk_store_8888_sse2+0x8b> .byte 243,15,127,36,178 // movdqu %xmm4,(%edx,%esi,4) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,28 // je 4ac2 <_sk_store_8888_sse2+0xaf> .byte 128,251,2 // cmp $0x2,%bl .byte 116,16 // je 4abb <_sk_store_8888_sse2+0xa8> .byte 128,251,3 // cmp $0x3,%bl .byte 117,219 // jne 4a8b <_sk_store_8888_sse2+0x78> .byte 102,15,112,236,78 // pshufd $0x4e,%xmm4,%xmm5 .byte 102,15,126,108,178,8 // movd %xmm5,0x8(%edx,%esi,4) .byte 102,15,214,36,178 // movq %xmm4,(%edx,%esi,4) .byte 235,201 // jmp 4a8b <_sk_store_8888_sse2+0x78> .byte 102,15,126,36,178 // movd %xmm4,(%edx,%esi,4) .byte 235,194 // jmp 4a8b <_sk_store_8888_sse2+0x78> HIDDEN _sk_load_bgra_sse2 .globl _sk_load_bgra_sse2 FUNCTION(_sk_load_bgra_sse2) _sk_load_bgra_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 4ad7 <_sk_load_bgra_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 193,230,2 // shl $0x2,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,102 // jne 4b5b <_sk_load_bgra_sse2+0x92> .byte 243,15,111,28,190 // movdqu (%esi,%edi,4),%xmm3 .byte 102,15,111,130,73,53,0,0 // movdqa 0x3549(%edx),%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,219,200 // pand %xmm0,%xmm1 .byte 15,91,209 // cvtdq2ps %xmm1,%xmm2 .byte 15,40,162,89,53,0,0 // movaps 0x3559(%edx),%xmm4 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,15,219,200 // pand %xmm0,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 102,15,111,235 // movdqa %xmm3,%xmm5 .byte 102,15,114,213,16 // psrld $0x10,%xmm5 .byte 102,15,219,232 // pand %xmm0,%xmm5 .byte 15,91,197 // cvtdq2ps %xmm5,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 102,15,114,211,24 // psrld $0x18,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,35 // je 4b86 <_sk_load_bgra_sse2+0xbd> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 128,251,2 // cmp $0x2,%bl .byte 116,16 // je 4b7c <_sk_load_bgra_sse2+0xb3> .byte 128,251,3 // cmp $0x3,%bl .byte 117,137 // jne 4afa <_sk_load_bgra_sse2+0x31> .byte 102,15,110,68,190,8 // movd 0x8(%esi,%edi,4),%xmm0 .byte 102,15,112,216,69 // pshufd $0x45,%xmm0,%xmm3 .byte 102,15,18,28,190 // movlpd (%esi,%edi,4),%xmm3 .byte 233,116,255,255,255 // jmp 4afa <_sk_load_bgra_sse2+0x31> .byte 102,15,110,28,190 // movd (%esi,%edi,4),%xmm3 .byte 233,106,255,255,255 // jmp 4afa <_sk_load_bgra_sse2+0x31> HIDDEN _sk_load_bgra_dst_sse2 .globl _sk_load_bgra_dst_sse2 FUNCTION(_sk_load_bgra_dst_sse2) _sk_load_bgra_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 4b9e <_sk_load_bgra_dst_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 193,230,2 // shl $0x2,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 117,118 // jne 4c32 <_sk_load_bgra_dst_sse2+0xa2> .byte 243,15,111,36,190 // movdqu (%esi,%edi,4),%xmm4 .byte 102,15,111,170,162,52,0,0 // movdqa 0x34a2(%edx),%xmm5 .byte 102,15,111,244 // movdqa %xmm4,%xmm6 .byte 102,15,219,245 // pand %xmm5,%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,40,186,178,52,0,0 // movaps 0x34b2(%edx),%xmm7 .byte 15,89,247 // mulps %xmm7,%xmm6 .byte 15,41,113,48 // movaps %xmm6,0x30(%ecx) .byte 102,15,111,244 // movdqa %xmm4,%xmm6 .byte 102,15,114,214,8 // psrld $0x8,%xmm6 .byte 102,15,219,245 // pand %xmm5,%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,89,247 // mulps %xmm7,%xmm6 .byte 15,41,113,32 // movaps %xmm6,0x20(%ecx) .byte 102,15,111,244 // movdqa %xmm4,%xmm6 .byte 102,15,114,214,16 // psrld $0x10,%xmm6 .byte 102,15,219,245 // pand %xmm5,%xmm6 .byte 15,91,238 // cvtdq2ps %xmm6,%xmm5 .byte 15,89,239 // mulps %xmm7,%xmm5 .byte 15,41,105,16 // movaps %xmm5,0x10(%ecx) .byte 102,15,114,212,24 // psrld $0x18,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,89,231 // mulps %xmm7,%xmm4 .byte 15,41,97,64 // movaps %xmm4,0x40(%ecx) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,39 // je 4c61 <_sk_load_bgra_dst_sse2+0xd1> .byte 102,15,239,228 // pxor %xmm4,%xmm4 .byte 128,251,2 // cmp $0x2,%bl .byte 116,20 // je 4c57 <_sk_load_bgra_dst_sse2+0xc7> .byte 128,251,3 // cmp $0x3,%bl .byte 15,133,117,255,255,255 // jne 4bc1 <_sk_load_bgra_dst_sse2+0x31> .byte 102,15,110,100,190,8 // movd 0x8(%esi,%edi,4),%xmm4 .byte 102,15,112,228,69 // pshufd $0x45,%xmm4,%xmm4 .byte 102,15,18,36,190 // movlpd (%esi,%edi,4),%xmm4 .byte 233,96,255,255,255 // jmp 4bc1 <_sk_load_bgra_dst_sse2+0x31> .byte 102,15,110,36,190 // movd (%esi,%edi,4),%xmm4 .byte 233,86,255,255,255 // jmp 4bc1 <_sk_load_bgra_dst_sse2+0x31> HIDDEN _sk_gather_bgra_sse2 .globl _sk_gather_bgra_sse2 FUNCTION(_sk_gather_bgra_sse2) _sk_gather_bgra_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 139,17 // mov (%ecx),%edx .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,81,4 // movd 0x4(%ecx),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,112,200,229 // pshufd $0xe5,%xmm0,%xmm1 .byte 102,15,112,208,231 // pshufd $0xe7,%xmm0,%xmm2 .byte 102,15,126,209 // movd %xmm2,%ecx .byte 102,15,110,20,138 // movd (%edx,%ecx,4),%xmm2 .byte 102,15,126,201 // movd %xmm1,%ecx .byte 102,15,110,12,138 // movd (%edx,%ecx,4),%xmm1 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 102,15,112,192,78 // pshufd $0x4e,%xmm0,%xmm0 .byte 102,15,110,28,138 // movd (%edx,%ecx,4),%xmm3 .byte 102,15,126,193 // movd %xmm0,%ecx .byte 102,15,110,4,138 // movd (%edx,%ecx,4),%xmm0 .byte 232,0,0,0,0 // call 4ce1 <_sk_gather_bgra_sse2+0x76> .byte 89 // pop %ecx .byte 102,15,98,202 // punpckldq %xmm2,%xmm1 .byte 102,15,98,216 // punpckldq %xmm0,%xmm3 .byte 102,15,98,217 // punpckldq %xmm1,%xmm3 .byte 102,15,111,129,127,51,0,0 // movdqa 0x337f(%ecx),%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,219,200 // pand %xmm0,%xmm1 .byte 15,91,209 // cvtdq2ps %xmm1,%xmm2 .byte 15,40,161,143,51,0,0 // movaps 0x338f(%ecx),%xmm4 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,114,209,8 // psrld $0x8,%xmm1 .byte 102,15,219,200 // pand %xmm0,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 102,15,111,235 // movdqa %xmm3,%xmm5 .byte 102,15,114,213,16 // psrld $0x10,%xmm5 .byte 102,15,219,232 // pand %xmm0,%xmm5 .byte 15,91,197 // cvtdq2ps %xmm5,%xmm0 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 102,15,114,211,24 // psrld $0x18,%xmm3 .byte 15,91,219 // cvtdq2ps %xmm3,%xmm3 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_store_bgra_sse2 .globl _sk_store_bgra_sse2 FUNCTION(_sk_store_bgra_sse2) _sk_store_bgra_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 232,0,0,0,0 // call 4d5c <_sk_store_bgra_sse2+0xe> .byte 95 // pop %edi .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,48 // mov (%eax),%esi .byte 139,86,4 // mov 0x4(%esi),%edx .byte 15,175,81,4 // imul 0x4(%ecx),%edx .byte 193,226,2 // shl $0x2,%edx .byte 3,22 // add (%esi),%edx .byte 139,49 // mov (%ecx),%esi .byte 15,40,167,36,51,0,0 // movaps 0x3324(%edi),%xmm4 .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 102,15,91,237 // cvtps2dq %xmm5,%xmm5 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,89,244 // mulps %xmm4,%xmm6 .byte 102,15,91,246 // cvtps2dq %xmm6,%xmm6 .byte 102,15,114,246,8 // pslld $0x8,%xmm6 .byte 102,15,235,245 // por %xmm5,%xmm6 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 102,15,91,237 // cvtps2dq %xmm5,%xmm5 .byte 102,15,114,245,16 // pslld $0x10,%xmm5 .byte 15,89,227 // mulps %xmm3,%xmm4 .byte 102,15,91,228 // cvtps2dq %xmm4,%xmm4 .byte 102,15,114,244,24 // pslld $0x18,%xmm4 .byte 102,15,235,229 // por %xmm5,%xmm4 .byte 102,15,235,230 // por %xmm6,%xmm4 .byte 133,219 // test %ebx,%ebx .byte 117,24 // jne 4dd9 <_sk_store_bgra_sse2+0x8b> .byte 243,15,127,36,178 // movdqu %xmm4,(%edx,%esi,4) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 128,227,3 // and $0x3,%bl .byte 128,251,1 // cmp $0x1,%bl .byte 116,28 // je 4dfd <_sk_store_bgra_sse2+0xaf> .byte 128,251,2 // cmp $0x2,%bl .byte 116,16 // je 4df6 <_sk_store_bgra_sse2+0xa8> .byte 128,251,3 // cmp $0x3,%bl .byte 117,219 // jne 4dc6 <_sk_store_bgra_sse2+0x78> .byte 102,15,112,236,78 // pshufd $0x4e,%xmm4,%xmm5 .byte 102,15,126,108,178,8 // movd %xmm5,0x8(%edx,%esi,4) .byte 102,15,214,36,178 // movq %xmm4,(%edx,%esi,4) .byte 235,201 // jmp 4dc6 <_sk_store_bgra_sse2+0x78> .byte 102,15,126,36,178 // movd %xmm4,(%edx,%esi,4) .byte 235,194 // jmp 4dc6 <_sk_store_bgra_sse2+0x78> HIDDEN _sk_load_f16_sse2 .globl _sk_load_f16_sse2 FUNCTION(_sk_load_f16_sse2) _sk_load_f16_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,92 // sub $0x5c,%esp .byte 232,0,0,0,0 // call 4e12 <_sk_load_f16_sse2+0xe> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 193,230,3 // shl $0x3,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 15,133,160,1,0,0 // jne 4fd4 <_sk_load_f16_sse2+0x1d0> .byte 102,15,16,4,254 // movupd (%esi,%edi,8),%xmm0 .byte 243,15,111,76,254,16 // movdqu 0x10(%esi,%edi,8),%xmm1 .byte 102,15,40,216 // movapd %xmm0,%xmm3 .byte 102,15,97,217 // punpcklwd %xmm1,%xmm3 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,15,97,208 // punpcklwd %xmm0,%xmm2 .byte 102,15,105,216 // punpckhwd %xmm0,%xmm3 .byte 102,15,126,85,208 // movd %xmm2,-0x30(%ebp) .byte 102,15,112,194,229 // pshufd $0xe5,%xmm2,%xmm0 .byte 102,15,126,69,212 // movd %xmm0,-0x2c(%ebp) .byte 243,15,126,77,208 // movq -0x30(%ebp),%xmm1 .byte 102,15,112,194,231 // pshufd $0xe7,%xmm2,%xmm0 .byte 102,15,126,69,220 // movd %xmm0,-0x24(%ebp) .byte 102,15,112,194,78 // pshufd $0x4e,%xmm2,%xmm0 .byte 102,15,126,69,216 // movd %xmm0,-0x28(%ebp) .byte 243,15,126,125,216 // movq -0x28(%ebp),%xmm7 .byte 102,15,126,93,224 // movd %xmm3,-0x20(%ebp) .byte 102,15,112,195,229 // pshufd $0xe5,%xmm3,%xmm0 .byte 102,15,126,69,228 // movd %xmm0,-0x1c(%ebp) .byte 243,15,126,109,224 // movq -0x20(%ebp),%xmm5 .byte 102,15,112,195,231 // pshufd $0xe7,%xmm3,%xmm0 .byte 102,15,126,69,236 // movd %xmm0,-0x14(%ebp) .byte 102,15,112,195,78 // pshufd $0x4e,%xmm3,%xmm0 .byte 102,15,126,69,232 // movd %xmm0,-0x18(%ebp) .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,111,154,126,50,0,0 // movdqa 0x327e(%edx),%xmm3 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,219,227 // pand %xmm3,%xmm4 .byte 102,15,239,204 // pxor %xmm4,%xmm1 .byte 102,15,114,244,16 // pslld $0x10,%xmm4 .byte 102,15,111,209 // movdqa %xmm1,%xmm2 .byte 102,15,114,242,13 // pslld $0xd,%xmm2 .byte 102,15,235,212 // por %xmm4,%xmm2 .byte 102,15,97,248 // punpcklwd %xmm0,%xmm7 .byte 102,15,111,231 // movdqa %xmm7,%xmm4 .byte 102,15,219,227 // pand %xmm3,%xmm4 .byte 102,15,239,252 // pxor %xmm4,%xmm7 .byte 102,15,127,125,152 // movdqa %xmm7,-0x68(%ebp) .byte 102,15,114,244,16 // pslld $0x10,%xmm4 .byte 102,15,111,247 // movdqa %xmm7,%xmm6 .byte 102,15,114,246,13 // pslld $0xd,%xmm6 .byte 102,15,235,244 // por %xmm4,%xmm6 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 102,15,111,253 // movdqa %xmm5,%xmm7 .byte 102,15,219,251 // pand %xmm3,%xmm7 .byte 102,15,239,239 // pxor %xmm7,%xmm5 .byte 102,15,127,109,168 // movdqa %xmm5,-0x58(%ebp) .byte 102,15,114,247,16 // pslld $0x10,%xmm7 .byte 102,15,114,245,13 // pslld $0xd,%xmm5 .byte 102,15,235,239 // por %xmm7,%xmm5 .byte 243,15,126,125,232 // movq -0x18(%ebp),%xmm7 .byte 102,15,97,248 // punpcklwd %xmm0,%xmm7 .byte 102,15,219,223 // pand %xmm7,%xmm3 .byte 102,15,239,251 // pxor %xmm3,%xmm7 .byte 102,15,114,243,16 // pslld $0x10,%xmm3 .byte 102,15,111,199 // movdqa %xmm7,%xmm0 .byte 102,15,114,240,13 // pslld $0xd,%xmm0 .byte 102,15,235,195 // por %xmm3,%xmm0 .byte 102,15,111,154,142,50,0,0 // movdqa 0x328e(%edx),%xmm3 .byte 102,15,254,211 // paddd %xmm3,%xmm2 .byte 102,15,254,243 // paddd %xmm3,%xmm6 .byte 102,15,254,235 // paddd %xmm3,%xmm5 .byte 102,15,254,195 // paddd %xmm3,%xmm0 .byte 102,15,111,154,158,50,0,0 // movdqa 0x329e(%edx),%xmm3 .byte 102,15,127,93,184 // movdqa %xmm3,-0x48(%ebp) .byte 102,15,239,203 // pxor %xmm3,%xmm1 .byte 102,15,111,154,174,50,0,0 // movdqa 0x32ae(%edx),%xmm3 .byte 102,15,111,227 // movdqa %xmm3,%xmm4 .byte 102,15,102,225 // pcmpgtd %xmm1,%xmm4 .byte 102,15,223,226 // pandn %xmm2,%xmm4 .byte 102,15,111,85,152 // movdqa -0x68(%ebp),%xmm2 .byte 102,15,239,85,184 // pxor -0x48(%ebp),%xmm2 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,102,202 // pcmpgtd %xmm2,%xmm1 .byte 102,15,223,206 // pandn %xmm6,%xmm1 .byte 102,15,111,117,168 // movdqa -0x58(%ebp),%xmm6 .byte 102,15,239,117,184 // pxor -0x48(%ebp),%xmm6 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,15,102,214 // pcmpgtd %xmm6,%xmm2 .byte 102,15,223,213 // pandn %xmm5,%xmm2 .byte 102,15,239,125,184 // pxor -0x48(%ebp),%xmm7 .byte 102,15,102,223 // pcmpgtd %xmm7,%xmm3 .byte 102,15,223,216 // pandn %xmm0,%xmm3 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 102,15,111,196 // movdqa %xmm4,%xmm0 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,108 // add $0x6c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 242,15,16,4,254 // movsd (%esi,%edi,8),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 131,251,1 // cmp $0x1,%ebx .byte 15,132,89,254,255,255 // je 4e3f <_sk_load_f16_sse2+0x3b> .byte 102,15,22,68,254,8 // movhpd 0x8(%esi,%edi,8),%xmm0 .byte 131,251,3 // cmp $0x3,%ebx .byte 15,130,74,254,255,255 // jb 4e3f <_sk_load_f16_sse2+0x3b> .byte 243,15,126,76,254,16 // movq 0x10(%esi,%edi,8),%xmm1 .byte 233,63,254,255,255 // jmp 4e3f <_sk_load_f16_sse2+0x3b> HIDDEN _sk_load_f16_dst_sse2 .globl _sk_load_f16_dst_sse2 FUNCTION(_sk_load_f16_dst_sse2) _sk_load_f16_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 129,236,140,0,0,0 // sub $0x8c,%esp .byte 15,41,157,104,255,255,255 // movaps %xmm3,-0x98(%ebp) .byte 15,41,149,120,255,255,255 // movaps %xmm2,-0x88(%ebp) .byte 102,15,127,77,136 // movdqa %xmm1,-0x78(%ebp) .byte 15,41,69,152 // movaps %xmm0,-0x68(%ebp) .byte 232,0,0,0,0 // call 5028 <_sk_load_f16_dst_sse2+0x28> .byte 90 // pop %edx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 193,230,3 // shl $0x3,%esi .byte 3,55 // add (%edi),%esi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 133,219 // test %ebx,%ebx .byte 139,57 // mov (%ecx),%edi .byte 15,133,206,1,0,0 // jne 5218 <_sk_load_f16_dst_sse2+0x218> .byte 102,15,16,4,254 // movupd (%esi,%edi,8),%xmm0 .byte 243,15,111,76,254,16 // movdqu 0x10(%esi,%edi,8),%xmm1 .byte 102,15,40,208 // movapd %xmm0,%xmm2 .byte 102,15,97,209 // punpcklwd %xmm1,%xmm2 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,15,111,218 // movdqa %xmm2,%xmm3 .byte 102,15,97,216 // punpcklwd %xmm0,%xmm3 .byte 102,15,105,208 // punpckhwd %xmm0,%xmm2 .byte 102,15,126,93,208 // movd %xmm3,-0x30(%ebp) .byte 102,15,112,195,229 // pshufd $0xe5,%xmm3,%xmm0 .byte 102,15,126,69,212 // movd %xmm0,-0x2c(%ebp) .byte 243,15,126,101,208 // movq -0x30(%ebp),%xmm4 .byte 102,15,112,195,231 // pshufd $0xe7,%xmm3,%xmm0 .byte 102,15,126,69,220 // movd %xmm0,-0x24(%ebp) .byte 102,15,112,195,78 // pshufd $0x4e,%xmm3,%xmm0 .byte 102,15,126,69,216 // movd %xmm0,-0x28(%ebp) .byte 243,15,126,69,216 // movq -0x28(%ebp),%xmm0 .byte 102,15,126,85,224 // movd %xmm2,-0x20(%ebp) .byte 102,15,112,218,229 // pshufd $0xe5,%xmm2,%xmm3 .byte 102,15,126,93,228 // movd %xmm3,-0x1c(%ebp) .byte 243,15,126,109,224 // movq -0x20(%ebp),%xmm5 .byte 102,15,112,218,231 // pshufd $0xe7,%xmm2,%xmm3 .byte 102,15,126,93,236 // movd %xmm3,-0x14(%ebp) .byte 102,15,112,210,78 // pshufd $0x4e,%xmm2,%xmm2 .byte 102,15,126,85,232 // movd %xmm2,-0x18(%ebp) .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,15,97,225 // punpcklwd %xmm1,%xmm4 .byte 102,15,111,154,168,48,0,0 // movdqa 0x30a8(%edx),%xmm3 .byte 102,15,111,212 // movdqa %xmm4,%xmm2 .byte 102,15,219,211 // pand %xmm3,%xmm2 .byte 102,15,239,226 // pxor %xmm2,%xmm4 .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,15,111,204 // movdqa %xmm4,%xmm1 .byte 102,15,114,241,13 // pslld $0xd,%xmm1 .byte 102,15,235,202 // por %xmm2,%xmm1 .byte 102,15,111,146,200,48,0,0 // movdqa 0x30c8(%edx),%xmm2 .byte 102,15,127,85,168 // movdqa %xmm2,-0x58(%ebp) .byte 102,15,239,226 // pxor %xmm2,%xmm4 .byte 102,15,111,178,216,48,0,0 // movdqa 0x30d8(%edx),%xmm6 .byte 102,15,111,254 // movdqa %xmm6,%xmm7 .byte 102,15,102,252 // pcmpgtd %xmm4,%xmm7 .byte 102,15,111,146,184,48,0,0 // movdqa 0x30b8(%edx),%xmm2 .byte 102,15,127,85,184 // movdqa %xmm2,-0x48(%ebp) .byte 102,15,254,202 // paddd %xmm2,%xmm1 .byte 102,15,223,249 // pandn %xmm1,%xmm7 .byte 243,15,126,85,232 // movq -0x18(%ebp),%xmm2 .byte 102,15,127,121,16 // movdqa %xmm7,0x10(%ecx) .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 102,15,97,193 // punpcklwd %xmm1,%xmm0 .byte 102,15,111,200 // movdqa %xmm0,%xmm1 .byte 102,15,219,203 // pand %xmm3,%xmm1 .byte 102,15,239,193 // pxor %xmm1,%xmm0 .byte 102,15,114,241,16 // pslld $0x10,%xmm1 .byte 102,15,111,248 // movdqa %xmm0,%xmm7 .byte 102,15,114,247,13 // pslld $0xd,%xmm7 .byte 102,15,235,249 // por %xmm1,%xmm7 .byte 102,15,111,101,168 // movdqa -0x58(%ebp),%xmm4 .byte 102,15,239,196 // pxor %xmm4,%xmm0 .byte 102,15,111,206 // movdqa %xmm6,%xmm1 .byte 102,15,102,200 // pcmpgtd %xmm0,%xmm1 .byte 102,15,254,125,184 // paddd -0x48(%ebp),%xmm7 .byte 102,15,223,207 // pandn %xmm7,%xmm1 .byte 102,15,127,73,32 // movdqa %xmm1,0x20(%ecx) .byte 102,15,239,255 // pxor %xmm7,%xmm7 .byte 102,15,97,239 // punpcklwd %xmm7,%xmm5 .byte 102,15,111,197 // movdqa %xmm5,%xmm0 .byte 102,15,219,195 // pand %xmm3,%xmm0 .byte 102,15,239,232 // pxor %xmm0,%xmm5 .byte 102,15,114,240,16 // pslld $0x10,%xmm0 .byte 102,15,111,205 // movdqa %xmm5,%xmm1 .byte 102,15,114,241,13 // pslld $0xd,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,15,239,236 // pxor %xmm4,%xmm5 .byte 102,15,111,198 // movdqa %xmm6,%xmm0 .byte 102,15,102,197 // pcmpgtd %xmm5,%xmm0 .byte 102,15,111,109,184 // movdqa -0x48(%ebp),%xmm5 .byte 102,15,254,205 // paddd %xmm5,%xmm1 .byte 102,15,223,193 // pandn %xmm1,%xmm0 .byte 102,15,127,65,48 // movdqa %xmm0,0x30(%ecx) .byte 102,15,97,215 // punpcklwd %xmm7,%xmm2 .byte 102,15,219,218 // pand %xmm2,%xmm3 .byte 102,15,239,211 // pxor %xmm3,%xmm2 .byte 102,15,114,243,16 // pslld $0x10,%xmm3 .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 102,15,114,240,13 // pslld $0xd,%xmm0 .byte 102,15,235,195 // por %xmm3,%xmm0 .byte 102,15,254,197 // paddd %xmm5,%xmm0 .byte 102,15,239,212 // pxor %xmm4,%xmm2 .byte 102,15,102,242 // pcmpgtd %xmm2,%xmm6 .byte 102,15,223,240 // pandn %xmm0,%xmm6 .byte 102,15,127,113,64 // movdqa %xmm6,0x40(%ecx) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,69,152 // movaps -0x68(%ebp),%xmm0 .byte 15,40,77,136 // movaps -0x78(%ebp),%xmm1 .byte 15,40,149,120,255,255,255 // movaps -0x88(%ebp),%xmm2 .byte 15,40,157,104,255,255,255 // movaps -0x98(%ebp),%xmm3 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 129,196,156,0,0,0 // add $0x9c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 242,15,16,4,254 // movsd (%esi,%edi,8),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 131,251,1 // cmp $0x1,%ebx .byte 15,132,43,254,255,255 // je 5055 <_sk_load_f16_dst_sse2+0x55> .byte 102,15,22,68,254,8 // movhpd 0x8(%esi,%edi,8),%xmm0 .byte 131,251,3 // cmp $0x3,%ebx .byte 15,130,28,254,255,255 // jb 5055 <_sk_load_f16_dst_sse2+0x55> .byte 243,15,126,76,254,16 // movq 0x10(%esi,%edi,8),%xmm1 .byte 233,17,254,255,255 // jmp 5055 <_sk_load_f16_dst_sse2+0x55> HIDDEN _sk_gather_f16_sse2 .globl _sk_gather_f16_sse2 FUNCTION(_sk_gather_f16_sse2) _sk_gather_f16_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,88 // sub $0x58,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,16 // mov (%eax),%edx .byte 139,10 // mov (%edx),%ecx .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,110,82,4 // movd 0x4(%edx),%xmm2 .byte 102,15,112,210,0 // pshufd $0x0,%xmm2,%xmm2 .byte 102,15,112,217,245 // pshufd $0xf5,%xmm1,%xmm3 .byte 102,15,244,218 // pmuludq %xmm2,%xmm3 .byte 102,15,112,219,232 // pshufd $0xe8,%xmm3,%xmm3 .byte 102,15,244,209 // pmuludq %xmm1,%xmm2 .byte 102,15,112,202,232 // pshufd $0xe8,%xmm2,%xmm1 .byte 102,15,98,203 // punpckldq %xmm3,%xmm1 .byte 243,15,91,192 // cvttps2dq %xmm0,%xmm0 .byte 102,15,254,193 // paddd %xmm1,%xmm0 .byte 102,15,112,200,78 // pshufd $0x4e,%xmm0,%xmm1 .byte 102,15,112,208,231 // pshufd $0xe7,%xmm0,%xmm2 .byte 102,15,126,210 // movd %xmm2,%edx .byte 102,15,110,84,209,4 // movd 0x4(%ecx,%edx,8),%xmm2 .byte 102,15,110,28,209 // movd (%ecx,%edx,8),%xmm3 .byte 102,15,126,202 // movd %xmm1,%edx .byte 102,15,110,76,209,4 // movd 0x4(%ecx,%edx,8),%xmm1 .byte 102,15,110,36,209 // movd (%ecx,%edx,8),%xmm4 .byte 102,15,126,194 // movd %xmm0,%edx .byte 102,15,112,192,229 // pshufd $0xe5,%xmm0,%xmm0 .byte 102,15,110,108,209,4 // movd 0x4(%ecx,%edx,8),%xmm5 .byte 102,15,110,52,209 // movd (%ecx,%edx,8),%xmm6 .byte 102,15,126,194 // movd %xmm0,%edx .byte 102,15,110,68,209,4 // movd 0x4(%ecx,%edx,8),%xmm0 .byte 102,15,110,60,209 // movd (%ecx,%edx,8),%xmm7 .byte 232,0,0,0,0 // call 52d2 <_sk_gather_f16_sse2+0x8e> .byte 89 // pop %ecx .byte 102,15,98,202 // punpckldq %xmm2,%xmm1 .byte 102,15,98,227 // punpckldq %xmm3,%xmm4 .byte 102,15,98,225 // punpckldq %xmm1,%xmm4 .byte 102,15,98,232 // punpckldq %xmm0,%xmm5 .byte 102,15,98,247 // punpckldq %xmm7,%xmm6 .byte 102,15,98,245 // punpckldq %xmm5,%xmm6 .byte 102,15,111,198 // movdqa %xmm6,%xmm0 .byte 102,15,97,196 // punpcklwd %xmm4,%xmm0 .byte 102,15,105,244 // punpckhwd %xmm4,%xmm6 .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,97,214 // punpcklwd %xmm6,%xmm2 .byte 102,15,105,198 // punpckhwd %xmm6,%xmm0 .byte 102,15,126,85,224 // movd %xmm2,-0x20(%ebp) .byte 102,15,112,202,229 // pshufd $0xe5,%xmm2,%xmm1 .byte 102,15,126,77,228 // movd %xmm1,-0x1c(%ebp) .byte 243,15,126,77,224 // movq -0x20(%ebp),%xmm1 .byte 102,15,112,218,231 // pshufd $0xe7,%xmm2,%xmm3 .byte 102,15,126,93,236 // movd %xmm3,-0x14(%ebp) .byte 102,15,112,210,78 // pshufd $0x4e,%xmm2,%xmm2 .byte 102,15,126,85,232 // movd %xmm2,-0x18(%ebp) .byte 243,15,126,125,232 // movq -0x18(%ebp),%xmm7 .byte 102,15,126,69,240 // movd %xmm0,-0x10(%ebp) .byte 102,15,112,216,229 // pshufd $0xe5,%xmm0,%xmm3 .byte 102,15,126,93,244 // movd %xmm3,-0xc(%ebp) .byte 243,15,126,109,240 // movq -0x10(%ebp),%xmm5 .byte 102,15,112,216,231 // pshufd $0xe7,%xmm0,%xmm3 .byte 102,15,126,93,252 // movd %xmm3,-0x4(%ebp) .byte 102,15,112,192,78 // pshufd $0x4e,%xmm0,%xmm0 .byte 102,15,126,69,248 // movd %xmm0,-0x8(%ebp) .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,111,153,62,46,0,0 // movdqa 0x2e3e(%ecx),%xmm3 .byte 102,15,111,225 // movdqa %xmm1,%xmm4 .byte 102,15,219,227 // pand %xmm3,%xmm4 .byte 102,15,239,204 // pxor %xmm4,%xmm1 .byte 102,15,114,244,16 // pslld $0x10,%xmm4 .byte 102,15,111,209 // movdqa %xmm1,%xmm2 .byte 102,15,114,242,13 // pslld $0xd,%xmm2 .byte 102,15,235,212 // por %xmm4,%xmm2 .byte 102,15,97,248 // punpcklwd %xmm0,%xmm7 .byte 102,15,111,231 // movdqa %xmm7,%xmm4 .byte 102,15,219,227 // pand %xmm3,%xmm4 .byte 102,15,239,252 // pxor %xmm4,%xmm7 .byte 102,15,127,125,168 // movdqa %xmm7,-0x58(%ebp) .byte 102,15,114,244,16 // pslld $0x10,%xmm4 .byte 102,15,111,247 // movdqa %xmm7,%xmm6 .byte 102,15,114,246,13 // pslld $0xd,%xmm6 .byte 102,15,235,244 // por %xmm4,%xmm6 .byte 102,15,97,232 // punpcklwd %xmm0,%xmm5 .byte 102,15,111,253 // movdqa %xmm5,%xmm7 .byte 102,15,219,251 // pand %xmm3,%xmm7 .byte 102,15,239,239 // pxor %xmm7,%xmm5 .byte 102,15,127,109,184 // movdqa %xmm5,-0x48(%ebp) .byte 102,15,114,247,16 // pslld $0x10,%xmm7 .byte 102,15,114,245,13 // pslld $0xd,%xmm5 .byte 102,15,235,239 // por %xmm7,%xmm5 .byte 243,15,126,125,248 // movq -0x8(%ebp),%xmm7 .byte 102,15,97,248 // punpcklwd %xmm0,%xmm7 .byte 102,15,219,223 // pand %xmm7,%xmm3 .byte 102,15,239,251 // pxor %xmm3,%xmm7 .byte 102,15,114,243,16 // pslld $0x10,%xmm3 .byte 102,15,111,199 // movdqa %xmm7,%xmm0 .byte 102,15,114,240,13 // pslld $0xd,%xmm0 .byte 102,15,235,195 // por %xmm3,%xmm0 .byte 102,15,111,153,78,46,0,0 // movdqa 0x2e4e(%ecx),%xmm3 .byte 102,15,254,211 // paddd %xmm3,%xmm2 .byte 102,15,254,243 // paddd %xmm3,%xmm6 .byte 102,15,254,235 // paddd %xmm3,%xmm5 .byte 102,15,254,195 // paddd %xmm3,%xmm0 .byte 102,15,111,153,94,46,0,0 // movdqa 0x2e5e(%ecx),%xmm3 .byte 102,15,127,93,200 // movdqa %xmm3,-0x38(%ebp) .byte 102,15,239,203 // pxor %xmm3,%xmm1 .byte 102,15,111,153,110,46,0,0 // movdqa 0x2e6e(%ecx),%xmm3 .byte 102,15,111,227 // movdqa %xmm3,%xmm4 .byte 102,15,102,225 // pcmpgtd %xmm1,%xmm4 .byte 102,15,223,226 // pandn %xmm2,%xmm4 .byte 102,15,111,85,168 // movdqa -0x58(%ebp),%xmm2 .byte 102,15,239,85,200 // pxor -0x38(%ebp),%xmm2 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,102,202 // pcmpgtd %xmm2,%xmm1 .byte 102,15,223,206 // pandn %xmm6,%xmm1 .byte 102,15,111,117,184 // movdqa -0x48(%ebp),%xmm6 .byte 102,15,239,117,200 // pxor -0x38(%ebp),%xmm6 .byte 102,15,111,211 // movdqa %xmm3,%xmm2 .byte 102,15,102,214 // pcmpgtd %xmm6,%xmm2 .byte 102,15,223,213 // pandn %xmm5,%xmm2 .byte 102,15,239,125,200 // pxor -0x38(%ebp),%xmm7 .byte 102,15,102,223 // pcmpgtd %xmm7,%xmm3 .byte 102,15,223,216 // pandn %xmm0,%xmm3 .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 102,15,111,196 // movdqa %xmm4,%xmm0 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,104 // add $0x68,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_store_f16_sse2 .globl _sk_store_f16_sse2 FUNCTION(_sk_store_f16_sse2) _sk_store_f16_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,80 // sub $0x50,%esp .byte 15,41,93,216 // movaps %xmm3,-0x28(%ebp) .byte 102,15,111,218 // movdqa %xmm2,%xmm3 .byte 232,0,0,0,0 // call 5495 <_sk_store_f16_sse2+0x15> .byte 88 // pop %eax .byte 102,15,111,176,187,44,0,0 // movdqa 0x2cbb(%eax),%xmm6 .byte 102,15,111,208 // movdqa %xmm0,%xmm2 .byte 102,15,219,214 // pand %xmm6,%xmm2 .byte 102,15,127,69,200 // movdqa %xmm0,-0x38(%ebp) .byte 102,15,111,232 // movdqa %xmm0,%xmm5 .byte 102,15,239,234 // pxor %xmm2,%xmm5 .byte 102,15,111,160,203,44,0,0 // movdqa 0x2ccb(%eax),%xmm4 .byte 102,15,114,210,16 // psrld $0x10,%xmm2 .byte 102,15,111,196 // movdqa %xmm4,%xmm0 .byte 102,15,102,197 // pcmpgtd %xmm5,%xmm0 .byte 102,15,114,213,13 // psrld $0xd,%xmm5 .byte 102,15,111,184,219,44,0,0 // movdqa 0x2cdb(%eax),%xmm7 .byte 102,15,254,215 // paddd %xmm7,%xmm2 .byte 102,15,127,125,232 // movdqa %xmm7,-0x18(%ebp) .byte 102,15,254,213 // paddd %xmm5,%xmm2 .byte 102,15,114,242,16 // pslld $0x10,%xmm2 .byte 102,15,114,226,16 // psrad $0x10,%xmm2 .byte 102,15,223,194 // pandn %xmm2,%xmm0 .byte 102,15,111,233 // movdqa %xmm1,%xmm5 .byte 102,15,219,238 // pand %xmm6,%xmm5 .byte 102,15,127,77,184 // movdqa %xmm1,-0x48(%ebp) .byte 102,15,239,205 // pxor %xmm5,%xmm1 .byte 102,15,114,213,16 // psrld $0x10,%xmm5 .byte 102,15,111,212 // movdqa %xmm4,%xmm2 .byte 102,15,102,209 // pcmpgtd %xmm1,%xmm2 .byte 102,15,114,209,13 // psrld $0xd,%xmm1 .byte 102,15,254,239 // paddd %xmm7,%xmm5 .byte 102,15,254,233 // paddd %xmm1,%xmm5 .byte 102,15,114,245,16 // pslld $0x10,%xmm5 .byte 102,15,114,229,16 // psrad $0x10,%xmm5 .byte 102,15,223,213 // pandn %xmm5,%xmm2 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,219,206 // pand %xmm6,%xmm1 .byte 102,15,127,93,168 // movdqa %xmm3,-0x58(%ebp) .byte 102,15,239,217 // pxor %xmm1,%xmm3 .byte 102,15,114,209,16 // psrld $0x10,%xmm1 .byte 102,15,111,236 // movdqa %xmm4,%xmm5 .byte 102,15,102,235 // pcmpgtd %xmm3,%xmm5 .byte 102,15,114,211,13 // psrld $0xd,%xmm3 .byte 102,15,254,77,232 // paddd -0x18(%ebp),%xmm1 .byte 102,15,254,203 // paddd %xmm3,%xmm1 .byte 102,15,111,93,216 // movdqa -0x28(%ebp),%xmm3 .byte 102,15,114,241,16 // pslld $0x10,%xmm1 .byte 102,15,114,225,16 // psrad $0x10,%xmm1 .byte 102,15,223,233 // pandn %xmm1,%xmm5 .byte 102,15,219,243 // pand %xmm3,%xmm6 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,239,206 // pxor %xmm6,%xmm1 .byte 102,15,114,214,16 // psrld $0x10,%xmm6 .byte 102,15,254,117,232 // paddd -0x18(%ebp),%xmm6 .byte 102,15,102,225 // pcmpgtd %xmm1,%xmm4 .byte 102,15,114,209,13 // psrld $0xd,%xmm1 .byte 102,15,254,241 // paddd %xmm1,%xmm6 .byte 102,15,111,200 // movdqa %xmm0,%xmm1 .byte 102,15,114,246,16 // pslld $0x10,%xmm6 .byte 102,15,114,230,16 // psrad $0x10,%xmm6 .byte 102,15,223,230 // pandn %xmm6,%xmm4 .byte 102,15,107,201 // packssdw %xmm1,%xmm1 .byte 102,15,107,210 // packssdw %xmm2,%xmm2 .byte 102,15,97,202 // punpcklwd %xmm2,%xmm1 .byte 102,15,107,237 // packssdw %xmm5,%xmm5 .byte 102,15,107,228 // packssdw %xmm4,%xmm4 .byte 102,15,97,236 // punpcklwd %xmm4,%xmm5 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,17 // mov (%ecx),%edx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 193,230,3 // shl $0x3,%esi .byte 3,55 // add (%edi),%esi .byte 139,121,8 // mov 0x8(%ecx),%edi .byte 133,255 // test %edi,%edi .byte 117,53 // jne 5607 <_sk_store_f16_sse2+0x187> .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,98,197 // punpckldq %xmm5,%xmm0 .byte 243,15,127,4,214 // movdqu %xmm0,(%esi,%edx,8) .byte 102,15,106,205 // punpckhdq %xmm5,%xmm1 .byte 243,15,127,76,214,16 // movdqu %xmm1,0x10(%esi,%edx,8) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,69,200 // movaps -0x38(%ebp),%xmm0 .byte 15,40,77,184 // movaps -0x48(%ebp),%xmm1 .byte 15,40,85,168 // movaps -0x58(%ebp),%xmm2 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,96 // add $0x60,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 93 // pop %ebp .byte 195 // ret .byte 102,15,111,209 // movdqa %xmm1,%xmm2 .byte 102,15,98,213 // punpckldq %xmm5,%xmm2 .byte 102,15,214,20,214 // movq %xmm2,(%esi,%edx,8) .byte 131,255,1 // cmp $0x1,%edi .byte 116,208 // je 55e9 <_sk_store_f16_sse2+0x169> .byte 102,15,23,84,214,8 // movhpd %xmm2,0x8(%esi,%edx,8) .byte 131,255,3 // cmp $0x3,%edi .byte 114,197 // jb 55e9 <_sk_store_f16_sse2+0x169> .byte 102,15,106,205 // punpckhdq %xmm5,%xmm1 .byte 102,15,214,76,214,16 // movq %xmm1,0x10(%esi,%edx,8) .byte 235,185 // jmp 55e9 <_sk_store_f16_sse2+0x169> HIDDEN _sk_load_u16_be_sse2 .globl _sk_load_u16_be_sse2 FUNCTION(_sk_load_u16_be_sse2) _sk_load_u16_be_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,44 // sub $0x2c,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,49 // mov (%ecx),%esi .byte 139,16 // mov (%eax),%edx .byte 139,122,4 // mov 0x4(%edx),%edi .byte 15,175,121,4 // imul 0x4(%ecx),%edi .byte 1,255 // add %edi,%edi .byte 3,58 // add (%edx),%edi .byte 139,89,8 // mov 0x8(%ecx),%ebx .byte 193,230,2 // shl $0x2,%esi .byte 133,219 // test %ebx,%ebx .byte 232,0,0,0,0 // call 565b <_sk_load_u16_be_sse2+0x2b> .byte 90 // pop %edx .byte 15,133,11,1,0,0 // jne 576d <_sk_load_u16_be_sse2+0x13d> .byte 102,15,16,4,119 // movupd (%edi,%esi,2),%xmm0 .byte 243,15,111,76,119,16 // movdqu 0x10(%edi,%esi,2),%xmm1 .byte 102,15,40,208 // movapd %xmm0,%xmm2 .byte 102,15,97,209 // punpcklwd %xmm1,%xmm2 .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 .byte 102,15,111,202 // movdqa %xmm2,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,105,208 // punpckhwd %xmm0,%xmm2 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,113,240,8 // psllw $0x8,%xmm0 .byte 102,15,112,233,78 // pshufd $0x4e,%xmm1,%xmm5 .byte 102,15,113,209,8 // psrlw $0x8,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,15,126,77,216 // movd %xmm1,-0x28(%ebp) .byte 102,15,112,193,229 // pshufd $0xe5,%xmm1,%xmm0 .byte 102,15,126,69,220 // movd %xmm0,-0x24(%ebp) .byte 243,15,126,69,216 // movq -0x28(%ebp),%xmm0 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,97,195 // punpcklwd %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,40,162,37,43,0,0 // movaps 0x2b25(%edx),%xmm4 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 102,15,111,205 // movdqa %xmm5,%xmm1 .byte 102,15,113,241,8 // psllw $0x8,%xmm1 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,235,233 // por %xmm1,%xmm5 .byte 102,15,126,109,208 // movd %xmm5,-0x30(%ebp) .byte 102,15,112,205,229 // pshufd $0xe5,%xmm5,%xmm1 .byte 102,15,126,77,212 // movd %xmm1,-0x2c(%ebp) .byte 243,15,126,77,208 // movq -0x30(%ebp),%xmm1 .byte 102,15,97,203 // punpcklwd %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 102,15,111,234 // movdqa %xmm2,%xmm5 .byte 102,15,113,245,8 // psllw $0x8,%xmm5 .byte 102,15,112,242,78 // pshufd $0x4e,%xmm2,%xmm6 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,235,213 // por %xmm5,%xmm2 .byte 102,15,126,85,232 // movd %xmm2,-0x18(%ebp) .byte 102,15,112,210,229 // pshufd $0xe5,%xmm2,%xmm2 .byte 102,15,126,85,236 // movd %xmm2,-0x14(%ebp) .byte 243,15,126,85,232 // movq -0x18(%ebp),%xmm2 .byte 102,15,97,211 // punpcklwd %xmm3,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 102,15,111,238 // movdqa %xmm6,%xmm5 .byte 102,15,113,245,8 // psllw $0x8,%xmm5 .byte 102,15,113,214,8 // psrlw $0x8,%xmm6 .byte 102,15,235,245 // por %xmm5,%xmm6 .byte 102,15,126,117,224 // movd %xmm6,-0x20(%ebp) .byte 102,15,112,238,229 // pshufd $0xe5,%xmm6,%xmm5 .byte 102,15,126,109,228 // movd %xmm5,-0x1c(%ebp) .byte 243,15,126,109,224 // movq -0x20(%ebp),%xmm5 .byte 102,15,97,235 // punpcklwd %xmm3,%xmm5 .byte 15,91,221 // cvtdq2ps %xmm5,%xmm3 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,60 // add $0x3c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 242,15,16,4,119 // movsd (%edi,%esi,2),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 131,251,1 // cmp $0x1,%ebx .byte 15,132,238,254,255,255 // je 566d <_sk_load_u16_be_sse2+0x3d> .byte 102,15,22,68,119,8 // movhpd 0x8(%edi,%esi,2),%xmm0 .byte 131,251,3 // cmp $0x3,%ebx .byte 15,130,223,254,255,255 // jb 566d <_sk_load_u16_be_sse2+0x3d> .byte 243,15,126,76,119,16 // movq 0x10(%edi,%esi,2),%xmm1 .byte 233,212,254,255,255 // jmp 566d <_sk_load_u16_be_sse2+0x3d> HIDDEN _sk_load_rgb_u16_be_sse2 .globl _sk_load_rgb_u16_be_sse2 FUNCTION(_sk_load_rgb_u16_be_sse2) _sk_load_rgb_u16_be_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,28 // sub $0x1c,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,121,8 // mov 0x8(%ecx),%edi .byte 139,16 // mov (%eax),%edx .byte 139,114,4 // mov 0x4(%edx),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 1,246 // add %esi,%esi .byte 3,50 // add (%edx),%esi .byte 107,25,3 // imul $0x3,(%ecx),%ebx .byte 133,255 // test %edi,%edi .byte 232,0,0,0,0 // call 57c2 <_sk_load_rgb_u16_be_sse2+0x29> .byte 90 // pop %edx .byte 15,133,240,0,0,0 // jne 58b9 <_sk_load_rgb_u16_be_sse2+0x120> .byte 243,15,111,20,94 // movdqu (%esi,%ebx,2),%xmm2 .byte 243,15,111,92,94,8 // movdqu 0x8(%esi,%ebx,2),%xmm3 .byte 102,15,115,219,4 // psrldq $0x4,%xmm3 .byte 102,15,111,194 // movdqa %xmm2,%xmm0 .byte 102,15,115,216,6 // psrldq $0x6,%xmm0 .byte 102,15,111,203 // movdqa %xmm3,%xmm1 .byte 102,15,115,217,6 // psrldq $0x6,%xmm1 .byte 102,15,97,211 // punpcklwd %xmm3,%xmm2 .byte 102,15,97,193 // punpcklwd %xmm1,%xmm0 .byte 102,15,111,202 // movdqa %xmm2,%xmm1 .byte 102,15,97,200 // punpcklwd %xmm0,%xmm1 .byte 102,15,112,225,78 // pshufd $0x4e,%xmm1,%xmm4 .byte 102,15,105,208 // punpckhwd %xmm0,%xmm2 .byte 102,15,111,193 // movdqa %xmm1,%xmm0 .byte 102,15,113,240,8 // psllw $0x8,%xmm0 .byte 102,15,113,209,8 // psrlw $0x8,%xmm1 .byte 102,15,235,200 // por %xmm0,%xmm1 .byte 102,15,126,77,224 // movd %xmm1,-0x20(%ebp) .byte 102,15,112,193,229 // pshufd $0xe5,%xmm1,%xmm0 .byte 102,15,126,69,228 // movd %xmm0,-0x1c(%ebp) .byte 243,15,126,69,224 // movq -0x20(%ebp),%xmm0 .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,97,195 // punpcklwd %xmm3,%xmm0 .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 .byte 15,40,170,206,41,0,0 // movaps 0x29ce(%edx),%xmm5 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 102,15,111,204 // movdqa %xmm4,%xmm1 .byte 102,15,113,241,8 // psllw $0x8,%xmm1 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,235,225 // por %xmm1,%xmm4 .byte 102,15,126,101,216 // movd %xmm4,-0x28(%ebp) .byte 102,15,112,204,229 // pshufd $0xe5,%xmm4,%xmm1 .byte 102,15,126,77,220 // movd %xmm1,-0x24(%ebp) .byte 243,15,126,77,216 // movq -0x28(%ebp),%xmm1 .byte 102,15,97,203 // punpcklwd %xmm3,%xmm1 .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 102,15,111,226 // movdqa %xmm2,%xmm4 .byte 102,15,113,244,8 // psllw $0x8,%xmm4 .byte 102,15,113,210,8 // psrlw $0x8,%xmm2 .byte 102,15,235,212 // por %xmm4,%xmm2 .byte 102,15,126,85,232 // movd %xmm2,-0x18(%ebp) .byte 102,15,112,210,229 // pshufd $0xe5,%xmm2,%xmm2 .byte 102,15,126,85,236 // movd %xmm2,-0x14(%ebp) .byte 243,15,126,85,232 // movq -0x18(%ebp),%xmm2 .byte 102,15,97,211 // punpcklwd %xmm3,%xmm2 .byte 15,91,210 // cvtdq2ps %xmm2,%xmm2 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 141,112,8 // lea 0x8(%eax),%esi .byte 131,236,8 // sub $0x8,%esp .byte 15,40,154,222,41,0,0 // movaps 0x29de(%edx),%xmm3 .byte 86 // push %esi .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,44 // add $0x2c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 102,15,110,20,94 // movd (%esi,%ebx,2),%xmm2 .byte 102,15,196,84,94,4,2 // pinsrw $0x2,0x4(%esi,%ebx,2),%xmm2 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 131,255,1 // cmp $0x1,%edi .byte 117,13 // jne 58db <_sk_load_rgb_u16_be_sse2+0x142> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 102,15,239,192 // pxor %xmm0,%xmm0 .byte 233,16,255,255,255 // jmp 57eb <_sk_load_rgb_u16_be_sse2+0x52> .byte 102,15,110,68,94,6 // movd 0x6(%esi,%ebx,2),%xmm0 .byte 102,15,196,68,94,10,2 // pinsrw $0x2,0xa(%esi,%ebx,2),%xmm0 .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 131,255,3 // cmp $0x3,%edi .byte 114,18 // jb 5903 <_sk_load_rgb_u16_be_sse2+0x16a> .byte 102,15,110,92,94,12 // movd 0xc(%esi,%ebx,2),%xmm3 .byte 102,15,196,92,94,16,2 // pinsrw $0x2,0x10(%esi,%ebx,2),%xmm3 .byte 233,232,254,255,255 // jmp 57eb <_sk_load_rgb_u16_be_sse2+0x52> .byte 102,15,239,219 // pxor %xmm3,%xmm3 .byte 233,223,254,255,255 // jmp 57eb <_sk_load_rgb_u16_be_sse2+0x52> HIDDEN _sk_store_u16_be_sse2 .globl _sk_store_u16_be_sse2 FUNCTION(_sk_store_u16_be_sse2) _sk_store_u16_be_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,16 // sub $0x10,%esp .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 232,0,0,0,0 // call 591d <_sk_store_u16_be_sse2+0x11> .byte 88 // pop %eax .byte 15,40,176,147,40,0,0 // movaps 0x2893(%eax),%xmm6 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,89,230 // mulps %xmm6,%xmm4 .byte 102,15,91,228 // cvtps2dq %xmm4,%xmm4 .byte 102,15,114,244,16 // pslld $0x10,%xmm4 .byte 102,15,114,228,16 // psrad $0x10,%xmm4 .byte 102,15,107,228 // packssdw %xmm4,%xmm4 .byte 102,15,111,236 // movdqa %xmm4,%xmm5 .byte 102,15,113,245,8 // psllw $0x8,%xmm5 .byte 102,15,113,212,8 // psrlw $0x8,%xmm4 .byte 102,15,235,229 // por %xmm5,%xmm4 .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,89,238 // mulps %xmm6,%xmm5 .byte 102,15,91,253 // cvtps2dq %xmm5,%xmm7 .byte 102,15,114,247,16 // pslld $0x10,%xmm7 .byte 102,15,114,231,16 // psrad $0x10,%xmm7 .byte 102,15,107,255 // packssdw %xmm7,%xmm7 .byte 102,15,111,239 // movdqa %xmm7,%xmm5 .byte 102,15,113,245,8 // psllw $0x8,%xmm5 .byte 102,15,113,215,8 // psrlw $0x8,%xmm7 .byte 102,15,235,253 // por %xmm5,%xmm7 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,89,238 // mulps %xmm6,%xmm5 .byte 102,15,91,237 // cvtps2dq %xmm5,%xmm5 .byte 102,15,114,245,16 // pslld $0x10,%xmm5 .byte 102,15,114,229,16 // psrad $0x10,%xmm5 .byte 102,15,107,237 // packssdw %xmm5,%xmm5 .byte 102,15,111,221 // movdqa %xmm5,%xmm3 .byte 102,15,113,243,8 // psllw $0x8,%xmm3 .byte 102,15,113,213,8 // psrlw $0x8,%xmm5 .byte 102,15,235,235 // por %xmm3,%xmm5 .byte 15,89,117,232 // mulps -0x18(%ebp),%xmm6 .byte 102,15,91,222 // cvtps2dq %xmm6,%xmm3 .byte 102,15,114,243,16 // pslld $0x10,%xmm3 .byte 102,15,114,227,16 // psrad $0x10,%xmm3 .byte 102,15,107,219 // packssdw %xmm3,%xmm3 .byte 102,15,111,243 // movdqa %xmm3,%xmm6 .byte 102,15,113,246,8 // psllw $0x8,%xmm6 .byte 102,15,113,211,8 // psrlw $0x8,%xmm3 .byte 102,15,235,222 // por %xmm6,%xmm3 .byte 102,15,97,231 // punpcklwd %xmm7,%xmm4 .byte 102,15,97,235 // punpcklwd %xmm3,%xmm5 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,17 // mov (%ecx),%edx .byte 139,56 // mov (%eax),%edi .byte 139,119,4 // mov 0x4(%edi),%esi .byte 15,175,113,4 // imul 0x4(%ecx),%esi .byte 1,246 // add %esi,%esi .byte 3,55 // add (%edi),%esi .byte 139,121,8 // mov 0x8(%ecx),%edi .byte 193,226,2 // shl $0x2,%edx .byte 133,255 // test %edi,%edi .byte 117,45 // jne 5a1f <_sk_store_u16_be_sse2+0x113> .byte 102,15,111,220 // movdqa %xmm4,%xmm3 .byte 102,15,98,221 // punpckldq %xmm5,%xmm3 .byte 243,15,127,28,86 // movdqu %xmm3,(%esi,%edx,2) .byte 102,15,106,229 // punpckhdq %xmm5,%xmm4 .byte 243,15,127,100,86,16 // movdqu %xmm4,0x10(%esi,%edx,2) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,32 // add $0x20,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 93 // pop %ebp .byte 195 // ret .byte 102,15,111,244 // movdqa %xmm4,%xmm6 .byte 102,15,98,245 // punpckldq %xmm5,%xmm6 .byte 102,15,214,52,86 // movq %xmm6,(%esi,%edx,2) .byte 131,255,1 // cmp $0x1,%edi .byte 116,216 // je 5a09 <_sk_store_u16_be_sse2+0xfd> .byte 102,15,23,116,86,8 // movhpd %xmm6,0x8(%esi,%edx,2) .byte 131,255,3 // cmp $0x3,%edi .byte 114,205 // jb 5a09 <_sk_store_u16_be_sse2+0xfd> .byte 102,15,106,229 // punpckhdq %xmm5,%xmm4 .byte 102,15,214,100,86,16 // movq %xmm4,0x10(%esi,%edx,2) .byte 235,193 // jmp 5a09 <_sk_store_u16_be_sse2+0xfd> HIDDEN _sk_load_f32_sse2 .globl _sk_load_f32_sse2 FUNCTION(_sk_load_f32_sse2) _sk_load_f32_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 87 // push %edi .byte 86 // push %esi .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,57 // mov (%ecx),%edi .byte 139,48 // mov (%eax),%esi .byte 139,86,4 // mov 0x4(%esi),%edx .byte 15,175,81,4 // imul 0x4(%ecx),%edx .byte 193,226,2 // shl $0x2,%edx .byte 3,22 // add (%esi),%edx .byte 141,52,189,0,0,0,0 // lea 0x0(,%edi,4),%esi .byte 193,231,4 // shl $0x4,%edi .byte 15,16,36,23 // movups (%edi,%edx,1),%xmm4 .byte 139,121,8 // mov 0x8(%ecx),%edi .byte 133,255 // test %edi,%edi .byte 117,71 // jne 5abf <_sk_load_f32_sse2+0x77> .byte 15,16,84,178,16 // movups 0x10(%edx,%esi,4),%xmm2 .byte 15,16,92,178,32 // movups 0x20(%edx,%esi,4),%xmm3 .byte 15,16,68,178,48 // movups 0x30(%edx,%esi,4),%xmm0 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,20,234 // unpcklps %xmm2,%xmm5 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,20,200 // unpcklps %xmm0,%xmm1 .byte 15,21,226 // unpckhps %xmm2,%xmm4 .byte 15,21,216 // unpckhps %xmm0,%xmm3 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 102,15,20,193 // unpcklpd %xmm1,%xmm0 .byte 15,18,205 // movhlps %xmm5,%xmm1 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 102,15,20,211 // unpcklpd %xmm3,%xmm2 .byte 15,18,220 // movhlps %xmm4,%xmm3 .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,16 // add $0x10,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 93 // pop %ebp .byte 195 // ret .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 131,255,1 // cmp $0x1,%edi .byte 117,8 // jne 5acf <_sk_load_f32_sse2+0x87> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 235,184 // jmp 5a87 <_sk_load_f32_sse2+0x3f> .byte 15,16,84,178,16 // movups 0x10(%edx,%esi,4),%xmm2 .byte 131,255,3 // cmp $0x3,%edi .byte 114,7 // jb 5ae0 <_sk_load_f32_sse2+0x98> .byte 15,16,92,178,32 // movups 0x20(%edx,%esi,4),%xmm3 .byte 235,167 // jmp 5a87 <_sk_load_f32_sse2+0x3f> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 235,162 // jmp 5a87 <_sk_load_f32_sse2+0x3f> HIDDEN _sk_load_f32_dst_sse2 .globl _sk_load_f32_dst_sse2 FUNCTION(_sk_load_f32_dst_sse2) _sk_load_f32_dst_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,32 // sub $0x20,%esp .byte 15,41,93,216 // movaps %xmm3,-0x28(%ebp) .byte 15,41,85,232 // movaps %xmm2,-0x18(%ebp) .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,57 // mov (%ecx),%edi .byte 139,48 // mov (%eax),%esi .byte 139,86,4 // mov 0x4(%esi),%edx .byte 15,175,81,4 // imul 0x4(%ecx),%edx .byte 193,226,2 // shl $0x2,%edx .byte 3,22 // add (%esi),%edx .byte 141,52,189,0,0,0,0 // lea 0x0(,%edi,4),%esi .byte 193,231,4 // shl $0x4,%edi .byte 15,16,52,23 // movups (%edi,%edx,1),%xmm6 .byte 139,121,8 // mov 0x8(%ecx),%edi .byte 133,255 // test %edi,%edi .byte 117,97 // jne 5b81 <_sk_load_f32_dst_sse2+0x9c> .byte 15,16,124,178,16 // movups 0x10(%edx,%esi,4),%xmm7 .byte 15,16,92,178,32 // movups 0x20(%edx,%esi,4),%xmm3 .byte 15,16,84,178,48 // movups 0x30(%edx,%esi,4),%xmm2 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 15,20,231 // unpcklps %xmm7,%xmm4 .byte 15,40,235 // movaps %xmm3,%xmm5 .byte 15,20,234 // unpcklps %xmm2,%xmm5 .byte 15,21,247 // unpckhps %xmm7,%xmm6 .byte 15,21,218 // unpckhps %xmm2,%xmm3 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 102,15,20,213 // unpcklpd %xmm5,%xmm2 .byte 15,18,236 // movhlps %xmm4,%xmm5 .byte 15,40,230 // movaps %xmm6,%xmm4 .byte 102,15,20,227 // unpcklpd %xmm3,%xmm4 .byte 15,18,222 // movhlps %xmm6,%xmm3 .byte 102,15,41,81,16 // movapd %xmm2,0x10(%ecx) .byte 15,41,105,32 // movaps %xmm5,0x20(%ecx) .byte 102,15,41,97,48 // movapd %xmm4,0x30(%ecx) .byte 15,41,89,64 // movaps %xmm3,0x40(%ecx) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,85,232 // movaps -0x18(%ebp),%xmm2 .byte 15,40,93,216 // movaps -0x28(%ebp),%xmm3 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,48 // add $0x30,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 93 // pop %ebp .byte 195 // ret .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 131,255,1 // cmp $0x1,%edi .byte 117,8 // jne 5b91 <_sk_load_f32_dst_sse2+0xac> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 235,158 // jmp 5b2f <_sk_load_f32_dst_sse2+0x4a> .byte 15,16,124,178,16 // movups 0x10(%edx,%esi,4),%xmm7 .byte 131,255,3 // cmp $0x3,%edi .byte 114,7 // jb 5ba2 <_sk_load_f32_dst_sse2+0xbd> .byte 15,16,92,178,32 // movups 0x20(%edx,%esi,4),%xmm3 .byte 235,141 // jmp 5b2f <_sk_load_f32_dst_sse2+0x4a> .byte 15,87,219 // xorps %xmm3,%xmm3 .byte 235,136 // jmp 5b2f <_sk_load_f32_dst_sse2+0x4a> HIDDEN _sk_store_f32_sse2 .globl _sk_store_f32_sse2 FUNCTION(_sk_store_f32_sse2) _sk_store_f32_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,25 // mov (%ecx),%ebx .byte 139,48 // mov (%eax),%esi .byte 139,86,4 // mov 0x4(%esi),%edx .byte 15,175,81,4 // imul 0x4(%ecx),%edx .byte 193,226,2 // shl $0x2,%edx .byte 3,22 // add (%esi),%edx .byte 141,52,157,0,0,0,0 // lea 0x0(,%ebx,4),%esi .byte 193,227,4 // shl $0x4,%ebx .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,20,233 // unpcklps %xmm1,%xmm5 .byte 15,40,226 // movaps %xmm2,%xmm4 .byte 15,20,227 // unpcklps %xmm3,%xmm4 .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 102,15,20,244 // unpcklpd %xmm4,%xmm6 .byte 139,121,8 // mov 0x8(%ecx),%edi .byte 102,15,17,52,19 // movupd %xmm6,(%ebx,%edx,1) .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,21,241 // unpckhps %xmm1,%xmm6 .byte 15,40,250 // movaps %xmm2,%xmm7 .byte 15,21,251 // unpckhps %xmm3,%xmm7 .byte 15,18,229 // movhlps %xmm5,%xmm4 .byte 15,40,238 // movaps %xmm6,%xmm5 .byte 102,15,20,239 // unpcklpd %xmm7,%xmm5 .byte 133,255 // test %edi,%edi .byte 117,40 // jne 5c2d <_sk_store_f32_sse2+0x86> .byte 102,15,21,247 // unpckhpd %xmm7,%xmm6 .byte 15,17,100,178,16 // movups %xmm4,0x10(%edx,%esi,4) .byte 102,15,17,108,178,32 // movupd %xmm5,0x20(%edx,%esi,4) .byte 102,15,17,116,178,48 // movupd %xmm6,0x30(%edx,%esi,4) .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret .byte 131,255,1 // cmp $0x1,%edi .byte 116,232 // je 5c1a <_sk_store_f32_sse2+0x73> .byte 15,17,100,178,16 // movups %xmm4,0x10(%edx,%esi,4) .byte 131,255,3 // cmp $0x3,%edi .byte 114,222 // jb 5c1a <_sk_store_f32_sse2+0x73> .byte 102,15,17,108,178,32 // movupd %xmm5,0x20(%edx,%esi,4) .byte 235,214 // jmp 5c1a <_sk_store_f32_sse2+0x73> HIDDEN _sk_clamp_x_sse2 .globl _sk_clamp_x_sse2 FUNCTION(_sk_clamp_x_sse2) _sk_clamp_x_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,95,224 // maxps %xmm0,%xmm4 .byte 243,15,16,1 // movss (%ecx),%xmm0 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 102,15,118,237 // pcmpeqd %xmm5,%xmm5 .byte 102,15,254,232 // paddd %xmm0,%xmm5 .byte 15,93,229 // minps %xmm5,%xmm4 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_clamp_y_sse2 .globl _sk_clamp_y_sse2 FUNCTION(_sk_clamp_y_sse2) _sk_clamp_y_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,95,225 // maxps %xmm1,%xmm4 .byte 243,15,16,9 // movss (%ecx),%xmm1 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 102,15,118,237 // pcmpeqd %xmm5,%xmm5 .byte 102,15,254,233 // paddd %xmm1,%xmm5 .byte 15,93,229 // minps %xmm5,%xmm4 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_repeat_x_sse2 .globl _sk_repeat_x_sse2 FUNCTION(_sk_repeat_x_sse2) _sk_repeat_x_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 5cc1 <_sk_repeat_x_sse2+0xb> .byte 89 // pop %ecx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,16 // mov (%eax),%edx .byte 243,15,16,42 // movss (%edx),%xmm5 .byte 243,15,16,114,4 // movss 0x4(%edx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,240 // mulps %xmm0,%xmm6 .byte 243,15,91,230 // cvttps2dq %xmm6,%xmm4 .byte 15,91,252 // cvtdq2ps %xmm4,%xmm7 .byte 15,194,247,1 // cmpltps %xmm7,%xmm6 .byte 15,84,177,255,36,0,0 // andps 0x24ff(%ecx),%xmm6 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,92,254 // subps %xmm6,%xmm7 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,253 // mulps %xmm5,%xmm7 .byte 15,92,199 // subps %xmm7,%xmm0 .byte 15,95,224 // maxps %xmm0,%xmm4 .byte 102,15,118,192 // pcmpeqd %xmm0,%xmm0 .byte 102,15,254,197 // paddd %xmm5,%xmm0 .byte 15,93,224 // minps %xmm0,%xmm4 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_repeat_y_sse2 .globl _sk_repeat_y_sse2 FUNCTION(_sk_repeat_y_sse2) _sk_repeat_y_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 5d27 <_sk_repeat_y_sse2+0xb> .byte 89 // pop %ecx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,16 // mov (%eax),%edx .byte 243,15,16,42 // movss (%edx),%xmm5 .byte 243,15,16,114,4 // movss 0x4(%edx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 243,15,91,230 // cvttps2dq %xmm6,%xmm4 .byte 15,91,252 // cvtdq2ps %xmm4,%xmm7 .byte 15,194,247,1 // cmpltps %xmm7,%xmm6 .byte 15,84,177,169,36,0,0 // andps 0x24a9(%ecx),%xmm6 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,92,254 // subps %xmm6,%xmm7 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,253 // mulps %xmm5,%xmm7 .byte 15,92,207 // subps %xmm7,%xmm1 .byte 15,95,225 // maxps %xmm1,%xmm4 .byte 102,15,118,201 // pcmpeqd %xmm1,%xmm1 .byte 102,15,254,205 // paddd %xmm5,%xmm1 .byte 15,93,225 // minps %xmm1,%xmm4 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_mirror_x_sse2 .globl _sk_mirror_x_sse2 FUNCTION(_sk_mirror_x_sse2) _sk_mirror_x_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 5d8d <_sk_mirror_x_sse2+0xb> .byte 89 // pop %ecx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,16 // mov (%eax),%edx .byte 243,15,16,42 // movss (%edx),%xmm5 .byte 243,15,16,114,4 // movss 0x4(%edx),%xmm6 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 243,15,89,177,67,41,0,0 // mulss 0x2943(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,240 // mulps %xmm0,%xmm6 .byte 243,15,91,254 // cvttps2dq %xmm6,%xmm7 .byte 15,91,255 // cvtdq2ps %xmm7,%xmm7 .byte 15,194,247,1 // cmpltps %xmm7,%xmm6 .byte 15,84,177,83,36,0,0 // andps 0x2453(%ecx),%xmm6 .byte 15,92,254 // subps %xmm6,%xmm7 .byte 243,15,88,237 // addss %xmm5,%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,253 // mulps %xmm5,%xmm7 .byte 15,92,199 // subps %xmm7,%xmm0 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,87,237 // xorps %xmm5,%xmm5 .byte 15,92,232 // subps %xmm0,%xmm5 .byte 15,84,232 // andps %xmm0,%xmm5 .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,95,197 // maxps %xmm5,%xmm0 .byte 102,15,118,237 // pcmpeqd %xmm5,%xmm5 .byte 102,15,254,236 // paddd %xmm4,%xmm5 .byte 15,93,197 // minps %xmm5,%xmm0 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_mirror_y_sse2 .globl _sk_mirror_y_sse2 FUNCTION(_sk_mirror_y_sse2) _sk_mirror_y_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 5e12 <_sk_mirror_y_sse2+0xb> .byte 89 // pop %ecx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,16 // mov (%eax),%edx .byte 243,15,16,42 // movss (%edx),%xmm5 .byte 243,15,16,114,4 // movss 0x4(%edx),%xmm6 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,92,204 // subps %xmm4,%xmm1 .byte 243,15,89,177,194,40,0,0 // mulss 0x28c2(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 243,15,91,254 // cvttps2dq %xmm6,%xmm7 .byte 15,91,255 // cvtdq2ps %xmm7,%xmm7 .byte 15,194,247,1 // cmpltps %xmm7,%xmm6 .byte 15,84,177,222,35,0,0 // andps 0x23de(%ecx),%xmm6 .byte 15,92,254 // subps %xmm6,%xmm7 .byte 243,15,88,237 // addss %xmm5,%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,253 // mulps %xmm5,%xmm7 .byte 15,92,207 // subps %xmm7,%xmm1 .byte 15,92,204 // subps %xmm4,%xmm1 .byte 15,87,237 // xorps %xmm5,%xmm5 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,84,233 // andps %xmm1,%xmm5 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,95,205 // maxps %xmm5,%xmm1 .byte 102,15,118,237 // pcmpeqd %xmm5,%xmm5 .byte 102,15,254,236 // paddd %xmm4,%xmm5 .byte 15,93,205 // minps %xmm5,%xmm1 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_clamp_x_1_sse2 .globl _sk_clamp_x_1_sse2 FUNCTION(_sk_clamp_x_1_sse2) _sk_clamp_x_1_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 5e97 <_sk_clamp_x_1_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,95,224 // maxps %xmm0,%xmm4 .byte 15,93,160,105,35,0,0 // minps 0x2369(%eax),%xmm4 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_repeat_x_1_sse2 .globl _sk_repeat_x_1_sse2 FUNCTION(_sk_repeat_x_1_sse2) _sk_repeat_x_1_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 5ec7 <_sk_repeat_x_1_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 243,15,91,224 // cvttps2dq %xmm0,%xmm4 .byte 15,91,228 // cvtdq2ps %xmm4,%xmm4 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,194,236,1 // cmpltps %xmm4,%xmm5 .byte 15,84,168,73,35,0,0 // andps 0x2349(%eax),%xmm5 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_mirror_x_1_sse2 .globl _sk_mirror_x_1_sse2 FUNCTION(_sk_mirror_x_1_sse2) _sk_mirror_x_1_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 5f02 <_sk_mirror_x_1_sse2+0xb> .byte 89 // pop %ecx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 15,40,161,30,35,0,0 // movaps 0x231e(%ecx),%xmm4 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,40,169,46,35,0,0 // movaps 0x232e(%ecx),%xmm5 .byte 15,89,232 // mulps %xmm0,%xmm5 .byte 243,15,91,245 // cvttps2dq %xmm5,%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,194,238,1 // cmpltps %xmm6,%xmm5 .byte 15,84,169,62,35,0,0 // andps 0x233e(%ecx),%xmm5 .byte 15,87,255 // xorps %xmm7,%xmm7 .byte 15,92,245 // subps %xmm5,%xmm6 .byte 15,88,246 // addps %xmm6,%xmm6 .byte 15,92,198 // subps %xmm6,%xmm0 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,92,248 // subps %xmm0,%xmm7 .byte 15,84,199 // andps %xmm7,%xmm0 .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_luminance_to_alpha_sse2 .globl _sk_luminance_to_alpha_sse2 FUNCTION(_sk_luminance_to_alpha_sse2) _sk_luminance_to_alpha_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 232,0,0,0,0 // call 5f60 <_sk_luminance_to_alpha_sse2+0xe> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 15,89,128,240,34,0,0 // mulps 0x22f0(%eax),%xmm0 .byte 15,89,136,0,35,0,0 // mulps 0x2300(%eax),%xmm1 .byte 15,88,200 // addps %xmm0,%xmm1 .byte 15,89,152,16,35,0,0 // mulps 0x2310(%eax),%xmm3 .byte 15,88,217 // addps %xmm1,%xmm3 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 15,87,192 // xorps %xmm0,%xmm0 .byte 15,87,201 // xorps %xmm1,%xmm1 .byte 15,87,210 // xorps %xmm2,%xmm2 .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_matrix_translate_sse2 .globl _sk_matrix_translate_sse2 FUNCTION(_sk_matrix_translate_sse2) _sk_matrix_translate_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,33 // movss (%ecx),%xmm4 .byte 243,15,16,105,4 // movss 0x4(%ecx),%xmm5 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,205 // addps %xmm5,%xmm1 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_matrix_scale_translate_sse2 .globl _sk_matrix_scale_translate_sse2 FUNCTION(_sk_matrix_scale_translate_sse2) _sk_matrix_scale_translate_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,97,8 // movss 0x8(%ecx),%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 243,15,16,41 // movss (%ecx),%xmm5 .byte 243,15,16,113,4 // movss 0x4(%ecx),%xmm6 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 243,15,16,97,12 // movss 0xc(%ecx),%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_matrix_2x3_sse2 .globl _sk_matrix_2x3_sse2 FUNCTION(_sk_matrix_2x3_sse2) _sk_matrix_2x3_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,1 // movss (%ecx),%xmm0 .byte 243,15,16,73,4 // movss 0x4(%ecx),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,15,16,113,8 // movss 0x8(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 243,15,16,121,16 // movss 0x10(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,113,12 // movss 0xc(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 243,15,16,121,20 // movss 0x14(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_matrix_3x4_sse2 .globl _sk_matrix_3x4_sse2 FUNCTION(_sk_matrix_3x4_sse2) _sk_matrix_3x4_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,1 // movss (%ecx),%xmm0 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,15,16,105,24 // movss 0x18(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 243,15,16,113,36 // movss 0x24(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,234 // mulps %xmm2,%xmm5 .byte 15,88,238 // addps %xmm6,%xmm5 .byte 243,15,16,113,12 // movss 0xc(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,88,245 // addps %xmm5,%xmm6 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 243,15,16,105,28 // movss 0x1c(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 243,15,16,113,40 // movss 0x28(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,234 // mulps %xmm2,%xmm5 .byte 15,88,238 // addps %xmm6,%xmm5 .byte 243,15,16,113,16 // movss 0x10(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,88,245 // addps %xmm5,%xmm6 .byte 243,15,16,105,4 // movss 0x4(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,88,238 // addps %xmm6,%xmm5 .byte 243,15,16,113,32 // movss 0x20(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,242 // mulps %xmm2,%xmm6 .byte 243,15,16,81,44 // movss 0x2c(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 15,88,242 // addps %xmm2,%xmm6 .byte 243,15,16,121,20 // movss 0x14(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,249 // mulps %xmm1,%xmm7 .byte 15,88,254 // addps %xmm6,%xmm7 .byte 243,15,16,81,8 // movss 0x8(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,215 // addps %xmm7,%xmm2 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_matrix_4x5_sse2 .globl _sk_matrix_4x5_sse2 FUNCTION(_sk_matrix_4x5_sse2) _sk_matrix_4x5_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 137,77,252 // mov %ecx,-0x4(%ebp) .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,33 // movss (%ecx),%xmm4 .byte 243,15,16,73,4 // movss 0x4(%ecx),%xmm1 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 243,15,16,113,48 // movss 0x30(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 243,15,16,121,64 // movss 0x40(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 243,15,16,121,32 // movss 0x20(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,250 // mulps %xmm2,%xmm7 .byte 15,88,254 // addps %xmm6,%xmm7 .byte 243,15,16,113,16 // movss 0x10(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,88,230 // addps %xmm6,%xmm4 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,113,52 // movss 0x34(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 243,15,16,121,68 // movss 0x44(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 243,15,16,121,36 // movss 0x24(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,250 // mulps %xmm2,%xmm7 .byte 15,88,254 // addps %xmm6,%xmm7 .byte 243,15,16,113,20 // movss 0x14(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 243,15,16,113,56 // movss 0x38(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 243,15,16,121,72 // movss 0x48(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 243,15,16,121,40 // movss 0x28(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,250 // mulps %xmm2,%xmm7 .byte 15,88,254 // addps %xmm6,%xmm7 .byte 243,15,16,113,24 // movss 0x18(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 243,15,16,121,8 // movss 0x8(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,248 // mulps %xmm0,%xmm7 .byte 15,88,254 // addps %xmm6,%xmm7 .byte 243,15,16,113,60 // movss 0x3c(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,243 // mulps %xmm3,%xmm6 .byte 243,15,16,89,76 // movss 0x4c(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 15,88,243 // addps %xmm3,%xmm6 .byte 243,15,16,89,44 // movss 0x2c(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 15,89,218 // mulps %xmm2,%xmm3 .byte 15,88,222 // addps %xmm6,%xmm3 .byte 243,15,16,81,28 // movss 0x1c(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 243,15,16,89,12 // movss 0xc(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,88,218 // addps %xmm2,%xmm3 .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,40,215 // movaps %xmm7,%xmm2 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_matrix_4x3_sse2 .globl _sk_matrix_4x3_sse2 FUNCTION(_sk_matrix_4x3_sse2) _sk_matrix_4x3_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,233 // movaps %xmm1,%xmm5 .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,1 // movss (%ecx),%xmm0 .byte 243,15,16,73,4 // movss 0x4(%ecx),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,15,16,81,16 // movss 0x10(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,89,32 // movss 0x20(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,81,20 // movss 0x14(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,89,36 // movss 0x24(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 243,15,16,81,8 // movss 0x8(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,89,24 // movss 0x18(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 243,15,16,113,40 // movss 0x28(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 15,88,222 // addps %xmm6,%xmm3 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 243,15,16,89,12 // movss 0xc(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 243,15,16,113,28 // movss 0x1c(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 243,15,16,121,44 // movss 0x2c(%ecx),%xmm7 .byte 15,198,255,0 // shufps $0x0,%xmm7,%xmm7 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,247 // addps %xmm7,%xmm6 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 15,88,222 // addps %xmm6,%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_matrix_perspective_sse2 .globl _sk_matrix_perspective_sse2 FUNCTION(_sk_matrix_perspective_sse2) _sk_matrix_perspective_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,1 // movss (%ecx),%xmm0 .byte 243,15,16,105,4 // movss 0x4(%ecx),%xmm5 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 243,15,16,113,8 // movss 0x8(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,233 // mulps %xmm1,%xmm5 .byte 15,88,238 // addps %xmm6,%xmm5 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,197 // addps %xmm5,%xmm0 .byte 243,15,16,113,16 // movss 0x10(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 243,15,16,105,20 // movss 0x14(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 15,88,245 // addps %xmm5,%xmm6 .byte 243,15,16,105,12 // movss 0xc(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,88,238 // addps %xmm6,%xmm5 .byte 243,15,16,113,28 // movss 0x1c(%ecx),%xmm6 .byte 15,198,246,0 // shufps $0x0,%xmm6,%xmm6 .byte 15,89,241 // mulps %xmm1,%xmm6 .byte 243,15,16,73,32 // movss 0x20(%ecx),%xmm1 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 15,88,241 // addps %xmm1,%xmm6 .byte 243,15,16,73,24 // movss 0x18(%ecx),%xmm1 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,206 // addps %xmm6,%xmm1 .byte 15,83,201 // rcpps %xmm1,%xmm1 .byte 15,89,193 // mulps %xmm1,%xmm0 .byte 15,89,233 // mulps %xmm1,%xmm5 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,205 // movaps %xmm5,%xmm1 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_evenly_spaced_gradient_sse2 .globl _sk_evenly_spaced_gradient_sse2 FUNCTION(_sk_evenly_spaced_gradient_sse2) _sk_evenly_spaced_gradient_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,60 // sub $0x3c,%esp .byte 15,41,69,184 // movaps %xmm0,-0x48(%ebp) .byte 232,0,0,0,0 // call 63fd <_sk_evenly_spaced_gradient_sse2+0x12> .byte 90 // pop %edx .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 137,69,240 // mov %eax,-0x10(%ebp) .byte 139,9 // mov (%ecx),%ecx .byte 139,49 // mov (%ecx),%esi .byte 139,65,4 // mov 0x4(%ecx),%eax .byte 78 // dec %esi .byte 102,15,110,206 // movd %esi,%xmm1 .byte 102,15,112,201,0 // pshufd $0x0,%xmm1,%xmm1 .byte 102,15,111,146,131,30,0,0 // movdqa 0x1e83(%edx),%xmm2 .byte 102,15,219,209 // pand %xmm1,%xmm2 .byte 102,15,235,146,147,30,0,0 // por 0x1e93(%edx),%xmm2 .byte 102,15,114,209,16 // psrld $0x10,%xmm1 .byte 102,15,235,138,163,30,0,0 // por 0x1ea3(%edx),%xmm1 .byte 15,88,138,179,30,0,0 // addps 0x1eb3(%edx),%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 243,15,91,201 // cvttps2dq %xmm1,%xmm1 .byte 102,15,112,209,229 // pshufd $0xe5,%xmm1,%xmm2 .byte 102,15,126,210 // movd %xmm2,%edx .byte 102,15,112,209,78 // pshufd $0x4e,%xmm1,%xmm2 .byte 102,15,112,217,231 // pshufd $0xe7,%xmm1,%xmm3 .byte 102,15,126,223 // movd %xmm3,%edi .byte 243,15,16,28,184 // movss (%eax,%edi,4),%xmm3 .byte 243,15,16,52,144 // movss (%eax,%edx,4),%xmm6 .byte 102,15,126,206 // movd %xmm1,%esi .byte 243,15,16,36,176 // movss (%eax,%esi,4),%xmm4 .byte 102,15,126,211 // movd %xmm2,%ebx .byte 243,15,16,12,152 // movss (%eax,%ebx,4),%xmm1 .byte 15,20,243 // unpcklps %xmm3,%xmm6 .byte 139,65,20 // mov 0x14(%ecx),%eax .byte 243,15,16,20,184 // movss (%eax,%edi,4),%xmm2 .byte 243,15,16,28,144 // movss (%eax,%edx,4),%xmm3 .byte 243,15,16,4,176 // movss (%eax,%esi,4),%xmm0 .byte 243,15,16,60,152 // movss (%eax,%ebx,4),%xmm7 .byte 15,20,225 // unpcklps %xmm1,%xmm4 .byte 15,20,230 // unpcklps %xmm6,%xmm4 .byte 15,20,218 // unpcklps %xmm2,%xmm3 .byte 15,20,199 // unpcklps %xmm7,%xmm0 .byte 139,65,8 // mov 0x8(%ecx),%eax .byte 243,15,16,20,184 // movss (%eax,%edi,4),%xmm2 .byte 243,15,16,52,144 // movss (%eax,%edx,4),%xmm6 .byte 243,15,16,12,176 // movss (%eax,%esi,4),%xmm1 .byte 243,15,16,60,152 // movss (%eax,%ebx,4),%xmm7 .byte 15,20,195 // unpcklps %xmm3,%xmm0 .byte 15,41,69,200 // movaps %xmm0,-0x38(%ebp) .byte 15,20,242 // unpcklps %xmm2,%xmm6 .byte 15,20,207 // unpcklps %xmm7,%xmm1 .byte 15,20,206 // unpcklps %xmm6,%xmm1 .byte 139,65,24 // mov 0x18(%ecx),%eax .byte 243,15,16,20,184 // movss (%eax,%edi,4),%xmm2 .byte 243,15,16,28,144 // movss (%eax,%edx,4),%xmm3 .byte 243,15,16,4,176 // movss (%eax,%esi,4),%xmm0 .byte 243,15,16,60,152 // movss (%eax,%ebx,4),%xmm7 .byte 15,20,218 // unpcklps %xmm2,%xmm3 .byte 15,20,199 // unpcklps %xmm7,%xmm0 .byte 15,20,195 // unpcklps %xmm3,%xmm0 .byte 15,41,69,216 // movaps %xmm0,-0x28(%ebp) .byte 139,65,12 // mov 0xc(%ecx),%eax .byte 243,15,16,20,184 // movss (%eax,%edi,4),%xmm2 .byte 243,15,16,28,144 // movss (%eax,%edx,4),%xmm3 .byte 15,20,218 // unpcklps %xmm2,%xmm3 .byte 243,15,16,20,176 // movss (%eax,%esi,4),%xmm2 .byte 243,15,16,60,152 // movss (%eax,%ebx,4),%xmm7 .byte 15,20,215 // unpcklps %xmm7,%xmm2 .byte 15,20,211 // unpcklps %xmm3,%xmm2 .byte 139,65,28 // mov 0x1c(%ecx),%eax .byte 243,15,16,60,184 // movss (%eax,%edi,4),%xmm7 .byte 243,15,16,28,144 // movss (%eax,%edx,4),%xmm3 .byte 15,20,223 // unpcklps %xmm7,%xmm3 .byte 243,15,16,60,176 // movss (%eax,%esi,4),%xmm7 .byte 243,15,16,44,152 // movss (%eax,%ebx,4),%xmm5 .byte 15,20,253 // unpcklps %xmm5,%xmm7 .byte 15,20,251 // unpcklps %xmm3,%xmm7 .byte 139,65,16 // mov 0x10(%ecx),%eax .byte 243,15,16,28,184 // movss (%eax,%edi,4),%xmm3 .byte 243,15,16,44,144 // movss (%eax,%edx,4),%xmm5 .byte 15,20,235 // unpcklps %xmm3,%xmm5 .byte 243,15,16,28,176 // movss (%eax,%esi,4),%xmm3 .byte 243,15,16,4,152 // movss (%eax,%ebx,4),%xmm0 .byte 15,20,216 // unpcklps %xmm0,%xmm3 .byte 15,20,221 // unpcklps %xmm5,%xmm3 .byte 139,65,32 // mov 0x20(%ecx),%eax .byte 243,15,16,4,184 // movss (%eax,%edi,4),%xmm0 .byte 243,15,16,44,144 // movss (%eax,%edx,4),%xmm5 .byte 15,20,232 // unpcklps %xmm0,%xmm5 .byte 243,15,16,4,176 // movss (%eax,%esi,4),%xmm0 .byte 243,15,16,52,152 // movss (%eax,%ebx,4),%xmm6 .byte 15,20,198 // unpcklps %xmm6,%xmm0 .byte 15,20,197 // unpcklps %xmm5,%xmm0 .byte 15,40,109,184 // movaps -0x48(%ebp),%xmm5 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,88,101,200 // addps -0x38(%ebp),%xmm4 .byte 15,89,205 // mulps %xmm5,%xmm1 .byte 15,88,77,216 // addps -0x28(%ebp),%xmm1 .byte 15,89,213 // mulps %xmm5,%xmm2 .byte 15,88,215 // addps %xmm7,%xmm2 .byte 15,89,221 // mulps %xmm5,%xmm3 .byte 15,88,216 // addps %xmm0,%xmm3 .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 141,74,8 // lea 0x8(%edx),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 81 // push %ecx .byte 80 // push %eax .byte 255,82,4 // call *0x4(%edx) .byte 131,196,76 // add $0x4c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_gauss_a_to_rgba_sse2 .globl _sk_gauss_a_to_rgba_sse2 FUNCTION(_sk_gauss_a_to_rgba_sse2) _sk_gauss_a_to_rgba_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 65b3 <_sk_gauss_a_to_rgba_sse2+0xb> .byte 88 // pop %eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 15,40,128,13,29,0,0 // movaps 0x1d0d(%eax),%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,128,29,29,0,0 // addps 0x1d1d(%eax),%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,128,45,29,0,0 // addps 0x1d2d(%eax),%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,128,61,29,0,0 // addps 0x1d3d(%eax),%xmm0 .byte 15,89,195 // mulps %xmm3,%xmm0 .byte 15,88,128,77,29,0,0 // addps 0x1d4d(%eax),%xmm0 .byte 141,65,4 // lea 0x4(%ecx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 15,40,208 // movaps %xmm0,%xmm2 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 80 // push %eax .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,17 // call *(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_gradient_sse2 .globl _sk_gradient_sse2 FUNCTION(_sk_gradient_sse2) _sk_gradient_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,60 // sub $0x3c,%esp .byte 232,0,0,0,0 // call 660e <_sk_gradient_sse2+0xe> .byte 95 // pop %edi .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 141,81,4 // lea 0x4(%ecx),%edx .byte 137,85,240 // mov %edx,-0x10(%ebp) .byte 139,9 // mov (%ecx),%ecx .byte 139,17 // mov (%ecx),%edx .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 131,250,2 // cmp $0x2,%edx .byte 114,43 // jb 6650 <_sk_gradient_sse2+0x50> .byte 139,113,36 // mov 0x24(%ecx),%esi .byte 74 // dec %edx .byte 131,198,4 // add $0x4,%esi .byte 102,15,239,201 // pxor %xmm1,%xmm1 .byte 15,40,151,2,29,0,0 // movaps 0x1d02(%edi),%xmm2 .byte 243,15,16,30 // movss (%esi),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 15,194,216,2 // cmpleps %xmm0,%xmm3 .byte 15,84,218 // andps %xmm2,%xmm3 .byte 102,15,254,203 // paddd %xmm3,%xmm1 .byte 131,198,4 // add $0x4,%esi .byte 74 // dec %edx .byte 117,231 // jne 6637 <_sk_gradient_sse2+0x37> .byte 102,15,126,202 // movd %xmm1,%edx .byte 102,15,112,209,229 // pshufd $0xe5,%xmm1,%xmm2 .byte 102,15,126,214 // movd %xmm2,%esi .byte 102,15,112,209,78 // pshufd $0x4e,%xmm1,%xmm2 .byte 102,15,112,201,231 // pshufd $0xe7,%xmm1,%xmm1 .byte 102,15,126,207 // movd %xmm1,%edi .byte 139,65,4 // mov 0x4(%ecx),%eax .byte 243,15,16,12,184 // movss (%eax,%edi,4),%xmm1 .byte 243,15,16,28,176 // movss (%eax,%esi,4),%xmm3 .byte 243,15,16,36,144 // movss (%eax,%edx,4),%xmm4 .byte 102,15,126,211 // movd %xmm2,%ebx .byte 243,15,16,20,152 // movss (%eax,%ebx,4),%xmm2 .byte 15,20,217 // unpcklps %xmm1,%xmm3 .byte 139,65,20 // mov 0x14(%ecx),%eax .byte 243,15,16,12,184 // movss (%eax,%edi,4),%xmm1 .byte 243,15,16,52,176 // movss (%eax,%esi,4),%xmm6 .byte 243,15,16,44,144 // movss (%eax,%edx,4),%xmm5 .byte 243,15,16,60,152 // movss (%eax,%ebx,4),%xmm7 .byte 15,20,226 // unpcklps %xmm2,%xmm4 .byte 15,20,227 // unpcklps %xmm3,%xmm4 .byte 15,41,101,184 // movaps %xmm4,-0x48(%ebp) .byte 15,20,241 // unpcklps %xmm1,%xmm6 .byte 15,20,239 // unpcklps %xmm7,%xmm5 .byte 139,65,8 // mov 0x8(%ecx),%eax .byte 243,15,16,20,184 // movss (%eax,%edi,4),%xmm2 .byte 243,15,16,28,176 // movss (%eax,%esi,4),%xmm3 .byte 243,15,16,12,144 // movss (%eax,%edx,4),%xmm1 .byte 243,15,16,60,152 // movss (%eax,%ebx,4),%xmm7 .byte 15,20,238 // unpcklps %xmm6,%xmm5 .byte 15,41,109,200 // movaps %xmm5,-0x38(%ebp) .byte 15,20,218 // unpcklps %xmm2,%xmm3 .byte 15,20,207 // unpcklps %xmm7,%xmm1 .byte 15,20,203 // unpcklps %xmm3,%xmm1 .byte 139,65,24 // mov 0x18(%ecx),%eax .byte 243,15,16,20,184 // movss (%eax,%edi,4),%xmm2 .byte 243,15,16,28,176 // movss (%eax,%esi,4),%xmm3 .byte 243,15,16,36,144 // movss (%eax,%edx,4),%xmm4 .byte 243,15,16,60,152 // movss (%eax,%ebx,4),%xmm7 .byte 15,20,218 // unpcklps %xmm2,%xmm3 .byte 15,20,231 // unpcklps %xmm7,%xmm4 .byte 15,20,227 // unpcklps %xmm3,%xmm4 .byte 15,41,101,216 // movaps %xmm4,-0x28(%ebp) .byte 139,65,12 // mov 0xc(%ecx),%eax .byte 243,15,16,20,184 // movss (%eax,%edi,4),%xmm2 .byte 243,15,16,28,176 // movss (%eax,%esi,4),%xmm3 .byte 15,20,218 // unpcklps %xmm2,%xmm3 .byte 243,15,16,20,144 // movss (%eax,%edx,4),%xmm2 .byte 243,15,16,60,152 // movss (%eax,%ebx,4),%xmm7 .byte 15,20,215 // unpcklps %xmm7,%xmm2 .byte 15,20,211 // unpcklps %xmm3,%xmm2 .byte 139,65,28 // mov 0x1c(%ecx),%eax .byte 243,15,16,60,184 // movss (%eax,%edi,4),%xmm7 .byte 243,15,16,28,176 // movss (%eax,%esi,4),%xmm3 .byte 15,20,223 // unpcklps %xmm7,%xmm3 .byte 243,15,16,60,144 // movss (%eax,%edx,4),%xmm7 .byte 243,15,16,44,152 // movss (%eax,%ebx,4),%xmm5 .byte 15,20,253 // unpcklps %xmm5,%xmm7 .byte 15,20,251 // unpcklps %xmm3,%xmm7 .byte 139,65,16 // mov 0x10(%ecx),%eax .byte 243,15,16,28,184 // movss (%eax,%edi,4),%xmm3 .byte 243,15,16,44,176 // movss (%eax,%esi,4),%xmm5 .byte 15,20,235 // unpcklps %xmm3,%xmm5 .byte 243,15,16,28,144 // movss (%eax,%edx,4),%xmm3 .byte 243,15,16,52,152 // movss (%eax,%ebx,4),%xmm6 .byte 15,20,222 // unpcklps %xmm6,%xmm3 .byte 15,20,221 // unpcklps %xmm5,%xmm3 .byte 139,65,32 // mov 0x20(%ecx),%eax .byte 243,15,16,44,184 // movss (%eax,%edi,4),%xmm5 .byte 243,15,16,52,176 // movss (%eax,%esi,4),%xmm6 .byte 15,20,245 // unpcklps %xmm5,%xmm6 .byte 243,15,16,44,144 // movss (%eax,%edx,4),%xmm5 .byte 243,15,16,36,152 // movss (%eax,%ebx,4),%xmm4 .byte 15,20,236 // unpcklps %xmm4,%xmm5 .byte 15,20,238 // unpcklps %xmm6,%xmm5 .byte 15,40,101,184 // movaps -0x48(%ebp),%xmm4 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,88,101,200 // addps -0x38(%ebp),%xmm4 .byte 15,89,200 // mulps %xmm0,%xmm1 .byte 15,88,77,216 // addps -0x28(%ebp),%xmm1 .byte 15,89,208 // mulps %xmm0,%xmm2 .byte 15,88,215 // addps %xmm7,%xmm2 .byte 15,89,216 // mulps %xmm0,%xmm3 .byte 15,88,221 // addps %xmm5,%xmm3 .byte 139,69,240 // mov -0x10(%ebp),%eax .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,76 // add $0x4c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_evenly_spaced_2_stop_gradient_sse2 .globl _sk_evenly_spaced_2_stop_gradient_sse2 FUNCTION(_sk_evenly_spaced_2_stop_gradient_sse2) _sk_evenly_spaced_2_stop_gradient_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,1 // movss (%ecx),%xmm0 .byte 243,15,16,73,4 // movss 0x4(%ecx),%xmm1 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 243,15,16,81,16 // movss 0x10(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 15,89,196 // mulps %xmm4,%xmm0 .byte 15,88,194 // addps %xmm2,%xmm0 .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 .byte 243,15,16,81,20 // movss 0x14(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 15,89,204 // mulps %xmm4,%xmm1 .byte 15,88,202 // addps %xmm2,%xmm1 .byte 243,15,16,81,8 // movss 0x8(%ecx),%xmm2 .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 .byte 243,15,16,89,24 // movss 0x18(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 15,89,212 // mulps %xmm4,%xmm2 .byte 15,88,211 // addps %xmm3,%xmm2 .byte 243,15,16,89,12 // movss 0xc(%ecx),%xmm3 .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 .byte 243,15,16,105,28 // movss 0x1c(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,220 // mulps %xmm4,%xmm3 .byte 15,88,221 // addps %xmm5,%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_xy_to_unit_angle_sse2 .globl _sk_xy_to_unit_angle_sse2 FUNCTION(_sk_xy_to_unit_angle_sse2) _sk_xy_to_unit_angle_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,24 // sub $0x18,%esp .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 15,40,209 // movaps %xmm1,%xmm2 .byte 15,40,200 // movaps %xmm0,%xmm1 .byte 232,0,0,0,0 // call 684a <_sk_xy_to_unit_angle_sse2+0x18> .byte 88 // pop %eax .byte 15,87,237 // xorps %xmm5,%xmm5 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,84,233 // andps %xmm1,%xmm5 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,92,226 // subps %xmm2,%xmm4 .byte 15,84,226 // andps %xmm2,%xmm4 .byte 15,40,245 // movaps %xmm5,%xmm6 .byte 15,93,244 // minps %xmm4,%xmm6 .byte 15,40,253 // movaps %xmm5,%xmm7 .byte 15,95,252 // maxps %xmm4,%xmm7 .byte 15,94,247 // divps %xmm7,%xmm6 .byte 15,40,254 // movaps %xmm6,%xmm7 .byte 15,89,255 // mulps %xmm7,%xmm7 .byte 15,40,128,214,26,0,0 // movaps 0x1ad6(%eax),%xmm0 .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,88,128,230,26,0,0 // addps 0x1ae6(%eax),%xmm0 .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,88,128,246,26,0,0 // addps 0x1af6(%eax),%xmm0 .byte 15,89,199 // mulps %xmm7,%xmm0 .byte 15,88,128,6,27,0,0 // addps 0x1b06(%eax),%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,194,236,1 // cmpltps %xmm4,%xmm5 .byte 15,40,176,22,27,0,0 // movaps 0x1b16(%eax),%xmm6 .byte 15,92,240 // subps %xmm0,%xmm6 .byte 15,84,245 // andps %xmm5,%xmm6 .byte 15,85,232 // andnps %xmm0,%xmm5 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,86,238 // orps %xmm6,%xmm5 .byte 15,194,204,1 // cmpltps %xmm4,%xmm1 .byte 15,40,128,38,27,0,0 // movaps 0x1b26(%eax),%xmm0 .byte 15,92,197 // subps %xmm5,%xmm0 .byte 15,84,193 // andps %xmm1,%xmm0 .byte 15,85,205 // andnps %xmm5,%xmm1 .byte 15,86,200 // orps %xmm0,%xmm1 .byte 15,40,194 // movaps %xmm2,%xmm0 .byte 15,194,196,1 // cmpltps %xmm4,%xmm0 .byte 15,40,168,54,27,0,0 // movaps 0x1b36(%eax),%xmm5 .byte 15,92,233 // subps %xmm1,%xmm5 .byte 15,84,232 // andps %xmm0,%xmm5 .byte 15,85,193 // andnps %xmm1,%xmm0 .byte 15,86,197 // orps %xmm5,%xmm0 .byte 15,194,224,7 // cmpordps %xmm0,%xmm4 .byte 15,84,224 // andps %xmm0,%xmm4 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,196 // movaps %xmm4,%xmm0 .byte 15,40,202 // movaps %xmm2,%xmm1 .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,40 // add $0x28,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_xy_to_radius_sse2 .globl _sk_xy_to_radius_sse2 FUNCTION(_sk_xy_to_radius_sse2) _sk_xy_to_radius_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 15,40,225 // movaps %xmm1,%xmm4 .byte 15,89,228 // mulps %xmm4,%xmm4 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 15,81,196 // sqrtps %xmm4,%xmm0 .byte 141,72,4 // lea 0x4(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,16 // call *(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_xy_to_2pt_conical_quadratic_max_sse2 .globl _sk_xy_to_2pt_conical_quadratic_max_sse2 FUNCTION(_sk_xy_to_2pt_conical_quadratic_max_sse2) _sk_xy_to_2pt_conical_quadratic_max_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,105,40 // movss 0x28(%ecx),%xmm5 .byte 243,15,16,97,44 // movss 0x2c(%ecx),%xmm4 .byte 243,15,89,229 // mulss %xmm5,%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,89,246 // mulps %xmm6,%xmm6 .byte 15,88,240 // addps %xmm0,%xmm6 .byte 232,0,0,0,0 // call 6967 <_sk_xy_to_2pt_conical_quadratic_max_sse2+0x31> .byte 90 // pop %edx .byte 243,15,89,237 // mulss %xmm5,%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,92,245 // subps %xmm5,%xmm6 .byte 243,15,16,65,32 // movss 0x20(%ecx),%xmm0 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 15,89,162,41,26,0,0 // mulps 0x1a29(%edx),%xmm4 .byte 15,89,130,57,26,0,0 // mulps 0x1a39(%edx),%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,89,237 // mulps %xmm5,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,81,237 // sqrtps %xmm5,%xmm5 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,87,162,73,26,0,0 // xorps 0x1a49(%edx),%xmm4 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 243,15,16,105,36 // movss 0x24(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,170,89,26,0,0 // mulps 0x1a59(%edx),%xmm5 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,95,196 // maxps %xmm4,%xmm0 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_xy_to_2pt_conical_quadratic_min_sse2 .globl _sk_xy_to_2pt_conical_quadratic_min_sse2 FUNCTION(_sk_xy_to_2pt_conical_quadratic_min_sse2) _sk_xy_to_2pt_conical_quadratic_min_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 243,15,16,105,40 // movss 0x28(%ecx),%xmm5 .byte 243,15,16,97,44 // movss 0x2c(%ecx),%xmm4 .byte 243,15,89,229 // mulss %xmm5,%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,88,224 // addps %xmm0,%xmm4 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,89,246 // mulps %xmm6,%xmm6 .byte 15,88,240 // addps %xmm0,%xmm6 .byte 232,0,0,0,0 // call 6a05 <_sk_xy_to_2pt_conical_quadratic_min_sse2+0x31> .byte 90 // pop %edx .byte 243,15,89,237 // mulss %xmm5,%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,92,245 // subps %xmm5,%xmm6 .byte 243,15,16,65,32 // movss 0x20(%ecx),%xmm0 .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 .byte 15,89,162,203,25,0,0 // mulps 0x19cb(%edx),%xmm4 .byte 15,89,130,219,25,0,0 // mulps 0x19db(%edx),%xmm0 .byte 15,89,198 // mulps %xmm6,%xmm0 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,89,237 // mulps %xmm5,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,81,237 // sqrtps %xmm5,%xmm5 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,87,162,235,25,0,0 // xorps 0x19eb(%edx),%xmm4 .byte 15,92,229 // subps %xmm5,%xmm4 .byte 243,15,16,105,36 // movss 0x24(%ecx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,89,170,251,25,0,0 // mulps 0x19fb(%edx),%xmm5 .byte 15,89,197 // mulps %xmm5,%xmm0 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,93,196 // minps %xmm4,%xmm0 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_xy_to_2pt_conical_linear_sse2 .globl _sk_xy_to_2pt_conical_linear_sse2 FUNCTION(_sk_xy_to_2pt_conical_linear_sse2) _sk_xy_to_2pt_conical_linear_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 232,0,0,0,0 // call 6a7d <_sk_xy_to_2pt_conical_linear_sse2+0xb> .byte 89 // pop %ecx .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,16 // mov (%eax),%edx .byte 243,15,16,98,40 // movss 0x28(%edx),%xmm4 .byte 243,15,16,106,44 // movss 0x2c(%edx),%xmm5 .byte 243,15,89,236 // mulss %xmm4,%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,88,232 // addps %xmm0,%xmm5 .byte 15,89,169,147,25,0,0 // mulps 0x1993(%ecx),%xmm5 .byte 15,89,192 // mulps %xmm0,%xmm0 .byte 15,40,241 // movaps %xmm1,%xmm6 .byte 15,89,246 // mulps %xmm6,%xmm6 .byte 15,88,198 // addps %xmm6,%xmm0 .byte 243,15,89,228 // mulss %xmm4,%xmm4 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,92,196 // subps %xmm4,%xmm0 .byte 15,87,129,163,25,0,0 // xorps 0x19a3(%ecx),%xmm0 .byte 15,94,197 // divps %xmm5,%xmm0 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_mask_2pt_conical_degenerates_sse2 .globl _sk_mask_2pt_conical_degenerates_sse2 FUNCTION(_sk_mask_2pt_conical_degenerates_sse2) _sk_mask_2pt_conical_degenerates_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,17 // mov (%ecx),%edx .byte 243,15,16,98,40 // movss 0x28(%edx),%xmm4 .byte 243,15,16,106,44 // movss 0x2c(%edx),%xmm5 .byte 15,198,237,0 // shufps $0x0,%xmm5,%xmm5 .byte 15,198,228,0 // shufps $0x0,%xmm4,%xmm4 .byte 15,89,232 // mulps %xmm0,%xmm5 .byte 15,88,236 // addps %xmm4,%xmm5 .byte 15,87,228 // xorps %xmm4,%xmm4 .byte 15,40,240 // movaps %xmm0,%xmm6 .byte 15,194,244,7 // cmpordps %xmm4,%xmm6 .byte 15,194,229,2 // cmpleps %xmm5,%xmm4 .byte 15,84,230 // andps %xmm6,%xmm4 .byte 15,17,34 // movups %xmm4,(%edx) .byte 141,81,8 // lea 0x8(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 80 // push %eax .byte 255,81,4 // call *0x4(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_apply_vector_mask_sse2 .globl _sk_apply_vector_mask_sse2 FUNCTION(_sk_apply_vector_mask_sse2) _sk_apply_vector_mask_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 15,16,33 // movups (%ecx),%xmm4 .byte 15,84,196 // andps %xmm4,%xmm0 .byte 15,84,204 // andps %xmm4,%xmm1 .byte 15,84,212 // andps %xmm4,%xmm2 .byte 15,84,220 // andps %xmm4,%xmm3 .byte 141,72,8 // lea 0x8(%eax),%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 255,117,8 // pushl 0x8(%ebp) .byte 255,80,4 // call *0x4(%eax) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_save_xy_sse2 .globl _sk_save_xy_sse2 FUNCTION(_sk_save_xy_sse2) _sk_save_xy_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,24 // sub $0x18,%esp .byte 15,41,93,232 // movaps %xmm3,-0x18(%ebp) .byte 15,40,218 // movaps %xmm2,%xmm3 .byte 232,0,0,0,0 // call 6b5a <_sk_save_xy_sse2+0x12> .byte 88 // pop %eax .byte 15,40,160,214,24,0,0 // movaps 0x18d6(%eax),%xmm4 .byte 15,40,232 // movaps %xmm0,%xmm5 .byte 15,88,236 // addps %xmm4,%xmm5 .byte 243,15,91,245 // cvttps2dq %xmm5,%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,40,253 // movaps %xmm5,%xmm7 .byte 15,194,254,1 // cmpltps %xmm6,%xmm7 .byte 15,40,144,230,24,0,0 // movaps 0x18e6(%eax),%xmm2 .byte 15,84,250 // andps %xmm2,%xmm7 .byte 15,92,247 // subps %xmm7,%xmm6 .byte 15,92,238 // subps %xmm6,%xmm5 .byte 15,88,225 // addps %xmm1,%xmm4 .byte 243,15,91,244 // cvttps2dq %xmm4,%xmm6 .byte 15,91,246 // cvtdq2ps %xmm6,%xmm6 .byte 15,40,252 // movaps %xmm4,%xmm7 .byte 15,194,254,1 // cmpltps %xmm6,%xmm7 .byte 15,84,250 // andps %xmm2,%xmm7 .byte 15,92,247 // subps %xmm7,%xmm6 .byte 15,92,230 // subps %xmm6,%xmm4 .byte 139,69,12 // mov 0xc(%ebp),%eax .byte 139,8 // mov (%eax),%ecx .byte 15,17,1 // movups %xmm0,(%ecx) .byte 15,17,73,32 // movups %xmm1,0x20(%ecx) .byte 15,17,105,64 // movups %xmm5,0x40(%ecx) .byte 15,17,97,96 // movups %xmm4,0x60(%ecx) .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 141,80,8 // lea 0x8(%eax),%edx .byte 131,236,8 // sub $0x8,%esp .byte 15,40,211 // movaps %xmm3,%xmm2 .byte 15,40,93,232 // movaps -0x18(%ebp),%xmm3 .byte 82 // push %edx .byte 81 // push %ecx .byte 255,80,4 // call *0x4(%eax) .byte 131,196,40 // add $0x28,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_accumulate_sse2 .globl _sk_accumulate_sse2 FUNCTION(_sk_accumulate_sse2) _sk_accumulate_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 131,236,8 // sub $0x8,%esp .byte 139,69,8 // mov 0x8(%ebp),%eax .byte 139,77,12 // mov 0xc(%ebp),%ecx .byte 139,17 // mov (%ecx),%edx .byte 15,16,162,128,0,0,0 // movups 0x80(%edx),%xmm4 .byte 15,16,170,160,0,0,0 // movups 0xa0(%edx),%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,89,224 // mulps %xmm0,%xmm4 .byte 15,88,96,16 // addps 0x10(%eax),%xmm4 .byte 15,41,96,16 // movaps %xmm4,0x10(%eax) .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,89,225 // mulps %xmm1,%xmm4 .byte 15,88,96,32 // addps 0x20(%eax),%xmm4 .byte 15,41,96,32 // movaps %xmm4,0x20(%eax) .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,89,226 // mulps %xmm2,%xmm4 .byte 15,88,96,48 // addps 0x30(%eax),%xmm4 .byte 15,41,96,48 // movaps %xmm4,0x30(%eax) .byte 15,89,235 // mulps %xmm3,%xmm5 .byte 15,88,104,64 // addps 0x40(%eax),%xmm5 .byte 15,41,104,64 // movaps %xmm5,0x40(%eax) .byte 141,81,8 // lea 0x8(%ecx),%edx .byte 131,236,8 // sub $0x8,%esp .byte 82 // push %edx .byte 80 // push %eax .byte 255,81,4 // call *0x4(%ecx) .byte 131,196,24 // add $0x18,%esp .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bilinear_nx_sse2 .globl _sk_bilinear_nx_sse2 FUNCTION(_sk_bilinear_nx_sse2) _sk_bilinear_nx_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6c3c <_sk_bilinear_nx_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,6 // movups (%esi),%xmm0 .byte 15,16,102,64 // movups 0x40(%esi),%xmm4 .byte 15,88,128,20,24,0,0 // addps 0x1814(%eax),%xmm0 .byte 15,40,168,36,24,0,0 // movaps 0x1824(%eax),%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,17,174,128,0,0,0 // movups %xmm5,0x80(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bilinear_px_sse2 .globl _sk_bilinear_px_sse2 FUNCTION(_sk_bilinear_px_sse2) _sk_bilinear_px_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6c7f <_sk_bilinear_px_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,6 // movups (%esi),%xmm0 .byte 15,16,102,64 // movups 0x40(%esi),%xmm4 .byte 15,88,128,241,23,0,0 // addps 0x17f1(%eax),%xmm0 .byte 15,17,166,128,0,0,0 // movups %xmm4,0x80(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bilinear_ny_sse2 .globl _sk_bilinear_ny_sse2 FUNCTION(_sk_bilinear_ny_sse2) _sk_bilinear_ny_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6cb8 <_sk_bilinear_ny_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,78,32 // movups 0x20(%esi),%xmm1 .byte 15,16,102,96 // movups 0x60(%esi),%xmm4 .byte 15,88,136,200,23,0,0 // addps 0x17c8(%eax),%xmm1 .byte 15,40,168,216,23,0,0 // movaps 0x17d8(%eax),%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,17,174,160,0,0,0 // movups %xmm5,0xa0(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bilinear_py_sse2 .globl _sk_bilinear_py_sse2 FUNCTION(_sk_bilinear_py_sse2) _sk_bilinear_py_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6cfc <_sk_bilinear_py_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,78,32 // movups 0x20(%esi),%xmm1 .byte 15,16,102,96 // movups 0x60(%esi),%xmm4 .byte 15,88,136,164,23,0,0 // addps 0x17a4(%eax),%xmm1 .byte 15,17,166,160,0,0,0 // movups %xmm4,0xa0(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bicubic_n3x_sse2 .globl _sk_bicubic_n3x_sse2 FUNCTION(_sk_bicubic_n3x_sse2) _sk_bicubic_n3x_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6d36 <_sk_bicubic_n3x_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,6 // movups (%esi),%xmm0 .byte 15,16,102,64 // movups 0x40(%esi),%xmm4 .byte 15,88,128,122,23,0,0 // addps 0x177a(%eax),%xmm0 .byte 15,40,168,138,23,0,0 // movaps 0x178a(%eax),%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,89,228 // mulps %xmm4,%xmm4 .byte 15,89,168,154,23,0,0 // mulps 0x179a(%eax),%xmm5 .byte 15,88,168,170,23,0,0 // addps 0x17aa(%eax),%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,17,174,128,0,0,0 // movups %xmm5,0x80(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bicubic_n1x_sse2 .globl _sk_bicubic_n1x_sse2 FUNCTION(_sk_bicubic_n1x_sse2) _sk_bicubic_n1x_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6d90 <_sk_bicubic_n1x_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,6 // movups (%esi),%xmm0 .byte 15,16,102,64 // movups 0x40(%esi),%xmm4 .byte 15,88,128,96,23,0,0 // addps 0x1760(%eax),%xmm0 .byte 15,40,168,112,23,0,0 // movaps 0x1770(%eax),%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,40,160,128,23,0,0 // movaps 0x1780(%eax),%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,88,160,144,23,0,0 // addps 0x1790(%eax),%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,88,160,160,23,0,0 // addps 0x17a0(%eax),%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,88,160,176,23,0,0 // addps 0x17b0(%eax),%xmm4 .byte 15,17,166,128,0,0,0 // movups %xmm4,0x80(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bicubic_p1x_sse2 .globl _sk_bicubic_p1x_sse2 FUNCTION(_sk_bicubic_p1x_sse2) _sk_bicubic_p1x_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6df8 <_sk_bicubic_p1x_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,40,160,88,23,0,0 // movaps 0x1758(%eax),%xmm4 .byte 15,16,6 // movups (%esi),%xmm0 .byte 15,16,110,64 // movups 0x40(%esi),%xmm5 .byte 15,88,196 // addps %xmm4,%xmm0 .byte 15,40,176,104,23,0,0 // movaps 0x1768(%eax),%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,176,120,23,0,0 // addps 0x1778(%eax),%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,244 // addps %xmm4,%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,176,136,23,0,0 // addps 0x1788(%eax),%xmm6 .byte 15,17,182,128,0,0,0 // movups %xmm6,0x80(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bicubic_p3x_sse2 .globl _sk_bicubic_p3x_sse2 FUNCTION(_sk_bicubic_p3x_sse2) _sk_bicubic_p3x_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6e55 <_sk_bicubic_p3x_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,6 // movups (%esi),%xmm0 .byte 15,16,102,64 // movups 0x40(%esi),%xmm4 .byte 15,88,128,59,23,0,0 // addps 0x173b(%eax),%xmm0 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,89,237 // mulps %xmm5,%xmm5 .byte 15,89,160,75,23,0,0 // mulps 0x174b(%eax),%xmm4 .byte 15,88,160,91,23,0,0 // addps 0x175b(%eax),%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,17,166,128,0,0,0 // movups %xmm4,0x80(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bicubic_n3y_sse2 .globl _sk_bicubic_n3y_sse2 FUNCTION(_sk_bicubic_n3y_sse2) _sk_bicubic_n3y_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6ea5 <_sk_bicubic_n3y_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,78,32 // movups 0x20(%esi),%xmm1 .byte 15,16,102,96 // movups 0x60(%esi),%xmm4 .byte 15,88,136,27,23,0,0 // addps 0x171b(%eax),%xmm1 .byte 15,40,168,43,23,0,0 // movaps 0x172b(%eax),%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,40,229 // movaps %xmm5,%xmm4 .byte 15,89,228 // mulps %xmm4,%xmm4 .byte 15,89,168,59,23,0,0 // mulps 0x173b(%eax),%xmm5 .byte 15,88,168,75,23,0,0 // addps 0x174b(%eax),%xmm5 .byte 15,89,236 // mulps %xmm4,%xmm5 .byte 15,17,174,160,0,0,0 // movups %xmm5,0xa0(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bicubic_n1y_sse2 .globl _sk_bicubic_n1y_sse2 FUNCTION(_sk_bicubic_n1y_sse2) _sk_bicubic_n1y_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6f00 <_sk_bicubic_n1y_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,78,32 // movups 0x20(%esi),%xmm1 .byte 15,16,102,96 // movups 0x60(%esi),%xmm4 .byte 15,88,136,0,23,0,0 // addps 0x1700(%eax),%xmm1 .byte 15,40,168,16,23,0,0 // movaps 0x1710(%eax),%xmm5 .byte 15,92,236 // subps %xmm4,%xmm5 .byte 15,40,160,32,23,0,0 // movaps 0x1720(%eax),%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,88,160,48,23,0,0 // addps 0x1730(%eax),%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,88,160,64,23,0,0 // addps 0x1740(%eax),%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,88,160,80,23,0,0 // addps 0x1750(%eax),%xmm4 .byte 15,17,166,160,0,0,0 // movups %xmm4,0xa0(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bicubic_p1y_sse2 .globl _sk_bicubic_p1y_sse2 FUNCTION(_sk_bicubic_p1y_sse2) _sk_bicubic_p1y_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6f69 <_sk_bicubic_p1y_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,40,160,247,22,0,0 // movaps 0x16f7(%eax),%xmm4 .byte 15,16,78,32 // movups 0x20(%esi),%xmm1 .byte 15,16,110,96 // movups 0x60(%esi),%xmm5 .byte 15,88,204 // addps %xmm4,%xmm1 .byte 15,40,176,7,23,0,0 // movaps 0x1707(%eax),%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,176,23,23,0,0 // addps 0x1717(%eax),%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,244 // addps %xmm4,%xmm6 .byte 15,89,245 // mulps %xmm5,%xmm6 .byte 15,88,176,39,23,0,0 // addps 0x1727(%eax),%xmm6 .byte 15,17,182,160,0,0,0 // movups %xmm6,0xa0(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_bicubic_p3y_sse2 .globl _sk_bicubic_p3y_sse2 FUNCTION(_sk_bicubic_p3y_sse2) _sk_bicubic_p3y_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 86 // push %esi .byte 80 // push %eax .byte 232,0,0,0,0 // call 6fc7 <_sk_bicubic_p3y_sse2+0xa> .byte 88 // pop %eax .byte 139,77,8 // mov 0x8(%ebp),%ecx .byte 139,85,12 // mov 0xc(%ebp),%edx .byte 139,50 // mov (%edx),%esi .byte 15,16,78,32 // movups 0x20(%esi),%xmm1 .byte 15,16,102,96 // movups 0x60(%esi),%xmm4 .byte 15,88,136,217,22,0,0 // addps 0x16d9(%eax),%xmm1 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,89,237 // mulps %xmm5,%xmm5 .byte 15,89,160,233,22,0,0 // mulps 0x16e9(%eax),%xmm4 .byte 15,88,160,249,22,0,0 // addps 0x16f9(%eax),%xmm4 .byte 15,89,229 // mulps %xmm5,%xmm4 .byte 15,17,166,160,0,0,0 // movups %xmm4,0xa0(%esi) .byte 141,66,8 // lea 0x8(%edx),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 81 // push %ecx .byte 255,82,4 // call *0x4(%edx) .byte 131,196,20 // add $0x14,%esp .byte 94 // pop %esi .byte 93 // pop %ebp .byte 195 // ret HIDDEN _sk_callback_sse2 .globl _sk_callback_sse2 FUNCTION(_sk_callback_sse2) _sk_callback_sse2: .byte 85 // push %ebp .byte 137,229 // mov %esp,%ebp .byte 83 // push %ebx .byte 87 // push %edi .byte 86 // push %esi .byte 131,236,12 // sub $0xc,%esp .byte 139,117,12 // mov 0xc(%ebp),%esi .byte 139,125,8 // mov 0x8(%ebp),%edi .byte 139,71,8 // mov 0x8(%edi),%eax .byte 139,30 // mov (%esi),%ebx .byte 15,40,224 // movaps %xmm0,%xmm4 .byte 15,20,225 // unpcklps %xmm1,%xmm4 .byte 15,40,234 // movaps %xmm2,%xmm5 .byte 15,20,235 // unpcklps %xmm3,%xmm5 .byte 15,21,193 // unpckhps %xmm1,%xmm0 .byte 15,21,211 // unpckhps %xmm3,%xmm2 .byte 15,40,204 // movaps %xmm4,%xmm1 .byte 102,15,20,205 // unpcklpd %xmm5,%xmm1 .byte 15,18,236 // movhlps %xmm4,%xmm5 .byte 15,40,216 // movaps %xmm0,%xmm3 .byte 102,15,20,218 // unpcklpd %xmm2,%xmm3 .byte 102,15,17,75,4 // movupd %xmm1,0x4(%ebx) .byte 15,18,208 // movhlps %xmm0,%xmm2 .byte 15,17,107,20 // movups %xmm5,0x14(%ebx) .byte 102,15,17,91,36 // movupd %xmm3,0x24(%ebx) .byte 15,17,83,52 // movups %xmm2,0x34(%ebx) .byte 133,192 // test %eax,%eax .byte 185,4,0,0,0 // mov $0x4,%ecx .byte 15,69,200 // cmovne %eax,%ecx .byte 131,236,8 // sub $0x8,%esp .byte 81 // push %ecx .byte 83 // push %ebx .byte 255,19 // call *(%ebx) .byte 131,196,16 // add $0x10,%esp .byte 139,131,132,0,0,0 // mov 0x84(%ebx),%eax .byte 15,16,32 // movups (%eax),%xmm4 .byte 15,16,64,16 // movups 0x10(%eax),%xmm0 .byte 15,16,88,32 // movups 0x20(%eax),%xmm3 .byte 15,16,80,48 // movups 0x30(%eax),%xmm2 .byte 15,40,236 // movaps %xmm4,%xmm5 .byte 15,20,232 // unpcklps %xmm0,%xmm5 .byte 15,40,203 // movaps %xmm3,%xmm1 .byte 15,20,202 // unpcklps %xmm2,%xmm1 .byte 15,21,224 // unpckhps %xmm0,%xmm4 .byte 15,21,218 // unpckhps %xmm2,%xmm3 .byte 15,40,197 // movaps %xmm5,%xmm0 .byte 102,15,20,193 // unpcklpd %xmm1,%xmm0 .byte 15,18,205 // movhlps %xmm5,%xmm1 .byte 15,40,212 // movaps %xmm4,%xmm2 .byte 102,15,20,211 // unpcklpd %xmm3,%xmm2 .byte 15,18,220 // movhlps %xmm4,%xmm3 .byte 141,70,8 // lea 0x8(%esi),%eax .byte 131,236,8 // sub $0x8,%esp .byte 80 // push %eax .byte 87 // push %edi .byte 255,86,4 // call *0x4(%esi) .byte 131,196,28 // add $0x1c,%esp .byte 94 // pop %esi .byte 95 // pop %edi .byte 91 // pop %ebx .byte 93 // pop %ebp .byte 195 // ret BALIGN16 .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,1 // cmpb $0x1,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,1 // add %al,(%ecx) .byte 0,0 // add %al,(%eax) .byte 0,1 // add %al,(%ecx) .byte 0,0 // add %al,(%eax) .byte 0,1 // add %al,(%ecx) .byte 0,0 // add %al,(%eax) .byte 0,4,0 // add %al,(%eax,%eax,1) .byte 0,0 // add %al,(%eax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%eax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%eax) .byte 4,0 // add $0x0,%al .byte 0,0 // add %al,(%eax) .byte 2,0 // add (%eax),%al .byte 0,0 // add %al,(%eax) .byte 2,0 // add (%eax),%al .byte 0,0 // add %al,(%eax) .byte 2,0 // add (%eax),%al .byte 0,0 // add %al,(%eax) .byte 2,0 // add (%eax),%al .byte 0,0 // add %al,(%eax) .byte 0,0 // add %al,(%eax) .byte 128,60,0,0 // cmpb $0x0,(%eax,%eax,1) .byte 128,60,0,0 // cmpb $0x0,(%eax,%eax,1) .byte 128,60,0,0 // cmpb $0x0,(%eax,%eax,1) .byte 128,60,0,0 // cmpb $0x0,(%eax,%eax,1) .byte 252 // cld .byte 190,0,0,252,190 // mov $0xbefc0000,%esi .byte 0,0 // add %al,(%eax) .byte 252 // cld .byte 190,0,0,252,190 // mov $0xbefc0000,%esi .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,191,0,0,128 // add %al,-0x7fffff41(%eax) .byte 191,0,0,128,191 // mov $0xbf800000,%edi .byte 0,0 // add %al,(%eax) .byte 128,191,0,0,224,64,0 // cmpb $0x0,0x40e00000(%edi) .byte 0,224 // add %ah,%al .byte 64 // inc %eax .byte 0,0 // add %al,(%eax) .byte 224,64 // loopne 72bc <.literal16+0x1fc> .byte 0,0 // add %al,(%eax) .byte 224,64 // loopne 72c0 <.literal16+0x200> .byte 154,153,153,62,154,153,153 // lcall $0x9999,$0x9a3e9999 .byte 62,154,153,153,62,154,153,153 // ds lcall $0x9999,$0x9a3e9999 .byte 62,61,10,23,63,61 // ds cmp $0x3d3f170a,%eax .byte 10,23 // or (%edi),%dl .byte 63 // aas .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%edi),%dl .byte 63 // aas .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 72e1 <.literal16+0x221> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 72e5 <.literal16+0x225> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 72e9 <.literal16+0x229> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 72ed <.literal16+0x22d> .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,154 // cmpb $0x9a,(%edi) .byte 153 // cltd .byte 153 // cltd .byte 62,154,153,153,62,154,153,153 // ds lcall $0x9999,$0x9a3e9999 .byte 62,154,153,153,62,61,10,23 // ds lcall $0x170a,$0x3d3e9999 .byte 63 // aas .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%edi),%dl .byte 63 // aas .byte 61,10,23,63,174 // cmp $0xae3f170a,%eax .byte 71 // inc %edi .byte 225,61 // loope 7321 <.literal16+0x261> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 7325 <.literal16+0x265> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 7329 <.literal16+0x269> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 732d <.literal16+0x26d> .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,154 // cmpb $0x9a,(%edi) .byte 153 // cltd .byte 153 // cltd .byte 62,154,153,153,62,154,153,153 // ds lcall $0x9999,$0x9a3e9999 .byte 62,154,153,153,62,61,10,23 // ds lcall $0x170a,$0x3d3e9999 .byte 63 // aas .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%edi),%dl .byte 63 // aas .byte 61,10,23,63,174 // cmp $0xae3f170a,%eax .byte 71 // inc %edi .byte 225,61 // loope 7361 <.literal16+0x2a1> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 7365 <.literal16+0x2a5> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 7369 <.literal16+0x2a9> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 736d <.literal16+0x2ad> .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,154 // cmpb $0x9a,(%edi) .byte 153 // cltd .byte 153 // cltd .byte 62,154,153,153,62,154,153,153 // ds lcall $0x9999,$0x9a3e9999 .byte 62,154,153,153,62,61,10,23 // ds lcall $0x170a,$0x3d3e9999 .byte 63 // aas .byte 61,10,23,63,61 // cmp $0x3d3f170a,%eax .byte 10,23 // or (%edi),%dl .byte 63 // aas .byte 61,10,23,63,174 // cmp $0xae3f170a,%eax .byte 71 // inc %edi .byte 225,61 // loope 73a1 <.literal16+0x2e1> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 73a5 <.literal16+0x2e5> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 73a9 <.literal16+0x2e9> .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 225,61 // loope 73ad <.literal16+0x2ed> .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,255 // cmpb $0xff,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%eax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%eax) .byte 0,255 // add %bh,%bh .byte 0,0 // add %al,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,127 // add %al,0x7f00003f(%eax) .byte 67 // inc %ebx .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 73eb <.literal16+0x32b> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 73ef <.literal16+0x32f> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 73f3 <.literal16+0x333> .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,145,131,158 // add %al,-0x617c6ec1(%eax) .byte 61,145,131,158,61 // cmp $0x3d9e8391,%eax .byte 145 // xchg %eax,%ecx .byte 131,158,61,145,131,158,61 // sbbl $0x3d,-0x617c6ec3(%esi) .byte 154,153,153,62,154,153,153 // lcall $0x9999,$0x9a3e9999 .byte 62,154,153,153,62,154,153,153 // ds lcall $0x9999,$0x9a3e9999 .byte 62,92 // ds pop %esp .byte 143 // (bad) .byte 50,63 // xor (%edi),%bh .byte 92 // pop %esp .byte 143 // (bad) .byte 50,63 // xor (%edi),%bh .byte 92 // pop %esp .byte 143 // (bad) .byte 50,63 // xor (%edi),%bh .byte 92 // pop %esp .byte 143 // (bad) .byte 50,63 // xor (%edi),%bh .byte 10,215 // or %bh,%dl .byte 35,59 // and (%ebx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%ebx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%ebx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%ebx),%edi .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 97 // popa .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 97 // popa .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 145 // xchg %eax,%ecx .byte 131,158,61,145,131,158,61 // sbbl $0x3d,-0x617c6ec3(%esi) .byte 145 // xchg %eax,%ecx .byte 131,158,61,145,131,158,61 // sbbl $0x3d,-0x617c6ec3(%esi) .byte 154,153,153,62,154,153,153 // lcall $0x9999,$0x9a3e9999 .byte 62,154,153,153,62,154,153,153 // ds lcall $0x9999,$0x9a3e9999 .byte 62,92 // ds pop %esp .byte 143 // (bad) .byte 50,63 // xor (%edi),%bh .byte 92 // pop %esp .byte 143 // (bad) .byte 50,63 // xor (%edi),%bh .byte 92 // pop %esp .byte 143 // (bad) .byte 50,63 // xor (%edi),%bh .byte 92 // pop %esp .byte 143 // (bad) .byte 50,63 // xor (%edi),%bh .byte 10,215 // or %bh,%dl .byte 35,59 // and (%ebx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%ebx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%ebx),%edi .byte 10,215 // or %bh,%dl .byte 35,59 // and (%ebx),%edi .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 97 // popa .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 174 // scas %es:(%edi),%al .byte 71 // inc %edi .byte 97 // popa .byte 61,174,71,97,61 // cmp $0x3d6147ae,%eax .byte 82 // push %edx .byte 184,78,65,82,184 // mov $0xb852414e,%eax .byte 78 // dec %esi .byte 65 // inc %ecx .byte 82 // push %edx .byte 184,78,65,82,184 // mov $0xb852414e,%eax .byte 78 // dec %esi .byte 65 // inc %ecx .byte 57,215 // cmp %edx,%edi .byte 32,187,57,215,32,187 // and %bh,-0x44df28c7(%ebx) .byte 57,215 // cmp %edx,%edi .byte 32,187,57,215,32,187 // and %bh,-0x44df28c7(%ebx) .byte 186,159,98,60,186 // mov $0xba3c629f,%edx .byte 159 // lahf .byte 98,60,186 // bound %edi,(%edx,%edi,4) .byte 159 // lahf .byte 98,60,186 // bound %edi,(%edx,%edi,4) .byte 159 // lahf .byte 98,60,109,165,144,63,109 // bound %edi,0x6d3f90a5(,%ebp,2) .byte 165 // movsl %ds:(%esi),%es:(%edi) .byte 144 // nop .byte 63 // aas .byte 109 // insl (%dx),%es:(%edi) .byte 165 // movsl %ds:(%esi),%es:(%edi) .byte 144 // nop .byte 63 // aas .byte 109 // insl (%dx),%es:(%edi) .byte 165 // movsl %ds:(%esi),%es:(%edi) .byte 144 // nop .byte 63 // aas .byte 252 // cld .byte 191,16,62,252,191 // mov $0xbffc3e10,%edi .byte 16,62 // adc %bh,(%esi) .byte 252 // cld .byte 191,16,62,252,191 // mov $0xbffc3e10,%edi .byte 16,62 // adc %bh,(%esi) .byte 168,177 // test $0xb1,%al .byte 152 // cwtl .byte 59,168,177,152,59,168 // cmp -0x57c4674f(%eax),%ebp .byte 177,152 // mov $0x98,%cl .byte 59,168,177,152,59,0 // cmp 0x3b98b1(%eax),%ebp .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,192 // add %al,-0x3fffffc1(%eax) .byte 64 // inc %eax .byte 0,0 // add %al,(%eax) .byte 192,64,0,0 // rolb $0x0,0x0(%eax) .byte 192,64,0,0 // rolb $0x0,0x0(%eax) .byte 192,64,0,0 // rolb $0x0,0x0(%eax) .byte 0,64,0 // add %al,0x0(%eax) .byte 0,0 // add %al,(%eax) .byte 64 // inc %eax .byte 0,0 // add %al,(%eax) .byte 0,64,0 // add %al,0x0(%eax) .byte 0,0 // add %al,(%eax) .byte 64 // inc %eax .byte 0,0 // add %al,(%eax) .byte 128,64,0,0 // addb $0x0,0x0(%eax) .byte 128,64,0,0 // addb $0x0,0x0(%eax) .byte 128,64,0,0 // addb $0x0,0x0(%eax) .byte 128,64,171,170 // addb $0xaa,-0x55(%eax) .byte 42,62 // sub (%esi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,62 // sub (%esi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,62 // sub (%esi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,62 // sub (%esi),%bh .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 62,171 // ds stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 62,171 // ds stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 62,171 // ds stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 62,0,0 // add %al,%ds:(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,171 // cmpb $0xab,(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,63 // sub (%edi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,63 // sub (%edi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,63 // sub (%edi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,63 // sub (%edi),%bh .byte 0,0 // add %al,(%eax) .byte 192,64,0,0 // rolb $0x0,0x0(%eax) .byte 192,64,0,0 // rolb $0x0,0x0(%eax) .byte 192,64,0,0 // rolb $0x0,0x0(%eax) .byte 192,64,0,0 // rolb $0x0,0x0(%eax) .byte 128,64,0,0 // addb $0x0,0x0(%eax) .byte 128,64,0,0 // addb $0x0,0x0(%eax) .byte 128,64,0,0 // addb $0x0,0x0(%eax) .byte 128,64,171,170 // addb $0xaa,-0x55(%eax) .byte 42,62 // sub (%esi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,62 // sub (%esi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,62 // sub (%esi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 42,62 // sub (%esi),%bh .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,0,248,0,0 // addb $0x0,0xf8003b(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 224,7 // loopne 7649 <.literal16+0x589> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 764d <.literal16+0x58d> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7651 <.literal16+0x591> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7655 <.literal16+0x595> .byte 0,0 // add %al,(%eax) .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 31 // pop %ds .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,8 // add %cl,(%eax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%edi,1) .byte 8,33 // or %ah,(%ecx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%ecx) .byte 4,61 // add $0x3d,%al .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,128,0,128,55 // addb $0x37,-0x7fff7fc5(%eax) .byte 128,0,128 // addb $0x80,(%eax) .byte 55 // aaa .byte 128,0,128 // addb $0x80,(%eax) .byte 55 // aaa .byte 128,0,128 // addb $0x80,(%eax) .byte 55 // aaa .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,127,67 // add %bh,0x43(%edi) .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 770b <.literal16+0x64b> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 770f <.literal16+0x64f> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 7713 <.literal16+0x653> .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,129,128,128,59 // addb $0x3b,-0x7f7f7ec5(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,0 // cmpb $0x0,(%ebx) .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 7704 <.literal16+0x644> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 7708 <.literal16+0x648> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 770c <.literal16+0x64c> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 7710 <.literal16+0x650> .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 119,115 // ja 7795 <.literal16+0x6d5> .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,117,191 // ret $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 117,191 // jne 76f9 <.literal16+0x639> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 163,233,220,63,163 // mov %eax,0xa33fdce9 .byte 233,220,63,163,233 // jmp e9a3b736 <_sk_callback_sse2+0xe9a34728> .byte 220,63 // fdivrl (%edi) .byte 163,233,220,63,0 // mov %eax,0x3fdce9 .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,81,140,242 // add %al,-0xd73aec1(%eax) .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 248 // clc .byte 245 // cmc .byte 154,64,248,245,154,64,248 // lcall $0xf840,$0x9af5f840 .byte 245 // cmc .byte 154,64,248,245,154,64,254 // lcall $0xfe40,$0x9af5f840 .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,52,0 // add %dh,(%eax,%eax,1) .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 77d4 <.literal16+0x714> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 77d8 <.literal16+0x718> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 77dc <.literal16+0x71c> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 77e0 <.literal16+0x720> .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 119,115 // ja 7865 <.literal16+0x7a5> .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,117,191 // ret $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 117,191 // jne 77c9 <.literal16+0x709> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 163,233,220,63,163 // mov %eax,0xa33fdce9 .byte 233,220,63,163,233 // jmp e9a3b806 <_sk_callback_sse2+0xe9a347f8> .byte 220,63 // fdivrl (%edi) .byte 163,233,220,63,0 // mov %eax,0x3fdce9 .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,81,140,242 // add %al,-0xd73aec1(%eax) .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 248 // clc .byte 245 // cmc .byte 154,64,248,245,154,64,248 // lcall $0xf840,$0x9af5f840 .byte 245 // cmc .byte 154,64,248,245,154,64,254 // lcall $0xfe40,$0x9af5f840 .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,52,0 // add %dh,(%eax,%eax,1) .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 78a4 <.literal16+0x7e4> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 78a8 <.literal16+0x7e8> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 78ac <.literal16+0x7ec> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 78b0 <.literal16+0x7f0> .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 119,115 // ja 7935 <.literal16+0x875> .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,117,191 // ret $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 117,191 // jne 7899 <.literal16+0x7d9> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 163,233,220,63,163 // mov %eax,0xa33fdce9 .byte 233,220,63,163,233 // jmp e9a3b8d6 <_sk_callback_sse2+0xe9a348c8> .byte 220,63 // fdivrl (%edi) .byte 163,233,220,63,0 // mov %eax,0x3fdce9 .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,81,140,242 // add %al,-0xd73aec1(%eax) .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 248 // clc .byte 245 // cmc .byte 154,64,248,245,154,64,248 // lcall $0xf840,$0x9af5f840 .byte 245 // cmc .byte 154,64,248,245,154,64,254 // lcall $0xfe40,$0x9af5f840 .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,52,0 // add %dh,(%eax,%eax,1) .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 7974 <.literal16+0x8b4> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 7978 <.literal16+0x8b8> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 797c <.literal16+0x8bc> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 7980 <.literal16+0x8c0> .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 119,115 // ja 7a05 <.literal16+0x945> .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,117,191 // ret $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 117,191 // jne 7969 <.literal16+0x8a9> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 163,233,220,63,163 // mov %eax,0xa33fdce9 .byte 233,220,63,163,233 // jmp e9a3b9a6 <_sk_callback_sse2+0xe9a34998> .byte 220,63 // fdivrl (%edi) .byte 163,233,220,63,0 // mov %eax,0x3fdce9 .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,81,140,242 // add %al,-0xd73aec1(%eax) .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 248 // clc .byte 245 // cmc .byte 154,64,248,245,154,64,248 // lcall $0xf840,$0x9af5f840 .byte 245 // cmc .byte 154,64,248,245,154,64,254 // lcall $0xfe40,$0x9af5f840 .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,52,0 // add %dh,(%eax,%eax,1) .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,0 // xor $0x0,%al .byte 0,0 // add %al,(%eax) .byte 52,255 // xor $0xff,%al .byte 255 // (bad) .byte 127,0 // jg 7a44 <.literal16+0x984> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 7a48 <.literal16+0x988> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 7a4c <.literal16+0x98c> .byte 255 // (bad) .byte 255 // (bad) .byte 127,0 // jg 7a50 <.literal16+0x990> .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 119,115 // ja 7ad5 <.literal16+0xa15> .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,119,115 // ret $0x7377 .byte 248 // clc .byte 194,117,191 // ret $0xbf75 .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 117,191 // jne 7a39 <.literal16+0x979> .byte 191,63,117,191,191 // mov $0xbfbf753f,%edi .byte 63 // aas .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 249 // stc .byte 68 // inc %esp .byte 180,62 // mov $0x3e,%ah .byte 163,233,220,63,163 // mov %eax,0xa33fdce9 .byte 233,220,63,163,233 // jmp e9a3ba76 <_sk_callback_sse2+0xe9a34a68> .byte 220,63 // fdivrl (%edi) .byte 163,233,220,63,0 // mov %eax,0x3fdce9 .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,81,140,242 // add %al,-0xd73aec1(%eax) .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 81 // push %ecx .byte 140,242 // mov %?,%edx .byte 66 // inc %edx .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 141,188,190,63,141,188,190 // lea -0x414372c1(%esi,%edi,4),%edi .byte 63 // aas .byte 248 // clc .byte 245 // cmc .byte 154,64,248,245,154,64,248 // lcall $0xf840,$0x9af5f840 .byte 245 // cmc .byte 154,64,248,245,154,64,254 // lcall $0xfe40,$0x9af5f840 .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 254 // (bad) .byte 210,221 // rcr %cl,%ch .byte 65 // inc %ecx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 200,66,0,0 // enter $0x42,$0x0 .byte 200,66,0,0 // enter $0x42,$0x0 .byte 200,66,0,0 // enter $0x42,$0x0 .byte 200,66,0,0 // enter $0x42,$0x0 .byte 127,67 // jg 7b57 <.literal16+0xa97> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 7b5b <.literal16+0xa9b> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 7b5f <.literal16+0xa9f> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 7b63 <.literal16+0xaa3> .byte 0,0 // add %al,(%eax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%eax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%eax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%eax) .byte 0,195 // add %al,%bl .byte 0,0 // add %al,(%eax) .byte 128,65,0,0 // addb $0x0,0x0(%ecx) .byte 128,65,0,0 // addb $0x0,0x0(%ecx) .byte 128,65,0,0 // addb $0x0,0x0(%ecx) .byte 128,65,203,61 // addb $0x3d,-0x35(%ecx) .byte 13,60,203,61,13 // or $0xd3dcb3c,%eax .byte 60,203 // cmp $0xcb,%al .byte 61,13,60,203,61 // cmp $0x3dcb3c0d,%eax .byte 13,60,111,18,3 // or $0x3126f3c,%eax .byte 59,111,18 // cmp 0x12(%edi),%ebp .byte 3,59 // add (%ebx),%edi .byte 111 // outsl %ds:(%esi),(%dx) .byte 18,3 // adc (%ebx),%al .byte 59,111,18 // cmp 0x12(%edi),%ebp .byte 3,59 // add (%ebx),%edi .byte 10,215 // or %bh,%dl .byte 163,59,10,215,163 // mov %eax,0xa3d70a3b .byte 59,10 // cmp (%edx),%ecx .byte 215 // xlat %ds:(%ebx) .byte 163,59,10,215,163 // mov %eax,0xa3d70a3b .byte 59,194 // cmp %edx,%eax .byte 24,17 // sbb %dl,(%ecx) .byte 60,194 // cmp $0xc2,%al .byte 24,17 // sbb %dl,(%ecx) .byte 60,194 // cmp $0xc2,%al .byte 24,17 // sbb %dl,(%ecx) .byte 60,194 // cmp $0xc2,%al .byte 24,17 // sbb %dl,(%ecx) .byte 60,203 // cmp $0xcb,%al .byte 61,13,190,203,61 // cmp $0x3dcbbe0d,%eax .byte 13,190,203,61,13 // or $0xd3dcbbe,%eax .byte 190,203,61,13,190 // mov $0xbe0d3dcb,%esi .byte 80 // push %eax .byte 128,3,62 // addb $0x3e,(%ebx) .byte 80 // push %eax .byte 128,3,62 // addb $0x3e,(%ebx) .byte 80 // push %eax .byte 128,3,62 // addb $0x3e,(%ebx) .byte 80 // push %eax .byte 128,3,62 // addb $0x3e,(%ebx) .byte 31 // pop %ds .byte 215 // xlat %ds:(%ebx) .byte 118,63 // jbe 7be3 <.literal16+0xb23> .byte 31 // pop %ds .byte 215 // xlat %ds:(%ebx) .byte 118,63 // jbe 7be7 <.literal16+0xb27> .byte 31 // pop %ds .byte 215 // xlat %ds:(%ebx) .byte 118,63 // jbe 7beb <.literal16+0xb2b> .byte 31 // pop %ds .byte 215 // xlat %ds:(%ebx) .byte 118,63 // jbe 7bef <.literal16+0xb2f> .byte 246,64,83,63 // testb $0x3f,0x53(%eax) .byte 246,64,83,63 // testb $0x3f,0x53(%eax) .byte 246,64,83,63 // testb $0x3f,0x53(%eax) .byte 246,64,83,63 // testb $0x3f,0x53(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,129,128,128,59 // addb $0x3b,-0x7f7f7ec5(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,0 // cmpb $0x0,(%ebx) .byte 0,127,67 // add %bh,0x43(%edi) .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 7c5b <.literal16+0xb9b> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 7c5f <.literal16+0xb9f> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 7c63 <.literal16+0xba3> .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,0,0,128,63 // addb $0x3f,-0x7fffffc5(%eax) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,0,0,128,63 // addb $0x3f,-0x7fffffc5(%eax) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,0,0,128,63 // addb $0x3f,-0x7fffffc5(%eax) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 224,7 // loopne 7cd9 <.literal16+0xc19> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7cdd <.literal16+0xc1d> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7ce1 <.literal16+0xc21> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7ce5 <.literal16+0xc25> .byte 0,0 // add %al,(%eax) .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 31 // pop %ds .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,8 // add %cl,(%eax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%edi,1) .byte 8,33 // or %ah,(%ecx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%ecx) .byte 4,61 // add $0x3d,%al .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 248 // clc .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 224,7 // loopne 7d49 <.literal16+0xc89> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7d4d <.literal16+0xc8d> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7d51 <.literal16+0xc91> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7d55 <.literal16+0xc95> .byte 0,0 // add %al,(%eax) .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 31 // pop %ds .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,8 // add %cl,(%eax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%edi,1) .byte 8,33 // or %ah,(%ecx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%ecx) .byte 4,61 // add $0x3d,%al .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 248 // clc .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 0,248 // add %bh,%al .byte 0,0 // add %al,(%eax) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 8,33 // or %ah,(%ecx) .byte 132,55 // test %dh,(%edi) .byte 224,7 // loopne 7db9 <.literal16+0xcf9> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7dbd <.literal16+0xcfd> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7dc1 <.literal16+0xd01> .byte 0,0 // add %al,(%eax) .byte 224,7 // loopne 7dc5 <.literal16+0xd05> .byte 0,0 // add %al,(%eax) .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 33,8 // and %ecx,(%eax) .byte 2,58 // add (%edx),%bh .byte 31 // pop %ds .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,31 // add %bl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,8 // add %cl,(%eax) .byte 33,4,61,8,33,4,61 // and %eax,0x3d042108(,%edi,1) .byte 8,33 // or %ah,(%ecx) .byte 4,61 // add $0x3d,%al .byte 8,33 // or %ah,(%ecx) .byte 4,61 // add $0x3d,%al .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,248 // add %bh,%al .byte 65 // inc %ecx .byte 0,0 // add %al,(%eax) .byte 248 // clc .byte 65 // inc %ecx .byte 0,0 // add %al,(%eax) .byte 248 // clc .byte 65 // inc %ecx .byte 0,0 // add %al,(%eax) .byte 248 // clc .byte 65 // inc %ecx .byte 0,0 // add %al,(%eax) .byte 124,66 // jl 7e56 <.literal16+0xd96> .byte 0,0 // add %al,(%eax) .byte 124,66 // jl 7e5a <.literal16+0xd9a> .byte 0,0 // add %al,(%eax) .byte 124,66 // jl 7e5e <.literal16+0xd9e> .byte 0,0 // add %al,(%eax) .byte 124,66 // jl 7e62 <.literal16+0xda2> .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%eax) .byte 136,55 // mov %dh,(%edi) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%eax) .byte 136,55 // mov %dh,(%edi) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%eax) .byte 136,57 // mov %bh,(%ecx) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%eax) .byte 136,57 // mov %bh,(%ecx) .byte 240,0,0 // lock add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,137,136,136,59,137 // add %cl,-0x76c47778(%ecx) .byte 136,136,59,137,136,136 // mov %cl,-0x777776c5(%eax) .byte 59,137,136,136,59,15 // cmp 0xf3b8888(%ecx),%ecx .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,137,136,136,61,137 // add %cl,-0x76c27778(%ecx) .byte 136,136,61,137,136,136 // mov %cl,-0x777776c3(%eax) .byte 61,137,136,136,61 // cmp $0x3d888889,%eax .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%eax) .byte 136,55 // mov %dh,(%edi) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%eax) .byte 136,55 // mov %dh,(%edi) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%eax) .byte 136,57 // mov %bh,(%ecx) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%eax) .byte 136,57 // mov %bh,(%ecx) .byte 240,0,0 // lock add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,137,136,136,59,137 // add %cl,-0x76c47778(%ecx) .byte 136,136,59,137,136,136 // mov %cl,-0x777776c5(%eax) .byte 59,137,136,136,59,15 // cmp 0xf3b8888(%ecx),%ecx .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,137,136,136,61,137 // add %cl,-0x76c27778(%ecx) .byte 136,136,61,137,136,136 // mov %cl,-0x777776c3(%eax) .byte 61,137,136,136,61 // cmp $0x3d888889,%eax .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%eax) .byte 136,55 // mov %dh,(%edi) .byte 137,136,136,55,137,136 // mov %ecx,-0x7776c878(%eax) .byte 136,55 // mov %dh,(%edi) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%eax) .byte 136,57 // mov %bh,(%ecx) .byte 137,136,136,57,137,136 // mov %ecx,-0x7776c678(%eax) .byte 136,57 // mov %bh,(%ecx) .byte 240,0,0 // lock add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,240 // add %dh,%al .byte 0,0 // add %al,(%eax) .byte 0,137,136,136,59,137 // add %cl,-0x76c47778(%ecx) .byte 136,136,59,137,136,136 // mov %cl,-0x777776c5(%eax) .byte 59,137,136,136,59,15 // cmp 0xf3b8888(%ecx),%ecx .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,15 // add %cl,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,137,136,136,61,137 // add %cl,-0x76c27778(%ecx) .byte 136,136,61,137,136,136 // mov %cl,-0x777776c3(%eax) .byte 61,137,136,136,61 // cmp $0x3d888889,%eax .byte 0,0 // add %al,(%eax) .byte 112,65 // jo 7fe5 <.literal16+0xf25> .byte 0,0 // add %al,(%eax) .byte 112,65 // jo 7fe9 <.literal16+0xf29> .byte 0,0 // add %al,(%eax) .byte 112,65 // jo 7fed <.literal16+0xf2d> .byte 0,0 // add %al,(%eax) .byte 112,65 // jo 7ff1 <.literal16+0xf31> .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,0,0,127,67 // addb $0x43,0x7f00003b(%eax) .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 805b <.literal16+0xf9b> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 805f <.literal16+0xf9f> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 8063 <.literal16+0xfa3> .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,255,0,0,0 // addb $0x0,0xff3b(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 129,128,128,59,129,128,128,59,129,128// addl $0x80813b80,-0x7f7ec480(%eax) .byte 128,59,129 // cmpb $0x81,(%ebx) .byte 128,128,59,0,0,127,67 // addb $0x43,0x7f00003b(%eax) .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 80cb <.literal16+0x100b> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 80cf <.literal16+0x100f> .byte 0,0 // add %al,(%eax) .byte 127,67 // jg 80d3 <.literal16+0x1013> .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,4,0 // add %al,(%eax,%eax,1) .byte 128,0,4 // addb $0x4,(%eax) .byte 0,128,0,4,0,128 // add %al,-0x7ffffc00(%eax) .byte 0,4,0 // add %al,(%eax,%eax,1) .byte 128,0,128 // addb $0x80,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,0 // add %al,0x0(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,4,0 // add %al,(%eax,%eax,1) .byte 128,0,4 // addb $0x4,(%eax) .byte 0,128,0,4,0,128 // add %al,-0x7ffffc00(%eax) .byte 0,4,0 // add %al,(%eax,%eax,1) .byte 128,0,128 // addb $0x80,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,0 // add %al,0x0(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,56 // add %bh,(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,4,0 // add %al,(%eax,%eax,1) .byte 128,0,4 // addb $0x4,(%eax) .byte 0,128,0,4,0,128 // add %al,-0x7ffffc00(%eax) .byte 0,4,0 // add %al,(%eax,%eax,1) .byte 128,0,0 // addb $0x0,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 128,56,0 // cmpb $0x0,(%eax) .byte 0,128,56,0,0,128 // add %al,-0x7fffffc8(%eax) .byte 56,0 // cmp %al,(%eax) .byte 0,128,56,0,64,254 // add %al,-0x1bfffc8(%eax) .byte 255,0 // incl (%eax) .byte 64 // inc %eax .byte 254 // (bad) .byte 255,0 // incl (%eax) .byte 64 // inc %eax .byte 254 // (bad) .byte 255,0 // incl (%eax) .byte 64 // inc %eax .byte 254 // (bad) .byte 255,128,0,128,55,128 // incl -0x7fc88000(%eax) .byte 0,128,55,128,0,128 // add %al,-0x7fff7fc9(%eax) .byte 55 // aaa .byte 128,0,128 // addb $0x80,(%eax) .byte 55 // aaa .byte 128,0,128 // addb $0x80,(%eax) .byte 55 // aaa .byte 128,0,128 // addb $0x80,(%eax) .byte 55 // aaa .byte 128,0,128 // addb $0x80,(%eax) .byte 55 // aaa .byte 128,0,128 // addb $0x80,(%eax) .byte 55 // aaa .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 255 // (bad) .byte 127,71 // jg 81fb <.literal16+0x113b> .byte 0,255 // add %bh,%bh .byte 127,71 // jg 81ff <.literal16+0x113f> .byte 0,255 // add %bh,%bh .byte 127,71 // jg 8203 <.literal16+0x1143> .byte 0,255 // add %bh,%bh .byte 127,71 // jg 8207 <.literal16+0x1147> .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,191,0,0,128,191,0 // cmpb $0x0,-0x40800000(%edi) .byte 0,128,191,0,0,128 // add %al,-0x7fffff41(%eax) .byte 191,0,0,0,63 // mov $0x3f000000,%edi .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,208 // cmpb $0xd0,(%edi) .byte 179,89 // mov $0x59,%bl .byte 62,208 // ds (bad) .byte 179,89 // mov $0x59,%bl .byte 62,208 // ds (bad) .byte 179,89 // mov $0x59,%bl .byte 62,208 // ds (bad) .byte 179,89 // mov $0x59,%bl .byte 62,89 // ds pop %ecx .byte 23 // pop %ss .byte 55 // aaa .byte 63 // aas .byte 89 // pop %ecx .byte 23 // pop %ss .byte 55 // aaa .byte 63 // aas .byte 89 // pop %ecx .byte 23 // pop %ss .byte 55 // aaa .byte 63 // aas .byte 89 // pop %ecx .byte 23 // pop %ss .byte 55 // aaa .byte 63 // aas .byte 152 // cwtl .byte 221,147,61,152,221,147 // fstl -0x6c2267c3(%ebx) .byte 61,152,221,147,61 // cmp $0x3d93dd98,%eax .byte 152 // cwtl .byte 221,147,61,255,255,0 // fstl 0xffff3d(%ebx) .byte 0,255 // add %bh,%bh .byte 255,0 // incl (%eax) .byte 0,255 // add %bh,%bh .byte 255,0 // incl (%eax) .byte 0,255 // add %bh,%bh .byte 255,0 // incl (%eax) .byte 0,0 // add %al,(%eax) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 75 // dec %ebx .byte 0,0 // add %al,(%eax) .byte 0,75,0 // add %cl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 83 // push %ebx .byte 0,0 // add %al,(%eax) .byte 0,83,0 // add %dl,0x0(%ebx) .byte 0,0 // add %al,(%eax) .byte 83 // push %ebx .byte 0,0 // add %al,(%eax) .byte 0,83,128 // add %dl,-0x80(%ebx) .byte 0,0 // add %al,(%eax) .byte 211,128,0,0,211,128 // roll %cl,-0x7f2d0000(%eax) .byte 0,0 // add %al,(%eax) .byte 211,128,0,0,211,45 // roll %cl,0x2dd30000(%eax) .byte 16,17 // adc %dl,(%ecx) .byte 192,45,16,17,192,45,16 // shrb $0x10,0x2dc01110 .byte 17,192 // adc %eax,%eax .byte 45,16,17,192,18 // sub $0x12c01110,%eax .byte 120,57 // js 830c <.literal16+0x124c> .byte 64 // inc %eax .byte 18,120,57 // adc 0x39(%eax),%bh .byte 64 // inc %eax .byte 18,120,57 // adc 0x39(%eax),%bh .byte 64 // inc %eax .byte 18,120,57 // adc 0x39(%eax),%bh .byte 64 // inc %eax .byte 32,148,90,62,32,148,90 // and %dl,0x5a94203e(%edx,%ebx,2) .byte 62,32,148,90,62,32,148,90 // and %dl,%ds:0x5a94203e(%edx,%ebx,2) .byte 62,4,157 // ds add $0x9d,%al .byte 30 // push %ds .byte 62,4,157 // ds add $0x9d,%al .byte 30 // push %ds .byte 62,4,157 // ds add $0x9d,%al .byte 30 // push %ds .byte 62,4,157 // ds add $0x9d,%al .byte 30 // push %ds .byte 62,0,24 // add %bl,%ds:(%eax) .byte 161,57,0,24,161 // mov 0xa1180039,%eax .byte 57,0 // cmp %eax,(%eax) .byte 24,161,57,0,24,161 // sbb %ah,-0x5ee7ffc7(%ecx) .byte 57,1 // cmp %eax,(%ecx) .byte 0,0 // add %al,(%eax) .byte 0,1 // add %al,(%ecx) .byte 0,0 // add %al,(%eax) .byte 0,1 // add %al,(%ecx) .byte 0,0 // add %al,(%eax) .byte 0,1 // add %al,(%ecx) .byte 0,0 // add %al,(%eax) .byte 0,111,43 // add %ch,0x2b(%edi) .byte 231,187 // out %eax,$0xbb .byte 111 // outsl %ds:(%esi),(%dx) .byte 43,231 // sub %edi,%esp .byte 187,111,43,231,187 // mov $0xbbe72b6f,%ebx .byte 111 // outsl %ds:(%esi),(%dx) .byte 43,231 // sub %edi,%esp .byte 187,159,215,202,60 // mov $0x3ccad79f,%ebx .byte 159 // lahf .byte 215 // xlat %ds:(%ebx) .byte 202,60,159 // lret $0x9f3c .byte 215 // xlat %ds:(%ebx) .byte 202,60,159 // lret $0x9f3c .byte 215 // xlat %ds:(%ebx) .byte 202,60,212 // lret $0xd43c .byte 100,84 // fs push %esp .byte 189,212,100,84,189 // mov $0xbd5464d4,%ebp .byte 212,100 // aam $0x64 .byte 84 // push %esp .byte 189,212,100,84,189 // mov $0xbd5464d4,%ebp .byte 169,240,34,62,169 // test $0xa93e22f0,%eax .byte 240,34,62 // lock and (%esi),%bh .byte 169,240,34,62,169 // test $0xa93e22f0,%eax .byte 240,34,62 // lock and (%esi),%bh .byte 0,0 // add %al,(%eax) .byte 128,62,0 // cmpb $0x0,(%esi) .byte 0,128,62,0,0,128 // add %al,-0x7fffffc2(%eax) .byte 62,0,0 // add %al,%ds:(%eax) .byte 128,62,0 // cmpb $0x0,(%esi) .byte 0,0 // add %al,(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,0 // add %al,(%eax) .byte 192,0,0 // rolb $0x0,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 128,192,0 // add $0x0,%al .byte 0,128,192,0,0,128 // add %al,-0x7fffff40(%eax) .byte 192,0,0 // rolb $0x0,(%eax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%eax) .byte 128,0,0 // addb $0x0,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,63 // add %al,0x3f000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 128,192,0 // add $0x0,%al .byte 0,128,192,0,0,128 // add %al,-0x7fffff40(%eax) .byte 192,0,0 // rolb $0x0,(%eax) .byte 128,192,0 // add $0x0,%al .byte 0,0 // add %al,(%eax) .byte 128,0,0 // addb $0x0,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,63 // add %al,0x3f000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 0,192 // add %al,%al .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,128,0,0,0,128 // add %al,-0x80000000(%eax) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,0 // add %al,(%eax) .byte 191,0,0,0,191 // mov $0xbf000000,%edi .byte 0,0 // add %al,(%eax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%edi) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,0 // add %al,(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%edi) .byte 0,0 // add %al,(%eax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%edi) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,0 // add %al,(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 192,191,0,0,192,191,0 // sarb $0x0,-0x40400000(%edi) .byte 0,192 // add %al,%al .byte 191,0,0,192,191 // mov $0xbfc00000,%edi .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,114 // cmpb $0x72,(%edi) .byte 28,199 // sbb $0xc7,%al .byte 62,114,28 // jb,pt 84f2 <.literal16+0x1432> .byte 199 // (bad) .byte 62,114,28 // jb,pt 84f6 <.literal16+0x1436> .byte 199 // (bad) .byte 62,114,28 // jb,pt 84fa <.literal16+0x143a> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 0,0 // add %al,(%eax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%edi) .byte 0,0 // add %al,(%eax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%edi) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,85 // cmpb $0x55,(%edi) .byte 85 // push %ebp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %ebp .byte 85 // push %ebp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%esi) .byte 99,61,57,142,99,61 // arpl %di,0x3d638e39 .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%esi) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 85 // push %ebp .byte 85 // push %ebp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %ebp .byte 85 // push %ebp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%esi) .byte 99,61,57,142,99,61 // arpl %di,0x3d638e39 .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%esi) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 114,28 // jb 85be <.literal16+0x14fe> .byte 199 // (bad) .byte 62,114,28 // jb,pt 85c2 <.literal16+0x1502> .byte 199 // (bad) .byte 62,114,28 // jb,pt 85c6 <.literal16+0x1506> .byte 199 // (bad) .byte 62,114,28 // jb,pt 85ca <.literal16+0x150a> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 0,0 // add %al,(%eax) .byte 192,191,0,0,192,191,0 // sarb $0x0,-0x40400000(%edi) .byte 0,192 // add %al,%al .byte 191,0,0,192,191 // mov $0xbfc00000,%edi .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,114 // cmpb $0x72,(%edi) .byte 28,199 // sbb $0xc7,%al .byte 62,114,28 // jb,pt 8602 <.literal16+0x1542> .byte 199 // (bad) .byte 62,114,28 // jb,pt 8606 <.literal16+0x1546> .byte 199 // (bad) .byte 62,114,28 // jb,pt 860a <.literal16+0x154a> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 0,0 // add %al,(%eax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%edi) .byte 0,0 // add %al,(%eax) .byte 0,191,0,0,0,191 // add %bh,-0x41000000(%edi) .byte 0,0 // add %al,(%eax) .byte 128,63,0 // cmpb $0x0,(%edi) .byte 0,128,63,0,0,128 // add %al,-0x7fffffc1(%eax) .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 128,63,85 // cmpb $0x55,(%edi) .byte 85 // push %ebp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %ebp .byte 85 // push %ebp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%esi) .byte 99,61,57,142,99,61 // arpl %di,0x3d638e39 .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%esi) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 85 // push %ebp .byte 85 // push %ebp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 85 // push %ebp .byte 85 // push %ebp .byte 149 // xchg %eax,%ebp .byte 191,85,85,149,191 // mov $0xbf955555,%edi .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 57,142,99,61,57,142 // cmp %ecx,-0x71c6c29d(%esi) .byte 99,61,57,142,99,61 // arpl %di,0x3d638e39 .byte 57,142,99,61,0,0 // cmp %ecx,0x3d63(%esi) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 0,0 // add %al,(%eax) .byte 192,63,0 // sarb $0x0,(%edi) .byte 0,192 // add %al,%al .byte 63 // aas .byte 114,28 // jb 86ce <.literal16+0x160e> .byte 199 // (bad) .byte 62,114,28 // jb,pt 86d2 <_sk_callback_sse2+0x16c4> .byte 199 // (bad) .byte 62,114,28 // jb,pt 86d6 <_sk_callback_sse2+0x16c8> .byte 199 // (bad) .byte 62,114,28 // jb,pt 86da <_sk_callback_sse2+0x16cc> .byte 199 // (bad) .byte 62,171 // ds stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi .byte 171 // stos %eax,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 170 // stos %al,%es:(%edi) .byte 190,171,170,170,190 // mov $0xbeaaaaab,%esi BALIGN4 .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) .byte 0,0 // add %al,(%eax) .byte 0,63 // add %bh,(%edi) #endif