-
Notifications
You must be signed in to change notification settings - Fork 59
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
Fixed warning and added safe globals #423
Fixed warning and added safe globals #423
Conversation
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.
Thanks for quickly working on this issue! Looks like the CI is failing. Let me know if you need any help!
The fix works for a higher PyTorch version, will investigate a fix for v2.2. Has to do with telling the code that the custom classes are safe for depickling. |
@akihironitta It seems that the warning in #422 is not being reproduced for Torch v2.2.0 in the CI test logs. The warning occurs because pickle has a potential issue where unsafe code may be executed upon unpickling. Torch v2.4 is the only version where I was able to reproduce this warning. Torch v2.4 also contains the solution, being adding the custom classes pytorch/pytorch#129239 is where the warning was introduced. |
Hey @NeelKondapalli, thanks again for this PR! To keep supporting older PyTorch versions, we could try having a flag like this https://github.com/pyg-team/pytorch_geometric/blob/8c849a482c3cf2326c1f493e79d04169b26dfb0b/torch_geometric/typing.py#L12: if WITH_PT24:
torch.serialization.add_safe_globals(...) If feasible, we'd like to enable |
Adding a version specific flag like that is doable. From what I can see, Since the torch.serialization.add_safe_globals fn is not available in the older torch versions, it seems that turning on the The only way I can think of at the moment to amend this for lower torch versions is to maybe use a custom unpickler when loading the model (instead of Torch's internal load method) and configuring it to only read |
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.
Sorry for the delay. Having a look today.
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.
Looks great! Thanks again :)
I feel your 4ce8e5c is the right thing to do. Whenever possible, we should set weights_only=True
, but we can disable it in other cases.
@NeelKondapalli This is great! Thank you again for making your first contribution to PyTorch Frame! 🚀 |
Thank you! Awesome we could work it out. |
Fixes #422 by adding the
weights_only = True
argument totorch.load
in the fileio.py
. This protects agains the arbitrary data warning. The typesstype
andStatType
were added to the safe globals list.By: Neel Kondapalli (neel2h06@gmail.com)