diff --git a/src/jumper/SkJumper_generated.S b/src/jumper/SkJumper_generated.S index 25bfc1bcd8..c313e691c0 100644 --- a/src/jumper/SkJumper_generated.S +++ b/src/jumper/SkJumper_generated.S @@ -12,4019 +12,4019 @@ .globl _sk_start_pipeline_aarch64 _sk_start_pipeline_aarch64: - .long 0xa9bc5ff8 // stp x24, x23, [sp,#-64]! - .long 0xa90157f6 // stp x22, x21, [sp,#16] - .long 0xa9024ff4 // stp x20, x19, [sp,#32] - .long 0xa9037bfd // stp x29, x30, [sp,#48] - .long 0x9100c3fd // add x29, sp, #0x30 - .long 0xaa0103f3 // mov x19, x1 - .long 0xf8408677 // ldr x23, [x19],#8 - .long 0xaa0003f6 // mov x22, x0 - .long 0xaa0303f4 // mov x20, x3 - .long 0xaa0203f5 // mov x21, x2 - .long 0x910012c8 // add x8, x22, #0x4 - .long 0xeb14011f // cmp x8, x20 - .long 0x54000069 // b.ls 3c - .long 0xaa1603e0 // mov x0, x22 - .long 0x14000012 // b 80 - .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 0x6f00e404 // movi v4.2d, #0x0 - .long 0x6f00e405 // movi v5.2d, #0x0 - .long 0x6f00e406 // movi v6.2d, #0x0 - .long 0x6f00e407 // movi v7.2d, #0x0 - .long 0xaa1603e0 // mov x0, x22 - .long 0xaa1303e1 // mov x1, x19 - .long 0xaa1503e2 // mov x2, x21 - .long 0xd63f02e0 // blr x23 - .long 0x910022c8 // add x8, x22, #0x8 - .long 0x910012c0 // add x0, x22, #0x4 - .long 0xeb14011f // cmp x8, x20 - .long 0xaa0003f6 // mov x22, x0 - .long 0x54fffe09 // b.ls 3c - .long 0xa9437bfd // ldp x29, x30, [sp,#48] - .long 0xa9424ff4 // ldp x20, x19, [sp,#32] - .long 0xa94157f6 // ldp x22, x21, [sp,#16] - .long 0xa8c45ff8 // ldp x24, x23, [sp],#64 - .long 0xd65f03c0 // ret + .long 0xa9bc5ff8 // stp x24, x23, [sp,#-64]! + .long 0xa90157f6 // stp x22, x21, [sp,#16] + .long 0xa9024ff4 // stp x20, x19, [sp,#32] + .long 0xa9037bfd // stp x29, x30, [sp,#48] + .long 0x9100c3fd // add x29, sp, #0x30 + .long 0xaa0103f3 // mov x19, x1 + .long 0xf8408677 // ldr x23, [x19],#8 + .long 0xaa0003f6 // mov x22, x0 + .long 0xaa0303f4 // mov x20, x3 + .long 0xaa0203f5 // mov x21, x2 + .long 0x910012c8 // add x8, x22, #0x4 + .long 0xeb14011f // cmp x8, x20 + .long 0x54000069 // b.ls 3c + .long 0xaa1603e0 // mov x0, x22 + .long 0x14000012 // b 80 + .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 0x6f00e404 // movi v4.2d, #0x0 + .long 0x6f00e405 // movi v5.2d, #0x0 + .long 0x6f00e406 // movi v6.2d, #0x0 + .long 0x6f00e407 // movi v7.2d, #0x0 + .long 0xaa1603e0 // mov x0, x22 + .long 0xaa1303e1 // mov x1, x19 + .long 0xaa1503e2 // mov x2, x21 + .long 0xd63f02e0 // blr x23 + .long 0x910022c8 // add x8, x22, #0x8 + .long 0x910012c0 // add x0, x22, #0x4 + .long 0xeb14011f // cmp x8, x20 + .long 0xaa0003f6 // mov x22, x0 + .long 0x54fffe09 // b.ls 3c + .long 0xa9437bfd // ldp x29, x30, [sp,#48] + .long 0xa9424ff4 // ldp x20, x19, [sp,#32] + .long 0xa94157f6 // ldp x22, x21, [sp,#16] + .long 0xa8c45ff8 // ldp x24, x23, [sp],#64 + .long 0xd65f03c0 // ret .globl _sk_just_return_aarch64 _sk_just_return_aarch64: - .long 0xd65f03c0 // ret + .long 0xd65f03c0 // ret .globl _sk_seed_shader_aarch64 _sk_seed_shader_aarch64: - .long 0xaa0203e9 // mov x9, x2 - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0x4ddfc922 // ld1r {v2.4s}, [x9], #4 - .long 0x3cc14041 // ldur q1, [x2,#20] - .long 0x4e040c00 // dup v0.4s, w0 - .long 0x4d40c903 // ld1r {v3.4s}, [x8] - .long 0x4d40c924 // ld1r {v4.4s}, [x9] - .long 0x4e21d800 // scvtf v0.4s, v0.4s - .long 0x6f00e405 // movi v5.2d, #0x0 - .long 0x4e21d863 // scvtf v3.4s, v3.4s - .long 0x4e24d400 // fadd v0.4s, v0.4s, v4.4s - .long 0x4e20d420 // fadd v0.4s, v1.4s, v0.4s - .long 0x4e24d461 // fadd v1.4s, v3.4s, v4.4s - .long 0x6f00e403 // movi v3.2d, #0x0 - .long 0x6f00e404 // movi v4.2d, #0x0 - .long 0x6f00e406 // movi v6.2d, #0x0 - .long 0x6f00e407 // movi v7.2d, #0x0 - .long 0xd61f0060 // br x3 + .long 0xaa0203e9 // mov x9, x2 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0x4ddfc922 // ld1r {v2.4s}, [x9], #4 + .long 0x3cc14041 // ldur q1, [x2,#20] + .long 0x4e040c00 // dup v0.4s, w0 + .long 0x4d40c903 // ld1r {v3.4s}, [x8] + .long 0x4d40c924 // ld1r {v4.4s}, [x9] + .long 0x4e21d800 // scvtf v0.4s, v0.4s + .long 0x6f00e405 // movi v5.2d, #0x0 + .long 0x4e21d863 // scvtf v3.4s, v3.4s + .long 0x4e24d400 // fadd v0.4s, v0.4s, v4.4s + .long 0x4e20d420 // fadd v0.4s, v1.4s, v0.4s + .long 0x4e24d461 // fadd v1.4s, v3.4s, v4.4s + .long 0x6f00e403 // movi v3.2d, #0x0 + .long 0x6f00e404 // movi v4.2d, #0x0 + .long 0x6f00e406 // movi v6.2d, #0x0 + .long 0x6f00e407 // movi v7.2d, #0x0 + .long 0xd61f0060 // br x3 .globl _sk_constant_color_aarch64 _sk_constant_color_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0x3dc00103 // ldr q3, [x8] - .long 0x4e040460 // dup v0.4s, v3.s[0] - .long 0x4e0c0461 // dup v1.4s, v3.s[1] - .long 0x4e140462 // dup v2.4s, v3.s[2] - .long 0x4e1c0463 // dup v3.4s, v3.s[3] - .long 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0x3dc00103 // ldr q3, [x8] + .long 0x4e040460 // dup v0.4s, v3.s[0] + .long 0x4e0c0461 // dup v1.4s, v3.s[1] + .long 0x4e140462 // dup v2.4s, v3.s[2] + .long 0x4e1c0463 // dup v3.4s, v3.s[3] + .long 0xd61f0060 // br x3 .globl _sk_clear_aarch64 _sk_clear_aarch64: - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x91004028 // add x8, x1, #0x10 - .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 0xaa0803e1 // mov x1, x8 - .long 0xd61f0060 // br x3 + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x91004028 // add x8, x1, #0x10 + .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 0xaa0803e1 // mov x1, x8 + .long 0xd61f0060 // br x3 .globl _sk_plus__aarch64 _sk_plus__aarch64: - .long 0xf9400423 // ldr x3, [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 0x91004021 // add x1, x1, #0x10 - .long 0xd61f0060 // br x3 + .long 0xf9400423 // ldr x3, [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 0x91004021 // add x1, x1, #0x10 + .long 0xd61f0060 // br x3 .globl _sk_srcover_aarch64 _sk_srcover_aarch64: - .long 0x4d40c850 // ld1r {v16.4s}, [x2] - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x91004021 // add x1, x1, #0x10 - .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 0xd61f0060 // br x3 + .long 0x4d40c850 // ld1r {v16.4s}, [x2] + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x91004021 // add x1, x1, #0x10 + .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 0xd61f0060 // br x3 .globl _sk_dstover_aarch64 _sk_dstover_aarch64: - .long 0x4d40c851 // ld1r {v17.4s}, [x2] - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x4ea41c90 // mov v16.16b, v4.16b - .long 0x4ea61cd2 // mov v18.16b, v6.16b - .long 0x4ea7d634 // fsub v20.4s, v17.4s, v7.4s - .long 0x4ea51cb1 // mov v17.16b, v5.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 0x91004021 // add x1, x1, #0x10 - .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 0xd61f0060 // br x3 + .long 0x4d40c851 // ld1r {v17.4s}, [x2] + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x4ea41c90 // mov v16.16b, v4.16b + .long 0x4ea61cd2 // mov v18.16b, v6.16b + .long 0x4ea7d634 // fsub v20.4s, v17.4s, v7.4s + .long 0x4ea51cb1 // mov v17.16b, v5.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 0x91004021 // add x1, x1, #0x10 + .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 0xd61f0060 // br x3 .globl _sk_clamp_0_aarch64 _sk_clamp_0_aarch64: - .long 0xf9400423 // ldr x3, [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 0x91004021 // add x1, x1, #0x10 - .long 0xd61f0060 // br x3 + .long 0xf9400423 // ldr x3, [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 0x91004021 // add x1, x1, #0x10 + .long 0xd61f0060 // br x3 .globl _sk_clamp_1_aarch64 _sk_clamp_1_aarch64: - .long 0x4d40c850 // ld1r {v16.4s}, [x2] - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x91004021 // add x1, x1, #0x10 - .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 0xd61f0060 // br x3 + .long 0x4d40c850 // ld1r {v16.4s}, [x2] + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x91004021 // add x1, x1, #0x10 + .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 0xd61f0060 // br x3 .globl _sk_clamp_a_aarch64 _sk_clamp_a_aarch64: - .long 0x4d40c850 // ld1r {v16.4s}, [x2] - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x91004021 // add x1, x1, #0x10 - .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 0xd61f0060 // br x3 + .long 0x4d40c850 // ld1r {v16.4s}, [x2] + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x91004021 // add x1, x1, #0x10 + .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 0xd61f0060 // br x3 .globl _sk_set_rgb_aarch64 _sk_set_rgb_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0x91002109 // add x9, x8, #0x8 - .long 0x4ddfc900 // ld1r {v0.4s}, [x8], #4 - .long 0x4d40c922 // ld1r {v2.4s}, [x9] - .long 0x4d40c901 // ld1r {v1.4s}, [x8] - .long 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0x91002109 // add x9, x8, #0x8 + .long 0x4ddfc900 // ld1r {v0.4s}, [x8], #4 + .long 0x4d40c922 // ld1r {v2.4s}, [x9] + .long 0x4d40c901 // ld1r {v1.4s}, [x8] + .long 0xd61f0060 // br x3 .globl _sk_swap_rb_aarch64 _sk_swap_rb_aarch64: - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x4ea01c10 // mov v16.16b, v0.16b - .long 0x91004021 // add x1, x1, #0x10 - .long 0x4ea21c40 // mov v0.16b, v2.16b - .long 0x4eb01e02 // mov v2.16b, v16.16b - .long 0xd61f0060 // br x3 + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x4ea01c10 // mov v16.16b, v0.16b + .long 0x91004021 // add x1, x1, #0x10 + .long 0x4ea21c40 // mov v0.16b, v2.16b + .long 0x4eb01e02 // mov v2.16b, v16.16b + .long 0xd61f0060 // br x3 .globl _sk_swap_aarch64 _sk_swap_aarch64: - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x4ea31c70 // mov v16.16b, v3.16b - .long 0x4ea21c51 // mov v17.16b, v2.16b - .long 0x4ea11c32 // mov v18.16b, v1.16b - .long 0x4ea01c13 // mov v19.16b, v0.16b - .long 0x91004021 // add x1, x1, #0x10 - .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 0x4eb31e64 // mov v4.16b, v19.16b - .long 0x4eb21e45 // mov v5.16b, v18.16b - .long 0x4eb11e26 // mov v6.16b, v17.16b - .long 0x4eb01e07 // mov v7.16b, v16.16b - .long 0xd61f0060 // br x3 + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x4ea31c70 // mov v16.16b, v3.16b + .long 0x4ea21c51 // mov v17.16b, v2.16b + .long 0x4ea11c32 // mov v18.16b, v1.16b + .long 0x4ea01c13 // mov v19.16b, v0.16b + .long 0x91004021 // add x1, x1, #0x10 + .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 0x4eb31e64 // mov v4.16b, v19.16b + .long 0x4eb21e45 // mov v5.16b, v18.16b + .long 0x4eb11e26 // mov v6.16b, v17.16b + .long 0x4eb01e07 // mov v7.16b, v16.16b + .long 0xd61f0060 // br x3 .globl _sk_move_src_dst_aarch64 _sk_move_src_dst_aarch64: - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x91004021 // add x1, x1, #0x10 - .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 0xd61f0060 // br x3 + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x91004021 // add x1, x1, #0x10 + .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 0xd61f0060 // br x3 .globl _sk_move_dst_src_aarch64 _sk_move_dst_src_aarch64: - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x91004021 // add x1, x1, #0x10 - .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 0xd61f0060 // br x3 + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x91004021 // add x1, x1, #0x10 + .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 0xd61f0060 // br x3 .globl _sk_premul_aarch64 _sk_premul_aarch64: - .long 0xf9400423 // ldr x3, [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 0x91004021 // add x1, x1, #0x10 - .long 0xd61f0060 // br x3 + .long 0xf9400423 // ldr x3, [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 0x91004021 // add x1, x1, #0x10 + .long 0xd61f0060 // br x3 .globl _sk_unpremul_aarch64 _sk_unpremul_aarch64: - .long 0x4d40c850 // ld1r {v16.4s}, [x2] - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x4ea0d871 // fcmeq v17.4s, v3.4s, #0.0 - .long 0x91004021 // add x1, x1, #0x10 - .long 0x6e23fe10 // fdiv v16.4s, v16.4s, v3.4s - .long 0x4e711e10 // bic v16.16b, v16.16b, v17.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 0xd61f0060 // br x3 + .long 0x4d40c850 // ld1r {v16.4s}, [x2] + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x4ea0d871 // fcmeq v17.4s, v3.4s, #0.0 + .long 0x91004021 // add x1, x1, #0x10 + .long 0x6e23fe10 // fdiv v16.4s, v16.4s, v3.4s + .long 0x4e711e10 // bic v16.16b, v16.16b, v17.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 0xd61f0060 // br x3 .globl _sk_from_srgb_aarch64 _sk_from_srgb_aarch64: - .long 0x9100e048 // add x8, x2, #0x38 - .long 0x4d40c910 // ld1r {v16.4s}, [x8] - .long 0x9100d048 // add x8, x2, #0x34 - .long 0x4d40c911 // ld1r {v17.4s}, [x8] - .long 0x2d47cc52 // ldp s18, s19, [x2,#60] - .long 0x6e22dc54 // fmul v20.4s, v2.4s, v2.4s - .long 0x4eb01e15 // mov v21.16b, v16.16b - .long 0x4eb01e17 // mov v23.16b, v16.16b - .long 0x4f921050 // fmla v16.4s, v2.4s, v18.s[0] - .long 0x4eb11e36 // mov v22.16b, v17.16b - .long 0x4eb11e38 // mov v24.16b, v17.16b - .long 0x4e34ce11 // fmla v17.4s, v16.4s, v20.4s - .long 0x6e20dc10 // fmul v16.4s, v0.4s, v0.4s - .long 0x91011048 // add x8, x2, #0x44 - .long 0x4f921015 // fmla v21.4s, v0.4s, v18.s[0] - .long 0x4e30ceb6 // fmla v22.4s, v21.4s, v16.4s - .long 0x4d40c910 // ld1r {v16.4s}, [x8] - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x6e21dc34 // fmul v20.4s, v1.4s, v1.4s - .long 0x4f921037 // fmla v23.4s, v1.4s, v18.s[0] - .long 0x4f939015 // fmul v21.4s, v0.4s, v19.s[0] - .long 0x4f939032 // fmul v18.4s, v1.4s, v19.s[0] - .long 0x4f939053 // fmul v19.4s, v2.4s, v19.s[0] - .long 0x6ea0e600 // fcmgt v0.4s, v16.4s, v0.4s - .long 0x6ea1e601 // fcmgt v1.4s, v16.4s, v1.4s - .long 0x6ea2e602 // fcmgt v2.4s, v16.4s, v2.4s - .long 0x4e34cef8 // fmla v24.4s, v23.4s, v20.4s - .long 0x6e711e62 // bsl v2.16b, v19.16b, v17.16b - .long 0x6e761ea0 // bsl v0.16b, v21.16b, v22.16b - .long 0x6e781e41 // bsl v1.16b, v18.16b, v24.16b - .long 0x91004021 // add x1, x1, #0x10 - .long 0xd61f0060 // br x3 + .long 0x9100e048 // add x8, x2, #0x38 + .long 0x4d40c910 // ld1r {v16.4s}, [x8] + .long 0x9100d048 // add x8, x2, #0x34 + .long 0x4d40c911 // ld1r {v17.4s}, [x8] + .long 0x2d47cc52 // ldp s18, s19, [x2,#60] + .long 0x6e22dc54 // fmul v20.4s, v2.4s, v2.4s + .long 0x4eb01e15 // mov v21.16b, v16.16b + .long 0x4eb01e17 // mov v23.16b, v16.16b + .long 0x4f921050 // fmla v16.4s, v2.4s, v18.s[0] + .long 0x4eb11e36 // mov v22.16b, v17.16b + .long 0x4eb11e38 // mov v24.16b, v17.16b + .long 0x4e34ce11 // fmla v17.4s, v16.4s, v20.4s + .long 0x6e20dc10 // fmul v16.4s, v0.4s, v0.4s + .long 0x91011048 // add x8, x2, #0x44 + .long 0x4f921015 // fmla v21.4s, v0.4s, v18.s[0] + .long 0x4e30ceb6 // fmla v22.4s, v21.4s, v16.4s + .long 0x4d40c910 // ld1r {v16.4s}, [x8] + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x6e21dc34 // fmul v20.4s, v1.4s, v1.4s + .long 0x4f921037 // fmla v23.4s, v1.4s, v18.s[0] + .long 0x4f939015 // fmul v21.4s, v0.4s, v19.s[0] + .long 0x4f939032 // fmul v18.4s, v1.4s, v19.s[0] + .long 0x4f939053 // fmul v19.4s, v2.4s, v19.s[0] + .long 0x6ea0e600 // fcmgt v0.4s, v16.4s, v0.4s + .long 0x6ea1e601 // fcmgt v1.4s, v16.4s, v1.4s + .long 0x6ea2e602 // fcmgt v2.4s, v16.4s, v2.4s + .long 0x4e34cef8 // fmla v24.4s, v23.4s, v20.4s + .long 0x6e711e62 // bsl v2.16b, v19.16b, v17.16b + .long 0x6e761ea0 // bsl v0.16b, v21.16b, v22.16b + .long 0x6e781e41 // bsl v1.16b, v18.16b, v24.16b + .long 0x91004021 // add x1, x1, #0x10 + .long 0xd61f0060 // br x3 .globl _sk_to_srgb_aarch64 _sk_to_srgb_aarch64: - .long 0x6ea1d811 // frsqrte v17.4s, v0.4s - .long 0x6ea1d835 // frsqrte v21.4s, v1.4s - .long 0x6e31de37 // fmul v23.4s, v17.4s, v17.4s - .long 0x6ea1d856 // frsqrte v22.4s, v2.4s - .long 0x6e35deb9 // fmul v25.4s, v21.4s, v21.4s - .long 0x4eb7fc17 // frsqrts v23.4s, v0.4s, v23.4s - .long 0x91015048 // add x8, x2, #0x54 - .long 0x6e36deda // fmul v26.4s, v22.4s, v22.4s - .long 0x4eb9fc39 // frsqrts v25.4s, v1.4s, v25.4s - .long 0x6e37de31 // fmul v17.4s, v17.4s, v23.4s - .long 0x2d494052 // ldp s18, s16, [x2,#72] - .long 0x4d40c914 // ld1r {v20.4s}, [x8] - .long 0x4ebafc5a // frsqrts v26.4s, v2.4s, v26.4s - .long 0x6e39deb5 // fmul v21.4s, v21.4s, v25.4s - .long 0x4ea1da37 // frecpe v23.4s, v17.4s - .long 0xbd405053 // ldr s19, [x2,#80] - .long 0x91016048 // add x8, x2, #0x58 - .long 0x6e3aded6 // fmul v22.4s, v22.4s, v26.4s - .long 0x4ea1dabb // frecpe v27.4s, v21.4s - .long 0x4e37fe3d // frecps v29.4s, v17.4s, v23.4s - .long 0x4d40c918 // ld1r {v24.4s}, [x8] - .long 0x4ea1dadc // frecpe v28.4s, v22.4s - .long 0x6e3ddef7 // fmul v23.4s, v23.4s, v29.4s - .long 0x4e3bfebd // frecps v29.4s, v21.4s, v27.4s - .long 0x6e3ddf7b // fmul v27.4s, v27.4s, v29.4s - .long 0x4e3cfedd // frecps v29.4s, v22.4s, v28.4s - .long 0x6e3ddf9c // fmul v28.4s, v28.4s, v29.4s - .long 0x4eb41e9d // mov v29.16b, v20.16b - .long 0x6ea1da39 // frsqrte v25.4s, v17.4s - .long 0x4f9312fd // fmla v29.4s, v23.4s, v19.s[0] - .long 0x4eb41e97 // mov v23.16b, v20.16b - .long 0x4f92901a // fmul v26.4s, v0.4s, v18.s[0] - .long 0x4f931377 // fmla v23.4s, v27.4s, v19.s[0] - .long 0x4f931394 // fmla v20.4s, v28.4s, v19.s[0] - .long 0x4f929033 // fmul v19.4s, v1.4s, v18.s[0] - .long 0x4f929052 // fmul v18.4s, v2.4s, v18.s[0] - .long 0x6ea0e700 // fcmgt v0.4s, v24.4s, v0.4s - .long 0x6ea1e701 // fcmgt v1.4s, v24.4s, v1.4s - .long 0x6ea2e702 // fcmgt v2.4s, v24.4s, v2.4s - .long 0x6e39df38 // fmul v24.4s, v25.4s, v25.4s - .long 0x6ea1dabb // frsqrte v27.4s, v21.4s - .long 0x4eb8fe31 // frsqrts v17.4s, v17.4s, v24.4s - .long 0x6ea1dadc // frsqrte v28.4s, v22.4s - .long 0x6e3bdf78 // fmul v24.4s, v27.4s, v27.4s - .long 0x6e31df31 // fmul v17.4s, v25.4s, v17.4s - .long 0x4eb8feb5 // frsqrts v21.4s, v21.4s, v24.4s - .long 0x6e3cdf98 // fmul v24.4s, v28.4s, v28.4s - .long 0x4f90123d // fmla v29.4s, v17.4s, v16.s[0] - .long 0x4d40c851 // ld1r {v17.4s}, [x2] - .long 0x4eb8fed6 // frsqrts v22.4s, v22.4s, v24.4s - .long 0x6e35df75 // fmul v21.4s, v27.4s, v21.4s - .long 0x6e36df96 // fmul v22.4s, v28.4s, v22.4s - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x4f9012b7 // fmla v23.4s, v21.4s, v16.s[0] - .long 0x4f9012d4 // fmla v20.4s, v22.4s, v16.s[0] - .long 0x4ebdf630 // fmin v16.4s, v17.4s, v29.4s - .long 0x4eb7f635 // fmin v21.4s, v17.4s, v23.4s - .long 0x4eb4f631 // fmin v17.4s, v17.4s, v20.4s - .long 0x6e701f40 // bsl v0.16b, v26.16b, v16.16b - .long 0x6e751e61 // bsl v1.16b, v19.16b, v21.16b - .long 0x6e711e42 // bsl v2.16b, v18.16b, v17.16b - .long 0x91004021 // add x1, x1, #0x10 - .long 0xd61f0060 // br x3 + .long 0x6ea1d811 // frsqrte v17.4s, v0.4s + .long 0x6ea1d835 // frsqrte v21.4s, v1.4s + .long 0x6e31de37 // fmul v23.4s, v17.4s, v17.4s + .long 0x6ea1d856 // frsqrte v22.4s, v2.4s + .long 0x6e35deb9 // fmul v25.4s, v21.4s, v21.4s + .long 0x4eb7fc17 // frsqrts v23.4s, v0.4s, v23.4s + .long 0x91015048 // add x8, x2, #0x54 + .long 0x6e36deda // fmul v26.4s, v22.4s, v22.4s + .long 0x4eb9fc39 // frsqrts v25.4s, v1.4s, v25.4s + .long 0x6e37de31 // fmul v17.4s, v17.4s, v23.4s + .long 0x2d494052 // ldp s18, s16, [x2,#72] + .long 0x4d40c914 // ld1r {v20.4s}, [x8] + .long 0x4ebafc5a // frsqrts v26.4s, v2.4s, v26.4s + .long 0x6e39deb5 // fmul v21.4s, v21.4s, v25.4s + .long 0x4ea1da37 // frecpe v23.4s, v17.4s + .long 0xbd405053 // ldr s19, [x2,#80] + .long 0x91016048 // add x8, x2, #0x58 + .long 0x6e3aded6 // fmul v22.4s, v22.4s, v26.4s + .long 0x4ea1dabb // frecpe v27.4s, v21.4s + .long 0x4e37fe3d // frecps v29.4s, v17.4s, v23.4s + .long 0x4d40c918 // ld1r {v24.4s}, [x8] + .long 0x4ea1dadc // frecpe v28.4s, v22.4s + .long 0x6e3ddef7 // fmul v23.4s, v23.4s, v29.4s + .long 0x4e3bfebd // frecps v29.4s, v21.4s, v27.4s + .long 0x6e3ddf7b // fmul v27.4s, v27.4s, v29.4s + .long 0x4e3cfedd // frecps v29.4s, v22.4s, v28.4s + .long 0x6e3ddf9c // fmul v28.4s, v28.4s, v29.4s + .long 0x4eb41e9d // mov v29.16b, v20.16b + .long 0x6ea1da39 // frsqrte v25.4s, v17.4s + .long 0x4f9312fd // fmla v29.4s, v23.4s, v19.s[0] + .long 0x4eb41e97 // mov v23.16b, v20.16b + .long 0x4f92901a // fmul v26.4s, v0.4s, v18.s[0] + .long 0x4f931377 // fmla v23.4s, v27.4s, v19.s[0] + .long 0x4f931394 // fmla v20.4s, v28.4s, v19.s[0] + .long 0x4f929033 // fmul v19.4s, v1.4s, v18.s[0] + .long 0x4f929052 // fmul v18.4s, v2.4s, v18.s[0] + .long 0x6ea0e700 // fcmgt v0.4s, v24.4s, v0.4s + .long 0x6ea1e701 // fcmgt v1.4s, v24.4s, v1.4s + .long 0x6ea2e702 // fcmgt v2.4s, v24.4s, v2.4s + .long 0x6e39df38 // fmul v24.4s, v25.4s, v25.4s + .long 0x6ea1dabb // frsqrte v27.4s, v21.4s + .long 0x4eb8fe31 // frsqrts v17.4s, v17.4s, v24.4s + .long 0x6ea1dadc // frsqrte v28.4s, v22.4s + .long 0x6e3bdf78 // fmul v24.4s, v27.4s, v27.4s + .long 0x6e31df31 // fmul v17.4s, v25.4s, v17.4s + .long 0x4eb8feb5 // frsqrts v21.4s, v21.4s, v24.4s + .long 0x6e3cdf98 // fmul v24.4s, v28.4s, v28.4s + .long 0x4f90123d // fmla v29.4s, v17.4s, v16.s[0] + .long 0x4d40c851 // ld1r {v17.4s}, [x2] + .long 0x4eb8fed6 // frsqrts v22.4s, v22.4s, v24.4s + .long 0x6e35df75 // fmul v21.4s, v27.4s, v21.4s + .long 0x6e36df96 // fmul v22.4s, v28.4s, v22.4s + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x4f9012b7 // fmla v23.4s, v21.4s, v16.s[0] + .long 0x4f9012d4 // fmla v20.4s, v22.4s, v16.s[0] + .long 0x4ebdf630 // fmin v16.4s, v17.4s, v29.4s + .long 0x4eb7f635 // fmin v21.4s, v17.4s, v23.4s + .long 0x4eb4f631 // fmin v17.4s, v17.4s, v20.4s + .long 0x6e701f40 // bsl v0.16b, v26.16b, v16.16b + .long 0x6e751e61 // bsl v1.16b, v19.16b, v21.16b + .long 0x6e711e42 // bsl v2.16b, v18.16b, v17.16b + .long 0x91004021 // add x1, x1, #0x10 + .long 0xd61f0060 // br x3 .globl _sk_scale_u8_aarch64 _sk_scale_u8_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0xbd400c51 // ldr s17, [x2,#12] - .long 0xf9400108 // ldr x8, [x8] - .long 0x8b000108 // add x8, x8, x0 - .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 0x2f10a610 // uxtl v16.4s, v16.4h - .long 0x6e21da10 // ucvtf v16.4s, v16.4s - .long 0x4f919210 // fmul v16.4s, v16.4s, v17.s[0] - .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 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0xbd400c51 // ldr s17, [x2,#12] + .long 0xf9400108 // ldr x8, [x8] + .long 0x8b000108 // add x8, x8, x0 + .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 0x2f10a610 // uxtl v16.4s, v16.4h + .long 0x6e21da10 // ucvtf v16.4s, v16.4s + .long 0x4f919210 // fmul v16.4s, v16.4s, v17.s[0] + .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 0xd61f0060 // br x3 .globl _sk_lerp_u8_aarch64 _sk_lerp_u8_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0xbd400c51 // ldr s17, [x2,#12] - .long 0x4ea4d412 // fsub v18.4s, v0.4s, v4.4s - .long 0xf9400108 // ldr x8, [x8] - .long 0x8b000108 // add x8, x8, x0 - .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 0x2f10a600 // uxtl v0.4s, v16.4h - .long 0x6e21d800 // ucvtf v0.4s, v0.4s - .long 0x4f919010 // fmul v16.4s, v0.4s, v17.s[0] - .long 0x4ea41c80 // mov v0.16b, v4.16b - .long 0x4ea5d431 // fsub v17.4s, v1.4s, v5.4s - .long 0x4ea51ca1 // mov v1.16b, v5.16b - .long 0x4e32ce00 // fmla v0.4s, v16.4s, v18.4s - .long 0x4ea6d452 // fsub v18.4s, v2.4s, v6.4s - .long 0x4e31ce01 // fmla v1.4s, v16.4s, v17.4s - .long 0x4ea61cc2 // mov v2.16b, v6.16b - .long 0x4ea7d471 // fsub v17.4s, v3.4s, v7.4s - .long 0x4ea71ce3 // mov v3.16b, v7.16b - .long 0x4e32ce02 // fmla v2.4s, v16.4s, v18.4s - .long 0x4e31ce03 // fmla v3.4s, v16.4s, v17.4s - .long 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0xbd400c51 // ldr s17, [x2,#12] + .long 0x4ea4d412 // fsub v18.4s, v0.4s, v4.4s + .long 0xf9400108 // ldr x8, [x8] + .long 0x8b000108 // add x8, x8, x0 + .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 0x2f10a600 // uxtl v0.4s, v16.4h + .long 0x6e21d800 // ucvtf v0.4s, v0.4s + .long 0x4f919010 // fmul v16.4s, v0.4s, v17.s[0] + .long 0x4ea41c80 // mov v0.16b, v4.16b + .long 0x4ea5d431 // fsub v17.4s, v1.4s, v5.4s + .long 0x4ea51ca1 // mov v1.16b, v5.16b + .long 0x4e32ce00 // fmla v0.4s, v16.4s, v18.4s + .long 0x4ea6d452 // fsub v18.4s, v2.4s, v6.4s + .long 0x4e31ce01 // fmla v1.4s, v16.4s, v17.4s + .long 0x4ea61cc2 // mov v2.16b, v6.16b + .long 0x4ea7d471 // fsub v17.4s, v3.4s, v7.4s + .long 0x4ea71ce3 // mov v3.16b, v7.16b + .long 0x4e32ce02 // fmla v2.4s, v16.4s, v18.4s + .long 0x4e31ce03 // fmla v3.4s, v16.4s, v17.4s + .long 0xd61f0060 // br x3 .globl _sk_load_tables_aarch64 _sk_load_tables_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0x9100404b // add x11, x2, #0x10 - .long 0x4d40c960 // ld1r {v0.4s}, [x11] - .long 0xd37ef409 // lsl x9, x0, #2 - .long 0xa9402d0a // ldp x10, x11, [x8] - .long 0x3ce96942 // ldr q2, [x10,x9] - .long 0xa9412109 // ldp x9, x8, [x8,#16] - .long 0x4e221c01 // and v1.16b, v0.16b, v2.16b - .long 0x0e143c2c // mov w12, v1.s[2] - .long 0xbc6c5971 // ldr s17, [x11,w12,uxtw #2] - .long 0x1e26002c // fmov w12, s1 - .long 0x6f380443 // ushr v3.4s, v2.4s, #8 - .long 0x6f300450 // ushr v16.4s, v2.4s, #16 - .long 0x8b2c496c // add x12, x11, w12, uxtw #2 - .long 0x0e0c3c2a // mov w10, v1.s[1] - .long 0x0e1c3c2d // mov w13, v1.s[3] - .long 0x4e231c01 // and v1.16b, v0.16b, v3.16b - .long 0x4e301c03 // and v3.16b, v0.16b, v16.16b - .long 0x0d408180 // ld1 {v0.s}[0], [x12] - .long 0x0e143c2c // mov w12, v1.s[2] - .long 0xbc6c5932 // ldr s18, [x9,w12,uxtw #2] - .long 0x1e26002c // fmov w12, s1 - .long 0x8b2a496a // add x10, x11, w10, uxtw #2 - .long 0xbc6d5970 // ldr s16, [x11,w13,uxtw #2] - .long 0x0e0c3c2b // mov w11, v1.s[1] - .long 0x0e1c3c2d // mov w13, v1.s[3] - .long 0x8b2c492c // add x12, x9, w12, uxtw #2 - .long 0xbc6d5933 // ldr s19, [x9,w13,uxtw #2] - .long 0x0e0c3c6d // mov w13, v3.s[1] - .long 0x8b2b4929 // add x9, x9, w11, uxtw #2 - .long 0x0e143c6b // mov w11, v3.s[2] - .long 0x0d408181 // ld1 {v1.s}[0], [x12] - .long 0x0e1c3c6c // mov w12, v3.s[3] - .long 0x0d409140 // ld1 {v0.s}[1], [x10] - .long 0x1e26006a // fmov w10, s3 - .long 0xbd400c43 // ldr s3, [x2,#12] - .long 0x6f280442 // ushr v2.4s, v2.4s, #24 - .long 0x4e21d842 // scvtf v2.4s, v2.4s - .long 0x8b2a490a // add x10, x8, w10, uxtw #2 - .long 0x4f839043 // fmul v3.4s, v2.4s, v3.s[0] - .long 0x0d408142 // ld1 {v2.s}[0], [x10] - .long 0x8b2d490a // add x10, x8, w13, uxtw #2 - .long 0x6e140620 // mov v0.s[2], v17.s[0] - .long 0xbc6b5911 // ldr s17, [x8,w11,uxtw #2] - .long 0x0d409121 // ld1 {v1.s}[1], [x9] - .long 0x0d409142 // ld1 {v2.s}[1], [x10] - .long 0x6e1c0600 // mov v0.s[3], v16.s[0] - .long 0xbc6c5910 // ldr s16, [x8,w12,uxtw #2] - .long 0x6e140641 // mov v1.s[2], v18.s[0] - .long 0x6e140622 // mov v2.s[2], v17.s[0] - .long 0x6e1c0661 // mov v1.s[3], v19.s[0] - .long 0x6e1c0602 // mov v2.s[3], v16.s[0] - .long 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0x9100404b // add x11, x2, #0x10 + .long 0x4d40c960 // ld1r {v0.4s}, [x11] + .long 0xd37ef409 // lsl x9, x0, #2 + .long 0xa9402d0a // ldp x10, x11, [x8] + .long 0x3ce96942 // ldr q2, [x10,x9] + .long 0xa9412109 // ldp x9, x8, [x8,#16] + .long 0x4e221c01 // and v1.16b, v0.16b, v2.16b + .long 0x0e143c2c // mov w12, v1.s[2] + .long 0xbc6c5971 // ldr s17, [x11,w12,uxtw #2] + .long 0x1e26002c // fmov w12, s1 + .long 0x6f380443 // ushr v3.4s, v2.4s, #8 + .long 0x6f300450 // ushr v16.4s, v2.4s, #16 + .long 0x8b2c496c // add x12, x11, w12, uxtw #2 + .long 0x0e0c3c2a // mov w10, v1.s[1] + .long 0x0e1c3c2d // mov w13, v1.s[3] + .long 0x4e231c01 // and v1.16b, v0.16b, v3.16b + .long 0x4e301c03 // and v3.16b, v0.16b, v16.16b + .long 0x0d408180 // ld1 {v0.s}[0], [x12] + .long 0x0e143c2c // mov w12, v1.s[2] + .long 0xbc6c5932 // ldr s18, [x9,w12,uxtw #2] + .long 0x1e26002c // fmov w12, s1 + .long 0x8b2a496a // add x10, x11, w10, uxtw #2 + .long 0xbc6d5970 // ldr s16, [x11,w13,uxtw #2] + .long 0x0e0c3c2b // mov w11, v1.s[1] + .long 0x0e1c3c2d // mov w13, v1.s[3] + .long 0x8b2c492c // add x12, x9, w12, uxtw #2 + .long 0xbc6d5933 // ldr s19, [x9,w13,uxtw #2] + .long 0x0e0c3c6d // mov w13, v3.s[1] + .long 0x8b2b4929 // add x9, x9, w11, uxtw #2 + .long 0x0e143c6b // mov w11, v3.s[2] + .long 0x0d408181 // ld1 {v1.s}[0], [x12] + .long 0x0e1c3c6c // mov w12, v3.s[3] + .long 0x0d409140 // ld1 {v0.s}[1], [x10] + .long 0x1e26006a // fmov w10, s3 + .long 0xbd400c43 // ldr s3, [x2,#12] + .long 0x6f280442 // ushr v2.4s, v2.4s, #24 + .long 0x4e21d842 // scvtf v2.4s, v2.4s + .long 0x8b2a490a // add x10, x8, w10, uxtw #2 + .long 0x4f839043 // fmul v3.4s, v2.4s, v3.s[0] + .long 0x0d408142 // ld1 {v2.s}[0], [x10] + .long 0x8b2d490a // add x10, x8, w13, uxtw #2 + .long 0x6e140620 // mov v0.s[2], v17.s[0] + .long 0xbc6b5911 // ldr s17, [x8,w11,uxtw #2] + .long 0x0d409121 // ld1 {v1.s}[1], [x9] + .long 0x0d409142 // ld1 {v2.s}[1], [x10] + .long 0x6e1c0600 // mov v0.s[3], v16.s[0] + .long 0xbc6c5910 // ldr s16, [x8,w12,uxtw #2] + .long 0x6e140641 // mov v1.s[2], v18.s[0] + .long 0x6e140622 // mov v2.s[2], v17.s[0] + .long 0x6e1c0661 // mov v1.s[3], v19.s[0] + .long 0x6e1c0602 // mov v2.s[3], v16.s[0] + .long 0xd61f0060 // br x3 .globl _sk_load_8888_aarch64 _sk_load_8888_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0xd37ef409 // lsl x9, x0, #2 - .long 0xbd400c42 // ldr s2, [x2,#12] - .long 0xf9400108 // ldr x8, [x8] - .long 0x3ce96900 // ldr q0, [x8,x9] - .long 0x91004048 // add x8, x2, #0x10 - .long 0x4d40c901 // ld1r {v1.4s}, [x8] - .long 0x6f380410 // ushr v16.4s, v0.4s, #8 - .long 0x6f300411 // ushr v17.4s, v0.4s, #16 - .long 0x4e201c23 // and v3.16b, v1.16b, v0.16b - .long 0x6f280400 // ushr v0.4s, v0.4s, #24 - .long 0x4e301c30 // and v16.16b, v1.16b, v16.16b - .long 0x4e311c21 // and v1.16b, v1.16b, v17.16b - .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 0x4f829060 // fmul v0.4s, v3.4s, v2.s[0] - .long 0x4f829223 // fmul v3.4s, v17.4s, v2.s[0] - .long 0x4f829201 // fmul v1.4s, v16.4s, v2.s[0] - .long 0x4f829242 // fmul v2.4s, v18.4s, v2.s[0] - .long 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0xd37ef409 // lsl x9, x0, #2 + .long 0xbd400c42 // ldr s2, [x2,#12] + .long 0xf9400108 // ldr x8, [x8] + .long 0x3ce96900 // ldr q0, [x8,x9] + .long 0x91004048 // add x8, x2, #0x10 + .long 0x4d40c901 // ld1r {v1.4s}, [x8] + .long 0x6f380410 // ushr v16.4s, v0.4s, #8 + .long 0x6f300411 // ushr v17.4s, v0.4s, #16 + .long 0x4e201c23 // and v3.16b, v1.16b, v0.16b + .long 0x6f280400 // ushr v0.4s, v0.4s, #24 + .long 0x4e301c30 // and v16.16b, v1.16b, v16.16b + .long 0x4e311c21 // and v1.16b, v1.16b, v17.16b + .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 0x4f829060 // fmul v0.4s, v3.4s, v2.s[0] + .long 0x4f829223 // fmul v3.4s, v17.4s, v2.s[0] + .long 0x4f829201 // fmul v1.4s, v16.4s, v2.s[0] + .long 0x4f829242 // fmul v2.4s, v18.4s, v2.s[0] + .long 0xd61f0060 // br x3 .globl _sk_store_8888_aarch64 _sk_store_8888_aarch64: - .long 0xbd400850 // ldr s16, [x2,#8] - .long 0xf9400028 // ldr x8, [x1] - .long 0xd37ef409 // lsl x9, x0, #2 - .long 0x4f909032 // fmul v18.4s, v1.4s, v16.s[0] - .long 0x4f909011 // fmul v17.4s, v0.4s, v16.s[0] - .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s - .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 0x4f909052 // fmul v18.4s, v2.4s, v16.s[0] - .long 0xf9400108 // ldr x8, [x8] - .long 0x4f909070 // fmul v16.4s, v3.4s, v16.s[0] - .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s - .long 0x6e21aa10 // fcvtnu v16.4s, v16.4s - .long 0x4f305652 // shl v18.4s, v18.4s, #16 - .long 0x4eb21e31 // orr v17.16b, v17.16b, v18.16b - .long 0x4f385610 // shl v16.4s, v16.4s, #24 - .long 0x4eb01e30 // orr v16.16b, v17.16b, v16.16b - .long 0x3ca96910 // str q16, [x8,x9] - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x91004021 // add x1, x1, #0x10 - .long 0xd61f0060 // br x3 + .long 0xbd400850 // ldr s16, [x2,#8] + .long 0xf9400028 // ldr x8, [x1] + .long 0xd37ef409 // lsl x9, x0, #2 + .long 0x4f909032 // fmul v18.4s, v1.4s, v16.s[0] + .long 0x4f909011 // fmul v17.4s, v0.4s, v16.s[0] + .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s + .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 0x4f909052 // fmul v18.4s, v2.4s, v16.s[0] + .long 0xf9400108 // ldr x8, [x8] + .long 0x4f909070 // fmul v16.4s, v3.4s, v16.s[0] + .long 0x6e21aa52 // fcvtnu v18.4s, v18.4s + .long 0x6e21aa10 // fcvtnu v16.4s, v16.4s + .long 0x4f305652 // shl v18.4s, v18.4s, #16 + .long 0x4eb21e31 // orr v17.16b, v17.16b, v18.16b + .long 0x4f385610 // shl v16.4s, v16.4s, #24 + .long 0x4eb01e30 // orr v16.16b, v17.16b, v16.16b + .long 0x3ca96910 // str q16, [x8,x9] + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x91004021 // add x1, x1, #0x10 + .long 0xd61f0060 // br x3 .globl _sk_load_f16_aarch64 _sk_load_f16_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0xf9400108 // ldr x8, [x8] - .long 0x8b000d08 // add x8, x8, x0, lsl #3 - .long 0x0c400510 // ld4 {v16.4h-v19.4h}, [x8] - .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 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0xf9400108 // ldr x8, [x8] + .long 0x8b000d08 // add x8, x8, x0, lsl #3 + .long 0x0c400510 // ld4 {v16.4h-v19.4h}, [x8] + .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 0xd61f0060 // br x3 .globl _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 0xf9400108 // ldr x8, [x8] - .long 0x0e216873 // fcvtn v19.4h, v3.4s - .long 0x8b000d08 // add x8, x8, x0, lsl #3 - .long 0x0c000510 // st4 {v16.4h-v19.4h}, [x8] - .long 0xf9400423 // ldr x3, [x1,#8] - .long 0x91004021 // add x1, x1, #0x10 - .long 0xd61f0060 // br x3 + .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 0xf9400108 // ldr x8, [x8] + .long 0x0e216873 // fcvtn v19.4h, v3.4s + .long 0x8b000d08 // add x8, x8, x0, lsl #3 + .long 0x0c000510 // st4 {v16.4h-v19.4h}, [x8] + .long 0xf9400423 // ldr x3, [x1,#8] + .long 0x91004021 // add x1, x1, #0x10 + .long 0xd61f0060 // br x3 .globl _sk_clamp_x_aarch64 _sk_clamp_x_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0x6f07e7f0 // movi v16.2d, #0xffffffffffffffff - .long 0x6f00e411 // movi v17.2d, #0x0 - .long 0x4d40c912 // ld1r {v18.4s}, [x8] - .long 0x4eb08650 // add v16.4s, v18.4s, v16.4s - .long 0x4eb0f400 // fmin v0.4s, v0.4s, v16.4s - .long 0x4e20f620 // fmax v0.4s, v17.4s, v0.4s - .long 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0x6f07e7f0 // movi v16.2d, #0xffffffffffffffff + .long 0x6f00e411 // movi v17.2d, #0x0 + .long 0x4d40c912 // ld1r {v18.4s}, [x8] + .long 0x4eb08650 // add v16.4s, v18.4s, v16.4s + .long 0x4eb0f400 // fmin v0.4s, v0.4s, v16.4s + .long 0x4e20f620 // fmax v0.4s, v17.4s, v0.4s + .long 0xd61f0060 // br x3 .globl _sk_clamp_y_aarch64 _sk_clamp_y_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0x6f07e7f0 // movi v16.2d, #0xffffffffffffffff - .long 0x6f00e411 // movi v17.2d, #0x0 - .long 0x4d40c912 // ld1r {v18.4s}, [x8] - .long 0x4eb08650 // add v16.4s, v18.4s, v16.4s - .long 0x4eb0f421 // fmin v1.4s, v1.4s, v16.4s - .long 0x4e21f621 // fmax v1.4s, v17.4s, v1.4s - .long 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0x6f07e7f0 // movi v16.2d, #0xffffffffffffffff + .long 0x6f00e411 // movi v17.2d, #0x0 + .long 0x4d40c912 // ld1r {v18.4s}, [x8] + .long 0x4eb08650 // add v16.4s, v18.4s, v16.4s + .long 0x4eb0f421 // fmin v1.4s, v1.4s, v16.4s + .long 0x4e21f621 // fmax v1.4s, v17.4s, v1.4s + .long 0xd61f0060 // br x3 .globl _sk_matrix_2x3_aarch64 _sk_matrix_2x3_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [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 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [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 0xd61f0060 // br x3 .globl _sk_matrix_3x4_aarch64 _sk_matrix_3x4_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [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 0x2d415d14 // ldp s20, s23, [x8,#8] - .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 0x4f971030 // fmla v16.4s, v1.4s, v23.s[0] - .long 0x4e20ce70 // fmla v16.4s, v19.4s, v0.4s - .long 0x4f821031 // fmla v17.4s, v1.4s, v2.s[0] - .long 0xbd400122 // ldr s2, [x9] - .long 0x4f951032 // fmla v18.4s, v1.4s, v21.s[0] - .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 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [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 0x2d415d14 // ldp s20, s23, [x8,#8] + .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 0x4f971030 // fmla v16.4s, v1.4s, v23.s[0] + .long 0x4e20ce70 // fmla v16.4s, v19.4s, v0.4s + .long 0x4f821031 // fmla v17.4s, v1.4s, v2.s[0] + .long 0xbd400122 // ldr s2, [x9] + .long 0x4f951032 // fmla v18.4s, v1.4s, v21.s[0] + .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 0xd61f0060 // br x3 .globl _sk_linear_gradient_2stops_aarch64 _sk_linear_gradient_2stops_aarch64: - .long 0xa8c10c28 // ldp x8, x3, [x1],#16 - .long 0xad404503 // ldp q3, q17, [x8] - .long 0x4e040470 // dup v16.4s, v3.s[0] - .long 0x4e0c0461 // dup v1.4s, v3.s[1] - .long 0x4e140462 // dup v2.4s, v3.s[2] - .long 0x4e1c0463 // dup v3.4s, v3.s[3] - .long 0x4f911010 // fmla v16.4s, v0.4s, v17.s[0] - .long 0x4fb11001 // fmla v1.4s, v0.4s, v17.s[1] - .long 0x4f911802 // fmla v2.4s, v0.4s, v17.s[2] - .long 0x4fb11803 // fmla v3.4s, v0.4s, v17.s[3] - .long 0x4eb01e00 // mov v0.16b, v16.16b - .long 0xd61f0060 // br x3 + .long 0xa8c10c28 // ldp x8, x3, [x1],#16 + .long 0xad404503 // ldp q3, q17, [x8] + .long 0x4e040470 // dup v16.4s, v3.s[0] + .long 0x4e0c0461 // dup v1.4s, v3.s[1] + .long 0x4e140462 // dup v2.4s, v3.s[2] + .long 0x4e1c0463 // dup v3.4s, v3.s[3] + .long 0x4f911010 // fmla v16.4s, v0.4s, v17.s[0] + .long 0x4fb11001 // fmla v1.4s, v0.4s, v17.s[1] + .long 0x4f911802 // fmla v2.4s, v0.4s, v17.s[2] + .long 0x4fb11803 // fmla v3.4s, v0.4s, v17.s[3] + .long 0x4eb01e00 // mov v0.16b, v16.16b + .long 0xd61f0060 // br x3 #elif defined(__arm__) .balign 4 .globl _sk_start_pipeline_vfp4 _sk_start_pipeline_vfp4: - .long 0xe92d41f0 // push {r4, r5, r6, r7, r8, lr} - .long 0xe1a07001 // mov r7, r1 - .long 0xe1a04000 // mov r4, r0 - .long 0xe1a05003 // mov r5, r3 - .long 0xe1a08002 // mov r8, r2 - .long 0xe4976004 // ldr r6, [r7], #4 - .long 0xe2840002 // add r0, r4, #2 - .long 0xea00000d // b 58 - .long 0xf2800010 // vmov.i32 d0, #0 - .long 0xe1a00004 // mov r0, r4 - .long 0xf2801010 // vmov.i32 d1, #0 - .long 0xe1a01007 // mov r1, r7 - .long 0xf2802010 // vmov.i32 d2, #0 - .long 0xe1a02008 // mov r2, r8 - .long 0xf2803010 // vmov.i32 d3, #0 - .long 0xf2804010 // vmov.i32 d4, #0 - .long 0xf2805010 // vmov.i32 d5, #0 - .long 0xf2806010 // vmov.i32 d6, #0 - .long 0xf2807010 // vmov.i32 d7, #0 - .long 0xe12fff36 // blx r6 - .long 0xe2840004 // add r0, r4, #4 - .long 0xe2844002 // add r4, r4, #2 - .long 0xe1500005 // cmp r0, r5 - .long 0x9affffef // bls 20 - .long 0xe1a00004 // mov r0, r4 - .long 0xe8bd81f0 // pop {r4, r5, r6, r7, r8, pc} + .long 0xe92d41f0 // push {r4, r5, r6, r7, r8, lr} + .long 0xe1a07001 // mov r7, r1 + .long 0xe1a04000 // mov r4, r0 + .long 0xe1a05003 // mov r5, r3 + .long 0xe1a08002 // mov r8, r2 + .long 0xe4976004 // ldr r6, [r7], #4 + .long 0xe2840002 // add r0, r4, #2 + .long 0xea00000d // b 58 + .long 0xf2800010 // vmov.i32 d0, #0 + .long 0xe1a00004 // mov r0, r4 + .long 0xf2801010 // vmov.i32 d1, #0 + .long 0xe1a01007 // mov r1, r7 + .long 0xf2802010 // vmov.i32 d2, #0 + .long 0xe1a02008 // mov r2, r8 + .long 0xf2803010 // vmov.i32 d3, #0 + .long 0xf2804010 // vmov.i32 d4, #0 + .long 0xf2805010 // vmov.i32 d5, #0 + .long 0xf2806010 // vmov.i32 d6, #0 + .long 0xf2807010 // vmov.i32 d7, #0 + .long 0xe12fff36 // blx r6 + .long 0xe2840004 // add r0, r4, #4 + .long 0xe2844002 // add r4, r4, #2 + .long 0xe1500005 // cmp r0, r5 + .long 0x9affffef // bls 20 + .long 0xe1a00004 // mov r0, r4 + .long 0xe8bd81f0 // pop {r4, r5, r6, r7, r8, pc} .globl _sk_just_return_vfp4 _sk_just_return_vfp4: - .long 0xe12fff1e // bx lr + .long 0xe12fff1e // bx lr .globl _sk_seed_shader_vfp4 _sk_seed_shader_vfp4: - .long 0xe5913000 // ldr r3, [r1] - .long 0xee800b90 // vdup.32 d16, r0 - .long 0xf3fb0620 // vcvt.f32.s32 d16, d16 - .long 0xedd23b05 // vldr d19, [r2, #20] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xf2803010 // vmov.i32 d3, #0 - .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] - .long 0xe2823004 // add r3, r2, #4 - .long 0xf3fb1621 // vcvt.f32.s32 d17, d17 - .long 0xe2811008 // add r1, r1, #8 - .long 0xf4e32c9f // vld1.32 {d18[]}, [r3 :32] - .long 0xf2804010 // vmov.i32 d4, #0 - .long 0xf2400da2 // vadd.f32 d16, d16, d18 - .long 0xf2805010 // vmov.i32 d5, #0 - .long 0xf4a22c9f // vld1.32 {d2[]}, [r2 :32] - .long 0xf2011da2 // vadd.f32 d1, d17, d18 - .long 0xf2806010 // vmov.i32 d6, #0 - .long 0xf2030da0 // vadd.f32 d0, d19, d16 - .long 0xf2807010 // vmov.i32 d7, #0 - .long 0xe12fff1c // bx ip + .long 0xe5913000 // ldr r3, [r1] + .long 0xee800b90 // vdup.32 d16, r0 + .long 0xf3fb0620 // vcvt.f32.s32 d16, d16 + .long 0xedd23b05 // vldr d19, [r2, #20] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xf2803010 // vmov.i32 d3, #0 + .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] + .long 0xe2823004 // add r3, r2, #4 + .long 0xf3fb1621 // vcvt.f32.s32 d17, d17 + .long 0xe2811008 // add r1, r1, #8 + .long 0xf4e32c9f // vld1.32 {d18[]}, [r3 :32] + .long 0xf2804010 // vmov.i32 d4, #0 + .long 0xf2400da2 // vadd.f32 d16, d16, d18 + .long 0xf2805010 // vmov.i32 d5, #0 + .long 0xf4a22c9f // vld1.32 {d2[]}, [r2 :32] + .long 0xf2011da2 // vadd.f32 d1, d17, d18 + .long 0xf2806010 // vmov.i32 d6, #0 + .long 0xf2030da0 // vadd.f32 d0, d19, d16 + .long 0xf2807010 // vmov.i32 d7, #0 + .long 0xe12fff1c // bx ip .globl _sk_constant_color_vfp4 _sk_constant_color_vfp4: - .long 0xe5913000 // ldr r3, [r1] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xf4630a0f // vld1.8 {d16-d17}, [r3] - .long 0xf3b40c20 // vdup.32 d0, d16[0] - .long 0xf3bc1c20 // vdup.32 d1, d16[1] - .long 0xf3b42c21 // vdup.32 d2, d17[0] - .long 0xf3bc3c21 // vdup.32 d3, d17[1] - .long 0xe12fff1c // bx ip + .long 0xe5913000 // ldr r3, [r1] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xf4630a0f // vld1.8 {d16-d17}, [r3] + .long 0xf3b40c20 // vdup.32 d0, d16[0] + .long 0xf3bc1c20 // vdup.32 d1, d16[1] + .long 0xf3b42c21 // vdup.32 d2, d17[0] + .long 0xf3bc3c21 // vdup.32 d3, d17[1] + .long 0xe12fff1c // bx ip .globl _sk_clear_vfp4 _sk_clear_vfp4: - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xf2800010 // vmov.i32 d0, #0 - .long 0xf2801010 // vmov.i32 d1, #0 - .long 0xe2811008 // add r1, r1, #8 - .long 0xf2802010 // vmov.i32 d2, #0 - .long 0xf2803010 // vmov.i32 d3, #0 - .long 0xe12fff13 // bx r3 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xf2800010 // vmov.i32 d0, #0 + .long 0xf2801010 // vmov.i32 d1, #0 + .long 0xe2811008 // add r1, r1, #8 + .long 0xf2802010 // vmov.i32 d2, #0 + .long 0xf2803010 // vmov.i32 d3, #0 + .long 0xe12fff13 // bx r3 .globl _sk_plus__vfp4 _sk_plus__vfp4: - .long 0xf2000d04 // vadd.f32 d0, d0, d4 - .long 0xe2813008 // add r3, r1, #8 - .long 0xf2011d05 // vadd.f32 d1, d1, d5 - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xf2022d06 // vadd.f32 d2, d2, d6 - .long 0xe1a01003 // mov r1, r3 - .long 0xf2033d07 // vadd.f32 d3, d3, d7 - .long 0xe12fff1c // bx ip + .long 0xf2000d04 // vadd.f32 d0, d0, d4 + .long 0xe2813008 // add r3, r1, #8 + .long 0xf2011d05 // vadd.f32 d1, d1, d5 + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xf2022d06 // vadd.f32 d2, d2, d6 + .long 0xe1a01003 // mov r1, r3 + .long 0xf2033d07 // vadd.f32 d3, d3, d7 + .long 0xe12fff1c // bx ip .globl _sk_srcover_vfp4 _sk_srcover_vfp4: - .long 0xf4e20c9f // vld1.32 {d16[]}, [r2 :32] - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xf2600d83 // vsub.f32 d16, d16, d3 - .long 0xe2811008 // add r1, r1, #8 - .long 0xf2040c30 // vfma.f32 d0, d4, d16 - .long 0xf2051c30 // vfma.f32 d1, d5, d16 - .long 0xf2062c30 // vfma.f32 d2, d6, d16 - .long 0xf2073c30 // vfma.f32 d3, d7, d16 - .long 0xe12fff13 // bx r3 + .long 0xf4e20c9f // vld1.32 {d16[]}, [r2 :32] + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xf2600d83 // vsub.f32 d16, d16, d3 + .long 0xe2811008 // add r1, r1, #8 + .long 0xf2040c30 // vfma.f32 d0, d4, d16 + .long 0xf2051c30 // vfma.f32 d1, d5, d16 + .long 0xf2062c30 // vfma.f32 d2, d6, d16 + .long 0xf2073c30 // vfma.f32 d3, d7, d16 + .long 0xe12fff13 // bx r3 .globl _sk_dstover_vfp4 _sk_dstover_vfp4: - .long 0xf4e20c9f // vld1.32 {d16[]}, [r2 :32] - .long 0xf2651115 // vorr d17, d5, d5 - .long 0xf2604d87 // vsub.f32 d20, d16, d7 - .long 0xf2640114 // vorr d16, d4, d4 - .long 0xf2662116 // vorr d18, d6, d6 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xf2673117 // vorr d19, d7, d7 - .long 0xe2811008 // add r1, r1, #8 - .long 0xf2400c34 // vfma.f32 d16, d0, d20 - .long 0xf2411c34 // vfma.f32 d17, d1, d20 - .long 0xf2422c34 // vfma.f32 d18, d2, d20 - .long 0xf2433c34 // vfma.f32 d19, d3, d20 - .long 0xf22001b0 // vorr d0, d16, d16 - .long 0xf22111b1 // vorr d1, d17, d17 - .long 0xf22221b2 // vorr d2, d18, d18 - .long 0xf22331b3 // vorr d3, d19, d19 - .long 0xe12fff13 // bx r3 + .long 0xf4e20c9f // vld1.32 {d16[]}, [r2 :32] + .long 0xf2651115 // vorr d17, d5, d5 + .long 0xf2604d87 // vsub.f32 d20, d16, d7 + .long 0xf2640114 // vorr d16, d4, d4 + .long 0xf2662116 // vorr d18, d6, d6 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xf2673117 // vorr d19, d7, d7 + .long 0xe2811008 // add r1, r1, #8 + .long 0xf2400c34 // vfma.f32 d16, d0, d20 + .long 0xf2411c34 // vfma.f32 d17, d1, d20 + .long 0xf2422c34 // vfma.f32 d18, d2, d20 + .long 0xf2433c34 // vfma.f32 d19, d3, d20 + .long 0xf22001b0 // vorr d0, d16, d16 + .long 0xf22111b1 // vorr d1, d17, d17 + .long 0xf22221b2 // vorr d2, d18, d18 + .long 0xf22331b3 // vorr d3, d19, d19 + .long 0xe12fff13 // bx r3 .globl _sk_clamp_0_vfp4 _sk_clamp_0_vfp4: - .long 0xf2c00010 // vmov.i32 d16, #0 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xf2000f20 // vmax.f32 d0, d0, d16 - .long 0xf2011f20 // vmax.f32 d1, d1, d16 - .long 0xf2022f20 // vmax.f32 d2, d2, d16 - .long 0xf2033f20 // vmax.f32 d3, d3, d16 - .long 0xe12fff13 // bx r3 + .long 0xf2c00010 // vmov.i32 d16, #0 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xf2000f20 // vmax.f32 d0, d0, d16 + .long 0xf2011f20 // vmax.f32 d1, d1, d16 + .long 0xf2022f20 // vmax.f32 d2, d2, d16 + .long 0xf2033f20 // vmax.f32 d3, d3, d16 + .long 0xe12fff13 // bx r3 .globl _sk_clamp_1_vfp4 _sk_clamp_1_vfp4: - .long 0xf4e20c9f // vld1.32 {d16[]}, [r2 :32] - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xf2200f20 // vmin.f32 d0, d0, d16 - .long 0xe2811008 // add r1, r1, #8 - .long 0xf2211f20 // vmin.f32 d1, d1, d16 - .long 0xf2222f20 // vmin.f32 d2, d2, d16 - .long 0xf2233f20 // vmin.f32 d3, d3, d16 - .long 0xe12fff13 // bx r3 + .long 0xf4e20c9f // vld1.32 {d16[]}, [r2 :32] + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xf2200f20 // vmin.f32 d0, d0, d16 + .long 0xe2811008 // add r1, r1, #8 + .long 0xf2211f20 // vmin.f32 d1, d1, d16 + .long 0xf2222f20 // vmin.f32 d2, d2, d16 + .long 0xf2233f20 // vmin.f32 d3, d3, d16 + .long 0xe12fff13 // bx r3 .globl _sk_clamp_a_vfp4 _sk_clamp_a_vfp4: - .long 0xf4e20c9f // vld1.32 {d16[]}, [r2 :32] - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xf2233f20 // vmin.f32 d3, d3, d16 - .long 0xe2811008 // add r1, r1, #8 - .long 0xf2200f03 // vmin.f32 d0, d0, d3 - .long 0xf2211f03 // vmin.f32 d1, d1, d3 - .long 0xf2222f03 // vmin.f32 d2, d2, d3 - .long 0xe12fff13 // bx r3 + .long 0xf4e20c9f // vld1.32 {d16[]}, [r2 :32] + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xf2233f20 // vmin.f32 d3, d3, d16 + .long 0xe2811008 // add r1, r1, #8 + .long 0xf2200f03 // vmin.f32 d0, d0, d3 + .long 0xf2211f03 // vmin.f32 d1, d1, d3 + .long 0xf2222f03 // vmin.f32 d2, d2, d3 + .long 0xe12fff13 // bx r3 .globl _sk_set_rgb_vfp4 _sk_set_rgb_vfp4: - .long 0xe92d4800 // push {fp, lr} - .long 0xe591e000 // ldr lr, [r1] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xe28e3008 // add r3, lr, #8 - .long 0xf4ae0c9f // vld1.32 {d0[]}, [lr :32] - .long 0xf4a32c9f // vld1.32 {d2[]}, [r3 :32] - .long 0xe28e3004 // add r3, lr, #4 - .long 0xf4a31c9f // vld1.32 {d1[]}, [r3 :32] - .long 0xe8bd4800 // pop {fp, lr} - .long 0xe12fff1c // bx ip + .long 0xe92d4800 // push {fp, lr} + .long 0xe591e000 // ldr lr, [r1] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xe28e3008 // add r3, lr, #8 + .long 0xf4ae0c9f // vld1.32 {d0[]}, [lr :32] + .long 0xf4a32c9f // vld1.32 {d2[]}, [r3 :32] + .long 0xe28e3004 // add r3, lr, #4 + .long 0xf4a31c9f // vld1.32 {d1[]}, [r3 :32] + .long 0xe8bd4800 // pop {fp, lr} + .long 0xe12fff1c // bx ip .globl _sk_swap_rb_vfp4 _sk_swap_rb_vfp4: - .long 0xeef00b40 // vmov.f64 d16, d0 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xeeb00b42 // vmov.f64 d0, d2 - .long 0xeeb02b60 // vmov.f64 d2, d16 - .long 0xe12fff13 // bx r3 + .long 0xeef00b40 // vmov.f64 d16, d0 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xeeb00b42 // vmov.f64 d0, d2 + .long 0xeeb02b60 // vmov.f64 d2, d16 + .long 0xe12fff13 // bx r3 .globl _sk_swap_vfp4 _sk_swap_vfp4: - .long 0xeef00b43 // vmov.f64 d16, d3 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xeef01b42 // vmov.f64 d17, d2 - .long 0xeef02b41 // vmov.f64 d18, d1 - .long 0xeef03b40 // vmov.f64 d19, d0 - .long 0xeeb00b44 // vmov.f64 d0, d4 - .long 0xeeb01b45 // vmov.f64 d1, d5 - .long 0xeeb02b46 // vmov.f64 d2, d6 - .long 0xeeb03b47 // vmov.f64 d3, d7 - .long 0xeeb04b63 // vmov.f64 d4, d19 - .long 0xeeb05b62 // vmov.f64 d5, d18 - .long 0xeeb06b61 // vmov.f64 d6, d17 - .long 0xeeb07b60 // vmov.f64 d7, d16 - .long 0xe12fff13 // bx r3 + .long 0xeef00b43 // vmov.f64 d16, d3 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xeef01b42 // vmov.f64 d17, d2 + .long 0xeef02b41 // vmov.f64 d18, d1 + .long 0xeef03b40 // vmov.f64 d19, d0 + .long 0xeeb00b44 // vmov.f64 d0, d4 + .long 0xeeb01b45 // vmov.f64 d1, d5 + .long 0xeeb02b46 // vmov.f64 d2, d6 + .long 0xeeb03b47 // vmov.f64 d3, d7 + .long 0xeeb04b63 // vmov.f64 d4, d19 + .long 0xeeb05b62 // vmov.f64 d5, d18 + .long 0xeeb06b61 // vmov.f64 d6, d17 + .long 0xeeb07b60 // vmov.f64 d7, d16 + .long 0xe12fff13 // bx r3 .globl _sk_move_src_dst_vfp4 _sk_move_src_dst_vfp4: - .long 0xeeb04b40 // vmov.f64 d4, d0 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xeeb05b41 // vmov.f64 d5, d1 - .long 0xeeb06b42 // vmov.f64 d6, d2 - .long 0xeeb07b43 // vmov.f64 d7, d3 - .long 0xe12fff13 // bx r3 + .long 0xeeb04b40 // vmov.f64 d4, d0 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xeeb05b41 // vmov.f64 d5, d1 + .long 0xeeb06b42 // vmov.f64 d6, d2 + .long 0xeeb07b43 // vmov.f64 d7, d3 + .long 0xe12fff13 // bx r3 .globl _sk_move_dst_src_vfp4 _sk_move_dst_src_vfp4: - .long 0xeeb00b44 // vmov.f64 d0, d4 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xeeb01b45 // vmov.f64 d1, d5 - .long 0xeeb02b46 // vmov.f64 d2, d6 - .long 0xeeb03b47 // vmov.f64 d3, d7 - .long 0xe12fff13 // bx r3 + .long 0xeeb00b44 // vmov.f64 d0, d4 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xeeb01b45 // vmov.f64 d1, d5 + .long 0xeeb02b46 // vmov.f64 d2, d6 + .long 0xeeb03b47 // vmov.f64 d3, d7 + .long 0xe12fff13 // bx r3 .globl _sk_premul_vfp4 _sk_premul_vfp4: - .long 0xf3000d13 // vmul.f32 d0, d0, d3 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xf3011d13 // vmul.f32 d1, d1, d3 - .long 0xe2811008 // add r1, r1, #8 - .long 0xf3022d13 // vmul.f32 d2, d2, d3 - .long 0xe12fff13 // bx r3 + .long 0xf3000d13 // vmul.f32 d0, d0, d3 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xf3011d13 // vmul.f32 d1, d1, d3 + .long 0xe2811008 // add r1, r1, #8 + .long 0xf3022d13 // vmul.f32 d2, d2, d3 + .long 0xe12fff13 // bx r3 .globl _sk_unpremul_vfp4 _sk_unpremul_vfp4: - .long 0xed2d8b04 // vpush {d8-d9} - .long 0xed928a00 // vldr s16, [r2] - .long 0xf2c00010 // vmov.i32 d16, #0 - .long 0xf3f91503 // vceq.f32 d17, d3, #0 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xeec89a23 // vdiv.f32 s19, s16, s7 - .long 0xe2811008 // add r1, r1, #8 - .long 0xee889a03 // vdiv.f32 s18, s16, s6 - .long 0xf3501199 // vbsl d17, d16, d9 - .long 0xf3010d90 // vmul.f32 d0, d17, d0 - .long 0xf3011d91 // vmul.f32 d1, d17, d1 - .long 0xf3012d92 // vmul.f32 d2, d17, d2 - .long 0xecbd8b04 // vpop {d8-d9} - .long 0xe12fff13 // bx r3 + .long 0xed2d8b04 // vpush {d8-d9} + .long 0xed928a00 // vldr s16, [r2] + .long 0xf2c00010 // vmov.i32 d16, #0 + .long 0xf3f91503 // vceq.f32 d17, d3, #0 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xeec89a23 // vdiv.f32 s19, s16, s7 + .long 0xe2811008 // add r1, r1, #8 + .long 0xee889a03 // vdiv.f32 s18, s16, s6 + .long 0xf3501199 // vbsl d17, d16, d9 + .long 0xf3010d90 // vmul.f32 d0, d17, d0 + .long 0xf3011d91 // vmul.f32 d1, d17, d1 + .long 0xf3012d92 // vmul.f32 d2, d17, d2 + .long 0xecbd8b04 // vpop {d8-d9} + .long 0xe12fff13 // bx r3 .globl _sk_from_srgb_vfp4 _sk_from_srgb_vfp4: - .long 0xed2d8b02 // vpush {d8} - .long 0xe282303c // add r3, r2, #60 - .long 0xed928a10 // vldr s16, [r2, #64] - .long 0xf3402d10 // vmul.f32 d18, d0, d0 - .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] - .long 0xe2823038 // add r3, r2, #56 - .long 0xf3413d11 // vmul.f32 d19, d1, d1 - .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] - .long 0xe2823044 // add r3, r2, #68 - .long 0xf26141b1 // vorr d20, d17, d17 - .long 0xf26171b1 // vorr d23, d17, d17 - .long 0xf4e38c9f // vld1.32 {d24[]}, [r3 :32] - .long 0xf2404c30 // vfma.f32 d20, d0, d16 - .long 0xe2823034 // add r3, r2, #52 - .long 0xf2417c30 // vfma.f32 d23, d1, d16 - .long 0xf2421c30 // vfma.f32 d17, d2, d16 - .long 0xf3425d12 // vmul.f32 d21, d2, d2 - .long 0xf2e16948 // vmul.f32 d22, d1, d8[0] - .long 0xf2e00948 // vmul.f32 d16, d0, d8[0] - .long 0xf2e29948 // vmul.f32 d25, d2, d8[0] - .long 0xf3282e82 // vcgt.f32 d2, d24, d2 - .long 0xf3281e81 // vcgt.f32 d1, d24, d1 - .long 0xf3280e80 // vcgt.f32 d0, d24, d0 - .long 0xf4e38c9f // vld1.32 {d24[]}, [r3 :32] - .long 0xf268a1b8 // vorr d26, d24, d24 - .long 0xf242acb4 // vfma.f32 d26, d18, d20 - .long 0xf26821b8 // vorr d18, d24, d24 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xf2432cb7 // vfma.f32 d18, d19, d23 - .long 0xe2811008 // add r1, r1, #8 - .long 0xf2458cb1 // vfma.f32 d24, d21, d17 - .long 0xf31001ba // vbsl d0, d16, d26 - .long 0xf31611b2 // vbsl d1, d22, d18 - .long 0xf31921b8 // vbsl d2, d25, d24 - .long 0xecbd8b02 // vpop {d8} - .long 0xe12fff13 // bx r3 + .long 0xed2d8b02 // vpush {d8} + .long 0xe282303c // add r3, r2, #60 + .long 0xed928a10 // vldr s16, [r2, #64] + .long 0xf3402d10 // vmul.f32 d18, d0, d0 + .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] + .long 0xe2823038 // add r3, r2, #56 + .long 0xf3413d11 // vmul.f32 d19, d1, d1 + .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] + .long 0xe2823044 // add r3, r2, #68 + .long 0xf26141b1 // vorr d20, d17, d17 + .long 0xf26171b1 // vorr d23, d17, d17 + .long 0xf4e38c9f // vld1.32 {d24[]}, [r3 :32] + .long 0xf2404c30 // vfma.f32 d20, d0, d16 + .long 0xe2823034 // add r3, r2, #52 + .long 0xf2417c30 // vfma.f32 d23, d1, d16 + .long 0xf2421c30 // vfma.f32 d17, d2, d16 + .long 0xf3425d12 // vmul.f32 d21, d2, d2 + .long 0xf2e16948 // vmul.f32 d22, d1, d8[0] + .long 0xf2e00948 // vmul.f32 d16, d0, d8[0] + .long 0xf2e29948 // vmul.f32 d25, d2, d8[0] + .long 0xf3282e82 // vcgt.f32 d2, d24, d2 + .long 0xf3281e81 // vcgt.f32 d1, d24, d1 + .long 0xf3280e80 // vcgt.f32 d0, d24, d0 + .long 0xf4e38c9f // vld1.32 {d24[]}, [r3 :32] + .long 0xf268a1b8 // vorr d26, d24, d24 + .long 0xf242acb4 // vfma.f32 d26, d18, d20 + .long 0xf26821b8 // vorr d18, d24, d24 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xf2432cb7 // vfma.f32 d18, d19, d23 + .long 0xe2811008 // add r1, r1, #8 + .long 0xf2458cb1 // vfma.f32 d24, d21, d17 + .long 0xf31001ba // vbsl d0, d16, d26 + .long 0xf31611b2 // vbsl d1, d22, d18 + .long 0xf31921b8 // vbsl d2, d25, d24 + .long 0xecbd8b02 // vpop {d8} + .long 0xe12fff13 // bx r3 .globl _sk_to_srgb_vfp4 _sk_to_srgb_vfp4: - .long 0xed2d8b02 // vpush {d8} - .long 0xf3fb0580 // vrsqrte.f32 d16, d0 - .long 0xe2823050 // add r3, r2, #80 - .long 0xf3fb1581 // vrsqrte.f32 d17, d1 - .long 0xed928a12 // vldr s16, [r2, #72] - .long 0xf3fb2582 // vrsqrte.f32 d18, d2 - .long 0xf3403db0 // vmul.f32 d19, d16, d16 - .long 0xf3414db1 // vmul.f32 d20, d17, d17 - .long 0xf3425db2 // vmul.f32 d21, d18, d18 - .long 0xf2603f33 // vrsqrts.f32 d19, d0, d19 - .long 0xf2614f34 // vrsqrts.f32 d20, d1, d20 - .long 0xf2625f35 // vrsqrts.f32 d21, d2, d21 - .long 0xf3400db3 // vmul.f32 d16, d16, d19 - .long 0xf3411db4 // vmul.f32 d17, d17, d20 - .long 0xf3422db5 // vmul.f32 d18, d18, d21 - .long 0xf3fb3520 // vrecpe.f32 d19, d16 - .long 0xf3fb4521 // vrecpe.f32 d20, d17 - .long 0xf3fb6522 // vrecpe.f32 d22, d18 - .long 0xf3fb55a2 // vrsqrte.f32 d21, d18 - .long 0xf3fb75a0 // vrsqrte.f32 d23, d16 - .long 0xf3fb85a1 // vrsqrte.f32 d24, d17 - .long 0xf2409fb3 // vrecps.f32 d25, d16, d19 - .long 0xf241afb4 // vrecps.f32 d26, d17, d20 - .long 0xf242bfb6 // vrecps.f32 d27, d18, d22 - .long 0xf345cdb5 // vmul.f32 d28, d21, d21 - .long 0xf347ddb7 // vmul.f32 d29, d23, d23 - .long 0xf348edb8 // vmul.f32 d30, d24, d24 - .long 0xf2622fbc // vrsqrts.f32 d18, d18, d28 - .long 0xf2600fbd // vrsqrts.f32 d16, d16, d29 - .long 0xf2611fbe // vrsqrts.f32 d17, d17, d30 - .long 0xf3433db9 // vmul.f32 d19, d19, d25 - .long 0xf4e39c9f // vld1.32 {d25[]}, [r3 :32] - .long 0xe2823054 // add r3, r2, #84 - .long 0xf3444dba // vmul.f32 d20, d20, d26 - .long 0xf3466dbb // vmul.f32 d22, d22, d27 - .long 0xf4e3ac9f // vld1.32 {d26[]}, [r3 :32] - .long 0xe282304c // add r3, r2, #76 - .long 0xf26ab1ba // vorr d27, d26, d26 - .long 0xf249bcb3 // vfma.f32 d27, d25, d19 - .long 0xf26a31ba // vorr d19, d26, d26 - .long 0xf2493cb4 // vfma.f32 d19, d25, d20 - .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] - .long 0xf249acb6 // vfma.f32 d26, d25, d22 - .long 0xe2823058 // add r3, r2, #88 - .long 0xf3452db2 // vmul.f32 d18, d21, d18 - .long 0xf3470db0 // vmul.f32 d16, d23, d16 - .long 0xf3481db1 // vmul.f32 d17, d24, d17 - .long 0xf2e05948 // vmul.f32 d21, d0, d8[0] - .long 0xf244bcb0 // vfma.f32 d27, d20, d16 - .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] - .long 0xf2443cb1 // vfma.f32 d19, d20, d17 - .long 0xf244acb2 // vfma.f32 d26, d20, d18 - .long 0xf4e24c9f // vld1.32 {d20[]}, [r2 :32] - .long 0xf2e11948 // vmul.f32 d17, d1, d8[0] - .long 0xf2e22948 // vmul.f32 d18, d2, d8[0] - .long 0xf3201e81 // vcgt.f32 d1, d16, d1 - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xf3200e80 // vcgt.f32 d0, d16, d0 - .long 0xe2811008 // add r1, r1, #8 - .long 0xf3202e82 // vcgt.f32 d2, d16, d2 - .long 0xf2640fab // vmin.f32 d16, d20, d27 - .long 0xf2643fa3 // vmin.f32 d19, d20, d19 - .long 0xf2644faa // vmin.f32 d20, d20, d26 - .long 0xf31501b0 // vbsl d0, d21, d16 - .long 0xf31111b3 // vbsl d1, d17, d19 - .long 0xf31221b4 // vbsl d2, d18, d20 - .long 0xecbd8b02 // vpop {d8} - .long 0xe12fff13 // bx r3 + .long 0xed2d8b02 // vpush {d8} + .long 0xf3fb0580 // vrsqrte.f32 d16, d0 + .long 0xe2823050 // add r3, r2, #80 + .long 0xf3fb1581 // vrsqrte.f32 d17, d1 + .long 0xed928a12 // vldr s16, [r2, #72] + .long 0xf3fb2582 // vrsqrte.f32 d18, d2 + .long 0xf3403db0 // vmul.f32 d19, d16, d16 + .long 0xf3414db1 // vmul.f32 d20, d17, d17 + .long 0xf3425db2 // vmul.f32 d21, d18, d18 + .long 0xf2603f33 // vrsqrts.f32 d19, d0, d19 + .long 0xf2614f34 // vrsqrts.f32 d20, d1, d20 + .long 0xf2625f35 // vrsqrts.f32 d21, d2, d21 + .long 0xf3400db3 // vmul.f32 d16, d16, d19 + .long 0xf3411db4 // vmul.f32 d17, d17, d20 + .long 0xf3422db5 // vmul.f32 d18, d18, d21 + .long 0xf3fb3520 // vrecpe.f32 d19, d16 + .long 0xf3fb4521 // vrecpe.f32 d20, d17 + .long 0xf3fb6522 // vrecpe.f32 d22, d18 + .long 0xf3fb55a2 // vrsqrte.f32 d21, d18 + .long 0xf3fb75a0 // vrsqrte.f32 d23, d16 + .long 0xf3fb85a1 // vrsqrte.f32 d24, d17 + .long 0xf2409fb3 // vrecps.f32 d25, d16, d19 + .long 0xf241afb4 // vrecps.f32 d26, d17, d20 + .long 0xf242bfb6 // vrecps.f32 d27, d18, d22 + .long 0xf345cdb5 // vmul.f32 d28, d21, d21 + .long 0xf347ddb7 // vmul.f32 d29, d23, d23 + .long 0xf348edb8 // vmul.f32 d30, d24, d24 + .long 0xf2622fbc // vrsqrts.f32 d18, d18, d28 + .long 0xf2600fbd // vrsqrts.f32 d16, d16, d29 + .long 0xf2611fbe // vrsqrts.f32 d17, d17, d30 + .long 0xf3433db9 // vmul.f32 d19, d19, d25 + .long 0xf4e39c9f // vld1.32 {d25[]}, [r3 :32] + .long 0xe2823054 // add r3, r2, #84 + .long 0xf3444dba // vmul.f32 d20, d20, d26 + .long 0xf3466dbb // vmul.f32 d22, d22, d27 + .long 0xf4e3ac9f // vld1.32 {d26[]}, [r3 :32] + .long 0xe282304c // add r3, r2, #76 + .long 0xf26ab1ba // vorr d27, d26, d26 + .long 0xf249bcb3 // vfma.f32 d27, d25, d19 + .long 0xf26a31ba // vorr d19, d26, d26 + .long 0xf2493cb4 // vfma.f32 d19, d25, d20 + .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] + .long 0xf249acb6 // vfma.f32 d26, d25, d22 + .long 0xe2823058 // add r3, r2, #88 + .long 0xf3452db2 // vmul.f32 d18, d21, d18 + .long 0xf3470db0 // vmul.f32 d16, d23, d16 + .long 0xf3481db1 // vmul.f32 d17, d24, d17 + .long 0xf2e05948 // vmul.f32 d21, d0, d8[0] + .long 0xf244bcb0 // vfma.f32 d27, d20, d16 + .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] + .long 0xf2443cb1 // vfma.f32 d19, d20, d17 + .long 0xf244acb2 // vfma.f32 d26, d20, d18 + .long 0xf4e24c9f // vld1.32 {d20[]}, [r2 :32] + .long 0xf2e11948 // vmul.f32 d17, d1, d8[0] + .long 0xf2e22948 // vmul.f32 d18, d2, d8[0] + .long 0xf3201e81 // vcgt.f32 d1, d16, d1 + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xf3200e80 // vcgt.f32 d0, d16, d0 + .long 0xe2811008 // add r1, r1, #8 + .long 0xf3202e82 // vcgt.f32 d2, d16, d2 + .long 0xf2640fab // vmin.f32 d16, d20, d27 + .long 0xf2643fa3 // vmin.f32 d19, d20, d19 + .long 0xf2644faa // vmin.f32 d20, d20, d26 + .long 0xf31501b0 // vbsl d0, d21, d16 + .long 0xf31111b3 // vbsl d1, d17, d19 + .long 0xf31221b4 // vbsl d2, d18, d20 + .long 0xecbd8b02 // vpop {d8} + .long 0xe12fff13 // bx r3 .globl _sk_scale_u8_vfp4 _sk_scale_u8_vfp4: - .long 0xed2d8b02 // vpush {d8} - .long 0xe24dd008 // sub sp, sp, #8 - .long 0xe5913000 // ldr r3, [r1] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xe5933000 // ldr r3, [r3] - .long 0xe0833000 // add r3, r3, r0 - .long 0xe1d330b0 // ldrh r3, [r3] - .long 0xe1cd30b4 // strh r3, [sp, #4] - .long 0xe28d3004 // add r3, sp, #4 - .long 0xed928a03 // vldr s16, [r2, #12] - .long 0xf4e3041f // vld1.16 {d16[0]}, [r3 :16] - .long 0xf3c80a30 // vmovl.u8 q8, d16 - .long 0xf3d00a30 // vmovl.u16 q8, d16 - .long 0xf3fb06a0 // vcvt.f32.u32 d16, d16 - .long 0xf2e009c8 // vmul.f32 d16, d16, d8[0] - .long 0xf3000d90 // vmul.f32 d0, d16, d0 - .long 0xf3001d91 // vmul.f32 d1, d16, d1 - .long 0xf3002d92 // vmul.f32 d2, d16, d2 - .long 0xf3003d93 // vmul.f32 d3, d16, d3 - .long 0xe28dd008 // add sp, sp, #8 - .long 0xecbd8b02 // vpop {d8} - .long 0xe12fff1c // bx ip + .long 0xed2d8b02 // vpush {d8} + .long 0xe24dd008 // sub sp, sp, #8 + .long 0xe5913000 // ldr r3, [r1] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xe5933000 // ldr r3, [r3] + .long 0xe0833000 // add r3, r3, r0 + .long 0xe1d330b0 // ldrh r3, [r3] + .long 0xe1cd30b4 // strh r3, [sp, #4] + .long 0xe28d3004 // add r3, sp, #4 + .long 0xed928a03 // vldr s16, [r2, #12] + .long 0xf4e3041f // vld1.16 {d16[0]}, [r3 :16] + .long 0xf3c80a30 // vmovl.u8 q8, d16 + .long 0xf3d00a30 // vmovl.u16 q8, d16 + .long 0xf3fb06a0 // vcvt.f32.u32 d16, d16 + .long 0xf2e009c8 // vmul.f32 d16, d16, d8[0] + .long 0xf3000d90 // vmul.f32 d0, d16, d0 + .long 0xf3001d91 // vmul.f32 d1, d16, d1 + .long 0xf3002d92 // vmul.f32 d2, d16, d2 + .long 0xf3003d93 // vmul.f32 d3, d16, d3 + .long 0xe28dd008 // add sp, sp, #8 + .long 0xecbd8b02 // vpop {d8} + .long 0xe12fff1c // bx ip .globl _sk_lerp_u8_vfp4 _sk_lerp_u8_vfp4: - .long 0xed2d8b02 // vpush {d8} - .long 0xe24dd008 // sub sp, sp, #8 - .long 0xe5913000 // ldr r3, [r1] - .long 0xf2612d05 // vsub.f32 d18, d1, d5 - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xf2623d06 // vsub.f32 d19, d2, d6 - .long 0xf2634d07 // vsub.f32 d20, d3, d7 - .long 0xe2811008 // add r1, r1, #8 - .long 0xe5933000 // ldr r3, [r3] - .long 0xf2251115 // vorr d1, d5, d5 - .long 0xf2262116 // vorr d2, d6, d6 - .long 0xe0833000 // add r3, r3, r0 - .long 0xf2273117 // vorr d3, d7, d7 - .long 0xe1d330b0 // ldrh r3, [r3] - .long 0xe1cd30b4 // strh r3, [sp, #4] - .long 0xe28d3004 // add r3, sp, #4 - .long 0xed928a03 // vldr s16, [r2, #12] - .long 0xf4e3041f // vld1.16 {d16[0]}, [r3 :16] - .long 0xf3c80a30 // vmovl.u8 q8, d16 - .long 0xf3d00a30 // vmovl.u16 q8, d16 - .long 0xf3fb06a0 // vcvt.f32.u32 d16, d16 - .long 0xf2601d04 // vsub.f32 d17, d0, d4 - .long 0xf2240114 // vorr d0, d4, d4 - .long 0xf2e009c8 // vmul.f32 d16, d16, d8[0] - .long 0xf2010cb0 // vfma.f32 d0, d17, d16 - .long 0xf2021cb0 // vfma.f32 d1, d18, d16 - .long 0xf2032cb0 // vfma.f32 d2, d19, d16 - .long 0xf2043cb0 // vfma.f32 d3, d20, d16 - .long 0xe28dd008 // add sp, sp, #8 - .long 0xecbd8b02 // vpop {d8} - .long 0xe12fff1c // bx ip + .long 0xed2d8b02 // vpush {d8} + .long 0xe24dd008 // sub sp, sp, #8 + .long 0xe5913000 // ldr r3, [r1] + .long 0xf2612d05 // vsub.f32 d18, d1, d5 + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xf2623d06 // vsub.f32 d19, d2, d6 + .long 0xf2634d07 // vsub.f32 d20, d3, d7 + .long 0xe2811008 // add r1, r1, #8 + .long 0xe5933000 // ldr r3, [r3] + .long 0xf2251115 // vorr d1, d5, d5 + .long 0xf2262116 // vorr d2, d6, d6 + .long 0xe0833000 // add r3, r3, r0 + .long 0xf2273117 // vorr d3, d7, d7 + .long 0xe1d330b0 // ldrh r3, [r3] + .long 0xe1cd30b4 // strh r3, [sp, #4] + .long 0xe28d3004 // add r3, sp, #4 + .long 0xed928a03 // vldr s16, [r2, #12] + .long 0xf4e3041f // vld1.16 {d16[0]}, [r3 :16] + .long 0xf3c80a30 // vmovl.u8 q8, d16 + .long 0xf3d00a30 // vmovl.u16 q8, d16 + .long 0xf3fb06a0 // vcvt.f32.u32 d16, d16 + .long 0xf2601d04 // vsub.f32 d17, d0, d4 + .long 0xf2240114 // vorr d0, d4, d4 + .long 0xf2e009c8 // vmul.f32 d16, d16, d8[0] + .long 0xf2010cb0 // vfma.f32 d0, d17, d16 + .long 0xf2021cb0 // vfma.f32 d1, d18, d16 + .long 0xf2032cb0 // vfma.f32 d2, d19, d16 + .long 0xf2043cb0 // vfma.f32 d3, d20, d16 + .long 0xe28dd008 // add sp, sp, #8 + .long 0xecbd8b02 // vpop {d8} + .long 0xe12fff1c // bx ip .globl _sk_load_tables_vfp4 _sk_load_tables_vfp4: - .long 0xe92d48f0 // push {r4, r5, r6, r7, fp, lr} - .long 0xe5913000 // ldr r3, [r1] - .long 0xe2826010 // add r6, r2, #16 - .long 0xed922a03 // vldr s4, [r2, #12] - .long 0xf4e60c9f // vld1.32 {d16[]}, [r6 :32] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xe593e000 // ldr lr, [r3] - .long 0xe5934004 // ldr r4, [r3, #4] - .long 0xe08e6100 // add r6, lr, r0, lsl #2 - .long 0xe5935008 // ldr r5, [r3, #8] - .long 0xe593700c // ldr r7, [r3, #12] - .long 0xedd61b00 // vldr d17, [r6] - .long 0xf24021b1 // vand d18, d16, d17 - .long 0xf3f03031 // vshr.u32 d19, d17, #16 - .long 0xee326b90 // vmov.32 r6, d18[1] - .long 0xe0846106 // add r6, r4, r6, lsl #2 - .long 0xedd60a00 // vldr s1, [r6] - .long 0xee126b90 // vmov.32 r6, d18[0] - .long 0xf3f82031 // vshr.u32 d18, d17, #8 - .long 0xf24021b2 // vand d18, d16, d18 - .long 0xf24001b3 // vand d16, d16, d19 - .long 0xee103b90 // vmov.32 r3, d16[0] - .long 0xe0846106 // add r6, r4, r6, lsl #2 - .long 0xee304b90 // vmov.32 r4, d16[1] - .long 0xf3e80031 // vshr.u32 d16, d17, #24 - .long 0xed960a00 // vldr s0, [r6] - .long 0xee326b90 // vmov.32 r6, d18[1] - .long 0xf3fb0620 // vcvt.f32.s32 d16, d16 - .long 0xe0873103 // add r3, r7, r3, lsl #2 - .long 0xf2a039c2 // vmul.f32 d3, d16, d2[0] - .long 0xe0874104 // add r4, r7, r4, lsl #2 - .long 0xedd42a00 // vldr s5, [r4] - .long 0xe0856106 // add r6, r5, r6, lsl #2 - .long 0xed932a00 // vldr s4, [r3] - .long 0xedd61a00 // vldr s3, [r6] - .long 0xee126b90 // vmov.32 r6, d18[0] - .long 0xe0856106 // add r6, r5, r6, lsl #2 - .long 0xed961a00 // vldr s2, [r6] - .long 0xe8bd48f0 // pop {r4, r5, r6, r7, fp, lr} - .long 0xe12fff1c // bx ip + .long 0xe92d48f0 // push {r4, r5, r6, r7, fp, lr} + .long 0xe5913000 // ldr r3, [r1] + .long 0xe2826010 // add r6, r2, #16 + .long 0xed922a03 // vldr s4, [r2, #12] + .long 0xf4e60c9f // vld1.32 {d16[]}, [r6 :32] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xe593e000 // ldr lr, [r3] + .long 0xe5934004 // ldr r4, [r3, #4] + .long 0xe08e6100 // add r6, lr, r0, lsl #2 + .long 0xe5935008 // ldr r5, [r3, #8] + .long 0xe593700c // ldr r7, [r3, #12] + .long 0xedd61b00 // vldr d17, [r6] + .long 0xf24021b1 // vand d18, d16, d17 + .long 0xf3f03031 // vshr.u32 d19, d17, #16 + .long 0xee326b90 // vmov.32 r6, d18[1] + .long 0xe0846106 // add r6, r4, r6, lsl #2 + .long 0xedd60a00 // vldr s1, [r6] + .long 0xee126b90 // vmov.32 r6, d18[0] + .long 0xf3f82031 // vshr.u32 d18, d17, #8 + .long 0xf24021b2 // vand d18, d16, d18 + .long 0xf24001b3 // vand d16, d16, d19 + .long 0xee103b90 // vmov.32 r3, d16[0] + .long 0xe0846106 // add r6, r4, r6, lsl #2 + .long 0xee304b90 // vmov.32 r4, d16[1] + .long 0xf3e80031 // vshr.u32 d16, d17, #24 + .long 0xed960a00 // vldr s0, [r6] + .long 0xee326b90 // vmov.32 r6, d18[1] + .long 0xf3fb0620 // vcvt.f32.s32 d16, d16 + .long 0xe0873103 // add r3, r7, r3, lsl #2 + .long 0xf2a039c2 // vmul.f32 d3, d16, d2[0] + .long 0xe0874104 // add r4, r7, r4, lsl #2 + .long 0xedd42a00 // vldr s5, [r4] + .long 0xe0856106 // add r6, r5, r6, lsl #2 + .long 0xed932a00 // vldr s4, [r3] + .long 0xedd61a00 // vldr s3, [r6] + .long 0xee126b90 // vmov.32 r6, d18[0] + .long 0xe0856106 // add r6, r5, r6, lsl #2 + .long 0xed961a00 // vldr s2, [r6] + .long 0xe8bd48f0 // pop {r4, r5, r6, r7, fp, lr} + .long 0xe12fff1c // bx ip .globl _sk_load_8888_vfp4 _sk_load_8888_vfp4: - .long 0xe92d4800 // push {fp, lr} - .long 0xe5913000 // ldr r3, [r1] - .long 0xed922a03 // vldr s4, [r2, #12] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xe593e000 // ldr lr, [r3] - .long 0xe2823010 // add r3, r2, #16 - .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] - .long 0xe08e3100 // add r3, lr, r0, lsl #2 - .long 0xedd31b00 // vldr d17, [r3] - .long 0xf24021b1 // vand d18, d16, d17 - .long 0xf3f83031 // vshr.u32 d19, d17, #8 - .long 0xf3e84031 // vshr.u32 d20, d17, #24 - .long 0xf3f01031 // vshr.u32 d17, d17, #16 - .long 0xf24031b3 // vand d19, d16, d19 - .long 0xf24001b1 // vand d16, d16, d17 - .long 0xf3fb2622 // vcvt.f32.s32 d18, d18 - .long 0xf3fb4624 // vcvt.f32.s32 d20, d20 - .long 0xf3fb1623 // vcvt.f32.s32 d17, d19 - .long 0xf3fb0620 // vcvt.f32.s32 d16, d16 - .long 0xf2a209c2 // vmul.f32 d0, d18, d2[0] - .long 0xf2a439c2 // vmul.f32 d3, d20, d2[0] - .long 0xf2a119c2 // vmul.f32 d1, d17, d2[0] - .long 0xf2a029c2 // vmul.f32 d2, d16, d2[0] - .long 0xe8bd4800 // pop {fp, lr} - .long 0xe12fff1c // bx ip + .long 0xe92d4800 // push {fp, lr} + .long 0xe5913000 // ldr r3, [r1] + .long 0xed922a03 // vldr s4, [r2, #12] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xe593e000 // ldr lr, [r3] + .long 0xe2823010 // add r3, r2, #16 + .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] + .long 0xe08e3100 // add r3, lr, r0, lsl #2 + .long 0xedd31b00 // vldr d17, [r3] + .long 0xf24021b1 // vand d18, d16, d17 + .long 0xf3f83031 // vshr.u32 d19, d17, #8 + .long 0xf3e84031 // vshr.u32 d20, d17, #24 + .long 0xf3f01031 // vshr.u32 d17, d17, #16 + .long 0xf24031b3 // vand d19, d16, d19 + .long 0xf24001b1 // vand d16, d16, d17 + .long 0xf3fb2622 // vcvt.f32.s32 d18, d18 + .long 0xf3fb4624 // vcvt.f32.s32 d20, d20 + .long 0xf3fb1623 // vcvt.f32.s32 d17, d19 + .long 0xf3fb0620 // vcvt.f32.s32 d16, d16 + .long 0xf2a209c2 // vmul.f32 d0, d18, d2[0] + .long 0xf2a439c2 // vmul.f32 d3, d20, d2[0] + .long 0xf2a119c2 // vmul.f32 d1, d17, d2[0] + .long 0xf2a029c2 // vmul.f32 d2, d16, d2[0] + .long 0xe8bd4800 // pop {fp, lr} + .long 0xe12fff1c // bx ip .globl _sk_store_8888_vfp4 _sk_store_8888_vfp4: - .long 0xe2823008 // add r3, r2, #8 - .long 0xf2c3261f // vmov.i32 d18, #1056964608 - .long 0xf2c3361f // vmov.i32 d19, #1056964608 - .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] - .long 0xf2c3061f // vmov.i32 d16, #1056964608 - .long 0xf2412c31 // vfma.f32 d18, d1, d17 - .long 0xf2423c31 // vfma.f32 d19, d2, d17 - .long 0xf2c3461f // vmov.i32 d20, #1056964608 - .long 0xe5913000 // ldr r3, [r1] - .long 0xf2400c31 // vfma.f32 d16, d0, d17 - .long 0xf2434c31 // vfma.f32 d20, d3, d17 - .long 0xe5933000 // ldr r3, [r3] - .long 0xe0833100 // add r3, r3, r0, lsl #2 - .long 0xf3fb17a2 // vcvt.u32.f32 d17, d18 - .long 0xf3fb27a3 // vcvt.u32.f32 d18, d19 - .long 0xf3fb07a0 // vcvt.u32.f32 d16, d16 - .long 0xf3fb37a4 // vcvt.u32.f32 d19, d20 - .long 0xf2e81531 // vshl.s32 d17, d17, #8 - .long 0xf2f02532 // vshl.s32 d18, d18, #16 - .long 0xf26101b0 // vorr d16, d17, d16 - .long 0xf2f81533 // vshl.s32 d17, d19, #24 - .long 0xf26001b2 // vorr d16, d16, d18 - .long 0xf26001b1 // vorr d16, d16, d17 - .long 0xedc30b00 // vstr d16, [r3] - .long 0xe5913004 // ldr r3, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xe12fff13 // bx r3 + .long 0xe2823008 // add r3, r2, #8 + .long 0xf2c3261f // vmov.i32 d18, #1056964608 + .long 0xf2c3361f // vmov.i32 d19, #1056964608 + .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] + .long 0xf2c3061f // vmov.i32 d16, #1056964608 + .long 0xf2412c31 // vfma.f32 d18, d1, d17 + .long 0xf2423c31 // vfma.f32 d19, d2, d17 + .long 0xf2c3461f // vmov.i32 d20, #1056964608 + .long 0xe5913000 // ldr r3, [r1] + .long 0xf2400c31 // vfma.f32 d16, d0, d17 + .long 0xf2434c31 // vfma.f32 d20, d3, d17 + .long 0xe5933000 // ldr r3, [r3] + .long 0xe0833100 // add r3, r3, r0, lsl #2 + .long 0xf3fb17a2 // vcvt.u32.f32 d17, d18 + .long 0xf3fb27a3 // vcvt.u32.f32 d18, d19 + .long 0xf3fb07a0 // vcvt.u32.f32 d16, d16 + .long 0xf3fb37a4 // vcvt.u32.f32 d19, d20 + .long 0xf2e81531 // vshl.s32 d17, d17, #8 + .long 0xf2f02532 // vshl.s32 d18, d18, #16 + .long 0xf26101b0 // vorr d16, d17, d16 + .long 0xf2f81533 // vshl.s32 d17, d19, #24 + .long 0xf26001b2 // vorr d16, d16, d18 + .long 0xf26001b1 // vorr d16, d16, d17 + .long 0xedc30b00 // vstr d16, [r3] + .long 0xe5913004 // ldr r3, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xe12fff13 // bx r3 .globl _sk_load_f16_vfp4 _sk_load_f16_vfp4: - .long 0xed2d8b04 // vpush {d8-d9} - .long 0xe5913000 // ldr r3, [r1] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xe5933000 // ldr r3, [r3] - .long 0xe0833180 // add r3, r3, r0, lsl #3 - .long 0xf463084f // vld2.16 {d16-d17}, [r3] - .long 0xf3b62720 // vcvt.f32.f16 q1, d16 - .long 0xf3b68721 // vcvt.f32.f16 q4, d17 - .long 0xf2220112 // vorr d0, d2, d2 - .long 0xeef00a43 // vmov.f32 s1, s6 - .long 0xf2281118 // vorr d1, d8, d8 - .long 0xeeb03a62 // vmov.f32 s6, s5 - .long 0xeef01a49 // vmov.f32 s3, s18 - .long 0xeeb09a68 // vmov.f32 s18, s17 - .long 0xeeb02b43 // vmov.f64 d2, d3 - .long 0xeeb03b49 // vmov.f64 d3, d9 - .long 0xecbd8b04 // vpop {d8-d9} - .long 0xe12fff1c // bx ip + .long 0xed2d8b04 // vpush {d8-d9} + .long 0xe5913000 // ldr r3, [r1] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xe5933000 // ldr r3, [r3] + .long 0xe0833180 // add r3, r3, r0, lsl #3 + .long 0xf463084f // vld2.16 {d16-d17}, [r3] + .long 0xf3b62720 // vcvt.f32.f16 q1, d16 + .long 0xf3b68721 // vcvt.f32.f16 q4, d17 + .long 0xf2220112 // vorr d0, d2, d2 + .long 0xeef00a43 // vmov.f32 s1, s6 + .long 0xf2281118 // vorr d1, d8, d8 + .long 0xeeb03a62 // vmov.f32 s6, s5 + .long 0xeef01a49 // vmov.f32 s3, s18 + .long 0xeeb09a68 // vmov.f32 s18, s17 + .long 0xeeb02b43 // vmov.f64 d2, d3 + .long 0xeeb03b49 // vmov.f64 d3, d9 + .long 0xecbd8b04 // vpop {d8-d9} + .long 0xe12fff1c // bx ip .globl _sk_store_f16_vfp4 _sk_store_f16_vfp4: - .long 0xeef00b41 // vmov.f64 d16, d1 - .long 0xf2631113 // vorr d17, d3, d3 - .long 0xeef03b42 // vmov.f64 d19, d2 - .long 0xf2602110 // vorr d18, d0, d0 - .long 0xf3fa00a1 // vtrn.32 d16, d17 - .long 0xf3f61620 // vcvt.f16.f32 d17, q8 - .long 0xf3fa20a3 // vtrn.32 d18, d19 - .long 0xe5913000 // ldr r3, [r1] - .long 0xf3f60622 // vcvt.f16.f32 d16, q9 - .long 0xe5933000 // ldr r3, [r3] - .long 0xe0833180 // add r3, r3, r0, lsl #3 - .long 0xf443084f // vst2.16 {d16-d17}, [r3] - .long 0xe2813008 // add r3, r1, #8 - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe1a01003 // mov r1, r3 - .long 0xe12fff1c // bx ip + .long 0xeef00b41 // vmov.f64 d16, d1 + .long 0xf2631113 // vorr d17, d3, d3 + .long 0xeef03b42 // vmov.f64 d19, d2 + .long 0xf2602110 // vorr d18, d0, d0 + .long 0xf3fa00a1 // vtrn.32 d16, d17 + .long 0xf3f61620 // vcvt.f16.f32 d17, q8 + .long 0xf3fa20a3 // vtrn.32 d18, d19 + .long 0xe5913000 // ldr r3, [r1] + .long 0xf3f60622 // vcvt.f16.f32 d16, q9 + .long 0xe5933000 // ldr r3, [r3] + .long 0xe0833180 // add r3, r3, r0, lsl #3 + .long 0xf443084f // vst2.16 {d16-d17}, [r3] + .long 0xe2813008 // add r3, r1, #8 + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe1a01003 // mov r1, r3 + .long 0xe12fff1c // bx ip .globl _sk_clamp_x_vfp4 _sk_clamp_x_vfp4: - .long 0xe5913000 // ldr r3, [r1] - .long 0xf3c70e1f // vmov.i8 d16, #255 - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] - .long 0xf26108a0 // vadd.i32 d16, d17, d16 - .long 0xf2c01010 // vmov.i32 d17, #0 - .long 0xf2600f20 // vmin.f32 d16, d0, d16 - .long 0xf2010fa0 // vmax.f32 d0, d17, d16 - .long 0xe12fff1c // bx ip + .long 0xe5913000 // ldr r3, [r1] + .long 0xf3c70e1f // vmov.i8 d16, #255 + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] + .long 0xf26108a0 // vadd.i32 d16, d17, d16 + .long 0xf2c01010 // vmov.i32 d17, #0 + .long 0xf2600f20 // vmin.f32 d16, d0, d16 + .long 0xf2010fa0 // vmax.f32 d0, d17, d16 + .long 0xe12fff1c // bx ip .globl _sk_clamp_y_vfp4 _sk_clamp_y_vfp4: - .long 0xe5913000 // ldr r3, [r1] - .long 0xf3c70e1f // vmov.i8 d16, #255 - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] - .long 0xf26108a0 // vadd.i32 d16, d17, d16 - .long 0xf2c01010 // vmov.i32 d17, #0 - .long 0xf2610f20 // vmin.f32 d16, d1, d16 - .long 0xf2011fa0 // vmax.f32 d1, d17, d16 - .long 0xe12fff1c // bx ip + .long 0xe5913000 // ldr r3, [r1] + .long 0xf3c70e1f // vmov.i8 d16, #255 + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] + .long 0xf26108a0 // vadd.i32 d16, d17, d16 + .long 0xf2c01010 // vmov.i32 d17, #0 + .long 0xf2610f20 // vmin.f32 d16, d1, d16 + .long 0xf2011fa0 // vmax.f32 d1, d17, d16 + .long 0xe12fff1c // bx ip .globl _sk_matrix_2x3_vfp4 _sk_matrix_2x3_vfp4: - .long 0xe92d4800 // push {fp, lr} - .long 0xe591e000 // ldr lr, [r1] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xe28e300c // add r3, lr, #12 - .long 0xf4e32c9f // vld1.32 {d18[]}, [r3 :32] - .long 0xe28e3008 // add r3, lr, #8 - .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] - .long 0xe28e3010 // add r3, lr, #16 - .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] - .long 0xe28e3014 // add r3, lr, #20 - .long 0xf2410c31 // vfma.f32 d16, d1, d17 - .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] - .long 0xe28e3004 // add r3, lr, #4 - .long 0xf2411c32 // vfma.f32 d17, d1, d18 - .long 0xf4ee2c9f // vld1.32 {d18[]}, [lr :32] - .long 0xf4e33c9f // vld1.32 {d19[]}, [r3 :32] - .long 0xf2400c32 // vfma.f32 d16, d0, d18 - .long 0xf2401c33 // vfma.f32 d17, d0, d19 - .long 0xf22001b0 // vorr d0, d16, d16 - .long 0xf22111b1 // vorr d1, d17, d17 - .long 0xe8bd4800 // pop {fp, lr} - .long 0xe12fff1c // bx ip + .long 0xe92d4800 // push {fp, lr} + .long 0xe591e000 // ldr lr, [r1] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xe28e300c // add r3, lr, #12 + .long 0xf4e32c9f // vld1.32 {d18[]}, [r3 :32] + .long 0xe28e3008 // add r3, lr, #8 + .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] + .long 0xe28e3010 // add r3, lr, #16 + .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] + .long 0xe28e3014 // add r3, lr, #20 + .long 0xf2410c31 // vfma.f32 d16, d1, d17 + .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] + .long 0xe28e3004 // add r3, lr, #4 + .long 0xf2411c32 // vfma.f32 d17, d1, d18 + .long 0xf4ee2c9f // vld1.32 {d18[]}, [lr :32] + .long 0xf4e33c9f // vld1.32 {d19[]}, [r3 :32] + .long 0xf2400c32 // vfma.f32 d16, d0, d18 + .long 0xf2401c33 // vfma.f32 d17, d0, d19 + .long 0xf22001b0 // vorr d0, d16, d16 + .long 0xf22111b1 // vorr d1, d17, d17 + .long 0xe8bd4800 // pop {fp, lr} + .long 0xe12fff1c // bx ip .globl _sk_matrix_3x4_vfp4 _sk_matrix_3x4_vfp4: - .long 0xe92d4800 // push {fp, lr} - .long 0xe591e000 // ldr lr, [r1] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xe28e3020 // add r3, lr, #32 - .long 0xf4e33c9f // vld1.32 {d19[]}, [r3 :32] - .long 0xe28e302c // add r3, lr, #44 - .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] - .long 0xe28e301c // add r3, lr, #28 - .long 0xf2420c33 // vfma.f32 d16, d2, d19 - .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] - .long 0xe28e3018 // add r3, lr, #24 - .long 0xf4e32c9f // vld1.32 {d18[]}, [r3 :32] - .long 0xe28e3024 // add r3, lr, #36 - .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] - .long 0xe28e3028 // add r3, lr, #40 - .long 0xf2421c32 // vfma.f32 d17, d2, d18 - .long 0xf4e32c9f // vld1.32 {d18[]}, [r3 :32] - .long 0xe28e3010 // add r3, lr, #16 - .long 0xf2422c34 // vfma.f32 d18, d2, d20 - .long 0xf4e33c9f // vld1.32 {d19[]}, [r3 :32] - .long 0xe28e300c // add r3, lr, #12 - .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] - .long 0xe28e3014 // add r3, lr, #20 - .long 0xf2411c34 // vfma.f32 d17, d1, d20 - .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] - .long 0xf2410c34 // vfma.f32 d16, d1, d20 - .long 0xe28e3004 // add r3, lr, #4 - .long 0xf2412c33 // vfma.f32 d18, d1, d19 - .long 0xf4ee3c9f // vld1.32 {d19[]}, [lr :32] - .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] - .long 0xe28e3008 // add r3, lr, #8 - .long 0xf2401c33 // vfma.f32 d17, d0, d19 - .long 0xf4e33c9f // vld1.32 {d19[]}, [r3 :32] - .long 0xf2400c33 // vfma.f32 d16, d0, d19 - .long 0xf2402c34 // vfma.f32 d18, d0, d20 - .long 0xf22101b1 // vorr d0, d17, d17 - .long 0xf22021b0 // vorr d2, d16, d16 - .long 0xf22211b2 // vorr d1, d18, d18 - .long 0xe8bd4800 // pop {fp, lr} - .long 0xe12fff1c // bx ip + .long 0xe92d4800 // push {fp, lr} + .long 0xe591e000 // ldr lr, [r1] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xe28e3020 // add r3, lr, #32 + .long 0xf4e33c9f // vld1.32 {d19[]}, [r3 :32] + .long 0xe28e302c // add r3, lr, #44 + .long 0xf4e30c9f // vld1.32 {d16[]}, [r3 :32] + .long 0xe28e301c // add r3, lr, #28 + .long 0xf2420c33 // vfma.f32 d16, d2, d19 + .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] + .long 0xe28e3018 // add r3, lr, #24 + .long 0xf4e32c9f // vld1.32 {d18[]}, [r3 :32] + .long 0xe28e3024 // add r3, lr, #36 + .long 0xf4e31c9f // vld1.32 {d17[]}, [r3 :32] + .long 0xe28e3028 // add r3, lr, #40 + .long 0xf2421c32 // vfma.f32 d17, d2, d18 + .long 0xf4e32c9f // vld1.32 {d18[]}, [r3 :32] + .long 0xe28e3010 // add r3, lr, #16 + .long 0xf2422c34 // vfma.f32 d18, d2, d20 + .long 0xf4e33c9f // vld1.32 {d19[]}, [r3 :32] + .long 0xe28e300c // add r3, lr, #12 + .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] + .long 0xe28e3014 // add r3, lr, #20 + .long 0xf2411c34 // vfma.f32 d17, d1, d20 + .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] + .long 0xf2410c34 // vfma.f32 d16, d1, d20 + .long 0xe28e3004 // add r3, lr, #4 + .long 0xf2412c33 // vfma.f32 d18, d1, d19 + .long 0xf4ee3c9f // vld1.32 {d19[]}, [lr :32] + .long 0xf4e34c9f // vld1.32 {d20[]}, [r3 :32] + .long 0xe28e3008 // add r3, lr, #8 + .long 0xf2401c33 // vfma.f32 d17, d0, d19 + .long 0xf4e33c9f // vld1.32 {d19[]}, [r3 :32] + .long 0xf2400c33 // vfma.f32 d16, d0, d19 + .long 0xf2402c34 // vfma.f32 d18, d0, d20 + .long 0xf22101b1 // vorr d0, d17, d17 + .long 0xf22021b0 // vorr d2, d16, d16 + .long 0xf22211b2 // vorr d1, d18, d18 + .long 0xe8bd4800 // pop {fp, lr} + .long 0xe12fff1c // bx ip .globl _sk_linear_gradient_2stops_vfp4 _sk_linear_gradient_2stops_vfp4: - .long 0xe5913000 // ldr r3, [r1] - .long 0xe591c004 // ldr ip, [r1, #4] - .long 0xe2811008 // add r1, r1, #8 - .long 0xf4632a0d // vld1.8 {d18-d19}, [r3]! - .long 0xf4634a0f // vld1.8 {d20-d21}, [r3] - .long 0xf3f40c22 // vdup.32 d16, d18[0] - .long 0xf3f41c24 // vdup.32 d17, d20[0] - .long 0xf2400c31 // vfma.f32 d16, d0, d17 - .long 0xf3fc6c24 // vdup.32 d22, d20[1] - .long 0xf3bc1c22 // vdup.32 d1, d18[1] - .long 0xf3b42c23 // vdup.32 d2, d19[0] - .long 0xf2001c36 // vfma.f32 d1, d0, d22 - .long 0xf3f41c25 // vdup.32 d17, d21[0] - .long 0xf3fc4c25 // vdup.32 d20, d21[1] - .long 0xf2002c31 // vfma.f32 d2, d0, d17 - .long 0xf3bc3c23 // vdup.32 d3, d19[1] - .long 0xf2003c34 // vfma.f32 d3, d0, d20 - .long 0xf22001b0 // vorr d0, d16, d16 - .long 0xe12fff1c // bx ip + .long 0xe5913000 // ldr r3, [r1] + .long 0xe591c004 // ldr ip, [r1, #4] + .long 0xe2811008 // add r1, r1, #8 + .long 0xf4632a0d // vld1.8 {d18-d19}, [r3]! + .long 0xf4634a0f // vld1.8 {d20-d21}, [r3] + .long 0xf3f40c22 // vdup.32 d16, d18[0] + .long 0xf3f41c24 // vdup.32 d17, d20[0] + .long 0xf2400c31 // vfma.f32 d16, d0, d17 + .long 0xf3fc6c24 // vdup.32 d22, d20[1] + .long 0xf3bc1c22 // vdup.32 d1, d18[1] + .long 0xf3b42c23 // vdup.32 d2, d19[0] + .long 0xf2001c36 // vfma.f32 d1, d0, d22 + .long 0xf3f41c25 // vdup.32 d17, d21[0] + .long 0xf3fc4c25 // vdup.32 d20, d21[1] + .long 0xf2002c31 // vfma.f32 d2, d0, d17 + .long 0xf3bc3c23 // vdup.32 d3, d19[1] + .long 0xf2003c34 // vfma.f32 d3, d0, d20 + .long 0xf22001b0 // vorr d0, d16, d16 + .long 0xe12fff1c // bx ip #elif defined(__x86_64__) .globl _sk_start_pipeline_hsw _sk_start_pipeline_hsw: - .byte 0x41,0x57 // push %r15 - .byte 0x41,0x56 // push %r14 - .byte 0x41,0x55 // push %r13 - .byte 0x41,0x54 // push %r12 - .byte 0x53 // push %rbx - .byte 0x49,0x89,0xcf // mov %rcx,%r15 - .byte 0x49,0x89,0xd6 // mov %rdx,%r14 - .byte 0x48,0x89,0xfb // mov %rdi,%rbx - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x49,0x89,0xc4 // mov %rax,%r12 - .byte 0x49,0x89,0xf5 // mov %rsi,%r13 - .byte 0x48,0x8d,0x43,0x08 // lea 0x8(%rbx),%rax - .byte 0x4c,0x39,0xf8 // cmp %r15,%rax - .byte 0x76,0x05 // jbe 28 <_sk_start_pipeline_hsw+0x28> - .byte 0x48,0x89,0xd8 // mov %rbx,%rax - .byte 0xeb,0x3c // jmp 64 <_sk_start_pipeline_hsw+0x64> - .byte 0xc5,0xfc,0x57,0xc0 // vxorps %ymm0,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x57,0xc9 // vxorps %ymm1,%ymm1,%ymm1 - .byte 0xc5,0xec,0x57,0xd2 // vxorps %ymm2,%ymm2,%ymm2 - .byte 0xc5,0xe4,0x57,0xdb // vxorps %ymm3,%ymm3,%ymm3 - .byte 0xc5,0xdc,0x57,0xe4 // vxorps %ymm4,%ymm4,%ymm4 - .byte 0xc5,0xd4,0x57,0xed // vxorps %ymm5,%ymm5,%ymm5 - .byte 0xc5,0xcc,0x57,0xf6 // vxorps %ymm6,%ymm6,%ymm6 - .byte 0xc5,0xc4,0x57,0xff // vxorps %ymm7,%ymm7,%ymm7 - .byte 0x48,0x89,0xdf // mov %rbx,%rdi - .byte 0x4c,0x89,0xee // mov %r13,%rsi - .byte 0x4c,0x89,0xf2 // mov %r14,%rdx - .byte 0x41,0xff,0xd4 // callq *%r12 - .byte 0x48,0x8d,0x43,0x08 // lea 0x8(%rbx),%rax - .byte 0x48,0x83,0xc3,0x10 // add $0x10,%rbx - .byte 0x4c,0x39,0xfb // cmp %r15,%rbx - .byte 0x48,0x89,0xc3 // mov %rax,%rbx - .byte 0x76,0xc4 // jbe 28 <_sk_start_pipeline_hsw+0x28> - .byte 0x5b // pop %rbx - .byte 0x41,0x5c // pop %r12 - .byte 0x41,0x5d // pop %r13 - .byte 0x41,0x5e // pop %r14 - .byte 0x41,0x5f // pop %r15 - .byte 0xc5,0xf8,0x77 // vzeroupper - .byte 0xc3 // retq + .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 73,137,207 // mov %rcx,%r15 + .byte 73,137,214 // mov %rdx,%r14 + .byte 72,137,251 // mov %rdi,%rbx + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 73,137,196 // mov %rax,%r12 + .byte 73,137,245 // mov %rsi,%r13 + .byte 72,141,67,8 // lea 0x8(%rbx),%rax + .byte 76,57,248 // cmp %r15,%rax + .byte 118,5 // jbe 28 <_sk_start_pipeline_hsw+0x28> + .byte 72,137,216 // mov %rbx,%rax + .byte 235,60 // jmp 64 <_sk_start_pipeline_hsw+0x64> + .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 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 72,137,223 // mov %rbx,%rdi + .byte 76,137,238 // mov %r13,%rsi + .byte 76,137,242 // mov %r14,%rdx + .byte 65,255,212 // callq *%r12 + .byte 72,141,67,8 // lea 0x8(%rbx),%rax + .byte 72,131,195,16 // add $0x10,%rbx + .byte 76,57,251 // cmp %r15,%rbx + .byte 72,137,195 // mov %rax,%rbx + .byte 118,196 // jbe 28 <_sk_start_pipeline_hsw+0x28> + .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 197,248,119 // vzeroupper + .byte 195 // retq .globl _sk_just_return_hsw _sk_just_return_hsw: - .byte 0xc3 // retq + .byte 195 // retq .globl _sk_seed_shader_hsw _sk_seed_shader_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xf9,0x6e,0xc7 // vmovd %edi,%xmm0 - .byte 0xc4,0xe2,0x7d,0x18,0xc0 // vbroadcastss %xmm0,%ymm0 - .byte 0xc5,0xfc,0x5b,0xc0 // vcvtdq2ps %ymm0,%ymm0 - .byte 0xc4,0xe2,0x7d,0x18,0x4a,0x04 // vbroadcastss 0x4(%rdx),%ymm1 - .byte 0xc5,0xfc,0x58,0xc1 // vaddps %ymm1,%ymm0,%ymm0 - .byte 0xc5,0xfc,0x58,0x42,0x14 // vaddps 0x14(%rdx),%ymm0,%ymm0 - .byte 0xc4,0xe2,0x7d,0x18,0x10 // vbroadcastss (%rax),%ymm2 - .byte 0xc5,0xfc,0x5b,0xd2 // vcvtdq2ps %ymm2,%ymm2 - .byte 0xc5,0xec,0x58,0xc9 // vaddps %ymm1,%ymm2,%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x12 // vbroadcastss (%rdx),%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xe4,0x57,0xdb // vxorps %ymm3,%ymm3,%ymm3 - .byte 0xc5,0xdc,0x57,0xe4 // vxorps %ymm4,%ymm4,%ymm4 - .byte 0xc5,0xd4,0x57,0xed // vxorps %ymm5,%ymm5,%ymm5 - .byte 0xc5,0xcc,0x57,0xf6 // vxorps %ymm6,%ymm6,%ymm6 - .byte 0xc5,0xc4,0x57,0xff // vxorps %ymm7,%ymm7,%ymm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 197,249,110,199 // vmovd %edi,%xmm0 + .byte 196,226,125,24,192 // vbroadcastss %xmm0,%ymm0 + .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 + .byte 196,226,125,24,74,4 // vbroadcastss 0x4(%rdx),%ymm1 + .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 + .byte 197,252,88,66,20 // vaddps 0x14(%rdx),%ymm0,%ymm0 + .byte 196,226,125,24,16 // vbroadcastss (%rax),%ymm2 + .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 + .byte 197,236,88,201 // vaddps %ymm1,%ymm2,%ymm1 + .byte 196,226,125,24,18 // vbroadcastss (%rdx),%ymm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_constant_color_hsw _sk_constant_color_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0xe2,0x7d,0x18,0x00 // vbroadcastss (%rax),%ymm0 - .byte 0xc4,0xe2,0x7d,0x18,0x48,0x04 // vbroadcastss 0x4(%rax),%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x50,0x08 // vbroadcastss 0x8(%rax),%ymm2 - .byte 0xc4,0xe2,0x7d,0x18,0x58,0x0c // vbroadcastss 0xc(%rax),%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_clear_hsw _sk_clear_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x57,0xc0 // vxorps %ymm0,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x57,0xc9 // vxorps %ymm1,%ymm1,%ymm1 - .byte 0xc5,0xec,0x57,0xd2 // vxorps %ymm2,%ymm2,%ymm2 - .byte 0xc5,0xe4,0x57,0xdb // vxorps %ymm3,%ymm3,%ymm3 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_plus__hsw _sk_plus__hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x58,0xc4 // vaddps %ymm4,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x58,0xcd // vaddps %ymm5,%ymm1,%ymm1 - .byte 0xc5,0xec,0x58,0xd6 // vaddps %ymm6,%ymm2,%ymm2 - .byte 0xc5,0xe4,0x58,0xdf // vaddps %ymm7,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_srcover_hsw _sk_srcover_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x02 // vbroadcastss (%rdx),%ymm8 - .byte 0xc5,0x3c,0x5c,0xc3 // vsubps %ymm3,%ymm8,%ymm8 - .byte 0xc4,0xc2,0x5d,0xb8,0xc0 // vfmadd231ps %ymm8,%ymm4,%ymm0 - .byte 0xc4,0xc2,0x55,0xb8,0xc8 // vfmadd231ps %ymm8,%ymm5,%ymm1 - .byte 0xc4,0xc2,0x4d,0xb8,0xd0 // vfmadd231ps %ymm8,%ymm6,%ymm2 - .byte 0xc4,0xc2,0x45,0xb8,0xd8 // vfmadd231ps %ymm8,%ymm7,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,2 // vbroadcastss (%rdx),%ymm8 + .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 .globl _sk_dstover_hsw _sk_dstover_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x02 // vbroadcastss (%rdx),%ymm8 - .byte 0xc5,0x3c,0x5c,0xc7 // vsubps %ymm7,%ymm8,%ymm8 - .byte 0xc4,0xe2,0x3d,0xa8,0xc4 // vfmadd213ps %ymm4,%ymm8,%ymm0 - .byte 0xc4,0xe2,0x3d,0xa8,0xcd // vfmadd213ps %ymm5,%ymm8,%ymm1 - .byte 0xc4,0xe2,0x3d,0xa8,0xd6 // vfmadd213ps %ymm6,%ymm8,%ymm2 - .byte 0xc4,0xe2,0x3d,0xa8,0xdf // vfmadd213ps %ymm7,%ymm8,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,2 // vbroadcastss (%rdx),%ymm8 + .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 .globl _sk_clamp_0_hsw _sk_clamp_0_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x41,0x3c,0x57,0xc0 // vxorps %ymm8,%ymm8,%ymm8 - .byte 0xc4,0xc1,0x7c,0x5f,0xc0 // vmaxps %ymm8,%ymm0,%ymm0 - .byte 0xc4,0xc1,0x74,0x5f,0xc8 // vmaxps %ymm8,%ymm1,%ymm1 - .byte 0xc4,0xc1,0x6c,0x5f,0xd0 // vmaxps %ymm8,%ymm2,%ymm2 - .byte 0xc4,0xc1,0x64,0x5f,0xd8 // vmaxps %ymm8,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_clamp_1_hsw _sk_clamp_1_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x02 // vbroadcastss (%rdx),%ymm8 - .byte 0xc4,0xc1,0x7c,0x5d,0xc0 // vminps %ymm8,%ymm0,%ymm0 - .byte 0xc4,0xc1,0x74,0x5d,0xc8 // vminps %ymm8,%ymm1,%ymm1 - .byte 0xc4,0xc1,0x6c,0x5d,0xd0 // vminps %ymm8,%ymm2,%ymm2 - .byte 0xc4,0xc1,0x64,0x5d,0xd8 // vminps %ymm8,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,2 // vbroadcastss (%rdx),%ymm8 + .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 .globl _sk_clamp_a_hsw _sk_clamp_a_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x02 // vbroadcastss (%rdx),%ymm8 - .byte 0xc4,0xc1,0x64,0x5d,0xd8 // vminps %ymm8,%ymm3,%ymm3 - .byte 0xc5,0xfc,0x5d,0xc3 // vminps %ymm3,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x5d,0xcb // vminps %ymm3,%ymm1,%ymm1 - .byte 0xc5,0xec,0x5d,0xd3 // vminps %ymm3,%ymm2,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,2 // vbroadcastss (%rdx),%ymm8 + .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 .globl _sk_set_rgb_hsw _sk_set_rgb_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0xe2,0x7d,0x18,0x00 // vbroadcastss (%rax),%ymm0 - .byte 0xc4,0xe2,0x7d,0x18,0x48,0x04 // vbroadcastss 0x4(%rax),%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x50,0x08 // vbroadcastss 0x8(%rax),%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_swap_rb_hsw _sk_swap_rb_hsw: - .byte 0xc5,0x7c,0x28,0xc0 // vmovaps %ymm0,%ymm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x28,0xc2 // vmovaps %ymm2,%ymm0 - .byte 0xc5,0x7c,0x29,0xc2 // vmovaps %ymm8,%ymm2 - .byte 0xff,0xe0 // jmpq *%rax + .byte 197,124,40,192 // vmovaps %ymm0,%ymm8 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_swap_hsw _sk_swap_hsw: - .byte 0xc5,0x7c,0x28,0xc3 // vmovaps %ymm3,%ymm8 - .byte 0xc5,0x7c,0x28,0xca // vmovaps %ymm2,%ymm9 - .byte 0xc5,0x7c,0x28,0xd1 // vmovaps %ymm1,%ymm10 - .byte 0xc5,0x7c,0x28,0xd8 // vmovaps %ymm0,%ymm11 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x28,0xc4 // vmovaps %ymm4,%ymm0 - .byte 0xc5,0xfc,0x28,0xcd // vmovaps %ymm5,%ymm1 - .byte 0xc5,0xfc,0x28,0xd6 // vmovaps %ymm6,%ymm2 - .byte 0xc5,0xfc,0x28,0xdf // vmovaps %ymm7,%ymm3 - .byte 0xc5,0x7c,0x29,0xdc // vmovaps %ymm11,%ymm4 - .byte 0xc5,0x7c,0x29,0xd5 // vmovaps %ymm10,%ymm5 - .byte 0xc5,0x7c,0x29,0xce // vmovaps %ymm9,%ymm6 - .byte 0xc5,0x7c,0x29,0xc7 // vmovaps %ymm8,%ymm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 197,124,40,195 // vmovaps %ymm3,%ymm8 + .byte 197,124,40,202 // vmovaps %ymm2,%ymm9 + .byte 197,124,40,209 // vmovaps %ymm1,%ymm10 + .byte 197,124,40,216 // vmovaps %ymm0,%ymm11 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 197,124,41,220 // vmovaps %ymm11,%ymm4 + .byte 197,124,41,213 // vmovaps %ymm10,%ymm5 + .byte 197,124,41,206 // vmovaps %ymm9,%ymm6 + .byte 197,124,41,199 // vmovaps %ymm8,%ymm7 + .byte 255,224 // jmpq *%rax .globl _sk_move_src_dst_hsw _sk_move_src_dst_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x28,0xe0 // vmovaps %ymm0,%ymm4 - .byte 0xc5,0xfc,0x28,0xe9 // vmovaps %ymm1,%ymm5 - .byte 0xc5,0xfc,0x28,0xf2 // vmovaps %ymm2,%ymm6 - .byte 0xc5,0xfc,0x28,0xfb // vmovaps %ymm3,%ymm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_move_dst_src_hsw _sk_move_dst_src_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x28,0xc4 // vmovaps %ymm4,%ymm0 - .byte 0xc5,0xfc,0x28,0xcd // vmovaps %ymm5,%ymm1 - .byte 0xc5,0xfc,0x28,0xd6 // vmovaps %ymm6,%ymm2 - .byte 0xc5,0xfc,0x28,0xdf // vmovaps %ymm7,%ymm3 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_premul_hsw _sk_premul_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x59,0xc3 // vmulps %ymm3,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x59,0xcb // vmulps %ymm3,%ymm1,%ymm1 - .byte 0xc5,0xec,0x59,0xd3 // vmulps %ymm3,%ymm2,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_unpremul_hsw _sk_unpremul_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x41,0x3c,0x57,0xc0 // vxorps %ymm8,%ymm8,%ymm8 - .byte 0xc4,0x41,0x64,0xc2,0xc8,0x00 // vcmpeqps %ymm8,%ymm3,%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x12 // vbroadcastss (%rdx),%ymm10 - .byte 0xc5,0x2c,0x5e,0xd3 // vdivps %ymm3,%ymm10,%ymm10 - .byte 0xc4,0x43,0x2d,0x4a,0xc0,0x90 // vblendvps %ymm9,%ymm8,%ymm10,%ymm8 - .byte 0xc5,0xbc,0x59,0xc0 // vmulps %ymm0,%ymm8,%ymm0 - .byte 0xc5,0xbc,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm1 - .byte 0xc5,0xbc,0x59,0xd2 // vmulps %ymm2,%ymm8,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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,18 // vbroadcastss (%rdx),%ymm10 + .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 .globl _sk_from_srgb_hsw _sk_from_srgb_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x42,0x40 // vbroadcastss 0x40(%rdx),%ymm8 - .byte 0xc5,0x3c,0x59,0xc8 // vmulps %ymm0,%ymm8,%ymm9 - .byte 0xc5,0x7c,0x59,0xd0 // vmulps %ymm0,%ymm0,%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x5a,0x3c // vbroadcastss 0x3c(%rdx),%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x62,0x38 // vbroadcastss 0x38(%rdx),%ymm12 - .byte 0xc4,0x41,0x7c,0x28,0xeb // vmovaps %ymm11,%ymm13 - .byte 0xc4,0x42,0x7d,0xa8,0xec // vfmadd213ps %ymm12,%ymm0,%ymm13 - .byte 0xc4,0x62,0x7d,0x18,0x72,0x34 // vbroadcastss 0x34(%rdx),%ymm14 - .byte 0xc4,0x42,0x2d,0xa8,0xee // vfmadd213ps %ymm14,%ymm10,%ymm13 - .byte 0xc4,0x62,0x7d,0x18,0x52,0x44 // vbroadcastss 0x44(%rdx),%ymm10 - .byte 0xc4,0xc1,0x7c,0xc2,0xc2,0x01 // vcmpltps %ymm10,%ymm0,%ymm0 - .byte 0xc4,0xc3,0x15,0x4a,0xc1,0x00 // vblendvps %ymm0,%ymm9,%ymm13,%ymm0 - .byte 0xc5,0x3c,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm9 - .byte 0xc5,0x74,0x59,0xe9 // vmulps %ymm1,%ymm1,%ymm13 - .byte 0xc4,0x41,0x7c,0x28,0xfb // vmovaps %ymm11,%ymm15 - .byte 0xc4,0x42,0x75,0xa8,0xfc // vfmadd213ps %ymm12,%ymm1,%ymm15 - .byte 0xc4,0x42,0x15,0xa8,0xfe // vfmadd213ps %ymm14,%ymm13,%ymm15 - .byte 0xc4,0xc1,0x74,0xc2,0xca,0x01 // vcmpltps %ymm10,%ymm1,%ymm1 - .byte 0xc4,0xc3,0x05,0x4a,0xc9,0x10 // vblendvps %ymm1,%ymm9,%ymm15,%ymm1 - .byte 0xc5,0x3c,0x59,0xc2 // vmulps %ymm2,%ymm8,%ymm8 - .byte 0xc5,0x6c,0x59,0xca // vmulps %ymm2,%ymm2,%ymm9 - .byte 0xc4,0x42,0x6d,0xa8,0xdc // vfmadd213ps %ymm12,%ymm2,%ymm11 - .byte 0xc4,0x42,0x35,0xa8,0xde // vfmadd213ps %ymm14,%ymm9,%ymm11 - .byte 0xc4,0xc1,0x6c,0xc2,0xd2,0x01 // vcmpltps %ymm10,%ymm2,%ymm2 - .byte 0xc4,0xc3,0x25,0x4a,0xd0,0x20 // vblendvps %ymm2,%ymm8,%ymm11,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,66,64 // vbroadcastss 0x40(%rdx),%ymm8 + .byte 197,60,89,200 // vmulps %ymm0,%ymm8,%ymm9 + .byte 197,124,89,208 // vmulps %ymm0,%ymm0,%ymm10 + .byte 196,98,125,24,90,60 // vbroadcastss 0x3c(%rdx),%ymm11 + .byte 196,98,125,24,98,56 // vbroadcastss 0x38(%rdx),%ymm12 + .byte 196,65,124,40,235 // vmovaps %ymm11,%ymm13 + .byte 196,66,125,168,236 // vfmadd213ps %ymm12,%ymm0,%ymm13 + .byte 196,98,125,24,114,52 // vbroadcastss 0x34(%rdx),%ymm14 + .byte 196,66,45,168,238 // vfmadd213ps %ymm14,%ymm10,%ymm13 + .byte 196,98,125,24,82,68 // vbroadcastss 0x44(%rdx),%ymm10 + .byte 196,193,124,194,194,1 // vcmpltps %ymm10,%ymm0,%ymm0 + .byte 196,195,21,74,193,0 // vblendvps %ymm0,%ymm9,%ymm13,%ymm0 + .byte 197,60,89,201 // vmulps %ymm1,%ymm8,%ymm9 + .byte 197,116,89,233 // vmulps %ymm1,%ymm1,%ymm13 + .byte 196,65,124,40,251 // vmovaps %ymm11,%ymm15 + .byte 196,66,117,168,252 // vfmadd213ps %ymm12,%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 197,60,89,194 // vmulps %ymm2,%ymm8,%ymm8 + .byte 197,108,89,202 // vmulps %ymm2,%ymm2,%ymm9 + .byte 196,66,109,168,220 // vfmadd213ps %ymm12,%ymm2,%ymm11 + .byte 196,66,53,168,222 // vfmadd213ps %ymm14,%ymm9,%ymm11 + .byte 196,193,108,194,210,1 // vcmpltps %ymm10,%ymm2,%ymm2 + .byte 196,195,37,74,208,32 // vblendvps %ymm2,%ymm8,%ymm11,%ymm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_to_srgb_hsw _sk_to_srgb_hsw: - .byte 0xc5,0x7c,0x52,0xc0 // vrsqrtps %ymm0,%ymm8 - .byte 0xc4,0x41,0x7c,0x53,0xc8 // vrcpps %ymm8,%ymm9 - .byte 0xc4,0x41,0x7c,0x52,0xd0 // vrsqrtps %ymm8,%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x42,0x48 // vbroadcastss 0x48(%rdx),%ymm8 - .byte 0xc5,0x3c,0x59,0xd8 // vmulps %ymm0,%ymm8,%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x22 // vbroadcastss (%rdx),%ymm12 - .byte 0xc4,0x62,0x7d,0x18,0x6a,0x4c // vbroadcastss 0x4c(%rdx),%ymm13 - .byte 0xc4,0x62,0x7d,0x18,0x72,0x50 // vbroadcastss 0x50(%rdx),%ymm14 - .byte 0xc4,0x62,0x7d,0x18,0x7a,0x54 // vbroadcastss 0x54(%rdx),%ymm15 - .byte 0xc4,0x42,0x0d,0xa8,0xcf // vfmadd213ps %ymm15,%ymm14,%ymm9 - .byte 0xc4,0x42,0x15,0xb8,0xca // vfmadd231ps %ymm10,%ymm13,%ymm9 - .byte 0xc4,0x41,0x1c,0x5d,0xc9 // vminps %ymm9,%ymm12,%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x52,0x58 // vbroadcastss 0x58(%rdx),%ymm10 - .byte 0xc4,0xc1,0x7c,0xc2,0xc2,0x01 // vcmpltps %ymm10,%ymm0,%ymm0 - .byte 0xc4,0xc3,0x35,0x4a,0xc3,0x00 // vblendvps %ymm0,%ymm11,%ymm9,%ymm0 - .byte 0xc5,0x7c,0x52,0xc9 // vrsqrtps %ymm1,%ymm9 - .byte 0xc4,0x41,0x7c,0x53,0xd9 // vrcpps %ymm9,%ymm11 - .byte 0xc4,0x41,0x7c,0x52,0xc9 // vrsqrtps %ymm9,%ymm9 - .byte 0xc4,0x42,0x0d,0xa8,0xdf // vfmadd213ps %ymm15,%ymm14,%ymm11 - .byte 0xc4,0x42,0x15,0xb8,0xd9 // vfmadd231ps %ymm9,%ymm13,%ymm11 - .byte 0xc5,0x3c,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm9 - .byte 0xc4,0x41,0x1c,0x5d,0xdb // vminps %ymm11,%ymm12,%ymm11 - .byte 0xc4,0xc1,0x74,0xc2,0xca,0x01 // vcmpltps %ymm10,%ymm1,%ymm1 - .byte 0xc4,0xc3,0x25,0x4a,0xc9,0x10 // vblendvps %ymm1,%ymm9,%ymm11,%ymm1 - .byte 0xc5,0x7c,0x52,0xca // vrsqrtps %ymm2,%ymm9 - .byte 0xc4,0x41,0x7c,0x53,0xd9 // vrcpps %ymm9,%ymm11 - .byte 0xc4,0x42,0x0d,0xa8,0xdf // vfmadd213ps %ymm15,%ymm14,%ymm11 - .byte 0xc4,0x41,0x7c,0x52,0xc9 // vrsqrtps %ymm9,%ymm9 - .byte 0xc4,0x42,0x15,0xb8,0xd9 // vfmadd231ps %ymm9,%ymm13,%ymm11 - .byte 0xc4,0x41,0x1c,0x5d,0xcb // vminps %ymm11,%ymm12,%ymm9 - .byte 0xc5,0x3c,0x59,0xc2 // vmulps %ymm2,%ymm8,%ymm8 - .byte 0xc4,0xc1,0x6c,0xc2,0xd2,0x01 // vcmpltps %ymm10,%ymm2,%ymm2 - .byte 0xc4,0xc3,0x35,0x4a,0xd0,0x20 // vblendvps %ymm2,%ymm8,%ymm9,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 197,124,82,192 // vrsqrtps %ymm0,%ymm8 + .byte 196,65,124,83,200 // vrcpps %ymm8,%ymm9 + .byte 196,65,124,82,208 // vrsqrtps %ymm8,%ymm10 + .byte 196,98,125,24,66,72 // vbroadcastss 0x48(%rdx),%ymm8 + .byte 197,60,89,216 // vmulps %ymm0,%ymm8,%ymm11 + .byte 196,98,125,24,34 // vbroadcastss (%rdx),%ymm12 + .byte 196,98,125,24,106,76 // vbroadcastss 0x4c(%rdx),%ymm13 + .byte 196,98,125,24,114,80 // vbroadcastss 0x50(%rdx),%ymm14 + .byte 196,98,125,24,122,84 // vbroadcastss 0x54(%rdx),%ymm15 + .byte 196,66,13,168,207 // vfmadd213ps %ymm15,%ymm14,%ymm9 + .byte 196,66,21,184,202 // vfmadd231ps %ymm10,%ymm13,%ymm9 + .byte 196,65,28,93,201 // vminps %ymm9,%ymm12,%ymm9 + .byte 196,98,125,24,82,88 // vbroadcastss 0x58(%rdx),%ymm10 + .byte 196,193,124,194,194,1 // vcmpltps %ymm10,%ymm0,%ymm0 + .byte 196,195,53,74,195,0 // vblendvps %ymm0,%ymm11,%ymm9,%ymm0 + .byte 197,124,82,201 // vrsqrtps %ymm1,%ymm9 + .byte 196,65,124,83,217 // vrcpps %ymm9,%ymm11 + .byte 196,65,124,82,201 // vrsqrtps %ymm9,%ymm9 + .byte 196,66,13,168,223 // vfmadd213ps %ymm15,%ymm14,%ymm11 + .byte 196,66,21,184,217 // vfmadd231ps %ymm9,%ymm13,%ymm11 + .byte 197,60,89,201 // vmulps %ymm1,%ymm8,%ymm9 + .byte 196,65,28,93,219 // vminps %ymm11,%ymm12,%ymm11 + .byte 196,193,116,194,202,1 // vcmpltps %ymm10,%ymm1,%ymm1 + .byte 196,195,37,74,201,16 // vblendvps %ymm1,%ymm9,%ymm11,%ymm1 + .byte 197,124,82,202 // vrsqrtps %ymm2,%ymm9 + .byte 196,65,124,83,217 // vrcpps %ymm9,%ymm11 + .byte 196,66,13,168,223 // vfmadd213ps %ymm15,%ymm14,%ymm11 + .byte 196,65,124,82,201 // vrsqrtps %ymm9,%ymm9 + .byte 196,66,21,184,217 // vfmadd231ps %ymm9,%ymm13,%ymm11 + .byte 196,65,28,93,203 // vminps %ymm11,%ymm12,%ymm9 + .byte 197,60,89,194 // vmulps %ymm2,%ymm8,%ymm8 + .byte 196,193,108,194,210,1 // vcmpltps %ymm10,%ymm2,%ymm2 + .byte 196,195,53,74,208,32 // vblendvps %ymm2,%ymm8,%ymm9,%ymm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_scale_u8_hsw _sk_scale_u8_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc4,0x62,0x7d,0x31,0x04,0x38 // vpmovzxbd (%rax,%rdi,1),%ymm8 - .byte 0xc4,0x41,0x7c,0x5b,0xc0 // vcvtdq2ps %ymm8,%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x4a,0x0c // vbroadcastss 0xc(%rdx),%ymm9 - .byte 0xc4,0x41,0x3c,0x59,0xc1 // vmulps %ymm9,%ymm8,%ymm8 - .byte 0xc5,0xbc,0x59,0xc0 // vmulps %ymm0,%ymm8,%ymm0 - .byte 0xc5,0xbc,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm1 - .byte 0xc5,0xbc,0x59,0xd2 // vmulps %ymm2,%ymm8,%ymm2 - .byte 0xc5,0xbc,0x59,0xdb // vmulps %ymm3,%ymm8,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 196,98,125,49,4,56 // vpmovzxbd (%rax,%rdi,1),%ymm8 + .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 + .byte 196,98,125,24,74,12 // vbroadcastss 0xc(%rdx),%ymm9 + .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 255,224 // jmpq *%rax .globl _sk_lerp_u8_hsw _sk_lerp_u8_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc4,0x62,0x7d,0x31,0x04,0x38 // vpmovzxbd (%rax,%rdi,1),%ymm8 - .byte 0xc4,0x41,0x7c,0x5b,0xc0 // vcvtdq2ps %ymm8,%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x4a,0x0c // vbroadcastss 0xc(%rdx),%ymm9 - .byte 0xc4,0x41,0x3c,0x59,0xc1 // vmulps %ymm9,%ymm8,%ymm8 - .byte 0xc5,0xfc,0x5c,0xc4 // vsubps %ymm4,%ymm0,%ymm0 - .byte 0xc4,0xe2,0x3d,0xa8,0xc4 // vfmadd213ps %ymm4,%ymm8,%ymm0 - .byte 0xc5,0xf4,0x5c,0xcd // vsubps %ymm5,%ymm1,%ymm1 - .byte 0xc4,0xe2,0x3d,0xa8,0xcd // vfmadd213ps %ymm5,%ymm8,%ymm1 - .byte 0xc5,0xec,0x5c,0xd6 // vsubps %ymm6,%ymm2,%ymm2 - .byte 0xc4,0xe2,0x3d,0xa8,0xd6 // vfmadd213ps %ymm6,%ymm8,%ymm2 - .byte 0xc5,0xe4,0x5c,0xdf // vsubps %ymm7,%ymm3,%ymm3 - .byte 0xc4,0xe2,0x3d,0xa8,0xdf // vfmadd213ps %ymm7,%ymm8,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 196,98,125,49,4,56 // vpmovzxbd (%rax,%rdi,1),%ymm8 + .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 + .byte 196,98,125,24,74,12 // vbroadcastss 0xc(%rdx),%ymm9 + .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 255,224 // jmpq *%rax .globl _sk_load_tables_hsw _sk_load_tables_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x08 // mov (%rax),%rcx - .byte 0x4c,0x8b,0x40,0x08 // mov 0x8(%rax),%r8 - .byte 0xc5,0xfc,0x10,0x1c,0xb9 // vmovups (%rcx,%rdi,4),%ymm3 - .byte 0xc4,0xe2,0x7d,0x18,0x52,0x10 // vbroadcastss 0x10(%rdx),%ymm2 - .byte 0xc5,0xec,0x54,0xcb // vandps %ymm3,%ymm2,%ymm1 - .byte 0xc5,0xfc,0x57,0xc0 // vxorps %ymm0,%ymm0,%ymm0 - .byte 0xc5,0x7c,0xc2,0xc0,0x00 // vcmpeqps %ymm0,%ymm0,%ymm8 - .byte 0xc4,0x41,0x7c,0x28,0xc8 // vmovaps %ymm8,%ymm9 - .byte 0xc4,0xc2,0x35,0x92,0x04,0x88 // vgatherdps %ymm9,(%r8,%ymm1,4),%ymm0 - .byte 0x48,0x8b,0x48,0x10 // mov 0x10(%rax),%rcx - .byte 0xc5,0xf5,0x72,0xd3,0x08 // vpsrld $0x8,%ymm3,%ymm1 - .byte 0xc5,0x6c,0x54,0xc9 // vandps %ymm1,%ymm2,%ymm9 - .byte 0xc4,0x41,0x7c,0x28,0xd0 // vmovaps %ymm8,%ymm10 - .byte 0xc4,0xa2,0x2d,0x92,0x0c,0x89 // vgatherdps %ymm10,(%rcx,%ymm9,4),%ymm1 - .byte 0x48,0x8b,0x40,0x18 // mov 0x18(%rax),%rax - .byte 0xc5,0xb5,0x72,0xd3,0x10 // vpsrld $0x10,%ymm3,%ymm9 - .byte 0xc4,0x41,0x6c,0x54,0xc9 // vandps %ymm9,%ymm2,%ymm9 - .byte 0xc4,0xa2,0x3d,0x92,0x14,0x88 // vgatherdps %ymm8,(%rax,%ymm9,4),%ymm2 - .byte 0xc5,0xe5,0x72,0xd3,0x18 // vpsrld $0x18,%ymm3,%ymm3 - .byte 0xc5,0xfc,0x5b,0xdb // vcvtdq2ps %ymm3,%ymm3 - .byte 0xc4,0x62,0x7d,0x18,0x42,0x0c // vbroadcastss 0xc(%rdx),%ymm8 - .byte 0xc4,0xc1,0x64,0x59,0xd8 // vmulps %ymm8,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,8 // mov (%rax),%rcx + .byte 76,139,64,8 // mov 0x8(%rax),%r8 + .byte 197,252,16,28,185 // vmovups (%rcx,%rdi,4),%ymm3 + .byte 196,226,125,24,82,16 // vbroadcastss 0x10(%rdx),%ymm2 + .byte 197,236,84,203 // vandps %ymm3,%ymm2,%ymm1 + .byte 197,252,87,192 // vxorps %ymm0,%ymm0,%ymm0 + .byte 197,124,194,192,0 // vcmpeqps %ymm0,%ymm0,%ymm8 + .byte 196,65,124,40,200 // vmovaps %ymm8,%ymm9 + .byte 196,194,53,146,4,136 // vgatherdps %ymm9,(%r8,%ymm1,4),%ymm0 + .byte 72,139,72,16 // mov 0x10(%rax),%rcx + .byte 197,245,114,211,8 // vpsrld $0x8,%ymm3,%ymm1 + .byte 197,108,84,201 // vandps %ymm1,%ymm2,%ymm9 + .byte 196,65,124,40,208 // vmovaps %ymm8,%ymm10 + .byte 196,162,45,146,12,137 // vgatherdps %ymm10,(%rcx,%ymm9,4),%ymm1 + .byte 72,139,64,24 // mov 0x18(%rax),%rax + .byte 197,181,114,211,16 // vpsrld $0x10,%ymm3,%ymm9 + .byte 196,65,108,84,201 // vandps %ymm9,%ymm2,%ymm9 + .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,66,12 // vbroadcastss 0xc(%rdx),%ymm8 + .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_load_8888_hsw _sk_load_8888_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc5,0xfc,0x10,0x1c,0xb8 // vmovups (%rax,%rdi,4),%ymm3 - .byte 0xc4,0xe2,0x7d,0x18,0x52,0x10 // vbroadcastss 0x10(%rdx),%ymm2 - .byte 0xc5,0xec,0x54,0xc3 // vandps %ymm3,%ymm2,%ymm0 - .byte 0xc5,0xfc,0x5b,0xc0 // vcvtdq2ps %ymm0,%ymm0 - .byte 0xc4,0x62,0x7d,0x18,0x42,0x0c // vbroadcastss 0xc(%rdx),%ymm8 - .byte 0xc5,0xbc,0x59,0xc0 // vmulps %ymm0,%ymm8,%ymm0 - .byte 0xc5,0xf5,0x72,0xd3,0x08 // vpsrld $0x8,%ymm3,%ymm1 - .byte 0xc5,0xec,0x54,0xc9 // vandps %ymm1,%ymm2,%ymm1 - .byte 0xc5,0xfc,0x5b,0xc9 // vcvtdq2ps %ymm1,%ymm1 - .byte 0xc5,0xbc,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm1 - .byte 0xc5,0xb5,0x72,0xd3,0x10 // vpsrld $0x10,%ymm3,%ymm9 - .byte 0xc4,0xc1,0x6c,0x54,0xd1 // vandps %ymm9,%ymm2,%ymm2 - .byte 0xc5,0xfc,0x5b,0xd2 // vcvtdq2ps %ymm2,%ymm2 - .byte 0xc5,0xbc,0x59,0xd2 // vmulps %ymm2,%ymm8,%ymm2 - .byte 0xc5,0xe5,0x72,0xd3,0x18 // vpsrld $0x18,%ymm3,%ymm3 - .byte 0xc5,0xfc,0x5b,0xdb // vcvtdq2ps %ymm3,%ymm3 - .byte 0xc4,0xc1,0x64,0x59,0xd8 // vmulps %ymm8,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 197,252,16,28,184 // vmovups (%rax,%rdi,4),%ymm3 + .byte 196,226,125,24,82,16 // vbroadcastss 0x10(%rdx),%ymm2 + .byte 197,236,84,195 // vandps %ymm3,%ymm2,%ymm0 + .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 + .byte 196,98,125,24,66,12 // vbroadcastss 0xc(%rdx),%ymm8 + .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 + .byte 197,245,114,211,8 // vpsrld $0x8,%ymm3,%ymm1 + .byte 197,236,84,201 // vandps %ymm1,%ymm2,%ymm1 + .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 + .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 + .byte 197,181,114,211,16 // vpsrld $0x10,%ymm3,%ymm9 + .byte 196,193,108,84,209 // vandps %ymm9,%ymm2,%ymm2 + .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 + .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%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 .globl _sk_store_8888_hsw _sk_store_8888_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc4,0x62,0x7d,0x18,0x42,0x08 // vbroadcastss 0x8(%rdx),%ymm8 - .byte 0xc5,0x3c,0x59,0xc8 // vmulps %ymm0,%ymm8,%ymm9 - .byte 0xc4,0x41,0x7d,0x5b,0xc9 // vcvtps2dq %ymm9,%ymm9 - .byte 0xc5,0x3c,0x59,0xd1 // vmulps %ymm1,%ymm8,%ymm10 - .byte 0xc4,0x41,0x7d,0x5b,0xd2 // vcvtps2dq %ymm10,%ymm10 - .byte 0xc4,0xc1,0x2d,0x72,0xf2,0x08 // vpslld $0x8,%ymm10,%ymm10 - .byte 0xc4,0x41,0x2d,0xeb,0xc9 // vpor %ymm9,%ymm10,%ymm9 - .byte 0xc5,0x3c,0x59,0xd2 // vmulps %ymm2,%ymm8,%ymm10 - .byte 0xc4,0x41,0x7d,0x5b,0xd2 // vcvtps2dq %ymm10,%ymm10 - .byte 0xc4,0xc1,0x2d,0x72,0xf2,0x10 // vpslld $0x10,%ymm10,%ymm10 - .byte 0xc5,0x3c,0x59,0xc3 // vmulps %ymm3,%ymm8,%ymm8 - .byte 0xc4,0x41,0x7d,0x5b,0xc0 // vcvtps2dq %ymm8,%ymm8 - .byte 0xc4,0xc1,0x3d,0x72,0xf0,0x18 // vpslld $0x18,%ymm8,%ymm8 - .byte 0xc4,0x41,0x2d,0xeb,0xc0 // vpor %ymm8,%ymm10,%ymm8 - .byte 0xc4,0x41,0x35,0xeb,0xc0 // vpor %ymm8,%ymm9,%ymm8 - .byte 0xc5,0x7e,0x7f,0x04,0xb8 // vmovdqu %ymm8,(%rax,%rdi,4) - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 196,98,125,24,66,8 // vbroadcastss 0x8(%rdx),%ymm8 + .byte 197,60,89,200 // vmulps %ymm0,%ymm8,%ymm9 + .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 + .byte 197,60,89,209 // vmulps %ymm1,%ymm8,%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 197,60,89,210 // vmulps %ymm2,%ymm8,%ymm10 + .byte 196,65,125,91,210 // vcvtps2dq %ymm10,%ymm10 + .byte 196,193,45,114,242,16 // vpslld $0x10,%ymm10,%ymm10 + .byte 197,60,89,195 // vmulps %ymm3,%ymm8,%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 197,126,127,4,184 // vmovdqu %ymm8,(%rax,%rdi,4) + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_load_f16_hsw _sk_load_f16_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc5,0xfa,0x6f,0x04,0xf8 // vmovdqu (%rax,%rdi,8),%xmm0 - .byte 0xc5,0xfa,0x6f,0x4c,0xf8,0x10 // vmovdqu 0x10(%rax,%rdi,8),%xmm1 - .byte 0xc5,0xfa,0x6f,0x54,0xf8,0x20 // vmovdqu 0x20(%rax,%rdi,8),%xmm2 - .byte 0xc5,0xfa,0x6f,0x5c,0xf8,0x30 // vmovdqu 0x30(%rax,%rdi,8),%xmm3 - .byte 0xc5,0x79,0x61,0xc1 // vpunpcklwd %xmm1,%xmm0,%xmm8 - .byte 0xc5,0xf9,0x69,0xc1 // vpunpckhwd %xmm1,%xmm0,%xmm0 - .byte 0xc5,0xe9,0x61,0xcb // vpunpcklwd %xmm3,%xmm2,%xmm1 - .byte 0xc5,0xe9,0x69,0xd3 // vpunpckhwd %xmm3,%xmm2,%xmm2 - .byte 0xc5,0x39,0x61,0xc8 // vpunpcklwd %xmm0,%xmm8,%xmm9 - .byte 0xc5,0x39,0x69,0xc0 // vpunpckhwd %xmm0,%xmm8,%xmm8 - .byte 0xc5,0xf1,0x61,0xda // vpunpcklwd %xmm2,%xmm1,%xmm3 - .byte 0xc5,0x71,0x69,0xd2 // vpunpckhwd %xmm2,%xmm1,%xmm10 - .byte 0xc5,0xb1,0x6c,0xc3 // vpunpcklqdq %xmm3,%xmm9,%xmm0 - .byte 0xc4,0xe2,0x7d,0x13,0xc0 // vcvtph2ps %xmm0,%ymm0 - .byte 0xc5,0xb1,0x6d,0xcb // vpunpckhqdq %xmm3,%xmm9,%xmm1 - .byte 0xc4,0xe2,0x7d,0x13,0xc9 // vcvtph2ps %xmm1,%ymm1 - .byte 0xc4,0xc1,0x39,0x6c,0xd2 // vpunpcklqdq %xmm10,%xmm8,%xmm2 - .byte 0xc4,0xe2,0x7d,0x13,0xd2 // vcvtph2ps %xmm2,%ymm2 - .byte 0xc4,0xc1,0x39,0x6d,0xda // vpunpckhqdq %xmm10,%xmm8,%xmm3 - .byte 0xc4,0xe2,0x7d,0x13,0xdb // vcvtph2ps %xmm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 197,250,111,4,248 // vmovdqu (%rax,%rdi,8),%xmm0 + .byte 197,250,111,76,248,16 // vmovdqu 0x10(%rax,%rdi,8),%xmm1 + .byte 197,250,111,84,248,32 // vmovdqu 0x20(%rax,%rdi,8),%xmm2 + .byte 197,250,111,92,248,48 // vmovdqu 0x30(%rax,%rdi,8),%xmm3 + .byte 197,121,97,193 // vpunpcklwd %xmm1,%xmm0,%xmm8 + .byte 197,249,105,193 // vpunpckhwd %xmm1,%xmm0,%xmm0 + .byte 197,233,97,203 // vpunpcklwd %xmm3,%xmm2,%xmm1 + .byte 197,233,105,211 // vpunpckhwd %xmm3,%xmm2,%xmm2 + .byte 197,57,97,200 // vpunpcklwd %xmm0,%xmm8,%xmm9 + .byte 197,57,105,192 // vpunpckhwd %xmm0,%xmm8,%xmm8 + .byte 197,241,97,218 // vpunpcklwd %xmm2,%xmm1,%xmm3 + .byte 197,113,105,210 // vpunpckhwd %xmm2,%xmm1,%xmm10 + .byte 197,177,108,195 // vpunpcklqdq %xmm3,%xmm9,%xmm0 + .byte 196,226,125,19,192 // vcvtph2ps %xmm0,%ymm0 + .byte 197,177,109,203 // vpunpckhqdq %xmm3,%xmm9,%xmm1 + .byte 196,226,125,19,201 // vcvtph2ps %xmm1,%ymm1 + .byte 196,193,57,108,210 // vpunpcklqdq %xmm10,%xmm8,%xmm2 + .byte 196,226,125,19,210 // vcvtph2ps %xmm2,%ymm2 + .byte 196,193,57,109,218 // vpunpckhqdq %xmm10,%xmm8,%xmm3 + .byte 196,226,125,19,219 // vcvtph2ps %xmm3,%ymm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_store_f16_hsw _sk_store_f16_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc4,0xc3,0x7d,0x1d,0xc0,0x04 // vcvtps2ph $0x4,%ymm0,%xmm8 - .byte 0xc4,0xc3,0x7d,0x1d,0xc9,0x04 // vcvtps2ph $0x4,%ymm1,%xmm9 - .byte 0xc4,0xc3,0x7d,0x1d,0xd2,0x04 // vcvtps2ph $0x4,%ymm2,%xmm10 - .byte 0xc4,0xc3,0x7d,0x1d,0xdb,0x04 // vcvtps2ph $0x4,%ymm3,%xmm11 - .byte 0xc4,0x41,0x39,0x61,0xe1 // vpunpcklwd %xmm9,%xmm8,%xmm12 - .byte 0xc4,0x41,0x39,0x69,0xc1 // vpunpckhwd %xmm9,%xmm8,%xmm8 - .byte 0xc4,0x41,0x29,0x61,0xcb // vpunpcklwd %xmm11,%xmm10,%xmm9 - .byte 0xc4,0x41,0x29,0x69,0xd3 // vpunpckhwd %xmm11,%xmm10,%xmm10 - .byte 0xc4,0x41,0x19,0x62,0xd9 // vpunpckldq %xmm9,%xmm12,%xmm11 - .byte 0xc5,0x7a,0x7f,0x1c,0xf8 // vmovdqu %xmm11,(%rax,%rdi,8) - .byte 0xc4,0x41,0x19,0x6a,0xc9 // vpunpckhdq %xmm9,%xmm12,%xmm9 - .byte 0xc5,0x7a,0x7f,0x4c,0xf8,0x10 // vmovdqu %xmm9,0x10(%rax,%rdi,8) - .byte 0xc4,0x41,0x39,0x62,0xca // vpunpckldq %xmm10,%xmm8,%xmm9 - .byte 0xc5,0x7a,0x7f,0x4c,0xf8,0x20 // vmovdqu %xmm9,0x20(%rax,%rdi,8) - .byte 0xc4,0x41,0x39,0x6a,0xc2 // vpunpckhdq %xmm10,%xmm8,%xmm8 - .byte 0xc5,0x7a,0x7f,0x44,0xf8,0x30 // vmovdqu %xmm8,0x30(%rax,%rdi,8) - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%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,211 // vpunpckhwd %xmm11,%xmm10,%xmm10 + .byte 196,65,25,98,217 // vpunpckldq %xmm9,%xmm12,%xmm11 + .byte 197,122,127,28,248 // vmovdqu %xmm11,(%rax,%rdi,8) + .byte 196,65,25,106,201 // vpunpckhdq %xmm9,%xmm12,%xmm9 + .byte 197,122,127,76,248,16 // vmovdqu %xmm9,0x10(%rax,%rdi,8) + .byte 196,65,57,98,202 // vpunpckldq %xmm10,%xmm8,%xmm9 + .byte 197,122,127,76,248,32 // vmovdqu %xmm9,0x20(%rax,%rdi,8) + .byte 196,65,57,106,194 // vpunpckhdq %xmm10,%xmm8,%xmm8 + .byte 197,122,127,68,248,48 // vmovdqu %xmm8,0x30(%rax,%rdi,8) + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_clamp_x_hsw _sk_clamp_x_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x58,0x00 // vpbroadcastd (%rax),%ymm8 - .byte 0xc4,0x41,0x35,0x76,0xc9 // vpcmpeqd %ymm9,%ymm9,%ymm9 - .byte 0xc4,0x41,0x3d,0xfe,0xc1 // vpaddd %ymm9,%ymm8,%ymm8 - .byte 0xc4,0xc1,0x7c,0x5d,0xc0 // vminps %ymm8,%ymm0,%ymm0 - .byte 0xc4,0x41,0x3c,0x57,0xc0 // vxorps %ymm8,%ymm8,%ymm8 - .byte 0xc5,0xbc,0x5f,0xc0 // vmaxps %ymm0,%ymm8,%ymm0 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 + .byte 197,188,95,192 // vmaxps %ymm0,%ymm8,%ymm0 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_clamp_y_hsw _sk_clamp_y_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x58,0x00 // vpbroadcastd (%rax),%ymm8 - .byte 0xc4,0x41,0x35,0x76,0xc9 // vpcmpeqd %ymm9,%ymm9,%ymm9 - .byte 0xc4,0x41,0x3d,0xfe,0xc1 // vpaddd %ymm9,%ymm8,%ymm8 - .byte 0xc4,0xc1,0x74,0x5d,0xc8 // vminps %ymm8,%ymm1,%ymm1 - .byte 0xc4,0x41,0x3c,0x57,0xc0 // vxorps %ymm8,%ymm8,%ymm8 - .byte 0xc5,0xbc,0x5f,0xc9 // vmaxps %ymm1,%ymm8,%ymm1 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 + .byte 197,188,95,201 // vmaxps %ymm1,%ymm8,%ymm1 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_matrix_2x3_hsw _sk_matrix_2x3_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x08 // vbroadcastss (%rax),%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x08 // vbroadcastss 0x8(%rax),%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x40,0x10 // vbroadcastss 0x10(%rax),%ymm8 - .byte 0xc4,0x42,0x75,0xb8,0xc2 // vfmadd231ps %ymm10,%ymm1,%ymm8 - .byte 0xc4,0x42,0x7d,0xb8,0xc1 // vfmadd231ps %ymm9,%ymm0,%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x04 // vbroadcastss 0x4(%rax),%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x58,0x0c // vbroadcastss 0xc(%rax),%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x48,0x14 // vbroadcastss 0x14(%rax),%ymm9 - .byte 0xc4,0x42,0x75,0xb8,0xcb // vfmadd231ps %ymm11,%ymm1,%ymm9 - .byte 0xc4,0x42,0x7d,0xb8,0xca // vfmadd231ps %ymm10,%ymm0,%ymm9 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0x7c,0x29,0xc0 // vmovaps %ymm8,%ymm0 - .byte 0xc5,0x7c,0x29,0xc9 // vmovaps %ymm9,%ymm1 - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_matrix_3x4_hsw _sk_matrix_3x4_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x08 // vbroadcastss (%rax),%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x0c // vbroadcastss 0xc(%rax),%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x58,0x18 // vbroadcastss 0x18(%rax),%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x40,0x24 // vbroadcastss 0x24(%rax),%ymm8 - .byte 0xc4,0x42,0x6d,0xb8,0xc3 // vfmadd231ps %ymm11,%ymm2,%ymm8 - .byte 0xc4,0x42,0x75,0xb8,0xc2 // vfmadd231ps %ymm10,%ymm1,%ymm8 - .byte 0xc4,0x42,0x7d,0xb8,0xc1 // vfmadd231ps %ymm9,%ymm0,%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x04 // vbroadcastss 0x4(%rax),%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x58,0x10 // vbroadcastss 0x10(%rax),%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x60,0x1c // vbroadcastss 0x1c(%rax),%ymm12 - .byte 0xc4,0x62,0x7d,0x18,0x48,0x28 // vbroadcastss 0x28(%rax),%ymm9 - .byte 0xc4,0x42,0x6d,0xb8,0xcc // vfmadd231ps %ymm12,%ymm2,%ymm9 - .byte 0xc4,0x42,0x75,0xb8,0xcb // vfmadd231ps %ymm11,%ymm1,%ymm9 - .byte 0xc4,0x42,0x7d,0xb8,0xca // vfmadd231ps %ymm10,%ymm0,%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x58,0x08 // vbroadcastss 0x8(%rax),%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x60,0x14 // vbroadcastss 0x14(%rax),%ymm12 - .byte 0xc4,0x62,0x7d,0x18,0x68,0x20 // vbroadcastss 0x20(%rax),%ymm13 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x2c // vbroadcastss 0x2c(%rax),%ymm10 - .byte 0xc4,0x42,0x6d,0xb8,0xd5 // vfmadd231ps %ymm13,%ymm2,%ymm10 - .byte 0xc4,0x42,0x75,0xb8,0xd4 // vfmadd231ps %ymm12,%ymm1,%ymm10 - .byte 0xc4,0x42,0x7d,0xb8,0xd3 // vfmadd231ps %ymm11,%ymm0,%ymm10 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0x7c,0x29,0xc0 // vmovaps %ymm8,%ymm0 - .byte 0xc5,0x7c,0x29,0xc9 // vmovaps %ymm9,%ymm1 - .byte 0xc5,0x7c,0x29,0xd2 // vmovaps %ymm10,%ymm2 - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_linear_gradient_2stops_hsw _sk_linear_gradient_2stops_hsw: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0xe2,0x7d,0x18,0x48,0x10 // vbroadcastss 0x10(%rax),%ymm1 - .byte 0xc4,0x62,0x7d,0x18,0x00 // vbroadcastss (%rax),%ymm8 - .byte 0xc4,0x62,0x7d,0xb8,0xc1 // vfmadd231ps %ymm1,%ymm0,%ymm8 - .byte 0xc4,0xe2,0x7d,0x18,0x50,0x14 // vbroadcastss 0x14(%rax),%ymm2 - .byte 0xc4,0xe2,0x7d,0x18,0x48,0x04 // vbroadcastss 0x4(%rax),%ymm1 - .byte 0xc4,0xe2,0x7d,0xb8,0xca // vfmadd231ps %ymm2,%ymm0,%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x58,0x18 // vbroadcastss 0x18(%rax),%ymm3 - .byte 0xc4,0xe2,0x7d,0x18,0x50,0x08 // vbroadcastss 0x8(%rax),%ymm2 - .byte 0xc4,0xe2,0x7d,0xb8,0xd3 // vfmadd231ps %ymm3,%ymm0,%ymm2 - .byte 0xc4,0x62,0x7d,0x18,0x48,0x1c // vbroadcastss 0x1c(%rax),%ymm9 - .byte 0xc4,0xe2,0x7d,0x18,0x58,0x0c // vbroadcastss 0xc(%rax),%ymm3 - .byte 0xc4,0xc2,0x7d,0xb8,0xd9 // vfmadd231ps %ymm9,%ymm0,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0x7c,0x29,0xc0 // vmovaps %ymm8,%ymm0 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,226,125,24,72,16 // vbroadcastss 0x10(%rax),%ymm1 + .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 + .byte 196,98,125,184,193 // vfmadd231ps %ymm1,%ymm0,%ymm8 + .byte 196,226,125,24,80,20 // vbroadcastss 0x14(%rax),%ymm2 + .byte 196,226,125,24,72,4 // vbroadcastss 0x4(%rax),%ymm1 + .byte 196,226,125,184,202 // vfmadd231ps %ymm2,%ymm0,%ymm1 + .byte 196,226,125,24,88,24 // vbroadcastss 0x18(%rax),%ymm3 + .byte 196,226,125,24,80,8 // vbroadcastss 0x8(%rax),%ymm2 + .byte 196,226,125,184,211 // vfmadd231ps %ymm3,%ymm0,%ymm2 + .byte 196,98,125,24,72,28 // vbroadcastss 0x1c(%rax),%ymm9 + .byte 196,226,125,24,88,12 // vbroadcastss 0xc(%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 .globl _sk_start_pipeline_avx _sk_start_pipeline_avx: - .byte 0x41,0x57 // push %r15 - .byte 0x41,0x56 // push %r14 - .byte 0x41,0x55 // push %r13 - .byte 0x41,0x54 // push %r12 - .byte 0x53 // push %rbx - .byte 0x49,0x89,0xcf // mov %rcx,%r15 - .byte 0x49,0x89,0xd6 // mov %rdx,%r14 - .byte 0x48,0x89,0xfb // mov %rdi,%rbx - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x49,0x89,0xc4 // mov %rax,%r12 - .byte 0x49,0x89,0xf5 // mov %rsi,%r13 - .byte 0x48,0x8d,0x43,0x08 // lea 0x8(%rbx),%rax - .byte 0x4c,0x39,0xf8 // cmp %r15,%rax - .byte 0x76,0x05 // jbe 28 <_sk_start_pipeline_avx+0x28> - .byte 0x48,0x89,0xd8 // mov %rbx,%rax - .byte 0xeb,0x3c // jmp 64 <_sk_start_pipeline_avx+0x64> - .byte 0xc5,0xfc,0x57,0xc0 // vxorps %ymm0,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x57,0xc9 // vxorps %ymm1,%ymm1,%ymm1 - .byte 0xc5,0xec,0x57,0xd2 // vxorps %ymm2,%ymm2,%ymm2 - .byte 0xc5,0xe4,0x57,0xdb // vxorps %ymm3,%ymm3,%ymm3 - .byte 0xc5,0xdc,0x57,0xe4 // vxorps %ymm4,%ymm4,%ymm4 - .byte 0xc5,0xd4,0x57,0xed // vxorps %ymm5,%ymm5,%ymm5 - .byte 0xc5,0xcc,0x57,0xf6 // vxorps %ymm6,%ymm6,%ymm6 - .byte 0xc5,0xc4,0x57,0xff // vxorps %ymm7,%ymm7,%ymm7 - .byte 0x48,0x89,0xdf // mov %rbx,%rdi - .byte 0x4c,0x89,0xee // mov %r13,%rsi - .byte 0x4c,0x89,0xf2 // mov %r14,%rdx - .byte 0x41,0xff,0xd4 // callq *%r12 - .byte 0x48,0x8d,0x43,0x08 // lea 0x8(%rbx),%rax - .byte 0x48,0x83,0xc3,0x10 // add $0x10,%rbx - .byte 0x4c,0x39,0xfb // cmp %r15,%rbx - .byte 0x48,0x89,0xc3 // mov %rax,%rbx - .byte 0x76,0xc4 // jbe 28 <_sk_start_pipeline_avx+0x28> - .byte 0x5b // pop %rbx - .byte 0x41,0x5c // pop %r12 - .byte 0x41,0x5d // pop %r13 - .byte 0x41,0x5e // pop %r14 - .byte 0x41,0x5f // pop %r15 - .byte 0xc5,0xf8,0x77 // vzeroupper - .byte 0xc3 // retq + .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 73,137,207 // mov %rcx,%r15 + .byte 73,137,214 // mov %rdx,%r14 + .byte 72,137,251 // mov %rdi,%rbx + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 73,137,196 // mov %rax,%r12 + .byte 73,137,245 // mov %rsi,%r13 + .byte 72,141,67,8 // lea 0x8(%rbx),%rax + .byte 76,57,248 // cmp %r15,%rax + .byte 118,5 // jbe 28 <_sk_start_pipeline_avx+0x28> + .byte 72,137,216 // mov %rbx,%rax + .byte 235,60 // jmp 64 <_sk_start_pipeline_avx+0x64> + .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 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 72,137,223 // mov %rbx,%rdi + .byte 76,137,238 // mov %r13,%rsi + .byte 76,137,242 // mov %r14,%rdx + .byte 65,255,212 // callq *%r12 + .byte 72,141,67,8 // lea 0x8(%rbx),%rax + .byte 72,131,195,16 // add $0x10,%rbx + .byte 76,57,251 // cmp %r15,%rbx + .byte 72,137,195 // mov %rax,%rbx + .byte 118,196 // jbe 28 <_sk_start_pipeline_avx+0x28> + .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 197,248,119 // vzeroupper + .byte 195 // retq .globl _sk_just_return_avx _sk_just_return_avx: - .byte 0xc3 // retq + .byte 195 // retq .globl _sk_seed_shader_avx _sk_seed_shader_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xf9,0x6e,0xc7 // vmovd %edi,%xmm0 - .byte 0xc4,0xe3,0x79,0x04,0xc0,0x00 // vpermilps $0x0,%xmm0,%xmm0 - .byte 0xc4,0xe3,0x7d,0x18,0xc0,0x01 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm0 - .byte 0xc5,0xfc,0x5b,0xc0 // vcvtdq2ps %ymm0,%ymm0 - .byte 0xc4,0xe2,0x7d,0x18,0x4a,0x04 // vbroadcastss 0x4(%rdx),%ymm1 - .byte 0xc5,0xfc,0x58,0xc1 // vaddps %ymm1,%ymm0,%ymm0 - .byte 0xc5,0xfc,0x58,0x42,0x14 // vaddps 0x14(%rdx),%ymm0,%ymm0 - .byte 0xc5,0xf9,0x6e,0x10 // vmovd (%rax),%xmm2 - .byte 0xc4,0xe3,0x79,0x04,0xd2,0x00 // vpermilps $0x0,%xmm2,%xmm2 - .byte 0xc4,0xe3,0x6d,0x18,0xd2,0x01 // vinsertf128 $0x1,%xmm2,%ymm2,%ymm2 - .byte 0xc5,0xfc,0x5b,0xd2 // vcvtdq2ps %ymm2,%ymm2 - .byte 0xc5,0xec,0x58,0xc9 // vaddps %ymm1,%ymm2,%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x12 // vbroadcastss (%rdx),%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xe4,0x57,0xdb // vxorps %ymm3,%ymm3,%ymm3 - .byte 0xc5,0xdc,0x57,0xe4 // vxorps %ymm4,%ymm4,%ymm4 - .byte 0xc5,0xd4,0x57,0xed // vxorps %ymm5,%ymm5,%ymm5 - .byte 0xc5,0xcc,0x57,0xf6 // vxorps %ymm6,%ymm6,%ymm6 - .byte 0xc5,0xc4,0x57,0xff // vxorps %ymm7,%ymm7,%ymm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 197,249,110,199 // vmovd %edi,%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,252,91,192 // vcvtdq2ps %ymm0,%ymm0 + .byte 196,226,125,24,74,4 // vbroadcastss 0x4(%rdx),%ymm1 + .byte 197,252,88,193 // vaddps %ymm1,%ymm0,%ymm0 + .byte 197,252,88,66,20 // vaddps 0x14(%rdx),%ymm0,%ymm0 + .byte 197,249,110,16 // vmovd (%rax),%xmm2 + .byte 196,227,121,4,210,0 // vpermilps $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 196,226,125,24,18 // vbroadcastss (%rdx),%ymm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_constant_color_avx _sk_constant_color_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0xe2,0x7d,0x18,0x00 // vbroadcastss (%rax),%ymm0 - .byte 0xc4,0xe2,0x7d,0x18,0x48,0x04 // vbroadcastss 0x4(%rax),%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x50,0x08 // vbroadcastss 0x8(%rax),%ymm2 - .byte 0xc4,0xe2,0x7d,0x18,0x58,0x0c // vbroadcastss 0xc(%rax),%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_clear_avx _sk_clear_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x57,0xc0 // vxorps %ymm0,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x57,0xc9 // vxorps %ymm1,%ymm1,%ymm1 - .byte 0xc5,0xec,0x57,0xd2 // vxorps %ymm2,%ymm2,%ymm2 - .byte 0xc5,0xe4,0x57,0xdb // vxorps %ymm3,%ymm3,%ymm3 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_plus__avx _sk_plus__avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x58,0xc4 // vaddps %ymm4,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x58,0xcd // vaddps %ymm5,%ymm1,%ymm1 - .byte 0xc5,0xec,0x58,0xd6 // vaddps %ymm6,%ymm2,%ymm2 - .byte 0xc5,0xe4,0x58,0xdf // vaddps %ymm7,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_srcover_avx _sk_srcover_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x02 // vbroadcastss (%rdx),%ymm8 - .byte 0xc5,0x3c,0x5c,0xc3 // vsubps %ymm3,%ymm8,%ymm8 - .byte 0xc5,0x3c,0x59,0xcc // vmulps %ymm4,%ymm8,%ymm9 - .byte 0xc5,0xb4,0x58,0xc0 // vaddps %ymm0,%ymm9,%ymm0 - .byte 0xc5,0x3c,0x59,0xcd // vmulps %ymm5,%ymm8,%ymm9 - .byte 0xc5,0xb4,0x58,0xc9 // vaddps %ymm1,%ymm9,%ymm1 - .byte 0xc5,0x3c,0x59,0xce // vmulps %ymm6,%ymm8,%ymm9 - .byte 0xc5,0xb4,0x58,0xd2 // vaddps %ymm2,%ymm9,%ymm2 - .byte 0xc5,0x3c,0x59,0xc7 // vmulps %ymm7,%ymm8,%ymm8 - .byte 0xc5,0xbc,0x58,0xdb // vaddps %ymm3,%ymm8,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,2 // vbroadcastss (%rdx),%ymm8 + .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 .globl _sk_dstover_avx _sk_dstover_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x02 // vbroadcastss (%rdx),%ymm8 - .byte 0xc5,0x3c,0x5c,0xc7 // vsubps %ymm7,%ymm8,%ymm8 - .byte 0xc5,0xbc,0x59,0xc0 // vmulps %ymm0,%ymm8,%ymm0 - .byte 0xc5,0xfc,0x58,0xc4 // vaddps %ymm4,%ymm0,%ymm0 - .byte 0xc5,0xbc,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm1 - .byte 0xc5,0xf4,0x58,0xcd // vaddps %ymm5,%ymm1,%ymm1 - .byte 0xc5,0xbc,0x59,0xd2 // vmulps %ymm2,%ymm8,%ymm2 - .byte 0xc5,0xec,0x58,0xd6 // vaddps %ymm6,%ymm2,%ymm2 - .byte 0xc5,0xbc,0x59,0xdb // vmulps %ymm3,%ymm8,%ymm3 - .byte 0xc5,0xe4,0x58,0xdf // vaddps %ymm7,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,2 // vbroadcastss (%rdx),%ymm8 + .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 .globl _sk_clamp_0_avx _sk_clamp_0_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x41,0x3c,0x57,0xc0 // vxorps %ymm8,%ymm8,%ymm8 - .byte 0xc4,0xc1,0x7c,0x5f,0xc0 // vmaxps %ymm8,%ymm0,%ymm0 - .byte 0xc4,0xc1,0x74,0x5f,0xc8 // vmaxps %ymm8,%ymm1,%ymm1 - .byte 0xc4,0xc1,0x6c,0x5f,0xd0 // vmaxps %ymm8,%ymm2,%ymm2 - .byte 0xc4,0xc1,0x64,0x5f,0xd8 // vmaxps %ymm8,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_clamp_1_avx _sk_clamp_1_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x02 // vbroadcastss (%rdx),%ymm8 - .byte 0xc4,0xc1,0x7c,0x5d,0xc0 // vminps %ymm8,%ymm0,%ymm0 - .byte 0xc4,0xc1,0x74,0x5d,0xc8 // vminps %ymm8,%ymm1,%ymm1 - .byte 0xc4,0xc1,0x6c,0x5d,0xd0 // vminps %ymm8,%ymm2,%ymm2 - .byte 0xc4,0xc1,0x64,0x5d,0xd8 // vminps %ymm8,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,2 // vbroadcastss (%rdx),%ymm8 + .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 .globl _sk_clamp_a_avx _sk_clamp_a_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x02 // vbroadcastss (%rdx),%ymm8 - .byte 0xc4,0xc1,0x64,0x5d,0xd8 // vminps %ymm8,%ymm3,%ymm3 - .byte 0xc5,0xfc,0x5d,0xc3 // vminps %ymm3,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x5d,0xcb // vminps %ymm3,%ymm1,%ymm1 - .byte 0xc5,0xec,0x5d,0xd3 // vminps %ymm3,%ymm2,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,2 // vbroadcastss (%rdx),%ymm8 + .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 .globl _sk_set_rgb_avx _sk_set_rgb_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0xe2,0x7d,0x18,0x00 // vbroadcastss (%rax),%ymm0 - .byte 0xc4,0xe2,0x7d,0x18,0x48,0x04 // vbroadcastss 0x4(%rax),%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x50,0x08 // vbroadcastss 0x8(%rax),%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_swap_rb_avx _sk_swap_rb_avx: - .byte 0xc5,0x7c,0x28,0xc0 // vmovaps %ymm0,%ymm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x28,0xc2 // vmovaps %ymm2,%ymm0 - .byte 0xc5,0x7c,0x29,0xc2 // vmovaps %ymm8,%ymm2 - .byte 0xff,0xe0 // jmpq *%rax + .byte 197,124,40,192 // vmovaps %ymm0,%ymm8 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_swap_avx _sk_swap_avx: - .byte 0xc5,0x7c,0x28,0xc3 // vmovaps %ymm3,%ymm8 - .byte 0xc5,0x7c,0x28,0xca // vmovaps %ymm2,%ymm9 - .byte 0xc5,0x7c,0x28,0xd1 // vmovaps %ymm1,%ymm10 - .byte 0xc5,0x7c,0x28,0xd8 // vmovaps %ymm0,%ymm11 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x28,0xc4 // vmovaps %ymm4,%ymm0 - .byte 0xc5,0xfc,0x28,0xcd // vmovaps %ymm5,%ymm1 - .byte 0xc5,0xfc,0x28,0xd6 // vmovaps %ymm6,%ymm2 - .byte 0xc5,0xfc,0x28,0xdf // vmovaps %ymm7,%ymm3 - .byte 0xc5,0x7c,0x29,0xdc // vmovaps %ymm11,%ymm4 - .byte 0xc5,0x7c,0x29,0xd5 // vmovaps %ymm10,%ymm5 - .byte 0xc5,0x7c,0x29,0xce // vmovaps %ymm9,%ymm6 - .byte 0xc5,0x7c,0x29,0xc7 // vmovaps %ymm8,%ymm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 197,124,40,195 // vmovaps %ymm3,%ymm8 + .byte 197,124,40,202 // vmovaps %ymm2,%ymm9 + .byte 197,124,40,209 // vmovaps %ymm1,%ymm10 + .byte 197,124,40,216 // vmovaps %ymm0,%ymm11 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 197,124,41,220 // vmovaps %ymm11,%ymm4 + .byte 197,124,41,213 // vmovaps %ymm10,%ymm5 + .byte 197,124,41,206 // vmovaps %ymm9,%ymm6 + .byte 197,124,41,199 // vmovaps %ymm8,%ymm7 + .byte 255,224 // jmpq *%rax .globl _sk_move_src_dst_avx _sk_move_src_dst_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x28,0xe0 // vmovaps %ymm0,%ymm4 - .byte 0xc5,0xfc,0x28,0xe9 // vmovaps %ymm1,%ymm5 - .byte 0xc5,0xfc,0x28,0xf2 // vmovaps %ymm2,%ymm6 - .byte 0xc5,0xfc,0x28,0xfb // vmovaps %ymm3,%ymm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_move_dst_src_avx _sk_move_dst_src_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x28,0xc4 // vmovaps %ymm4,%ymm0 - .byte 0xc5,0xfc,0x28,0xcd // vmovaps %ymm5,%ymm1 - .byte 0xc5,0xfc,0x28,0xd6 // vmovaps %ymm6,%ymm2 - .byte 0xc5,0xfc,0x28,0xdf // vmovaps %ymm7,%ymm3 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_premul_avx _sk_premul_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0xfc,0x59,0xc3 // vmulps %ymm3,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x59,0xcb // vmulps %ymm3,%ymm1,%ymm1 - .byte 0xc5,0xec,0x59,0xd3 // vmulps %ymm3,%ymm2,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_unpremul_avx _sk_unpremul_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x41,0x3c,0x57,0xc0 // vxorps %ymm8,%ymm8,%ymm8 - .byte 0xc4,0x41,0x64,0xc2,0xc8,0x00 // vcmpeqps %ymm8,%ymm3,%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x12 // vbroadcastss (%rdx),%ymm10 - .byte 0xc5,0x2c,0x5e,0xd3 // vdivps %ymm3,%ymm10,%ymm10 - .byte 0xc4,0x43,0x2d,0x4a,0xc0,0x90 // vblendvps %ymm9,%ymm8,%ymm10,%ymm8 - .byte 0xc5,0xbc,0x59,0xc0 // vmulps %ymm0,%ymm8,%ymm0 - .byte 0xc5,0xbc,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm1 - .byte 0xc5,0xbc,0x59,0xd2 // vmulps %ymm2,%ymm8,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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,18 // vbroadcastss (%rdx),%ymm10 + .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 .globl _sk_from_srgb_avx _sk_from_srgb_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x42,0x40 // vbroadcastss 0x40(%rdx),%ymm8 - .byte 0xc5,0x3c,0x59,0xc8 // vmulps %ymm0,%ymm8,%ymm9 - .byte 0xc5,0x7c,0x59,0xd0 // vmulps %ymm0,%ymm0,%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x5a,0x3c // vbroadcastss 0x3c(%rdx),%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x62,0x38 // vbroadcastss 0x38(%rdx),%ymm12 - .byte 0xc5,0x24,0x59,0xe8 // vmulps %ymm0,%ymm11,%ymm13 - .byte 0xc4,0x41,0x14,0x58,0xec // vaddps %ymm12,%ymm13,%ymm13 - .byte 0xc4,0x62,0x7d,0x18,0x72,0x34 // vbroadcastss 0x34(%rdx),%ymm14 - .byte 0xc4,0x41,0x2c,0x59,0xd5 // vmulps %ymm13,%ymm10,%ymm10 - .byte 0xc4,0x41,0x0c,0x58,0xd2 // vaddps %ymm10,%ymm14,%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x6a,0x44 // vbroadcastss 0x44(%rdx),%ymm13 - .byte 0xc4,0xc1,0x7c,0xc2,0xc5,0x01 // vcmpltps %ymm13,%ymm0,%ymm0 - .byte 0xc4,0xc3,0x2d,0x4a,0xc1,0x00 // vblendvps %ymm0,%ymm9,%ymm10,%ymm0 - .byte 0xc5,0x3c,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm9 - .byte 0xc5,0x74,0x59,0xd1 // vmulps %ymm1,%ymm1,%ymm10 - .byte 0xc5,0x24,0x59,0xf9 // vmulps %ymm1,%ymm11,%ymm15 - .byte 0xc4,0x41,0x04,0x58,0xfc // vaddps %ymm12,%ymm15,%ymm15 - .byte 0xc4,0x41,0x2c,0x59,0xd7 // vmulps %ymm15,%ymm10,%ymm10 - .byte 0xc4,0x41,0x0c,0x58,0xd2 // vaddps %ymm10,%ymm14,%ymm10 - .byte 0xc4,0xc1,0x74,0xc2,0xcd,0x01 // vcmpltps %ymm13,%ymm1,%ymm1 - .byte 0xc4,0xc3,0x2d,0x4a,0xc9,0x10 // vblendvps %ymm1,%ymm9,%ymm10,%ymm1 - .byte 0xc5,0x3c,0x59,0xc2 // vmulps %ymm2,%ymm8,%ymm8 - .byte 0xc5,0x6c,0x59,0xca // vmulps %ymm2,%ymm2,%ymm9 - .byte 0xc5,0x24,0x59,0xd2 // vmulps %ymm2,%ymm11,%ymm10 - .byte 0xc4,0x41,0x2c,0x58,0xd4 // vaddps %ymm12,%ymm10,%ymm10 - .byte 0xc4,0x41,0x34,0x59,0xca // vmulps %ymm10,%ymm9,%ymm9 - .byte 0xc4,0x41,0x0c,0x58,0xc9 // vaddps %ymm9,%ymm14,%ymm9 - .byte 0xc4,0xc1,0x6c,0xc2,0xd5,0x01 // vcmpltps %ymm13,%ymm2,%ymm2 - .byte 0xc4,0xc3,0x35,0x4a,0xd0,0x20 // vblendvps %ymm2,%ymm8,%ymm9,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,66,64 // vbroadcastss 0x40(%rdx),%ymm8 + .byte 197,60,89,200 // vmulps %ymm0,%ymm8,%ymm9 + .byte 197,124,89,208 // vmulps %ymm0,%ymm0,%ymm10 + .byte 196,98,125,24,90,60 // vbroadcastss 0x3c(%rdx),%ymm11 + .byte 196,98,125,24,98,56 // vbroadcastss 0x38(%rdx),%ymm12 + .byte 197,36,89,232 // vmulps %ymm0,%ymm11,%ymm13 + .byte 196,65,20,88,236 // vaddps %ymm12,%ymm13,%ymm13 + .byte 196,98,125,24,114,52 // vbroadcastss 0x34(%rdx),%ymm14 + .byte 196,65,44,89,213 // vmulps %ymm13,%ymm10,%ymm10 + .byte 196,65,12,88,210 // vaddps %ymm10,%ymm14,%ymm10 + .byte 196,98,125,24,106,68 // vbroadcastss 0x44(%rdx),%ymm13 + .byte 196,193,124,194,197,1 // vcmpltps %ymm13,%ymm0,%ymm0 + .byte 196,195,45,74,193,0 // vblendvps %ymm0,%ymm9,%ymm10,%ymm0 + .byte 197,60,89,201 // vmulps %ymm1,%ymm8,%ymm9 + .byte 197,116,89,209 // vmulps %ymm1,%ymm1,%ymm10 + .byte 197,36,89,249 // vmulps %ymm1,%ymm11,%ymm15 + .byte 196,65,4,88,252 // vaddps %ymm12,%ymm15,%ymm15 + .byte 196,65,44,89,215 // vmulps %ymm15,%ymm10,%ymm10 + .byte 196,65,12,88,210 // vaddps %ymm10,%ymm14,%ymm10 + .byte 196,193,116,194,205,1 // vcmpltps %ymm13,%ymm1,%ymm1 + .byte 196,195,45,74,201,16 // vblendvps %ymm1,%ymm9,%ymm10,%ymm1 + .byte 197,60,89,194 // vmulps %ymm2,%ymm8,%ymm8 + .byte 197,108,89,202 // vmulps %ymm2,%ymm2,%ymm9 + .byte 197,36,89,210 // vmulps %ymm2,%ymm11,%ymm10 + .byte 196,65,44,88,212 // vaddps %ymm12,%ymm10,%ymm10 + .byte 196,65,52,89,202 // vmulps %ymm10,%ymm9,%ymm9 + .byte 196,65,12,88,201 // vaddps %ymm9,%ymm14,%ymm9 + .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 .globl _sk_to_srgb_avx _sk_to_srgb_avx: - .byte 0xc5,0x7c,0x52,0xc0 // vrsqrtps %ymm0,%ymm8 - .byte 0xc4,0x41,0x7c,0x53,0xc8 // vrcpps %ymm8,%ymm9 - .byte 0xc4,0x41,0x7c,0x52,0xd0 // vrsqrtps %ymm8,%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x42,0x48 // vbroadcastss 0x48(%rdx),%ymm8 - .byte 0xc5,0x3c,0x59,0xd8 // vmulps %ymm0,%ymm8,%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x22 // vbroadcastss (%rdx),%ymm12 - .byte 0xc4,0x62,0x7d,0x18,0x6a,0x4c // vbroadcastss 0x4c(%rdx),%ymm13 - .byte 0xc4,0x62,0x7d,0x18,0x72,0x50 // vbroadcastss 0x50(%rdx),%ymm14 - .byte 0xc4,0x62,0x7d,0x18,0x7a,0x54 // vbroadcastss 0x54(%rdx),%ymm15 - .byte 0xc4,0x41,0x34,0x59,0xce // vmulps %ymm14,%ymm9,%ymm9 - .byte 0xc4,0x41,0x34,0x58,0xcf // vaddps %ymm15,%ymm9,%ymm9 - .byte 0xc4,0x41,0x2c,0x59,0xd5 // vmulps %ymm13,%ymm10,%ymm10 - .byte 0xc4,0x41,0x2c,0x58,0xc9 // vaddps %ymm9,%ymm10,%ymm9 - .byte 0xc4,0x41,0x1c,0x5d,0xc9 // vminps %ymm9,%ymm12,%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x52,0x58 // vbroadcastss 0x58(%rdx),%ymm10 - .byte 0xc4,0xc1,0x7c,0xc2,0xc2,0x01 // vcmpltps %ymm10,%ymm0,%ymm0 - .byte 0xc4,0xc3,0x35,0x4a,0xc3,0x00 // vblendvps %ymm0,%ymm11,%ymm9,%ymm0 - .byte 0xc5,0x7c,0x52,0xc9 // vrsqrtps %ymm1,%ymm9 - .byte 0xc4,0x41,0x7c,0x53,0xd9 // vrcpps %ymm9,%ymm11 - .byte 0xc4,0x41,0x7c,0x52,0xc9 // vrsqrtps %ymm9,%ymm9 - .byte 0xc4,0x41,0x0c,0x59,0xdb // vmulps %ymm11,%ymm14,%ymm11 - .byte 0xc4,0x41,0x04,0x58,0xdb // vaddps %ymm11,%ymm15,%ymm11 - .byte 0xc4,0x41,0x14,0x59,0xc9 // vmulps %ymm9,%ymm13,%ymm9 - .byte 0xc4,0x41,0x34,0x58,0xcb // vaddps %ymm11,%ymm9,%ymm9 - .byte 0xc5,0x3c,0x59,0xd9 // vmulps %ymm1,%ymm8,%ymm11 - .byte 0xc4,0x41,0x1c,0x5d,0xc9 // vminps %ymm9,%ymm12,%ymm9 - .byte 0xc4,0xc1,0x74,0xc2,0xca,0x01 // vcmpltps %ymm10,%ymm1,%ymm1 - .byte 0xc4,0xc3,0x35,0x4a,0xcb,0x10 // vblendvps %ymm1,%ymm11,%ymm9,%ymm1 - .byte 0xc5,0x7c,0x52,0xca // vrsqrtps %ymm2,%ymm9 - .byte 0xc4,0x41,0x7c,0x53,0xd9 // vrcpps %ymm9,%ymm11 - .byte 0xc4,0x41,0x0c,0x59,0xdb // vmulps %ymm11,%ymm14,%ymm11 - .byte 0xc4,0x41,0x04,0x58,0xdb // vaddps %ymm11,%ymm15,%ymm11 - .byte 0xc4,0x41,0x7c,0x52,0xc9 // vrsqrtps %ymm9,%ymm9 - .byte 0xc4,0x41,0x14,0x59,0xc9 // vmulps %ymm9,%ymm13,%ymm9 - .byte 0xc4,0x41,0x34,0x58,0xcb // vaddps %ymm11,%ymm9,%ymm9 - .byte 0xc4,0x41,0x1c,0x5d,0xc9 // vminps %ymm9,%ymm12,%ymm9 - .byte 0xc5,0x3c,0x59,0xc2 // vmulps %ymm2,%ymm8,%ymm8 - .byte 0xc4,0xc1,0x6c,0xc2,0xd2,0x01 // vcmpltps %ymm10,%ymm2,%ymm2 - .byte 0xc4,0xc3,0x35,0x4a,0xd0,0x20 // vblendvps %ymm2,%ymm8,%ymm9,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 197,124,82,192 // vrsqrtps %ymm0,%ymm8 + .byte 196,65,124,83,200 // vrcpps %ymm8,%ymm9 + .byte 196,65,124,82,208 // vrsqrtps %ymm8,%ymm10 + .byte 196,98,125,24,66,72 // vbroadcastss 0x48(%rdx),%ymm8 + .byte 197,60,89,216 // vmulps %ymm0,%ymm8,%ymm11 + .byte 196,98,125,24,34 // vbroadcastss (%rdx),%ymm12 + .byte 196,98,125,24,106,76 // vbroadcastss 0x4c(%rdx),%ymm13 + .byte 196,98,125,24,114,80 // vbroadcastss 0x50(%rdx),%ymm14 + .byte 196,98,125,24,122,84 // vbroadcastss 0x54(%rdx),%ymm15 + .byte 196,65,52,89,206 // vmulps %ymm14,%ymm9,%ymm9 + .byte 196,65,52,88,207 // vaddps %ymm15,%ymm9,%ymm9 + .byte 196,65,44,89,213 // vmulps %ymm13,%ymm10,%ymm10 + .byte 196,65,44,88,201 // vaddps %ymm9,%ymm10,%ymm9 + .byte 196,65,28,93,201 // vminps %ymm9,%ymm12,%ymm9 + .byte 196,98,125,24,82,88 // vbroadcastss 0x58(%rdx),%ymm10 + .byte 196,193,124,194,194,1 // vcmpltps %ymm10,%ymm0,%ymm0 + .byte 196,195,53,74,195,0 // vblendvps %ymm0,%ymm11,%ymm9,%ymm0 + .byte 197,124,82,201 // vrsqrtps %ymm1,%ymm9 + .byte 196,65,124,83,217 // vrcpps %ymm9,%ymm11 + .byte 196,65,124,82,201 // vrsqrtps %ymm9,%ymm9 + .byte 196,65,12,89,219 // vmulps %ymm11,%ymm14,%ymm11 + .byte 196,65,4,88,219 // vaddps %ymm11,%ymm15,%ymm11 + .byte 196,65,20,89,201 // vmulps %ymm9,%ymm13,%ymm9 + .byte 196,65,52,88,203 // vaddps %ymm11,%ymm9,%ymm9 + .byte 197,60,89,217 // vmulps %ymm1,%ymm8,%ymm11 + .byte 196,65,28,93,201 // vminps %ymm9,%ymm12,%ymm9 + .byte 196,193,116,194,202,1 // vcmpltps %ymm10,%ymm1,%ymm1 + .byte 196,195,53,74,203,16 // vblendvps %ymm1,%ymm11,%ymm9,%ymm1 + .byte 197,124,82,202 // vrsqrtps %ymm2,%ymm9 + .byte 196,65,124,83,217 // vrcpps %ymm9,%ymm11 + .byte 196,65,12,89,219 // vmulps %ymm11,%ymm14,%ymm11 + .byte 196,65,4,88,219 // vaddps %ymm11,%ymm15,%ymm11 + .byte 196,65,124,82,201 // vrsqrtps %ymm9,%ymm9 + .byte 196,65,20,89,201 // vmulps %ymm9,%ymm13,%ymm9 + .byte 196,65,52,88,203 // vaddps %ymm11,%ymm9,%ymm9 + .byte 196,65,28,93,201 // vminps %ymm9,%ymm12,%ymm9 + .byte 197,60,89,194 // vmulps %ymm2,%ymm8,%ymm8 + .byte 196,193,108,194,210,1 // vcmpltps %ymm10,%ymm2,%ymm2 + .byte 196,195,53,74,208,32 // vblendvps %ymm2,%ymm8,%ymm9,%ymm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_scale_u8_avx _sk_scale_u8_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc4,0x62,0x79,0x31,0x44,0x38,0x04 // vpmovzxbd 0x4(%rax,%rdi,1),%xmm8 - .byte 0xc4,0x62,0x79,0x31,0x0c,0x38 // vpmovzxbd (%rax,%rdi,1),%xmm9 - .byte 0xc4,0x43,0x35,0x18,0xc0,0x01 // vinsertf128 $0x1,%xmm8,%ymm9,%ymm8 - .byte 0xc4,0x41,0x7c,0x5b,0xc0 // vcvtdq2ps %ymm8,%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x4a,0x0c // vbroadcastss 0xc(%rdx),%ymm9 - .byte 0xc4,0x41,0x3c,0x59,0xc1 // vmulps %ymm9,%ymm8,%ymm8 - .byte 0xc5,0xbc,0x59,0xc0 // vmulps %ymm0,%ymm8,%ymm0 - .byte 0xc5,0xbc,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm1 - .byte 0xc5,0xbc,0x59,0xd2 // vmulps %ymm2,%ymm8,%ymm2 - .byte 0xc5,0xbc,0x59,0xdb // vmulps %ymm3,%ymm8,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 196,98,121,49,68,56,4 // vpmovzxbd 0x4(%rax,%rdi,1),%xmm8 + .byte 196,98,121,49,12,56 // vpmovzxbd (%rax,%rdi,1),%xmm9 + .byte 196,67,53,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm9,%ymm8 + .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 + .byte 196,98,125,24,74,12 // vbroadcastss 0xc(%rdx),%ymm9 + .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 255,224 // jmpq *%rax .globl _sk_lerp_u8_avx _sk_lerp_u8_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc4,0x62,0x79,0x31,0x44,0x38,0x04 // vpmovzxbd 0x4(%rax,%rdi,1),%xmm8 - .byte 0xc4,0x62,0x79,0x31,0x0c,0x38 // vpmovzxbd (%rax,%rdi,1),%xmm9 - .byte 0xc4,0x43,0x35,0x18,0xc0,0x01 // vinsertf128 $0x1,%xmm8,%ymm9,%ymm8 - .byte 0xc4,0x41,0x7c,0x5b,0xc0 // vcvtdq2ps %ymm8,%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x4a,0x0c // vbroadcastss 0xc(%rdx),%ymm9 - .byte 0xc4,0x41,0x3c,0x59,0xc1 // vmulps %ymm9,%ymm8,%ymm8 - .byte 0xc5,0xfc,0x5c,0xc4 // vsubps %ymm4,%ymm0,%ymm0 - .byte 0xc4,0xc1,0x7c,0x59,0xc0 // vmulps %ymm8,%ymm0,%ymm0 - .byte 0xc5,0xfc,0x58,0xc4 // vaddps %ymm4,%ymm0,%ymm0 - .byte 0xc5,0xf4,0x5c,0xcd // vsubps %ymm5,%ymm1,%ymm1 - .byte 0xc4,0xc1,0x74,0x59,0xc8 // vmulps %ymm8,%ymm1,%ymm1 - .byte 0xc5,0xf4,0x58,0xcd // vaddps %ymm5,%ymm1,%ymm1 - .byte 0xc5,0xec,0x5c,0xd6 // vsubps %ymm6,%ymm2,%ymm2 - .byte 0xc4,0xc1,0x6c,0x59,0xd0 // vmulps %ymm8,%ymm2,%ymm2 - .byte 0xc5,0xec,0x58,0xd6 // vaddps %ymm6,%ymm2,%ymm2 - .byte 0xc5,0xe4,0x5c,0xdf // vsubps %ymm7,%ymm3,%ymm3 - .byte 0xc4,0xc1,0x64,0x59,0xd8 // vmulps %ymm8,%ymm3,%ymm3 - .byte 0xc5,0xe4,0x58,0xdf // vaddps %ymm7,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 196,98,121,49,68,56,4 // vpmovzxbd 0x4(%rax,%rdi,1),%xmm8 + .byte 196,98,121,49,12,56 // vpmovzxbd (%rax,%rdi,1),%xmm9 + .byte 196,67,53,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm9,%ymm8 + .byte 196,65,124,91,192 // vcvtdq2ps %ymm8,%ymm8 + .byte 196,98,125,24,74,12 // vbroadcastss 0xc(%rdx),%ymm9 + .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 255,224 // jmpq *%rax .globl _sk_load_tables_avx _sk_load_tables_avx: - .byte 0x41,0x57 // push %r15 - .byte 0x41,0x56 // push %r14 - .byte 0x41,0x54 // push %r12 - .byte 0x53 // push %rbx - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x4c,0x8b,0x00 // mov (%rax),%r8 - .byte 0x48,0x8b,0x48,0x08 // mov 0x8(%rax),%rcx - .byte 0xc4,0x41,0x7c,0x10,0x14,0xb8 // vmovups (%r8,%rdi,4),%ymm10 - .byte 0xc5,0xf9,0x6e,0x42,0x10 // vmovd 0x10(%rdx),%xmm0 - .byte 0xc4,0xe3,0x79,0x04,0xc0,0x00 // vpermilps $0x0,%xmm0,%xmm0 - .byte 0xc4,0x63,0x7d,0x18,0xc8,0x01 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm9 - .byte 0xc4,0xc1,0x34,0x54,0xc2 // vandps %ymm10,%ymm9,%ymm0 - .byte 0xc4,0xc1,0xf9,0x7e,0xc0 // vmovq %xmm0,%r8 - .byte 0x45,0x89,0xc1 // mov %r8d,%r9d - .byte 0xc4,0xc3,0xf9,0x16,0xc2,0x01 // vpextrq $0x1,%xmm0,%r10 - .byte 0x45,0x89,0xd3 // mov %r10d,%r11d - .byte 0x49,0xc1,0xea,0x20 // shr $0x20,%r10 - .byte 0x49,0xc1,0xe8,0x20 // shr $0x20,%r8 - .byte 0xc4,0xe3,0x7d,0x19,0xc0,0x01 // vextractf128 $0x1,%ymm0,%xmm0 - .byte 0xc4,0xc1,0xf9,0x7e,0xc7 // vmovq %xmm0,%r15 - .byte 0x45,0x89,0xfe // mov %r15d,%r14d - .byte 0xc4,0xe3,0xf9,0x16,0xc3,0x01 // vpextrq $0x1,%xmm0,%rbx - .byte 0x41,0x89,0xdc // mov %ebx,%r12d - .byte 0x48,0xc1,0xeb,0x20 // shr $0x20,%rbx - .byte 0x49,0xc1,0xef,0x20 // shr $0x20,%r15 - .byte 0xc4,0xa1,0x7a,0x10,0x04,0xb1 // vmovss (%rcx,%r14,4),%xmm0 - .byte 0xc4,0xa3,0x79,0x21,0x04,0xb9,0x10 // vinsertps $0x10,(%rcx,%r15,4),%xmm0,%xmm0 - .byte 0xc4,0xa3,0x79,0x21,0x04,0xa1,0x20 // vinsertps $0x20,(%rcx,%r12,4),%xmm0,%xmm0 - .byte 0xc4,0xe3,0x79,0x21,0x04,0x99,0x30 // vinsertps $0x30,(%rcx,%rbx,4),%xmm0,%xmm0 - .byte 0xc4,0xa1,0x7a,0x10,0x0c,0x89 // vmovss (%rcx,%r9,4),%xmm1 - .byte 0xc4,0xa3,0x71,0x21,0x0c,0x81,0x10 // vinsertps $0x10,(%rcx,%r8,4),%xmm1,%xmm1 - .byte 0xc4,0xa3,0x71,0x21,0x0c,0x99,0x20 // vinsertps $0x20,(%rcx,%r11,4),%xmm1,%xmm1 - .byte 0xc4,0xa3,0x71,0x21,0x0c,0x91,0x30 // vinsertps $0x30,(%rcx,%r10,4),%xmm1,%xmm1 - .byte 0xc4,0xe3,0x75,0x18,0xc0,0x01 // vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 - .byte 0x4c,0x8b,0x78,0x10 // mov 0x10(%rax),%r15 - .byte 0xc4,0xc1,0x71,0x72,0xd2,0x08 // vpsrld $0x8,%xmm10,%xmm1 - .byte 0xc4,0x43,0x7d,0x19,0xd0,0x01 // vextractf128 $0x1,%ymm10,%xmm8 - .byte 0xc4,0xc1,0x69,0x72,0xd0,0x08 // vpsrld $0x8,%xmm8,%xmm2 - .byte 0xc4,0xe3,0x75,0x18,0xca,0x01 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 - .byte 0xc5,0xb4,0x54,0xc9 // vandps %ymm1,%ymm9,%ymm1 - .byte 0xc4,0xc1,0xf9,0x7e,0xc8 // vmovq %xmm1,%r8 - .byte 0x45,0x89,0xc2 // mov %r8d,%r10d - .byte 0xc4,0xc3,0xf9,0x16,0xc9,0x01 // vpextrq $0x1,%xmm1,%r9 - .byte 0x45,0x89,0xcb // mov %r9d,%r11d - .byte 0x49,0xc1,0xe9,0x20 // shr $0x20,%r9 - .byte 0x49,0xc1,0xe8,0x20 // shr $0x20,%r8 - .byte 0xc4,0xe3,0x7d,0x19,0xc9,0x01 // vextractf128 $0x1,%ymm1,%xmm1 - .byte 0xc4,0xe1,0xf9,0x7e,0xcb // vmovq %xmm1,%rbx - .byte 0x41,0x89,0xde // mov %ebx,%r14d - .byte 0xc4,0xe3,0xf9,0x16,0xc9,0x01 // vpextrq $0x1,%xmm1,%rcx - .byte 0x41,0x89,0xcc // mov %ecx,%r12d - .byte 0x48,0xc1,0xe9,0x20 // shr $0x20,%rcx - .byte 0x48,0xc1,0xeb,0x20 // shr $0x20,%rbx - .byte 0xc4,0x81,0x7a,0x10,0x0c,0xb7 // vmovss (%r15,%r14,4),%xmm1 - .byte 0xc4,0xc3,0x71,0x21,0x0c,0x9f,0x10 // vinsertps $0x10,(%r15,%rbx,4),%xmm1,%xmm1 - .byte 0xc4,0x81,0x7a,0x10,0x14,0xa7 // vmovss (%r15,%r12,4),%xmm2 - .byte 0xc4,0xe3,0x71,0x21,0xca,0x20 // vinsertps $0x20,%xmm2,%xmm1,%xmm1 - .byte 0xc4,0xc1,0x7a,0x10,0x14,0x8f // vmovss (%r15,%rcx,4),%xmm2 - .byte 0xc4,0xe3,0x71,0x21,0xca,0x30 // vinsertps $0x30,%xmm2,%xmm1,%xmm1 - .byte 0xc4,0x81,0x7a,0x10,0x14,0x97 // vmovss (%r15,%r10,4),%xmm2 - .byte 0xc4,0x83,0x69,0x21,0x14,0x87,0x10 // vinsertps $0x10,(%r15,%r8,4),%xmm2,%xmm2 - .byte 0xc4,0x81,0x7a,0x10,0x1c,0x9f // vmovss (%r15,%r11,4),%xmm3 - .byte 0xc4,0xe3,0x69,0x21,0xd3,0x20 // vinsertps $0x20,%xmm3,%xmm2,%xmm2 - .byte 0xc4,0x81,0x7a,0x10,0x1c,0x8f // vmovss (%r15,%r9,4),%xmm3 - .byte 0xc4,0xe3,0x69,0x21,0xd3,0x30 // vinsertps $0x30,%xmm3,%xmm2,%xmm2 - .byte 0xc4,0xe3,0x6d,0x18,0xc9,0x01 // vinsertf128 $0x1,%xmm1,%ymm2,%ymm1 - .byte 0x48,0x8b,0x40,0x18 // mov 0x18(%rax),%rax - .byte 0xc4,0xc1,0x69,0x72,0xd2,0x10 // vpsrld $0x10,%xmm10,%xmm2 - .byte 0xc4,0xc1,0x61,0x72,0xd0,0x10 // vpsrld $0x10,%xmm8,%xmm3 - .byte 0xc4,0xe3,0x6d,0x18,0xd3,0x01 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 - .byte 0xc5,0xb4,0x54,0xd2 // vandps %ymm2,%ymm9,%ymm2 - .byte 0xc4,0xc1,0xf9,0x7e,0xd0 // vmovq %xmm2,%r8 - .byte 0x45,0x89,0xc1 // mov %r8d,%r9d - .byte 0xc4,0xc3,0xf9,0x16,0xd6,0x01 // vpextrq $0x1,%xmm2,%r14 - .byte 0x45,0x89,0xf2 // mov %r14d,%r10d - .byte 0x49,0xc1,0xee,0x20 // shr $0x20,%r14 - .byte 0x49,0xc1,0xe8,0x20 // shr $0x20,%r8 - .byte 0xc4,0xe3,0x7d,0x19,0xd2,0x01 // vextractf128 $0x1,%ymm2,%xmm2 - .byte 0xc4,0xe1,0xf9,0x7e,0xd3 // vmovq %xmm2,%rbx - .byte 0x41,0x89,0xdb // mov %ebx,%r11d - .byte 0xc4,0xe3,0xf9,0x16,0xd1,0x01 // vpextrq $0x1,%xmm2,%rcx - .byte 0x41,0x89,0xcf // mov %ecx,%r15d - .byte 0x48,0xc1,0xe9,0x20 // shr $0x20,%rcx - .byte 0x48,0xc1,0xeb,0x20 // shr $0x20,%rbx - .byte 0xc4,0xa1,0x7a,0x10,0x14,0x98 // vmovss (%rax,%r11,4),%xmm2 - .byte 0xc4,0xe3,0x69,0x21,0x14,0x98,0x10 // vinsertps $0x10,(%rax,%rbx,4),%xmm2,%xmm2 - .byte 0xc4,0xa1,0x7a,0x10,0x1c,0xb8 // vmovss (%rax,%r15,4),%xmm3 - .byte 0xc4,0xe3,0x69,0x21,0xd3,0x20 // vinsertps $0x20,%xmm3,%xmm2,%xmm2 - .byte 0xc5,0xfa,0x10,0x1c,0x88 // vmovss (%rax,%rcx,4),%xmm3 - .byte 0xc4,0x63,0x69,0x21,0xcb,0x30 // vinsertps $0x30,%xmm3,%xmm2,%xmm9 - .byte 0xc4,0xa1,0x7a,0x10,0x1c,0x88 // vmovss (%rax,%r9,4),%xmm3 - .byte 0xc4,0xa3,0x61,0x21,0x1c,0x80,0x10 // vinsertps $0x10,(%rax,%r8,4),%xmm3,%xmm3 - .byte 0xc4,0xa1,0x7a,0x10,0x14,0x90 // vmovss (%rax,%r10,4),%xmm2 - .byte 0xc4,0xe3,0x61,0x21,0xd2,0x20 // vinsertps $0x20,%xmm2,%xmm3,%xmm2 - .byte 0xc4,0xa1,0x7a,0x10,0x1c,0xb0 // vmovss (%rax,%r14,4),%xmm3 - .byte 0xc4,0xe3,0x69,0x21,0xd3,0x30 // vinsertps $0x30,%xmm3,%xmm2,%xmm2 - .byte 0xc4,0xc3,0x6d,0x18,0xd1,0x01 // vinsertf128 $0x1,%xmm9,%ymm2,%ymm2 - .byte 0xc4,0xc1,0x31,0x72,0xd2,0x18 // vpsrld $0x18,%xmm10,%xmm9 - .byte 0xc4,0xc1,0x61,0x72,0xd0,0x18 // vpsrld $0x18,%xmm8,%xmm3 - .byte 0xc4,0xe3,0x35,0x18,0xdb,0x01 // vinsertf128 $0x1,%xmm3,%ymm9,%ymm3 - .byte 0xc5,0xfc,0x5b,0xdb // vcvtdq2ps %ymm3,%ymm3 - .byte 0xc4,0x62,0x7d,0x18,0x42,0x0c // vbroadcastss 0xc(%rdx),%ymm8 - .byte 0xc4,0xc1,0x64,0x59,0xd8 // vmulps %ymm8,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x5b // pop %rbx - .byte 0x41,0x5c // pop %r12 - .byte 0x41,0x5e // pop %r14 - .byte 0x41,0x5f // pop %r15 - .byte 0xff,0xe0 // jmpq *%rax + .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 76,139,0 // mov (%rax),%r8 + .byte 72,139,72,8 // mov 0x8(%rax),%rcx + .byte 196,65,124,16,20,184 // vmovups (%r8,%rdi,4),%ymm10 + .byte 197,249,110,66,16 // vmovd 0x10(%rdx),%xmm0 + .byte 196,227,121,4,192,0 // vpermilps $0x0,%xmm0,%xmm0 + .byte 196,99,125,24,200,1 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm9 + .byte 196,193,52,84,194 // vandps %ymm10,%ymm9,%ymm0 + .byte 196,193,249,126,192 // vmovq %xmm0,%r8 + .byte 69,137,193 // mov %r8d,%r9d + .byte 196,195,249,22,194,1 // vpextrq $0x1,%xmm0,%r10 + .byte 69,137,211 // mov %r10d,%r11d + .byte 73,193,234,32 // shr $0x20,%r10 + .byte 73,193,232,32 // shr $0x20,%r8 + .byte 196,227,125,25,192,1 // vextractf128 $0x1,%ymm0,%xmm0 + .byte 196,193,249,126,199 // vmovq %xmm0,%r15 + .byte 69,137,254 // mov %r15d,%r14d + .byte 196,227,249,22,195,1 // vpextrq $0x1,%xmm0,%rbx + .byte 65,137,220 // mov %ebx,%r12d + .byte 72,193,235,32 // shr $0x20,%rbx + .byte 73,193,239,32 // shr $0x20,%r15 + .byte 196,161,122,16,4,177 // vmovss (%rcx,%r14,4),%xmm0 + .byte 196,163,121,33,4,185,16 // vinsertps $0x10,(%rcx,%r15,4),%xmm0,%xmm0 + .byte 196,163,121,33,4,161,32 // vinsertps $0x20,(%rcx,%r12,4),%xmm0,%xmm0 + .byte 196,227,121,33,4,153,48 // vinsertps $0x30,(%rcx,%rbx,4),%xmm0,%xmm0 + .byte 196,161,122,16,12,137 // vmovss (%rcx,%r9,4),%xmm1 + .byte 196,163,113,33,12,129,16 // vinsertps $0x10,(%rcx,%r8,4),%xmm1,%xmm1 + .byte 196,163,113,33,12,153,32 // vinsertps $0x20,(%rcx,%r11,4),%xmm1,%xmm1 + .byte 196,163,113,33,12,145,48 // vinsertps $0x30,(%rcx,%r10,4),%xmm1,%xmm1 + .byte 196,227,117,24,192,1 // vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 + .byte 76,139,120,16 // mov 0x10(%rax),%r15 + .byte 196,193,113,114,210,8 // vpsrld $0x8,%xmm10,%xmm1 + .byte 196,67,125,25,208,1 // vextractf128 $0x1,%ymm10,%xmm8 + .byte 196,193,105,114,208,8 // vpsrld $0x8,%xmm8,%xmm2 + .byte 196,227,117,24,202,1 // vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 + .byte 197,180,84,201 // vandps %ymm1,%ymm9,%ymm1 + .byte 196,193,249,126,200 // vmovq %xmm1,%r8 + .byte 69,137,194 // mov %r8d,%r10d + .byte 196,195,249,22,201,1 // vpextrq $0x1,%xmm1,%r9 + .byte 69,137,203 // mov %r9d,%r11d + .byte 73,193,233,32 // shr $0x20,%r9 + .byte 73,193,232,32 // shr $0x20,%r8 + .byte 196,227,125,25,201,1 // vextractf128 $0x1,%ymm1,%xmm1 + .byte 196,225,249,126,203 // vmovq %xmm1,%rbx + .byte 65,137,222 // mov %ebx,%r14d + .byte 196,227,249,22,201,1 // vpextrq $0x1,%xmm1,%rcx + .byte 65,137,204 // mov %ecx,%r12d + .byte 72,193,233,32 // shr $0x20,%rcx + .byte 72,193,235,32 // shr $0x20,%rbx + .byte 196,129,122,16,12,183 // vmovss (%r15,%r14,4),%xmm1 + .byte 196,195,113,33,12,159,16 // vinsertps $0x10,(%r15,%rbx,4),%xmm1,%xmm1 + .byte 196,129,122,16,20,167 // vmovss (%r15,%r12,4),%xmm2 + .byte 196,227,113,33,202,32 // vinsertps $0x20,%xmm2,%xmm1,%xmm1 + .byte 196,193,122,16,20,143 // vmovss (%r15,%rcx,4),%xmm2 + .byte 196,227,113,33,202,48 // vinsertps $0x30,%xmm2,%xmm1,%xmm1 + .byte 196,129,122,16,20,151 // vmovss (%r15,%r10,4),%xmm2 + .byte 196,131,105,33,20,135,16 // vinsertps $0x10,(%r15,%r8,4),%xmm2,%xmm2 + .byte 196,129,122,16,28,159 // vmovss (%r15,%r11,4),%xmm3 + .byte 196,227,105,33,211,32 // vinsertps $0x20,%xmm3,%xmm2,%xmm2 + .byte 196,129,122,16,28,143 // vmovss (%r15,%r9,4),%xmm3 + .byte 196,227,105,33,211,48 // vinsertps $0x30,%xmm3,%xmm2,%xmm2 + .byte 196,227,109,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm2,%ymm1 + .byte 72,139,64,24 // mov 0x18(%rax),%rax + .byte 196,193,105,114,210,16 // vpsrld $0x10,%xmm10,%xmm2 + .byte 196,193,97,114,208,16 // vpsrld $0x10,%xmm8,%xmm3 + .byte 196,227,109,24,211,1 // vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 + .byte 197,180,84,210 // vandps %ymm2,%ymm9,%ymm2 + .byte 196,193,249,126,208 // vmovq %xmm2,%r8 + .byte 69,137,193 // mov %r8d,%r9d + .byte 196,195,249,22,214,1 // vpextrq $0x1,%xmm2,%r14 + .byte 69,137,242 // mov %r14d,%r10d + .byte 73,193,238,32 // shr $0x20,%r14 + .byte 73,193,232,32 // shr $0x20,%r8 + .byte 196,227,125,25,210,1 // vextractf128 $0x1,%ymm2,%xmm2 + .byte 196,225,249,126,211 // vmovq %xmm2,%rbx + .byte 65,137,219 // mov %ebx,%r11d + .byte 196,227,249,22,209,1 // vpextrq $0x1,%xmm2,%rcx + .byte 65,137,207 // mov %ecx,%r15d + .byte 72,193,233,32 // shr $0x20,%rcx + .byte 72,193,235,32 // shr $0x20,%rbx + .byte 196,161,122,16,20,152 // vmovss (%rax,%r11,4),%xmm2 + .byte 196,227,105,33,20,152,16 // vinsertps $0x10,(%rax,%rbx,4),%xmm2,%xmm2 + .byte 196,161,122,16,28,184 // vmovss (%rax,%r15,4),%xmm3 + .byte 196,227,105,33,211,32 // vinsertps $0x20,%xmm3,%xmm2,%xmm2 + .byte 197,250,16,28,136 // vmovss (%rax,%rcx,4),%xmm3 + .byte 196,99,105,33,203,48 // vinsertps $0x30,%xmm3,%xmm2,%xmm9 + .byte 196,161,122,16,28,136 // vmovss (%rax,%r9,4),%xmm3 + .byte 196,163,97,33,28,128,16 // vinsertps $0x10,(%rax,%r8,4),%xmm3,%xmm3 + .byte 196,161,122,16,20,144 // vmovss (%rax,%r10,4),%xmm2 + .byte 196,227,97,33,210,32 // vinsertps $0x20,%xmm2,%xmm3,%xmm2 + .byte 196,161,122,16,28,176 // vmovss (%rax,%r14,4),%xmm3 + .byte 196,227,105,33,211,48 // vinsertps $0x30,%xmm3,%xmm2,%xmm2 + .byte 196,195,109,24,209,1 // vinsertf128 $0x1,%xmm9,%ymm2,%ymm2 + .byte 196,193,49,114,210,24 // vpsrld $0x18,%xmm10,%xmm9 + .byte 196,193,97,114,208,24 // vpsrld $0x18,%xmm8,%xmm3 + .byte 196,227,53,24,219,1 // vinsertf128 $0x1,%xmm3,%ymm9,%ymm3 + .byte 197,252,91,219 // vcvtdq2ps %ymm3,%ymm3 + .byte 196,98,125,24,66,12 // vbroadcastss 0xc(%rdx),%ymm8 + .byte 196,193,100,89,216 // vmulps %ymm8,%ymm3,%ymm3 + .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 .globl _sk_load_8888_avx _sk_load_8888_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc5,0xfc,0x10,0x1c,0xb8 // vmovups (%rax,%rdi,4),%ymm3 - .byte 0xc5,0xf9,0x6e,0x42,0x10 // vmovd 0x10(%rdx),%xmm0 - .byte 0xc4,0xe3,0x79,0x04,0xc0,0x00 // vpermilps $0x0,%xmm0,%xmm0 - .byte 0xc4,0x63,0x7d,0x18,0xd8,0x01 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm11 - .byte 0xc5,0xa4,0x54,0xc3 // vandps %ymm3,%ymm11,%ymm0 - .byte 0xc5,0xfc,0x5b,0xc0 // vcvtdq2ps %ymm0,%ymm0 - .byte 0xc4,0x62,0x7d,0x18,0x42,0x0c // vbroadcastss 0xc(%rdx),%ymm8 - .byte 0xc5,0xbc,0x59,0xc0 // vmulps %ymm0,%ymm8,%ymm0 - .byte 0xc5,0xa9,0x72,0xd3,0x08 // vpsrld $0x8,%xmm3,%xmm10 - .byte 0xc4,0xc3,0x7d,0x19,0xd9,0x01 // vextractf128 $0x1,%ymm3,%xmm9 - .byte 0xc4,0xc1,0x71,0x72,0xd1,0x08 // vpsrld $0x8,%xmm9,%xmm1 - .byte 0xc4,0xe3,0x2d,0x18,0xc9,0x01 // vinsertf128 $0x1,%xmm1,%ymm10,%ymm1 - .byte 0xc5,0xa4,0x54,0xc9 // vandps %ymm1,%ymm11,%ymm1 - .byte 0xc5,0xfc,0x5b,0xc9 // vcvtdq2ps %ymm1,%ymm1 - .byte 0xc5,0xbc,0x59,0xc9 // vmulps %ymm1,%ymm8,%ymm1 - .byte 0xc5,0xa9,0x72,0xd3,0x10 // vpsrld $0x10,%xmm3,%xmm10 - .byte 0xc4,0xc1,0x69,0x72,0xd1,0x10 // vpsrld $0x10,%xmm9,%xmm2 - .byte 0xc4,0xe3,0x2d,0x18,0xd2,0x01 // vinsertf128 $0x1,%xmm2,%ymm10,%ymm2 - .byte 0xc5,0xa4,0x54,0xd2 // vandps %ymm2,%ymm11,%ymm2 - .byte 0xc5,0xfc,0x5b,0xd2 // vcvtdq2ps %ymm2,%ymm2 - .byte 0xc5,0xbc,0x59,0xd2 // vmulps %ymm2,%ymm8,%ymm2 - .byte 0xc5,0xa9,0x72,0xd3,0x18 // vpsrld $0x18,%xmm3,%xmm10 - .byte 0xc4,0xc1,0x61,0x72,0xd1,0x18 // vpsrld $0x18,%xmm9,%xmm3 - .byte 0xc4,0xe3,0x2d,0x18,0xdb,0x01 // vinsertf128 $0x1,%xmm3,%ymm10,%ymm3 - .byte 0xc5,0xfc,0x5b,0xdb // vcvtdq2ps %ymm3,%ymm3 - .byte 0xc4,0xc1,0x64,0x59,0xd8 // vmulps %ymm8,%ymm3,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 197,252,16,28,184 // vmovups (%rax,%rdi,4),%ymm3 + .byte 197,249,110,66,16 // vmovd 0x10(%rdx),%xmm0 + .byte 196,227,121,4,192,0 // vpermilps $0x0,%xmm0,%xmm0 + .byte 196,99,125,24,216,1 // vinsertf128 $0x1,%xmm0,%ymm0,%ymm11 + .byte 197,164,84,195 // vandps %ymm3,%ymm11,%ymm0 + .byte 197,252,91,192 // vcvtdq2ps %ymm0,%ymm0 + .byte 196,98,125,24,66,12 // vbroadcastss 0xc(%rdx),%ymm8 + .byte 197,188,89,192 // vmulps %ymm0,%ymm8,%ymm0 + .byte 197,169,114,211,8 // vpsrld $0x8,%xmm3,%xmm10 + .byte 196,195,125,25,217,1 // vextractf128 $0x1,%ymm3,%xmm9 + .byte 196,193,113,114,209,8 // vpsrld $0x8,%xmm9,%xmm1 + .byte 196,227,45,24,201,1 // vinsertf128 $0x1,%xmm1,%ymm10,%ymm1 + .byte 197,164,84,201 // vandps %ymm1,%ymm11,%ymm1 + .byte 197,252,91,201 // vcvtdq2ps %ymm1,%ymm1 + .byte 197,188,89,201 // vmulps %ymm1,%ymm8,%ymm1 + .byte 197,169,114,211,16 // vpsrld $0x10,%xmm3,%xmm10 + .byte 196,193,105,114,209,16 // vpsrld $0x10,%xmm9,%xmm2 + .byte 196,227,45,24,210,1 // vinsertf128 $0x1,%xmm2,%ymm10,%ymm2 + .byte 197,164,84,210 // vandps %ymm2,%ymm11,%ymm2 + .byte 197,252,91,210 // vcvtdq2ps %ymm2,%ymm2 + .byte 197,188,89,210 // vmulps %ymm2,%ymm8,%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 255,224 // jmpq *%rax .globl _sk_store_8888_avx _sk_store_8888_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xc4,0x62,0x7d,0x18,0x42,0x08 // vbroadcastss 0x8(%rdx),%ymm8 - .byte 0xc5,0x3c,0x59,0xc8 // vmulps %ymm0,%ymm8,%ymm9 - .byte 0xc4,0x41,0x7d,0x5b,0xc9 // vcvtps2dq %ymm9,%ymm9 - .byte 0xc5,0x3c,0x59,0xd1 // vmulps %ymm1,%ymm8,%ymm10 - .byte 0xc4,0x41,0x7d,0x5b,0xd2 // vcvtps2dq %ymm10,%ymm10 - .byte 0xc4,0xc1,0x21,0x72,0xf2,0x08 // vpslld $0x8,%xmm10,%xmm11 - .byte 0xc4,0x43,0x7d,0x19,0xd2,0x01 // vextractf128 $0x1,%ymm10,%xmm10 - .byte 0xc4,0xc1,0x29,0x72,0xf2,0x08 // vpslld $0x8,%xmm10,%xmm10 - .byte 0xc4,0x43,0x25,0x18,0xd2,0x01 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 - .byte 0xc4,0x41,0x2d,0x56,0xc9 // vorpd %ymm9,%ymm10,%ymm9 - .byte 0xc5,0x3c,0x59,0xd2 // vmulps %ymm2,%ymm8,%ymm10 - .byte 0xc4,0x41,0x7d,0x5b,0xd2 // vcvtps2dq %ymm10,%ymm10 - .byte 0xc4,0xc1,0x21,0x72,0xf2,0x10 // vpslld $0x10,%xmm10,%xmm11 - .byte 0xc4,0x43,0x7d,0x19,0xd2,0x01 // vextractf128 $0x1,%ymm10,%xmm10 - .byte 0xc4,0xc1,0x29,0x72,0xf2,0x10 // vpslld $0x10,%xmm10,%xmm10 - .byte 0xc4,0x43,0x25,0x18,0xd2,0x01 // vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 - .byte 0xc4,0x41,0x35,0x56,0xca // vorpd %ymm10,%ymm9,%ymm9 - .byte 0xc5,0x3c,0x59,0xc3 // vmulps %ymm3,%ymm8,%ymm8 - .byte 0xc4,0x41,0x7d,0x5b,0xc0 // vcvtps2dq %ymm8,%ymm8 - .byte 0xc4,0xc1,0x29,0x72,0xf0,0x18 // vpslld $0x18,%xmm8,%xmm10 - .byte 0xc4,0x43,0x7d,0x19,0xc0,0x01 // vextractf128 $0x1,%ymm8,%xmm8 - .byte 0xc4,0xc1,0x39,0x72,0xf0,0x18 // vpslld $0x18,%xmm8,%xmm8 - .byte 0xc4,0x43,0x2d,0x18,0xc0,0x01 // vinsertf128 $0x1,%xmm8,%ymm10,%ymm8 - .byte 0xc4,0x41,0x35,0x56,0xc0 // vorpd %ymm8,%ymm9,%ymm8 - .byte 0xc5,0x7d,0x11,0x04,0xb8 // vmovupd %ymm8,(%rax,%rdi,4) - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 196,98,125,24,66,8 // vbroadcastss 0x8(%rdx),%ymm8 + .byte 197,60,89,200 // vmulps %ymm0,%ymm8,%ymm9 + .byte 196,65,125,91,201 // vcvtps2dq %ymm9,%ymm9 + .byte 197,60,89,209 // vmulps %ymm1,%ymm8,%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 197,60,89,210 // vmulps %ymm2,%ymm8,%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,53,86,202 // vorpd %ymm10,%ymm9,%ymm9 + .byte 197,60,89,195 // vmulps %ymm3,%ymm8,%ymm8 + .byte 196,65,125,91,192 // vcvtps2dq %ymm8,%ymm8 + .byte 196,193,41,114,240,24 // vpslld $0x18,%xmm8,%xmm10 + .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,45,24,192,1 // vinsertf128 $0x1,%xmm8,%ymm10,%ymm8 + .byte 196,65,53,86,192 // vorpd %ymm8,%ymm9,%ymm8 + .byte 197,125,17,4,184 // vmovupd %ymm8,(%rax,%rdi,4) + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_load_f16_avx _sk_load_f16_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_store_f16_avx _sk_store_f16_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_clamp_x_avx _sk_clamp_x_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x00 // vbroadcastss (%rax),%ymm8 - .byte 0xc4,0x43,0x7d,0x19,0xc1,0x01 // vextractf128 $0x1,%ymm8,%xmm9 - .byte 0xc4,0x41,0x29,0x76,0xd2 // vpcmpeqd %xmm10,%xmm10,%xmm10 - .byte 0xc4,0x41,0x31,0xfe,0xca // vpaddd %xmm10,%xmm9,%xmm9 - .byte 0xc4,0x41,0x39,0xfe,0xc2 // vpaddd %xmm10,%xmm8,%xmm8 - .byte 0xc4,0x43,0x3d,0x18,0xc1,0x01 // vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 - .byte 0xc4,0xc1,0x7c,0x5d,0xc0 // vminps %ymm8,%ymm0,%ymm0 - .byte 0xc4,0x41,0x3c,0x57,0xc0 // vxorps %ymm8,%ymm8,%ymm8 - .byte 0xc5,0xbc,0x5f,0xc0 // vmaxps %ymm0,%ymm8,%ymm0 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 + .byte 196,67,125,25,193,1 // vextractf128 $0x1,%ymm8,%xmm9 + .byte 196,65,41,118,210 // vpcmpeqd %xmm10,%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 196,193,124,93,192 // vminps %ymm8,%ymm0,%ymm0 + .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 + .byte 197,188,95,192 // vmaxps %ymm0,%ymm8,%ymm0 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_clamp_y_avx _sk_clamp_y_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x00 // vbroadcastss (%rax),%ymm8 - .byte 0xc4,0x43,0x7d,0x19,0xc1,0x01 // vextractf128 $0x1,%ymm8,%xmm9 - .byte 0xc4,0x41,0x29,0x76,0xd2 // vpcmpeqd %xmm10,%xmm10,%xmm10 - .byte 0xc4,0x41,0x31,0xfe,0xca // vpaddd %xmm10,%xmm9,%xmm9 - .byte 0xc4,0x41,0x39,0xfe,0xc2 // vpaddd %xmm10,%xmm8,%xmm8 - .byte 0xc4,0x43,0x3d,0x18,0xc1,0x01 // vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 - .byte 0xc4,0xc1,0x74,0x5d,0xc8 // vminps %ymm8,%ymm1,%ymm1 - .byte 0xc4,0x41,0x3c,0x57,0xc0 // vxorps %ymm8,%ymm8,%ymm8 - .byte 0xc5,0xbc,0x5f,0xc9 // vmaxps %ymm1,%ymm8,%ymm1 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,98,125,24,0 // vbroadcastss (%rax),%ymm8 + .byte 196,67,125,25,193,1 // vextractf128 $0x1,%ymm8,%xmm9 + .byte 196,65,41,118,210 // vpcmpeqd %xmm10,%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 196,193,116,93,200 // vminps %ymm8,%ymm1,%ymm1 + .byte 196,65,60,87,192 // vxorps %ymm8,%ymm8,%ymm8 + .byte 197,188,95,201 // vmaxps %ymm1,%ymm8,%ymm1 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_matrix_2x3_avx _sk_matrix_2x3_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x00 // vbroadcastss (%rax),%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x48,0x08 // vbroadcastss 0x8(%rax),%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x10 // vbroadcastss 0x10(%rax),%ymm10 - .byte 0xc5,0x34,0x59,0xc9 // vmulps %ymm1,%ymm9,%ymm9 - .byte 0xc4,0x41,0x34,0x58,0xca // vaddps %ymm10,%ymm9,%ymm9 - .byte 0xc5,0x3c,0x59,0xc0 // vmulps %ymm0,%ymm8,%ymm8 - .byte 0xc4,0x41,0x3c,0x58,0xc1 // vaddps %ymm9,%ymm8,%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x48,0x04 // vbroadcastss 0x4(%rax),%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x0c // vbroadcastss 0xc(%rax),%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x58,0x14 // vbroadcastss 0x14(%rax),%ymm11 - .byte 0xc5,0xac,0x59,0xc9 // vmulps %ymm1,%ymm10,%ymm1 - .byte 0xc4,0xc1,0x74,0x58,0xcb // vaddps %ymm11,%ymm1,%ymm1 - .byte 0xc5,0xb4,0x59,0xc0 // vmulps %ymm0,%ymm9,%ymm0 - .byte 0xc5,0xfc,0x58,0xc9 // vaddps %ymm1,%ymm0,%ymm1 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0x7c,0x29,0xc0 // vmovaps %ymm8,%ymm0 - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_matrix_3x4_avx _sk_matrix_3x4_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0x62,0x7d,0x18,0x00 // vbroadcastss (%rax),%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x48,0x0c // vbroadcastss 0xc(%rax),%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x18 // vbroadcastss 0x18(%rax),%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x58,0x24 // vbroadcastss 0x24(%rax),%ymm11 - .byte 0xc5,0x2c,0x59,0xd2 // vmulps %ymm2,%ymm10,%ymm10 - .byte 0xc4,0x41,0x2c,0x58,0xd3 // vaddps %ymm11,%ymm10,%ymm10 - .byte 0xc5,0x34,0x59,0xc9 // vmulps %ymm1,%ymm9,%ymm9 - .byte 0xc4,0x41,0x34,0x58,0xca // vaddps %ymm10,%ymm9,%ymm9 - .byte 0xc5,0x3c,0x59,0xc0 // vmulps %ymm0,%ymm8,%ymm8 - .byte 0xc4,0x41,0x3c,0x58,0xc1 // vaddps %ymm9,%ymm8,%ymm8 - .byte 0xc4,0x62,0x7d,0x18,0x48,0x04 // vbroadcastss 0x4(%rax),%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x10 // vbroadcastss 0x10(%rax),%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x58,0x1c // vbroadcastss 0x1c(%rax),%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x60,0x28 // vbroadcastss 0x28(%rax),%ymm12 - .byte 0xc5,0x24,0x59,0xda // vmulps %ymm2,%ymm11,%ymm11 - .byte 0xc4,0x41,0x24,0x58,0xdc // vaddps %ymm12,%ymm11,%ymm11 - .byte 0xc5,0x2c,0x59,0xd1 // vmulps %ymm1,%ymm10,%ymm10 - .byte 0xc4,0x41,0x2c,0x58,0xd3 // vaddps %ymm11,%ymm10,%ymm10 - .byte 0xc5,0x34,0x59,0xc8 // vmulps %ymm0,%ymm9,%ymm9 - .byte 0xc4,0x41,0x34,0x58,0xca // vaddps %ymm10,%ymm9,%ymm9 - .byte 0xc4,0x62,0x7d,0x18,0x50,0x08 // vbroadcastss 0x8(%rax),%ymm10 - .byte 0xc4,0x62,0x7d,0x18,0x58,0x14 // vbroadcastss 0x14(%rax),%ymm11 - .byte 0xc4,0x62,0x7d,0x18,0x60,0x20 // vbroadcastss 0x20(%rax),%ymm12 - .byte 0xc4,0x62,0x7d,0x18,0x68,0x2c // vbroadcastss 0x2c(%rax),%ymm13 - .byte 0xc5,0x9c,0x59,0xd2 // vmulps %ymm2,%ymm12,%ymm2 - .byte 0xc4,0xc1,0x6c,0x58,0xd5 // vaddps %ymm13,%ymm2,%ymm2 - .byte 0xc5,0xa4,0x59,0xc9 // vmulps %ymm1,%ymm11,%ymm1 - .byte 0xc5,0xf4,0x58,0xca // vaddps %ymm2,%ymm1,%ymm1 - .byte 0xc5,0xac,0x59,0xc0 // vmulps %ymm0,%ymm10,%ymm0 - .byte 0xc5,0xfc,0x58,0xd1 // vaddps %ymm1,%ymm0,%ymm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0x7c,0x29,0xc0 // vmovaps %ymm8,%ymm0 - .byte 0xc5,0x7c,0x29,0xc9 // vmovaps %ymm9,%ymm1 - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_linear_gradient_2stops_avx _sk_linear_gradient_2stops_avx: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc4,0xe2,0x7d,0x18,0x48,0x10 // vbroadcastss 0x10(%rax),%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x10 // vbroadcastss (%rax),%ymm2 - .byte 0xc5,0xf4,0x59,0xc8 // vmulps %ymm0,%ymm1,%ymm1 - .byte 0xc5,0x6c,0x58,0xc1 // vaddps %ymm1,%ymm2,%ymm8 - .byte 0xc4,0xe2,0x7d,0x18,0x48,0x14 // vbroadcastss 0x14(%rax),%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x50,0x04 // vbroadcastss 0x4(%rax),%ymm2 - .byte 0xc5,0xf4,0x59,0xc8 // vmulps %ymm0,%ymm1,%ymm1 - .byte 0xc5,0xec,0x58,0xc9 // vaddps %ymm1,%ymm2,%ymm1 - .byte 0xc4,0xe2,0x7d,0x18,0x50,0x18 // vbroadcastss 0x18(%rax),%ymm2 - .byte 0xc4,0xe2,0x7d,0x18,0x58,0x08 // vbroadcastss 0x8(%rax),%ymm3 - .byte 0xc5,0xec,0x59,0xd0 // vmulps %ymm0,%ymm2,%ymm2 - .byte 0xc5,0xe4,0x58,0xd2 // vaddps %ymm2,%ymm3,%ymm2 - .byte 0xc4,0xe2,0x7d,0x18,0x58,0x1c // vbroadcastss 0x1c(%rax),%ymm3 - .byte 0xc4,0x62,0x7d,0x18,0x48,0x0c // vbroadcastss 0xc(%rax),%ymm9 - .byte 0xc5,0xe4,0x59,0xc0 // vmulps %ymm0,%ymm3,%ymm0 - .byte 0xc5,0xb4,0x58,0xd8 // vaddps %ymm0,%ymm9,%ymm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xc5,0x7c,0x29,0xc0 // vmovaps %ymm8,%ymm0 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 196,226,125,24,72,16 // vbroadcastss 0x10(%rax),%ymm1 + .byte 196,226,125,24,16 // vbroadcastss (%rax),%ymm2 + .byte 197,244,89,200 // vmulps %ymm0,%ymm1,%ymm1 + .byte 197,108,88,193 // vaddps %ymm1,%ymm2,%ymm8 + .byte 196,226,125,24,72,20 // vbroadcastss 0x14(%rax),%ymm1 + .byte 196,226,125,24,80,4 // vbroadcastss 0x4(%rax),%ymm2 + .byte 197,244,89,200 // vmulps %ymm0,%ymm1,%ymm1 + .byte 197,236,88,201 // vaddps %ymm1,%ymm2,%ymm1 + .byte 196,226,125,24,80,24 // vbroadcastss 0x18(%rax),%ymm2 + .byte 196,226,125,24,88,8 // vbroadcastss 0x8(%rax),%ymm3 + .byte 197,236,89,208 // vmulps %ymm0,%ymm2,%ymm2 + .byte 197,228,88,210 // vaddps %ymm2,%ymm3,%ymm2 + .byte 196,226,125,24,88,28 // vbroadcastss 0x1c(%rax),%ymm3 + .byte 196,98,125,24,72,12 // vbroadcastss 0xc(%rax),%ymm9 + .byte 197,228,89,192 // vmulps %ymm0,%ymm3,%ymm0 + .byte 197,180,88,216 // vaddps %ymm0,%ymm9,%ymm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 197,124,41,192 // vmovaps %ymm8,%ymm0 + .byte 255,224 // jmpq *%rax .globl _sk_start_pipeline_sse41 _sk_start_pipeline_sse41: - .byte 0x41,0x57 // push %r15 - .byte 0x41,0x56 // push %r14 - .byte 0x41,0x55 // push %r13 - .byte 0x41,0x54 // push %r12 - .byte 0x53 // push %rbx - .byte 0x49,0x89,0xcf // mov %rcx,%r15 - .byte 0x49,0x89,0xd6 // mov %rdx,%r14 - .byte 0x48,0x89,0xfb // mov %rdi,%rbx - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x49,0x89,0xc4 // mov %rax,%r12 - .byte 0x49,0x89,0xf5 // mov %rsi,%r13 - .byte 0x48,0x8d,0x43,0x04 // lea 0x4(%rbx),%rax - .byte 0x4c,0x39,0xf8 // cmp %r15,%rax - .byte 0x76,0x05 // jbe 28 <_sk_start_pipeline_sse41+0x28> - .byte 0x48,0x89,0xd8 // mov %rbx,%rax - .byte 0xeb,0x34 // jmp 5c <_sk_start_pipeline_sse41+0x5c> - .byte 0x0f,0x57,0xc0 // xorps %xmm0,%xmm0 - .byte 0x0f,0x57,0xc9 // xorps %xmm1,%xmm1 - .byte 0x0f,0x57,0xd2 // xorps %xmm2,%xmm2 - .byte 0x0f,0x57,0xdb // xorps %xmm3,%xmm3 - .byte 0x0f,0x57,0xe4 // xorps %xmm4,%xmm4 - .byte 0x0f,0x57,0xed // xorps %xmm5,%xmm5 - .byte 0x0f,0x57,0xf6 // xorps %xmm6,%xmm6 - .byte 0x0f,0x57,0xff // xorps %xmm7,%xmm7 - .byte 0x48,0x89,0xdf // mov %rbx,%rdi - .byte 0x4c,0x89,0xee // mov %r13,%rsi - .byte 0x4c,0x89,0xf2 // mov %r14,%rdx - .byte 0x41,0xff,0xd4 // callq *%r12 - .byte 0x48,0x8d,0x43,0x04 // lea 0x4(%rbx),%rax - .byte 0x48,0x83,0xc3,0x08 // add $0x8,%rbx - .byte 0x4c,0x39,0xfb // cmp %r15,%rbx - .byte 0x48,0x89,0xc3 // mov %rax,%rbx - .byte 0x76,0xcc // jbe 28 <_sk_start_pipeline_sse41+0x28> - .byte 0x5b // pop %rbx - .byte 0x41,0x5c // pop %r12 - .byte 0x41,0x5d // pop %r13 - .byte 0x41,0x5e // pop %r14 - .byte 0x41,0x5f // pop %r15 - .byte 0xc3 // retq + .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 73,137,207 // mov %rcx,%r15 + .byte 73,137,214 // mov %rdx,%r14 + .byte 72,137,251 // mov %rdi,%rbx + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 73,137,196 // mov %rax,%r12 + .byte 73,137,245 // mov %rsi,%r13 + .byte 72,141,67,4 // lea 0x4(%rbx),%rax + .byte 76,57,248 // cmp %r15,%rax + .byte 118,5 // jbe 28 <_sk_start_pipeline_sse41+0x28> + .byte 72,137,216 // mov %rbx,%rax + .byte 235,52 // jmp 5c <_sk_start_pipeline_sse41+0x5c> + .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 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 72,137,223 // mov %rbx,%rdi + .byte 76,137,238 // mov %r13,%rsi + .byte 76,137,242 // mov %r14,%rdx + .byte 65,255,212 // callq *%r12 + .byte 72,141,67,4 // lea 0x4(%rbx),%rax + .byte 72,131,195,8 // add $0x8,%rbx + .byte 76,57,251 // cmp %r15,%rbx + .byte 72,137,195 // mov %rax,%rbx + .byte 118,204 // jbe 28 <_sk_start_pipeline_sse41+0x28> + .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 195 // retq .globl _sk_just_return_sse41 _sk_just_return_sse41: - .byte 0xc3 // retq + .byte 195 // retq .globl _sk_seed_shader_sse41 _sk_seed_shader_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x66,0x0f,0x6e,0xc7 // movd %edi,%xmm0 - .byte 0x66,0x0f,0x70,0xc0,0x00 // pshufd $0x0,%xmm0,%xmm0 - .byte 0x0f,0x5b,0xc8 // cvtdq2ps %xmm0,%xmm1 - .byte 0xf3,0x0f,0x10,0x12 // movss (%rdx),%xmm2 - .byte 0xf3,0x0f,0x10,0x5a,0x04 // movss 0x4(%rdx),%xmm3 - .byte 0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm3,%xmm3 - .byte 0x0f,0x58,0xcb // addps %xmm3,%xmm1 - .byte 0x0f,0x10,0x42,0x14 // movups 0x14(%rdx),%xmm0 - .byte 0x0f,0x58,0xc1 // addps %xmm1,%xmm0 - .byte 0x66,0x0f,0x6e,0x08 // movd (%rax),%xmm1 - .byte 0x66,0x0f,0x70,0xc9,0x00 // pshufd $0x0,%xmm1,%xmm1 - .byte 0x0f,0x5b,0xc9 // cvtdq2ps %xmm1,%xmm1 - .byte 0x0f,0x58,0xcb // addps %xmm3,%xmm1 - .byte 0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm2,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x57,0xdb // xorps %xmm3,%xmm3 - .byte 0x0f,0x57,0xe4 // xorps %xmm4,%xmm4 - .byte 0x0f,0x57,0xed // xorps %xmm5,%xmm5 - .byte 0x0f,0x57,0xf6 // xorps %xmm6,%xmm6 - .byte 0x0f,0x57,0xff // xorps %xmm7,%xmm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 102,15,110,199 // movd %edi,%xmm0 + .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 + .byte 15,91,200 // cvtdq2ps %xmm0,%xmm1 + .byte 243,15,16,18 // movss (%rdx),%xmm2 + .byte 243,15,16,90,4 // movss 0x4(%rdx),%xmm3 + .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 + .byte 15,88,203 // addps %xmm3,%xmm1 + .byte 15,16,66,20 // movups 0x14(%rdx),%xmm0 + .byte 15,88,193 // addps %xmm1,%xmm0 + .byte 102,15,110,8 // movd (%rax),%xmm1 + .byte 102,15,112,201,0 // pshufd $0x0,%xmm1,%xmm1 + .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 + .byte 15,88,203 // addps %xmm3,%xmm1 + .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_constant_color_sse41 _sk_constant_color_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x10,0x18 // movups (%rax),%xmm3 - .byte 0x0f,0x28,0xc3 // movaps %xmm3,%xmm0 - .byte 0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm0,%xmm0 - .byte 0x0f,0x28,0xcb // movaps %xmm3,%xmm1 - .byte 0x0f,0xc6,0xc9,0x55 // shufps $0x55,%xmm1,%xmm1 - .byte 0x0f,0x28,0xd3 // movaps %xmm3,%xmm2 - .byte 0x0f,0xc6,0xd2,0xaa // shufps $0xaa,%xmm2,%xmm2 - .byte 0x0f,0xc6,0xdb,0xff // shufps $0xff,%xmm3,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 15,16,24 // movups (%rax),%xmm3 + .byte 15,40,195 // movaps %xmm3,%xmm0 + .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 + .byte 15,40,203 // movaps %xmm3,%xmm1 + .byte 15,198,201,85 // shufps $0x55,%xmm1,%xmm1 + .byte 15,40,211 // movaps %xmm3,%xmm2 + .byte 15,198,210,170 // shufps $0xaa,%xmm2,%xmm2 + .byte 15,198,219,255 // shufps $0xff,%xmm3,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_clear_sse41 _sk_clear_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x57,0xc0 // xorps %xmm0,%xmm0 - .byte 0x0f,0x57,0xc9 // xorps %xmm1,%xmm1 - .byte 0x0f,0x57,0xd2 // xorps %xmm2,%xmm2 - .byte 0x0f,0x57,0xdb // xorps %xmm3,%xmm3 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_plus__sse41 _sk_plus__sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x58,0xc4 // addps %xmm4,%xmm0 - .byte 0x0f,0x58,0xcd // addps %xmm5,%xmm1 - .byte 0x0f,0x58,0xd6 // addps %xmm6,%xmm2 - .byte 0x0f,0x58,0xdf // addps %xmm7,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_srcover_sse41 _sk_srcover_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x02 // movss (%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x44,0x0f,0x5c,0xc3 // subps %xmm3,%xmm8 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xcc // mulps %xmm4,%xmm9 - .byte 0x41,0x0f,0x58,0xc1 // addps %xmm9,%xmm0 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xcd // mulps %xmm5,%xmm9 - .byte 0x41,0x0f,0x58,0xc9 // addps %xmm9,%xmm1 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xce // mulps %xmm6,%xmm9 - .byte 0x41,0x0f,0x58,0xd1 // addps %xmm9,%xmm2 - .byte 0x44,0x0f,0x59,0xc7 // mulps %xmm7,%xmm8 - .byte 0x41,0x0f,0x58,0xd8 // addps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,2 // movss (%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .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 .globl _sk_dstover_sse41 _sk_dstover_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x02 // movss (%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x44,0x0f,0x5c,0xc7 // subps %xmm7,%xmm8 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x0f,0x58,0xc4 // addps %xmm4,%xmm0 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x0f,0x58,0xcd // addps %xmm5,%xmm1 - .byte 0x41,0x0f,0x59,0xd0 // mulps %xmm8,%xmm2 - .byte 0x0f,0x58,0xd6 // addps %xmm6,%xmm2 - .byte 0x41,0x0f,0x59,0xd8 // mulps %xmm8,%xmm3 - .byte 0x0f,0x58,0xdf // addps %xmm7,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,2 // movss (%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .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 .globl _sk_clamp_0_sse41 _sk_clamp_0_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x45,0x0f,0x57,0xc0 // xorps %xmm8,%xmm8 - .byte 0x41,0x0f,0x5f,0xc0 // maxps %xmm8,%xmm0 - .byte 0x41,0x0f,0x5f,0xc8 // maxps %xmm8,%xmm1 - .byte 0x41,0x0f,0x5f,0xd0 // maxps %xmm8,%xmm2 - .byte 0x41,0x0f,0x5f,0xd8 // maxps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_clamp_1_sse41 _sk_clamp_1_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x02 // movss (%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x41,0x0f,0x5d,0xc0 // minps %xmm8,%xmm0 - .byte 0x41,0x0f,0x5d,0xc8 // minps %xmm8,%xmm1 - .byte 0x41,0x0f,0x5d,0xd0 // minps %xmm8,%xmm2 - .byte 0x41,0x0f,0x5d,0xd8 // minps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,2 // movss (%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .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 .globl _sk_clamp_a_sse41 _sk_clamp_a_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x02 // movss (%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x41,0x0f,0x5d,0xd8 // minps %xmm8,%xmm3 - .byte 0x0f,0x5d,0xc3 // minps %xmm3,%xmm0 - .byte 0x0f,0x5d,0xcb // minps %xmm3,%xmm1 - .byte 0x0f,0x5d,0xd3 // minps %xmm3,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,2 // movss (%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 65,15,93,216 // minps %xmm8,%xmm3 + .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 .globl _sk_set_rgb_sse41 _sk_set_rgb_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x0f,0x10,0x00 // movss (%rax),%xmm0 - .byte 0xf3,0x0f,0x10,0x48,0x04 // movss 0x4(%rax),%xmm1 - .byte 0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm0,%xmm0 - .byte 0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm1,%xmm1 - .byte 0xf3,0x0f,0x10,0x50,0x08 // movss 0x8(%rax),%xmm2 - .byte 0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm2,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_swap_rb_sse41 _sk_swap_rb_sse41: - .byte 0x44,0x0f,0x28,0xc0 // movaps %xmm0,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x28,0xc2 // movaps %xmm2,%xmm0 - .byte 0x41,0x0f,0x28,0xd0 // movaps %xmm8,%xmm2 - .byte 0xff,0xe0 // jmpq *%rax + .byte 68,15,40,192 // movaps %xmm0,%xmm8 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_swap_sse41 _sk_swap_sse41: - .byte 0x44,0x0f,0x28,0xc3 // movaps %xmm3,%xmm8 - .byte 0x44,0x0f,0x28,0xca // movaps %xmm2,%xmm9 - .byte 0x44,0x0f,0x28,0xd1 // movaps %xmm1,%xmm10 - .byte 0x44,0x0f,0x28,0xd8 // movaps %xmm0,%xmm11 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x28,0xc4 // movaps %xmm4,%xmm0 - .byte 0x0f,0x28,0xcd // movaps %xmm5,%xmm1 - .byte 0x0f,0x28,0xd6 // movaps %xmm6,%xmm2 - .byte 0x0f,0x28,0xdf // movaps %xmm7,%xmm3 - .byte 0x41,0x0f,0x28,0xe3 // movaps %xmm11,%xmm4 - .byte 0x41,0x0f,0x28,0xea // movaps %xmm10,%xmm5 - .byte 0x41,0x0f,0x28,0xf1 // movaps %xmm9,%xmm6 - .byte 0x41,0x0f,0x28,0xf8 // movaps %xmm8,%xmm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 68,15,40,195 // movaps %xmm3,%xmm8 + .byte 68,15,40,202 // movaps %xmm2,%xmm9 + .byte 68,15,40,209 // movaps %xmm1,%xmm10 + .byte 68,15,40,216 // movaps %xmm0,%xmm11 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 65,15,40,227 // movaps %xmm11,%xmm4 + .byte 65,15,40,234 // movaps %xmm10,%xmm5 + .byte 65,15,40,241 // movaps %xmm9,%xmm6 + .byte 65,15,40,248 // movaps %xmm8,%xmm7 + .byte 255,224 // jmpq *%rax .globl _sk_move_src_dst_sse41 _sk_move_src_dst_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x28,0xe0 // movaps %xmm0,%xmm4 - .byte 0x0f,0x28,0xe9 // movaps %xmm1,%xmm5 - .byte 0x0f,0x28,0xf2 // movaps %xmm2,%xmm6 - .byte 0x0f,0x28,0xfb // movaps %xmm3,%xmm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_move_dst_src_sse41 _sk_move_dst_src_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x28,0xc4 // movaps %xmm4,%xmm0 - .byte 0x0f,0x28,0xcd // movaps %xmm5,%xmm1 - .byte 0x0f,0x28,0xd6 // movaps %xmm6,%xmm2 - .byte 0x0f,0x28,0xdf // movaps %xmm7,%xmm3 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_premul_sse41 _sk_premul_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x59,0xc3 // mulps %xmm3,%xmm0 - .byte 0x0f,0x59,0xcb // mulps %xmm3,%xmm1 - .byte 0x0f,0x59,0xd3 // mulps %xmm3,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_unpremul_sse41 _sk_unpremul_sse41: - .byte 0x44,0x0f,0x28,0xc0 // movaps %xmm0,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x45,0x0f,0x57,0xc9 // xorps %xmm9,%xmm9 - .byte 0xf3,0x44,0x0f,0x10,0x12 // movss (%rdx),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0x44,0x0f,0x5e,0xd3 // divps %xmm3,%xmm10 - .byte 0x0f,0x28,0xc3 // movaps %xmm3,%xmm0 - .byte 0x41,0x0f,0xc2,0xc1,0x00 // cmpeqps %xmm9,%xmm0 - .byte 0x66,0x45,0x0f,0x38,0x14,0xd1 // blendvps %xmm0,%xmm9,%xmm10 - .byte 0x45,0x0f,0x59,0xc2 // mulps %xmm10,%xmm8 - .byte 0x41,0x0f,0x59,0xca // mulps %xmm10,%xmm1 - .byte 0x41,0x0f,0x59,0xd2 // mulps %xmm10,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xc0 // movaps %xmm8,%xmm0 - .byte 0xff,0xe0 // jmpq *%rax + .byte 68,15,40,192 // movaps %xmm0,%xmm8 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 69,15,87,201 // xorps %xmm9,%xmm9 + .byte 243,68,15,16,18 // movss (%rdx),%xmm10 + .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 + .byte 68,15,94,211 // divps %xmm3,%xmm10 + .byte 15,40,195 // movaps %xmm3,%xmm0 + .byte 65,15,194,193,0 // cmpeqps %xmm9,%xmm0 + .byte 102,69,15,56,20,209 // blendvps %xmm0,%xmm9,%xmm10 + .byte 69,15,89,194 // mulps %xmm10,%xmm8 + .byte 65,15,89,202 // mulps %xmm10,%xmm1 + .byte 65,15,89,210 // mulps %xmm10,%xmm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 65,15,40,192 // movaps %xmm8,%xmm0 + .byte 255,224 // jmpq *%rax .globl _sk_from_srgb_sse41 _sk_from_srgb_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x5a,0x40 // movss 0x40(%rdx),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0x45,0x0f,0x28,0xd3 // movaps %xmm11,%xmm10 - .byte 0x44,0x0f,0x59,0xd0 // mulps %xmm0,%xmm10 - .byte 0x44,0x0f,0x28,0xf0 // movaps %xmm0,%xmm14 - .byte 0x45,0x0f,0x59,0xf6 // mulps %xmm14,%xmm14 - .byte 0xf3,0x44,0x0f,0x10,0x42,0x3c // movss 0x3c(%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0xf3,0x44,0x0f,0x10,0x62,0x34 // movss 0x34(%rdx),%xmm12 - .byte 0xf3,0x44,0x0f,0x10,0x6a,0x38 // movss 0x38(%rdx),%xmm13 - .byte 0x45,0x0f,0xc6,0xed,0x00 // shufps $0x0,%xmm13,%xmm13 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xc8 // mulps %xmm0,%xmm9 - .byte 0x45,0x0f,0x58,0xcd // addps %xmm13,%xmm9 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0x45,0x0f,0x59,0xce // mulps %xmm14,%xmm9 - .byte 0x45,0x0f,0x58,0xcc // addps %xmm12,%xmm9 - .byte 0xf3,0x44,0x0f,0x10,0x72,0x44 // movss 0x44(%rdx),%xmm14 - .byte 0x45,0x0f,0xc6,0xf6,0x00 // shufps $0x0,%xmm14,%xmm14 - .byte 0x41,0x0f,0xc2,0xc6,0x01 // cmpltps %xmm14,%xmm0 - .byte 0x66,0x45,0x0f,0x38,0x14,0xca // blendvps %xmm0,%xmm10,%xmm9 - .byte 0x45,0x0f,0x28,0xfb // movaps %xmm11,%xmm15 - .byte 0x44,0x0f,0x59,0xf9 // mulps %xmm1,%xmm15 - .byte 0x0f,0x28,0xc1 // movaps %xmm1,%xmm0 - .byte 0x0f,0x59,0xc0 // mulps %xmm0,%xmm0 - .byte 0x45,0x0f,0x28,0xd0 // movaps %xmm8,%xmm10 - .byte 0x44,0x0f,0x59,0xd1 // mulps %xmm1,%xmm10 - .byte 0x45,0x0f,0x58,0xd5 // addps %xmm13,%xmm10 - .byte 0x44,0x0f,0x59,0xd0 // mulps %xmm0,%xmm10 - .byte 0x45,0x0f,0x58,0xd4 // addps %xmm12,%xmm10 - .byte 0x41,0x0f,0xc2,0xce,0x01 // cmpltps %xmm14,%xmm1 - .byte 0x0f,0x28,0xc1 // movaps %xmm1,%xmm0 - .byte 0x66,0x45,0x0f,0x38,0x14,0xd7 // blendvps %xmm0,%xmm15,%xmm10 - .byte 0x44,0x0f,0x59,0xda // mulps %xmm2,%xmm11 - .byte 0x0f,0x28,0xc2 // movaps %xmm2,%xmm0 - .byte 0x0f,0x59,0xc0 // mulps %xmm0,%xmm0 - .byte 0x44,0x0f,0x59,0xc2 // mulps %xmm2,%xmm8 - .byte 0x45,0x0f,0x58,0xc5 // addps %xmm13,%xmm8 - .byte 0x44,0x0f,0x59,0xc0 // mulps %xmm0,%xmm8 - .byte 0x45,0x0f,0x58,0xc4 // addps %xmm12,%xmm8 - .byte 0x41,0x0f,0xc2,0xd6,0x01 // cmpltps %xmm14,%xmm2 - .byte 0x0f,0x28,0xc2 // movaps %xmm2,%xmm0 - .byte 0x66,0x45,0x0f,0x38,0x14,0xc3 // blendvps %xmm0,%xmm11,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xc1 // movaps %xmm9,%xmm0 - .byte 0x41,0x0f,0x28,0xca // movaps %xmm10,%xmm1 - .byte 0x41,0x0f,0x28,0xd0 // movaps %xmm8,%xmm2 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,90,64 // movss 0x40(%rdx),%xmm11 + .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 + .byte 69,15,40,211 // movaps %xmm11,%xmm10 + .byte 68,15,89,208 // mulps %xmm0,%xmm10 + .byte 68,15,40,240 // movaps %xmm0,%xmm14 + .byte 69,15,89,246 // mulps %xmm14,%xmm14 + .byte 243,68,15,16,66,60 // movss 0x3c(%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 243,68,15,16,98,52 // movss 0x34(%rdx),%xmm12 + .byte 243,68,15,16,106,56 // movss 0x38(%rdx),%xmm13 + .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 + .byte 69,15,40,200 // movaps %xmm8,%xmm9 + .byte 68,15,89,200 // mulps %xmm0,%xmm9 + .byte 69,15,88,205 // addps %xmm13,%xmm9 + .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 + .byte 69,15,89,206 // mulps %xmm14,%xmm9 + .byte 69,15,88,204 // addps %xmm12,%xmm9 + .byte 243,68,15,16,114,68 // movss 0x44(%rdx),%xmm14 + .byte 69,15,198,246,0 // shufps $0x0,%xmm14,%xmm14 + .byte 65,15,194,198,1 // cmpltps %xmm14,%xmm0 + .byte 102,69,15,56,20,202 // blendvps %xmm0,%xmm10,%xmm9 + .byte 69,15,40,251 // movaps %xmm11,%xmm15 + .byte 68,15,89,249 // mulps %xmm1,%xmm15 + .byte 15,40,193 // movaps %xmm1,%xmm0 + .byte 15,89,192 // mulps %xmm0,%xmm0 + .byte 69,15,40,208 // movaps %xmm8,%xmm10 + .byte 68,15,89,209 // mulps %xmm1,%xmm10 + .byte 69,15,88,213 // addps %xmm13,%xmm10 + .byte 68,15,89,208 // mulps %xmm0,%xmm10 + .byte 69,15,88,212 // addps %xmm12,%xmm10 + .byte 65,15,194,206,1 // cmpltps %xmm14,%xmm1 + .byte 15,40,193 // movaps %xmm1,%xmm0 + .byte 102,69,15,56,20,215 // blendvps %xmm0,%xmm15,%xmm10 + .byte 68,15,89,218 // mulps %xmm2,%xmm11 + .byte 15,40,194 // movaps %xmm2,%xmm0 + .byte 15,89,192 // mulps %xmm0,%xmm0 + .byte 68,15,89,194 // mulps %xmm2,%xmm8 + .byte 69,15,88,197 // addps %xmm13,%xmm8 + .byte 68,15,89,192 // mulps %xmm0,%xmm8 + .byte 69,15,88,196 // addps %xmm12,%xmm8 + .byte 65,15,194,214,1 // cmpltps %xmm14,%xmm2 + .byte 15,40,194 // movaps %xmm2,%xmm0 + .byte 102,69,15,56,20,195 // blendvps %xmm0,%xmm11,%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,208 // movaps %xmm8,%xmm2 + .byte 255,224 // jmpq *%rax .globl _sk_to_srgb_sse41 _sk_to_srgb_sse41: - .byte 0x48,0x83,0xec,0x18 // sub $0x18,%rsp - .byte 0x0f,0x29,0x3c,0x24 // movaps %xmm7,(%rsp) - .byte 0x0f,0x28,0xfe // movaps %xmm6,%xmm7 - .byte 0x0f,0x28,0xf5 // movaps %xmm5,%xmm6 - .byte 0x0f,0x28,0xec // movaps %xmm4,%xmm5 - .byte 0x0f,0x28,0xe3 // movaps %xmm3,%xmm4 - .byte 0x44,0x0f,0x28,0xc2 // movaps %xmm2,%xmm8 - .byte 0x0f,0x28,0xd9 // movaps %xmm1,%xmm3 - .byte 0x0f,0x52,0xd0 // rsqrtps %xmm0,%xmm2 - .byte 0x44,0x0f,0x53,0xca // rcpps %xmm2,%xmm9 - .byte 0x44,0x0f,0x52,0xd2 // rsqrtps %xmm2,%xmm10 - .byte 0xf3,0x0f,0x10,0x12 // movss (%rdx),%xmm2 - .byte 0xf3,0x44,0x0f,0x10,0x5a,0x48 // movss 0x48(%rdx),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0x41,0x0f,0x28,0xcb // movaps %xmm11,%xmm1 - .byte 0x0f,0x59,0xc8 // mulps %xmm0,%xmm1 - .byte 0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm2,%xmm2 - .byte 0xf3,0x44,0x0f,0x10,0x62,0x4c // movss 0x4c(%rdx),%xmm12 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0xf3,0x44,0x0f,0x10,0x6a,0x50 // movss 0x50(%rdx),%xmm13 - .byte 0x45,0x0f,0xc6,0xed,0x00 // shufps $0x0,%xmm13,%xmm13 - .byte 0xf3,0x44,0x0f,0x10,0x72,0x54 // movss 0x54(%rdx),%xmm14 - .byte 0x45,0x0f,0xc6,0xf6,0x00 // shufps $0x0,%xmm14,%xmm14 - .byte 0x45,0x0f,0x59,0xcd // mulps %xmm13,%xmm9 - .byte 0x45,0x0f,0x58,0xce // addps %xmm14,%xmm9 - .byte 0x45,0x0f,0x59,0xd4 // mulps %xmm12,%xmm10 - .byte 0x45,0x0f,0x58,0xd1 // addps %xmm9,%xmm10 - .byte 0x44,0x0f,0x28,0xca // movaps %xmm2,%xmm9 - .byte 0x45,0x0f,0x5d,0xca // minps %xmm10,%xmm9 - .byte 0xf3,0x44,0x0f,0x10,0x7a,0x58 // movss 0x58(%rdx),%xmm15 - .byte 0x45,0x0f,0xc6,0xff,0x00 // shufps $0x0,%xmm15,%xmm15 - .byte 0x41,0x0f,0xc2,0xc7,0x01 // cmpltps %xmm15,%xmm0 - .byte 0x66,0x44,0x0f,0x38,0x14,0xc9 // blendvps %xmm0,%xmm1,%xmm9 - .byte 0x0f,0x52,0xc3 // rsqrtps %xmm3,%xmm0 - .byte 0x0f,0x53,0xc8 // rcpps %xmm0,%xmm1 - .byte 0x0f,0x52,0xc0 // rsqrtps %xmm0,%xmm0 - .byte 0x41,0x0f,0x59,0xcd // mulps %xmm13,%xmm1 - .byte 0x41,0x0f,0x58,0xce // addps %xmm14,%xmm1 - .byte 0x41,0x0f,0x59,0xc4 // mulps %xmm12,%xmm0 - .byte 0x0f,0x58,0xc1 // addps %xmm1,%xmm0 - .byte 0x44,0x0f,0x28,0xd2 // movaps %xmm2,%xmm10 - .byte 0x44,0x0f,0x5d,0xd0 // minps %xmm0,%xmm10 - .byte 0x41,0x0f,0x28,0xcb // movaps %xmm11,%xmm1 - .byte 0x0f,0x59,0xcb // mulps %xmm3,%xmm1 - .byte 0x41,0x0f,0xc2,0xdf,0x01 // cmpltps %xmm15,%xmm3 - .byte 0x0f,0x28,0xc3 // movaps %xmm3,%xmm0 - .byte 0x66,0x44,0x0f,0x38,0x14,0xd1 // blendvps %xmm0,%xmm1,%xmm10 - .byte 0x41,0x0f,0x52,0xc0 // rsqrtps %xmm8,%xmm0 - .byte 0x0f,0x53,0xc8 // rcpps %xmm0,%xmm1 - .byte 0x41,0x0f,0x59,0xcd // mulps %xmm13,%xmm1 - .byte 0x41,0x0f,0x58,0xce // addps %xmm14,%xmm1 - .byte 0x0f,0x52,0xc0 // rsqrtps %xmm0,%xmm0 - .byte 0x41,0x0f,0x59,0xc4 // mulps %xmm12,%xmm0 - .byte 0x0f,0x58,0xc1 // addps %xmm1,%xmm0 - .byte 0x0f,0x5d,0xd0 // minps %xmm0,%xmm2 - .byte 0x45,0x0f,0x59,0xd8 // mulps %xmm8,%xmm11 - .byte 0x45,0x0f,0xc2,0xc7,0x01 // cmpltps %xmm15,%xmm8 - .byte 0x41,0x0f,0x28,0xc0 // movaps %xmm8,%xmm0 - .byte 0x66,0x41,0x0f,0x38,0x14,0xd3 // blendvps %xmm0,%xmm11,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xc1 // movaps %xmm9,%xmm0 - .byte 0x41,0x0f,0x28,0xca // movaps %xmm10,%xmm1 - .byte 0x0f,0x28,0xdc // movaps %xmm4,%xmm3 - .byte 0x0f,0x28,0xe5 // movaps %xmm5,%xmm4 - .byte 0x0f,0x28,0xee // movaps %xmm6,%xmm5 - .byte 0x0f,0x28,0xf7 // movaps %xmm7,%xmm6 - .byte 0x0f,0x28,0x3c,0x24 // movaps (%rsp),%xmm7 - .byte 0x48,0x83,0xc4,0x18 // add $0x18,%rsp - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,131,236,24 // sub $0x18,%rsp + .byte 15,41,60,36 // movaps %xmm7,(%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 68,15,40,194 // movaps %xmm2,%xmm8 + .byte 15,40,217 // movaps %xmm1,%xmm3 + .byte 15,82,208 // rsqrtps %xmm0,%xmm2 + .byte 68,15,83,202 // rcpps %xmm2,%xmm9 + .byte 68,15,82,210 // rsqrtps %xmm2,%xmm10 + .byte 243,15,16,18 // movss (%rdx),%xmm2 + .byte 243,68,15,16,90,72 // movss 0x48(%rdx),%xmm11 + .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 + .byte 65,15,40,203 // movaps %xmm11,%xmm1 + .byte 15,89,200 // mulps %xmm0,%xmm1 + .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 + .byte 243,68,15,16,98,76 // movss 0x4c(%rdx),%xmm12 + .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 + .byte 243,68,15,16,106,80 // movss 0x50(%rdx),%xmm13 + .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 + .byte 243,68,15,16,114,84 // movss 0x54(%rdx),%xmm14 + .byte 69,15,198,246,0 // shufps $0x0,%xmm14,%xmm14 + .byte 69,15,89,205 // mulps %xmm13,%xmm9 + .byte 69,15,88,206 // addps %xmm14,%xmm9 + .byte 69,15,89,212 // mulps %xmm12,%xmm10 + .byte 69,15,88,209 // addps %xmm9,%xmm10 + .byte 68,15,40,202 // movaps %xmm2,%xmm9 + .byte 69,15,93,202 // minps %xmm10,%xmm9 + .byte 243,68,15,16,122,88 // movss 0x58(%rdx),%xmm15 + .byte 69,15,198,255,0 // shufps $0x0,%xmm15,%xmm15 + .byte 65,15,194,199,1 // cmpltps %xmm15,%xmm0 + .byte 102,68,15,56,20,201 // blendvps %xmm0,%xmm1,%xmm9 + .byte 15,82,195 // rsqrtps %xmm3,%xmm0 + .byte 15,83,200 // rcpps %xmm0,%xmm1 + .byte 15,82,192 // rsqrtps %xmm0,%xmm0 + .byte 65,15,89,205 // mulps %xmm13,%xmm1 + .byte 65,15,88,206 // addps %xmm14,%xmm1 + .byte 65,15,89,196 // mulps %xmm12,%xmm0 + .byte 15,88,193 // addps %xmm1,%xmm0 + .byte 68,15,40,210 // movaps %xmm2,%xmm10 + .byte 68,15,93,208 // minps %xmm0,%xmm10 + .byte 65,15,40,203 // movaps %xmm11,%xmm1 + .byte 15,89,203 // mulps %xmm3,%xmm1 + .byte 65,15,194,223,1 // cmpltps %xmm15,%xmm3 + .byte 15,40,195 // movaps %xmm3,%xmm0 + .byte 102,68,15,56,20,209 // blendvps %xmm0,%xmm1,%xmm10 + .byte 65,15,82,192 // rsqrtps %xmm8,%xmm0 + .byte 15,83,200 // rcpps %xmm0,%xmm1 + .byte 65,15,89,205 // mulps %xmm13,%xmm1 + .byte 65,15,88,206 // addps %xmm14,%xmm1 + .byte 15,82,192 // rsqrtps %xmm0,%xmm0 + .byte 65,15,89,196 // mulps %xmm12,%xmm0 + .byte 15,88,193 // addps %xmm1,%xmm0 + .byte 15,93,208 // minps %xmm0,%xmm2 + .byte 69,15,89,216 // mulps %xmm8,%xmm11 + .byte 69,15,194,199,1 // cmpltps %xmm15,%xmm8 + .byte 65,15,40,192 // movaps %xmm8,%xmm0 + .byte 102,65,15,56,20,211 // blendvps %xmm0,%xmm11,%xmm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 65,15,40,193 // movaps %xmm9,%xmm0 + .byte 65,15,40,202 // movaps %xmm10,%xmm1 + .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,60,36 // movaps (%rsp),%xmm7 + .byte 72,131,196,24 // add $0x18,%rsp + .byte 255,224 // jmpq *%rax .globl _sk_scale_u8_sse41 _sk_scale_u8_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0x66,0x44,0x0f,0x38,0x31,0x04,0x38 // pmovzxbd (%rax,%rdi,1),%xmm8 - .byte 0x45,0x0f,0x5b,0xc0 // cvtdq2ps %xmm8,%xmm8 - .byte 0xf3,0x44,0x0f,0x10,0x4a,0x0c // movss 0xc(%rdx),%xmm9 - .byte 0x45,0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm9,%xmm9 - .byte 0x45,0x0f,0x59,0xc8 // mulps %xmm8,%xmm9 - .byte 0x41,0x0f,0x59,0xc1 // mulps %xmm9,%xmm0 - .byte 0x41,0x0f,0x59,0xc9 // mulps %xmm9,%xmm1 - .byte 0x41,0x0f,0x59,0xd1 // mulps %xmm9,%xmm2 - .byte 0x41,0x0f,0x59,0xd9 // mulps %xmm9,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 102,68,15,56,49,4,56 // pmovzxbd (%rax,%rdi,1),%xmm8 + .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 + .byte 243,68,15,16,74,12 // movss 0xc(%rdx),%xmm9 + .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 + .byte 69,15,89,200 // mulps %xmm8,%xmm9 + .byte 65,15,89,193 // mulps %xmm9,%xmm0 + .byte 65,15,89,201 // mulps %xmm9,%xmm1 + .byte 65,15,89,209 // mulps %xmm9,%xmm2 + .byte 65,15,89,217 // mulps %xmm9,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_lerp_u8_sse41 _sk_lerp_u8_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0x66,0x44,0x0f,0x38,0x31,0x04,0x38 // pmovzxbd (%rax,%rdi,1),%xmm8 - .byte 0x45,0x0f,0x5b,0xc0 // cvtdq2ps %xmm8,%xmm8 - .byte 0xf3,0x44,0x0f,0x10,0x4a,0x0c // movss 0xc(%rdx),%xmm9 - .byte 0x45,0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm9,%xmm9 - .byte 0x45,0x0f,0x59,0xc8 // mulps %xmm8,%xmm9 - .byte 0x0f,0x5c,0xc4 // subps %xmm4,%xmm0 - .byte 0x41,0x0f,0x59,0xc1 // mulps %xmm9,%xmm0 - .byte 0x0f,0x58,0xc4 // addps %xmm4,%xmm0 - .byte 0x0f,0x5c,0xcd // subps %xmm5,%xmm1 - .byte 0x41,0x0f,0x59,0xc9 // mulps %xmm9,%xmm1 - .byte 0x0f,0x58,0xcd // addps %xmm5,%xmm1 - .byte 0x0f,0x5c,0xd6 // subps %xmm6,%xmm2 - .byte 0x41,0x0f,0x59,0xd1 // mulps %xmm9,%xmm2 - .byte 0x0f,0x58,0xd6 // addps %xmm6,%xmm2 - .byte 0x0f,0x5c,0xdf // subps %xmm7,%xmm3 - .byte 0x41,0x0f,0x59,0xd9 // mulps %xmm9,%xmm3 - .byte 0x0f,0x58,0xdf // addps %xmm7,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 102,68,15,56,49,4,56 // pmovzxbd (%rax,%rdi,1),%xmm8 + .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 + .byte 243,68,15,16,74,12 // movss 0xc(%rdx),%xmm9 + .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 + .byte 69,15,89,200 // mulps %xmm8,%xmm9 + .byte 15,92,196 // subps %xmm4,%xmm0 + .byte 65,15,89,193 // mulps %xmm9,%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,209 // mulps %xmm9,%xmm2 + .byte 15,88,214 // addps %xmm6,%xmm2 + .byte 15,92,223 // subps %xmm7,%xmm3 + .byte 65,15,89,217 // mulps %xmm9,%xmm3 + .byte 15,88,223 // addps %xmm7,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_load_tables_sse41 _sk_load_tables_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x08 // mov (%rax),%rcx - .byte 0x4c,0x8b,0x40,0x08 // mov 0x8(%rax),%r8 - .byte 0xf3,0x44,0x0f,0x6f,0x04,0xb9 // movdqu (%rcx,%rdi,4),%xmm8 - .byte 0x66,0x0f,0x6e,0x42,0x10 // movd 0x10(%rdx),%xmm0 - .byte 0x66,0x0f,0x70,0xc0,0x00 // pshufd $0x0,%xmm0,%xmm0 - .byte 0x66,0x41,0x0f,0x6f,0xc8 // movdqa %xmm8,%xmm1 - .byte 0x66,0x0f,0x72,0xd1,0x08 // psrld $0x8,%xmm1 - .byte 0x66,0x0f,0xdb,0xc8 // pand %xmm0,%xmm1 - .byte 0x66,0x41,0x0f,0x6f,0xd0 // movdqa %xmm8,%xmm2 - .byte 0x66,0x0f,0x72,0xd2,0x10 // psrld $0x10,%xmm2 - .byte 0x66,0x0f,0xdb,0xd0 // pand %xmm0,%xmm2 - .byte 0x66,0x41,0x0f,0xdb,0xc0 // pand %xmm8,%xmm0 - .byte 0x66,0x48,0x0f,0x3a,0x16,0xc1,0x01 // pextrq $0x1,%xmm0,%rcx - .byte 0x41,0x89,0xc9 // mov %ecx,%r9d - .byte 0x48,0xc1,0xe9,0x20 // shr $0x20,%rcx - .byte 0x66,0x49,0x0f,0x7e,0xc2 // movq %xmm0,%r10 - .byte 0x45,0x89,0xd3 // mov %r10d,%r11d - .byte 0x49,0xc1,0xea,0x20 // shr $0x20,%r10 - .byte 0xf3,0x43,0x0f,0x10,0x04,0x98 // movss (%r8,%r11,4),%xmm0 - .byte 0x66,0x43,0x0f,0x3a,0x21,0x04,0x90,0x10 // insertps $0x10,(%r8,%r10,4),%xmm0 - .byte 0x66,0x43,0x0f,0x3a,0x21,0x04,0x88,0x20 // insertps $0x20,(%r8,%r9,4),%xmm0 - .byte 0x66,0x41,0x0f,0x3a,0x21,0x04,0x88,0x30 // insertps $0x30,(%r8,%rcx,4),%xmm0 - .byte 0x48,0x8b,0x48,0x10 // mov 0x10(%rax),%rcx - .byte 0x66,0x49,0x0f,0x3a,0x16,0xc8,0x01 // pextrq $0x1,%xmm1,%r8 - .byte 0x45,0x89,0xc1 // mov %r8d,%r9d - .byte 0x49,0xc1,0xe8,0x20 // shr $0x20,%r8 - .byte 0x66,0x49,0x0f,0x7e,0xca // movq %xmm1,%r10 - .byte 0x45,0x89,0xd3 // mov %r10d,%r11d - .byte 0x49,0xc1,0xea,0x20 // shr $0x20,%r10 - .byte 0xf3,0x42,0x0f,0x10,0x0c,0x99 // movss (%rcx,%r11,4),%xmm1 - .byte 0x66,0x42,0x0f,0x3a,0x21,0x0c,0x91,0x10 // insertps $0x10,(%rcx,%r10,4),%xmm1 - .byte 0xf3,0x42,0x0f,0x10,0x1c,0x89 // movss (%rcx,%r9,4),%xmm3 - .byte 0x66,0x0f,0x3a,0x21,0xcb,0x20 // insertps $0x20,%xmm3,%xmm1 - .byte 0xf3,0x42,0x0f,0x10,0x1c,0x81 // movss (%rcx,%r8,4),%xmm3 - .byte 0x66,0x0f,0x3a,0x21,0xcb,0x30 // insertps $0x30,%xmm3,%xmm1 - .byte 0x48,0x8b,0x40,0x18 // mov 0x18(%rax),%rax - .byte 0x66,0x48,0x0f,0x3a,0x16,0xd1,0x01 // pextrq $0x1,%xmm2,%rcx - .byte 0x41,0x89,0xc8 // mov %ecx,%r8d - .byte 0x48,0xc1,0xe9,0x20 // shr $0x20,%rcx - .byte 0x66,0x49,0x0f,0x7e,0xd1 // movq %xmm2,%r9 - .byte 0x45,0x89,0xca // mov %r9d,%r10d - .byte 0x49,0xc1,0xe9,0x20 // shr $0x20,%r9 - .byte 0xf3,0x42,0x0f,0x10,0x14,0x90 // movss (%rax,%r10,4),%xmm2 - .byte 0x66,0x42,0x0f,0x3a,0x21,0x14,0x88,0x10 // insertps $0x10,(%rax,%r9,4),%xmm2 - .byte 0xf3,0x42,0x0f,0x10,0x1c,0x80 // movss (%rax,%r8,4),%xmm3 - .byte 0x66,0x0f,0x3a,0x21,0xd3,0x20 // insertps $0x20,%xmm3,%xmm2 - .byte 0xf3,0x0f,0x10,0x1c,0x88 // movss (%rax,%rcx,4),%xmm3 - .byte 0x66,0x0f,0x3a,0x21,0xd3,0x30 // insertps $0x30,%xmm3,%xmm2 - .byte 0x66,0x41,0x0f,0x72,0xd0,0x18 // psrld $0x18,%xmm8 - .byte 0x45,0x0f,0x5b,0xc0 // cvtdq2ps %xmm8,%xmm8 - .byte 0xf3,0x0f,0x10,0x5a,0x0c // movss 0xc(%rdx),%xmm3 - .byte 0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm3,%xmm3 - .byte 0x41,0x0f,0x59,0xd8 // mulps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,8 // mov (%rax),%rcx + .byte 76,139,64,8 // mov 0x8(%rax),%r8 + .byte 243,68,15,111,4,185 // movdqu (%rcx,%rdi,4),%xmm8 + .byte 102,15,110,66,16 // movd 0x10(%rdx),%xmm0 + .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 + .byte 102,65,15,111,200 // movdqa %xmm8,%xmm1 + .byte 102,15,114,209,8 // psrld $0x8,%xmm1 + .byte 102,15,219,200 // pand %xmm0,%xmm1 + .byte 102,65,15,111,208 // movdqa %xmm8,%xmm2 + .byte 102,15,114,210,16 // psrld $0x10,%xmm2 + .byte 102,15,219,208 // pand %xmm0,%xmm2 + .byte 102,65,15,219,192 // pand %xmm8,%xmm0 + .byte 102,72,15,58,22,193,1 // pextrq $0x1,%xmm0,%rcx + .byte 65,137,201 // mov %ecx,%r9d + .byte 72,193,233,32 // shr $0x20,%rcx + .byte 102,73,15,126,194 // movq %xmm0,%r10 + .byte 69,137,211 // mov %r10d,%r11d + .byte 73,193,234,32 // shr $0x20,%r10 + .byte 243,67,15,16,4,152 // movss (%r8,%r11,4),%xmm0 + .byte 102,67,15,58,33,4,144,16 // insertps $0x10,(%r8,%r10,4),%xmm0 + .byte 102,67,15,58,33,4,136,32 // insertps $0x20,(%r8,%r9,4),%xmm0 + .byte 102,65,15,58,33,4,136,48 // insertps $0x30,(%r8,%rcx,4),%xmm0 + .byte 72,139,72,16 // mov 0x10(%rax),%rcx + .byte 102,73,15,58,22,200,1 // pextrq $0x1,%xmm1,%r8 + .byte 69,137,193 // mov %r8d,%r9d + .byte 73,193,232,32 // shr $0x20,%r8 + .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 243,66,15,16,12,153 // movss (%rcx,%r11,4),%xmm1 + .byte 102,66,15,58,33,12,145,16 // insertps $0x10,(%rcx,%r10,4),%xmm1 + .byte 243,66,15,16,28,137 // movss (%rcx,%r9,4),%xmm3 + .byte 102,15,58,33,203,32 // insertps $0x20,%xmm3,%xmm1 + .byte 243,66,15,16,28,129 // movss (%rcx,%r8,4),%xmm3 + .byte 102,15,58,33,203,48 // insertps $0x30,%xmm3,%xmm1 + .byte 72,139,64,24 // mov 0x18(%rax),%rax + .byte 102,72,15,58,22,209,1 // pextrq $0x1,%xmm2,%rcx + .byte 65,137,200 // mov %ecx,%r8d + .byte 72,193,233,32 // shr $0x20,%rcx + .byte 102,73,15,126,209 // movq %xmm2,%r9 + .byte 69,137,202 // mov %r9d,%r10d + .byte 73,193,233,32 // shr $0x20,%r9 + .byte 243,66,15,16,20,144 // movss (%rax,%r10,4),%xmm2 + .byte 102,66,15,58,33,20,136,16 // insertps $0x10,(%rax,%r9,4),%xmm2 + .byte 243,66,15,16,28,128 // movss (%rax,%r8,4),%xmm3 + .byte 102,15,58,33,211,32 // insertps $0x20,%xmm3,%xmm2 + .byte 243,15,16,28,136 // movss (%rax,%rcx,4),%xmm3 + .byte 102,15,58,33,211,48 // insertps $0x30,%xmm3,%xmm2 + .byte 102,65,15,114,208,24 // psrld $0x18,%xmm8 + .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 + .byte 243,15,16,90,12 // movss 0xc(%rdx),%xmm3 + .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 + .byte 65,15,89,216 // mulps %xmm8,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_load_8888_sse41 _sk_load_8888_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xf3,0x0f,0x6f,0x1c,0xb8 // movdqu (%rax,%rdi,4),%xmm3 - .byte 0x66,0x0f,0x6e,0x42,0x10 // movd 0x10(%rdx),%xmm0 - .byte 0x66,0x0f,0x70,0xc0,0x00 // pshufd $0x0,%xmm0,%xmm0 - .byte 0x66,0x0f,0x6f,0xcb // movdqa %xmm3,%xmm1 - .byte 0x66,0x0f,0x72,0xd1,0x08 // psrld $0x8,%xmm1 - .byte 0x66,0x0f,0xdb,0xc8 // pand %xmm0,%xmm1 - .byte 0x66,0x0f,0x6f,0xd3 // movdqa %xmm3,%xmm2 - .byte 0x66,0x0f,0x72,0xd2,0x10 // psrld $0x10,%xmm2 - .byte 0x66,0x0f,0xdb,0xd0 // pand %xmm0,%xmm2 - .byte 0x66,0x0f,0xdb,0xc3 // pand %xmm3,%xmm0 - .byte 0x0f,0x5b,0xc0 // cvtdq2ps %xmm0,%xmm0 - .byte 0xf3,0x44,0x0f,0x10,0x42,0x0c // movss 0xc(%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x0f,0x5b,0xc9 // cvtdq2ps %xmm1,%xmm1 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x0f,0x5b,0xd2 // cvtdq2ps %xmm2,%xmm2 - .byte 0x41,0x0f,0x59,0xd0 // mulps %xmm8,%xmm2 - .byte 0x66,0x0f,0x72,0xd3,0x18 // psrld $0x18,%xmm3 - .byte 0x0f,0x5b,0xdb // cvtdq2ps %xmm3,%xmm3 - .byte 0x41,0x0f,0x59,0xd8 // mulps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 243,15,111,28,184 // movdqu (%rax,%rdi,4),%xmm3 + .byte 102,15,110,66,16 // movd 0x10(%rdx),%xmm0 + .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 + .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 102,15,111,211 // movdqa %xmm3,%xmm2 + .byte 102,15,114,210,16 // psrld $0x10,%xmm2 + .byte 102,15,219,208 // pand %xmm0,%xmm2 + .byte 102,15,219,195 // pand %xmm3,%xmm0 + .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 + .byte 243,68,15,16,66,12 // movss 0xc(%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 65,15,89,192 // mulps %xmm8,%xmm0 + .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 + .byte 65,15,89,200 // mulps %xmm8,%xmm1 + .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 .globl _sk_store_8888_sse41 _sk_store_8888_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xf3,0x44,0x0f,0x10,0x42,0x08 // movss 0x8(%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xc8 // mulps %xmm0,%xmm9 - .byte 0x66,0x45,0x0f,0x5b,0xc9 // cvtps2dq %xmm9,%xmm9 - .byte 0x45,0x0f,0x28,0xd0 // movaps %xmm8,%xmm10 - .byte 0x44,0x0f,0x59,0xd1 // mulps %xmm1,%xmm10 - .byte 0x66,0x45,0x0f,0x5b,0xd2 // cvtps2dq %xmm10,%xmm10 - .byte 0x66,0x41,0x0f,0x72,0xf2,0x08 // pslld $0x8,%xmm10 - .byte 0x66,0x45,0x0f,0xeb,0xd1 // por %xmm9,%xmm10 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xca // mulps %xmm2,%xmm9 - .byte 0x66,0x45,0x0f,0x5b,0xc9 // cvtps2dq %xmm9,%xmm9 - .byte 0x66,0x41,0x0f,0x72,0xf1,0x10 // pslld $0x10,%xmm9 - .byte 0x44,0x0f,0x59,0xc3 // mulps %xmm3,%xmm8 - .byte 0x66,0x45,0x0f,0x5b,0xc0 // cvtps2dq %xmm8,%xmm8 - .byte 0x66,0x41,0x0f,0x72,0xf0,0x18 // pslld $0x18,%xmm8 - .byte 0x66,0x45,0x0f,0xeb,0xc1 // por %xmm9,%xmm8 - .byte 0x66,0x45,0x0f,0xeb,0xc2 // por %xmm10,%xmm8 - .byte 0xf3,0x44,0x0f,0x7f,0x04,0xb8 // movdqu %xmm8,(%rax,%rdi,4) - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 243,68,15,16,66,8 // movss 0x8(%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 69,15,40,200 // movaps %xmm8,%xmm9 + .byte 68,15,89,200 // mulps %xmm0,%xmm9 + .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 + .byte 69,15,40,208 // movaps %xmm8,%xmm10 + .byte 68,15,89,209 // mulps %xmm1,%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 69,15,40,200 // movaps %xmm8,%xmm9 + .byte 68,15,89,202 // mulps %xmm2,%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 243,68,15,127,4,184 // movdqu %xmm8,(%rax,%rdi,4) + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_load_f16_sse41 _sk_load_f16_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xf3,0x0f,0x6f,0x04,0xf8 // movdqu (%rax,%rdi,8),%xmm0 - .byte 0xf3,0x0f,0x6f,0x4c,0xf8,0x10 // movdqu 0x10(%rax,%rdi,8),%xmm1 - .byte 0x66,0x0f,0x6f,0xd0 // movdqa %xmm0,%xmm2 - .byte 0x66,0x0f,0x61,0xd1 // punpcklwd %xmm1,%xmm2 - .byte 0x66,0x0f,0x69,0xc1 // punpckhwd %xmm1,%xmm0 - .byte 0x66,0x44,0x0f,0x6f,0xc2 // movdqa %xmm2,%xmm8 - .byte 0x66,0x44,0x0f,0x61,0xc0 // punpcklwd %xmm0,%xmm8 - .byte 0x66,0x0f,0x69,0xd0 // punpckhwd %xmm0,%xmm2 - .byte 0x66,0x0f,0x6e,0x42,0x64 // movd 0x64(%rdx),%xmm0 - .byte 0x66,0x0f,0x70,0xd8,0x00 // pshufd $0x0,%xmm0,%xmm3 - .byte 0x66,0x0f,0x6f,0xcb // movdqa %xmm3,%xmm1 - .byte 0x66,0x41,0x0f,0x65,0xc8 // pcmpgtw %xmm8,%xmm1 - .byte 0x66,0x41,0x0f,0xdf,0xc8 // pandn %xmm8,%xmm1 - .byte 0x66,0x0f,0x65,0xda // pcmpgtw %xmm2,%xmm3 - .byte 0x66,0x0f,0xdf,0xda // pandn %xmm2,%xmm3 - .byte 0x66,0x0f,0x38,0x33,0xc1 // pmovzxwd %xmm1,%xmm0 - .byte 0x66,0x0f,0x72,0xf0,0x0d // pslld $0xd,%xmm0 - .byte 0x66,0x0f,0x6e,0x52,0x5c // movd 0x5c(%rdx),%xmm2 - .byte 0x66,0x44,0x0f,0x70,0xc2,0x00 // pshufd $0x0,%xmm2,%xmm8 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x66,0x45,0x0f,0xef,0xc9 // pxor %xmm9,%xmm9 - .byte 0x66,0x41,0x0f,0x69,0xc9 // punpckhwd %xmm9,%xmm1 - .byte 0x66,0x0f,0x72,0xf1,0x0d // pslld $0xd,%xmm1 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x66,0x0f,0x38,0x33,0xd3 // pmovzxwd %xmm3,%xmm2 - .byte 0x66,0x0f,0x72,0xf2,0x0d // pslld $0xd,%xmm2 - .byte 0x41,0x0f,0x59,0xd0 // mulps %xmm8,%xmm2 - .byte 0x66,0x41,0x0f,0x69,0xd9 // punpckhwd %xmm9,%xmm3 - .byte 0x66,0x0f,0x72,0xf3,0x0d // pslld $0xd,%xmm3 - .byte 0x41,0x0f,0x59,0xd8 // mulps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 243,15,111,4,248 // movdqu (%rax,%rdi,8),%xmm0 + .byte 243,15,111,76,248,16 // movdqu 0x10(%rax,%rdi,8),%xmm1 + .byte 102,15,111,208 // movdqa %xmm0,%xmm2 + .byte 102,15,97,209 // punpcklwd %xmm1,%xmm2 + .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 + .byte 102,68,15,111,194 // movdqa %xmm2,%xmm8 + .byte 102,68,15,97,192 // punpcklwd %xmm0,%xmm8 + .byte 102,15,105,208 // punpckhwd %xmm0,%xmm2 + .byte 102,15,110,66,100 // movd 0x64(%rdx),%xmm0 + .byte 102,15,112,216,0 // pshufd $0x0,%xmm0,%xmm3 + .byte 102,15,111,203 // movdqa %xmm3,%xmm1 + .byte 102,65,15,101,200 // pcmpgtw %xmm8,%xmm1 + .byte 102,65,15,223,200 // pandn %xmm8,%xmm1 + .byte 102,15,101,218 // pcmpgtw %xmm2,%xmm3 + .byte 102,15,223,218 // pandn %xmm2,%xmm3 + .byte 102,15,56,51,193 // pmovzxwd %xmm1,%xmm0 + .byte 102,15,114,240,13 // pslld $0xd,%xmm0 + .byte 102,15,110,82,92 // movd 0x5c(%rdx),%xmm2 + .byte 102,68,15,112,194,0 // pshufd $0x0,%xmm2,%xmm8 + .byte 65,15,89,192 // mulps %xmm8,%xmm0 + .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 + .byte 102,65,15,105,201 // punpckhwd %xmm9,%xmm1 + .byte 102,15,114,241,13 // pslld $0xd,%xmm1 + .byte 65,15,89,200 // mulps %xmm8,%xmm1 + .byte 102,15,56,51,211 // pmovzxwd %xmm3,%xmm2 + .byte 102,15,114,242,13 // pslld $0xd,%xmm2 + .byte 65,15,89,208 // mulps %xmm8,%xmm2 + .byte 102,65,15,105,217 // punpckhwd %xmm9,%xmm3 + .byte 102,15,114,243,13 // pslld $0xd,%xmm3 + .byte 65,15,89,216 // mulps %xmm8,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_store_f16_sse41 _sk_store_f16_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0x66,0x44,0x0f,0x6e,0x42,0x60 // movd 0x60(%rdx),%xmm8 - .byte 0x66,0x45,0x0f,0x70,0xc0,0x00 // pshufd $0x0,%xmm8,%xmm8 - .byte 0x66,0x45,0x0f,0x6f,0xc8 // movdqa %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xc8 // mulps %xmm0,%xmm9 - .byte 0x66,0x41,0x0f,0x72,0xd1,0x0d // psrld $0xd,%xmm9 - .byte 0x66,0x45,0x0f,0x6f,0xd0 // movdqa %xmm8,%xmm10 - .byte 0x44,0x0f,0x59,0xd1 // mulps %xmm1,%xmm10 - .byte 0x66,0x41,0x0f,0x72,0xd2,0x0d // psrld $0xd,%xmm10 - .byte 0x66,0x45,0x0f,0x6f,0xd8 // movdqa %xmm8,%xmm11 - .byte 0x44,0x0f,0x59,0xda // mulps %xmm2,%xmm11 - .byte 0x66,0x41,0x0f,0x72,0xd3,0x0d // psrld $0xd,%xmm11 - .byte 0x44,0x0f,0x59,0xc3 // mulps %xmm3,%xmm8 - .byte 0x66,0x41,0x0f,0x72,0xd0,0x0d // psrld $0xd,%xmm8 - .byte 0x66,0x41,0x0f,0x73,0xfa,0x02 // pslldq $0x2,%xmm10 - .byte 0x66,0x45,0x0f,0xeb,0xd1 // por %xmm9,%xmm10 - .byte 0x66,0x41,0x0f,0x73,0xf8,0x02 // pslldq $0x2,%xmm8 - .byte 0x66,0x45,0x0f,0xeb,0xc3 // por %xmm11,%xmm8 - .byte 0x66,0x45,0x0f,0x6f,0xca // movdqa %xmm10,%xmm9 - .byte 0x66,0x45,0x0f,0x62,0xc8 // punpckldq %xmm8,%xmm9 - .byte 0xf3,0x44,0x0f,0x7f,0x0c,0xf8 // movdqu %xmm9,(%rax,%rdi,8) - .byte 0x66,0x45,0x0f,0x6a,0xd0 // punpckhdq %xmm8,%xmm10 - .byte 0xf3,0x44,0x0f,0x7f,0x54,0xf8,0x10 // movdqu %xmm10,0x10(%rax,%rdi,8) - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 102,68,15,110,66,96 // movd 0x60(%rdx),%xmm8 + .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 + .byte 102,69,15,111,200 // movdqa %xmm8,%xmm9 + .byte 68,15,89,200 // mulps %xmm0,%xmm9 + .byte 102,65,15,114,209,13 // psrld $0xd,%xmm9 + .byte 102,69,15,111,208 // movdqa %xmm8,%xmm10 + .byte 68,15,89,209 // mulps %xmm1,%xmm10 + .byte 102,65,15,114,210,13 // psrld $0xd,%xmm10 + .byte 102,69,15,111,216 // movdqa %xmm8,%xmm11 + .byte 68,15,89,218 // mulps %xmm2,%xmm11 + .byte 102,65,15,114,211,13 // psrld $0xd,%xmm11 + .byte 68,15,89,195 // mulps %xmm3,%xmm8 + .byte 102,65,15,114,208,13 // psrld $0xd,%xmm8 + .byte 102,65,15,115,250,2 // pslldq $0x2,%xmm10 + .byte 102,69,15,235,209 // por %xmm9,%xmm10 + .byte 102,65,15,115,248,2 // pslldq $0x2,%xmm8 + .byte 102,69,15,235,195 // por %xmm11,%xmm8 + .byte 102,69,15,111,202 // movdqa %xmm10,%xmm9 + .byte 102,69,15,98,200 // punpckldq %xmm8,%xmm9 + .byte 243,68,15,127,12,248 // movdqu %xmm9,(%rax,%rdi,8) + .byte 102,69,15,106,208 // punpckhdq %xmm8,%xmm10 + .byte 243,68,15,127,84,248,16 // movdqu %xmm10,0x10(%rax,%rdi,8) + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_clamp_x_sse41 _sk_clamp_x_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x00 // movss (%rax),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x66,0x45,0x0f,0x76,0xc9 // pcmpeqd %xmm9,%xmm9 - .byte 0x66,0x45,0x0f,0xfe,0xc8 // paddd %xmm8,%xmm9 - .byte 0x41,0x0f,0x5d,0xc1 // minps %xmm9,%xmm0 - .byte 0x45,0x0f,0x57,0xc0 // xorps %xmm8,%xmm8 - .byte 0x44,0x0f,0x5f,0xc0 // maxps %xmm0,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xc0 // movaps %xmm8,%xmm0 - .byte 0xff,0xe0 // jmpq *%rax + .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 102,69,15,118,201 // pcmpeqd %xmm9,%xmm9 + .byte 102,69,15,254,200 // paddd %xmm8,%xmm9 + .byte 65,15,93,193 // minps %xmm9,%xmm0 + .byte 69,15,87,192 // xorps %xmm8,%xmm8 + .byte 68,15,95,192 // maxps %xmm0,%xmm8 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 65,15,40,192 // movaps %xmm8,%xmm0 + .byte 255,224 // jmpq *%rax .globl _sk_clamp_y_sse41 _sk_clamp_y_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x00 // movss (%rax),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x66,0x45,0x0f,0x76,0xc9 // pcmpeqd %xmm9,%xmm9 - .byte 0x66,0x45,0x0f,0xfe,0xc8 // paddd %xmm8,%xmm9 - .byte 0x41,0x0f,0x5d,0xc9 // minps %xmm9,%xmm1 - .byte 0x45,0x0f,0x57,0xc0 // xorps %xmm8,%xmm8 - .byte 0x44,0x0f,0x5f,0xc1 // maxps %xmm1,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xc8 // movaps %xmm8,%xmm1 - .byte 0xff,0xe0 // jmpq *%rax + .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 102,69,15,118,201 // pcmpeqd %xmm9,%xmm9 + .byte 102,69,15,254,200 // paddd %xmm8,%xmm9 + .byte 65,15,93,201 // minps %xmm9,%xmm1 + .byte 69,15,87,192 // xorps %xmm8,%xmm8 + .byte 68,15,95,193 // maxps %xmm1,%xmm8 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 65,15,40,200 // movaps %xmm8,%xmm1 + .byte 255,224 // jmpq *%rax .globl _sk_matrix_2x3_sse41 _sk_matrix_2x3_sse41: - .byte 0x44,0x0f,0x28,0xc9 // movaps %xmm1,%xmm9 - .byte 0x44,0x0f,0x28,0xc0 // movaps %xmm0,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x0f,0x10,0x00 // movss (%rax),%xmm0 - .byte 0xf3,0x0f,0x10,0x48,0x04 // movss 0x4(%rax),%xmm1 - .byte 0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm0,%xmm0 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x08 // movss 0x8(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x10 // movss 0x10(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0x45,0x0f,0x59,0xd1 // mulps %xmm9,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x41,0x0f,0x58,0xc2 // addps %xmm10,%xmm0 - .byte 0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm1,%xmm1 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x0c // movss 0xc(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x14 // movss 0x14(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0x45,0x0f,0x59,0xd1 // mulps %xmm9,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x41,0x0f,0x58,0xca // addps %xmm10,%xmm1 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_matrix_3x4_sse41 _sk_matrix_3x4_sse41: - .byte 0x44,0x0f,0x28,0xc9 // movaps %xmm1,%xmm9 - .byte 0x44,0x0f,0x28,0xc0 // movaps %xmm0,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x0f,0x10,0x00 // movss (%rax),%xmm0 - .byte 0xf3,0x0f,0x10,0x48,0x04 // movss 0x4(%rax),%xmm1 - .byte 0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm0,%xmm0 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x0c // movss 0xc(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x18 // movss 0x18(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0xf3,0x44,0x0f,0x10,0x60,0x24 // movss 0x24(%rax),%xmm12 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0x44,0x0f,0x59,0xda // mulps %xmm2,%xmm11 - .byte 0x45,0x0f,0x58,0xdc // addps %xmm12,%xmm11 - .byte 0x45,0x0f,0x59,0xd1 // mulps %xmm9,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x41,0x0f,0x58,0xc2 // addps %xmm10,%xmm0 - .byte 0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm1,%xmm1 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x10 // movss 0x10(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x1c // movss 0x1c(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0xf3,0x44,0x0f,0x10,0x60,0x28 // movss 0x28(%rax),%xmm12 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0x44,0x0f,0x59,0xda // mulps %xmm2,%xmm11 - .byte 0x45,0x0f,0x58,0xdc // addps %xmm12,%xmm11 - .byte 0x45,0x0f,0x59,0xd1 // mulps %xmm9,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x41,0x0f,0x58,0xca // addps %xmm10,%xmm1 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x08 // movss 0x8(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x14 // movss 0x14(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0xf3,0x44,0x0f,0x10,0x60,0x20 // movss 0x20(%rax),%xmm12 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0xf3,0x44,0x0f,0x10,0x68,0x2c // movss 0x2c(%rax),%xmm13 - .byte 0x45,0x0f,0xc6,0xed,0x00 // shufps $0x0,%xmm13,%xmm13 - .byte 0x44,0x0f,0x59,0xe2 // mulps %xmm2,%xmm12 - .byte 0x45,0x0f,0x58,0xe5 // addps %xmm13,%xmm12 - .byte 0x45,0x0f,0x59,0xd9 // mulps %xmm9,%xmm11 - .byte 0x45,0x0f,0x58,0xdc // addps %xmm12,%xmm11 - .byte 0x45,0x0f,0x59,0xd0 // mulps %xmm8,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xd2 // movaps %xmm10,%xmm2 - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_linear_gradient_2stops_sse41 _sk_linear_gradient_2stops_sse41: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x44,0x0f,0x10,0x08 // movups (%rax),%xmm9 - .byte 0x0f,0x10,0x58,0x10 // movups 0x10(%rax),%xmm3 - .byte 0x44,0x0f,0x28,0xc3 // movaps %xmm3,%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x41,0x0f,0x28,0xc9 // movaps %xmm9,%xmm1 - .byte 0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm1,%xmm1 - .byte 0x44,0x0f,0x59,0xc0 // mulps %xmm0,%xmm8 - .byte 0x44,0x0f,0x58,0xc1 // addps %xmm1,%xmm8 - .byte 0x0f,0x28,0xcb // movaps %xmm3,%xmm1 - .byte 0x0f,0xc6,0xc9,0x55 // shufps $0x55,%xmm1,%xmm1 - .byte 0x41,0x0f,0x28,0xd1 // movaps %xmm9,%xmm2 - .byte 0x0f,0xc6,0xd2,0x55 // shufps $0x55,%xmm2,%xmm2 - .byte 0x0f,0x59,0xc8 // mulps %xmm0,%xmm1 - .byte 0x0f,0x58,0xca // addps %xmm2,%xmm1 - .byte 0x0f,0x28,0xd3 // movaps %xmm3,%xmm2 - .byte 0x0f,0xc6,0xd2,0xaa // shufps $0xaa,%xmm2,%xmm2 - .byte 0x45,0x0f,0x28,0xd1 // movaps %xmm9,%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0xaa // shufps $0xaa,%xmm10,%xmm10 - .byte 0x0f,0x59,0xd0 // mulps %xmm0,%xmm2 - .byte 0x41,0x0f,0x58,0xd2 // addps %xmm10,%xmm2 - .byte 0x0f,0xc6,0xdb,0xff // shufps $0xff,%xmm3,%xmm3 - .byte 0x45,0x0f,0xc6,0xc9,0xff // shufps $0xff,%xmm9,%xmm9 - .byte 0x0f,0x59,0xd8 // mulps %xmm0,%xmm3 - .byte 0x41,0x0f,0x58,0xd9 // addps %xmm9,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xc0 // movaps %xmm8,%xmm0 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 68,15,16,8 // movups (%rax),%xmm9 + .byte 15,16,88,16 // movups 0x10(%rax),%xmm3 + .byte 68,15,40,195 // movaps %xmm3,%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 65,15,40,201 // movaps %xmm9,%xmm1 + .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 + .byte 68,15,89,192 // mulps %xmm0,%xmm8 + .byte 68,15,88,193 // addps %xmm1,%xmm8 + .byte 15,40,203 // movaps %xmm3,%xmm1 + .byte 15,198,201,85 // shufps $0x55,%xmm1,%xmm1 + .byte 65,15,40,209 // movaps %xmm9,%xmm2 + .byte 15,198,210,85 // shufps $0x55,%xmm2,%xmm2 + .byte 15,89,200 // mulps %xmm0,%xmm1 + .byte 15,88,202 // addps %xmm2,%xmm1 + .byte 15,40,211 // movaps %xmm3,%xmm2 + .byte 15,198,210,170 // shufps $0xaa,%xmm2,%xmm2 + .byte 69,15,40,209 // movaps %xmm9,%xmm10 + .byte 69,15,198,210,170 // shufps $0xaa,%xmm10,%xmm10 + .byte 15,89,208 // mulps %xmm0,%xmm2 + .byte 65,15,88,210 // addps %xmm10,%xmm2 + .byte 15,198,219,255 // shufps $0xff,%xmm3,%xmm3 + .byte 69,15,198,201,255 // shufps $0xff,%xmm9,%xmm9 + .byte 15,89,216 // mulps %xmm0,%xmm3 + .byte 65,15,88,217 // addps %xmm9,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 65,15,40,192 // movaps %xmm8,%xmm0 + .byte 255,224 // jmpq *%rax .globl _sk_start_pipeline_sse2 _sk_start_pipeline_sse2: - .byte 0x41,0x57 // push %r15 - .byte 0x41,0x56 // push %r14 - .byte 0x41,0x55 // push %r13 - .byte 0x41,0x54 // push %r12 - .byte 0x53 // push %rbx - .byte 0x49,0x89,0xcf // mov %rcx,%r15 - .byte 0x49,0x89,0xd6 // mov %rdx,%r14 - .byte 0x48,0x89,0xfb // mov %rdi,%rbx - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x49,0x89,0xc4 // mov %rax,%r12 - .byte 0x49,0x89,0xf5 // mov %rsi,%r13 - .byte 0x48,0x8d,0x43,0x04 // lea 0x4(%rbx),%rax - .byte 0x4c,0x39,0xf8 // cmp %r15,%rax - .byte 0x76,0x05 // jbe 28 <_sk_start_pipeline_sse2+0x28> - .byte 0x48,0x89,0xd8 // mov %rbx,%rax - .byte 0xeb,0x34 // jmp 5c <_sk_start_pipeline_sse2+0x5c> - .byte 0x0f,0x57,0xc0 // xorps %xmm0,%xmm0 - .byte 0x0f,0x57,0xc9 // xorps %xmm1,%xmm1 - .byte 0x0f,0x57,0xd2 // xorps %xmm2,%xmm2 - .byte 0x0f,0x57,0xdb // xorps %xmm3,%xmm3 - .byte 0x0f,0x57,0xe4 // xorps %xmm4,%xmm4 - .byte 0x0f,0x57,0xed // xorps %xmm5,%xmm5 - .byte 0x0f,0x57,0xf6 // xorps %xmm6,%xmm6 - .byte 0x0f,0x57,0xff // xorps %xmm7,%xmm7 - .byte 0x48,0x89,0xdf // mov %rbx,%rdi - .byte 0x4c,0x89,0xee // mov %r13,%rsi - .byte 0x4c,0x89,0xf2 // mov %r14,%rdx - .byte 0x41,0xff,0xd4 // callq *%r12 - .byte 0x48,0x8d,0x43,0x04 // lea 0x4(%rbx),%rax - .byte 0x48,0x83,0xc3,0x08 // add $0x8,%rbx - .byte 0x4c,0x39,0xfb // cmp %r15,%rbx - .byte 0x48,0x89,0xc3 // mov %rax,%rbx - .byte 0x76,0xcc // jbe 28 <_sk_start_pipeline_sse2+0x28> - .byte 0x5b // pop %rbx - .byte 0x41,0x5c // pop %r12 - .byte 0x41,0x5d // pop %r13 - .byte 0x41,0x5e // pop %r14 - .byte 0x41,0x5f // pop %r15 - .byte 0xc3 // retq + .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 73,137,207 // mov %rcx,%r15 + .byte 73,137,214 // mov %rdx,%r14 + .byte 72,137,251 // mov %rdi,%rbx + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 73,137,196 // mov %rax,%r12 + .byte 73,137,245 // mov %rsi,%r13 + .byte 72,141,67,4 // lea 0x4(%rbx),%rax + .byte 76,57,248 // cmp %r15,%rax + .byte 118,5 // jbe 28 <_sk_start_pipeline_sse2+0x28> + .byte 72,137,216 // mov %rbx,%rax + .byte 235,52 // jmp 5c <_sk_start_pipeline_sse2+0x5c> + .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 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 72,137,223 // mov %rbx,%rdi + .byte 76,137,238 // mov %r13,%rsi + .byte 76,137,242 // mov %r14,%rdx + .byte 65,255,212 // callq *%r12 + .byte 72,141,67,4 // lea 0x4(%rbx),%rax + .byte 72,131,195,8 // add $0x8,%rbx + .byte 76,57,251 // cmp %r15,%rbx + .byte 72,137,195 // mov %rax,%rbx + .byte 118,204 // jbe 28 <_sk_start_pipeline_sse2+0x28> + .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 195 // retq .globl _sk_just_return_sse2 _sk_just_return_sse2: - .byte 0xc3 // retq + .byte 195 // retq .globl _sk_seed_shader_sse2 _sk_seed_shader_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x66,0x0f,0x6e,0xc7 // movd %edi,%xmm0 - .byte 0x66,0x0f,0x70,0xc0,0x00 // pshufd $0x0,%xmm0,%xmm0 - .byte 0x0f,0x5b,0xc8 // cvtdq2ps %xmm0,%xmm1 - .byte 0xf3,0x0f,0x10,0x12 // movss (%rdx),%xmm2 - .byte 0xf3,0x0f,0x10,0x5a,0x04 // movss 0x4(%rdx),%xmm3 - .byte 0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm3,%xmm3 - .byte 0x0f,0x58,0xcb // addps %xmm3,%xmm1 - .byte 0x0f,0x10,0x42,0x14 // movups 0x14(%rdx),%xmm0 - .byte 0x0f,0x58,0xc1 // addps %xmm1,%xmm0 - .byte 0x66,0x0f,0x6e,0x08 // movd (%rax),%xmm1 - .byte 0x66,0x0f,0x70,0xc9,0x00 // pshufd $0x0,%xmm1,%xmm1 - .byte 0x0f,0x5b,0xc9 // cvtdq2ps %xmm1,%xmm1 - .byte 0x0f,0x58,0xcb // addps %xmm3,%xmm1 - .byte 0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm2,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x57,0xdb // xorps %xmm3,%xmm3 - .byte 0x0f,0x57,0xe4 // xorps %xmm4,%xmm4 - .byte 0x0f,0x57,0xed // xorps %xmm5,%xmm5 - .byte 0x0f,0x57,0xf6 // xorps %xmm6,%xmm6 - .byte 0x0f,0x57,0xff // xorps %xmm7,%xmm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 102,15,110,199 // movd %edi,%xmm0 + .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 + .byte 15,91,200 // cvtdq2ps %xmm0,%xmm1 + .byte 243,15,16,18 // movss (%rdx),%xmm2 + .byte 243,15,16,90,4 // movss 0x4(%rdx),%xmm3 + .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 + .byte 15,88,203 // addps %xmm3,%xmm1 + .byte 15,16,66,20 // movups 0x14(%rdx),%xmm0 + .byte 15,88,193 // addps %xmm1,%xmm0 + .byte 102,15,110,8 // movd (%rax),%xmm1 + .byte 102,15,112,201,0 // pshufd $0x0,%xmm1,%xmm1 + .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 + .byte 15,88,203 // addps %xmm3,%xmm1 + .byte 15,198,210,0 // shufps $0x0,%xmm2,%xmm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_constant_color_sse2 _sk_constant_color_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x10,0x18 // movups (%rax),%xmm3 - .byte 0x0f,0x28,0xc3 // movaps %xmm3,%xmm0 - .byte 0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm0,%xmm0 - .byte 0x0f,0x28,0xcb // movaps %xmm3,%xmm1 - .byte 0x0f,0xc6,0xc9,0x55 // shufps $0x55,%xmm1,%xmm1 - .byte 0x0f,0x28,0xd3 // movaps %xmm3,%xmm2 - .byte 0x0f,0xc6,0xd2,0xaa // shufps $0xaa,%xmm2,%xmm2 - .byte 0x0f,0xc6,0xdb,0xff // shufps $0xff,%xmm3,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 15,16,24 // movups (%rax),%xmm3 + .byte 15,40,195 // movaps %xmm3,%xmm0 + .byte 15,198,192,0 // shufps $0x0,%xmm0,%xmm0 + .byte 15,40,203 // movaps %xmm3,%xmm1 + .byte 15,198,201,85 // shufps $0x55,%xmm1,%xmm1 + .byte 15,40,211 // movaps %xmm3,%xmm2 + .byte 15,198,210,170 // shufps $0xaa,%xmm2,%xmm2 + .byte 15,198,219,255 // shufps $0xff,%xmm3,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_clear_sse2 _sk_clear_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x57,0xc0 // xorps %xmm0,%xmm0 - .byte 0x0f,0x57,0xc9 // xorps %xmm1,%xmm1 - .byte 0x0f,0x57,0xd2 // xorps %xmm2,%xmm2 - .byte 0x0f,0x57,0xdb // xorps %xmm3,%xmm3 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_plus__sse2 _sk_plus__sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x58,0xc4 // addps %xmm4,%xmm0 - .byte 0x0f,0x58,0xcd // addps %xmm5,%xmm1 - .byte 0x0f,0x58,0xd6 // addps %xmm6,%xmm2 - .byte 0x0f,0x58,0xdf // addps %xmm7,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_srcover_sse2 _sk_srcover_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x02 // movss (%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x44,0x0f,0x5c,0xc3 // subps %xmm3,%xmm8 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xcc // mulps %xmm4,%xmm9 - .byte 0x41,0x0f,0x58,0xc1 // addps %xmm9,%xmm0 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xcd // mulps %xmm5,%xmm9 - .byte 0x41,0x0f,0x58,0xc9 // addps %xmm9,%xmm1 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xce // mulps %xmm6,%xmm9 - .byte 0x41,0x0f,0x58,0xd1 // addps %xmm9,%xmm2 - .byte 0x44,0x0f,0x59,0xc7 // mulps %xmm7,%xmm8 - .byte 0x41,0x0f,0x58,0xd8 // addps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,2 // movss (%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .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 .globl _sk_dstover_sse2 _sk_dstover_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x02 // movss (%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x44,0x0f,0x5c,0xc7 // subps %xmm7,%xmm8 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x0f,0x58,0xc4 // addps %xmm4,%xmm0 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x0f,0x58,0xcd // addps %xmm5,%xmm1 - .byte 0x41,0x0f,0x59,0xd0 // mulps %xmm8,%xmm2 - .byte 0x0f,0x58,0xd6 // addps %xmm6,%xmm2 - .byte 0x41,0x0f,0x59,0xd8 // mulps %xmm8,%xmm3 - .byte 0x0f,0x58,0xdf // addps %xmm7,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,2 // movss (%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .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 .globl _sk_clamp_0_sse2 _sk_clamp_0_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x45,0x0f,0x57,0xc0 // xorps %xmm8,%xmm8 - .byte 0x41,0x0f,0x5f,0xc0 // maxps %xmm8,%xmm0 - .byte 0x41,0x0f,0x5f,0xc8 // maxps %xmm8,%xmm1 - .byte 0x41,0x0f,0x5f,0xd0 // maxps %xmm8,%xmm2 - .byte 0x41,0x0f,0x5f,0xd8 // maxps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_clamp_1_sse2 _sk_clamp_1_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x02 // movss (%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x41,0x0f,0x5d,0xc0 // minps %xmm8,%xmm0 - .byte 0x41,0x0f,0x5d,0xc8 // minps %xmm8,%xmm1 - .byte 0x41,0x0f,0x5d,0xd0 // minps %xmm8,%xmm2 - .byte 0x41,0x0f,0x5d,0xd8 // minps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,2 // movss (%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .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 .globl _sk_clamp_a_sse2 _sk_clamp_a_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x02 // movss (%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x41,0x0f,0x5d,0xd8 // minps %xmm8,%xmm3 - .byte 0x0f,0x5d,0xc3 // minps %xmm3,%xmm0 - .byte 0x0f,0x5d,0xcb // minps %xmm3,%xmm1 - .byte 0x0f,0x5d,0xd3 // minps %xmm3,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,2 // movss (%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 65,15,93,216 // minps %xmm8,%xmm3 + .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 .globl _sk_set_rgb_sse2 _sk_set_rgb_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x0f,0x10,0x00 // movss (%rax),%xmm0 - .byte 0xf3,0x0f,0x10,0x48,0x04 // movss 0x4(%rax),%xmm1 - .byte 0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm0,%xmm0 - .byte 0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm1,%xmm1 - .byte 0xf3,0x0f,0x10,0x50,0x08 // movss 0x8(%rax),%xmm2 - .byte 0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm2,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_swap_rb_sse2 _sk_swap_rb_sse2: - .byte 0x44,0x0f,0x28,0xc0 // movaps %xmm0,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x28,0xc2 // movaps %xmm2,%xmm0 - .byte 0x41,0x0f,0x28,0xd0 // movaps %xmm8,%xmm2 - .byte 0xff,0xe0 // jmpq *%rax + .byte 68,15,40,192 // movaps %xmm0,%xmm8 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_swap_sse2 _sk_swap_sse2: - .byte 0x44,0x0f,0x28,0xc3 // movaps %xmm3,%xmm8 - .byte 0x44,0x0f,0x28,0xca // movaps %xmm2,%xmm9 - .byte 0x44,0x0f,0x28,0xd1 // movaps %xmm1,%xmm10 - .byte 0x44,0x0f,0x28,0xd8 // movaps %xmm0,%xmm11 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x28,0xc4 // movaps %xmm4,%xmm0 - .byte 0x0f,0x28,0xcd // movaps %xmm5,%xmm1 - .byte 0x0f,0x28,0xd6 // movaps %xmm6,%xmm2 - .byte 0x0f,0x28,0xdf // movaps %xmm7,%xmm3 - .byte 0x41,0x0f,0x28,0xe3 // movaps %xmm11,%xmm4 - .byte 0x41,0x0f,0x28,0xea // movaps %xmm10,%xmm5 - .byte 0x41,0x0f,0x28,0xf1 // movaps %xmm9,%xmm6 - .byte 0x41,0x0f,0x28,0xf8 // movaps %xmm8,%xmm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 68,15,40,195 // movaps %xmm3,%xmm8 + .byte 68,15,40,202 // movaps %xmm2,%xmm9 + .byte 68,15,40,209 // movaps %xmm1,%xmm10 + .byte 68,15,40,216 // movaps %xmm0,%xmm11 + .byte 72,173 // lods %ds:(%rsi),%rax + .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 65,15,40,227 // movaps %xmm11,%xmm4 + .byte 65,15,40,234 // movaps %xmm10,%xmm5 + .byte 65,15,40,241 // movaps %xmm9,%xmm6 + .byte 65,15,40,248 // movaps %xmm8,%xmm7 + .byte 255,224 // jmpq *%rax .globl _sk_move_src_dst_sse2 _sk_move_src_dst_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x28,0xe0 // movaps %xmm0,%xmm4 - .byte 0x0f,0x28,0xe9 // movaps %xmm1,%xmm5 - .byte 0x0f,0x28,0xf2 // movaps %xmm2,%xmm6 - .byte 0x0f,0x28,0xfb // movaps %xmm3,%xmm7 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_move_dst_src_sse2 _sk_move_dst_src_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x28,0xc4 // movaps %xmm4,%xmm0 - .byte 0x0f,0x28,0xcd // movaps %xmm5,%xmm1 - .byte 0x0f,0x28,0xd6 // movaps %xmm6,%xmm2 - .byte 0x0f,0x28,0xdf // movaps %xmm7,%xmm3 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_premul_sse2 _sk_premul_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x59,0xc3 // mulps %xmm3,%xmm0 - .byte 0x0f,0x59,0xcb // mulps %xmm3,%xmm1 - .byte 0x0f,0x59,0xd3 // mulps %xmm3,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .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 .globl _sk_unpremul_sse2 _sk_unpremul_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x45,0x0f,0x57,0xc0 // xorps %xmm8,%xmm8 - .byte 0x44,0x0f,0xc2,0xc3,0x00 // cmpeqps %xmm3,%xmm8 - .byte 0xf3,0x44,0x0f,0x10,0x0a // movss (%rdx),%xmm9 - .byte 0x45,0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm9,%xmm9 - .byte 0x44,0x0f,0x5e,0xcb // divps %xmm3,%xmm9 - .byte 0x45,0x0f,0x55,0xc1 // andnps %xmm9,%xmm8 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x41,0x0f,0x59,0xd0 // mulps %xmm8,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 69,15,87,192 // xorps %xmm8,%xmm8 + .byte 68,15,194,195,0 // cmpeqps %xmm3,%xmm8 + .byte 243,68,15,16,10 // movss (%rdx),%xmm9 + .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 + .byte 68,15,94,203 // divps %xmm3,%xmm9 + .byte 69,15,85,193 // andnps %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 .globl _sk_from_srgb_sse2 _sk_from_srgb_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x42,0x40 // movss 0x40(%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x45,0x0f,0x28,0xe8 // movaps %xmm8,%xmm13 - .byte 0x44,0x0f,0x59,0xe8 // mulps %xmm0,%xmm13 - .byte 0x44,0x0f,0x28,0xe0 // movaps %xmm0,%xmm12 - .byte 0x45,0x0f,0x59,0xe4 // mulps %xmm12,%xmm12 - .byte 0xf3,0x44,0x0f,0x10,0x4a,0x3c // movss 0x3c(%rdx),%xmm9 - .byte 0x45,0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm9,%xmm9 - .byte 0xf3,0x44,0x0f,0x10,0x52,0x34 // movss 0x34(%rdx),%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x5a,0x38 // movss 0x38(%rdx),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0x45,0x0f,0x28,0xf1 // movaps %xmm9,%xmm14 - .byte 0x44,0x0f,0x59,0xf0 // mulps %xmm0,%xmm14 - .byte 0x45,0x0f,0x58,0xf3 // addps %xmm11,%xmm14 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0x45,0x0f,0x59,0xf4 // mulps %xmm12,%xmm14 - .byte 0x45,0x0f,0x58,0xf2 // addps %xmm10,%xmm14 - .byte 0xf3,0x44,0x0f,0x10,0x62,0x44 // movss 0x44(%rdx),%xmm12 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0x41,0x0f,0xc2,0xc4,0x01 // cmpltps %xmm12,%xmm0 - .byte 0x44,0x0f,0x54,0xe8 // andps %xmm0,%xmm13 - .byte 0x41,0x0f,0x55,0xc6 // andnps %xmm14,%xmm0 - .byte 0x41,0x0f,0x56,0xc5 // orps %xmm13,%xmm0 - .byte 0x45,0x0f,0x28,0xe8 // movaps %xmm8,%xmm13 - .byte 0x44,0x0f,0x59,0xe9 // mulps %xmm1,%xmm13 - .byte 0x44,0x0f,0x28,0xf1 // movaps %xmm1,%xmm14 - .byte 0x45,0x0f,0x59,0xf6 // mulps %xmm14,%xmm14 - .byte 0x45,0x0f,0x28,0xf9 // movaps %xmm9,%xmm15 - .byte 0x44,0x0f,0x59,0xf9 // mulps %xmm1,%xmm15 - .byte 0x45,0x0f,0x58,0xfb // addps %xmm11,%xmm15 - .byte 0x45,0x0f,0x59,0xfe // mulps %xmm14,%xmm15 - .byte 0x45,0x0f,0x58,0xfa // addps %xmm10,%xmm15 - .byte 0x41,0x0f,0xc2,0xcc,0x01 // cmpltps %xmm12,%xmm1 - .byte 0x44,0x0f,0x54,0xe9 // andps %xmm1,%xmm13 - .byte 0x41,0x0f,0x55,0xcf // andnps %xmm15,%xmm1 - .byte 0x41,0x0f,0x56,0xcd // orps %xmm13,%xmm1 - .byte 0x44,0x0f,0x59,0xc2 // mulps %xmm2,%xmm8 - .byte 0x44,0x0f,0x28,0xea // movaps %xmm2,%xmm13 - .byte 0x45,0x0f,0x59,0xed // mulps %xmm13,%xmm13 - .byte 0x44,0x0f,0x59,0xca // mulps %xmm2,%xmm9 - .byte 0x45,0x0f,0x58,0xcb // addps %xmm11,%xmm9 - .byte 0x45,0x0f,0x59,0xcd // mulps %xmm13,%xmm9 - .byte 0x45,0x0f,0x58,0xca // addps %xmm10,%xmm9 - .byte 0x41,0x0f,0xc2,0xd4,0x01 // cmpltps %xmm12,%xmm2 - .byte 0x44,0x0f,0x54,0xc2 // andps %xmm2,%xmm8 - .byte 0x41,0x0f,0x55,0xd1 // andnps %xmm9,%xmm2 - .byte 0x41,0x0f,0x56,0xd0 // orps %xmm8,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 243,68,15,16,66,64 // movss 0x40(%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 69,15,40,232 // movaps %xmm8,%xmm13 + .byte 68,15,89,232 // mulps %xmm0,%xmm13 + .byte 68,15,40,224 // movaps %xmm0,%xmm12 + .byte 69,15,89,228 // mulps %xmm12,%xmm12 + .byte 243,68,15,16,74,60 // movss 0x3c(%rdx),%xmm9 + .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 + .byte 243,68,15,16,82,52 // movss 0x34(%rdx),%xmm10 + .byte 243,68,15,16,90,56 // movss 0x38(%rdx),%xmm11 + .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 + .byte 69,15,40,241 // movaps %xmm9,%xmm14 + .byte 68,15,89,240 // mulps %xmm0,%xmm14 + .byte 69,15,88,243 // addps %xmm11,%xmm14 + .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 + .byte 69,15,89,244 // mulps %xmm12,%xmm14 + .byte 69,15,88,242 // addps %xmm10,%xmm14 + .byte 243,68,15,16,98,68 // movss 0x44(%rdx),%xmm12 + .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 + .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 69,15,40,232 // movaps %xmm8,%xmm13 + .byte 68,15,89,233 // mulps %xmm1,%xmm13 + .byte 68,15,40,241 // movaps %xmm1,%xmm14 + .byte 69,15,89,246 // mulps %xmm14,%xmm14 + .byte 69,15,40,249 // movaps %xmm9,%xmm15 + .byte 68,15,89,249 // mulps %xmm1,%xmm15 + .byte 69,15,88,251 // addps %xmm11,%xmm15 + .byte 69,15,89,254 // mulps %xmm14,%xmm15 + .byte 69,15,88,250 // addps %xmm10,%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,203 // addps %xmm11,%xmm9 + .byte 69,15,89,205 // mulps %xmm13,%xmm9 + .byte 69,15,88,202 // addps %xmm10,%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 .globl _sk_to_srgb_sse2 _sk_to_srgb_sse2: - .byte 0x48,0x83,0xec,0x28 // sub $0x28,%rsp - .byte 0x0f,0x29,0x7c,0x24,0x10 // movaps %xmm7,0x10(%rsp) - .byte 0x0f,0x29,0x34,0x24 // movaps %xmm6,(%rsp) - .byte 0x0f,0x28,0xf5 // movaps %xmm5,%xmm6 - .byte 0x0f,0x28,0xec // movaps %xmm4,%xmm5 - .byte 0x0f,0x28,0xe3 // movaps %xmm3,%xmm4 - .byte 0x44,0x0f,0x52,0xc0 // rsqrtps %xmm0,%xmm8 - .byte 0x45,0x0f,0x53,0xe8 // rcpps %xmm8,%xmm13 - .byte 0x45,0x0f,0x52,0xf8 // rsqrtps %xmm8,%xmm15 - .byte 0xf3,0x0f,0x10,0x1a // movss (%rdx),%xmm3 - .byte 0xf3,0x44,0x0f,0x10,0x42,0x48 // movss 0x48(%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x45,0x0f,0x28,0xf0 // movaps %xmm8,%xmm14 - .byte 0x44,0x0f,0x59,0xf0 // mulps %xmm0,%xmm14 - .byte 0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm3,%xmm3 - .byte 0xf3,0x44,0x0f,0x10,0x52,0x4c // movss 0x4c(%rdx),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x5a,0x50 // movss 0x50(%rdx),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0xf3,0x44,0x0f,0x10,0x62,0x54 // movss 0x54(%rdx),%xmm12 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0x45,0x0f,0x59,0xeb // mulps %xmm11,%xmm13 - .byte 0x45,0x0f,0x58,0xec // addps %xmm12,%xmm13 - .byte 0x45,0x0f,0x59,0xfa // mulps %xmm10,%xmm15 - .byte 0x45,0x0f,0x58,0xfd // addps %xmm13,%xmm15 - .byte 0x44,0x0f,0x28,0xcb // movaps %xmm3,%xmm9 - .byte 0x45,0x0f,0x5d,0xcf // minps %xmm15,%xmm9 - .byte 0xf3,0x44,0x0f,0x10,0x6a,0x58 // movss 0x58(%rdx),%xmm13 - .byte 0x45,0x0f,0xc6,0xed,0x00 // shufps $0x0,%xmm13,%xmm13 - .byte 0x41,0x0f,0xc2,0xc5,0x01 // cmpltps %xmm13,%xmm0 - .byte 0x44,0x0f,0x54,0xf0 // andps %xmm0,%xmm14 - .byte 0x41,0x0f,0x55,0xc1 // andnps %xmm9,%xmm0 - .byte 0x41,0x0f,0x56,0xc6 // orps %xmm14,%xmm0 - .byte 0x44,0x0f,0x52,0xc9 // rsqrtps %xmm1,%xmm9 - .byte 0x45,0x0f,0x53,0xf1 // rcpps %xmm9,%xmm14 - .byte 0x45,0x0f,0x52,0xc9 // rsqrtps %xmm9,%xmm9 - .byte 0x45,0x0f,0x59,0xf3 // mulps %xmm11,%xmm14 - .byte 0x45,0x0f,0x58,0xf4 // addps %xmm12,%xmm14 - .byte 0x45,0x0f,0x59,0xca // mulps %xmm10,%xmm9 - .byte 0x45,0x0f,0x58,0xce // addps %xmm14,%xmm9 - .byte 0x44,0x0f,0x28,0xf3 // movaps %xmm3,%xmm14 - .byte 0x45,0x0f,0x5d,0xf1 // minps %xmm9,%xmm14 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xc9 // mulps %xmm1,%xmm9 - .byte 0x41,0x0f,0xc2,0xcd,0x01 // cmpltps %xmm13,%xmm1 - .byte 0x44,0x0f,0x54,0xc9 // andps %xmm1,%xmm9 - .byte 0x41,0x0f,0x55,0xce // andnps %xmm14,%xmm1 - .byte 0x41,0x0f,0x56,0xc9 // orps %xmm9,%xmm1 - .byte 0x44,0x0f,0x52,0xca // rsqrtps %xmm2,%xmm9 - .byte 0x45,0x0f,0x53,0xf1 // rcpps %xmm9,%xmm14 - .byte 0x45,0x0f,0x59,0xf3 // mulps %xmm11,%xmm14 - .byte 0x45,0x0f,0x58,0xf4 // addps %xmm12,%xmm14 - .byte 0x41,0x0f,0x52,0xf9 // rsqrtps %xmm9,%xmm7 - .byte 0x41,0x0f,0x59,0xfa // mulps %xmm10,%xmm7 - .byte 0x41,0x0f,0x58,0xfe // addps %xmm14,%xmm7 - .byte 0x0f,0x5d,0xdf // minps %xmm7,%xmm3 - .byte 0x44,0x0f,0x59,0xc2 // mulps %xmm2,%xmm8 - .byte 0x41,0x0f,0xc2,0xd5,0x01 // cmpltps %xmm13,%xmm2 - .byte 0x44,0x0f,0x54,0xc2 // andps %xmm2,%xmm8 - .byte 0x0f,0x55,0xd3 // andnps %xmm3,%xmm2 - .byte 0x41,0x0f,0x56,0xd0 // orps %xmm8,%xmm2 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x0f,0x28,0xdc // movaps %xmm4,%xmm3 - .byte 0x0f,0x28,0xe5 // movaps %xmm5,%xmm4 - .byte 0x0f,0x28,0xee // movaps %xmm6,%xmm5 - .byte 0x0f,0x28,0x34,0x24 // movaps (%rsp),%xmm6 - .byte 0x0f,0x28,0x7c,0x24,0x10 // movaps 0x10(%rsp),%xmm7 - .byte 0x48,0x83,0xc4,0x28 // add $0x28,%rsp - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,131,236,40 // sub $0x28,%rsp + .byte 15,41,124,36,16 // movaps %xmm7,0x10(%rsp) + .byte 15,41,52,36 // movaps %xmm6,(%rsp) + .byte 15,40,245 // movaps %xmm5,%xmm6 + .byte 15,40,236 // movaps %xmm4,%xmm5 + .byte 15,40,227 // movaps %xmm3,%xmm4 + .byte 68,15,82,192 // rsqrtps %xmm0,%xmm8 + .byte 69,15,83,232 // rcpps %xmm8,%xmm13 + .byte 69,15,82,248 // rsqrtps %xmm8,%xmm15 + .byte 243,15,16,26 // movss (%rdx),%xmm3 + .byte 243,68,15,16,66,72 // movss 0x48(%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 69,15,40,240 // movaps %xmm8,%xmm14 + .byte 68,15,89,240 // mulps %xmm0,%xmm14 + .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 + .byte 243,68,15,16,82,76 // movss 0x4c(%rdx),%xmm10 + .byte 69,15,198,210,0 // shufps $0x0,%xmm10,%xmm10 + .byte 243,68,15,16,90,80 // movss 0x50(%rdx),%xmm11 + .byte 69,15,198,219,0 // shufps $0x0,%xmm11,%xmm11 + .byte 243,68,15,16,98,84 // movss 0x54(%rdx),%xmm12 + .byte 69,15,198,228,0 // shufps $0x0,%xmm12,%xmm12 + .byte 69,15,89,235 // mulps %xmm11,%xmm13 + .byte 69,15,88,236 // addps %xmm12,%xmm13 + .byte 69,15,89,250 // mulps %xmm10,%xmm15 + .byte 69,15,88,253 // addps %xmm13,%xmm15 + .byte 68,15,40,203 // movaps %xmm3,%xmm9 + .byte 69,15,93,207 // minps %xmm15,%xmm9 + .byte 243,68,15,16,106,88 // movss 0x58(%rdx),%xmm13 + .byte 69,15,198,237,0 // shufps $0x0,%xmm13,%xmm13 + .byte 65,15,194,197,1 // cmpltps %xmm13,%xmm0 + .byte 68,15,84,240 // andps %xmm0,%xmm14 + .byte 65,15,85,193 // andnps %xmm9,%xmm0 + .byte 65,15,86,198 // orps %xmm14,%xmm0 + .byte 68,15,82,201 // rsqrtps %xmm1,%xmm9 + .byte 69,15,83,241 // rcpps %xmm9,%xmm14 + .byte 69,15,82,201 // rsqrtps %xmm9,%xmm9 + .byte 69,15,89,243 // mulps %xmm11,%xmm14 + .byte 69,15,88,244 // addps %xmm12,%xmm14 + .byte 69,15,89,202 // mulps %xmm10,%xmm9 + .byte 69,15,88,206 // addps %xmm14,%xmm9 + .byte 68,15,40,243 // movaps %xmm3,%xmm14 + .byte 69,15,93,241 // minps %xmm9,%xmm14 + .byte 69,15,40,200 // movaps %xmm8,%xmm9 + .byte 68,15,89,201 // mulps %xmm1,%xmm9 + .byte 65,15,194,205,1 // cmpltps %xmm13,%xmm1 + .byte 68,15,84,201 // andps %xmm1,%xmm9 + .byte 65,15,85,206 // andnps %xmm14,%xmm1 + .byte 65,15,86,201 // orps %xmm9,%xmm1 + .byte 68,15,82,202 // rsqrtps %xmm2,%xmm9 + .byte 69,15,83,241 // rcpps %xmm9,%xmm14 + .byte 69,15,89,243 // mulps %xmm11,%xmm14 + .byte 69,15,88,244 // addps %xmm12,%xmm14 + .byte 65,15,82,249 // rsqrtps %xmm9,%xmm7 + .byte 65,15,89,250 // mulps %xmm10,%xmm7 + .byte 65,15,88,254 // addps %xmm14,%xmm7 + .byte 15,93,223 // minps %xmm7,%xmm3 + .byte 68,15,89,194 // mulps %xmm2,%xmm8 + .byte 65,15,194,213,1 // cmpltps %xmm13,%xmm2 + .byte 68,15,84,194 // andps %xmm2,%xmm8 + .byte 15,85,211 // andnps %xmm3,%xmm2 + .byte 65,15,86,208 // orps %xmm8,%xmm2 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 15,40,220 // movaps %xmm4,%xmm3 + .byte 15,40,229 // movaps %xmm5,%xmm4 + .byte 15,40,238 // movaps %xmm6,%xmm5 + .byte 15,40,52,36 // movaps (%rsp),%xmm6 + .byte 15,40,124,36,16 // movaps 0x10(%rsp),%xmm7 + .byte 72,131,196,40 // add $0x28,%rsp + .byte 255,224 // jmpq *%rax .globl _sk_scale_u8_sse2 _sk_scale_u8_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0x66,0x44,0x0f,0x6e,0x04,0x38 // movd (%rax,%rdi,1),%xmm8 - .byte 0x66,0x45,0x0f,0xef,0xc9 // pxor %xmm9,%xmm9 - .byte 0x66,0x45,0x0f,0x60,0xc1 // punpcklbw %xmm9,%xmm8 - .byte 0x66,0x45,0x0f,0x61,0xc1 // punpcklwd %xmm9,%xmm8 - .byte 0x45,0x0f,0x5b,0xc0 // cvtdq2ps %xmm8,%xmm8 - .byte 0xf3,0x44,0x0f,0x10,0x4a,0x0c // movss 0xc(%rdx),%xmm9 - .byte 0x45,0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm9,%xmm9 - .byte 0x45,0x0f,0x59,0xc8 // mulps %xmm8,%xmm9 - .byte 0x41,0x0f,0x59,0xc1 // mulps %xmm9,%xmm0 - .byte 0x41,0x0f,0x59,0xc9 // mulps %xmm9,%xmm1 - .byte 0x41,0x0f,0x59,0xd1 // mulps %xmm9,%xmm2 - .byte 0x41,0x0f,0x59,0xd9 // mulps %xmm9,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 102,68,15,110,4,56 // movd (%rax,%rdi,1),%xmm8 + .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 + .byte 102,69,15,96,193 // punpcklbw %xmm9,%xmm8 + .byte 102,69,15,97,193 // punpcklwd %xmm9,%xmm8 + .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 + .byte 243,68,15,16,74,12 // movss 0xc(%rdx),%xmm9 + .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 + .byte 69,15,89,200 // mulps %xmm8,%xmm9 + .byte 65,15,89,193 // mulps %xmm9,%xmm0 + .byte 65,15,89,201 // mulps %xmm9,%xmm1 + .byte 65,15,89,209 // mulps %xmm9,%xmm2 + .byte 65,15,89,217 // mulps %xmm9,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_lerp_u8_sse2 _sk_lerp_u8_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0x66,0x44,0x0f,0x6e,0x04,0x38 // movd (%rax,%rdi,1),%xmm8 - .byte 0x66,0x45,0x0f,0xef,0xc9 // pxor %xmm9,%xmm9 - .byte 0x66,0x45,0x0f,0x60,0xc1 // punpcklbw %xmm9,%xmm8 - .byte 0x66,0x45,0x0f,0x61,0xc1 // punpcklwd %xmm9,%xmm8 - .byte 0x45,0x0f,0x5b,0xc0 // cvtdq2ps %xmm8,%xmm8 - .byte 0xf3,0x44,0x0f,0x10,0x4a,0x0c // movss 0xc(%rdx),%xmm9 - .byte 0x45,0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm9,%xmm9 - .byte 0x45,0x0f,0x59,0xc8 // mulps %xmm8,%xmm9 - .byte 0x0f,0x5c,0xc4 // subps %xmm4,%xmm0 - .byte 0x41,0x0f,0x59,0xc1 // mulps %xmm9,%xmm0 - .byte 0x0f,0x58,0xc4 // addps %xmm4,%xmm0 - .byte 0x0f,0x5c,0xcd // subps %xmm5,%xmm1 - .byte 0x41,0x0f,0x59,0xc9 // mulps %xmm9,%xmm1 - .byte 0x0f,0x58,0xcd // addps %xmm5,%xmm1 - .byte 0x0f,0x5c,0xd6 // subps %xmm6,%xmm2 - .byte 0x41,0x0f,0x59,0xd1 // mulps %xmm9,%xmm2 - .byte 0x0f,0x58,0xd6 // addps %xmm6,%xmm2 - .byte 0x0f,0x5c,0xdf // subps %xmm7,%xmm3 - .byte 0x41,0x0f,0x59,0xd9 // mulps %xmm9,%xmm3 - .byte 0x0f,0x58,0xdf // addps %xmm7,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 102,68,15,110,4,56 // movd (%rax,%rdi,1),%xmm8 + .byte 102,69,15,239,201 // pxor %xmm9,%xmm9 + .byte 102,69,15,96,193 // punpcklbw %xmm9,%xmm8 + .byte 102,69,15,97,193 // punpcklwd %xmm9,%xmm8 + .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 + .byte 243,68,15,16,74,12 // movss 0xc(%rdx),%xmm9 + .byte 69,15,198,201,0 // shufps $0x0,%xmm9,%xmm9 + .byte 69,15,89,200 // mulps %xmm8,%xmm9 + .byte 15,92,196 // subps %xmm4,%xmm0 + .byte 65,15,89,193 // mulps %xmm9,%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,209 // mulps %xmm9,%xmm2 + .byte 15,88,214 // addps %xmm6,%xmm2 + .byte 15,92,223 // subps %xmm7,%xmm3 + .byte 65,15,89,217 // mulps %xmm9,%xmm3 + .byte 15,88,223 // addps %xmm7,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_load_tables_sse2 _sk_load_tables_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x08 // mov (%rax),%rcx - .byte 0x4c,0x8b,0x40,0x08 // mov 0x8(%rax),%r8 - .byte 0xf3,0x44,0x0f,0x6f,0x04,0xb9 // movdqu (%rcx,%rdi,4),%xmm8 - .byte 0x66,0x0f,0x6e,0x42,0x10 // movd 0x10(%rdx),%xmm0 - .byte 0x66,0x0f,0x70,0xc0,0x00 // pshufd $0x0,%xmm0,%xmm0 - .byte 0x66,0x45,0x0f,0x6f,0xc8 // movdqa %xmm8,%xmm9 - .byte 0x66,0x41,0x0f,0x72,0xd1,0x08 // psrld $0x8,%xmm9 - .byte 0x66,0x44,0x0f,0xdb,0xc8 // pand %xmm0,%xmm9 - .byte 0x66,0x45,0x0f,0x6f,0xd0 // movdqa %xmm8,%xmm10 - .byte 0x66,0x41,0x0f,0x72,0xd2,0x10 // psrld $0x10,%xmm10 - .byte 0x66,0x44,0x0f,0xdb,0xd0 // pand %xmm0,%xmm10 - .byte 0x66,0x41,0x0f,0xdb,0xc0 // pand %xmm8,%xmm0 - .byte 0x66,0x0f,0x70,0xd8,0x4e // pshufd $0x4e,%xmm0,%xmm3 - .byte 0x66,0x48,0x0f,0x7e,0xd9 // movq %xmm3,%rcx - .byte 0x41,0x89,0xc9 // mov %ecx,%r9d - .byte 0x48,0xc1,0xe9,0x20 // shr $0x20,%rcx - .byte 0x66,0x49,0x0f,0x7e,0xc2 // movq %xmm0,%r10 - .byte 0x45,0x89,0xd3 // mov %r10d,%r11d - .byte 0x49,0xc1,0xea,0x20 // shr $0x20,%r10 - .byte 0xf3,0x43,0x0f,0x10,0x1c,0x90 // movss (%r8,%r10,4),%xmm3 - .byte 0xf3,0x41,0x0f,0x10,0x04,0x88 // movss (%r8,%rcx,4),%xmm0 - .byte 0x0f,0x14,0xd8 // unpcklps %xmm0,%xmm3 - .byte 0xf3,0x43,0x0f,0x10,0x04,0x98 // movss (%r8,%r11,4),%xmm0 - .byte 0xf3,0x43,0x0f,0x10,0x0c,0x88 // movss (%r8,%r9,4),%xmm1 - .byte 0x0f,0x14,0xc1 // unpcklps %xmm1,%xmm0 - .byte 0x0f,0x14,0xc3 // unpcklps %xmm3,%xmm0 - .byte 0x48,0x8b,0x48,0x10 // mov 0x10(%rax),%rcx - .byte 0x66,0x41,0x0f,0x70,0xc9,0x4e // pshufd $0x4e,%xmm9,%xmm1 - .byte 0x66,0x49,0x0f,0x7e,0xc8 // movq %xmm1,%r8 - .byte 0x45,0x89,0xc1 // mov %r8d,%r9d - .byte 0x49,0xc1,0xe8,0x20 // shr $0x20,%r8 - .byte 0x66,0x4d,0x0f,0x7e,0xca // movq %xmm9,%r10 - .byte 0x45,0x89,0xd3 // mov %r10d,%r11d - .byte 0x49,0xc1,0xea,0x20 // shr $0x20,%r10 - .byte 0xf3,0x42,0x0f,0x10,0x1c,0x91 // movss (%rcx,%r10,4),%xmm3 - .byte 0xf3,0x42,0x0f,0x10,0x0c,0x81 // movss (%rcx,%r8,4),%xmm1 - .byte 0x0f,0x14,0xd9 // unpcklps %xmm1,%xmm3 - .byte 0xf3,0x42,0x0f,0x10,0x0c,0x99 // movss (%rcx,%r11,4),%xmm1 - .byte 0xf3,0x42,0x0f,0x10,0x14,0x89 // movss (%rcx,%r9,4),%xmm2 - .byte 0x0f,0x14,0xca // unpcklps %xmm2,%xmm1 - .byte 0x0f,0x14,0xcb // unpcklps %xmm3,%xmm1 - .byte 0x48,0x8b,0x40,0x18 // mov 0x18(%rax),%rax - .byte 0x66,0x41,0x0f,0x70,0xd2,0x4e // pshufd $0x4e,%xmm10,%xmm2 - .byte 0x66,0x48,0x0f,0x7e,0xd1 // movq %xmm2,%rcx - .byte 0x41,0x89,0xc8 // mov %ecx,%r8d - .byte 0x48,0xc1,0xe9,0x20 // shr $0x20,%rcx - .byte 0x66,0x4d,0x0f,0x7e,0xd1 // movq %xmm10,%r9 - .byte 0x45,0x89,0xca // mov %r9d,%r10d - .byte 0x49,0xc1,0xe9,0x20 // shr $0x20,%r9 - .byte 0xf3,0x46,0x0f,0x10,0x0c,0x88 // movss (%rax,%r9,4),%xmm9 - .byte 0xf3,0x0f,0x10,0x14,0x88 // movss (%rax,%rcx,4),%xmm2 - .byte 0x44,0x0f,0x14,0xca // unpcklps %xmm2,%xmm9 - .byte 0xf3,0x42,0x0f,0x10,0x14,0x90 // movss (%rax,%r10,4),%xmm2 - .byte 0xf3,0x42,0x0f,0x10,0x1c,0x80 // movss (%rax,%r8,4),%xmm3 - .byte 0x0f,0x14,0xd3 // unpcklps %xmm3,%xmm2 - .byte 0x41,0x0f,0x14,0xd1 // unpcklps %xmm9,%xmm2 - .byte 0x66,0x41,0x0f,0x72,0xd0,0x18 // psrld $0x18,%xmm8 - .byte 0x45,0x0f,0x5b,0xc0 // cvtdq2ps %xmm8,%xmm8 - .byte 0xf3,0x0f,0x10,0x5a,0x0c // movss 0xc(%rdx),%xmm3 - .byte 0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm3,%xmm3 - .byte 0x41,0x0f,0x59,0xd8 // mulps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,8 // mov (%rax),%rcx + .byte 76,139,64,8 // mov 0x8(%rax),%r8 + .byte 243,68,15,111,4,185 // movdqu (%rcx,%rdi,4),%xmm8 + .byte 102,15,110,66,16 // movd 0x10(%rdx),%xmm0 + .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 + .byte 102,69,15,111,200 // movdqa %xmm8,%xmm9 + .byte 102,65,15,114,209,8 // psrld $0x8,%xmm9 + .byte 102,68,15,219,200 // pand %xmm0,%xmm9 + .byte 102,69,15,111,208 // movdqa %xmm8,%xmm10 + .byte 102,65,15,114,210,16 // psrld $0x10,%xmm10 + .byte 102,68,15,219,208 // pand %xmm0,%xmm10 + .byte 102,65,15,219,192 // pand %xmm8,%xmm0 + .byte 102,15,112,216,78 // pshufd $0x4e,%xmm0,%xmm3 + .byte 102,72,15,126,217 // movq %xmm3,%rcx + .byte 65,137,201 // mov %ecx,%r9d + .byte 72,193,233,32 // shr $0x20,%rcx + .byte 102,73,15,126,194 // movq %xmm0,%r10 + .byte 69,137,211 // mov %r10d,%r11d + .byte 73,193,234,32 // shr $0x20,%r10 + .byte 243,67,15,16,28,144 // movss (%r8,%r10,4),%xmm3 + .byte 243,65,15,16,4,136 // movss (%r8,%rcx,4),%xmm0 + .byte 15,20,216 // unpcklps %xmm0,%xmm3 + .byte 243,67,15,16,4,152 // movss (%r8,%r11,4),%xmm0 + .byte 243,67,15,16,12,136 // movss (%r8,%r9,4),%xmm1 + .byte 15,20,193 // unpcklps %xmm1,%xmm0 + .byte 15,20,195 // unpcklps %xmm3,%xmm0 + .byte 72,139,72,16 // mov 0x10(%rax),%rcx + .byte 102,65,15,112,201,78 // pshufd $0x4e,%xmm9,%xmm1 + .byte 102,73,15,126,200 // movq %xmm1,%r8 + .byte 69,137,193 // mov %r8d,%r9d + .byte 73,193,232,32 // shr $0x20,%r8 + .byte 102,77,15,126,202 // movq %xmm9,%r10 + .byte 69,137,211 // mov %r10d,%r11d + .byte 73,193,234,32 // shr $0x20,%r10 + .byte 243,66,15,16,28,145 // movss (%rcx,%r10,4),%xmm3 + .byte 243,66,15,16,12,129 // movss (%rcx,%r8,4),%xmm1 + .byte 15,20,217 // unpcklps %xmm1,%xmm3 + .byte 243,66,15,16,12,153 // movss (%rcx,%r11,4),%xmm1 + .byte 243,66,15,16,20,137 // movss (%rcx,%r9,4),%xmm2 + .byte 15,20,202 // unpcklps %xmm2,%xmm1 + .byte 15,20,203 // unpcklps %xmm3,%xmm1 + .byte 72,139,64,24 // mov 0x18(%rax),%rax + .byte 102,65,15,112,210,78 // pshufd $0x4e,%xmm10,%xmm2 + .byte 102,72,15,126,209 // movq %xmm2,%rcx + .byte 65,137,200 // mov %ecx,%r8d + .byte 72,193,233,32 // shr $0x20,%rcx + .byte 102,77,15,126,209 // movq %xmm10,%r9 + .byte 69,137,202 // mov %r9d,%r10d + .byte 73,193,233,32 // shr $0x20,%r9 + .byte 243,70,15,16,12,136 // movss (%rax,%r9,4),%xmm9 + .byte 243,15,16,20,136 // movss (%rax,%rcx,4),%xmm2 + .byte 68,15,20,202 // unpcklps %xmm2,%xmm9 + .byte 243,66,15,16,20,144 // movss (%rax,%r10,4),%xmm2 + .byte 243,66,15,16,28,128 // movss (%rax,%r8,4),%xmm3 + .byte 15,20,211 // unpcklps %xmm3,%xmm2 + .byte 65,15,20,209 // unpcklps %xmm9,%xmm2 + .byte 102,65,15,114,208,24 // psrld $0x18,%xmm8 + .byte 69,15,91,192 // cvtdq2ps %xmm8,%xmm8 + .byte 243,15,16,90,12 // movss 0xc(%rdx),%xmm3 + .byte 15,198,219,0 // shufps $0x0,%xmm3,%xmm3 + .byte 65,15,89,216 // mulps %xmm8,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_load_8888_sse2 _sk_load_8888_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xf3,0x0f,0x6f,0x1c,0xb8 // movdqu (%rax,%rdi,4),%xmm3 - .byte 0x66,0x0f,0x6e,0x42,0x10 // movd 0x10(%rdx),%xmm0 - .byte 0x66,0x0f,0x70,0xc0,0x00 // pshufd $0x0,%xmm0,%xmm0 - .byte 0x66,0x0f,0x6f,0xcb // movdqa %xmm3,%xmm1 - .byte 0x66,0x0f,0x72,0xd1,0x08 // psrld $0x8,%xmm1 - .byte 0x66,0x0f,0xdb,0xc8 // pand %xmm0,%xmm1 - .byte 0x66,0x0f,0x6f,0xd3 // movdqa %xmm3,%xmm2 - .byte 0x66,0x0f,0x72,0xd2,0x10 // psrld $0x10,%xmm2 - .byte 0x66,0x0f,0xdb,0xd0 // pand %xmm0,%xmm2 - .byte 0x66,0x0f,0xdb,0xc3 // pand %xmm3,%xmm0 - .byte 0x0f,0x5b,0xc0 // cvtdq2ps %xmm0,%xmm0 - .byte 0xf3,0x44,0x0f,0x10,0x42,0x0c // movss 0xc(%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x0f,0x5b,0xc9 // cvtdq2ps %xmm1,%xmm1 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x0f,0x5b,0xd2 // cvtdq2ps %xmm2,%xmm2 - .byte 0x41,0x0f,0x59,0xd0 // mulps %xmm8,%xmm2 - .byte 0x66,0x0f,0x72,0xd3,0x18 // psrld $0x18,%xmm3 - .byte 0x0f,0x5b,0xdb // cvtdq2ps %xmm3,%xmm3 - .byte 0x41,0x0f,0x59,0xd8 // mulps %xmm8,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 243,15,111,28,184 // movdqu (%rax,%rdi,4),%xmm3 + .byte 102,15,110,66,16 // movd 0x10(%rdx),%xmm0 + .byte 102,15,112,192,0 // pshufd $0x0,%xmm0,%xmm0 + .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 102,15,111,211 // movdqa %xmm3,%xmm2 + .byte 102,15,114,210,16 // psrld $0x10,%xmm2 + .byte 102,15,219,208 // pand %xmm0,%xmm2 + .byte 102,15,219,195 // pand %xmm3,%xmm0 + .byte 15,91,192 // cvtdq2ps %xmm0,%xmm0 + .byte 243,68,15,16,66,12 // movss 0xc(%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 65,15,89,192 // mulps %xmm8,%xmm0 + .byte 15,91,201 // cvtdq2ps %xmm1,%xmm1 + .byte 65,15,89,200 // mulps %xmm8,%xmm1 + .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 .globl _sk_store_8888_sse2 _sk_store_8888_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xf3,0x44,0x0f,0x10,0x42,0x08 // movss 0x8(%rdx),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xc8 // mulps %xmm0,%xmm9 - .byte 0x66,0x45,0x0f,0x5b,0xc9 // cvtps2dq %xmm9,%xmm9 - .byte 0x45,0x0f,0x28,0xd0 // movaps %xmm8,%xmm10 - .byte 0x44,0x0f,0x59,0xd1 // mulps %xmm1,%xmm10 - .byte 0x66,0x45,0x0f,0x5b,0xd2 // cvtps2dq %xmm10,%xmm10 - .byte 0x66,0x41,0x0f,0x72,0xf2,0x08 // pslld $0x8,%xmm10 - .byte 0x66,0x45,0x0f,0xeb,0xd1 // por %xmm9,%xmm10 - .byte 0x45,0x0f,0x28,0xc8 // movaps %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xca // mulps %xmm2,%xmm9 - .byte 0x66,0x45,0x0f,0x5b,0xc9 // cvtps2dq %xmm9,%xmm9 - .byte 0x66,0x41,0x0f,0x72,0xf1,0x10 // pslld $0x10,%xmm9 - .byte 0x44,0x0f,0x59,0xc3 // mulps %xmm3,%xmm8 - .byte 0x66,0x45,0x0f,0x5b,0xc0 // cvtps2dq %xmm8,%xmm8 - .byte 0x66,0x41,0x0f,0x72,0xf0,0x18 // pslld $0x18,%xmm8 - .byte 0x66,0x45,0x0f,0xeb,0xc1 // por %xmm9,%xmm8 - .byte 0x66,0x45,0x0f,0xeb,0xc2 // por %xmm10,%xmm8 - .byte 0xf3,0x44,0x0f,0x7f,0x04,0xb8 // movdqu %xmm8,(%rax,%rdi,4) - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 243,68,15,16,66,8 // movss 0x8(%rdx),%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 69,15,40,200 // movaps %xmm8,%xmm9 + .byte 68,15,89,200 // mulps %xmm0,%xmm9 + .byte 102,69,15,91,201 // cvtps2dq %xmm9,%xmm9 + .byte 69,15,40,208 // movaps %xmm8,%xmm10 + .byte 68,15,89,209 // mulps %xmm1,%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 69,15,40,200 // movaps %xmm8,%xmm9 + .byte 68,15,89,202 // mulps %xmm2,%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 243,68,15,127,4,184 // movdqu %xmm8,(%rax,%rdi,4) + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_load_f16_sse2 _sk_load_f16_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0xf3,0x0f,0x6f,0x04,0xf8 // movdqu (%rax,%rdi,8),%xmm0 - .byte 0xf3,0x0f,0x6f,0x4c,0xf8,0x10 // movdqu 0x10(%rax,%rdi,8),%xmm1 - .byte 0x66,0x0f,0x6f,0xd0 // movdqa %xmm0,%xmm2 - .byte 0x66,0x0f,0x61,0xd1 // punpcklwd %xmm1,%xmm2 - .byte 0x66,0x0f,0x69,0xc1 // punpckhwd %xmm1,%xmm0 - .byte 0x66,0x44,0x0f,0x6f,0xc2 // movdqa %xmm2,%xmm8 - .byte 0x66,0x44,0x0f,0x61,0xc0 // punpcklwd %xmm0,%xmm8 - .byte 0x66,0x0f,0x69,0xd0 // punpckhwd %xmm0,%xmm2 - .byte 0x66,0x0f,0x6e,0x42,0x64 // movd 0x64(%rdx),%xmm0 - .byte 0x66,0x0f,0x70,0xd8,0x00 // pshufd $0x0,%xmm0,%xmm3 - .byte 0x66,0x0f,0x6f,0xcb // movdqa %xmm3,%xmm1 - .byte 0x66,0x41,0x0f,0x65,0xc8 // pcmpgtw %xmm8,%xmm1 - .byte 0x66,0x41,0x0f,0xdf,0xc8 // pandn %xmm8,%xmm1 - .byte 0x66,0x0f,0x65,0xda // pcmpgtw %xmm2,%xmm3 - .byte 0x66,0x0f,0xdf,0xda // pandn %xmm2,%xmm3 - .byte 0x66,0x45,0x0f,0xef,0xc0 // pxor %xmm8,%xmm8 - .byte 0x66,0x0f,0x6f,0xc1 // movdqa %xmm1,%xmm0 - .byte 0x66,0x41,0x0f,0x61,0xc0 // punpcklwd %xmm8,%xmm0 - .byte 0x66,0x0f,0x72,0xf0,0x0d // pslld $0xd,%xmm0 - .byte 0x66,0x0f,0x6e,0x52,0x5c // movd 0x5c(%rdx),%xmm2 - .byte 0x66,0x44,0x0f,0x70,0xca,0x00 // pshufd $0x0,%xmm2,%xmm9 - .byte 0x41,0x0f,0x59,0xc1 // mulps %xmm9,%xmm0 - .byte 0x66,0x41,0x0f,0x69,0xc8 // punpckhwd %xmm8,%xmm1 - .byte 0x66,0x0f,0x72,0xf1,0x0d // pslld $0xd,%xmm1 - .byte 0x41,0x0f,0x59,0xc9 // mulps %xmm9,%xmm1 - .byte 0x66,0x0f,0x6f,0xd3 // movdqa %xmm3,%xmm2 - .byte 0x66,0x41,0x0f,0x61,0xd0 // punpcklwd %xmm8,%xmm2 - .byte 0x66,0x0f,0x72,0xf2,0x0d // pslld $0xd,%xmm2 - .byte 0x41,0x0f,0x59,0xd1 // mulps %xmm9,%xmm2 - .byte 0x66,0x41,0x0f,0x69,0xd8 // punpckhwd %xmm8,%xmm3 - .byte 0x66,0x0f,0x72,0xf3,0x0d // pslld $0xd,%xmm3 - .byte 0x41,0x0f,0x59,0xd9 // mulps %xmm9,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 243,15,111,4,248 // movdqu (%rax,%rdi,8),%xmm0 + .byte 243,15,111,76,248,16 // movdqu 0x10(%rax,%rdi,8),%xmm1 + .byte 102,15,111,208 // movdqa %xmm0,%xmm2 + .byte 102,15,97,209 // punpcklwd %xmm1,%xmm2 + .byte 102,15,105,193 // punpckhwd %xmm1,%xmm0 + .byte 102,68,15,111,194 // movdqa %xmm2,%xmm8 + .byte 102,68,15,97,192 // punpcklwd %xmm0,%xmm8 + .byte 102,15,105,208 // punpckhwd %xmm0,%xmm2 + .byte 102,15,110,66,100 // movd 0x64(%rdx),%xmm0 + .byte 102,15,112,216,0 // pshufd $0x0,%xmm0,%xmm3 + .byte 102,15,111,203 // movdqa %xmm3,%xmm1 + .byte 102,65,15,101,200 // pcmpgtw %xmm8,%xmm1 + .byte 102,65,15,223,200 // pandn %xmm8,%xmm1 + .byte 102,15,101,218 // pcmpgtw %xmm2,%xmm3 + .byte 102,15,223,218 // pandn %xmm2,%xmm3 + .byte 102,69,15,239,192 // pxor %xmm8,%xmm8 + .byte 102,15,111,193 // movdqa %xmm1,%xmm0 + .byte 102,65,15,97,192 // punpcklwd %xmm8,%xmm0 + .byte 102,15,114,240,13 // pslld $0xd,%xmm0 + .byte 102,15,110,82,92 // movd 0x5c(%rdx),%xmm2 + .byte 102,68,15,112,202,0 // pshufd $0x0,%xmm2,%xmm9 + .byte 65,15,89,193 // mulps %xmm9,%xmm0 + .byte 102,65,15,105,200 // punpckhwd %xmm8,%xmm1 + .byte 102,15,114,241,13 // pslld $0xd,%xmm1 + .byte 65,15,89,201 // mulps %xmm9,%xmm1 + .byte 102,15,111,211 // movdqa %xmm3,%xmm2 + .byte 102,65,15,97,208 // punpcklwd %xmm8,%xmm2 + .byte 102,15,114,242,13 // pslld $0xd,%xmm2 + .byte 65,15,89,209 // mulps %xmm9,%xmm2 + .byte 102,65,15,105,216 // punpckhwd %xmm8,%xmm3 + .byte 102,15,114,243,13 // pslld $0xd,%xmm3 + .byte 65,15,89,217 // mulps %xmm9,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_store_f16_sse2 _sk_store_f16_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x48,0x8b,0x00 // mov (%rax),%rax - .byte 0x66,0x44,0x0f,0x6e,0x42,0x60 // movd 0x60(%rdx),%xmm8 - .byte 0x66,0x45,0x0f,0x70,0xc0,0x00 // pshufd $0x0,%xmm8,%xmm8 - .byte 0x66,0x45,0x0f,0x6f,0xc8 // movdqa %xmm8,%xmm9 - .byte 0x44,0x0f,0x59,0xc8 // mulps %xmm0,%xmm9 - .byte 0x66,0x41,0x0f,0x72,0xd1,0x0d // psrld $0xd,%xmm9 - .byte 0x66,0x45,0x0f,0x6f,0xd0 // movdqa %xmm8,%xmm10 - .byte 0x44,0x0f,0x59,0xd1 // mulps %xmm1,%xmm10 - .byte 0x66,0x41,0x0f,0x72,0xd2,0x0d // psrld $0xd,%xmm10 - .byte 0x66,0x45,0x0f,0x6f,0xd8 // movdqa %xmm8,%xmm11 - .byte 0x44,0x0f,0x59,0xda // mulps %xmm2,%xmm11 - .byte 0x66,0x41,0x0f,0x72,0xd3,0x0d // psrld $0xd,%xmm11 - .byte 0x44,0x0f,0x59,0xc3 // mulps %xmm3,%xmm8 - .byte 0x66,0x41,0x0f,0x72,0xd0,0x0d // psrld $0xd,%xmm8 - .byte 0x66,0x41,0x0f,0x73,0xfa,0x02 // pslldq $0x2,%xmm10 - .byte 0x66,0x45,0x0f,0xeb,0xd1 // por %xmm9,%xmm10 - .byte 0x66,0x41,0x0f,0x73,0xf8,0x02 // pslldq $0x2,%xmm8 - .byte 0x66,0x45,0x0f,0xeb,0xc3 // por %xmm11,%xmm8 - .byte 0x66,0x45,0x0f,0x6f,0xca // movdqa %xmm10,%xmm9 - .byte 0x66,0x45,0x0f,0x62,0xc8 // punpckldq %xmm8,%xmm9 - .byte 0xf3,0x44,0x0f,0x7f,0x0c,0xf8 // movdqu %xmm9,(%rax,%rdi,8) - .byte 0x66,0x45,0x0f,0x6a,0xd0 // punpckhdq %xmm8,%xmm10 - .byte 0xf3,0x44,0x0f,0x7f,0x54,0xf8,0x10 // movdqu %xmm10,0x10(%rax,%rdi,8) - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 72,139,0 // mov (%rax),%rax + .byte 102,68,15,110,66,96 // movd 0x60(%rdx),%xmm8 + .byte 102,69,15,112,192,0 // pshufd $0x0,%xmm8,%xmm8 + .byte 102,69,15,111,200 // movdqa %xmm8,%xmm9 + .byte 68,15,89,200 // mulps %xmm0,%xmm9 + .byte 102,65,15,114,209,13 // psrld $0xd,%xmm9 + .byte 102,69,15,111,208 // movdqa %xmm8,%xmm10 + .byte 68,15,89,209 // mulps %xmm1,%xmm10 + .byte 102,65,15,114,210,13 // psrld $0xd,%xmm10 + .byte 102,69,15,111,216 // movdqa %xmm8,%xmm11 + .byte 68,15,89,218 // mulps %xmm2,%xmm11 + .byte 102,65,15,114,211,13 // psrld $0xd,%xmm11 + .byte 68,15,89,195 // mulps %xmm3,%xmm8 + .byte 102,65,15,114,208,13 // psrld $0xd,%xmm8 + .byte 102,65,15,115,250,2 // pslldq $0x2,%xmm10 + .byte 102,69,15,235,209 // por %xmm9,%xmm10 + .byte 102,65,15,115,248,2 // pslldq $0x2,%xmm8 + .byte 102,69,15,235,195 // por %xmm11,%xmm8 + .byte 102,69,15,111,202 // movdqa %xmm10,%xmm9 + .byte 102,69,15,98,200 // punpckldq %xmm8,%xmm9 + .byte 243,68,15,127,12,248 // movdqu %xmm9,(%rax,%rdi,8) + .byte 102,69,15,106,208 // punpckhdq %xmm8,%xmm10 + .byte 243,68,15,127,84,248,16 // movdqu %xmm10,0x10(%rax,%rdi,8) + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 255,224 // jmpq *%rax .globl _sk_clamp_x_sse2 _sk_clamp_x_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x00 // movss (%rax),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x66,0x45,0x0f,0x76,0xc9 // pcmpeqd %xmm9,%xmm9 - .byte 0x66,0x45,0x0f,0xfe,0xc8 // paddd %xmm8,%xmm9 - .byte 0x41,0x0f,0x5d,0xc1 // minps %xmm9,%xmm0 - .byte 0x45,0x0f,0x57,0xc0 // xorps %xmm8,%xmm8 - .byte 0x44,0x0f,0x5f,0xc0 // maxps %xmm0,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xc0 // movaps %xmm8,%xmm0 - .byte 0xff,0xe0 // jmpq *%rax + .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 102,69,15,118,201 // pcmpeqd %xmm9,%xmm9 + .byte 102,69,15,254,200 // paddd %xmm8,%xmm9 + .byte 65,15,93,193 // minps %xmm9,%xmm0 + .byte 69,15,87,192 // xorps %xmm8,%xmm8 + .byte 68,15,95,192 // maxps %xmm0,%xmm8 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 65,15,40,192 // movaps %xmm8,%xmm0 + .byte 255,224 // jmpq *%rax .globl _sk_clamp_y_sse2 _sk_clamp_y_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x44,0x0f,0x10,0x00 // movss (%rax),%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x66,0x45,0x0f,0x76,0xc9 // pcmpeqd %xmm9,%xmm9 - .byte 0x66,0x45,0x0f,0xfe,0xc8 // paddd %xmm8,%xmm9 - .byte 0x41,0x0f,0x5d,0xc9 // minps %xmm9,%xmm1 - .byte 0x45,0x0f,0x57,0xc0 // xorps %xmm8,%xmm8 - .byte 0x44,0x0f,0x5f,0xc1 // maxps %xmm1,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xc8 // movaps %xmm8,%xmm1 - .byte 0xff,0xe0 // jmpq *%rax + .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 102,69,15,118,201 // pcmpeqd %xmm9,%xmm9 + .byte 102,69,15,254,200 // paddd %xmm8,%xmm9 + .byte 65,15,93,201 // minps %xmm9,%xmm1 + .byte 69,15,87,192 // xorps %xmm8,%xmm8 + .byte 68,15,95,193 // maxps %xmm1,%xmm8 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 65,15,40,200 // movaps %xmm8,%xmm1 + .byte 255,224 // jmpq *%rax .globl _sk_matrix_2x3_sse2 _sk_matrix_2x3_sse2: - .byte 0x44,0x0f,0x28,0xc9 // movaps %xmm1,%xmm9 - .byte 0x44,0x0f,0x28,0xc0 // movaps %xmm0,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x0f,0x10,0x00 // movss (%rax),%xmm0 - .byte 0xf3,0x0f,0x10,0x48,0x04 // movss 0x4(%rax),%xmm1 - .byte 0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm0,%xmm0 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x08 // movss 0x8(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x10 // movss 0x10(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0x45,0x0f,0x59,0xd1 // mulps %xmm9,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x41,0x0f,0x58,0xc2 // addps %xmm10,%xmm0 - .byte 0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm1,%xmm1 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x0c // movss 0xc(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x14 // movss 0x14(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0x45,0x0f,0x59,0xd1 // mulps %xmm9,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x41,0x0f,0x58,0xca // addps %xmm10,%xmm1 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_matrix_3x4_sse2 _sk_matrix_3x4_sse2: - .byte 0x44,0x0f,0x28,0xc9 // movaps %xmm1,%xmm9 - .byte 0x44,0x0f,0x28,0xc0 // movaps %xmm0,%xmm8 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0xf3,0x0f,0x10,0x00 // movss (%rax),%xmm0 - .byte 0xf3,0x0f,0x10,0x48,0x04 // movss 0x4(%rax),%xmm1 - .byte 0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm0,%xmm0 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x0c // movss 0xc(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x18 // movss 0x18(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0xf3,0x44,0x0f,0x10,0x60,0x24 // movss 0x24(%rax),%xmm12 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0x44,0x0f,0x59,0xda // mulps %xmm2,%xmm11 - .byte 0x45,0x0f,0x58,0xdc // addps %xmm12,%xmm11 - .byte 0x45,0x0f,0x59,0xd1 // mulps %xmm9,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x41,0x0f,0x59,0xc0 // mulps %xmm8,%xmm0 - .byte 0x41,0x0f,0x58,0xc2 // addps %xmm10,%xmm0 - .byte 0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm1,%xmm1 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x10 // movss 0x10(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x1c // movss 0x1c(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0xf3,0x44,0x0f,0x10,0x60,0x28 // movss 0x28(%rax),%xmm12 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0x44,0x0f,0x59,0xda // mulps %xmm2,%xmm11 - .byte 0x45,0x0f,0x58,0xdc // addps %xmm12,%xmm11 - .byte 0x45,0x0f,0x59,0xd1 // mulps %xmm9,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x41,0x0f,0x59,0xc8 // mulps %xmm8,%xmm1 - .byte 0x41,0x0f,0x58,0xca // addps %xmm10,%xmm1 - .byte 0xf3,0x44,0x0f,0x10,0x50,0x08 // movss 0x8(%rax),%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0x00 // shufps $0x0,%xmm10,%xmm10 - .byte 0xf3,0x44,0x0f,0x10,0x58,0x14 // movss 0x14(%rax),%xmm11 - .byte 0x45,0x0f,0xc6,0xdb,0x00 // shufps $0x0,%xmm11,%xmm11 - .byte 0xf3,0x44,0x0f,0x10,0x60,0x20 // movss 0x20(%rax),%xmm12 - .byte 0x45,0x0f,0xc6,0xe4,0x00 // shufps $0x0,%xmm12,%xmm12 - .byte 0xf3,0x44,0x0f,0x10,0x68,0x2c // movss 0x2c(%rax),%xmm13 - .byte 0x45,0x0f,0xc6,0xed,0x00 // shufps $0x0,%xmm13,%xmm13 - .byte 0x44,0x0f,0x59,0xe2 // mulps %xmm2,%xmm12 - .byte 0x45,0x0f,0x58,0xe5 // addps %xmm13,%xmm12 - .byte 0x45,0x0f,0x59,0xd9 // mulps %xmm9,%xmm11 - .byte 0x45,0x0f,0x58,0xdc // addps %xmm12,%xmm11 - .byte 0x45,0x0f,0x59,0xd0 // mulps %xmm8,%xmm10 - .byte 0x45,0x0f,0x58,0xd3 // addps %xmm11,%xmm10 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xd2 // movaps %xmm10,%xmm2 - .byte 0xff,0xe0 // jmpq *%rax + .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 .globl _sk_linear_gradient_2stops_sse2 _sk_linear_gradient_2stops_sse2: - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x44,0x0f,0x10,0x08 // movups (%rax),%xmm9 - .byte 0x0f,0x10,0x58,0x10 // movups 0x10(%rax),%xmm3 - .byte 0x44,0x0f,0x28,0xc3 // movaps %xmm3,%xmm8 - .byte 0x45,0x0f,0xc6,0xc0,0x00 // shufps $0x0,%xmm8,%xmm8 - .byte 0x41,0x0f,0x28,0xc9 // movaps %xmm9,%xmm1 - .byte 0x0f,0xc6,0xc9,0x00 // shufps $0x0,%xmm1,%xmm1 - .byte 0x44,0x0f,0x59,0xc0 // mulps %xmm0,%xmm8 - .byte 0x44,0x0f,0x58,0xc1 // addps %xmm1,%xmm8 - .byte 0x0f,0x28,0xcb // movaps %xmm3,%xmm1 - .byte 0x0f,0xc6,0xc9,0x55 // shufps $0x55,%xmm1,%xmm1 - .byte 0x41,0x0f,0x28,0xd1 // movaps %xmm9,%xmm2 - .byte 0x0f,0xc6,0xd2,0x55 // shufps $0x55,%xmm2,%xmm2 - .byte 0x0f,0x59,0xc8 // mulps %xmm0,%xmm1 - .byte 0x0f,0x58,0xca // addps %xmm2,%xmm1 - .byte 0x0f,0x28,0xd3 // movaps %xmm3,%xmm2 - .byte 0x0f,0xc6,0xd2,0xaa // shufps $0xaa,%xmm2,%xmm2 - .byte 0x45,0x0f,0x28,0xd1 // movaps %xmm9,%xmm10 - .byte 0x45,0x0f,0xc6,0xd2,0xaa // shufps $0xaa,%xmm10,%xmm10 - .byte 0x0f,0x59,0xd0 // mulps %xmm0,%xmm2 - .byte 0x41,0x0f,0x58,0xd2 // addps %xmm10,%xmm2 - .byte 0x0f,0xc6,0xdb,0xff // shufps $0xff,%xmm3,%xmm3 - .byte 0x45,0x0f,0xc6,0xc9,0xff // shufps $0xff,%xmm9,%xmm9 - .byte 0x0f,0x59,0xd8 // mulps %xmm0,%xmm3 - .byte 0x41,0x0f,0x58,0xd9 // addps %xmm9,%xmm3 - .byte 0x48,0xad // lods %ds:(%rsi),%rax - .byte 0x41,0x0f,0x28,0xc0 // movaps %xmm8,%xmm0 - .byte 0xff,0xe0 // jmpq *%rax + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 68,15,16,8 // movups (%rax),%xmm9 + .byte 15,16,88,16 // movups 0x10(%rax),%xmm3 + .byte 68,15,40,195 // movaps %xmm3,%xmm8 + .byte 69,15,198,192,0 // shufps $0x0,%xmm8,%xmm8 + .byte 65,15,40,201 // movaps %xmm9,%xmm1 + .byte 15,198,201,0 // shufps $0x0,%xmm1,%xmm1 + .byte 68,15,89,192 // mulps %xmm0,%xmm8 + .byte 68,15,88,193 // addps %xmm1,%xmm8 + .byte 15,40,203 // movaps %xmm3,%xmm1 + .byte 15,198,201,85 // shufps $0x55,%xmm1,%xmm1 + .byte 65,15,40,209 // movaps %xmm9,%xmm2 + .byte 15,198,210,85 // shufps $0x55,%xmm2,%xmm2 + .byte 15,89,200 // mulps %xmm0,%xmm1 + .byte 15,88,202 // addps %xmm2,%xmm1 + .byte 15,40,211 // movaps %xmm3,%xmm2 + .byte 15,198,210,170 // shufps $0xaa,%xmm2,%xmm2 + .byte 69,15,40,209 // movaps %xmm9,%xmm10 + .byte 69,15,198,210,170 // shufps $0xaa,%xmm10,%xmm10 + .byte 15,89,208 // mulps %xmm0,%xmm2 + .byte 65,15,88,210 // addps %xmm10,%xmm2 + .byte 15,198,219,255 // shufps $0xff,%xmm3,%xmm3 + .byte 69,15,198,201,255 // shufps $0xff,%xmm9,%xmm9 + .byte 15,89,216 // mulps %xmm0,%xmm3 + .byte 65,15,88,217 // addps %xmm9,%xmm3 + .byte 72,173 // lods %ds:(%rsi),%rax + .byte 65,15,40,192 // movaps %xmm8,%xmm0 + .byte 255,224 // jmpq *%rax #endif diff --git a/src/jumper/SkJumper_generated_win.S b/src/jumper/SkJumper_generated_win.S index 1409d03c6f..ea620945a3 100644 --- a/src/jumper/SkJumper_generated_win.S +++ b/src/jumper/SkJumper_generated_win.S @@ -10,2837 +10,2837 @@ _text SEGMENT PUBLIC _sk_start_pipeline_hsw _sk_start_pipeline_hsw LABEL PROC - DB 65,87 ; push %r15 - DB 65,86 ; push %r14 - DB 65,85 ; push %r13 - DB 65,84 ; push %r12 - DB 86 ; push %rsi - DB 87 ; push %rdi - DB 83 ; push %rbx - DB 72,129,236,160,0,0,0 ; sub $0xa0,%rsp - DB 197,120,41,188,36,144,0,0,0 ; vmovaps %xmm15,0x90(%rsp) - DB 197,120,41,180,36,128,0,0,0 ; vmovaps %xmm14,0x80(%rsp) - DB 197,120,41,108,36,112 ; vmovaps %xmm13,0x70(%rsp) - DB 197,120,41,100,36,96 ; vmovaps %xmm12,0x60(%rsp) - DB 197,120,41,92,36,80 ; vmovaps %xmm11,0x50(%rsp) - DB 197,120,41,84,36,64 ; vmovaps %xmm10,0x40(%rsp) - DB 197,120,41,76,36,48 ; vmovaps %xmm9,0x30(%rsp) - DB 197,120,41,68,36,32 ; vmovaps %xmm8,0x20(%rsp) - DB 197,248,41,124,36,16 ; vmovaps %xmm7,0x10(%rsp) - DB 197,248,41,52,36 ; vmovaps %xmm6,(%rsp) - DB 77,137,207 ; mov %r9,%r15 - DB 77,137,198 ; mov %r8,%r14 - DB 72,137,203 ; mov %rcx,%rbx - DB 72,137,214 ; mov %rdx,%rsi - DB 72,173 ; lods %ds:(%rsi),%rax - DB 73,137,196 ; mov %rax,%r12 - DB 73,137,245 ; mov %rsi,%r13 - DB 72,141,67,8 ; lea 0x8(%rbx),%rax - DB 76,57,248 ; cmp %r15,%rax - DB 118,5 ; jbe 75 <_sk_start_pipeline_hsw+0x75> - DB 72,137,216 ; mov %rbx,%rax - DB 235,60 ; jmp b1 <_sk_start_pipeline_hsw+0xb1> - DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 - DB 197,244,87,201 ; vxorps %ymm1,%ymm1,%ymm1 - DB 197,236,87,210 ; vxorps %ymm2,%ymm2,%ymm2 - DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 - DB 197,220,87,228 ; vxorps %ymm4,%ymm4,%ymm4 - DB 197,212,87,237 ; vxorps %ymm5,%ymm5,%ymm5 - DB 197,204,87,246 ; vxorps %ymm6,%ymm6,%ymm6 - DB 197,196,87,255 ; vxorps %ymm7,%ymm7,%ymm7 - DB 72,137,223 ; mov %rbx,%rdi - DB 76,137,238 ; mov %r13,%rsi - DB 76,137,242 ; mov %r14,%rdx - DB 65,255,212 ; callq *%r12 - DB 72,141,67,8 ; lea 0x8(%rbx),%rax - DB 72,131,195,16 ; add $0x10,%rbx - DB 76,57,251 ; cmp %r15,%rbx - DB 72,137,195 ; mov %rax,%rbx - DB 118,196 ; jbe 75 <_sk_start_pipeline_hsw+0x75> - DB 197,248,40,52,36 ; vmovaps (%rsp),%xmm6 - DB 197,248,40,124,36,16 ; vmovaps 0x10(%rsp),%xmm7 - DB 197,120,40,68,36,32 ; vmovaps 0x20(%rsp),%xmm8 - DB 197,120,40,76,36,48 ; vmovaps 0x30(%rsp),%xmm9 - DB 197,120,40,84,36,64 ; vmovaps 0x40(%rsp),%xmm10 - DB 197,120,40,92,36,80 ; vmovaps 0x50(%rsp),%xmm11 - DB 197,120,40,100,36,96 ; vmovaps 0x60(%rsp),%xmm12 - DB 197,120,40,108,36,112 ; vmovaps 0x70(%rsp),%xmm13 - DB 197,120,40,180,36,128,0,0,0 ; vmovaps 0x80(%rsp),%xmm14 - DB 197,120,40,188,36,144,0,0,0 ; vmovaps 0x90(%rsp),%xmm15 - DB 72,129,196,160,0,0,0 ; add $0xa0,%rsp - DB 91 ; pop %rbx - DB 95 ; pop %rdi - DB 94 ; pop %rsi - DB 65,92 ; pop %r12 - DB 65,93 ; pop %r13 - DB 65,94 ; pop %r14 - DB 65,95 ; pop %r15 - DB 197,248,119 ; vzeroupper - DB 195 ; retq + DB 65,87 ; push %r15 + DB 65,86 ; push %r14 + DB 65,85 ; push %r13 + DB 65,84 ; push %r12 + DB 86 ; push %rsi + DB 87 ; push %rdi + DB 83 ; push %rbx + DB 72,129,236,160,0,0,0 ; sub $0xa0,%rsp + DB 197,120,41,188,36,144,0,0,0 ; vmovaps %xmm15,0x90(%rsp) + DB 197,120,41,180,36,128,0,0,0 ; vmovaps %xmm14,0x80(%rsp) + DB 197,120,41,108,36,112 ; vmovaps %xmm13,0x70(%rsp) + DB 197,120,41,100,36,96 ; vmovaps %xmm12,0x60(%rsp) + DB 197,120,41,92,36,80 ; vmovaps %xmm11,0x50(%rsp) + DB 197,120,41,84,36,64 ; vmovaps %xmm10,0x40(%rsp) + DB 197,120,41,76,36,48 ; vmovaps %xmm9,0x30(%rsp) + DB 197,120,41,68,36,32 ; vmovaps %xmm8,0x20(%rsp) + DB 197,248,41,124,36,16 ; vmovaps %xmm7,0x10(%rsp) + DB 197,248,41,52,36 ; vmovaps %xmm6,(%rsp) + DB 77,137,207 ; mov %r9,%r15 + DB 77,137,198 ; mov %r8,%r14 + DB 72,137,203 ; mov %rcx,%rbx + DB 72,137,214 ; mov %rdx,%rsi + DB 72,173 ; lods %ds:(%rsi),%rax + DB 73,137,196 ; mov %rax,%r12 + DB 73,137,245 ; mov %rsi,%r13 + DB 72,141,67,8 ; lea 0x8(%rbx),%rax + DB 76,57,248 ; cmp %r15,%rax + DB 118,5 ; jbe 75 <_sk_start_pipeline_hsw+0x75> + DB 72,137,216 ; mov %rbx,%rax + DB 235,60 ; jmp b1 <_sk_start_pipeline_hsw+0xb1> + DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 + DB 197,244,87,201 ; vxorps %ymm1,%ymm1,%ymm1 + DB 197,236,87,210 ; vxorps %ymm2,%ymm2,%ymm2 + DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 + DB 197,220,87,228 ; vxorps %ymm4,%ymm4,%ymm4 + DB 197,212,87,237 ; vxorps %ymm5,%ymm5,%ymm5 + DB 197,204,87,246 ; vxorps %ymm6,%ymm6,%ymm6 + DB 197,196,87,255 ; vxorps %ymm7,%ymm7,%ymm7 + DB 72,137,223 ; mov %rbx,%rdi + DB 76,137,238 ; mov %r13,%rsi + DB 76,137,242 ; mov %r14,%rdx + DB 65,255,212 ; callq *%r12 + DB 72,141,67,8 ; lea 0x8(%rbx),%rax + DB 72,131,195,16 ; add $0x10,%rbx + DB 76,57,251 ; cmp %r15,%rbx + DB 72,137,195 ; mov %rax,%rbx + DB 118,196 ; jbe 75 <_sk_start_pipeline_hsw+0x75> + DB 197,248,40,52,36 ; vmovaps (%rsp),%xmm6 + DB 197,248,40,124,36,16 ; vmovaps 0x10(%rsp),%xmm7 + DB 197,120,40,68,36,32 ; vmovaps 0x20(%rsp),%xmm8 + DB 197,120,40,76,36,48 ; vmovaps 0x30(%rsp),%xmm9 + DB 197,120,40,84,36,64 ; vmovaps 0x40(%rsp),%xmm10 + DB 197,120,40,92,36,80 ; vmovaps 0x50(%rsp),%xmm11 + DB 197,120,40,100,36,96 ; vmovaps 0x60(%rsp),%xmm12 + DB 197,120,40,108,36,112 ; vmovaps 0x70(%rsp),%xmm13 + DB 197,120,40,180,36,128,0,0,0 ; vmovaps 0x80(%rsp),%xmm14 + DB 197,120,40,188,36,144,0,0,0 ; vmovaps 0x90(%rsp),%xmm15 + DB 72,129,196,160,0,0,0 ; add $0xa0,%rsp + DB 91 ; pop %rbx + DB 95 ; pop %rdi + DB 94 ; pop %rsi + DB 65,92 ; pop %r12 + DB 65,93 ; pop %r13 + DB 65,94 ; pop %r14 + DB 65,95 ; pop %r15 + DB 197,248,119 ; vzeroupper + DB 195 ; retq PUBLIC _sk_just_return_hsw _sk_just_return_hsw LABEL PROC - DB 195 ; retq + DB 195 ; retq PUBLIC _sk_seed_shader_hsw _sk_seed_shader_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,249,110,199 ; vmovd %edi,%xmm0 - DB 196,226,125,24,192 ; vbroadcastss %xmm0,%ymm0 - DB 197,252,91,192 ; vcvtdq2ps %ymm0,%ymm0 - DB 196,226,125,24,74,4 ; vbroadcastss 0x4(%rdx),%ymm1 - DB 197,252,88,193 ; vaddps %ymm1,%ymm0,%ymm0 - DB 197,252,88,66,20 ; vaddps 0x14(%rdx),%ymm0,%ymm0 - DB 196,226,125,24,16 ; vbroadcastss (%rax),%ymm2 - DB 197,252,91,210 ; vcvtdq2ps %ymm2,%ymm2 - DB 197,236,88,201 ; vaddps %ymm1,%ymm2,%ymm1 - DB 196,226,125,24,18 ; vbroadcastss (%rdx),%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 - DB 197,220,87,228 ; vxorps %ymm4,%ymm4,%ymm4 - DB 197,212,87,237 ; vxorps %ymm5,%ymm5,%ymm5 - DB 197,204,87,246 ; vxorps %ymm6,%ymm6,%ymm6 - DB 197,196,87,255 ; vxorps %ymm7,%ymm7,%ymm7 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,249,110,199 ; vmovd %edi,%xmm0 + DB 196,226,125,24,192 ; vbroadcastss %xmm0,%ymm0 + DB 197,252,91,192 ; vcvtdq2ps %ymm0,%ymm0 + DB 196,226,125,24,74,4 ; vbroadcastss 0x4(%rdx),%ymm1 + DB 197,252,88,193 ; vaddps %ymm1,%ymm0,%ymm0 + DB 197,252,88,66,20 ; vaddps 0x14(%rdx),%ymm0,%ymm0 + DB 196,226,125,24,16 ; vbroadcastss (%rax),%ymm2 + DB 197,252,91,210 ; vcvtdq2ps %ymm2,%ymm2 + DB 197,236,88,201 ; vaddps %ymm1,%ymm2,%ymm1 + DB 196,226,125,24,18 ; vbroadcastss (%rdx),%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 + DB 197,220,87,228 ; vxorps %ymm4,%ymm4,%ymm4 + DB 197,212,87,237 ; vxorps %ymm5,%ymm5,%ymm5 + DB 197,204,87,246 ; vxorps %ymm6,%ymm6,%ymm6 + DB 197,196,87,255 ; vxorps %ymm7,%ymm7,%ymm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_constant_color_hsw _sk_constant_color_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,226,125,24,0 ; vbroadcastss (%rax),%ymm0 - DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 - DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 - DB 196,226,125,24,88,12 ; vbroadcastss 0xc(%rax),%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,226,125,24,0 ; vbroadcastss (%rax),%ymm0 + DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 + DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 + DB 196,226,125,24,88,12 ; vbroadcastss 0xc(%rax),%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clear_hsw _sk_clear_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 - DB 197,244,87,201 ; vxorps %ymm1,%ymm1,%ymm1 - DB 197,236,87,210 ; vxorps %ymm2,%ymm2,%ymm2 - DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 + DB 197,244,87,201 ; vxorps %ymm1,%ymm1,%ymm1 + DB 197,236,87,210 ; vxorps %ymm2,%ymm2,%ymm2 + DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 + DB 255,224 ; jmpq *%rax PUBLIC _sk_plus__hsw _sk_plus__hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,88,196 ; vaddps %ymm4,%ymm0,%ymm0 - DB 197,244,88,205 ; vaddps %ymm5,%ymm1,%ymm1 - DB 197,236,88,214 ; vaddps %ymm6,%ymm2,%ymm2 - DB 197,228,88,223 ; vaddps %ymm7,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,88,196 ; vaddps %ymm4,%ymm0,%ymm0 + DB 197,244,88,205 ; vaddps %ymm5,%ymm1,%ymm1 + DB 197,236,88,214 ; vaddps %ymm6,%ymm2,%ymm2 + DB 197,228,88,223 ; vaddps %ymm7,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_srcover_hsw _sk_srcover_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 - DB 197,60,92,195 ; vsubps %ymm3,%ymm8,%ymm8 - DB 196,194,93,184,192 ; vfmadd231ps %ymm8,%ymm4,%ymm0 - DB 196,194,85,184,200 ; vfmadd231ps %ymm8,%ymm5,%ymm1 - DB 196,194,77,184,208 ; vfmadd231ps %ymm8,%ymm6,%ymm2 - DB 196,194,69,184,216 ; vfmadd231ps %ymm8,%ymm7,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 + DB 197,60,92,195 ; vsubps %ymm3,%ymm8,%ymm8 + DB 196,194,93,184,192 ; vfmadd231ps %ymm8,%ymm4,%ymm0 + DB 196,194,85,184,200 ; vfmadd231ps %ymm8,%ymm5,%ymm1 + DB 196,194,77,184,208 ; vfmadd231ps %ymm8,%ymm6,%ymm2 + DB 196,194,69,184,216 ; vfmadd231ps %ymm8,%ymm7,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_dstover_hsw _sk_dstover_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 - DB 197,60,92,199 ; vsubps %ymm7,%ymm8,%ymm8 - DB 196,226,61,168,196 ; vfmadd213ps %ymm4,%ymm8,%ymm0 - DB 196,226,61,168,205 ; vfmadd213ps %ymm5,%ymm8,%ymm1 - DB 196,226,61,168,214 ; vfmadd213ps %ymm6,%ymm8,%ymm2 - DB 196,226,61,168,223 ; vfmadd213ps %ymm7,%ymm8,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 + DB 197,60,92,199 ; vsubps %ymm7,%ymm8,%ymm8 + DB 196,226,61,168,196 ; vfmadd213ps %ymm4,%ymm8,%ymm0 + DB 196,226,61,168,205 ; vfmadd213ps %ymm5,%ymm8,%ymm1 + DB 196,226,61,168,214 ; vfmadd213ps %ymm6,%ymm8,%ymm2 + DB 196,226,61,168,223 ; vfmadd213ps %ymm7,%ymm8,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_0_hsw _sk_clamp_0_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 - DB 196,193,124,95,192 ; vmaxps %ymm8,%ymm0,%ymm0 - DB 196,193,116,95,200 ; vmaxps %ymm8,%ymm1,%ymm1 - DB 196,193,108,95,208 ; vmaxps %ymm8,%ymm2,%ymm2 - DB 196,193,100,95,216 ; vmaxps %ymm8,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 + DB 196,193,124,95,192 ; vmaxps %ymm8,%ymm0,%ymm0 + DB 196,193,116,95,200 ; vmaxps %ymm8,%ymm1,%ymm1 + DB 196,193,108,95,208 ; vmaxps %ymm8,%ymm2,%ymm2 + DB 196,193,100,95,216 ; vmaxps %ymm8,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_1_hsw _sk_clamp_1_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 - DB 196,193,124,93,192 ; vminps %ymm8,%ymm0,%ymm0 - DB 196,193,116,93,200 ; vminps %ymm8,%ymm1,%ymm1 - DB 196,193,108,93,208 ; vminps %ymm8,%ymm2,%ymm2 - DB 196,193,100,93,216 ; vminps %ymm8,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 + DB 196,193,124,93,192 ; vminps %ymm8,%ymm0,%ymm0 + DB 196,193,116,93,200 ; vminps %ymm8,%ymm1,%ymm1 + DB 196,193,108,93,208 ; vminps %ymm8,%ymm2,%ymm2 + DB 196,193,100,93,216 ; vminps %ymm8,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_a_hsw _sk_clamp_a_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 - DB 196,193,100,93,216 ; vminps %ymm8,%ymm3,%ymm3 - DB 197,252,93,195 ; vminps %ymm3,%ymm0,%ymm0 - DB 197,244,93,203 ; vminps %ymm3,%ymm1,%ymm1 - DB 197,236,93,211 ; vminps %ymm3,%ymm2,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 + DB 196,193,100,93,216 ; vminps %ymm8,%ymm3,%ymm3 + DB 197,252,93,195 ; vminps %ymm3,%ymm0,%ymm0 + DB 197,244,93,203 ; vminps %ymm3,%ymm1,%ymm1 + DB 197,236,93,211 ; vminps %ymm3,%ymm2,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_set_rgb_hsw _sk_set_rgb_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,226,125,24,0 ; vbroadcastss (%rax),%ymm0 - DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 - DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,226,125,24,0 ; vbroadcastss (%rax),%ymm0 + DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 + DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_swap_rb_hsw _sk_swap_rb_hsw LABEL PROC - DB 197,124,40,192 ; vmovaps %ymm0,%ymm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,40,194 ; vmovaps %ymm2,%ymm0 - DB 197,124,41,194 ; vmovaps %ymm8,%ymm2 - DB 255,224 ; jmpq *%rax + DB 197,124,40,192 ; vmovaps %ymm0,%ymm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,40,194 ; vmovaps %ymm2,%ymm0 + DB 197,124,41,194 ; vmovaps %ymm8,%ymm2 + DB 255,224 ; jmpq *%rax PUBLIC _sk_swap_hsw _sk_swap_hsw LABEL PROC - DB 197,124,40,195 ; vmovaps %ymm3,%ymm8 - DB 197,124,40,202 ; vmovaps %ymm2,%ymm9 - DB 197,124,40,209 ; vmovaps %ymm1,%ymm10 - DB 197,124,40,216 ; vmovaps %ymm0,%ymm11 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,40,196 ; vmovaps %ymm4,%ymm0 - DB 197,252,40,205 ; vmovaps %ymm5,%ymm1 - DB 197,252,40,214 ; vmovaps %ymm6,%ymm2 - DB 197,252,40,223 ; vmovaps %ymm7,%ymm3 - DB 197,124,41,220 ; vmovaps %ymm11,%ymm4 - DB 197,124,41,213 ; vmovaps %ymm10,%ymm5 - DB 197,124,41,206 ; vmovaps %ymm9,%ymm6 - DB 197,124,41,199 ; vmovaps %ymm8,%ymm7 - DB 255,224 ; jmpq *%rax + DB 197,124,40,195 ; vmovaps %ymm3,%ymm8 + DB 197,124,40,202 ; vmovaps %ymm2,%ymm9 + DB 197,124,40,209 ; vmovaps %ymm1,%ymm10 + DB 197,124,40,216 ; vmovaps %ymm0,%ymm11 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,40,196 ; vmovaps %ymm4,%ymm0 + DB 197,252,40,205 ; vmovaps %ymm5,%ymm1 + DB 197,252,40,214 ; vmovaps %ymm6,%ymm2 + DB 197,252,40,223 ; vmovaps %ymm7,%ymm3 + DB 197,124,41,220 ; vmovaps %ymm11,%ymm4 + DB 197,124,41,213 ; vmovaps %ymm10,%ymm5 + DB 197,124,41,206 ; vmovaps %ymm9,%ymm6 + DB 197,124,41,199 ; vmovaps %ymm8,%ymm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_move_src_dst_hsw _sk_move_src_dst_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,40,224 ; vmovaps %ymm0,%ymm4 - DB 197,252,40,233 ; vmovaps %ymm1,%ymm5 - DB 197,252,40,242 ; vmovaps %ymm2,%ymm6 - DB 197,252,40,251 ; vmovaps %ymm3,%ymm7 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,40,224 ; vmovaps %ymm0,%ymm4 + DB 197,252,40,233 ; vmovaps %ymm1,%ymm5 + DB 197,252,40,242 ; vmovaps %ymm2,%ymm6 + DB 197,252,40,251 ; vmovaps %ymm3,%ymm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_move_dst_src_hsw _sk_move_dst_src_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,40,196 ; vmovaps %ymm4,%ymm0 - DB 197,252,40,205 ; vmovaps %ymm5,%ymm1 - DB 197,252,40,214 ; vmovaps %ymm6,%ymm2 - DB 197,252,40,223 ; vmovaps %ymm7,%ymm3 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,40,196 ; vmovaps %ymm4,%ymm0 + DB 197,252,40,205 ; vmovaps %ymm5,%ymm1 + DB 197,252,40,214 ; vmovaps %ymm6,%ymm2 + DB 197,252,40,223 ; vmovaps %ymm7,%ymm3 + DB 255,224 ; jmpq *%rax PUBLIC _sk_premul_hsw _sk_premul_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,89,195 ; vmulps %ymm3,%ymm0,%ymm0 - DB 197,244,89,203 ; vmulps %ymm3,%ymm1,%ymm1 - DB 197,236,89,211 ; vmulps %ymm3,%ymm2,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,89,195 ; vmulps %ymm3,%ymm0,%ymm0 + DB 197,244,89,203 ; vmulps %ymm3,%ymm1,%ymm1 + DB 197,236,89,211 ; vmulps %ymm3,%ymm2,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_unpremul_hsw _sk_unpremul_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 - DB 196,65,100,194,200,0 ; vcmpeqps %ymm8,%ymm3,%ymm9 - DB 196,98,125,24,18 ; vbroadcastss (%rdx),%ymm10 - DB 197,44,94,211 ; vdivps %ymm3,%ymm10,%ymm10 - DB 196,67,45,74,192,144 ; vblendvps %ymm9,%ymm8,%ymm10,%ymm8 - DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 - DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 - DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 + DB 196,65,100,194,200,0 ; vcmpeqps %ymm8,%ymm3,%ymm9 + DB 196,98,125,24,18 ; vbroadcastss (%rdx),%ymm10 + DB 197,44,94,211 ; vdivps %ymm3,%ymm10,%ymm10 + DB 196,67,45,74,192,144 ; vblendvps %ymm9,%ymm8,%ymm10,%ymm8 + DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 + DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 + DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_from_srgb_hsw _sk_from_srgb_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,66,64 ; vbroadcastss 0x40(%rdx),%ymm8 - DB 197,60,89,200 ; vmulps %ymm0,%ymm8,%ymm9 - DB 197,124,89,208 ; vmulps %ymm0,%ymm0,%ymm10 - DB 196,98,125,24,90,60 ; vbroadcastss 0x3c(%rdx),%ymm11 - DB 196,98,125,24,98,56 ; vbroadcastss 0x38(%rdx),%ymm12 - DB 196,65,124,40,235 ; vmovaps %ymm11,%ymm13 - DB 196,66,125,168,236 ; vfmadd213ps %ymm12,%ymm0,%ymm13 - DB 196,98,125,24,114,52 ; vbroadcastss 0x34(%rdx),%ymm14 - DB 196,66,45,168,238 ; vfmadd213ps %ymm14,%ymm10,%ymm13 - DB 196,98,125,24,82,68 ; vbroadcastss 0x44(%rdx),%ymm10 - DB 196,193,124,194,194,1 ; vcmpltps %ymm10,%ymm0,%ymm0 - DB 196,195,21,74,193,0 ; vblendvps %ymm0,%ymm9,%ymm13,%ymm0 - DB 197,60,89,201 ; vmulps %ymm1,%ymm8,%ymm9 - DB 197,116,89,233 ; vmulps %ymm1,%ymm1,%ymm13 - DB 196,65,124,40,251 ; vmovaps %ymm11,%ymm15 - DB 196,66,117,168,252 ; vfmadd213ps %ymm12,%ymm1,%ymm15 - DB 196,66,21,168,254 ; vfmadd213ps %ymm14,%ymm13,%ymm15 - DB 196,193,116,194,202,1 ; vcmpltps %ymm10,%ymm1,%ymm1 - DB 196,195,5,74,201,16 ; vblendvps %ymm1,%ymm9,%ymm15,%ymm1 - DB 197,60,89,194 ; vmulps %ymm2,%ymm8,%ymm8 - DB 197,108,89,202 ; vmulps %ymm2,%ymm2,%ymm9 - DB 196,66,109,168,220 ; vfmadd213ps %ymm12,%ymm2,%ymm11 - DB 196,66,53,168,222 ; vfmadd213ps %ymm14,%ymm9,%ymm11 - DB 196,193,108,194,210,1 ; vcmpltps %ymm10,%ymm2,%ymm2 - DB 196,195,37,74,208,32 ; vblendvps %ymm2,%ymm8,%ymm11,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,66,64 ; vbroadcastss 0x40(%rdx),%ymm8 + DB 197,60,89,200 ; vmulps %ymm0,%ymm8,%ymm9 + DB 197,124,89,208 ; vmulps %ymm0,%ymm0,%ymm10 + DB 196,98,125,24,90,60 ; vbroadcastss 0x3c(%rdx),%ymm11 + DB 196,98,125,24,98,56 ; vbroadcastss 0x38(%rdx),%ymm12 + DB 196,65,124,40,235 ; vmovaps %ymm11,%ymm13 + DB 196,66,125,168,236 ; vfmadd213ps %ymm12,%ymm0,%ymm13 + DB 196,98,125,24,114,52 ; vbroadcastss 0x34(%rdx),%ymm14 + DB 196,66,45,168,238 ; vfmadd213ps %ymm14,%ymm10,%ymm13 + DB 196,98,125,24,82,68 ; vbroadcastss 0x44(%rdx),%ymm10 + DB 196,193,124,194,194,1 ; vcmpltps %ymm10,%ymm0,%ymm0 + DB 196,195,21,74,193,0 ; vblendvps %ymm0,%ymm9,%ymm13,%ymm0 + DB 197,60,89,201 ; vmulps %ymm1,%ymm8,%ymm9 + DB 197,116,89,233 ; vmulps %ymm1,%ymm1,%ymm13 + DB 196,65,124,40,251 ; vmovaps %ymm11,%ymm15 + DB 196,66,117,168,252 ; vfmadd213ps %ymm12,%ymm1,%ymm15 + DB 196,66,21,168,254 ; vfmadd213ps %ymm14,%ymm13,%ymm15 + DB 196,193,116,194,202,1 ; vcmpltps %ymm10,%ymm1,%ymm1 + DB 196,195,5,74,201,16 ; vblendvps %ymm1,%ymm9,%ymm15,%ymm1 + DB 197,60,89,194 ; vmulps %ymm2,%ymm8,%ymm8 + DB 197,108,89,202 ; vmulps %ymm2,%ymm2,%ymm9 + DB 196,66,109,168,220 ; vfmadd213ps %ymm12,%ymm2,%ymm11 + DB 196,66,53,168,222 ; vfmadd213ps %ymm14,%ymm9,%ymm11 + DB 196,193,108,194,210,1 ; vcmpltps %ymm10,%ymm2,%ymm2 + DB 196,195,37,74,208,32 ; vblendvps %ymm2,%ymm8,%ymm11,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_to_srgb_hsw _sk_to_srgb_hsw LABEL PROC - DB 197,124,82,192 ; vrsqrtps %ymm0,%ymm8 - DB 196,65,124,83,200 ; vrcpps %ymm8,%ymm9 - DB 196,65,124,82,208 ; vrsqrtps %ymm8,%ymm10 - DB 196,98,125,24,66,72 ; vbroadcastss 0x48(%rdx),%ymm8 - DB 197,60,89,216 ; vmulps %ymm0,%ymm8,%ymm11 - DB 196,98,125,24,34 ; vbroadcastss (%rdx),%ymm12 - DB 196,98,125,24,106,76 ; vbroadcastss 0x4c(%rdx),%ymm13 - DB 196,98,125,24,114,80 ; vbroadcastss 0x50(%rdx),%ymm14 - DB 196,98,125,24,122,84 ; vbroadcastss 0x54(%rdx),%ymm15 - DB 196,66,13,168,207 ; vfmadd213ps %ymm15,%ymm14,%ymm9 - DB 196,66,21,184,202 ; vfmadd231ps %ymm10,%ymm13,%ymm9 - DB 196,65,28,93,201 ; vminps %ymm9,%ymm12,%ymm9 - DB 196,98,125,24,82,88 ; vbroadcastss 0x58(%rdx),%ymm10 - DB 196,193,124,194,194,1 ; vcmpltps %ymm10,%ymm0,%ymm0 - DB 196,195,53,74,195,0 ; vblendvps %ymm0,%ymm11,%ymm9,%ymm0 - DB 197,124,82,201 ; vrsqrtps %ymm1,%ymm9 - DB 196,65,124,83,217 ; vrcpps %ymm9,%ymm11 - DB 196,65,124,82,201 ; vrsqrtps %ymm9,%ymm9 - DB 196,66,13,168,223 ; vfmadd213ps %ymm15,%ymm14,%ymm11 - DB 196,66,21,184,217 ; vfmadd231ps %ymm9,%ymm13,%ymm11 - DB 197,60,89,201 ; vmulps %ymm1,%ymm8,%ymm9 - DB 196,65,28,93,219 ; vminps %ymm11,%ymm12,%ymm11 - DB 196,193,116,194,202,1 ; vcmpltps %ymm10,%ymm1,%ymm1 - DB 196,195,37,74,201,16 ; vblendvps %ymm1,%ymm9,%ymm11,%ymm1 - DB 197,124,82,202 ; vrsqrtps %ymm2,%ymm9 - DB 196,65,124,83,217 ; vrcpps %ymm9,%ymm11 - DB 196,66,13,168,223 ; vfmadd213ps %ymm15,%ymm14,%ymm11 - DB 196,65,124,82,201 ; vrsqrtps %ymm9,%ymm9 - DB 196,66,21,184,217 ; vfmadd231ps %ymm9,%ymm13,%ymm11 - DB 196,65,28,93,203 ; vminps %ymm11,%ymm12,%ymm9 - DB 197,60,89,194 ; vmulps %ymm2,%ymm8,%ymm8 - DB 196,193,108,194,210,1 ; vcmpltps %ymm10,%ymm2,%ymm2 - DB 196,195,53,74,208,32 ; vblendvps %ymm2,%ymm8,%ymm9,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 197,124,82,192 ; vrsqrtps %ymm0,%ymm8 + DB 196,65,124,83,200 ; vrcpps %ymm8,%ymm9 + DB 196,65,124,82,208 ; vrsqrtps %ymm8,%ymm10 + DB 196,98,125,24,66,72 ; vbroadcastss 0x48(%rdx),%ymm8 + DB 197,60,89,216 ; vmulps %ymm0,%ymm8,%ymm11 + DB 196,98,125,24,34 ; vbroadcastss (%rdx),%ymm12 + DB 196,98,125,24,106,76 ; vbroadcastss 0x4c(%rdx),%ymm13 + DB 196,98,125,24,114,80 ; vbroadcastss 0x50(%rdx),%ymm14 + DB 196,98,125,24,122,84 ; vbroadcastss 0x54(%rdx),%ymm15 + DB 196,66,13,168,207 ; vfmadd213ps %ymm15,%ymm14,%ymm9 + DB 196,66,21,184,202 ; vfmadd231ps %ymm10,%ymm13,%ymm9 + DB 196,65,28,93,201 ; vminps %ymm9,%ymm12,%ymm9 + DB 196,98,125,24,82,88 ; vbroadcastss 0x58(%rdx),%ymm10 + DB 196,193,124,194,194,1 ; vcmpltps %ymm10,%ymm0,%ymm0 + DB 196,195,53,74,195,0 ; vblendvps %ymm0,%ymm11,%ymm9,%ymm0 + DB 197,124,82,201 ; vrsqrtps %ymm1,%ymm9 + DB 196,65,124,83,217 ; vrcpps %ymm9,%ymm11 + DB 196,65,124,82,201 ; vrsqrtps %ymm9,%ymm9 + DB 196,66,13,168,223 ; vfmadd213ps %ymm15,%ymm14,%ymm11 + DB 196,66,21,184,217 ; vfmadd231ps %ymm9,%ymm13,%ymm11 + DB 197,60,89,201 ; vmulps %ymm1,%ymm8,%ymm9 + DB 196,65,28,93,219 ; vminps %ymm11,%ymm12,%ymm11 + DB 196,193,116,194,202,1 ; vcmpltps %ymm10,%ymm1,%ymm1 + DB 196,195,37,74,201,16 ; vblendvps %ymm1,%ymm9,%ymm11,%ymm1 + DB 197,124,82,202 ; vrsqrtps %ymm2,%ymm9 + DB 196,65,124,83,217 ; vrcpps %ymm9,%ymm11 + DB 196,66,13,168,223 ; vfmadd213ps %ymm15,%ymm14,%ymm11 + DB 196,65,124,82,201 ; vrsqrtps %ymm9,%ymm9 + DB 196,66,21,184,217 ; vfmadd231ps %ymm9,%ymm13,%ymm11 + DB 196,65,28,93,203 ; vminps %ymm11,%ymm12,%ymm9 + DB 197,60,89,194 ; vmulps %ymm2,%ymm8,%ymm8 + DB 196,193,108,194,210,1 ; vcmpltps %ymm10,%ymm2,%ymm2 + DB 196,195,53,74,208,32 ; vblendvps %ymm2,%ymm8,%ymm9,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_scale_u8_hsw _sk_scale_u8_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 196,98,125,49,4,56 ; vpmovzxbd (%rax,%rdi,1),%ymm8 - DB 196,65,124,91,192 ; vcvtdq2ps %ymm8,%ymm8 - DB 196,98,125,24,74,12 ; vbroadcastss 0xc(%rdx),%ymm9 - DB 196,65,60,89,193 ; vmulps %ymm9,%ymm8,%ymm8 - DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 - DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 - DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 - DB 197,188,89,219 ; vmulps %ymm3,%ymm8,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 196,98,125,49,4,56 ; vpmovzxbd (%rax,%rdi,1),%ymm8 + DB 196,65,124,91,192 ; vcvtdq2ps %ymm8,%ymm8 + DB 196,98,125,24,74,12 ; vbroadcastss 0xc(%rdx),%ymm9 + DB 196,65,60,89,193 ; vmulps %ymm9,%ymm8,%ymm8 + DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 + DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 + DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 + DB 197,188,89,219 ; vmulps %ymm3,%ymm8,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_lerp_u8_hsw _sk_lerp_u8_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 196,98,125,49,4,56 ; vpmovzxbd (%rax,%rdi,1),%ymm8 - DB 196,65,124,91,192 ; vcvtdq2ps %ymm8,%ymm8 - DB 196,98,125,24,74,12 ; vbroadcastss 0xc(%rdx),%ymm9 - DB 196,65,60,89,193 ; vmulps %ymm9,%ymm8,%ymm8 - DB 197,252,92,196 ; vsubps %ymm4,%ymm0,%ymm0 - DB 196,226,61,168,196 ; vfmadd213ps %ymm4,%ymm8,%ymm0 - DB 197,244,92,205 ; vsubps %ymm5,%ymm1,%ymm1 - DB 196,226,61,168,205 ; vfmadd213ps %ymm5,%ymm8,%ymm1 - DB 197,236,92,214 ; vsubps %ymm6,%ymm2,%ymm2 - DB 196,226,61,168,214 ; vfmadd213ps %ymm6,%ymm8,%ymm2 - DB 197,228,92,223 ; vsubps %ymm7,%ymm3,%ymm3 - DB 196,226,61,168,223 ; vfmadd213ps %ymm7,%ymm8,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 196,98,125,49,4,56 ; vpmovzxbd (%rax,%rdi,1),%ymm8 + DB 196,65,124,91,192 ; vcvtdq2ps %ymm8,%ymm8 + DB 196,98,125,24,74,12 ; vbroadcastss 0xc(%rdx),%ymm9 + DB 196,65,60,89,193 ; vmulps %ymm9,%ymm8,%ymm8 + DB 197,252,92,196 ; vsubps %ymm4,%ymm0,%ymm0 + DB 196,226,61,168,196 ; vfmadd213ps %ymm4,%ymm8,%ymm0 + DB 197,244,92,205 ; vsubps %ymm5,%ymm1,%ymm1 + DB 196,226,61,168,205 ; vfmadd213ps %ymm5,%ymm8,%ymm1 + DB 197,236,92,214 ; vsubps %ymm6,%ymm2,%ymm2 + DB 196,226,61,168,214 ; vfmadd213ps %ymm6,%ymm8,%ymm2 + DB 197,228,92,223 ; vsubps %ymm7,%ymm3,%ymm3 + DB 196,226,61,168,223 ; vfmadd213ps %ymm7,%ymm8,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_tables_hsw _sk_load_tables_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,8 ; mov (%rax),%rcx - DB 76,139,64,8 ; mov 0x8(%rax),%r8 - DB 197,252,16,28,185 ; vmovups (%rcx,%rdi,4),%ymm3 - DB 196,226,125,24,82,16 ; vbroadcastss 0x10(%rdx),%ymm2 - DB 197,236,84,203 ; vandps %ymm3,%ymm2,%ymm1 - DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 - DB 197,124,194,192,0 ; vcmpeqps %ymm0,%ymm0,%ymm8 - DB 196,65,124,40,200 ; vmovaps %ymm8,%ymm9 - DB 196,194,53,146,4,136 ; vgatherdps %ymm9,(%r8,%ymm1,4),%ymm0 - DB 72,139,72,16 ; mov 0x10(%rax),%rcx - DB 197,245,114,211,8 ; vpsrld $0x8,%ymm3,%ymm1 - DB 197,108,84,201 ; vandps %ymm1,%ymm2,%ymm9 - DB 196,65,124,40,208 ; vmovaps %ymm8,%ymm10 - DB 196,162,45,146,12,137 ; vgatherdps %ymm10,(%rcx,%ymm9,4),%ymm1 - DB 72,139,64,24 ; mov 0x18(%rax),%rax - DB 197,181,114,211,16 ; vpsrld $0x10,%ymm3,%ymm9 - DB 196,65,108,84,201 ; vandps %ymm9,%ymm2,%ymm9 - DB 196,162,61,146,20,136 ; vgatherdps %ymm8,(%rax,%ymm9,4),%ymm2 - DB 197,229,114,211,24 ; vpsrld $0x18,%ymm3,%ymm3 - DB 197,252,91,219 ; vcvtdq2ps %ymm3,%ymm3 - DB 196,98,125,24,66,12 ; vbroadcastss 0xc(%rdx),%ymm8 - DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,8 ; mov (%rax),%rcx + DB 76,139,64,8 ; mov 0x8(%rax),%r8 + DB 197,252,16,28,185 ; vmovups (%rcx,%rdi,4),%ymm3 + DB 196,226,125,24,82,16 ; vbroadcastss 0x10(%rdx),%ymm2 + DB 197,236,84,203 ; vandps %ymm3,%ymm2,%ymm1 + DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 + DB 197,124,194,192,0 ; vcmpeqps %ymm0,%ymm0,%ymm8 + DB 196,65,124,40,200 ; vmovaps %ymm8,%ymm9 + DB 196,194,53,146,4,136 ; vgatherdps %ymm9,(%r8,%ymm1,4),%ymm0 + DB 72,139,72,16 ; mov 0x10(%rax),%rcx + DB 197,245,114,211,8 ; vpsrld $0x8,%ymm3,%ymm1 + DB 197,108,84,201 ; vandps %ymm1,%ymm2,%ymm9 + DB 196,65,124,40,208 ; vmovaps %ymm8,%ymm10 + DB 196,162,45,146,12,137 ; vgatherdps %ymm10,(%rcx,%ymm9,4),%ymm1 + DB 72,139,64,24 ; mov 0x18(%rax),%rax + DB 197,181,114,211,16 ; vpsrld $0x10,%ymm3,%ymm9 + DB 196,65,108,84,201 ; vandps %ymm9,%ymm2,%ymm9 + DB 196,162,61,146,20,136 ; vgatherdps %ymm8,(%rax,%ymm9,4),%ymm2 + DB 197,229,114,211,24 ; vpsrld $0x18,%ymm3,%ymm3 + DB 197,252,91,219 ; vcvtdq2ps %ymm3,%ymm3 + DB 196,98,125,24,66,12 ; vbroadcastss 0xc(%rdx),%ymm8 + DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_8888_hsw _sk_load_8888_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 197,252,16,28,184 ; vmovups (%rax,%rdi,4),%ymm3 - DB 196,226,125,24,82,16 ; vbroadcastss 0x10(%rdx),%ymm2 - DB 197,236,84,195 ; vandps %ymm3,%ymm2,%ymm0 - DB 197,252,91,192 ; vcvtdq2ps %ymm0,%ymm0 - DB 196,98,125,24,66,12 ; vbroadcastss 0xc(%rdx),%ymm8 - DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 - DB 197,245,114,211,8 ; vpsrld $0x8,%ymm3,%ymm1 - DB 197,236,84,201 ; vandps %ymm1,%ymm2,%ymm1 - DB 197,252,91,201 ; vcvtdq2ps %ymm1,%ymm1 - DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 - DB 197,181,114,211,16 ; vpsrld $0x10,%ymm3,%ymm9 - DB 196,193,108,84,209 ; vandps %ymm9,%ymm2,%ymm2 - DB 197,252,91,210 ; vcvtdq2ps %ymm2,%ymm2 - DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 - DB 197,229,114,211,24 ; vpsrld $0x18,%ymm3,%ymm3 - DB 197,252,91,219 ; vcvtdq2ps %ymm3,%ymm3 - DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 197,252,16,28,184 ; vmovups (%rax,%rdi,4),%ymm3 + DB 196,226,125,24,82,16 ; vbroadcastss 0x10(%rdx),%ymm2 + DB 197,236,84,195 ; vandps %ymm3,%ymm2,%ymm0 + DB 197,252,91,192 ; vcvtdq2ps %ymm0,%ymm0 + DB 196,98,125,24,66,12 ; vbroadcastss 0xc(%rdx),%ymm8 + DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 + DB 197,245,114,211,8 ; vpsrld $0x8,%ymm3,%ymm1 + DB 197,236,84,201 ; vandps %ymm1,%ymm2,%ymm1 + DB 197,252,91,201 ; vcvtdq2ps %ymm1,%ymm1 + DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 + DB 197,181,114,211,16 ; vpsrld $0x10,%ymm3,%ymm9 + DB 196,193,108,84,209 ; vandps %ymm9,%ymm2,%ymm2 + DB 197,252,91,210 ; vcvtdq2ps %ymm2,%ymm2 + DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 + DB 197,229,114,211,24 ; vpsrld $0x18,%ymm3,%ymm3 + DB 197,252,91,219 ; vcvtdq2ps %ymm3,%ymm3 + DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_store_8888_hsw _sk_store_8888_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 196,98,125,24,66,8 ; vbroadcastss 0x8(%rdx),%ymm8 - DB 197,60,89,200 ; vmulps %ymm0,%ymm8,%ymm9 - DB 196,65,125,91,201 ; vcvtps2dq %ymm9,%ymm9 - DB 197,60,89,209 ; vmulps %ymm1,%ymm8,%ymm10 - DB 196,65,125,91,210 ; vcvtps2dq %ymm10,%ymm10 - DB 196,193,45,114,242,8 ; vpslld $0x8,%ymm10,%ymm10 - DB 196,65,45,235,201 ; vpor %ymm9,%ymm10,%ymm9 - DB 197,60,89,210 ; vmulps %ymm2,%ymm8,%ymm10 - DB 196,65,125,91,210 ; vcvtps2dq %ymm10,%ymm10 - DB 196,193,45,114,242,16 ; vpslld $0x10,%ymm10,%ymm10 - DB 197,60,89,195 ; vmulps %ymm3,%ymm8,%ymm8 - DB 196,65,125,91,192 ; vcvtps2dq %ymm8,%ymm8 - DB 196,193,61,114,240,24 ; vpslld $0x18,%ymm8,%ymm8 - DB 196,65,45,235,192 ; vpor %ymm8,%ymm10,%ymm8 - DB 196,65,53,235,192 ; vpor %ymm8,%ymm9,%ymm8 - DB 197,126,127,4,184 ; vmovdqu %ymm8,(%rax,%rdi,4) - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 196,98,125,24,66,8 ; vbroadcastss 0x8(%rdx),%ymm8 + DB 197,60,89,200 ; vmulps %ymm0,%ymm8,%ymm9 + DB 196,65,125,91,201 ; vcvtps2dq %ymm9,%ymm9 + DB 197,60,89,209 ; vmulps %ymm1,%ymm8,%ymm10 + DB 196,65,125,91,210 ; vcvtps2dq %ymm10,%ymm10 + DB 196,193,45,114,242,8 ; vpslld $0x8,%ymm10,%ymm10 + DB 196,65,45,235,201 ; vpor %ymm9,%ymm10,%ymm9 + DB 197,60,89,210 ; vmulps %ymm2,%ymm8,%ymm10 + DB 196,65,125,91,210 ; vcvtps2dq %ymm10,%ymm10 + DB 196,193,45,114,242,16 ; vpslld $0x10,%ymm10,%ymm10 + DB 197,60,89,195 ; vmulps %ymm3,%ymm8,%ymm8 + DB 196,65,125,91,192 ; vcvtps2dq %ymm8,%ymm8 + DB 196,193,61,114,240,24 ; vpslld $0x18,%ymm8,%ymm8 + DB 196,65,45,235,192 ; vpor %ymm8,%ymm10,%ymm8 + DB 196,65,53,235,192 ; vpor %ymm8,%ymm9,%ymm8 + DB 197,126,127,4,184 ; vmovdqu %ymm8,(%rax,%rdi,4) + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_f16_hsw _sk_load_f16_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 197,250,111,4,248 ; vmovdqu (%rax,%rdi,8),%xmm0 - DB 197,250,111,76,248,16 ; vmovdqu 0x10(%rax,%rdi,8),%xmm1 - DB 197,250,111,84,248,32 ; vmovdqu 0x20(%rax,%rdi,8),%xmm2 - DB 197,250,111,92,248,48 ; vmovdqu 0x30(%rax,%rdi,8),%xmm3 - DB 197,121,97,193 ; vpunpcklwd %xmm1,%xmm0,%xmm8 - DB 197,249,105,193 ; vpunpckhwd %xmm1,%xmm0,%xmm0 - DB 197,233,97,203 ; vpunpcklwd %xmm3,%xmm2,%xmm1 - DB 197,233,105,211 ; vpunpckhwd %xmm3,%xmm2,%xmm2 - DB 197,57,97,200 ; vpunpcklwd %xmm0,%xmm8,%xmm9 - DB 197,57,105,192 ; vpunpckhwd %xmm0,%xmm8,%xmm8 - DB 197,241,97,218 ; vpunpcklwd %xmm2,%xmm1,%xmm3 - DB 197,113,105,210 ; vpunpckhwd %xmm2,%xmm1,%xmm10 - DB 197,177,108,195 ; vpunpcklqdq %xmm3,%xmm9,%xmm0 - DB 196,226,125,19,192 ; vcvtph2ps %xmm0,%ymm0 - DB 197,177,109,203 ; vpunpckhqdq %xmm3,%xmm9,%xmm1 - DB 196,226,125,19,201 ; vcvtph2ps %xmm1,%ymm1 - DB 196,193,57,108,210 ; vpunpcklqdq %xmm10,%xmm8,%xmm2 - DB 196,226,125,19,210 ; vcvtph2ps %xmm2,%ymm2 - DB 196,193,57,109,218 ; vpunpckhqdq %xmm10,%xmm8,%xmm3 - DB 196,226,125,19,219 ; vcvtph2ps %xmm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 197,250,111,4,248 ; vmovdqu (%rax,%rdi,8),%xmm0 + DB 197,250,111,76,248,16 ; vmovdqu 0x10(%rax,%rdi,8),%xmm1 + DB 197,250,111,84,248,32 ; vmovdqu 0x20(%rax,%rdi,8),%xmm2 + DB 197,250,111,92,248,48 ; vmovdqu 0x30(%rax,%rdi,8),%xmm3 + DB 197,121,97,193 ; vpunpcklwd %xmm1,%xmm0,%xmm8 + DB 197,249,105,193 ; vpunpckhwd %xmm1,%xmm0,%xmm0 + DB 197,233,97,203 ; vpunpcklwd %xmm3,%xmm2,%xmm1 + DB 197,233,105,211 ; vpunpckhwd %xmm3,%xmm2,%xmm2 + DB 197,57,97,200 ; vpunpcklwd %xmm0,%xmm8,%xmm9 + DB 197,57,105,192 ; vpunpckhwd %xmm0,%xmm8,%xmm8 + DB 197,241,97,218 ; vpunpcklwd %xmm2,%xmm1,%xmm3 + DB 197,113,105,210 ; vpunpckhwd %xmm2,%xmm1,%xmm10 + DB 197,177,108,195 ; vpunpcklqdq %xmm3,%xmm9,%xmm0 + DB 196,226,125,19,192 ; vcvtph2ps %xmm0,%ymm0 + DB 197,177,109,203 ; vpunpckhqdq %xmm3,%xmm9,%xmm1 + DB 196,226,125,19,201 ; vcvtph2ps %xmm1,%ymm1 + DB 196,193,57,108,210 ; vpunpcklqdq %xmm10,%xmm8,%xmm2 + DB 196,226,125,19,210 ; vcvtph2ps %xmm2,%ymm2 + DB 196,193,57,109,218 ; vpunpckhqdq %xmm10,%xmm8,%xmm3 + DB 196,226,125,19,219 ; vcvtph2ps %xmm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_store_f16_hsw _sk_store_f16_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 196,195,125,29,192,4 ; vcvtps2ph $0x4,%ymm0,%xmm8 - DB 196,195,125,29,201,4 ; vcvtps2ph $0x4,%ymm1,%xmm9 - DB 196,195,125,29,210,4 ; vcvtps2ph $0x4,%ymm2,%xmm10 - DB 196,195,125,29,219,4 ; vcvtps2ph $0x4,%ymm3,%xmm11 - DB 196,65,57,97,225 ; vpunpcklwd %xmm9,%xmm8,%xmm12 - DB 196,65,57,105,193 ; vpunpckhwd %xmm9,%xmm8,%xmm8 - DB 196,65,41,97,203 ; vpunpcklwd %xmm11,%xmm10,%xmm9 - DB 196,65,41,105,211 ; vpunpckhwd %xmm11,%xmm10,%xmm10 - DB 196,65,25,98,217 ; vpunpckldq %xmm9,%xmm12,%xmm11 - DB 197,122,127,28,248 ; vmovdqu %xmm11,(%rax,%rdi,8) - DB 196,65,25,106,201 ; vpunpckhdq %xmm9,%xmm12,%xmm9 - DB 197,122,127,76,248,16 ; vmovdqu %xmm9,0x10(%rax,%rdi,8) - DB 196,65,57,98,202 ; vpunpckldq %xmm10,%xmm8,%xmm9 - DB 197,122,127,76,248,32 ; vmovdqu %xmm9,0x20(%rax,%rdi,8) - DB 196,65,57,106,194 ; vpunpckhdq %xmm10,%xmm8,%xmm8 - DB 197,122,127,68,248,48 ; vmovdqu %xmm8,0x30(%rax,%rdi,8) - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 196,195,125,29,192,4 ; vcvtps2ph $0x4,%ymm0,%xmm8 + DB 196,195,125,29,201,4 ; vcvtps2ph $0x4,%ymm1,%xmm9 + DB 196,195,125,29,210,4 ; vcvtps2ph $0x4,%ymm2,%xmm10 + DB 196,195,125,29,219,4 ; vcvtps2ph $0x4,%ymm3,%xmm11 + DB 196,65,57,97,225 ; vpunpcklwd %xmm9,%xmm8,%xmm12 + DB 196,65,57,105,193 ; vpunpckhwd %xmm9,%xmm8,%xmm8 + DB 196,65,41,97,203 ; vpunpcklwd %xmm11,%xmm10,%xmm9 + DB 196,65,41,105,211 ; vpunpckhwd %xmm11,%xmm10,%xmm10 + DB 196,65,25,98,217 ; vpunpckldq %xmm9,%xmm12,%xmm11 + DB 197,122,127,28,248 ; vmovdqu %xmm11,(%rax,%rdi,8) + DB 196,65,25,106,201 ; vpunpckhdq %xmm9,%xmm12,%xmm9 + DB 197,122,127,76,248,16 ; vmovdqu %xmm9,0x10(%rax,%rdi,8) + DB 196,65,57,98,202 ; vpunpckldq %xmm10,%xmm8,%xmm9 + DB 197,122,127,76,248,32 ; vmovdqu %xmm9,0x20(%rax,%rdi,8) + DB 196,65,57,106,194 ; vpunpckhdq %xmm10,%xmm8,%xmm8 + DB 197,122,127,68,248,48 ; vmovdqu %xmm8,0x30(%rax,%rdi,8) + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_x_hsw _sk_clamp_x_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,88,0 ; vpbroadcastd (%rax),%ymm8 - DB 196,65,53,118,201 ; vpcmpeqd %ymm9,%ymm9,%ymm9 - DB 196,65,61,254,193 ; vpaddd %ymm9,%ymm8,%ymm8 - DB 196,193,124,93,192 ; vminps %ymm8,%ymm0,%ymm0 - DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 - DB 197,188,95,192 ; vmaxps %ymm0,%ymm8,%ymm0 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,88,0 ; vpbroadcastd (%rax),%ymm8 + DB 196,65,53,118,201 ; vpcmpeqd %ymm9,%ymm9,%ymm9 + DB 196,65,61,254,193 ; vpaddd %ymm9,%ymm8,%ymm8 + DB 196,193,124,93,192 ; vminps %ymm8,%ymm0,%ymm0 + DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 + DB 197,188,95,192 ; vmaxps %ymm0,%ymm8,%ymm0 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_y_hsw _sk_clamp_y_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,88,0 ; vpbroadcastd (%rax),%ymm8 - DB 196,65,53,118,201 ; vpcmpeqd %ymm9,%ymm9,%ymm9 - DB 196,65,61,254,193 ; vpaddd %ymm9,%ymm8,%ymm8 - DB 196,193,116,93,200 ; vminps %ymm8,%ymm1,%ymm1 - DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 - DB 197,188,95,201 ; vmaxps %ymm1,%ymm8,%ymm1 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,88,0 ; vpbroadcastd (%rax),%ymm8 + DB 196,65,53,118,201 ; vpcmpeqd %ymm9,%ymm9,%ymm9 + DB 196,65,61,254,193 ; vpaddd %ymm9,%ymm8,%ymm8 + DB 196,193,116,93,200 ; vminps %ymm8,%ymm1,%ymm1 + DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 + DB 197,188,95,201 ; vmaxps %ymm1,%ymm8,%ymm1 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_matrix_2x3_hsw _sk_matrix_2x3_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,8 ; vbroadcastss (%rax),%ymm9 - DB 196,98,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm10 - DB 196,98,125,24,64,16 ; vbroadcastss 0x10(%rax),%ymm8 - DB 196,66,117,184,194 ; vfmadd231ps %ymm10,%ymm1,%ymm8 - DB 196,66,125,184,193 ; vfmadd231ps %ymm9,%ymm0,%ymm8 - DB 196,98,125,24,80,4 ; vbroadcastss 0x4(%rax),%ymm10 - DB 196,98,125,24,88,12 ; vbroadcastss 0xc(%rax),%ymm11 - DB 196,98,125,24,72,20 ; vbroadcastss 0x14(%rax),%ymm9 - DB 196,66,117,184,203 ; vfmadd231ps %ymm11,%ymm1,%ymm9 - DB 196,66,125,184,202 ; vfmadd231ps %ymm10,%ymm0,%ymm9 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 - DB 197,124,41,201 ; vmovaps %ymm9,%ymm1 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,8 ; vbroadcastss (%rax),%ymm9 + DB 196,98,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm10 + DB 196,98,125,24,64,16 ; vbroadcastss 0x10(%rax),%ymm8 + DB 196,66,117,184,194 ; vfmadd231ps %ymm10,%ymm1,%ymm8 + DB 196,66,125,184,193 ; vfmadd231ps %ymm9,%ymm0,%ymm8 + DB 196,98,125,24,80,4 ; vbroadcastss 0x4(%rax),%ymm10 + DB 196,98,125,24,88,12 ; vbroadcastss 0xc(%rax),%ymm11 + DB 196,98,125,24,72,20 ; vbroadcastss 0x14(%rax),%ymm9 + DB 196,66,117,184,203 ; vfmadd231ps %ymm11,%ymm1,%ymm9 + DB 196,66,125,184,202 ; vfmadd231ps %ymm10,%ymm0,%ymm9 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 + DB 197,124,41,201 ; vmovaps %ymm9,%ymm1 + DB 255,224 ; jmpq *%rax PUBLIC _sk_matrix_3x4_hsw _sk_matrix_3x4_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,8 ; vbroadcastss (%rax),%ymm9 - DB 196,98,125,24,80,12 ; vbroadcastss 0xc(%rax),%ymm10 - DB 196,98,125,24,88,24 ; vbroadcastss 0x18(%rax),%ymm11 - DB 196,98,125,24,64,36 ; vbroadcastss 0x24(%rax),%ymm8 - DB 196,66,109,184,195 ; vfmadd231ps %ymm11,%ymm2,%ymm8 - DB 196,66,117,184,194 ; vfmadd231ps %ymm10,%ymm1,%ymm8 - DB 196,66,125,184,193 ; vfmadd231ps %ymm9,%ymm0,%ymm8 - DB 196,98,125,24,80,4 ; vbroadcastss 0x4(%rax),%ymm10 - DB 196,98,125,24,88,16 ; vbroadcastss 0x10(%rax),%ymm11 - DB 196,98,125,24,96,28 ; vbroadcastss 0x1c(%rax),%ymm12 - DB 196,98,125,24,72,40 ; vbroadcastss 0x28(%rax),%ymm9 - DB 196,66,109,184,204 ; vfmadd231ps %ymm12,%ymm2,%ymm9 - DB 196,66,117,184,203 ; vfmadd231ps %ymm11,%ymm1,%ymm9 - DB 196,66,125,184,202 ; vfmadd231ps %ymm10,%ymm0,%ymm9 - DB 196,98,125,24,88,8 ; vbroadcastss 0x8(%rax),%ymm11 - DB 196,98,125,24,96,20 ; vbroadcastss 0x14(%rax),%ymm12 - DB 196,98,125,24,104,32 ; vbroadcastss 0x20(%rax),%ymm13 - DB 196,98,125,24,80,44 ; vbroadcastss 0x2c(%rax),%ymm10 - DB 196,66,109,184,213 ; vfmadd231ps %ymm13,%ymm2,%ymm10 - DB 196,66,117,184,212 ; vfmadd231ps %ymm12,%ymm1,%ymm10 - DB 196,66,125,184,211 ; vfmadd231ps %ymm11,%ymm0,%ymm10 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 - DB 197,124,41,201 ; vmovaps %ymm9,%ymm1 - DB 197,124,41,210 ; vmovaps %ymm10,%ymm2 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,8 ; vbroadcastss (%rax),%ymm9 + DB 196,98,125,24,80,12 ; vbroadcastss 0xc(%rax),%ymm10 + DB 196,98,125,24,88,24 ; vbroadcastss 0x18(%rax),%ymm11 + DB 196,98,125,24,64,36 ; vbroadcastss 0x24(%rax),%ymm8 + DB 196,66,109,184,195 ; vfmadd231ps %ymm11,%ymm2,%ymm8 + DB 196,66,117,184,194 ; vfmadd231ps %ymm10,%ymm1,%ymm8 + DB 196,66,125,184,193 ; vfmadd231ps %ymm9,%ymm0,%ymm8 + DB 196,98,125,24,80,4 ; vbroadcastss 0x4(%rax),%ymm10 + DB 196,98,125,24,88,16 ; vbroadcastss 0x10(%rax),%ymm11 + DB 196,98,125,24,96,28 ; vbroadcastss 0x1c(%rax),%ymm12 + DB 196,98,125,24,72,40 ; vbroadcastss 0x28(%rax),%ymm9 + DB 196,66,109,184,204 ; vfmadd231ps %ymm12,%ymm2,%ymm9 + DB 196,66,117,184,203 ; vfmadd231ps %ymm11,%ymm1,%ymm9 + DB 196,66,125,184,202 ; vfmadd231ps %ymm10,%ymm0,%ymm9 + DB 196,98,125,24,88,8 ; vbroadcastss 0x8(%rax),%ymm11 + DB 196,98,125,24,96,20 ; vbroadcastss 0x14(%rax),%ymm12 + DB 196,98,125,24,104,32 ; vbroadcastss 0x20(%rax),%ymm13 + DB 196,98,125,24,80,44 ; vbroadcastss 0x2c(%rax),%ymm10 + DB 196,66,109,184,213 ; vfmadd231ps %ymm13,%ymm2,%ymm10 + DB 196,66,117,184,212 ; vfmadd231ps %ymm12,%ymm1,%ymm10 + DB 196,66,125,184,211 ; vfmadd231ps %ymm11,%ymm0,%ymm10 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 + DB 197,124,41,201 ; vmovaps %ymm9,%ymm1 + DB 197,124,41,210 ; vmovaps %ymm10,%ymm2 + DB 255,224 ; jmpq *%rax PUBLIC _sk_linear_gradient_2stops_hsw _sk_linear_gradient_2stops_hsw LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,226,125,24,72,16 ; vbroadcastss 0x10(%rax),%ymm1 - DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 - DB 196,98,125,184,193 ; vfmadd231ps %ymm1,%ymm0,%ymm8 - DB 196,226,125,24,80,20 ; vbroadcastss 0x14(%rax),%ymm2 - DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 - DB 196,226,125,184,202 ; vfmadd231ps %ymm2,%ymm0,%ymm1 - DB 196,226,125,24,88,24 ; vbroadcastss 0x18(%rax),%ymm3 - DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 - DB 196,226,125,184,211 ; vfmadd231ps %ymm3,%ymm0,%ymm2 - DB 196,98,125,24,72,28 ; vbroadcastss 0x1c(%rax),%ymm9 - DB 196,226,125,24,88,12 ; vbroadcastss 0xc(%rax),%ymm3 - DB 196,194,125,184,217 ; vfmadd231ps %ymm9,%ymm0,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,226,125,24,72,16 ; vbroadcastss 0x10(%rax),%ymm1 + DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 + DB 196,98,125,184,193 ; vfmadd231ps %ymm1,%ymm0,%ymm8 + DB 196,226,125,24,80,20 ; vbroadcastss 0x14(%rax),%ymm2 + DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 + DB 196,226,125,184,202 ; vfmadd231ps %ymm2,%ymm0,%ymm1 + DB 196,226,125,24,88,24 ; vbroadcastss 0x18(%rax),%ymm3 + DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 + DB 196,226,125,184,211 ; vfmadd231ps %ymm3,%ymm0,%ymm2 + DB 196,98,125,24,72,28 ; vbroadcastss 0x1c(%rax),%ymm9 + DB 196,226,125,24,88,12 ; vbroadcastss 0xc(%rax),%ymm3 + DB 196,194,125,184,217 ; vfmadd231ps %ymm9,%ymm0,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 + DB 255,224 ; jmpq *%rax PUBLIC _sk_start_pipeline_avx _sk_start_pipeline_avx LABEL PROC - DB 65,87 ; push %r15 - DB 65,86 ; push %r14 - DB 65,85 ; push %r13 - DB 65,84 ; push %r12 - DB 86 ; push %rsi - DB 87 ; push %rdi - DB 83 ; push %rbx - DB 72,129,236,160,0,0,0 ; sub $0xa0,%rsp - DB 197,120,41,188,36,144,0,0,0 ; vmovaps %xmm15,0x90(%rsp) - DB 197,120,41,180,36,128,0,0,0 ; vmovaps %xmm14,0x80(%rsp) - DB 197,120,41,108,36,112 ; vmovaps %xmm13,0x70(%rsp) - DB 197,120,41,100,36,96 ; vmovaps %xmm12,0x60(%rsp) - DB 197,120,41,92,36,80 ; vmovaps %xmm11,0x50(%rsp) - DB 197,120,41,84,36,64 ; vmovaps %xmm10,0x40(%rsp) - DB 197,120,41,76,36,48 ; vmovaps %xmm9,0x30(%rsp) - DB 197,120,41,68,36,32 ; vmovaps %xmm8,0x20(%rsp) - DB 197,248,41,124,36,16 ; vmovaps %xmm7,0x10(%rsp) - DB 197,248,41,52,36 ; vmovaps %xmm6,(%rsp) - DB 77,137,207 ; mov %r9,%r15 - DB 77,137,198 ; mov %r8,%r14 - DB 72,137,203 ; mov %rcx,%rbx - DB 72,137,214 ; mov %rdx,%rsi - DB 72,173 ; lods %ds:(%rsi),%rax - DB 73,137,196 ; mov %rax,%r12 - DB 73,137,245 ; mov %rsi,%r13 - DB 72,141,67,8 ; lea 0x8(%rbx),%rax - DB 76,57,248 ; cmp %r15,%rax - DB 118,5 ; jbe 75 <_sk_start_pipeline_avx+0x75> - DB 72,137,216 ; mov %rbx,%rax - DB 235,60 ; jmp b1 <_sk_start_pipeline_avx+0xb1> - DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 - DB 197,244,87,201 ; vxorps %ymm1,%ymm1,%ymm1 - DB 197,236,87,210 ; vxorps %ymm2,%ymm2,%ymm2 - DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 - DB 197,220,87,228 ; vxorps %ymm4,%ymm4,%ymm4 - DB 197,212,87,237 ; vxorps %ymm5,%ymm5,%ymm5 - DB 197,204,87,246 ; vxorps %ymm6,%ymm6,%ymm6 - DB 197,196,87,255 ; vxorps %ymm7,%ymm7,%ymm7 - DB 72,137,223 ; mov %rbx,%rdi - DB 76,137,238 ; mov %r13,%rsi - DB 76,137,242 ; mov %r14,%rdx - DB 65,255,212 ; callq *%r12 - DB 72,141,67,8 ; lea 0x8(%rbx),%rax - DB 72,131,195,16 ; add $0x10,%rbx - DB 76,57,251 ; cmp %r15,%rbx - DB 72,137,195 ; mov %rax,%rbx - DB 118,196 ; jbe 75 <_sk_start_pipeline_avx+0x75> - DB 197,248,40,52,36 ; vmovaps (%rsp),%xmm6 - DB 197,248,40,124,36,16 ; vmovaps 0x10(%rsp),%xmm7 - DB 197,120,40,68,36,32 ; vmovaps 0x20(%rsp),%xmm8 - DB 197,120,40,76,36,48 ; vmovaps 0x30(%rsp),%xmm9 - DB 197,120,40,84,36,64 ; vmovaps 0x40(%rsp),%xmm10 - DB 197,120,40,92,36,80 ; vmovaps 0x50(%rsp),%xmm11 - DB 197,120,40,100,36,96 ; vmovaps 0x60(%rsp),%xmm12 - DB 197,120,40,108,36,112 ; vmovaps 0x70(%rsp),%xmm13 - DB 197,120,40,180,36,128,0,0,0 ; vmovaps 0x80(%rsp),%xmm14 - DB 197,120,40,188,36,144,0,0,0 ; vmovaps 0x90(%rsp),%xmm15 - DB 72,129,196,160,0,0,0 ; add $0xa0,%rsp - DB 91 ; pop %rbx - DB 95 ; pop %rdi - DB 94 ; pop %rsi - DB 65,92 ; pop %r12 - DB 65,93 ; pop %r13 - DB 65,94 ; pop %r14 - DB 65,95 ; pop %r15 - DB 197,248,119 ; vzeroupper - DB 195 ; retq + DB 65,87 ; push %r15 + DB 65,86 ; push %r14 + DB 65,85 ; push %r13 + DB 65,84 ; push %r12 + DB 86 ; push %rsi + DB 87 ; push %rdi + DB 83 ; push %rbx + DB 72,129,236,160,0,0,0 ; sub $0xa0,%rsp + DB 197,120,41,188,36,144,0,0,0 ; vmovaps %xmm15,0x90(%rsp) + DB 197,120,41,180,36,128,0,0,0 ; vmovaps %xmm14,0x80(%rsp) + DB 197,120,41,108,36,112 ; vmovaps %xmm13,0x70(%rsp) + DB 197,120,41,100,36,96 ; vmovaps %xmm12,0x60(%rsp) + DB 197,120,41,92,36,80 ; vmovaps %xmm11,0x50(%rsp) + DB 197,120,41,84,36,64 ; vmovaps %xmm10,0x40(%rsp) + DB 197,120,41,76,36,48 ; vmovaps %xmm9,0x30(%rsp) + DB 197,120,41,68,36,32 ; vmovaps %xmm8,0x20(%rsp) + DB 197,248,41,124,36,16 ; vmovaps %xmm7,0x10(%rsp) + DB 197,248,41,52,36 ; vmovaps %xmm6,(%rsp) + DB 77,137,207 ; mov %r9,%r15 + DB 77,137,198 ; mov %r8,%r14 + DB 72,137,203 ; mov %rcx,%rbx + DB 72,137,214 ; mov %rdx,%rsi + DB 72,173 ; lods %ds:(%rsi),%rax + DB 73,137,196 ; mov %rax,%r12 + DB 73,137,245 ; mov %rsi,%r13 + DB 72,141,67,8 ; lea 0x8(%rbx),%rax + DB 76,57,248 ; cmp %r15,%rax + DB 118,5 ; jbe 75 <_sk_start_pipeline_avx+0x75> + DB 72,137,216 ; mov %rbx,%rax + DB 235,60 ; jmp b1 <_sk_start_pipeline_avx+0xb1> + DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 + DB 197,244,87,201 ; vxorps %ymm1,%ymm1,%ymm1 + DB 197,236,87,210 ; vxorps %ymm2,%ymm2,%ymm2 + DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 + DB 197,220,87,228 ; vxorps %ymm4,%ymm4,%ymm4 + DB 197,212,87,237 ; vxorps %ymm5,%ymm5,%ymm5 + DB 197,204,87,246 ; vxorps %ymm6,%ymm6,%ymm6 + DB 197,196,87,255 ; vxorps %ymm7,%ymm7,%ymm7 + DB 72,137,223 ; mov %rbx,%rdi + DB 76,137,238 ; mov %r13,%rsi + DB 76,137,242 ; mov %r14,%rdx + DB 65,255,212 ; callq *%r12 + DB 72,141,67,8 ; lea 0x8(%rbx),%rax + DB 72,131,195,16 ; add $0x10,%rbx + DB 76,57,251 ; cmp %r15,%rbx + DB 72,137,195 ; mov %rax,%rbx + DB 118,196 ; jbe 75 <_sk_start_pipeline_avx+0x75> + DB 197,248,40,52,36 ; vmovaps (%rsp),%xmm6 + DB 197,248,40,124,36,16 ; vmovaps 0x10(%rsp),%xmm7 + DB 197,120,40,68,36,32 ; vmovaps 0x20(%rsp),%xmm8 + DB 197,120,40,76,36,48 ; vmovaps 0x30(%rsp),%xmm9 + DB 197,120,40,84,36,64 ; vmovaps 0x40(%rsp),%xmm10 + DB 197,120,40,92,36,80 ; vmovaps 0x50(%rsp),%xmm11 + DB 197,120,40,100,36,96 ; vmovaps 0x60(%rsp),%xmm12 + DB 197,120,40,108,36,112 ; vmovaps 0x70(%rsp),%xmm13 + DB 197,120,40,180,36,128,0,0,0 ; vmovaps 0x80(%rsp),%xmm14 + DB 197,120,40,188,36,144,0,0,0 ; vmovaps 0x90(%rsp),%xmm15 + DB 72,129,196,160,0,0,0 ; add $0xa0,%rsp + DB 91 ; pop %rbx + DB 95 ; pop %rdi + DB 94 ; pop %rsi + DB 65,92 ; pop %r12 + DB 65,93 ; pop %r13 + DB 65,94 ; pop %r14 + DB 65,95 ; pop %r15 + DB 197,248,119 ; vzeroupper + DB 195 ; retq PUBLIC _sk_just_return_avx _sk_just_return_avx LABEL PROC - DB 195 ; retq + DB 195 ; retq PUBLIC _sk_seed_shader_avx _sk_seed_shader_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,249,110,199 ; vmovd %edi,%xmm0 - DB 196,227,121,4,192,0 ; vpermilps $0x0,%xmm0,%xmm0 - DB 196,227,125,24,192,1 ; vinsertf128 $0x1,%xmm0,%ymm0,%ymm0 - DB 197,252,91,192 ; vcvtdq2ps %ymm0,%ymm0 - DB 196,226,125,24,74,4 ; vbroadcastss 0x4(%rdx),%ymm1 - DB 197,252,88,193 ; vaddps %ymm1,%ymm0,%ymm0 - DB 197,252,88,66,20 ; vaddps 0x14(%rdx),%ymm0,%ymm0 - DB 197,249,110,16 ; vmovd (%rax),%xmm2 - DB 196,227,121,4,210,0 ; vpermilps $0x0,%xmm2,%xmm2 - DB 196,227,109,24,210,1 ; vinsertf128 $0x1,%xmm2,%ymm2,%ymm2 - DB 197,252,91,210 ; vcvtdq2ps %ymm2,%ymm2 - DB 197,236,88,201 ; vaddps %ymm1,%ymm2,%ymm1 - DB 196,226,125,24,18 ; vbroadcastss (%rdx),%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 - DB 197,220,87,228 ; vxorps %ymm4,%ymm4,%ymm4 - DB 197,212,87,237 ; vxorps %ymm5,%ymm5,%ymm5 - DB 197,204,87,246 ; vxorps %ymm6,%ymm6,%ymm6 - DB 197,196,87,255 ; vxorps %ymm7,%ymm7,%ymm7 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,249,110,199 ; vmovd %edi,%xmm0 + DB 196,227,121,4,192,0 ; vpermilps $0x0,%xmm0,%xmm0 + DB 196,227,125,24,192,1 ; vinsertf128 $0x1,%xmm0,%ymm0,%ymm0 + DB 197,252,91,192 ; vcvtdq2ps %ymm0,%ymm0 + DB 196,226,125,24,74,4 ; vbroadcastss 0x4(%rdx),%ymm1 + DB 197,252,88,193 ; vaddps %ymm1,%ymm0,%ymm0 + DB 197,252,88,66,20 ; vaddps 0x14(%rdx),%ymm0,%ymm0 + DB 197,249,110,16 ; vmovd (%rax),%xmm2 + DB 196,227,121,4,210,0 ; vpermilps $0x0,%xmm2,%xmm2 + DB 196,227,109,24,210,1 ; vinsertf128 $0x1,%xmm2,%ymm2,%ymm2 + DB 197,252,91,210 ; vcvtdq2ps %ymm2,%ymm2 + DB 197,236,88,201 ; vaddps %ymm1,%ymm2,%ymm1 + DB 196,226,125,24,18 ; vbroadcastss (%rdx),%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 + DB 197,220,87,228 ; vxorps %ymm4,%ymm4,%ymm4 + DB 197,212,87,237 ; vxorps %ymm5,%ymm5,%ymm5 + DB 197,204,87,246 ; vxorps %ymm6,%ymm6,%ymm6 + DB 197,196,87,255 ; vxorps %ymm7,%ymm7,%ymm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_constant_color_avx _sk_constant_color_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,226,125,24,0 ; vbroadcastss (%rax),%ymm0 - DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 - DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 - DB 196,226,125,24,88,12 ; vbroadcastss 0xc(%rax),%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,226,125,24,0 ; vbroadcastss (%rax),%ymm0 + DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 + DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 + DB 196,226,125,24,88,12 ; vbroadcastss 0xc(%rax),%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clear_avx _sk_clear_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 - DB 197,244,87,201 ; vxorps %ymm1,%ymm1,%ymm1 - DB 197,236,87,210 ; vxorps %ymm2,%ymm2,%ymm2 - DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,87,192 ; vxorps %ymm0,%ymm0,%ymm0 + DB 197,244,87,201 ; vxorps %ymm1,%ymm1,%ymm1 + DB 197,236,87,210 ; vxorps %ymm2,%ymm2,%ymm2 + DB 197,228,87,219 ; vxorps %ymm3,%ymm3,%ymm3 + DB 255,224 ; jmpq *%rax PUBLIC _sk_plus__avx _sk_plus__avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,88,196 ; vaddps %ymm4,%ymm0,%ymm0 - DB 197,244,88,205 ; vaddps %ymm5,%ymm1,%ymm1 - DB 197,236,88,214 ; vaddps %ymm6,%ymm2,%ymm2 - DB 197,228,88,223 ; vaddps %ymm7,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,88,196 ; vaddps %ymm4,%ymm0,%ymm0 + DB 197,244,88,205 ; vaddps %ymm5,%ymm1,%ymm1 + DB 197,236,88,214 ; vaddps %ymm6,%ymm2,%ymm2 + DB 197,228,88,223 ; vaddps %ymm7,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_srcover_avx _sk_srcover_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 - DB 197,60,92,195 ; vsubps %ymm3,%ymm8,%ymm8 - DB 197,60,89,204 ; vmulps %ymm4,%ymm8,%ymm9 - DB 197,180,88,192 ; vaddps %ymm0,%ymm9,%ymm0 - DB 197,60,89,205 ; vmulps %ymm5,%ymm8,%ymm9 - DB 197,180,88,201 ; vaddps %ymm1,%ymm9,%ymm1 - DB 197,60,89,206 ; vmulps %ymm6,%ymm8,%ymm9 - DB 197,180,88,210 ; vaddps %ymm2,%ymm9,%ymm2 - DB 197,60,89,199 ; vmulps %ymm7,%ymm8,%ymm8 - DB 197,188,88,219 ; vaddps %ymm3,%ymm8,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 + DB 197,60,92,195 ; vsubps %ymm3,%ymm8,%ymm8 + DB 197,60,89,204 ; vmulps %ymm4,%ymm8,%ymm9 + DB 197,180,88,192 ; vaddps %ymm0,%ymm9,%ymm0 + DB 197,60,89,205 ; vmulps %ymm5,%ymm8,%ymm9 + DB 197,180,88,201 ; vaddps %ymm1,%ymm9,%ymm1 + DB 197,60,89,206 ; vmulps %ymm6,%ymm8,%ymm9 + DB 197,180,88,210 ; vaddps %ymm2,%ymm9,%ymm2 + DB 197,60,89,199 ; vmulps %ymm7,%ymm8,%ymm8 + DB 197,188,88,219 ; vaddps %ymm3,%ymm8,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_dstover_avx _sk_dstover_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 - DB 197,60,92,199 ; vsubps %ymm7,%ymm8,%ymm8 - DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 - DB 197,252,88,196 ; vaddps %ymm4,%ymm0,%ymm0 - DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 - DB 197,244,88,205 ; vaddps %ymm5,%ymm1,%ymm1 - DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 - DB 197,236,88,214 ; vaddps %ymm6,%ymm2,%ymm2 - DB 197,188,89,219 ; vmulps %ymm3,%ymm8,%ymm3 - DB 197,228,88,223 ; vaddps %ymm7,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 + DB 197,60,92,199 ; vsubps %ymm7,%ymm8,%ymm8 + DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 + DB 197,252,88,196 ; vaddps %ymm4,%ymm0,%ymm0 + DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 + DB 197,244,88,205 ; vaddps %ymm5,%ymm1,%ymm1 + DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 + DB 197,236,88,214 ; vaddps %ymm6,%ymm2,%ymm2 + DB 197,188,89,219 ; vmulps %ymm3,%ymm8,%ymm3 + DB 197,228,88,223 ; vaddps %ymm7,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_0_avx _sk_clamp_0_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 - DB 196,193,124,95,192 ; vmaxps %ymm8,%ymm0,%ymm0 - DB 196,193,116,95,200 ; vmaxps %ymm8,%ymm1,%ymm1 - DB 196,193,108,95,208 ; vmaxps %ymm8,%ymm2,%ymm2 - DB 196,193,100,95,216 ; vmaxps %ymm8,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 + DB 196,193,124,95,192 ; vmaxps %ymm8,%ymm0,%ymm0 + DB 196,193,116,95,200 ; vmaxps %ymm8,%ymm1,%ymm1 + DB 196,193,108,95,208 ; vmaxps %ymm8,%ymm2,%ymm2 + DB 196,193,100,95,216 ; vmaxps %ymm8,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_1_avx _sk_clamp_1_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 - DB 196,193,124,93,192 ; vminps %ymm8,%ymm0,%ymm0 - DB 196,193,116,93,200 ; vminps %ymm8,%ymm1,%ymm1 - DB 196,193,108,93,208 ; vminps %ymm8,%ymm2,%ymm2 - DB 196,193,100,93,216 ; vminps %ymm8,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 + DB 196,193,124,93,192 ; vminps %ymm8,%ymm0,%ymm0 + DB 196,193,116,93,200 ; vminps %ymm8,%ymm1,%ymm1 + DB 196,193,108,93,208 ; vminps %ymm8,%ymm2,%ymm2 + DB 196,193,100,93,216 ; vminps %ymm8,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_a_avx _sk_clamp_a_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 - DB 196,193,100,93,216 ; vminps %ymm8,%ymm3,%ymm3 - DB 197,252,93,195 ; vminps %ymm3,%ymm0,%ymm0 - DB 197,244,93,203 ; vminps %ymm3,%ymm1,%ymm1 - DB 197,236,93,211 ; vminps %ymm3,%ymm2,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,2 ; vbroadcastss (%rdx),%ymm8 + DB 196,193,100,93,216 ; vminps %ymm8,%ymm3,%ymm3 + DB 197,252,93,195 ; vminps %ymm3,%ymm0,%ymm0 + DB 197,244,93,203 ; vminps %ymm3,%ymm1,%ymm1 + DB 197,236,93,211 ; vminps %ymm3,%ymm2,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_set_rgb_avx _sk_set_rgb_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,226,125,24,0 ; vbroadcastss (%rax),%ymm0 - DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 - DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,226,125,24,0 ; vbroadcastss (%rax),%ymm0 + DB 196,226,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm1 + DB 196,226,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_swap_rb_avx _sk_swap_rb_avx LABEL PROC - DB 197,124,40,192 ; vmovaps %ymm0,%ymm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,40,194 ; vmovaps %ymm2,%ymm0 - DB 197,124,41,194 ; vmovaps %ymm8,%ymm2 - DB 255,224 ; jmpq *%rax + DB 197,124,40,192 ; vmovaps %ymm0,%ymm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,40,194 ; vmovaps %ymm2,%ymm0 + DB 197,124,41,194 ; vmovaps %ymm8,%ymm2 + DB 255,224 ; jmpq *%rax PUBLIC _sk_swap_avx _sk_swap_avx LABEL PROC - DB 197,124,40,195 ; vmovaps %ymm3,%ymm8 - DB 197,124,40,202 ; vmovaps %ymm2,%ymm9 - DB 197,124,40,209 ; vmovaps %ymm1,%ymm10 - DB 197,124,40,216 ; vmovaps %ymm0,%ymm11 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,40,196 ; vmovaps %ymm4,%ymm0 - DB 197,252,40,205 ; vmovaps %ymm5,%ymm1 - DB 197,252,40,214 ; vmovaps %ymm6,%ymm2 - DB 197,252,40,223 ; vmovaps %ymm7,%ymm3 - DB 197,124,41,220 ; vmovaps %ymm11,%ymm4 - DB 197,124,41,213 ; vmovaps %ymm10,%ymm5 - DB 197,124,41,206 ; vmovaps %ymm9,%ymm6 - DB 197,124,41,199 ; vmovaps %ymm8,%ymm7 - DB 255,224 ; jmpq *%rax + DB 197,124,40,195 ; vmovaps %ymm3,%ymm8 + DB 197,124,40,202 ; vmovaps %ymm2,%ymm9 + DB 197,124,40,209 ; vmovaps %ymm1,%ymm10 + DB 197,124,40,216 ; vmovaps %ymm0,%ymm11 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,40,196 ; vmovaps %ymm4,%ymm0 + DB 197,252,40,205 ; vmovaps %ymm5,%ymm1 + DB 197,252,40,214 ; vmovaps %ymm6,%ymm2 + DB 197,252,40,223 ; vmovaps %ymm7,%ymm3 + DB 197,124,41,220 ; vmovaps %ymm11,%ymm4 + DB 197,124,41,213 ; vmovaps %ymm10,%ymm5 + DB 197,124,41,206 ; vmovaps %ymm9,%ymm6 + DB 197,124,41,199 ; vmovaps %ymm8,%ymm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_move_src_dst_avx _sk_move_src_dst_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,40,224 ; vmovaps %ymm0,%ymm4 - DB 197,252,40,233 ; vmovaps %ymm1,%ymm5 - DB 197,252,40,242 ; vmovaps %ymm2,%ymm6 - DB 197,252,40,251 ; vmovaps %ymm3,%ymm7 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,40,224 ; vmovaps %ymm0,%ymm4 + DB 197,252,40,233 ; vmovaps %ymm1,%ymm5 + DB 197,252,40,242 ; vmovaps %ymm2,%ymm6 + DB 197,252,40,251 ; vmovaps %ymm3,%ymm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_move_dst_src_avx _sk_move_dst_src_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,40,196 ; vmovaps %ymm4,%ymm0 - DB 197,252,40,205 ; vmovaps %ymm5,%ymm1 - DB 197,252,40,214 ; vmovaps %ymm6,%ymm2 - DB 197,252,40,223 ; vmovaps %ymm7,%ymm3 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,40,196 ; vmovaps %ymm4,%ymm0 + DB 197,252,40,205 ; vmovaps %ymm5,%ymm1 + DB 197,252,40,214 ; vmovaps %ymm6,%ymm2 + DB 197,252,40,223 ; vmovaps %ymm7,%ymm3 + DB 255,224 ; jmpq *%rax PUBLIC _sk_premul_avx _sk_premul_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,252,89,195 ; vmulps %ymm3,%ymm0,%ymm0 - DB 197,244,89,203 ; vmulps %ymm3,%ymm1,%ymm1 - DB 197,236,89,211 ; vmulps %ymm3,%ymm2,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,252,89,195 ; vmulps %ymm3,%ymm0,%ymm0 + DB 197,244,89,203 ; vmulps %ymm3,%ymm1,%ymm1 + DB 197,236,89,211 ; vmulps %ymm3,%ymm2,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_unpremul_avx _sk_unpremul_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 - DB 196,65,100,194,200,0 ; vcmpeqps %ymm8,%ymm3,%ymm9 - DB 196,98,125,24,18 ; vbroadcastss (%rdx),%ymm10 - DB 197,44,94,211 ; vdivps %ymm3,%ymm10,%ymm10 - DB 196,67,45,74,192,144 ; vblendvps %ymm9,%ymm8,%ymm10,%ymm8 - DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 - DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 - DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 + DB 196,65,100,194,200,0 ; vcmpeqps %ymm8,%ymm3,%ymm9 + DB 196,98,125,24,18 ; vbroadcastss (%rdx),%ymm10 + DB 197,44,94,211 ; vdivps %ymm3,%ymm10,%ymm10 + DB 196,67,45,74,192,144 ; vblendvps %ymm9,%ymm8,%ymm10,%ymm8 + DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 + DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 + DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_from_srgb_avx _sk_from_srgb_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,66,64 ; vbroadcastss 0x40(%rdx),%ymm8 - DB 197,60,89,200 ; vmulps %ymm0,%ymm8,%ymm9 - DB 197,124,89,208 ; vmulps %ymm0,%ymm0,%ymm10 - DB 196,98,125,24,90,60 ; vbroadcastss 0x3c(%rdx),%ymm11 - DB 196,98,125,24,98,56 ; vbroadcastss 0x38(%rdx),%ymm12 - DB 197,36,89,232 ; vmulps %ymm0,%ymm11,%ymm13 - DB 196,65,20,88,236 ; vaddps %ymm12,%ymm13,%ymm13 - DB 196,98,125,24,114,52 ; vbroadcastss 0x34(%rdx),%ymm14 - DB 196,65,44,89,213 ; vmulps %ymm13,%ymm10,%ymm10 - DB 196,65,12,88,210 ; vaddps %ymm10,%ymm14,%ymm10 - DB 196,98,125,24,106,68 ; vbroadcastss 0x44(%rdx),%ymm13 - DB 196,193,124,194,197,1 ; vcmpltps %ymm13,%ymm0,%ymm0 - DB 196,195,45,74,193,0 ; vblendvps %ymm0,%ymm9,%ymm10,%ymm0 - DB 197,60,89,201 ; vmulps %ymm1,%ymm8,%ymm9 - DB 197,116,89,209 ; vmulps %ymm1,%ymm1,%ymm10 - DB 197,36,89,249 ; vmulps %ymm1,%ymm11,%ymm15 - DB 196,65,4,88,252 ; vaddps %ymm12,%ymm15,%ymm15 - DB 196,65,44,89,215 ; vmulps %ymm15,%ymm10,%ymm10 - DB 196,65,12,88,210 ; vaddps %ymm10,%ymm14,%ymm10 - DB 196,193,116,194,205,1 ; vcmpltps %ymm13,%ymm1,%ymm1 - DB 196,195,45,74,201,16 ; vblendvps %ymm1,%ymm9,%ymm10,%ymm1 - DB 197,60,89,194 ; vmulps %ymm2,%ymm8,%ymm8 - DB 197,108,89,202 ; vmulps %ymm2,%ymm2,%ymm9 - DB 197,36,89,210 ; vmulps %ymm2,%ymm11,%ymm10 - DB 196,65,44,88,212 ; vaddps %ymm12,%ymm10,%ymm10 - DB 196,65,52,89,202 ; vmulps %ymm10,%ymm9,%ymm9 - DB 196,65,12,88,201 ; vaddps %ymm9,%ymm14,%ymm9 - DB 196,193,108,194,213,1 ; vcmpltps %ymm13,%ymm2,%ymm2 - DB 196,195,53,74,208,32 ; vblendvps %ymm2,%ymm8,%ymm9,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,66,64 ; vbroadcastss 0x40(%rdx),%ymm8 + DB 197,60,89,200 ; vmulps %ymm0,%ymm8,%ymm9 + DB 197,124,89,208 ; vmulps %ymm0,%ymm0,%ymm10 + DB 196,98,125,24,90,60 ; vbroadcastss 0x3c(%rdx),%ymm11 + DB 196,98,125,24,98,56 ; vbroadcastss 0x38(%rdx),%ymm12 + DB 197,36,89,232 ; vmulps %ymm0,%ymm11,%ymm13 + DB 196,65,20,88,236 ; vaddps %ymm12,%ymm13,%ymm13 + DB 196,98,125,24,114,52 ; vbroadcastss 0x34(%rdx),%ymm14 + DB 196,65,44,89,213 ; vmulps %ymm13,%ymm10,%ymm10 + DB 196,65,12,88,210 ; vaddps %ymm10,%ymm14,%ymm10 + DB 196,98,125,24,106,68 ; vbroadcastss 0x44(%rdx),%ymm13 + DB 196,193,124,194,197,1 ; vcmpltps %ymm13,%ymm0,%ymm0 + DB 196,195,45,74,193,0 ; vblendvps %ymm0,%ymm9,%ymm10,%ymm0 + DB 197,60,89,201 ; vmulps %ymm1,%ymm8,%ymm9 + DB 197,116,89,209 ; vmulps %ymm1,%ymm1,%ymm10 + DB 197,36,89,249 ; vmulps %ymm1,%ymm11,%ymm15 + DB 196,65,4,88,252 ; vaddps %ymm12,%ymm15,%ymm15 + DB 196,65,44,89,215 ; vmulps %ymm15,%ymm10,%ymm10 + DB 196,65,12,88,210 ; vaddps %ymm10,%ymm14,%ymm10 + DB 196,193,116,194,205,1 ; vcmpltps %ymm13,%ymm1,%ymm1 + DB 196,195,45,74,201,16 ; vblendvps %ymm1,%ymm9,%ymm10,%ymm1 + DB 197,60,89,194 ; vmulps %ymm2,%ymm8,%ymm8 + DB 197,108,89,202 ; vmulps %ymm2,%ymm2,%ymm9 + DB 197,36,89,210 ; vmulps %ymm2,%ymm11,%ymm10 + DB 196,65,44,88,212 ; vaddps %ymm12,%ymm10,%ymm10 + DB 196,65,52,89,202 ; vmulps %ymm10,%ymm9,%ymm9 + DB 196,65,12,88,201 ; vaddps %ymm9,%ymm14,%ymm9 + DB 196,193,108,194,213,1 ; vcmpltps %ymm13,%ymm2,%ymm2 + DB 196,195,53,74,208,32 ; vblendvps %ymm2,%ymm8,%ymm9,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_to_srgb_avx _sk_to_srgb_avx LABEL PROC - DB 197,124,82,192 ; vrsqrtps %ymm0,%ymm8 - DB 196,65,124,83,200 ; vrcpps %ymm8,%ymm9 - DB 196,65,124,82,208 ; vrsqrtps %ymm8,%ymm10 - DB 196,98,125,24,66,72 ; vbroadcastss 0x48(%rdx),%ymm8 - DB 197,60,89,216 ; vmulps %ymm0,%ymm8,%ymm11 - DB 196,98,125,24,34 ; vbroadcastss (%rdx),%ymm12 - DB 196,98,125,24,106,76 ; vbroadcastss 0x4c(%rdx),%ymm13 - DB 196,98,125,24,114,80 ; vbroadcastss 0x50(%rdx),%ymm14 - DB 196,98,125,24,122,84 ; vbroadcastss 0x54(%rdx),%ymm15 - DB 196,65,52,89,206 ; vmulps %ymm14,%ymm9,%ymm9 - DB 196,65,52,88,207 ; vaddps %ymm15,%ymm9,%ymm9 - DB 196,65,44,89,213 ; vmulps %ymm13,%ymm10,%ymm10 - DB 196,65,44,88,201 ; vaddps %ymm9,%ymm10,%ymm9 - DB 196,65,28,93,201 ; vminps %ymm9,%ymm12,%ymm9 - DB 196,98,125,24,82,88 ; vbroadcastss 0x58(%rdx),%ymm10 - DB 196,193,124,194,194,1 ; vcmpltps %ymm10,%ymm0,%ymm0 - DB 196,195,53,74,195,0 ; vblendvps %ymm0,%ymm11,%ymm9,%ymm0 - DB 197,124,82,201 ; vrsqrtps %ymm1,%ymm9 - DB 196,65,124,83,217 ; vrcpps %ymm9,%ymm11 - DB 196,65,124,82,201 ; vrsqrtps %ymm9,%ymm9 - DB 196,65,12,89,219 ; vmulps %ymm11,%ymm14,%ymm11 - DB 196,65,4,88,219 ; vaddps %ymm11,%ymm15,%ymm11 - DB 196,65,20,89,201 ; vmulps %ymm9,%ymm13,%ymm9 - DB 196,65,52,88,203 ; vaddps %ymm11,%ymm9,%ymm9 - DB 197,60,89,217 ; vmulps %ymm1,%ymm8,%ymm11 - DB 196,65,28,93,201 ; vminps %ymm9,%ymm12,%ymm9 - DB 196,193,116,194,202,1 ; vcmpltps %ymm10,%ymm1,%ymm1 - DB 196,195,53,74,203,16 ; vblendvps %ymm1,%ymm11,%ymm9,%ymm1 - DB 197,124,82,202 ; vrsqrtps %ymm2,%ymm9 - DB 196,65,124,83,217 ; vrcpps %ymm9,%ymm11 - DB 196,65,12,89,219 ; vmulps %ymm11,%ymm14,%ymm11 - DB 196,65,4,88,219 ; vaddps %ymm11,%ymm15,%ymm11 - DB 196,65,124,82,201 ; vrsqrtps %ymm9,%ymm9 - DB 196,65,20,89,201 ; vmulps %ymm9,%ymm13,%ymm9 - DB 196,65,52,88,203 ; vaddps %ymm11,%ymm9,%ymm9 - DB 196,65,28,93,201 ; vminps %ymm9,%ymm12,%ymm9 - DB 197,60,89,194 ; vmulps %ymm2,%ymm8,%ymm8 - DB 196,193,108,194,210,1 ; vcmpltps %ymm10,%ymm2,%ymm2 - DB 196,195,53,74,208,32 ; vblendvps %ymm2,%ymm8,%ymm9,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 197,124,82,192 ; vrsqrtps %ymm0,%ymm8 + DB 196,65,124,83,200 ; vrcpps %ymm8,%ymm9 + DB 196,65,124,82,208 ; vrsqrtps %ymm8,%ymm10 + DB 196,98,125,24,66,72 ; vbroadcastss 0x48(%rdx),%ymm8 + DB 197,60,89,216 ; vmulps %ymm0,%ymm8,%ymm11 + DB 196,98,125,24,34 ; vbroadcastss (%rdx),%ymm12 + DB 196,98,125,24,106,76 ; vbroadcastss 0x4c(%rdx),%ymm13 + DB 196,98,125,24,114,80 ; vbroadcastss 0x50(%rdx),%ymm14 + DB 196,98,125,24,122,84 ; vbroadcastss 0x54(%rdx),%ymm15 + DB 196,65,52,89,206 ; vmulps %ymm14,%ymm9,%ymm9 + DB 196,65,52,88,207 ; vaddps %ymm15,%ymm9,%ymm9 + DB 196,65,44,89,213 ; vmulps %ymm13,%ymm10,%ymm10 + DB 196,65,44,88,201 ; vaddps %ymm9,%ymm10,%ymm9 + DB 196,65,28,93,201 ; vminps %ymm9,%ymm12,%ymm9 + DB 196,98,125,24,82,88 ; vbroadcastss 0x58(%rdx),%ymm10 + DB 196,193,124,194,194,1 ; vcmpltps %ymm10,%ymm0,%ymm0 + DB 196,195,53,74,195,0 ; vblendvps %ymm0,%ymm11,%ymm9,%ymm0 + DB 197,124,82,201 ; vrsqrtps %ymm1,%ymm9 + DB 196,65,124,83,217 ; vrcpps %ymm9,%ymm11 + DB 196,65,124,82,201 ; vrsqrtps %ymm9,%ymm9 + DB 196,65,12,89,219 ; vmulps %ymm11,%ymm14,%ymm11 + DB 196,65,4,88,219 ; vaddps %ymm11,%ymm15,%ymm11 + DB 196,65,20,89,201 ; vmulps %ymm9,%ymm13,%ymm9 + DB 196,65,52,88,203 ; vaddps %ymm11,%ymm9,%ymm9 + DB 197,60,89,217 ; vmulps %ymm1,%ymm8,%ymm11 + DB 196,65,28,93,201 ; vminps %ymm9,%ymm12,%ymm9 + DB 196,193,116,194,202,1 ; vcmpltps %ymm10,%ymm1,%ymm1 + DB 196,195,53,74,203,16 ; vblendvps %ymm1,%ymm11,%ymm9,%ymm1 + DB 197,124,82,202 ; vrsqrtps %ymm2,%ymm9 + DB 196,65,124,83,217 ; vrcpps %ymm9,%ymm11 + DB 196,65,12,89,219 ; vmulps %ymm11,%ymm14,%ymm11 + DB 196,65,4,88,219 ; vaddps %ymm11,%ymm15,%ymm11 + DB 196,65,124,82,201 ; vrsqrtps %ymm9,%ymm9 + DB 196,65,20,89,201 ; vmulps %ymm9,%ymm13,%ymm9 + DB 196,65,52,88,203 ; vaddps %ymm11,%ymm9,%ymm9 + DB 196,65,28,93,201 ; vminps %ymm9,%ymm12,%ymm9 + DB 197,60,89,194 ; vmulps %ymm2,%ymm8,%ymm8 + DB 196,193,108,194,210,1 ; vcmpltps %ymm10,%ymm2,%ymm2 + DB 196,195,53,74,208,32 ; vblendvps %ymm2,%ymm8,%ymm9,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_scale_u8_avx _sk_scale_u8_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 196,98,121,49,68,56,4 ; vpmovzxbd 0x4(%rax,%rdi,1),%xmm8 - DB 196,98,121,49,12,56 ; vpmovzxbd (%rax,%rdi,1),%xmm9 - DB 196,67,53,24,192,1 ; vinsertf128 $0x1,%xmm8,%ymm9,%ymm8 - DB 196,65,124,91,192 ; vcvtdq2ps %ymm8,%ymm8 - DB 196,98,125,24,74,12 ; vbroadcastss 0xc(%rdx),%ymm9 - DB 196,65,60,89,193 ; vmulps %ymm9,%ymm8,%ymm8 - DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 - DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 - DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 - DB 197,188,89,219 ; vmulps %ymm3,%ymm8,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 196,98,121,49,68,56,4 ; vpmovzxbd 0x4(%rax,%rdi,1),%xmm8 + DB 196,98,121,49,12,56 ; vpmovzxbd (%rax,%rdi,1),%xmm9 + DB 196,67,53,24,192,1 ; vinsertf128 $0x1,%xmm8,%ymm9,%ymm8 + DB 196,65,124,91,192 ; vcvtdq2ps %ymm8,%ymm8 + DB 196,98,125,24,74,12 ; vbroadcastss 0xc(%rdx),%ymm9 + DB 196,65,60,89,193 ; vmulps %ymm9,%ymm8,%ymm8 + DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 + DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 + DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 + DB 197,188,89,219 ; vmulps %ymm3,%ymm8,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_lerp_u8_avx _sk_lerp_u8_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 196,98,121,49,68,56,4 ; vpmovzxbd 0x4(%rax,%rdi,1),%xmm8 - DB 196,98,121,49,12,56 ; vpmovzxbd (%rax,%rdi,1),%xmm9 - DB 196,67,53,24,192,1 ; vinsertf128 $0x1,%xmm8,%ymm9,%ymm8 - DB 196,65,124,91,192 ; vcvtdq2ps %ymm8,%ymm8 - DB 196,98,125,24,74,12 ; vbroadcastss 0xc(%rdx),%ymm9 - DB 196,65,60,89,193 ; vmulps %ymm9,%ymm8,%ymm8 - DB 197,252,92,196 ; vsubps %ymm4,%ymm0,%ymm0 - DB 196,193,124,89,192 ; vmulps %ymm8,%ymm0,%ymm0 - DB 197,252,88,196 ; vaddps %ymm4,%ymm0,%ymm0 - DB 197,244,92,205 ; vsubps %ymm5,%ymm1,%ymm1 - DB 196,193,116,89,200 ; vmulps %ymm8,%ymm1,%ymm1 - DB 197,244,88,205 ; vaddps %ymm5,%ymm1,%ymm1 - DB 197,236,92,214 ; vsubps %ymm6,%ymm2,%ymm2 - DB 196,193,108,89,208 ; vmulps %ymm8,%ymm2,%ymm2 - DB 197,236,88,214 ; vaddps %ymm6,%ymm2,%ymm2 - DB 197,228,92,223 ; vsubps %ymm7,%ymm3,%ymm3 - DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 - DB 197,228,88,223 ; vaddps %ymm7,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 196,98,121,49,68,56,4 ; vpmovzxbd 0x4(%rax,%rdi,1),%xmm8 + DB 196,98,121,49,12,56 ; vpmovzxbd (%rax,%rdi,1),%xmm9 + DB 196,67,53,24,192,1 ; vinsertf128 $0x1,%xmm8,%ymm9,%ymm8 + DB 196,65,124,91,192 ; vcvtdq2ps %ymm8,%ymm8 + DB 196,98,125,24,74,12 ; vbroadcastss 0xc(%rdx),%ymm9 + DB 196,65,60,89,193 ; vmulps %ymm9,%ymm8,%ymm8 + DB 197,252,92,196 ; vsubps %ymm4,%ymm0,%ymm0 + DB 196,193,124,89,192 ; vmulps %ymm8,%ymm0,%ymm0 + DB 197,252,88,196 ; vaddps %ymm4,%ymm0,%ymm0 + DB 197,244,92,205 ; vsubps %ymm5,%ymm1,%ymm1 + DB 196,193,116,89,200 ; vmulps %ymm8,%ymm1,%ymm1 + DB 197,244,88,205 ; vaddps %ymm5,%ymm1,%ymm1 + DB 197,236,92,214 ; vsubps %ymm6,%ymm2,%ymm2 + DB 196,193,108,89,208 ; vmulps %ymm8,%ymm2,%ymm2 + DB 197,236,88,214 ; vaddps %ymm6,%ymm2,%ymm2 + DB 197,228,92,223 ; vsubps %ymm7,%ymm3,%ymm3 + DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 + DB 197,228,88,223 ; vaddps %ymm7,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_tables_avx _sk_load_tables_avx LABEL PROC - DB 65,87 ; push %r15 - DB 65,86 ; push %r14 - DB 65,84 ; push %r12 - DB 83 ; push %rbx - DB 72,173 ; lods %ds:(%rsi),%rax - DB 76,139,0 ; mov (%rax),%r8 - DB 72,139,72,8 ; mov 0x8(%rax),%rcx - DB 196,65,124,16,20,184 ; vmovups (%r8,%rdi,4),%ymm10 - DB 197,249,110,66,16 ; vmovd 0x10(%rdx),%xmm0 - DB 196,227,121,4,192,0 ; vpermilps $0x0,%xmm0,%xmm0 - DB 196,99,125,24,200,1 ; vinsertf128 $0x1,%xmm0,%ymm0,%ymm9 - DB 196,193,52,84,194 ; vandps %ymm10,%ymm9,%ymm0 - DB 196,193,249,126,192 ; vmovq %xmm0,%r8 - DB 69,137,193 ; mov %r8d,%r9d - DB 196,195,249,22,194,1 ; vpextrq $0x1,%xmm0,%r10 - DB 69,137,211 ; mov %r10d,%r11d - DB 73,193,234,32 ; shr $0x20,%r10 - DB 73,193,232,32 ; shr $0x20,%r8 - DB 196,227,125,25,192,1 ; vextractf128 $0x1,%ymm0,%xmm0 - DB 196,193,249,126,199 ; vmovq %xmm0,%r15 - DB 69,137,254 ; mov %r15d,%r14d - DB 196,227,249,22,195,1 ; vpextrq $0x1,%xmm0,%rbx - DB 65,137,220 ; mov %ebx,%r12d - DB 72,193,235,32 ; shr $0x20,%rbx - DB 73,193,239,32 ; shr $0x20,%r15 - DB 196,161,122,16,4,177 ; vmovss (%rcx,%r14,4),%xmm0 - DB 196,163,121,33,4,185,16 ; vinsertps $0x10,(%rcx,%r15,4),%xmm0,%xmm0 - DB 196,163,121,33,4,161,32 ; vinsertps $0x20,(%rcx,%r12,4),%xmm0,%xmm0 - DB 196,227,121,33,4,153,48 ; vinsertps $0x30,(%rcx,%rbx,4),%xmm0,%xmm0 - DB 196,161,122,16,12,137 ; vmovss (%rcx,%r9,4),%xmm1 - DB 196,163,113,33,12,129,16 ; vinsertps $0x10,(%rcx,%r8,4),%xmm1,%xmm1 - DB 196,163,113,33,12,153,32 ; vinsertps $0x20,(%rcx,%r11,4),%xmm1,%xmm1 - DB 196,163,113,33,12,145,48 ; vinsertps $0x30,(%rcx,%r10,4),%xmm1,%xmm1 - DB 196,227,117,24,192,1 ; vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 - DB 76,139,120,16 ; mov 0x10(%rax),%r15 - DB 196,193,113,114,210,8 ; vpsrld $0x8,%xmm10,%xmm1 - DB 196,67,125,25,208,1 ; vextractf128 $0x1,%ymm10,%xmm8 - DB 196,193,105,114,208,8 ; vpsrld $0x8,%xmm8,%xmm2 - DB 196,227,117,24,202,1 ; vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 - DB 197,180,84,201 ; vandps %ymm1,%ymm9,%ymm1 - DB 196,193,249,126,200 ; vmovq %xmm1,%r8 - DB 69,137,194 ; mov %r8d,%r10d - DB 196,195,249,22,201,1 ; vpextrq $0x1,%xmm1,%r9 - DB 69,137,203 ; mov %r9d,%r11d - DB 73,193,233,32 ; shr $0x20,%r9 - DB 73,193,232,32 ; shr $0x20,%r8 - DB 196,227,125,25,201,1 ; vextractf128 $0x1,%ymm1,%xmm1 - DB 196,225,249,126,203 ; vmovq %xmm1,%rbx - DB 65,137,222 ; mov %ebx,%r14d - DB 196,227,249,22,201,1 ; vpextrq $0x1,%xmm1,%rcx - DB 65,137,204 ; mov %ecx,%r12d - DB 72,193,233,32 ; shr $0x20,%rcx - DB 72,193,235,32 ; shr $0x20,%rbx - DB 196,129,122,16,12,183 ; vmovss (%r15,%r14,4),%xmm1 - DB 196,195,113,33,12,159,16 ; vinsertps $0x10,(%r15,%rbx,4),%xmm1,%xmm1 - DB 196,129,122,16,20,167 ; vmovss (%r15,%r12,4),%xmm2 - DB 196,227,113,33,202,32 ; vinsertps $0x20,%xmm2,%xmm1,%xmm1 - DB 196,193,122,16,20,143 ; vmovss (%r15,%rcx,4),%xmm2 - DB 196,227,113,33,202,48 ; vinsertps $0x30,%xmm2,%xmm1,%xmm1 - DB 196,129,122,16,20,151 ; vmovss (%r15,%r10,4),%xmm2 - DB 196,131,105,33,20,135,16 ; vinsertps $0x10,(%r15,%r8,4),%xmm2,%xmm2 - DB 196,129,122,16,28,159 ; vmovss (%r15,%r11,4),%xmm3 - DB 196,227,105,33,211,32 ; vinsertps $0x20,%xmm3,%xmm2,%xmm2 - DB 196,129,122,16,28,143 ; vmovss (%r15,%r9,4),%xmm3 - DB 196,227,105,33,211,48 ; vinsertps $0x30,%xmm3,%xmm2,%xmm2 - DB 196,227,109,24,201,1 ; vinsertf128 $0x1,%xmm1,%ymm2,%ymm1 - DB 72,139,64,24 ; mov 0x18(%rax),%rax - DB 196,193,105,114,210,16 ; vpsrld $0x10,%xmm10,%xmm2 - DB 196,193,97,114,208,16 ; vpsrld $0x10,%xmm8,%xmm3 - DB 196,227,109,24,211,1 ; vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 - DB 197,180,84,210 ; vandps %ymm2,%ymm9,%ymm2 - DB 196,193,249,126,208 ; vmovq %xmm2,%r8 - DB 69,137,193 ; mov %r8d,%r9d - DB 196,195,249,22,214,1 ; vpextrq $0x1,%xmm2,%r14 - DB 69,137,242 ; mov %r14d,%r10d - DB 73,193,238,32 ; shr $0x20,%r14 - DB 73,193,232,32 ; shr $0x20,%r8 - DB 196,227,125,25,210,1 ; vextractf128 $0x1,%ymm2,%xmm2 - DB 196,225,249,126,211 ; vmovq %xmm2,%rbx - DB 65,137,219 ; mov %ebx,%r11d - DB 196,227,249,22,209,1 ; vpextrq $0x1,%xmm2,%rcx - DB 65,137,207 ; mov %ecx,%r15d - DB 72,193,233,32 ; shr $0x20,%rcx - DB 72,193,235,32 ; shr $0x20,%rbx - DB 196,161,122,16,20,152 ; vmovss (%rax,%r11,4),%xmm2 - DB 196,227,105,33,20,152,16 ; vinsertps $0x10,(%rax,%rbx,4),%xmm2,%xmm2 - DB 196,161,122,16,28,184 ; vmovss (%rax,%r15,4),%xmm3 - DB 196,227,105,33,211,32 ; vinsertps $0x20,%xmm3,%xmm2,%xmm2 - DB 197,250,16,28,136 ; vmovss (%rax,%rcx,4),%xmm3 - DB 196,99,105,33,203,48 ; vinsertps $0x30,%xmm3,%xmm2,%xmm9 - DB 196,161,122,16,28,136 ; vmovss (%rax,%r9,4),%xmm3 - DB 196,163,97,33,28,128,16 ; vinsertps $0x10,(%rax,%r8,4),%xmm3,%xmm3 - DB 196,161,122,16,20,144 ; vmovss (%rax,%r10,4),%xmm2 - DB 196,227,97,33,210,32 ; vinsertps $0x20,%xmm2,%xmm3,%xmm2 - DB 196,161,122,16,28,176 ; vmovss (%rax,%r14,4),%xmm3 - DB 196,227,105,33,211,48 ; vinsertps $0x30,%xmm3,%xmm2,%xmm2 - DB 196,195,109,24,209,1 ; vinsertf128 $0x1,%xmm9,%ymm2,%ymm2 - DB 196,193,49,114,210,24 ; vpsrld $0x18,%xmm10,%xmm9 - DB 196,193,97,114,208,24 ; vpsrld $0x18,%xmm8,%xmm3 - DB 196,227,53,24,219,1 ; vinsertf128 $0x1,%xmm3,%ymm9,%ymm3 - DB 197,252,91,219 ; vcvtdq2ps %ymm3,%ymm3 - DB 196,98,125,24,66,12 ; vbroadcastss 0xc(%rdx),%ymm8 - DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 91 ; pop %rbx - DB 65,92 ; pop %r12 - DB 65,94 ; pop %r14 - DB 65,95 ; pop %r15 - DB 255,224 ; jmpq *%rax + DB 65,87 ; push %r15 + DB 65,86 ; push %r14 + DB 65,84 ; push %r12 + DB 83 ; push %rbx + DB 72,173 ; lods %ds:(%rsi),%rax + DB 76,139,0 ; mov (%rax),%r8 + DB 72,139,72,8 ; mov 0x8(%rax),%rcx + DB 196,65,124,16,20,184 ; vmovups (%r8,%rdi,4),%ymm10 + DB 197,249,110,66,16 ; vmovd 0x10(%rdx),%xmm0 + DB 196,227,121,4,192,0 ; vpermilps $0x0,%xmm0,%xmm0 + DB 196,99,125,24,200,1 ; vinsertf128 $0x1,%xmm0,%ymm0,%ymm9 + DB 196,193,52,84,194 ; vandps %ymm10,%ymm9,%ymm0 + DB 196,193,249,126,192 ; vmovq %xmm0,%r8 + DB 69,137,193 ; mov %r8d,%r9d + DB 196,195,249,22,194,1 ; vpextrq $0x1,%xmm0,%r10 + DB 69,137,211 ; mov %r10d,%r11d + DB 73,193,234,32 ; shr $0x20,%r10 + DB 73,193,232,32 ; shr $0x20,%r8 + DB 196,227,125,25,192,1 ; vextractf128 $0x1,%ymm0,%xmm0 + DB 196,193,249,126,199 ; vmovq %xmm0,%r15 + DB 69,137,254 ; mov %r15d,%r14d + DB 196,227,249,22,195,1 ; vpextrq $0x1,%xmm0,%rbx + DB 65,137,220 ; mov %ebx,%r12d + DB 72,193,235,32 ; shr $0x20,%rbx + DB 73,193,239,32 ; shr $0x20,%r15 + DB 196,161,122,16,4,177 ; vmovss (%rcx,%r14,4),%xmm0 + DB 196,163,121,33,4,185,16 ; vinsertps $0x10,(%rcx,%r15,4),%xmm0,%xmm0 + DB 196,163,121,33,4,161,32 ; vinsertps $0x20,(%rcx,%r12,4),%xmm0,%xmm0 + DB 196,227,121,33,4,153,48 ; vinsertps $0x30,(%rcx,%rbx,4),%xmm0,%xmm0 + DB 196,161,122,16,12,137 ; vmovss (%rcx,%r9,4),%xmm1 + DB 196,163,113,33,12,129,16 ; vinsertps $0x10,(%rcx,%r8,4),%xmm1,%xmm1 + DB 196,163,113,33,12,153,32 ; vinsertps $0x20,(%rcx,%r11,4),%xmm1,%xmm1 + DB 196,163,113,33,12,145,48 ; vinsertps $0x30,(%rcx,%r10,4),%xmm1,%xmm1 + DB 196,227,117,24,192,1 ; vinsertf128 $0x1,%xmm0,%ymm1,%ymm0 + DB 76,139,120,16 ; mov 0x10(%rax),%r15 + DB 196,193,113,114,210,8 ; vpsrld $0x8,%xmm10,%xmm1 + DB 196,67,125,25,208,1 ; vextractf128 $0x1,%ymm10,%xmm8 + DB 196,193,105,114,208,8 ; vpsrld $0x8,%xmm8,%xmm2 + DB 196,227,117,24,202,1 ; vinsertf128 $0x1,%xmm2,%ymm1,%ymm1 + DB 197,180,84,201 ; vandps %ymm1,%ymm9,%ymm1 + DB 196,193,249,126,200 ; vmovq %xmm1,%r8 + DB 69,137,194 ; mov %r8d,%r10d + DB 196,195,249,22,201,1 ; vpextrq $0x1,%xmm1,%r9 + DB 69,137,203 ; mov %r9d,%r11d + DB 73,193,233,32 ; shr $0x20,%r9 + DB 73,193,232,32 ; shr $0x20,%r8 + DB 196,227,125,25,201,1 ; vextractf128 $0x1,%ymm1,%xmm1 + DB 196,225,249,126,203 ; vmovq %xmm1,%rbx + DB 65,137,222 ; mov %ebx,%r14d + DB 196,227,249,22,201,1 ; vpextrq $0x1,%xmm1,%rcx + DB 65,137,204 ; mov %ecx,%r12d + DB 72,193,233,32 ; shr $0x20,%rcx + DB 72,193,235,32 ; shr $0x20,%rbx + DB 196,129,122,16,12,183 ; vmovss (%r15,%r14,4),%xmm1 + DB 196,195,113,33,12,159,16 ; vinsertps $0x10,(%r15,%rbx,4),%xmm1,%xmm1 + DB 196,129,122,16,20,167 ; vmovss (%r15,%r12,4),%xmm2 + DB 196,227,113,33,202,32 ; vinsertps $0x20,%xmm2,%xmm1,%xmm1 + DB 196,193,122,16,20,143 ; vmovss (%r15,%rcx,4),%xmm2 + DB 196,227,113,33,202,48 ; vinsertps $0x30,%xmm2,%xmm1,%xmm1 + DB 196,129,122,16,20,151 ; vmovss (%r15,%r10,4),%xmm2 + DB 196,131,105,33,20,135,16 ; vinsertps $0x10,(%r15,%r8,4),%xmm2,%xmm2 + DB 196,129,122,16,28,159 ; vmovss (%r15,%r11,4),%xmm3 + DB 196,227,105,33,211,32 ; vinsertps $0x20,%xmm3,%xmm2,%xmm2 + DB 196,129,122,16,28,143 ; vmovss (%r15,%r9,4),%xmm3 + DB 196,227,105,33,211,48 ; vinsertps $0x30,%xmm3,%xmm2,%xmm2 + DB 196,227,109,24,201,1 ; vinsertf128 $0x1,%xmm1,%ymm2,%ymm1 + DB 72,139,64,24 ; mov 0x18(%rax),%rax + DB 196,193,105,114,210,16 ; vpsrld $0x10,%xmm10,%xmm2 + DB 196,193,97,114,208,16 ; vpsrld $0x10,%xmm8,%xmm3 + DB 196,227,109,24,211,1 ; vinsertf128 $0x1,%xmm3,%ymm2,%ymm2 + DB 197,180,84,210 ; vandps %ymm2,%ymm9,%ymm2 + DB 196,193,249,126,208 ; vmovq %xmm2,%r8 + DB 69,137,193 ; mov %r8d,%r9d + DB 196,195,249,22,214,1 ; vpextrq $0x1,%xmm2,%r14 + DB 69,137,242 ; mov %r14d,%r10d + DB 73,193,238,32 ; shr $0x20,%r14 + DB 73,193,232,32 ; shr $0x20,%r8 + DB 196,227,125,25,210,1 ; vextractf128 $0x1,%ymm2,%xmm2 + DB 196,225,249,126,211 ; vmovq %xmm2,%rbx + DB 65,137,219 ; mov %ebx,%r11d + DB 196,227,249,22,209,1 ; vpextrq $0x1,%xmm2,%rcx + DB 65,137,207 ; mov %ecx,%r15d + DB 72,193,233,32 ; shr $0x20,%rcx + DB 72,193,235,32 ; shr $0x20,%rbx + DB 196,161,122,16,20,152 ; vmovss (%rax,%r11,4),%xmm2 + DB 196,227,105,33,20,152,16 ; vinsertps $0x10,(%rax,%rbx,4),%xmm2,%xmm2 + DB 196,161,122,16,28,184 ; vmovss (%rax,%r15,4),%xmm3 + DB 196,227,105,33,211,32 ; vinsertps $0x20,%xmm3,%xmm2,%xmm2 + DB 197,250,16,28,136 ; vmovss (%rax,%rcx,4),%xmm3 + DB 196,99,105,33,203,48 ; vinsertps $0x30,%xmm3,%xmm2,%xmm9 + DB 196,161,122,16,28,136 ; vmovss (%rax,%r9,4),%xmm3 + DB 196,163,97,33,28,128,16 ; vinsertps $0x10,(%rax,%r8,4),%xmm3,%xmm3 + DB 196,161,122,16,20,144 ; vmovss (%rax,%r10,4),%xmm2 + DB 196,227,97,33,210,32 ; vinsertps $0x20,%xmm2,%xmm3,%xmm2 + DB 196,161,122,16,28,176 ; vmovss (%rax,%r14,4),%xmm3 + DB 196,227,105,33,211,48 ; vinsertps $0x30,%xmm3,%xmm2,%xmm2 + DB 196,195,109,24,209,1 ; vinsertf128 $0x1,%xmm9,%ymm2,%ymm2 + DB 196,193,49,114,210,24 ; vpsrld $0x18,%xmm10,%xmm9 + DB 196,193,97,114,208,24 ; vpsrld $0x18,%xmm8,%xmm3 + DB 196,227,53,24,219,1 ; vinsertf128 $0x1,%xmm3,%ymm9,%ymm3 + DB 197,252,91,219 ; vcvtdq2ps %ymm3,%ymm3 + DB 196,98,125,24,66,12 ; vbroadcastss 0xc(%rdx),%ymm8 + DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 91 ; pop %rbx + DB 65,92 ; pop %r12 + DB 65,94 ; pop %r14 + DB 65,95 ; pop %r15 + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_8888_avx _sk_load_8888_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 197,252,16,28,184 ; vmovups (%rax,%rdi,4),%ymm3 - DB 197,249,110,66,16 ; vmovd 0x10(%rdx),%xmm0 - DB 196,227,121,4,192,0 ; vpermilps $0x0,%xmm0,%xmm0 - DB 196,99,125,24,216,1 ; vinsertf128 $0x1,%xmm0,%ymm0,%ymm11 - DB 197,164,84,195 ; vandps %ymm3,%ymm11,%ymm0 - DB 197,252,91,192 ; vcvtdq2ps %ymm0,%ymm0 - DB 196,98,125,24,66,12 ; vbroadcastss 0xc(%rdx),%ymm8 - DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 - DB 197,169,114,211,8 ; vpsrld $0x8,%xmm3,%xmm10 - DB 196,195,125,25,217,1 ; vextractf128 $0x1,%ymm3,%xmm9 - DB 196,193,113,114,209,8 ; vpsrld $0x8,%xmm9,%xmm1 - DB 196,227,45,24,201,1 ; vinsertf128 $0x1,%xmm1,%ymm10,%ymm1 - DB 197,164,84,201 ; vandps %ymm1,%ymm11,%ymm1 - DB 197,252,91,201 ; vcvtdq2ps %ymm1,%ymm1 - DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 - DB 197,169,114,211,16 ; vpsrld $0x10,%xmm3,%xmm10 - DB 196,193,105,114,209,16 ; vpsrld $0x10,%xmm9,%xmm2 - DB 196,227,45,24,210,1 ; vinsertf128 $0x1,%xmm2,%ymm10,%ymm2 - DB 197,164,84,210 ; vandps %ymm2,%ymm11,%ymm2 - DB 197,252,91,210 ; vcvtdq2ps %ymm2,%ymm2 - DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 - DB 197,169,114,211,24 ; vpsrld $0x18,%xmm3,%xmm10 - DB 196,193,97,114,209,24 ; vpsrld $0x18,%xmm9,%xmm3 - DB 196,227,45,24,219,1 ; vinsertf128 $0x1,%xmm3,%ymm10,%ymm3 - DB 197,252,91,219 ; vcvtdq2ps %ymm3,%ymm3 - DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 197,252,16,28,184 ; vmovups (%rax,%rdi,4),%ymm3 + DB 197,249,110,66,16 ; vmovd 0x10(%rdx),%xmm0 + DB 196,227,121,4,192,0 ; vpermilps $0x0,%xmm0,%xmm0 + DB 196,99,125,24,216,1 ; vinsertf128 $0x1,%xmm0,%ymm0,%ymm11 + DB 197,164,84,195 ; vandps %ymm3,%ymm11,%ymm0 + DB 197,252,91,192 ; vcvtdq2ps %ymm0,%ymm0 + DB 196,98,125,24,66,12 ; vbroadcastss 0xc(%rdx),%ymm8 + DB 197,188,89,192 ; vmulps %ymm0,%ymm8,%ymm0 + DB 197,169,114,211,8 ; vpsrld $0x8,%xmm3,%xmm10 + DB 196,195,125,25,217,1 ; vextractf128 $0x1,%ymm3,%xmm9 + DB 196,193,113,114,209,8 ; vpsrld $0x8,%xmm9,%xmm1 + DB 196,227,45,24,201,1 ; vinsertf128 $0x1,%xmm1,%ymm10,%ymm1 + DB 197,164,84,201 ; vandps %ymm1,%ymm11,%ymm1 + DB 197,252,91,201 ; vcvtdq2ps %ymm1,%ymm1 + DB 197,188,89,201 ; vmulps %ymm1,%ymm8,%ymm1 + DB 197,169,114,211,16 ; vpsrld $0x10,%xmm3,%xmm10 + DB 196,193,105,114,209,16 ; vpsrld $0x10,%xmm9,%xmm2 + DB 196,227,45,24,210,1 ; vinsertf128 $0x1,%xmm2,%ymm10,%ymm2 + DB 197,164,84,210 ; vandps %ymm2,%ymm11,%ymm2 + DB 197,252,91,210 ; vcvtdq2ps %ymm2,%ymm2 + DB 197,188,89,210 ; vmulps %ymm2,%ymm8,%ymm2 + DB 197,169,114,211,24 ; vpsrld $0x18,%xmm3,%xmm10 + DB 196,193,97,114,209,24 ; vpsrld $0x18,%xmm9,%xmm3 + DB 196,227,45,24,219,1 ; vinsertf128 $0x1,%xmm3,%ymm10,%ymm3 + DB 197,252,91,219 ; vcvtdq2ps %ymm3,%ymm3 + DB 196,193,100,89,216 ; vmulps %ymm8,%ymm3,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_store_8888_avx _sk_store_8888_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 196,98,125,24,66,8 ; vbroadcastss 0x8(%rdx),%ymm8 - DB 197,60,89,200 ; vmulps %ymm0,%ymm8,%ymm9 - DB 196,65,125,91,201 ; vcvtps2dq %ymm9,%ymm9 - DB 197,60,89,209 ; vmulps %ymm1,%ymm8,%ymm10 - DB 196,65,125,91,210 ; vcvtps2dq %ymm10,%ymm10 - DB 196,193,33,114,242,8 ; vpslld $0x8,%xmm10,%xmm11 - DB 196,67,125,25,210,1 ; vextractf128 $0x1,%ymm10,%xmm10 - DB 196,193,41,114,242,8 ; vpslld $0x8,%xmm10,%xmm10 - DB 196,67,37,24,210,1 ; vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 - DB 196,65,45,86,201 ; vorpd %ymm9,%ymm10,%ymm9 - DB 197,60,89,210 ; vmulps %ymm2,%ymm8,%ymm10 - DB 196,65,125,91,210 ; vcvtps2dq %ymm10,%ymm10 - DB 196,193,33,114,242,16 ; vpslld $0x10,%xmm10,%xmm11 - DB 196,67,125,25,210,1 ; vextractf128 $0x1,%ymm10,%xmm10 - DB 196,193,41,114,242,16 ; vpslld $0x10,%xmm10,%xmm10 - DB 196,67,37,24,210,1 ; vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 - DB 196,65,53,86,202 ; vorpd %ymm10,%ymm9,%ymm9 - DB 197,60,89,195 ; vmulps %ymm3,%ymm8,%ymm8 - DB 196,65,125,91,192 ; vcvtps2dq %ymm8,%ymm8 - DB 196,193,41,114,240,24 ; vpslld $0x18,%xmm8,%xmm10 - DB 196,67,125,25,192,1 ; vextractf128 $0x1,%ymm8,%xmm8 - DB 196,193,57,114,240,24 ; vpslld $0x18,%xmm8,%xmm8 - DB 196,67,45,24,192,1 ; vinsertf128 $0x1,%xmm8,%ymm10,%ymm8 - DB 196,65,53,86,192 ; vorpd %ymm8,%ymm9,%ymm8 - DB 197,125,17,4,184 ; vmovupd %ymm8,(%rax,%rdi,4) - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 196,98,125,24,66,8 ; vbroadcastss 0x8(%rdx),%ymm8 + DB 197,60,89,200 ; vmulps %ymm0,%ymm8,%ymm9 + DB 196,65,125,91,201 ; vcvtps2dq %ymm9,%ymm9 + DB 197,60,89,209 ; vmulps %ymm1,%ymm8,%ymm10 + DB 196,65,125,91,210 ; vcvtps2dq %ymm10,%ymm10 + DB 196,193,33,114,242,8 ; vpslld $0x8,%xmm10,%xmm11 + DB 196,67,125,25,210,1 ; vextractf128 $0x1,%ymm10,%xmm10 + DB 196,193,41,114,242,8 ; vpslld $0x8,%xmm10,%xmm10 + DB 196,67,37,24,210,1 ; vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 + DB 196,65,45,86,201 ; vorpd %ymm9,%ymm10,%ymm9 + DB 197,60,89,210 ; vmulps %ymm2,%ymm8,%ymm10 + DB 196,65,125,91,210 ; vcvtps2dq %ymm10,%ymm10 + DB 196,193,33,114,242,16 ; vpslld $0x10,%xmm10,%xmm11 + DB 196,67,125,25,210,1 ; vextractf128 $0x1,%ymm10,%xmm10 + DB 196,193,41,114,242,16 ; vpslld $0x10,%xmm10,%xmm10 + DB 196,67,37,24,210,1 ; vinsertf128 $0x1,%xmm10,%ymm11,%ymm10 + DB 196,65,53,86,202 ; vorpd %ymm10,%ymm9,%ymm9 + DB 197,60,89,195 ; vmulps %ymm3,%ymm8,%ymm8 + DB 196,65,125,91,192 ; vcvtps2dq %ymm8,%ymm8 + DB 196,193,41,114,240,24 ; vpslld $0x18,%xmm8,%xmm10 + DB 196,67,125,25,192,1 ; vextractf128 $0x1,%ymm8,%xmm8 + DB 196,193,57,114,240,24 ; vpslld $0x18,%xmm8,%xmm8 + DB 196,67,45,24,192,1 ; vinsertf128 $0x1,%xmm8,%ymm10,%ymm8 + DB 196,65,53,86,192 ; vorpd %ymm8,%ymm9,%ymm8 + DB 197,125,17,4,184 ; vmovupd %ymm8,(%rax,%rdi,4) + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_f16_avx _sk_load_f16_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_store_f16_avx _sk_store_f16_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_x_avx _sk_clamp_x_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 - DB 196,67,125,25,193,1 ; vextractf128 $0x1,%ymm8,%xmm9 - DB 196,65,41,118,210 ; vpcmpeqd %xmm10,%xmm10,%xmm10 - DB 196,65,49,254,202 ; vpaddd %xmm10,%xmm9,%xmm9 - DB 196,65,57,254,194 ; vpaddd %xmm10,%xmm8,%xmm8 - DB 196,67,61,24,193,1 ; vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 - DB 196,193,124,93,192 ; vminps %ymm8,%ymm0,%ymm0 - DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 - DB 197,188,95,192 ; vmaxps %ymm0,%ymm8,%ymm0 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 + DB 196,67,125,25,193,1 ; vextractf128 $0x1,%ymm8,%xmm9 + DB 196,65,41,118,210 ; vpcmpeqd %xmm10,%xmm10,%xmm10 + DB 196,65,49,254,202 ; vpaddd %xmm10,%xmm9,%xmm9 + DB 196,65,57,254,194 ; vpaddd %xmm10,%xmm8,%xmm8 + DB 196,67,61,24,193,1 ; vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 + DB 196,193,124,93,192 ; vminps %ymm8,%ymm0,%ymm0 + DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 + DB 197,188,95,192 ; vmaxps %ymm0,%ymm8,%ymm0 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_y_avx _sk_clamp_y_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 - DB 196,67,125,25,193,1 ; vextractf128 $0x1,%ymm8,%xmm9 - DB 196,65,41,118,210 ; vpcmpeqd %xmm10,%xmm10,%xmm10 - DB 196,65,49,254,202 ; vpaddd %xmm10,%xmm9,%xmm9 - DB 196,65,57,254,194 ; vpaddd %xmm10,%xmm8,%xmm8 - DB 196,67,61,24,193,1 ; vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 - DB 196,193,116,93,200 ; vminps %ymm8,%ymm1,%ymm1 - DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 - DB 197,188,95,201 ; vmaxps %ymm1,%ymm8,%ymm1 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 + DB 196,67,125,25,193,1 ; vextractf128 $0x1,%ymm8,%xmm9 + DB 196,65,41,118,210 ; vpcmpeqd %xmm10,%xmm10,%xmm10 + DB 196,65,49,254,202 ; vpaddd %xmm10,%xmm9,%xmm9 + DB 196,65,57,254,194 ; vpaddd %xmm10,%xmm8,%xmm8 + DB 196,67,61,24,193,1 ; vinsertf128 $0x1,%xmm9,%ymm8,%ymm8 + DB 196,193,116,93,200 ; vminps %ymm8,%ymm1,%ymm1 + DB 196,65,60,87,192 ; vxorps %ymm8,%ymm8,%ymm8 + DB 197,188,95,201 ; vmaxps %ymm1,%ymm8,%ymm1 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_matrix_2x3_avx _sk_matrix_2x3_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 - DB 196,98,125,24,72,8 ; vbroadcastss 0x8(%rax),%ymm9 - DB 196,98,125,24,80,16 ; vbroadcastss 0x10(%rax),%ymm10 - DB 197,52,89,201 ; vmulps %ymm1,%ymm9,%ymm9 - DB 196,65,52,88,202 ; vaddps %ymm10,%ymm9,%ymm9 - DB 197,60,89,192 ; vmulps %ymm0,%ymm8,%ymm8 - DB 196,65,60,88,193 ; vaddps %ymm9,%ymm8,%ymm8 - DB 196,98,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm9 - DB 196,98,125,24,80,12 ; vbroadcastss 0xc(%rax),%ymm10 - DB 196,98,125,24,88,20 ; vbroadcastss 0x14(%rax),%ymm11 - DB 197,172,89,201 ; vmulps %ymm1,%ymm10,%ymm1 - DB 196,193,116,88,203 ; vaddps %ymm11,%ymm1,%ymm1 - DB 197,180,89,192 ; vmulps %ymm0,%ymm9,%ymm0 - DB 197,252,88,201 ; vaddps %ymm1,%ymm0,%ymm1 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 + DB 196,98,125,24,72,8 ; vbroadcastss 0x8(%rax),%ymm9 + DB 196,98,125,24,80,16 ; vbroadcastss 0x10(%rax),%ymm10 + DB 197,52,89,201 ; vmulps %ymm1,%ymm9,%ymm9 + DB 196,65,52,88,202 ; vaddps %ymm10,%ymm9,%ymm9 + DB 197,60,89,192 ; vmulps %ymm0,%ymm8,%ymm8 + DB 196,65,60,88,193 ; vaddps %ymm9,%ymm8,%ymm8 + DB 196,98,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm9 + DB 196,98,125,24,80,12 ; vbroadcastss 0xc(%rax),%ymm10 + DB 196,98,125,24,88,20 ; vbroadcastss 0x14(%rax),%ymm11 + DB 197,172,89,201 ; vmulps %ymm1,%ymm10,%ymm1 + DB 196,193,116,88,203 ; vaddps %ymm11,%ymm1,%ymm1 + DB 197,180,89,192 ; vmulps %ymm0,%ymm9,%ymm0 + DB 197,252,88,201 ; vaddps %ymm1,%ymm0,%ymm1 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 + DB 255,224 ; jmpq *%rax PUBLIC _sk_matrix_3x4_avx _sk_matrix_3x4_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 - DB 196,98,125,24,72,12 ; vbroadcastss 0xc(%rax),%ymm9 - DB 196,98,125,24,80,24 ; vbroadcastss 0x18(%rax),%ymm10 - DB 196,98,125,24,88,36 ; vbroadcastss 0x24(%rax),%ymm11 - DB 197,44,89,210 ; vmulps %ymm2,%ymm10,%ymm10 - DB 196,65,44,88,211 ; vaddps %ymm11,%ymm10,%ymm10 - DB 197,52,89,201 ; vmulps %ymm1,%ymm9,%ymm9 - DB 196,65,52,88,202 ; vaddps %ymm10,%ymm9,%ymm9 - DB 197,60,89,192 ; vmulps %ymm0,%ymm8,%ymm8 - DB 196,65,60,88,193 ; vaddps %ymm9,%ymm8,%ymm8 - DB 196,98,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm9 - DB 196,98,125,24,80,16 ; vbroadcastss 0x10(%rax),%ymm10 - DB 196,98,125,24,88,28 ; vbroadcastss 0x1c(%rax),%ymm11 - DB 196,98,125,24,96,40 ; vbroadcastss 0x28(%rax),%ymm12 - DB 197,36,89,218 ; vmulps %ymm2,%ymm11,%ymm11 - DB 196,65,36,88,220 ; vaddps %ymm12,%ymm11,%ymm11 - DB 197,44,89,209 ; vmulps %ymm1,%ymm10,%ymm10 - DB 196,65,44,88,211 ; vaddps %ymm11,%ymm10,%ymm10 - DB 197,52,89,200 ; vmulps %ymm0,%ymm9,%ymm9 - DB 196,65,52,88,202 ; vaddps %ymm10,%ymm9,%ymm9 - DB 196,98,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm10 - DB 196,98,125,24,88,20 ; vbroadcastss 0x14(%rax),%ymm11 - DB 196,98,125,24,96,32 ; vbroadcastss 0x20(%rax),%ymm12 - DB 196,98,125,24,104,44 ; vbroadcastss 0x2c(%rax),%ymm13 - DB 197,156,89,210 ; vmulps %ymm2,%ymm12,%ymm2 - DB 196,193,108,88,213 ; vaddps %ymm13,%ymm2,%ymm2 - DB 197,164,89,201 ; vmulps %ymm1,%ymm11,%ymm1 - DB 197,244,88,202 ; vaddps %ymm2,%ymm1,%ymm1 - DB 197,172,89,192 ; vmulps %ymm0,%ymm10,%ymm0 - DB 197,252,88,209 ; vaddps %ymm1,%ymm0,%ymm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 - DB 197,124,41,201 ; vmovaps %ymm9,%ymm1 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,98,125,24,0 ; vbroadcastss (%rax),%ymm8 + DB 196,98,125,24,72,12 ; vbroadcastss 0xc(%rax),%ymm9 + DB 196,98,125,24,80,24 ; vbroadcastss 0x18(%rax),%ymm10 + DB 196,98,125,24,88,36 ; vbroadcastss 0x24(%rax),%ymm11 + DB 197,44,89,210 ; vmulps %ymm2,%ymm10,%ymm10 + DB 196,65,44,88,211 ; vaddps %ymm11,%ymm10,%ymm10 + DB 197,52,89,201 ; vmulps %ymm1,%ymm9,%ymm9 + DB 196,65,52,88,202 ; vaddps %ymm10,%ymm9,%ymm9 + DB 197,60,89,192 ; vmulps %ymm0,%ymm8,%ymm8 + DB 196,65,60,88,193 ; vaddps %ymm9,%ymm8,%ymm8 + DB 196,98,125,24,72,4 ; vbroadcastss 0x4(%rax),%ymm9 + DB 196,98,125,24,80,16 ; vbroadcastss 0x10(%rax),%ymm10 + DB 196,98,125,24,88,28 ; vbroadcastss 0x1c(%rax),%ymm11 + DB 196,98,125,24,96,40 ; vbroadcastss 0x28(%rax),%ymm12 + DB 197,36,89,218 ; vmulps %ymm2,%ymm11,%ymm11 + DB 196,65,36,88,220 ; vaddps %ymm12,%ymm11,%ymm11 + DB 197,44,89,209 ; vmulps %ymm1,%ymm10,%ymm10 + DB 196,65,44,88,211 ; vaddps %ymm11,%ymm10,%ymm10 + DB 197,52,89,200 ; vmulps %ymm0,%ymm9,%ymm9 + DB 196,65,52,88,202 ; vaddps %ymm10,%ymm9,%ymm9 + DB 196,98,125,24,80,8 ; vbroadcastss 0x8(%rax),%ymm10 + DB 196,98,125,24,88,20 ; vbroadcastss 0x14(%rax),%ymm11 + DB 196,98,125,24,96,32 ; vbroadcastss 0x20(%rax),%ymm12 + DB 196,98,125,24,104,44 ; vbroadcastss 0x2c(%rax),%ymm13 + DB 197,156,89,210 ; vmulps %ymm2,%ymm12,%ymm2 + DB 196,193,108,88,213 ; vaddps %ymm13,%ymm2,%ymm2 + DB 197,164,89,201 ; vmulps %ymm1,%ymm11,%ymm1 + DB 197,244,88,202 ; vaddps %ymm2,%ymm1,%ymm1 + DB 197,172,89,192 ; vmulps %ymm0,%ymm10,%ymm0 + DB 197,252,88,209 ; vaddps %ymm1,%ymm0,%ymm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 + DB 197,124,41,201 ; vmovaps %ymm9,%ymm1 + DB 255,224 ; jmpq *%rax PUBLIC _sk_linear_gradient_2stops_avx _sk_linear_gradient_2stops_avx LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 196,226,125,24,72,16 ; vbroadcastss 0x10(%rax),%ymm1 - DB 196,226,125,24,16 ; vbroadcastss (%rax),%ymm2 - DB 197,244,89,200 ; vmulps %ymm0,%ymm1,%ymm1 - DB 197,108,88,193 ; vaddps %ymm1,%ymm2,%ymm8 - DB 196,226,125,24,72,20 ; vbroadcastss 0x14(%rax),%ymm1 - DB 196,226,125,24,80,4 ; vbroadcastss 0x4(%rax),%ymm2 - DB 197,244,89,200 ; vmulps %ymm0,%ymm1,%ymm1 - DB 197,236,88,201 ; vaddps %ymm1,%ymm2,%ymm1 - DB 196,226,125,24,80,24 ; vbroadcastss 0x18(%rax),%ymm2 - DB 196,226,125,24,88,8 ; vbroadcastss 0x8(%rax),%ymm3 - DB 197,236,89,208 ; vmulps %ymm0,%ymm2,%ymm2 - DB 197,228,88,210 ; vaddps %ymm2,%ymm3,%ymm2 - DB 196,226,125,24,88,28 ; vbroadcastss 0x1c(%rax),%ymm3 - DB 196,98,125,24,72,12 ; vbroadcastss 0xc(%rax),%ymm9 - DB 197,228,89,192 ; vmulps %ymm0,%ymm3,%ymm0 - DB 197,180,88,216 ; vaddps %ymm0,%ymm9,%ymm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 196,226,125,24,72,16 ; vbroadcastss 0x10(%rax),%ymm1 + DB 196,226,125,24,16 ; vbroadcastss (%rax),%ymm2 + DB 197,244,89,200 ; vmulps %ymm0,%ymm1,%ymm1 + DB 197,108,88,193 ; vaddps %ymm1,%ymm2,%ymm8 + DB 196,226,125,24,72,20 ; vbroadcastss 0x14(%rax),%ymm1 + DB 196,226,125,24,80,4 ; vbroadcastss 0x4(%rax),%ymm2 + DB 197,244,89,200 ; vmulps %ymm0,%ymm1,%ymm1 + DB 197,236,88,201 ; vaddps %ymm1,%ymm2,%ymm1 + DB 196,226,125,24,80,24 ; vbroadcastss 0x18(%rax),%ymm2 + DB 196,226,125,24,88,8 ; vbroadcastss 0x8(%rax),%ymm3 + DB 197,236,89,208 ; vmulps %ymm0,%ymm2,%ymm2 + DB 197,228,88,210 ; vaddps %ymm2,%ymm3,%ymm2 + DB 196,226,125,24,88,28 ; vbroadcastss 0x1c(%rax),%ymm3 + DB 196,98,125,24,72,12 ; vbroadcastss 0xc(%rax),%ymm9 + DB 197,228,89,192 ; vmulps %ymm0,%ymm3,%ymm0 + DB 197,180,88,216 ; vaddps %ymm0,%ymm9,%ymm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 197,124,41,192 ; vmovaps %ymm8,%ymm0 + DB 255,224 ; jmpq *%rax PUBLIC _sk_start_pipeline_sse41 _sk_start_pipeline_sse41 LABEL PROC - DB 65,87 ; push %r15 - DB 65,86 ; push %r14 - DB 65,85 ; push %r13 - DB 65,84 ; push %r12 - DB 86 ; push %rsi - DB 87 ; push %rdi - DB 83 ; push %rbx - DB 72,129,236,160,0,0,0 ; sub $0xa0,%rsp - DB 68,15,41,188,36,144,0,0,0 ; movaps %xmm15,0x90(%rsp) - DB 68,15,41,180,36,128,0,0,0 ; movaps %xmm14,0x80(%rsp) - DB 68,15,41,108,36,112 ; movaps %xmm13,0x70(%rsp) - DB 68,15,41,100,36,96 ; movaps %xmm12,0x60(%rsp) - DB 68,15,41,92,36,80 ; movaps %xmm11,0x50(%rsp) - DB 68,15,41,84,36,64 ; movaps %xmm10,0x40(%rsp) - DB 68,15,41,76,36,48 ; movaps %xmm9,0x30(%rsp) - DB 68,15,41,68,36,32 ; movaps %xmm8,0x20(%rsp) - DB 15,41,124,36,16 ; movaps %xmm7,0x10(%rsp) - DB 15,41,52,36 ; movaps %xmm6,(%rsp) - DB 77,137,207 ; mov %r9,%r15 - DB 77,137,198 ; mov %r8,%r14 - DB 72,137,203 ; mov %rcx,%rbx - DB 72,137,214 ; mov %rdx,%rsi - DB 72,173 ; lods %ds:(%rsi),%rax - DB 73,137,196 ; mov %rax,%r12 - DB 73,137,245 ; mov %rsi,%r13 - DB 72,141,67,4 ; lea 0x4(%rbx),%rax - DB 76,57,248 ; cmp %r15,%rax - DB 118,5 ; jbe 73 <_sk_start_pipeline_sse41+0x73> - DB 72,137,216 ; mov %rbx,%rax - DB 235,52 ; jmp a7 <_sk_start_pipeline_sse41+0xa7> - DB 15,87,192 ; xorps %xmm0,%xmm0 - DB 15,87,201 ; xorps %xmm1,%xmm1 - DB 15,87,210 ; xorps %xmm2,%xmm2 - DB 15,87,219 ; xorps %xmm3,%xmm3 - DB 15,87,228 ; xorps %xmm4,%xmm4 - DB 15,87,237 ; xorps %xmm5,%xmm5 - DB 15,87,246 ; xorps %xmm6,%xmm6 - DB 15,87,255 ; xorps %xmm7,%xmm7 - DB 72,137,223 ; mov %rbx,%rdi - DB 76,137,238 ; mov %r13,%rsi - DB 76,137,242 ; mov %r14,%rdx - DB 65,255,212 ; callq *%r12 - DB 72,141,67,4 ; lea 0x4(%rbx),%rax - DB 72,131,195,8 ; add $0x8,%rbx - DB 76,57,251 ; cmp %r15,%rbx - DB 72,137,195 ; mov %rax,%rbx - DB 118,204 ; jbe 73 <_sk_start_pipeline_sse41+0x73> - DB 15,40,52,36 ; movaps (%rsp),%xmm6 - DB 15,40,124,36,16 ; movaps 0x10(%rsp),%xmm7 - DB 68,15,40,68,36,32 ; movaps 0x20(%rsp),%xmm8 - DB 68,15,40,76,36,48 ; movaps 0x30(%rsp),%xmm9 - DB 68,15,40,84,36,64 ; movaps 0x40(%rsp),%xmm10 - DB 68,15,40,92,36,80 ; movaps 0x50(%rsp),%xmm11 - DB 68,15,40,100,36,96 ; movaps 0x60(%rsp),%xmm12 - DB 68,15,40,108,36,112 ; movaps 0x70(%rsp),%xmm13 - DB 68,15,40,180,36,128,0,0,0 ; movaps 0x80(%rsp),%xmm14 - DB 68,15,40,188,36,144,0,0,0 ; movaps 0x90(%rsp),%xmm15 - DB 72,129,196,160,0,0,0 ; add $0xa0,%rsp - DB 91 ; pop %rbx - DB 95 ; pop %rdi - DB 94 ; pop %rsi - DB 65,92 ; pop %r12 - DB 65,93 ; pop %r13 - DB 65,94 ; pop %r14 - DB 65,95 ; pop %r15 - DB 195 ; retq + DB 65,87 ; push %r15 + DB 65,86 ; push %r14 + DB 65,85 ; push %r13 + DB 65,84 ; push %r12 + DB 86 ; push %rsi + DB 87 ; push %rdi + DB 83 ; push %rbx + DB 72,129,236,160,0,0,0 ; sub $0xa0,%rsp + DB 68,15,41,188,36,144,0,0,0 ; movaps %xmm15,0x90(%rsp) + DB 68,15,41,180,36,128,0,0,0 ; movaps %xmm14,0x80(%rsp) + DB 68,15,41,108,36,112 ; movaps %xmm13,0x70(%rsp) + DB 68,15,41,100,36,96 ; movaps %xmm12,0x60(%rsp) + DB 68,15,41,92,36,80 ; movaps %xmm11,0x50(%rsp) + DB 68,15,41,84,36,64 ; movaps %xmm10,0x40(%rsp) + DB 68,15,41,76,36,48 ; movaps %xmm9,0x30(%rsp) + DB 68,15,41,68,36,32 ; movaps %xmm8,0x20(%rsp) + DB 15,41,124,36,16 ; movaps %xmm7,0x10(%rsp) + DB 15,41,52,36 ; movaps %xmm6,(%rsp) + DB 77,137,207 ; mov %r9,%r15 + DB 77,137,198 ; mov %r8,%r14 + DB 72,137,203 ; mov %rcx,%rbx + DB 72,137,214 ; mov %rdx,%rsi + DB 72,173 ; lods %ds:(%rsi),%rax + DB 73,137,196 ; mov %rax,%r12 + DB 73,137,245 ; mov %rsi,%r13 + DB 72,141,67,4 ; lea 0x4(%rbx),%rax + DB 76,57,248 ; cmp %r15,%rax + DB 118,5 ; jbe 73 <_sk_start_pipeline_sse41+0x73> + DB 72,137,216 ; mov %rbx,%rax + DB 235,52 ; jmp a7 <_sk_start_pipeline_sse41+0xa7> + DB 15,87,192 ; xorps %xmm0,%xmm0 + DB 15,87,201 ; xorps %xmm1,%xmm1 + DB 15,87,210 ; xorps %xmm2,%xmm2 + DB 15,87,219 ; xorps %xmm3,%xmm3 + DB 15,87,228 ; xorps %xmm4,%xmm4 + DB 15,87,237 ; xorps %xmm5,%xmm5 + DB 15,87,246 ; xorps %xmm6,%xmm6 + DB 15,87,255 ; xorps %xmm7,%xmm7 + DB 72,137,223 ; mov %rbx,%rdi + DB 76,137,238 ; mov %r13,%rsi + DB 76,137,242 ; mov %r14,%rdx + DB 65,255,212 ; callq *%r12 + DB 72,141,67,4 ; lea 0x4(%rbx),%rax + DB 72,131,195,8 ; add $0x8,%rbx + DB 76,57,251 ; cmp %r15,%rbx + DB 72,137,195 ; mov %rax,%rbx + DB 118,204 ; jbe 73 <_sk_start_pipeline_sse41+0x73> + DB 15,40,52,36 ; movaps (%rsp),%xmm6 + DB 15,40,124,36,16 ; movaps 0x10(%rsp),%xmm7 + DB 68,15,40,68,36,32 ; movaps 0x20(%rsp),%xmm8 + DB 68,15,40,76,36,48 ; movaps 0x30(%rsp),%xmm9 + DB 68,15,40,84,36,64 ; movaps 0x40(%rsp),%xmm10 + DB 68,15,40,92,36,80 ; movaps 0x50(%rsp),%xmm11 + DB 68,15,40,100,36,96 ; movaps 0x60(%rsp),%xmm12 + DB 68,15,40,108,36,112 ; movaps 0x70(%rsp),%xmm13 + DB 68,15,40,180,36,128,0,0,0 ; movaps 0x80(%rsp),%xmm14 + DB 68,15,40,188,36,144,0,0,0 ; movaps 0x90(%rsp),%xmm15 + DB 72,129,196,160,0,0,0 ; add $0xa0,%rsp + DB 91 ; pop %rbx + DB 95 ; pop %rdi + DB 94 ; pop %rsi + DB 65,92 ; pop %r12 + DB 65,93 ; pop %r13 + DB 65,94 ; pop %r14 + DB 65,95 ; pop %r15 + DB 195 ; retq PUBLIC _sk_just_return_sse41 _sk_just_return_sse41 LABEL PROC - DB 195 ; retq + DB 195 ; retq PUBLIC _sk_seed_shader_sse41 _sk_seed_shader_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 102,15,110,199 ; movd %edi,%xmm0 - DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 - DB 15,91,200 ; cvtdq2ps %xmm0,%xmm1 - DB 243,15,16,18 ; movss (%rdx),%xmm2 - DB 243,15,16,90,4 ; movss 0x4(%rdx),%xmm3 - DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 - DB 15,88,203 ; addps %xmm3,%xmm1 - DB 15,16,66,20 ; movups 0x14(%rdx),%xmm0 - DB 15,88,193 ; addps %xmm1,%xmm0 - DB 102,15,110,8 ; movd (%rax),%xmm1 - DB 102,15,112,201,0 ; pshufd $0x0,%xmm1,%xmm1 - DB 15,91,201 ; cvtdq2ps %xmm1,%xmm1 - DB 15,88,203 ; addps %xmm3,%xmm1 - DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,87,219 ; xorps %xmm3,%xmm3 - DB 15,87,228 ; xorps %xmm4,%xmm4 - DB 15,87,237 ; xorps %xmm5,%xmm5 - DB 15,87,246 ; xorps %xmm6,%xmm6 - DB 15,87,255 ; xorps %xmm7,%xmm7 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 102,15,110,199 ; movd %edi,%xmm0 + DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 + DB 15,91,200 ; cvtdq2ps %xmm0,%xmm1 + DB 243,15,16,18 ; movss (%rdx),%xmm2 + DB 243,15,16,90,4 ; movss 0x4(%rdx),%xmm3 + DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 + DB 15,88,203 ; addps %xmm3,%xmm1 + DB 15,16,66,20 ; movups 0x14(%rdx),%xmm0 + DB 15,88,193 ; addps %xmm1,%xmm0 + DB 102,15,110,8 ; movd (%rax),%xmm1 + DB 102,15,112,201,0 ; pshufd $0x0,%xmm1,%xmm1 + DB 15,91,201 ; cvtdq2ps %xmm1,%xmm1 + DB 15,88,203 ; addps %xmm3,%xmm1 + DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,87,219 ; xorps %xmm3,%xmm3 + DB 15,87,228 ; xorps %xmm4,%xmm4 + DB 15,87,237 ; xorps %xmm5,%xmm5 + DB 15,87,246 ; xorps %xmm6,%xmm6 + DB 15,87,255 ; xorps %xmm7,%xmm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_constant_color_sse41 _sk_constant_color_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,16,24 ; movups (%rax),%xmm3 - DB 15,40,195 ; movaps %xmm3,%xmm0 - DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 - DB 15,40,203 ; movaps %xmm3,%xmm1 - DB 15,198,201,85 ; shufps $0x55,%xmm1,%xmm1 - DB 15,40,211 ; movaps %xmm3,%xmm2 - DB 15,198,210,170 ; shufps $0xaa,%xmm2,%xmm2 - DB 15,198,219,255 ; shufps $0xff,%xmm3,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,16,24 ; movups (%rax),%xmm3 + DB 15,40,195 ; movaps %xmm3,%xmm0 + DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 + DB 15,40,203 ; movaps %xmm3,%xmm1 + DB 15,198,201,85 ; shufps $0x55,%xmm1,%xmm1 + DB 15,40,211 ; movaps %xmm3,%xmm2 + DB 15,198,210,170 ; shufps $0xaa,%xmm2,%xmm2 + DB 15,198,219,255 ; shufps $0xff,%xmm3,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clear_sse41 _sk_clear_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,87,192 ; xorps %xmm0,%xmm0 - DB 15,87,201 ; xorps %xmm1,%xmm1 - DB 15,87,210 ; xorps %xmm2,%xmm2 - DB 15,87,219 ; xorps %xmm3,%xmm3 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,87,192 ; xorps %xmm0,%xmm0 + DB 15,87,201 ; xorps %xmm1,%xmm1 + DB 15,87,210 ; xorps %xmm2,%xmm2 + DB 15,87,219 ; xorps %xmm3,%xmm3 + DB 255,224 ; jmpq *%rax PUBLIC _sk_plus__sse41 _sk_plus__sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,88,196 ; addps %xmm4,%xmm0 - DB 15,88,205 ; addps %xmm5,%xmm1 - DB 15,88,214 ; addps %xmm6,%xmm2 - DB 15,88,223 ; addps %xmm7,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,88,196 ; addps %xmm4,%xmm0 + DB 15,88,205 ; addps %xmm5,%xmm1 + DB 15,88,214 ; addps %xmm6,%xmm2 + DB 15,88,223 ; addps %xmm7,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_srcover_sse41 _sk_srcover_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,2 ; movss (%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 68,15,92,195 ; subps %xmm3,%xmm8 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,204 ; mulps %xmm4,%xmm9 - DB 65,15,88,193 ; addps %xmm9,%xmm0 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,205 ; mulps %xmm5,%xmm9 - DB 65,15,88,201 ; addps %xmm9,%xmm1 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,206 ; mulps %xmm6,%xmm9 - DB 65,15,88,209 ; addps %xmm9,%xmm2 - DB 68,15,89,199 ; mulps %xmm7,%xmm8 - DB 65,15,88,216 ; addps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,2 ; movss (%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 68,15,92,195 ; subps %xmm3,%xmm8 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,204 ; mulps %xmm4,%xmm9 + DB 65,15,88,193 ; addps %xmm9,%xmm0 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,205 ; mulps %xmm5,%xmm9 + DB 65,15,88,201 ; addps %xmm9,%xmm1 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,206 ; mulps %xmm6,%xmm9 + DB 65,15,88,209 ; addps %xmm9,%xmm2 + DB 68,15,89,199 ; mulps %xmm7,%xmm8 + DB 65,15,88,216 ; addps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_dstover_sse41 _sk_dstover_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,2 ; movss (%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 68,15,92,199 ; subps %xmm7,%xmm8 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 15,88,196 ; addps %xmm4,%xmm0 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 15,88,205 ; addps %xmm5,%xmm1 - DB 65,15,89,208 ; mulps %xmm8,%xmm2 - DB 15,88,214 ; addps %xmm6,%xmm2 - DB 65,15,89,216 ; mulps %xmm8,%xmm3 - DB 15,88,223 ; addps %xmm7,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,2 ; movss (%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 68,15,92,199 ; subps %xmm7,%xmm8 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 15,88,196 ; addps %xmm4,%xmm0 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 15,88,205 ; addps %xmm5,%xmm1 + DB 65,15,89,208 ; mulps %xmm8,%xmm2 + DB 15,88,214 ; addps %xmm6,%xmm2 + DB 65,15,89,216 ; mulps %xmm8,%xmm3 + DB 15,88,223 ; addps %xmm7,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_0_sse41 _sk_clamp_0_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 69,15,87,192 ; xorps %xmm8,%xmm8 - DB 65,15,95,192 ; maxps %xmm8,%xmm0 - DB 65,15,95,200 ; maxps %xmm8,%xmm1 - DB 65,15,95,208 ; maxps %xmm8,%xmm2 - DB 65,15,95,216 ; maxps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 69,15,87,192 ; xorps %xmm8,%xmm8 + DB 65,15,95,192 ; maxps %xmm8,%xmm0 + DB 65,15,95,200 ; maxps %xmm8,%xmm1 + DB 65,15,95,208 ; maxps %xmm8,%xmm2 + DB 65,15,95,216 ; maxps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_1_sse41 _sk_clamp_1_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,2 ; movss (%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 65,15,93,192 ; minps %xmm8,%xmm0 - DB 65,15,93,200 ; minps %xmm8,%xmm1 - DB 65,15,93,208 ; minps %xmm8,%xmm2 - DB 65,15,93,216 ; minps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,2 ; movss (%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 65,15,93,192 ; minps %xmm8,%xmm0 + DB 65,15,93,200 ; minps %xmm8,%xmm1 + DB 65,15,93,208 ; minps %xmm8,%xmm2 + DB 65,15,93,216 ; minps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_a_sse41 _sk_clamp_a_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,2 ; movss (%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 65,15,93,216 ; minps %xmm8,%xmm3 - DB 15,93,195 ; minps %xmm3,%xmm0 - DB 15,93,203 ; minps %xmm3,%xmm1 - DB 15,93,211 ; minps %xmm3,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,2 ; movss (%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 65,15,93,216 ; minps %xmm8,%xmm3 + DB 15,93,195 ; minps %xmm3,%xmm0 + DB 15,93,203 ; minps %xmm3,%xmm1 + DB 15,93,211 ; minps %xmm3,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_set_rgb_sse41 _sk_set_rgb_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,15,16,0 ; movss (%rax),%xmm0 - DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 - DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 - DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 - DB 243,15,16,80,8 ; movss 0x8(%rax),%xmm2 - DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,15,16,0 ; movss (%rax),%xmm0 + DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 + DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 + DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 + DB 243,15,16,80,8 ; movss 0x8(%rax),%xmm2 + DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_swap_rb_sse41 _sk_swap_rb_sse41 LABEL PROC - DB 68,15,40,192 ; movaps %xmm0,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,40,194 ; movaps %xmm2,%xmm0 - DB 65,15,40,208 ; movaps %xmm8,%xmm2 - DB 255,224 ; jmpq *%rax + DB 68,15,40,192 ; movaps %xmm0,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,40,194 ; movaps %xmm2,%xmm0 + DB 65,15,40,208 ; movaps %xmm8,%xmm2 + DB 255,224 ; jmpq *%rax PUBLIC _sk_swap_sse41 _sk_swap_sse41 LABEL PROC - DB 68,15,40,195 ; movaps %xmm3,%xmm8 - DB 68,15,40,202 ; movaps %xmm2,%xmm9 - DB 68,15,40,209 ; movaps %xmm1,%xmm10 - DB 68,15,40,216 ; movaps %xmm0,%xmm11 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,40,196 ; movaps %xmm4,%xmm0 - DB 15,40,205 ; movaps %xmm5,%xmm1 - DB 15,40,214 ; movaps %xmm6,%xmm2 - DB 15,40,223 ; movaps %xmm7,%xmm3 - DB 65,15,40,227 ; movaps %xmm11,%xmm4 - DB 65,15,40,234 ; movaps %xmm10,%xmm5 - DB 65,15,40,241 ; movaps %xmm9,%xmm6 - DB 65,15,40,248 ; movaps %xmm8,%xmm7 - DB 255,224 ; jmpq *%rax + DB 68,15,40,195 ; movaps %xmm3,%xmm8 + DB 68,15,40,202 ; movaps %xmm2,%xmm9 + DB 68,15,40,209 ; movaps %xmm1,%xmm10 + DB 68,15,40,216 ; movaps %xmm0,%xmm11 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,40,196 ; movaps %xmm4,%xmm0 + DB 15,40,205 ; movaps %xmm5,%xmm1 + DB 15,40,214 ; movaps %xmm6,%xmm2 + DB 15,40,223 ; movaps %xmm7,%xmm3 + DB 65,15,40,227 ; movaps %xmm11,%xmm4 + DB 65,15,40,234 ; movaps %xmm10,%xmm5 + DB 65,15,40,241 ; movaps %xmm9,%xmm6 + DB 65,15,40,248 ; movaps %xmm8,%xmm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_move_src_dst_sse41 _sk_move_src_dst_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,40,224 ; movaps %xmm0,%xmm4 - DB 15,40,233 ; movaps %xmm1,%xmm5 - DB 15,40,242 ; movaps %xmm2,%xmm6 - DB 15,40,251 ; movaps %xmm3,%xmm7 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,40,224 ; movaps %xmm0,%xmm4 + DB 15,40,233 ; movaps %xmm1,%xmm5 + DB 15,40,242 ; movaps %xmm2,%xmm6 + DB 15,40,251 ; movaps %xmm3,%xmm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_move_dst_src_sse41 _sk_move_dst_src_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,40,196 ; movaps %xmm4,%xmm0 - DB 15,40,205 ; movaps %xmm5,%xmm1 - DB 15,40,214 ; movaps %xmm6,%xmm2 - DB 15,40,223 ; movaps %xmm7,%xmm3 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,40,196 ; movaps %xmm4,%xmm0 + DB 15,40,205 ; movaps %xmm5,%xmm1 + DB 15,40,214 ; movaps %xmm6,%xmm2 + DB 15,40,223 ; movaps %xmm7,%xmm3 + DB 255,224 ; jmpq *%rax PUBLIC _sk_premul_sse41 _sk_premul_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,89,195 ; mulps %xmm3,%xmm0 - DB 15,89,203 ; mulps %xmm3,%xmm1 - DB 15,89,211 ; mulps %xmm3,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,89,195 ; mulps %xmm3,%xmm0 + DB 15,89,203 ; mulps %xmm3,%xmm1 + DB 15,89,211 ; mulps %xmm3,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_unpremul_sse41 _sk_unpremul_sse41 LABEL PROC - DB 68,15,40,192 ; movaps %xmm0,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 69,15,87,201 ; xorps %xmm9,%xmm9 - DB 243,68,15,16,18 ; movss (%rdx),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 68,15,94,211 ; divps %xmm3,%xmm10 - DB 15,40,195 ; movaps %xmm3,%xmm0 - DB 65,15,194,193,0 ; cmpeqps %xmm9,%xmm0 - DB 102,69,15,56,20,209 ; blendvps %xmm0,%xmm9,%xmm10 - DB 69,15,89,194 ; mulps %xmm10,%xmm8 - DB 65,15,89,202 ; mulps %xmm10,%xmm1 - DB 65,15,89,210 ; mulps %xmm10,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,192 ; movaps %xmm8,%xmm0 - DB 255,224 ; jmpq *%rax + DB 68,15,40,192 ; movaps %xmm0,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 69,15,87,201 ; xorps %xmm9,%xmm9 + DB 243,68,15,16,18 ; movss (%rdx),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 68,15,94,211 ; divps %xmm3,%xmm10 + DB 15,40,195 ; movaps %xmm3,%xmm0 + DB 65,15,194,193,0 ; cmpeqps %xmm9,%xmm0 + DB 102,69,15,56,20,209 ; blendvps %xmm0,%xmm9,%xmm10 + DB 69,15,89,194 ; mulps %xmm10,%xmm8 + DB 65,15,89,202 ; mulps %xmm10,%xmm1 + DB 65,15,89,210 ; mulps %xmm10,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,192 ; movaps %xmm8,%xmm0 + DB 255,224 ; jmpq *%rax PUBLIC _sk_from_srgb_sse41 _sk_from_srgb_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,90,64 ; movss 0x40(%rdx),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 69,15,40,211 ; movaps %xmm11,%xmm10 - DB 68,15,89,208 ; mulps %xmm0,%xmm10 - DB 68,15,40,240 ; movaps %xmm0,%xmm14 - DB 69,15,89,246 ; mulps %xmm14,%xmm14 - DB 243,68,15,16,66,60 ; movss 0x3c(%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 243,68,15,16,98,52 ; movss 0x34(%rdx),%xmm12 - DB 243,68,15,16,106,56 ; movss 0x38(%rdx),%xmm13 - DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,200 ; mulps %xmm0,%xmm9 - DB 69,15,88,205 ; addps %xmm13,%xmm9 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 69,15,89,206 ; mulps %xmm14,%xmm9 - DB 69,15,88,204 ; addps %xmm12,%xmm9 - DB 243,68,15,16,114,68 ; movss 0x44(%rdx),%xmm14 - DB 69,15,198,246,0 ; shufps $0x0,%xmm14,%xmm14 - DB 65,15,194,198,1 ; cmpltps %xmm14,%xmm0 - DB 102,69,15,56,20,202 ; blendvps %xmm0,%xmm10,%xmm9 - DB 69,15,40,251 ; movaps %xmm11,%xmm15 - DB 68,15,89,249 ; mulps %xmm1,%xmm15 - DB 15,40,193 ; movaps %xmm1,%xmm0 - DB 15,89,192 ; mulps %xmm0,%xmm0 - DB 69,15,40,208 ; movaps %xmm8,%xmm10 - DB 68,15,89,209 ; mulps %xmm1,%xmm10 - DB 69,15,88,213 ; addps %xmm13,%xmm10 - DB 68,15,89,208 ; mulps %xmm0,%xmm10 - DB 69,15,88,212 ; addps %xmm12,%xmm10 - DB 65,15,194,206,1 ; cmpltps %xmm14,%xmm1 - DB 15,40,193 ; movaps %xmm1,%xmm0 - DB 102,69,15,56,20,215 ; blendvps %xmm0,%xmm15,%xmm10 - DB 68,15,89,218 ; mulps %xmm2,%xmm11 - DB 15,40,194 ; movaps %xmm2,%xmm0 - DB 15,89,192 ; mulps %xmm0,%xmm0 - DB 68,15,89,194 ; mulps %xmm2,%xmm8 - DB 69,15,88,197 ; addps %xmm13,%xmm8 - DB 68,15,89,192 ; mulps %xmm0,%xmm8 - DB 69,15,88,196 ; addps %xmm12,%xmm8 - DB 65,15,194,214,1 ; cmpltps %xmm14,%xmm2 - DB 15,40,194 ; movaps %xmm2,%xmm0 - DB 102,69,15,56,20,195 ; blendvps %xmm0,%xmm11,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,193 ; movaps %xmm9,%xmm0 - DB 65,15,40,202 ; movaps %xmm10,%xmm1 - DB 65,15,40,208 ; movaps %xmm8,%xmm2 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,90,64 ; movss 0x40(%rdx),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 69,15,40,211 ; movaps %xmm11,%xmm10 + DB 68,15,89,208 ; mulps %xmm0,%xmm10 + DB 68,15,40,240 ; movaps %xmm0,%xmm14 + DB 69,15,89,246 ; mulps %xmm14,%xmm14 + DB 243,68,15,16,66,60 ; movss 0x3c(%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 243,68,15,16,98,52 ; movss 0x34(%rdx),%xmm12 + DB 243,68,15,16,106,56 ; movss 0x38(%rdx),%xmm13 + DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,200 ; mulps %xmm0,%xmm9 + DB 69,15,88,205 ; addps %xmm13,%xmm9 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 69,15,89,206 ; mulps %xmm14,%xmm9 + DB 69,15,88,204 ; addps %xmm12,%xmm9 + DB 243,68,15,16,114,68 ; movss 0x44(%rdx),%xmm14 + DB 69,15,198,246,0 ; shufps $0x0,%xmm14,%xmm14 + DB 65,15,194,198,1 ; cmpltps %xmm14,%xmm0 + DB 102,69,15,56,20,202 ; blendvps %xmm0,%xmm10,%xmm9 + DB 69,15,40,251 ; movaps %xmm11,%xmm15 + DB 68,15,89,249 ; mulps %xmm1,%xmm15 + DB 15,40,193 ; movaps %xmm1,%xmm0 + DB 15,89,192 ; mulps %xmm0,%xmm0 + DB 69,15,40,208 ; movaps %xmm8,%xmm10 + DB 68,15,89,209 ; mulps %xmm1,%xmm10 + DB 69,15,88,213 ; addps %xmm13,%xmm10 + DB 68,15,89,208 ; mulps %xmm0,%xmm10 + DB 69,15,88,212 ; addps %xmm12,%xmm10 + DB 65,15,194,206,1 ; cmpltps %xmm14,%xmm1 + DB 15,40,193 ; movaps %xmm1,%xmm0 + DB 102,69,15,56,20,215 ; blendvps %xmm0,%xmm15,%xmm10 + DB 68,15,89,218 ; mulps %xmm2,%xmm11 + DB 15,40,194 ; movaps %xmm2,%xmm0 + DB 15,89,192 ; mulps %xmm0,%xmm0 + DB 68,15,89,194 ; mulps %xmm2,%xmm8 + DB 69,15,88,197 ; addps %xmm13,%xmm8 + DB 68,15,89,192 ; mulps %xmm0,%xmm8 + DB 69,15,88,196 ; addps %xmm12,%xmm8 + DB 65,15,194,214,1 ; cmpltps %xmm14,%xmm2 + DB 15,40,194 ; movaps %xmm2,%xmm0 + DB 102,69,15,56,20,195 ; blendvps %xmm0,%xmm11,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,193 ; movaps %xmm9,%xmm0 + DB 65,15,40,202 ; movaps %xmm10,%xmm1 + DB 65,15,40,208 ; movaps %xmm8,%xmm2 + DB 255,224 ; jmpq *%rax PUBLIC _sk_to_srgb_sse41 _sk_to_srgb_sse41 LABEL PROC - DB 72,131,236,24 ; sub $0x18,%rsp - DB 15,41,60,36 ; movaps %xmm7,(%rsp) - DB 15,40,254 ; movaps %xmm6,%xmm7 - DB 15,40,245 ; movaps %xmm5,%xmm6 - DB 15,40,236 ; movaps %xmm4,%xmm5 - DB 15,40,227 ; movaps %xmm3,%xmm4 - DB 68,15,40,194 ; movaps %xmm2,%xmm8 - DB 15,40,217 ; movaps %xmm1,%xmm3 - DB 15,82,208 ; rsqrtps %xmm0,%xmm2 - DB 68,15,83,202 ; rcpps %xmm2,%xmm9 - DB 68,15,82,210 ; rsqrtps %xmm2,%xmm10 - DB 243,15,16,18 ; movss (%rdx),%xmm2 - DB 243,68,15,16,90,72 ; movss 0x48(%rdx),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 65,15,40,203 ; movaps %xmm11,%xmm1 - DB 15,89,200 ; mulps %xmm0,%xmm1 - DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 - DB 243,68,15,16,98,76 ; movss 0x4c(%rdx),%xmm12 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 243,68,15,16,106,80 ; movss 0x50(%rdx),%xmm13 - DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 - DB 243,68,15,16,114,84 ; movss 0x54(%rdx),%xmm14 - DB 69,15,198,246,0 ; shufps $0x0,%xmm14,%xmm14 - DB 69,15,89,205 ; mulps %xmm13,%xmm9 - DB 69,15,88,206 ; addps %xmm14,%xmm9 - DB 69,15,89,212 ; mulps %xmm12,%xmm10 - DB 69,15,88,209 ; addps %xmm9,%xmm10 - DB 68,15,40,202 ; movaps %xmm2,%xmm9 - DB 69,15,93,202 ; minps %xmm10,%xmm9 - DB 243,68,15,16,122,88 ; movss 0x58(%rdx),%xmm15 - DB 69,15,198,255,0 ; shufps $0x0,%xmm15,%xmm15 - DB 65,15,194,199,1 ; cmpltps %xmm15,%xmm0 - DB 102,68,15,56,20,201 ; blendvps %xmm0,%xmm1,%xmm9 - DB 15,82,195 ; rsqrtps %xmm3,%xmm0 - DB 15,83,200 ; rcpps %xmm0,%xmm1 - DB 15,82,192 ; rsqrtps %xmm0,%xmm0 - DB 65,15,89,205 ; mulps %xmm13,%xmm1 - DB 65,15,88,206 ; addps %xmm14,%xmm1 - DB 65,15,89,196 ; mulps %xmm12,%xmm0 - DB 15,88,193 ; addps %xmm1,%xmm0 - DB 68,15,40,210 ; movaps %xmm2,%xmm10 - DB 68,15,93,208 ; minps %xmm0,%xmm10 - DB 65,15,40,203 ; movaps %xmm11,%xmm1 - DB 15,89,203 ; mulps %xmm3,%xmm1 - DB 65,15,194,223,1 ; cmpltps %xmm15,%xmm3 - DB 15,40,195 ; movaps %xmm3,%xmm0 - DB 102,68,15,56,20,209 ; blendvps %xmm0,%xmm1,%xmm10 - DB 65,15,82,192 ; rsqrtps %xmm8,%xmm0 - DB 15,83,200 ; rcpps %xmm0,%xmm1 - DB 65,15,89,205 ; mulps %xmm13,%xmm1 - DB 65,15,88,206 ; addps %xmm14,%xmm1 - DB 15,82,192 ; rsqrtps %xmm0,%xmm0 - DB 65,15,89,196 ; mulps %xmm12,%xmm0 - DB 15,88,193 ; addps %xmm1,%xmm0 - DB 15,93,208 ; minps %xmm0,%xmm2 - DB 69,15,89,216 ; mulps %xmm8,%xmm11 - DB 69,15,194,199,1 ; cmpltps %xmm15,%xmm8 - DB 65,15,40,192 ; movaps %xmm8,%xmm0 - DB 102,65,15,56,20,211 ; blendvps %xmm0,%xmm11,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,193 ; movaps %xmm9,%xmm0 - DB 65,15,40,202 ; movaps %xmm10,%xmm1 - DB 15,40,220 ; movaps %xmm4,%xmm3 - DB 15,40,229 ; movaps %xmm5,%xmm4 - DB 15,40,238 ; movaps %xmm6,%xmm5 - DB 15,40,247 ; movaps %xmm7,%xmm6 - DB 15,40,60,36 ; movaps (%rsp),%xmm7 - DB 72,131,196,24 ; add $0x18,%rsp - DB 255,224 ; jmpq *%rax + DB 72,131,236,24 ; sub $0x18,%rsp + DB 15,41,60,36 ; movaps %xmm7,(%rsp) + DB 15,40,254 ; movaps %xmm6,%xmm7 + DB 15,40,245 ; movaps %xmm5,%xmm6 + DB 15,40,236 ; movaps %xmm4,%xmm5 + DB 15,40,227 ; movaps %xmm3,%xmm4 + DB 68,15,40,194 ; movaps %xmm2,%xmm8 + DB 15,40,217 ; movaps %xmm1,%xmm3 + DB 15,82,208 ; rsqrtps %xmm0,%xmm2 + DB 68,15,83,202 ; rcpps %xmm2,%xmm9 + DB 68,15,82,210 ; rsqrtps %xmm2,%xmm10 + DB 243,15,16,18 ; movss (%rdx),%xmm2 + DB 243,68,15,16,90,72 ; movss 0x48(%rdx),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 65,15,40,203 ; movaps %xmm11,%xmm1 + DB 15,89,200 ; mulps %xmm0,%xmm1 + DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 + DB 243,68,15,16,98,76 ; movss 0x4c(%rdx),%xmm12 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 243,68,15,16,106,80 ; movss 0x50(%rdx),%xmm13 + DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 + DB 243,68,15,16,114,84 ; movss 0x54(%rdx),%xmm14 + DB 69,15,198,246,0 ; shufps $0x0,%xmm14,%xmm14 + DB 69,15,89,205 ; mulps %xmm13,%xmm9 + DB 69,15,88,206 ; addps %xmm14,%xmm9 + DB 69,15,89,212 ; mulps %xmm12,%xmm10 + DB 69,15,88,209 ; addps %xmm9,%xmm10 + DB 68,15,40,202 ; movaps %xmm2,%xmm9 + DB 69,15,93,202 ; minps %xmm10,%xmm9 + DB 243,68,15,16,122,88 ; movss 0x58(%rdx),%xmm15 + DB 69,15,198,255,0 ; shufps $0x0,%xmm15,%xmm15 + DB 65,15,194,199,1 ; cmpltps %xmm15,%xmm0 + DB 102,68,15,56,20,201 ; blendvps %xmm0,%xmm1,%xmm9 + DB 15,82,195 ; rsqrtps %xmm3,%xmm0 + DB 15,83,200 ; rcpps %xmm0,%xmm1 + DB 15,82,192 ; rsqrtps %xmm0,%xmm0 + DB 65,15,89,205 ; mulps %xmm13,%xmm1 + DB 65,15,88,206 ; addps %xmm14,%xmm1 + DB 65,15,89,196 ; mulps %xmm12,%xmm0 + DB 15,88,193 ; addps %xmm1,%xmm0 + DB 68,15,40,210 ; movaps %xmm2,%xmm10 + DB 68,15,93,208 ; minps %xmm0,%xmm10 + DB 65,15,40,203 ; movaps %xmm11,%xmm1 + DB 15,89,203 ; mulps %xmm3,%xmm1 + DB 65,15,194,223,1 ; cmpltps %xmm15,%xmm3 + DB 15,40,195 ; movaps %xmm3,%xmm0 + DB 102,68,15,56,20,209 ; blendvps %xmm0,%xmm1,%xmm10 + DB 65,15,82,192 ; rsqrtps %xmm8,%xmm0 + DB 15,83,200 ; rcpps %xmm0,%xmm1 + DB 65,15,89,205 ; mulps %xmm13,%xmm1 + DB 65,15,88,206 ; addps %xmm14,%xmm1 + DB 15,82,192 ; rsqrtps %xmm0,%xmm0 + DB 65,15,89,196 ; mulps %xmm12,%xmm0 + DB 15,88,193 ; addps %xmm1,%xmm0 + DB 15,93,208 ; minps %xmm0,%xmm2 + DB 69,15,89,216 ; mulps %xmm8,%xmm11 + DB 69,15,194,199,1 ; cmpltps %xmm15,%xmm8 + DB 65,15,40,192 ; movaps %xmm8,%xmm0 + DB 102,65,15,56,20,211 ; blendvps %xmm0,%xmm11,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,193 ; movaps %xmm9,%xmm0 + DB 65,15,40,202 ; movaps %xmm10,%xmm1 + DB 15,40,220 ; movaps %xmm4,%xmm3 + DB 15,40,229 ; movaps %xmm5,%xmm4 + DB 15,40,238 ; movaps %xmm6,%xmm5 + DB 15,40,247 ; movaps %xmm7,%xmm6 + DB 15,40,60,36 ; movaps (%rsp),%xmm7 + DB 72,131,196,24 ; add $0x18,%rsp + DB 255,224 ; jmpq *%rax PUBLIC _sk_scale_u8_sse41 _sk_scale_u8_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 102,68,15,56,49,4,56 ; pmovzxbd (%rax,%rdi,1),%xmm8 - DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 - DB 243,68,15,16,74,12 ; movss 0xc(%rdx),%xmm9 - DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 - DB 69,15,89,200 ; mulps %xmm8,%xmm9 - DB 65,15,89,193 ; mulps %xmm9,%xmm0 - DB 65,15,89,201 ; mulps %xmm9,%xmm1 - DB 65,15,89,209 ; mulps %xmm9,%xmm2 - DB 65,15,89,217 ; mulps %xmm9,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 102,68,15,56,49,4,56 ; pmovzxbd (%rax,%rdi,1),%xmm8 + DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 + DB 243,68,15,16,74,12 ; movss 0xc(%rdx),%xmm9 + DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 + DB 69,15,89,200 ; mulps %xmm8,%xmm9 + DB 65,15,89,193 ; mulps %xmm9,%xmm0 + DB 65,15,89,201 ; mulps %xmm9,%xmm1 + DB 65,15,89,209 ; mulps %xmm9,%xmm2 + DB 65,15,89,217 ; mulps %xmm9,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_lerp_u8_sse41 _sk_lerp_u8_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 102,68,15,56,49,4,56 ; pmovzxbd (%rax,%rdi,1),%xmm8 - DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 - DB 243,68,15,16,74,12 ; movss 0xc(%rdx),%xmm9 - DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 - DB 69,15,89,200 ; mulps %xmm8,%xmm9 - DB 15,92,196 ; subps %xmm4,%xmm0 - DB 65,15,89,193 ; mulps %xmm9,%xmm0 - DB 15,88,196 ; addps %xmm4,%xmm0 - DB 15,92,205 ; subps %xmm5,%xmm1 - DB 65,15,89,201 ; mulps %xmm9,%xmm1 - DB 15,88,205 ; addps %xmm5,%xmm1 - DB 15,92,214 ; subps %xmm6,%xmm2 - DB 65,15,89,209 ; mulps %xmm9,%xmm2 - DB 15,88,214 ; addps %xmm6,%xmm2 - DB 15,92,223 ; subps %xmm7,%xmm3 - DB 65,15,89,217 ; mulps %xmm9,%xmm3 - DB 15,88,223 ; addps %xmm7,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 102,68,15,56,49,4,56 ; pmovzxbd (%rax,%rdi,1),%xmm8 + DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 + DB 243,68,15,16,74,12 ; movss 0xc(%rdx),%xmm9 + DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 + DB 69,15,89,200 ; mulps %xmm8,%xmm9 + DB 15,92,196 ; subps %xmm4,%xmm0 + DB 65,15,89,193 ; mulps %xmm9,%xmm0 + DB 15,88,196 ; addps %xmm4,%xmm0 + DB 15,92,205 ; subps %xmm5,%xmm1 + DB 65,15,89,201 ; mulps %xmm9,%xmm1 + DB 15,88,205 ; addps %xmm5,%xmm1 + DB 15,92,214 ; subps %xmm6,%xmm2 + DB 65,15,89,209 ; mulps %xmm9,%xmm2 + DB 15,88,214 ; addps %xmm6,%xmm2 + DB 15,92,223 ; subps %xmm7,%xmm3 + DB 65,15,89,217 ; mulps %xmm9,%xmm3 + DB 15,88,223 ; addps %xmm7,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_tables_sse41 _sk_load_tables_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,8 ; mov (%rax),%rcx - DB 76,139,64,8 ; mov 0x8(%rax),%r8 - DB 243,68,15,111,4,185 ; movdqu (%rcx,%rdi,4),%xmm8 - DB 102,15,110,66,16 ; movd 0x10(%rdx),%xmm0 - DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 - DB 102,65,15,111,200 ; movdqa %xmm8,%xmm1 - DB 102,15,114,209,8 ; psrld $0x8,%xmm1 - DB 102,15,219,200 ; pand %xmm0,%xmm1 - DB 102,65,15,111,208 ; movdqa %xmm8,%xmm2 - DB 102,15,114,210,16 ; psrld $0x10,%xmm2 - DB 102,15,219,208 ; pand %xmm0,%xmm2 - DB 102,65,15,219,192 ; pand %xmm8,%xmm0 - DB 102,72,15,58,22,193,1 ; pextrq $0x1,%xmm0,%rcx - DB 65,137,201 ; mov %ecx,%r9d - DB 72,193,233,32 ; shr $0x20,%rcx - DB 102,73,15,126,194 ; movq %xmm0,%r10 - DB 69,137,211 ; mov %r10d,%r11d - DB 73,193,234,32 ; shr $0x20,%r10 - DB 243,67,15,16,4,152 ; movss (%r8,%r11,4),%xmm0 - DB 102,67,15,58,33,4,144,16 ; insertps $0x10,(%r8,%r10,4),%xmm0 - DB 102,67,15,58,33,4,136,32 ; insertps $0x20,(%r8,%r9,4),%xmm0 - DB 102,65,15,58,33,4,136,48 ; insertps $0x30,(%r8,%rcx,4),%xmm0 - DB 72,139,72,16 ; mov 0x10(%rax),%rcx - DB 102,73,15,58,22,200,1 ; pextrq $0x1,%xmm1,%r8 - DB 69,137,193 ; mov %r8d,%r9d - DB 73,193,232,32 ; shr $0x20,%r8 - DB 102,73,15,126,202 ; movq %xmm1,%r10 - DB 69,137,211 ; mov %r10d,%r11d - DB 73,193,234,32 ; shr $0x20,%r10 - DB 243,66,15,16,12,153 ; movss (%rcx,%r11,4),%xmm1 - DB 102,66,15,58,33,12,145,16 ; insertps $0x10,(%rcx,%r10,4),%xmm1 - DB 243,66,15,16,28,137 ; movss (%rcx,%r9,4),%xmm3 - DB 102,15,58,33,203,32 ; insertps $0x20,%xmm3,%xmm1 - DB 243,66,15,16,28,129 ; movss (%rcx,%r8,4),%xmm3 - DB 102,15,58,33,203,48 ; insertps $0x30,%xmm3,%xmm1 - DB 72,139,64,24 ; mov 0x18(%rax),%rax - DB 102,72,15,58,22,209,1 ; pextrq $0x1,%xmm2,%rcx - DB 65,137,200 ; mov %ecx,%r8d - DB 72,193,233,32 ; shr $0x20,%rcx - DB 102,73,15,126,209 ; movq %xmm2,%r9 - DB 69,137,202 ; mov %r9d,%r10d - DB 73,193,233,32 ; shr $0x20,%r9 - DB 243,66,15,16,20,144 ; movss (%rax,%r10,4),%xmm2 - DB 102,66,15,58,33,20,136,16 ; insertps $0x10,(%rax,%r9,4),%xmm2 - DB 243,66,15,16,28,128 ; movss (%rax,%r8,4),%xmm3 - DB 102,15,58,33,211,32 ; insertps $0x20,%xmm3,%xmm2 - DB 243,15,16,28,136 ; movss (%rax,%rcx,4),%xmm3 - DB 102,15,58,33,211,48 ; insertps $0x30,%xmm3,%xmm2 - DB 102,65,15,114,208,24 ; psrld $0x18,%xmm8 - DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 - DB 243,15,16,90,12 ; movss 0xc(%rdx),%xmm3 - DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 - DB 65,15,89,216 ; mulps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,8 ; mov (%rax),%rcx + DB 76,139,64,8 ; mov 0x8(%rax),%r8 + DB 243,68,15,111,4,185 ; movdqu (%rcx,%rdi,4),%xmm8 + DB 102,15,110,66,16 ; movd 0x10(%rdx),%xmm0 + DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 + DB 102,65,15,111,200 ; movdqa %xmm8,%xmm1 + DB 102,15,114,209,8 ; psrld $0x8,%xmm1 + DB 102,15,219,200 ; pand %xmm0,%xmm1 + DB 102,65,15,111,208 ; movdqa %xmm8,%xmm2 + DB 102,15,114,210,16 ; psrld $0x10,%xmm2 + DB 102,15,219,208 ; pand %xmm0,%xmm2 + DB 102,65,15,219,192 ; pand %xmm8,%xmm0 + DB 102,72,15,58,22,193,1 ; pextrq $0x1,%xmm0,%rcx + DB 65,137,201 ; mov %ecx,%r9d + DB 72,193,233,32 ; shr $0x20,%rcx + DB 102,73,15,126,194 ; movq %xmm0,%r10 + DB 69,137,211 ; mov %r10d,%r11d + DB 73,193,234,32 ; shr $0x20,%r10 + DB 243,67,15,16,4,152 ; movss (%r8,%r11,4),%xmm0 + DB 102,67,15,58,33,4,144,16 ; insertps $0x10,(%r8,%r10,4),%xmm0 + DB 102,67,15,58,33,4,136,32 ; insertps $0x20,(%r8,%r9,4),%xmm0 + DB 102,65,15,58,33,4,136,48 ; insertps $0x30,(%r8,%rcx,4),%xmm0 + DB 72,139,72,16 ; mov 0x10(%rax),%rcx + DB 102,73,15,58,22,200,1 ; pextrq $0x1,%xmm1,%r8 + DB 69,137,193 ; mov %r8d,%r9d + DB 73,193,232,32 ; shr $0x20,%r8 + DB 102,73,15,126,202 ; movq %xmm1,%r10 + DB 69,137,211 ; mov %r10d,%r11d + DB 73,193,234,32 ; shr $0x20,%r10 + DB 243,66,15,16,12,153 ; movss (%rcx,%r11,4),%xmm1 + DB 102,66,15,58,33,12,145,16 ; insertps $0x10,(%rcx,%r10,4),%xmm1 + DB 243,66,15,16,28,137 ; movss (%rcx,%r9,4),%xmm3 + DB 102,15,58,33,203,32 ; insertps $0x20,%xmm3,%xmm1 + DB 243,66,15,16,28,129 ; movss (%rcx,%r8,4),%xmm3 + DB 102,15,58,33,203,48 ; insertps $0x30,%xmm3,%xmm1 + DB 72,139,64,24 ; mov 0x18(%rax),%rax + DB 102,72,15,58,22,209,1 ; pextrq $0x1,%xmm2,%rcx + DB 65,137,200 ; mov %ecx,%r8d + DB 72,193,233,32 ; shr $0x20,%rcx + DB 102,73,15,126,209 ; movq %xmm2,%r9 + DB 69,137,202 ; mov %r9d,%r10d + DB 73,193,233,32 ; shr $0x20,%r9 + DB 243,66,15,16,20,144 ; movss (%rax,%r10,4),%xmm2 + DB 102,66,15,58,33,20,136,16 ; insertps $0x10,(%rax,%r9,4),%xmm2 + DB 243,66,15,16,28,128 ; movss (%rax,%r8,4),%xmm3 + DB 102,15,58,33,211,32 ; insertps $0x20,%xmm3,%xmm2 + DB 243,15,16,28,136 ; movss (%rax,%rcx,4),%xmm3 + DB 102,15,58,33,211,48 ; insertps $0x30,%xmm3,%xmm2 + DB 102,65,15,114,208,24 ; psrld $0x18,%xmm8 + DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 + DB 243,15,16,90,12 ; movss 0xc(%rdx),%xmm3 + DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 + DB 65,15,89,216 ; mulps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_8888_sse41 _sk_load_8888_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 243,15,111,28,184 ; movdqu (%rax,%rdi,4),%xmm3 - DB 102,15,110,66,16 ; movd 0x10(%rdx),%xmm0 - DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 - DB 102,15,111,203 ; movdqa %xmm3,%xmm1 - DB 102,15,114,209,8 ; psrld $0x8,%xmm1 - DB 102,15,219,200 ; pand %xmm0,%xmm1 - DB 102,15,111,211 ; movdqa %xmm3,%xmm2 - DB 102,15,114,210,16 ; psrld $0x10,%xmm2 - DB 102,15,219,208 ; pand %xmm0,%xmm2 - DB 102,15,219,195 ; pand %xmm3,%xmm0 - DB 15,91,192 ; cvtdq2ps %xmm0,%xmm0 - DB 243,68,15,16,66,12 ; movss 0xc(%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 15,91,201 ; cvtdq2ps %xmm1,%xmm1 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 15,91,210 ; cvtdq2ps %xmm2,%xmm2 - DB 65,15,89,208 ; mulps %xmm8,%xmm2 - DB 102,15,114,211,24 ; psrld $0x18,%xmm3 - DB 15,91,219 ; cvtdq2ps %xmm3,%xmm3 - DB 65,15,89,216 ; mulps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 243,15,111,28,184 ; movdqu (%rax,%rdi,4),%xmm3 + DB 102,15,110,66,16 ; movd 0x10(%rdx),%xmm0 + DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 + DB 102,15,111,203 ; movdqa %xmm3,%xmm1 + DB 102,15,114,209,8 ; psrld $0x8,%xmm1 + DB 102,15,219,200 ; pand %xmm0,%xmm1 + DB 102,15,111,211 ; movdqa %xmm3,%xmm2 + DB 102,15,114,210,16 ; psrld $0x10,%xmm2 + DB 102,15,219,208 ; pand %xmm0,%xmm2 + DB 102,15,219,195 ; pand %xmm3,%xmm0 + DB 15,91,192 ; cvtdq2ps %xmm0,%xmm0 + DB 243,68,15,16,66,12 ; movss 0xc(%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 15,91,201 ; cvtdq2ps %xmm1,%xmm1 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 15,91,210 ; cvtdq2ps %xmm2,%xmm2 + DB 65,15,89,208 ; mulps %xmm8,%xmm2 + DB 102,15,114,211,24 ; psrld $0x18,%xmm3 + DB 15,91,219 ; cvtdq2ps %xmm3,%xmm3 + DB 65,15,89,216 ; mulps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_store_8888_sse41 _sk_store_8888_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 243,68,15,16,66,8 ; movss 0x8(%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,200 ; mulps %xmm0,%xmm9 - DB 102,69,15,91,201 ; cvtps2dq %xmm9,%xmm9 - DB 69,15,40,208 ; movaps %xmm8,%xmm10 - DB 68,15,89,209 ; mulps %xmm1,%xmm10 - DB 102,69,15,91,210 ; cvtps2dq %xmm10,%xmm10 - DB 102,65,15,114,242,8 ; pslld $0x8,%xmm10 - DB 102,69,15,235,209 ; por %xmm9,%xmm10 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,202 ; mulps %xmm2,%xmm9 - DB 102,69,15,91,201 ; cvtps2dq %xmm9,%xmm9 - DB 102,65,15,114,241,16 ; pslld $0x10,%xmm9 - DB 68,15,89,195 ; mulps %xmm3,%xmm8 - DB 102,69,15,91,192 ; cvtps2dq %xmm8,%xmm8 - DB 102,65,15,114,240,24 ; pslld $0x18,%xmm8 - DB 102,69,15,235,193 ; por %xmm9,%xmm8 - DB 102,69,15,235,194 ; por %xmm10,%xmm8 - DB 243,68,15,127,4,184 ; movdqu %xmm8,(%rax,%rdi,4) - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 243,68,15,16,66,8 ; movss 0x8(%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,200 ; mulps %xmm0,%xmm9 + DB 102,69,15,91,201 ; cvtps2dq %xmm9,%xmm9 + DB 69,15,40,208 ; movaps %xmm8,%xmm10 + DB 68,15,89,209 ; mulps %xmm1,%xmm10 + DB 102,69,15,91,210 ; cvtps2dq %xmm10,%xmm10 + DB 102,65,15,114,242,8 ; pslld $0x8,%xmm10 + DB 102,69,15,235,209 ; por %xmm9,%xmm10 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,202 ; mulps %xmm2,%xmm9 + DB 102,69,15,91,201 ; cvtps2dq %xmm9,%xmm9 + DB 102,65,15,114,241,16 ; pslld $0x10,%xmm9 + DB 68,15,89,195 ; mulps %xmm3,%xmm8 + DB 102,69,15,91,192 ; cvtps2dq %xmm8,%xmm8 + DB 102,65,15,114,240,24 ; pslld $0x18,%xmm8 + DB 102,69,15,235,193 ; por %xmm9,%xmm8 + DB 102,69,15,235,194 ; por %xmm10,%xmm8 + DB 243,68,15,127,4,184 ; movdqu %xmm8,(%rax,%rdi,4) + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_f16_sse41 _sk_load_f16_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 243,15,111,4,248 ; movdqu (%rax,%rdi,8),%xmm0 - DB 243,15,111,76,248,16 ; movdqu 0x10(%rax,%rdi,8),%xmm1 - DB 102,15,111,208 ; movdqa %xmm0,%xmm2 - DB 102,15,97,209 ; punpcklwd %xmm1,%xmm2 - DB 102,15,105,193 ; punpckhwd %xmm1,%xmm0 - DB 102,68,15,111,194 ; movdqa %xmm2,%xmm8 - DB 102,68,15,97,192 ; punpcklwd %xmm0,%xmm8 - DB 102,15,105,208 ; punpckhwd %xmm0,%xmm2 - DB 102,15,110,66,100 ; movd 0x64(%rdx),%xmm0 - DB 102,15,112,216,0 ; pshufd $0x0,%xmm0,%xmm3 - DB 102,15,111,203 ; movdqa %xmm3,%xmm1 - DB 102,65,15,101,200 ; pcmpgtw %xmm8,%xmm1 - DB 102,65,15,223,200 ; pandn %xmm8,%xmm1 - DB 102,15,101,218 ; pcmpgtw %xmm2,%xmm3 - DB 102,15,223,218 ; pandn %xmm2,%xmm3 - DB 102,15,56,51,193 ; pmovzxwd %xmm1,%xmm0 - DB 102,15,114,240,13 ; pslld $0xd,%xmm0 - DB 102,15,110,82,92 ; movd 0x5c(%rdx),%xmm2 - DB 102,68,15,112,194,0 ; pshufd $0x0,%xmm2,%xmm8 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 102,69,15,239,201 ; pxor %xmm9,%xmm9 - DB 102,65,15,105,201 ; punpckhwd %xmm9,%xmm1 - DB 102,15,114,241,13 ; pslld $0xd,%xmm1 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 102,15,56,51,211 ; pmovzxwd %xmm3,%xmm2 - DB 102,15,114,242,13 ; pslld $0xd,%xmm2 - DB 65,15,89,208 ; mulps %xmm8,%xmm2 - DB 102,65,15,105,217 ; punpckhwd %xmm9,%xmm3 - DB 102,15,114,243,13 ; pslld $0xd,%xmm3 - DB 65,15,89,216 ; mulps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 243,15,111,4,248 ; movdqu (%rax,%rdi,8),%xmm0 + DB 243,15,111,76,248,16 ; movdqu 0x10(%rax,%rdi,8),%xmm1 + DB 102,15,111,208 ; movdqa %xmm0,%xmm2 + DB 102,15,97,209 ; punpcklwd %xmm1,%xmm2 + DB 102,15,105,193 ; punpckhwd %xmm1,%xmm0 + DB 102,68,15,111,194 ; movdqa %xmm2,%xmm8 + DB 102,68,15,97,192 ; punpcklwd %xmm0,%xmm8 + DB 102,15,105,208 ; punpckhwd %xmm0,%xmm2 + DB 102,15,110,66,100 ; movd 0x64(%rdx),%xmm0 + DB 102,15,112,216,0 ; pshufd $0x0,%xmm0,%xmm3 + DB 102,15,111,203 ; movdqa %xmm3,%xmm1 + DB 102,65,15,101,200 ; pcmpgtw %xmm8,%xmm1 + DB 102,65,15,223,200 ; pandn %xmm8,%xmm1 + DB 102,15,101,218 ; pcmpgtw %xmm2,%xmm3 + DB 102,15,223,218 ; pandn %xmm2,%xmm3 + DB 102,15,56,51,193 ; pmovzxwd %xmm1,%xmm0 + DB 102,15,114,240,13 ; pslld $0xd,%xmm0 + DB 102,15,110,82,92 ; movd 0x5c(%rdx),%xmm2 + DB 102,68,15,112,194,0 ; pshufd $0x0,%xmm2,%xmm8 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 102,69,15,239,201 ; pxor %xmm9,%xmm9 + DB 102,65,15,105,201 ; punpckhwd %xmm9,%xmm1 + DB 102,15,114,241,13 ; pslld $0xd,%xmm1 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 102,15,56,51,211 ; pmovzxwd %xmm3,%xmm2 + DB 102,15,114,242,13 ; pslld $0xd,%xmm2 + DB 65,15,89,208 ; mulps %xmm8,%xmm2 + DB 102,65,15,105,217 ; punpckhwd %xmm9,%xmm3 + DB 102,15,114,243,13 ; pslld $0xd,%xmm3 + DB 65,15,89,216 ; mulps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_store_f16_sse41 _sk_store_f16_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 102,68,15,110,66,96 ; movd 0x60(%rdx),%xmm8 - DB 102,69,15,112,192,0 ; pshufd $0x0,%xmm8,%xmm8 - DB 102,69,15,111,200 ; movdqa %xmm8,%xmm9 - DB 68,15,89,200 ; mulps %xmm0,%xmm9 - DB 102,65,15,114,209,13 ; psrld $0xd,%xmm9 - DB 102,69,15,111,208 ; movdqa %xmm8,%xmm10 - DB 68,15,89,209 ; mulps %xmm1,%xmm10 - DB 102,65,15,114,210,13 ; psrld $0xd,%xmm10 - DB 102,69,15,111,216 ; movdqa %xmm8,%xmm11 - DB 68,15,89,218 ; mulps %xmm2,%xmm11 - DB 102,65,15,114,211,13 ; psrld $0xd,%xmm11 - DB 68,15,89,195 ; mulps %xmm3,%xmm8 - DB 102,65,15,114,208,13 ; psrld $0xd,%xmm8 - DB 102,65,15,115,250,2 ; pslldq $0x2,%xmm10 - DB 102,69,15,235,209 ; por %xmm9,%xmm10 - DB 102,65,15,115,248,2 ; pslldq $0x2,%xmm8 - DB 102,69,15,235,195 ; por %xmm11,%xmm8 - DB 102,69,15,111,202 ; movdqa %xmm10,%xmm9 - DB 102,69,15,98,200 ; punpckldq %xmm8,%xmm9 - DB 243,68,15,127,12,248 ; movdqu %xmm9,(%rax,%rdi,8) - DB 102,69,15,106,208 ; punpckhdq %xmm8,%xmm10 - DB 243,68,15,127,84,248,16 ; movdqu %xmm10,0x10(%rax,%rdi,8) - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 102,68,15,110,66,96 ; movd 0x60(%rdx),%xmm8 + DB 102,69,15,112,192,0 ; pshufd $0x0,%xmm8,%xmm8 + DB 102,69,15,111,200 ; movdqa %xmm8,%xmm9 + DB 68,15,89,200 ; mulps %xmm0,%xmm9 + DB 102,65,15,114,209,13 ; psrld $0xd,%xmm9 + DB 102,69,15,111,208 ; movdqa %xmm8,%xmm10 + DB 68,15,89,209 ; mulps %xmm1,%xmm10 + DB 102,65,15,114,210,13 ; psrld $0xd,%xmm10 + DB 102,69,15,111,216 ; movdqa %xmm8,%xmm11 + DB 68,15,89,218 ; mulps %xmm2,%xmm11 + DB 102,65,15,114,211,13 ; psrld $0xd,%xmm11 + DB 68,15,89,195 ; mulps %xmm3,%xmm8 + DB 102,65,15,114,208,13 ; psrld $0xd,%xmm8 + DB 102,65,15,115,250,2 ; pslldq $0x2,%xmm10 + DB 102,69,15,235,209 ; por %xmm9,%xmm10 + DB 102,65,15,115,248,2 ; pslldq $0x2,%xmm8 + DB 102,69,15,235,195 ; por %xmm11,%xmm8 + DB 102,69,15,111,202 ; movdqa %xmm10,%xmm9 + DB 102,69,15,98,200 ; punpckldq %xmm8,%xmm9 + DB 243,68,15,127,12,248 ; movdqu %xmm9,(%rax,%rdi,8) + DB 102,69,15,106,208 ; punpckhdq %xmm8,%xmm10 + DB 243,68,15,127,84,248,16 ; movdqu %xmm10,0x10(%rax,%rdi,8) + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_x_sse41 _sk_clamp_x_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,0 ; movss (%rax),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 102,69,15,118,201 ; pcmpeqd %xmm9,%xmm9 - DB 102,69,15,254,200 ; paddd %xmm8,%xmm9 - DB 65,15,93,193 ; minps %xmm9,%xmm0 - DB 69,15,87,192 ; xorps %xmm8,%xmm8 - DB 68,15,95,192 ; maxps %xmm0,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,192 ; movaps %xmm8,%xmm0 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,0 ; movss (%rax),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 102,69,15,118,201 ; pcmpeqd %xmm9,%xmm9 + DB 102,69,15,254,200 ; paddd %xmm8,%xmm9 + DB 65,15,93,193 ; minps %xmm9,%xmm0 + DB 69,15,87,192 ; xorps %xmm8,%xmm8 + DB 68,15,95,192 ; maxps %xmm0,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,192 ; movaps %xmm8,%xmm0 + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_y_sse41 _sk_clamp_y_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,0 ; movss (%rax),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 102,69,15,118,201 ; pcmpeqd %xmm9,%xmm9 - DB 102,69,15,254,200 ; paddd %xmm8,%xmm9 - DB 65,15,93,201 ; minps %xmm9,%xmm1 - DB 69,15,87,192 ; xorps %xmm8,%xmm8 - DB 68,15,95,193 ; maxps %xmm1,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,200 ; movaps %xmm8,%xmm1 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,0 ; movss (%rax),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 102,69,15,118,201 ; pcmpeqd %xmm9,%xmm9 + DB 102,69,15,254,200 ; paddd %xmm8,%xmm9 + DB 65,15,93,201 ; minps %xmm9,%xmm1 + DB 69,15,87,192 ; xorps %xmm8,%xmm8 + DB 68,15,95,193 ; maxps %xmm1,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,200 ; movaps %xmm8,%xmm1 + DB 255,224 ; jmpq *%rax PUBLIC _sk_matrix_2x3_sse41 _sk_matrix_2x3_sse41 LABEL PROC - DB 68,15,40,201 ; movaps %xmm1,%xmm9 - DB 68,15,40,192 ; movaps %xmm0,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,15,16,0 ; movss (%rax),%xmm0 - DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 - DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 - DB 243,68,15,16,80,8 ; movss 0x8(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,16 ; movss 0x10(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 69,15,89,209 ; mulps %xmm9,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 65,15,88,194 ; addps %xmm10,%xmm0 - DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 - DB 243,68,15,16,80,12 ; movss 0xc(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,20 ; movss 0x14(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 69,15,89,209 ; mulps %xmm9,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 65,15,88,202 ; addps %xmm10,%xmm1 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 68,15,40,201 ; movaps %xmm1,%xmm9 + DB 68,15,40,192 ; movaps %xmm0,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,15,16,0 ; movss (%rax),%xmm0 + DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 + DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 + DB 243,68,15,16,80,8 ; movss 0x8(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,16 ; movss 0x10(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 69,15,89,209 ; mulps %xmm9,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 65,15,88,194 ; addps %xmm10,%xmm0 + DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 + DB 243,68,15,16,80,12 ; movss 0xc(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,20 ; movss 0x14(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 69,15,89,209 ; mulps %xmm9,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 65,15,88,202 ; addps %xmm10,%xmm1 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_matrix_3x4_sse41 _sk_matrix_3x4_sse41 LABEL PROC - DB 68,15,40,201 ; movaps %xmm1,%xmm9 - DB 68,15,40,192 ; movaps %xmm0,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,15,16,0 ; movss (%rax),%xmm0 - DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 - DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 - DB 243,68,15,16,80,12 ; movss 0xc(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,24 ; movss 0x18(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 243,68,15,16,96,36 ; movss 0x24(%rax),%xmm12 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 68,15,89,218 ; mulps %xmm2,%xmm11 - DB 69,15,88,220 ; addps %xmm12,%xmm11 - DB 69,15,89,209 ; mulps %xmm9,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 65,15,88,194 ; addps %xmm10,%xmm0 - DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 - DB 243,68,15,16,80,16 ; movss 0x10(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,28 ; movss 0x1c(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 243,68,15,16,96,40 ; movss 0x28(%rax),%xmm12 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 68,15,89,218 ; mulps %xmm2,%xmm11 - DB 69,15,88,220 ; addps %xmm12,%xmm11 - DB 69,15,89,209 ; mulps %xmm9,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 65,15,88,202 ; addps %xmm10,%xmm1 - DB 243,68,15,16,80,8 ; movss 0x8(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,20 ; movss 0x14(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 243,68,15,16,96,32 ; movss 0x20(%rax),%xmm12 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 243,68,15,16,104,44 ; movss 0x2c(%rax),%xmm13 - DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 - DB 68,15,89,226 ; mulps %xmm2,%xmm12 - DB 69,15,88,229 ; addps %xmm13,%xmm12 - DB 69,15,89,217 ; mulps %xmm9,%xmm11 - DB 69,15,88,220 ; addps %xmm12,%xmm11 - DB 69,15,89,208 ; mulps %xmm8,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,210 ; movaps %xmm10,%xmm2 - DB 255,224 ; jmpq *%rax + DB 68,15,40,201 ; movaps %xmm1,%xmm9 + DB 68,15,40,192 ; movaps %xmm0,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,15,16,0 ; movss (%rax),%xmm0 + DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 + DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 + DB 243,68,15,16,80,12 ; movss 0xc(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,24 ; movss 0x18(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 243,68,15,16,96,36 ; movss 0x24(%rax),%xmm12 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 68,15,89,218 ; mulps %xmm2,%xmm11 + DB 69,15,88,220 ; addps %xmm12,%xmm11 + DB 69,15,89,209 ; mulps %xmm9,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 65,15,88,194 ; addps %xmm10,%xmm0 + DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 + DB 243,68,15,16,80,16 ; movss 0x10(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,28 ; movss 0x1c(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 243,68,15,16,96,40 ; movss 0x28(%rax),%xmm12 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 68,15,89,218 ; mulps %xmm2,%xmm11 + DB 69,15,88,220 ; addps %xmm12,%xmm11 + DB 69,15,89,209 ; mulps %xmm9,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 65,15,88,202 ; addps %xmm10,%xmm1 + DB 243,68,15,16,80,8 ; movss 0x8(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,20 ; movss 0x14(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 243,68,15,16,96,32 ; movss 0x20(%rax),%xmm12 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 243,68,15,16,104,44 ; movss 0x2c(%rax),%xmm13 + DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 + DB 68,15,89,226 ; mulps %xmm2,%xmm12 + DB 69,15,88,229 ; addps %xmm13,%xmm12 + DB 69,15,89,217 ; mulps %xmm9,%xmm11 + DB 69,15,88,220 ; addps %xmm12,%xmm11 + DB 69,15,89,208 ; mulps %xmm8,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,210 ; movaps %xmm10,%xmm2 + DB 255,224 ; jmpq *%rax PUBLIC _sk_linear_gradient_2stops_sse41 _sk_linear_gradient_2stops_sse41 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 68,15,16,8 ; movups (%rax),%xmm9 - DB 15,16,88,16 ; movups 0x10(%rax),%xmm3 - DB 68,15,40,195 ; movaps %xmm3,%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 65,15,40,201 ; movaps %xmm9,%xmm1 - DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 - DB 68,15,89,192 ; mulps %xmm0,%xmm8 - DB 68,15,88,193 ; addps %xmm1,%xmm8 - DB 15,40,203 ; movaps %xmm3,%xmm1 - DB 15,198,201,85 ; shufps $0x55,%xmm1,%xmm1 - DB 65,15,40,209 ; movaps %xmm9,%xmm2 - DB 15,198,210,85 ; shufps $0x55,%xmm2,%xmm2 - DB 15,89,200 ; mulps %xmm0,%xmm1 - DB 15,88,202 ; addps %xmm2,%xmm1 - DB 15,40,211 ; movaps %xmm3,%xmm2 - DB 15,198,210,170 ; shufps $0xaa,%xmm2,%xmm2 - DB 69,15,40,209 ; movaps %xmm9,%xmm10 - DB 69,15,198,210,170 ; shufps $0xaa,%xmm10,%xmm10 - DB 15,89,208 ; mulps %xmm0,%xmm2 - DB 65,15,88,210 ; addps %xmm10,%xmm2 - DB 15,198,219,255 ; shufps $0xff,%xmm3,%xmm3 - DB 69,15,198,201,255 ; shufps $0xff,%xmm9,%xmm9 - DB 15,89,216 ; mulps %xmm0,%xmm3 - DB 65,15,88,217 ; addps %xmm9,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,192 ; movaps %xmm8,%xmm0 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 68,15,16,8 ; movups (%rax),%xmm9 + DB 15,16,88,16 ; movups 0x10(%rax),%xmm3 + DB 68,15,40,195 ; movaps %xmm3,%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 65,15,40,201 ; movaps %xmm9,%xmm1 + DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 + DB 68,15,89,192 ; mulps %xmm0,%xmm8 + DB 68,15,88,193 ; addps %xmm1,%xmm8 + DB 15,40,203 ; movaps %xmm3,%xmm1 + DB 15,198,201,85 ; shufps $0x55,%xmm1,%xmm1 + DB 65,15,40,209 ; movaps %xmm9,%xmm2 + DB 15,198,210,85 ; shufps $0x55,%xmm2,%xmm2 + DB 15,89,200 ; mulps %xmm0,%xmm1 + DB 15,88,202 ; addps %xmm2,%xmm1 + DB 15,40,211 ; movaps %xmm3,%xmm2 + DB 15,198,210,170 ; shufps $0xaa,%xmm2,%xmm2 + DB 69,15,40,209 ; movaps %xmm9,%xmm10 + DB 69,15,198,210,170 ; shufps $0xaa,%xmm10,%xmm10 + DB 15,89,208 ; mulps %xmm0,%xmm2 + DB 65,15,88,210 ; addps %xmm10,%xmm2 + DB 15,198,219,255 ; shufps $0xff,%xmm3,%xmm3 + DB 69,15,198,201,255 ; shufps $0xff,%xmm9,%xmm9 + DB 15,89,216 ; mulps %xmm0,%xmm3 + DB 65,15,88,217 ; addps %xmm9,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,192 ; movaps %xmm8,%xmm0 + DB 255,224 ; jmpq *%rax PUBLIC _sk_start_pipeline_sse2 _sk_start_pipeline_sse2 LABEL PROC - DB 65,87 ; push %r15 - DB 65,86 ; push %r14 - DB 65,85 ; push %r13 - DB 65,84 ; push %r12 - DB 86 ; push %rsi - DB 87 ; push %rdi - DB 83 ; push %rbx - DB 72,129,236,160,0,0,0 ; sub $0xa0,%rsp - DB 68,15,41,188,36,144,0,0,0 ; movaps %xmm15,0x90(%rsp) - DB 68,15,41,180,36,128,0,0,0 ; movaps %xmm14,0x80(%rsp) - DB 68,15,41,108,36,112 ; movaps %xmm13,0x70(%rsp) - DB 68,15,41,100,36,96 ; movaps %xmm12,0x60(%rsp) - DB 68,15,41,92,36,80 ; movaps %xmm11,0x50(%rsp) - DB 68,15,41,84,36,64 ; movaps %xmm10,0x40(%rsp) - DB 68,15,41,76,36,48 ; movaps %xmm9,0x30(%rsp) - DB 68,15,41,68,36,32 ; movaps %xmm8,0x20(%rsp) - DB 15,41,124,36,16 ; movaps %xmm7,0x10(%rsp) - DB 15,41,52,36 ; movaps %xmm6,(%rsp) - DB 77,137,207 ; mov %r9,%r15 - DB 77,137,198 ; mov %r8,%r14 - DB 72,137,203 ; mov %rcx,%rbx - DB 72,137,214 ; mov %rdx,%rsi - DB 72,173 ; lods %ds:(%rsi),%rax - DB 73,137,196 ; mov %rax,%r12 - DB 73,137,245 ; mov %rsi,%r13 - DB 72,141,67,4 ; lea 0x4(%rbx),%rax - DB 76,57,248 ; cmp %r15,%rax - DB 118,5 ; jbe 73 <_sk_start_pipeline_sse2+0x73> - DB 72,137,216 ; mov %rbx,%rax - DB 235,52 ; jmp a7 <_sk_start_pipeline_sse2+0xa7> - DB 15,87,192 ; xorps %xmm0,%xmm0 - DB 15,87,201 ; xorps %xmm1,%xmm1 - DB 15,87,210 ; xorps %xmm2,%xmm2 - DB 15,87,219 ; xorps %xmm3,%xmm3 - DB 15,87,228 ; xorps %xmm4,%xmm4 - DB 15,87,237 ; xorps %xmm5,%xmm5 - DB 15,87,246 ; xorps %xmm6,%xmm6 - DB 15,87,255 ; xorps %xmm7,%xmm7 - DB 72,137,223 ; mov %rbx,%rdi - DB 76,137,238 ; mov %r13,%rsi - DB 76,137,242 ; mov %r14,%rdx - DB 65,255,212 ; callq *%r12 - DB 72,141,67,4 ; lea 0x4(%rbx),%rax - DB 72,131,195,8 ; add $0x8,%rbx - DB 76,57,251 ; cmp %r15,%rbx - DB 72,137,195 ; mov %rax,%rbx - DB 118,204 ; jbe 73 <_sk_start_pipeline_sse2+0x73> - DB 15,40,52,36 ; movaps (%rsp),%xmm6 - DB 15,40,124,36,16 ; movaps 0x10(%rsp),%xmm7 - DB 68,15,40,68,36,32 ; movaps 0x20(%rsp),%xmm8 - DB 68,15,40,76,36,48 ; movaps 0x30(%rsp),%xmm9 - DB 68,15,40,84,36,64 ; movaps 0x40(%rsp),%xmm10 - DB 68,15,40,92,36,80 ; movaps 0x50(%rsp),%xmm11 - DB 68,15,40,100,36,96 ; movaps 0x60(%rsp),%xmm12 - DB 68,15,40,108,36,112 ; movaps 0x70(%rsp),%xmm13 - DB 68,15,40,180,36,128,0,0,0 ; movaps 0x80(%rsp),%xmm14 - DB 68,15,40,188,36,144,0,0,0 ; movaps 0x90(%rsp),%xmm15 - DB 72,129,196,160,0,0,0 ; add $0xa0,%rsp - DB 91 ; pop %rbx - DB 95 ; pop %rdi - DB 94 ; pop %rsi - DB 65,92 ; pop %r12 - DB 65,93 ; pop %r13 - DB 65,94 ; pop %r14 - DB 65,95 ; pop %r15 - DB 195 ; retq + DB 65,87 ; push %r15 + DB 65,86 ; push %r14 + DB 65,85 ; push %r13 + DB 65,84 ; push %r12 + DB 86 ; push %rsi + DB 87 ; push %rdi + DB 83 ; push %rbx + DB 72,129,236,160,0,0,0 ; sub $0xa0,%rsp + DB 68,15,41,188,36,144,0,0,0 ; movaps %xmm15,0x90(%rsp) + DB 68,15,41,180,36,128,0,0,0 ; movaps %xmm14,0x80(%rsp) + DB 68,15,41,108,36,112 ; movaps %xmm13,0x70(%rsp) + DB 68,15,41,100,36,96 ; movaps %xmm12,0x60(%rsp) + DB 68,15,41,92,36,80 ; movaps %xmm11,0x50(%rsp) + DB 68,15,41,84,36,64 ; movaps %xmm10,0x40(%rsp) + DB 68,15,41,76,36,48 ; movaps %xmm9,0x30(%rsp) + DB 68,15,41,68,36,32 ; movaps %xmm8,0x20(%rsp) + DB 15,41,124,36,16 ; movaps %xmm7,0x10(%rsp) + DB 15,41,52,36 ; movaps %xmm6,(%rsp) + DB 77,137,207 ; mov %r9,%r15 + DB 77,137,198 ; mov %r8,%r14 + DB 72,137,203 ; mov %rcx,%rbx + DB 72,137,214 ; mov %rdx,%rsi + DB 72,173 ; lods %ds:(%rsi),%rax + DB 73,137,196 ; mov %rax,%r12 + DB 73,137,245 ; mov %rsi,%r13 + DB 72,141,67,4 ; lea 0x4(%rbx),%rax + DB 76,57,248 ; cmp %r15,%rax + DB 118,5 ; jbe 73 <_sk_start_pipeline_sse2+0x73> + DB 72,137,216 ; mov %rbx,%rax + DB 235,52 ; jmp a7 <_sk_start_pipeline_sse2+0xa7> + DB 15,87,192 ; xorps %xmm0,%xmm0 + DB 15,87,201 ; xorps %xmm1,%xmm1 + DB 15,87,210 ; xorps %xmm2,%xmm2 + DB 15,87,219 ; xorps %xmm3,%xmm3 + DB 15,87,228 ; xorps %xmm4,%xmm4 + DB 15,87,237 ; xorps %xmm5,%xmm5 + DB 15,87,246 ; xorps %xmm6,%xmm6 + DB 15,87,255 ; xorps %xmm7,%xmm7 + DB 72,137,223 ; mov %rbx,%rdi + DB 76,137,238 ; mov %r13,%rsi + DB 76,137,242 ; mov %r14,%rdx + DB 65,255,212 ; callq *%r12 + DB 72,141,67,4 ; lea 0x4(%rbx),%rax + DB 72,131,195,8 ; add $0x8,%rbx + DB 76,57,251 ; cmp %r15,%rbx + DB 72,137,195 ; mov %rax,%rbx + DB 118,204 ; jbe 73 <_sk_start_pipeline_sse2+0x73> + DB 15,40,52,36 ; movaps (%rsp),%xmm6 + DB 15,40,124,36,16 ; movaps 0x10(%rsp),%xmm7 + DB 68,15,40,68,36,32 ; movaps 0x20(%rsp),%xmm8 + DB 68,15,40,76,36,48 ; movaps 0x30(%rsp),%xmm9 + DB 68,15,40,84,36,64 ; movaps 0x40(%rsp),%xmm10 + DB 68,15,40,92,36,80 ; movaps 0x50(%rsp),%xmm11 + DB 68,15,40,100,36,96 ; movaps 0x60(%rsp),%xmm12 + DB 68,15,40,108,36,112 ; movaps 0x70(%rsp),%xmm13 + DB 68,15,40,180,36,128,0,0,0 ; movaps 0x80(%rsp),%xmm14 + DB 68,15,40,188,36,144,0,0,0 ; movaps 0x90(%rsp),%xmm15 + DB 72,129,196,160,0,0,0 ; add $0xa0,%rsp + DB 91 ; pop %rbx + DB 95 ; pop %rdi + DB 94 ; pop %rsi + DB 65,92 ; pop %r12 + DB 65,93 ; pop %r13 + DB 65,94 ; pop %r14 + DB 65,95 ; pop %r15 + DB 195 ; retq PUBLIC _sk_just_return_sse2 _sk_just_return_sse2 LABEL PROC - DB 195 ; retq + DB 195 ; retq PUBLIC _sk_seed_shader_sse2 _sk_seed_shader_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 102,15,110,199 ; movd %edi,%xmm0 - DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 - DB 15,91,200 ; cvtdq2ps %xmm0,%xmm1 - DB 243,15,16,18 ; movss (%rdx),%xmm2 - DB 243,15,16,90,4 ; movss 0x4(%rdx),%xmm3 - DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 - DB 15,88,203 ; addps %xmm3,%xmm1 - DB 15,16,66,20 ; movups 0x14(%rdx),%xmm0 - DB 15,88,193 ; addps %xmm1,%xmm0 - DB 102,15,110,8 ; movd (%rax),%xmm1 - DB 102,15,112,201,0 ; pshufd $0x0,%xmm1,%xmm1 - DB 15,91,201 ; cvtdq2ps %xmm1,%xmm1 - DB 15,88,203 ; addps %xmm3,%xmm1 - DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,87,219 ; xorps %xmm3,%xmm3 - DB 15,87,228 ; xorps %xmm4,%xmm4 - DB 15,87,237 ; xorps %xmm5,%xmm5 - DB 15,87,246 ; xorps %xmm6,%xmm6 - DB 15,87,255 ; xorps %xmm7,%xmm7 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 102,15,110,199 ; movd %edi,%xmm0 + DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 + DB 15,91,200 ; cvtdq2ps %xmm0,%xmm1 + DB 243,15,16,18 ; movss (%rdx),%xmm2 + DB 243,15,16,90,4 ; movss 0x4(%rdx),%xmm3 + DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 + DB 15,88,203 ; addps %xmm3,%xmm1 + DB 15,16,66,20 ; movups 0x14(%rdx),%xmm0 + DB 15,88,193 ; addps %xmm1,%xmm0 + DB 102,15,110,8 ; movd (%rax),%xmm1 + DB 102,15,112,201,0 ; pshufd $0x0,%xmm1,%xmm1 + DB 15,91,201 ; cvtdq2ps %xmm1,%xmm1 + DB 15,88,203 ; addps %xmm3,%xmm1 + DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,87,219 ; xorps %xmm3,%xmm3 + DB 15,87,228 ; xorps %xmm4,%xmm4 + DB 15,87,237 ; xorps %xmm5,%xmm5 + DB 15,87,246 ; xorps %xmm6,%xmm6 + DB 15,87,255 ; xorps %xmm7,%xmm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_constant_color_sse2 _sk_constant_color_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,16,24 ; movups (%rax),%xmm3 - DB 15,40,195 ; movaps %xmm3,%xmm0 - DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 - DB 15,40,203 ; movaps %xmm3,%xmm1 - DB 15,198,201,85 ; shufps $0x55,%xmm1,%xmm1 - DB 15,40,211 ; movaps %xmm3,%xmm2 - DB 15,198,210,170 ; shufps $0xaa,%xmm2,%xmm2 - DB 15,198,219,255 ; shufps $0xff,%xmm3,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,16,24 ; movups (%rax),%xmm3 + DB 15,40,195 ; movaps %xmm3,%xmm0 + DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 + DB 15,40,203 ; movaps %xmm3,%xmm1 + DB 15,198,201,85 ; shufps $0x55,%xmm1,%xmm1 + DB 15,40,211 ; movaps %xmm3,%xmm2 + DB 15,198,210,170 ; shufps $0xaa,%xmm2,%xmm2 + DB 15,198,219,255 ; shufps $0xff,%xmm3,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clear_sse2 _sk_clear_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,87,192 ; xorps %xmm0,%xmm0 - DB 15,87,201 ; xorps %xmm1,%xmm1 - DB 15,87,210 ; xorps %xmm2,%xmm2 - DB 15,87,219 ; xorps %xmm3,%xmm3 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,87,192 ; xorps %xmm0,%xmm0 + DB 15,87,201 ; xorps %xmm1,%xmm1 + DB 15,87,210 ; xorps %xmm2,%xmm2 + DB 15,87,219 ; xorps %xmm3,%xmm3 + DB 255,224 ; jmpq *%rax PUBLIC _sk_plus__sse2 _sk_plus__sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,88,196 ; addps %xmm4,%xmm0 - DB 15,88,205 ; addps %xmm5,%xmm1 - DB 15,88,214 ; addps %xmm6,%xmm2 - DB 15,88,223 ; addps %xmm7,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,88,196 ; addps %xmm4,%xmm0 + DB 15,88,205 ; addps %xmm5,%xmm1 + DB 15,88,214 ; addps %xmm6,%xmm2 + DB 15,88,223 ; addps %xmm7,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_srcover_sse2 _sk_srcover_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,2 ; movss (%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 68,15,92,195 ; subps %xmm3,%xmm8 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,204 ; mulps %xmm4,%xmm9 - DB 65,15,88,193 ; addps %xmm9,%xmm0 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,205 ; mulps %xmm5,%xmm9 - DB 65,15,88,201 ; addps %xmm9,%xmm1 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,206 ; mulps %xmm6,%xmm9 - DB 65,15,88,209 ; addps %xmm9,%xmm2 - DB 68,15,89,199 ; mulps %xmm7,%xmm8 - DB 65,15,88,216 ; addps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,2 ; movss (%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 68,15,92,195 ; subps %xmm3,%xmm8 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,204 ; mulps %xmm4,%xmm9 + DB 65,15,88,193 ; addps %xmm9,%xmm0 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,205 ; mulps %xmm5,%xmm9 + DB 65,15,88,201 ; addps %xmm9,%xmm1 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,206 ; mulps %xmm6,%xmm9 + DB 65,15,88,209 ; addps %xmm9,%xmm2 + DB 68,15,89,199 ; mulps %xmm7,%xmm8 + DB 65,15,88,216 ; addps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_dstover_sse2 _sk_dstover_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,2 ; movss (%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 68,15,92,199 ; subps %xmm7,%xmm8 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 15,88,196 ; addps %xmm4,%xmm0 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 15,88,205 ; addps %xmm5,%xmm1 - DB 65,15,89,208 ; mulps %xmm8,%xmm2 - DB 15,88,214 ; addps %xmm6,%xmm2 - DB 65,15,89,216 ; mulps %xmm8,%xmm3 - DB 15,88,223 ; addps %xmm7,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,2 ; movss (%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 68,15,92,199 ; subps %xmm7,%xmm8 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 15,88,196 ; addps %xmm4,%xmm0 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 15,88,205 ; addps %xmm5,%xmm1 + DB 65,15,89,208 ; mulps %xmm8,%xmm2 + DB 15,88,214 ; addps %xmm6,%xmm2 + DB 65,15,89,216 ; mulps %xmm8,%xmm3 + DB 15,88,223 ; addps %xmm7,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_0_sse2 _sk_clamp_0_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 69,15,87,192 ; xorps %xmm8,%xmm8 - DB 65,15,95,192 ; maxps %xmm8,%xmm0 - DB 65,15,95,200 ; maxps %xmm8,%xmm1 - DB 65,15,95,208 ; maxps %xmm8,%xmm2 - DB 65,15,95,216 ; maxps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 69,15,87,192 ; xorps %xmm8,%xmm8 + DB 65,15,95,192 ; maxps %xmm8,%xmm0 + DB 65,15,95,200 ; maxps %xmm8,%xmm1 + DB 65,15,95,208 ; maxps %xmm8,%xmm2 + DB 65,15,95,216 ; maxps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_1_sse2 _sk_clamp_1_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,2 ; movss (%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 65,15,93,192 ; minps %xmm8,%xmm0 - DB 65,15,93,200 ; minps %xmm8,%xmm1 - DB 65,15,93,208 ; minps %xmm8,%xmm2 - DB 65,15,93,216 ; minps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,2 ; movss (%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 65,15,93,192 ; minps %xmm8,%xmm0 + DB 65,15,93,200 ; minps %xmm8,%xmm1 + DB 65,15,93,208 ; minps %xmm8,%xmm2 + DB 65,15,93,216 ; minps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_a_sse2 _sk_clamp_a_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,2 ; movss (%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 65,15,93,216 ; minps %xmm8,%xmm3 - DB 15,93,195 ; minps %xmm3,%xmm0 - DB 15,93,203 ; minps %xmm3,%xmm1 - DB 15,93,211 ; minps %xmm3,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,2 ; movss (%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 65,15,93,216 ; minps %xmm8,%xmm3 + DB 15,93,195 ; minps %xmm3,%xmm0 + DB 15,93,203 ; minps %xmm3,%xmm1 + DB 15,93,211 ; minps %xmm3,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_set_rgb_sse2 _sk_set_rgb_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,15,16,0 ; movss (%rax),%xmm0 - DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 - DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 - DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 - DB 243,15,16,80,8 ; movss 0x8(%rax),%xmm2 - DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,15,16,0 ; movss (%rax),%xmm0 + DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 + DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 + DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 + DB 243,15,16,80,8 ; movss 0x8(%rax),%xmm2 + DB 15,198,210,0 ; shufps $0x0,%xmm2,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_swap_rb_sse2 _sk_swap_rb_sse2 LABEL PROC - DB 68,15,40,192 ; movaps %xmm0,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,40,194 ; movaps %xmm2,%xmm0 - DB 65,15,40,208 ; movaps %xmm8,%xmm2 - DB 255,224 ; jmpq *%rax + DB 68,15,40,192 ; movaps %xmm0,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,40,194 ; movaps %xmm2,%xmm0 + DB 65,15,40,208 ; movaps %xmm8,%xmm2 + DB 255,224 ; jmpq *%rax PUBLIC _sk_swap_sse2 _sk_swap_sse2 LABEL PROC - DB 68,15,40,195 ; movaps %xmm3,%xmm8 - DB 68,15,40,202 ; movaps %xmm2,%xmm9 - DB 68,15,40,209 ; movaps %xmm1,%xmm10 - DB 68,15,40,216 ; movaps %xmm0,%xmm11 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,40,196 ; movaps %xmm4,%xmm0 - DB 15,40,205 ; movaps %xmm5,%xmm1 - DB 15,40,214 ; movaps %xmm6,%xmm2 - DB 15,40,223 ; movaps %xmm7,%xmm3 - DB 65,15,40,227 ; movaps %xmm11,%xmm4 - DB 65,15,40,234 ; movaps %xmm10,%xmm5 - DB 65,15,40,241 ; movaps %xmm9,%xmm6 - DB 65,15,40,248 ; movaps %xmm8,%xmm7 - DB 255,224 ; jmpq *%rax + DB 68,15,40,195 ; movaps %xmm3,%xmm8 + DB 68,15,40,202 ; movaps %xmm2,%xmm9 + DB 68,15,40,209 ; movaps %xmm1,%xmm10 + DB 68,15,40,216 ; movaps %xmm0,%xmm11 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,40,196 ; movaps %xmm4,%xmm0 + DB 15,40,205 ; movaps %xmm5,%xmm1 + DB 15,40,214 ; movaps %xmm6,%xmm2 + DB 15,40,223 ; movaps %xmm7,%xmm3 + DB 65,15,40,227 ; movaps %xmm11,%xmm4 + DB 65,15,40,234 ; movaps %xmm10,%xmm5 + DB 65,15,40,241 ; movaps %xmm9,%xmm6 + DB 65,15,40,248 ; movaps %xmm8,%xmm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_move_src_dst_sse2 _sk_move_src_dst_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,40,224 ; movaps %xmm0,%xmm4 - DB 15,40,233 ; movaps %xmm1,%xmm5 - DB 15,40,242 ; movaps %xmm2,%xmm6 - DB 15,40,251 ; movaps %xmm3,%xmm7 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,40,224 ; movaps %xmm0,%xmm4 + DB 15,40,233 ; movaps %xmm1,%xmm5 + DB 15,40,242 ; movaps %xmm2,%xmm6 + DB 15,40,251 ; movaps %xmm3,%xmm7 + DB 255,224 ; jmpq *%rax PUBLIC _sk_move_dst_src_sse2 _sk_move_dst_src_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,40,196 ; movaps %xmm4,%xmm0 - DB 15,40,205 ; movaps %xmm5,%xmm1 - DB 15,40,214 ; movaps %xmm6,%xmm2 - DB 15,40,223 ; movaps %xmm7,%xmm3 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,40,196 ; movaps %xmm4,%xmm0 + DB 15,40,205 ; movaps %xmm5,%xmm1 + DB 15,40,214 ; movaps %xmm6,%xmm2 + DB 15,40,223 ; movaps %xmm7,%xmm3 + DB 255,224 ; jmpq *%rax PUBLIC _sk_premul_sse2 _sk_premul_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,89,195 ; mulps %xmm3,%xmm0 - DB 15,89,203 ; mulps %xmm3,%xmm1 - DB 15,89,211 ; mulps %xmm3,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,89,195 ; mulps %xmm3,%xmm0 + DB 15,89,203 ; mulps %xmm3,%xmm1 + DB 15,89,211 ; mulps %xmm3,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_unpremul_sse2 _sk_unpremul_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 69,15,87,192 ; xorps %xmm8,%xmm8 - DB 68,15,194,195,0 ; cmpeqps %xmm3,%xmm8 - DB 243,68,15,16,10 ; movss (%rdx),%xmm9 - DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 - DB 68,15,94,203 ; divps %xmm3,%xmm9 - DB 69,15,85,193 ; andnps %xmm9,%xmm8 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 65,15,89,208 ; mulps %xmm8,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 69,15,87,192 ; xorps %xmm8,%xmm8 + DB 68,15,194,195,0 ; cmpeqps %xmm3,%xmm8 + DB 243,68,15,16,10 ; movss (%rdx),%xmm9 + DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 + DB 68,15,94,203 ; divps %xmm3,%xmm9 + DB 69,15,85,193 ; andnps %xmm9,%xmm8 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 65,15,89,208 ; mulps %xmm8,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_from_srgb_sse2 _sk_from_srgb_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,66,64 ; movss 0x40(%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 69,15,40,232 ; movaps %xmm8,%xmm13 - DB 68,15,89,232 ; mulps %xmm0,%xmm13 - DB 68,15,40,224 ; movaps %xmm0,%xmm12 - DB 69,15,89,228 ; mulps %xmm12,%xmm12 - DB 243,68,15,16,74,60 ; movss 0x3c(%rdx),%xmm9 - DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 - DB 243,68,15,16,82,52 ; movss 0x34(%rdx),%xmm10 - DB 243,68,15,16,90,56 ; movss 0x38(%rdx),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 69,15,40,241 ; movaps %xmm9,%xmm14 - DB 68,15,89,240 ; mulps %xmm0,%xmm14 - DB 69,15,88,243 ; addps %xmm11,%xmm14 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 69,15,89,244 ; mulps %xmm12,%xmm14 - DB 69,15,88,242 ; addps %xmm10,%xmm14 - DB 243,68,15,16,98,68 ; movss 0x44(%rdx),%xmm12 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 65,15,194,196,1 ; cmpltps %xmm12,%xmm0 - DB 68,15,84,232 ; andps %xmm0,%xmm13 - DB 65,15,85,198 ; andnps %xmm14,%xmm0 - DB 65,15,86,197 ; orps %xmm13,%xmm0 - DB 69,15,40,232 ; movaps %xmm8,%xmm13 - DB 68,15,89,233 ; mulps %xmm1,%xmm13 - DB 68,15,40,241 ; movaps %xmm1,%xmm14 - DB 69,15,89,246 ; mulps %xmm14,%xmm14 - DB 69,15,40,249 ; movaps %xmm9,%xmm15 - DB 68,15,89,249 ; mulps %xmm1,%xmm15 - DB 69,15,88,251 ; addps %xmm11,%xmm15 - DB 69,15,89,254 ; mulps %xmm14,%xmm15 - DB 69,15,88,250 ; addps %xmm10,%xmm15 - DB 65,15,194,204,1 ; cmpltps %xmm12,%xmm1 - DB 68,15,84,233 ; andps %xmm1,%xmm13 - DB 65,15,85,207 ; andnps %xmm15,%xmm1 - DB 65,15,86,205 ; orps %xmm13,%xmm1 - DB 68,15,89,194 ; mulps %xmm2,%xmm8 - DB 68,15,40,234 ; movaps %xmm2,%xmm13 - DB 69,15,89,237 ; mulps %xmm13,%xmm13 - DB 68,15,89,202 ; mulps %xmm2,%xmm9 - DB 69,15,88,203 ; addps %xmm11,%xmm9 - DB 69,15,89,205 ; mulps %xmm13,%xmm9 - DB 69,15,88,202 ; addps %xmm10,%xmm9 - DB 65,15,194,212,1 ; cmpltps %xmm12,%xmm2 - DB 68,15,84,194 ; andps %xmm2,%xmm8 - DB 65,15,85,209 ; andnps %xmm9,%xmm2 - DB 65,15,86,208 ; orps %xmm8,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,66,64 ; movss 0x40(%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 69,15,40,232 ; movaps %xmm8,%xmm13 + DB 68,15,89,232 ; mulps %xmm0,%xmm13 + DB 68,15,40,224 ; movaps %xmm0,%xmm12 + DB 69,15,89,228 ; mulps %xmm12,%xmm12 + DB 243,68,15,16,74,60 ; movss 0x3c(%rdx),%xmm9 + DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 + DB 243,68,15,16,82,52 ; movss 0x34(%rdx),%xmm10 + DB 243,68,15,16,90,56 ; movss 0x38(%rdx),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 69,15,40,241 ; movaps %xmm9,%xmm14 + DB 68,15,89,240 ; mulps %xmm0,%xmm14 + DB 69,15,88,243 ; addps %xmm11,%xmm14 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 69,15,89,244 ; mulps %xmm12,%xmm14 + DB 69,15,88,242 ; addps %xmm10,%xmm14 + DB 243,68,15,16,98,68 ; movss 0x44(%rdx),%xmm12 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 65,15,194,196,1 ; cmpltps %xmm12,%xmm0 + DB 68,15,84,232 ; andps %xmm0,%xmm13 + DB 65,15,85,198 ; andnps %xmm14,%xmm0 + DB 65,15,86,197 ; orps %xmm13,%xmm0 + DB 69,15,40,232 ; movaps %xmm8,%xmm13 + DB 68,15,89,233 ; mulps %xmm1,%xmm13 + DB 68,15,40,241 ; movaps %xmm1,%xmm14 + DB 69,15,89,246 ; mulps %xmm14,%xmm14 + DB 69,15,40,249 ; movaps %xmm9,%xmm15 + DB 68,15,89,249 ; mulps %xmm1,%xmm15 + DB 69,15,88,251 ; addps %xmm11,%xmm15 + DB 69,15,89,254 ; mulps %xmm14,%xmm15 + DB 69,15,88,250 ; addps %xmm10,%xmm15 + DB 65,15,194,204,1 ; cmpltps %xmm12,%xmm1 + DB 68,15,84,233 ; andps %xmm1,%xmm13 + DB 65,15,85,207 ; andnps %xmm15,%xmm1 + DB 65,15,86,205 ; orps %xmm13,%xmm1 + DB 68,15,89,194 ; mulps %xmm2,%xmm8 + DB 68,15,40,234 ; movaps %xmm2,%xmm13 + DB 69,15,89,237 ; mulps %xmm13,%xmm13 + DB 68,15,89,202 ; mulps %xmm2,%xmm9 + DB 69,15,88,203 ; addps %xmm11,%xmm9 + DB 69,15,89,205 ; mulps %xmm13,%xmm9 + DB 69,15,88,202 ; addps %xmm10,%xmm9 + DB 65,15,194,212,1 ; cmpltps %xmm12,%xmm2 + DB 68,15,84,194 ; andps %xmm2,%xmm8 + DB 65,15,85,209 ; andnps %xmm9,%xmm2 + DB 65,15,86,208 ; orps %xmm8,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_to_srgb_sse2 _sk_to_srgb_sse2 LABEL PROC - DB 72,131,236,40 ; sub $0x28,%rsp - DB 15,41,124,36,16 ; movaps %xmm7,0x10(%rsp) - DB 15,41,52,36 ; movaps %xmm6,(%rsp) - DB 15,40,245 ; movaps %xmm5,%xmm6 - DB 15,40,236 ; movaps %xmm4,%xmm5 - DB 15,40,227 ; movaps %xmm3,%xmm4 - DB 68,15,82,192 ; rsqrtps %xmm0,%xmm8 - DB 69,15,83,232 ; rcpps %xmm8,%xmm13 - DB 69,15,82,248 ; rsqrtps %xmm8,%xmm15 - DB 243,15,16,26 ; movss (%rdx),%xmm3 - DB 243,68,15,16,66,72 ; movss 0x48(%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 69,15,40,240 ; movaps %xmm8,%xmm14 - DB 68,15,89,240 ; mulps %xmm0,%xmm14 - DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 - DB 243,68,15,16,82,76 ; movss 0x4c(%rdx),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,90,80 ; movss 0x50(%rdx),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 243,68,15,16,98,84 ; movss 0x54(%rdx),%xmm12 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 69,15,89,235 ; mulps %xmm11,%xmm13 - DB 69,15,88,236 ; addps %xmm12,%xmm13 - DB 69,15,89,250 ; mulps %xmm10,%xmm15 - DB 69,15,88,253 ; addps %xmm13,%xmm15 - DB 68,15,40,203 ; movaps %xmm3,%xmm9 - DB 69,15,93,207 ; minps %xmm15,%xmm9 - DB 243,68,15,16,106,88 ; movss 0x58(%rdx),%xmm13 - DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 - DB 65,15,194,197,1 ; cmpltps %xmm13,%xmm0 - DB 68,15,84,240 ; andps %xmm0,%xmm14 - DB 65,15,85,193 ; andnps %xmm9,%xmm0 - DB 65,15,86,198 ; orps %xmm14,%xmm0 - DB 68,15,82,201 ; rsqrtps %xmm1,%xmm9 - DB 69,15,83,241 ; rcpps %xmm9,%xmm14 - DB 69,15,82,201 ; rsqrtps %xmm9,%xmm9 - DB 69,15,89,243 ; mulps %xmm11,%xmm14 - DB 69,15,88,244 ; addps %xmm12,%xmm14 - DB 69,15,89,202 ; mulps %xmm10,%xmm9 - DB 69,15,88,206 ; addps %xmm14,%xmm9 - DB 68,15,40,243 ; movaps %xmm3,%xmm14 - DB 69,15,93,241 ; minps %xmm9,%xmm14 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,201 ; mulps %xmm1,%xmm9 - DB 65,15,194,205,1 ; cmpltps %xmm13,%xmm1 - DB 68,15,84,201 ; andps %xmm1,%xmm9 - DB 65,15,85,206 ; andnps %xmm14,%xmm1 - DB 65,15,86,201 ; orps %xmm9,%xmm1 - DB 68,15,82,202 ; rsqrtps %xmm2,%xmm9 - DB 69,15,83,241 ; rcpps %xmm9,%xmm14 - DB 69,15,89,243 ; mulps %xmm11,%xmm14 - DB 69,15,88,244 ; addps %xmm12,%xmm14 - DB 65,15,82,249 ; rsqrtps %xmm9,%xmm7 - DB 65,15,89,250 ; mulps %xmm10,%xmm7 - DB 65,15,88,254 ; addps %xmm14,%xmm7 - DB 15,93,223 ; minps %xmm7,%xmm3 - DB 68,15,89,194 ; mulps %xmm2,%xmm8 - DB 65,15,194,213,1 ; cmpltps %xmm13,%xmm2 - DB 68,15,84,194 ; andps %xmm2,%xmm8 - DB 15,85,211 ; andnps %xmm3,%xmm2 - DB 65,15,86,208 ; orps %xmm8,%xmm2 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,173 ; lods %ds:(%rsi),%rax - DB 15,40,220 ; movaps %xmm4,%xmm3 - DB 15,40,229 ; movaps %xmm5,%xmm4 - DB 15,40,238 ; movaps %xmm6,%xmm5 - DB 15,40,52,36 ; movaps (%rsp),%xmm6 - DB 15,40,124,36,16 ; movaps 0x10(%rsp),%xmm7 - DB 72,131,196,40 ; add $0x28,%rsp - DB 255,224 ; jmpq *%rax + DB 72,131,236,40 ; sub $0x28,%rsp + DB 15,41,124,36,16 ; movaps %xmm7,0x10(%rsp) + DB 15,41,52,36 ; movaps %xmm6,(%rsp) + DB 15,40,245 ; movaps %xmm5,%xmm6 + DB 15,40,236 ; movaps %xmm4,%xmm5 + DB 15,40,227 ; movaps %xmm3,%xmm4 + DB 68,15,82,192 ; rsqrtps %xmm0,%xmm8 + DB 69,15,83,232 ; rcpps %xmm8,%xmm13 + DB 69,15,82,248 ; rsqrtps %xmm8,%xmm15 + DB 243,15,16,26 ; movss (%rdx),%xmm3 + DB 243,68,15,16,66,72 ; movss 0x48(%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 69,15,40,240 ; movaps %xmm8,%xmm14 + DB 68,15,89,240 ; mulps %xmm0,%xmm14 + DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 + DB 243,68,15,16,82,76 ; movss 0x4c(%rdx),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,90,80 ; movss 0x50(%rdx),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 243,68,15,16,98,84 ; movss 0x54(%rdx),%xmm12 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 69,15,89,235 ; mulps %xmm11,%xmm13 + DB 69,15,88,236 ; addps %xmm12,%xmm13 + DB 69,15,89,250 ; mulps %xmm10,%xmm15 + DB 69,15,88,253 ; addps %xmm13,%xmm15 + DB 68,15,40,203 ; movaps %xmm3,%xmm9 + DB 69,15,93,207 ; minps %xmm15,%xmm9 + DB 243,68,15,16,106,88 ; movss 0x58(%rdx),%xmm13 + DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 + DB 65,15,194,197,1 ; cmpltps %xmm13,%xmm0 + DB 68,15,84,240 ; andps %xmm0,%xmm14 + DB 65,15,85,193 ; andnps %xmm9,%xmm0 + DB 65,15,86,198 ; orps %xmm14,%xmm0 + DB 68,15,82,201 ; rsqrtps %xmm1,%xmm9 + DB 69,15,83,241 ; rcpps %xmm9,%xmm14 + DB 69,15,82,201 ; rsqrtps %xmm9,%xmm9 + DB 69,15,89,243 ; mulps %xmm11,%xmm14 + DB 69,15,88,244 ; addps %xmm12,%xmm14 + DB 69,15,89,202 ; mulps %xmm10,%xmm9 + DB 69,15,88,206 ; addps %xmm14,%xmm9 + DB 68,15,40,243 ; movaps %xmm3,%xmm14 + DB 69,15,93,241 ; minps %xmm9,%xmm14 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,201 ; mulps %xmm1,%xmm9 + DB 65,15,194,205,1 ; cmpltps %xmm13,%xmm1 + DB 68,15,84,201 ; andps %xmm1,%xmm9 + DB 65,15,85,206 ; andnps %xmm14,%xmm1 + DB 65,15,86,201 ; orps %xmm9,%xmm1 + DB 68,15,82,202 ; rsqrtps %xmm2,%xmm9 + DB 69,15,83,241 ; rcpps %xmm9,%xmm14 + DB 69,15,89,243 ; mulps %xmm11,%xmm14 + DB 69,15,88,244 ; addps %xmm12,%xmm14 + DB 65,15,82,249 ; rsqrtps %xmm9,%xmm7 + DB 65,15,89,250 ; mulps %xmm10,%xmm7 + DB 65,15,88,254 ; addps %xmm14,%xmm7 + DB 15,93,223 ; minps %xmm7,%xmm3 + DB 68,15,89,194 ; mulps %xmm2,%xmm8 + DB 65,15,194,213,1 ; cmpltps %xmm13,%xmm2 + DB 68,15,84,194 ; andps %xmm2,%xmm8 + DB 15,85,211 ; andnps %xmm3,%xmm2 + DB 65,15,86,208 ; orps %xmm8,%xmm2 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 15,40,220 ; movaps %xmm4,%xmm3 + DB 15,40,229 ; movaps %xmm5,%xmm4 + DB 15,40,238 ; movaps %xmm6,%xmm5 + DB 15,40,52,36 ; movaps (%rsp),%xmm6 + DB 15,40,124,36,16 ; movaps 0x10(%rsp),%xmm7 + DB 72,131,196,40 ; add $0x28,%rsp + DB 255,224 ; jmpq *%rax PUBLIC _sk_scale_u8_sse2 _sk_scale_u8_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 102,68,15,110,4,56 ; movd (%rax,%rdi,1),%xmm8 - DB 102,69,15,239,201 ; pxor %xmm9,%xmm9 - DB 102,69,15,96,193 ; punpcklbw %xmm9,%xmm8 - DB 102,69,15,97,193 ; punpcklwd %xmm9,%xmm8 - DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 - DB 243,68,15,16,74,12 ; movss 0xc(%rdx),%xmm9 - DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 - DB 69,15,89,200 ; mulps %xmm8,%xmm9 - DB 65,15,89,193 ; mulps %xmm9,%xmm0 - DB 65,15,89,201 ; mulps %xmm9,%xmm1 - DB 65,15,89,209 ; mulps %xmm9,%xmm2 - DB 65,15,89,217 ; mulps %xmm9,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 102,68,15,110,4,56 ; movd (%rax,%rdi,1),%xmm8 + DB 102,69,15,239,201 ; pxor %xmm9,%xmm9 + DB 102,69,15,96,193 ; punpcklbw %xmm9,%xmm8 + DB 102,69,15,97,193 ; punpcklwd %xmm9,%xmm8 + DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 + DB 243,68,15,16,74,12 ; movss 0xc(%rdx),%xmm9 + DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 + DB 69,15,89,200 ; mulps %xmm8,%xmm9 + DB 65,15,89,193 ; mulps %xmm9,%xmm0 + DB 65,15,89,201 ; mulps %xmm9,%xmm1 + DB 65,15,89,209 ; mulps %xmm9,%xmm2 + DB 65,15,89,217 ; mulps %xmm9,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_lerp_u8_sse2 _sk_lerp_u8_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 102,68,15,110,4,56 ; movd (%rax,%rdi,1),%xmm8 - DB 102,69,15,239,201 ; pxor %xmm9,%xmm9 - DB 102,69,15,96,193 ; punpcklbw %xmm9,%xmm8 - DB 102,69,15,97,193 ; punpcklwd %xmm9,%xmm8 - DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 - DB 243,68,15,16,74,12 ; movss 0xc(%rdx),%xmm9 - DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 - DB 69,15,89,200 ; mulps %xmm8,%xmm9 - DB 15,92,196 ; subps %xmm4,%xmm0 - DB 65,15,89,193 ; mulps %xmm9,%xmm0 - DB 15,88,196 ; addps %xmm4,%xmm0 - DB 15,92,205 ; subps %xmm5,%xmm1 - DB 65,15,89,201 ; mulps %xmm9,%xmm1 - DB 15,88,205 ; addps %xmm5,%xmm1 - DB 15,92,214 ; subps %xmm6,%xmm2 - DB 65,15,89,209 ; mulps %xmm9,%xmm2 - DB 15,88,214 ; addps %xmm6,%xmm2 - DB 15,92,223 ; subps %xmm7,%xmm3 - DB 65,15,89,217 ; mulps %xmm9,%xmm3 - DB 15,88,223 ; addps %xmm7,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 102,68,15,110,4,56 ; movd (%rax,%rdi,1),%xmm8 + DB 102,69,15,239,201 ; pxor %xmm9,%xmm9 + DB 102,69,15,96,193 ; punpcklbw %xmm9,%xmm8 + DB 102,69,15,97,193 ; punpcklwd %xmm9,%xmm8 + DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 + DB 243,68,15,16,74,12 ; movss 0xc(%rdx),%xmm9 + DB 69,15,198,201,0 ; shufps $0x0,%xmm9,%xmm9 + DB 69,15,89,200 ; mulps %xmm8,%xmm9 + DB 15,92,196 ; subps %xmm4,%xmm0 + DB 65,15,89,193 ; mulps %xmm9,%xmm0 + DB 15,88,196 ; addps %xmm4,%xmm0 + DB 15,92,205 ; subps %xmm5,%xmm1 + DB 65,15,89,201 ; mulps %xmm9,%xmm1 + DB 15,88,205 ; addps %xmm5,%xmm1 + DB 15,92,214 ; subps %xmm6,%xmm2 + DB 65,15,89,209 ; mulps %xmm9,%xmm2 + DB 15,88,214 ; addps %xmm6,%xmm2 + DB 15,92,223 ; subps %xmm7,%xmm3 + DB 65,15,89,217 ; mulps %xmm9,%xmm3 + DB 15,88,223 ; addps %xmm7,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_tables_sse2 _sk_load_tables_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,8 ; mov (%rax),%rcx - DB 76,139,64,8 ; mov 0x8(%rax),%r8 - DB 243,68,15,111,4,185 ; movdqu (%rcx,%rdi,4),%xmm8 - DB 102,15,110,66,16 ; movd 0x10(%rdx),%xmm0 - DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 - DB 102,69,15,111,200 ; movdqa %xmm8,%xmm9 - DB 102,65,15,114,209,8 ; psrld $0x8,%xmm9 - DB 102,68,15,219,200 ; pand %xmm0,%xmm9 - DB 102,69,15,111,208 ; movdqa %xmm8,%xmm10 - DB 102,65,15,114,210,16 ; psrld $0x10,%xmm10 - DB 102,68,15,219,208 ; pand %xmm0,%xmm10 - DB 102,65,15,219,192 ; pand %xmm8,%xmm0 - DB 102,15,112,216,78 ; pshufd $0x4e,%xmm0,%xmm3 - DB 102,72,15,126,217 ; movq %xmm3,%rcx - DB 65,137,201 ; mov %ecx,%r9d - DB 72,193,233,32 ; shr $0x20,%rcx - DB 102,73,15,126,194 ; movq %xmm0,%r10 - DB 69,137,211 ; mov %r10d,%r11d - DB 73,193,234,32 ; shr $0x20,%r10 - DB 243,67,15,16,28,144 ; movss (%r8,%r10,4),%xmm3 - DB 243,65,15,16,4,136 ; movss (%r8,%rcx,4),%xmm0 - DB 15,20,216 ; unpcklps %xmm0,%xmm3 - DB 243,67,15,16,4,152 ; movss (%r8,%r11,4),%xmm0 - DB 243,67,15,16,12,136 ; movss (%r8,%r9,4),%xmm1 - DB 15,20,193 ; unpcklps %xmm1,%xmm0 - DB 15,20,195 ; unpcklps %xmm3,%xmm0 - DB 72,139,72,16 ; mov 0x10(%rax),%rcx - DB 102,65,15,112,201,78 ; pshufd $0x4e,%xmm9,%xmm1 - DB 102,73,15,126,200 ; movq %xmm1,%r8 - DB 69,137,193 ; mov %r8d,%r9d - DB 73,193,232,32 ; shr $0x20,%r8 - DB 102,77,15,126,202 ; movq %xmm9,%r10 - DB 69,137,211 ; mov %r10d,%r11d - DB 73,193,234,32 ; shr $0x20,%r10 - DB 243,66,15,16,28,145 ; movss (%rcx,%r10,4),%xmm3 - DB 243,66,15,16,12,129 ; movss (%rcx,%r8,4),%xmm1 - DB 15,20,217 ; unpcklps %xmm1,%xmm3 - DB 243,66,15,16,12,153 ; movss (%rcx,%r11,4),%xmm1 - DB 243,66,15,16,20,137 ; movss (%rcx,%r9,4),%xmm2 - DB 15,20,202 ; unpcklps %xmm2,%xmm1 - DB 15,20,203 ; unpcklps %xmm3,%xmm1 - DB 72,139,64,24 ; mov 0x18(%rax),%rax - DB 102,65,15,112,210,78 ; pshufd $0x4e,%xmm10,%xmm2 - DB 102,72,15,126,209 ; movq %xmm2,%rcx - DB 65,137,200 ; mov %ecx,%r8d - DB 72,193,233,32 ; shr $0x20,%rcx - DB 102,77,15,126,209 ; movq %xmm10,%r9 - DB 69,137,202 ; mov %r9d,%r10d - DB 73,193,233,32 ; shr $0x20,%r9 - DB 243,70,15,16,12,136 ; movss (%rax,%r9,4),%xmm9 - DB 243,15,16,20,136 ; movss (%rax,%rcx,4),%xmm2 - DB 68,15,20,202 ; unpcklps %xmm2,%xmm9 - DB 243,66,15,16,20,144 ; movss (%rax,%r10,4),%xmm2 - DB 243,66,15,16,28,128 ; movss (%rax,%r8,4),%xmm3 - DB 15,20,211 ; unpcklps %xmm3,%xmm2 - DB 65,15,20,209 ; unpcklps %xmm9,%xmm2 - DB 102,65,15,114,208,24 ; psrld $0x18,%xmm8 - DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 - DB 243,15,16,90,12 ; movss 0xc(%rdx),%xmm3 - DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 - DB 65,15,89,216 ; mulps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,8 ; mov (%rax),%rcx + DB 76,139,64,8 ; mov 0x8(%rax),%r8 + DB 243,68,15,111,4,185 ; movdqu (%rcx,%rdi,4),%xmm8 + DB 102,15,110,66,16 ; movd 0x10(%rdx),%xmm0 + DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 + DB 102,69,15,111,200 ; movdqa %xmm8,%xmm9 + DB 102,65,15,114,209,8 ; psrld $0x8,%xmm9 + DB 102,68,15,219,200 ; pand %xmm0,%xmm9 + DB 102,69,15,111,208 ; movdqa %xmm8,%xmm10 + DB 102,65,15,114,210,16 ; psrld $0x10,%xmm10 + DB 102,68,15,219,208 ; pand %xmm0,%xmm10 + DB 102,65,15,219,192 ; pand %xmm8,%xmm0 + DB 102,15,112,216,78 ; pshufd $0x4e,%xmm0,%xmm3 + DB 102,72,15,126,217 ; movq %xmm3,%rcx + DB 65,137,201 ; mov %ecx,%r9d + DB 72,193,233,32 ; shr $0x20,%rcx + DB 102,73,15,126,194 ; movq %xmm0,%r10 + DB 69,137,211 ; mov %r10d,%r11d + DB 73,193,234,32 ; shr $0x20,%r10 + DB 243,67,15,16,28,144 ; movss (%r8,%r10,4),%xmm3 + DB 243,65,15,16,4,136 ; movss (%r8,%rcx,4),%xmm0 + DB 15,20,216 ; unpcklps %xmm0,%xmm3 + DB 243,67,15,16,4,152 ; movss (%r8,%r11,4),%xmm0 + DB 243,67,15,16,12,136 ; movss (%r8,%r9,4),%xmm1 + DB 15,20,193 ; unpcklps %xmm1,%xmm0 + DB 15,20,195 ; unpcklps %xmm3,%xmm0 + DB 72,139,72,16 ; mov 0x10(%rax),%rcx + DB 102,65,15,112,201,78 ; pshufd $0x4e,%xmm9,%xmm1 + DB 102,73,15,126,200 ; movq %xmm1,%r8 + DB 69,137,193 ; mov %r8d,%r9d + DB 73,193,232,32 ; shr $0x20,%r8 + DB 102,77,15,126,202 ; movq %xmm9,%r10 + DB 69,137,211 ; mov %r10d,%r11d + DB 73,193,234,32 ; shr $0x20,%r10 + DB 243,66,15,16,28,145 ; movss (%rcx,%r10,4),%xmm3 + DB 243,66,15,16,12,129 ; movss (%rcx,%r8,4),%xmm1 + DB 15,20,217 ; unpcklps %xmm1,%xmm3 + DB 243,66,15,16,12,153 ; movss (%rcx,%r11,4),%xmm1 + DB 243,66,15,16,20,137 ; movss (%rcx,%r9,4),%xmm2 + DB 15,20,202 ; unpcklps %xmm2,%xmm1 + DB 15,20,203 ; unpcklps %xmm3,%xmm1 + DB 72,139,64,24 ; mov 0x18(%rax),%rax + DB 102,65,15,112,210,78 ; pshufd $0x4e,%xmm10,%xmm2 + DB 102,72,15,126,209 ; movq %xmm2,%rcx + DB 65,137,200 ; mov %ecx,%r8d + DB 72,193,233,32 ; shr $0x20,%rcx + DB 102,77,15,126,209 ; movq %xmm10,%r9 + DB 69,137,202 ; mov %r9d,%r10d + DB 73,193,233,32 ; shr $0x20,%r9 + DB 243,70,15,16,12,136 ; movss (%rax,%r9,4),%xmm9 + DB 243,15,16,20,136 ; movss (%rax,%rcx,4),%xmm2 + DB 68,15,20,202 ; unpcklps %xmm2,%xmm9 + DB 243,66,15,16,20,144 ; movss (%rax,%r10,4),%xmm2 + DB 243,66,15,16,28,128 ; movss (%rax,%r8,4),%xmm3 + DB 15,20,211 ; unpcklps %xmm3,%xmm2 + DB 65,15,20,209 ; unpcklps %xmm9,%xmm2 + DB 102,65,15,114,208,24 ; psrld $0x18,%xmm8 + DB 69,15,91,192 ; cvtdq2ps %xmm8,%xmm8 + DB 243,15,16,90,12 ; movss 0xc(%rdx),%xmm3 + DB 15,198,219,0 ; shufps $0x0,%xmm3,%xmm3 + DB 65,15,89,216 ; mulps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_8888_sse2 _sk_load_8888_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 243,15,111,28,184 ; movdqu (%rax,%rdi,4),%xmm3 - DB 102,15,110,66,16 ; movd 0x10(%rdx),%xmm0 - DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 - DB 102,15,111,203 ; movdqa %xmm3,%xmm1 - DB 102,15,114,209,8 ; psrld $0x8,%xmm1 - DB 102,15,219,200 ; pand %xmm0,%xmm1 - DB 102,15,111,211 ; movdqa %xmm3,%xmm2 - DB 102,15,114,210,16 ; psrld $0x10,%xmm2 - DB 102,15,219,208 ; pand %xmm0,%xmm2 - DB 102,15,219,195 ; pand %xmm3,%xmm0 - DB 15,91,192 ; cvtdq2ps %xmm0,%xmm0 - DB 243,68,15,16,66,12 ; movss 0xc(%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 15,91,201 ; cvtdq2ps %xmm1,%xmm1 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 15,91,210 ; cvtdq2ps %xmm2,%xmm2 - DB 65,15,89,208 ; mulps %xmm8,%xmm2 - DB 102,15,114,211,24 ; psrld $0x18,%xmm3 - DB 15,91,219 ; cvtdq2ps %xmm3,%xmm3 - DB 65,15,89,216 ; mulps %xmm8,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 243,15,111,28,184 ; movdqu (%rax,%rdi,4),%xmm3 + DB 102,15,110,66,16 ; movd 0x10(%rdx),%xmm0 + DB 102,15,112,192,0 ; pshufd $0x0,%xmm0,%xmm0 + DB 102,15,111,203 ; movdqa %xmm3,%xmm1 + DB 102,15,114,209,8 ; psrld $0x8,%xmm1 + DB 102,15,219,200 ; pand %xmm0,%xmm1 + DB 102,15,111,211 ; movdqa %xmm3,%xmm2 + DB 102,15,114,210,16 ; psrld $0x10,%xmm2 + DB 102,15,219,208 ; pand %xmm0,%xmm2 + DB 102,15,219,195 ; pand %xmm3,%xmm0 + DB 15,91,192 ; cvtdq2ps %xmm0,%xmm0 + DB 243,68,15,16,66,12 ; movss 0xc(%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 15,91,201 ; cvtdq2ps %xmm1,%xmm1 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 15,91,210 ; cvtdq2ps %xmm2,%xmm2 + DB 65,15,89,208 ; mulps %xmm8,%xmm2 + DB 102,15,114,211,24 ; psrld $0x18,%xmm3 + DB 15,91,219 ; cvtdq2ps %xmm3,%xmm3 + DB 65,15,89,216 ; mulps %xmm8,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_store_8888_sse2 _sk_store_8888_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 243,68,15,16,66,8 ; movss 0x8(%rdx),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,200 ; mulps %xmm0,%xmm9 - DB 102,69,15,91,201 ; cvtps2dq %xmm9,%xmm9 - DB 69,15,40,208 ; movaps %xmm8,%xmm10 - DB 68,15,89,209 ; mulps %xmm1,%xmm10 - DB 102,69,15,91,210 ; cvtps2dq %xmm10,%xmm10 - DB 102,65,15,114,242,8 ; pslld $0x8,%xmm10 - DB 102,69,15,235,209 ; por %xmm9,%xmm10 - DB 69,15,40,200 ; movaps %xmm8,%xmm9 - DB 68,15,89,202 ; mulps %xmm2,%xmm9 - DB 102,69,15,91,201 ; cvtps2dq %xmm9,%xmm9 - DB 102,65,15,114,241,16 ; pslld $0x10,%xmm9 - DB 68,15,89,195 ; mulps %xmm3,%xmm8 - DB 102,69,15,91,192 ; cvtps2dq %xmm8,%xmm8 - DB 102,65,15,114,240,24 ; pslld $0x18,%xmm8 - DB 102,69,15,235,193 ; por %xmm9,%xmm8 - DB 102,69,15,235,194 ; por %xmm10,%xmm8 - DB 243,68,15,127,4,184 ; movdqu %xmm8,(%rax,%rdi,4) - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 243,68,15,16,66,8 ; movss 0x8(%rdx),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,200 ; mulps %xmm0,%xmm9 + DB 102,69,15,91,201 ; cvtps2dq %xmm9,%xmm9 + DB 69,15,40,208 ; movaps %xmm8,%xmm10 + DB 68,15,89,209 ; mulps %xmm1,%xmm10 + DB 102,69,15,91,210 ; cvtps2dq %xmm10,%xmm10 + DB 102,65,15,114,242,8 ; pslld $0x8,%xmm10 + DB 102,69,15,235,209 ; por %xmm9,%xmm10 + DB 69,15,40,200 ; movaps %xmm8,%xmm9 + DB 68,15,89,202 ; mulps %xmm2,%xmm9 + DB 102,69,15,91,201 ; cvtps2dq %xmm9,%xmm9 + DB 102,65,15,114,241,16 ; pslld $0x10,%xmm9 + DB 68,15,89,195 ; mulps %xmm3,%xmm8 + DB 102,69,15,91,192 ; cvtps2dq %xmm8,%xmm8 + DB 102,65,15,114,240,24 ; pslld $0x18,%xmm8 + DB 102,69,15,235,193 ; por %xmm9,%xmm8 + DB 102,69,15,235,194 ; por %xmm10,%xmm8 + DB 243,68,15,127,4,184 ; movdqu %xmm8,(%rax,%rdi,4) + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_load_f16_sse2 _sk_load_f16_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 243,15,111,4,248 ; movdqu (%rax,%rdi,8),%xmm0 - DB 243,15,111,76,248,16 ; movdqu 0x10(%rax,%rdi,8),%xmm1 - DB 102,15,111,208 ; movdqa %xmm0,%xmm2 - DB 102,15,97,209 ; punpcklwd %xmm1,%xmm2 - DB 102,15,105,193 ; punpckhwd %xmm1,%xmm0 - DB 102,68,15,111,194 ; movdqa %xmm2,%xmm8 - DB 102,68,15,97,192 ; punpcklwd %xmm0,%xmm8 - DB 102,15,105,208 ; punpckhwd %xmm0,%xmm2 - DB 102,15,110,66,100 ; movd 0x64(%rdx),%xmm0 - DB 102,15,112,216,0 ; pshufd $0x0,%xmm0,%xmm3 - DB 102,15,111,203 ; movdqa %xmm3,%xmm1 - DB 102,65,15,101,200 ; pcmpgtw %xmm8,%xmm1 - DB 102,65,15,223,200 ; pandn %xmm8,%xmm1 - DB 102,15,101,218 ; pcmpgtw %xmm2,%xmm3 - DB 102,15,223,218 ; pandn %xmm2,%xmm3 - DB 102,69,15,239,192 ; pxor %xmm8,%xmm8 - DB 102,15,111,193 ; movdqa %xmm1,%xmm0 - DB 102,65,15,97,192 ; punpcklwd %xmm8,%xmm0 - DB 102,15,114,240,13 ; pslld $0xd,%xmm0 - DB 102,15,110,82,92 ; movd 0x5c(%rdx),%xmm2 - DB 102,68,15,112,202,0 ; pshufd $0x0,%xmm2,%xmm9 - DB 65,15,89,193 ; mulps %xmm9,%xmm0 - DB 102,65,15,105,200 ; punpckhwd %xmm8,%xmm1 - DB 102,15,114,241,13 ; pslld $0xd,%xmm1 - DB 65,15,89,201 ; mulps %xmm9,%xmm1 - DB 102,15,111,211 ; movdqa %xmm3,%xmm2 - DB 102,65,15,97,208 ; punpcklwd %xmm8,%xmm2 - DB 102,15,114,242,13 ; pslld $0xd,%xmm2 - DB 65,15,89,209 ; mulps %xmm9,%xmm2 - DB 102,65,15,105,216 ; punpckhwd %xmm8,%xmm3 - DB 102,15,114,243,13 ; pslld $0xd,%xmm3 - DB 65,15,89,217 ; mulps %xmm9,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 243,15,111,4,248 ; movdqu (%rax,%rdi,8),%xmm0 + DB 243,15,111,76,248,16 ; movdqu 0x10(%rax,%rdi,8),%xmm1 + DB 102,15,111,208 ; movdqa %xmm0,%xmm2 + DB 102,15,97,209 ; punpcklwd %xmm1,%xmm2 + DB 102,15,105,193 ; punpckhwd %xmm1,%xmm0 + DB 102,68,15,111,194 ; movdqa %xmm2,%xmm8 + DB 102,68,15,97,192 ; punpcklwd %xmm0,%xmm8 + DB 102,15,105,208 ; punpckhwd %xmm0,%xmm2 + DB 102,15,110,66,100 ; movd 0x64(%rdx),%xmm0 + DB 102,15,112,216,0 ; pshufd $0x0,%xmm0,%xmm3 + DB 102,15,111,203 ; movdqa %xmm3,%xmm1 + DB 102,65,15,101,200 ; pcmpgtw %xmm8,%xmm1 + DB 102,65,15,223,200 ; pandn %xmm8,%xmm1 + DB 102,15,101,218 ; pcmpgtw %xmm2,%xmm3 + DB 102,15,223,218 ; pandn %xmm2,%xmm3 + DB 102,69,15,239,192 ; pxor %xmm8,%xmm8 + DB 102,15,111,193 ; movdqa %xmm1,%xmm0 + DB 102,65,15,97,192 ; punpcklwd %xmm8,%xmm0 + DB 102,15,114,240,13 ; pslld $0xd,%xmm0 + DB 102,15,110,82,92 ; movd 0x5c(%rdx),%xmm2 + DB 102,68,15,112,202,0 ; pshufd $0x0,%xmm2,%xmm9 + DB 65,15,89,193 ; mulps %xmm9,%xmm0 + DB 102,65,15,105,200 ; punpckhwd %xmm8,%xmm1 + DB 102,15,114,241,13 ; pslld $0xd,%xmm1 + DB 65,15,89,201 ; mulps %xmm9,%xmm1 + DB 102,15,111,211 ; movdqa %xmm3,%xmm2 + DB 102,65,15,97,208 ; punpcklwd %xmm8,%xmm2 + DB 102,15,114,242,13 ; pslld $0xd,%xmm2 + DB 65,15,89,209 ; mulps %xmm9,%xmm2 + DB 102,65,15,105,216 ; punpckhwd %xmm8,%xmm3 + DB 102,15,114,243,13 ; pslld $0xd,%xmm3 + DB 65,15,89,217 ; mulps %xmm9,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_store_f16_sse2 _sk_store_f16_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 72,139,0 ; mov (%rax),%rax - DB 102,68,15,110,66,96 ; movd 0x60(%rdx),%xmm8 - DB 102,69,15,112,192,0 ; pshufd $0x0,%xmm8,%xmm8 - DB 102,69,15,111,200 ; movdqa %xmm8,%xmm9 - DB 68,15,89,200 ; mulps %xmm0,%xmm9 - DB 102,65,15,114,209,13 ; psrld $0xd,%xmm9 - DB 102,69,15,111,208 ; movdqa %xmm8,%xmm10 - DB 68,15,89,209 ; mulps %xmm1,%xmm10 - DB 102,65,15,114,210,13 ; psrld $0xd,%xmm10 - DB 102,69,15,111,216 ; movdqa %xmm8,%xmm11 - DB 68,15,89,218 ; mulps %xmm2,%xmm11 - DB 102,65,15,114,211,13 ; psrld $0xd,%xmm11 - DB 68,15,89,195 ; mulps %xmm3,%xmm8 - DB 102,65,15,114,208,13 ; psrld $0xd,%xmm8 - DB 102,65,15,115,250,2 ; pslldq $0x2,%xmm10 - DB 102,69,15,235,209 ; por %xmm9,%xmm10 - DB 102,65,15,115,248,2 ; pslldq $0x2,%xmm8 - DB 102,69,15,235,195 ; por %xmm11,%xmm8 - DB 102,69,15,111,202 ; movdqa %xmm10,%xmm9 - DB 102,69,15,98,200 ; punpckldq %xmm8,%xmm9 - DB 243,68,15,127,12,248 ; movdqu %xmm9,(%rax,%rdi,8) - DB 102,69,15,106,208 ; punpckhdq %xmm8,%xmm10 - DB 243,68,15,127,84,248,16 ; movdqu %xmm10,0x10(%rax,%rdi,8) - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 72,139,0 ; mov (%rax),%rax + DB 102,68,15,110,66,96 ; movd 0x60(%rdx),%xmm8 + DB 102,69,15,112,192,0 ; pshufd $0x0,%xmm8,%xmm8 + DB 102,69,15,111,200 ; movdqa %xmm8,%xmm9 + DB 68,15,89,200 ; mulps %xmm0,%xmm9 + DB 102,65,15,114,209,13 ; psrld $0xd,%xmm9 + DB 102,69,15,111,208 ; movdqa %xmm8,%xmm10 + DB 68,15,89,209 ; mulps %xmm1,%xmm10 + DB 102,65,15,114,210,13 ; psrld $0xd,%xmm10 + DB 102,69,15,111,216 ; movdqa %xmm8,%xmm11 + DB 68,15,89,218 ; mulps %xmm2,%xmm11 + DB 102,65,15,114,211,13 ; psrld $0xd,%xmm11 + DB 68,15,89,195 ; mulps %xmm3,%xmm8 + DB 102,65,15,114,208,13 ; psrld $0xd,%xmm8 + DB 102,65,15,115,250,2 ; pslldq $0x2,%xmm10 + DB 102,69,15,235,209 ; por %xmm9,%xmm10 + DB 102,65,15,115,248,2 ; pslldq $0x2,%xmm8 + DB 102,69,15,235,195 ; por %xmm11,%xmm8 + DB 102,69,15,111,202 ; movdqa %xmm10,%xmm9 + DB 102,69,15,98,200 ; punpckldq %xmm8,%xmm9 + DB 243,68,15,127,12,248 ; movdqu %xmm9,(%rax,%rdi,8) + DB 102,69,15,106,208 ; punpckhdq %xmm8,%xmm10 + DB 243,68,15,127,84,248,16 ; movdqu %xmm10,0x10(%rax,%rdi,8) + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_x_sse2 _sk_clamp_x_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,0 ; movss (%rax),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 102,69,15,118,201 ; pcmpeqd %xmm9,%xmm9 - DB 102,69,15,254,200 ; paddd %xmm8,%xmm9 - DB 65,15,93,193 ; minps %xmm9,%xmm0 - DB 69,15,87,192 ; xorps %xmm8,%xmm8 - DB 68,15,95,192 ; maxps %xmm0,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,192 ; movaps %xmm8,%xmm0 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,0 ; movss (%rax),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 102,69,15,118,201 ; pcmpeqd %xmm9,%xmm9 + DB 102,69,15,254,200 ; paddd %xmm8,%xmm9 + DB 65,15,93,193 ; minps %xmm9,%xmm0 + DB 69,15,87,192 ; xorps %xmm8,%xmm8 + DB 68,15,95,192 ; maxps %xmm0,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,192 ; movaps %xmm8,%xmm0 + DB 255,224 ; jmpq *%rax PUBLIC _sk_clamp_y_sse2 _sk_clamp_y_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,68,15,16,0 ; movss (%rax),%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 102,69,15,118,201 ; pcmpeqd %xmm9,%xmm9 - DB 102,69,15,254,200 ; paddd %xmm8,%xmm9 - DB 65,15,93,201 ; minps %xmm9,%xmm1 - DB 69,15,87,192 ; xorps %xmm8,%xmm8 - DB 68,15,95,193 ; maxps %xmm1,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,200 ; movaps %xmm8,%xmm1 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,68,15,16,0 ; movss (%rax),%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 102,69,15,118,201 ; pcmpeqd %xmm9,%xmm9 + DB 102,69,15,254,200 ; paddd %xmm8,%xmm9 + DB 65,15,93,201 ; minps %xmm9,%xmm1 + DB 69,15,87,192 ; xorps %xmm8,%xmm8 + DB 68,15,95,193 ; maxps %xmm1,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,200 ; movaps %xmm8,%xmm1 + DB 255,224 ; jmpq *%rax PUBLIC _sk_matrix_2x3_sse2 _sk_matrix_2x3_sse2 LABEL PROC - DB 68,15,40,201 ; movaps %xmm1,%xmm9 - DB 68,15,40,192 ; movaps %xmm0,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,15,16,0 ; movss (%rax),%xmm0 - DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 - DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 - DB 243,68,15,16,80,8 ; movss 0x8(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,16 ; movss 0x10(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 69,15,89,209 ; mulps %xmm9,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 65,15,88,194 ; addps %xmm10,%xmm0 - DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 - DB 243,68,15,16,80,12 ; movss 0xc(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,20 ; movss 0x14(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 69,15,89,209 ; mulps %xmm9,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 65,15,88,202 ; addps %xmm10,%xmm1 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 255,224 ; jmpq *%rax + DB 68,15,40,201 ; movaps %xmm1,%xmm9 + DB 68,15,40,192 ; movaps %xmm0,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,15,16,0 ; movss (%rax),%xmm0 + DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 + DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 + DB 243,68,15,16,80,8 ; movss 0x8(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,16 ; movss 0x10(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 69,15,89,209 ; mulps %xmm9,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 65,15,88,194 ; addps %xmm10,%xmm0 + DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 + DB 243,68,15,16,80,12 ; movss 0xc(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,20 ; movss 0x14(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 69,15,89,209 ; mulps %xmm9,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 65,15,88,202 ; addps %xmm10,%xmm1 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 255,224 ; jmpq *%rax PUBLIC _sk_matrix_3x4_sse2 _sk_matrix_3x4_sse2 LABEL PROC - DB 68,15,40,201 ; movaps %xmm1,%xmm9 - DB 68,15,40,192 ; movaps %xmm0,%xmm8 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 243,15,16,0 ; movss (%rax),%xmm0 - DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 - DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 - DB 243,68,15,16,80,12 ; movss 0xc(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,24 ; movss 0x18(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 243,68,15,16,96,36 ; movss 0x24(%rax),%xmm12 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 68,15,89,218 ; mulps %xmm2,%xmm11 - DB 69,15,88,220 ; addps %xmm12,%xmm11 - DB 69,15,89,209 ; mulps %xmm9,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 65,15,89,192 ; mulps %xmm8,%xmm0 - DB 65,15,88,194 ; addps %xmm10,%xmm0 - DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 - DB 243,68,15,16,80,16 ; movss 0x10(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,28 ; movss 0x1c(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 243,68,15,16,96,40 ; movss 0x28(%rax),%xmm12 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 68,15,89,218 ; mulps %xmm2,%xmm11 - DB 69,15,88,220 ; addps %xmm12,%xmm11 - DB 69,15,89,209 ; mulps %xmm9,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 65,15,89,200 ; mulps %xmm8,%xmm1 - DB 65,15,88,202 ; addps %xmm10,%xmm1 - DB 243,68,15,16,80,8 ; movss 0x8(%rax),%xmm10 - DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 - DB 243,68,15,16,88,20 ; movss 0x14(%rax),%xmm11 - DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 - DB 243,68,15,16,96,32 ; movss 0x20(%rax),%xmm12 - DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 - DB 243,68,15,16,104,44 ; movss 0x2c(%rax),%xmm13 - DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 - DB 68,15,89,226 ; mulps %xmm2,%xmm12 - DB 69,15,88,229 ; addps %xmm13,%xmm12 - DB 69,15,89,217 ; mulps %xmm9,%xmm11 - DB 69,15,88,220 ; addps %xmm12,%xmm11 - DB 69,15,89,208 ; mulps %xmm8,%xmm10 - DB 69,15,88,211 ; addps %xmm11,%xmm10 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,210 ; movaps %xmm10,%xmm2 - DB 255,224 ; jmpq *%rax + DB 68,15,40,201 ; movaps %xmm1,%xmm9 + DB 68,15,40,192 ; movaps %xmm0,%xmm8 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 243,15,16,0 ; movss (%rax),%xmm0 + DB 243,15,16,72,4 ; movss 0x4(%rax),%xmm1 + DB 15,198,192,0 ; shufps $0x0,%xmm0,%xmm0 + DB 243,68,15,16,80,12 ; movss 0xc(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,24 ; movss 0x18(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 243,68,15,16,96,36 ; movss 0x24(%rax),%xmm12 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 68,15,89,218 ; mulps %xmm2,%xmm11 + DB 69,15,88,220 ; addps %xmm12,%xmm11 + DB 69,15,89,209 ; mulps %xmm9,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 65,15,89,192 ; mulps %xmm8,%xmm0 + DB 65,15,88,194 ; addps %xmm10,%xmm0 + DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 + DB 243,68,15,16,80,16 ; movss 0x10(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,28 ; movss 0x1c(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 243,68,15,16,96,40 ; movss 0x28(%rax),%xmm12 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 68,15,89,218 ; mulps %xmm2,%xmm11 + DB 69,15,88,220 ; addps %xmm12,%xmm11 + DB 69,15,89,209 ; mulps %xmm9,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 65,15,89,200 ; mulps %xmm8,%xmm1 + DB 65,15,88,202 ; addps %xmm10,%xmm1 + DB 243,68,15,16,80,8 ; movss 0x8(%rax),%xmm10 + DB 69,15,198,210,0 ; shufps $0x0,%xmm10,%xmm10 + DB 243,68,15,16,88,20 ; movss 0x14(%rax),%xmm11 + DB 69,15,198,219,0 ; shufps $0x0,%xmm11,%xmm11 + DB 243,68,15,16,96,32 ; movss 0x20(%rax),%xmm12 + DB 69,15,198,228,0 ; shufps $0x0,%xmm12,%xmm12 + DB 243,68,15,16,104,44 ; movss 0x2c(%rax),%xmm13 + DB 69,15,198,237,0 ; shufps $0x0,%xmm13,%xmm13 + DB 68,15,89,226 ; mulps %xmm2,%xmm12 + DB 69,15,88,229 ; addps %xmm13,%xmm12 + DB 69,15,89,217 ; mulps %xmm9,%xmm11 + DB 69,15,88,220 ; addps %xmm12,%xmm11 + DB 69,15,89,208 ; mulps %xmm8,%xmm10 + DB 69,15,88,211 ; addps %xmm11,%xmm10 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,210 ; movaps %xmm10,%xmm2 + DB 255,224 ; jmpq *%rax PUBLIC _sk_linear_gradient_2stops_sse2 _sk_linear_gradient_2stops_sse2 LABEL PROC - DB 72,173 ; lods %ds:(%rsi),%rax - DB 68,15,16,8 ; movups (%rax),%xmm9 - DB 15,16,88,16 ; movups 0x10(%rax),%xmm3 - DB 68,15,40,195 ; movaps %xmm3,%xmm8 - DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 - DB 65,15,40,201 ; movaps %xmm9,%xmm1 - DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 - DB 68,15,89,192 ; mulps %xmm0,%xmm8 - DB 68,15,88,193 ; addps %xmm1,%xmm8 - DB 15,40,203 ; movaps %xmm3,%xmm1 - DB 15,198,201,85 ; shufps $0x55,%xmm1,%xmm1 - DB 65,15,40,209 ; movaps %xmm9,%xmm2 - DB 15,198,210,85 ; shufps $0x55,%xmm2,%xmm2 - DB 15,89,200 ; mulps %xmm0,%xmm1 - DB 15,88,202 ; addps %xmm2,%xmm1 - DB 15,40,211 ; movaps %xmm3,%xmm2 - DB 15,198,210,170 ; shufps $0xaa,%xmm2,%xmm2 - DB 69,15,40,209 ; movaps %xmm9,%xmm10 - DB 69,15,198,210,170 ; shufps $0xaa,%xmm10,%xmm10 - DB 15,89,208 ; mulps %xmm0,%xmm2 - DB 65,15,88,210 ; addps %xmm10,%xmm2 - DB 15,198,219,255 ; shufps $0xff,%xmm3,%xmm3 - DB 69,15,198,201,255 ; shufps $0xff,%xmm9,%xmm9 - DB 15,89,216 ; mulps %xmm0,%xmm3 - DB 65,15,88,217 ; addps %xmm9,%xmm3 - DB 72,173 ; lods %ds:(%rsi),%rax - DB 65,15,40,192 ; movaps %xmm8,%xmm0 - DB 255,224 ; jmpq *%rax + DB 72,173 ; lods %ds:(%rsi),%rax + DB 68,15,16,8 ; movups (%rax),%xmm9 + DB 15,16,88,16 ; movups 0x10(%rax),%xmm3 + DB 68,15,40,195 ; movaps %xmm3,%xmm8 + DB 69,15,198,192,0 ; shufps $0x0,%xmm8,%xmm8 + DB 65,15,40,201 ; movaps %xmm9,%xmm1 + DB 15,198,201,0 ; shufps $0x0,%xmm1,%xmm1 + DB 68,15,89,192 ; mulps %xmm0,%xmm8 + DB 68,15,88,193 ; addps %xmm1,%xmm8 + DB 15,40,203 ; movaps %xmm3,%xmm1 + DB 15,198,201,85 ; shufps $0x55,%xmm1,%xmm1 + DB 65,15,40,209 ; movaps %xmm9,%xmm2 + DB 15,198,210,85 ; shufps $0x55,%xmm2,%xmm2 + DB 15,89,200 ; mulps %xmm0,%xmm1 + DB 15,88,202 ; addps %xmm2,%xmm1 + DB 15,40,211 ; movaps %xmm3,%xmm2 + DB 15,198,210,170 ; shufps $0xaa,%xmm2,%xmm2 + DB 69,15,40,209 ; movaps %xmm9,%xmm10 + DB 69,15,198,210,170 ; shufps $0xaa,%xmm10,%xmm10 + DB 15,89,208 ; mulps %xmm0,%xmm2 + DB 65,15,88,210 ; addps %xmm10,%xmm2 + DB 15,198,219,255 ; shufps $0xff,%xmm3,%xmm3 + DB 69,15,198,201,255 ; shufps $0xff,%xmm9,%xmm9 + DB 15,89,216 ; mulps %xmm0,%xmm3 + DB 65,15,88,217 ; addps %xmm9,%xmm3 + DB 72,173 ; lods %ds:(%rsi),%rax + DB 65,15,40,192 ; movaps %xmm8,%xmm0 + DB 255,224 ; jmpq *%rax END diff --git a/src/jumper/build_stages.py b/src/jumper/build_stages.py index 945f77606f..e22ab9b136 100755 --- a/src/jumper/build_stages.py +++ b/src/jumper/build_stages.py @@ -68,9 +68,12 @@ subprocess.check_call(['clang++'] + cflags + vfp4 + ['-o', 'vfp4.o']) def parse_object_file(dot_o, directive, target=None): - globl, label, comment, dehex = '.globl', ':', '// ', lambda h: '0x'+h + globl, label, comment = '.globl', ':', '// ' if 'win' in dot_o: globl, label, comment = 'PUBLIC', ' LABEL PROC', '; ' + + dehex = lambda h: '0x'+h + if directive != '.long': dehex = lambda h: str(int(h, 16)) cmd = [ objdump, '-d', '--insn-width=9', dot_o] @@ -108,7 +111,7 @@ def parse_object_file(dot_o, directive, target=None): hexed = ','.join(dehex(x) for x in code.split(' ')) - print ' ' + directive + ' ' + hexed + ' '*(48-len(hexed)) + \ + print ' ' + directive + ' ' + hexed + ' '*(36-len(hexed)) + \ comment + inst + (' '*(14-len(inst)) + args if args else '') sys.stdout = open('src/jumper/SkJumper_generated.S', 'w')