8217423: Windows gtest build fails after JDK-8212826 (Make PtrQueue free list lock-free)

Reviewed-by: clanger, zgu, kbarrett
This commit is contained in:
Aleksey Shipilev 2019-01-21 10:05:24 +01:00
parent 99e6b5ca18
commit 5f325c2363

View File

@ -46,13 +46,13 @@ public:
size_t id() const { return _id; } size_t id() const { return _id; }
void set_id(size_t value) { _id = value; } void set_id(size_t value) { _id = value; }
typedef LockFreeStack<Element, &entry_ptr> Stack; typedef LockFreeStack<Element, &entry_ptr> TestStack;
typedef LockFreeStack<Element, &entry1_ptr> Stack1; typedef LockFreeStack<Element, &entry1_ptr> TestStack1;
}; };
typedef LockFreeStackTestElement Element; typedef LockFreeStackTestElement Element;
typedef Element::Stack Stack; typedef Element::TestStack TestStack;
typedef Element::Stack1 Stack1; typedef Element::TestStack1 TestStack1;
static void initialize_ids(Element* elements, size_t size) { static void initialize_ids(Element* elements, size_t size) {
for (size_t i = 0; i < size; ++i) { for (size_t i = 0; i < size; ++i) {
@ -66,7 +66,7 @@ public:
static const size_t nelements = 10; static const size_t nelements = 10;
Element elements[nelements]; Element elements[nelements];
Stack stack; TestStack stack;
private: private:
void initialize(); void initialize();
@ -111,7 +111,7 @@ TEST_F(LockFreeStackTestBasics, push_pop) {
} }
TEST_F(LockFreeStackTestBasics, prepend_one) { TEST_F(LockFreeStackTestBasics, prepend_one) {
Stack other_stack; TestStack other_stack;
ASSERT_TRUE(other_stack.empty()); ASSERT_TRUE(other_stack.empty());
ASSERT_TRUE(other_stack.pop() == NULL); ASSERT_TRUE(other_stack.pop() == NULL);
ASSERT_EQ(0u, other_stack.length()); ASSERT_EQ(0u, other_stack.length());
@ -138,7 +138,7 @@ TEST_F(LockFreeStackTestBasics, prepend_one) {
} }
TEST_F(LockFreeStackTestBasics, prepend_two) { TEST_F(LockFreeStackTestBasics, prepend_two) {
Stack other_stack; TestStack other_stack;
ASSERT_TRUE(other_stack.empty()); ASSERT_TRUE(other_stack.empty());
ASSERT_EQ(0u, other_stack.length()); ASSERT_EQ(0u, other_stack.length());
ASSERT_TRUE(other_stack.top() == NULL); ASSERT_TRUE(other_stack.top() == NULL);
@ -161,7 +161,7 @@ TEST_F(LockFreeStackTestBasics, prepend_two) {
} }
TEST_F(LockFreeStackTestBasics, two_stacks) { TEST_F(LockFreeStackTestBasics, two_stacks) {
Stack1 stack1; TestStack1 stack1;
ASSERT_TRUE(stack1.pop() == NULL); ASSERT_TRUE(stack1.pop() == NULL);
for (size_t id = 0; id < nelements; ++id) { for (size_t id = 0; id < nelements; ++id) {
@ -201,8 +201,8 @@ TEST_F(LockFreeStackTestBasics, two_stacks) {
class LockFreeStackTestThread : public JavaTestThread { class LockFreeStackTestThread : public JavaTestThread {
uint _id; uint _id;
Stack* _from; TestStack* _from;
Stack* _to; TestStack* _to;
volatile size_t* _processed; volatile size_t* _processed;
size_t _process_limit; size_t _process_limit;
size_t _local_processed; size_t _local_processed;
@ -211,8 +211,8 @@ class LockFreeStackTestThread : public JavaTestThread {
public: public:
LockFreeStackTestThread(Semaphore* post, LockFreeStackTestThread(Semaphore* post,
uint id, uint id,
Stack* from, TestStack* from,
Stack* to, TestStack* to,
volatile size_t* processed, volatile size_t* processed,
size_t process_limit) : size_t process_limit) :
JavaTestThread(post), JavaTestThread(post),
@ -245,10 +245,10 @@ public:
TEST_VM(LockFreeStackTest, stress) { TEST_VM(LockFreeStackTest, stress) {
Semaphore post; Semaphore post;
Stack initial_stack; TestStack initial_stack;
Stack start_stack; TestStack start_stack;
Stack middle_stack; TestStack middle_stack;
Stack final_stack; TestStack final_stack;
volatile size_t stage1_processed = 0; volatile size_t stage1_processed = 0;
volatile size_t stage2_processed = 0; volatile size_t stage2_processed = 0;
@ -271,8 +271,8 @@ TEST_VM(LockFreeStackTest, stress) {
LockFreeStackTestThread* threads[nthreads] = {}; LockFreeStackTestThread* threads[nthreads] = {};
for (uint i = 0; i < ARRAY_SIZE(threads); ++i) { for (uint i = 0; i < ARRAY_SIZE(threads); ++i) {
Stack* from = &start_stack; TestStack* from = &start_stack;
Stack* to = &middle_stack; TestStack* to = &middle_stack;
volatile size_t* processed = &stage1_processed; volatile size_t* processed = &stage1_processed;
if (i >= stage1_threads) { if (i >= stage1_threads) {
from = &middle_stack; from = &middle_stack;