Skip to content

UAF on fut->fut_{callback,context}0 with evil __getattribute__ in _asynciomodule.c#125984

@picnixz

Description

@picnixz

Crash report

What happened?

importasyncioclassEvilLoop: defcall_soon(*args): # will crash before it actually gets here print(args) defget_debug(self): returnFalsedef__getattribute__(self, name): globaltrackerifname=="call_soon": fut.remove_done_callback(tracker) deltrackerprint("returning call_soon method after clearing callback0") returnobject.__getattribute__(self, name) classTrackDel: def__del__(self): print("deleted", self) fut=asyncio.Future(loop=EvilLoop()) tracker=TrackDel() fut.add_done_callback(tracker) fut.set_result("kaboom")

Originally posted by @Nico-Posada in #125970 (comment)

Not sure I'll be able to work on it today, so anyone's free to take on it.


Traceback

deleted <__main__.TrackDel object at 0x7f4ab660a420> returning call_soon method after clearing callback0 Python/context.c:534: _PyObject_GC_UNTRACK: Assertion "_PyObject_GC_IS_TRACKED(((PyObject*)(op)))" failed: object not tracked by the garbage collector Enable tracemalloc to get the memory block allocation traceback object address : 0x7f4ab64ca4b0 object refcount : 0 object type : 0x9bfc60 object type name: _contextvars.Context object repr : <refcnt 0 at 0x7f4ab64ca4b0> Fatal Python error: _PyObject_AssertFailed: _PyObject_AssertFailed Python runtime state: initialized TypeError: EvilLoop.call_soon() got an unexpected keyword argument 'context' 

Linked PRs

Metadata

Metadata

Assignees

Labels

3.12only security fixes3.13bugs and security fixes3.14bugs and security fixestopic-asynciotype-crashA hard crash of the interpreter, possibly with a core dump

Projects

Status

Done

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions