Merge pull request #43680 from yongtang:fs_api

PiperOrigin-RevId: 337929031
Change-Id: Ia9370b1ce576cf0446bd4eaed267b9d5eaa2cdcc
This commit is contained in:
TensorFlower Gardener 2020-10-19 14:21:00 -07:00
commit 31547630e0
8 changed files with 60 additions and 0 deletions

View File

@ -348,6 +348,8 @@
context.
* Add `tf.config.experimental.mlir_bridge_rollout` which will help us
rollout the new MLIR TPU bridge.
* Added `tf.experimental.register_filesystem_plugin` to load modular
filesystem plugins from Python
* <ADD RELEASE NOTES HERE>
## Thanks to our Contributors

View File

@ -202,6 +202,7 @@ tf_cuda_library(
":tf_status",
":tf_tensor",
"@com_google_absl//absl/strings",
"//tensorflow/c/experimental/filesystem:modular_filesystem",
"//tensorflow/cc/saved_model:loader_lite",
"//tensorflow/cc:gradients",
"//tensorflow/cc:ops",

View File

@ -25,6 +25,7 @@ limitations under the License.
#include "tensorflow/core/platform/platform.h" // NOLINT
#if !defined(IS_MOBILE_PLATFORM) && !defined(IS_SLIM_BUILD)
#include "tensorflow/c/experimental/filesystem/modular_filesystem.h"
#include "tensorflow/cc/framework/gradients.h"
#include "tensorflow/cc/framework/ops.h"
#include "tensorflow/cc/framework/scope_internal.h"
@ -2606,4 +2607,14 @@ void TF_RegisterLogListener(void (*listener)(const char*)) {
#endif // !defined(IS_MOBILE_PLATFORM) && !defined(IS_SLIM_BUILD)
}
void TF_RegisterFilesystemPlugin(const char* plugin_filename,
TF_Status* status) {
#if defined(IS_MOBILE_PLATFORM) || defined(IS_SLIM_BUILD)
status->status = tensorflow::errors::Unimplemented(
"FileSystem plugin functionality is not supported on mobile");
#else
status->status = tensorflow::RegisterFilesystemPlugin(plugin_filename);
#endif // defined(IS_MOBILE_PLATFORM) || defined(IS_SLIM_BUILD)
}
} // end extern "C"

View File

@ -1577,6 +1577,13 @@ TF_CAPI_EXPORT extern void TF_DeleteServer(TF_Server* server);
TF_CAPI_EXPORT extern void TF_RegisterLogListener(
void (*listener)(const char*));
// Register a FileSystem plugin from filename `plugin_filename`.
//
// On success, place OK in status.
// On failure, place an error status in status.
TF_CAPI_EXPORT extern void TF_RegisterFilesystemPlugin(
const char* plugin_filename, TF_Status* status);
#ifdef __cplusplus
} /* end extern "C" */
#endif

View File

@ -1155,6 +1155,13 @@ PYBIND11_MODULE(_pywrap_tf_session, m) {
return "TensorHandle";
});
m.def("TF_RegisterFilesystemPlugin", [](const char* plugin_filename) {
tensorflow::Safe_TF_StatusPtr status =
tensorflow::make_safe(TF_NewStatus());
TF_RegisterFilesystemPlugin(plugin_filename, status.get());
tensorflow::MaybeRaiseRegisteredFromTFStatus(status.get());
});
py::enum_<TF_DataType>(m, "TF_DataType")
.value("TF_FLOAT", TF_FLOAT)
.value("TF_DOUBLE", TF_DOUBLE)

View File

@ -157,3 +157,27 @@ def load_library(library_location):
errno.ENOENT,
'The file or folder to load kernel libraries from does not exist.',
library_location)
@tf_export('experimental.register_filesystem_plugin')
def register_filesystem_plugin(plugin_location):
"""Loads a TensorFlow FileSystem plugin.
Args:
plugin_location: Path to the plugin. Relative or absolute filesystem plugin
path to a dynamic library file.
Returns:
None
Raises:
OSError: When the file to be loaded is not found.
RuntimeError: when unable to load the library.
"""
if os.path.exists(plugin_location):
py_tf.TF_RegisterFilesystemPlugin(plugin_location)
else:
raise OSError(errno.ENOENT,
'The file to load file system plugin from does not exist.',
plugin_location)

View File

@ -20,4 +20,8 @@ tf_module {
name: "output_all_intermediates"
argspec: "args=[\'state\'], varargs=None, keywords=None, defaults=None"
}
member_method {
name: "register_filesystem_plugin"
argspec: "args=[\'plugin_location\'], varargs=None, keywords=None, defaults=None"
}
}

View File

@ -28,4 +28,8 @@ tf_module {
name: "function_executor_type"
argspec: "args=[\'executor_type\'], varargs=None, keywords=None, defaults=None"
}
member_method {
name: "register_filesystem_plugin"
argspec: "args=[\'plugin_location\'], varargs=None, keywords=None, defaults=None"
}
}