x86 instruction reordering for code compression
Runtime executable code compression is a method which uses standard data compression methods and binary machine code transformations to achieve smaller file size, yet maintaining the ability to execute the compressed file as a regular executable. With a disassembler, an almost perfect instructional...
Elmentve itt :
Szerző: | |
---|---|
Dokumentumtípus: | Cikk |
Megjelent: |
2013
|
Sorozat: | Acta cybernetica
21 No. 1 |
Kulcsszavak: | Számítástechnika, Kibernetika, Matematika |
Tárgyszavak: | |
doi: | 10.14232/actacyb.21.1.2013.13 |
Online Access: | http://acta.bibl.u-szeged.hu/30857 |
Tartalmi kivonat: | Runtime executable code compression is a method which uses standard data compression methods and binary machine code transformations to achieve smaller file size, yet maintaining the ability to execute the compressed file as a regular executable. With a disassembler, an almost perfect instructional and functional level disassembly can be generated. Using the structural information of the compiled machine code each function can be split into so called basic blocks. In this work we show that reordering instructions within basic blocks using data flow constraints can improve code compression without changing the behavior of the code. We use two kinds of data affection (read, write) and 20 data types including registers: 8 basic x86 registers, 11 eflags, and memory data. Due to the complexity of the reordering, some simplification is required. Our solution is to search local optimum of the compression on the function level and then combine the results to get a suboptimal global result. Using the reordering method better results can be achieved, namely the compression size gain for gzip can be as high as 1.24%, for lzma 0.68% on the tested executables. |
---|---|
Terjedelem/Fizikai jellemzők: | 177-190 |
ISSN: | 0324-721X |