-
-
Notifications
You must be signed in to change notification settings - Fork 30.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
bpo-38588: Fix possible crashes in dict and list when calling PyObject_RichCompareBool #17734
Conversation
Could you include the rest of the cases that LCatro was mentioning? He mentioned another 2 for lists. |
poc3 is not reproducible on my local mac machine and Linux machine with the master branch. Line 452 in 3c87a66
However poc2 is reproducible, so I will add the patch on this PR. $ cat poc3.py
class poc() :
def __eq__(self,other) :
list1.clear()
return NotImplemented
list1 = [ set() ]
poc() in list1
print('end')
$ ./python poc3.py
end |
FWIW, LCatro had opened another issue (https://bugs.python.org/issue38610) for similar crashes in the |
@pablogsal And for the And IMHO, we can close bpo-38588 with this patch |
@pablogsal Updated! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Thanks for the quick fix, @corona10!
Thanks @corona10 for the PR, and @pablogsal for merging it 🌮🎉.. I'm working now to backport this PR to: 3.7, 3.8. |
I'm having trouble backporting to |
Sorry, @corona10 and @pablogsal, I could not cleanly backport this to |
@corona10 Can you make the backport to 3.7 and 3.8 using |
Thanks @corona10 for the PR, and @pablogsal for merging it 🌮🎉.. I'm working now to backport this PR to: 3.8. |
Sorry @corona10 and @pablogsal, I had trouble checking out the |
GH-17764 is a backport of this pull request to the 3.8 branch. |
…yObject_RichCompareBool (pythonGH-17734) Take strong references before calling PyObject_RichCompareBool to protect against the case where the object dies during the call. (cherry picked from commit 2d5bf56) Co-authored-by: Dong-hee Na <donghee.na92@gmail.com>
Oh, please check the b.p.o before merge... |
Apologies, I had totally missed the comment in bpo :( |
GH-17765 is a backport of this pull request to the 3.7 branch. |
Sorry @corona10, I will leave the backports open until we decide what to do finally in the bpo issue. |
@pablogsal cc @methane |
GH-17765) * [3.7] bpo-38588: Fix possible crashes in dict and list when calling PyObject_RichCompareBool (GH-17734) Take strong references before calling PyObject_RichCompareBool to protect against the case where the object dies during the call.. (cherry picked from commit 2d5bf56) Co-authored-by: Dong-hee Na <donghee.na92@gmail.com> * methane's suggestion methane's suggestion Co-Authored-By: Inada Naoki <songofacandy@gmail.com> Co-authored-by: Inada Naoki <songofacandy@gmail.com>
GH-17764) * [3.8] bpo-38588: Fix possible crashes in dict and list when calling PyObject_RichCompareBool (GH-17734) Take strong references before calling PyObject_RichCompareBool to protect against the case where the object dies during the call. (cherry picked from commit 2d5bf56) Co-authored-by: Dong-hee Na <donghee.na92@gmail.com> * Update Objects/listobject.c @methane's suggestion Co-Authored-By: Inada Naoki <songofacandy@gmail.com> Co-authored-by: Inada Naoki <songofacandy@gmail.com>
pythonGH-17765) * [3.7] bpo-38588: Fix possible crashes in dict and list when calling PyObject_RichCompareBool (pythonGH-17734) Take strong references before calling PyObject_RichCompareBool to protect against the case where the object dies during the call.. (cherry picked from commit 2d5bf56) Co-authored-by: Dong-hee Na <donghee.na92@gmail.com> * methane's suggestion methane's suggestion Co-Authored-By: Inada Naoki <songofacandy@gmail.com> Co-authored-by: Inada Naoki <songofacandy@gmail.com>
…t_RichCompareBool (pythonGH-17734) Take strong references before calling PyObject_RichCompareBool to protect against the case where the object dies during the call.
Based on LCatro's report
https://bugs.python.org/issue38588