Home | History | Annotate | Download | only in aot
      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