2010-10-30 18:34:22 -05:00
|
|
|
`timescale 1ns / 1ps
|
|
|
|
/*module ADC(clk, sram_data, addr, nwe, ncs, noe, reset, led, ADC_EOC,
|
|
|
|
ADC_SCLK, ADC_SDIN, ADC_SDOUT, ADC_CS, ADC_CSTART, led2);
|
|
|
|
*/
|
2010-10-30 22:27:00 -05:00
|
|
|
module beta(clk, sram_data, quadA, quadB, quadC, quadD, addr, nwe, ncs, noe, reset, hbridge);
|
2010-10-30 18:34:22 -05:00
|
|
|
|
|
|
|
parameter B = (7);
|
|
|
|
|
|
|
|
// input clk, addr, nwe, ncs, noe, reset, ADC_EOC;
|
|
|
|
inout [B:0] sram_data;
|
|
|
|
// output led, led2, ADC_CS, ADC_CSTART, ADC_SCLK;//agregado led2, quitados ODn
|
|
|
|
// inout ADC_SDIN, ADC_SDOUT;
|
|
|
|
input clk, addr, nwe, ncs, noe, reset;
|
|
|
|
output [3:0] hbridge;
|
2010-10-30 22:27:00 -05:00
|
|
|
input quadA,quadB, quadC, quadD;
|
2010-10-30 18:34:22 -05:00
|
|
|
|
|
|
|
// External conection
|
|
|
|
//wire led, led2;
|
|
|
|
|
|
|
|
// synchronize signals
|
|
|
|
reg sncs, snwe;
|
|
|
|
reg [12:0] buffer_addr;
|
|
|
|
reg [B:0] buffer_data;
|
|
|
|
|
|
|
|
// bram interfaz signals
|
|
|
|
reg we;
|
|
|
|
reg w_st=0;
|
|
|
|
reg [B:0] wrBus;
|
|
|
|
wire [B:0] rdBus;
|
|
|
|
|
|
|
|
// interfaz fpga signals
|
|
|
|
wire [12:0] addr;
|
|
|
|
|
|
|
|
// interefaz signals assignments
|
|
|
|
wire T = ~noe | ncs;
|
|
|
|
assign sram_data = T?8'bZ:rdBus;
|
|
|
|
|
|
|
|
// synchronize assignment
|
|
|
|
always @(negedge clk)
|
|
|
|
begin
|
|
|
|
sncs <= ncs;
|
|
|
|
snwe <= nwe;
|
|
|
|
buffer_data <= sram_data;
|
|
|
|
buffer_addr <= addr;
|
|
|
|
end
|
|
|
|
|
|
|
|
// write access cpu to bram
|
|
|
|
always @(posedge clk)
|
|
|
|
if(~reset) {w_st, we, wrBus} <= 0;
|
|
|
|
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
|
|
|
|
|
|
|
|
// Peripherals control
|
|
|
|
wire [3:0] csN;
|
|
|
|
wire [7:0] rdBus0, rdBus1, rdBus2, rdBus3;
|
|
|
|
|
|
|
|
assign csN = buffer_addr[12]? (buffer_addr[11]? 4'b1000:
|
|
|
|
4'b0100)
|
|
|
|
: (buffer_addr[11]? 4'b0010:
|
|
|
|
4'b0001);
|
|
|
|
|
|
|
|
assign rdBus = buffer_addr[12]? (buffer_addr[11]? rdBus3:
|
|
|
|
rdBus2)
|
|
|
|
: (buffer_addr[11]? rdBus1:
|
|
|
|
rdBus0);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//assign led2=1;
|
|
|
|
// assign led=1;
|
|
|
|
|
|
|
|
// Peripheral instantiation
|
|
|
|
/* ADC_peripheral P1(
|
|
|
|
.clk(clk),
|
|
|
|
.reset(~reset),
|
|
|
|
.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),
|
|
|
|
.addr(buffer_addr[10:0]),
|
|
|
|
.rdBus(rdBus0),
|
|
|
|
.wrBus(wrBus),
|
|
|
|
.we(we));
|
|
|
|
*/
|
|
|
|
|
|
|
|
enco enco1(
|
|
|
|
.clk(clk),
|
|
|
|
.enable(csN[0]),
|
|
|
|
.quadA(quadA),
|
|
|
|
.quadB(quadB),
|
|
|
|
.out(rdBus0),
|
|
|
|
.buffer_addr(buffer_addr[10:0])
|
|
|
|
);
|
|
|
|
|
2010-10-30 22:27:00 -05:00
|
|
|
enco enco2(
|
|
|
|
.clk(clk),
|
|
|
|
.enable(csN[1]),
|
|
|
|
.quadA(quadC),
|
|
|
|
.quadB(quadD),
|
|
|
|
.out(rdBus1),
|
|
|
|
.buffer_addr(buffer_addr[10:0])
|
|
|
|
);
|
|
|
|
|
2010-10-30 18:34:22 -05:00
|
|
|
PuenteH puente (
|
|
|
|
.clk(clk),
|
|
|
|
.reset(~reset),
|
|
|
|
.enable(csN[2]),
|
|
|
|
.we(we),
|
|
|
|
.addr(buffer_addr[10:0]),
|
|
|
|
.IN(wrBus),
|
|
|
|
.pwm_out(hbridge),
|
|
|
|
.ram_read(rdBus2)
|
|
|
|
);
|
|
|
|
|
2010-10-30 22:27:00 -05:00
|
|
|
RAMB16_S9 ba0( .CLK(~clk),
|
|
|
|
.EN(csN[3]),
|
|
|
|
.DOP(),
|
|
|
|
.SSR(1'b0),
|
|
|
|
.ADDR(buffer_addr[10:0]),
|
|
|
|
.WE(we),
|
|
|
|
.DI(wrBus),
|
|
|
|
.DIP(1'b0),
|
|
|
|
.DO(rdBus3));
|
2010-10-30 18:34:22 -05:00
|
|
|
|
|
|
|
endmodule
|
|
|
|
|