Commit 78700a04 authored by Stefan Behnel's avatar Stefan Behnel

fine tune method call optimisation to mark likely plain function calls...

fine tune method call optimisation to mark likely plain function calls explicitly as unlikely() for the C compiler
parent 7d386fe6
...@@ -4837,13 +4837,22 @@ class PyMethodCallNode(SimpleCallNode): ...@@ -4837,13 +4837,22 @@ class PyMethodCallNode(SimpleCallNode):
arg_offset_cname = code.funcstate.allocate_temp(PyrexTypes.c_py_ssize_t_type, manage_ref=False) arg_offset_cname = code.funcstate.allocate_temp(PyrexTypes.c_py_ssize_t_type, manage_ref=False)
code.putln("%s = 0;" % arg_offset_cname) code.putln("%s = 0;" % arg_offset_cname)
if self.function.is_attribute and self.function.obj.type is not Builtin.type_type: def attribute_is_likely_bound_method(attr):
likely_method = 'likely' obj = attr.obj
if obj.type is Builtin.type_type:
return False # more likely to be an unbound method
if obj.is_name and obj.entry.is_pyglobal:
return False # more likely to be a function
return True
if self.function.is_attribute:
likely_method = 'likely' if attribute_is_likely_bound_method(self.function) else 'unlikely'
elif self.function.is_name and self.function.cf_state: elif self.function.is_name and self.function.cf_state:
# not an attribute itself, but might have been assigned from one (e.g. bound method) # not an attribute itself, but might have been assigned from one (e.g. bound method)
for assignment in self.function.cf_state: for assignment in self.function.cf_state:
value = assignment.rhs value = assignment.rhs
if value.is_attribute and value.obj.type.is_pyobject and value.obj.type is not Builtin.type_type: if value.is_attribute and value.obj.type.is_pyobject:
if attribute_is_likely_bound_method(value):
likely_method = 'likely' likely_method = 'likely'
break break
else: else:
......
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