changeset: 103046:1d7a938b1e47 parent: 103044:125cf99907c7 parent: 103045:3e4452424f9b user: Benjamin Peterson date: Mon Sep 05 10:40:34 2016 -0700 files: Misc/NEWS Objects/genobject.c description: merge 3.5 (#27812) diff -r 125cf99907c7 -r 1d7a938b1e47 Misc/NEWS --- a/Misc/NEWS Mon Sep 05 10:17:37 2016 -0700 +++ b/Misc/NEWS Mon Sep 05 10:40:34 2016 -0700 @@ -29,6 +29,9 @@ - Issue #27506: Support passing the bytes/bytearray.translate() "delete" argument by keyword. +- Issue #27812: Properly clear out a generator's frame's backreference to the + generator to prevent crashes in frame.clear(). + - Issue #27811: Fix a crash when a coroutine that has not been awaited is finalized with warnings-as-errors enabled. diff -r 125cf99907c7 -r 1d7a938b1e47 Objects/genobject.c --- a/Objects/genobject.c Mon Sep 05 10:17:37 2016 -0700 +++ b/Objects/genobject.c Mon Sep 05 10:40:34 2016 -0700 @@ -71,7 +71,10 @@ return; /* resurrected. :( */ _PyObject_GC_UNTRACK(self); - Py_CLEAR(gen->gi_frame); + if (gen->gi_frame != NULL) { + gen->gi_frame->f_gen = NULL; + Py_CLEAR(gen->gi_frame); + } Py_CLEAR(gen->gi_code); Py_CLEAR(gen->gi_name); Py_CLEAR(gen->gi_qualname);