mirror of
https://github.com/ZDoom/gzdoom.git
synced 2025-01-21 17:11:04 +00:00
Merge branch 'master' into lightmaps2
This commit is contained in:
commit
f216ca4ea8
279 changed files with 19936 additions and 5340 deletions
3
.gitmodules
vendored
3
.gitmodules
vendored
|
@ -1,3 +0,0 @@
|
||||||
[submodule "wadsrc_widescreen/static"]
|
|
||||||
path = wadsrc_widescreen/static
|
|
||||||
url = https://github.com/nashmuhandes/WidePix
|
|
|
@ -288,7 +288,7 @@ else()
|
||||||
|
|
||||||
|
|
||||||
if( APPLE )
|
if( APPLE )
|
||||||
set(CMAKE_OSX_DEPLOYMENT_TARGET "10.9")
|
set(CMAKE_OSX_DEPLOYMENT_TARGET "10.12")
|
||||||
if( CMAKE_CXX_COMPILER_ID STREQUAL "GNU" )
|
if( CMAKE_CXX_COMPILER_ID STREQUAL "GNU" )
|
||||||
# If we're compiling with a custom GCC on the Mac (which we know since g++-4.2 doesn't support C++11) statically link libgcc.
|
# If we're compiling with a custom GCC on the Mac (which we know since g++-4.2 doesn't support C++11) statically link libgcc.
|
||||||
set( ALL_C_FLAGS "-static-libgcc" )
|
set( ALL_C_FLAGS "-static-libgcc" )
|
||||||
|
@ -414,7 +414,7 @@ add_subdirectory( wadsrc )
|
||||||
add_subdirectory( wadsrc_bm )
|
add_subdirectory( wadsrc_bm )
|
||||||
add_subdirectory( wadsrc_lights )
|
add_subdirectory( wadsrc_lights )
|
||||||
add_subdirectory( wadsrc_extra )
|
add_subdirectory( wadsrc_extra )
|
||||||
add_subdirectory( wadsrc_widescreen )
|
add_subdirectory( wadsrc_widepix )
|
||||||
add_subdirectory( src )
|
add_subdirectory( src )
|
||||||
|
|
||||||
if( NOT CMAKE_CROSSCOMPILING )
|
if( NOT CMAKE_CROSSCOMPILING )
|
||||||
|
|
|
@ -716,6 +716,7 @@ set( NOT_COMPILED_SOURCE_FILES
|
||||||
zcc-parse.c
|
zcc-parse.c
|
||||||
zcc-parse.h
|
zcc-parse.h
|
||||||
common/platform/win32/zutil.natvis
|
common/platform/win32/zutil.natvis
|
||||||
|
common/rendering/vulkan/thirdparty/vk_mem_alloc/vk_mem_alloc.natvis
|
||||||
)
|
)
|
||||||
|
|
||||||
set( VM_JIT_SOURCES
|
set( VM_JIT_SOURCES
|
||||||
|
@ -1406,6 +1407,7 @@ if( APPLE )
|
||||||
set_target_properties(zdoom PROPERTIES
|
set_target_properties(zdoom PROPERTIES
|
||||||
LINK_FLAGS "${LINK_FRAMEWORKS}"
|
LINK_FLAGS "${LINK_FRAMEWORKS}"
|
||||||
MACOSX_BUNDLE_INFO_PLIST "${CMAKE_CURRENT_SOURCE_DIR}/posix/osx/zdoom-info.plist"
|
MACOSX_BUNDLE_INFO_PLIST "${CMAKE_CURRENT_SOURCE_DIR}/posix/osx/zdoom-info.plist"
|
||||||
|
XCODE_ATTRIBUTE_PRODUCT_BUNDLE_IDENTIFIER "org.drdteam.gzdoom"
|
||||||
XCODE_ATTRIBUTE_CODE_SIGN_IDENTITY "" )
|
XCODE_ATTRIBUTE_CODE_SIGN_IDENTITY "" )
|
||||||
|
|
||||||
# Dymanic libraries like libvulkan.dylib or libMoltenVK.dylib will be loaded by dlopen()
|
# Dymanic libraries like libvulkan.dylib or libMoltenVK.dylib will be loaded by dlopen()
|
||||||
|
|
|
@ -131,6 +131,8 @@ struct islope_t
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
|
|
||||||
CVAR(Bool, am_textured, false, CVAR_ARCHIVE)
|
CVAR(Bool, am_textured, false, CVAR_ARCHIVE)
|
||||||
|
CVAR(Float, am_linealpha, 1.0f, CVAR_ARCHIVE)
|
||||||
|
CVAR(Int, am_linethickness, 1, CVAR_ARCHIVE)
|
||||||
CVAR(Bool, am_thingrenderstyles, true, CVAR_ARCHIVE)
|
CVAR(Bool, am_thingrenderstyles, true, CVAR_ARCHIVE)
|
||||||
CVAR(Int, am_showsubsector, -1, 0);
|
CVAR(Int, am_showsubsector, -1, 0);
|
||||||
|
|
||||||
|
@ -1735,7 +1737,16 @@ void DAutomap::drawMline (mline_t *ml, const AMColor &color)
|
||||||
|
|
||||||
if (clipMline (ml, &fl))
|
if (clipMline (ml, &fl))
|
||||||
{
|
{
|
||||||
twod->AddLine (f_x + fl.a.x, f_y + fl.a.y, f_x + fl.b.x, f_y + fl.b.y, -1, -1, INT_MAX, INT_MAX, color.RGB);
|
const int x1 = f_x + fl.a.x;
|
||||||
|
const int y1 = f_y + fl.a.y;
|
||||||
|
const int x2 = f_x + fl.b.x;
|
||||||
|
const int y2 = f_y + fl.b.y;
|
||||||
|
if (am_linethickness >= 2) {
|
||||||
|
twod->AddThickLine(x1, y1, x2, y2, am_linethickness, color.RGB, uint8_t(am_linealpha * 255));
|
||||||
|
} else {
|
||||||
|
// Use more efficient thin line drawing routine.
|
||||||
|
twod->AddLine(x1, y1, x2, y2, -1, -1, INT_MAX, INT_MAX, color.RGB, uint8_t(am_linealpha * 255));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3130,11 +3141,20 @@ void DAutomap::drawAuthorMarkers ()
|
||||||
auto it = Level->GetActorIterator(mark->args[0]);
|
auto it = Level->GetActorIterator(mark->args[0]);
|
||||||
AActor *marked = mark->args[0] == 0 ? mark : it.Next();
|
AActor *marked = mark->args[0] == 0 ? mark : it.Next();
|
||||||
|
|
||||||
|
double xscale = mark->Scale.X;
|
||||||
|
double yscale = mark->Scale.Y;
|
||||||
|
// [MK] scale with automap zoom if args[2] is 1, otherwise keep a constant scale
|
||||||
|
if (mark->args[2] == 1)
|
||||||
|
{
|
||||||
|
xscale = MTOF(xscale);
|
||||||
|
yscale = MTOF(yscale);
|
||||||
|
}
|
||||||
|
|
||||||
while (marked != nullptr)
|
while (marked != nullptr)
|
||||||
{
|
{
|
||||||
if (mark->args[1] == 0 || (mark->args[1] == 1 && (marked->subsector->flags & SSECMF_DRAWN)))
|
if (mark->args[1] == 0 || (mark->args[1] == 1 && (marked->subsector->flags & SSECMF_DRAWN)))
|
||||||
{
|
{
|
||||||
DrawMarker (tex, marked->X(), marked->Y(), 0, flip, mark->Scale.X, mark->Scale.Y, mark->Translation,
|
DrawMarker (tex, marked->X(), marked->Y(), 0, flip, xscale, yscale, mark->Translation,
|
||||||
mark->Alpha, mark->fillcolor, mark->RenderStyle);
|
mark->Alpha, mark->fillcolor, mark->RenderStyle);
|
||||||
}
|
}
|
||||||
marked = mark->args[0] != 0 ? it.Next() : nullptr;
|
marked = mark->args[0] != 0 ? it.Next() : nullptr;
|
||||||
|
|
|
@ -284,11 +284,11 @@ uint8_t ModifierToDIK(const uint32_t modifier)
|
||||||
{
|
{
|
||||||
switch (modifier)
|
switch (modifier)
|
||||||
{
|
{
|
||||||
case NSAlphaShiftKeyMask: return DIK_CAPITAL;
|
case NSEventModifierFlagCapsLock: return DIK_CAPITAL;
|
||||||
case NSShiftKeyMask: return DIK_LSHIFT;
|
case NSEventModifierFlagShift: return DIK_LSHIFT;
|
||||||
case NSControlKeyMask: return DIK_LCONTROL;
|
case NSEventModifierFlagControl: return DIK_LCONTROL;
|
||||||
case NSAlternateKeyMask: return DIK_LMENU;
|
case NSEventModifierFlagOption: return DIK_LMENU;
|
||||||
case NSCommandKeyMask: return DIK_LWIN;
|
case NSEventModifierFlagCommand: return DIK_LWIN;
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -296,20 +296,20 @@ uint8_t ModifierToDIK(const uint32_t modifier)
|
||||||
|
|
||||||
int16_t ModifierFlagsToGUIKeyModifiers(NSEvent* theEvent)
|
int16_t ModifierFlagsToGUIKeyModifiers(NSEvent* theEvent)
|
||||||
{
|
{
|
||||||
const NSUInteger modifiers([theEvent modifierFlags] & NSDeviceIndependentModifierFlagsMask);
|
const NSUInteger modifiers([theEvent modifierFlags] & NSEventModifierFlagDeviceIndependentFlagsMask);
|
||||||
return ((modifiers & NSShiftKeyMask ) ? GKM_SHIFT : 0)
|
return ((modifiers & NSEventModifierFlagShift ) ? GKM_SHIFT : 0)
|
||||||
| ((modifiers & NSControlKeyMask ) ? GKM_CTRL : 0)
|
| ((modifiers & NSEventModifierFlagControl) ? GKM_CTRL : 0)
|
||||||
| ((modifiers & NSAlternateKeyMask) ? GKM_ALT : 0)
|
| ((modifiers & NSEventModifierFlagOption ) ? GKM_ALT : 0)
|
||||||
| ((modifiers & NSCommandKeyMask ) ? GKM_META : 0);
|
| ((modifiers & NSEventModifierFlagCommand) ? GKM_META : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ShouldGenerateGUICharEvent(NSEvent* theEvent)
|
bool ShouldGenerateGUICharEvent(NSEvent* theEvent)
|
||||||
{
|
{
|
||||||
const NSUInteger modifiers([theEvent modifierFlags] & NSDeviceIndependentModifierFlagsMask);
|
const NSUInteger modifiers([theEvent modifierFlags] & NSEventModifierFlagDeviceIndependentFlagsMask);
|
||||||
return !(modifiers & NSControlKeyMask)
|
return !(modifiers & NSEventModifierFlagControl)
|
||||||
&& !(modifiers & NSAlternateKeyMask)
|
&& !(modifiers & NSEventModifierFlagOption)
|
||||||
&& !(modifiers & NSCommandKeyMask)
|
&& !(modifiers & NSEventModifierFlagCommand)
|
||||||
&& !(modifiers & NSFunctionKeyMask);
|
&& !(modifiers & NSEventModifierFlagFunction);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -373,7 +373,7 @@ void ProcessKeyboardEventInMenu(NSEvent* theEvent)
|
||||||
|
|
||||||
unichar realchar;
|
unichar realchar;
|
||||||
event.type = EV_GUI_Event;
|
event.type = EV_GUI_Event;
|
||||||
event.subtype = NSKeyDown == [theEvent type] ? EV_GUI_KeyDown : EV_GUI_KeyUp;
|
event.subtype = NSEventTypeKeyDown == [theEvent type] ? EV_GUI_KeyDown : EV_GUI_KeyUp;
|
||||||
event.data2 = GetCharacterFromNSEvent(theEvent, &realchar);
|
event.data2 = GetCharacterFromNSEvent(theEvent, &realchar);
|
||||||
event.data3 = ModifierFlagsToGUIKeyModifiers(theEvent);
|
event.data3 = ModifierFlagsToGUIKeyModifiers(theEvent);
|
||||||
|
|
||||||
|
@ -505,8 +505,8 @@ void ProcessKeyboardEvent(NSEvent* theEvent)
|
||||||
|
|
||||||
if (k_allowfullscreentoggle
|
if (k_allowfullscreentoggle
|
||||||
&& (kVK_ANSI_F == keyCode)
|
&& (kVK_ANSI_F == keyCode)
|
||||||
&& (NSCommandKeyMask & [theEvent modifierFlags])
|
&& (NSEventModifierFlagCommand & [theEvent modifierFlags])
|
||||||
&& (NSKeyDown == [theEvent type])
|
&& (NSEventTypeKeyDown == [theEvent type])
|
||||||
&& !isARepeat)
|
&& !isARepeat)
|
||||||
{
|
{
|
||||||
ToggleFullscreen = !ToggleFullscreen;
|
ToggleFullscreen = !ToggleFullscreen;
|
||||||
|
@ -521,7 +521,7 @@ void ProcessKeyboardEvent(NSEvent* theEvent)
|
||||||
{
|
{
|
||||||
event_t event = {};
|
event_t event = {};
|
||||||
|
|
||||||
event.type = NSKeyDown == [theEvent type] ? EV_KeyDown : EV_KeyUp;
|
event.type = NSEventTypeKeyDown == [theEvent type] ? EV_KeyDown : EV_KeyUp;
|
||||||
event.data1 = KEYCODE_TO_DIK[ keyCode ];
|
event.data1 = KEYCODE_TO_DIK[ keyCode ];
|
||||||
|
|
||||||
if (0 != event.data1)
|
if (0 != event.data1)
|
||||||
|
@ -542,7 +542,7 @@ void ProcessKeyboardFlagsEvent(NSEvent* theEvent)
|
||||||
}
|
}
|
||||||
|
|
||||||
static const uint32_t FLAGS_MASK =
|
static const uint32_t FLAGS_MASK =
|
||||||
NSDeviceIndependentModifierFlagsMask & ~NSNumericPadKeyMask;
|
NSEventModifierFlagDeviceIndependentFlagsMask & ~NSEventModifierFlagNumericPad;
|
||||||
|
|
||||||
const uint32_t modifiers = [theEvent modifierFlags] & FLAGS_MASK;
|
const uint32_t modifiers = [theEvent modifierFlags] & FLAGS_MASK;
|
||||||
static uint32_t oldModifiers = 0;
|
static uint32_t oldModifiers = 0;
|
||||||
|
@ -611,12 +611,12 @@ void ProcessMouseButtonEvent(NSEvent* theEvent)
|
||||||
|
|
||||||
switch (cocoaEventType)
|
switch (cocoaEventType)
|
||||||
{
|
{
|
||||||
case NSLeftMouseDown: event.subtype = EV_GUI_LButtonDown; break;
|
case NSEventTypeLeftMouseDown: event.subtype = EV_GUI_LButtonDown; break;
|
||||||
case NSRightMouseDown: event.subtype = EV_GUI_RButtonDown; break;
|
case NSEventTypeRightMouseDown: event.subtype = EV_GUI_RButtonDown; break;
|
||||||
case NSOtherMouseDown: event.subtype = EV_GUI_MButtonDown; break;
|
case NSEventTypeOtherMouseDown: event.subtype = EV_GUI_MButtonDown; break;
|
||||||
case NSLeftMouseUp: event.subtype = EV_GUI_LButtonUp; break;
|
case NSEventTypeLeftMouseUp: event.subtype = EV_GUI_LButtonUp; break;
|
||||||
case NSRightMouseUp: event.subtype = EV_GUI_RButtonUp; break;
|
case NSEventTypeRightMouseUp: event.subtype = EV_GUI_RButtonUp; break;
|
||||||
case NSOtherMouseUp: event.subtype = EV_GUI_MButtonUp; break;
|
case NSEventTypeOtherMouseUp: event.subtype = EV_GUI_MButtonUp; break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -628,15 +628,15 @@ void ProcessMouseButtonEvent(NSEvent* theEvent)
|
||||||
{
|
{
|
||||||
switch (cocoaEventType)
|
switch (cocoaEventType)
|
||||||
{
|
{
|
||||||
case NSLeftMouseDown:
|
case NSEventTypeLeftMouseDown:
|
||||||
case NSRightMouseDown:
|
case NSEventTypeRightMouseDown:
|
||||||
case NSOtherMouseDown:
|
case NSEventTypeOtherMouseDown:
|
||||||
event.type = EV_KeyDown;
|
event.type = EV_KeyDown;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NSLeftMouseUp:
|
case NSEventTypeLeftMouseUp:
|
||||||
case NSRightMouseUp:
|
case NSEventTypeRightMouseUp:
|
||||||
case NSOtherMouseUp:
|
case NSEventTypeOtherMouseUp:
|
||||||
event.type = EV_KeyUp;
|
event.type = EV_KeyUp;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -694,36 +694,36 @@ void I_ProcessEvent(NSEvent* event)
|
||||||
|
|
||||||
switch (eventType)
|
switch (eventType)
|
||||||
{
|
{
|
||||||
case NSMouseMoved:
|
case NSEventTypeMouseMoved:
|
||||||
ProcessMouseMoveEvent(event);
|
ProcessMouseMoveEvent(event);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NSLeftMouseDown:
|
case NSEventTypeLeftMouseDown:
|
||||||
case NSLeftMouseUp:
|
case NSEventTypeLeftMouseUp:
|
||||||
case NSRightMouseDown:
|
case NSEventTypeRightMouseDown:
|
||||||
case NSRightMouseUp:
|
case NSEventTypeRightMouseUp:
|
||||||
case NSOtherMouseDown:
|
case NSEventTypeOtherMouseDown:
|
||||||
case NSOtherMouseUp:
|
case NSEventTypeOtherMouseUp:
|
||||||
ProcessMouseButtonEvent(event);
|
ProcessMouseButtonEvent(event);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NSLeftMouseDragged:
|
case NSEventTypeLeftMouseDragged:
|
||||||
case NSRightMouseDragged:
|
case NSEventTypeRightMouseDragged:
|
||||||
case NSOtherMouseDragged:
|
case NSEventTypeOtherMouseDragged:
|
||||||
ProcessMouseButtonEvent(event);
|
ProcessMouseButtonEvent(event);
|
||||||
ProcessMouseMoveEvent(event);
|
ProcessMouseMoveEvent(event);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NSScrollWheel:
|
case NSEventTypeScrollWheel:
|
||||||
ProcessMouseWheelEvent(event);
|
ProcessMouseWheelEvent(event);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NSKeyDown:
|
case NSEventTypeKeyDown:
|
||||||
case NSKeyUp:
|
case NSEventTypeKeyUp:
|
||||||
ProcessKeyboardEvent(event);
|
ProcessKeyboardEvent(event);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NSFlagsChanged:
|
case NSEventTypeFlagsChanged:
|
||||||
ProcessKeyboardFlagsEvent(event);
|
ProcessKeyboardFlagsEvent(event);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -396,7 +396,7 @@ extern bool AppActive;
|
||||||
|
|
||||||
while (true)
|
while (true)
|
||||||
{
|
{
|
||||||
NSEvent* event = [NSApp nextEventMatchingMask:NSAnyEventMask
|
NSEvent* event = [NSApp nextEventMatchingMask:NSEventMaskAny
|
||||||
untilDate:[NSDate dateWithTimeIntervalSinceNow:0]
|
untilDate:[NSDate dateWithTimeIntervalSinceNow:0]
|
||||||
inMode:NSDefaultRunLoopMode
|
inMode:NSDefaultRunLoopMode
|
||||||
dequeue:YES];
|
dequeue:YES];
|
||||||
|
@ -449,7 +449,7 @@ NSMenuItem* CreateApplicationMenu()
|
||||||
[[menu addItemWithTitle:@"Hide Others"
|
[[menu addItemWithTitle:@"Hide Others"
|
||||||
action:@selector(hideOtherApplications:)
|
action:@selector(hideOtherApplications:)
|
||||||
keyEquivalent:@"h"]
|
keyEquivalent:@"h"]
|
||||||
setKeyEquivalentModifierMask:NSAlternateKeyMask | NSCommandKeyMask];
|
setKeyEquivalentModifierMask:NSEventModifierFlagOption | NSEventModifierFlagCommand];
|
||||||
[menu addItemWithTitle:@"Show All"
|
[menu addItemWithTitle:@"Show All"
|
||||||
action:@selector(unhideAllApplications:)
|
action:@selector(unhideAllApplications:)
|
||||||
keyEquivalent:@""];
|
keyEquivalent:@""];
|
||||||
|
|
|
@ -121,8 +121,8 @@ namespace
|
||||||
const NSInteger LEVEL_FULLSCREEN = NSMainMenuWindowLevel + 1;
|
const NSInteger LEVEL_FULLSCREEN = NSMainMenuWindowLevel + 1;
|
||||||
const NSInteger LEVEL_WINDOWED = NSNormalWindowLevel;
|
const NSInteger LEVEL_WINDOWED = NSNormalWindowLevel;
|
||||||
|
|
||||||
const NSUInteger STYLE_MASK_FULLSCREEN = NSBorderlessWindowMask;
|
const NSUInteger STYLE_MASK_FULLSCREEN = NSWindowStyleMaskBorderless;
|
||||||
const NSUInteger STYLE_MASK_WINDOWED = NSTitledWindowMask | NSClosableWindowMask | NSMiniaturizableWindowMask | NSResizableWindowMask;
|
const NSUInteger STYLE_MASK_WINDOWED = NSWindowStyleMaskTitled | NSWindowStyleMaskClosable | NSWindowStyleMaskMiniaturizable | NSWindowStyleMaskResizable;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -104,7 +104,7 @@ FConsoleWindow::FConsoleWindow()
|
||||||
NSString* const title = [NSString stringWithFormat:@"%s %s - Console", GAMENAME, GetVersionString()];
|
NSString* const title = [NSString stringWithFormat:@"%s %s - Console", GAMENAME, GetVersionString()];
|
||||||
|
|
||||||
[m_window initWithContentRect:initialRect
|
[m_window initWithContentRect:initialRect
|
||||||
styleMask:NSTitledWindowMask | NSClosableWindowMask | NSResizableWindowMask
|
styleMask:NSWindowStyleMaskTitled | NSWindowStyleMaskClosable | NSWindowStyleMaskResizable
|
||||||
backing:NSBackingStoreBuffered
|
backing:NSBackingStoreBuffered
|
||||||
defer:NO];
|
defer:NO];
|
||||||
[m_window setMinSize:[m_window frame].size];
|
[m_window setMinSize:[m_window frame].size];
|
||||||
|
@ -348,7 +348,7 @@ void FConsoleWindow::SetTitleText()
|
||||||
NSTextField* titleText = [[NSTextField alloc] initWithFrame:titleTextRect];
|
NSTextField* titleText = [[NSTextField alloc] initWithFrame:titleTextRect];
|
||||||
[titleText setStringValue:[NSString stringWithCString:GameStartupInfo.Name.GetChars()
|
[titleText setStringValue:[NSString stringWithCString:GameStartupInfo.Name.GetChars()
|
||||||
encoding:NSISOLatin1StringEncoding]];
|
encoding:NSISOLatin1StringEncoding]];
|
||||||
[titleText setAlignment:NSCenterTextAlignment];
|
[titleText setAlignment:NSTextAlignmentCenter];
|
||||||
[titleText setTextColor:RGB(GameStartupInfo.FgColor)];
|
[titleText setTextColor:RGB(GameStartupInfo.FgColor)];
|
||||||
[titleText setBackgroundColor:RGB(GameStartupInfo.BkColor)];
|
[titleText setBackgroundColor:RGB(GameStartupInfo.BkColor)];
|
||||||
[titleText setFont:[NSFont fontWithName:@"Trebuchet MS Bold" size:18.0f]];
|
[titleText setFont:[NSFont fontWithName:@"Trebuchet MS Bold" size:18.0f]];
|
||||||
|
@ -434,7 +434,7 @@ void FConsoleWindow::NetInit(const char* const message, const int playerCount)
|
||||||
// Text with connected/total players count
|
// Text with connected/total players count
|
||||||
m_netCountText = [[NSTextField alloc] initWithFrame:NSMakeRect(428.0f, 64.0f, 72.0f, 16.0f)];
|
m_netCountText = [[NSTextField alloc] initWithFrame:NSMakeRect(428.0f, 64.0f, 72.0f, 16.0f)];
|
||||||
[m_netCountText setAutoresizingMask:NSViewMinXMargin];
|
[m_netCountText setAutoresizingMask:NSViewMinXMargin];
|
||||||
[m_netCountText setAlignment:NSRightTextAlignment];
|
[m_netCountText setAlignment:NSTextAlignmentRight];
|
||||||
[m_netCountText setDrawsBackground:NO];
|
[m_netCountText setDrawsBackground:NO];
|
||||||
[m_netCountText setSelectable:NO];
|
[m_netCountText setSelectable:NO];
|
||||||
[m_netCountText setBordered:NO];
|
[m_netCountText setBordered:NO];
|
||||||
|
|
|
@ -194,7 +194,7 @@ static NSArray* GetKnownExtensions()
|
||||||
[openPanel setResolvesAliases:YES];
|
[openPanel setResolvesAliases:YES];
|
||||||
[openPanel setAllowedFileTypes:GetKnownExtensions()];
|
[openPanel setAllowedFileTypes:GetKnownExtensions()];
|
||||||
|
|
||||||
if (NSOKButton == [openPanel runModal])
|
if (NSModalResponseOK == [openPanel runModal])
|
||||||
{
|
{
|
||||||
NSArray* files = [openPanel URLs];
|
NSArray* files = [openPanel URLs];
|
||||||
NSMutableString* parameters = [NSMutableString string];
|
NSMutableString* parameters = [NSMutableString string];
|
||||||
|
@ -259,7 +259,7 @@ static NSArray* GetKnownExtensions()
|
||||||
id windowTitle = [NSString stringWithFormat:@"%s %s", GAMENAME, GetVersionString()];
|
id windowTitle = [NSString stringWithFormat:@"%s %s", GAMENAME, GetVersionString()];
|
||||||
|
|
||||||
NSRect frame = NSMakeRect(0, 0, 440, 450);
|
NSRect frame = NSMakeRect(0, 0, 440, 450);
|
||||||
window = [[NSWindow alloc] initWithContentRect:frame styleMask:NSTitledWindowMask backing:NSBackingStoreBuffered defer:NO];
|
window = [[NSWindow alloc] initWithContentRect:frame styleMask:NSWindowStyleMaskTitled backing:NSBackingStoreBuffered defer:NO];
|
||||||
[window setTitle:windowTitle];
|
[window setTitle:windowTitle];
|
||||||
|
|
||||||
NSTextField *description = [[NSTextField alloc] initWithFrame:NSMakeRect(18, 384, 402, 50)];
|
NSTextField *description = [[NSTextField alloc] initWithFrame:NSMakeRect(18, 384, 402, 50)];
|
||||||
|
|
|
@ -49,6 +49,8 @@
|
||||||
#include <map>
|
#include <map>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
|
EXTERN_CVAR(Bool, r_skipmats)
|
||||||
|
|
||||||
namespace OpenGLRenderer
|
namespace OpenGLRenderer
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -733,6 +735,9 @@ FShader *FShaderManager::BindEffect(int effect, EPassType passType)
|
||||||
|
|
||||||
FShader *FShaderManager::Get(unsigned int eff, bool alphateston, EPassType passType)
|
FShader *FShaderManager::Get(unsigned int eff, bool alphateston, EPassType passType)
|
||||||
{
|
{
|
||||||
|
if (r_skipmats && eff >= 3 && eff <= 4)
|
||||||
|
eff = 0;
|
||||||
|
|
||||||
if (passType < mPassShaders.Size())
|
if (passType < mPassShaders.Size())
|
||||||
return mPassShaders[passType]->Get(eff, alphateston);
|
return mPassShaders[passType]->Get(eff, alphateston);
|
||||||
else
|
else
|
||||||
|
|
|
@ -894,7 +894,7 @@ void PPShadowMap::Update(PPRenderState* renderstate)
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
CVAR(Bool, gl_custompost, true, 0)
|
CVAR(Bool, gl_custompost, true, CVAR_ARCHIVE | CVAR_GLOBALCONFIG | CVAR_NOINITCALL)
|
||||||
|
|
||||||
void PPCustomShaders::Run(PPRenderState *renderstate, FString target)
|
void PPCustomShaders::Run(PPRenderState *renderstate, FString target)
|
||||||
{
|
{
|
||||||
|
|
|
@ -72,6 +72,8 @@ CVAR(Int, win_w, -1, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
|
||||||
CVAR(Int, win_h, -1, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
|
CVAR(Int, win_h, -1, CVAR_ARCHIVE | CVAR_GLOBALCONFIG)
|
||||||
CVAR(Bool, win_maximized, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG | CVAR_NOINITCALL)
|
CVAR(Bool, win_maximized, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG | CVAR_NOINITCALL)
|
||||||
|
|
||||||
|
CVAR(Bool, r_skipmats, false, CVAR_ARCHIVE | CVAR_GLOBALCONFIG | CVAR_NOINITCALL)
|
||||||
|
|
||||||
// 0 means 'no pipelining' for non GLES2 and 4 elements for GLES2
|
// 0 means 'no pipelining' for non GLES2 and 4 elements for GLES2
|
||||||
CUSTOM_CVAR(Int, gl_pipeline_depth, 0, CVAR_ARCHIVE | CVAR_GLOBALCONFIG | CVAR_NOINITCALL)
|
CUSTOM_CVAR(Int, gl_pipeline_depth, 0, CVAR_ARCHIVE | CVAR_GLOBALCONFIG | CVAR_NOINITCALL)
|
||||||
{
|
{
|
||||||
|
|
|
@ -37,6 +37,7 @@
|
||||||
#include "hwrenderer/data/shaderuniforms.h"
|
#include "hwrenderer/data/shaderuniforms.h"
|
||||||
|
|
||||||
CVAR(Int, vk_submit_size, 1000, 0);
|
CVAR(Int, vk_submit_size, 1000, 0);
|
||||||
|
EXTERN_CVAR(Bool, r_skipmats)
|
||||||
|
|
||||||
VkRenderState::VkRenderState()
|
VkRenderState::VkRenderState()
|
||||||
{
|
{
|
||||||
|
@ -239,6 +240,8 @@ void VkRenderState::ApplyRenderPass(int dt)
|
||||||
int effectState = mMaterial.mOverrideShader >= 0 ? mMaterial.mOverrideShader : (mMaterial.mMaterial ? mMaterial.mMaterial->GetShaderIndex() : 0);
|
int effectState = mMaterial.mOverrideShader >= 0 ? mMaterial.mOverrideShader : (mMaterial.mMaterial ? mMaterial.mMaterial->GetShaderIndex() : 0);
|
||||||
pipelineKey.SpecialEffect = EFF_NONE;
|
pipelineKey.SpecialEffect = EFF_NONE;
|
||||||
pipelineKey.EffectState = mTextureEnabled ? effectState : SHADER_NoTexture;
|
pipelineKey.EffectState = mTextureEnabled ? effectState : SHADER_NoTexture;
|
||||||
|
if (r_skipmats && pipelineKey.EffectState >= 3 && pipelineKey.EffectState <= 4)
|
||||||
|
pipelineKey.EffectState = 0;
|
||||||
pipelineKey.AlphaTest = mAlphaThreshold >= 0.f;
|
pipelineKey.AlphaTest = mAlphaThreshold >= 0.f;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -220,6 +220,7 @@ void VulkanDevice::CreateAllocator()
|
||||||
allocinfo.flags = VMA_ALLOCATOR_CREATE_KHR_DEDICATED_ALLOCATION_BIT;
|
allocinfo.flags = VMA_ALLOCATOR_CREATE_KHR_DEDICATED_ALLOCATION_BIT;
|
||||||
allocinfo.physicalDevice = PhysicalDevice.Device;
|
allocinfo.physicalDevice = PhysicalDevice.Device;
|
||||||
allocinfo.device = device;
|
allocinfo.device = device;
|
||||||
|
allocinfo.instance = instance;
|
||||||
allocinfo.preferredLargeHeapBlockSize = 64 * 1024 * 1024;
|
allocinfo.preferredLargeHeapBlockSize = 64 * 1024 * 1024;
|
||||||
if (vmaCreateAllocator(&allocinfo, &allocator) != VK_SUCCESS)
|
if (vmaCreateAllocator(&allocinfo, &allocator) != VK_SUCCESS)
|
||||||
VulkanError("Unable to create allocator");
|
VulkanError("Unable to create allocator");
|
||||||
|
|
|
@ -2,4 +2,7 @@
|
||||||
#define VMA_IMPLEMENTATION
|
#define VMA_IMPLEMENTATION
|
||||||
#define VMA_STATIC_VULKAN_FUNCTIONS 1
|
#define VMA_STATIC_VULKAN_FUNCTIONS 1
|
||||||
|
|
||||||
|
#define VMA_NULLABLE
|
||||||
|
#define VMA_NOT_NULL
|
||||||
|
|
||||||
#include "vk_mem_alloc.h"
|
#include "vk_mem_alloc.h"
|
||||||
|
|
File diff suppressed because it is too large
Load diff
40
src/common/rendering/vulkan/thirdparty/vk_mem_alloc/vk_mem_alloc.natvis
vendored
Normal file
40
src/common/rendering/vulkan/thirdparty/vk_mem_alloc/vk_mem_alloc.natvis
vendored
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<AutoVisualizer xmlns="http://schemas.microsoft.com/vstudio/debugger/natvis/2010">
|
||||||
|
<Type Name="VmaRawList<*>">
|
||||||
|
<DisplayString>{{ Count={m_Count} }}</DisplayString>
|
||||||
|
<Expand>
|
||||||
|
<Item Name="[Count]">m_Count</Item>
|
||||||
|
<LinkedListItems>
|
||||||
|
<Size>m_Count</Size>
|
||||||
|
<HeadPointer>m_pFront</HeadPointer>
|
||||||
|
<NextPointer>pNext</NextPointer>
|
||||||
|
<ValueNode>Value</ValueNode>
|
||||||
|
</LinkedListItems>
|
||||||
|
</Expand>
|
||||||
|
</Type>
|
||||||
|
|
||||||
|
<Type Name="VmaList<*>">
|
||||||
|
<DisplayString>{{ Count={m_RawList.m_Count} }}</DisplayString>
|
||||||
|
<Expand>
|
||||||
|
<Item Name="[Count]">m_RawList.m_Count</Item>
|
||||||
|
<LinkedListItems>
|
||||||
|
<Size>m_RawList.m_Count</Size>
|
||||||
|
<HeadPointer>m_RawList.m_pFront</HeadPointer>
|
||||||
|
<NextPointer>pNext</NextPointer>
|
||||||
|
<ValueNode>Value</ValueNode>
|
||||||
|
</LinkedListItems>
|
||||||
|
</Expand>
|
||||||
|
</Type>
|
||||||
|
|
||||||
|
<Type Name="VmaVector<*>">
|
||||||
|
<DisplayString>{{ Count={m_Count} }}</DisplayString>
|
||||||
|
<Expand>
|
||||||
|
<Item Name="[Count]">m_Count</Item>
|
||||||
|
<Item Name="[Capacity]">m_Capacity</Item>
|
||||||
|
<ArrayItems>
|
||||||
|
<Size>m_Count</Size>
|
||||||
|
<ValuePointer>m_pArray</ValuePointer>
|
||||||
|
</ArrayItems>
|
||||||
|
</Expand>
|
||||||
|
</Type>
|
||||||
|
</AutoVisualizer>
|
|
@ -41,17 +41,45 @@
|
||||||
// that if the loader is older, it should automatically fail a
|
// that if the loader is older, it should automatically fail a
|
||||||
// call for any API version > 1.0. Otherwise, the loader will
|
// call for any API version > 1.0. Otherwise, the loader will
|
||||||
// manually determine if it can support the expected version.
|
// manually determine if it can support the expected version.
|
||||||
#define CURRENT_LOADER_ICD_INTERFACE_VERSION 5
|
// Version 6 - Add support for vk_icdEnumerateAdapterPhysicalDevices.
|
||||||
|
#define CURRENT_LOADER_ICD_INTERFACE_VERSION 6
|
||||||
#define MIN_SUPPORTED_LOADER_ICD_INTERFACE_VERSION 0
|
#define MIN_SUPPORTED_LOADER_ICD_INTERFACE_VERSION 0
|
||||||
#define MIN_PHYS_DEV_EXTENSION_ICD_INTERFACE_VERSION 4
|
#define MIN_PHYS_DEV_EXTENSION_ICD_INTERFACE_VERSION 4
|
||||||
typedef VkResult(VKAPI_PTR *PFN_vkNegotiateLoaderICDInterfaceVersion)(uint32_t *pVersion);
|
|
||||||
|
|
||||||
|
// Old typedefs that don't follow a proper naming convention but are preserved for compatibility
|
||||||
|
typedef VkResult(VKAPI_PTR *PFN_vkNegotiateLoaderICDInterfaceVersion)(uint32_t *pVersion);
|
||||||
// This is defined in vk_layer.h which will be found by the loader, but if an ICD is building against this
|
// This is defined in vk_layer.h which will be found by the loader, but if an ICD is building against this
|
||||||
// file directly, it won't be found.
|
// file directly, it won't be found.
|
||||||
#ifndef PFN_GetPhysicalDeviceProcAddr
|
#ifndef PFN_GetPhysicalDeviceProcAddr
|
||||||
typedef PFN_vkVoidFunction(VKAPI_PTR *PFN_GetPhysicalDeviceProcAddr)(VkInstance instance, const char *pName);
|
typedef PFN_vkVoidFunction(VKAPI_PTR *PFN_GetPhysicalDeviceProcAddr)(VkInstance instance, const char *pName);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Typedefs for loader/ICD interface
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vk_icdNegotiateLoaderICDInterfaceVersion)(uint32_t* pVersion);
|
||||||
|
typedef PFN_vkVoidFunction (VKAPI_PTR *PFN_vk_icdGetInstanceProcAddr)(VkInstance instance, const char* pName);
|
||||||
|
typedef PFN_vkVoidFunction (VKAPI_PTR *PFN_vk_icdGetPhysicalDeviceProcAddr)(VkInstance instance, const char* pName);
|
||||||
|
#if defined(VK_USE_PLATFORM_WIN32_KHR)
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vk_icdEnumerateAdapterPhysicalDevices)(VkInstance instance, LUID adapterLUID,
|
||||||
|
uint32_t* pPhysicalDeviceCount, VkPhysicalDevice* pPhysicalDevices);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Prototypes for loader/ICD interface
|
||||||
|
#if !defined(VK_NO_PROTOTYPES)
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vk_icdNegotiateLoaderICDInterfaceVersion(uint32_t* pVersion);
|
||||||
|
VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vk_icdGetInstanceProcAddr(VkInstance instance, const char* pName);
|
||||||
|
VKAPI_ATTR PFN_vkVoidFunction VKAPI_CALL vk_icdGetPhysicalDeviceProcAddr(VkInstance isntance, const char* pName);
|
||||||
|
#if defined(VK_USE_PLATFORM_WIN32_KHR)
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vk_icdEnumerateAdapterPhysicalDevices(VkInstance instance, LUID adapterLUID,
|
||||||
|
uint32_t* pPhysicalDeviceCount, VkPhysicalDevice* pPhysicalDevices);
|
||||||
|
#endif
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The ICD must reserve space for a pointer for the loader's dispatch
|
* The ICD must reserve space for a pointer for the loader's dispatch
|
||||||
* table, at the start of <each object>.
|
* table, at the start of <each object>.
|
||||||
|
@ -89,7 +117,12 @@ typedef enum {
|
||||||
VK_ICD_WSI_PLATFORM_MACOS,
|
VK_ICD_WSI_PLATFORM_MACOS,
|
||||||
VK_ICD_WSI_PLATFORM_IOS,
|
VK_ICD_WSI_PLATFORM_IOS,
|
||||||
VK_ICD_WSI_PLATFORM_DISPLAY,
|
VK_ICD_WSI_PLATFORM_DISPLAY,
|
||||||
VK_ICD_WSI_PLATFORM_HEADLESS
|
VK_ICD_WSI_PLATFORM_HEADLESS,
|
||||||
|
VK_ICD_WSI_PLATFORM_METAL,
|
||||||
|
VK_ICD_WSI_PLATFORM_DIRECTFB,
|
||||||
|
VK_ICD_WSI_PLATFORM_VI,
|
||||||
|
VK_ICD_WSI_PLATFORM_GGP,
|
||||||
|
VK_ICD_WSI_PLATFORM_SCREEN,
|
||||||
} VkIcdWsiPlatform;
|
} VkIcdWsiPlatform;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -136,6 +169,14 @@ typedef struct {
|
||||||
} VkIcdSurfaceXlib;
|
} VkIcdSurfaceXlib;
|
||||||
#endif // VK_USE_PLATFORM_XLIB_KHR
|
#endif // VK_USE_PLATFORM_XLIB_KHR
|
||||||
|
|
||||||
|
#ifdef VK_USE_PLATFORM_DIRECTFB_EXT
|
||||||
|
typedef struct {
|
||||||
|
VkIcdSurfaceBase base;
|
||||||
|
IDirectFB *dfb;
|
||||||
|
IDirectFBSurface *surface;
|
||||||
|
} VkIcdSurfaceDirectFB;
|
||||||
|
#endif // VK_USE_PLATFORM_DIRECTFB_EXT
|
||||||
|
|
||||||
#ifdef VK_USE_PLATFORM_ANDROID_KHR
|
#ifdef VK_USE_PLATFORM_ANDROID_KHR
|
||||||
typedef struct {
|
typedef struct {
|
||||||
VkIcdSurfaceBase base;
|
VkIcdSurfaceBase base;
|
||||||
|
@ -157,6 +198,13 @@ typedef struct {
|
||||||
} VkIcdSurfaceIOS;
|
} VkIcdSurfaceIOS;
|
||||||
#endif // VK_USE_PLATFORM_IOS_MVK
|
#endif // VK_USE_PLATFORM_IOS_MVK
|
||||||
|
|
||||||
|
#ifdef VK_USE_PLATFORM_GGP
|
||||||
|
typedef struct {
|
||||||
|
VkIcdSurfaceBase base;
|
||||||
|
GgpStreamDescriptor streamDescriptor;
|
||||||
|
} VkIcdSurfaceGgp;
|
||||||
|
#endif // VK_USE_PLATFORM_GGP
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
VkIcdSurfaceBase base;
|
VkIcdSurfaceBase base;
|
||||||
VkDisplayModeKHR displayMode;
|
VkDisplayModeKHR displayMode;
|
||||||
|
@ -172,4 +220,26 @@ typedef struct {
|
||||||
VkIcdSurfaceBase base;
|
VkIcdSurfaceBase base;
|
||||||
} VkIcdSurfaceHeadless;
|
} VkIcdSurfaceHeadless;
|
||||||
|
|
||||||
|
#ifdef VK_USE_PLATFORM_METAL_EXT
|
||||||
|
typedef struct {
|
||||||
|
VkIcdSurfaceBase base;
|
||||||
|
const CAMetalLayer *pLayer;
|
||||||
|
} VkIcdSurfaceMetal;
|
||||||
|
#endif // VK_USE_PLATFORM_METAL_EXT
|
||||||
|
|
||||||
|
#ifdef VK_USE_PLATFORM_VI_NN
|
||||||
|
typedef struct {
|
||||||
|
VkIcdSurfaceBase base;
|
||||||
|
void *window;
|
||||||
|
} VkIcdSurfaceVi;
|
||||||
|
#endif // VK_USE_PLATFORM_VI_NN
|
||||||
|
|
||||||
|
#ifdef VK_USE_PLATFORM_SCREEN_QNX
|
||||||
|
typedef struct {
|
||||||
|
VkIcdSurfaceBase base;
|
||||||
|
struct _screen_context *context;
|
||||||
|
struct _screen_window *window;
|
||||||
|
} VkIcdSurfaceScreen;
|
||||||
|
#endif // VK_USE_PLATFORM_SCREEN_QNX
|
||||||
|
|
||||||
#endif // VKICD_H
|
#endif // VKICD_H
|
||||||
|
|
|
@ -83,7 +83,8 @@ typedef VkResult(VKAPI_PTR *PFN_PhysDevExt)(VkPhysicalDevice phys_device);
|
||||||
typedef enum VkLayerFunction_ {
|
typedef enum VkLayerFunction_ {
|
||||||
VK_LAYER_LINK_INFO = 0,
|
VK_LAYER_LINK_INFO = 0,
|
||||||
VK_LOADER_DATA_CALLBACK = 1,
|
VK_LOADER_DATA_CALLBACK = 1,
|
||||||
VK_LOADER_LAYER_CREATE_DEVICE_CALLBACK = 2
|
VK_LOADER_LAYER_CREATE_DEVICE_CALLBACK = 2,
|
||||||
|
VK_LOADER_FEATURES = 3,
|
||||||
} VkLayerFunction;
|
} VkLayerFunction;
|
||||||
|
|
||||||
typedef struct VkLayerInstanceLink_ {
|
typedef struct VkLayerInstanceLink_ {
|
||||||
|
@ -111,6 +112,12 @@ typedef VkResult (VKAPI_PTR *PFN_vkSetDeviceLoaderData)(VkDevice device,
|
||||||
typedef VkResult (VKAPI_PTR *PFN_vkLayerCreateDevice)(VkInstance instance, VkPhysicalDevice physicalDevice, const VkDeviceCreateInfo *pCreateInfo,
|
typedef VkResult (VKAPI_PTR *PFN_vkLayerCreateDevice)(VkInstance instance, VkPhysicalDevice physicalDevice, const VkDeviceCreateInfo *pCreateInfo,
|
||||||
const VkAllocationCallbacks *pAllocator, VkDevice *pDevice, PFN_vkGetInstanceProcAddr layerGIPA, PFN_vkGetDeviceProcAddr *nextGDPA);
|
const VkAllocationCallbacks *pAllocator, VkDevice *pDevice, PFN_vkGetInstanceProcAddr layerGIPA, PFN_vkGetDeviceProcAddr *nextGDPA);
|
||||||
typedef void (VKAPI_PTR *PFN_vkLayerDestroyDevice)(VkDevice physicalDevice, const VkAllocationCallbacks *pAllocator, PFN_vkDestroyDevice destroyFunction);
|
typedef void (VKAPI_PTR *PFN_vkLayerDestroyDevice)(VkDevice physicalDevice, const VkAllocationCallbacks *pAllocator, PFN_vkDestroyDevice destroyFunction);
|
||||||
|
|
||||||
|
typedef enum VkLoaderFeastureFlagBits {
|
||||||
|
VK_LOADER_FEATURE_PHYSICAL_DEVICE_SORTING = 0x00000001,
|
||||||
|
} VkLoaderFlagBits;
|
||||||
|
typedef VkFlags VkLoaderFeatureFlags;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
VkStructureType sType; // VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO
|
VkStructureType sType; // VK_STRUCTURE_TYPE_LOADER_INSTANCE_CREATE_INFO
|
||||||
const void *pNext;
|
const void *pNext;
|
||||||
|
@ -119,9 +126,10 @@ typedef struct {
|
||||||
VkLayerInstanceLink *pLayerInfo;
|
VkLayerInstanceLink *pLayerInfo;
|
||||||
PFN_vkSetInstanceLoaderData pfnSetInstanceLoaderData;
|
PFN_vkSetInstanceLoaderData pfnSetInstanceLoaderData;
|
||||||
struct {
|
struct {
|
||||||
PFN_vkLayerCreateDevice pfnLayerCreateDevice;
|
PFN_vkLayerCreateDevice pfnLayerCreateDevice;
|
||||||
PFN_vkLayerDestroyDevice pfnLayerDestroyDevice;
|
PFN_vkLayerDestroyDevice pfnLayerDestroyDevice;
|
||||||
} layerDevice;
|
} layerDevice;
|
||||||
|
VkLoaderFeatureFlags loaderFeatures;
|
||||||
} u;
|
} u;
|
||||||
} VkLayerInstanceCreateInfo;
|
} VkLayerInstanceCreateInfo;
|
||||||
|
|
||||||
|
|
|
@ -1,525 +0,0 @@
|
||||||
// *** THIS FILE IS GENERATED - DO NOT EDIT ***
|
|
||||||
// See loader_extension_generator.py for modifications
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Copyright (c) 2015-2017 The Khronos Group Inc.
|
|
||||||
* Copyright (c) 2015-2017 Valve Corporation
|
|
||||||
* Copyright (c) 2015-2017 LunarG, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*
|
|
||||||
* Author: Mark Lobodzinski <mark@lunarg.com>
|
|
||||||
* Author: Mark Young <marky@lunarg.com>
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
typedef PFN_vkVoidFunction (VKAPI_PTR *PFN_GetPhysicalDeviceProcAddr)(VkInstance instance, const char* pName);
|
|
||||||
|
|
||||||
// Instance function pointer dispatch table
|
|
||||||
typedef struct VkLayerInstanceDispatchTable_ {
|
|
||||||
// Manually add in GetPhysicalDeviceProcAddr entry
|
|
||||||
PFN_GetPhysicalDeviceProcAddr GetPhysicalDeviceProcAddr;
|
|
||||||
|
|
||||||
// ---- Core 1_0 commands
|
|
||||||
PFN_vkCreateInstance CreateInstance;
|
|
||||||
PFN_vkDestroyInstance DestroyInstance;
|
|
||||||
PFN_vkEnumeratePhysicalDevices EnumeratePhysicalDevices;
|
|
||||||
PFN_vkGetPhysicalDeviceFeatures GetPhysicalDeviceFeatures;
|
|
||||||
PFN_vkGetPhysicalDeviceFormatProperties GetPhysicalDeviceFormatProperties;
|
|
||||||
PFN_vkGetPhysicalDeviceImageFormatProperties GetPhysicalDeviceImageFormatProperties;
|
|
||||||
PFN_vkGetPhysicalDeviceProperties GetPhysicalDeviceProperties;
|
|
||||||
PFN_vkGetPhysicalDeviceQueueFamilyProperties GetPhysicalDeviceQueueFamilyProperties;
|
|
||||||
PFN_vkGetPhysicalDeviceMemoryProperties GetPhysicalDeviceMemoryProperties;
|
|
||||||
PFN_vkGetInstanceProcAddr GetInstanceProcAddr;
|
|
||||||
PFN_vkCreateDevice CreateDevice;
|
|
||||||
PFN_vkEnumerateInstanceExtensionProperties EnumerateInstanceExtensionProperties;
|
|
||||||
PFN_vkEnumerateDeviceExtensionProperties EnumerateDeviceExtensionProperties;
|
|
||||||
PFN_vkEnumerateInstanceLayerProperties EnumerateInstanceLayerProperties;
|
|
||||||
PFN_vkEnumerateDeviceLayerProperties EnumerateDeviceLayerProperties;
|
|
||||||
PFN_vkGetPhysicalDeviceSparseImageFormatProperties GetPhysicalDeviceSparseImageFormatProperties;
|
|
||||||
|
|
||||||
// ---- Core 1_1 commands
|
|
||||||
PFN_vkEnumerateInstanceVersion EnumerateInstanceVersion;
|
|
||||||
PFN_vkEnumeratePhysicalDeviceGroups EnumeratePhysicalDeviceGroups;
|
|
||||||
PFN_vkGetPhysicalDeviceFeatures2 GetPhysicalDeviceFeatures2;
|
|
||||||
PFN_vkGetPhysicalDeviceProperties2 GetPhysicalDeviceProperties2;
|
|
||||||
PFN_vkGetPhysicalDeviceFormatProperties2 GetPhysicalDeviceFormatProperties2;
|
|
||||||
PFN_vkGetPhysicalDeviceImageFormatProperties2 GetPhysicalDeviceImageFormatProperties2;
|
|
||||||
PFN_vkGetPhysicalDeviceQueueFamilyProperties2 GetPhysicalDeviceQueueFamilyProperties2;
|
|
||||||
PFN_vkGetPhysicalDeviceMemoryProperties2 GetPhysicalDeviceMemoryProperties2;
|
|
||||||
PFN_vkGetPhysicalDeviceSparseImageFormatProperties2 GetPhysicalDeviceSparseImageFormatProperties2;
|
|
||||||
PFN_vkGetPhysicalDeviceExternalBufferProperties GetPhysicalDeviceExternalBufferProperties;
|
|
||||||
PFN_vkGetPhysicalDeviceExternalFenceProperties GetPhysicalDeviceExternalFenceProperties;
|
|
||||||
PFN_vkGetPhysicalDeviceExternalSemaphoreProperties GetPhysicalDeviceExternalSemaphoreProperties;
|
|
||||||
|
|
||||||
// ---- VK_KHR_surface extension commands
|
|
||||||
PFN_vkDestroySurfaceKHR DestroySurfaceKHR;
|
|
||||||
PFN_vkGetPhysicalDeviceSurfaceSupportKHR GetPhysicalDeviceSurfaceSupportKHR;
|
|
||||||
PFN_vkGetPhysicalDeviceSurfaceCapabilitiesKHR GetPhysicalDeviceSurfaceCapabilitiesKHR;
|
|
||||||
PFN_vkGetPhysicalDeviceSurfaceFormatsKHR GetPhysicalDeviceSurfaceFormatsKHR;
|
|
||||||
PFN_vkGetPhysicalDeviceSurfacePresentModesKHR GetPhysicalDeviceSurfacePresentModesKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_swapchain extension commands
|
|
||||||
PFN_vkGetPhysicalDevicePresentRectanglesKHR GetPhysicalDevicePresentRectanglesKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_display extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceDisplayPropertiesKHR GetPhysicalDeviceDisplayPropertiesKHR;
|
|
||||||
PFN_vkGetPhysicalDeviceDisplayPlanePropertiesKHR GetPhysicalDeviceDisplayPlanePropertiesKHR;
|
|
||||||
PFN_vkGetDisplayPlaneSupportedDisplaysKHR GetDisplayPlaneSupportedDisplaysKHR;
|
|
||||||
PFN_vkGetDisplayModePropertiesKHR GetDisplayModePropertiesKHR;
|
|
||||||
PFN_vkCreateDisplayModeKHR CreateDisplayModeKHR;
|
|
||||||
PFN_vkGetDisplayPlaneCapabilitiesKHR GetDisplayPlaneCapabilitiesKHR;
|
|
||||||
PFN_vkCreateDisplayPlaneSurfaceKHR CreateDisplayPlaneSurfaceKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_xlib_surface extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_XLIB_KHR
|
|
||||||
PFN_vkCreateXlibSurfaceKHR CreateXlibSurfaceKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_XLIB_KHR
|
|
||||||
#ifdef VK_USE_PLATFORM_XLIB_KHR
|
|
||||||
PFN_vkGetPhysicalDeviceXlibPresentationSupportKHR GetPhysicalDeviceXlibPresentationSupportKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_XLIB_KHR
|
|
||||||
|
|
||||||
// ---- VK_KHR_xcb_surface extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_XCB_KHR
|
|
||||||
PFN_vkCreateXcbSurfaceKHR CreateXcbSurfaceKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_XCB_KHR
|
|
||||||
#ifdef VK_USE_PLATFORM_XCB_KHR
|
|
||||||
PFN_vkGetPhysicalDeviceXcbPresentationSupportKHR GetPhysicalDeviceXcbPresentationSupportKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_XCB_KHR
|
|
||||||
|
|
||||||
// ---- VK_KHR_wayland_surface extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_WAYLAND_KHR
|
|
||||||
PFN_vkCreateWaylandSurfaceKHR CreateWaylandSurfaceKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WAYLAND_KHR
|
|
||||||
#ifdef VK_USE_PLATFORM_WAYLAND_KHR
|
|
||||||
PFN_vkGetPhysicalDeviceWaylandPresentationSupportKHR GetPhysicalDeviceWaylandPresentationSupportKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WAYLAND_KHR
|
|
||||||
|
|
||||||
// ---- VK_KHR_mir_surface extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_MIR_KHR
|
|
||||||
PFN_vkCreateMirSurfaceKHR CreateMirSurfaceKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_MIR_KHR
|
|
||||||
#ifdef VK_USE_PLATFORM_MIR_KHR
|
|
||||||
PFN_vkGetPhysicalDeviceMirPresentationSupportKHR GetPhysicalDeviceMirPresentationSupportKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_MIR_KHR
|
|
||||||
|
|
||||||
// ---- VK_KHR_android_surface extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_ANDROID_KHR
|
|
||||||
PFN_vkCreateAndroidSurfaceKHR CreateAndroidSurfaceKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_ANDROID_KHR
|
|
||||||
|
|
||||||
// ---- VK_KHR_win32_surface extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
PFN_vkCreateWin32SurfaceKHR CreateWin32SurfaceKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
#ifdef VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
PFN_vkGetPhysicalDeviceWin32PresentationSupportKHR GetPhysicalDeviceWin32PresentationSupportKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
|
|
||||||
// ---- VK_KHR_get_physical_device_properties2 extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceFeatures2KHR GetPhysicalDeviceFeatures2KHR;
|
|
||||||
PFN_vkGetPhysicalDeviceProperties2KHR GetPhysicalDeviceProperties2KHR;
|
|
||||||
PFN_vkGetPhysicalDeviceFormatProperties2KHR GetPhysicalDeviceFormatProperties2KHR;
|
|
||||||
PFN_vkGetPhysicalDeviceImageFormatProperties2KHR GetPhysicalDeviceImageFormatProperties2KHR;
|
|
||||||
PFN_vkGetPhysicalDeviceQueueFamilyProperties2KHR GetPhysicalDeviceQueueFamilyProperties2KHR;
|
|
||||||
PFN_vkGetPhysicalDeviceMemoryProperties2KHR GetPhysicalDeviceMemoryProperties2KHR;
|
|
||||||
PFN_vkGetPhysicalDeviceSparseImageFormatProperties2KHR GetPhysicalDeviceSparseImageFormatProperties2KHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_device_group_creation extension commands
|
|
||||||
PFN_vkEnumeratePhysicalDeviceGroupsKHR EnumeratePhysicalDeviceGroupsKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_external_memory_capabilities extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceExternalBufferPropertiesKHR GetPhysicalDeviceExternalBufferPropertiesKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_external_semaphore_capabilities extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceExternalSemaphorePropertiesKHR GetPhysicalDeviceExternalSemaphorePropertiesKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_external_fence_capabilities extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceExternalFencePropertiesKHR GetPhysicalDeviceExternalFencePropertiesKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_get_surface_capabilities2 extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceSurfaceCapabilities2KHR GetPhysicalDeviceSurfaceCapabilities2KHR;
|
|
||||||
PFN_vkGetPhysicalDeviceSurfaceFormats2KHR GetPhysicalDeviceSurfaceFormats2KHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_get_display_properties2 extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceDisplayProperties2KHR GetPhysicalDeviceDisplayProperties2KHR;
|
|
||||||
PFN_vkGetPhysicalDeviceDisplayPlaneProperties2KHR GetPhysicalDeviceDisplayPlaneProperties2KHR;
|
|
||||||
PFN_vkGetDisplayModeProperties2KHR GetDisplayModeProperties2KHR;
|
|
||||||
PFN_vkGetDisplayPlaneCapabilities2KHR GetDisplayPlaneCapabilities2KHR;
|
|
||||||
|
|
||||||
// ---- VK_EXT_debug_report extension commands
|
|
||||||
PFN_vkCreateDebugReportCallbackEXT CreateDebugReportCallbackEXT;
|
|
||||||
PFN_vkDestroyDebugReportCallbackEXT DestroyDebugReportCallbackEXT;
|
|
||||||
PFN_vkDebugReportMessageEXT DebugReportMessageEXT;
|
|
||||||
|
|
||||||
// ---- VK_NV_external_memory_capabilities extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceExternalImageFormatPropertiesNV GetPhysicalDeviceExternalImageFormatPropertiesNV;
|
|
||||||
|
|
||||||
// ---- VK_NN_vi_surface extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_VI_NN
|
|
||||||
PFN_vkCreateViSurfaceNN CreateViSurfaceNN;
|
|
||||||
#endif // VK_USE_PLATFORM_VI_NN
|
|
||||||
|
|
||||||
// ---- VK_NVX_device_generated_commands extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceGeneratedCommandsPropertiesNVX GetPhysicalDeviceGeneratedCommandsPropertiesNVX;
|
|
||||||
|
|
||||||
// ---- VK_EXT_direct_mode_display extension commands
|
|
||||||
PFN_vkReleaseDisplayEXT ReleaseDisplayEXT;
|
|
||||||
|
|
||||||
// ---- VK_EXT_acquire_xlib_display extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_XLIB_XRANDR_EXT
|
|
||||||
PFN_vkAcquireXlibDisplayEXT AcquireXlibDisplayEXT;
|
|
||||||
#endif // VK_USE_PLATFORM_XLIB_XRANDR_EXT
|
|
||||||
#ifdef VK_USE_PLATFORM_XLIB_XRANDR_EXT
|
|
||||||
PFN_vkGetRandROutputDisplayEXT GetRandROutputDisplayEXT;
|
|
||||||
#endif // VK_USE_PLATFORM_XLIB_XRANDR_EXT
|
|
||||||
|
|
||||||
// ---- VK_EXT_display_surface_counter extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceSurfaceCapabilities2EXT GetPhysicalDeviceSurfaceCapabilities2EXT;
|
|
||||||
|
|
||||||
// ---- VK_MVK_ios_surface extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_IOS_MVK
|
|
||||||
PFN_vkCreateIOSSurfaceMVK CreateIOSSurfaceMVK;
|
|
||||||
#endif // VK_USE_PLATFORM_IOS_MVK
|
|
||||||
|
|
||||||
// ---- VK_MVK_macos_surface extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_MACOS_MVK
|
|
||||||
PFN_vkCreateMacOSSurfaceMVK CreateMacOSSurfaceMVK;
|
|
||||||
#endif // VK_USE_PLATFORM_MACOS_MVK
|
|
||||||
|
|
||||||
// ---- VK_EXT_debug_utils extension commands
|
|
||||||
PFN_vkCreateDebugUtilsMessengerEXT CreateDebugUtilsMessengerEXT;
|
|
||||||
PFN_vkDestroyDebugUtilsMessengerEXT DestroyDebugUtilsMessengerEXT;
|
|
||||||
PFN_vkSubmitDebugUtilsMessageEXT SubmitDebugUtilsMessageEXT;
|
|
||||||
|
|
||||||
// ---- VK_EXT_sample_locations extension commands
|
|
||||||
PFN_vkGetPhysicalDeviceMultisamplePropertiesEXT GetPhysicalDeviceMultisamplePropertiesEXT;
|
|
||||||
} VkLayerInstanceDispatchTable;
|
|
||||||
|
|
||||||
// Device function pointer dispatch table
|
|
||||||
typedef struct VkLayerDispatchTable_ {
|
|
||||||
|
|
||||||
// ---- Core 1_0 commands
|
|
||||||
PFN_vkGetDeviceProcAddr GetDeviceProcAddr;
|
|
||||||
PFN_vkDestroyDevice DestroyDevice;
|
|
||||||
PFN_vkGetDeviceQueue GetDeviceQueue;
|
|
||||||
PFN_vkQueueSubmit QueueSubmit;
|
|
||||||
PFN_vkQueueWaitIdle QueueWaitIdle;
|
|
||||||
PFN_vkDeviceWaitIdle DeviceWaitIdle;
|
|
||||||
PFN_vkAllocateMemory AllocateMemory;
|
|
||||||
PFN_vkFreeMemory FreeMemory;
|
|
||||||
PFN_vkMapMemory MapMemory;
|
|
||||||
PFN_vkUnmapMemory UnmapMemory;
|
|
||||||
PFN_vkFlushMappedMemoryRanges FlushMappedMemoryRanges;
|
|
||||||
PFN_vkInvalidateMappedMemoryRanges InvalidateMappedMemoryRanges;
|
|
||||||
PFN_vkGetDeviceMemoryCommitment GetDeviceMemoryCommitment;
|
|
||||||
PFN_vkBindBufferMemory BindBufferMemory;
|
|
||||||
PFN_vkBindImageMemory BindImageMemory;
|
|
||||||
PFN_vkGetBufferMemoryRequirements GetBufferMemoryRequirements;
|
|
||||||
PFN_vkGetImageMemoryRequirements GetImageMemoryRequirements;
|
|
||||||
PFN_vkGetImageSparseMemoryRequirements GetImageSparseMemoryRequirements;
|
|
||||||
PFN_vkQueueBindSparse QueueBindSparse;
|
|
||||||
PFN_vkCreateFence CreateFence;
|
|
||||||
PFN_vkDestroyFence DestroyFence;
|
|
||||||
PFN_vkResetFences ResetFences;
|
|
||||||
PFN_vkGetFenceStatus GetFenceStatus;
|
|
||||||
PFN_vkWaitForFences WaitForFences;
|
|
||||||
PFN_vkCreateSemaphore CreateSemaphore;
|
|
||||||
PFN_vkDestroySemaphore DestroySemaphore;
|
|
||||||
PFN_vkCreateEvent CreateEvent;
|
|
||||||
PFN_vkDestroyEvent DestroyEvent;
|
|
||||||
PFN_vkGetEventStatus GetEventStatus;
|
|
||||||
PFN_vkSetEvent SetEvent;
|
|
||||||
PFN_vkResetEvent ResetEvent;
|
|
||||||
PFN_vkCreateQueryPool CreateQueryPool;
|
|
||||||
PFN_vkDestroyQueryPool DestroyQueryPool;
|
|
||||||
PFN_vkGetQueryPoolResults GetQueryPoolResults;
|
|
||||||
PFN_vkCreateBuffer CreateBuffer;
|
|
||||||
PFN_vkDestroyBuffer DestroyBuffer;
|
|
||||||
PFN_vkCreateBufferView CreateBufferView;
|
|
||||||
PFN_vkDestroyBufferView DestroyBufferView;
|
|
||||||
PFN_vkCreateImage CreateImage;
|
|
||||||
PFN_vkDestroyImage DestroyImage;
|
|
||||||
PFN_vkGetImageSubresourceLayout GetImageSubresourceLayout;
|
|
||||||
PFN_vkCreateImageView CreateImageView;
|
|
||||||
PFN_vkDestroyImageView DestroyImageView;
|
|
||||||
PFN_vkCreateShaderModule CreateShaderModule;
|
|
||||||
PFN_vkDestroyShaderModule DestroyShaderModule;
|
|
||||||
PFN_vkCreatePipelineCache CreatePipelineCache;
|
|
||||||
PFN_vkDestroyPipelineCache DestroyPipelineCache;
|
|
||||||
PFN_vkGetPipelineCacheData GetPipelineCacheData;
|
|
||||||
PFN_vkMergePipelineCaches MergePipelineCaches;
|
|
||||||
PFN_vkCreateGraphicsPipelines CreateGraphicsPipelines;
|
|
||||||
PFN_vkCreateComputePipelines CreateComputePipelines;
|
|
||||||
PFN_vkDestroyPipeline DestroyPipeline;
|
|
||||||
PFN_vkCreatePipelineLayout CreatePipelineLayout;
|
|
||||||
PFN_vkDestroyPipelineLayout DestroyPipelineLayout;
|
|
||||||
PFN_vkCreateSampler CreateSampler;
|
|
||||||
PFN_vkDestroySampler DestroySampler;
|
|
||||||
PFN_vkCreateDescriptorSetLayout CreateDescriptorSetLayout;
|
|
||||||
PFN_vkDestroyDescriptorSetLayout DestroyDescriptorSetLayout;
|
|
||||||
PFN_vkCreateDescriptorPool CreateDescriptorPool;
|
|
||||||
PFN_vkDestroyDescriptorPool DestroyDescriptorPool;
|
|
||||||
PFN_vkResetDescriptorPool ResetDescriptorPool;
|
|
||||||
PFN_vkAllocateDescriptorSets AllocateDescriptorSets;
|
|
||||||
PFN_vkFreeDescriptorSets FreeDescriptorSets;
|
|
||||||
PFN_vkUpdateDescriptorSets UpdateDescriptorSets;
|
|
||||||
PFN_vkCreateFramebuffer CreateFramebuffer;
|
|
||||||
PFN_vkDestroyFramebuffer DestroyFramebuffer;
|
|
||||||
PFN_vkCreateRenderPass CreateRenderPass;
|
|
||||||
PFN_vkDestroyRenderPass DestroyRenderPass;
|
|
||||||
PFN_vkGetRenderAreaGranularity GetRenderAreaGranularity;
|
|
||||||
PFN_vkCreateCommandPool CreateCommandPool;
|
|
||||||
PFN_vkDestroyCommandPool DestroyCommandPool;
|
|
||||||
PFN_vkResetCommandPool ResetCommandPool;
|
|
||||||
PFN_vkAllocateCommandBuffers AllocateCommandBuffers;
|
|
||||||
PFN_vkFreeCommandBuffers FreeCommandBuffers;
|
|
||||||
PFN_vkBeginCommandBuffer BeginCommandBuffer;
|
|
||||||
PFN_vkEndCommandBuffer EndCommandBuffer;
|
|
||||||
PFN_vkResetCommandBuffer ResetCommandBuffer;
|
|
||||||
PFN_vkCmdBindPipeline CmdBindPipeline;
|
|
||||||
PFN_vkCmdSetViewport CmdSetViewport;
|
|
||||||
PFN_vkCmdSetScissor CmdSetScissor;
|
|
||||||
PFN_vkCmdSetLineWidth CmdSetLineWidth;
|
|
||||||
PFN_vkCmdSetDepthBias CmdSetDepthBias;
|
|
||||||
PFN_vkCmdSetBlendConstants CmdSetBlendConstants;
|
|
||||||
PFN_vkCmdSetDepthBounds CmdSetDepthBounds;
|
|
||||||
PFN_vkCmdSetStencilCompareMask CmdSetStencilCompareMask;
|
|
||||||
PFN_vkCmdSetStencilWriteMask CmdSetStencilWriteMask;
|
|
||||||
PFN_vkCmdSetStencilReference CmdSetStencilReference;
|
|
||||||
PFN_vkCmdBindDescriptorSets CmdBindDescriptorSets;
|
|
||||||
PFN_vkCmdBindIndexBuffer CmdBindIndexBuffer;
|
|
||||||
PFN_vkCmdBindVertexBuffers CmdBindVertexBuffers;
|
|
||||||
PFN_vkCmdDraw CmdDraw;
|
|
||||||
PFN_vkCmdDrawIndexed CmdDrawIndexed;
|
|
||||||
PFN_vkCmdDrawIndirect CmdDrawIndirect;
|
|
||||||
PFN_vkCmdDrawIndexedIndirect CmdDrawIndexedIndirect;
|
|
||||||
PFN_vkCmdDispatch CmdDispatch;
|
|
||||||
PFN_vkCmdDispatchIndirect CmdDispatchIndirect;
|
|
||||||
PFN_vkCmdCopyBuffer CmdCopyBuffer;
|
|
||||||
PFN_vkCmdCopyImage CmdCopyImage;
|
|
||||||
PFN_vkCmdBlitImage CmdBlitImage;
|
|
||||||
PFN_vkCmdCopyBufferToImage CmdCopyBufferToImage;
|
|
||||||
PFN_vkCmdCopyImageToBuffer CmdCopyImageToBuffer;
|
|
||||||
PFN_vkCmdUpdateBuffer CmdUpdateBuffer;
|
|
||||||
PFN_vkCmdFillBuffer CmdFillBuffer;
|
|
||||||
PFN_vkCmdClearColorImage CmdClearColorImage;
|
|
||||||
PFN_vkCmdClearDepthStencilImage CmdClearDepthStencilImage;
|
|
||||||
PFN_vkCmdClearAttachments CmdClearAttachments;
|
|
||||||
PFN_vkCmdResolveImage CmdResolveImage;
|
|
||||||
PFN_vkCmdSetEvent CmdSetEvent;
|
|
||||||
PFN_vkCmdResetEvent CmdResetEvent;
|
|
||||||
PFN_vkCmdWaitEvents CmdWaitEvents;
|
|
||||||
PFN_vkCmdPipelineBarrier CmdPipelineBarrier;
|
|
||||||
PFN_vkCmdBeginQuery CmdBeginQuery;
|
|
||||||
PFN_vkCmdEndQuery CmdEndQuery;
|
|
||||||
PFN_vkCmdResetQueryPool CmdResetQueryPool;
|
|
||||||
PFN_vkCmdWriteTimestamp CmdWriteTimestamp;
|
|
||||||
PFN_vkCmdCopyQueryPoolResults CmdCopyQueryPoolResults;
|
|
||||||
PFN_vkCmdPushConstants CmdPushConstants;
|
|
||||||
PFN_vkCmdBeginRenderPass CmdBeginRenderPass;
|
|
||||||
PFN_vkCmdNextSubpass CmdNextSubpass;
|
|
||||||
PFN_vkCmdEndRenderPass CmdEndRenderPass;
|
|
||||||
PFN_vkCmdExecuteCommands CmdExecuteCommands;
|
|
||||||
|
|
||||||
// ---- Core 1_1 commands
|
|
||||||
PFN_vkBindBufferMemory2 BindBufferMemory2;
|
|
||||||
PFN_vkBindImageMemory2 BindImageMemory2;
|
|
||||||
PFN_vkGetDeviceGroupPeerMemoryFeatures GetDeviceGroupPeerMemoryFeatures;
|
|
||||||
PFN_vkCmdSetDeviceMask CmdSetDeviceMask;
|
|
||||||
PFN_vkCmdDispatchBase CmdDispatchBase;
|
|
||||||
PFN_vkGetImageMemoryRequirements2 GetImageMemoryRequirements2;
|
|
||||||
PFN_vkGetBufferMemoryRequirements2 GetBufferMemoryRequirements2;
|
|
||||||
PFN_vkGetImageSparseMemoryRequirements2 GetImageSparseMemoryRequirements2;
|
|
||||||
PFN_vkTrimCommandPool TrimCommandPool;
|
|
||||||
PFN_vkGetDeviceQueue2 GetDeviceQueue2;
|
|
||||||
PFN_vkCreateSamplerYcbcrConversion CreateSamplerYcbcrConversion;
|
|
||||||
PFN_vkDestroySamplerYcbcrConversion DestroySamplerYcbcrConversion;
|
|
||||||
PFN_vkCreateDescriptorUpdateTemplate CreateDescriptorUpdateTemplate;
|
|
||||||
PFN_vkDestroyDescriptorUpdateTemplate DestroyDescriptorUpdateTemplate;
|
|
||||||
PFN_vkUpdateDescriptorSetWithTemplate UpdateDescriptorSetWithTemplate;
|
|
||||||
PFN_vkGetDescriptorSetLayoutSupport GetDescriptorSetLayoutSupport;
|
|
||||||
|
|
||||||
// ---- VK_KHR_swapchain extension commands
|
|
||||||
PFN_vkCreateSwapchainKHR CreateSwapchainKHR;
|
|
||||||
PFN_vkDestroySwapchainKHR DestroySwapchainKHR;
|
|
||||||
PFN_vkGetSwapchainImagesKHR GetSwapchainImagesKHR;
|
|
||||||
PFN_vkAcquireNextImageKHR AcquireNextImageKHR;
|
|
||||||
PFN_vkQueuePresentKHR QueuePresentKHR;
|
|
||||||
PFN_vkGetDeviceGroupPresentCapabilitiesKHR GetDeviceGroupPresentCapabilitiesKHR;
|
|
||||||
PFN_vkGetDeviceGroupSurfacePresentModesKHR GetDeviceGroupSurfacePresentModesKHR;
|
|
||||||
PFN_vkAcquireNextImage2KHR AcquireNextImage2KHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_display_swapchain extension commands
|
|
||||||
PFN_vkCreateSharedSwapchainsKHR CreateSharedSwapchainsKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_device_group extension commands
|
|
||||||
PFN_vkGetDeviceGroupPeerMemoryFeaturesKHR GetDeviceGroupPeerMemoryFeaturesKHR;
|
|
||||||
PFN_vkCmdSetDeviceMaskKHR CmdSetDeviceMaskKHR;
|
|
||||||
PFN_vkCmdDispatchBaseKHR CmdDispatchBaseKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_maintenance1 extension commands
|
|
||||||
PFN_vkTrimCommandPoolKHR TrimCommandPoolKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_external_memory_win32 extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
PFN_vkGetMemoryWin32HandleKHR GetMemoryWin32HandleKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
#ifdef VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
PFN_vkGetMemoryWin32HandlePropertiesKHR GetMemoryWin32HandlePropertiesKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
|
|
||||||
// ---- VK_KHR_external_memory_fd extension commands
|
|
||||||
PFN_vkGetMemoryFdKHR GetMemoryFdKHR;
|
|
||||||
PFN_vkGetMemoryFdPropertiesKHR GetMemoryFdPropertiesKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_external_semaphore_win32 extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
PFN_vkImportSemaphoreWin32HandleKHR ImportSemaphoreWin32HandleKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
#ifdef VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
PFN_vkGetSemaphoreWin32HandleKHR GetSemaphoreWin32HandleKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
|
|
||||||
// ---- VK_KHR_external_semaphore_fd extension commands
|
|
||||||
PFN_vkImportSemaphoreFdKHR ImportSemaphoreFdKHR;
|
|
||||||
PFN_vkGetSemaphoreFdKHR GetSemaphoreFdKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_push_descriptor extension commands
|
|
||||||
PFN_vkCmdPushDescriptorSetKHR CmdPushDescriptorSetKHR;
|
|
||||||
PFN_vkCmdPushDescriptorSetWithTemplateKHR CmdPushDescriptorSetWithTemplateKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_descriptor_update_template extension commands
|
|
||||||
PFN_vkCreateDescriptorUpdateTemplateKHR CreateDescriptorUpdateTemplateKHR;
|
|
||||||
PFN_vkDestroyDescriptorUpdateTemplateKHR DestroyDescriptorUpdateTemplateKHR;
|
|
||||||
PFN_vkUpdateDescriptorSetWithTemplateKHR UpdateDescriptorSetWithTemplateKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_shared_presentable_image extension commands
|
|
||||||
PFN_vkGetSwapchainStatusKHR GetSwapchainStatusKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_external_fence_win32 extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
PFN_vkImportFenceWin32HandleKHR ImportFenceWin32HandleKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
#ifdef VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
PFN_vkGetFenceWin32HandleKHR GetFenceWin32HandleKHR;
|
|
||||||
#endif // VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
|
|
||||||
// ---- VK_KHR_external_fence_fd extension commands
|
|
||||||
PFN_vkImportFenceFdKHR ImportFenceFdKHR;
|
|
||||||
PFN_vkGetFenceFdKHR GetFenceFdKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_get_memory_requirements2 extension commands
|
|
||||||
PFN_vkGetImageMemoryRequirements2KHR GetImageMemoryRequirements2KHR;
|
|
||||||
PFN_vkGetBufferMemoryRequirements2KHR GetBufferMemoryRequirements2KHR;
|
|
||||||
PFN_vkGetImageSparseMemoryRequirements2KHR GetImageSparseMemoryRequirements2KHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_sampler_ycbcr_conversion extension commands
|
|
||||||
PFN_vkCreateSamplerYcbcrConversionKHR CreateSamplerYcbcrConversionKHR;
|
|
||||||
PFN_vkDestroySamplerYcbcrConversionKHR DestroySamplerYcbcrConversionKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_bind_memory2 extension commands
|
|
||||||
PFN_vkBindBufferMemory2KHR BindBufferMemory2KHR;
|
|
||||||
PFN_vkBindImageMemory2KHR BindImageMemory2KHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_maintenance3 extension commands
|
|
||||||
PFN_vkGetDescriptorSetLayoutSupportKHR GetDescriptorSetLayoutSupportKHR;
|
|
||||||
|
|
||||||
// ---- VK_KHR_draw_indirect_count extension commands
|
|
||||||
PFN_vkCmdDrawIndirectCountKHR CmdDrawIndirectCountKHR;
|
|
||||||
PFN_vkCmdDrawIndexedIndirectCountKHR CmdDrawIndexedIndirectCountKHR;
|
|
||||||
|
|
||||||
// ---- VK_EXT_debug_marker extension commands
|
|
||||||
PFN_vkDebugMarkerSetObjectTagEXT DebugMarkerSetObjectTagEXT;
|
|
||||||
PFN_vkDebugMarkerSetObjectNameEXT DebugMarkerSetObjectNameEXT;
|
|
||||||
PFN_vkCmdDebugMarkerBeginEXT CmdDebugMarkerBeginEXT;
|
|
||||||
PFN_vkCmdDebugMarkerEndEXT CmdDebugMarkerEndEXT;
|
|
||||||
PFN_vkCmdDebugMarkerInsertEXT CmdDebugMarkerInsertEXT;
|
|
||||||
|
|
||||||
// ---- VK_AMD_draw_indirect_count extension commands
|
|
||||||
PFN_vkCmdDrawIndirectCountAMD CmdDrawIndirectCountAMD;
|
|
||||||
PFN_vkCmdDrawIndexedIndirectCountAMD CmdDrawIndexedIndirectCountAMD;
|
|
||||||
|
|
||||||
// ---- VK_AMD_shader_info extension commands
|
|
||||||
PFN_vkGetShaderInfoAMD GetShaderInfoAMD;
|
|
||||||
|
|
||||||
// ---- VK_NV_external_memory_win32 extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
PFN_vkGetMemoryWin32HandleNV GetMemoryWin32HandleNV;
|
|
||||||
#endif // VK_USE_PLATFORM_WIN32_KHR
|
|
||||||
|
|
||||||
// ---- VK_NVX_device_generated_commands extension commands
|
|
||||||
PFN_vkCmdProcessCommandsNVX CmdProcessCommandsNVX;
|
|
||||||
PFN_vkCmdReserveSpaceForCommandsNVX CmdReserveSpaceForCommandsNVX;
|
|
||||||
PFN_vkCreateIndirectCommandsLayoutNVX CreateIndirectCommandsLayoutNVX;
|
|
||||||
PFN_vkDestroyIndirectCommandsLayoutNVX DestroyIndirectCommandsLayoutNVX;
|
|
||||||
PFN_vkCreateObjectTableNVX CreateObjectTableNVX;
|
|
||||||
PFN_vkDestroyObjectTableNVX DestroyObjectTableNVX;
|
|
||||||
PFN_vkRegisterObjectsNVX RegisterObjectsNVX;
|
|
||||||
PFN_vkUnregisterObjectsNVX UnregisterObjectsNVX;
|
|
||||||
|
|
||||||
// ---- VK_NV_clip_space_w_scaling extension commands
|
|
||||||
PFN_vkCmdSetViewportWScalingNV CmdSetViewportWScalingNV;
|
|
||||||
|
|
||||||
// ---- VK_EXT_display_control extension commands
|
|
||||||
PFN_vkDisplayPowerControlEXT DisplayPowerControlEXT;
|
|
||||||
PFN_vkRegisterDeviceEventEXT RegisterDeviceEventEXT;
|
|
||||||
PFN_vkRegisterDisplayEventEXT RegisterDisplayEventEXT;
|
|
||||||
PFN_vkGetSwapchainCounterEXT GetSwapchainCounterEXT;
|
|
||||||
|
|
||||||
// ---- VK_GOOGLE_display_timing extension commands
|
|
||||||
PFN_vkGetRefreshCycleDurationGOOGLE GetRefreshCycleDurationGOOGLE;
|
|
||||||
PFN_vkGetPastPresentationTimingGOOGLE GetPastPresentationTimingGOOGLE;
|
|
||||||
|
|
||||||
// ---- VK_EXT_discard_rectangles extension commands
|
|
||||||
PFN_vkCmdSetDiscardRectangleEXT CmdSetDiscardRectangleEXT;
|
|
||||||
|
|
||||||
// ---- VK_EXT_hdr_metadata extension commands
|
|
||||||
PFN_vkSetHdrMetadataEXT SetHdrMetadataEXT;
|
|
||||||
|
|
||||||
// ---- VK_EXT_debug_utils extension commands
|
|
||||||
PFN_vkSetDebugUtilsObjectNameEXT SetDebugUtilsObjectNameEXT;
|
|
||||||
PFN_vkSetDebugUtilsObjectTagEXT SetDebugUtilsObjectTagEXT;
|
|
||||||
PFN_vkQueueBeginDebugUtilsLabelEXT QueueBeginDebugUtilsLabelEXT;
|
|
||||||
PFN_vkQueueEndDebugUtilsLabelEXT QueueEndDebugUtilsLabelEXT;
|
|
||||||
PFN_vkQueueInsertDebugUtilsLabelEXT QueueInsertDebugUtilsLabelEXT;
|
|
||||||
PFN_vkCmdBeginDebugUtilsLabelEXT CmdBeginDebugUtilsLabelEXT;
|
|
||||||
PFN_vkCmdEndDebugUtilsLabelEXT CmdEndDebugUtilsLabelEXT;
|
|
||||||
PFN_vkCmdInsertDebugUtilsLabelEXT CmdInsertDebugUtilsLabelEXT;
|
|
||||||
|
|
||||||
// ---- VK_ANDROID_external_memory_android_hardware_buffer extension commands
|
|
||||||
#ifdef VK_USE_PLATFORM_ANDROID_KHR
|
|
||||||
PFN_vkGetAndroidHardwareBufferPropertiesANDROID GetAndroidHardwareBufferPropertiesANDROID;
|
|
||||||
#endif // VK_USE_PLATFORM_ANDROID_KHR
|
|
||||||
#ifdef VK_USE_PLATFORM_ANDROID_KHR
|
|
||||||
PFN_vkGetMemoryAndroidHardwareBufferANDROID GetMemoryAndroidHardwareBufferANDROID;
|
|
||||||
#endif // VK_USE_PLATFORM_ANDROID_KHR
|
|
||||||
|
|
||||||
// ---- VK_EXT_sample_locations extension commands
|
|
||||||
PFN_vkCmdSetSampleLocationsEXT CmdSetSampleLocationsEXT;
|
|
||||||
|
|
||||||
// ---- VK_EXT_validation_cache extension commands
|
|
||||||
PFN_vkCreateValidationCacheEXT CreateValidationCacheEXT;
|
|
||||||
PFN_vkDestroyValidationCacheEXT DestroyValidationCacheEXT;
|
|
||||||
PFN_vkMergeValidationCachesEXT MergeValidationCachesEXT;
|
|
||||||
PFN_vkGetValidationCacheDataEXT GetValidationCacheDataEXT;
|
|
||||||
|
|
||||||
// ---- VK_EXT_external_memory_host extension commands
|
|
||||||
PFN_vkGetMemoryHostPointerPropertiesEXT GetMemoryHostPointerPropertiesEXT;
|
|
||||||
|
|
||||||
// ---- VK_AMD_buffer_marker extension commands
|
|
||||||
PFN_vkCmdWriteBufferMarkerAMD CmdWriteBufferMarkerAMD;
|
|
||||||
} VkLayerDispatchTable;
|
|
||||||
|
|
||||||
|
|
|
@ -2,19 +2,9 @@
|
||||||
// File: vk_platform.h
|
// File: vk_platform.h
|
||||||
//
|
//
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2014-2017 The Khronos Group Inc.
|
** Copyright 2014-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
@ -68,7 +58,9 @@ extern "C"
|
||||||
#define VKAPI_PTR
|
#define VKAPI_PTR
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <stddef.h>
|
#if !defined(VK_NO_STDDEF_H)
|
||||||
|
#include <stddef.h>
|
||||||
|
#endif // !defined(VK_NO_STDDEF_H)
|
||||||
|
|
||||||
#if !defined(VK_NO_STDINT_H)
|
#if !defined(VK_NO_STDINT_H)
|
||||||
#if defined(_MSC_VER) && (_MSC_VER < 1600)
|
#if defined(_MSC_VER) && (_MSC_VER < 1600)
|
||||||
|
|
|
@ -2,19 +2,9 @@
|
||||||
#define VULKAN_H_ 1
|
#define VULKAN_H_ 1
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "vk_platform.h"
|
#include "vk_platform.h"
|
||||||
|
@ -71,6 +61,12 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef VK_USE_PLATFORM_DIRECTFB_EXT
|
||||||
|
#include <directfb.h>
|
||||||
|
#include "vulkan_directfb.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef VK_USE_PLATFORM_XLIB_XRANDR_EXT
|
#ifdef VK_USE_PLATFORM_XLIB_XRANDR_EXT
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
#include <X11/extensions/Xrandr.h>
|
#include <X11/extensions/Xrandr.h>
|
||||||
|
@ -83,4 +79,14 @@
|
||||||
#include "vulkan_ggp.h"
|
#include "vulkan_ggp.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef VK_USE_PLATFORM_SCREEN_QNX
|
||||||
|
#include <screen/screen.h>
|
||||||
|
#include "vulkan_screen.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
||||||
|
#include "vulkan_beta.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif // VULKAN_H_
|
#endif // VULKAN_H_
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_ANDROID_H_
|
#ifndef VULKAN_ANDROID_H_
|
||||||
#define VULKAN_ANDROID_H_ 1
|
#define VULKAN_ANDROID_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_KHR_android_surface 1
|
#define VK_KHR_android_surface 1
|
||||||
struct ANativeWindow;
|
struct ANativeWindow;
|
||||||
|
|
704
src/common/rendering/vulkan/thirdparty/vulkan/vulkan_beta.h
vendored
Normal file
704
src/common/rendering/vulkan/thirdparty/vulkan/vulkan_beta.h
vendored
Normal file
|
@ -0,0 +1,704 @@
|
||||||
|
#ifndef VULKAN_BETA_H_
|
||||||
|
#define VULKAN_BETA_H_ 1
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
|
**
|
||||||
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
** This header is generated from the Khronos Vulkan XML API Registry.
|
||||||
|
**
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_KHR_video_queue 1
|
||||||
|
VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkVideoSessionKHR)
|
||||||
|
VK_DEFINE_NON_DISPATCHABLE_HANDLE(VkVideoSessionParametersKHR)
|
||||||
|
#define VK_KHR_VIDEO_QUEUE_SPEC_VERSION 2
|
||||||
|
#define VK_KHR_VIDEO_QUEUE_EXTENSION_NAME "VK_KHR_video_queue"
|
||||||
|
|
||||||
|
typedef enum VkQueryResultStatusKHR {
|
||||||
|
VK_QUERY_RESULT_STATUS_ERROR_KHR = -1,
|
||||||
|
VK_QUERY_RESULT_STATUS_NOT_READY_KHR = 0,
|
||||||
|
VK_QUERY_RESULT_STATUS_COMPLETE_KHR = 1,
|
||||||
|
VK_QUERY_RESULT_STATUS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkQueryResultStatusKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoCodecOperationFlagBitsKHR {
|
||||||
|
VK_VIDEO_CODEC_OPERATION_INVALID_BIT_KHR = 0,
|
||||||
|
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
||||||
|
VK_VIDEO_CODEC_OPERATION_ENCODE_H264_BIT_EXT = 0x00010000,
|
||||||
|
#endif
|
||||||
|
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
||||||
|
VK_VIDEO_CODEC_OPERATION_DECODE_H264_BIT_EXT = 0x00000001,
|
||||||
|
#endif
|
||||||
|
#ifdef VK_ENABLE_BETA_EXTENSIONS
|
||||||
|
VK_VIDEO_CODEC_OPERATION_DECODE_H265_BIT_EXT = 0x00000002,
|
||||||
|
#endif
|
||||||
|
VK_VIDEO_CODEC_OPERATION_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoCodecOperationFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoCodecOperationFlagsKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoChromaSubsamplingFlagBitsKHR {
|
||||||
|
VK_VIDEO_CHROMA_SUBSAMPLING_INVALID_BIT_KHR = 0,
|
||||||
|
VK_VIDEO_CHROMA_SUBSAMPLING_MONOCHROME_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_CHROMA_SUBSAMPLING_420_BIT_KHR = 0x00000002,
|
||||||
|
VK_VIDEO_CHROMA_SUBSAMPLING_422_BIT_KHR = 0x00000004,
|
||||||
|
VK_VIDEO_CHROMA_SUBSAMPLING_444_BIT_KHR = 0x00000008,
|
||||||
|
VK_VIDEO_CHROMA_SUBSAMPLING_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoChromaSubsamplingFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoChromaSubsamplingFlagsKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoComponentBitDepthFlagBitsKHR {
|
||||||
|
VK_VIDEO_COMPONENT_BIT_DEPTH_INVALID_KHR = 0,
|
||||||
|
VK_VIDEO_COMPONENT_BIT_DEPTH_8_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_COMPONENT_BIT_DEPTH_10_BIT_KHR = 0x00000004,
|
||||||
|
VK_VIDEO_COMPONENT_BIT_DEPTH_12_BIT_KHR = 0x00000010,
|
||||||
|
VK_VIDEO_COMPONENT_BIT_DEPTH_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoComponentBitDepthFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoComponentBitDepthFlagsKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoCapabilityFlagBitsKHR {
|
||||||
|
VK_VIDEO_CAPABILITY_PROTECTED_CONTENT_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_CAPABILITY_SEPARATE_REFERENCE_IMAGES_BIT_KHR = 0x00000002,
|
||||||
|
VK_VIDEO_CAPABILITY_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoCapabilityFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoCapabilityFlagsKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoSessionCreateFlagBitsKHR {
|
||||||
|
VK_VIDEO_SESSION_CREATE_DEFAULT_KHR = 0,
|
||||||
|
VK_VIDEO_SESSION_CREATE_PROTECTED_CONTENT_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_SESSION_CREATE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoSessionCreateFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoSessionCreateFlagsKHR;
|
||||||
|
typedef VkFlags VkVideoBeginCodingFlagsKHR;
|
||||||
|
typedef VkFlags VkVideoEndCodingFlagsKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoCodingControlFlagBitsKHR {
|
||||||
|
VK_VIDEO_CODING_CONTROL_DEFAULT_KHR = 0,
|
||||||
|
VK_VIDEO_CODING_CONTROL_RESET_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_CODING_CONTROL_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoCodingControlFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoCodingControlFlagsKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoCodingQualityPresetFlagBitsKHR {
|
||||||
|
VK_VIDEO_CODING_QUALITY_PRESET_DEFAULT_BIT_KHR = 0,
|
||||||
|
VK_VIDEO_CODING_QUALITY_PRESET_NORMAL_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_CODING_QUALITY_PRESET_POWER_BIT_KHR = 0x00000002,
|
||||||
|
VK_VIDEO_CODING_QUALITY_PRESET_QUALITY_BIT_KHR = 0x00000004,
|
||||||
|
VK_VIDEO_CODING_QUALITY_PRESET_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoCodingQualityPresetFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoCodingQualityPresetFlagsKHR;
|
||||||
|
typedef struct VkVideoQueueFamilyProperties2KHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
VkVideoCodecOperationFlagsKHR videoCodecOperations;
|
||||||
|
} VkVideoQueueFamilyProperties2KHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoProfileKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
VkVideoCodecOperationFlagBitsKHR videoCodecOperation;
|
||||||
|
VkVideoChromaSubsamplingFlagsKHR chromaSubsampling;
|
||||||
|
VkVideoComponentBitDepthFlagsKHR lumaBitDepth;
|
||||||
|
VkVideoComponentBitDepthFlagsKHR chromaBitDepth;
|
||||||
|
} VkVideoProfileKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoProfilesKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
uint32_t profileCount;
|
||||||
|
const VkVideoProfileKHR* pProfiles;
|
||||||
|
} VkVideoProfilesKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoCapabilitiesKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
VkVideoCapabilityFlagsKHR capabilityFlags;
|
||||||
|
VkDeviceSize minBitstreamBufferOffsetAlignment;
|
||||||
|
VkDeviceSize minBitstreamBufferSizeAlignment;
|
||||||
|
VkExtent2D videoPictureExtentGranularity;
|
||||||
|
VkExtent2D minExtent;
|
||||||
|
VkExtent2D maxExtent;
|
||||||
|
uint32_t maxReferencePicturesSlotsCount;
|
||||||
|
uint32_t maxReferencePicturesActiveCount;
|
||||||
|
} VkVideoCapabilitiesKHR;
|
||||||
|
|
||||||
|
typedef struct VkPhysicalDeviceVideoFormatInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
VkImageUsageFlags imageUsage;
|
||||||
|
const VkVideoProfilesKHR* pVideoProfiles;
|
||||||
|
} VkPhysicalDeviceVideoFormatInfoKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoFormatPropertiesKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
VkFormat format;
|
||||||
|
} VkVideoFormatPropertiesKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoPictureResourceKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkOffset2D codedOffset;
|
||||||
|
VkExtent2D codedExtent;
|
||||||
|
uint32_t baseArrayLayer;
|
||||||
|
VkImageView imageViewBinding;
|
||||||
|
} VkVideoPictureResourceKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoReferenceSlotKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
int8_t slotIndex;
|
||||||
|
const VkVideoPictureResourceKHR* pPictureResource;
|
||||||
|
} VkVideoReferenceSlotKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoGetMemoryPropertiesKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t memoryBindIndex;
|
||||||
|
VkMemoryRequirements2* pMemoryRequirements;
|
||||||
|
} VkVideoGetMemoryPropertiesKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoBindMemoryKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t memoryBindIndex;
|
||||||
|
VkDeviceMemory memory;
|
||||||
|
VkDeviceSize memoryOffset;
|
||||||
|
VkDeviceSize memorySize;
|
||||||
|
} VkVideoBindMemoryKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoSessionCreateInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t queueFamilyIndex;
|
||||||
|
VkVideoSessionCreateFlagsKHR flags;
|
||||||
|
const VkVideoProfileKHR* pVideoProfile;
|
||||||
|
VkFormat pictureFormat;
|
||||||
|
VkExtent2D maxCodedExtent;
|
||||||
|
VkFormat referencePicturesFormat;
|
||||||
|
uint32_t maxReferencePicturesSlotsCount;
|
||||||
|
uint32_t maxReferencePicturesActiveCount;
|
||||||
|
} VkVideoSessionCreateInfoKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoSessionParametersCreateInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoSessionParametersKHR videoSessionParametersTemplate;
|
||||||
|
VkVideoSessionKHR videoSession;
|
||||||
|
} VkVideoSessionParametersCreateInfoKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoSessionParametersUpdateInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t updateSequenceCount;
|
||||||
|
} VkVideoSessionParametersUpdateInfoKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoBeginCodingInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoBeginCodingFlagsKHR flags;
|
||||||
|
VkVideoCodingQualityPresetFlagsKHR codecQualityPreset;
|
||||||
|
VkVideoSessionKHR videoSession;
|
||||||
|
VkVideoSessionParametersKHR videoSessionParameters;
|
||||||
|
uint32_t referenceSlotCount;
|
||||||
|
const VkVideoReferenceSlotKHR* pReferenceSlots;
|
||||||
|
} VkVideoBeginCodingInfoKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoEndCodingInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoEndCodingFlagsKHR flags;
|
||||||
|
} VkVideoEndCodingInfoKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoCodingControlInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoCodingControlFlagsKHR flags;
|
||||||
|
} VkVideoCodingControlInfoKHR;
|
||||||
|
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceVideoCapabilitiesKHR)(VkPhysicalDevice physicalDevice, const VkVideoProfileKHR* pVideoProfile, VkVideoCapabilitiesKHR* pCapabilities);
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkGetPhysicalDeviceVideoFormatPropertiesKHR)(VkPhysicalDevice physicalDevice, const VkPhysicalDeviceVideoFormatInfoKHR* pVideoFormatInfo, uint32_t* pVideoFormatPropertyCount, VkVideoFormatPropertiesKHR* pVideoFormatProperties);
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkCreateVideoSessionKHR)(VkDevice device, const VkVideoSessionCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkVideoSessionKHR* pVideoSession);
|
||||||
|
typedef void (VKAPI_PTR *PFN_vkDestroyVideoSessionKHR)(VkDevice device, VkVideoSessionKHR videoSession, const VkAllocationCallbacks* pAllocator);
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkGetVideoSessionMemoryRequirementsKHR)(VkDevice device, VkVideoSessionKHR videoSession, uint32_t* pVideoSessionMemoryRequirementsCount, VkVideoGetMemoryPropertiesKHR* pVideoSessionMemoryRequirements);
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkBindVideoSessionMemoryKHR)(VkDevice device, VkVideoSessionKHR videoSession, uint32_t videoSessionBindMemoryCount, const VkVideoBindMemoryKHR* pVideoSessionBindMemories);
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkCreateVideoSessionParametersKHR)(VkDevice device, const VkVideoSessionParametersCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkVideoSessionParametersKHR* pVideoSessionParameters);
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkUpdateVideoSessionParametersKHR)(VkDevice device, VkVideoSessionParametersKHR videoSessionParameters, const VkVideoSessionParametersUpdateInfoKHR* pUpdateInfo);
|
||||||
|
typedef void (VKAPI_PTR *PFN_vkDestroyVideoSessionParametersKHR)(VkDevice device, VkVideoSessionParametersKHR videoSessionParameters, const VkAllocationCallbacks* pAllocator);
|
||||||
|
typedef void (VKAPI_PTR *PFN_vkCmdBeginVideoCodingKHR)(VkCommandBuffer commandBuffer, const VkVideoBeginCodingInfoKHR* pBeginInfo);
|
||||||
|
typedef void (VKAPI_PTR *PFN_vkCmdEndVideoCodingKHR)(VkCommandBuffer commandBuffer, const VkVideoEndCodingInfoKHR* pEndCodingInfo);
|
||||||
|
typedef void (VKAPI_PTR *PFN_vkCmdControlVideoCodingKHR)(VkCommandBuffer commandBuffer, const VkVideoCodingControlInfoKHR* pCodingControlInfo);
|
||||||
|
|
||||||
|
#ifndef VK_NO_PROTOTYPES
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceVideoCapabilitiesKHR(
|
||||||
|
VkPhysicalDevice physicalDevice,
|
||||||
|
const VkVideoProfileKHR* pVideoProfile,
|
||||||
|
VkVideoCapabilitiesKHR* pCapabilities);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkGetPhysicalDeviceVideoFormatPropertiesKHR(
|
||||||
|
VkPhysicalDevice physicalDevice,
|
||||||
|
const VkPhysicalDeviceVideoFormatInfoKHR* pVideoFormatInfo,
|
||||||
|
uint32_t* pVideoFormatPropertyCount,
|
||||||
|
VkVideoFormatPropertiesKHR* pVideoFormatProperties);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkCreateVideoSessionKHR(
|
||||||
|
VkDevice device,
|
||||||
|
const VkVideoSessionCreateInfoKHR* pCreateInfo,
|
||||||
|
const VkAllocationCallbacks* pAllocator,
|
||||||
|
VkVideoSessionKHR* pVideoSession);
|
||||||
|
|
||||||
|
VKAPI_ATTR void VKAPI_CALL vkDestroyVideoSessionKHR(
|
||||||
|
VkDevice device,
|
||||||
|
VkVideoSessionKHR videoSession,
|
||||||
|
const VkAllocationCallbacks* pAllocator);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkGetVideoSessionMemoryRequirementsKHR(
|
||||||
|
VkDevice device,
|
||||||
|
VkVideoSessionKHR videoSession,
|
||||||
|
uint32_t* pVideoSessionMemoryRequirementsCount,
|
||||||
|
VkVideoGetMemoryPropertiesKHR* pVideoSessionMemoryRequirements);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkBindVideoSessionMemoryKHR(
|
||||||
|
VkDevice device,
|
||||||
|
VkVideoSessionKHR videoSession,
|
||||||
|
uint32_t videoSessionBindMemoryCount,
|
||||||
|
const VkVideoBindMemoryKHR* pVideoSessionBindMemories);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkCreateVideoSessionParametersKHR(
|
||||||
|
VkDevice device,
|
||||||
|
const VkVideoSessionParametersCreateInfoKHR* pCreateInfo,
|
||||||
|
const VkAllocationCallbacks* pAllocator,
|
||||||
|
VkVideoSessionParametersKHR* pVideoSessionParameters);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkUpdateVideoSessionParametersKHR(
|
||||||
|
VkDevice device,
|
||||||
|
VkVideoSessionParametersKHR videoSessionParameters,
|
||||||
|
const VkVideoSessionParametersUpdateInfoKHR* pUpdateInfo);
|
||||||
|
|
||||||
|
VKAPI_ATTR void VKAPI_CALL vkDestroyVideoSessionParametersKHR(
|
||||||
|
VkDevice device,
|
||||||
|
VkVideoSessionParametersKHR videoSessionParameters,
|
||||||
|
const VkAllocationCallbacks* pAllocator);
|
||||||
|
|
||||||
|
VKAPI_ATTR void VKAPI_CALL vkCmdBeginVideoCodingKHR(
|
||||||
|
VkCommandBuffer commandBuffer,
|
||||||
|
const VkVideoBeginCodingInfoKHR* pBeginInfo);
|
||||||
|
|
||||||
|
VKAPI_ATTR void VKAPI_CALL vkCmdEndVideoCodingKHR(
|
||||||
|
VkCommandBuffer commandBuffer,
|
||||||
|
const VkVideoEndCodingInfoKHR* pEndCodingInfo);
|
||||||
|
|
||||||
|
VKAPI_ATTR void VKAPI_CALL vkCmdControlVideoCodingKHR(
|
||||||
|
VkCommandBuffer commandBuffer,
|
||||||
|
const VkVideoCodingControlInfoKHR* pCodingControlInfo);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_KHR_video_decode_queue 1
|
||||||
|
#define VK_KHR_VIDEO_DECODE_QUEUE_SPEC_VERSION 1
|
||||||
|
#define VK_KHR_VIDEO_DECODE_QUEUE_EXTENSION_NAME "VK_KHR_video_decode_queue"
|
||||||
|
|
||||||
|
typedef enum VkVideoDecodeFlagBitsKHR {
|
||||||
|
VK_VIDEO_DECODE_DEFAULT_KHR = 0,
|
||||||
|
VK_VIDEO_DECODE_RESERVED_0_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_DECODE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoDecodeFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoDecodeFlagsKHR;
|
||||||
|
typedef struct VkVideoDecodeInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoDecodeFlagsKHR flags;
|
||||||
|
VkOffset2D codedOffset;
|
||||||
|
VkExtent2D codedExtent;
|
||||||
|
VkBuffer srcBuffer;
|
||||||
|
VkDeviceSize srcBufferOffset;
|
||||||
|
VkDeviceSize srcBufferRange;
|
||||||
|
VkVideoPictureResourceKHR dstPictureResource;
|
||||||
|
const VkVideoReferenceSlotKHR* pSetupReferenceSlot;
|
||||||
|
uint32_t referenceSlotCount;
|
||||||
|
const VkVideoReferenceSlotKHR* pReferenceSlots;
|
||||||
|
} VkVideoDecodeInfoKHR;
|
||||||
|
|
||||||
|
typedef void (VKAPI_PTR *PFN_vkCmdDecodeVideoKHR)(VkCommandBuffer commandBuffer, const VkVideoDecodeInfoKHR* pFrameInfo);
|
||||||
|
|
||||||
|
#ifndef VK_NO_PROTOTYPES
|
||||||
|
VKAPI_ATTR void VKAPI_CALL vkCmdDecodeVideoKHR(
|
||||||
|
VkCommandBuffer commandBuffer,
|
||||||
|
const VkVideoDecodeInfoKHR* pFrameInfo);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_KHR_portability_subset 1
|
||||||
|
#define VK_KHR_PORTABILITY_SUBSET_SPEC_VERSION 1
|
||||||
|
#define VK_KHR_PORTABILITY_SUBSET_EXTENSION_NAME "VK_KHR_portability_subset"
|
||||||
|
typedef struct VkPhysicalDevicePortabilitySubsetFeaturesKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
VkBool32 constantAlphaColorBlendFactors;
|
||||||
|
VkBool32 events;
|
||||||
|
VkBool32 imageViewFormatReinterpretation;
|
||||||
|
VkBool32 imageViewFormatSwizzle;
|
||||||
|
VkBool32 imageView2DOn3DImage;
|
||||||
|
VkBool32 multisampleArrayImage;
|
||||||
|
VkBool32 mutableComparisonSamplers;
|
||||||
|
VkBool32 pointPolygons;
|
||||||
|
VkBool32 samplerMipLodBias;
|
||||||
|
VkBool32 separateStencilMaskRef;
|
||||||
|
VkBool32 shaderSampleRateInterpolationFunctions;
|
||||||
|
VkBool32 tessellationIsolines;
|
||||||
|
VkBool32 tessellationPointMode;
|
||||||
|
VkBool32 triangleFans;
|
||||||
|
VkBool32 vertexAttributeAccessBeyondStride;
|
||||||
|
} VkPhysicalDevicePortabilitySubsetFeaturesKHR;
|
||||||
|
|
||||||
|
typedef struct VkPhysicalDevicePortabilitySubsetPropertiesKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
uint32_t minVertexInputBindingStrideAlignment;
|
||||||
|
} VkPhysicalDevicePortabilitySubsetPropertiesKHR;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_KHR_video_encode_queue 1
|
||||||
|
#define VK_KHR_VIDEO_ENCODE_QUEUE_SPEC_VERSION 2
|
||||||
|
#define VK_KHR_VIDEO_ENCODE_QUEUE_EXTENSION_NAME "VK_KHR_video_encode_queue"
|
||||||
|
|
||||||
|
typedef enum VkVideoEncodeFlagBitsKHR {
|
||||||
|
VK_VIDEO_ENCODE_DEFAULT_KHR = 0,
|
||||||
|
VK_VIDEO_ENCODE_RESERVED_0_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_ENCODE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoEncodeFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoEncodeFlagsKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoEncodeRateControlFlagBitsKHR {
|
||||||
|
VK_VIDEO_ENCODE_RATE_CONTROL_DEFAULT_KHR = 0,
|
||||||
|
VK_VIDEO_ENCODE_RATE_CONTROL_RESET_BIT_KHR = 0x00000001,
|
||||||
|
VK_VIDEO_ENCODE_RATE_CONTROL_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoEncodeRateControlFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoEncodeRateControlFlagsKHR;
|
||||||
|
|
||||||
|
typedef enum VkVideoEncodeRateControlModeFlagBitsKHR {
|
||||||
|
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_NONE_BIT_KHR = 0,
|
||||||
|
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_CBR_BIT_KHR = 1,
|
||||||
|
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_VBR_BIT_KHR = 2,
|
||||||
|
VK_VIDEO_ENCODE_RATE_CONTROL_MODE_FLAG_BITS_MAX_ENUM_KHR = 0x7FFFFFFF
|
||||||
|
} VkVideoEncodeRateControlModeFlagBitsKHR;
|
||||||
|
typedef VkFlags VkVideoEncodeRateControlModeFlagsKHR;
|
||||||
|
typedef struct VkVideoEncodeInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoEncodeFlagsKHR flags;
|
||||||
|
uint32_t qualityLevel;
|
||||||
|
VkExtent2D codedExtent;
|
||||||
|
VkBuffer dstBitstreamBuffer;
|
||||||
|
VkDeviceSize dstBitstreamBufferOffset;
|
||||||
|
VkDeviceSize dstBitstreamBufferMaxRange;
|
||||||
|
VkVideoPictureResourceKHR srcPictureResource;
|
||||||
|
const VkVideoReferenceSlotKHR* pSetupReferenceSlot;
|
||||||
|
uint32_t referenceSlotCount;
|
||||||
|
const VkVideoReferenceSlotKHR* pReferenceSlots;
|
||||||
|
} VkVideoEncodeInfoKHR;
|
||||||
|
|
||||||
|
typedef struct VkVideoEncodeRateControlInfoKHR {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoEncodeRateControlFlagsKHR flags;
|
||||||
|
VkVideoEncodeRateControlModeFlagBitsKHR rateControlMode;
|
||||||
|
uint32_t averageBitrate;
|
||||||
|
uint16_t peakToAverageBitrateRatio;
|
||||||
|
uint16_t frameRateNumerator;
|
||||||
|
uint16_t frameRateDenominator;
|
||||||
|
uint32_t virtualBufferSizeInMs;
|
||||||
|
} VkVideoEncodeRateControlInfoKHR;
|
||||||
|
|
||||||
|
typedef void (VKAPI_PTR *PFN_vkCmdEncodeVideoKHR)(VkCommandBuffer commandBuffer, const VkVideoEncodeInfoKHR* pEncodeInfo);
|
||||||
|
|
||||||
|
#ifndef VK_NO_PROTOTYPES
|
||||||
|
VKAPI_ATTR void VKAPI_CALL vkCmdEncodeVideoKHR(
|
||||||
|
VkCommandBuffer commandBuffer,
|
||||||
|
const VkVideoEncodeInfoKHR* pEncodeInfo);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_EXT_video_encode_h264 1
|
||||||
|
#include "vk_video/vulkan_video_codec_h264std.h"
|
||||||
|
#include "vk_video/vulkan_video_codec_h264std_encode.h"
|
||||||
|
#define VK_EXT_VIDEO_ENCODE_H264_SPEC_VERSION 2
|
||||||
|
#define VK_EXT_VIDEO_ENCODE_H264_EXTENSION_NAME "VK_EXT_video_encode_h264"
|
||||||
|
|
||||||
|
typedef enum VkVideoEncodeH264CapabilityFlagBitsEXT {
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_CABAC_BIT_EXT = 0x00000001,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_CAVLC_BIT_EXT = 0x00000002,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_WEIGHTED_BI_PRED_IMPLICIT_BIT_EXT = 0x00000004,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_TRANSFORM_8X8_BIT_EXT = 0x00000008,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_CHROMA_QP_OFFSET_BIT_EXT = 0x00000010,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_SECOND_CHROMA_QP_OFFSET_BIT_EXT = 0x00000020,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_DEBLOCKING_FILTER_DISABLED_BIT_EXT = 0x00000040,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_DEBLOCKING_FILTER_ENABLED_BIT_EXT = 0x00000080,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_DEBLOCKING_FILTER_PARTIAL_BIT_EXT = 0x00000100,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_MULTIPLE_SLICE_PER_FRAME_BIT_EXT = 0x00000200,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_EVENLY_DISTRIBUTED_SLICE_SIZE_BIT_EXT = 0x00000400,
|
||||||
|
VK_VIDEO_ENCODE_H264_CAPABILITY_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
||||||
|
} VkVideoEncodeH264CapabilityFlagBitsEXT;
|
||||||
|
typedef VkFlags VkVideoEncodeH264CapabilityFlagsEXT;
|
||||||
|
|
||||||
|
typedef enum VkVideoEncodeH264InputModeFlagBitsEXT {
|
||||||
|
VK_VIDEO_ENCODE_H264_INPUT_MODE_FRAME_BIT_EXT = 0x00000001,
|
||||||
|
VK_VIDEO_ENCODE_H264_INPUT_MODE_SLICE_BIT_EXT = 0x00000002,
|
||||||
|
VK_VIDEO_ENCODE_H264_INPUT_MODE_NON_VCL_BIT_EXT = 0x00000004,
|
||||||
|
VK_VIDEO_ENCODE_H264_INPUT_MODE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
||||||
|
} VkVideoEncodeH264InputModeFlagBitsEXT;
|
||||||
|
typedef VkFlags VkVideoEncodeH264InputModeFlagsEXT;
|
||||||
|
|
||||||
|
typedef enum VkVideoEncodeH264OutputModeFlagBitsEXT {
|
||||||
|
VK_VIDEO_ENCODE_H264_OUTPUT_MODE_FRAME_BIT_EXT = 0x00000001,
|
||||||
|
VK_VIDEO_ENCODE_H264_OUTPUT_MODE_SLICE_BIT_EXT = 0x00000002,
|
||||||
|
VK_VIDEO_ENCODE_H264_OUTPUT_MODE_NON_VCL_BIT_EXT = 0x00000004,
|
||||||
|
VK_VIDEO_ENCODE_H264_OUTPUT_MODE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
||||||
|
} VkVideoEncodeH264OutputModeFlagBitsEXT;
|
||||||
|
typedef VkFlags VkVideoEncodeH264OutputModeFlagsEXT;
|
||||||
|
|
||||||
|
typedef enum VkVideoEncodeH264CreateFlagBitsEXT {
|
||||||
|
VK_VIDEO_ENCODE_H264_CREATE_DEFAULT_EXT = 0,
|
||||||
|
VK_VIDEO_ENCODE_H264_CREATE_RESERVED_0_BIT_EXT = 0x00000001,
|
||||||
|
VK_VIDEO_ENCODE_H264_CREATE_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
||||||
|
} VkVideoEncodeH264CreateFlagBitsEXT;
|
||||||
|
typedef VkFlags VkVideoEncodeH264CreateFlagsEXT;
|
||||||
|
typedef struct VkVideoEncodeH264CapabilitiesEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoEncodeH264CapabilityFlagsEXT flags;
|
||||||
|
VkVideoEncodeH264InputModeFlagsEXT inputModeFlags;
|
||||||
|
VkVideoEncodeH264OutputModeFlagsEXT outputModeFlags;
|
||||||
|
VkExtent2D minPictureSizeInMbs;
|
||||||
|
VkExtent2D maxPictureSizeInMbs;
|
||||||
|
VkExtent2D inputImageDataAlignment;
|
||||||
|
uint8_t maxNumL0ReferenceForP;
|
||||||
|
uint8_t maxNumL0ReferenceForB;
|
||||||
|
uint8_t maxNumL1Reference;
|
||||||
|
uint8_t qualityLevelCount;
|
||||||
|
VkExtensionProperties stdExtensionVersion;
|
||||||
|
} VkVideoEncodeH264CapabilitiesEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoEncodeH264SessionCreateInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoEncodeH264CreateFlagsEXT flags;
|
||||||
|
VkExtent2D maxPictureSizeInMbs;
|
||||||
|
const VkExtensionProperties* pStdExtensionVersion;
|
||||||
|
} VkVideoEncodeH264SessionCreateInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoEncodeH264SessionParametersAddInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t spsStdCount;
|
||||||
|
const StdVideoH264SequenceParameterSet* pSpsStd;
|
||||||
|
uint32_t ppsStdCount;
|
||||||
|
const StdVideoH264PictureParameterSet* pPpsStd;
|
||||||
|
} VkVideoEncodeH264SessionParametersAddInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoEncodeH264SessionParametersCreateInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t maxSpsStdCount;
|
||||||
|
uint32_t maxPpsStdCount;
|
||||||
|
const VkVideoEncodeH264SessionParametersAddInfoEXT* pParametersAddInfo;
|
||||||
|
} VkVideoEncodeH264SessionParametersCreateInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoEncodeH264DpbSlotInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
int8_t slotIndex;
|
||||||
|
const StdVideoEncodeH264PictureInfo* pStdPictureInfo;
|
||||||
|
} VkVideoEncodeH264DpbSlotInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoEncodeH264NaluSliceEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
const StdVideoEncodeH264SliceHeader* pSliceHeaderStd;
|
||||||
|
uint32_t mbCount;
|
||||||
|
uint8_t refFinalList0EntryCount;
|
||||||
|
const VkVideoEncodeH264DpbSlotInfoEXT* pRefFinalList0Entries;
|
||||||
|
uint8_t refFinalList1EntryCount;
|
||||||
|
const VkVideoEncodeH264DpbSlotInfoEXT* pRefFinalList1Entries;
|
||||||
|
uint32_t precedingNaluBytes;
|
||||||
|
uint8_t minQp;
|
||||||
|
uint8_t maxQp;
|
||||||
|
} VkVideoEncodeH264NaluSliceEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoEncodeH264VclFrameInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint8_t refDefaultFinalList0EntryCount;
|
||||||
|
const VkVideoEncodeH264DpbSlotInfoEXT* pRefDefaultFinalList0Entries;
|
||||||
|
uint8_t refDefaultFinalList1EntryCount;
|
||||||
|
const VkVideoEncodeH264DpbSlotInfoEXT* pRefDefaultFinalList1Entries;
|
||||||
|
uint32_t naluSliceEntryCount;
|
||||||
|
const VkVideoEncodeH264NaluSliceEXT* pNaluSliceEntries;
|
||||||
|
const VkVideoEncodeH264DpbSlotInfoEXT* pCurrentPictureInfo;
|
||||||
|
} VkVideoEncodeH264VclFrameInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoEncodeH264EmitPictureParametersEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint8_t spsId;
|
||||||
|
VkBool32 emitSpsEnable;
|
||||||
|
uint32_t ppsIdEntryCount;
|
||||||
|
const uint8_t* ppsIdEntries;
|
||||||
|
} VkVideoEncodeH264EmitPictureParametersEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoEncodeH264ProfileEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
StdVideoH264ProfileIdc stdProfileIdc;
|
||||||
|
} VkVideoEncodeH264ProfileEXT;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_EXT_video_decode_h264 1
|
||||||
|
#include "vk_video/vulkan_video_codec_h264std_decode.h"
|
||||||
|
#define VK_EXT_VIDEO_DECODE_H264_SPEC_VERSION 3
|
||||||
|
#define VK_EXT_VIDEO_DECODE_H264_EXTENSION_NAME "VK_EXT_video_decode_h264"
|
||||||
|
|
||||||
|
typedef enum VkVideoDecodeH264PictureLayoutFlagBitsEXT {
|
||||||
|
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_PROGRESSIVE_EXT = 0,
|
||||||
|
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_INTERLACED_INTERLEAVED_LINES_BIT_EXT = 0x00000001,
|
||||||
|
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_INTERLACED_SEPARATE_PLANES_BIT_EXT = 0x00000002,
|
||||||
|
VK_VIDEO_DECODE_H264_PICTURE_LAYOUT_FLAG_BITS_MAX_ENUM_EXT = 0x7FFFFFFF
|
||||||
|
} VkVideoDecodeH264PictureLayoutFlagBitsEXT;
|
||||||
|
typedef VkFlags VkVideoDecodeH264PictureLayoutFlagsEXT;
|
||||||
|
typedef VkFlags VkVideoDecodeH264CreateFlagsEXT;
|
||||||
|
typedef struct VkVideoDecodeH264ProfileEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
StdVideoH264ProfileIdc stdProfileIdc;
|
||||||
|
VkVideoDecodeH264PictureLayoutFlagsEXT pictureLayout;
|
||||||
|
} VkVideoDecodeH264ProfileEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH264CapabilitiesEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
uint32_t maxLevel;
|
||||||
|
VkOffset2D fieldOffsetGranularity;
|
||||||
|
VkExtensionProperties stdExtensionVersion;
|
||||||
|
} VkVideoDecodeH264CapabilitiesEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH264SessionCreateInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoDecodeH264CreateFlagsEXT flags;
|
||||||
|
const VkExtensionProperties* pStdExtensionVersion;
|
||||||
|
} VkVideoDecodeH264SessionCreateInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH264SessionParametersAddInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t spsStdCount;
|
||||||
|
const StdVideoH264SequenceParameterSet* pSpsStd;
|
||||||
|
uint32_t ppsStdCount;
|
||||||
|
const StdVideoH264PictureParameterSet* pPpsStd;
|
||||||
|
} VkVideoDecodeH264SessionParametersAddInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH264SessionParametersCreateInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t maxSpsStdCount;
|
||||||
|
uint32_t maxPpsStdCount;
|
||||||
|
const VkVideoDecodeH264SessionParametersAddInfoEXT* pParametersAddInfo;
|
||||||
|
} VkVideoDecodeH264SessionParametersCreateInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH264PictureInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
const StdVideoDecodeH264PictureInfo* pStdPictureInfo;
|
||||||
|
uint32_t slicesCount;
|
||||||
|
const uint32_t* pSlicesDataOffsets;
|
||||||
|
} VkVideoDecodeH264PictureInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH264MvcEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
const StdVideoDecodeH264Mvc* pStdMvc;
|
||||||
|
} VkVideoDecodeH264MvcEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH264DpbSlotInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
const StdVideoDecodeH264ReferenceInfo* pStdReferenceInfo;
|
||||||
|
} VkVideoDecodeH264DpbSlotInfoEXT;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_EXT_video_decode_h265 1
|
||||||
|
#include "vk_video/vulkan_video_codec_h265std.h"
|
||||||
|
#include "vk_video/vulkan_video_codec_h265std_decode.h"
|
||||||
|
#define VK_EXT_VIDEO_DECODE_H265_SPEC_VERSION 1
|
||||||
|
#define VK_EXT_VIDEO_DECODE_H265_EXTENSION_NAME "VK_EXT_video_decode_h265"
|
||||||
|
typedef VkFlags VkVideoDecodeH265CreateFlagsEXT;
|
||||||
|
typedef struct VkVideoDecodeH265ProfileEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
StdVideoH265ProfileIdc stdProfileIdc;
|
||||||
|
} VkVideoDecodeH265ProfileEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH265CapabilitiesEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
uint32_t maxLevel;
|
||||||
|
VkExtensionProperties stdExtensionVersion;
|
||||||
|
} VkVideoDecodeH265CapabilitiesEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH265SessionCreateInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkVideoDecodeH265CreateFlagsEXT flags;
|
||||||
|
const VkExtensionProperties* pStdExtensionVersion;
|
||||||
|
} VkVideoDecodeH265SessionCreateInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH265SessionParametersAddInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t spsStdCount;
|
||||||
|
const StdVideoH265SequenceParameterSet* pSpsStd;
|
||||||
|
uint32_t ppsStdCount;
|
||||||
|
const StdVideoH265PictureParameterSet* pPpsStd;
|
||||||
|
} VkVideoDecodeH265SessionParametersAddInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH265SessionParametersCreateInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
uint32_t maxSpsStdCount;
|
||||||
|
uint32_t maxPpsStdCount;
|
||||||
|
const VkVideoDecodeH265SessionParametersAddInfoEXT* pParametersAddInfo;
|
||||||
|
} VkVideoDecodeH265SessionParametersCreateInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH265PictureInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
StdVideoDecodeH265PictureInfo* pStdPictureInfo;
|
||||||
|
uint32_t slicesCount;
|
||||||
|
const uint32_t* pSlicesDataOffsets;
|
||||||
|
} VkVideoDecodeH265PictureInfoEXT;
|
||||||
|
|
||||||
|
typedef struct VkVideoDecodeH265DpbSlotInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
const StdVideoDecodeH265ReferenceInfo* pStdReferenceInfo;
|
||||||
|
} VkVideoDecodeH265DpbSlotInfoEXT;
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
File diff suppressed because it is too large
Load diff
54
src/common/rendering/vulkan/thirdparty/vulkan/vulkan_directfb.h
vendored
Normal file
54
src/common/rendering/vulkan/thirdparty/vulkan/vulkan_directfb.h
vendored
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
#ifndef VULKAN_DIRECTFB_H_
|
||||||
|
#define VULKAN_DIRECTFB_H_ 1
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
|
**
|
||||||
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
** This header is generated from the Khronos Vulkan XML API Registry.
|
||||||
|
**
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_EXT_directfb_surface 1
|
||||||
|
#define VK_EXT_DIRECTFB_SURFACE_SPEC_VERSION 1
|
||||||
|
#define VK_EXT_DIRECTFB_SURFACE_EXTENSION_NAME "VK_EXT_directfb_surface"
|
||||||
|
typedef VkFlags VkDirectFBSurfaceCreateFlagsEXT;
|
||||||
|
typedef struct VkDirectFBSurfaceCreateInfoEXT {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkDirectFBSurfaceCreateFlagsEXT flags;
|
||||||
|
IDirectFB* dfb;
|
||||||
|
IDirectFBSurface* surface;
|
||||||
|
} VkDirectFBSurfaceCreateInfoEXT;
|
||||||
|
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkCreateDirectFBSurfaceEXT)(VkInstance instance, const VkDirectFBSurfaceCreateInfoEXT* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
|
||||||
|
typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceDirectFBPresentationSupportEXT)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, IDirectFB* dfb);
|
||||||
|
|
||||||
|
#ifndef VK_NO_PROTOTYPES
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkCreateDirectFBSurfaceEXT(
|
||||||
|
VkInstance instance,
|
||||||
|
const VkDirectFBSurfaceCreateInfoEXT* pCreateInfo,
|
||||||
|
const VkAllocationCallbacks* pAllocator,
|
||||||
|
VkSurfaceKHR* pSurface);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceDirectFBPresentationSupportEXT(
|
||||||
|
VkPhysicalDevice physicalDevice,
|
||||||
|
uint32_t queueFamilyIndex,
|
||||||
|
IDirectFB* dfb);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_FUCHSIA_H_
|
#ifndef VULKAN_FUCHSIA_H_
|
||||||
#define VULKAN_FUCHSIA_H_ 1
|
#define VULKAN_FUCHSIA_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_FUCHSIA_imagepipe_surface 1
|
#define VK_FUCHSIA_imagepipe_surface 1
|
||||||
#define VK_FUCHSIA_IMAGEPIPE_SURFACE_SPEC_VERSION 1
|
#define VK_FUCHSIA_IMAGEPIPE_SURFACE_SPEC_VERSION 1
|
||||||
|
@ -49,6 +40,80 @@ VKAPI_ATTR VkResult VKAPI_CALL vkCreateImagePipeSurfaceFUCHSIA(
|
||||||
VkSurfaceKHR* pSurface);
|
VkSurfaceKHR* pSurface);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_FUCHSIA_external_memory 1
|
||||||
|
#define VK_FUCHSIA_EXTERNAL_MEMORY_SPEC_VERSION 1
|
||||||
|
#define VK_FUCHSIA_EXTERNAL_MEMORY_EXTENSION_NAME "VK_FUCHSIA_external_memory"
|
||||||
|
typedef struct VkImportMemoryZirconHandleInfoFUCHSIA {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkExternalMemoryHandleTypeFlagBits handleType;
|
||||||
|
zx_handle_t handle;
|
||||||
|
} VkImportMemoryZirconHandleInfoFUCHSIA;
|
||||||
|
|
||||||
|
typedef struct VkMemoryZirconHandlePropertiesFUCHSIA {
|
||||||
|
VkStructureType sType;
|
||||||
|
void* pNext;
|
||||||
|
uint32_t memoryTypeBits;
|
||||||
|
} VkMemoryZirconHandlePropertiesFUCHSIA;
|
||||||
|
|
||||||
|
typedef struct VkMemoryGetZirconHandleInfoFUCHSIA {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkDeviceMemory memory;
|
||||||
|
VkExternalMemoryHandleTypeFlagBits handleType;
|
||||||
|
} VkMemoryGetZirconHandleInfoFUCHSIA;
|
||||||
|
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryZirconHandleFUCHSIA)(VkDevice device, const VkMemoryGetZirconHandleInfoFUCHSIA* pGetZirconHandleInfo, zx_handle_t* pZirconHandle);
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkGetMemoryZirconHandlePropertiesFUCHSIA)(VkDevice device, VkExternalMemoryHandleTypeFlagBits handleType, zx_handle_t zirconHandle, VkMemoryZirconHandlePropertiesFUCHSIA* pMemoryZirconHandleProperties);
|
||||||
|
|
||||||
|
#ifndef VK_NO_PROTOTYPES
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryZirconHandleFUCHSIA(
|
||||||
|
VkDevice device,
|
||||||
|
const VkMemoryGetZirconHandleInfoFUCHSIA* pGetZirconHandleInfo,
|
||||||
|
zx_handle_t* pZirconHandle);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryZirconHandlePropertiesFUCHSIA(
|
||||||
|
VkDevice device,
|
||||||
|
VkExternalMemoryHandleTypeFlagBits handleType,
|
||||||
|
zx_handle_t zirconHandle,
|
||||||
|
VkMemoryZirconHandlePropertiesFUCHSIA* pMemoryZirconHandleProperties);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_FUCHSIA_external_semaphore 1
|
||||||
|
#define VK_FUCHSIA_EXTERNAL_SEMAPHORE_SPEC_VERSION 1
|
||||||
|
#define VK_FUCHSIA_EXTERNAL_SEMAPHORE_EXTENSION_NAME "VK_FUCHSIA_external_semaphore"
|
||||||
|
typedef struct VkImportSemaphoreZirconHandleInfoFUCHSIA {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkSemaphore semaphore;
|
||||||
|
VkSemaphoreImportFlags flags;
|
||||||
|
VkExternalSemaphoreHandleTypeFlagBits handleType;
|
||||||
|
zx_handle_t zirconHandle;
|
||||||
|
} VkImportSemaphoreZirconHandleInfoFUCHSIA;
|
||||||
|
|
||||||
|
typedef struct VkSemaphoreGetZirconHandleInfoFUCHSIA {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkSemaphore semaphore;
|
||||||
|
VkExternalSemaphoreHandleTypeFlagBits handleType;
|
||||||
|
} VkSemaphoreGetZirconHandleInfoFUCHSIA;
|
||||||
|
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkImportSemaphoreZirconHandleFUCHSIA)(VkDevice device, const VkImportSemaphoreZirconHandleInfoFUCHSIA* pImportSemaphoreZirconHandleInfo);
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkGetSemaphoreZirconHandleFUCHSIA)(VkDevice device, const VkSemaphoreGetZirconHandleInfoFUCHSIA* pGetZirconHandleInfo, zx_handle_t* pZirconHandle);
|
||||||
|
|
||||||
|
#ifndef VK_NO_PROTOTYPES
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkImportSemaphoreZirconHandleFUCHSIA(
|
||||||
|
VkDevice device,
|
||||||
|
const VkImportSemaphoreZirconHandleInfoFUCHSIA* pImportSemaphoreZirconHandleInfo);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkGetSemaphoreZirconHandleFUCHSIA(
|
||||||
|
VkDevice device,
|
||||||
|
const VkSemaphoreGetZirconHandleInfoFUCHSIA* pGetZirconHandleInfo,
|
||||||
|
zx_handle_t* pZirconHandle);
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_GGP_H_
|
#ifndef VULKAN_GGP_H_
|
||||||
#define VULKAN_GGP_H_ 1
|
#define VULKAN_GGP_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_GGP_stream_descriptor_surface 1
|
#define VK_GGP_stream_descriptor_surface 1
|
||||||
#define VK_GGP_STREAM_DESCRIPTOR_SURFACE_SPEC_VERSION 1
|
#define VK_GGP_STREAM_DESCRIPTOR_SURFACE_SPEC_VERSION 1
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_IOS_H_
|
#ifndef VULKAN_IOS_H_
|
||||||
#define VULKAN_IOS_H_ 1
|
#define VULKAN_IOS_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,9 +13,14 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_MVK_ios_surface 1
|
#define VK_MVK_ios_surface 1
|
||||||
#define VK_MVK_IOS_SURFACE_SPEC_VERSION 2
|
#define VK_MVK_IOS_SURFACE_SPEC_VERSION 3
|
||||||
#define VK_MVK_IOS_SURFACE_EXTENSION_NAME "VK_MVK_ios_surface"
|
#define VK_MVK_IOS_SURFACE_EXTENSION_NAME "VK_MVK_ios_surface"
|
||||||
typedef VkFlags VkIOSSurfaceCreateFlagsMVK;
|
typedef VkFlags VkIOSSurfaceCreateFlagsMVK;
|
||||||
typedef struct VkIOSSurfaceCreateInfoMVK {
|
typedef struct VkIOSSurfaceCreateInfoMVK {
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_MACOS_H_
|
#ifndef VULKAN_MACOS_H_
|
||||||
#define VULKAN_MACOS_H_ 1
|
#define VULKAN_MACOS_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,9 +13,14 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_MVK_macos_surface 1
|
#define VK_MVK_macos_surface 1
|
||||||
#define VK_MVK_MACOS_SURFACE_SPEC_VERSION 2
|
#define VK_MVK_MACOS_SURFACE_SPEC_VERSION 3
|
||||||
#define VK_MVK_MACOS_SURFACE_EXTENSION_NAME "VK_MVK_macos_surface"
|
#define VK_MVK_MACOS_SURFACE_EXTENSION_NAME "VK_MVK_macos_surface"
|
||||||
typedef VkFlags VkMacOSSurfaceCreateFlagsMVK;
|
typedef VkFlags VkMacOSSurfaceCreateFlagsMVK;
|
||||||
typedef struct VkMacOSSurfaceCreateInfoMVK {
|
typedef struct VkMacOSSurfaceCreateInfoMVK {
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_METAL_H_
|
#ifndef VULKAN_METAL_H_
|
||||||
#define VULKAN_METAL_H_ 1
|
#define VULKAN_METAL_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_EXT_metal_surface 1
|
#define VK_EXT_metal_surface 1
|
||||||
|
|
||||||
|
|
|
@ -1,65 +0,0 @@
|
||||||
#ifndef VULKAN_MIR_H_
|
|
||||||
#define VULKAN_MIR_H_ 1
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
** Copyright (c) 2015-2018 The Khronos Group Inc.
|
|
||||||
**
|
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
** This header is generated from the Khronos Vulkan XML API Registry.
|
|
||||||
**
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_KHR_mir_surface 1
|
|
||||||
#define VK_KHR_MIR_SURFACE_SPEC_VERSION 4
|
|
||||||
#define VK_KHR_MIR_SURFACE_EXTENSION_NAME "VK_KHR_mir_surface"
|
|
||||||
|
|
||||||
typedef VkFlags VkMirSurfaceCreateFlagsKHR;
|
|
||||||
|
|
||||||
typedef struct VkMirSurfaceCreateInfoKHR {
|
|
||||||
VkStructureType sType;
|
|
||||||
const void* pNext;
|
|
||||||
VkMirSurfaceCreateFlagsKHR flags;
|
|
||||||
MirConnection* connection;
|
|
||||||
MirSurface* mirSurface;
|
|
||||||
} VkMirSurfaceCreateInfoKHR;
|
|
||||||
|
|
||||||
|
|
||||||
typedef VkResult (VKAPI_PTR *PFN_vkCreateMirSurfaceKHR)(VkInstance instance, const VkMirSurfaceCreateInfoKHR* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
|
|
||||||
typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceMirPresentationSupportKHR)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, MirConnection* connection);
|
|
||||||
|
|
||||||
#ifndef VK_NO_PROTOTYPES
|
|
||||||
VKAPI_ATTR VkResult VKAPI_CALL vkCreateMirSurfaceKHR(
|
|
||||||
VkInstance instance,
|
|
||||||
const VkMirSurfaceCreateInfoKHR* pCreateInfo,
|
|
||||||
const VkAllocationCallbacks* pAllocator,
|
|
||||||
VkSurfaceKHR* pSurface);
|
|
||||||
|
|
||||||
VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceMirPresentationSupportKHR(
|
|
||||||
VkPhysicalDevice physicalDevice,
|
|
||||||
uint32_t queueFamilyIndex,
|
|
||||||
MirConnection* connection);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
54
src/common/rendering/vulkan/thirdparty/vulkan/vulkan_screen.h
vendored
Normal file
54
src/common/rendering/vulkan/thirdparty/vulkan/vulkan_screen.h
vendored
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
#ifndef VULKAN_SCREEN_H_
|
||||||
|
#define VULKAN_SCREEN_H_ 1
|
||||||
|
|
||||||
|
/*
|
||||||
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
|
**
|
||||||
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
** This header is generated from the Khronos Vulkan XML API Registry.
|
||||||
|
**
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define VK_QNX_screen_surface 1
|
||||||
|
#define VK_QNX_SCREEN_SURFACE_SPEC_VERSION 1
|
||||||
|
#define VK_QNX_SCREEN_SURFACE_EXTENSION_NAME "VK_QNX_screen_surface"
|
||||||
|
typedef VkFlags VkScreenSurfaceCreateFlagsQNX;
|
||||||
|
typedef struct VkScreenSurfaceCreateInfoQNX {
|
||||||
|
VkStructureType sType;
|
||||||
|
const void* pNext;
|
||||||
|
VkScreenSurfaceCreateFlagsQNX flags;
|
||||||
|
struct _screen_context* context;
|
||||||
|
struct _screen_window* window;
|
||||||
|
} VkScreenSurfaceCreateInfoQNX;
|
||||||
|
|
||||||
|
typedef VkResult (VKAPI_PTR *PFN_vkCreateScreenSurfaceQNX)(VkInstance instance, const VkScreenSurfaceCreateInfoQNX* pCreateInfo, const VkAllocationCallbacks* pAllocator, VkSurfaceKHR* pSurface);
|
||||||
|
typedef VkBool32 (VKAPI_PTR *PFN_vkGetPhysicalDeviceScreenPresentationSupportQNX)(VkPhysicalDevice physicalDevice, uint32_t queueFamilyIndex, struct _screen_window* window);
|
||||||
|
|
||||||
|
#ifndef VK_NO_PROTOTYPES
|
||||||
|
VKAPI_ATTR VkResult VKAPI_CALL vkCreateScreenSurfaceQNX(
|
||||||
|
VkInstance instance,
|
||||||
|
const VkScreenSurfaceCreateInfoQNX* pCreateInfo,
|
||||||
|
const VkAllocationCallbacks* pAllocator,
|
||||||
|
VkSurfaceKHR* pSurface);
|
||||||
|
|
||||||
|
VKAPI_ATTR VkBool32 VKAPI_CALL vkGetPhysicalDeviceScreenPresentationSupportQNX(
|
||||||
|
VkPhysicalDevice physicalDevice,
|
||||||
|
uint32_t queueFamilyIndex,
|
||||||
|
struct _screen_window* window);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_VI_H_
|
#ifndef VULKAN_VI_H_
|
||||||
#define VULKAN_VI_H_ 1
|
#define VULKAN_VI_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_NN_vi_surface 1
|
#define VK_NN_vi_surface 1
|
||||||
#define VK_NN_VI_SURFACE_SPEC_VERSION 1
|
#define VK_NN_VI_SURFACE_SPEC_VERSION 1
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_WAYLAND_H_
|
#ifndef VULKAN_WAYLAND_H_
|
||||||
#define VULKAN_WAYLAND_H_ 1
|
#define VULKAN_WAYLAND_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_KHR_wayland_surface 1
|
#define VK_KHR_wayland_surface 1
|
||||||
#define VK_KHR_WAYLAND_SURFACE_SPEC_VERSION 6
|
#define VK_KHR_WAYLAND_SURFACE_SPEC_VERSION 6
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_WIN32_H_
|
#ifndef VULKAN_WIN32_H_
|
||||||
#define VULKAN_WIN32_H_ 1
|
#define VULKAN_WIN32_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_KHR_win32_surface 1
|
#define VK_KHR_win32_surface 1
|
||||||
#define VK_KHR_WIN32_SURFACE_SPEC_VERSION 6
|
#define VK_KHR_WIN32_SURFACE_SPEC_VERSION 6
|
||||||
|
@ -246,7 +237,7 @@ VKAPI_ATTR VkResult VKAPI_CALL vkGetMemoryWin32HandleNV(
|
||||||
|
|
||||||
|
|
||||||
#define VK_NV_win32_keyed_mutex 1
|
#define VK_NV_win32_keyed_mutex 1
|
||||||
#define VK_NV_WIN32_KEYED_MUTEX_SPEC_VERSION 1
|
#define VK_NV_WIN32_KEYED_MUTEX_SPEC_VERSION 2
|
||||||
#define VK_NV_WIN32_KEYED_MUTEX_EXTENSION_NAME "VK_NV_win32_keyed_mutex"
|
#define VK_NV_WIN32_KEYED_MUTEX_EXTENSION_NAME "VK_NV_win32_keyed_mutex"
|
||||||
typedef struct VkWin32KeyedMutexAcquireReleaseInfoNV {
|
typedef struct VkWin32KeyedMutexAcquireReleaseInfoNV {
|
||||||
VkStructureType sType;
|
VkStructureType sType;
|
||||||
|
@ -263,7 +254,7 @@ typedef struct VkWin32KeyedMutexAcquireReleaseInfoNV {
|
||||||
|
|
||||||
|
|
||||||
#define VK_EXT_full_screen_exclusive 1
|
#define VK_EXT_full_screen_exclusive 1
|
||||||
#define VK_EXT_FULL_SCREEN_EXCLUSIVE_SPEC_VERSION 3
|
#define VK_EXT_FULL_SCREEN_EXCLUSIVE_SPEC_VERSION 4
|
||||||
#define VK_EXT_FULL_SCREEN_EXCLUSIVE_EXTENSION_NAME "VK_EXT_full_screen_exclusive"
|
#define VK_EXT_FULL_SCREEN_EXCLUSIVE_EXTENSION_NAME "VK_EXT_full_screen_exclusive"
|
||||||
|
|
||||||
typedef enum VkFullScreenExclusiveEXT {
|
typedef enum VkFullScreenExclusiveEXT {
|
||||||
|
@ -271,9 +262,6 @@ typedef enum VkFullScreenExclusiveEXT {
|
||||||
VK_FULL_SCREEN_EXCLUSIVE_ALLOWED_EXT = 1,
|
VK_FULL_SCREEN_EXCLUSIVE_ALLOWED_EXT = 1,
|
||||||
VK_FULL_SCREEN_EXCLUSIVE_DISALLOWED_EXT = 2,
|
VK_FULL_SCREEN_EXCLUSIVE_DISALLOWED_EXT = 2,
|
||||||
VK_FULL_SCREEN_EXCLUSIVE_APPLICATION_CONTROLLED_EXT = 3,
|
VK_FULL_SCREEN_EXCLUSIVE_APPLICATION_CONTROLLED_EXT = 3,
|
||||||
VK_FULL_SCREEN_EXCLUSIVE_BEGIN_RANGE_EXT = VK_FULL_SCREEN_EXCLUSIVE_DEFAULT_EXT,
|
|
||||||
VK_FULL_SCREEN_EXCLUSIVE_END_RANGE_EXT = VK_FULL_SCREEN_EXCLUSIVE_APPLICATION_CONTROLLED_EXT,
|
|
||||||
VK_FULL_SCREEN_EXCLUSIVE_RANGE_SIZE_EXT = (VK_FULL_SCREEN_EXCLUSIVE_APPLICATION_CONTROLLED_EXT - VK_FULL_SCREEN_EXCLUSIVE_DEFAULT_EXT + 1),
|
|
||||||
VK_FULL_SCREEN_EXCLUSIVE_MAX_ENUM_EXT = 0x7FFFFFFF
|
VK_FULL_SCREEN_EXCLUSIVE_MAX_ENUM_EXT = 0x7FFFFFFF
|
||||||
} VkFullScreenExclusiveEXT;
|
} VkFullScreenExclusiveEXT;
|
||||||
typedef struct VkSurfaceFullScreenExclusiveInfoEXT {
|
typedef struct VkSurfaceFullScreenExclusiveInfoEXT {
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_XCB_H_
|
#ifndef VULKAN_XCB_H_
|
||||||
#define VULKAN_XCB_H_ 1
|
#define VULKAN_XCB_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_KHR_xcb_surface 1
|
#define VK_KHR_xcb_surface 1
|
||||||
#define VK_KHR_XCB_SURFACE_SPEC_VERSION 6
|
#define VK_KHR_XCB_SURFACE_SPEC_VERSION 6
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_XLIB_H_
|
#ifndef VULKAN_XLIB_H_
|
||||||
#define VULKAN_XLIB_H_ 1
|
#define VULKAN_XLIB_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_KHR_xlib_surface 1
|
#define VK_KHR_xlib_surface 1
|
||||||
#define VK_KHR_XLIB_SURFACE_SPEC_VERSION 6
|
#define VK_KHR_XLIB_SURFACE_SPEC_VERSION 6
|
||||||
|
|
|
@ -1,24 +1,10 @@
|
||||||
#ifndef VULKAN_XLIB_XRANDR_H_
|
#ifndef VULKAN_XLIB_XRANDR_H_
|
||||||
#define VULKAN_XLIB_XRANDR_H_ 1
|
#define VULKAN_XLIB_XRANDR_H_ 1
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Copyright (c) 2015-2019 The Khronos Group Inc.
|
** Copyright 2015-2021 The Khronos Group Inc.
|
||||||
**
|
**
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
** SPDX-License-Identifier: Apache-2.0
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -27,6 +13,11 @@ extern "C" {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define VK_EXT_acquire_xlib_display 1
|
#define VK_EXT_acquire_xlib_display 1
|
||||||
#define VK_EXT_ACQUIRE_XLIB_DISPLAY_SPEC_VERSION 1
|
#define VK_EXT_ACQUIRE_XLIB_DISPLAY_SPEC_VERSION 1
|
||||||
|
|
|
@ -162,7 +162,7 @@ DEFINE_ACTION_FUNCTION_NATIVE(DStatusBarCore, DrawImageRotated, SBar_DrawImageRo
|
||||||
void SBar_DrawTextureRotated(DStatusBarCore* self, int texid, double x, double y, int flags, double angle, double alpha, double scaleX, double scaleY, int style, int color, int translation)
|
void SBar_DrawTextureRotated(DStatusBarCore* self, int texid, double x, double y, int flags, double angle, double alpha, double scaleX, double scaleY, int style, int color, int translation)
|
||||||
{
|
{
|
||||||
if (!twod->HasBegun2D()) ThrowAbortException(X_OTHER, "Attempt to draw to screen outside a draw function");
|
if (!twod->HasBegun2D()) ThrowAbortException(X_OTHER, "Attempt to draw to screen outside a draw function");
|
||||||
self->DrawRotated(FSetTextureID(texid), x, y, flags, alpha, scaleX, scaleY, color, translation, style);
|
self->DrawRotated(FSetTextureID(texid), x, y, flags, angle, alpha, scaleX, scaleY, color, translation, (ERenderStyle)style);
|
||||||
}
|
}
|
||||||
|
|
||||||
DEFINE_ACTION_FUNCTION_NATIVE(DStatusBarCore, DrawTextureRotated, SBar_DrawTextureRotated)
|
DEFINE_ACTION_FUNCTION_NATIVE(DStatusBarCore, DrawTextureRotated, SBar_DrawTextureRotated)
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
#include "v_video.h"
|
#include "v_video.h"
|
||||||
|
|
||||||
|
|
||||||
CVAR(Bool, gl_customshader, true, 0);
|
CVAR(Bool, gl_customshader, true, CVAR_ARCHIVE | CVAR_GLOBALCONFIG | CVAR_NOINITCALL);
|
||||||
|
|
||||||
|
|
||||||
static IHardwareTexture* (*layercallback)(int layer, int translation);
|
static IHardwareTexture* (*layercallback)(int layer, int translation);
|
||||||
|
|
|
@ -2,16 +2,7 @@
|
||||||
|
|
||||||
// Simple lightweight reference counting pointer alternative for std::shared_ptr which stores the reference counter in the handled object itself.
|
// Simple lightweight reference counting pointer alternative for std::shared_ptr which stores the reference counter in the handled object itself.
|
||||||
|
|
||||||
// Base classes for handled objects
|
// Base class for handled objects
|
||||||
class NoVirtualRefCountedBase
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
void IncRef() { refCount++; }
|
|
||||||
void DecRef() { if (--refCount <= 0) delete this; }
|
|
||||||
private:
|
|
||||||
int refCount = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
class RefCountedBase
|
class RefCountedBase
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -1026,18 +1026,31 @@ void D_Display ()
|
||||||
// draw pause pic
|
// draw pause pic
|
||||||
if ((paused || pauseext) && menuactive == MENU_Off)
|
if ((paused || pauseext) && menuactive == MENU_Off)
|
||||||
{
|
{
|
||||||
auto tex = TexMan.GetGameTextureByName(gameinfo.PauseSign, true);
|
// [MK] optionally let the status bar handle this
|
||||||
double x = (SCREENWIDTH - tex->GetDisplayWidth() * CleanXfac)/2 +
|
bool skip = false;
|
||||||
tex->GetDisplayLeftOffset() * CleanXfac;
|
IFVIRTUALPTR(StatusBar, DBaseStatusBar, DrawPaused)
|
||||||
DrawTexture(twod, tex, x, 4, DTA_CleanNoMove, true, TAG_DONE);
|
|
||||||
if (paused && multiplayer)
|
|
||||||
{
|
{
|
||||||
FFont *font = generic_ui? NewSmallFont : SmallFont;
|
VMValue params[] { (DObject*)StatusBar, paused-1 };
|
||||||
FString pstring = GStrings("TXT_BY");
|
int rv;
|
||||||
pstring.Substitute("%s", players[paused - 1].userinfo.GetName());
|
VMReturn ret(&rv);
|
||||||
DrawText(twod, font, CR_RED,
|
VMCall(func, params, countof(params), &ret, 1);
|
||||||
(twod->GetWidth() - font->StringWidth(pstring)*CleanXfac) / 2,
|
skip = !!rv;
|
||||||
(tex->GetDisplayHeight() * CleanYfac) + 4, pstring, DTA_CleanNoMove, true, TAG_DONE);
|
}
|
||||||
|
if ( !skip )
|
||||||
|
{
|
||||||
|
auto tex = TexMan.GetGameTextureByName(gameinfo.PauseSign, true);
|
||||||
|
double x = (SCREENWIDTH - tex->GetDisplayWidth() * CleanXfac)/2 +
|
||||||
|
tex->GetDisplayLeftOffset() * CleanXfac;
|
||||||
|
DrawTexture(twod, tex, x, 4, DTA_CleanNoMove, true, TAG_DONE);
|
||||||
|
if (paused && multiplayer)
|
||||||
|
{
|
||||||
|
FFont *font = generic_ui? NewSmallFont : SmallFont;
|
||||||
|
FString pstring = GStrings("TXT_BY");
|
||||||
|
pstring.Substitute("%s", players[paused - 1].userinfo.GetName());
|
||||||
|
DrawText(twod, font, CR_RED,
|
||||||
|
(twod->GetWidth() - font->StringWidth(pstring)*CleanXfac) / 2,
|
||||||
|
(tex->GetDisplayHeight() * CleanYfac) + 4, pstring, DTA_CleanNoMove, true, TAG_DONE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -404,6 +404,8 @@ void FMapInfoParser::ParseGameInfo()
|
||||||
GAMEINFOKEY_MUSIC(intermissionMusic, intermissionOrder, "intermissionMusic")
|
GAMEINFOKEY_MUSIC(intermissionMusic, intermissionOrder, "intermissionMusic")
|
||||||
GAMEINFOKEY_STRING(CursorPic, "CursorPic")
|
GAMEINFOKEY_STRING(CursorPic, "CursorPic")
|
||||||
GAMEINFOKEY_STRING(MessageBoxClass, "MessageBoxClass")
|
GAMEINFOKEY_STRING(MessageBoxClass, "MessageBoxClass")
|
||||||
|
GAMEINFOKEY_STRING(HelpMenuClass, "HelpMenuClass")
|
||||||
|
GAMEINFOKEY_STRING(MenuDelegateClass, "MenuDelegateClass")
|
||||||
GAMEINFOKEY_BOOL(noloopfinalemusic, "noloopfinalemusic")
|
GAMEINFOKEY_BOOL(noloopfinalemusic, "noloopfinalemusic")
|
||||||
GAMEINFOKEY_BOOL(drawreadthis, "drawreadthis")
|
GAMEINFOKEY_BOOL(drawreadthis, "drawreadthis")
|
||||||
GAMEINFOKEY_BOOL(swapmenu, "swapmenu")
|
GAMEINFOKEY_BOOL(swapmenu, "swapmenu")
|
||||||
|
|
|
@ -162,6 +162,8 @@ struct gameinfo_t
|
||||||
FName althudclass;
|
FName althudclass;
|
||||||
int statusbarclassfile = -1;
|
int statusbarclassfile = -1;
|
||||||
FName MessageBoxClass;
|
FName MessageBoxClass;
|
||||||
|
FName HelpMenuClass;
|
||||||
|
FName MenuDelegateClass;
|
||||||
FName backpacktype;
|
FName backpacktype;
|
||||||
FString intermissionMusic;
|
FString intermissionMusic;
|
||||||
int intermissionOrder;
|
int intermissionOrder;
|
||||||
|
|
|
@ -202,6 +202,10 @@ bool M_SetSpecialMenu(FName& menu, int param)
|
||||||
menu = NAME_Optionsmenu;
|
menu = NAME_Optionsmenu;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case NAME_Readthismenu:
|
||||||
|
// [MK] allow us to override the ReadThisMenu class
|
||||||
|
menu = gameinfo.HelpMenuClass;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
DMenuDescriptor** desc = MenuDescriptors.CheckKey(menu);
|
DMenuDescriptor** desc = MenuDescriptors.CheckKey(menu);
|
||||||
|
@ -1300,7 +1304,17 @@ void SetDefaultMenuColors()
|
||||||
OptionSettings.mFontColorHighlight = V_FindFontColor(gameinfo.mFontColorHighlight);
|
OptionSettings.mFontColorHighlight = V_FindFontColor(gameinfo.mFontColorHighlight);
|
||||||
OptionSettings.mFontColorSelection = V_FindFontColor(gameinfo.mFontColorSelection);
|
OptionSettings.mFontColorSelection = V_FindFontColor(gameinfo.mFontColorSelection);
|
||||||
|
|
||||||
auto cls = PClass::FindClass("DoomMenuDelegate");
|
auto cls = PClass::FindClass(gameinfo.HelpMenuClass);
|
||||||
|
if (!cls)
|
||||||
|
I_FatalError("%s: Undefined help menu class", gameinfo.HelpMenuClass.GetChars());
|
||||||
|
if (!cls->IsDescendantOf(RUNTIME_CLASS(DMenu)))
|
||||||
|
I_FatalError("'%s' does not inherit from Menu", gameinfo.HelpMenuClass.GetChars());
|
||||||
|
|
||||||
|
cls = PClass::FindClass(gameinfo.MenuDelegateClass);
|
||||||
|
if (!cls)
|
||||||
|
I_FatalError("%s: Undefined menu delegate class", gameinfo.HelpMenuClass.GetChars());
|
||||||
|
if (!cls->IsDescendantOf("MenuDelegateBase"))
|
||||||
|
I_FatalError("'%s' does not inherit from MenuDelegateBase", gameinfo.MenuDelegateClass.GetChars());
|
||||||
menuDelegate = cls->CreateNew();
|
menuDelegate = cls->CreateNew();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -499,6 +499,8 @@ bool AActor::SetState (FState *newstate, bool nofunction)
|
||||||
{
|
{
|
||||||
if (debugfile && player && (player->cheats & CF_PREDICTING))
|
if (debugfile && player && (player->cheats & CF_PREDICTING))
|
||||||
fprintf (debugfile, "for pl %d: SetState while predicting!\n", Level->PlayerNum(player));
|
fprintf (debugfile, "for pl %d: SetState while predicting!\n", Level->PlayerNum(player));
|
||||||
|
|
||||||
|
auto oldstate = state;
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
if (newstate == NULL)
|
if (newstate == NULL)
|
||||||
|
@ -584,7 +586,7 @@ bool AActor::SetState (FState *newstate, bool nofunction)
|
||||||
newstate = newstate->GetNextState();
|
newstate = newstate->GetNextState();
|
||||||
} while (tics == 0);
|
} while (tics == 0);
|
||||||
|
|
||||||
if (GetInfo()->LightAssociations.Size() || (state && state->Light > 0))
|
if (GetInfo()->LightAssociations.Size() || (state && state->Light > 0) || (oldstate && oldstate->Light > 0))
|
||||||
{
|
{
|
||||||
flags8 |= MF8_RECREATELIGHTS;
|
flags8 |= MF8_RECREATELIGHTS;
|
||||||
Level->flags3 |= LEVEL3_LIGHTCREATED;
|
Level->flags3 |= LEVEL3_LIGHTCREATED;
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
<key>LSApplicationCategoryType</key>
|
<key>LSApplicationCategoryType</key>
|
||||||
<string>public.app-category.action-games</string>
|
<string>public.app-category.action-games</string>
|
||||||
<key>LSMinimumSystemVersion</key>
|
<key>LSMinimumSystemVersion</key>
|
||||||
<string>10.9</string>
|
<string>10.12</string>
|
||||||
<key>CFBundleDocumentTypes</key>
|
<key>CFBundleDocumentTypes</key>
|
||||||
<array>
|
<array>
|
||||||
<dict>
|
<dict>
|
||||||
|
|
|
@ -791,4 +791,6 @@ Swap mouse buttons,MOUSEMNU_SWAPBUTTONS,,,,Prohodit tlačítka myši,Maustasten
|
||||||
Environment map on mirrors,GLPREFMNU_ENVIRONMENTMAPMIRROR,,,,Mapa prostředí na zrcadlech,Lichteffekt auf Spiegeln,,Medimapo sur speguloj,Mapa de entorno en espejos,,Ympäristökartta peileissä,Mappage environment sur les miroirs,Környezettérkép a tükrökön,Ambiente mappa sugli specchi,マップオンミラーの画像表示,거울 주변의지도 활성,Milieukaart op spiegels,Mapa środowiska w lustrach,Mapa de ambiente em espelhos,,Efecte suplimentare pentru oglinzi,Карта окружения на зеркалах,Околинска мапа на прозорима
|
Environment map on mirrors,GLPREFMNU_ENVIRONMENTMAPMIRROR,,,,Mapa prostředí na zrcadlech,Lichteffekt auf Spiegeln,,Medimapo sur speguloj,Mapa de entorno en espejos,,Ympäristökartta peileissä,Mappage environment sur les miroirs,Környezettérkép a tükrökön,Ambiente mappa sugli specchi,マップオンミラーの画像表示,거울 주변의지도 활성,Milieukaart op spiegels,Mapa środowiska w lustrach,Mapa de ambiente em espelhos,,Efecte suplimentare pentru oglinzi,Карта окружения на зеркалах,Околинска мапа на прозорима
|
||||||
OpenGL ES,OPTVAL_OPENGLES,Rendering backend,,,,,,,,,,,,,,,,,OpenGL ES,,,,
|
OpenGL ES,OPTVAL_OPENGLES,Rendering backend,,,,,,,,,,,,,,,,,OpenGL ES,,,,
|
||||||
Press any key or click anywhere in the window to quit.,TXT_QUITENDOOM,,,,"Pro ukončení stiskni libovolnou klávesu, nebo klikni kdekoliv v okně.",Drücke eine Taste oder klicke mit der Maus ins Fenster zum Beenden.,Πάτα οποιοδήποτε πλήκτρο ή πάτα οπουδήποτε για να κάνεις έξοδο,Premu ajnan klavon aŭ alklaku ie ajn en la fenestro por forlasi.,Presiona una tecla o haz click en cualquier lugar de la ventana para salir.,Presiona una tecla o da click en cualquier lugar de la ventana para salir.,Paina mitä tahansa näppäintä tai napsauta minne tahansa ikkunaa lopettaaksesi.,Appuyez sur une touche ou cliquez pour quitter.,Nyomjon egy gombot vagy kattintson valahova a kilépéshez.,Premi un qualunque tasto o fai un click ovunque nella finestra per uscire.,何かのキーを押すか、ウィンドウのどこかをクリックすると終了する。,아무 키를 누르거나 아무 곳이나 클릭하면 종료됩니다.,Druk op een willekeurige toets of klik ergens in het venster om te stoppen.,Wciśnij dowolny klawisz lub gdziekolwiek kliknij myszką aby wyjść.,Aperte uma tecla ou clique em qualquer lugar na janela para sair.,Carrega numa tecla ou clique em qualquer lugar na janela para sair.,Apasă orice tastă sau dă click oriunde în fereastră pentru a ieși.,"Нажмите любую клавишу или кликните по окну, чтобы выйти.",Притисните било који тастер или кликните било где на екрану да одустанете.
|
Press any key or click anywhere in the window to quit.,TXT_QUITENDOOM,,,,"Pro ukončení stiskni libovolnou klávesu, nebo klikni kdekoliv v okně.",Drücke eine Taste oder klicke mit der Maus ins Fenster zum Beenden.,Πάτα οποιοδήποτε πλήκτρο ή πάτα οπουδήποτε για να κάνεις έξοδο,Premu ajnan klavon aŭ alklaku ie ajn en la fenestro por forlasi.,Presiona una tecla o haz click en cualquier lugar de la ventana para salir.,Presiona una tecla o da click en cualquier lugar de la ventana para salir.,Paina mitä tahansa näppäintä tai napsauta minne tahansa ikkunaa lopettaaksesi.,Appuyez sur une touche ou cliquez pour quitter.,Nyomjon egy gombot vagy kattintson valahova a kilépéshez.,Premi un qualunque tasto o fai un click ovunque nella finestra per uscire.,何かのキーを押すか、ウィンドウのどこかをクリックすると終了する。,아무 키를 누르거나 아무 곳이나 클릭하면 종료됩니다.,Druk op een willekeurige toets of klik ergens in het venster om te stoppen.,Wciśnij dowolny klawisz lub gdziekolwiek kliknij myszką aby wyjść.,Aperte uma tecla ou clique em qualquer lugar na janela para sair.,Carrega numa tecla ou clique em qualquer lugar na janela para sair.,Apasă orice tastă sau dă click oriunde în fereastră pentru a ieși.,"Нажмите любую клавишу или кликните по окну, чтобы выйти.",Притисните било који тастер или кликните било где на екрану да одустанете.
|
||||||
Only modified,OPTVAL_ONLYMODIFIED,,,,Pouze upravené,Nur modfizierte,,Sole modifita,Solo modificados,,Vain muunneltu,Modifié seulement,Csak módosított,Solo modificato,モディファイのみ,수정된 것만,Alleen gewijzigd,Tylko zmodyfikowane,Somente modificado,,Numai modificat,Только в модификациях,Само модификовано
|
Only modified,OPTVAL_ONLYMODIFIED,,,,Pouze upravené,Nur modfizierte,,Sole modifita,Solo modificados,,Vain muunneltu,Modifié seulement,Csak módosított,Solo modificato,モディファイのみ,수정된 것만,Alleen gewijzigd,Tylko zmodyfikowane,Somente modificado,,Numai modificat,Только в модификациях,Само модификовано
|
||||||
|
Line alpha,AUTOMAPMNU_LINEALPHA,,,,,Alpha für Linien,,,,,,,,,,,,,,,,,
|
||||||
|
Line thickness,AUTOMAPMNU_LINETHICKNESS,,,,,Dicke der Linien,,,,,,,,,,,,,,,,,
|
|
@ -74,6 +74,8 @@ gameinfo
|
||||||
statscreen_dm = "DeathmatchStatusScreen"
|
statscreen_dm = "DeathmatchStatusScreen"
|
||||||
statscreen_single = "DoomStatusScreen"
|
statscreen_single = "DoomStatusScreen"
|
||||||
messageboxclass = "MessageBoxMenu"
|
messageboxclass = "MessageBoxMenu"
|
||||||
|
helpmenuclass = "ReadThisMenu"
|
||||||
|
menudelegateclass = "DoomMenuDelegate"
|
||||||
normforwardmove = 0x19, 0x32
|
normforwardmove = 0x19, 0x32
|
||||||
normsidemove = 0x18, 0x28
|
normsidemove = 0x18, 0x28
|
||||||
}
|
}
|
||||||
|
|
|
@ -75,6 +75,8 @@ gameinfo
|
||||||
statscreen_dm = "DeathmatchStatusScreen"
|
statscreen_dm = "DeathmatchStatusScreen"
|
||||||
statscreen_single = "DoomStatusScreen"
|
statscreen_single = "DoomStatusScreen"
|
||||||
messageboxclass = "MessageBoxMenu"
|
messageboxclass = "MessageBoxMenu"
|
||||||
|
helpmenuclass = "ReadThisMenu"
|
||||||
|
menudelegateclass = "DoomMenuDelegate"
|
||||||
normforwardmove = 0x19, 0x32
|
normforwardmove = 0x19, 0x32
|
||||||
normsidemove = 0x18, 0x28
|
normsidemove = 0x18, 0x28
|
||||||
}
|
}
|
||||||
|
|
|
@ -73,6 +73,8 @@ gameinfo
|
||||||
statscreen_dm = "DeathmatchStatusScreen"
|
statscreen_dm = "DeathmatchStatusScreen"
|
||||||
statscreen_single = "RavenStatusScreen"
|
statscreen_single = "RavenStatusScreen"
|
||||||
messageboxclass = "MessageBoxMenu"
|
messageboxclass = "MessageBoxMenu"
|
||||||
|
helpmenuclass = "ReadThisMenu"
|
||||||
|
menudelegateclass = "DoomMenuDelegate"
|
||||||
normforwardmove = 0x19, 0x32
|
normforwardmove = 0x19, 0x32
|
||||||
normsidemove = 0x18, 0x28
|
normsidemove = 0x18, 0x28
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,6 +71,8 @@ gameinfo
|
||||||
statscreen_dm = "DeathmatchStatusScreen"
|
statscreen_dm = "DeathmatchStatusScreen"
|
||||||
statscreen_single = "RavenStatusScreen"
|
statscreen_single = "RavenStatusScreen"
|
||||||
messageboxclass = "MessageBoxMenu"
|
messageboxclass = "MessageBoxMenu"
|
||||||
|
helpmenuclass = "ReadThisMenu"
|
||||||
|
menudelegateclass = "DoomMenuDelegate"
|
||||||
normforwardmove = 0x19, 0x32
|
normforwardmove = 0x19, 0x32
|
||||||
normsidemove = 0x18, 0x28
|
normsidemove = 0x18, 0x28
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,6 +61,8 @@ gameinfo
|
||||||
statscreen_contentfont = "*BigFont"
|
statscreen_contentfont = "*BigFont"
|
||||||
statscreen_authorFont = "*SmallFont"
|
statscreen_authorFont = "*SmallFont"
|
||||||
messageboxclass = "MessageBoxMenu"
|
messageboxclass = "MessageBoxMenu"
|
||||||
|
helpmenuclass = "ReadThisMenu"
|
||||||
|
menudelegateclass = "DoomMenuDelegate"
|
||||||
}
|
}
|
||||||
|
|
||||||
gamedefaults
|
gamedefaults
|
||||||
|
|
|
@ -73,6 +73,8 @@ gameinfo
|
||||||
statscreen_single = "RavenStatusScreen"
|
statscreen_single = "RavenStatusScreen"
|
||||||
statusbarclass = "StrifeStatusBar"
|
statusbarclass = "StrifeStatusBar"
|
||||||
messageboxclass = "MessageBoxMenu"
|
messageboxclass = "MessageBoxMenu"
|
||||||
|
helpmenuclass = "ReadThisMenu"
|
||||||
|
menudelegateclass = "DoomMenuDelegate"
|
||||||
normforwardmove = 0x19, 0x32
|
normforwardmove = 0x19, 0x32
|
||||||
normsidemove = 0x18, 0x28
|
normsidemove = 0x18, 0x28
|
||||||
}
|
}
|
||||||
|
|
|
@ -1339,9 +1339,11 @@ OptionMenu AutomapOptions protected
|
||||||
|
|
||||||
StaticText ""
|
StaticText ""
|
||||||
Option "$AUTOMAPMNU_ROTATE", "am_rotate", "RotateTypes"
|
Option "$AUTOMAPMNU_ROTATE", "am_rotate", "RotateTypes"
|
||||||
|
Option "$AUTOMAPMNU_FOLLOW", "am_followplayer", "OnOff"
|
||||||
Option "$AUTOMAPMNU_OVERLAY", "am_overlay", "OverlayTypes"
|
Option "$AUTOMAPMNU_OVERLAY", "am_overlay", "OverlayTypes"
|
||||||
Option "$AUTOMAPMNU_TEXTURED", "am_textured", "OnOff"
|
Option "$AUTOMAPMNU_TEXTURED", "am_textured", "OnOff"
|
||||||
Option "$AUTOMAPMNU_FOLLOW", "am_followplayer", "OnOff"
|
Slider "$AUTOMAPMNU_LINEALPHA", "am_linealpha", 0.1, 1.0, 0.1, 1
|
||||||
|
Slider "$AUTOMAPMNU_LINETHICKNESS", "am_linethickness", 1, 8, 1, 0
|
||||||
|
|
||||||
StaticText ""
|
StaticText ""
|
||||||
Option "$AUTOMAPMNU_SHOWITEMS", "am_showitems", "OnOff"
|
Option "$AUTOMAPMNU_SHOWITEMS", "am_showitems", "OnOff"
|
||||||
|
|
|
@ -853,6 +853,17 @@ class Inventory : Actor
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// Inventory :: PreTravelled
|
||||||
|
//
|
||||||
|
// Called when an item in somebody's inventory is about to be carried
|
||||||
|
// over to another map, in case it needs to do special clean-up.
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
virtual void PreTravelled() {}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
//
|
//
|
||||||
// Inventory :: Travelled
|
// Inventory :: Travelled
|
||||||
|
|
|
@ -2083,6 +2083,15 @@ class PlayerPawn : Actor
|
||||||
me.ClearInventory();
|
me.ClearInventory();
|
||||||
me.GiveDefaultInventory();
|
me.GiveDefaultInventory();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// [MK] notify self and inventory that we're about to travel
|
||||||
|
// this must be called here so these functions can still have a
|
||||||
|
// chance to alter the world before a snapshot is done in hubs
|
||||||
|
me.PreTravelled();
|
||||||
|
for (item = me.Inv; item != NULL; item = item.Inv)
|
||||||
|
{
|
||||||
|
item.PreTravelled();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
@ -2461,6 +2470,18 @@ class PlayerPawn : Actor
|
||||||
return wasdrowning;
|
return wasdrowning;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//===========================================================================
|
||||||
|
//
|
||||||
|
// PlayerPawn :: PreTravelled
|
||||||
|
//
|
||||||
|
// Called before the player moves to another map, in case it needs to do
|
||||||
|
// special clean-up. This is called right before all carried items
|
||||||
|
// execute their respective PreTravelled() virtuals.
|
||||||
|
//
|
||||||
|
//===========================================================================
|
||||||
|
|
||||||
|
virtual void PreTravelled() {}
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
//
|
//
|
||||||
// PlayerPawn :: Travelled
|
// PlayerPawn :: Travelled
|
||||||
|
|
|
@ -7,6 +7,9 @@
|
||||||
// args[1] == 0, show the sprite always
|
// args[1] == 0, show the sprite always
|
||||||
// == 1, show the sprite only after its sector has been drawn
|
// == 1, show the sprite only after its sector has been drawn
|
||||||
//
|
//
|
||||||
|
// args[2] == 0, show the sprite with a constant scale
|
||||||
|
// == 1, show the sprite with a scale relative to automap zoom
|
||||||
|
//
|
||||||
// To enable display of the sprite, activate it. To turn off the sprite,
|
// To enable display of the sprite, activate it. To turn off the sprite,
|
||||||
// deactivate it.
|
// deactivate it.
|
||||||
//
|
//
|
||||||
|
|
|
@ -987,6 +987,15 @@ class LevelCompatibility : LevelPostProcessor
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case '6CDA2721AA1076F063557CF89D88E92B': // hexen.wad map08
|
||||||
|
{
|
||||||
|
// Amulet of warding accidentally shifted outside of map
|
||||||
|
SetThingXY(256,-1632,2352);
|
||||||
|
// Icon of the defender outside of map
|
||||||
|
SetThingSkills(261,0);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case '39C594CAC07EE51C80F757DA465FCC94': // strife1.wad map10
|
case '39C594CAC07EE51C80F757DA465FCC94': // strife1.wad map10
|
||||||
{
|
{
|
||||||
// fix the shooting range by matching sector 138 and 145 properties together
|
// fix the shooting range by matching sector 138 and 145 properties together
|
||||||
|
|
|
@ -235,6 +235,8 @@ class BaseStatusBar : StatusBarCore native
|
||||||
virtual bool ProcessMidPrint(Font fnt, String msg, bool bold) { return false; }
|
virtual bool ProcessMidPrint(Font fnt, String msg, bool bold) { return false; }
|
||||||
// [MK] let the HUD handle drawing the chat prompt
|
// [MK] let the HUD handle drawing the chat prompt
|
||||||
virtual bool DrawChat(String txt) { return false; }
|
virtual bool DrawChat(String txt) { return false; }
|
||||||
|
// [MK] let the HUD handle drawing the pause graphics
|
||||||
|
virtual bool DrawPaused(int player) { return false; }
|
||||||
|
|
||||||
native TextureID GetMugshot(int accuracy, int stateflags=MugShot.STANDARD, String default_face = "STF");
|
native TextureID GetMugshot(int accuracy, int stateflags=MugShot.STANDARD, String default_face = "STF");
|
||||||
native int GetTopOfStatusBar();
|
native int GetTopOfStatusBar();
|
||||||
|
|
2
wadsrc_widepix/static/.gitignore
vendored
Normal file
2
wadsrc_widepix/static/.gitignore
vendored
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
/psd
|
||||||
|
/reference
|
76
wadsrc_widepix/static/credits.txt
Normal file
76
wadsrc_widepix/static/credits.txt
Normal file
|
@ -0,0 +1,76 @@
|
||||||
|
WidePix v1.3
|
||||||
|
-------------
|
||||||
|
|
||||||
|
Made by Nash Muhandes
|
||||||
|
|
||||||
|
(C) 2020 - 2021 Nash Muhandes
|
||||||
|
|
||||||
|
Widescreen (16:9 and 21:9) graphical extensions.
|
||||||
|
|
||||||
|
Supported games:
|
||||||
|
- Doom
|
||||||
|
- Heretic
|
||||||
|
- Hexen
|
||||||
|
- Strife
|
||||||
|
- Chex Quest
|
||||||
|
- Hacx
|
||||||
|
- Harmony
|
||||||
|
|
||||||
|
Please see license.md for licensing info.
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
NOTE:
|
||||||
|
-----
|
||||||
|
|
||||||
|
WidePix was conceived on March 15, 2020, before there was any public knowledge
|
||||||
|
about the widescreen images that shipped with the September 2020 update of the
|
||||||
|
Unity port of Doom.
|
||||||
|
|
||||||
|
Differences between WidePix and Doom Unity:
|
||||||
|
|
||||||
|
- Completely built from the ground up (not based off Doom Unity's graphics)
|
||||||
|
- The original 4:3 portion is left completely unaltered where possible*
|
||||||
|
- Ultrawide (21:9) aspect ratio support
|
||||||
|
- Custom animation for Doom 1 Episode 3
|
||||||
|
- Weapon sprite extensions (both horizontally/vertically, where applicable)
|
||||||
|
|
||||||
|
* I generally avoid changing the center image as I feel it's important to
|
||||||
|
preserve the original artwork. However, that said, there are some cases where
|
||||||
|
alterations were unavoidable because not doing so would've made it impossible
|
||||||
|
to extend the images. I have documented such cases below:
|
||||||
|
|
||||||
|
TNT INTERPIC: There was a solid-black, 1-pixel border around the image.
|
||||||
|
|
||||||
|
Hexen TITLEPIC and INTERPIC: There were what appeared to be anti-aliasing
|
||||||
|
artifacts on the left and right borders.
|
||||||
|
|
||||||
|
Strife SS4F3, SS5F1, SS5F3, SS6F2, SS6F3, VELLOGO: Weird artifacts at the
|
||||||
|
borders made the images impossible to extend.
|
||||||
|
|
||||||
|
Chex Quest WIMAP0: There's a bright 1-pixel-wide sliver to the left.
|
||||||
|
|
||||||
|
CREDITS:
|
||||||
|
--------
|
||||||
|
|
||||||
|
id Software: For making Doom.
|
||||||
|
|
||||||
|
Nash Muhandes: For making WidePix.
|
||||||
|
|
||||||
|
Gez: For telling me the exact dimensions needed for the 21:9 graphics, and tips
|
||||||
|
on how to handle Wadsmoosh.
|
||||||
|
|
||||||
|
Kinsie: For providing the unaltered Doom 1 Registered TITLEPIC.
|
||||||
|
|
||||||
|
Rachael Alexanderson: Github maintenance help.
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
Some high resolution images were used as a source to create the widescreen
|
||||||
|
extensions. They are listed below.
|
||||||
|
|
||||||
|
Don Ivan Punchatz - Doom 1 cover artwork.
|
||||||
|
|
||||||
|
Gerald Brom - Doom 2 cover artwork.
|
||||||
|
|
||||||
|
Simon "fragglet" Howard: High res versions of the original cover artwork.
|
BIN
wadsrc_widepix/static/filter/chex.chex1/titlepic.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex1/titlepic.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex1/wimap0.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex1/wimap0.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/credit.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/credit.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/pfub1.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/pfub1.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/pfub2.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/pfub2.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/titlepic.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/titlepic.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/victory2.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex2/graphics/victory2.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/endpic.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/endpic.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/interpic.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/interpic.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/pfub1.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/pfub1.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/pfub2.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/pfub2.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/titlepic.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/titlepic.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/victory2.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/victory2.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/wimap0.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/wimap0.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/wimap1.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/wimap1.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/wimap2.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex.chex3/graphics/wimap2.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex/graphics/credit.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex/graphics/credit.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/chex/graphics/help1.lmp
Normal file
BIN
wadsrc_widepix/static/filter/chex/graphics/help1.lmp
Normal file
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
|
@ -0,0 +1,5 @@
|
||||||
|
graphic INTERPIC, 560, 200
|
||||||
|
{
|
||||||
|
patch INTER_E4, 0, 0 { }
|
||||||
|
}
|
||||||
|
|
BIN
wadsrc_widepix/static/filter/doom.id.doom1/graphics/credit.lmp
Normal file
BIN
wadsrc_widepix/static/filter/doom.id.doom1/graphics/credit.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/doom.id.doom1/graphics/help1.lmp
Normal file
BIN
wadsrc_widepix/static/filter/doom.id.doom1/graphics/help1.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/doom.id.doom1/graphics/help2.lmp
Normal file
BIN
wadsrc_widepix/static/filter/doom.id.doom1/graphics/help2.lmp
Normal file
Binary file not shown.
Binary file not shown.
|
@ -0,0 +1,10 @@
|
||||||
|
graphic BOSSBACK, 560, 200
|
||||||
|
{
|
||||||
|
patch PLUBOSS, 0, 0 { }
|
||||||
|
}
|
||||||
|
|
||||||
|
graphic INTERPIC, 560, 200
|
||||||
|
{
|
||||||
|
patch PLUINTER, 0, 0 { }
|
||||||
|
}
|
||||||
|
|
Binary file not shown.
10
wadsrc_widepix/static/filter/doom.id.doom2.tnt/textures.txt
Normal file
10
wadsrc_widepix/static/filter/doom.id.doom2.tnt/textures.txt
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
graphic BOSSBACK, 560, 200
|
||||||
|
{
|
||||||
|
patch TNTBOSS, 0, 0 { }
|
||||||
|
}
|
||||||
|
|
||||||
|
graphic INTERPIC, 560, 200
|
||||||
|
{
|
||||||
|
patch TNTINTER, 0, 0 { }
|
||||||
|
}
|
||||||
|
|
BIN
wadsrc_widepix/static/filter/doom.id.doom2/graphics/credit.lmp
Normal file
BIN
wadsrc_widepix/static/filter/doom.id.doom2/graphics/credit.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/doom.id.doom2/graphics/help.lmp
Normal file
BIN
wadsrc_widepix/static/filter/doom.id.doom2/graphics/help.lmp
Normal file
Binary file not shown.
BIN
wadsrc_widepix/static/filter/doom.id.doom2/graphics/titlepic.lmp
Normal file
BIN
wadsrc_widepix/static/filter/doom.id.doom2/graphics/titlepic.lmp
Normal file
Binary file not shown.
5
wadsrc_widepix/static/filter/doom.id.doom2/textures.txt
Normal file
5
wadsrc_widepix/static/filter/doom.id.doom2/textures.txt
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
sprite SHT2E0, 233, 63
|
||||||
|
{
|
||||||
|
offset 32, -105
|
||||||
|
patch "/patches/SHT2E0.lmp", 0, 0 { }
|
||||||
|
}
|
|
@ -0,0 +1,5 @@
|
||||||
|
sprite SHT2E0, 233, 63
|
||||||
|
{
|
||||||
|
offset 32, -105
|
||||||
|
patch "/patches/SHT2E0.lmp", 0, 0 { }
|
||||||
|
}
|
BIN
wadsrc_widepix/static/filter/doom.id/graphics/bossback.lmp
Normal file
BIN
wadsrc_widepix/static/filter/doom.id/graphics/bossback.lmp
Normal file
Binary file not shown.
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue