SDL  2.0
VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo Struct Reference

#include <vulkan.hpp>

+ Collaboration diagram for VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo:

Public Member Functions

VULKAN_HPP_CONSTEXPR MemoryAllocateFlagsInfo (VULKAN_HPP_NAMESPACE::MemoryAllocateFlags flags_={}, uint32_t deviceMask_={}) VULKAN_HPP_NOEXCEPT
 
VULKAN_HPP_CONSTEXPR MemoryAllocateFlagsInfo (MemoryAllocateFlagsInfo const &rhs) VULKAN_HPP_NOEXCEPT=default
 
 MemoryAllocateFlagsInfo (VkMemoryAllocateFlagsInfo const &rhs) VULKAN_HPP_NOEXCEPT
 
MemoryAllocateFlagsInfooperator= (VkMemoryAllocateFlagsInfo const &rhs) VULKAN_HPP_NOEXCEPT
 
MemoryAllocateFlagsInfooperator= (MemoryAllocateFlagsInfo const &rhs) VULKAN_HPP_NOEXCEPT
 
MemoryAllocateFlagsInfosetPNext (const void *pNext_) VULKAN_HPP_NOEXCEPT
 
MemoryAllocateFlagsInfosetFlags (VULKAN_HPP_NAMESPACE::MemoryAllocateFlags flags_) VULKAN_HPP_NOEXCEPT
 
MemoryAllocateFlagsInfosetDeviceMask (uint32_t deviceMask_) VULKAN_HPP_NOEXCEPT
 
 operator VkMemoryAllocateFlagsInfo const & () const VULKAN_HPP_NOEXCEPT
 
 operator VkMemoryAllocateFlagsInfo & () VULKAN_HPP_NOEXCEPT
 
bool operator== (MemoryAllocateFlagsInfo const &rhs) const VULKAN_HPP_NOEXCEPT
 
bool operator!= (MemoryAllocateFlagsInfo const &rhs) const VULKAN_HPP_NOEXCEPT
 

Data Fields

const VULKAN_HPP_NAMESPACE::StructureType sType = StructureType::eMemoryAllocateFlagsInfo
 
const voidpNext = {}
 
VULKAN_HPP_NAMESPACE::MemoryAllocateFlags flags = {}
 
uint32_t deviceMask = {}
 

Static Public Attributes

static const bool allowDuplicate = false
 
static VULKAN_HPP_CONST_OR_CONSTEXPR StructureType structureType = StructureType::eMemoryAllocateFlagsInfo
 

Detailed Description

Definition at line 60494 of file vulkan.hpp.

Constructor & Destructor Documentation

◆ MemoryAllocateFlagsInfo() [1/3]

VULKAN_HPP_CONSTEXPR VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::MemoryAllocateFlagsInfo ( VULKAN_HPP_NAMESPACE::MemoryAllocateFlags  flags_ = {},
uint32_t  deviceMask_ = {} 
)
inline

Definition at line 60500 of file vulkan.hpp.

60500  {}, uint32_t deviceMask_ = {}) VULKAN_HPP_NOEXCEPT
60501  : flags( flags_ ), deviceMask( deviceMask_ )
60502  {}
unsigned int uint32_t
set set set set set set set set set set set set set set set set set set set set *set set set macro pixldst op &r &cond WK op &r &cond WK op &r &cond WK else op &m &cond &ia op &r &cond WK else op &m &cond &ia elseif elseif else error unsupported base if elseif elseif else error unsupported unaligned pixldst unaligned endm macro pixst base base else pixldst base endif endm macro PF base if bpp PF set rept prefetch_distance PF set OFFSET endr endif endm macro preload_leading_step2 base if bpp ifc DST PF PF else if bpp lsl PF PF lsl PF PF lsl PF PF PF else PF lsl PF lsl PF lsl PF endif SIZE macro preload_middle scratch_holds_offset if bpp if else PF PF endif endif endif endm macro preload_trailing base if bpp if bpp *pix_per_block PF PF lsl PF PF PF PF PF else PF lsl PF lsl PF PF PF PF PF base if bpp if narrow_case &&bpp<=dst_w_bpp) PF bic, WK0, base, #31 PF pld,[WK0] PF add, WK1, base, X, LSL #bpp_shift PF sub, WK1, WK1, #1 PF bic, WK1, WK1, #31 PF cmp, WK1, WK0 PF beq, 90f PF pld,[WK1]90:.else PF bic, WK0, base, #31 PF pld,[WK0] PF add, WK1, base, X, lsl #bpp_shift PF sub, WK1, WK1, #1 PF bic, WK1, WK1, #31 PF cmp, WK1, WK0 PF beq, 92f91:PF add, WK0, WK0, #32 PF cmp, WK0, WK1 PF pld,[WK0] PF bne, 91b92:.endif .endif.endm.macro conditional_process1_helper cond, process_head, process_tail, numbytes, firstreg, unaligned_src, unaligned_mask, decrementx process_head cond, numbytes, firstreg, unaligned_src, unaligned_mask, 0 .if decrementx sub &cond X, X, #8 *numbytes/dst_w_bpp .endif process_tail cond, numbytes, firstreg .if !((flags) &FLAG_PROCESS_DOES_STORE) pixst cond, numbytes, firstreg, DST .endif.endm.macro conditional_process1 cond, process_head, process_tail, numbytes, firstreg, unaligned_src, unaligned_mask, decrementx .if(flags) &FLAG_BRANCH_OVER .ifc cond, mi bpl 100f .endif .ifc cond, cs bcc 100f .endif .ifc cond, ne beq 100f .endif conditional_process1_helper, process_head, process_tail, numbytes, firstreg, unaligned_src, unaligned_mask, decrementx100:.else conditional_process1_helper cond, process_head, process_tail, numbytes, firstreg, unaligned_src, unaligned_mask, decrementx .endif.endm.macro conditional_process2 test, cond1, cond2, process_head, process_tail, numbytes1, numbytes2, firstreg1, firstreg2, unaligned_src, unaligned_mask, decrementx .if(flags) &(FLAG_DST_READWRITE|FLAG_BRANCH_OVER|FLAG_PROCESS_CORRUPTS_PSR|FLAG_PROCESS_DOES_STORE) test conditional_process1 cond1, process_head, process_tail, numbytes1, firstreg1, unaligned_src, unaligned_mask, decrementx .if(flags) &FLAG_PROCESS_CORRUPTS_PSR test .endif conditional_process1 cond2, process_head, process_tail, numbytes2, firstreg2, unaligned_src, unaligned_mask, decrementx .else test process_head cond1, numbytes1, firstreg1, unaligned_src, unaligned_mask, 0 process_head cond2, numbytes2, firstreg2, unaligned_src, unaligned_mask, 0 .if decrementx sub &cond1 X, X, #8 *numbytes1/dst_w_bpp sub &cond2 X, X, #8 *numbytes2/dst_w_bpp .endif process_tail cond1, numbytes1, firstreg1 process_tail cond2, numbytes2, firstreg2 pixst cond1, numbytes1, firstreg1, DST pixst cond2, numbytes2, firstreg2, DST .endif.endm.macro test_bits_1_0_ptr .if(flags) &FLAG_PROCESS_CORRUPTS_WK0 movs SCRATCH, X, lsl #32-1 .else movs SCRATCH, WK0, lsl #32-1 .endif.endm.macro test_bits_3_2_ptr .if(flags) &FLAG_PROCESS_CORRUPTS_WK0 movs SCRATCH, X, lsl #32-3 .else movs SCRATCH, WK0, lsl #32-3 .endif.endm.macro leading_15bytes process_head, process_tail .set DECREMENT_X, 1 .if(flags) &FLAG_PROCESS_CORRUPTS_WK0 .set DECREMENT_X, 0 sub X, X, WK0, lsr #dst_bpp_shift str X,[sp, #LINE_SAVED_REG_COUNT *4] mov X, WK0 .endif .if dst_w_bpp==8 conditional_process2 test_bits_1_0_ptr, mi, cs, process_head, process_tail, 1, 2, 1, 2, 1, 1, DECREMENT_X .elseif dst_w_bpp==16 test_bits_1_0_ptr conditional_process1 cs, process_head, process_tail, 2, 2, 1, 1, DECREMENT_X .endif conditional_process2 test_bits_3_2_ptr, mi, cs, process_head, process_tail, 4, 8, 1, 2, 1, 1, DECREMENT_X .if(flags) &FLAG_PROCESS_CORRUPTS_WK0 ldr X,[sp, #LINE_SAVED_REG_COUNT *4] .endif.endm.macro test_bits_3_2_pix movs SCRATCH, X, lsl #dst_bpp_shift+32-3.endm.macro test_bits_1_0_pix .if dst_w_bpp==8 movs SCRATCH, X, lsl #dst_bpp_shift+32-1 .else movs SCRATCH, X, lsr #1 .endif.endm.macro trailing_15bytes process_head, process_tail, unaligned_src, unaligned_mask conditional_process2 test_bits_3_2_pix, cs, mi, process_head, process_tail, 8, 4, 0, 2, unaligned_src, unaligned_mask, 0 .if dst_w_bpp==16 test_bits_1_0_pix conditional_process1 cs, process_head, process_tail, 2, 0, unaligned_src, unaligned_mask, 0 .elseif dst_w_bpp==8 conditional_process2 test_bits_1_0_pix, cs, mi, process_head, process_tail, 2, 1, 0, 1, unaligned_src, unaligned_mask, 0 .endif.endm.macro wide_case_inner_loop process_head, process_tail, unaligned_src, unaligned_mask, dst_alignment110:.set SUBBLOCK, 0 .rept pix_per_block *dst_w_bpp/128 process_head, 16, 0, unaligned_src, unaligned_mask, 1 .if(src_bpp > 0) &&(mask_bpp==0) &&((flags) &FLAG_PROCESS_PRESERVES_SCRATCH) preload_middle src_bpp, SRC, 1 .elseif(src_bpp==0) &&(mask_bpp > 0) &&((flags) &FLAG_PROCESS_PRESERVES_SCRATCH) preload_middle mask_bpp, MASK, 1 .else preload_middle src_bpp, SRC, 0 preload_middle mask_bpp, MASK, 0 .endif .if(dst_r_bpp > 0) &&((SUBBLOCK % 2)==0) &&(((flags) &FLAG_NO_PRELOAD_DST)==0) PF pld,[DST, #32 *prefetch_distance - dst_alignment] .endif process_tail, 16, 0 .if !((flags) &FLAG_PROCESS_DOES_STORE) pixst, 16, 0, DST .endif .set SUBBLOCK, SUBBLOCK+1 .endr subs X, X, #pix_per_block bhs 110b.endm.macro wide_case_inner_loop_and_trailing_pixels process_head, process_tail, process_inner_loop, exit_label, unaligned_src, unaligned_mask .if dst_r_bpp > tst bne process_inner_loop DST_PRELOAD_BIAS endif preload_trailing SRC preload_trailing MASK DST endif add medium_case_inner_loop_and_trailing_pixels unaligned_mask endm macro medium_case_inner_loop_and_trailing_pixels DST endif subs bhs tst beq exit_label trailing_15bytes unaligned_mask endm macro narrow_case_inner_loop_and_trailing_pixels unaligned_mask tst conditional_process1 trailing_15bytes unaligned_mask endm macro switch_on_alignment exit_label if bne endif if bne endif action if endif if bne endif action if endif endif endm macro end_of_line last_one if SINGLE_SCANLINE ifc b endif else if vars_spilled word LINE_SAVED_REGS endif subs if vars_spilled endif endif add STRIDE_D if src_bpp add STRIDE_S endif if mask_bpp add STRIDE_M endif if restore_x mov ORIG_W endif bhs loop_label ifc if vars_spilled b else b endif else flags_
VULKAN_HPP_NAMESPACE::MemoryAllocateFlags flags
Definition: vulkan.hpp:60576
#define VULKAN_HPP_NOEXCEPT
Definition: vulkan.hpp:179

◆ MemoryAllocateFlagsInfo() [2/3]

VULKAN_HPP_CONSTEXPR VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::MemoryAllocateFlagsInfo ( MemoryAllocateFlagsInfo const &  rhs)
default

◆ MemoryAllocateFlagsInfo() [3/3]

VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::MemoryAllocateFlagsInfo ( VkMemoryAllocateFlagsInfo const &  rhs)
inline

Definition at line 60506 of file vulkan.hpp.

60507  {
60508  *this = rhs;
60509  }

Member Function Documentation

◆ operator VkMemoryAllocateFlagsInfo &()

VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::operator VkMemoryAllocateFlagsInfo & ( )
inline

Definition at line 60548 of file vulkan.hpp.

60549  {
60550  return *reinterpret_cast<VkMemoryAllocateFlagsInfo*>( this );
60551  }

◆ operator VkMemoryAllocateFlagsInfo const &()

VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::operator VkMemoryAllocateFlagsInfo const & ( ) const
inline

Definition at line 60543 of file vulkan.hpp.

60544  {
60545  return *reinterpret_cast<const VkMemoryAllocateFlagsInfo*>( this );
60546  }

◆ operator!=()

bool VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::operator!= ( MemoryAllocateFlagsInfo const &  rhs) const
inline

Definition at line 60565 of file vulkan.hpp.

60566  {
60567  return !operator==( rhs );
60568  }
bool operator==(MemoryAllocateFlagsInfo const &rhs) const VULKAN_HPP_NOEXCEPT
Definition: vulkan.hpp:60557

References VULKAN_HPP_NAMESPACE::operator==().

◆ operator=() [1/2]

MemoryAllocateFlagsInfo& VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::operator= ( MemoryAllocateFlagsInfo const &  rhs)
inline

Definition at line 60518 of file vulkan.hpp.

60519  {
60520  memcpy( static_cast<void *>( this ), &rhs, sizeof( MemoryAllocateFlagsInfo ) );
60521  return *this;
60522  }
#define memcpy
Definition: SDL_malloc.c:630
VULKAN_HPP_CONSTEXPR MemoryAllocateFlagsInfo(VULKAN_HPP_NAMESPACE::MemoryAllocateFlags flags_={}, uint32_t deviceMask_={}) VULKAN_HPP_NOEXCEPT
Definition: vulkan.hpp:60500

References memcpy.

◆ operator=() [2/2]

MemoryAllocateFlagsInfo& VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::operator= ( VkMemoryAllocateFlagsInfo const &  rhs)
inline

Definition at line 60512 of file vulkan.hpp.

60513  {
60514  *this = *reinterpret_cast<VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo const *>( &rhs );
60515  return *this;
60516  }

◆ operator==()

bool VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::operator== ( MemoryAllocateFlagsInfo const &  rhs) const
inline

Definition at line 60557 of file vulkan.hpp.

60558  {
60559  return ( sType == rhs.sType )
60560  && ( pNext == rhs.pNext )
60561  && ( flags == rhs.flags )
60562  && ( deviceMask == rhs.deviceMask );
60563  }
GLbitfield flags
const VULKAN_HPP_NAMESPACE::StructureType sType
Definition: vulkan.hpp:60574

◆ setDeviceMask()

MemoryAllocateFlagsInfo& VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::setDeviceMask ( uint32_t  deviceMask_)
inline

Definition at line 60536 of file vulkan.hpp.

60537  {
60538  deviceMask = deviceMask_;
60539  return *this;
60540  }

◆ setFlags()

MemoryAllocateFlagsInfo& VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::setFlags ( VULKAN_HPP_NAMESPACE::MemoryAllocateFlags  flags_)
inline

Definition at line 60530 of file vulkan.hpp.

60531  {
60532  flags = flags_;
60533  return *this;
60534  }

References flags_.

◆ setPNext()

MemoryAllocateFlagsInfo& VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::setPNext ( const void pNext_)
inline

Definition at line 60524 of file vulkan.hpp.

60525  {
60526  pNext = pNext_;
60527  return *this;
60528  }

Field Documentation

◆ allowDuplicate

const bool VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::allowDuplicate = false
static

Definition at line 60496 of file vulkan.hpp.

◆ deviceMask

uint32_t VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::deviceMask = {}

Definition at line 60577 of file vulkan.hpp.

◆ flags

VULKAN_HPP_NAMESPACE::MemoryAllocateFlags VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::flags = {}

Definition at line 60576 of file vulkan.hpp.

◆ pNext

const void* VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::pNext = {}

Definition at line 60575 of file vulkan.hpp.

◆ structureType

VULKAN_HPP_CONST_OR_CONSTEXPR StructureType VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::structureType = StructureType::eMemoryAllocateFlagsInfo
static

Definition at line 60497 of file vulkan.hpp.

◆ sType

const VULKAN_HPP_NAMESPACE::StructureType VULKAN_HPP_NAMESPACE::MemoryAllocateFlagsInfo::sType = StructureType::eMemoryAllocateFlagsInfo

Definition at line 60574 of file vulkan.hpp.


The documentation for this struct was generated from the following file: