bgfx/3rdparty/spirv-tools/source/spirv_target_env.h

50 lines
1.9 KiB
C
Raw Normal View History

2018-04-11 05:44:28 +03:00
// Copyright (c) 2016 Google 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.
2018-09-03 07:14:20 +03:00
#ifndef SOURCE_SPIRV_TARGET_ENV_H_
#define SOURCE_SPIRV_TARGET_ENV_H_
2018-04-11 05:44:28 +03:00
2019-01-26 09:09:33 +03:00
#include <string>
2018-04-11 05:44:28 +03:00
#include "spirv-tools/libspirv.h"
// Returns true if |env| is a VULKAN environment, false otherwise.
bool spvIsVulkanEnv(spv_target_env env);
2019-01-05 19:15:11 +03:00
// Returns true if |env| is an OPENCL environment, false otherwise.
bool spvIsOpenCLEnv(spv_target_env env);
2019-07-03 18:08:41 +03:00
// Returns true if |env| is an OPENGL environment, false otherwise.
bool spvIsOpenGLEnv(spv_target_env env);
2021-11-01 06:37:36 +03:00
// Returns true if |env| is an implemented/valid environment, false otherwise.
bool spvIsValidEnv(spv_target_env env);
2018-04-11 05:44:28 +03:00
// Returns the version number for the given SPIR-V target environment.
uint32_t spvVersionForTargetEnv(spv_target_env env);
2019-01-26 09:09:33 +03:00
// Returns a string to use in logging messages that indicates the class of
2021-01-16 07:33:45 +03:00
// environment, i.e. "Vulkan", "OpenCL", etc.
2019-01-26 09:09:33 +03:00
std::string spvLogStringForEnv(spv_target_env env);
2019-06-22 17:30:33 +03:00
// Returns a formatted list of all SPIR-V target environment names that
// can be parsed by spvParseTargetEnv.
2022-01-29 07:07:21 +03:00
// |pad| is the number of space characters that the beginning of each line
2019-06-22 17:30:33 +03:00
// except the first one will be padded with.
// |wrap| is the max length of lines the user desires. Word-wrapping will
// occur to satisfy this limit.
std::string spvTargetEnvList(const int pad, const int wrap);
2018-09-03 07:14:20 +03:00
#endif // SOURCE_SPIRV_TARGET_ENV_H_