1
0
mirror of https://github.com/upx/upx synced 2025-09-28 19:06:07 +08:00

Save some more bytes in dos/exe lzma stub.

This commit is contained in:
Markus F.X.J. Oberhumer 2007-09-14 15:47:18 +02:00
parent 49455c99ad
commit 4d3b627839
6 changed files with 1970 additions and 1916 deletions

View File

@ -279,7 +279,6 @@ void Packer::defineDecompressorSymbols()
if (ph.format == UPX_F_DOS_EXE)
{
linker->defineSymbol("lzma_properties_hi", properties >> 16); // pb
// len - 2 because of properties
linker->defineSymbol("lzma_c_len_hi", (ph.c_len - 2) >> 16);
linker->defineSymbol("lzma_u_len_hi", ph.u_len >> 16);
linker->defineSymbol("lzma_u_len_segment", (ph.u_len & 0xf0000) >> 4);

File diff suppressed because it is too large Load Diff

View File

@ -38,6 +38,7 @@ class opts:
auto_inline = 1
call_rewrite = 1
loop_rewrite = 1
mov_rewrite = 1
inline_map = {
@ -119,7 +120,7 @@ def main(argv):
def match(a, b):
if b is None:
return False
if "^" in a or "*" in a:
if "^" in a or "*" in a or "$" in a:
# regexp
return re.search(a, b.lower())
else:
@ -355,6 +356,61 @@ def main(argv):
m = "M_shrd_11_disi_bp %s %s" % (bp_dx, bp_ax)
orewrite_inst(i, m, "", dpos1 + dpos2[-2:])
continue
if opts.mov_rewrite and inst in ["mov"]:
s = [
["mov", r"^al,byte ptr \[(di|si)\]$"],
["xor", r"^ah,ah$"],
["mov", r"^word ptr \[bp([+-](\d+))\],ax$"],
["mov", r"^word ptr \[bp([+-](\d+))\],(0|1)$"],
["mov", r"^word ptr \[bp([+-](\d+))\],(0|1)$"],
["mov", r"^word ptr \[bp([+-](\d+))\],(0|1)$"],
["mov", r"^word ptr \[bp([+-](\d+))\],(0|1)$"],
["mov", r"^word ptr \[bp([+-](\d+))\],(0|1)$"],
["mov", r"^word ptr \[bp([+-](\d+))\],(0|1)$"],
["mov", r"^word ptr \[bp([+-](\d+))\],(0|1)$"],
["mov", r"^word ptr \[bp([+-](\d+))\],(0|1)$"],
["mov", r"^word ptr \[bp([+-](\d+))\],(0|1)$"],
["mov", r"^bx,word ptr \[bp([+-](\d+))\]$"],
["mov", r"^word ptr \[bx\],(0)$"],
["mov", r"^word ptr \[bx([+-](\d+))\],(0)$"],
["mov", r"^bx,word ptr \[bp([+-](\d+))\]$"],
["mov", r"^word ptr \[bx\],(0)$"],
["mov", r"^word ptr \[bx([+-](\d+))\],(0)$"],
["mov", r"^dl,byte ptr \[(di|si)([+-](\d+))\]$"],
["xor", r"^dh,dh$"],
["mov", r"^cx,ax$"],
]
dpos = omatch(i, -len(s), s)
if dpos:
ipos, n_del = 16, 0
pos0 = dpos[0][0]
r = []
for pos, m0, m1 in dpos:
assert pos == pos0 + len(r)
r.append([olines[pos][1], olines[pos][2]])
z0 = r[0]; z1 = r[2]; del r[:3]
r.insert(0, ["xor", "ax,ax"])
r.insert(ipos, z0); r.insert(ipos + 1, z1)
i = 0
while i < len(r):
inst, args = r[i]
if inst == "mov" and args.endswith(",0"):
r[i] = [inst, args[:-1] + "ax"]
elif inst == "mov" and args.endswith(",1"):
assert i < ipos
r.insert(ipos, [inst, args[:-1] + "ax"])
del r[i]; i -= 1; n_del += 1
i += 1
assert len(r) == len(dpos)
pos = pos0
for inst, args in r:
print pos-pos0, inst, args
olines[pos][1] = inst
olines[pos][2] = args
pos += 1
if n_del:
olines.insert(pos0 + ipos - n_del, [None, "inc", "ax", None])
continue
#
if inst_has_label(inst):
k, v = parse_label(inst, args)

View File

@ -22,24 +22,25 @@
cwd
mov word ptr [bp-86],ax
mov word ptr [bp-84],dx
mov al,byte ptr [si]
xor ah,ah
mov word ptr [bp-78],ax
mov word ptr [bp-16],0
mov word ptr [bp-102],1
mov word ptr [bp-100],0
mov word ptr [bp-52],1
mov word ptr [bp-50],0
mov word ptr [bp-56],1
mov word ptr [bp-54],0
mov word ptr [bp-68],1
mov word ptr [bp-74],0
xor ax,ax
mov word ptr [bp-16],ax
mov word ptr [bp-100],ax
mov word ptr [bp-50],ax
mov word ptr [bp-54],ax
mov word ptr [bp-74],ax
mov bx,word ptr [bp+18]
mov word ptr [bx],0
mov word ptr [bx+2],0
mov word ptr [bx],ax
mov word ptr [bx+2],ax
mov bx,word ptr [bp+28]
mov word ptr [bx],0
mov word ptr [bx+2],0
mov word ptr [bx],ax
mov word ptr [bx+2],ax
inc ax
mov word ptr [bp-102],ax
mov word ptr [bp-52],ax
mov word ptr [bp-56],ax
mov word ptr [bp-68],ax
mov al,byte ptr [si]
mov word ptr [bp-78],ax
mov dl,byte ptr [si+1]
xor dh,dh
mov cx,ax

View File

@ -22,24 +22,25 @@
cwd
mov word ptr [bp-86],ax
mov word ptr [bp-84],dx
mov al,byte ptr [si]
xor ah,ah
mov word ptr [bp-78],ax
mov word ptr [bp-16],0
mov word ptr [bp-102],1
mov word ptr [bp-100],0
mov word ptr [bp-52],1
mov word ptr [bp-50],0
mov word ptr [bp-56],1
mov word ptr [bp-54],0
mov word ptr [bp-68],1
mov word ptr [bp-74],0
xor ax,ax
mov word ptr [bp-16],ax
mov word ptr [bp-100],ax
mov word ptr [bp-50],ax
mov word ptr [bp-54],ax
mov word ptr [bp-74],ax
mov bx,word ptr [bp+18]
mov word ptr [bx],0
mov word ptr [bx+2],0
mov word ptr [bx],ax
mov word ptr [bx+2],ax
mov bx,word ptr [bp+28]
mov word ptr [bx],0
mov word ptr [bx+2],0
mov word ptr [bx],ax
mov word ptr [bx+2],ax
inc ax
mov word ptr [bp-102],ax
mov word ptr [bp-52],ax
mov word ptr [bp-56],ax
mov word ptr [bp-68],ax
mov al,byte ptr [si]
mov word ptr [bp-78],ax
mov dl,byte ptr [si+1]
xor dh,dh
mov cx,ax

View File

@ -73,27 +73,27 @@ Idx Name Size VMA LMA File off Algn Flags
68 NRV2EEX9 00000004 00000000 00000000 00000336 2**0 CONTENTS, READONLY
69 LZMA_DEC00 00000032 00000000 00000000 0000033a 2**0 CONTENTS, RELOC, READONLY
70 ignore_reloc_overflow 00000008 00000000 00000000 0000036c 2**0 CONTENTS, RELOC, READONLY
71 LZMA_DEC10 00001207 00000000 00000000 00000374 2**0 CONTENTS, READONLY
72 LZMA_DEC20 0000129f 00000000 00000000 0000157b 2**0 CONTENTS, READONLY
73 LZMA_DEC30 00000001 00000000 00000000 0000281a 2**0 CONTENTS, READONLY
74 LZMA_DEC31 0000000c 00000000 00000000 0000281b 2**0 CONTENTS, RELOC, READONLY
75 LZMA_DEC32 00000005 00000000 00000000 00002827 2**0 CONTENTS, RELOC, READONLY
76 LZMA_DEC33 00000007 00000000 00000000 0000282c 2**0 CONTENTS, RELOC, READONLY
77 EXEMAIN5 00000001 00000000 00000000 00002833 2**0 CONTENTS, READONLY
78 EXEADJUS 00000007 00000000 00000000 00002834 2**0 CONTENTS, READONLY
79 EXENOADJ 00000002 00000000 00000000 0000283b 2**0 CONTENTS, READONLY
80 EXERELO1 0000001e 00000000 00000000 0000283d 2**0 CONTENTS, RELOC, READONLY
81 EXEREL9A 00000012 00000000 00000000 0000285b 2**0 CONTENTS, RELOC, READONLY
82 EXERELO2 00000004 00000000 00000000 0000286d 2**0 CONTENTS, READONLY
83 EXEREBIG 00000002 00000000 00000000 00002871 2**0 CONTENTS, RELOC, READONLY
84 EXERELO3 00000002 00000000 00000000 00002873 2**0 CONTENTS, RELOC, READONLY
85 EXEMAIN8 00000003 00000000 00000000 00002875 2**0 CONTENTS, READONLY
86 DEVICEEND 00000013 00000000 00000000 00002878 2**0 CONTENTS, READONLY
87 EXESTACK 00000006 00000000 00000000 0000288b 2**0 CONTENTS, RELOC, READONLY
88 EXESTASP 00000003 00000000 00000000 00002891 2**0 CONTENTS, RELOC, READONLY
89 EXEJUMPF 00000005 00000000 00000000 00002894 2**0 CONTENTS, RELOC, READONLY
90 EXERCSPO 00000004 00000000 00000000 00002899 2**0 CONTENTS, RELOC, READONLY
91 EXERETIP 00000006 00000000 00000000 0000289d 2**0 CONTENTS, RELOC, READONLY
71 LZMA_DEC10 000011ee 00000000 00000000 00000374 2**0 CONTENTS, READONLY
72 LZMA_DEC20 00001286 00000000 00000000 00001562 2**0 CONTENTS, READONLY
73 LZMA_DEC30 00000001 00000000 00000000 000027e8 2**0 CONTENTS, READONLY
74 LZMA_DEC31 0000000c 00000000 00000000 000027e9 2**0 CONTENTS, RELOC, READONLY
75 LZMA_DEC32 00000005 00000000 00000000 000027f5 2**0 CONTENTS, RELOC, READONLY
76 LZMA_DEC33 00000007 00000000 00000000 000027fa 2**0 CONTENTS, RELOC, READONLY
77 EXEMAIN5 00000001 00000000 00000000 00002801 2**0 CONTENTS, READONLY
78 EXEADJUS 00000007 00000000 00000000 00002802 2**0 CONTENTS, READONLY
79 EXENOADJ 00000002 00000000 00000000 00002809 2**0 CONTENTS, READONLY
80 EXERELO1 0000001e 00000000 00000000 0000280b 2**0 CONTENTS, RELOC, READONLY
81 EXEREL9A 00000012 00000000 00000000 00002829 2**0 CONTENTS, RELOC, READONLY
82 EXERELO2 00000004 00000000 00000000 0000283b 2**0 CONTENTS, READONLY
83 EXEREBIG 00000002 00000000 00000000 0000283f 2**0 CONTENTS, RELOC, READONLY
84 EXERELO3 00000002 00000000 00000000 00002841 2**0 CONTENTS, RELOC, READONLY
85 EXEMAIN8 00000003 00000000 00000000 00002843 2**0 CONTENTS, READONLY
86 DEVICEEND 00000013 00000000 00000000 00002846 2**0 CONTENTS, READONLY
87 EXESTACK 00000006 00000000 00000000 00002859 2**0 CONTENTS, RELOC, READONLY
88 EXESTASP 00000003 00000000 00000000 0000285f 2**0 CONTENTS, RELOC, READONLY
89 EXEJUMPF 00000005 00000000 00000000 00002862 2**0 CONTENTS, RELOC, READONLY
90 EXERCSPO 00000004 00000000 00000000 00002867 2**0 CONTENTS, RELOC, READONLY
91 EXERETIP 00000006 00000000 00000000 0000286b 2**0 CONTENTS, RELOC, READONLY
SYMBOL TABLE:
00000000 l d DEVICEENTRY 00000000 DEVICEENTRY
00000000 l d COMPRESSED_LZMA_START 00000000 COMPRESSED_LZMA_START