mirror of
https://github.com/KhronosGroup/SPIRV-Tools
synced 2025-01-14 02:10:17 +00:00
5ea7099374
Implements the following simplifications: (a - b) + b => a (a * b) + (a * c) => a * (b + c) Also adds logic to simplification to handle rules that create new operations that might need simplification, such as the second rule above. Only perform the second simplification if the multiplies have the add as their only use. Otherwise this is a deoptimization of size and performance.
59 lines
2.1 KiB
C++
59 lines
2.1 KiB
C++
// Copyright (c) 2018 Google LLC
|
|
//
|
|
// 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 SOURCE_OPT_SIMPLIFICATION_PASS_H_
|
|
#define SOURCE_OPT_SIMPLIFICATION_PASS_H_
|
|
|
|
#include "source/opt/function.h"
|
|
#include "source/opt/ir_context.h"
|
|
#include "source/opt/pass.h"
|
|
|
|
namespace spvtools {
|
|
namespace opt {
|
|
|
|
// See optimizer.hpp for documentation.
|
|
class SimplificationPass : public Pass {
|
|
public:
|
|
const char* name() const override { return "simplify-instructions"; }
|
|
Status Process() override;
|
|
|
|
IRContext::Analysis GetPreservedAnalyses() override {
|
|
return IRContext::kAnalysisDefUse |
|
|
IRContext::kAnalysisInstrToBlockMapping |
|
|
IRContext::kAnalysisDecorations | IRContext::kAnalysisCombinators |
|
|
IRContext::kAnalysisCFG | IRContext::kAnalysisDominatorAnalysis |
|
|
IRContext::kAnalysisNameMap | IRContext::kAnalysisConstants |
|
|
IRContext::kAnalysisTypes;
|
|
}
|
|
|
|
private:
|
|
// Returns true if the module was changed. The simplifier is called on every
|
|
// instruction in |function| until nothing else in the function can be
|
|
// simplified.
|
|
bool SimplifyFunction(Function* function);
|
|
|
|
// FactorAddMul can create |folded_inst| Mul of new Add. If Mul, push any Add
|
|
// operand not in |seen_inst| into |worklist|. This is heavily restricted to
|
|
// improve compile time but can be expanded for future simplifications which
|
|
// simiarly create new operations.
|
|
void AddNewOperands(Instruction* folded_inst,
|
|
std::unordered_set<Instruction*>* inst_seen,
|
|
std::vector<Instruction*>* work_list);
|
|
};
|
|
|
|
} // namespace opt
|
|
} // namespace spvtools
|
|
|
|
#endif // SOURCE_OPT_SIMPLIFICATION_PASS_H_
|