Re: 回复: JDK-8257039: Memory allocated by GenericTaskQueue::_array_allocator may be double freed(Internet mail)
Hohensee, Paul
hohensee at amazon.com
Tue Apr 27 17:07:49 UTC 2021
Do you need a sponsor?
-----Original Message-----
From: jdk8u-dev <jdk8u-dev-retn at openjdk.java.net> on behalf of "Hohensee, Paul" <hohensee at amazon.com>
Date: Thursday, April 15, 2021 at 12:06 PM
To: "wattsun(孙宇)" <wattsun at tencent.com>, "jdk8u-dev at openjdk.java.net" <jdk8u-dev at openjdk.java.net>
Subject: RE: 回复: JDK-8257039: Memory allocated by GenericTaskQueue::_array_allocator may be double freed(Internet mail)
Lgtm.
-----Original Message-----
From: "wattsun(孙宇)" <wattsun at tencent.com>
Date: Thursday, April 15, 2021 at 5:37 AM
To: "Hohensee, Paul" <hohensee at amazon.com>, "jdk8u-dev at openjdk.java.net" <jdk8u-dev at openjdk.java.net>
Subject: 回复: JDK-8257039: Memory allocated by GenericTaskQueue::_array_allocator may be double freed(Internet mail)
Thanks for your reply, Paul.
make sense, both methods can eliminate the risk of double-free , and free the memory in ~ArrayAllocator is more reasonable. Update the patch:
diff -r 91b61f678a19 src/share/vm/utilities/taskqueue.hpp
--- a/src/share/vm/utilities/taskqueue.hpp Sat Mar 27 19:01:26 2021 +0000
+++ b/src/share/vm/utilities/taskqueue.hpp Thu Apr 15 20:32:02 2021 +0800
@@ -430,9 +430,7 @@
}
template<class E, MEMFLAGS F, unsigned int N>
-GenericTaskQueue<E, F, N>::~GenericTaskQueue() {
- FREE_C_HEAP_ARRAY(E, _elems, F);
-}
+GenericTaskQueue<E, F, N>::~GenericTaskQueue() {}
// OverflowTaskQueue is a TaskQueue that also includes an overflow stack for
// elements that do not fit in the TaskQueue.
Thanks
wattsun
-----邮件原件-----
发件人: Hohensee, Paul <hohensee at amazon.com>
发送时间: 2021年4月15日 5:16
收件人: wattsun(孙宇) <wattsun at tencent.com>; jdk8u-dev at openjdk.java.net
主题: RE: JDK-8257039: Memory allocated by GenericTaskQueue::_array_allocator may be double freed(Internet mail)
If I read this correctly, you're disabling ArrayAllocator::free() to accommodate ~GenericTaskQueue, which latter explicitly frees the queue element array. This seems backwards to me because ~GenericTaskQueue currently reachs into the implementation of ArrayAllocator, violating encapsulation. Your original patch, which eliminated the explicit free in ~GenericTaskQueue, removed that reaching and left it up to ~ArrayAllocator to handle it, which is what I'd prefer.
Thanks,
Paul
-----Original Message-----
From: jdk8u-dev <jdk8u-dev-retn at openjdk.java.net> on behalf of "wattsun(孙宇)" <wattsun at tencent.com>
Date: Wednesday, December 23, 2020 at 2:06 AM
To: "jdk8u-dev at openjdk.java.net" <jdk8u-dev at openjdk.java.net>
Subject: JDK-8257039: Memory allocated by GenericTaskQueue::_array_allocator may be double freed
Dear All,
may I hava this small bug fix to review?
Bug: https://bugs.openjdk.java.net/browse/JDK-8257039
the diff:
diff -r 83661fdee9f0 src/share/vm/utilities/taskqueue.hpp
--- a/src/share/vm/utilities/taskqueue.hpp Wed Nov 18 06:55:35 2020 +0000
+++ b/src/share/vm/utilities/taskqueue.hpp Wed Nov 25 18:10:28 2020 +0800
@@ -314,7 +314,7 @@
};
template<class E, MEMFLAGS F, unsigned int N>
-GenericTaskQueue<E, F, N>::GenericTaskQueue() {
+GenericTaskQueue<E, F, N>::GenericTaskQueue() : _array_allocator(false) {
assert(sizeof(Age) == sizeof(size_t), "Depends on this.");
}
Thanks!
watt
More information about the jdk8u-dev
mailing list