.file "asma.c" .section .rodata .align 128 const9a: .rept 16 .byte 0x9a .endr const20: .rept 16 .byte 0x20 .endr const3f: .rept 16 .byte 0x3f .endr .text .globl asma .type asma, @function asma: .LFB2: /*init %xmm8 mit "'Z' + 1 + min_t - 'A'" fuer jedes byte * 'Z' + 1 + min_t - 'A' = 90 + 1 - 128 - 65 = -102 * 102 = 01100110 * ~102 = 10011001 * (~102)+1 = 10011010 = 0x9A */ movdqa const9a, %xmm8 //speicheradresse des pointers zeigt auf 16*8 feld = 128bit movdqu (%rdi), %xmm11 /*addiere in %xmm11 "min_t-'A'" * = -128 - 65 = 63 = 0x3f * c+min_t-'A' */ paddb const3f, %xmm11 /*"Packed COMpare Greater Than (Byte)" * X = 'Z' + 1 + min_t - 'A' > c + min_t - 'A' ? 0xff : 0 * achtung beim intuitiven lesen des befehles. 'kleiner' * ist mit 'groesser' vertauscht und vice versa */ pcmpgtb %xmm11, %xmm8 /*Y = min(X, 'a' - 'A') * mit "'a'-'A'= 97-65 = 32 = 0x20 */ pminub const20, %xmm8 //retuniere an die richtige speicheradresse mov %rdi, %rax //c += Y psubb const3f, %xmm11 paddb %xmm11, %xmm8 movdqu %xmm8, (%rax) ret .LFE2: .size asma, .-asma .section .eh_frame,"a",@progbits .Lframe1: .long .LECIE1-.LSCIE1 .LSCIE1: .long 0x0 .byte 0x1 .string "zR" .uleb128 0x1 .sleb128 -8 .byte 0x10 .uleb128 0x1 .byte 0x3 .byte 0xc .uleb128 0x7 .uleb128 0x8 .byte 0x90 .uleb128 0x1 .align 8 .LECIE1: .LSFDE1: .long .LEFDE1-.LASFDE1 .LASFDE1: .long .LASFDE1-.Lframe1 .long .LFB2 .long .LFE2-.LFB2 .uleb128 0x0 .align 8 .LEFDE1: .ident "GCC: (Debian 4.3.2-1.1) 4.3.2" .section .note.GNU-stack,"",@progbits