pe: win32/win64 pack/unpack seems to work again

This commit is contained in:
László Molnár
2014-03-05 23:40:24 +01:00
parent 129cb0b3cd
commit ca2369f1c1
4 changed files with 13 additions and 19 deletions
+7 -10
View File
@@ -107,11 +107,7 @@ static void xcheck(size_t poff, size_t plen, const void *b, size_t blen)
**************************************************************************/
PackW32Pe::PackW32Pe(InputFile *f) : super(f)
{
isrtm = false;
use_dep_hack = true;
use_clear_dirty_stack = true;
}
{}
PackW32Pe::~PackW32Pe()
@@ -297,17 +293,18 @@ void PackW32Pe::defineSymbols(unsigned ncsection, unsigned upxsection,
linker->defineSymbol("vp_size", ((addr & 0xfff) + 0x28 >= 0x1000) ?
0x2000 : 0x1000); // 2 pages or 1 page
linker->defineSymbol("vp_base", addr &~ 0xfff); // page mask
linker->defineSymbol("VirtualProtect", myimport +
linker->defineSymbol("VirtualProtect", -rvamin +
ilinkerGetAddress("kernel32.dll", "VirtualProtect"));
}
linker->defineSymbol("reloc_delt", 0u - (unsigned) ih.imagebase - rvamin);
linker->defineSymbol("start_of_relocs", crelocs);
linker->defineSymbol("ExitProcess", myimport +
ilinkerGetAddress("kernel32.dll", "ExitProcess"));
linker->defineSymbol("GetProcAddress", myimport +
if (!isdll)
linker->defineSymbol("ExitProcess", -rvamin +
ilinkerGetAddress("kernel32.dll", "ExitProcess"));
linker->defineSymbol("GetProcAddress", -rvamin +
ilinkerGetAddress("kernel32.dll", "GetProcAddress"));
linker->defineSymbol("kernel32_ordinals", myimport);
linker->defineSymbol("LoadLibraryA", myimport +
linker->defineSymbol("LoadLibraryA", -rvamin +
ilinkerGetAddress("kernel32.dll", "LoadLibraryA"));
linker->defineSymbol("start_of_imports", myimport);
linker->defineSymbol("compressed_imports", cimports);
+1 -5
View File
@@ -112,11 +112,7 @@ static void xcheck(size_t poff, size_t plen, const void *b, size_t blen)
**************************************************************************/
PackW64Pep::PackW64Pep(InputFile *f) : super(f)
{
isrtm = false;
use_dep_hack = true;
use_clear_dirty_stack = true;
}
{}
PackW64Pep::~PackW64Pep()
-4
View File
@@ -59,10 +59,6 @@ public:
protected:
virtual void buildLoader(const Filter *ft);
virtual Linker* newLinker() const;
bool isrtm;
bool use_dep_hack;
bool use_clear_dirty_stack;
};
+5
View File
@@ -139,6 +139,10 @@ PeFile::PeFile(InputFile *f) : super(f)
use_tls_callbacks = false;
oloadconf = NULL;
soloadconf = 0;
use_dep_hack = true;
use_clear_dirty_stack = true;
isrtm = false;
}
@@ -763,6 +767,7 @@ public:
for (unsigned ic = 0; ic < nsections; ic++)
osize += sections[ic]->size;
output = new upx_byte[osize];
outputlen = 0;
// sort the sections by name before adding them all
qsort(sections, nsections, sizeof (Section*), ImportLinker::compare);