1
0
mirror of git://projects.qi-hardware.com/sie-ceimtun.git synced 2025-01-23 15:41:05 +02:00

145 lines
3.4 KiB
Verilog

`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);
*/
module beta(clk, sram_data, quadA, quadB, quadC, quadD, addr, nwe, ncs, noe, reset, hbridge);
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;
input quadA,quadB, quadC, quadD;
// 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])
);
enco enco2(
.clk(clk),
.enable(csN[1]),
.quadA(quadC),
.quadB(quadD),
.out(rdBus1),
.buffer_addr(buffer_addr[10:0])
);
PuenteH puente (
.clk(clk),
.reset(~reset),
.enable(csN[2]),
.we(we),
.addr(buffer_addr[10:0]),
.IN(wrBus),
.pwm_out(hbridge),
.ram_read(rdBus2)
);
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));
endmodule