[J3] [EXTERNAL] Re: Custom Memory Allocator

Reuben D. Budiardja reubendb at ornl.gov
Fri Nov 15 19:30:57 EST 2019


Hi Jon,

Interesting. I was not aware of this (but then again I am not yet fully 
familiar with OpenMP 5). However, in the spec it says for Fortran the 
list item "must not have the ALLOCATABLE attribute" unless associated 
with "allocate statement".

So I am not sure how this would solve my issue (provided I could find 
such compiler). Or am I misunderstanding thing?

Thanks,
Reuben

On 11/15/2019 05:18 PM, Steidel, Jon L via J3 wrote:
> OpenMP 5.0 has the ALLOCATE directive, with the ALLOCATOR clause.  I don't know if you have access to an OpenMP 5.0 compiler (or if there is yet one available), or if this would work for you if you can find such a compiler.
> 
> -jon
> 
> -----Original Message-----
> From: J3 <j3-bounces at mailman.j3-fortran.org> On Behalf Of Reuben D. Budiardja via J3
> Sent: Friday, November 15, 2019 2:30 PM
> To: j3 at mailman.j3-fortran.org
> Cc: Reuben D. Budiardja <reubendb at ornl.gov>
> Subject: [J3] Custom Memory Allocator
> 
> Hello,
> 
> I am wondering if there is a standard-conformance way to allocate allocatable array with a custom memory allocator, e.g. via third-party provided C-library.
> 
> At first I looked into passing the allocatable into a bind(c) subroutine and use the C descriptor from the C side. But sec 18.6 and 18.7 prevent using any custom allocator other than using CFI_allocate().
> 
> Real-world use case examples: we need to use CUDA memory allocator
> cudaMallocManaged() to use CUDA Unified Memory, and cudaHostAlloc() to use page-locked memory on the system.
> 
> I suppose the hack-ish way is to swap the base_address member of C descriptor to the address given cudaMallocManaged() (and free-up the original address from CFI_allocate()).
> 
> I wondered if for further enhancement on C interoperability we may consider allowing custom allocator into the standard.
> 
> I'd be interested in any feedback.
> 
> Best,
> Reuben
> 

-- 
Reuben D. Budiardja
reubendb at ornl.gov | (865) 576-9519
National Center for Computational Sciences
Oak Ridge National Laboratory


More information about the J3 mailing list