Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve the code cache allocation process on Linux #2095

Merged
merged 2 commits into from
Dec 19, 2017

Conversation

harryyu1994
Copy link
Contributor

@harryyu1994 harryyu1994 commented Dec 1, 2017

On the OMR side: add a new Virtual Memory Option called OMRPORT_VMEM_ADDRESS_HINT
Change the method getMemoryInRangeForDefaultPages() to do the following:

  • when OMRPORT_VMEM_ADDRESS_HINT is used, instead of trying page by page to allocate in the desired region, we stop after the first attempt and return whatever default_pageSize_reserve_memory() gives us
  • when doing OMRPORT_VMEM_ALLOC_QUICK, do not try the slow search with mmap if the fast search with smaps failed
  • when doing OMRPORT_VMEM_ALLOC_QUICK, avoid doing the range check when OMRPORT_VMEM_ADDRESS_STRICT is not set

On the OpenJ9 side: change the JIT to do the following during code cache allocation

  • try to allocate memory providing a desired address and setting OMRPORT_VMEM_ADDRESS_HINT
  • if the address returned by the OS is not within (2GB - 24MB) of the JIT dll, then try again by setting OMRPORT_VMEM_ALLOC_QUICK and a much larger address range(the full 2GB - 24MB from JIT dll address range), but not setting OMRPORT_VMEM_STRICT_ADDRESS and accept whatever we get back
  • refactor redundant code into functions and change the order of operation inside J9::CodeCacheManager::allocateCodeCacheSegment to make the code cleaner

The OpenJ9 side change is dependent on the OMR side change, therefore pull in the OMR side change first.
See issue 270 in OpenJ9 for more detail.

Signed-off-by: Harry Yu [email protected]

On the OMR side: add a new Virtual Memory Option called OMRPORT_VMEM_ADDRESS_HINT
Change the method getMemoryInRangeForDefaultPages() to do the following:
	- when OMRPORT_VMEM_ADDRESS_HINT is used, instead of trying page by page to allocate in the desired region, we stop after the first attempt and return whatever default_pageSize_reserve_memory() gives us
	- when doing OMRPORT_VMEM_ALLOC_QUICK, do not try the slow search with mmap if the fast search with smaps failed
	- when doing OMRPORT_VMEM_ALLOC_QUICK, avoid doing the range check when OMRPORT_VMEM_ADDRESS_STRICT is not set

On the OpenJ9 side: change the JIT to do the following during code cache allocation
	- try to allocate memory providing a desired address and setting OMRPORT_VMEM_ADDRESS_HINT
	- if the address returned by the OS is not within (2GB - 24MB) of the JIT dll, then try again by setting OMRPORT_VMEM_ALLOC_QUICK and a much larger address range(the full 2GB - 24MB from JIT dll address range), but not setting OMRPORT_VMEM_STRICT_ADDRESS and accept whatever we get back
	- refactor redundant code into functions and change the order of operation inside J9::CodeCacheManager::allocateCodeCacheSegment to make the code cleaner

The OpenJ9 side change is dependent on the OMR side change, therefore pull in the OMR side change first.
See issue 270 in OpenJ9 for more detail.

Signed-off-by: Harry Yu <[email protected]>
@harryyu1994
Copy link
Contributor Author

@DanHeidinga Hi Dan, could you or someone on the vm team who's familiar with memory management in the portlib review this change please? This is part of the fix for openj9's issue270 (eclipse-openj9/openj9#270). The OMR side change needs to be merged before the OpenJ9 change goes in. Thanks a lot!

@dsouzai
Copy link
Contributor

dsouzai commented Dec 4, 2017

@pdbain-ibm could you review these changes?

@charliegracie charliegracie self-assigned this Dec 13, 2017
* - If not set, search memory page by page until returned address is within desired range
* - If set, return whatever mmap gives us
* - this option is based on the observation that mmap would take the preferred address as a hint about where to place the mapping
* - therefore instead of trying page after page to allocate in the desired region, we stop after the first attempt and return whatever default_pageSize_reserver_memory() gives us as it might give us an address that's good enough
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What if the address is NOT good enough? There are already STRICT flags so how does this change work if someone has also passed in STRICT?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also what happens for non-default page sizes? By default we the GC and other components request large pages when they are available.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for taking your time to review this! If the address is not good enough, then one can try again with other options (i.e. with OMRPORT_VMEM_ALLOC_QUICK and larger range in this case). When HINT is set, we don't really care about the STRICT flag anymore. I guess if someone wants STRICT only then they shouldn't be using the HINT option. The whole idea of the hint was based on the observation that mmap would give us a memory address that's close enough even if it's not in the requested range. We don't think the HINT option works for large pages as it uses shmat instead of mmap. The behaviour for large pages stays the same. @mpirvu Hi Marius, correct me if I'm wrong.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Harry's response is correct.
If both STRICT and HINT are specified, STRICT is ignored. The difference between HINT and non-STRICT is that with HINT there is only one allocation attempt while in the non-STRICT case there could be many attempts.
Large page allocations are non affected by HINT because the allocation is done with shmat which does not have the notion of a hint like mmap does.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we make sure that it is documented that HINT has no effect on large page allocations?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Okay, updated.

@charliegracie
Copy link
Contributor

genie-omr build all

Document that OMRPORT_VMEM_ADDRESS_HINT has no effect on large page allocations.

Signed-off-by: Harry Yu <[email protected]>
@charliegracie
Copy link
Contributor

Only comment changes since the last CI builds

@charliegracie charliegracie merged commit c5a5729 into eclipse-omr:master Dec 19, 2017
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants