1
0
mirror of https://github.com/UzixLS/zx-sizif-xxs.git synced 2025-07-19 07:11:28 +03:00
Files
zx-sizif-xxs/fpga/rtl/turbosound.sv
2022-02-01 18:54:45 +03:00

95 lines
1.9 KiB
Systemverilog

import common::*;
module turbosound(
input rst_n,
input clk28,
input ck35,
input en,
input en_ts,
cpu_bus bus,
output [7:0] d_out,
output d_out_active,
output [7:0] ay_a0,
output [7:0] ay_b0,
output [7:0] ay_c0,
output [7:0] ay_a1,
output [7:0] ay_b1,
output [7:0] ay_c1
);
reg ay_bdir;
reg ay_bc1;
reg ay_sel;
wire ay_rd0 = bus.rd && ay_bc1 == 1'b1 && ay_bdir == 1'b0 && ay_sel == 1'b0;
wire ay_rd1 = bus.rd && ay_bc1 == 1'b1 && ay_bdir == 1'b0 && ay_sel == 1'b1;
wire port_bffd = en && bus.ioreq && bus.a_reg[15] == 1'b1 && bus.a_reg[1] == 0;
wire port_fffd = en && bus.ioreq && bus.a_reg[15] == 1'b1 && bus.a_reg[14] == 1'b1 && bus.a_reg[1] == 0;
always @(posedge clk28 or negedge rst_n) begin
if (!rst_n) begin
ay_bc1 <= 0;
ay_bdir <= 0;
ay_sel <= 0;
end
else begin
ay_bc1 <= port_fffd;
ay_bdir <= port_bffd && bus.wr;
if (!en_ts)
ay_sel <= 0;
else if (bus.ioreq && port_fffd && bus.wr && bus.d_reg[7:3] == 5'b11111)
ay_sel <= bus.d_reg[0];
end
end
reg [1:0] ay_ck;
always @(posedge clk28 or negedge rst_n) begin
if (!rst_n)
ay_ck <= 0;
else if (ck35)
ay_ck <= ay_ck + 1'b1;
else
ay_ck[1] <= 0;
end
wire [7:0] ay_dout0, ay_dout1;
YM2149 ym2149_0(
.CLK(clk28),
.CE(ay_ck[1]),
.RESET(~rst_n),
.A8(~ay_sel),
.BDIR(ay_bdir),
.BC(ay_bc1),
.DI(bus.d_reg),
.DO(ay_dout0),
.SEL(1'b0),
.MODE(1'b1),
.CHANNEL_A(ay_a0),
.CHANNEL_B(ay_b0),
.CHANNEL_C(ay_c0)
);
YM2149 ym2149_1(
.CLK(clk28),
.CE(ay_ck[1]),
.RESET(~rst_n || !en_ts),
.A8(ay_sel),
.BDIR(ay_bdir),
.BC(ay_bc1),
.DI(bus.d_reg),
.DO(ay_dout1),
.SEL(1'b0),
.MODE(1'b0),
.CHANNEL_A(ay_a1),
.CHANNEL_B(ay_b1),
.CHANNEL_C(ay_c1)
);
assign d_out_active = ay_rd0 | ay_rd1;
assign d_out = ay_rd1? ay_dout1 : ay_dout0;
endmodule