OpenCores
URL https://opencores.org/ocsvn/usbhostslave/usbhostslave/trunk

Subversion Repositories usbhostslave

[/] [usbhostslave/] [trunk/] [RTL/] [include/] [usbSerialInterfaceEngine_h.v] - Blame information for rev 14

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 sfielding
//////////////////////////////////////////////////////////////////////
2 5 sfielding
// usbSerialInterfaceEngine_h.v                                
3
//////////////////////////////////////////////////////////////////////
4 2 sfielding
 
5 5 sfielding
`ifdef usbSerialInterfaceEngine_h_vdefined
6
`else
7
`define usbSerialInterfaceEngine_h_vdefined
8 2 sfielding
 
9 9 sfielding
 // Sampling frequency = 'FS_OVER_SAMPLE_RATE' * full speed bit rate = 'LS_OVER_SAMPLE_RATE' * low speed bit rate
10
`define FS_OVER_SAMPLE_RATE 4
11
`define LS_OVER_SAMPLE_RATE 32
12 2 sfielding
 
13
//timeOuts
14
`define RX_PACKET_TOUT 18
15
 
16
//TXStreamControlTypes
17
`define TX_DIRECT_CONTROL 8'h00
18
`define TX_RESUME_START 8'h01
19
`define TX_PACKET_START 8'h02
20
`define TX_PACKET_STREAM 8'h03
21
`define TX_PACKET_STOP 8'h04
22
`define TX_IDLE 8'h05
23 14 sfielding
`define TX_LS_KEEP_ALIVE 8'h06
24 2 sfielding
 
25
//RXStreamControlTypes
26
`define RX_PACKET_START 0
27
`define RX_PACKET_STREAM 1
28
`define RX_PACKET_STOP 2
29
 
30
//USBLineStates
31
// ONE_ZERO corresponds to differential 1. ie D+ = Hi, D- = Lo
32
`define ONE_ZERO 2'b10
33
`define ZERO_ONE 2'b01
34
`define SE0 2'b00
35
`define SE1 2'b11
36
 
37
//RXStatusIndices
38
`define CRC_ERROR_BIT 0
39
`define BIT_STUFF_ERROR_BIT 1
40
`define RX_OVERFLOW_BIT 2
41
`define NAK_RXED_BIT 3
42
`define STALL_RXED_BIT 4
43
`define ACK_RXED_BIT 5
44
`define DATA_SEQUENCE_BIT 6
45
 
46
//usbWireControlStates
47
`define TRI_STATE 1'b0
48
`define DRIVE 1'b1
49
 
50
//limits
51 12 sfielding
`define MAX_CONSEC_SAME_BITS 4'h6
52
`define MAX_CONSEC_SAME_BITS_PLUS1 4'h7
53 14 sfielding
// RESUME_RX_WAIT_TIME defines the time period for resume detection
54
// The resume counter is incremented at the bit rate, so
55
// RESUME_RX_WAIT_TIME = 29 corresponds to 30 * 1/12MHz = 2.5uS at full speed
56
// and 30 * 1/1.5MHz =  20uS at low speed, both of which are within the USB spec of 
57
// 2.5uS <= resumeDetectTime <= 100uS
58
`define RESUME_RX_WAIT_TIME 5'd29
59
//`define RESUME_WAIT_TIME_MINUS1 9
60
// 'HOST_TX_RESUME_TIME' assumes counter is incremented at low speed bit rate 
61
`define HOST_TX_RESUME_TIME 16'd30000  //Host sends resume for 30000 * 1/1.5MHz = 20mS
62
//`define CONNECT_WAIT_TIME 8'd20
63
`define CONNECT_WAIT_TIME 8'd120      //Device connect detected after 120 * 1/48MHz = 2.5uS
64
//`define DISCONNECT_WAIT_TIME 8'd20   
65
`define DISCONNECT_WAIT_TIME 8'd120   //Device disconnect detected after 120 * 1/48MHz = 2.5uS
66 2 sfielding
 
67
//RXConnectStates
68
`define DISCONNECT 2'b00
69
`define LOW_SPEED_CONNECT 2'b01
70
`define FULL_SPEED_CONNECT 2'b10
71
 
72
//TX_RX_InternalStreamTypes
73
`define DATA_START 8'h00
74
`define DATA_STOP 8'h01
75
`define DATA_STREAM 8'h02
76
`define DATA_BIT_STUFF_ERROR 8'h03
77
 
78
//RXStMach states
79
`define DISCONNECT_ST 4'h0
80
`define WAIT_FULL_SPEED_CONN_ST 4'h1
81
`define WAIT_LOW_SPEED_CONN_ST 4'h2
82
`define CONNECT_LOW_SPEED_ST 4'h3
83
`define CONNECT_FULL_SPEED_ST 4'h4
84
`define WAIT_LOW_SP_DISCONNECT_ST 4'h5
85
`define WAIT_FULL_SP_DISCONNECT_ST 4'h6
86
 
87
//RXBitStateMachStates
88
`define IDLE_BIT_ST 2'b00
89
`define DATA_RECEIVE_BIT_ST 2'b01
90
`define WAIT_RESUME_ST 2'b10
91
`define RESUME_END_WAIT_ST 2'b11
92
 
93
//RXByteStateMachStates 
94
`define IDLE_BYTE_ST 3'b000
95
`define CHECK_SYNC_ST 3'b001
96
`define CHECK_PID_ST 3'b010
97
`define HS_BYTE_ST 3'b011
98
`define TOKEN_BYTE_ST 3'b100
99
`define DATA_BYTE_ST 3'b101
100
 
101 5 sfielding
`endif //usbSerialInterfaceEngine_h_vdefined
102 2 sfielding
 
103
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.