diff options
author | nsylvain@chromium.org <nsylvain@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-23 22:42:25 +0000 |
---|---|---|
committer | nsylvain@chromium.org <nsylvain@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-23 22:42:25 +0000 |
commit | 27d753ac9ecc5afa4e49214e486d5dfbb50ce588 (patch) | |
tree | 58a3bdc2b415c6d99fe7431a7535927d84074d86 /sandbox/sandbox_poc | |
parent | 34f993563386ad569f3674d157153e697e847e0a (diff) | |
download | chromium_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.cc | 12 | ||||
-rw-r--r-- | sandbox/sandbox_poc/pocdll/handles.cc | 15 | ||||
-rw-r--r-- | sandbox/sandbox_poc/sandbox.cc | 8 |
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()); |