Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(8366)

Unified Diff: ceee/ie/broker/broker_rpc_client.cc

Issue 5258006: Restart of ceee_broker on crash. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 10 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: ceee/ie/broker/broker_rpc_client.cc
===================================================================
--- ceee/ie/broker/broker_rpc_client.cc (revision 67655)
+++ ceee/ie/broker/broker_rpc_client.cc (working copy)
@@ -9,17 +9,61 @@
#include <atlbase.h>
#include "base/lock.h"
#include "base/logging.h"
+#include "base/tuple.h"
#include "base/win/scoped_comptr.h"
#include "broker_lib.h" // NOLINT
#include "broker_rpc_lib.h" // NOLINT
#include "ceee/common/com_utils.h"
#include "ceee/ie/broker/broker_rpc_utils.h"
-BrokerRpcClient::BrokerRpcClient() : context_(0), binding_handle_(NULL) {
+
+namespace {
+
+void LogRpcException(const char* str, unsigned int exception_code) {
+ LOG(ERROR) << str << com::LogWe(exception_code);
}
-BrokerRpcClient::~BrokerRpcClient() {
- Disconnect();
+HRESULT BindRpc(std::wstring endpoint, RPC_BINDING_HANDLE* binding_handle) {
+ DCHECK(binding_handle);
+ std::wstring protocol = kRpcProtocol;
+ DCHECK(!protocol.empty());
+ DCHECK(!endpoint.empty());
+ if (protocol.empty() || endpoint.empty() || binding_handle == NULL)
+ return E_INVALIDARG;
+
+ RPC_BINDING_HANDLE tmp_binding_handle = NULL;
+
+ // TODO(vitalybuka@google.com): There's no guarantee (aside from name
+ // uniqueness) that it will connect to an endpoint created by the same user.
+ // Hint: The missing invocation is RpcBindingSetAuthInfoEx.
+ LOG(INFO) << "Connecting to RPC server. Endpoint: " << endpoint;
+ RPC_WSTR string_binding = NULL;
+ // Create binding string with given protocol and end point.
+ RPC_STATUS status = ::RpcStringBindingCompose(
+ NULL,
+ reinterpret_cast<RPC_WSTR>(&protocol[0]),
+ NULL,
+ reinterpret_cast<RPC_WSTR>(&endpoint[0]),
+ NULL,
+ &string_binding);
+ LOG_IF(ERROR, RPC_S_OK != status) <<
+ "Failed to compose binding string. RPC_STATUS=0x" << com::LogWe(status);
+
+ if (RPC_S_OK == status) {
+ // Create binding from just generated binding string. Binding handle should
+ // used for PRC calls.
+ status = ::RpcBindingFromStringBinding(string_binding, &tmp_binding_handle);
+ LOG_IF(ERROR, RPC_S_OK != status) <<
+ "Failed to bind. RPC_STATUS=0x" << com::LogWe(status);
+ ::RpcStringFree(&string_binding);
+ if (RPC_S_OK == status) {
+ LOG(INFO) << "RPC client is connected. Endpoint: " << endpoint;
+ *binding_handle = tmp_binding_handle;
+ return S_OK;
+ }
+ }
+ ::RpcBindingFree(binding_handle);
+ return RPC_E_FAULT;
}
int HandleRpcException(unsigned int rpc_exception_code) {
@@ -38,10 +82,33 @@
return EXCEPTION_EXECUTE_HANDLER;
}
-static void LogRpcException(const char* str, unsigned int exception_code) {
- LOG(ERROR) << str << com::LogWe(exception_code);
+HRESULT GetServerEndpoint(RPC_BINDING_HANDLE binding_handle,
+ int max_size,
+ wchar_t* endpoint) {
+ RpcTryExcept {
+ int endpoint_size = BrokerRpcClient_GetServerEndpoint(binding_handle,
+ max_size, endpoint);
+ if (endpoint_size > max_size)
+ return E_INVALIDARG;
+ return S_OK;
+ } RpcExcept(HandleRpcException(RpcExceptionCode())) {
+ LogRpcException("RPC error in LockContext", RpcExceptionCode());
+ return RPC_E_FAULT;
+ } RpcEndExcept
}
+} // namespace
+
+BrokerRpcClient::BrokerRpcClient(bool allow_restarts)
+ : context_(0),
+ binding_handle_(NULL),
+ allow_restarts_(allow_restarts) {
+}
+
+BrokerRpcClient::~BrokerRpcClient() {
+ Disconnect();
+}
+
void BrokerRpcClient::LockContext() {
RpcTryExcept {
context_ = BrokerRpcClient_Connect(binding_handle_);
@@ -58,56 +125,43 @@
} RpcEndExcept
}
+HRESULT BrokerRpcClient::StartServer(IUnknown** server) {
+ base::win::ScopedComPtr<IUnknown> broker;
+ // TODO(vitalybuka@google.com): Start broker without COM after the last
+ // COM interface is removed.
+ HRESULT hr = broker.CreateInstance(CLSID_CeeeBroker);
+ LOG_IF(ERROR, FAILED(hr)) << "Failed to create broker. " << com::LogHr(hr);
+ if (FAILED(hr))
+ return hr;
+ *server = broker.Detach();
+ return S_OK;
+}
+
HRESULT BrokerRpcClient::Connect(bool start_server) {
if (is_connected())
return S_OK;
// Keep alive until RPC is connected.
- base::win::ScopedComPtr<ICeeeBrokerRegistrar> broker;
+ base::win::ScopedComPtr<IUnknown> broker;
if (start_server) {
- // TODO(vitalybuka@google.com): Start broker without COM after the last
- // COM interface is removed.
- HRESULT hr = broker.CreateInstance(CLSID_CeeeBroker);
- LOG_IF(ERROR, FAILED(hr)) << "Failed to create broker. " << com::LogHr(hr);
+ HRESULT hr = StartServer(broker.Receive());
if (FAILED(hr))
return hr;
}
- std::wstring end_point = GetRpcEndPointAddress();
- std::wstring protocol = kRpcProtocol;
- DCHECK(!protocol.empty());
- DCHECK(!end_point.empty());
- if (protocol.empty() || end_point.empty())
- return RPC_E_FAULT;
-
- // TODO(vitalybuka@google.com): There's no guarantee (aside from name
- // uniqueness) that it will connect to an endpoint created by the same user.
- // Hint: The missing invocation is RpcBindingSetAuthInfoEx.
- LOG(INFO) << "Connecting to RPC server. Endpoint: " << end_point;
- RPC_WSTR string_binding = NULL;
- // Create binding string with given protocol and end point.
- RPC_STATUS status = ::RpcStringBindingCompose(
- NULL,
- reinterpret_cast<RPC_WSTR>(&protocol[0]),
- NULL,
- reinterpret_cast<RPC_WSTR>(&end_point[0]),
- NULL,
- &string_binding);
- LOG_IF(ERROR, RPC_S_OK != status) <<
- "Failed to compose binding string. RPC_STATUS=0x" << com::LogWe(status);
-
- if (RPC_S_OK == status) {
- // Create binding from just generated binding string. Binding handle should
- // used for PRC calls.
- status = ::RpcBindingFromStringBinding(string_binding, &binding_handle_);
- LOG_IF(ERROR, RPC_S_OK != status) <<
- "Failed to bind. RPC_STATUS=0x" << com::LogWe(status);
- ::RpcStringFree(&string_binding);
- if (RPC_S_OK == status) {
- LOG(INFO) << "RPC client is connected. Endpoint: " << end_point;
+ RPC_BINDING_HANDLE tmp_binding = NULL;
+ if (SUCCEEDED(BindRpc(GetRpcEndpointAddress(), &tmp_binding))) {
+ wchar_t server_endpoint[kMaxEndpointSize + 1];
+ if (SUCCEEDED(GetServerEndpoint(tmp_binding, arraysize(server_endpoint),
+ server_endpoint)) &&
+ SUCCEEDED(BindRpc(server_endpoint, &binding_handle_))) {
LockContext();
}
+ RPC_STATUS status = ::RpcBindingFree(&tmp_binding);
+ LOG_IF(WARNING, RPC_S_OK != status) <<
+ "Failed to unbind. RPC_STATUS=0x" << com::LogWe(status);
}
+
if (!is_connected()) {
Disconnect();
return RPC_E_FAULT;
@@ -125,25 +179,40 @@
}
}
-HRESULT BrokerRpcClient::FireEvent(const char* event_name,
- const char* event_args) {
+template<class Function, class Params>
+HRESULT BrokerRpcClient::RunRpc(bool allow_restart,
+ Function rpc_function,
+ Params params) {
Sigurður Ásgeirsson 2010/11/30 13:47:48 const Params& to reduce copying
Vitaly Buka (NO REVIEWS) 2010/12/01 01:20:12 I need something modifiable to change binding hand
+ DCHECK(rpc_function);
+ if (!is_connected())
+ return RPC_E_FAULT;
RpcTryExcept {
- BrokerRpcClient_FireEvent(binding_handle_, event_name, event_args);
+ DispatchToFunction(rpc_function, params);
return S_OK;
} RpcExcept(HandleRpcException(RpcExceptionCode())) {
LogRpcException("RPC error in FireEvent", RpcExceptionCode());
+
+ if (allow_restart &&
+ RPC_S_OK != ::RpcMgmtIsServerListening(binding_handle_)) {
+ Disconnect();
+ if (SUCCEEDED(Connect(true))) {
+ params.a = binding_handle_;
+ return RunRpc(false, rpc_function, params);
+ }
+ }
return RPC_E_FAULT;
} RpcEndExcept
}
+HRESULT BrokerRpcClient::FireEvent(const char* event_name,
+ const char* event_args) {
+ return RunRpc(allow_restarts_, &BrokerRpcClient_FireEvent,
Sigurður Ásgeirsson 2010/11/30 13:47:48 nit: drop method name down to next line.
Vitaly Buka (NO REVIEWS) 2010/12/01 01:20:12 Done.
+ MakeTuple(binding_handle_, event_name, event_args));
+}
+
HRESULT BrokerRpcClient::SendUmaHistogramTimes(const char* name, int sample) {
- RpcTryExcept {
- BrokerRpcClient_SendUmaHistogramTimes(binding_handle_, name, sample);
- return S_OK;
- } RpcExcept(HandleRpcException(RpcExceptionCode())) {
- LogRpcException("RPC error in SendUmaHistogramTimes", RpcExceptionCode());
- return RPC_E_FAULT;
- } RpcEndExcept
+ return RunRpc(allow_restarts_, &BrokerRpcClient_SendUmaHistogramTimes,
Sigurður Ásgeirsson 2010/11/30 13:47:48 ditto.
Vitaly Buka (NO REVIEWS) 2010/12/01 01:20:12 Done.
+ MakeTuple(binding_handle_, name, sample));
}
HRESULT BrokerRpcClient::SendUmaHistogramData(const char* name,
@@ -151,12 +220,6 @@
int min,
int max,
int bucket_count) {
- RpcTryExcept {
- BrokerRpcClient_SendUmaHistogramData(
- binding_handle_, name, sample, min, max, bucket_count);
- return S_OK;
- } RpcExcept(HandleRpcException(RpcExceptionCode())) {
- LogRpcException("RPC error in SendUmaHistogramData", RpcExceptionCode());
- return RPC_E_FAULT;
- } RpcEndExcept
+ return RunRpc(allow_restarts_, &BrokerRpcClient_SendUmaHistogramData,
+ MakeTuple(binding_handle_, name, sample, min, max, bucket_count));
}

Powered by Google App Engine
This is Rietveld 408576698