Commit efbc28c9 authored by Brenden Blanco's avatar Brenden Blanco

Fix python map.items() racing with bpf delete

The default python implementation of itervalues(), iteritems(), items(), and
values() do a sequence of iter().next followed by self[key], which may
produce a KeyError since a bpf program can delete them quickly. It
should be safe to suppress such errors, hiding them from the user.
Signed-off-by: default avatarBrenden Blanco <bblanco@plumgrid.com>
parent d366b0e0
...@@ -286,6 +286,30 @@ class BPF(object): ...@@ -286,6 +286,30 @@ class BPF(object):
if res < 0: if res < 0:
raise KeyError raise KeyError
# override the MutableMapping's implementation of these since they
# don't handle KeyError nicely
def itervalues(self):
for key in self:
# a map entry may be deleted in between discovering the key and
# fetching the value, suppress such errors
try:
yield self[key]
except KeyError:
pass
def iteritems(self):
for key in self:
try:
yield (key, self[key])
except KeyError:
pass
def items(self):
return [item for item in self.iteritems()]
def values(self):
return [value for value in self.itervalues()]
def clear(self): def clear(self):
# default clear uses popitem, which can race with the bpf prog # default clear uses popitem, which can race with the bpf prog
for k in self.keys(): for k in self.keys():
......
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