// Generated by the protocol buffer compiler.  DO NOT EDIT!
// NO CHECKED-IN PROTOBUF GENCODE
// source: xla/service/gpu/launch_dimensions.proto
// Protobuf C++ Version: 5.28.3

#ifndef GOOGLE_PROTOBUF_INCLUDED_xla_2fservice_2fgpu_2flaunch_5fdimensions_2eproto_2epb_2eh
#define GOOGLE_PROTOBUF_INCLUDED_xla_2fservice_2fgpu_2flaunch_5fdimensions_2eproto_2epb_2eh

#include <limits>
#include <string>
#include <type_traits>
#include <utility>

#include "google/protobuf/runtime_version.h"
#if PROTOBUF_VERSION != 5028003
#error "Protobuf C++ gencode is built with an incompatible version of"
#error "Protobuf C++ headers/runtime. See"
#error "https://protobuf.dev/support/cross-version-runtime-guarantee/#cpp"
#endif
#include "google/protobuf/io/coded_stream.h"
#include "google/protobuf/arena.h"
#include "google/protobuf/arenastring.h"
#include "google/protobuf/generated_message_tctable_decl.h"
#include "google/protobuf/generated_message_util.h"
#include "google/protobuf/metadata_lite.h"
#include "google/protobuf/generated_message_reflection.h"
#include "google/protobuf/message.h"
#include "google/protobuf/repeated_field.h"  // IWYU pragma: export
#include "google/protobuf/extension_set.h"  // IWYU pragma: export
#include "google/protobuf/unknown_field_set.h"
#include "xla/stream_executor/launch_dim.pb.h"
// @@protoc_insertion_point(includes)

// Must be included last.
#include "google/protobuf/port_def.inc"

#define PROTOBUF_INTERNAL_EXPORT_xla_2fservice_2fgpu_2flaunch_5fdimensions_2eproto PROTOBUF_EXPORT

namespace google {
namespace protobuf {
namespace internal {
class AnyMetadata;
}  // namespace internal
}  // namespace protobuf
}  // namespace google

// Internal implementation detail -- do not use these members.
struct PROTOBUF_EXPORT TableStruct_xla_2fservice_2fgpu_2flaunch_5fdimensions_2eproto {
  static const ::uint32_t offsets[];
};
PROTOBUF_EXPORT extern const ::google::protobuf::internal::DescriptorTable
    descriptor_table_xla_2fservice_2fgpu_2flaunch_5fdimensions_2eproto;
namespace xla {
namespace gpu {
class LaunchDimensionsProto;
struct LaunchDimensionsProtoDefaultTypeInternal;
PROTOBUF_EXPORT extern LaunchDimensionsProtoDefaultTypeInternal _LaunchDimensionsProto_default_instance_;
}  // namespace gpu
}  // namespace xla
namespace google {
namespace protobuf {
}  // namespace protobuf
}  // namespace google

namespace xla {
namespace gpu {

// ===================================================================


// -------------------------------------------------------------------

class PROTOBUF_EXPORT LaunchDimensionsProto final : public ::google::protobuf::Message
/* @@protoc_insertion_point(class_definition:xla.gpu.LaunchDimensionsProto) */ {
 public:
  inline LaunchDimensionsProto() : LaunchDimensionsProto(nullptr) {}
  ~LaunchDimensionsProto() PROTOBUF_FINAL;
  template <typename = void>
  explicit PROTOBUF_CONSTEXPR LaunchDimensionsProto(
      ::google::protobuf::internal::ConstantInitialized);

  inline LaunchDimensionsProto(const LaunchDimensionsProto& from) : LaunchDimensionsProto(nullptr, from) {}
  inline LaunchDimensionsProto(LaunchDimensionsProto&& from) noexcept
      : LaunchDimensionsProto(nullptr, std::move(from)) {}
  inline LaunchDimensionsProto& operator=(const LaunchDimensionsProto& from) {
    CopyFrom(from);
    return *this;
  }
  inline LaunchDimensionsProto& operator=(LaunchDimensionsProto&& from) noexcept {
    if (this == &from) return *this;
    if (GetArena() == from.GetArena()
#ifdef PROTOBUF_FORCE_COPY_IN_MOVE
        && GetArena() != nullptr
#endif  // !PROTOBUF_FORCE_COPY_IN_MOVE
    ) {
      InternalSwap(&from);
    } else {
      CopyFrom(from);
    }
    return *this;
  }

  inline const ::google::protobuf::UnknownFieldSet& unknown_fields() const
      ABSL_ATTRIBUTE_LIFETIME_BOUND {
    return _internal_metadata_.unknown_fields<::google::protobuf::UnknownFieldSet>(::google::protobuf::UnknownFieldSet::default_instance);
  }
  inline ::google::protobuf::UnknownFieldSet* mutable_unknown_fields()
      ABSL_ATTRIBUTE_LIFETIME_BOUND {
    return _internal_metadata_.mutable_unknown_fields<::google::protobuf::UnknownFieldSet>();
  }

  static const ::google::protobuf::Descriptor* descriptor() {
    return GetDescriptor();
  }
  static const ::google::protobuf::Descriptor* GetDescriptor() {
    return default_instance().GetMetadata().descriptor;
  }
  static const ::google::protobuf::Reflection* GetReflection() {
    return default_instance().GetMetadata().reflection;
  }
  static const LaunchDimensionsProto& default_instance() {
    return *internal_default_instance();
  }
  static inline const LaunchDimensionsProto* internal_default_instance() {
    return reinterpret_cast<const LaunchDimensionsProto*>(
        &_LaunchDimensionsProto_default_instance_);
  }
  static constexpr int kIndexInFileMessages = 0;
  friend void swap(LaunchDimensionsProto& a, LaunchDimensionsProto& b) { a.Swap(&b); }
  inline void Swap(LaunchDimensionsProto* other) {
    if (other == this) return;
#ifdef PROTOBUF_FORCE_COPY_IN_SWAP
    if (GetArena() != nullptr && GetArena() == other->GetArena()) {
#else   // PROTOBUF_FORCE_COPY_IN_SWAP
    if (GetArena() == other->GetArena()) {
#endif  // !PROTOBUF_FORCE_COPY_IN_SWAP
      InternalSwap(other);
    } else {
      ::google::protobuf::internal::GenericSwap(this, other);
    }
  }
  void UnsafeArenaSwap(LaunchDimensionsProto* other) {
    if (other == this) return;
    ABSL_DCHECK(GetArena() == other->GetArena());
    InternalSwap(other);
  }

  // implements Message ----------------------------------------------

  LaunchDimensionsProto* New(::google::protobuf::Arena* arena = nullptr) const PROTOBUF_FINAL {
    return ::google::protobuf::Message::DefaultConstruct<LaunchDimensionsProto>(arena);
  }
  using ::google::protobuf::Message::CopyFrom;
  void CopyFrom(const LaunchDimensionsProto& from);
  using ::google::protobuf::Message::MergeFrom;
  void MergeFrom(const LaunchDimensionsProto& from) { LaunchDimensionsProto::MergeImpl(*this, from); }

  private:
  static void MergeImpl(
      ::google::protobuf::MessageLite& to_msg,
      const ::google::protobuf::MessageLite& from_msg);

  public:
  bool IsInitialized() const {
    return true;
  }
  ABSL_ATTRIBUTE_REINITIALIZES void Clear() PROTOBUF_FINAL;
  #if defined(PROTOBUF_CUSTOM_VTABLE)
  private:
  static ::size_t ByteSizeLong(const ::google::protobuf::MessageLite& msg);
  static ::uint8_t* _InternalSerialize(
      const MessageLite& msg, ::uint8_t* target,
      ::google::protobuf::io::EpsCopyOutputStream* stream);

  public:
  ::size_t ByteSizeLong() const { return ByteSizeLong(*this); }
  ::uint8_t* _InternalSerialize(
      ::uint8_t* target,
      ::google::protobuf::io::EpsCopyOutputStream* stream) const {
    return _InternalSerialize(*this, target, stream);
  }
  #else   // PROTOBUF_CUSTOM_VTABLE
  ::size_t ByteSizeLong() const final;
  ::uint8_t* _InternalSerialize(
      ::uint8_t* target,
      ::google::protobuf::io::EpsCopyOutputStream* stream) const final;
  #endif  // PROTOBUF_CUSTOM_VTABLE
  int GetCachedSize() const { return _impl_._cached_size_.Get(); }

  private:
  void SharedCtor(::google::protobuf::Arena* arena);
  void SharedDtor();
  void InternalSwap(LaunchDimensionsProto* other);
 private:
  friend class ::google::protobuf::internal::AnyMetadata;
  static ::absl::string_view FullMessageName() { return "xla.gpu.LaunchDimensionsProto"; }

 protected:
  explicit LaunchDimensionsProto(::google::protobuf::Arena* arena);
  LaunchDimensionsProto(::google::protobuf::Arena* arena, const LaunchDimensionsProto& from);
  LaunchDimensionsProto(::google::protobuf::Arena* arena, LaunchDimensionsProto&& from) noexcept
      : LaunchDimensionsProto(arena) {
    *this = ::std::move(from);
  }
  const ::google::protobuf::Message::ClassData* GetClassData() const PROTOBUF_FINAL;
  static const ::google::protobuf::Message::ClassDataFull _class_data_;

 public:
  ::google::protobuf::Metadata GetMetadata() const;
  // nested types ----------------------------------------------------

  // accessors -------------------------------------------------------
  enum : int {
    kBlockCountsFieldNumber = 1,
    kThreadCountsPerBlockFieldNumber = 2,
  };
  // .stream_executor.BlockDimProto block_counts = 1;
  bool has_block_counts() const;
  void clear_block_counts() ;
  const ::stream_executor::BlockDimProto& block_counts() const;
  PROTOBUF_NODISCARD ::stream_executor::BlockDimProto* release_block_counts();
  ::stream_executor::BlockDimProto* mutable_block_counts();
  void set_allocated_block_counts(::stream_executor::BlockDimProto* value);
  void unsafe_arena_set_allocated_block_counts(::stream_executor::BlockDimProto* value);
  ::stream_executor::BlockDimProto* unsafe_arena_release_block_counts();

  private:
  const ::stream_executor::BlockDimProto& _internal_block_counts() const;
  ::stream_executor::BlockDimProto* _internal_mutable_block_counts();

  public:
  // .stream_executor.ThreadDimProto thread_counts_per_block = 2;
  bool has_thread_counts_per_block() const;
  void clear_thread_counts_per_block() ;
  const ::stream_executor::ThreadDimProto& thread_counts_per_block() const;
  PROTOBUF_NODISCARD ::stream_executor::ThreadDimProto* release_thread_counts_per_block();
  ::stream_executor::ThreadDimProto* mutable_thread_counts_per_block();
  void set_allocated_thread_counts_per_block(::stream_executor::ThreadDimProto* value);
  void unsafe_arena_set_allocated_thread_counts_per_block(::stream_executor::ThreadDimProto* value);
  ::stream_executor::ThreadDimProto* unsafe_arena_release_thread_counts_per_block();

  private:
  const ::stream_executor::ThreadDimProto& _internal_thread_counts_per_block() const;
  ::stream_executor::ThreadDimProto* _internal_mutable_thread_counts_per_block();

  public:
  // @@protoc_insertion_point(class_scope:xla.gpu.LaunchDimensionsProto)
 private:
  class _Internal;
  friend class ::google::protobuf::internal::TcParser;
  static const ::google::protobuf::internal::TcParseTable<
      1, 2, 2,
      0, 2>
      _table_;


  friend class ::google::protobuf::MessageLite;
  friend class ::google::protobuf::Arena;
  template <typename T>
  friend class ::google::protobuf::Arena::InternalHelper;
  using InternalArenaConstructable_ = void;
  using DestructorSkippable_ = void;
  struct Impl_ {
    inline explicit constexpr Impl_(
        ::google::protobuf::internal::ConstantInitialized) noexcept;
    inline explicit Impl_(::google::protobuf::internal::InternalVisibility visibility,
                          ::google::protobuf::Arena* arena);
    inline explicit Impl_(::google::protobuf::internal::InternalVisibility visibility,
                          ::google::protobuf::Arena* arena, const Impl_& from,
                          const LaunchDimensionsProto& from_msg);
    ::google::protobuf::internal::HasBits<1> _has_bits_;
    mutable ::google::protobuf::internal::CachedSize _cached_size_;
    ::stream_executor::BlockDimProto* block_counts_;
    ::stream_executor::ThreadDimProto* thread_counts_per_block_;
    PROTOBUF_TSAN_DECLARE_MEMBER
  };
  union { Impl_ _impl_; };
  friend struct ::TableStruct_xla_2fservice_2fgpu_2flaunch_5fdimensions_2eproto;
};

// ===================================================================




// ===================================================================


#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wstrict-aliasing"
#endif  // __GNUC__
// -------------------------------------------------------------------

// LaunchDimensionsProto

// .stream_executor.BlockDimProto block_counts = 1;
inline bool LaunchDimensionsProto::has_block_counts() const {
  bool value = (_impl_._has_bits_[0] & 0x00000001u) != 0;
  PROTOBUF_ASSUME(!value || _impl_.block_counts_ != nullptr);
  return value;
}
inline const ::stream_executor::BlockDimProto& LaunchDimensionsProto::_internal_block_counts() const {
  ::google::protobuf::internal::TSanRead(&_impl_);
  const ::stream_executor::BlockDimProto* p = _impl_.block_counts_;
  return p != nullptr ? *p : reinterpret_cast<const ::stream_executor::BlockDimProto&>(::stream_executor::_BlockDimProto_default_instance_);
}
inline const ::stream_executor::BlockDimProto& LaunchDimensionsProto::block_counts() const ABSL_ATTRIBUTE_LIFETIME_BOUND {
  // @@protoc_insertion_point(field_get:xla.gpu.LaunchDimensionsProto.block_counts)
  return _internal_block_counts();
}
inline void LaunchDimensionsProto::unsafe_arena_set_allocated_block_counts(::stream_executor::BlockDimProto* value) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  if (GetArena() == nullptr) {
    delete reinterpret_cast<::google::protobuf::MessageLite*>(_impl_.block_counts_);
  }
  _impl_.block_counts_ = reinterpret_cast<::stream_executor::BlockDimProto*>(value);
  if (value != nullptr) {
    _impl_._has_bits_[0] |= 0x00000001u;
  } else {
    _impl_._has_bits_[0] &= ~0x00000001u;
  }
  // @@protoc_insertion_point(field_unsafe_arena_set_allocated:xla.gpu.LaunchDimensionsProto.block_counts)
}
inline ::stream_executor::BlockDimProto* LaunchDimensionsProto::release_block_counts() {
  ::google::protobuf::internal::TSanWrite(&_impl_);

  _impl_._has_bits_[0] &= ~0x00000001u;
  ::stream_executor::BlockDimProto* released = _impl_.block_counts_;
  _impl_.block_counts_ = nullptr;
#ifdef PROTOBUF_FORCE_COPY_IN_RELEASE
  auto* old = reinterpret_cast<::google::protobuf::MessageLite*>(released);
  released = ::google::protobuf::internal::DuplicateIfNonNull(released);
  if (GetArena() == nullptr) {
    delete old;
  }
#else   // PROTOBUF_FORCE_COPY_IN_RELEASE
  if (GetArena() != nullptr) {
    released = ::google::protobuf::internal::DuplicateIfNonNull(released);
  }
#endif  // !PROTOBUF_FORCE_COPY_IN_RELEASE
  return released;
}
inline ::stream_executor::BlockDimProto* LaunchDimensionsProto::unsafe_arena_release_block_counts() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  // @@protoc_insertion_point(field_release:xla.gpu.LaunchDimensionsProto.block_counts)

  _impl_._has_bits_[0] &= ~0x00000001u;
  ::stream_executor::BlockDimProto* temp = _impl_.block_counts_;
  _impl_.block_counts_ = nullptr;
  return temp;
}
inline ::stream_executor::BlockDimProto* LaunchDimensionsProto::_internal_mutable_block_counts() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  if (_impl_.block_counts_ == nullptr) {
    auto* p = ::google::protobuf::Message::DefaultConstruct<::stream_executor::BlockDimProto>(GetArena());
    _impl_.block_counts_ = reinterpret_cast<::stream_executor::BlockDimProto*>(p);
  }
  return _impl_.block_counts_;
}
inline ::stream_executor::BlockDimProto* LaunchDimensionsProto::mutable_block_counts() ABSL_ATTRIBUTE_LIFETIME_BOUND {
  _impl_._has_bits_[0] |= 0x00000001u;
  ::stream_executor::BlockDimProto* _msg = _internal_mutable_block_counts();
  // @@protoc_insertion_point(field_mutable:xla.gpu.LaunchDimensionsProto.block_counts)
  return _msg;
}
inline void LaunchDimensionsProto::set_allocated_block_counts(::stream_executor::BlockDimProto* value) {
  ::google::protobuf::Arena* message_arena = GetArena();
  ::google::protobuf::internal::TSanWrite(&_impl_);
  if (message_arena == nullptr) {
    delete reinterpret_cast<::google::protobuf::MessageLite*>(_impl_.block_counts_);
  }

  if (value != nullptr) {
    ::google::protobuf::Arena* submessage_arena = reinterpret_cast<::google::protobuf::MessageLite*>(value)->GetArena();
    if (message_arena != submessage_arena) {
      value = ::google::protobuf::internal::GetOwnedMessage(message_arena, value, submessage_arena);
    }
    _impl_._has_bits_[0] |= 0x00000001u;
  } else {
    _impl_._has_bits_[0] &= ~0x00000001u;
  }

  _impl_.block_counts_ = reinterpret_cast<::stream_executor::BlockDimProto*>(value);
  // @@protoc_insertion_point(field_set_allocated:xla.gpu.LaunchDimensionsProto.block_counts)
}

// .stream_executor.ThreadDimProto thread_counts_per_block = 2;
inline bool LaunchDimensionsProto::has_thread_counts_per_block() const {
  bool value = (_impl_._has_bits_[0] & 0x00000002u) != 0;
  PROTOBUF_ASSUME(!value || _impl_.thread_counts_per_block_ != nullptr);
  return value;
}
inline const ::stream_executor::ThreadDimProto& LaunchDimensionsProto::_internal_thread_counts_per_block() const {
  ::google::protobuf::internal::TSanRead(&_impl_);
  const ::stream_executor::ThreadDimProto* p = _impl_.thread_counts_per_block_;
  return p != nullptr ? *p : reinterpret_cast<const ::stream_executor::ThreadDimProto&>(::stream_executor::_ThreadDimProto_default_instance_);
}
inline const ::stream_executor::ThreadDimProto& LaunchDimensionsProto::thread_counts_per_block() const ABSL_ATTRIBUTE_LIFETIME_BOUND {
  // @@protoc_insertion_point(field_get:xla.gpu.LaunchDimensionsProto.thread_counts_per_block)
  return _internal_thread_counts_per_block();
}
inline void LaunchDimensionsProto::unsafe_arena_set_allocated_thread_counts_per_block(::stream_executor::ThreadDimProto* value) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  if (GetArena() == nullptr) {
    delete reinterpret_cast<::google::protobuf::MessageLite*>(_impl_.thread_counts_per_block_);
  }
  _impl_.thread_counts_per_block_ = reinterpret_cast<::stream_executor::ThreadDimProto*>(value);
  if (value != nullptr) {
    _impl_._has_bits_[0] |= 0x00000002u;
  } else {
    _impl_._has_bits_[0] &= ~0x00000002u;
  }
  // @@protoc_insertion_point(field_unsafe_arena_set_allocated:xla.gpu.LaunchDimensionsProto.thread_counts_per_block)
}
inline ::stream_executor::ThreadDimProto* LaunchDimensionsProto::release_thread_counts_per_block() {
  ::google::protobuf::internal::TSanWrite(&_impl_);

  _impl_._has_bits_[0] &= ~0x00000002u;
  ::stream_executor::ThreadDimProto* released = _impl_.thread_counts_per_block_;
  _impl_.thread_counts_per_block_ = nullptr;
#ifdef PROTOBUF_FORCE_COPY_IN_RELEASE
  auto* old = reinterpret_cast<::google::protobuf::MessageLite*>(released);
  released = ::google::protobuf::internal::DuplicateIfNonNull(released);
  if (GetArena() == nullptr) {
    delete old;
  }
#else   // PROTOBUF_FORCE_COPY_IN_RELEASE
  if (GetArena() != nullptr) {
    released = ::google::protobuf::internal::DuplicateIfNonNull(released);
  }
#endif  // !PROTOBUF_FORCE_COPY_IN_RELEASE
  return released;
}
inline ::stream_executor::ThreadDimProto* LaunchDimensionsProto::unsafe_arena_release_thread_counts_per_block() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  // @@protoc_insertion_point(field_release:xla.gpu.LaunchDimensionsProto.thread_counts_per_block)

  _impl_._has_bits_[0] &= ~0x00000002u;
  ::stream_executor::ThreadDimProto* temp = _impl_.thread_counts_per_block_;
  _impl_.thread_counts_per_block_ = nullptr;
  return temp;
}
inline ::stream_executor::ThreadDimProto* LaunchDimensionsProto::_internal_mutable_thread_counts_per_block() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  if (_impl_.thread_counts_per_block_ == nullptr) {
    auto* p = ::google::protobuf::Message::DefaultConstruct<::stream_executor::ThreadDimProto>(GetArena());
    _impl_.thread_counts_per_block_ = reinterpret_cast<::stream_executor::ThreadDimProto*>(p);
  }
  return _impl_.thread_counts_per_block_;
}
inline ::stream_executor::ThreadDimProto* LaunchDimensionsProto::mutable_thread_counts_per_block() ABSL_ATTRIBUTE_LIFETIME_BOUND {
  _impl_._has_bits_[0] |= 0x00000002u;
  ::stream_executor::ThreadDimProto* _msg = _internal_mutable_thread_counts_per_block();
  // @@protoc_insertion_point(field_mutable:xla.gpu.LaunchDimensionsProto.thread_counts_per_block)
  return _msg;
}
inline void LaunchDimensionsProto::set_allocated_thread_counts_per_block(::stream_executor::ThreadDimProto* value) {
  ::google::protobuf::Arena* message_arena = GetArena();
  ::google::protobuf::internal::TSanWrite(&_impl_);
  if (message_arena == nullptr) {
    delete reinterpret_cast<::google::protobuf::MessageLite*>(_impl_.thread_counts_per_block_);
  }

  if (value != nullptr) {
    ::google::protobuf::Arena* submessage_arena = reinterpret_cast<::google::protobuf::MessageLite*>(value)->GetArena();
    if (message_arena != submessage_arena) {
      value = ::google::protobuf::internal::GetOwnedMessage(message_arena, value, submessage_arena);
    }
    _impl_._has_bits_[0] |= 0x00000002u;
  } else {
    _impl_._has_bits_[0] &= ~0x00000002u;
  }

  _impl_.thread_counts_per_block_ = reinterpret_cast<::stream_executor::ThreadDimProto*>(value);
  // @@protoc_insertion_point(field_set_allocated:xla.gpu.LaunchDimensionsProto.thread_counts_per_block)
}

#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif  // __GNUC__

// @@protoc_insertion_point(namespace_scope)
}  // namespace gpu
}  // namespace xla


// @@protoc_insertion_point(global_scope)

#include "google/protobuf/port_undef.inc"

#endif  // GOOGLE_PROTOBUF_INCLUDED_xla_2fservice_2fgpu_2flaunch_5fdimensions_2eproto_2epb_2eh
