P4C
The P4 Compiler
Loading...
Searching...
No Matches
removeSelectBooleans.h
1
/*
2
Copyright 2017 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_REMOVESELECTBOOLEANS_H_
18
#define MIDEND_REMOVESELECTBOOLEANS_H_
19
20
#include "frontends/p4/typeChecking/typeChecker.h"
21
#include "frontends/p4/typeMap.h"
22
#include "ir/ir.h"
23
24
namespace
P4
{
25
33
class
DoRemoveSelectBooleans
:
public
Transform
{
34
const
P4::TypeMap
*typeMap;
35
36
const
IR::Expression *addToplevelCasts(
const
IR::Expression *expression);
37
38
public
:
39
explicit
DoRemoveSelectBooleans
(
const
P4::TypeMap
*typeMap) : typeMap(typeMap) {
40
CHECK_NULL(typeMap);
41
setName(
"DoRemoveSelectBooleans"
);
42
}
43
44
const
IR::Node
*postorder(IR::SelectExpression *expression)
override
;
45
const
IR::Node
*postorder(IR::SelectCase *selectCase)
override
;
46
};
47
48
class
RemoveSelectBooleans
:
public
PassManager
{
49
public
:
50
explicit
RemoveSelectBooleans
(
TypeMap
*typeMap,
TypeChecking
*typeChecking =
nullptr
) {
51
if
(!typeChecking) typeChecking =
new
TypeChecking
(
nullptr
, typeMap);
52
passes.push_back(typeChecking);
53
passes.push_back(
new
DoRemoveSelectBooleans
(typeMap));
54
passes.push_back(
new
ClearTypeMap
(typeMap));
// some types have changed
55
setName(
"RemoveSelectBooleans"
);
56
}
57
};
58
59
}
// namespace P4
60
61
#endif
/* MIDEND_REMOVESELECTBOOLEANS_H_ */
P4::ClearTypeMap
Definition
typeChecker.h:32
P4::DoRemoveSelectBooleans
Definition
removeSelectBooleans.h:33
P4::IR::Node
Definition
node.h:95
P4::PassManager
Definition
ir/pass_manager.h:40
P4::RemoveSelectBooleans
Definition
removeSelectBooleans.h:48
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
removeSelectBooleans.h
Generated by
1.12.0