mirror of
https://github.com/RPCS3/glslang.git
synced 2025-01-02 00:18:33 +00:00
f1709e7146
This adds infrastructure suitable for any front end to create SPIR-V loop control flags. The only current front end doing so is HLSL. [unroll] turns into spv::LoopControlUnrollMask [loop] turns into spv::LoopControlDontUnrollMask no specification means spv::LoopControlMaskNone
119 lines
4.4 KiB
C++
119 lines
4.4 KiB
C++
//
|
|
// Copyright (C) 2016 LunarG, Inc.
|
|
//
|
|
// All rights reserved.
|
|
//
|
|
// Redistribution and use in source and binary forms, with or without
|
|
// modification, are permitted provided that the following conditions
|
|
// are met:
|
|
//
|
|
// Redistributions of source code must retain the above copyright
|
|
// notice, this list of conditions and the following disclaimer.
|
|
//
|
|
// Redistributions in binary form must reproduce the above
|
|
// copyright notice, this list of conditions and the following
|
|
// disclaimer in the documentation and/or other materials provided
|
|
// with the distribution.
|
|
//
|
|
// Neither the name of Google, Inc., nor the names of its
|
|
// contributors may be used to endorse or promote products derived
|
|
// from this software without specific prior written permission.
|
|
//
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
|
// FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
|
// COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
|
// BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
|
// CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
// LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
|
// ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
// POSSIBILITY OF SUCH DAMAGE.
|
|
//
|
|
|
|
#include "hlslAttributes.h"
|
|
#include <cstdlib>
|
|
#include <cctype>
|
|
|
|
namespace glslang {
|
|
// Map the given string to an attribute enum from TAttributeType,
|
|
// or EatNone if invalid.
|
|
TAttributeType TAttributeMap::attributeFromName(const TString& name)
|
|
{
|
|
// These are case insensitive.
|
|
TString lowername(name);
|
|
std::transform(lowername.begin(), lowername.end(), lowername.begin(), ::tolower);
|
|
|
|
if (lowername == "allow_uav_condition")
|
|
return EatAllow_uav_condition;
|
|
else if (lowername == "branch")
|
|
return EatBranch;
|
|
else if (lowername == "call")
|
|
return EatCall;
|
|
else if (lowername == "domain")
|
|
return EatDomain;
|
|
else if (lowername == "earlydepthstencil")
|
|
return EatEarlyDepthStencil;
|
|
else if (lowername == "fastopt")
|
|
return EatFastOpt;
|
|
else if (lowername == "flatten")
|
|
return EatFlatten;
|
|
else if (lowername == "forcecase")
|
|
return EatForceCase;
|
|
else if (lowername == "instance")
|
|
return EatInstance;
|
|
else if (lowername == "maxtessfactor")
|
|
return EatMaxTessFactor;
|
|
else if (lowername == "maxvertexcount")
|
|
return EatMaxVertexCount;
|
|
else if (lowername == "numthreads")
|
|
return EatNumThreads;
|
|
else if (lowername == "outputcontrolpoints")
|
|
return EatOutputControlPoints;
|
|
else if (lowername == "outputtopology")
|
|
return EatOutputTopology;
|
|
else if (lowername == "partitioning")
|
|
return EatPartitioning;
|
|
else if (lowername == "patchconstantfunc")
|
|
return EatPatchConstantFunc;
|
|
else if (lowername == "unroll")
|
|
return EatUnroll;
|
|
else if (lowername == "loop")
|
|
return EatLoop;
|
|
else
|
|
return EatNone;
|
|
}
|
|
|
|
// Look up entry, inserting if it's not there, and if name is a valid attribute name
|
|
// as known by attributeFromName.
|
|
TAttributeType TAttributeMap::setAttribute(const TString* name, TIntermAggregate* value)
|
|
{
|
|
if (name == nullptr)
|
|
return EatNone;
|
|
|
|
const TAttributeType attr = attributeFromName(*name);
|
|
|
|
if (attr != EatNone)
|
|
attributes[attr] = value;
|
|
|
|
return attr;
|
|
}
|
|
|
|
// Look up entry (const version), and return aggregate node. This cannot change the map.
|
|
const TIntermAggregate* TAttributeMap::operator[](TAttributeType attr) const
|
|
{
|
|
const auto entry = attributes.find(attr);
|
|
|
|
return (entry == attributes.end()) ? nullptr : entry->second;
|
|
}
|
|
|
|
// True if entry exists in map (even if value is nullptr)
|
|
bool TAttributeMap::contains(TAttributeType attr) const
|
|
{
|
|
return attributes.find(attr) != attributes.end();
|
|
}
|
|
|
|
} // end namespace glslang
|