URL
https://opencores.org/ocsvn/wb_lpc/wb_lpc/trunk
Subversion Repositories wb_lpc
[/] [wb_lpc/] [trunk/] [examples/] [pci_lpc/] [top_pci_lpc_host.v] - Rev 7
Go to most recent revision | Compare with Previous | Blame | View Log
////////////////////////////////////////////////////////////////////// //// //// //// $Id: top_pci_lpc_host.v,v 1.1 2008-03-05 05:58:41 hharte Exp $ //// //// top_pci_lpc_host.v - Top Level for PCI to LPC Host //// //// for the Enterpoint Raggedstone1 PCI Card. Based on the //// //// OpenCores raggedstone project, and uses the OpenCores //// //// pci32tlite core. //// //// //// //// This file is part of the Wishbone LPC Bridge project //// //// http://www.opencores.org/projects/wb_lpc/ //// //// //// //// Author: //// //// - Howard M. Harte (hharte@opencores.org) //// //// //// ////////////////////////////////////////////////////////////////////// //// //// //// Copyright (C) 2008 Howard M. Harte //// //// //// //// This source file may be used and distributed without //// //// restriction provided that this copyright statement is not //// //// removed from the file and that any derivative work contains //// //// the original copyright notice and the associated disclaimer. //// //// //// //// This source file is free software; you can redistribute it //// //// and/or modify it under the terms of the GNU Lesser General //// //// Public License as published by the Free Software Foundation; //// //// either version 2.1 of the License, or (at your option) any //// //// later version. //// //// //// //// This source is distributed in the hope that it will be //// //// useful, but WITHOUT ANY WARRANTY; without even the implied //// //// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR //// //// PURPOSE. See the GNU Lesser General Public License for more //// //// details. //// //// //// //// You should have received a copy of the GNU Lesser General //// //// Public License along with this source; if not, download it //// //// from http://www.opencores.org/lgpl.shtml //// //// //// ////////////////////////////////////////////////////////////////////// module pci_lpc_host ( CLK, RST, // Active Low INTA, REQ, GNT, FRAME, IRDY, IDSEL, DEVSEL, TRDY, STOP, PAR, PERR, SERR, PCI_AD, CBE0, CBE1, CBE2, CBE3, DISP_SEL, DISP_LED, LPC_CLK, LFRAME, LAD, LAD_OE, LPC_INT, PREVENT_STRIPPING_OF_UNUSED_INPUTS ); input CLK ; input RST ; inout [31:0] PCI_AD ; input CBE0, CBE1, CBE2, CBE3 ; output PAR ; input FRAME ; input IRDY ; output TRDY ; output DEVSEL ; inout STOP ; input IDSEL ; inout PERR ; inout SERR ; output INTA ; //attribute s: string; -- SAVE NET FLAG input REQ ; // attribute s of PCI_nREQ: signal is "yes"; input GNT ; // attribute s of PCI_nGNT: signal is "yes"; output [3:0] DISP_SEL ; output [6:0] DISP_LED ; output LPC_CLK; output LFRAME; inout [3:0] LAD; input LPC_INT; output LAD_OE; output PREVENT_STRIPPING_OF_UNUSED_INPUTS ; assign PREVENT_STRIPPING_OF_UNUSED_INPUTS = REQ & GNT; wire [2:0] dma_chan_i = 3'b000; wire dma_tc_i = 1'b0; wire lframe_o; wire [3:0] lad_i; wire [3:0] lad_o; wire host_lad_oe; assign LAD = (host_lad_oe ? lad_o : 4'bzzzz); assign LAD_OE = host_lad_oe; assign LPC_CLK = CLK; assign LFRAME = ~lframe_o; wire [3:0] CBE_in = { CBE3, CBE2, CBE1, CBE0 } ; wire PCI_CLK = CLK; wire [24:0] wb_adr_o; wire [31:0] wb_dat_i; wire [31:0] wb_dat_o; wire [3:0] wb_sel_o; wire [1:0] wb_tga; wire wb_we_o; wire wb_stb_o; wire wb_cyc_o; wire wb_ack_i; wire wb_rty_i = 1'b0; wire wb_err_i = 1'b0; wire wb_int_i; //assign wb_tga = wb_adr_o[17:16]; // I/O Cycle assign wb_tga = 2'b10; // Firmware cycle assign wb_int_i = ~LPC_INT; // Instantiate the pci32tlite module pci32tLite #( // .vendorID(16'h10ee), // .deviceID(16'hf00d), // .revisionID(8'h01), .vendorID(16'h14e4), .deviceID(16'h43f5), .revisionID(8'h0a), .subsystemID(16'h0), .subsystemvID(16'h0), .BARS("1BARMEM"), .WBSIZE(32), .WBENDIAN("LITTLE")) pci_target ( .clk33(PCI_CLK), .rst(~RST), .ad(PCI_AD), .cbe(CBE_in), .par(PAR), .frame(FRAME), .irdy(IRDY), .trdy(TRDY), .devsel(DEVSEL), .stop(STOP), .idsel(IDSEL), .perr(PERR), .serr(SERR), .intb(INTA), .wb_adr_o(wb_adr_o), .wb_dat_i(wb_dat_i), .wb_dat_o(wb_dat_o), .wb_sel_o(wb_sel_o), .wb_we_o(wb_we_o), .wb_stb_o(wb_stb_o), .wb_cyc_o(wb_cyc_o), .wb_ack_i(wb_ack_i), .wb_rty_i(wb_rty_i), .wb_err_i(wb_err_i), .wb_int_i(wb_int_i) ); wb_lpc_host lpc_host ( .clk_i(CLK), .nrst_i(RST), .wbs_adr_i(wb_adr_o), .wbs_dat_o(wb_dat_i), .wbs_dat_i(wb_dat_o), .wbs_sel_i(wb_sel_o), .wbs_tga_i(wb_tga), .wbs_we_i(wb_we_o), .wbs_stb_i(wb_stb_o), .wbs_cyc_i(wb_cyc_o), .wbs_ack_o(wb_ack_i), .dma_chan_i(dma_chan_i), .dma_tc_i(dma_tc_i), .lframe_o(lframe_o), .lad_i(LAD), .lad_o(lad_o), .lad_oe(host_lad_oe) ); // The 7-segment display is write-only from the PCI interface. // Use some dummy nets for inputs that are ignored. wire [31:0] wb2_dat_i; wire wb2_ack_i; wire wb2_err_i; wire wb2_int_i; // Instantiate the 7-Segment module on the host wb_7seg seven_seg0 ( .clk_i(CLK), .nrst_i(RST), .wb_adr_i(wb_adr_o), .wb_dat_o(wb2_dat_i), .wb_dat_i(wb_dat_o), .wb_sel_i(wb_sel_o), .wb_we_i(wb_we_o), .wb_stb_i(wb_stb_o), .wb_cyc_i(wb_cyc_o), .wb_ack_o(wb2_ack_i), .wb_err_o(wb2_err_i), .wb_int_o(wb2_int_i), .DISP_SEL(DISP_SEL), .DISP_LED(DISP_LED) ); endmodule
Go to most recent revision | Compare with Previous | Blame | View Log