2019-07-18 09:25:04 +00:00
|
|
|
// Copyright 2019 The Dawn Authors
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
|
|
|
|
#ifndef DAWNNATIVE_FORMAT_H_
|
|
|
|
#define DAWNNATIVE_FORMAT_H_
|
|
|
|
|
|
|
|
#include "dawn_native/dawn_platform.h"
|
|
|
|
|
2020-07-30 15:25:37 +00:00
|
|
|
#include "common/ityp_bitset.h"
|
|
|
|
#include "dawn_native/EnumClassBitmasks.h"
|
2020-10-15 09:05:03 +00:00
|
|
|
#include "dawn_native/Error.h"
|
2020-07-30 15:25:37 +00:00
|
|
|
|
2019-07-18 09:25:04 +00:00
|
|
|
#include <array>
|
|
|
|
|
2021-02-05 20:11:24 +00:00
|
|
|
// About multi-planar formats.
|
|
|
|
//
|
|
|
|
// Dawn supports additional multi-planar formats when the multiplanar_formats extension is enabled.
|
|
|
|
// When enabled, Dawn treats planar data as sub-resources (ie. 1 sub-resource == 1 view == 1 plane).
|
|
|
|
// A multi-planar format name encodes the channel mapping and order of planes. For example,
|
|
|
|
// R8BG8Biplanar420Unorm is YUV 4:2:0 where Plane 0 = R8, and Plane 1 = BG8.
|
|
|
|
//
|
|
|
|
// Requirements:
|
|
|
|
// * Plane aspects cannot be combined with color, depth, or stencil aspects.
|
|
|
|
// * Only compatible multi-planar formats of planes can be used with multi-planar texture
|
|
|
|
// formats.
|
|
|
|
// * Can't access multiple planes without creating per plane views (no color conversion).
|
|
|
|
// * Multi-planar format cannot be written or read without a per plane view.
|
|
|
|
//
|
|
|
|
// TODO(dawn:551): Consider moving this comment.
|
|
|
|
|
2019-07-18 09:25:04 +00:00
|
|
|
namespace dawn_native {
|
|
|
|
|
2020-07-30 15:25:37 +00:00
|
|
|
enum class Aspect : uint8_t;
|
2019-07-18 09:25:04 +00:00
|
|
|
class DeviceBase;
|
|
|
|
|
2020-10-16 14:07:06 +00:00
|
|
|
// This mirrors wgpu::TextureComponentType as a bitmask instead.
|
|
|
|
enum class ComponentTypeBit : uint8_t {
|
|
|
|
None = 0x0,
|
|
|
|
Float = 0x1,
|
|
|
|
Sint = 0x2,
|
|
|
|
Uint = 0x4,
|
2020-10-16 14:13:16 +00:00
|
|
|
DepthComparison = 0x8,
|
2020-10-16 14:07:06 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Converts an wgpu::TextureComponentType to its bitmask representation.
|
|
|
|
ComponentTypeBit ToComponentTypeBit(wgpu::TextureComponentType type);
|
2020-12-21 20:14:26 +00:00
|
|
|
// Converts an wgpu::TextureSampleType to its bitmask representation.
|
|
|
|
ComponentTypeBit SampleTypeToComponentTypeBit(wgpu::TextureSampleType sampleType);
|
2020-10-16 14:07:06 +00:00
|
|
|
|
2020-07-30 15:29:57 +00:00
|
|
|
struct TexelBlockInfo {
|
2020-10-15 09:05:03 +00:00
|
|
|
uint32_t byteSize;
|
|
|
|
uint32_t width;
|
|
|
|
uint32_t height;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct AspectInfo {
|
|
|
|
TexelBlockInfo block;
|
2020-10-16 14:07:06 +00:00
|
|
|
wgpu::TextureComponentType baseType;
|
|
|
|
ComponentTypeBit supportedComponentTypes;
|
2021-02-16 19:55:09 +00:00
|
|
|
wgpu::TextureFormat format;
|
2020-07-30 15:29:57 +00:00
|
|
|
};
|
|
|
|
|
2019-07-18 09:25:04 +00:00
|
|
|
// The number of formats Dawn knows about. Asserts in BuildFormatTable ensure that this is the
|
|
|
|
// exact number of known format.
|
2021-02-16 19:55:09 +00:00
|
|
|
static constexpr size_t kKnownFormatCount = 55;
|
|
|
|
|
|
|
|
// The maximum number of planes per format Dawn knows about. Asserts in BuildFormatTable that
|
|
|
|
// the per plane index does not exceed the known maximum plane count
|
|
|
|
static constexpr uint32_t kMaxPlanesPerFormat = 2;
|
2019-07-18 09:25:04 +00:00
|
|
|
|
2020-09-02 18:50:09 +00:00
|
|
|
struct Format;
|
|
|
|
using FormatTable = std::array<Format, kKnownFormatCount>;
|
|
|
|
|
2019-10-23 11:57:41 +00:00
|
|
|
// A wgpu::TextureFormat along with all the information about it necessary for validation.
|
2020-09-02 18:50:09 +00:00
|
|
|
struct Format {
|
2019-10-23 11:57:41 +00:00
|
|
|
wgpu::TextureFormat format;
|
2019-07-18 09:25:04 +00:00
|
|
|
bool isRenderable;
|
|
|
|
bool isCompressed;
|
|
|
|
// A format can be known but not supported because it is part of a disabled extension.
|
|
|
|
bool isSupported;
|
2020-01-15 00:09:42 +00:00
|
|
|
bool supportsStorageUsage;
|
2020-07-30 15:25:37 +00:00
|
|
|
Aspect aspects;
|
2019-07-18 09:25:04 +00:00
|
|
|
|
|
|
|
bool IsColor() const;
|
|
|
|
bool HasDepth() const;
|
|
|
|
bool HasStencil() const;
|
|
|
|
bool HasDepthOrStencil() const;
|
|
|
|
|
2021-02-05 20:11:24 +00:00
|
|
|
// IsMultiPlanar() returns true if the format allows selecting a plane index. This is only
|
|
|
|
// allowed by multi-planar formats (ex. NV12).
|
|
|
|
bool IsMultiPlanar() const;
|
|
|
|
|
2020-10-15 09:05:03 +00:00
|
|
|
const AspectInfo& GetAspectInfo(wgpu::TextureAspect aspect) const;
|
|
|
|
const AspectInfo& GetAspectInfo(Aspect aspect) const;
|
2020-07-30 15:29:57 +00:00
|
|
|
|
2019-07-18 09:25:04 +00:00
|
|
|
// The index of the format in the list of all known formats: a unique number for each format
|
|
|
|
// in [0, kKnownFormatCount)
|
|
|
|
size_t GetIndex() const;
|
2020-09-02 18:50:09 +00:00
|
|
|
|
|
|
|
private:
|
2021-02-16 19:55:09 +00:00
|
|
|
// Used to store the aspectInfo for one or more planes. For single plane "color" formats,
|
|
|
|
// only the first aspect info or aspectInfo[0] is valid. For depth-stencil, the first aspect
|
|
|
|
// info is depth and the second aspect info is stencil. For multi-planar formats,
|
|
|
|
// aspectInfo[i] is the ith plane.
|
|
|
|
std::array<AspectInfo, kMaxPlanesPerFormat> aspectInfo;
|
2020-09-02 18:50:09 +00:00
|
|
|
|
|
|
|
friend FormatTable BuildFormatTable(const DeviceBase* device);
|
2019-07-18 09:25:04 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
// Implementation details of the format table in the device.
|
|
|
|
|
|
|
|
// Returns the index of a format in the FormatTable.
|
2019-10-23 11:57:41 +00:00
|
|
|
size_t ComputeFormatIndex(wgpu::TextureFormat format);
|
2019-07-18 09:25:04 +00:00
|
|
|
// Builds the format table with the extensions enabled on the device.
|
|
|
|
FormatTable BuildFormatTable(const DeviceBase* device);
|
|
|
|
|
|
|
|
} // namespace dawn_native
|
|
|
|
|
2020-10-16 14:07:06 +00:00
|
|
|
namespace wgpu {
|
|
|
|
|
|
|
|
template <>
|
|
|
|
struct IsDawnBitmask<dawn_native::ComponentTypeBit> {
|
|
|
|
static constexpr bool enable = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace wgpu
|
|
|
|
|
2019-07-18 09:25:04 +00:00
|
|
|
#endif // DAWNNATIVE_FORMAT_H_
|