⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 oc8051_ram_sel.v

📁 8051的Verilog
💻 V
字号:
//////////////////////////////////////////////////////////////////////////                                                              ////////  8051 ram select                                             ////////                                                              ////////  This file is part of the 8051 cores project                 ////////  http://www.opencores.org/cores/8051/                        ////////                                                              ////////  Description                                                 ////////   Multiplexer wiht whitch we select data send to alu source  ////////   select.                                                    ////////                                                              ////////  To Do:                                                      ////////   nothing                                                    ////////                                                              ////////  Author(s):                                                  ////////      - Simon Teran, simont@opencores.org                     ////////                                                              //////////////////////////////////////////////////////////////////////////////                                                              //////// Copyright (C) 2000 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                     ////////                                                              ////////////////////////////////////////////////////////////////////////////// CVS Revision History//// $Log: oc8051_ram_sel.v,v $// Revision 1.6  2002/11/05 17:23:54  simont// add module oc8051_sfr, 256 bytes internal ram//// Revision 1.5  2002/09/30 17:33:59  simont// prepared header////// synopsys translate_off`include "oc8051_timescale.v"// synopsys translate_on`include "oc8051_defines.v"module oc8051_ram_sel (addr, bit_in, in_ram, sfr, sfr_bit, rd_ind, bit_out, out_data);//// addr         (in)  address [oc8051_ram_rd_sel.out -r]// bit_in       (in)  bit input (from ram) [oc8051_ram_top.bit_data_out]// in_ram       (in)  imput from ram [oc8051_ram_top.rd_data]// psw          (in)  program status word input [oc8051_psw.data_out]// acc          (in)  accumulator input [oc8051_acc.data_out]// dptr_hi      (in)  data pointer high bits input [oc8051_dptr.data_hi]// ports_in     (in)  ports input [oc8051_ports.data_out]// sp           (in)  stack pointer [oc8051_sp.data_out]// b_reg        (in)  b register input [oc8051_b_register.data_out]// uart         (in)  input from uart [oc8051_uart.data_out]// int		(in)  input from interrupt module// tc		(in)  input from timer counter module// bit_out      (out) bit output [oc8051_alu.bit_in, oc8051_comp.b_in, oc8051_cy_select.data_in]// out_data     (out) data (byte) output [oc8051_alu_src1_sel.ram, oc8051_alu_src2_sel.ram, oc8051_comp.ram]//input bit_in, sfr_bit, rd_ind;input [7:0] addr, in_ram, sfr;output bit_out;output [7:0] out_data;reg bit_out;reg [7:0] out_data;/*////set output in case of address (byte)always @(addr or in_ram or psw or acc or dptr_hi or ports_in or sp or b_reg or uart or tc or int)begin  case (addr)    `OC8051_SFR_ACC: out_data = acc;    `OC8051_SFR_PSW: out_data = psw;    `OC8051_SFR_P0: out_data = ports_in;    `OC8051_SFR_P1: out_data = ports_in;    `OC8051_SFR_P2: out_data = ports_in;    `OC8051_SFR_P3: out_data = ports_in;    `OC8051_SFR_SP: out_data = sp;    `OC8051_SFR_B: out_data = b_reg;    `OC8051_SFR_DPTR_HI: out_data = dptr_hi;    `OC8051_SFR_SCON:  out_data = uart;    `OC8051_SFR_SBUF:  out_data = uart;    `OC8051_SFR_PCON:  out_data = uart;    `OC8051_SFR_TH0: out_data = tc;    `OC8051_SFR_TH1: out_data = tc;    `OC8051_SFR_TL0: out_data = tc;    `OC8051_SFR_TL1: out_data = tc;    `OC8051_SFR_TMOD: out_data = tc;    `OC8051_SFR_IP: out_data = int;    `OC8051_SFR_IE: out_data = int;    `OC8051_SFR_TCON: out_data = int;    default: out_data = in_ram;  endcaseend////set output in case of address (bit)always @(addr or bit_in or b_bit or acc_bit or psw_bit or int_bit or port_bit or uart_bit)begin  case (addr[7:3])    `OC8051_SFR_B_ACC: bit_out = acc_bit;    `OC8051_SFR_B_PSW: bit_out = psw_bit;    `OC8051_SFR_B_P0: bit_out = port_bit;    `OC8051_SFR_B_P1: bit_out = port_bit;    `OC8051_SFR_B_P2: bit_out = port_bit;    `OC8051_SFR_B_P3: bit_out = port_bit;    `OC8051_SFR_B_B: bit_out = b_bit;    `OC8051_SFR_B_IP: bit_out = int_bit;    `OC8051_SFR_B_IE: bit_out = int_bit;    `OC8051_SFR_B_TCON: bit_out = int_bit;    `OC8051_SFR_B_SCON: bit_out = uart_bit;    default: bit_out = bit_in;  endcaseend*///always @(addr or in_ram or sfr or bit_in or sfr_bit)begin  if (addr[7] && !rd_ind) begin    out_data = sfr;    bit_out = sfr_bit;  end else begin    out_data = in_ram;    bit_out = bit_in;  endendendmodule

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -