head 1.2; access; symbols rel_00_01_alpha:1.1.1.1 start:1.1.1.1 avendor:1.1.1; locks; strict; comment @# @; 1.2 date 2004.12.18.14.38.05; author sfielding; state dead; branches; next 1.1; 1.1 date 2004.10.11.04.00.08; author sfielding; state Exp; branches 1.1.1.1; next ; 1.1.1.1 date 2004.10.11.04.00.08; author sfielding; state Exp; branches; next ; desc @@ 1.2 log @Removed html documentation @ text @ writeUSBWireData.v
//////////////////////////////////////////////////////////////////////
////                                                              ////
//// writeUSBWireData.v                                           ////
////                                                              ////
//// This file is part of the usbhostslave opencores effort.
//// <http://www.opencores.org/cores//>                           ////
////                                                              ////
//// Module Description:                                          ////
//// 
////                                                              ////
//// To Do:                                                       ////
//// 
////                                                              ////
//// Author(s):                                                   ////
//// - Steve Fielding, sfielding@@base2designs.com                 ////
////                                                              ////
//////////////////////////////////////////////////////////////////////
////                                                              ////
//// Copyright (C) 2004 Steve Fielding and OPENCORES.ORG          ////
////                                                              ////
//// This source file may be used and distributed without         ////
//// restriction provided that this copyright statement is not    ////
//// removed from the file and that any derivative work contains  ////
//// the original copyright notice and the associated disclaimer. ////
////                                                              ////
//// This source file is free software; you can redistribute it   ////
//// and/or modify it under the terms of the GNU Lesser General   ////
//// Public License as published by the Free Software Foundation; ////
//// either version 2.1 of the License, or (at your option) any   ////
//// later version.                                               ////
////                                                              ////
//// This source is distributed in the hope that it will be       ////
//// useful, but WITHOUT ANY WARRANTY; without even the implied   ////
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      ////
//// PURPOSE. See the GNU Lesser General Public License for more  ////
//// details.                                                     ////
////                                                              ////
//// You should have received a copy of the GNU Lesser General    ////
//// Public License along with this source; if not, download it   ////
//// from <http://www.opencores.org/lgpl.shtml>                   ////
////                                                              ////
//////////////////////////////////////////////////////////////////////
//
// $Id: index.htm,v 1.1 2004/10/11 04:00:08 sfielding Exp $
//
// CVS Revision History
//
// $Log: index.htm,v $
// Revision 1.1  2004/10/11 04:00:08  sfielding
// Initial revision
//
//

`timescale 1ns / 1ps
`include "usbSerialInterfaceEngine_h.v"

`define BUFFER_FULL  3'b100

module writeUSBWireData (
  TxBitsIn, 
  TxBitsOut,
  TxDataOutTick,
  TxCtrlIn, 
  TxCtrlOut, 
  USBWireRdy,
  USBWireWEn, 
  disableWireReadOut, 
  fullSpeedRate, 
  clk, 
  rst,
  noActivityTimeOut );
  
input   [1:0] TxBitsIn;
input   TxCtrlIn;
input   USBWireWEn;
input   clk;
input   fullSpeedRate;
input   rst;
output  [1:0] TxBitsOut;
output TxDataOutTick;
output  TxCtrlOut;
output  USBWireRdy;
output  disableWireReadOut;
output noActivityTimeOut;

wire    [1:0] TxBitsIn;
reg     [1:0] TxBitsOut;
reg     TxDataOutTick;
wire    TxCtrlIn;
reg     TxCtrlOut;
reg     USBWireRdy;
wire    USBWireWEn;
wire    clk;
wire    fullSpeedRate;
wire    rst;
reg  disableWireReadOut;
reg noActivityTimeOut;

// local registers
reg  [2:0]buffer0;
reg  [2:0]buffer1;
reg  [2:0]buffer2;
reg  [2:0]buffer3;
reg  [2:0]bufferCnt;
reg  [1:0]bufferInIndex;
reg  [1:0]bufferOutIndex;
reg decBufferCnt;
reg  [4:0]i;
reg incBufferCnt;
reg fullSpeedTick;
reg lowSpeedTick;
reg [15:0] timeOutCnt;

// buffer in state machine state codes:
`define WAIT_BUFFER_NOT_FULL 2'b00
`define WAIT_WRITE_REQ 2'b01
`define CLR_INC_BUFFER_CNT 2'b10

// buffer output state machine state codes:
`define WAIT_BUFFER_FULL 2'b00
`define WAIT_LINE_WRITE 2'b01
`define LINE_WRITE 2'b10

reg [1:0] bufferInStMachCurrState;
reg [1:0] bufferOutStMachCurrState;

// buffer control
always @@(posedge clk)
begin
  if (rst == 1'b1)
  begin
    bufferCnt <= 3'b000;
  end
  else
  begin
    if (incBufferCnt == 1'b1 && decBufferCnt == 1'b0)
      bufferCnt <= bufferCnt + 1'b1;
    else if (incBufferCnt == 1'b0 && decBufferCnt == 1'b1)
      bufferCnt <= bufferCnt - 1'b1;
  end
end


//buffer input state machine 
always @@(posedge clk) begin
  if (rst == 1'b1) begin
    incBufferCnt <= 1'b0;
   bufferInIndex <= 2'b00;
   buffer0 <= 3'b000;
   buffer1 <= 3'b000;
   buffer2 <= 3'b000;
   buffer3 <= 3'b000;
   USBWireRdy <= 1'b0;
   bufferInStMachCurrState <= `WAIT_BUFFER_NOT_FULL;
  end
  else begin
    case (bufferInStMachCurrState)
     `WAIT_BUFFER_NOT_FULL:
     begin
       if (bufferCnt != `BUFFER_FULL) 
       begin
        bufferInStMachCurrState <= `WAIT_WRITE_REQ;
        USBWireRdy <= 1'b1;
       end
     end
     `WAIT_WRITE_REQ:
     begin
       if (USBWireWEn == 1'b1)
       begin
        incBufferCnt <= 1'b1;
        USBWireRdy <= 1'b0;
        bufferInIndex <= bufferInIndex + 1'b1;
        case (bufferInIndex)
          2'b00 : buffer0 <= {TxBitsIn, TxCtrlIn};
          2'b01 : buffer1 <= {TxBitsIn, TxCtrlIn};
          2'b10 : buffer2 <= {TxBitsIn, TxCtrlIn};
          2'b11 : buffer3 <= {TxBitsIn, TxCtrlIn};
        endcase
        bufferInStMachCurrState <= `CLR_INC_BUFFER_CNT;
       end
     end
     `CLR_INC_BUFFER_CNT:
     begin
       incBufferCnt <= 1'b0;
       if (bufferCnt != (`BUFFER_FULL - 1'b1) ) 
       begin
        bufferInStMachCurrState <= `WAIT_WRITE_REQ;
        USBWireRdy <= 1'b1;
       end
        else begin
         bufferInStMachCurrState <= `WAIT_BUFFER_NOT_FULL;
        end
     end
    endcase
  end
end
      
//increment counter used to generate USB bit rate
always @@(posedge clk) begin
  if (rst == 1'b1)
  begin
    i <= 5'b00000;
    fullSpeedTick <= 1'b0;
    lowSpeedTick <= 1'b0;
  end
  else
  begin
    i <= i + 1'b1;
    if (i[1:0] == 2'b00)
      fullSpeedTick <= 1'b1;
    else
      fullSpeedTick <= 1'b0; 
    if (i == 5'b00000)
      lowSpeedTick <= 1'b1;
    else
      lowSpeedTick <= 1'b0;
  end
end

//buffer output state machine
//After reset, waits for the output buffer to become full.
//Once the buffer is full then it is constantly emptied at either
//the full or low speed rate with no under run protection
always @@(posedge clk) begin
  if (rst == 1'b1)
  begin
   bufferOutIndex <= 2'b00;
   decBufferCnt <= 1'b0;
   TxBitsOut <= 2'b00;
   TxCtrlOut <= `TRI_STATE;
    TxDataOutTick <= 1'b0;
   bufferOutStMachCurrState <= `WAIT_BUFFER_FULL;
  end
  else
  begin
    case (bufferOutStMachCurrState)
     `WAIT_BUFFER_FULL:
     begin
       if (bufferCnt == `BUFFER_FULL)
        bufferOutStMachCurrState <= `WAIT_LINE_WRITE;
     end
     `WAIT_LINE_WRITE:
     begin
       if ((fullSpeedRate == 1'b1 && fullSpeedTick == 1'b1) || (fullSpeedRate == 1'b0 && lowSpeedTick == 1'b1) )
       begin
          TxDataOutTick <= !TxDataOutTick;
        bufferOutStMachCurrState <= `LINE_WRITE;
        decBufferCnt <= 1'b1;
        bufferOutIndex <= bufferOutIndex + 1'b1;
        case (bufferOutIndex)
          2'b00 :
        begin 
          TxBitsOut <= buffer0[2:1];
          TxCtrlOut <= buffer0[0];
        end
        2'b01 : 
        begin
          TxBitsOut <= buffer1[2:1];
          TxCtrlOut <= buffer1[0];
        end
        2'b10 : 
        begin 
          TxBitsOut <= buffer2[2:1];
          TxCtrlOut <= buffer2[0];
        end
        2'b11 : 
        begin
          TxBitsOut <= buffer3[2:1];
          TxCtrlOut <= buffer3[0];
        end
        endcase
       end
     end
     `LINE_WRITE:
     begin
       decBufferCnt <= 1'b0;
       bufferOutStMachCurrState <= `WAIT_LINE_WRITE;
     end
    endcase
  end
end

// control 'disableWireReadOut' 
always @@(TxCtrlOut)
begin 
  if (TxCtrlOut == `DRIVE)
   disableWireReadOut <= 1'b1;
  else
   disableWireReadOut <= 1'b0;
end

//generate time out flag if no tx activity for (RX_PACKET_TOUT * OVER_SAMPLE_RATE) ticks
always @@(posedge clk) begin
  if (rst) begin
    timeOutCnt <= 16'h0000;
    noActivityTimeOut <= 1'b0;
  end
  else begin
    if (TxCtrlOut == `DRIVE)
      timeOutCnt <= 16'h0000;
    else 
      timeOutCnt <= timeOutCnt + 1'b1;
    //if (timeOutCnt == `RX_PACKET_TOUT * `OVER_SAMPLE_RATE)
    if (timeOutCnt == 16'h200)  //temporary fix
      noActivityTimeOut <= 1'b1;
    else
      noActivityTimeOut <= 1'b0;
  end
end

endmodule
@ 1.1 log @Initial revision @ text @d53 1 a53 1 // $Id$ d57 4 a60 1 // $Log$ @ 1.1.1.1 log @Created @ text @@