50
50
#include <umf/memory_pool.h>
51
51
#include <umf/memory_provider.h>
52
52
#include <umf/providers/provider_os_memory.h>
53
+ #include <umf/proxy_lib_handlers.h>
53
54
54
55
#include "base_alloc_linear.h"
55
- #include "proxy_lib.h"
56
56
#include "utils_common.h"
57
57
#include "utils_load_library.h"
58
58
#include "utils_log.h"
@@ -135,6 +135,22 @@ static __TLS int was_called_from_umfPool = 0;
135
135
// TODO remove this WA when the issue is fixed.
136
136
static __TLS int was_called_from_malloc_usable_size = 0 ;
137
137
138
+ // malloc API handlers
139
+ static umf_proxy_lib_handler_malloc_pre_t Handler_malloc_pre = NULL ;
140
+ static umf_proxy_lib_handler_aligned_malloc_pre_t Handler_aligned_malloc_pre =
141
+ NULL ;
142
+ static umf_proxy_lib_handler_free_pre_t Handler_free_pre = NULL ;
143
+
144
+ static umf_proxy_lib_handler_malloc_post_t Handler_malloc_post = NULL ;
145
+ static umf_proxy_lib_handler_aligned_malloc_post_t Handler_aligned_malloc_post =
146
+ NULL ;
147
+
148
+ static void * Handler_malloc_pre_user_data = NULL ;
149
+ static void * Handler_aligned_malloc_pre_user_data = NULL ;
150
+ static void * Handler_free_pre_user_data = NULL ;
151
+ static void * Handler_malloc_post_user_data = NULL ;
152
+ static void * Handler_aligned_malloc_post_user_data = NULL ;
153
+
138
154
/*****************************************************************************/
139
155
/*** The constructor and destructor of the proxy library *********************/
140
156
/*****************************************************************************/
@@ -353,20 +369,34 @@ static inline size_t ba_leak_pool_contains_pointer(void *ptr) {
353
369
/*****************************************************************************/
354
370
355
371
void * malloc (size_t size ) {
372
+ if (Handler_malloc_pre ) {
373
+ Handler_malloc_pre (Handler_malloc_pre_user_data , & size );
374
+ }
375
+
376
+ void * ptr = NULL ;
356
377
#ifndef _WIN32
357
378
if (size < Size_threshold_value ) {
358
- return System_malloc (size );
379
+ ptr = System_malloc (size );
380
+ goto handler_post ;
359
381
}
360
382
#endif /* _WIN32 */
361
383
362
- if (!was_called_from_umfPool && Proxy_pool ) {
384
+ umf_memory_pool_handle_t pool = Proxy_pool ;
385
+ if (!was_called_from_umfPool && pool ) {
363
386
was_called_from_umfPool = 1 ;
364
- void * ptr = umfPoolMalloc (Proxy_pool , size );
387
+ ptr = umfPoolMalloc (pool , size );
365
388
was_called_from_umfPool = 0 ;
366
- return ptr ;
389
+ goto handler_post ;
367
390
}
368
391
369
- return ba_leak_malloc (size );
392
+ ptr = ba_leak_malloc (size );
393
+
394
+ handler_post :
395
+ if (Handler_malloc_post ) {
396
+ Handler_malloc_post (Handler_malloc_post_user_data , & ptr , pool );
397
+ }
398
+
399
+ return ptr ;
370
400
}
371
401
372
402
void * calloc (size_t nmemb , size_t size ) {
@@ -387,15 +417,28 @@ void *calloc(size_t nmemb, size_t size) {
387
417
}
388
418
389
419
void free (void * ptr ) {
420
+ umf_memory_pool_handle_t pool = NULL ;
421
+ if (Handler_free_pre ) {
422
+ pool = umfPoolByPtr (ptr );
423
+ Handler_free_pre (Handler_free_pre_user_data , & ptr , pool );
424
+ }
425
+
390
426
if (ptr == NULL ) {
391
427
return ;
392
428
}
393
429
430
+ // NOTE: for system allocations made during UMF and Proxy Lib
431
+ // initialisation, we never call free handlers, as they should handle
432
+ // only user-made allocations
394
433
if (ba_leak_free (ptr ) == 0 ) {
395
434
return ;
396
435
}
397
436
398
- if (Proxy_pool && (umfPoolByPtr (ptr ) == Proxy_pool )) {
437
+ if (Proxy_pool && pool == NULL ) {
438
+ pool = umfPoolByPtr (ptr );
439
+ }
440
+
441
+ if (pool == Proxy_pool ) {
399
442
if (umfPoolFree (Proxy_pool , ptr ) != UMF_RESULT_SUCCESS ) {
400
443
LOG_ERR ("umfPoolFree() failed" );
401
444
}
@@ -448,20 +491,36 @@ void *realloc(void *ptr, size_t size) {
448
491
}
449
492
450
493
void * aligned_alloc (size_t alignment , size_t size ) {
494
+ umf_memory_pool_handle_t pool = Proxy_pool ;
495
+ if (Handler_aligned_malloc_pre ) {
496
+ Handler_aligned_malloc_pre (Handler_aligned_malloc_pre_user_data , & pool ,
497
+ & size , & alignment );
498
+ }
499
+
500
+ void * ptr = NULL ;
451
501
#ifndef _WIN32
452
502
if (size < Size_threshold_value ) {
453
- return System_aligned_alloc (alignment , size );
503
+ ptr = System_aligned_alloc (alignment , size );
504
+ goto handler_post ;
454
505
}
455
506
#endif /* _WIN32 */
456
507
457
508
if (!was_called_from_umfPool && Proxy_pool ) {
458
509
was_called_from_umfPool = 1 ;
459
- void * ptr = umfPoolAlignedMalloc (Proxy_pool , size , alignment );
510
+ ptr = umfPoolAlignedMalloc (Proxy_pool , size , alignment );
460
511
was_called_from_umfPool = 0 ;
461
- return ptr ;
512
+ goto handler_post ;
462
513
}
463
514
464
- return ba_leak_aligned_alloc (alignment , size );
515
+ ptr = ba_leak_aligned_alloc (alignment , size );
516
+
517
+ handler_post :
518
+ if (Handler_aligned_malloc_post ) {
519
+ Handler_aligned_malloc_post (Handler_aligned_malloc_post_user_data , & ptr ,
520
+ pool );
521
+ }
522
+
523
+ return ptr ;
465
524
}
466
525
467
526
#ifdef _WIN32
@@ -555,3 +614,35 @@ void *_aligned_offset_recalloc(void *ptr, size_t num, size_t size,
555
614
}
556
615
557
616
#endif
617
+
618
+ // malloc API handlers
619
+
620
+ void umfSetProxyLibHandlerMallocPre (umf_proxy_lib_handler_malloc_pre_t handler ,
621
+ void * user_data ) {
622
+ Handler_malloc_pre = handler ;
623
+ Handler_malloc_pre_user_data = user_data ;
624
+ }
625
+
626
+ void umfSetProxyLibHandlerAlignedMallocPre (
627
+ umf_proxy_lib_handler_aligned_malloc_pre_t handler , void * user_data ) {
628
+ Handler_aligned_malloc_pre = handler ;
629
+ Handler_aligned_malloc_pre_user_data = user_data ;
630
+ }
631
+
632
+ void umfSetProxyLibHandlerFreePre (umf_proxy_lib_handler_free_pre_t handler ,
633
+ void * user_data ) {
634
+ Handler_free_pre = handler ;
635
+ Handler_free_pre_user_data = user_data ;
636
+ }
637
+
638
+ void umfSetProxyLibHandlerMallocPost (
639
+ umf_proxy_lib_handler_malloc_post_t handler , void * user_data ) {
640
+ Handler_malloc_post = handler ;
641
+ Handler_malloc_post_user_data = user_data ;
642
+ }
643
+
644
+ void umfSetProxyLibHandlerAlignedMallocPost (
645
+ umf_proxy_lib_handler_aligned_malloc_post_t handler , void * user_data ) {
646
+ Handler_aligned_malloc_post = handler ;
647
+ Handler_aligned_malloc_post_user_data = user_data ;
648
+ }
0 commit comments