2010-04-02 21:44:09 -05:00
|
|
|
`timescale 1ns / 1ps
|
|
|
|
module ADC(clk, sram_data, addr, nwe, ncs, noe, reset, led, ADC_EOC,
|
2010-07-30 10:46:16 -05:00
|
|
|
ADC_SCLK, ADC_SDIN, ADC_SDOUT, ADC_CS, ADC_CSTART, irq_pin, OD1, OD2, OD3);
|
2010-04-02 21:44:09 -05:00
|
|
|
|
2010-06-11 08:06:13 -05:00
|
|
|
parameter B = (7);
|
2010-04-02 21:44:09 -05:00
|
|
|
|
|
|
|
input clk, addr, nwe, ncs, noe, reset, ADC_EOC;
|
|
|
|
inout [B:0] sram_data;
|
|
|
|
output led, ADC_CS, ADC_CSTART, ADC_SCLK;
|
2010-07-30 10:46:16 -05:00
|
|
|
output OD1, OD2, OD3;
|
2010-06-11 08:06:13 -05:00
|
|
|
inout ADC_SDIN, ADC_SDOUT;
|
|
|
|
input irq_pin;
|
2010-04-02 21:44:09 -05:00
|
|
|
|
|
|
|
|
|
|
|
// Internal conection
|
|
|
|
reg led;
|
2010-07-30 10:46:16 -05:00
|
|
|
reg OD1, OD2, OD3;
|
2010-04-02 21:44:09 -05:00
|
|
|
|
|
|
|
// synchronize signals
|
|
|
|
reg sncs, snwe;
|
2010-04-04 13:58:41 -05:00
|
|
|
reg [12:0] buffer_addr;
|
2010-04-02 21:44:09 -05:00
|
|
|
reg [B:0] buffer_data;
|
|
|
|
|
|
|
|
// bram interfaz signals
|
|
|
|
reg we;
|
|
|
|
reg w_st=0;
|
|
|
|
reg [B:0] wrBus;
|
|
|
|
wire [B:0] rdBus;
|
2010-04-02 23:30:52 -05:00
|
|
|
|
|
|
|
// interfaz fpga signals
|
2010-04-04 13:58:41 -05:00
|
|
|
wire [12:0] addr;
|
2010-04-02 23:30:52 -05:00
|
|
|
|
2010-04-02 21:44:09 -05:00
|
|
|
|
|
|
|
reg [25:0] counter;
|
|
|
|
|
|
|
|
// Test : LED blinking
|
|
|
|
always @(posedge clk) begin
|
2010-06-11 08:06:13 -05:00
|
|
|
if (~reset)
|
2010-04-02 23:30:52 -05:00
|
|
|
counter <= {25{1'b0}};
|
|
|
|
else
|
|
|
|
counter <= counter + 1;
|
2010-07-30 10:46:16 -05:00
|
|
|
led <= counter[25];
|
|
|
|
OD1 <= counter[25];
|
|
|
|
OD2 <= counter[16];
|
|
|
|
OD3 <= counter[15];
|
|
|
|
|
2010-04-02 21:44:09 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
// interefaz signals assignments
|
|
|
|
wire T = ~noe | ncs;
|
|
|
|
assign sram_data = T?8'bZ:rdBus;
|
|
|
|
|
|
|
|
// synchronize assignment
|
|
|
|
always @(negedge clk)
|
|
|
|
begin
|
2010-04-02 23:30:52 -05:00
|
|
|
sncs <= ncs;
|
|
|
|
snwe <= nwe;
|
|
|
|
buffer_data <= sram_data;
|
|
|
|
buffer_addr <= addr;
|
2010-04-02 21:44:09 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
// write access cpu to bram
|
|
|
|
always @(posedge clk)
|
2010-06-11 08:06:13 -05:00
|
|
|
if(~reset) {w_st, we, wrBus} <= 0;
|
2010-04-02 21:44:09 -05:00
|
|
|
else begin
|
|
|
|
wrBus <= buffer_data;
|
|
|
|
case (w_st)
|
|
|
|
0: begin
|
|
|
|
we <= 0;
|
|
|
|
if(sncs | snwe) w_st <= 1;
|
|
|
|
end
|
|
|
|
1: begin
|
|
|
|
if(~(sncs | snwe)) begin
|
|
|
|
we <= 1;
|
|
|
|
w_st <= 0;
|
|
|
|
end
|
|
|
|
else we <= 0;
|
|
|
|
end
|
|
|
|
endcase
|
|
|
|
end
|
|
|
|
|
2010-04-02 23:30:52 -05:00
|
|
|
// Peripherals control
|
|
|
|
wire [3:0] csN;
|
|
|
|
wire [7:0] rdBus0, rdBus1, rdBus2, rdBus3;
|
|
|
|
|
2010-04-04 13:58:41 -05:00
|
|
|
assign csN = buffer_addr[12]? (buffer_addr[11]? 4'b1000:
|
2010-04-09 10:39:15 -05:00
|
|
|
4'b0100)
|
2010-04-04 13:58:41 -05:00
|
|
|
: (buffer_addr[11]? 4'b0010:
|
2010-04-09 10:39:15 -05:00
|
|
|
4'b0001);
|
2010-04-02 23:30:52 -05:00
|
|
|
|
2010-04-04 13:58:41 -05:00
|
|
|
assign rdBus = buffer_addr[12]? (buffer_addr[11]? rdBus3:
|
2010-04-09 10:39:15 -05:00
|
|
|
rdBus2)
|
2010-04-04 13:58:41 -05:00
|
|
|
: (buffer_addr[11]? rdBus1:
|
2010-04-09 10:39:15 -05:00
|
|
|
rdBus0);
|
2010-04-02 21:44:09 -05:00
|
|
|
|
|
|
|
// Peripheral instantiation
|
2010-04-02 23:30:52 -05:00
|
|
|
ADC_peripheral P1(
|
|
|
|
.clk(clk),
|
2010-06-11 08:06:13 -05:00
|
|
|
.reset(~reset),
|
2010-04-02 23:30:52 -05:00
|
|
|
.cs(csN[0]),
|
|
|
|
.ADC_EOC(ADC_EOC),
|
|
|
|
.ADC_CS(ADC_CS),
|
|
|
|
.ADC_CSTART(ADC_CSTART),
|
|
|
|
.ADC_SCLK(ADC_SCLK),
|
|
|
|
.ADC_SDIN(ADC_SDIN),
|
|
|
|
.ADC_SDOUT(ADC_SDOUT),
|
2010-04-04 13:58:41 -05:00
|
|
|
.addr(buffer_addr[10:0]),
|
2010-04-02 23:30:52 -05:00
|
|
|
.rdBus(rdBus0),
|
|
|
|
.wrBus(wrBus),
|
|
|
|
.we(we));
|
2010-04-02 21:44:09 -05:00
|
|
|
endmodule
|
|
|
|
|