treiber_stack_hp.cpp 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. // Copyright (c) 2006-2018 Maxim Khizhinsky
  2. //
  3. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  4. // file LICENSE or copy at http://www.boost.org/LICENSE_1_0.txt)
  5. #include "test_treiber_stack.h"
  6. #include <cds/gc/hp.h>
  7. #include <cds/container/treiber_stack.h>
  8. namespace {
  9. namespace cc = cds::container;
  10. typedef cds::gc::HP gc_type;
  11. class TreiberStack_HP : public cds_test::TreiberStack
  12. {
  13. typedef cds_test::TreiberStack base_class;
  14. protected:
  15. void SetUp()
  16. {
  17. typedef cc::TreiberStack< gc_type, int > stack_type;
  18. cds::gc::hp::GarbageCollector::Construct( stack_type::c_nHazardPtrCount, 1, 16 );
  19. cds::threading::Manager::attachThread();
  20. }
  21. void TearDown()
  22. {
  23. cds::threading::Manager::detachThread();
  24. cds::gc::hp::GarbageCollector::Destruct( true );
  25. }
  26. template <typename Stack>
  27. void test()
  28. {
  29. Stack stack;
  30. base_class::test( stack );
  31. }
  32. template <typename Stack>
  33. void test_dyn( size_t elimination_size )
  34. {
  35. Stack stack( elimination_size );
  36. base_class::test( stack );
  37. }
  38. };
  39. TEST_F( TreiberStack_HP, defaulted )
  40. {
  41. typedef cc::TreiberStack< gc_type, int > stack_type;
  42. test<stack_type>();
  43. }
  44. TEST_F( TreiberStack_HP, backoff )
  45. {
  46. typedef cc::TreiberStack< gc_type, int
  47. , typename cc::treiber_stack::make_traits<
  48. cds::opt::back_off< cds::backoff::yield>
  49. >::type
  50. > stack_type;
  51. test<stack_type>();
  52. }
  53. TEST_F( TreiberStack_HP, alloc )
  54. {
  55. // allocator must be rebinded for real value type
  56. struct foo;
  57. typedef cc::TreiberStack< gc_type, int
  58. , typename cc::treiber_stack::make_traits<
  59. cds::opt::back_off< cds::backoff::pause>
  60. ,cds::opt::memory_model<cds::opt::v::relaxed_ordering>
  61. ,cds::opt::allocator< std::allocator< foo >>
  62. >::type
  63. > stack_type;
  64. test<stack_type>();
  65. }
  66. TEST_F( TreiberStack_HP, elimination )
  67. {
  68. typedef cc::TreiberStack< gc_type, int
  69. , typename cc::treiber_stack::make_traits<
  70. cds::opt::enable_elimination<true>
  71. >::type
  72. > stack_type;
  73. test<stack_type>();
  74. }
  75. TEST_F( TreiberStack_HP, elimination_backoff )
  76. {
  77. struct traits : public cc::treiber_stack::traits
  78. {
  79. enum {
  80. enable_elimination = true
  81. };
  82. typedef cds::backoff::pause back_off;
  83. };
  84. typedef cc::TreiberStack< gc_type, int, traits > stack_type;
  85. test<stack_type>();
  86. }
  87. TEST_F( TreiberStack_HP, elimination_dynamic )
  88. {
  89. typedef cc::TreiberStack< gc_type, int
  90. , typename cc::treiber_stack::make_traits<
  91. cds::opt::enable_elimination<true>
  92. , cds::opt::buffer< cds::opt::v::initialized_dynamic_buffer<void *> >
  93. >::type
  94. > stack_type;
  95. test_dyn<stack_type>( 4 );
  96. }
  97. TEST_F( TreiberStack_HP, elimination_stat )
  98. {
  99. typedef cc::TreiberStack< gc_type, int
  100. , typename cc::treiber_stack::make_traits<
  101. cds::opt::enable_elimination<true>
  102. , cds::opt::stat< cc::treiber_stack::stat<> >
  103. >::type
  104. > stack_type;
  105. test<stack_type>();
  106. }
  107. TEST_F( TreiberStack_HP, elimination_dynamic_backoff )
  108. {
  109. struct traits : public cc::treiber_stack::traits
  110. {
  111. enum {
  112. enable_elimination = true
  113. };
  114. typedef cds::opt::v::initialized_dynamic_buffer<void *> buffer;
  115. typedef cds::backoff::yield back_off;
  116. };
  117. typedef cc::TreiberStack< gc_type, int, traits > stack_type;
  118. test_dyn<stack_type>( 2 );
  119. }
  120. } // namespace