<div dir="ltr"><div>Hi Folks,</div><div><br></div>It's been a while, but I'd like to pick up this discussion of adding a context to memory allocations again.<div><br></div><div>The immediate motivation I have is that I'd like to support use of the memkind library (<a href="https://github.com/memkind/memkind">https://github.com/memkind/memkind</a>), though adding a context to PetscMallocN() (or making some other interface, say PetscAdvMalloc() or whatever) could have much broader utility than simply memkind support (which Jed doesn't like anyway, and I share some of his concerns). For the sake of having a concrete example, I'll discuss memkind here.</div><div><br></div><div>Memkind's memkind_malloc() works like malloc() but takes a memkind_t argument to specify some desired property of the memory being allocated. For example, </div><div><br></div><div> <span style="color:rgb(51,51,51);font-family:Consolas,'Liberation Mono',Menlo,Courier,monospace;font-size:12px;line-height:16.7999992370605px;white-space:pre"> hugetlb_str = (</span><span class="" style="color:rgb(167,29,93);font-family:Consolas,'Liberation Mono',Menlo,Courier,monospace;font-size:12px;line-height:16.7999992370605px;white-space:pre">char</span><span style="color:rgb(51,51,51);font-family:Consolas,'Liberation Mono',Menlo,Courier,monospace;font-size:12px;line-height:16.7999992370605px;white-space:pre"> *)</span><span class="" style="color:rgb(0,134,179);font-family:Consolas,'Liberation Mono',Menlo,Courier,monospace;font-size:12px;line-height:16.7999992370605px;white-space:pre">memkind_malloc</span><span style="color:rgb(51,51,51);font-family:Consolas,'Liberation Mono',Menlo,Courier,monospace;font-size:12px;line-height:16.7999992370605px;white-space:pre">(MEMKIND_HUGETLB, size);</span></div><div><span style="color:rgb(51,51,51);font-family:Consolas,'Liberation Mono',Menlo,Courier,monospace;font-size:12px;line-height:16.7999992370605px;white-space:pre"><br></span></div><div>returns a pointer to memory allocated using huge pages, and </div><div><br></div><div><font face="monospace, monospace"><span style="color:rgb(51,51,51);font-size:12px;line-height:16.7999992370605px;white-space:pre"> hbw_preferred_str = (</span><span class="" style="color:rgb(167,29,93);font-size:12px;line-height:16.7999992370605px;white-space:pre">char</span><span style="color:rgb(51,51,51);font-size:12px;line-height:16.7999992370605px;white-space:pre"> *)</span><span class="" style="color:rgb(0,134,179);font-size:12px;line-height:16.7999992370605px;white-space:pre">memkind_malloc</span><span style="color:rgb(51,51,51);font-size:12px;line-height:16.7999992370605px;white-space:pre">(MEMKIND_HBW_PREFERRED, size);</span></font><br></div><div><span style="color:rgb(51,51,51);font-family:Consolas,'Liberation Mono',Menlo,Courier,monospace;font-size:12px;line-height:16.7999992370605px;white-space:pre"><br></span></div><div>allocates memory from a high-bandwidth region if it's available and elsewhere if not (specifying MEMKIND_HBW will insist on the allocation coming from high-bandwidth memory, failing if it's not available).</div><div><br></div><div>It should be straightforward to add a variant of PetscMalloc() that accepts a context: I'll call this PetscAdvMalloc(), for now, though we can come up with a better name later. This will allow passing on the memkind_t via this context to the underlying memkind allocator, and we can have some mechanism to set a default context (in the case of Memkind, this is likely MEMKIND_DEFAULT) that gets used when plain PetscMalloc() gets called.</div><div><br></div><div>Of course, we'll need some way to ensure that the "advanced malloc" gets used to allocated the critical data structures. As a low-level way to start, it may make sense to simply add a way to stash a context in Vec and Mat objects. Maybe have VecSetAdvMallocCtx(), and if that context gets set, then PetscAdvMalloc() is used for the allocations associated with the contents of that object. It would probably be better to eventually have a higher-level way to do this, e.g., support standard settings in the options database that PETSc uses to construct the appropriate arguments to underlying allocators that are supported, but I think just adding a way to set this context directly is an appropriate first step.</div><div> </div><div>Does this sound like a reasonable thing for me to prototype, or are others thinking something very different? Please let me know. I'm getting more access to early systems I can experiment on, and I'd really like to move forward on trying things with high bandwidth memory (imperfect as our APIs for using it are).</div><div><br></div><div>Best regards,</div><div>Richard</div><div><br><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Apr 29, 2015 at 11:10 PM, Richard Mills <span dir="ltr"><<a href="mailto:rtm@utk.edu" target="_blank">rtm@utk.edu</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra"><div class="gmail_quote"><span>On Wed, Apr 29, 2015 at 1:28 PM, Barry Smith <span dir="ltr"><<a href="mailto:bsmith@mcs.anl.gov" target="_blank">bsmith@mcs.anl.gov</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><br>
Forget about the issue of "changing" PetscMallocN() or adding a new interface instead, that is a minor syntax and annoyance issue:<br>
<br>
The question is "is it worth exploring adding a context for certain memory allocations that would allow us to "do" various things to the memory and "indicate" properties of the memory"? I think, though I agree with Jed that it could be fraught with difficulties, that is is worthwhile playing around with this.<br>
<span><font color="#888888"><br>
Barry<br>
</font></span><div><div><br></div></div></blockquote><div><br></div></span><div>I vote "yes". One might want to, say</div><div><br></div><div>* Give hints via something like madvise() on how/when the memory might be accessed.</div><div>* Specify a preferred "kind" of memory (and behavior if the preferred kind is not available, or perhaps even specify a priority on how hard to try to get the preferred memory kind)</div><div>* Specify something like a preference to interleave allocation blocks between different kinds of memory</div><div><br></div><div>I'm sure we can come up with plenty of other possibilities, some of which might actually be useful, many of which will be useful only for very contrived cases, and some that are not useful today but may become useful as memory systems evolve.</div><span><font color="#888888"><div><br></div><div>--Richard</div></font></span></div></div></div>
</blockquote></div><br></div></div></div>