Upx_Doxygen
https://github.com/upx/upx
p_tmt.h
1
/* p_tmt.h --
2
3
This file is part of the UPX executable compressor.
4
5
Copyright (C) 1996-2016 Markus Franz Xaver Johannes Oberhumer
6
Copyright (C) 1996-2016 Laszlo Molnar
7
All Rights Reserved.
8
9
UPX and the UCL library are free software; you can redistribute them
10
and/or modify them under the terms of the GNU General Public License as
11
published by the Free Software Foundation; either version 2 of
12
the License, or (at your option) any later version.
13
14
This program is distributed in the hope that it will be useful,
15
but WITHOUT ANY WARRANTY; without even the implied warranty of
16
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17
GNU General Public License for more details.
18
19
You should have received a copy of the GNU General Public License
20
along with this program; see the file COPYING.
21
If not, write to the Free Software Foundation, Inc.,
22
59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
23
24
Markus F.X.J. Oberhumer Laszlo Molnar
25
<markus@oberhumer.com> <ezerotven+github@gmail.com>
26
*/
27
28
29
#ifndef __UPX_P_TMT_H
30
#define __UPX_P_TMT_H 1
31
32
33
/*************************************************************************
34
// tmt/adam
35
**************************************************************************/
36
37
class
PackTmt
:
public
Packer
38
{
39
typedef
Packer
super
;
40
public
:
41
PackTmt
(
InputFile
*f);
42
virtual
int
getVersion()
const
{
return
13; }
43
virtual
int
getFormat()
const
{
return
UPX_F_TMT_ADAM; }
44
virtual
const
char
*getName()
const
{
return
"tmt/adam"
; }
45
virtual
const
char
*getFullName(
const
options_t
*)
const
{
return
"i386-dos32.tmt.adam"
; }
46
virtual
const
int
*getCompressionMethods(
int
method,
int
level)
const
;
47
virtual
const
int
*getFilters()
const
;
48
49
virtual
void
pack(
OutputFile
*fo);
50
virtual
void
unpack(
OutputFile
*fo);
51
52
virtual
bool
canPack();
53
virtual
int
canUnpack();
54
55
protected
:
56
virtual
int
readFileHeader();
57
58
virtual
unsigned
findOverlapOverhead(
const
upx_bytep buf,
59
const
upx_bytep tbuf,
60
unsigned
range = 0,
61
unsigned
upper_limit = ~0u)
const
;
62
virtual
void
buildLoader(
const
Filter
*ft);
63
virtual
Linker
* newLinker()
const
;
64
65
unsigned
adam_offset;
66
int
big_relocs;
67
68
struct
tmt_header_t
69
{
70
char
_[16];
// signature,linkerversion,minversion,exesize,imagestart
71
LE32 imagesize;
72
char
__[4];
// initial memory
73
LE32 entry;
74
char
___[12];
// esp,numfixups,flags
75
LE32 relocsize;
76
} ih, oh;
77
};
78
79
80
#endif
/* already included */
81
82
/* vim:set ts=4 sw=4 et: */
ElfLinker
Definition:
linker.h:35
options_t
Definition:
options.h:45
PackTmt
Definition:
p_tmt.h:37
InputFile
Definition:
file.h:89
Packer
Definition:
packer.h:115
OutputFile
Definition:
file.h:121
Filter
Definition:
filter.h:53
PackTmt::tmt_header_t
Definition:
p_tmt.h:68
Generated by
1.8.13