view ListOfArrays.c @ 14:70c43c8fbded

Renamed VMS to PR, in new branch
author Sean Halle <seanhalle@yahoo.com>
date Mon, 03 Sep 2012 15:05:31 -0700
parents 5df9392eca1a
children 7731a4d31baa
line source
2 #include "ListOfArrays.h"
3 #include "PR_impl/Services_Offered_by_PR/Memory_Handling/vmalloc.h"
5 ListOfArrays* makeListOfArrays(size_t entry_size, int num_entries_per_block){
6 ListOfArrays* newLoA = (ListOfArrays*) PR_int__malloc(sizeof(ListOfArrays));
7 newLoA->dim1info = makePrivDynArrayOfSize(&(newLoA->dim1),8);
9 newLoA->entry_size = entry_size;
10 newLoA->num_entries_per_fragment = num_entries_per_block;
11 newLoA->next_free_index = 0;
13 return newLoA;
14 }
16 void forAllInListOfArraysDo(ListOfArrays* list, ListOfArraysFnPtr fnPtr){
17 int n;
18 uintptr_t p;
19 int num_full = list->next_free_index / list->num_entries_per_fragment; //list->dim1info->numInArray -1
20 for(n=0;n<num_full; n++){
21 for(p = (uintptr_t) (list->dim1)[n]; p < (uintptr_t) (list->dim1)[n] + list->num_entries_per_fragment * list->entry_size; p += list->entry_size){
22 (*fnPtr)((void*)p);
23 }
24 }
25 int offset_in_last = list->next_free_index % list->num_entries_per_fragment;
26 n = list->dim1info->numInArray - 1;
27 if (n >= 0){
28 for(p = (uintptr_t)(list->dim1)[n]; p < (uintptr_t)(list->dim1)[n] + offset_in_last * list->entry_size; p += list->entry_size){
29 (*fnPtr)((void*)p);
30 }
31 }
32 }
34 void freeListOfArrays(ListOfArrays* list){
35 freeDynArrayDeep(list->dim1info,&PR_int__free);
36 PR_int__free((void*)list);
37 }
39 /*
40 void addToListOfArraysDependency(Dependency value, ListOfArrays* list){
41 int offset_in_fragment = list->next_free_index % list->num_entries_per_fragment;
42 if(offset_in_fragment == 0){
43 void* newBlock = PR_int__malloc(list->entry_size * list->num_entries_per_fragment);
44 addToDynArray(newBlock,list->dim1info);
45 }
46 Dependency* typedFragment = (Dependency*) ((list->dim1)[list->dim1info->numInArray -1]);
47 typedFragment[offset_in_fragment] = value;
48 list->next_free_index++;
49 }
51 void addToListOfArraysUnit(Unit value, ListOfArrays* list){
52 int offset_in_fragment = list->next_free_index % list->num_entries_per_fragment;
53 if(offset_in_fragment == 0){
54 void* newBlock = PR_int__malloc(list->entry_size * list->num_entries_per_fragment);
55 addToDynArray(newBlock,list->dim1info);
56 }
57 Unit* typedFragment = (Unit*) ((list->dim1)[list->dim1info->numInArray -1]);
58 typedFragment[offset_in_fragment] = value;
59 list->next_free_index++;
60 }
61 */