# Electronics Club

## Task-4

Chirag Hegde

#### Design.v:

```
module transmissionBlock(
input clk,
input data, start,
output reg [95:0] fec,
output reg done,
output reg [6:0] cycleCounter
);
  reg [5:0] count=0;
  reg [3:0] shift;
  reg [15:0] r, temp;
  always @(posedge clk, posedge start) begin
    cycleCounter=cycleCounter+1;
    if(start) begin
      done=0;
      r=16'hFFFF;
      fec=96'd0;
      count=49;
      cycleCounter=-1;
      shift=4'b0000;
    end
    else if(count>17) begin
      //CRC
      r[15] <= r[14]+r[15]+data;
      r[14:3] <= r[13:2];
      r[2] <= r[1] + data + r[15];
      r[1] <= r[0];
      r[0] <= data+r[15];
      //FEC
      shift[3:1] <= shift[2:0];</pre>
      shift[0]<=data;</pre>
      fec[0] <= shift[0]+shift[1]+shift[2]+shift[3];</pre>
      fec[1] <= shift[0]+shift[2]+shift[3];</pre>
      fec[95:2]<=fec[93:0];
      count<=count-1;</pre>
```

```
else if (count<=17 && count!=0) begin
      temp=r[15];
      shift[3:1] <= shift[2:0];</pre>
      shift[0]<=temp;</pre>
      fec[0] <= shift[0]+shift[1]+shift[2]+shift[3];</pre>
      fec[1] <= shift[0]+shift[2]+shift[3];</pre>
      fec[95:2]<=fec[93:0];
      r[15:1]<=r[14:0];
      count<=count-1;</pre>
      if(count==1) begin
      done<=1;</pre>
      end
    end
  end
endmodule
module interleavingModule(
  input [95:0] fec,
  output [95:0] int fec
);
       fourByteInterleaver T1(fec[31:0],int fec[31:0]);
       fourByteInterleaver T2(fec[63:32],int fec[63:32]);
       fourByteInterleaver T3(fec[95:64],int fec[95:64]);
endmodule
module fourByteInterleaver(
  input [31:0] inFourBytes,
  output [31:0] outFourBytes
);
  wire [7:0] byte0;
  wire [7:0] byte1;
  wire [7:0] byte2;
  wire [7:0] byte3;
  wire [7:0] out0;
  wire [7:0] out1;
  wire [7:0] out2;
  wire [7:0] out3;
  assign byte0 = inFourBytes[7:0];
  assign byte1 = inFourBytes[15:8];
  assign byte2 = inFourBytes[23:16];
  assign byte3 = inFourBytes[31:24];
  assign out3 = {byte0[1:0],byte1[1:0],byte2[1:0],byte3[1:0]};
  assign out2 = {byte0[3:2],byte1[3:2],byte2[3:2],byte3[3:2]};
  assign out1 = {byte0[5:4],byte1[5:4],byte2[5:4],byte3[5:4]};
  assign out0 = {byte0[7:6],byte1[7:6],byte2[7:6],byte3[7:6]};
  assign outFourBytes = {out3,out2,out1,out0};
```

#### Testbench.v:

```
module t_transmissionBlock;
  reg clk;
  reg data, start;
 wire [95:0] fec;
  wire [95:0] interleaved fec;
 wire done;
  wire [6:0] cycleCounter;
  wire count;
  reg [31:0] input data = 32'h03 01 02 03;
  integer k;
  initial forever #5 clk = ~clk;
 transmissionBlock M1
(.clk(clk),.data(data),.start(start),.fec(fec),.done(done),.cycleCounter(cycleCounter)
ter));
  interleavingModule M2(.fec(fec),.int_fec(interleaved_fec));
  initial begin
    clk=0;
    start=0;
    #1;
    start=1;
    #4 start=0;
    //#10;
    data=input_data[31];
    for(k=0; k<32; k=k+1)
      begin
        #10;
        input_data = input_data<<1;</pre>
        data=input data[31];
      end
    end
  initial begin
    @(posedge done) begin
      #10 $finish;
    end
  end
```

```
initial begin
     $monitor("%h %h %d",fec,interleaved_fec,cycleCounter);
  end
endmodule
```

### Waveforms:



```
Transcript =
  UUUUUUUJa3UUQIU3/CU3aUa3 CUUUUUUUI33U1232CCU3a3a1
# 0000000e8c037c0df00e828c 80c000004cf3301228cc03a3
                                                      40
# 0000003a300df037c03a0a30 8080c000c44cf3302828cc03
                                                      41
# 000000e8c037c0df00e828c0 008080c0ccc44cf3002828cc
                                                      42
# 000003a300df037c03a0a303 f00080803cccc44cf3002828
                                                      43
# 00000e8c037c0df00e828c0e 20f00080133cccc48af30028
                                                      44
# 00003a300df037c03a0a3039 2020f00031133ccc4a8af300
                                                      45
# 0000e8c037c0df00e828c0e5 002020f03331133c404a8af3
                                                      46
# 0003a300df037c03a0a30397 3c002020cf3333113fc404a8a
                                                      47
# 000e8c037c0df00e828c0e5e c83c002084cf33331a2fc404a
 ** Note: $finish : C:/Modeltech_pe_edu_10.4a/examples/t_final.v(44)
#
     Time: 495 ns Iteration: 0 Instance: /t transmissionBlock
```