# **CSEE4824 Computer Architecture Project1**

Zhongheng Cheng (zc2737)

## 4-bit Combinational Priority Selector

### ps4-assign

To use "assign" for constructing ps4, assign every digit of gnt seperately.

```
project1 > source > ≡ ps4-assign.sv
       module ps4 (
            input
                           [3:0] req,
            input
                                 en,
            output logic [3:0] gnt
       );
            assign gnt[3] = en & req[3];
            assign gnt[2] = en \& req[2] \& \sim req[3];
  9
            assign gnt[1] = en \& req[1] \& \sim req[2] \& \sim req[3];
 10
            assign gnt[0] = en \& req[0] \& \sim req[1] \& \sim req[2] \& \sim req[3];
 11
 12
 13
 14
       endmodule
```

#### ps4-if\_else

To use "if\_else" for constructing ps4, assign every value by conditions inside "always\_comb".

```
project1 > source > ≡ ps4-if_else.sv
       module ps4 (
           input
                         [3:0] req,
           input
                               en,
           output logic [3:0] gnt
       );
           always_comb begin
               gnt = 4'b0000;
 10
               if (en) begin
                   if (req[3])
 11
 12
                        gnt = 4'b1000;
 13
                   else if (req[2] & ~req[3])
                        gnt = 4'b0100;
 14
                   else if (req[1] & ~req[2] & ~req[3])
 15
 16
                        gnt = 4'b0010;
                   else if (req[0] & ~req[1] & ~req[2] & ~req[3])
 17
                        gnt = 4'b0001;
 18
 19
               end
 20
           end
 21
 22
       endmodule
 23
```

## ps4\_testing

The testbench is passed for all cases.

```
Chronologic VCS simulator copyright 1991-2019
Contains Synopsys proprietary information.
Compiler version P-2019.06_Full64; Runtime version P-2019.06_Full64; Feb 6 13:20 2024
Time:
       0 reg:0000 en:1 gnt:0000
Time: 5 req:1000 en:1 gnt:1000
Time: 10 req:0100 en:1 gnt:0100
Time: 15 req:0010 en:1 gnt:0010
Time: 20 req:0001 en:1 gnt:0001
Time: 25 req:0101 en:1 gnt:0100
Time: 30 reg:0110 en:1 gnt:0100
Time: 35 req:1110 en:1 gnt:1000
Time: 40 reg:1111 en:1 gnt:1000
Time: 45 reg:1111 en:0 gnt:0000
Time: 50 req:0110 en:0 gnt:0000
aaa Passed
```

## **Hierarchical Priority Selectors**

#### ps8

To build a ps8, we can build a ps2 firstly.

```
module ps2 (
 2
                         [1:0] req,
 3
          input
          input
 4
                                en,
 5
          output logic [1:0] gnt,
 6
          output logic
                                req_up
 7
 8
 9
          assign req_up = |req;
          assign gnt[1] = en & req[1];
10
          assign gnt[0] = en \& req[0] \& \sim req[1];
11
12
      endmodule
13
```

Then use the ps2 to build a ps4, which is made of two ps2s.

```
module ps4 (
16
          input
                         [3:0] req,
17
18
          input
                               en,
19
          output logic [3:0] gnt,
          output logic
20
                               req_up
21
      );
22
23
          logic req_high;
          logic req_low;
24
25
26
          ps2 high(
               .req(req[3:2]),
27
28
               .en(en),
               .gnt(gnt[3:2]),
29
30
               .req_up(req_high)
31
           );
32
          ps2 low(
33
34
               . req(req[1:0]),
35
               .en(en & ~req_high),
               .gnt(gnt[1:0]),
36
37
               .req_up(req_low)
38
           );
39
40
          assign req_up = req_high | req_low;
```

Finally, use the ps4 to build a ps8, similiar to the previous step.

```
module ps8 (
46
47
          input
                         [7:0] req,
          input
48
                               en,
49
          output logic [7:0] gnt,
50
          output logic
                               req_up
51
52
      );
53
54
          logic req_high;
55
          logic req_low;
56
57
          ps4 high(
58
               .req(req[7:4]),
               .en(en),
59
60
               .gnt(gnt[7:4]),
61
               .req_up(req_high)
62
          );
63
          ps4 low(
64
65
               .req(req[3:0]),
               .en(en & ~req_high),
66
67
               .gnt(gnt[3:0]),
68
               . req_up(req_low)
69
          );
70
          assign req_up = req_high | req_low;
71
72
```



#### ps8\_testing

I selected some of the cases and wrote testcases for ps8. All the cases are passed.

```
Chronologic VCS simulator copyright 1991-2019
Contains Synopsys proprietary information.
Compiler version P-2019.06_Full64; Runtime version P-2019.06_Full64; Feb 6 13:06 2024
Time:
       0 req:00000000 en:1 gnt:00000000
Time: 5 req:10000000 en:1 gnt:10000000
Time: 10 req:01000000 en:1 gnt:01000000
Time: 15 req:00100000 en:1 gnt:00100000
Time: 20 reg:00010000 en:1 gnt:00010000
Time: 25 req:00001000 en:1 gnt:00001000
Time: 30 req:00000100 en:1 gnt:00000100
Time: 35 reg:00000010 en:1 gnt:00000010
Time: 40 req:00000001 en:1 gnt:00000001
Time: 45 reg:11010000 en:1 gnt:10000000
Time: 50 req:01101000 en:1 gnt:01000000
Time: 55 req:00110100 en:1 gnt:00100000
Time: 60 reg:00011010 en:1 gnt:00010000
Time: 65 req:00001101 en:1 gnt:00001000
Time: 70 req:11111110 en:1 gnt:10000000
Time: 75 req:11111111 en:1 gnt:10000000
Time: 80 req:11111111 en:0 gnt:00000000
Time: 85 req:00011010 en:0 gnt:00000000
aaa Passed
$finish called from file "ps8 test.sv", line 62.
$finish at simulation time
          V C S
                  Simulation Report
Time: 90
CPU Time:
              0.410 seconds; Data structure size:
                                                         0.0Mb
Tue Feb 6 13:06:18 2024
output saved to program.out
```

## **Hierarchical Rotating Priority Selectors**

#### rps4

To build a rps4, build a rps2 first.

```
2
      module rps2 (
 3
          input
                               sel,
          input
                        [1:0] req,
 5
          input
                               en,
 6
          output logic [1:0] gnt,
          output logic
 8
                               req_up
 9
      );
10
          always_comb begin
11
12
               req_up = |req;
13
              if (~en) gnt = 2'b00;
              else begin
14
15
                   gnt = req;
16
                   if (req == 2'b11)
                       gnt = (sel == 1) ? 2'b10 : 2'b01;
17
18
              end
19
          end
20
21
      endmodule
```

Then use three rps2 modules according to the model shown in the instructions.

```
always_ff @(posedge clock) begin
34
35
              if (reset) count <= 2'b00;
36
              else begin
37
                   if (count == 2'b11) count <= 2'b00;
38
                   else count <= count + 1'b1;
39
              end
40
          end
41
42
          logic [1:0] req_up_temp;
          logic [1:0] gnt_temp;
43
          logic req_up;
44
45
46
          rps2 left(
47
               .req(req[3:2]),
               .en(gnt_temp[1]),
48
49
               .sel(count[0]),
               .gnt(gnt[3:2]),
50
               .req_up(req_up_temp[1])
51
52
          );
53
54
          rps2 right(
               .req(req[1:0]),
55
56
               .en(gnt_temp[0]),
               .sel(count[0]),
57
               .gnt(gnt[1:0]),
58
               .req_up(req_up_temp[0])
59
60
          );
61
62
          rps2 top(
               .req(req_up_temp[1:0]),
63
               .en(en),
64
```

#### rps4\_testing

All tests are passed.

```
Chronologic VCS simulator copyright 1991-2019
Contains Synopsys proprietary information.
Compiler version P-2019.06_Full64; Runtime version P-2019.06_Full64; Feb 5 20:17 2024
Time:
       0 req:xxxx en:x gnt:xxxx, cnt:xx
Time:
       5 reg:xxxx en:x gnt:xxxx, cnt:00
      6 req:0001 en:1 gnt:0001, cnt:00
Time:
Time:
      15 reg:0001 en:1 gnt:0001, cnt:01
Time:
      16 reg:0010 en:1 gnt:0010, cnt:01
Time:
      25 reg:0010 en:1 gnt:0010, cnt:10
      26 req:0101 en:1 gnt:0100, cnt:10
Time:
Time:
      35 req:0101 en:1 gnt:0100, cnt:11
Time: 36 req:0011 en:1 gnt:0010, cnt:11
Time:
      45 reg:0011 en:1 gnt:0001, cnt:00
Time:
      46 req:1111 en:1 gnt:0001, cnt:00
      55 req:1111 en:1 gnt:0010, cnt:01
Time:
Time:
      65 reg:1111 en:1 gnt:0100, cnt:10
Time: 75 req:1111 en:1 gnt:1000, cnt:11
      85 req:1111 en:1 gnt:0001, cnt:00
Time:
      86 reg:1111 en:0 gnt:0000, cnt:00
Time:
      95 req:1111 en:0 gnt:0000, cnt:01
Time: 105 req:1111 en:0 gnt:0000, cnt:10
@@@ Passed
$finish called from file "rps4_test.sv", line 95.
$finish at simulation time
                                           106
          V C S
                  Simulation
                                        Report
Time: 106
CPU Time:
              0.430 seconds;
                              Data structure size:
                                                         0.0Mb
Mon Feb 5 20:17:05 2024
output saved to program.out
```