8013171: G1: C1 x86_64 barriers use 32-bit accesses to 64-bit PtrQueue::_index
Reviewed-by: roland, tschatzl
This commit is contained in:
parent
7ede39f590
commit
7e9f9f9107
@ -1631,36 +1631,22 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) {
|
|||||||
|
|
||||||
NOT_LP64(__ get_thread(thread);)
|
NOT_LP64(__ get_thread(thread);)
|
||||||
|
|
||||||
Address in_progress(thread, in_bytes(JavaThread::satb_mark_queue_offset() +
|
|
||||||
PtrQueue::byte_offset_of_active()));
|
|
||||||
|
|
||||||
Address queue_index(thread, in_bytes(JavaThread::satb_mark_queue_offset() +
|
Address queue_index(thread, in_bytes(JavaThread::satb_mark_queue_offset() +
|
||||||
PtrQueue::byte_offset_of_index()));
|
PtrQueue::byte_offset_of_index()));
|
||||||
Address buffer(thread, in_bytes(JavaThread::satb_mark_queue_offset() +
|
Address buffer(thread, in_bytes(JavaThread::satb_mark_queue_offset() +
|
||||||
PtrQueue::byte_offset_of_buf()));
|
PtrQueue::byte_offset_of_buf()));
|
||||||
|
|
||||||
|
|
||||||
Label done;
|
Label done;
|
||||||
Label runtime;
|
Label runtime;
|
||||||
|
|
||||||
// Can we store original value in the thread's buffer?
|
// Can we store original value in the thread's buffer?
|
||||||
|
|
||||||
#ifdef _LP64
|
__ movptr(tmp, queue_index);
|
||||||
__ movslq(tmp, queue_index);
|
__ testptr(tmp, tmp);
|
||||||
__ cmpq(tmp, 0);
|
__ jcc(Assembler::zero, runtime);
|
||||||
#else
|
__ subptr(tmp, wordSize);
|
||||||
__ cmpl(queue_index, 0);
|
__ movptr(queue_index, tmp);
|
||||||
#endif
|
__ addptr(tmp, buffer);
|
||||||
__ jcc(Assembler::equal, runtime);
|
|
||||||
#ifdef _LP64
|
|
||||||
__ subq(tmp, wordSize);
|
|
||||||
__ movl(queue_index, tmp);
|
|
||||||
__ addq(tmp, buffer);
|
|
||||||
#else
|
|
||||||
__ subl(queue_index, wordSize);
|
|
||||||
__ movl(tmp, buffer);
|
|
||||||
__ addl(tmp, queue_index);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// prev_val (rax)
|
// prev_val (rax)
|
||||||
f.load_argument(0, pre_val);
|
f.load_argument(0, pre_val);
|
||||||
@ -1713,6 +1699,7 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) {
|
|||||||
assert(sizeof(*ct->byte_map_base) == sizeof(jbyte), "adjust this code");
|
assert(sizeof(*ct->byte_map_base) == sizeof(jbyte), "adjust this code");
|
||||||
|
|
||||||
Label done;
|
Label done;
|
||||||
|
Label enqueued;
|
||||||
Label runtime;
|
Label runtime;
|
||||||
|
|
||||||
// At this point we know new_value is non-NULL and the new_value crosses regions.
|
// At this point we know new_value is non-NULL and the new_value crosses regions.
|
||||||
@ -1752,28 +1739,19 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) {
|
|||||||
|
|
||||||
__ movb(Address(card_addr, 0), (int)CardTableModRefBS::dirty_card_val());
|
__ movb(Address(card_addr, 0), (int)CardTableModRefBS::dirty_card_val());
|
||||||
|
|
||||||
__ cmpl(queue_index, 0);
|
const Register tmp = rdx;
|
||||||
__ jcc(Assembler::equal, runtime);
|
__ push(rdx);
|
||||||
__ subl(queue_index, wordSize);
|
|
||||||
|
|
||||||
const Register buffer_addr = rbx;
|
__ movptr(tmp, queue_index);
|
||||||
__ push(rbx);
|
__ testptr(tmp, tmp);
|
||||||
|
__ jcc(Assembler::zero, runtime);
|
||||||
__ movptr(buffer_addr, buffer);
|
__ subptr(tmp, wordSize);
|
||||||
|
__ movptr(queue_index, tmp);
|
||||||
#ifdef _LP64
|
__ addptr(tmp, buffer);
|
||||||
__ movslq(rscratch1, queue_index);
|
__ movptr(Address(tmp, 0), card_addr);
|
||||||
__ addptr(buffer_addr, rscratch1);
|
__ jmp(enqueued);
|
||||||
#else
|
|
||||||
__ addptr(buffer_addr, queue_index);
|
|
||||||
#endif
|
|
||||||
__ movptr(Address(buffer_addr, 0), card_addr);
|
|
||||||
|
|
||||||
__ pop(rbx);
|
|
||||||
__ jmp(done);
|
|
||||||
|
|
||||||
__ bind(runtime);
|
__ bind(runtime);
|
||||||
__ push(rdx);
|
|
||||||
#ifdef _LP64
|
#ifdef _LP64
|
||||||
__ push(r8);
|
__ push(r8);
|
||||||
__ push(r9);
|
__ push(r9);
|
||||||
@ -1795,12 +1773,12 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) {
|
|||||||
__ pop(r9);
|
__ pop(r9);
|
||||||
__ pop(r8);
|
__ pop(r8);
|
||||||
#endif
|
#endif
|
||||||
|
__ bind(enqueued);
|
||||||
__ pop(rdx);
|
__ pop(rdx);
|
||||||
__ bind(done);
|
|
||||||
|
|
||||||
|
__ bind(done);
|
||||||
__ pop(rcx);
|
__ pop(rcx);
|
||||||
__ pop(rax);
|
__ pop(rax);
|
||||||
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif // INCLUDE_ALL_GCS
|
#endif // INCLUDE_ALL_GCS
|
||||||
|
Loading…
x
Reference in New Issue
Block a user