https://git.reactos.org/?p=reactos.git;a=commitdiff;h=ffa94ca0f079e19cae8f6…
commit ffa94ca0f079e19cae8f6f257d77a44f31d3be3e
Author: Thomas Faber <thomas.faber(a)reactos.org>
AuthorDate: Thu Apr 19 21:55:35 2018 +0200
Commit: Mark Jansen <mark.jansen(a)reactos.org>
CommitDate: Sun Jun 3 20:40:51 2018 +0200
[NTDLL_APITEST] Add tests for mapping and relocating an image with
IMAGE_SCN_CNT_UNINITIALIZED_DATA
CORE-12582
CORE-14556
---
.../rostests/apitests/ntdll/NtMapViewOfSection.c | 100 ++++++++++++++++-----
1 file changed, 77 insertions(+), 23 deletions(-)
diff --git a/modules/rostests/apitests/ntdll/NtMapViewOfSection.c
b/modules/rostests/apitests/ntdll/NtMapViewOfSection.c
index 000c4a2738..081ddc7b7d 100644
--- a/modules/rostests/apitests/ntdll/NtMapViewOfSection.c
+++ b/modules/rostests/apitests/ntdll/NtMapViewOfSection.c
@@ -1173,10 +1173,12 @@ static struct _MY_IMAGE_FILE
IMAGE_SECTION_HEADER text_header;
IMAGE_SECTION_HEADER rossym_header;
IMAGE_SECTION_HEADER rsrc_header;
- BYTE pad[16];
+ IMAGE_SECTION_HEADER clc_header;
+ BYTE pad[488];
BYTE text_data[0x400];
BYTE rossym_data[0x400];
BYTE rsrc_data[0x400];
+ BYTE clc_data[0x1000];
} ImageFile =
{
/* IMAGE_DOS_HEADER */
@@ -1197,7 +1199,7 @@ static struct _MY_IMAGE_FILE
/* IMAGE_FILE_HEADER */
{
IMAGE_FILE_MACHINE_I386, /* Machine */
- 3, /* NumberOfSections */
+ 4, /* NumberOfSections */
0x47EFDF09, /* TimeDateStamp */
0, /* PointerToSymbolTable */
0, /* NumberOfSymbols */
@@ -1227,8 +1229,8 @@ static struct _MY_IMAGE_FILE
4, /* MajorSubsystemVersion */
0, /* MinorSubsystemVersion */
0, /* Win32VersionValue */
- 0x8000, /* SizeOfImage */
- 0x200, /* SizeOfHeaders */
+ 0xa000, /* SizeOfImage */
+ 0x400, /* SizeOfHeaders */
0x0, /* CheckSum */
IMAGE_SUBSYSTEM_WINDOWS_CUI, /* Subsystem */
IMAGE_DLLCHARACTERISTICS_DYNAMIC_BASE |
@@ -1267,13 +1269,13 @@ static struct _MY_IMAGE_FILE
{ 0x394 }, /* Misc.VirtualSize */
0x2000, /* VirtualAddress */
0x400, /* SizeOfRawData */
- 0x200, /* PointerToRawData */
+ 0x400, /* PointerToRawData */
0, /* PointerToRelocations */
0, /* PointerToLinenumbers */
0, /* NumberOfRelocations */
0, /* NumberOfLinenumbers */
IMAGE_SCN_MEM_READ | IMAGE_SCN_MEM_EXECUTE |
- IMAGE_SCN_CNT_CODE, /* Characteristics */
+ IMAGE_SCN_CNT_CODE, /* Characteristics */
},
/* IMAGE_SECTION_HEADER */
{
@@ -1281,11 +1283,12 @@ static struct _MY_IMAGE_FILE
{ 0x100 }, /* Misc.VirtualSize */
0x4000, /* VirtualAddress */
0x400, /* SizeOfRawData */
- 0x600, /* PointerToRawData */
+ 0x800, /* PointerToRawData */
0, /* PointerToRelocations */
0, /* PointerToLinenumbers */
0, /* NumberOfRelocations */
0, /* NumberOfLinenumbers */
+ /* CORE-8384 */
IMAGE_SCN_MEM_READ | IMAGE_SCN_TYPE_NOLOAD, /* Characteristics */
},
/* IMAGE_SECTION_HEADER */
@@ -1294,37 +1297,75 @@ static struct _MY_IMAGE_FILE
{ 0x100 }, /* Misc.VirtualSize */
0x6000, /* VirtualAddress */
0x400, /* SizeOfRawData */
- 0xA00, /* PointerToRawData */
+ 0xC00, /* PointerToRawData */
0, /* PointerToRelocations */
0, /* PointerToLinenumbers */
0, /* NumberOfRelocations */
0, /* NumberOfLinenumbers */
- IMAGE_SCN_CNT_INITIALIZED_DATA | IMAGE_SCN_MEM_READ, /* Characteristics */
+ IMAGE_SCN_MEM_READ |
+ IMAGE_SCN_CNT_INITIALIZED_DATA, /* Characteristics */
+ },
+ /* IMAGE_SECTION_HEADER */
+ {
+ ".clc", /* Name */
+ { 0x2000 }, /* Misc.VirtualSize */
+ 0x8000, /* VirtualAddress */
+ 0x1000, /* SizeOfRawData */
+ 0x1000, /* PointerToRawData */
+ 0, /* PointerToRelocations */
+ 0, /* PointerToLinenumbers */
+ 0, /* NumberOfRelocations */
+ 0, /* NumberOfLinenumbers */
+ /* CORE-12582 */
+ IMAGE_SCN_MEM_WRITE | IMAGE_SCN_MEM_READ | IMAGE_SCN_MEM_EXECUTE |
+ IMAGE_SCN_CNT_UNINITIALIZED_DATA | IMAGE_SCN_CNT_INITIALIZED_DATA |
IMAGE_SCN_CNT_CODE, /* Characteristics */
},
/* fill */
{ 0 },
/* text */
{ 0xc3, 0 },
/* rossym */
- { 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef,
- BYTES8(0xaa),
- BYTES16(0xbb),
- BYTES32(0xcc),
- BYTES64(0xdd),
- BYTES64(0xee),
- BYTES64(0xff),
+ {
+ 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef,
+ BYTES8(0xaa),
+ BYTES16(0xbb),
+ BYTES32(0xcc),
+ BYTES64(0xdd),
+ BYTES64(0xee),
+ BYTES64(0xff),
},
/* rsrc */
- { 0 },
+ {
+ BYTES128(0xee),
+ BYTES128(0x55),
+ BYTES128(0xee),
+ BYTES128(0x11),
+ BYTES128(0xff),
+ BYTES128(0x00),
+ BYTES128(0x00),
+ BYTES128(0xdd),
+ },
+ /* clc */
+ {
+ BYTES512(0x11),
+ BYTES512(0x22),
+ BYTES512(0x33),
+ BYTES512(0x44),
+ BYTES512(0x55),
+ BYTES512(0x66),
+ BYTES512(0x77),
+ BYTES512(0x88),
+ },
};
-C_ASSERT(FIELD_OFFSET(struct _MY_IMAGE_FILE, text_data) == 0x200);
-C_ASSERT(FIELD_OFFSET(struct _MY_IMAGE_FILE, rossym_data) == 0x600);
-C_ASSERT(FIELD_OFFSET(struct _MY_IMAGE_FILE, rsrc_data) == 0xa00);
+C_ASSERT(FIELD_OFFSET(struct _MY_IMAGE_FILE, text_data) == 0x400);
+C_ASSERT(FIELD_OFFSET(struct _MY_IMAGE_FILE, rossym_data) == 0x800);
+C_ASSERT(FIELD_OFFSET(struct _MY_IMAGE_FILE, rsrc_data) == 0xc00);
+C_ASSERT(FIELD_OFFSET(struct _MY_IMAGE_FILE, clc_data) == 0x1000);
static
void
-Test_NoLoadSection(BOOL Relocate)
+Test_SectionContents(BOOL Relocate)
{
NTSTATUS Status;
WCHAR TempPath[MAX_PATH];
@@ -1405,8 +1446,12 @@ Test_NoLoadSection(BOOL Relocate)
{
PUCHAR Bytes = BaseAddress;
#define TEST_BYTE(n, v) StartSeh() ok_hex(Bytes[n], v); EndSeh(STATUS_SUCCESS);
+#define TEST_WRITE(n) StartSeh() *(volatile UCHAR *)&Bytes[n] = Bytes[n];
EndSeh(STATUS_SUCCESS);
+#define TEST_NOWRITE(n) StartSeh() *(volatile UCHAR *)&Bytes[n] = Bytes[n];
EndSeh(STATUS_ACCESS_VIOLATION);
+ TEST_NOWRITE(0x2000);
TEST_BYTE(0x2000, 0xc3);
TEST_BYTE(0x2001, 0x00);
+ TEST_NOWRITE(0x4000);
TEST_BYTE(0x4000, 0x01);
TEST_BYTE(0x4001, 0x23);
TEST_BYTE(0x4007, 0xef);
@@ -1419,6 +1464,15 @@ Test_NoLoadSection(BOOL Relocate)
TEST_BYTE(0x40ff, 0xff);
TEST_BYTE(0x4100, 0x00);
TEST_BYTE(0x41ff, 0x00);
+ TEST_NOWRITE(0x6000);
+ TEST_BYTE(0x6000, 0xee);
+ TEST_BYTE(0x60ff, 0x55);
+ TEST_BYTE(0x6100, 0xee);
+ TEST_BYTE(0x63ff, 0xdd);
+ TEST_BYTE(0x6400, 0x00);
+ TEST_WRITE(0x8000);
+ TEST_BYTE(0x8000, 0x11);
+ TEST_BYTE(0x8400, 0x33);
Status = NtUnmapViewOfSection(NtCurrentProcess(), BaseAddress);
ok_ntstatus(Status, STATUS_SUCCESS);
}
@@ -1577,8 +1631,8 @@ START_TEST(NtMapViewOfSection)
Test_PageFileSection();
Test_ImageSection();
Test_BasedSection();
- Test_NoLoadSection(FALSE);
- Test_NoLoadSection(TRUE);
+ Test_SectionContents(FALSE);
+ Test_SectionContents(TRUE);
Test_EmptyFile();
Test_Truncate();
}