1
0
mirror of https://github.com/TREX-CoE/qmckl.git synced 2025-01-05 11:00:36 +01:00

Fixed context

This commit is contained in:
Anthony Scemama 2021-03-18 19:12:39 +01:00
parent 1af0bf053f
commit d10c84acbb
2 changed files with 92 additions and 65 deletions

View File

@ -195,6 +195,20 @@ qmckl_context qmckl_context_create() {
const qmckl_context context = (qmckl_context) ctx; const qmckl_context context = (qmckl_context) ctx;
assert ( qmckl_context_check(context) != QMCKL_NULL_CONTEXT ); assert ( qmckl_context_check(context) != QMCKL_NULL_CONTEXT );
/*
qmckl_memory_struct* alloc = (qmckl_memory_struct*)
malloc(sizeof(qmckl_memory_struct));
if (alloc == NULL) {
qmckl_unlock(context);
return QMCKL_NULL_CONTEXT;
}
memset(alloc,0,sizeof(qmckl_memory_struct));
ctx->alloc = alloc;
*/
return context; return context;
} }
#+end_src #+end_src
@ -261,7 +275,9 @@ void qmckl_lock(qmckl_context context) {
} }
assert (rc == 0); assert (rc == 0);
ctx->lock_count++; ctx->lock_count++;
/*
printf(" lock : %d\n", ctx->lock_count); printf(" lock : %d\n", ctx->lock_count);
*/
} }
void qmckl_unlock(qmckl_context context) { void qmckl_unlock(qmckl_context context) {
@ -273,7 +289,9 @@ void qmckl_unlock(qmckl_context context) {
} }
assert (rc == 0); assert (rc == 0);
ctx->lock_count--; ctx->lock_count--;
/*
printf("unlock : %d\n", ctx->lock_count); printf("unlock : %d\n", ctx->lock_count);
*/
} }
#+end_src #+end_src
@ -315,10 +333,11 @@ qmckl_context qmckl_context_copy(const qmckl_context context) {
/* Copy the old context on the new one */ /* Copy the old context on the new one */
memcpy(new_ctx, old_ctx, sizeof(qmckl_context_struct)); memcpy(new_ctx, old_ctx, sizeof(qmckl_context_struct));
qmckl_unlock( (qmckl_context) old_ctx );
new_ctx->prev = old_ctx; new_ctx->prev = old_ctx;
qmckl_unlock( (qmckl_context) new_ctx );
qmckl_unlock( (qmckl_context) old_ctx );
return (qmckl_context) new_ctx; return (qmckl_context) new_ctx;
} }
@ -367,28 +386,34 @@ qmckl_context qmckl_context_destroy(const qmckl_context context) {
qmckl_unlock(context); qmckl_unlock(context);
const int rc_destroy = pthread_mutex_destroy( &(ctx->mutex) );
if (rc_destroy != 0) {
fprintf(stderr, "qmckl_context_destroy: %s %d\n", strerror(rc_destroy), ctx->lock_count);
abort();
}
const qmckl_context prev_context = (qmckl_context) ctx->prev; const qmckl_context prev_context = (qmckl_context) ctx->prev;
if (prev_context == QMCKL_NULL_CONTEXT) { if (prev_context == QMCKL_NULL_CONTEXT) {
/* This is the first context, free all memory. */ /* This is the first context, free all memory. */
struct qmckl_memory_struct* old = NULL; struct qmckl_memory_struct* new = NULL;
while (ctx->alloc != NULL) { while (ctx->alloc != NULL) {
old = ctx->alloc; new = ctx->alloc->next;
ctx->alloc = ctx->alloc->prev; free(ctx->alloc->pointer);
free(old->pointer); ctx->alloc->pointer = NULL;
old->pointer = NULL; free(ctx->alloc);
free(old); ctx->alloc = new;
old = NULL;
} }
} }
qmckl_exit_code rc;
rc = qmckl_context_remove_memory(context,ctx);
/*
assert (rc == QMCKL_SUCCESS);
*/
ctx->tag = INVALID_TAG; ctx->tag = INVALID_TAG;
const qmckl_exit_code rc = qmckl_free(context,ctx);
const int rc_destroy = pthread_mutex_destroy( &(ctx->mutex) );
if (rc_destroy != 0) {
fprintf(stderr, "qmckl_context_destroy: %s (count = %d)\n", strerror(rc_destroy), ctx->lock_count);
abort();
}
rc = qmckl_free(context,ctx);
assert (rc == QMCKL_SUCCESS); assert (rc == QMCKL_SUCCESS);
//memset(ctx, 0, sizeof(qmckl_context_struct)); //memset(ctx, 0, sizeof(qmckl_context_struct));
@ -472,7 +497,7 @@ munit_assert_int64(qmckl_context_previous(QMCKL_NULL_CONTEXT), ==, QMCKL_NULL_CO
#+NAME: qmckl_memory_struct #+NAME: qmckl_memory_struct
#+begin_src c :comments org :tangle no #+begin_src c :comments org :tangle no
typedef struct qmckl_memory_struct { typedef struct qmckl_memory_struct {
struct qmckl_memory_struct * prev ; struct qmckl_memory_struct * next ;
void * pointer ; void * pointer ;
size_t size ; size_t size ;
} qmckl_memory_struct; } qmckl_memory_struct;
@ -510,19 +535,27 @@ qmckl_exit_code qmckl_context_append_memory(qmckl_context context,
qmckl_context_struct* ctx = (qmckl_context_struct*) context; qmckl_context_struct* ctx = (qmckl_context_struct*) context;
qmckl_memory_struct* alloc = (qmckl_memory_struct*) qmckl_memory_struct* new_alloc = (qmckl_memory_struct*)
malloc(sizeof(qmckl_memory_struct)); malloc(sizeof(qmckl_memory_struct));
if (alloc == NULL) { if (new_alloc == NULL) {
qmckl_unlock(context); qmckl_unlock(context);
return QMCKL_ALLOCATION_FAILED; return QMCKL_ALLOCATION_FAILED;
} }
alloc->prev = ctx->alloc; new_alloc->next = NULL;
alloc->pointer = pointer; new_alloc->pointer = pointer;
alloc->size = size; new_alloc->size = size;
ctx->alloc = alloc; qmckl_memory_struct* alloc = ctx->alloc;
if (alloc == NULL) {
ctx->alloc = new_alloc;
} else {
while (alloc != NULL) {
alloc = alloc->next;
}
alloc->next = new_alloc;
}
qmckl_unlock(context); qmckl_unlock(context);
@ -560,35 +593,26 @@ qmckl_exit_code qmckl_context_remove_memory(qmckl_context context,
qmckl_context_struct* ctx = (qmckl_context_struct*) context; qmckl_context_struct* ctx = (qmckl_context_struct*) context;
qmckl_memory_struct* alloc; qmckl_memory_struct* alloc = ctx->alloc;
qmckl_memory_struct* next; qmckl_memory_struct* prev = ctx->alloc;
if (ctx->alloc->pointer == pointer) { while ( (alloc != NULL) && (alloc->pointer != pointer) ) {
prev = alloc;
alloc = alloc->next;
}
alloc = ctx->alloc->prev; if (alloc != NULL) {
free(ctx->alloc); prev->next = alloc->next;
ctx->alloc = alloc;
} else {
next = ctx->alloc;
alloc = next->prev;
while (alloc != NULL) {
if (alloc->pointer == pointer) {
next->prev = alloc->prev;
free(alloc); free(alloc);
alloc = NULL;
} else {
next = alloc;
alloc = alloc->prev;
}
}
} }
qmckl_unlock(context); qmckl_unlock(context);
if (alloc != NULL) {
return QMCKL_SUCCESS; return QMCKL_SUCCESS;
} else {
return QMCKL_DEALLOCATION_FAILED;
}
} }
#+end_src #+end_src

View File

@ -62,7 +62,8 @@ typedef int32_t qmckl_exit_code;
| ~QMCKL_ERRNO~ | 102 | | ~QMCKL_ERRNO~ | 102 |
| ~QMCKL_INVALID_CONTEXT~ | 103 | | ~QMCKL_INVALID_CONTEXT~ | 103 |
| ~QMCKL_ALLOCATION_FAILED~ | 104 | | ~QMCKL_ALLOCATION_FAILED~ | 104 |
| ~QMCKL_INVALID_EXIT_CODE~ | 105 | | ~QMCKL_DEALLOCATION_FAILED~ | 105 |
| ~QMCKL_INVALID_EXIT_CODE~ | 106 |
# We need to force Emacs not to indent the Python code: # We need to force Emacs not to indent the Python code:
# -*- org-src-preserve-indentation: t # -*- org-src-preserve-indentation: t
@ -108,7 +109,8 @@ return '\n'.join(result)
#define QMCKL_ERRNO 102 #define QMCKL_ERRNO 102
#define QMCKL_INVALID_CONTEXT 103 #define QMCKL_INVALID_CONTEXT 103
#define QMCKL_ALLOCATION_FAILED 104 #define QMCKL_ALLOCATION_FAILED 104
#define QMCKL_INVALID_EXIT_CODE 105 #define QMCKL_DEALLOCATION_FAILED 105
#define QMCKL_INVALID_EXIT_CODE 106
#+end_src #+end_src
#+begin_src f90 :comments org :tangle (eval fh) :exports none #+begin_src f90 :comments org :tangle (eval fh) :exports none
@ -127,7 +129,8 @@ return '\n'.join(result)
integer, parameter :: QMCKL_ERRNO = 102 integer, parameter :: QMCKL_ERRNO = 102
integer, parameter :: QMCKL_INVALID_CONTEXT = 103 integer, parameter :: QMCKL_INVALID_CONTEXT = 103
integer, parameter :: QMCKL_ALLOCATION_FAILED = 104 integer, parameter :: QMCKL_ALLOCATION_FAILED = 104
integer, parameter :: QMCKL_INVALID_EXIT_CODE = 105 integer, parameter :: QMCKL_DEALLOCATION_FAILED = 105
integer, parameter :: QMCKL_INVALID_EXIT_CODE = 106
#+end_src #+end_src
:end: :end: