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