From 756053733bccc3804a97e1cfbe588153cf0b5fe5 Mon Sep 17 00:00:00 2001 From: bdemsky Date: Tue, 12 Oct 2010 00:23:59 +0000 Subject: [PATCH] towards getting the compiler to run --- .../src/IR/Flat/RuntimeConflictResolver.java | 4 +- Robust/src/Runtime/oooJava/WaitingQueue.c | 5 +- Robust/src/Runtime/oooJava/hashStructure.c | 107 +++++++++--------- Robust/src/Runtime/oooJava/hashStructure.h | 39 +++---- 4 files changed, 77 insertions(+), 78 deletions(-) diff --git a/Robust/src/IR/Flat/RuntimeConflictResolver.java b/Robust/src/IR/Flat/RuntimeConflictResolver.java index 6fe7598e..79c8aea6 100644 --- a/Robust/src/IR/Flat/RuntimeConflictResolver.java +++ b/Robust/src/IR/Flat/RuntimeConflictResolver.java @@ -299,10 +299,10 @@ public class RuntimeConflictResolver { private void createMasterHashTableArray() { headerFile.println("void createAndFillMasterHashStructureArray();"); cFile.println("void createAndFillMasterHashStructureArray() {\n" + - " createMasterHashTableArray("+weaklyConnectedHRCounter + ");"); + " rcr_createMasterHashTableArray("+weaklyConnectedHRCounter + ");"); for(int i = 0; i < weaklyConnectedHRCounter; i++) { - cFile.println(" allHashStructures["+i+"] = (HashStructure *) createhashTable("+num2WeaklyConnectedHRGroup.get(i).connectedHRs.size()+");}"); + cFile.println(" allHashStructures["+i+"] = (HashStructure *) rcr_createHashtable("+num2WeaklyConnectedHRGroup.get(i).connectedHRs.size()+");"); } cFile.println("}"); } diff --git a/Robust/src/Runtime/oooJava/WaitingQueue.c b/Robust/src/Runtime/oooJava/WaitingQueue.c index 61669238..e35ab772 100644 --- a/Robust/src/Runtime/oooJava/WaitingQueue.c +++ b/Robust/src/Runtime/oooJava/WaitingQueue.c @@ -2,6 +2,7 @@ #include #include #include "WaitingQueue.h" +#include "hashStructure.h" //TODO check that the right path is pointed to by the below #include #include "RuntimeConflictResolver.h" @@ -113,7 +114,7 @@ WaitingQueueBinVector * returnWaitingQueueBinVectorToFreePool(WaitingQueueBinVec WaitingQueueBinVector * ptrNext; do { freeHead = (WaitingQueueBinVector *) 0x1; - freeHead = LOCKXCHG(&freeBinVectors, freeHead); + freeHead = (WaitingQueueBinVector *) LOCKXCHG((unsigned INTPTR *)&freeBinVectors, (unsigned INTPTR) freeHead); } while (freeHead == (WaitingQueueBinVector *) 0x1); //free bins locked @@ -134,7 +135,7 @@ WaitingQueueBinVector * getUsableWaitingQueueBinVector() { WaitingQueueBinVector * ptr; do { ptr = (WaitingQueueBinVector *) 0x1; - ptr = LOCKXCHG(&freeBinVectors, ptr); + ptr = (WaitingQueueBinVector *) LOCKXCHG((unsigned INTPTR *) &freeBinVectors, (unsigned INTPTR) ptr); } while (ptr == (WaitingQueueBinVector *) 0x1); //free bins locked diff --git a/Robust/src/Runtime/oooJava/hashStructure.c b/Robust/src/Runtime/oooJava/hashStructure.c index 066c03a5..dbf9838d 100644 --- a/Robust/src/Runtime/oooJava/hashStructure.c +++ b/Robust/src/Runtime/oooJava/hashStructure.c @@ -1,23 +1,17 @@ #include "hashStructure.h" #include "WaitingQueue.h" #include "mlp_lock.h" -#include "tm.h" +#include "mem.h" //NOTE: this is only temporary (for testing) and will be removed in favor of thread local variables //It's basically an array of hashStructures so we can simulate what would happen in a many-threaded version HashStructure ** allHashStructures; //NOTE: only temporary -void createMasterHashTableArray(int maxSize){ - int i; - allHashTables = (HashTable**) malloc(sizeof(Hashtable) * maxSize); - - for(i = 0; i < maxSize; i++) { - allHashTables[i] = createHashtable(); - } +void rcr_createMasterHashTableArray(int maxSize){ } -HashStructure* createHashtable(int sizeofWaitingQueue){ +HashStructure* rcr_createHashtable(int sizeofWaitingQueue){ int i=0; HashStructure* newTable=(HashStructure*)RUNMALLOC(sizeof(HashStructure)); for(i=0;iitem.type=WRITEBIN; return binitem; } -ReadBinItem_rcr* createReadBinItem(){ +ReadBinItem_rcr* rcr_createReadBinItem(){ ReadBinItem_rcr* binitem=(ReadBinItem_rcr*)RUNMALLOC(sizeof(ReadBinItem_rcr)); - binitem->tail_Index=0; - binitem->head_Index=0; + binitem->index=0; binitem->item.type=READBIN; return binitem; } -int isReadBinItem(BinItem_rcr* b){ +int rcr_isReadBinItem(BinItem_rcr* b){ return b->type==READBIN; } -int isWriteBinItem(BinItem_rcr* b){ +int rcr_isWriteBinItem(BinItem_rcr* b){ return b->type==WRITEBIN; } -inline int generateKey(void * ptr){ +inline int rcr_generateKey(void * ptr){ return (((struct genericObjectStruct *) ptr)->oid)&H_MASK; } //TODO handle logic for waiting Queues separately //TODO pass in task to traverser -int ADDTABLEITEM(HashStructure* table, void * ptr, int type, int traverserID, SESEcommon *task, void * heaproot){ +int rcr_ADDTABLEITEM(HashStructure* table, void * ptr, int type, int traverserID, SESEcommon *task, void * heaproot){ BinItem_rcr * val; - int key=generateKey(ptr); + int key=rcr_generateKey(ptr); //LOCK is still needed as different threads will remove items... do { val=(BinItem_rcr *)0x1; - val=(BinItem_rcr *)LOCKXCHG((unsigned INTPTR*)&(table->array[key]->bin->head), (unsigned INTPTR)val); + val=(BinItem_rcr *)LOCKXCHG((unsigned INTPTR*)&(table->array[key].head), (unsigned INTPTR)val); } while(val==(BinItem_rcr*)0x1); if (val==NULL) { - return EMPTYBINCASE(table, table->array[key], ptr, type, traverserID, task, heaproot); + return rcr_EMPTYBINCASE(table, &table->array[key], ptr, type, traverserID, task, heaproot); } else { //else create item if (type == WRITEEFFECT) { - return WRITEBINCASE(table, ptr, val, key, traverserID, task, heaproot); + return rcr_WRITEBINCASE(table, val, ptr, key, traverserID, task, heaproot); } else if (type == READEFFECT) { - return READBINCASE(table, ptr, val, key, traverserID, task, heaproot); + return rcr_READBINCASE(table, val, ptr, key, traverserID, task, heaproot); } } } -int EMPTYBINCASE(HashStructure *T, BinElement_rcr* be, void *ptr, int type, int traverserId, SESEcommon * task, void *heaproot){ +int rcr_EMPTYBINCASE(HashStructure *T, BinElement_rcr* be, void *ptr, int type, int traverserId, SESEcommon * task, void *heaproot){ BinItem_rcr* b; TraverserData * td; //TODO: NEED PARENT CHECK HERE!!!!!!!!! if (type == WRITEEFFECT) { - b=(BinItem_rcr*)createWriteBinItem(); + b=(BinItem_rcr*)rcr_createWriteBinItem(); td = &((WriteBinItem_rcr*)b)->val; } else if (type == READEFFECT) { - b=(BinItem_rcr*)createReadBinItem(); + b=(BinItem_rcr*)rcr_createReadBinItem(); ReadBinItem_rcr* readbin=(ReadBinItem_rcr*)b; - td = &(readbin->array[readbin->tail_Index++]); + td = &(readbin->array[readbin->index++]); } b->total=1; b->type= type; @@ -113,12 +106,12 @@ int EMPTYBINCASE(HashStructure *T, BinElement_rcr* be, void *ptr, int type, int } -int WRITEBINCASE(HashStructure *T, void *ptr, BinItem * val, int key, int traverserID, SESEcommon *task, void *heaproot) { +int rcr_WRITEBINCASE(HashStructure *T, BinItem_rcr *val, void *ptr, int key, int traverserID, SESEcommon *task, void *heaproot) { //chain of bins exists => tail is valid //if there is something in front of us, then we are not ready int status=NOTREADY; BinElement_rcr* be= &(T->array[key]); //do not grab head from here since it's locked (i.e. = 0x1) - BinItem *bintail=be->tail; + BinItem_rcr *bintail=be->tail; if (bintail->type == WRITEBIN) { TraverserData * td = &(((WriteBinItem_rcr *)bintail)->val); @@ -135,13 +128,13 @@ int WRITEBINCASE(HashStructure *T, void *ptr, BinItem * val, int key, int traver } } - WriteBinItem_rcr *b=createWriteBinItem(); + WriteBinItem_rcr *b=rcr_createWriteBinItem(); TraverserData * td = &b->val; b->item.total=1; //fillout traverserData //Note: this list could be smaller in the future, for now I'm just including all the info I may need. - td->binitem = b; + td->binitem = (BinItem_rcr*)b; td->hashtable=T; td->resumePtr = ptr; td->task= task; @@ -156,7 +149,7 @@ int WRITEBINCASE(HashStructure *T, void *ptr, BinItem * val, int key, int traver return status; } -int READBINCASE(HashStructure *T, void *ptr, BinItem *val, int key, int traverserID, SESEcommon * task, void *heaproot) { +int rcr_READBINCASE(HashStructure *T, BinItem_rcr *val, void *ptr, int key, int traverserID, SESEcommon * task, void *heaproot) { BinElement_rcr * be = &(T->array[key]); BinItem_rcr * bintail=be->tail; //check if already added item or not. @@ -177,15 +170,15 @@ int READBINCASE(HashStructure *T, void *ptr, BinItem *val, int key, int traverse } if (isReadBinItem(bintail)) { - return TAILREADCASE(T, ptr, val, bintail, key, traverserID, task, heaproot); + return rcr_TAILREADCASE(T, ptr, val, bintail, key, traverserID, task, heaproot); } else if (!isReadBinItem(bintail)) { - TAILWRITECASE(T, ptr, val, bintail, key, traverserID, task, heaproot); + rcr_TAILWRITECASE(T, ptr, val, bintail, key, traverserID, task, heaproot); return NOTREADY; } } -int TAILREADCASE(HashStructure *T, void * ptr, BinItem *val, BinItem_rcr *bintail, int key, int traverserID, SESEcommon * task, void *heaproot) { +int rcr_TAILREADCASE(HashStructure *T, void * ptr, BinItem_rcr *val, BinItem_rcr *bintail, int key, int traverserID, SESEcommon * task, void *heaproot) { ReadBinItem_rcr * readbintail=(ReadBinItem_rcr*)T->array[key].tail; int status, retval; TraverserData *td; @@ -197,16 +190,16 @@ int TAILREADCASE(HashStructure *T, void * ptr, BinItem *val, BinItem_rcr *bintai retval=NOTREADY; } - if (readbintail->tail_Index==NUMREAD) { // create new read group - ReadBinItem_rcr* rb=createReadBinItem(); - td = &rb->array[rb->tail_Index++]; + if (readbintail->index==NUMREAD) { // create new read group + ReadBinItem_rcr* rb=rcr_createReadBinItem(); + td = &rb->array[rb->index++]; rb->item.total=1; rb->item.status=status; T->array[key].tail->next=(BinItem_rcr*)rb; T->array[key].tail=(BinItem_rcr*)rb; } else { // group into old tail - td = &readbintail->array[readbintail->tail_Index++]; + td = &readbintail->array[readbintail->index++]; atomic_inc(&readbintail->item.total); //printf("grouping with %d\n",readbintail->index); } @@ -218,17 +211,17 @@ int TAILREADCASE(HashStructure *T, void * ptr, BinItem *val, BinItem_rcr *bintai td->traverserID = traverserID; td->heaproot = heaproot; - T->array[key]->head=val;//released lock + T->array[key].head=val;//released lock return retval; } -void TAILWRITECASE(HashStructure *T, void *ptr, BinItem *val, BinItem_rcr *bintail, int key, int traverserID, SESEcommon * task, void *heaproot) { - ReadBinItem_rcr* rb=createReadBinItem(); - TraverserData * td = &(rb->array[rb->tail_Index++]); +void rcr_TAILWRITECASE(HashStructure *T, void *ptr, BinItem_rcr *val, BinItem_rcr *bintail, int key, int traverserID, SESEcommon * task, void *heaproot) { + ReadBinItem_rcr* rb=rcr_createReadBinItem(); + TraverserData * td = &(rb->array[rb->index++]); rb->item.total=1; rb->item.status=NOTREADY; - td->binitem = rb; + td->binitem = (BinItem_rcr *) rb; td->hashtable=T; td->resumePtr = ptr; td->task= task; @@ -237,36 +230,37 @@ void TAILWRITECASE(HashStructure *T, void *ptr, BinItem *val, BinItem_rcr *binta T->array[key].tail->next=(BinItem_rcr*)rb; T->array[key].tail=(BinItem_rcr*)rb; - T->array[key]->head=val;//released lock + T->array[key].head=val;//released lock } //TODO write deletion/removal methods +/* RETIREHASHTABLE(MemoryQueue *q, REntry *r) { Hashtable *T=r->hashtable; - BinItem *b=r->binitem; + BinItem_rcr *b=r->binitem; RETIREBIN(T,r,b); } -RETIREBIN(Hashtable *T, REntry *r, BinItem *b) { +RETIREBIN(Hashtable *T, REntry *r, BinItem_rcr *b) { int key=generateKey( OBJPTRPTR_2_OBJOID( r->pointer ) ); if(isFineRead(r)) { atomic_dec(&b->total); } if (isFineWrite(r) || (isFineRead(r) && b->next!=NULL && b->total==0)) { // CHECK FIRST IF next is nonnull to guarantee that b.total cannot change - BinItem * val; + BinItem_rcr * val; do { - val=(BinItem*)0x1; - val=(BinItem*)LOCKXCHG((unsigned INTPTR*)&(T->array[key]->head), (unsigned INTPTR)val); - } while(val==(BinItem*)0x1); + val=(BinItem_rcr*)0x1; + val=(BinItem_rcr*)LOCKXCHG((unsigned INTPTR*)&(T->array[key]->head), (unsigned INTPTR)val); + } while(val==(BinItem_rcr*)0x1); // at this point have locked bin - BinItem *ptr=val; + BinItem_rcr *ptr=val; int haveread=FALSE; int i; while (ptr!=NULL) { if (isReadBinItem(ptr)) { - ReadBinItem* rptr=(ReadBinItem*)ptr; + ReadBinItem_rcr* rptr=(ReadBinItem_rcr*)ptr; if (rptr->item.status==NOTREADY) { for (i=0;iindex;i++) { resolveDependencies(rptr->array[i]); @@ -283,16 +277,16 @@ RETIREBIN(Hashtable *T, REntry *r, BinItem *b) { } if (rptr->item.total!=0) { haveread=TRUE; - } else if ((BinItem*)rptr==val) { + } else if ((BinItem_rcr*)rptr==val) { val=val->next; } } else if(isWriteBinItem(ptr)) { if (haveread) break; if(ptr->status==NOTREADY){ - resolveDependencies(((WriteBinItem*)ptr)->val); + resolveDependencies(((WriteBinItem_rcr*)ptr)->val); ptr->status=READY; - if(isParent(((WriteBinItem*)ptr)->val)){ + if(isParent(((WriteBinItem_rcr*)ptr)->val)){ atomic_dec(&T->item.total); val=val->next; }else @@ -306,7 +300,9 @@ RETIREBIN(Hashtable *T, REntry *r, BinItem *b) { T->array[key]->head=val; // release lock } } +*/ +/* //Int will return success/fail. -1 indicates error (i.e. there's nothing there). //0 = nothing removed, >0 something was removed int REMOVETABLEITEM(HashStructure* table, void * ptr, int traverserID, SESEcommon *task, void * heaproot) { @@ -379,3 +375,4 @@ int REMOVETABLEITEM(HashStructure* table, void * ptr, int traverserID, SESEcommo return -1; } +*/ diff --git a/Robust/src/Runtime/oooJava/hashStructure.h b/Robust/src/Runtime/oooJava/hashStructure.h index 83ac6c6f..9eb37ee3 100644 --- a/Robust/src/Runtime/oooJava/hashStructure.h +++ b/Robust/src/Runtime/oooJava/hashStructure.h @@ -4,15 +4,15 @@ #include "mlp_runtime.h" #include "WaitingQueue.h" -#define ITEM_NOT_AT_FRONT_OF_WAITINGQ = 3; -#define TRAVERSER_FINISHED = 2; +#define ITEM_NOT_AT_FRONT_OF_WAITINGQ 3 +#define TRAVERSER_FINISHED 2 //Note READEFFECT = READBIN and WRITEEFFECT=WRITEBIN. They mean the same thing //but are named differently for clarity in code. #define READEFFECT 0 #define WRITEEFFECT 1 -#define WAITINGQUEUENOTE 2; +#define WAITINGQUEUENOTE 2 #define READBIN 0 #define WRITEBIN 1 @@ -91,8 +91,7 @@ typedef struct ReadBinItem_rcr { BinItem_rcr item; TraverserData array[NUMREAD]; //We don't need a head index since if the item before it was freed, then all these would be considered ready as well. - int tail_Index; - int head_Index; + int index; } ReadBinItem_rcr; typedef struct WQNote_rcr { @@ -100,22 +99,24 @@ typedef struct WQNote_rcr { int allocSiteID; } WaitingQueueNote; -void createMasterHashTableArray(int maxSize); //temporary -HashStructure* createHashtable(int sizeofWaitingQueue); -WriteBinItem_rcr* createWriteBinItem(); -ReadBinItem_rcr* createReadBinItem(); -int isReadBinItem(BinItem_rcr* b); -int isWriteBinItem(BinItem_rcr* b); -inline int generateKey(void * ptr); +extern HashStructure ** allHashStructures; + +void rcr_createMasterHashTableArray(int maxSize); //temporary +HashStructure* rcr_createHashtable(int sizeofWaitingQueue); +WriteBinItem_rcr* rcr_createWriteBinItem(); +ReadBinItem_rcr* rcr_createReadBinItem(); +int rcr_isReadBinItem(BinItem_rcr* b); +int rcr_isWriteBinItem(BinItem_rcr* b); +inline int rcr_generateKey(void * ptr); //Method signatures are not in their final form since I have still not decided what is the optimum amount of data //to store in each entry. -int ADDTABLEITEM(HashStructure* table, void * ptr, int type, int traverserID, SESEcommon *task, void * heaproot); -int EMPTYBINCASE(HashStructure *T, BinElement_rcr* be, void *ptr, int type, int traverserId, SESEcommon * task, void *heaproot); -int WRITEBINCASE(HashStructure *T, void *ptr, int key, int traverserID, SESEcommon *task, void *heaproot); -int READBINCASE(HashStructure *T, void *ptr, int key, int traverserID, SESEcommon * task, void *heaproot); -int TAILREADCASE(HashStructure *T, void * ptr, BinItem_rcr *bintail, int key, int traverserID, SESEcommon * task, void *heaproot); -void TAILWRITECASE(HashStructure *T, void *ptr, BinItem_rcr *bintail, int key, int traverserID, SESEcommon * task, void *heaproot); -int REMOVETABLEITEM(HashStructure* table, void * ptr, int traverserID, SESEcommon *task, void * heaproot); +int rcr_ADDTABLEITEM(HashStructure* table, void * ptr, int type, int traverserID, SESEcommon *task, void * heaproot); +int rcr_EMPTYBINCASE(HashStructure *T, BinElement_rcr* be, void *ptr, int type, int traverserId, SESEcommon * task, void *heaproot); +int rcr_WRITEBINCASE(HashStructure *T, BinItem_rcr *val, void *ptr, int key, int traverserID, SESEcommon *task, void *heaproot); +int rcr_READBINCASE(HashStructure *T, BinItem_rcr *val, void *ptr, int key, int traverserID, SESEcommon * task, void *heaproot); +int rcr_TAILREADCASE(HashStructure *T, void * ptr, BinItem_rcr *val, BinItem_rcr *bintail, int key, int traverserID, SESEcommon * task, void *heaproot); +void rcr_TAILWRITECASE(HashStructure *T, void *ptr, BinItem_rcr *val, BinItem_rcr *bintail, int key, int traverserID, SESEcommon * task, void *heaproot); +int rcr_REMOVETABLEITEM(HashStructure* table, void * ptr, int traverserID, SESEcommon *task, void * heaproot); #endif -- 2.34.1