summaryrefslogtreecommitdiffstats
path: root/sandbox/sandbox_poc
diff options
context:
space:
mode:
authornsylvain@chromium.org <nsylvain@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-03-23 22:42:25 +0000
committernsylvain@chromium.org <nsylvain@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-03-23 22:42:25 +0000
commit27d753ac9ecc5afa4e49214e486d5dfbb50ce588 (patch)
tree58a3bdc2b415c6d99fe7431a7535927d84074d86 /sandbox/sandbox_poc
parent34f993563386ad569f3674d157153e697e847e0a (diff)
downloadchromium_src-27d753ac9ecc5afa4e49214e486d5dfbb50ce588.zip
chromium_src-27d753ac9ecc5afa4e49214e486d5dfbb50ce588.tar.gz
chromium_src-27d753ac9ecc5afa4e49214e486d5dfbb50ce588.tar.bz2
Fix the POC and some of unit tests to be build and
run correctly in 64 bit. BUG=27218 Review URL: http://codereview.chromium.org/1168002 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@42392 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'sandbox/sandbox_poc')
-rw-r--r--sandbox/sandbox_poc/main_ui_window.cc12
-rw-r--r--sandbox/sandbox_poc/pocdll/handles.cc15
-rw-r--r--sandbox/sandbox_poc/sandbox.cc8
3 files changed, 15 insertions, 20 deletions
diff --git a/sandbox/sandbox_poc/main_ui_window.cc b/sandbox/sandbox_poc/main_ui_window.cc
index 9669c4b..ef4d550 100644
--- a/sandbox/sandbox_poc/main_ui_window.cc
+++ b/sandbox/sandbox_poc/main_ui_window.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2006-2009 The Chromium Authors. All rights reserved.
+// Copyright (c) 2006-2010 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -96,9 +96,9 @@ unsigned int MainUIWindow::CreateMainWindowAndLoop(
if (NULL == window)
return ::GetLastError();
- ::SetWindowLong(window,
- GWL_USERDATA,
- static_cast<LONG>(reinterpret_cast<LONG_PTR>(this)));
+ ::SetWindowLongPtr(window,
+ GWLP_USERDATA,
+ reinterpret_cast<LONG_PTR>(this));
::SetWindowText(window, L"Sandbox Proof of Concept");
@@ -233,9 +233,9 @@ MainUIWindow* MainUIWindow::FromWindow(HWND main_window) {
// so that we can retrieve it with this function later. This prevents us
// from having to define all the message handling functions (that we refer to
// in the window proc) as static
- ::GetWindowLong(main_window, GWL_USERDATA);
+ ::GetWindowLongPtr(main_window, GWLP_USERDATA);
return reinterpret_cast<MainUIWindow*>(
- static_cast<LONG_PTR>(::GetWindowLong(main_window, GWL_USERDATA)));
+ ::GetWindowLongPtr(main_window, GWLP_USERDATA));
}
BOOL MainUIWindow::OnCreate(HWND parent_window, LPCREATESTRUCT) {
diff --git a/sandbox/sandbox_poc/pocdll/handles.cc b/sandbox/sandbox_poc/pocdll/handles.cc
index 410e977..05a57b7 100644
--- a/sandbox/sandbox_poc/pocdll/handles.cc
+++ b/sandbox/sandbox_poc/pocdll/handles.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
+// Copyright (c) 2006-2010 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -18,7 +18,7 @@ void POCDLL_API TestGetHandle(HANDLE log) {
FILE *output = handle2file.Translate(log, "w");
// Initialize the NTAPI functions we need
- HMODULE ntdll_handle = ::LoadLibraryA("ntdll.dll");
+ HMODULE ntdll_handle = ::GetModuleHandle(L"ntdll.dll");
if (!ntdll_handle) {
fprintf(output, "[ERROR] Cannot load ntdll.dll. Error %d\r\n",
::GetLastError());
@@ -35,7 +35,6 @@ void POCDLL_API TestGetHandle(HANDLE log) {
if (!NtQueryObject || !NtQueryInformationFile || !NtQuerySystemInformation) {
fprintf(output, "[ERROR] Cannot load all NT functions. Error %d\r\n",
::GetLastError());
- ::FreeLibrary(ntdll_handle);
return;
}
@@ -48,7 +47,6 @@ void POCDLL_API TestGetHandle(HANDLE log) {
if (!buffer_size) {
fprintf(output, "[ERROR] Get the number of handles. Error 0x%X\r\n",
status);
- ::FreeLibrary(ntdll_handle);
return;
}
@@ -60,12 +58,11 @@ void POCDLL_API TestGetHandle(HANDLE log) {
if (STATUS_SUCCESS != status) {
fprintf(output, "[ERROR] Failed to get the handle list. Error 0x%X\r\n",
status);
- ::FreeLibrary(ntdll_handle);
delete [] system_handles;
return;
}
- for (unsigned int i = 0; i < system_handles->NumberOfHandles; ++i) {
+ for (ULONG i = 0; i < system_handles->NumberOfHandles; ++i) {
USHORT h = system_handles->Information[i].Handle;
if (system_handles->Information[i].ProcessId != ::GetCurrentProcessId())
continue;
@@ -122,8 +119,8 @@ void POCDLL_API TestGetHandle(HANDLE log) {
// This function does not return the size of the buffer. We need to
// iterate and always increase the buffer size until the function
// succeeds. (Or at least does not fail with STATUS_BUFFER_OVERFLOW)
- DWORD size_file = MAX_PATH;
- IO_STATUS_BLOCK status_block;
+ ULONG size_file = MAX_PATH;
+ IO_STATUS_BLOCK status_block = {0};
do {
// Delete the previous buffer create. The buffer was too small
if (file_name) {
@@ -186,6 +183,4 @@ void POCDLL_API TestGetHandle(HANDLE log) {
if (system_handles) {
delete [] system_handles;
}
-
- ::FreeLibrary(ntdll_handle);
}
diff --git a/sandbox/sandbox_poc/sandbox.cc b/sandbox/sandbox_poc/sandbox.cc
index 53a9f5a..4dc0882 100644
--- a/sandbox/sandbox_poc/sandbox.cc
+++ b/sandbox/sandbox_poc/sandbox.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
+// Copyright (c) 2006-2010 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -148,9 +148,6 @@ int APIENTRY _tWinMain(HINSTANCE instance, HINSTANCE, wchar_t* command_line,
return -4;
}
- // Initialization is finished, so we can enter lock-down mode
- target_service->LowerToken();
-
// We now know what we should load, so load it
HMODULE dll_module = ::LoadLibraryA(dll_name.c_str());
if (dll_module == NULL) {
@@ -158,6 +155,9 @@ int APIENTRY _tWinMain(HINSTANCE instance, HINSTANCE, wchar_t* command_line,
return -5;
}
+ // Initialization is finished, so we can enter lock-down mode
+ target_service->LowerToken();
+
lpfnInit init_function =
(lpfnInit) ::GetProcAddress(dll_module, entry_point.c_str());