blob: ccbd292fe7658d15e9747bf13419532e38f8ca38 [file] [log] [blame]
//===- SPIRVBasicBlock.h – SPIR-V Basic Block --------------------*- C++ -*-===//
//
// The LLVM/SPIRV Translator
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
// Copyright (c) 2014 Advanced Micro Devices, Inc. All rights reserved.
//
// Permission is hereby granted, free of charge, to any person obtaining a
// copy of this software and associated documentation files (the "Software"),
// to deal with the Software without restriction, including without limitation
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
// and/or sell copies of the Software, and to permit persons to whom the
// Software is furnished to do so, subject to the following conditions:
//
// Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimers.
// Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimers in the documentation
// and/or other materials provided with the distribution.
// Neither the names of Advanced Micro Devices, Inc., nor the names of its
// contributors may be used to endorse or promote products derived from this
// Software without specific prior written permission.
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// CONTRIBUTORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS WITH
// THE SOFTWARE.
//
//===----------------------------------------------------------------------===//
/// \file
///
/// This file defines Basic Block class for SPIR-V.
///
//===----------------------------------------------------------------------===//
#ifndef SPIRVBASICBLOCK_HPP_
#define SPIRVBASICBLOCK_HPP_
#include "SPIRVValue.h"
#include <algorithm>
namespace SPIRV{
class SPIRVFunction;
class SPIRVInstruction;
class SPIRVDecoder;
class SPIRVBasicBlock: public SPIRVValue {
public:
SPIRVBasicBlock(SPIRVId TheId, SPIRVFunction *Func);
SPIRVBasicBlock():SPIRVValue(OpLabel), ParentF(NULL){
setAttr();
}
SPIRVDecoder getDecoder(std::istream &IS);
SPIRVFunction *getParent() const { return ParentF;}
size_t getNumInst() const { return InstVec.size();}
SPIRVInstruction *getInst(size_t I) const { return InstVec[I];}
SPIRVInstruction *getPrevious(const SPIRVInstruction *I) const {
auto Loc = find(I);
if (Loc == InstVec.end() || Loc == InstVec.begin())
return nullptr;
return *(--Loc);
}
SPIRVInstruction *getNext(const SPIRVInstruction *I) const {
auto Loc = find(I);
if (Loc == InstVec.end())
return nullptr;
++Loc;
if (Loc == InstVec.end())
return nullptr;
return *Loc;
}
void setScope(SPIRVEntry *Scope);
void setParent(SPIRVFunction *F) { ParentF = F;}
SPIRVInstruction *addInstruction(SPIRVInstruction *I);
void setAttr() { setHasNoType();}
_SPIRV_DCL_ENCDEC
void encodeChildren(spv_ostream &)const;
void validate()const {
SPIRVValue::validate();
assert(ParentF && "Invalid parent function");
}
private:
SPIRVFunction *ParentF;
typedef std::vector<SPIRVInstruction *> SPIRVInstructionVector;
SPIRVInstructionVector InstVec;
SPIRVInstructionVector::const_iterator find(const SPIRVInstruction *Inst)
const {
return std::find(InstVec.begin(), InstVec.end(), Inst);
}
};
typedef SPIRVBasicBlock SPIRVLabel;
}
#endif