-
Notifications
You must be signed in to change notification settings - Fork 20
/
0x0a.asm
41 lines (37 loc) · 1.29 KB
/
0x0a.asm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
;
; $Id: 0x0a.asm,v 1.1.1.1 2016/03/27 08:40:12 raptor Exp $
;
; 0x0a explanation - from xchg rax,rax by xorpd@xorpd.net
; Copyright (c) 2016 Marco Ivaldi <raptor@0xdeadbeef.info>
;
; This snippet increments the least-significant byte at the
; memory location pointed by rdi. Then, in a loop, it keeps
; incrementing the memory pointer in rdi and increments again
; the least-significant byte at the memory location pointed
; by rdi, but only if the carry flag (cf) is set.
;
; In other words, this snippet increments by one a rcx byte
; long integer stored at the address pointed by rdi.
;
; It is interesting to note that the inc instruction allows
; a loop counter to be updated without disturbing the cf
; flag. Conversely, an add instruction with an immediate
; operand of 1 does update the cf flag.
;
BITS 64
;SECTION .data ; added for the analysis
;string db "ABCD" ; added for the analysis
SECTION .text
global main
main:
;mov rdi,string ; added for the analysis
add byte [rdi],1 ; increment the least-significant byte
; at the memory location pointed by rdi
.loop:
inc rdi ; increment the memory pointer in rdi
; while preserving the status of the cf
; flag
adc byte [rdi],0 ; increment the least-significant byte
; at the memory location pointed by rdi
; if cf = 1
loop .loop