URL
https://opencores.org/ocsvn/klc32/klc32/trunk
Subversion Repositories klc32
[/] [klc32/] [trunk/] [rtl/] [verilog/] [PUSH.v] - Rev 11
Go to most recent revision | Compare with Previous | Blame | View Log
// ============================================================================ // (C) 2011 Robert Finch // All Rights Reserved. // robfinch<remove>@opencores.org // // KLC32 - 32 bit CPU // PUSH.v - push type instructions // PUSH / PEA / LINK // // 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 3 of the License, or // (at your option) any later version. // // This source file 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 General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see <http://www.gnu.org/licenses/>. // // ============================================================================ // PUSH1: if (ir[25:1]==25'd0) state <= IFETCH; else begin Rn <= ir[25:21]; ir[25:0] <= {ir[20:1],6'b0}; if (ir[25:21]!=5'd0) state <= PUSH2; end PUSH2: begin fc_o <= {sf,2'b01}; cyc_o <= 1'b1; stb_o <= 1'b1; we_o <= 1'b1; sel_o <= 4'b1111; adr_o <= sf ? ssp - 32'd4 : usp - 32'd4; dat_o <= rfo; state <= PUSH3; end PUSH3: if (ack_i) begin cyc_o <= 1'b0; stb_o <= 1'b0; we_o <= 1'b0; sel_o <= 4'b0000; if (sf) ssp <= ssp - 32'd4; else usp <= usp - 32'd4; state <= PUSH1; end else if (err_i) begin cyc_o <= 1'b0; stb_o <= 1'b0; we_o <= 1'b0; sel_o <= 4'b0000; vector <= `BUS_ERR_VECTOR; state <= TRAP; end PEA: if (!cyc_o) begin fc_o <= {sf,2'b01}; cyc_o <= 1'b1; stb_o <= 1'b1; we_o <= 1'b1; sel_o <= 4'b1111; adr_o <= sf ? ssp - 32'd4 : usp - 32'd4; dat_o <= ea; end else if (ack_i) begin cyc_o <= 1'b0; stb_o <= 1'b0; we_o <= 1'b0; sel_o <= 4'b0000; if (sf) ssp <= ssp - 32'd4; else usp <= usp - 32'd4; state <= IFETCH; end else if (err_i) begin cyc_o <= 1'b0; stb_o <= 1'b0; we_o <= 1'b0; sel_o <= 4'b0000; vector <= `BUS_ERR_VECTOR; state <= TRAP; end LINK: if (!cyc_o) begin fc_o <= {sf,2'b01}; cyc_o <= 1'b1; stb_o <= 1'b1; we_o <= 1'b1; sel_o <= 4'b1111; adr_o <= sf ? ssp - 32'd4 : usp - 32'd4; dat_o <= a; end else if (ack_i) begin cyc_o <= 1'b0; stb_o <= 1'b0; we_o <= 1'b0; sel_o <= 4'b0000; if (sf) begin ssp <= ssp - 32'd4; res <= ssp - 32'd4; end else begin usp <= usp - 32'd4; res <= usp - 32'd4; end state <= WRITEBACK; end else if (err_i) begin cyc_o <= 1'b0; stb_o <= 1'b0; we_o <= 1'b0; sel_o <= 4'b0000; vector <= `BUS_ERR_VECTOR; state <= TRAP; end
Go to most recent revision | Compare with Previous | Blame | View Log