mirror of
https://github.com/rdolbeau/NuBusFPGA.git
synced 2025-01-25 18:30:52 +00:00
113 lines
3.5 KiB
Coq
113 lines
3.5 KiB
Coq
|
/*
|
||
|
* NuBus sampling
|
||
|
*
|
||
|
* Romain Dolbeau <romain@dolbeau.org> for the NuBusFPGA
|
||
|
* Copyright (c) 2021022
|
||
|
*/
|
||
|
|
||
|
/* This module is running on the FPGA */
|
||
|
|
||
|
module nubus_sampling
|
||
|
(
|
||
|
/* *** NuBus signals *** */
|
||
|
/* those are connected to the FPGA */
|
||
|
/* connected via the CPLD */
|
||
|
input nub_clkn, // Clock (rising is driving edge, faling is sampling)
|
||
|
input nub_resetn, // Reset
|
||
|
//input [ 3:0] nub_idn, // Slot Identification
|
||
|
input nub_tm0n, // Transfer Mode
|
||
|
input nub_tm1n, // Transfer Mode
|
||
|
input nub_startn, // Start
|
||
|
input nub_rqstn, // Request
|
||
|
input nub_ackn, // Acknowledge
|
||
|
|
||
|
// connected via the CPLD but NuBus90 (unimplemented)
|
||
|
//input nub_clk2xn,
|
||
|
//inout nub_tm2n,
|
||
|
|
||
|
/* connected via the 74LVT245 */
|
||
|
input [31:0] nub_adn, // Address/Data
|
||
|
|
||
|
/* those are not used, and not even connected in the board */
|
||
|
// inout nub_pfwn, // Power Fail Warning
|
||
|
// inout nub_spn, // System Parity
|
||
|
// inout nub_spvn, // System Parity Valid
|
||
|
|
||
|
/* those ared used but handled in directly in the Litex code */
|
||
|
// output nub_nmrqn, // Non-Master Request, handled in the Litex code
|
||
|
|
||
|
/* those are used but connected only to the CPLD */
|
||
|
/* we deal with the CPLD via 'arbcy_n' and 'grant' */
|
||
|
// inout [ 3:0] nub_arbn, // Arbitration
|
||
|
|
||
|
output tm0,
|
||
|
output tm1,
|
||
|
output start,
|
||
|
output rqst,
|
||
|
output ack,
|
||
|
output [31:0] ad,
|
||
|
|
||
|
output [3:0] sel,
|
||
|
output block,
|
||
|
output busy
|
||
|
);
|
||
|
|
||
|
reg reg_tm0n, reg_tm1n;
|
||
|
reg reg_startn;
|
||
|
reg reg_rqstn;
|
||
|
reg reg_ackn;
|
||
|
reg [31:0] reg_adn;
|
||
|
reg reg_busy;
|
||
|
|
||
|
|
||
|
always @(negedge nub_clkn) begin: proc_sampling
|
||
|
if (~nub_resetn) begin
|
||
|
reg_tm0n <= 1;
|
||
|
reg_tm1n <= 1;
|
||
|
reg_startn <= 1;
|
||
|
reg_rqstn <= 1;
|
||
|
reg_ackn <= 1;
|
||
|
reg_adn <= 0;
|
||
|
reg_busy <= 0;
|
||
|
end else begin
|
||
|
reg_tm0n <= nub_tm0n;
|
||
|
reg_tm1n <= nub_tm1n;
|
||
|
reg_startn <= nub_startn;
|
||
|
reg_rqstn <= nub_rqstn;
|
||
|
reg_ackn <= nub_ackn;
|
||
|
reg_adn <= nub_adn;
|
||
|
reg_busy <= ~reg_busy & nub_ackn & ~nub_startn /* beginning of transaction */
|
||
|
| reg_busy & nub_ackn & nub_resetn; /* hold during cycle */
|
||
|
end
|
||
|
end
|
||
|
|
||
|
assign tm0 = ~reg_tm0n;
|
||
|
assign tm1 = ~reg_tm1n;
|
||
|
assign start = ~reg_startn;
|
||
|
assign rqst = ~reg_rqstn;
|
||
|
assign ack = ~reg_ackn;
|
||
|
assign ad = ~reg_adn;
|
||
|
assign busy = reg_busy;
|
||
|
|
||
|
// write selector for Wishbone
|
||
|
assign sel[3] = ~reg_tm1n & ~reg_adn[1] & ~reg_adn[0] & ~reg_tm0n /* Byte 3 */
|
||
|
| ~reg_tm1n & ~reg_adn[1] & ~reg_adn[0] & reg_tm0n /* Half 1 */
|
||
|
| ~reg_tm1n & reg_adn[1] & reg_adn[0] & reg_tm0n /* Word */
|
||
|
;
|
||
|
assign sel[2] = ~reg_tm1n & ~reg_adn[1] & reg_adn[0] & ~reg_tm0n /* Byte 2 */
|
||
|
| ~reg_tm1n & ~reg_adn[1] & ~reg_adn[0] & reg_tm0n /* Half 1 */
|
||
|
| ~reg_tm1n & reg_adn[1] & reg_adn[0] & reg_tm0n /* Word */
|
||
|
;
|
||
|
assign sel[1] = ~reg_tm1n & reg_adn[1] & ~reg_adn[0] & ~reg_tm0n /* Byte 1 */
|
||
|
| ~reg_tm1n & reg_adn[1] & ~reg_adn[0] & reg_tm0n /* Half 0 */
|
||
|
| ~reg_tm1n & reg_adn[1] & reg_adn[0] & reg_tm0n /* Word */
|
||
|
;
|
||
|
assign sel[0] = ~reg_tm1n & reg_adn[1] & reg_adn[0] & ~reg_tm0n /* Byte 0 */
|
||
|
| ~reg_tm1n & reg_adn[1] & ~reg_adn[0] & reg_tm0n /* Half 0 */
|
||
|
| ~reg_tm1n & reg_adn[1] & reg_adn[0] & reg_tm0n /* Word */
|
||
|
;
|
||
|
|
||
|
assign block = ~reg_adn[1] & reg_adn[0] & reg_tm0n; // 1x block write or 1x block read
|
||
|
|
||
|
endmodule
|