mirror of
https://github.com/techav-homebrew/SE-Exp30.git
synced 2025-01-16 14:30:42 +00:00
Debug1
This commit is contained in:
parent
96dbd98368
commit
e457b3fec4
1472
Waveform.vwf
Normal file
1472
Waveform.vwf
Normal file
File diff suppressed because it is too large
Load Diff
72
paste.sv
72
paste.sv
@ -12,6 +12,7 @@ module paste (
|
|||||||
inout wire ncpuReset, // 68030 reset signal (tristate)
|
inout wire ncpuReset, // 68030 reset signal (tristate)
|
||||||
inout wire ncpuHalt, // 68030 halt signal (tristate)
|
inout wire ncpuHalt, // 68030 halt signal (tristate)
|
||||||
input wire ncpuDS, // 68030 data strobe signal
|
input wire ncpuDS, // 68030 data strobe signal
|
||||||
|
input wire ncpuAS, // 68030 address strobe signal
|
||||||
output wire ncpuDsack0, // 68030 DS Ack 0 signal
|
output wire ncpuDsack0, // 68030 DS Ack 0 signal
|
||||||
output wire ncpuDsack1, // 68030 DS Ack 1 signal
|
output wire ncpuDsack1, // 68030 DS Ack 1 signal
|
||||||
input wire cpuSize0, // 68030 Size 0 signal
|
input wire cpuSize0, // 68030 Size 0 signal
|
||||||
@ -29,6 +30,7 @@ module paste (
|
|||||||
input wire npdsReset, // PDS Reset signal
|
input wire npdsReset, // PDS Reset signal
|
||||||
inout wire npdsLds, // PDS Lower Data Strobe signal
|
inout wire npdsLds, // PDS Lower Data Strobe signal
|
||||||
inout wire npdsUds, // PDS Upper Data Strobe signal
|
inout wire npdsUds, // PDS Upper Data Strobe signal
|
||||||
|
inout wire npdsAs, // PDS Address Strobe signal
|
||||||
input wire npdsDtack, // PDS Data Xfer Ack signal
|
input wire npdsDtack, // PDS Data Xfer Ack signal
|
||||||
input wire npdsBg, // PDS Bus Grant signal
|
input wire npdsBg, // PDS Bus Grant signal
|
||||||
output wire npdsBGack, // PDS Bus Grant Ack signal
|
output wire npdsBGack, // PDS Bus Grant Ack signal
|
||||||
@ -66,6 +68,13 @@ wire nDsack68; // 6800 bus termination signal
|
|||||||
wire nDsackSE; // SE bus termination signal
|
wire nDsackSE; // SE bus termination signal
|
||||||
wire nUD; // SE upper data byte select
|
wire nUD; // SE upper data byte select
|
||||||
wire nLD; // SE lower data byte select
|
wire nLD; // SE lower data byte select
|
||||||
|
reg nAS; // SE address strobe
|
||||||
|
|
||||||
|
// D-latch to synchronize nAS to 8MHz clock
|
||||||
|
always @(posedge pdsC8m or negedge npdsReset) begin
|
||||||
|
if(npdsReset == 0) nAS <= 1;
|
||||||
|
else nAS <= ncpuAS;
|
||||||
|
end
|
||||||
|
|
||||||
// state machine for npdsVma generation
|
// state machine for npdsVma generation
|
||||||
always @(posedge pdsC8m or negedge npdsReset) begin
|
always @(posedge pdsC8m or negedge npdsReset) begin
|
||||||
@ -225,6 +234,9 @@ always @(posedge cpuClock or negedge npdsReset) begin
|
|||||||
end
|
end
|
||||||
|
|
||||||
// and finally, our combinatorial logic
|
// and finally, our combinatorial logic
|
||||||
|
assign nUD = ~(~cpuA0 || cpuRnW);
|
||||||
|
assign nLD = ~(cpuA0 || ~cpuSize0 || cpuSize1 || cpuRnW);
|
||||||
|
|
||||||
always_comb begin
|
always_comb begin
|
||||||
// DSACK intermediary signals
|
// DSACK intermediary signals
|
||||||
if(dsack68genState == S1) begin
|
if(dsack68genState == S1) begin
|
||||||
@ -238,43 +250,37 @@ always_comb begin
|
|||||||
nDsackSE <= 1'b1;
|
nDsackSE <= 1'b1;
|
||||||
end
|
end
|
||||||
|
|
||||||
// Upper/Lower data byte intermediary signals
|
// Upper/Lower data strobes
|
||||||
if(~cpuA0 || cpuRnW) begin
|
if(npdsBg == 1) begin
|
||||||
nUD <= 1'b0;
|
npdsUds <= 1'bZ;
|
||||||
|
npdsLds <= 1'bZ;
|
||||||
end else begin
|
end else begin
|
||||||
nUD <= 1'b1;
|
if(ncpuDS == 0 && nUD == 0) npdsUds <= 0;
|
||||||
end
|
else npdsUds <= 1;
|
||||||
if(cpuA0 || ~cpuSize0 || cpuSize1 || cpuRnW) begin
|
if(ncpuDS == 0 && nLD == 0) npdsLds <= 0;
|
||||||
nLD <= 1'b0;
|
else npdsLds <= 1;
|
||||||
end else begin
|
|
||||||
nLD <= 1'b1;
|
|
||||||
end
|
end
|
||||||
|
|
||||||
// Upper/Lower data strobes
|
// Address strobe
|
||||||
if(~ncpuDS || ~nUD) begin
|
if(npdsBg == 1) begin
|
||||||
npdsUds <= 1'b0;
|
npdsAs <= 1'bZ;
|
||||||
end else begin
|
end else begin
|
||||||
npdsUds <= 1'bZ;
|
npdsAs <= nAS;
|
||||||
end
|
|
||||||
if(~ncpuDS || ~nLD) begin
|
|
||||||
npdsLds <= 1'b0;
|
|
||||||
end else begin
|
|
||||||
npdsLds <= 1'bZ;
|
|
||||||
end
|
end
|
||||||
|
|
||||||
// buffer enable signals
|
// buffer enable signals
|
||||||
if(ncpuBG == 1'b1) begin
|
if(ncpuBG == 1'b1) begin
|
||||||
if(~nUD || ~npdsBg) begin
|
if(nUD == 0 && npdsBg == 0) begin
|
||||||
nbufDhiEn <= 1'b0;
|
nbufDhiEn <= 1'b0;
|
||||||
end else begin
|
end else begin
|
||||||
nbufDhiEn <= 1'b1;
|
nbufDhiEn <= 1'b1;
|
||||||
end
|
end
|
||||||
if(~nLD || nUD || ~npdsBg) begin
|
if(nLD == 0 && nUD == 1 && npdsBg == 0) begin
|
||||||
nbufDlo2En <= 1'b0;
|
nbufDlo2En <= 1'b0;
|
||||||
end else begin
|
end else begin
|
||||||
nbufDlo2En <= 1'b1;
|
nbufDlo2En <= 1'b1;
|
||||||
end
|
end
|
||||||
if(~nLD || ~nUD || ~npdsBg) begin
|
if(nLD == 0 && nUD == 0 && npdsBg == 0) begin
|
||||||
nbufDlo1En <= 1'b0;
|
nbufDlo1En <= 1'b0;
|
||||||
end else begin
|
end else begin
|
||||||
nbufDlo1En <= 1'b1;
|
nbufDlo1En <= 1'b1;
|
||||||
@ -312,19 +318,29 @@ always_comb begin
|
|||||||
end
|
end
|
||||||
|
|
||||||
// DS Ack signals
|
// DS Ack signals
|
||||||
if((nDsack68 == 1'b0 || (nDsackSE == 1'b0 && cpuAddrHi < 4'h5)) && cpuFC < 3'h7) begin
|
// 8-bit: ncpuDsack1=1, ncpuDsack0=0
|
||||||
ncpuDsack0 <= 1'b0;
|
// 16-bit: ncpuDsack1=0, ncpuDsack0=1
|
||||||
|
// nDsack68 is always an 8-bit transfer
|
||||||
|
// nDsackSE is a 16-bit transfer below address $50,0000
|
||||||
|
// nDsackSE is an 8-bit transfer above address $50,0000, inclusive
|
||||||
|
if(
|
||||||
|
(
|
||||||
|
nDsack68 == 0 ||
|
||||||
|
(nDsackSE == 0 && cpuAddrHi >= 4'h5)
|
||||||
|
)
|
||||||
|
&& cpuFC < 3'h7 ) begin
|
||||||
|
ncpuDsack0 <= 0;
|
||||||
end else begin
|
end else begin
|
||||||
ncpuDsack0 <= 1'b1;
|
ncpuDsack0 <= 1;
|
||||||
end
|
end
|
||||||
if(nDsackSE == 1'b0 && cpuAddrHi >= 4'h5 && cpuFC < 3'h7) begin
|
if(nDsackSE == 0 && cpuAddrHi < 4'h5 && cpuFC < 3'h7) begin
|
||||||
ncpuDsack1 <= 1'b0;
|
ncpuDsack1 <= 0;
|
||||||
end else begin
|
end else begin
|
||||||
ncpuDsack1 <= 1'b1;
|
ncpuDsack1 <= 1;
|
||||||
end
|
end
|
||||||
|
|
||||||
// CPU reset signals
|
// CPU reset signals
|
||||||
if(resetgenState == S2) begin
|
if(resetgenState != S2) begin
|
||||||
ncpuReset <= 1'b0;
|
ncpuReset <= 1'b0;
|
||||||
ncpuHalt <= 1'b0;
|
ncpuHalt <= 1'b0;
|
||||||
end else begin
|
end else begin
|
||||||
|
Loading…
x
Reference in New Issue
Block a user