HierarchyFilesModulesSignalsTasksFunctionsHelp

/******************************************************************************/ 
/*                                                                            */ 
/* Copyright (c) 1999 Sun Microsystems, Inc. All rights reserved.             */ 
/*                                                                            */ 
/* The contents of this file are subject to the current version of the Sun    */ 
/* Community Source License, microSPARCII ("the License"). You may not use    */ 
/* this file except in compliance with the License.  You may obtain a copy    */ 
/* of the License by searching for "Sun Community Source License" on the      */ 
/* World Wide Web at http://www.sun.com. See the License for the rights,      */ 
/* obligations, and limitations governing use of the contents of this file.   */ 
/*                                                                            */ 
/* Sun Microsystems, Inc. has intellectual property rights relating to the    */ 
/* technology embodied in these files. In particular, and without limitation, */ 
/* these intellectual property rights may include one or more U.S. patents,   */ 
/* foreign patents, or pending applications.                                  */ 
/*                                                                            */ 
/* Sun, Sun Microsystems, the Sun logo, all Sun-based trademarks and logos,   */ 
/* Solaris, Java and all Java-based trademarks and logos are trademarks or    */ 
/* registered trademarks of Sun Microsystems, Inc. in the United States and   */ 
/* other countries. microSPARC is a trademark or registered trademark of      */ 
/* SPARC International, Inc. All SPARC trademarks are used under license and  */ 
/* are trademarks or registered trademarks of SPARC International, Inc. in    */ 
/* the United States and other countries. Products bearing SPARC trademarks   */ 
/* are based upon an architecture developed by Sun Microsystems, Inc.         */ 
/*                                                                            */ 
/******************************************************************************/ 
/***************************************************************************
****************************************************************************
***
***  Program File:  @(#)final_adder.v
***
****************************************************************************
****************************************************************************/

//  @(#)final_adder.v	1.2  7/10/92
//
// **************************************************************
//  final_add  -- generate rounded 53-bit mantissa given 54-bit
//		  carry-sum, sticky, and c51.
//
// **************************************************************

[Up: fpm_frac final_adder]
module final_adder (
		  mantissa,
		  inexact,
		  frac_ovf,
		  sum,
		  carry,
		  mode,
		  sign,
		  sticky,
		  c51,
		  double_precision
		  );

    output [52:0] mantissa;
    output inexact;
    output frac_ovf;		// fraction overflow (mantissa >= 2.0)

    input  [105:51] sum;	// recoded
    input  [105:52] carry;	// recoded
    input  [1:0] mode;
    input  sign;
    input sticky;
    input c51;
    input double_precision;


    wire [105:54] sum_0, sum_1;
    wire [1:0] select, man_n;

    ME_TIEOFF t1 (, LOW) ;


    adder52
	add52_0 (			// 52-bit dual adder
		 .sum_0( sum_0[105:54] ),
		 .sum_1( sum_1[105:54] ),
		 .x( {carry[105:54]} ),
		 .y( {sum[105:54]} )
		 );

    add2_3
	add2_3 (
		c54,
		{lsb, g, r},
		{carry[53:52], LOW},
		sum[53:51],
		c51
		);

    fpm_round
	round (
	       rnd_n,
	       rnd_v,
	       lsb,
	       g,
	       r,
	       sticky,
	       sign,
	       mode[1:0]
	       );

    man_n
	man_n_0 (
		 man_n[1:0],
		 c54_n,
		 {lsb, g},
		 rnd_n,
		 c54
		 );

    man_v
	man_v_0 (
		 man_v,
		 c54_v,
		 lsb,
		 rnd_v,
		 c54
		 );

    select
	select0 (
		frac_ovf,		// fraction overflow (mantissa >= 2.0)
		select[1:0],
		sum_0[105],
		sum_1[105],
		sum_0[76],
		sum_1[76],
		c54_n,
		c54_v,
		c54,
		double_precision
		);

    inexact
	inexact0 (
	       inexact,
	       select[1],	// final_overflow (after rounding)
	       g,
	       r,
	       sticky
	       );

    ME_MUX41H53
	mux4to1 (
		 mantissa[52:0],
		 {sum_0[104:54], man_n[1:0]},
		 {sum_1[104:54], man_n[1:0]},
		 {sum_0[105:54], man_v},
		 {sum_1[105:54], man_v},
		 select[1:0]
		 );

endmodule
HierarchyFilesModulesSignalsTasksFunctionsHelp

This page: Created:Thu Aug 19 12:02:43 1999
From: ../../../sparc_v8/ssparc/fpu/fp_fpm/rtl/final_adder.v

Verilog converted to html by v2html 5.0 (written by Costas Calamvokis).Help