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

Subversion Repositories z80control

[/] [z80control/] [trunk/] [CII_Starter_USB_API_v1/] [HW/] [I2C_Controller.v] - Blame information for rev 12

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 12 tylerapohl
//Legal Notice: (C)2006 Altera Corporation. All rights reserved. Your
2
//use of Altera Corporation's design tools, logic functions and other
3
//software and tools, and its AMPP partner logic functions, and any
4
//output files any of the foregoing (including device programming or
5
//simulation files), and any associated documentation or information are
6
//expressly subject to the terms and conditions of the Altera Program
7
//License Subscription Agreement or other applicable license agreement,
8
//including, without limitation, that your use is for the sole purpose
9
//of programming logic devices manufactured by Altera and sold by Altera
10
//or its authorized distributors.  Please refer to the applicable
11
//agreement for further details.
12
 
13
module I2C_Controller (
14
        CLOCK,
15
        I2C_SCLK,//I2C CLOCK
16
        I2C_SDAT,//I2C DATA
17
        I2C_DATA,//DATA:[SLAVE_ADDR,SUB_ADDR,DATA]
18
        GO,      //GO transfor
19
        END,     //END transfor 
20
        W_R,     //W_R
21
        ACK,      //ACK
22
        RESET,
23
        //TEST
24
        SD_COUNTER,
25
        SDO
26
);
27
        input  CLOCK;
28
        input  [23:0]I2C_DATA;
29
        input  GO;
30
        input  RESET;
31
        input  W_R;
32
        inout  I2C_SDAT;
33
        output I2C_SCLK;
34
        output END;
35
        output ACK;
36
 
37
//TEST
38
        output [5:0] SD_COUNTER;
39
        output SDO;
40
 
41
 
42
reg SDO;
43
reg SCLK;
44
reg END;
45
reg [23:0]SD;
46
reg [5:0]SD_COUNTER;
47
 
48
wire I2C_SCLK=SCLK | ( ((SD_COUNTER >= 4) & (SD_COUNTER <=30))? ~CLOCK :0 );
49
wire I2C_SDAT=SDO?1'bz:0 ;
50
 
51
reg ACK1,ACK2,ACK3;
52
wire ACK=ACK1 | ACK2 |ACK3;
53
 
54
//--I2C COUNTER
55
always @(negedge RESET or posedge CLOCK ) begin
56
if (!RESET) SD_COUNTER=6'b111111;
57
else begin
58
if (GO==0)
59
        SD_COUNTER=0;
60
        else
61
        if (SD_COUNTER < 6'b111111) SD_COUNTER=SD_COUNTER+1;
62
end
63
end
64
//----
65
 
66
always @(negedge RESET or  posedge CLOCK ) begin
67
if (!RESET) begin SCLK=1;SDO=1; ACK1=0;ACK2=0;ACK3=0; END=1; end
68
else
69
case (SD_COUNTER)
70
        6'd0  : begin ACK1=0 ;ACK2=0 ;ACK3=0 ; END=0; SDO=1; SCLK=1;end
71
        //start
72
        6'd1  : begin SD=I2C_DATA;SDO=0;end
73
        6'd2  : SCLK=0;
74
        //SLAVE ADDR
75
        6'd3  : SDO=SD[23];
76
        6'd4  : SDO=SD[22];
77
        6'd5  : SDO=SD[21];
78
        6'd6  : SDO=SD[20];
79
        6'd7  : SDO=SD[19];
80
        6'd8  : SDO=SD[18];
81
        6'd9  : SDO=SD[17];
82
        6'd10 : SDO=SD[16];
83
        6'd11 : SDO=1'b1;//ACK
84
 
85
        //SUB ADDR
86
        6'd12  : begin SDO=SD[15]; ACK1=I2C_SDAT; end
87
        6'd13  : SDO=SD[14];
88
        6'd14  : SDO=SD[13];
89
        6'd15  : SDO=SD[12];
90
        6'd16  : SDO=SD[11];
91
        6'd17  : SDO=SD[10];
92
        6'd18  : SDO=SD[9];
93
        6'd19  : SDO=SD[8];
94
        6'd20  : SDO=1'b1;//ACK
95
 
96
        //DATA
97
        6'd21  : begin SDO=SD[7]; ACK2=I2C_SDAT; end
98
        6'd22  : SDO=SD[6];
99
        6'd23  : SDO=SD[5];
100
        6'd24  : SDO=SD[4];
101
        6'd25  : SDO=SD[3];
102
        6'd26  : SDO=SD[2];
103
        6'd27  : SDO=SD[1];
104
        6'd28  : SDO=SD[0];
105
        6'd29  : SDO=1'b1;//ACK
106
 
107
 
108
        //stop
109
    6'd30 : begin SDO=1'b0;     SCLK=1'b0; ACK3=I2C_SDAT; end
110
    6'd31 : SCLK=1'b1;
111
    6'd32 : begin SDO=1'b1; END=1; end
112
 
113
endcase
114
end
115
 
116
 
117
 
118
endmodule

powered by: WebSVN 2.1.0

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