-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathEntry.java
More file actions
executable file
·67 lines (63 loc) · 1.81 KB
/
Entry.java
File metadata and controls
executable file
·67 lines (63 loc) · 1.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
public class Entry{
private final int NUM_THREAD;
private Semaphore[] sem; /* private semaphores */
private boolean free; /* state of the entry */
//QUEUE OF BLOCKED THREAD HANDLING:
private int[] blocked;
private int front;
private int rear;
private int waiting; /* number of waiting clients for the entry */
//REDENZVOUS:
private Semaphore server_sync; /* implements the redenz-vous barrier between client and server */
private Semaphore client_sync; /* implements the redenz-vous barrier between client and server */
private Semaphore entryRet; /* synchronization semaphore to notify the server the call of an entryRet */
public Entry(int n){
NUM_THREAD = n;
sem = new Semaphore[NUM_THREAD];
blocked = new int[NUM_THREAD];
front = 0;
rear = 0;
waiting = 0;
free = true;
for (int i = 0; i < NUM_THREAD; i++)
sem[i] = new Semaphore(0);
server_sync = new Semaphore(0);
client_sync = new Semaphore(0);
entryRet = new Semaphore(0);
}
public void entryCall() throws InterruptedException{
int id = ((Client)Thread.currentThread()).getMyId();
synchronized(this){
if (free){
free = false;
sem[id].V();
}
else{
blocked[rear] = id;
rear = (rear + 1)%NUM_THREAD;
waiting++;
}
}/* avoid nested monitor calls */
sem[id].P();/* blocking operation only if free initially false */
client_sync.V();
server_sync.P();
}
public void accept() throws InterruptedException{
server_sync.V();
client_sync.P();
entryRet.P();
synchronized(this){
if (waiting > 0){
int id = blocked[front];
front = (front + 1)%NUM_THREAD;
free = false;
waiting--;
sem[id].V();
}
}
}
public synchronized void entryRet() throws InterruptedException{
free = true;
entryRet.V();
}
}