<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal-compose;
        font-family:"Calibri","sans-serif";
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal">Hello all,<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I would like to propose adding a capability in the JVM to allocate object heap on new kinds of heterogeneous memories which are exposed through a file system. This could be achieved by adding a command line option to specify a path in the
 filesystem which would be used for mmap() system call.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Details:<o:p></o:p></p>
<p class="MsoNormal">Linux kernel 4.0 onwards supports DAX mode[1] in Ext4 file system [2] which is designed to support new heterogeneous memory devices such as Intel’s 3D XPoint memory [3]. DAX mode removes the need for page cache and provides a direct mapping
 of process virtual space to storage space.<o:p></o:p></p>
<p class="MsoNormal">We would like to add a command line option called “FSDirForHeap” which will – 1) Enable using a file system as backing store for Java object heap 2) Use the provided path to create a temporary file for mmap() system call.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">The description of the feature can be found at <a href="https://bugs.openjdk.java.net/browse/JDK-8153327">
https://bugs.openjdk.java.net/browse/JDK-8153327</a><o:p></o:p></p>
<p class="MsoNormal">and the webrev is uploaded at <a href="http://cr.openjdk.java.net/~vdeshpande/8153327/webrev.00/">
http://cr.openjdk.java.net/~vdeshpande/8153327/webrev.00/</a><o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">References:<o:p></o:p></p>
<p class="MsoNormal">[1] <a href="https://www.kernel.org/doc/Documentation/filesystems/dax.txt">
https://www.kernel.org/doc/Documentation/filesystems/dax.txt</a><o:p></o:p></p>
<p class="MsoNormal">[2] <a href="https://www.kernel.org/doc/Documentation/filesystems/ext4.txt">
https://www.kernel.org/doc/Documentation/filesystems/ext4.txt</a><o:p></o:p></p>
<p class="MsoNormal">[3] https://newsroom.intel.com/press-kits/introducing-intel-optane-technology-bringing-3d-xpoint-memory-to-storage-and-memory-products/<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Much appreciated!<o:p></o:p></p>
<p class="MsoNormal">Thanks you.<o:p></o:p></p>
<p class="MsoNormal">Kishor Kharbas<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</body>
</html>