Merge
This commit is contained in:
commit
93fe673dad
@ -190,47 +190,19 @@ void DirtyCardQueueSet::handle_zero_index_for_thread(JavaThread* t) {
|
|||||||
|
|
||||||
bool DirtyCardQueueSet::mut_process_buffer(void** buf) {
|
bool DirtyCardQueueSet::mut_process_buffer(void** buf) {
|
||||||
guarantee(_free_ids != NULL, "must be");
|
guarantee(_free_ids != NULL, "must be");
|
||||||
// Used to determine if we had already claimed a par_id
|
|
||||||
// before entering this method.
|
|
||||||
bool already_claimed = false;
|
|
||||||
|
|
||||||
// We grab the current JavaThread.
|
// claim a par id
|
||||||
JavaThread* thread = JavaThread::current();
|
uint worker_i = _free_ids->claim_par_id();
|
||||||
|
|
||||||
// We get the the number of any par_id that this thread
|
bool b = DirtyCardQueue::apply_closure_to_buffer(_mut_process_closure, buf, 0,
|
||||||
// might have already claimed.
|
_sz, true, worker_i);
|
||||||
uint worker_i = thread->get_claimed_par_id();
|
if (b) {
|
||||||
|
Atomic::inc(&_processed_buffers_mut);
|
||||||
// If worker_i is not UINT_MAX then the thread has already claimed
|
|
||||||
// a par_id. We make note of it using the already_claimed value
|
|
||||||
if (worker_i != UINT_MAX) {
|
|
||||||
already_claimed = true;
|
|
||||||
} else {
|
|
||||||
|
|
||||||
// Otherwise we need to claim a par id
|
|
||||||
worker_i = _free_ids->claim_par_id();
|
|
||||||
|
|
||||||
// And store the par_id value in the thread
|
|
||||||
thread->set_claimed_par_id(worker_i);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool b = false;
|
// release the id
|
||||||
if (worker_i != UINT_MAX) {
|
|
||||||
b = DirtyCardQueue::apply_closure_to_buffer(_mut_process_closure, buf, 0,
|
|
||||||
_sz, true, worker_i);
|
|
||||||
if (b) Atomic::inc(&_processed_buffers_mut);
|
|
||||||
|
|
||||||
// If we had not claimed an id before entering the method
|
|
||||||
// then we must release the id.
|
|
||||||
if (!already_claimed) {
|
|
||||||
|
|
||||||
// we release the id
|
|
||||||
_free_ids->release_par_id(worker_i);
|
_free_ids->release_par_id(worker_i);
|
||||||
|
|
||||||
// and set the claimed_id in the thread to UINT_MAX
|
|
||||||
thread->set_claimed_par_id(UINT_MAX);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return b;
|
return b;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1419,9 +1419,6 @@ void JavaThread::collect_counters(typeArrayOop array) {
|
|||||||
void JavaThread::initialize() {
|
void JavaThread::initialize() {
|
||||||
// Initialize fields
|
// Initialize fields
|
||||||
|
|
||||||
// Set the claimed par_id to UINT_MAX (ie not claiming any par_ids)
|
|
||||||
set_claimed_par_id(UINT_MAX);
|
|
||||||
|
|
||||||
set_saved_exception_pc(NULL);
|
set_saved_exception_pc(NULL);
|
||||||
set_threadObj(NULL);
|
set_threadObj(NULL);
|
||||||
_anchor.clear();
|
_anchor.clear();
|
||||||
|
@ -1964,14 +1964,6 @@ class JavaThread: public Thread {
|
|||||||
bool is_attaching_via_jni() const { return _jni_attach_state == _attaching_via_jni; }
|
bool is_attaching_via_jni() const { return _jni_attach_state == _attaching_via_jni; }
|
||||||
bool has_attached_via_jni() const { return is_attaching_via_jni() || _jni_attach_state == _attached_via_jni; }
|
bool has_attached_via_jni() const { return is_attaching_via_jni() || _jni_attach_state == _attached_via_jni; }
|
||||||
inline void set_done_attaching_via_jni();
|
inline void set_done_attaching_via_jni();
|
||||||
private:
|
|
||||||
// This field is used to determine if a thread has claimed
|
|
||||||
// a par_id: it is UINT_MAX if the thread has not claimed a par_id;
|
|
||||||
// otherwise its value is the par_id that has been claimed.
|
|
||||||
uint _claimed_par_id;
|
|
||||||
public:
|
|
||||||
uint get_claimed_par_id() { return _claimed_par_id; }
|
|
||||||
void set_claimed_par_id(uint id) { _claimed_par_id = id; }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
// Inline implementation of JavaThread::current
|
// Inline implementation of JavaThread::current
|
||||||
|
Loading…
Reference in New Issue
Block a user