Assembly組合 LODS指令


在密碼學中,Caesar 密碼是一個最簡單的已知的加密技術。在該方法中,以被加密的資料中的每個字母被替換下來的字母跟一些固定的位置數。

在這個例子中,讓我們通過簡單地更換每個字母,其具有移位的兩個字母中的資料進行加密,因此,c, b將被d取代

我們使用LODS,載入的原始字串'password'入記憶體。

section .text
   global _start         ;must be declared for using gcc
_start:    ;tell linker entry yiibai
   mov    ecx, len
   mov    esi, s1
   mov    edi, s2
loop_here:
   lodsb
   add al, 02
   stosb
   loop    loop_here          
   cld
   rep     movsb
   mov     edx,20   ;message length
   mov     ecx,s2   ;message to write
   mov     ebx,1    ;file descriptor (stdout)
   mov     eax,4    ;system call number (sys_write)
   int     0x80     ;call kernel
   mov     eax,1    ;system call number (sys_exit)
   int     0x80     ;call kernel
section .data
s1 db 'password', 0 ;source
len equ $-s1
section .bss
s2 resb 10         ;destination

上面的程式碼編譯和執行時,它會產生以下結果:

rcuuyqtf