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

📄 or1200_du.v

📁 LEON(sparc)微处理器的源代码
💻 V
📖 第 1 页 / 共 3 页
字号:
		13'b0_0001_xxxx_xxxx: begin			except_stop[`OR1200_DU_DRR_BUSEE] = 1'b1;		end		13'b0_0000_1xxx_xxxx:			except_stop[`OR1200_DU_DRR_IIE] = 1'b1;		13'b0_0000_01xx_xxxx: begin			except_stop[`OR1200_DU_DRR_AE] = 1'b1;		end		13'b0_0000_001x_xxxx: begin			except_stop[`OR1200_DU_DRR_DME] = 1'b1;		end		13'b0_0000_0001_xxxx:			except_stop[`OR1200_DU_DRR_DPFE] = 1'b1;		13'b0_0000_0000_1xxx:			except_stop[`OR1200_DU_DRR_BUSEE] = 1'b1;		13'b0_0000_0000_01xx: begin			except_stop[`OR1200_DU_DRR_RE] = 1'b1;		end		13'b0_0000_0000_001x: begin			except_stop[`OR1200_DU_DRR_TE] = 1'b1;		end		13'b0_0000_0000_0001:			except_stop[`OR1200_DU_DRR_SCE] = 1'b1;		default:			except_stop = 14'b0000_0000_0000;	endcaseend//// dbg_bp_o is registered//assign dbg_bp_o = dbg_bp_r;//// Breakpoint activation register//always @(posedge clk or posedge rst)	if (rst)		dbg_bp_r <= #1 1'b0;	else if (!ex_freeze)		dbg_bp_r <= #1 |except_stop`ifdef OR1200_DU_DMR1_ST                        | ~((ex_insn[31:26] == `OR1200_OR32_NOP) & ex_insn[16]) & dmr1[`OR1200_DU_DMR1_ST]`endif`ifdef OR1200_DU_DMR1_BT                        | (branch_op != `OR1200_BRANCHOP_NOP) & dmr1[`OR1200_DU_DMR1_BT]`endif			;        else                dbg_bp_r <= #1 |except_stop;//// Write to DMR1//`ifdef OR1200_DU_DMR1always @(posedge clk or posedge rst)	if (rst)		dmr1 <= 25'h000_0000;	else if (dmr1_sel && spr_write)`ifdef OR1200_DU_HWBKPTS		dmr1 <= #1 spr_dat_i[24:0];`else		dmr1 <= #1 {1'b0, spr_dat_i[23:22], 22'h00_0000};`endif`elseassign dmr1 = 25'h000_0000;`endif//// Write to DMR2//`ifdef OR1200_DU_DMR2always @(posedge clk or posedge rst)	if (rst)		dmr2 <= 24'h00_0000;	else if (dmr2_sel && spr_write)		dmr2 <= #1 spr_dat_i[23:0];`elseassign dmr2 = 24'h00_0000;`endif//// Write to DSR//`ifdef OR1200_DU_DSRalways @(posedge clk or posedge rst)	if (rst)		dsr <= {`OR1200_DU_DSR_WIDTH{1'b0}};	else if (dsr_sel && spr_write)		dsr <= #1 spr_dat_i[`OR1200_DU_DSR_WIDTH-1:0];`elseassign dsr = {`OR1200_DU_DSR_WIDTH{1'b0}};`endif//// Write to DRR//`ifdef OR1200_DU_DRRalways @(posedge clk or posedge rst)	if (rst)		drr <= 14'b0;	else if (drr_sel && spr_write)		drr <= #1 spr_dat_i[13:0];	else		drr <= #1 drr | except_stop;`elseassign drr = 14'b0;`endif//// Write to DVR0//`ifdef OR1200_DU_DVR0always @(posedge clk or posedge rst)	if (rst)		dvr0 <= 32'h0000_0000;	else if (dvr0_sel && spr_write)		dvr0 <= #1 spr_dat_i[31:0];`elseassign dvr0 = 32'h0000_0000;`endif//// Write to DVR1//`ifdef OR1200_DU_DVR1always @(posedge clk or posedge rst)	if (rst)		dvr1 <= 32'h0000_0000;	else if (dvr1_sel && spr_write)		dvr1 <= #1 spr_dat_i[31:0];`elseassign dvr1 = 32'h0000_0000;`endif//// Write to DVR2//`ifdef OR1200_DU_DVR2always @(posedge clk or posedge rst)	if (rst)		dvr2 <= 32'h0000_0000;	else if (dvr2_sel && spr_write)		dvr2 <= #1 spr_dat_i[31:0];`elseassign dvr2 = 32'h0000_0000;`endif//// Write to DVR3//`ifdef OR1200_DU_DVR3always @(posedge clk or posedge rst)	if (rst)		dvr3 <= 32'h0000_0000;	else if (dvr3_sel && spr_write)		dvr3 <= #1 spr_dat_i[31:0];`elseassign dvr3 = 32'h0000_0000;`endif//// Write to DVR4//`ifdef OR1200_DU_DVR4always @(posedge clk or posedge rst)	if (rst)		dvr4 <= 32'h0000_0000;	else if (dvr4_sel && spr_write)		dvr4 <= #1 spr_dat_i[31:0];`elseassign dvr4 = 32'h0000_0000;`endif//// Write to DVR5//`ifdef OR1200_DU_DVR5always @(posedge clk or posedge rst)	if (rst)		dvr5 <= 32'h0000_0000;	else if (dvr5_sel && spr_write)		dvr5 <= #1 spr_dat_i[31:0];`elseassign dvr5 = 32'h0000_0000;`endif//// Write to DVR6//`ifdef OR1200_DU_DVR6always @(posedge clk or posedge rst)	if (rst)		dvr6 <= 32'h0000_0000;	else if (dvr6_sel && spr_write)		dvr6 <= #1 spr_dat_i[31:0];`elseassign dvr6 = 32'h0000_0000;`endif//// Write to DVR7//`ifdef OR1200_DU_DVR7always @(posedge clk or posedge rst)	if (rst)		dvr7 <= 32'h0000_0000;	else if (dvr7_sel && spr_write)		dvr7 <= #1 spr_dat_i[31:0];`elseassign dvr7 = 32'h0000_0000;`endif//// Write to DCR0//`ifdef OR1200_DU_DCR0always @(posedge clk or posedge rst)	if (rst)		dcr0 <= 8'h00;	else if (dcr0_sel && spr_write)		dcr0 <= #1 spr_dat_i[7:0];`elseassign dcr0 = 8'h00;`endif//// Write to DCR1//`ifdef OR1200_DU_DCR1always @(posedge clk or posedge rst)	if (rst)		dcr1 <= 8'h00;	else if (dcr1_sel && spr_write)		dcr1 <= #1 spr_dat_i[7:0];`elseassign dcr1 = 8'h00;`endif//// Write to DCR2//`ifdef OR1200_DU_DCR2always @(posedge clk or posedge rst)	if (rst)		dcr2 <= 8'h00;	else if (dcr2_sel && spr_write)		dcr2 <= #1 spr_dat_i[7:0];`elseassign dcr2 = 8'h00;`endif//// Write to DCR3//`ifdef OR1200_DU_DCR3always @(posedge clk or posedge rst)	if (rst)		dcr3 <= 8'h00;	else if (dcr3_sel && spr_write)		dcr3 <= #1 spr_dat_i[7:0];`elseassign dcr3 = 8'h00;`endif//// Write to DCR4//`ifdef OR1200_DU_DCR4always @(posedge clk or posedge rst)	if (rst)		dcr4 <= 8'h00;	else if (dcr4_sel && spr_write)		dcr4 <= #1 spr_dat_i[7:0];`elseassign dcr4 = 8'h00;`endif//// Write to DCR5//`ifdef OR1200_DU_DCR5always @(posedge clk or posedge rst)	if (rst)		dcr5 <= 8'h00;	else if (dcr5_sel && spr_write)		dcr5 <= #1 spr_dat_i[7:0];`elseassign dcr5 = 8'h00;`endif//// Write to DCR6//`ifdef OR1200_DU_DCR6always @(posedge clk or posedge rst)	if (rst)		dcr6 <= 8'h00;	else if (dcr6_sel && spr_write)		dcr6 <= #1 spr_dat_i[7:0];`elseassign dcr6 = 8'h00;`endif//// Write to DCR7//`ifdef OR1200_DU_DCR7always @(posedge clk or posedge rst)	if (rst)		dcr7 <= 8'h00;	else if (dcr7_sel && spr_write)		dcr7 <= #1 spr_dat_i[7:0];`elseassign dcr7 = 8'h00;`endif//// Write to DWCR0//`ifdef OR1200_DU_DWCR0always @(posedge clk or posedge rst)	if (rst)		dwcr0 <= 32'h0000_0000;	else if (dwcr0_sel && spr_write)		dwcr0 <= #1 spr_dat_i[31:0];	else if (incr_wpcntr0)		dwcr0[`OR1200_DU_DWCR_COUNT] <= #1 dwcr0[`OR1200_DU_DWCR_COUNT] + 16'h0001;`elseassign dwcr0 = 32'h0000_0000;`endif//// Write to DWCR1//`ifdef OR1200_DU_DWCR1always @(posedge clk or posedge rst)	if (rst)		dwcr1 <= 32'h0000_0000;	else if (dwcr1_sel && spr_write)		dwcr1 <= #1 spr_dat_i[31:0];	else if (incr_wpcntr1)		dwcr1[`OR1200_DU_DWCR_COUNT] <= #1 dwcr1[`OR1200_DU_DWCR_COUNT] + 16'h0001;`elseassign dwcr1 = 32'h0000_0000;`endif//// Read DU registers//`ifdef OR1200_DU_READREGSalways @(spr_addr or dsr or drr or dmr1 or dmr2	or dvr0 or dvr1 or dvr2 or dvr3 or dvr4	or dvr5 or dvr6 or dvr7	or dcr0 or dcr1 or dcr2 or dcr3 or dcr4	or dcr5 or dcr6 or dcr7	or dwcr0 or dwcr1`ifdef OR1200_DU_TB_IMPLEMENTED	or tb_wadr or tbia_dat_o or tbim_dat_o	or tbar_dat_o or tbts_dat_o`endif	)	casex (spr_addr[`OR1200_DUOFS_BITS]) // synopsys parallel_case`ifdef OR1200_DU_DVR0		`OR1200_DU_DVR0:			spr_dat_o = dvr0;`endif`ifdef OR1200_DU_DVR1		`OR1200_DU_DVR1:			spr_dat_o = dvr1;`endif`ifdef OR1200_DU_DVR2		`OR1200_DU_DVR2:			spr_dat_o = dvr2;`endif`ifdef OR1200_DU_DVR3		`OR1200_DU_DVR3:			spr_dat_o = dvr3;`endif`ifdef OR1200_DU_DVR4		`OR1200_DU_DVR4:			spr_dat_o = dvr4;`endif`ifdef OR1200_DU_DVR5		`OR1200_DU_DVR5:			spr_dat_o = dvr5;`endif`ifdef OR1200_DU_DVR6		`OR1200_DU_DVR6:			spr_dat_o = dvr6;`endif`ifdef OR1200_DU_DVR7		`OR1200_DU_DVR7:			spr_dat_o = dvr7;`endif`ifdef OR1200_DU_DCR0		`OR1200_DU_DCR0:			spr_dat_o = {24'h00_0000, dcr0};`endif`ifdef OR1200_DU_DCR1		`OR1200_DU_DCR1:			spr_dat_o = {24'h00_0000, dcr1};`endif`ifdef OR1200_DU_DCR2		`OR1200_DU_DCR2:			spr_dat_o = {24'h00_0000, dcr2};`endif`ifdef OR1200_DU_DCR3		`OR1200_DU_DCR3:			spr_dat_o = {24'h00_0000, dcr3};`endif`ifdef OR1200_DU_DCR4		`OR1200_DU_DCR4:			spr_dat_o = {24'h00_0000, dcr4};`endif`ifdef OR1200_DU_DCR5		`OR1200_DU_DCR5:			spr_dat_o = {24'h00_0000, dcr5};`endif`ifdef OR1200_DU_DCR6		`OR1200_DU_DCR6:			spr_dat_o = {24'h00_0000, dcr6};`endif`ifdef OR1200_DU_DCR7		`OR1200_DU_DCR7:			spr_dat_o = {24'h00_0000, dcr7};`endif`ifdef OR1200_DU_DMR1		`OR1200_DU_DMR1:			spr_dat_o = {7'h00, dmr1};`endif`ifdef OR1200_DU_DMR2		`OR1200_DU_DMR2:			spr_dat_o = {8'h00, dmr2};`endif`ifdef OR1200_DU_DWCR0		`OR1200_DU_DWCR0:			spr_dat_o = dwcr0;`endif`ifdef OR1200_DU_DWCR1		`OR1200_DU_DWCR1:			spr_dat_o = dwcr1;`endif`ifdef OR1200_DU_DSR		`OR1200_DU_DSR:			spr_dat_o = {18'b0, dsr};`endif`ifdef OR1200_DU_DRR		`OR1200_DU_DRR:			spr_dat_o = {18'b0, drr};`endif`ifdef OR1200_DU_TB_IMPLEMENTED		`OR1200_DU_TBADR:			spr_dat_o = {24'h000000, tb_wadr};		`OR1200_DU_TBIA:			spr_dat_o = tbia_dat_o;		`OR1200_DU_TBIM:			spr_dat_o = tbim_dat_o;		`OR1200_DU_TBAR:			spr_dat_o = tbar_dat_o;		`OR1200_DU_TBTS:			spr_dat_o = tbts_dat_o;`endif		default:			spr_dat_o = 32'h0000_0000;	endcase`endif//// DSR alias//assign du_dsr = dsr;`ifdef OR1200_DU_HWBKPTS//// Compare To What (Match Condition 0)//always @(dcr0 or id_pc or dcpu_adr_i or dcpu_dat_dc	or dcpu_dat_lsu or dcpu_we_i)	case (dcr0[`OR1200_DU_DCR_CT])		// synopsys parallel_case		3'b001:	match_cond0_ct = id_pc;		// insn fetch EA		3'b010:	match_cond0_ct = dcpu_adr_i;	// load EA		3'b011:	match_cond0_ct = dcpu_adr_i;	// store EA		3'b100:	match_cond0_ct = dcpu_dat_dc;	// load data		3'b101:	match_cond0_ct = dcpu_dat_lsu;	// store data		3'b110:	match_cond0_ct = dcpu_adr_i;	// load/store EA		default:match_cond0_ct = dcpu_we_i ? dcpu_dat_lsu : dcpu_dat_dc;	endcase//// When To Compare (Match Condition 0)//always @(dcr0 or dcpu_cycstb_i)	case (dcr0[`OR1200_DU_DCR_CT]) 		// synopsys parallel_case		3'b000:	match_cond0_stb = 1'b0;		//comparison disabled		3'b001:	match_cond0_stb = 1'b1;		// insn fetch EA		default:match_cond0_stb = dcpu_cycstb_i; // any load/store	endcase//// Match Condition 0//always @(match_cond0_stb or dcr0 or dvr0 or match_cond0_ct)	casex ({match_cond0_stb, dcr0[`OR1200_DU_DCR_CC]})		4'b0_xxx,		4'b1_000,		4'b1_111: match0 = 1'b0;		4'b1_001: match0 =			((match_cond0_ct[31] ^ dcr0[`OR1200_DU_DCR_SC]) ==			(dvr0[31] ^ dcr0[`OR1200_DU_DCR_SC]));		4'b1_010: match0 = 			((match_cond0_ct[31] ^ dcr0[`OR1200_DU_DCR_SC]) <			(dvr0[31] ^ dcr0[`OR1200_DU_DCR_SC]));		4'b1_011: match0 = 			((match_cond0_ct[31] ^ dcr0[`OR1200_DU_DCR_SC]) <=			(dvr0[31] ^ dcr0[`OR1200_DU_DCR_SC]));		4'b1_100: match0 = 			((match_cond0_ct[31] ^ dcr0[`OR1200_DU_DCR_SC]) >			(dvr0[31] ^ dcr0[`OR1200_DU_DCR_SC]));		4'b1_101: match0 = 			((match_cond0_ct[31] ^ dcr0[`OR1200_DU_DCR_SC]) >=			(dvr0[31] ^ dcr0[`OR1200_DU_DCR_SC]));		4'b1_110: match0 = 			((match_cond0_ct[31] ^ dcr0[`OR1200_DU_DCR_SC]) !=			(dvr0[31] ^ dcr0[`OR1200_DU_DCR_SC]));	endcase//// Watchpoint 0//always @(dmr1 or match0)	case (dmr1[`OR1200_DU_DMR1_CW0])		2'b00: wp[0] = match0;		2'b01: wp[0] = match0;		2'b10: wp[0] = match0;		2'b11: wp[0] = 1'b0;	endcase//// Compare To What (Match Condition 1)//always @(dcr1 or id_pc or dcpu_adr_i or dcpu_dat_dc	or dcpu_dat_lsu or dcpu_we_i)	case (dcr1[`OR1200_DU_DCR_CT])		// synopsys parallel_case		3'b001:	match_cond1_ct = id_pc;		// insn fetch EA		3'b010:	match_cond1_ct = dcpu_adr_i;	// load EA		3'b011:	match_cond1_ct = dcpu_adr_i;	// store EA		3'b100:	match_cond1_ct = dcpu_dat_dc;	// load data		3'b101:	match_cond1_ct = dcpu_dat_lsu;	// store data		3'b110:	match_cond1_ct = dcpu_adr_i;	// load/store EA		default:match_cond1_ct = dcpu_we_i ? dcpu_dat_lsu : dcpu_dat_dc;	endcase//// When To Compare (Match Condition 1)//always @(dcr1 or dcpu_cycstb_i)	case (dcr1[`OR1200_DU_DCR_CT]) 		// synopsys parallel_case		3'b000:	match_cond1_stb = 1'b0;		//comparison disabled		3'b001:	match_cond1_stb = 1'b1;		// insn fetch EA		default:match_cond1_stb = dcpu_cycstb_i; // any load/store	endcase//// Match Condition 1//always @(match_cond1_stb or dcr1 or dvr1 or match_cond1_ct)	casex ({match_cond1_stb, dcr1[`OR1200_DU_DCR_CC]})		4'b0_xxx,		4'b1_000,		4'b1_111: match1 = 1'b0;		4'b1_001: match1 =			((match_cond1_ct[31] ^ dcr1[`OR1200_DU_DCR_SC]) ==			(dvr1[31] ^ dcr1[`OR1200_DU_DCR_SC]));		4'b1_010: match1 = 			((match_cond1_ct[31] ^ dcr1[`OR1200_DU_DCR_SC]) <			(dvr1[31] ^ dcr1[`OR1200_DU_DCR_SC]));		4'b1_011: match1 = 			((match_cond1_ct[31] ^ dcr1[`OR1200_DU_DCR_SC]) <=			(dvr1[31] ^ dcr1[`OR1200_DU_DCR_SC]));		4'b1_100: match1 = 			((match_cond1_ct[31] ^ dcr1[`OR1200_DU_DCR_SC]) >			(dvr1[31] ^ dcr1[`OR1200_DU_DCR_SC]));		4'b1_101: match1 = 			((match_cond1_ct[31] ^ dcr1[`OR1200_DU_DCR_SC]) >=			(dvr1[31] ^ dcr1[`OR1200_DU_DCR_SC]));		4'b1_110: match1 = 			((match_cond1_ct[31] ^ dcr1[`OR1200_DU_DCR_SC]) !=			(dvr1[31] ^ dcr1[`OR1200_DU_DCR_SC]));	endcase//// Watchpoint 1//always @(dmr1 or match1 or wp)	case (dmr1[`OR1200_DU_DMR1_CW1])		2'b00: wp[1] = match1;		2'b01: wp[1] = match1 & wp[0];		2'b10: wp[1] = match1 | wp[0];		2'b11: wp[1] = 1'b0;

⌨️ 快捷键说明

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