1. 17 11月, 2010 1 次提交
    • J
      6978187: G1: assert(ParallelGCThreads> 1 || n_yielded() == _hrrs->occupied()) strikes again · 8d02802f
      johnc 提交于
      Summary: An evacuation failure while copying the roots caused an object, A, to be forwarded to itself. During the subsequent RSet updating a reference to A was processed causing the reference to be added to the RSet of A's heap region. As a result of adding to the remembered set we ran into the issue described in 6930581 - the sparse table expanded and the RSet scanning code walked the cards in one instance of RHashTable (_cur) while the occupied() counts the cards in the expanded table (_next).
      Reviewed-by: tonyp, iveresov
      8d02802f
  2. 12 11月, 2010 1 次提交
  3. 10 11月, 2010 3 次提交
  4. 07 11月, 2010 1 次提交
  5. 06 11月, 2010 3 次提交
  6. 03 11月, 2010 2 次提交
  7. 31 10月, 2010 3 次提交
  8. 29 10月, 2010 1 次提交
  9. 28 10月, 2010 1 次提交
  10. 27 10月, 2010 1 次提交
  11. 24 10月, 2010 1 次提交
  12. 23 10月, 2010 1 次提交
  13. 22 10月, 2010 3 次提交
  14. 21 10月, 2010 1 次提交
  15. 20 10月, 2010 2 次提交
  16. 19 10月, 2010 1 次提交
  17. 17 10月, 2010 1 次提交
    • T
      6991377: G1: race between concurrent refinement and humongous object allocation · a9a0cccb
      tonyp 提交于
      Summary: There is a race between the concurrent refinement threads and the humongous object allocation that can cause the concurrent refinement threads to corrupt the part of the BOT that it is being initialized by the humongous object allocation operation. The solution is to do the humongous object allocation in careful steps to ensure that the concurrent refinement threads always have a consistent view over the BOT, region contents, and top. The fix includes some very minor tidying up in sparsePRT.
      Reviewed-by: jcoomes, johnc, ysr
      a9a0cccb
  18. 19 10月, 2010 1 次提交
    • J
      6988458: G1: assert(mr.end() <= _cm->finger()) failed: otherwise the region... · f0680241
      johnc 提交于
      6988458: G1: assert(mr.end() <= _cm->finger()) failed: otherwise the region shouldn't be on the stack
      Summary: The changes from 6941395 did not clear the CMTask::_aborted_region fields when concurrent marking aborted because of overflow. As a result, the next time around we could see a memory region whose start address was above the global finger and the assertion tripped. Moved the clearing of the aborted regions to ConcurrentMark::clear_marking_state, which is executed on all of the exit paths.
      Reviewed-by: tonyp, ysr, jmasa
      f0680241
  19. 16 10月, 2010 2 次提交
  20. 15 10月, 2010 1 次提交
  21. 14 10月, 2010 1 次提交
  22. 13 10月, 2010 4 次提交
  23. 12 10月, 2010 2 次提交
  24. 11 10月, 2010 1 次提交
  25. 08 10月, 2010 1 次提交