/** * 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 #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 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 &tensors) { EventReply reply; grpc::ClientContext context; std::unique_ptr > 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 &watchpoints) { EventReply reply; grpc::ClientContext context; std::unique_ptr > 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