提交 2d418fce 编写于 作者: A asaha

Merge

...@@ -898,6 +898,7 @@ ac29c9c1193aef5d480b200ed94c5d579243c17b jdk8u102-b14 ...@@ -898,6 +898,7 @@ ac29c9c1193aef5d480b200ed94c5d579243c17b jdk8u102-b14
c8988d2e4212583ec0f04591c8e241ad3cf95674 jdk8u102-b32 c8988d2e4212583ec0f04591c8e241ad3cf95674 jdk8u102-b32
9050d85e29600400ce4ba2b4db9616388082ae08 jdk8u102-b33 9050d85e29600400ce4ba2b4db9616388082ae08 jdk8u102-b33
b678b66d1538af31bac7cf5e74c029395607decd jdk8u102-b34 b678b66d1538af31bac7cf5e74c029395607decd jdk8u102-b34
8a2db0a6c499250050b59f9a47acd9ea80de92c2 jdk8u102-b35
ceecf88e5c2c09bfabf5926581e6d0b0f65f5148 jdk8u111-b00 ceecf88e5c2c09bfabf5926581e6d0b0f65f5148 jdk8u111-b00
e73d79ce00e4a0451e464c7a73d9c911d01e169a jdk8u111-b01 e73d79ce00e4a0451e464c7a73d9c911d01e169a jdk8u111-b01
d584a614818562e1187e1a15c202aec01491caeb jdk8u111-b02 d584a614818562e1187e1a15c202aec01491caeb jdk8u111-b02
......
/* /*
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -148,8 +148,10 @@ void G1ParScanThreadState::trim_queue() { ...@@ -148,8 +148,10 @@ void G1ParScanThreadState::trim_queue() {
do { do {
// Drain the overflow stack first, so other threads can steal. // Drain the overflow stack first, so other threads can steal.
while (_refs->pop_overflow(ref)) { while (_refs->pop_overflow(ref)) {
if (!_refs->try_push_to_taskqueue(ref)) {
dispatch_reference(ref); dispatch_reference(ref);
} }
}
while (_refs->pop_local(ref)) { while (_refs->pop_local(ref)) {
dispatch_reference(ref); dispatch_reference(ref);
......
/* /*
* Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2001, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
...@@ -453,6 +453,9 @@ public: ...@@ -453,6 +453,9 @@ public:
// Push task t onto the queue or onto the overflow stack. Return true. // Push task t onto the queue or onto the overflow stack. Return true.
inline bool push(E t); inline bool push(E t);
// Try to push task t onto the queue only. Returns true if successful, false otherwise.
inline bool try_push_to_taskqueue(E t);
// Attempt to pop from the overflow stack; return true if anything was popped. // Attempt to pop from the overflow stack; return true if anything was popped.
inline bool pop_overflow(E& t); inline bool pop_overflow(E& t);
...@@ -486,6 +489,10 @@ bool OverflowTaskQueue<E, F, N>::pop_overflow(E& t) ...@@ -486,6 +489,10 @@ bool OverflowTaskQueue<E, F, N>::pop_overflow(E& t)
return true; return true;
} }
template <class E, MEMFLAGS F, unsigned int N>
bool OverflowTaskQueue<E, F, N>::try_push_to_taskqueue(E t) {
return taskqueue_t::push(t);
}
class TaskQueueSetSuper { class TaskQueueSetSuper {
protected: protected:
static int randomParkAndMiller(int* seed0); static int randomParkAndMiller(int* seed0);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册