-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathverilog code.v
127 lines (103 loc) · 2.95 KB
/
verilog code.v
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
module arbiter (
clk,
rst,
req3,
req2,
req1,
req0,
gnt3,
gnt2,
gnt1,
gnt0
);
// PORT DECLARATION
input clk; //CLOCK
input rst; //RESET
input req3; //REQUEST SIGNALS
input req2;
input req1;
input req0;
output gnt3; //GRANT SIGNALS
output gnt2;
output gnt1;
output gnt0;
//INTERNAL REGISTERS
wire [1:0] gnt ;
wire comreq ;
wire beg ; // BEGIN SIGNAL
wire [1:0] lgnt ; // LATCHED ENCODED GRANT
wire lcomreq ; // BUS STATUS
reg lgnt0 ; // LATCHED GRANTS
reg lgnt1 ;
reg lgnt2 ;
reg lgnt3 ;
reg mask_enable ;
reg lmask0 ;
reg lmask1 ;
reg ledge ;
//--//
always @ (posedge clk)
if (rst) //if reset is true
begin
lgnt0 <= 0;
lgnt1 <= 0;
lgnt2 <= 0;
lgnt3 <= 0;
end
else
begin
lgnt0 <=(~lcomreq & ~lmask1 & ~lmask0 & ~req3 & ~req2 & ~req1 & req0)
| (~lcomreq & ~lmask1 & lmask0 & ~req3 & ~req2 & req0)
| (~lcomreq & lmask1 & ~lmask0 & ~req3 & req0)
| (~lcomreq & lmask1 & lmask0 & req0 )
| ( lcomreq & lgnt0 );
lgnt1 <=(~lcomreq & ~lmask1 & ~lmask0 & req1)
| (~lcomreq & ~lmask1 & lmask0 & ~req3 & ~req2 & req1 & ~req0)
| (~lcomreq & lmask1 & ~lmask0 & ~req3 & req1 & ~req0)
| (~lcomreq & lmask1 & lmask0 & req1 & ~req0)
| ( lcomreq & lgnt1);
lgnt2 <=(~lcomreq & ~lmask1 & ~lmask0 & req2 & ~req1)
| (~lcomreq & ~lmask1 & lmask0 & req2)
| (~lcomreq & lmask1 & ~lmask0 & ~req3 & req2 & ~req1 & ~req0)
| (~lcomreq & lmask1 & lmask0 & req2 & ~req1 & ~req0)
| ( lcomreq & lgnt2);
lgnt3 <=(~lcomreq & ~lmask1 & ~lmask0 & req3 & ~req2 & ~req1)
| (~lcomreq & ~lmask1 & lmask0 & req3 & ~req2)
| (~lcomreq & lmask1 & ~lmask0 & req3)
| (~lcomreq & lmask1 & lmask0 & req3 & ~req2 & ~req1 & ~req0)
| ( lcomreq & lgnt3);
end
//BEGIN SIGNAL
assign beg = (req3 | req2 | req1 | req0) & ~lcomreq;
// comreq logic (BUS STATUS)
assign lcomreq = ( req3 & lgnt3 )
| ( req2 & lgnt2 )
| ( req1 & lgnt1 )
| ( req0 & lgnt0 );
// Encoder logic
assign lgnt = {(lgnt3 | lgnt2),(lgnt3 | lgnt1)};
// lmask register.
always @ (posedge clk )
if( rst )
begin
lmask1 <= 0;
lmask0 <= 0;
end
else if(mask_enable)
begin
lmask1 <= lgnt[1];
lmask0 <= lgnt[0];
end
else
begin
lmask1 <= lmask1;
lmask0 <= lmask0;
end
assign comreq = lcomreq;
assign gnt = lgnt;
// Drive the outputs
assign gnt3 = lgnt3;
assign gnt2 = lgnt2;
assign gnt1 = lgnt1;
assign gnt0 = lgnt0;
endmodule