P4C
The P4 Compiler
Toggle main menu visibility
Main Page
P4C Repository Organization
Getting Started
P4C Intermediate Representation (IR)
Frontend
Midend
Backends
Behavioral Model Backend
DPDK Backend
eBPF Backend
TC Backend
uBPF Backend
P4test Backend
Graphs Backend
p4fmt (P4 Formatter)
P4Tools
P4Smith
P4Testgen
Contribute to the P4 Compiler Project
Releases
Namespaces
Namespace List
Namespace Members
All
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
r
s
t
w
x
z
Functions
a
c
d
e
f
g
h
i
l
m
n
o
p
r
s
t
w
x
Variables
Typedefs
Enumerations
Enumerator
Classes
Class List
Class Index
Class Hierarchy
Class Members
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
r
s
t
u
v
w
y
z
~
Functions
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
r
s
t
u
v
w
z
~
Variables
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
r
s
t
u
v
w
y
Typedefs
Enumerations
Enumerator
Related Symbols
•
All
Classes
Namespaces
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Modules
Pages
Loading...
Searching...
No Matches
check_for_unimplemented_features.h
1
19
#ifndef BACKENDS_TOFINO_BF_P4C_COMMON_CHECK_FOR_UNIMPLEMENTED_FEATURES_H_
20
#define BACKENDS_TOFINO_BF_P4C_COMMON_CHECK_FOR_UNIMPLEMENTED_FEATURES_H_
21
22
#include <optional>
23
24
#include "ir/ir.h"
25
#include "ir/pass_manager.h"
26
35
class
CheckOperations
:
public
Inspector {
36
// Helper that removes casts to make identifying unsupported operator
37
// combinations easier.
38
struct
RemoveCasts :
public
Transform {
39
IR::Node *preorder(IR::Cast *cast)
override
{
return
cast->expr->clone(); }
40
};
41
44
std::optional<const IR::Operation_Binary *> getSrcBinop(
const
IR::MAU::Primitive *p)
const
;
45
48
bool
isFunnelShift(
const
IR::MAU::Primitive *p)
const
;
49
52
bool
isModBitMask(
const
IR::MAU::Primitive *p)
const
;
53
54
bool
preorder(
const
IR::MAU::Primitive *)
override
;
55
};
35
class
CheckOperations
:
public
Inspector {
…
};
56
57
class
CheckForUnimplementedFeatures
:
public
PassManager {
58
public
:
59
CheckForUnimplementedFeatures
() {
60
addPasses({
61
new
CheckOperations
(),
62
});
63
}
64
};
57
class
CheckForUnimplementedFeatures
:
public
PassManager {
…
};
65
66
#endif
/* BACKENDS_TOFINO_BF_P4C_COMMON_CHECK_FOR_UNIMPLEMENTED_FEATURES_H_ */
CheckForUnimplementedFeatures
Definition
check_for_unimplemented_features.h:57
CheckOperations
Definition
check_for_unimplemented_features.h:35
backends
tofino
bf-p4c
common
check_for_unimplemented_features.h
Generated by
1.12.0