-
Notifications
You must be signed in to change notification settings - Fork 457
/
Copy pathcheckSize.h
58 lines (48 loc) · 1.93 KB
/
checkSize.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/*
Copyright 2018 VMware, Inc.
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 MIDEND_CHECKSIZE_H_
#define MIDEND_CHECKSIZE_H_
#include "ir/ir.h"
namespace P4 {
/// Checks some possible misuses of the table size property
class CheckTableSize : public Modifier {
public:
CheckTableSize() { setName("CheckTableSize"); }
bool preorder(IR::P4Table *table) override {
auto size = table->getSizeProperty();
if (size == nullptr) return false;
bool deleteSize = false;
auto key = table->getKey();
if (key == nullptr) {
if (size->value != 1) {
warn(ErrorType::WARN_MISMATCH, "%1%: size %2% specified for table without keys",
table, size);
deleteSize = true;
}
}
auto entries = table->properties->getProperty(IR::TableProperties::entriesPropertyName);
if (entries != nullptr && entries->isConstant) {
warn(ErrorType::WARN_MISMATCH,
"%1%: size %2% specified for table with constant entries", table, size);
deleteSize = true;
}
if (deleteSize) {
auto props = IR::IndexedVector<IR::Property>(table->properties->properties);
props.removeByName(IR::TableProperties::sizePropertyName);
table->properties = new IR::TableProperties(table->properties->srcInfo, props);
}
return false;
}
};
} // namespace P4
#endif /* MIDEND_CHECKSIZE_H_ */