Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
go
Commits
e44f42e0
Commit
e44f42e0
authored
Mar 06, 2013
by
Alex Brainman
Committed by
Russ Cox
Mar 06, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
libmach: fix amd64 pe handling
Fixes #4841. R=golang-dev, rsc CC=golang-dev
https://golang.org/cl/7475046
parent
77deeda7
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
48 additions
and
7 deletions
+48
-7
src/libmach/executable.c
src/libmach/executable.c
+48
-7
No files found.
src/libmach/executable.c
View file @
e44f42e0
...
@@ -1335,13 +1335,45 @@ typedef struct {
...
@@ -1335,13 +1335,45 @@ typedef struct {
IMAGE_DATA_DIRECTORY
DataDirectory
[
16
];
IMAGE_DATA_DIRECTORY
DataDirectory
[
16
];
}
IMAGE_OPTIONAL_HEADER
;
}
IMAGE_OPTIONAL_HEADER
;
typedef
struct
{
uint16
Magic
;
uint8
MajorLinkerVersion
;
uint8
MinorLinkerVersion
;
uint32
SizeOfCode
;
uint32
SizeOfInitializedData
;
uint32
SizeOfUninitializedData
;
uint32
AddressOfEntryPoint
;
uint32
BaseOfCode
;
uint64
ImageBase
;
uint32
SectionAlignment
;
uint32
FileAlignment
;
uint16
MajorOperatingSystemVersion
;
uint16
MinorOperatingSystemVersion
;
uint16
MajorImageVersion
;
uint16
MinorImageVersion
;
uint16
MajorSubsystemVersion
;
uint16
MinorSubsystemVersion
;
uint32
Win32VersionValue
;
uint32
SizeOfImage
;
uint32
SizeOfHeaders
;
uint32
CheckSum
;
uint16
Subsystem
;
uint16
DllCharacteristics
;
uint64
SizeOfStackReserve
;
uint64
SizeOfStackCommit
;
uint64
SizeOfHeapReserve
;
uint64
SizeOfHeapCommit
;
uint32
LoaderFlags
;
uint32
NumberOfRvaAndSizes
;
IMAGE_DATA_DIRECTORY
DataDirectory
[
16
];
}
PE64_IMAGE_OPTIONAL_HEADER
;
static
int
static
int
match8
(
void
*
buf
,
char
*
cmp
)
match8
(
void
*
buf
,
char
*
cmp
)
{
{
return
strncmp
((
char
*
)
buf
,
cmp
,
8
)
==
0
;
return
strncmp
((
char
*
)
buf
,
cmp
,
8
)
==
0
;
}
}
/* TODO(czaplinski): 64b windows? */
/*
/*
* Read from Windows PE/COFF .exe file image.
* Read from Windows PE/COFF .exe file image.
*/
*/
...
@@ -1353,9 +1385,10 @@ pedotout(int fd, Fhdr *fp, ExecHdr *hp)
...
@@ -1353,9 +1385,10 @@ pedotout(int fd, Fhdr *fp, ExecHdr *hp)
IMAGE_FILE_HEADER
fh
;
IMAGE_FILE_HEADER
fh
;
IMAGE_SECTION_HEADER
sh
;
IMAGE_SECTION_HEADER
sh
;
IMAGE_OPTIONAL_HEADER
oh
;
IMAGE_OPTIONAL_HEADER
oh
;
PE64_IMAGE_OPTIONAL_HEADER
oh64
;
uint8
sym
[
18
];
uint8
sym
[
18
];
uint32
*
valp
,
ib
;
uint32
*
valp
,
ib
,
entry
;
int
i
;
int
i
,
ohoffset
;
USED
(
hp
);
USED
(
hp
);
seek
(
fd
,
0x3c
,
0
);
seek
(
fd
,
0x3c
,
0
);
...
@@ -1384,6 +1417,7 @@ pedotout(int fd, Fhdr *fp, ExecHdr *hp)
...
@@ -1384,6 +1417,7 @@ pedotout(int fd, Fhdr *fp, ExecHdr *hp)
return
0
;
return
0
;
}
}
ohoffset
=
seek
(
fd
,
0
,
1
);
if
(
readn
(
fd
,
&
oh
,
sizeof
(
oh
))
!=
sizeof
(
oh
))
{
if
(
readn
(
fd
,
&
oh
,
sizeof
(
oh
))
!=
sizeof
(
oh
))
{
werrstr
(
"crippled PE Optional Header"
);
werrstr
(
"crippled PE Optional Header"
);
return
0
;
return
0
;
...
@@ -1392,17 +1426,24 @@ pedotout(int fd, Fhdr *fp, ExecHdr *hp)
...
@@ -1392,17 +1426,24 @@ pedotout(int fd, Fhdr *fp, ExecHdr *hp)
switch
(
oh
.
Magic
)
{
switch
(
oh
.
Magic
)
{
case
0x10b
:
// PE32
case
0x10b
:
// PE32
fp
->
type
=
FI386
;
fp
->
type
=
FI386
;
ib
=
leswal
(
oh
.
ImageBase
);
entry
=
leswal
(
oh
.
AddressOfEntryPoint
);
break
;
break
;
case
0x20b
:
// PE32+
case
0x20b
:
// PE32+
fp
->
type
=
FAMD64
;
fp
->
type
=
FAMD64
;
seek
(
fd
,
ohoffset
,
0
);
if
(
readn
(
fd
,
&
oh64
,
sizeof
(
oh64
))
!=
sizeof
(
oh64
))
{
werrstr
(
"crippled PE32+ Optional Header"
);
return
0
;
}
ib
=
leswal
(
oh64
.
ImageBase
);
entry
=
leswal
(
oh64
.
AddressOfEntryPoint
);
break
;
break
;
default:
default:
werrstr
(
"invalid PE Optional magic number"
);
werrstr
(
"invalid PE Optional
Header
magic number"
);
return
0
;
return
0
;
}
}
ib
=
leswal
(
oh
.
ImageBase
);
seek
(
fd
,
start
+
sizeof
(
magic
)
+
sizeof
(
fh
)
+
leswab
(
fh
.
SizeOfOptionalHeader
),
0
);
fp
->
txtaddr
=
0
;
fp
->
txtaddr
=
0
;
fp
->
dataddr
=
0
;
fp
->
dataddr
=
0
;
for
(
i
=
0
;
i
<
leswab
(
fh
.
NumberOfSections
);
i
++
)
{
for
(
i
=
0
;
i
<
leswab
(
fh
.
NumberOfSections
);
i
++
)
{
...
@@ -1411,7 +1452,7 @@ pedotout(int fd, Fhdr *fp, ExecHdr *hp)
...
@@ -1411,7 +1452,7 @@ pedotout(int fd, Fhdr *fp, ExecHdr *hp)
return
0
;
return
0
;
}
}
if
(
match8
(
sh
.
Name
,
".text"
))
if
(
match8
(
sh
.
Name
,
".text"
))
settext
(
fp
,
ib
+
leswal
(
oh
.
AddressOfEntryPoint
)
,
ib
+
leswal
(
sh
.
VirtualAddress
),
leswal
(
sh
.
VirtualSize
),
leswal
(
sh
.
PointerToRawData
));
settext
(
fp
,
ib
+
entry
,
ib
+
leswal
(
sh
.
VirtualAddress
),
leswal
(
sh
.
VirtualSize
),
leswal
(
sh
.
PointerToRawData
));
if
(
match8
(
sh
.
Name
,
".data"
))
if
(
match8
(
sh
.
Name
,
".data"
))
setdata
(
fp
,
ib
+
leswal
(
sh
.
VirtualAddress
),
leswal
(
sh
.
SizeOfRawData
),
leswal
(
sh
.
PointerToRawData
),
leswal
(
sh
.
VirtualSize
)
-
leswal
(
sh
.
SizeOfRawData
));
setdata
(
fp
,
ib
+
leswal
(
sh
.
VirtualAddress
),
leswal
(
sh
.
SizeOfRawData
),
leswal
(
sh
.
PointerToRawData
),
leswal
(
sh
.
VirtualSize
)
-
leswal
(
sh
.
SizeOfRawData
));
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment