Commit 7db182b7 authored by yonghong-song's avatar yonghong-song Committed by GitHub

Merge pull request #1356 from sandip4n/fix-test-debuginfo

Fix 'test_debuginfo' from failing if a kernel symbol has multiple aliases
parents bbe32f56 d06b4381
...@@ -9,12 +9,27 @@ from unittest import main, TestCase ...@@ -9,12 +9,27 @@ from unittest import main, TestCase
class TestKSyms(TestCase): class TestKSyms(TestCase):
def grab_sym(self): def grab_sym(self):
# Grab the first symbol in kallsyms that has type 't'. address = ""
aliases = []
# Grab the first symbol in kallsyms that has type 't' or 'T'.
# Also, find all aliases of this symbol which are identifiable
# by the same address.
with open("/proc/kallsyms") as f: with open("/proc/kallsyms") as f:
for line in f: for line in f:
(addr, t, name) = line.strip().split()
if t == "t": # Extract the first 3 columns only. The 4th column
return (addr, name) # containing the module name may not exist for all
# symbols.
(addr, t, name) = line.strip().split()[:3]
if t == "t" or t == "T":
if not address:
address = addr
if addr == address:
aliases.append(name)
# Return all aliases of the first symbol.
return (address, aliases)
def test_ksymname(self): def test_ksymname(self):
sym = BPF.ksymname("__kmalloc") sym = BPF.ksymname("__kmalloc")
...@@ -22,9 +37,10 @@ class TestKSyms(TestCase): ...@@ -22,9 +37,10 @@ class TestKSyms(TestCase):
self.assertNotEqual(sym, 0) self.assertNotEqual(sym, 0)
def test_ksym(self): def test_ksym(self):
(addr, name) = self.grab_sym() (addr, aliases) = self.grab_sym()
sym = BPF.ksym(int(addr, 16)) sym = BPF.ksym(int(addr, 16))
self.assertEqual(sym, name) found = sym in aliases
self.assertTrue(found)
class Harness(TestCase): class Harness(TestCase):
def setUp(self): def setUp(self):
......
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