diff --git a/inference-engine/src/gna_plugin/gna_executable_network.hpp b/inference-engine/src/gna_plugin/gna_executable_network.hpp index dbfe8ada17bda7..6fa2cb79007901 100644 --- a/inference-engine/src/gna_plugin/gna_executable_network.hpp +++ b/inference-engine/src/gna_plugin/gna_executable_network.hpp @@ -21,12 +21,17 @@ class GNAExecutableNetwork : public InferenceEngine::ExecutableNetworkThreadSafe std::shared_ptr plg; public: - GNAExecutableNetwork(const std::string &aotFileName, std::shared_ptr plg) - : plg(plg) { - plg->ImportNetwork(aotFileName); - _networkInputs = plg->GetInputs(); - _networkOutputs = plg->GetOutputs(); - } + GNAExecutableNetwork(const std::string& aotFileName, std::shared_ptr plg) + : plg(plg) { + std::fstream inputStream(aotFileName, std::ios_base::in | std::ios_base::binary); + if (inputStream.fail()) { + THROW_GNA_EXCEPTION << "Cannot open file to import model: " << aotFileName; + } + + plg->ImportNetwork(inputStream); + _networkInputs = plg->GetInputs(); + _networkOutputs = plg->GetOutputs(); + } GNAExecutableNetwork(std::istream& networkModel, std::shared_ptr plg) : plg(plg) { @@ -40,7 +45,7 @@ class GNAExecutableNetwork : public InferenceEngine::ExecutableNetworkThreadSafe plg->LoadNetwork(network); } - GNAExecutableNetwork(const std::string &aotFileName, const std::map &config) + GNAExecutableNetwork(const std::string& aotFileName, const std::map& config) : GNAExecutableNetwork(aotFileName, std::make_shared(config)) { } diff --git a/inference-engine/src/gna_plugin/gna_plugin.cpp b/inference-engine/src/gna_plugin/gna_plugin.cpp index 5120dbda0d364e..23179d7474b2ef 100644 --- a/inference-engine/src/gna_plugin/gna_plugin.cpp +++ b/inference-engine/src/gna_plugin/gna_plugin.cpp @@ -1134,16 +1134,6 @@ void GNAPlugin::SetName(const std::string & pluginName) noexcept { _pluginName = pluginName; } -InferenceEngine::IExecutableNetwork::Ptr GNAPlugin::ImportNetwork(const std::string &modelFileName) { - // no need to return anything dueto weird design of internal base classes - std::fstream inputStream(modelFileName, ios_base::in | ios_base::binary); - if (inputStream.fail()) { - THROW_GNA_EXCEPTION << "Cannot open file to import model: " << modelFileName; - } - - return ImportNetwork(inputStream); -} - InferenceEngine::IExecutableNetwork::Ptr GNAPlugin::ImportNetwork(std::istream& networkModel) { auto header = GNAModelSerial::ReadHeader(networkModel); diff --git a/inference-engine/src/gna_plugin/gna_plugin.hpp b/inference-engine/src/gna_plugin/gna_plugin.hpp index 89e54c6d711534..839d9abb388f7b 100644 --- a/inference-engine/src/gna_plugin/gna_plugin.hpp +++ b/inference-engine/src/gna_plugin/gna_plugin.hpp @@ -146,7 +146,6 @@ class GNAPlugin : public InferenceEngine::IInferencePlugin { THROW_GNA_EXCEPTION << "Not implemented"; } - InferenceEngine::IExecutableNetwork::Ptr ImportNetwork(const std::string &modelFileName); InferenceEngine::IExecutableNetwork::Ptr ImportNetwork(std::istream& networkModel); /** diff --git a/inference-engine/src/gna_plugin/gna_plugin_internal.hpp b/inference-engine/src/gna_plugin/gna_plugin_internal.hpp index a43f0870342df4..df42d03c3bd18a 100644 --- a/inference-engine/src/gna_plugin/gna_plugin_internal.hpp +++ b/inference-engine/src/gna_plugin/gna_plugin_internal.hpp @@ -43,13 +43,14 @@ class GNAPluginInternal : public InferenceEngine::InferencePluginInternal { defaultConfig.UpdateFromMap(config); } - InferenceEngine::IExecutableNetwork::Ptr ImportNetwork( + InferenceEngine::IExecutableNetwork::Ptr ImportNetwork( const std::string &modelFileName, const std::map &config) override { Config updated_config(defaultConfig); updated_config.UpdateFromMap(config); auto plg = std::make_shared(updated_config.key_config_map); plgPtr = plg; + return make_executable_network(std::make_shared(modelFileName, plg)); } diff --git a/inference-engine/tests_deprecated/unit/engines/gna/gna_matcher.cpp b/inference-engine/tests_deprecated/unit/engines/gna/gna_matcher.cpp index f9af5553f79a32..4d8d4c78bc1130 100644 --- a/inference-engine/tests_deprecated/unit/engines/gna/gna_matcher.cpp +++ b/inference-engine/tests_deprecated/unit/engines/gna/gna_matcher.cpp @@ -164,7 +164,12 @@ void GNAPropagateMatcher :: match() { }; auto loadNetworkFromAOT = [&] () { - auto sp = plugin.ImportNetwork(_env.importedModelFileName); + std::fstream inputStream(_env.importedModelFileName, std::ios_base::in | std::ios_base::binary); + if (inputStream.fail()) { + THROW_GNA_EXCEPTION << "Cannot open file to import model: " << _env.importedModelFileName; + } + + auto sp = plugin.ImportNetwork(inputStream); inputsInfo = plugin.GetInputs(); outputsInfo = plugin.GetOutputs(); }; @@ -505,7 +510,12 @@ void GNADumpXNNMatcher::load(std::shared_ptr & plugin) { }; auto loadNetworkFromAOT = [&]() { - plugin->ImportNetwork(_env.importedModelFileName); + std::fstream inputStream(_env.importedModelFileName, std::ios_base::in | std::ios_base::binary); + if (inputStream.fail()) { + THROW_GNA_EXCEPTION << "Cannot open file to import model: " << _env.importedModelFileName; + } + + plugin->ImportNetwork(inputStream); }; auto loadNetwork = [&]() {