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

Subversion Repositories apbi2c

[/] [apbi2c/] [trunk/] [rtl/] [i2c.v] - Blame information for rev 4

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

Line No. Rev Author Line
1 2 redbear
//////////////////////////////////////////////////////////////////
2
////
3
////
4
////    TOP I2C BLOCK to I2C Core
5
////
6
////
7
////
8
//// This file is part of the APB to I2C project
9
////
10
//// http://www.opencores.org/cores/apbi2c/
11
////
12
////
13
////
14
//// Description
15
////
16
//// Implementation of APB IP core according to
17
////
18
//// apbi2c_spec IP core specification document.
19
////
20
////
21
////
22
//// To Do: Things are right here but always all block can suffer changes
23
////
24
////
25
////
26
////
27
////
28
//// Author(s): - Felipe Fernandes Da Costa, fefe2560@gmail.com
29
////              Ronal Dario Celaya
30
////
31
///////////////////////////////////////////////////////////////// 
32
////
33
////
34
//// Copyright (C) 2009 Authors and OPENCORES.ORG
35
////
36
////
37
////
38
//// This source file may be used and distributed without
39
////
40
//// restriction provided that this copyright statement is not
41
////
42
//// removed from the file and that any derivative work contains
43
//// the original copyright notice and the associated disclaimer.
44
////
45
////
46
//// This source file is free software; you can redistribute it
47
////
48
//// and/or modify it under the terms of the GNU Lesser General
49
////
50
//// Public License as published by the Free Software Foundation;
51
//// either version 2.1 of the License, or (at your option) any
52
////
53
//// later version.
54
////
55
////
56
////
57
//// This source is distributed in the hope that it will be
58
////
59
//// useful, but WITHOUT ANY WARRANTY; without even the implied
60
////
61
//// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
62
////
63
//// PURPOSE. See the GNU Lesser General Public License for more
64
//// details.
65
////
66
////
67
////
68
//// You should have received a copy of the GNU Lesser General
69
////
70
//// Public License along with this source; if not, download it
71
////
72
//// from http://www.opencores.org/lgpl.shtml
73
////
74
////
75
///////////////////////////////////////////////////////////////////
76
 
77
`timescale 1ns/1ps //timescale 
78
 
79
module i2c(
80
        //APB PORTS
81
        input PCLK,
82
        input PRESETn,
83
        input [31:0] PADDR,
84
        input [31:0] PWDATA,
85
        input PWRITE,
86
        input PSELx,
87
        input PENABLE,
88
        output PREADY,
89
        output PSLVERR,
90
        output INT_RX,
91
        output INT_TX,
92
        output [31:0] PRDATA,
93
        //I2C OUTPUT
94
        inout SDA,
95
        inout SCL
96
 
97
          );
98
 
99
        wire RESET_N;
100
 
101
        //THIS IS USED TO RESET FIFO
102
        assign RESET_N = (PRESETn == 0)?1'b1:1'b0;
103
 
104
        //WIRES USED TO CONECT BLOCK WITH EACH OTHER
105
        wire TX_RD_EN;
106
        wire TX_F_EMPTY;
107
        wire TX_F_FULL;
108
        wire [31:0] TX_DATA_IN;
109
        wire [31:0] TX_DATA_OUT;
110
        wire TX_WRITE_ENA;
111
 
112
        wire RX_RD_EN;
113
        wire RX_F_EMPTY;
114
        wire RX_F_FULL;
115
        wire [31:0] RX_DATA_IN;
116
        wire [31:0] RX_DATA_OUT;
117
        wire RX_WRITE_ENA;
118
 
119
 
120
        wire [13:0] REGISTER_CONFIG;
121
 
122
 
123
        wire error;
124
        wire tx_empty;
125
        wire rx_empty;
126
 
127
        //CONECTIONS WITH FIFO TX
128
        fifo DUT_FIFO_TX (
129
                                .clock(PCLK),
130
                                .reset(RESET_N),
131
                                .wr_en(TX_WRITE_ENA),
132
                                .rd_en(TX_RD_EN),
133
                                .data_in(TX_DATA_IN),
134
                                .f_full(TX_F_FULL),
135
                                .f_empty(TX_F_EMPTY),
136
                                .data_out(TX_DATA_OUT)
137
 
138
                         );
139
 
140
        //CONECTIONS WITH FIFO RX
141
        fifo DUT_FIFO_RX (
142
                                .clock(PCLK),
143
                                .reset(RESET_N),
144
                                .wr_en(RX_WRITE_ENA),
145
                                .rd_en(RX_RD_EN),
146
                                .data_in(RX_DATA_IN),
147
                                .f_full(RX_F_FULL),
148
                                .f_empty(RX_F_EMPTY),
149
                                .data_out(RX_DATA_OUT)
150
                         );
151
 
152
        //CONECTIONS WITH APB AND ALL BLOCKS WHERE IS TWO FIFOS AND I2C CORE
153
        apb DUT_APB (
154
 
155
                        .PCLK(PCLK),
156
                        .PRESETn(PRESETn),
157
                        .PADDR(PADDR),
158
                        .PRDATA(PRDATA),
159
                        .PWDATA(PWDATA),
160
                        .PWRITE(PWRITE),
161
                        .PSELx(PSELx),
162
                        .PENABLE(PENABLE),
163
                        .PREADY(PREADY),
164
                        .PSLVERR(PSLVERR),
165
                        .READ_DATA_ON_RX(RX_DATA_OUT),
166
                        .INTERNAL_I2C_REGISTER_CONFIG(REGISTER_CONFIG),
167
                        .INT_RX(INT_RX),
168
                        .WR_ENA(TX_WRITE_ENA),
169
                        .WRITE_DATA_ON_TX(TX_DATA_IN),
170
                        .RD_ENA(RX_RD_EN),
171
                        .INT_TX(INT_TX),
172
                        .TX_EMPTY(tx_empty),
173
                        .RX_EMPTY(rx_empty),
174
                        .ERROR(error)
175
 
176
                     );
177
 
178
        //I2C CORE BLOCK WITH ALL ANOTHER BLOCKS
179
        module_i2c DUT_I2C_INTERNAL (
180
                                        .PCLK(PCLK),
181
                                        .PRESETn(PRESETn),
182
                                        .fifo_tx_rd_en(TX_RD_EN),
183
                                        .fifo_tx_f_full(TX_F_FULL),
184
                                        .fifo_tx_f_empty(TX_F_EMPTY),
185
                                        .fifo_tx_data_out(TX_DATA_OUT),
186
                                        .fifo_rx_wr_en(RX_WRITE_ENA),
187
                                        .fifo_rx_f_empty(RX_F_EMPTY),
188
                                        .fifo_rx_data_in(RX_DATA_IN),
189
                                        .fifo_rx_f_full(RX_F_FULL),
190
                                        .DATA_CONFIG_REG(REGISTER_CONFIG),
191
                                        .TX_EMPTY(tx_empty),
192
                                        .RX_EMPTY(rx_empty),
193
                                        .ERROR(error),
194
                                        .SDA(SDA),
195
                                        .SCL(SCL)
196
                                    );
197
endmodule

powered by: WebSVN 2.1.0

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