P4C
The P4 Compiler
Loading...
Searching...
No Matches
simplifySelectCases.h
1
/*
2
Copyright 2016 VMware, Inc.
3
4
Licensed under the Apache License, Version 2.0 (the "License");
5
you may not use this file except in compliance with the License.
6
You may obtain a copy of the License at
7
8
http://www.apache.org/licenses/LICENSE-2.0
9
10
Unless required by applicable law or agreed to in writing, software
11
distributed under the License is distributed on an "AS IS" BASIS,
12
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
See the License for the specific language governing permissions and
14
limitations under the License.
15
*/
16
17
#ifndef MIDEND_SIMPLIFYSELECTCASES_H_
18
#define MIDEND_SIMPLIFYSELECTCASES_H_
19
20
#include "frontends/p4/typeChecking/typeChecker.h"
21
#include "ir/ir.h"
22
23
namespace
P4
{
24
38
class
DoSimplifySelectCases
:
public
Transform
{
39
const
TypeMap
*typeMap;
40
bool
requireConstants;
41
42
void
checkSimpleConstant(
const
IR::Expression *expr)
const
;
43
44
public
:
45
DoSimplifySelectCases
(
const
TypeMap
*typeMap,
bool
requireConstants)
46
: typeMap(typeMap), requireConstants(requireConstants) {
47
setName(
"DoSimplifySelectCases"
);
48
}
49
const
IR::Node
*preorder(IR::SelectExpression *expression)
override
;
50
};
51
52
class
SimplifySelectCases
:
public
PassManager
{
53
public
:
54
SimplifySelectCases
(
TypeMap
*typeMap,
bool
requireConstants,
55
TypeChecking
*typeChecking =
nullptr
) {
56
if
(!typeChecking) typeChecking =
new
TypeChecking
(
nullptr
, typeMap);
57
passes.push_back(typeChecking);
58
passes.push_back(
new
DoSimplifySelectCases
(typeMap, requireConstants));
59
setName(
"SimplifySelectCases"
);
60
}
61
};
62
63
}
// namespace P4
64
65
#endif
/* MIDEND_SIMPLIFYSELECTCASES_H_ */
P4::DoSimplifySelectCases
Definition
simplifySelectCases.h:38
P4::IR::Node
Definition
node.h:94
P4::PassManager
Definition
ir/pass_manager.h:40
P4::SimplifySelectCases
Definition
simplifySelectCases.h:52
P4::Transform
Definition
visitor.h:424
P4::TypeChecking
Definition
typeChecker.h:55
P4::TypeMap
Definition
typeMap.h:41
P4
TODO: this is not really specific to BMV2, it should reside somewhere else.
Definition
applyOptionsPragmas.cpp:24
midend
simplifySelectCases.h
Generated by
1.12.0