about summary refs log tree commit diff stats
path: root/subx/ex5.subx
blob: f7411939e8d0641a0f2008fb740acf3e0bcf06cc (plain) (blame)
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
42
43
44
45
46
47
## read a character from stdin, save it to a local on the stack, write it to stdout

== 0x08048054  # code segment, after leaving room for ELF header and segment headers
# opcode        ModR/M                    SIB                   displacement    immediate
# instruction   mod, reg, Reg/Mem bits    scale, index, base
# 1-3 bytes     0/1 byte                  0/1 byte              0/1/2/4 bytes   0/1/2/4 bytes

## function main
  # prolog
  55                                                                                          # push EBP
  89            e5                                                                            # copy ESP to EBP
                # ModR/M: 11 (direct mode) 100 (src ESP) 101 (dest EBP)
  # allocate x on the stack
  81            ec                                                              4/imm32       # subtract 4 bytes from ESP
                # ModR/M: 11 (direct mode) 101 (subtract imm32) 100 (dest EBP)

  ## read(stdin, x, 1)
  # fd = 0 (stdin)
  bb                                                                            0/imm32       # copy 0 to EBX
  # set location to read character to
  89            e9                                                                            # copy EBP to ECX
                # ModR/M: 11 (direct mode) 101 (src EBP) 001 (dest ECX)
  # size = 1 character
  ba                                                                            1/imm32       # copy 1 to EDX
  # syscall = read
  b8                                                                            3/imm32       # copy 3 to EAX
  # call
  cd                                                                            128/imm8      # int 80h

  ## write(stdout, x, 1)
  # fd = 1 (stdout)
  bb                                                                            1/imm32       # copy 1 to EBX
  # set location of character to write out
  89            e9                                                                            # copy EBP to ECX
                # ModR/M: 11 (direct mode) 101 (src EBP) 001 (dest ECX)
  # size = 1 character
  ba                                                                            1/imm32       # copy 1 to EDX
  # syscall = write
  b8                                                                            4/imm32       # copy 4 to EAX
  # call
  cd                                                                            128/imm8      # int 80h

  ## exit(EBX)
  b8                                                                            1/imm32       # copy 1 to EAX
  cd                                                                            128/imm8      # int 80h

# vim:ft=subx:nowrap