|
- /**
- * Copyright 2020 Huawei Technologies Co., Ltd
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
- #include <thread>
- #include "debug/debugger/grpc_client.h"
- #include "utils/log_adapter.h"
-
- using debugger::EventListener;
- using debugger::EventReply;
- using debugger::EventReply_Status_FAILED;
- using debugger::GraphProto;
- using debugger::Metadata;
- using debugger::TensorProto;
- using debugger::WatchpointHit;
-
- namespace mindspore {
- GrpcClient::GrpcClient(const std::string &host, const std::string &port) : stub_(nullptr) { Init(host, port); }
-
- void GrpcClient::Init(const std::string &host, const std::string &port) {
- std::string target_str = host + ":" + port;
- MS_LOG(INFO) << "GrpcClient connecting to: " << target_str;
-
- std::shared_ptr<grpc::Channel> channel = grpc::CreateChannel(target_str, grpc::InsecureChannelCredentials());
- stub_ = EventListener::NewStub(channel);
- }
-
- void GrpcClient::Reset() { stub_ = nullptr; }
-
- EventReply GrpcClient::WaitForCommand(const Metadata &metadata) {
- EventReply reply;
- grpc::ClientContext context;
- grpc::Status status = stub_->WaitCMD(&context, metadata, &reply);
-
- if (!status.ok()) {
- MS_LOG(ERROR) << "RPC failed: WaitForCommand";
- MS_LOG(ERROR) << status.error_code() << ": " << status.error_message();
- reply.set_status(EventReply_Status_FAILED);
- }
- return reply;
- }
-
- EventReply GrpcClient::SendMetadata(const Metadata &metadata) {
- EventReply reply;
- grpc::ClientContext context;
- grpc::Status status = stub_->SendMetadata(&context, metadata, &reply);
-
- if (!status.ok()) {
- MS_LOG(ERROR) << "RPC failed: SendMetadata";
- MS_LOG(ERROR) << status.error_code() << ": " << status.error_message();
- reply.set_status(EventReply_Status_FAILED);
- }
- return reply;
- }
-
- EventReply GrpcClient::SendGraph(const GraphProto &graph) {
- EventReply reply;
- grpc::ClientContext context;
- grpc::Status status = stub_->SendGraph(&context, graph, &reply);
-
- if (!status.ok()) {
- MS_LOG(ERROR) << "RPC failed: SendGraph";
- MS_LOG(ERROR) << status.error_code() << ": " << status.error_message();
- reply.set_status(EventReply_Status_FAILED);
- }
- return reply;
- }
-
- EventReply GrpcClient::SendTensors(const std::list<TensorProto> &tensors) {
- EventReply reply;
- grpc::ClientContext context;
-
- std::unique_ptr<grpc::ClientWriter<TensorProto> > writer(stub_->SendTensors(&context, &reply));
- for (const auto &tensor : tensors) {
- if (!writer->Write(tensor)) {
- break;
- }
- std::this_thread::sleep_for(std::chrono::milliseconds(1));
- }
- writer->WritesDone();
- grpc::Status status = writer->Finish();
-
- if (!status.ok()) {
- MS_LOG(ERROR) << "RPC failed: SendTensors";
- MS_LOG(ERROR) << status.error_code() << ": " << status.error_message();
- reply.set_status(EventReply_Status_FAILED);
- }
- return reply;
- }
-
- EventReply GrpcClient::SendWatchpointHits(const std::list<WatchpointHit> &watchpoints) {
- EventReply reply;
- grpc::ClientContext context;
-
- std::unique_ptr<grpc::ClientWriter<WatchpointHit> > writer(stub_->SendWatchpointHits(&context, &reply));
- for (const auto &watchpoint : watchpoints) {
- if (!writer->Write(watchpoint)) {
- break;
- }
- std::this_thread::sleep_for(std::chrono::milliseconds(1));
- }
- writer->WritesDone();
- grpc::Status status = writer->Finish();
-
- if (!status.ok()) {
- MS_LOG(ERROR) << "RPC failed: SendWatchpointHits";
- MS_LOG(ERROR) << status.error_code() << ": " << status.error_message();
- reply.set_status(EventReply_Status_FAILED);
- }
- return reply;
- }
- } // namespace mindspore
|