URL
https://opencores.org/ocsvn/apb2spi/apb2spi/trunk
Subversion Repositories apb2spi
[/] [apb2spi/] [trunk/] [rtl/] [APB_SLAVE.v] - Rev 11
Go to most recent revision | Compare with Previous | Blame | View Log
////////////////////////////////////////////////////////////////////// //// //// //// APB- SPI 0.1 IP Core //// //// //// //// This file is part of the APB- SPI 0.1 IP Core project //// //// http://www.opencores.org/cores/APB- SPI 0.1 IP Core/ //// //// //// //// Description //// //// Implementation of XXX IP core according to //// //// XXX IP core specification document. //// //// //// //// To Do: //// //// - //// //// //// //// Author(s): //// //// - Lakshmi Narayanan Vernugopal, email@opencores.org //// //// //// ////////////////////////////////////////////////////////////////////// //// //// //// Copyright (C) 2009 Authors and OPENCORES.ORG //// //// //// //// 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 //// //// //// /// /////////////////////////////////////////////////////////////////// `define APB_DATA_WIDTH 8 `define SPI_REG_WIDTH 8 `define APB_ADDR_WIDTH 3 //`define CLK_DIV_WIDTH 16 //`timescale 1ns/1ps module APB_SLAVE ( // APB SLAVE PORT INTERFACE input PCLK, input PRESETn, input [`APB_ADDR_WIDTH-1:0 ] PADDR, input PWRITE, input PSEL, input PENABLE, input [`APB_DATA_WIDTH-1:0 ] PWDATA, output reg [`APB_DATA_WIDTH-1:0 ] PRDATA, output reg PREADY, input TrFr, // SPI INTERFACE output reg [`SPI_REG_WIDTH-1:0] SPI_CR_1, output reg [`SPI_REG_WIDTH-1:0] SPI_CR_2, output reg [`SPI_REG_WIDTH-1:0] SPI_BR_R, output reg [`SPI_REG_WIDTH-1:0] SPI_ST_R, output reg [`SPI_REG_WIDTH-1:0] SPI_DATA_Reg_1, output reg [`SPI_REG_WIDTH-1:0] SPI_DATA_Reg_2, output reg [`SPI_REG_WIDTH-1:0] SPI_DATA_Reg_3, output reg [`SPI_REG_WIDTH-1:0] SPI_DATA_Reg_4 ); ///////////////////////////////////////////// // Signal Description //// ///////////////////////////////////////////// localparam IDLE = 2'b00; localparam SETUP = 2'b01; localparam ENABLE = 2'b10; reg [1:0] STATE; always@(posedge PCLK or negedge PRESETn) begin if(!PRESETn) begin STATE <= IDLE; PREADY <= 0; end else begin PREADY <= 0; case(STATE) IDLE: begin PREADY <= 1; //if(PSEL && !PENABLE) if(TrFr) STATE <= SETUP; else STATE <= IDLE; end SETUP: begin if(PENABLE) STATE <= ENABLE; else STATE <= IDLE; end ENABLE:begin if(PENABLE) STATE <= SETUP; else STATE <= IDLE; end endcase end end assign write_en = PWRITE && (STATE==ENABLE); assign read_en = !PWRITE && (STATE==SETUP); //always@(PADDR,PWDATA,write_en) always@(posedge PCLK or negedge PRESETn) begin if(!PRESETn) begin PRDATA <= 8'd0; SPI_CR_1 <= 8'd0; SPI_CR_2 <= 8'd0; SPI_BR_R <= 8'd0; SPI_ST_R <= 8'd0; SPI_DATA_Reg_1 <= 8'd0; SPI_DATA_Reg_2 <= 8'd0; SPI_DATA_Reg_3 <= 8'd0; SPI_DATA_Reg_4 <= 8'd0; end else begin if(write_en) begin case(PADDR) 3'b000 : SPI_CR_1 <= PWDATA; 3'b001 : SPI_CR_2 <= PWDATA; 3'b010 : SPI_BR_R <= PWDATA; 3'b011 : SPI_ST_R <= PWDATA; 3'b100 : SPI_DATA_Reg_1 <= PWDATA; 3'b101 : SPI_DATA_Reg_2 <= PWDATA; 3'b110 : SPI_DATA_Reg_3 <= PWDATA; 3'b111 : SPI_DATA_Reg_4 <= PWDATA; default: SPI_CR_1 <= PWDATA; endcase end else if(read_en && PENABLE) begin case(PADDR) 3'b000 : PRDATA <= SPI_CR_1 ; 3'b001 : PRDATA <= SPI_CR_2 ; 3'b010 : PRDATA <= SPI_BR_R ; 3'b011 : PRDATA <= SPI_ST_R ; 3'b100 : PRDATA <= SPI_DATA_Reg_1; 3'b101 : PRDATA <= SPI_DATA_Reg_2; 3'b110 : PRDATA <= SPI_DATA_Reg_3; 3'b111 : PRDATA <= SPI_DATA_Reg_4; default: PRDATA <= SPI_CR_1; endcase end else begin SPI_CR_1 <= SPI_CR_1; SPI_CR_2 <= SPI_CR_2; SPI_BR_R <= SPI_BR_R; SPI_ST_R <= SPI_ST_R; SPI_DATA_Reg_1 <= SPI_DATA_Reg_1; SPI_DATA_Reg_2 <= SPI_DATA_Reg_2; SPI_DATA_Reg_3 <= SPI_DATA_Reg_3; SPI_DATA_Reg_4 <= SPI_DATA_Reg_4; end end end endmodule
Go to most recent revision | Compare with Previous | Blame | View Log