1 /* Copyright 2018 The TensorFlow Authors. All Rights Reserved. 2 3 Licensed under the Apache License, Version 2.0 (the "License"); 4 you may not use this file except in compliance with the License. 5 You may obtain a copy of the License at 6 7 http://www.apache.org/licenses/LICENSE-2.0 8 9 Unless required by applicable law or agreed to in writing, software 10 distributed under the License is distributed on an "AS IS" BASIS, 11 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 See the License for the specific language governing permissions and 13 limitations under the License. 14 ==============================================================================*/ 15 16 // This file defines utilities to help "embed" protocol buffers into object 17 // (".o") files. These C++ binaries and shared objects can link in these .o to 18 // get access to said protocol buffers at runtime. 19 20 #ifndef TENSORFLOW_COMPILER_AOT_EMBEDDED_PROTOCOL_BUFFERS_H_ 21 #define TENSORFLOW_COMPILER_AOT_EMBEDDED_PROTOCOL_BUFFERS_H_ 22 23 #include "absl/types/span.h" 24 #include "tensorflow/compiler/xla/statusor.h" 25 #include "tensorflow/core/platform/protobuf.h" 26 27 namespace tensorflow { 28 namespace tfcompile { 29 using xla::StatusOr; 30 31 // Represents a set of protocol buffers embedded into an object file and 32 // describes how to access them at runtime. 33 struct EmbeddedProtocolBuffers { 34 // Each instance CPPShim describes how to generate C++ code to instantiate a 35 // protobuf instance from the corresponding static data emitted into the 36 // object file. 37 struct CPPShim { 38 // `expression` is a C++ expression that creates an instance of said 39 // protocol buffer when executed. 40 string expression; 41 42 // `variable_decl` is an "extern C" array declaration that is used in 43 // `expression`. It must be visible wherever `expression` is emitted. 44 string variable_decl; 45 }; 46 47 // Each cpp_shim corresponds to one embedded protocol buffer. 48 std::vector<CPPShim> cpp_shims; 49 50 // The contents of the object (".o") file the protocol buffers are embbed in. 51 // This needs to be linked in to any program that wants to execute any of the 52 // expressions in `cpp_shims`. 53 string object_file_data; 54 }; 55 56 // Describes a protocol buffer to embed into an object file. 57 struct ProtobufToEmbed { 58 // `symbol_prefix` is prefix that is guaranteed to be unique across the binary 59 // or DSO the generated object file will be linked into. 60 string symbol_prefix; 61 62 // `qualified_cpp_protobuf_name` is a qualified ("qualified" as in C++ 63 // namespace qualified) protocol buffer name. This is only used in 64 // CPPShim::expression so relatively qualified names are fine as long as 65 // they're valid wherever CPPShim::expression is emitted. 66 string qualified_cpp_protobuf_name; 67 68 // `message` is the protocol buffer to be embedded. It is allowed to be 69 // nullptr, in which case the generated C++ shim expression is just `nullptr`, 70 // and the generated object file does not define any symbols. 71 const ::tensorflow::protobuf::MessageLite* message; 72 }; 73 74 // Embeds a sequence of protocol buffers into an object file. 75 // 76 // `target_triple` is the target triple for the target architecture for the 77 // generated object file. 78 // 79 // `protobufs_to_embed` describes the protocol buffers to embed into the 80 // resulting object file. The C++ shim for protobufs_to_embed[i] is 81 // cpp_shims[i] in the returned EmbeddedProtocolBuffers instance. The contents 82 // of all the protocol buffers are embedded into a single .o file whose content 83 // is stored in the object_file_data field in the returned 84 // EmbeddedProtocolBuffers instance. 85 StatusOr<EmbeddedProtocolBuffers> CreateEmbeddedProtocolBuffers( 86 absl::string_view target_triple, 87 absl::Span<const ProtobufToEmbed> protobufs_to_embed); 88 89 } // namespace tfcompile 90 } // namespace tensorflow 91 92 #endif // TENSORFLOW_COMPILER_AOT_EMBEDDED_PROTOCOL_BUFFERS_H_ 93