2016-05-02 12:17:39 -07:00
|
|
|
;
|
|
|
|
; Copyright (c) 2010 The WebM project authors. All Rights Reserved.
|
|
|
|
;
|
|
|
|
; Use of this source code is governed by a BSD-style license
|
|
|
|
; that can be found in the LICENSE file in the root of the source
|
|
|
|
; tree. An additional intellectual property rights grant can be found
|
|
|
|
; in the file PATENTS. All contributing project authors may
|
|
|
|
; be found in the AUTHORS file in the root of the source tree.
|
|
|
|
;
|
|
|
|
|
|
|
|
|
|
|
|
%include "vpx_ports/x86_abi_support.asm"
|
|
|
|
|
|
|
|
;void vpx_plane_add_noise_sse2(unsigned char *start, unsigned char *noise,
|
|
|
|
; unsigned char blackclamp[16],
|
|
|
|
; unsigned char whiteclamp[16],
|
|
|
|
; unsigned char bothclamp[16],
|
|
|
|
; unsigned int width, unsigned int height,
|
|
|
|
; int pitch)
|
|
|
|
global sym(vpx_plane_add_noise_sse2) PRIVATE
|
|
|
|
sym(vpx_plane_add_noise_sse2):
|
|
|
|
push rbp
|
|
|
|
mov rbp, rsp
|
|
|
|
SHADOW_ARGS_TO_STACK 8
|
|
|
|
GET_GOT rbx
|
|
|
|
push rsi
|
|
|
|
push rdi
|
|
|
|
; end prolog
|
|
|
|
|
2016-05-03 16:23:06 -07:00
|
|
|
; get the clamps in registers
|
|
|
|
mov rdx, arg(2) ; blackclamp
|
|
|
|
movdqu xmm3, [rdx]
|
|
|
|
mov rdx, arg(3) ; whiteclamp
|
|
|
|
movdqu xmm4, [rdx]
|
|
|
|
mov rdx, arg(4) ; bothclamp
|
|
|
|
movdqu xmm5, [rdx]
|
|
|
|
|
2016-05-02 12:17:39 -07:00
|
|
|
.addnoise_loop:
|
|
|
|
call sym(LIBVPX_RAND) WRT_PLT
|
|
|
|
mov rcx, arg(1) ;noise
|
|
|
|
and rax, 0xff
|
|
|
|
add rcx, rax
|
|
|
|
|
2016-05-03 16:23:06 -07:00
|
|
|
mov rdi, rcx
|
|
|
|
movsxd rcx, dword arg(5) ;[Width]
|
|
|
|
mov rsi, arg(0) ;Pos
|
|
|
|
xor rax,rax
|
2016-05-02 12:17:39 -07:00
|
|
|
|
|
|
|
.addnoise_nextset:
|
2016-05-03 16:23:06 -07:00
|
|
|
movdqu xmm1,[rsi+rax] ; get the source
|
2016-05-02 12:17:39 -07:00
|
|
|
|
2016-05-03 16:23:06 -07:00
|
|
|
psubusb xmm1, xmm3 ; subtract black clamp
|
|
|
|
paddusb xmm1, xmm5 ; add both clamp
|
|
|
|
psubusb xmm1, xmm4 ; subtract whiteclamp
|
2016-05-02 12:17:39 -07:00
|
|
|
|
2016-05-03 16:23:06 -07:00
|
|
|
movdqu xmm2,[rdi+rax] ; get the noise for this line
|
|
|
|
paddb xmm1,xmm2 ; add it in
|
|
|
|
movdqu [rsi+rax],xmm1 ; store the result
|
2016-05-02 12:17:39 -07:00
|
|
|
|
2016-05-03 16:23:06 -07:00
|
|
|
add rax,16 ; move to the next line
|
2016-05-02 12:17:39 -07:00
|
|
|
|
2016-05-03 16:23:06 -07:00
|
|
|
cmp rax, rcx
|
|
|
|
jl .addnoise_nextset
|
2016-05-02 12:17:39 -07:00
|
|
|
|
|
|
|
movsxd rax, dword arg(7) ; Pitch
|
|
|
|
add arg(0), rax ; Start += Pitch
|
|
|
|
sub dword arg(6), 1 ; Height -= 1
|
|
|
|
jg .addnoise_loop
|
|
|
|
|
|
|
|
; begin epilog
|
|
|
|
pop rdi
|
|
|
|
pop rsi
|
|
|
|
RESTORE_GOT
|
|
|
|
UNSHADOW_ARGS
|
|
|
|
pop rbp
|
|
|
|
ret
|
|
|
|
|
|
|
|
SECTION_RODATA
|
|
|
|
align 16
|
|
|
|
rd42:
|
|
|
|
times 8 dw 0x04
|
|
|
|
four8s:
|
|
|
|
times 4 dd 8
|