blob: 3b792e212ddbc8e5f79a2626936e5cf88ded357a [file] [log] [blame]
// Copyright 2015 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.
#ifndef CHROMEOS_BINDER_COMMAND_BROKER_H_
#define CHROMEOS_BINDER_COMMAND_BROKER_H_
#include <stdint.h>
#include <memory>
#include <utility>
#include "base/callback.h"
#include "base/macros.h"
#include "base/memory/weak_ptr.h"
#include "base/threading/thread_checker.h"
#include "chromeos/binder/command_stream.h"
#include "chromeos/chromeos_export.h"
namespace binder {
class Driver;
class TransactionData;
// Issues appropriate outgoing commands to perform required tasks, and
// dispatches incoming commands to appropriate objects.
// Usually this class lives as long as the corresponding thread.
// TODO(hashimoto): Add code to handle incoming commands (e.g. transactions).
class CHROMEOS_EXPORT CommandBroker
: public CommandStream::IncomingCommandHandler {
public:
explicit CommandBroker(Driver* driver);
~CommandBroker() override;
// Tells the driver that the current thread entered command handling loop.
// Returns true on success.
// This method must be used by the main thread which owns the Driver instance,
// sub threads should use RegisterLooper().
bool EnterLooper();
// Tells the driver that the current thread entered command handling loop.
// Returns true on success.
// This method must be used by sub threads, the main thread should use
// EnterLooper().
bool RegisterLooper();
// Tells the driver that the current thread exited command handling loop.
// Returns true on success.
bool ExitLooper();
// Fetches incoming commands and handles them.
// Returns true on success.
bool PollCommands();
// Performs transaction with the remote object specified by the handle.
// Returns true on success. If not one-way transaction, this method blocks
// until the target object sends a reply.
bool Transact(int32_t handle,
const TransactionData& request,
std::unique_ptr<TransactionData>* reply);
// Increments the ref-count of a remote object specified by |handle|.
void AddReference(int32_t handle);
// Decrements the ref-count of a remote object specified by |handle|.
void ReleaseReference(int32_t handle);
// Returns a closure which decrements the ref-count of a remote object.
// It's safe to run the returned closure even after the destruction of this
// object.
base::Closure GetReleaseReferenceClosure(int32_t handle);
// CommandStream::IncomingCommandHandler override:
bool OnTransaction(const TransactionData& data) override;
void OnReply(std::unique_ptr<TransactionData> data) override;
void OnDeadReply() override;
void OnTransactionComplete() override;
void OnIncrementWeakReference(void* ptr, void* cookie) override;
void OnIncrementStrongReference(void* ptr, void* cookie) override;
void OnDecrementStrongReference(void* ptr, void* cookie) override;
void OnDecrementWeakReference(void* ptr, void* cookie) override;
void OnFailedReply() override;
private:
enum ResponseType {
RESPONSE_TYPE_NONE,
RESPONSE_TYPE_TRANSACTION_COMPLETE,
RESPONSE_TYPE_TRANSACTION_REPLY,
RESPONSE_TYPE_FAILED,
RESPONSE_TYPE_DEAD,
};
// Waits for a response to the previous transaction.
ResponseType WaitForResponse(std::unique_ptr<TransactionData>* data);
base::ThreadChecker thread_checker_;
CommandStream command_stream_;
ResponseType response_type_ = RESPONSE_TYPE_NONE;
std::unique_ptr<TransactionData> response_data_;
base::WeakPtrFactory<CommandBroker> weak_ptr_factory_;
DISALLOW_COPY_AND_ASSIGN(CommandBroker);
};
} // namespace binder
#endif // CHROMEOS_BINDER_COMMAND_BROKER_H_