| Index: tools/ipc_fuzzer/ipc_fuzzer_main.cc
|
| diff --git a/tools/ipc_fuzzer/ipc_fuzzer_main.cc b/tools/ipc_fuzzer/ipc_fuzzer_main.cc
|
| deleted file mode 100644
|
| index 3fa1d48c034c5a07b1ab6f71fe82783434ae4a31..0000000000000000000000000000000000000000
|
| --- a/tools/ipc_fuzzer/ipc_fuzzer_main.cc
|
| +++ /dev/null
|
| @@ -1,198 +0,0 @@
|
| -// Copyright 2013 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.
|
| -
|
| -#include <limits.h>
|
| -#include <list>
|
| -
|
| -#include "base/bind.h"
|
| -#include "base/command_line.h"
|
| -#include "base/files/memory_mapped_file.h"
|
| -#include "base/logging.h"
|
| -#include "base/memory/scoped_ptr.h"
|
| -#include "base/message_loop/message_loop.h"
|
| -#include "base/posix/global_descriptors.h"
|
| -#include "base/stl_util.h"
|
| -#include "base/synchronization/waitable_event.h"
|
| -#include "base/threading/thread.h"
|
| -#include "base/timer/timer.h"
|
| -#include "chrome/common/chrome_switches.h"
|
| -#include "ipc/ipc_channel_proxy.h"
|
| -#include "ipc/ipc_descriptors.h"
|
| -#include "ipc/ipc_listener.h"
|
| -#include "ipc/ipc_message.h"
|
| -#include "ipc/ipc_platform_file.h"
|
| -#include "ipc/ipc_switches.h"
|
| -
|
| -namespace {
|
| -
|
| -class IpcFuzzerProcess : public IPC::Listener {
|
| - public:
|
| - IpcFuzzerProcess();
|
| - virtual ~IpcFuzzerProcess();
|
| -
|
| - // Set up command line, logging, IO thread.
|
| - void Initialize(int argc, const char **argv);
|
| -
|
| - // Open a channel to the browser process. It will think we are a renderer.
|
| - void OpenChannel();
|
| -
|
| - // Extract messages from a file specified by --ipc-fuzzer-testcase=.
|
| - bool OpenTestcase();
|
| -
|
| - // Trigger the sending of messages to the browser.
|
| - void StartSendingMessages();
|
| -
|
| - // IPC::Listener implementation.
|
| - virtual bool OnMessageReceived(const IPC::Message& message) OVERRIDE;
|
| - virtual void OnChannelError() OVERRIDE;
|
| -
|
| - private:
|
| - bool ExtractMessages(const char *data, size_t len);
|
| - void SendNextMessage();
|
| -
|
| - scoped_ptr<IPC::ChannelProxy> channel_;
|
| - base::MessageLoop main_loop_;
|
| - base::Thread io_thread_;
|
| - base::WaitableEvent shutdown_event_;
|
| - scoped_ptr<base::Timer> timer_;
|
| - scoped_ptr<base::MemoryMappedFile> testcase_map_;
|
| - std::list<IPC::Message*> messages_;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(IpcFuzzerProcess);
|
| -};
|
| -
|
| -IpcFuzzerProcess::IpcFuzzerProcess()
|
| - : main_loop_(base::MessageLoop::TYPE_DEFAULT),
|
| - io_thread_("Chrome_ChildIOThread"),
|
| - shutdown_event_(true, false) {
|
| -}
|
| -
|
| -IpcFuzzerProcess::~IpcFuzzerProcess() {
|
| - channel_.reset();
|
| - STLDeleteElements(&messages_);
|
| -}
|
| -
|
| -void IpcFuzzerProcess::Initialize(int argc, const char **argv) {
|
| - CommandLine::Init(argc, argv);
|
| -
|
| - // Log to default destination.
|
| - logging::SetMinLogLevel(logging::LOG_ERROR);
|
| - logging::InitLogging(logging::LoggingSettings());
|
| -
|
| - io_thread_.StartWithOptions(
|
| - base::Thread::Options(base::MessageLoop::TYPE_IO, 0));
|
| -
|
| -#if defined(OS_POSIX)
|
| - base::GlobalDescriptors* g_fds = base::GlobalDescriptors::GetInstance();
|
| - g_fds->Set(kPrimaryIPCChannel,
|
| - kPrimaryIPCChannel + base::GlobalDescriptors::kBaseDescriptor);
|
| -#endif
|
| -}
|
| -
|
| -void IpcFuzzerProcess::OpenChannel() {
|
| - std::string channel_name =
|
| - CommandLine::ForCurrentProcess()->GetSwitchValueASCII(
|
| - switches::kProcessChannelID);
|
| -
|
| - channel_.reset(
|
| - new IPC::ChannelProxy(channel_name,
|
| - IPC::Channel::MODE_CLIENT,
|
| - this,
|
| - io_thread_.message_loop_proxy()));
|
| -}
|
| -
|
| -bool IpcFuzzerProcess::ExtractMessages(const char *data, size_t len) {
|
| - const char* end = data + len;
|
| -
|
| - while (data < end) {
|
| - const char* message_tail = IPC::Message::FindNext(data, end);
|
| - if (!message_tail)
|
| - break;
|
| -
|
| - size_t len = message_tail - data;
|
| - if (len > INT_MAX) {
|
| - LOG(ERROR) << "Message too large";
|
| - break;
|
| - }
|
| -
|
| - IPC::Message* message = new IPC::Message(data, len);
|
| - messages_.push_back(message);
|
| - data = message_tail;
|
| - }
|
| -
|
| - if (data < end) {
|
| - unsigned long left = end - data;
|
| - LOG(ERROR) << left << " bytes left while extracting messages";
|
| - return false;
|
| - }
|
| -
|
| - return true;
|
| -}
|
| -
|
| -bool IpcFuzzerProcess::OpenTestcase() {
|
| - const CommandLine& command_line = *CommandLine::ForCurrentProcess();
|
| -
|
| - if (!command_line.HasSwitch(switches::kIpcFuzzerTestcase)) {
|
| - LOG(ERROR) << "No IPC fuzzer testcase specified";
|
| - return false;
|
| - }
|
| -
|
| - base::FilePath path =
|
| - command_line.GetSwitchValuePath(switches::kIpcFuzzerTestcase);
|
| - testcase_map_.reset(new base::MemoryMappedFile());
|
| - if (!testcase_map_->Initialize(path)) {
|
| - LOG(ERROR) << "Failed to map testcase: " << path.value();
|
| - return false;
|
| - }
|
| -
|
| - const char* data = reinterpret_cast<const char *>(testcase_map_->data());
|
| - size_t len = testcase_map_->length();
|
| -
|
| - return ExtractMessages(data, len);
|
| -}
|
| -
|
| -void IpcFuzzerProcess::SendNextMessage() {
|
| - if (messages_.empty()) {
|
| - base::MessageLoop::current()->Quit();
|
| - return;
|
| - }
|
| -
|
| - IPC::Message* message = messages_.front();
|
| - messages_.pop_front();
|
| -
|
| - channel_->Send(message);
|
| -}
|
| -
|
| -void IpcFuzzerProcess::StartSendingMessages() {
|
| - timer_.reset(new base::Timer(false, true));
|
| - timer_->Start(FROM_HERE,
|
| - base::TimeDelta::FromMilliseconds(1),
|
| - base::Bind(&IpcFuzzerProcess::SendNextMessage,
|
| - base::Unretained(this)));
|
| -}
|
| -
|
| -bool IpcFuzzerProcess::OnMessageReceived(const IPC::Message& msg) {
|
| - return true;
|
| -}
|
| -
|
| -void IpcFuzzerProcess::OnChannelError() {
|
| - LOG(ERROR) << "Channel error, quitting";
|
| - base::MessageLoop::current()->Quit();
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -int main(int argc, const char **argv) {
|
| - IpcFuzzerProcess fuzzer;
|
| - fuzzer.Initialize(argc, argv);
|
| - fuzzer.OpenChannel();
|
| -
|
| - if (!fuzzer.OpenTestcase())
|
| - return 0;
|
| -
|
| - fuzzer.StartSendingMessages();
|
| -
|
| - base::MessageLoop::current()->Run();
|
| - return 0;
|
| -}
|
|
|