x86 16 비트 이진
이 ( 1 2 ) 테이블, nasm 및 ndisasm 의 도움으로 수동으로 구성됩니다 . 이것은 바이트가 점프하거나 스택을 변경하지 않으며 ret
어떤 경우에도 단일 바이트 명령 으로 끝나기 위해 NOP로 채워지기 때문에 충돌이나 무한 루프없이 항상 반환됩니다 .
대부분의 경우 이것은 출력 FOO
이거나 그 하위 문자열입니다. AX
깨진 경우 임의의 int 10 (내 테스트 중 하나에서 커서 깜박임 속도가 변경됨) 을 호출 하지만 일반적으로 충돌이 발생하지 않습니다.
시도해 보려면 hexdump를 파일에 넣고을 사용한 xxd -r foo.hex > foo.com
다음 dos 환경에서 실행하십시오 (dosbox를 사용했습니다).
이 파일의 16 진 덤프는 다음과 같습니다.
0000000: b846 0d90 90fe c490 9090 bb05 0090 9043 .F.............C
0000010: 43cd 1090 b84f 0d90 90fe c490 9090 bb05 C....O..........
0000020: 0090 9043 43cd 1090 b84f 0d90 90fe c490 ...CC....O......
0000030: 9090 bb05 0090 9043 43cd 1090 9090 c3 .......CC......
그리고 몇 가지 흥미로운 분해 오프셋 :
+0
00000000 B8420D mov ax,0xd42
00000003 90 nop
00000004 90 nop
00000005 FEC4 inc ah
00000007 90 nop
00000008 90 nop
00000009 90 nop
0000000A BB0500 mov bx,0x5
0000000D 90 nop
0000000E 90 nop
0000000F 43 inc bx
00000010 43 inc bx
00000011 CD10 int 0x10
00000013 90 nop
00000014 B84F0D mov ax,0xd4f
00000017 90 nop
00000018 90 nop
00000019 FEC4 inc ah
0000001B 90 nop
0000001C 90 nop
0000001D 90 nop
0000001E BB0500 mov bx,0x5
00000021 90 nop
00000022 90 nop
00000023 43 inc bx
00000024 43 inc bx
00000025 CD10 int 0x10
00000027 90 nop
00000028 B84F0D mov ax,0xd4f
0000002B 90 nop
0000002C 90 nop
0000002D FEC4 inc ah
0000002F 90 nop
00000030 90 nop
00000031 90 nop
00000032 BB0500 mov bx,0x5
00000035 90 nop
00000036 90 nop
00000037 43 inc bx
00000038 43 inc bx
00000039 CD10 int 0x10
0000003B 90 nop
0000003C 90 nop
0000003D 90 nop
0000003E C3 ret
(아래 예의 나머지 바이너리는 여전히 유효합니다)
+1
00000000 42 inc dx
00000001 0D9090 or ax,0x9090
00000004 FEC4 inc ah
00000006 90 nop
+2
00000001 0D9090 or ax,0x9090
00000004 FEC4 inc ah
00000006 90 nop
+6
00000000 C4909090 les dx,[bx+si-0x6f70]
00000004 BB0500 mov bx,0x5
00000007 90 nop
00000008 90 nop
00000009 43 inc bx
0000000A 43 inc bx
0000000B CD10 int 0x10
+11
00000000 050090 add ax,0x9000
00000003 90 nop
00000004 43 inc bx
00000005 43 inc bx
00000006 CD10 int 0x10
+12
00000000 00909043 add [bx+si+0x4390],dl
00000004 43 inc bx
00000005 CD10 int 0x10
+18
00000000 1090B84F adc [bx+si+0x4fb8],dl
00000004 0D9090 or ax,0x9090
00000007 FEC4 inc ah
00000009 90 nop
(다른 오프셋은 단지 위의 반복입니다)
+58
00000000 10909090 adc [bx+si-0x6f70],dl
00000004 C3 ret