Commit 856b1777 authored by Brenden Blanco's avatar Brenden Blanco

Fix segfault in ~BPFModule on syntax error

~BPFModule was segfaulting because tables_ was an empty pointer. The
pointer is valid only for valid compilations. Add a test as well.
Signed-off-by: default avatarBrenden Blanco <bblanco@plumgrid.com>
parent cfc5b457
...@@ -114,9 +114,11 @@ BPFModule::~BPFModule() { ...@@ -114,9 +114,11 @@ BPFModule::~BPFModule() {
engine_.reset(); engine_.reset();
rw_engine_.reset(); rw_engine_.reset();
ctx_.reset(); ctx_.reset();
for (auto table : *tables_) { if (tables_) {
if (table.is_shared) for (auto table : *tables_) {
SharedTables::instance()->remove_fd(table.name); if (table.is_shared)
SharedTables::instance()->remove_fd(table.name);
}
} }
} }
......
...@@ -299,5 +299,9 @@ BPF_TABLE("array", int, union emptyu, t3, 1); ...@@ -299,5 +299,9 @@ BPF_TABLE("array", int, union emptyu, t3, 1);
b1 = BPF(text="""BPF_TABLE_PUBLIC("hash", int, int, table1, 10);""") b1 = BPF(text="""BPF_TABLE_PUBLIC("hash", int, int, table1, 10);""")
b2 = BPF(text="""BPF_TABLE("extern", int, int, table1, 10);""") b2 = BPF(text="""BPF_TABLE("extern", int, int, table1, 10);""")
def test_syntax_error(self):
with self.assertRaises(Exception):
b = BPF(text="""int failure(void *ctx) { if (); return 0; }""")
if __name__ == "__main__": if __name__ == "__main__":
main() main()
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment