Print this page
5261 libm should stop using synonyms.h
5298 fabs is 0-sized, confuses dis(1) and others
Reviewed by: Josef 'Jeff' Sipek <jeffpc@josefsipek.net>
Approved by: Gordon Ross <gwr@nexenta.com>


  16  * fields enclosed by brackets "[]" replaced with your own identifying
  17  * information: Portions Copyright [yyyy] [name of copyright owner]
  18  *
  19  * CDDL HEADER END
  20  */
  21 /*
  22  * Copyright 2011 Nexenta Systems, Inc.  All rights reserved.
  23  */
  24 /*
  25  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
  26  * Use is subject to license terms.
  27  */
  28 
  29         .file "isnanf.s"
  30 
  31 #include "libm.h"
  32 LIBM_ANSI_PRAGMA_WEAK(isnanf,function)
  33         .weak _isnanf
  34         .type _isnanf,@function
  35 _isnanf = __isnanf
  36 #include "libm_synonyms.h"
  37 
  38         ENTRY(isnanf)
  39         movl    4(%esp),%eax            / eax <-- x
  40         andl    $0x7fffffff,%eax        / eax <-- abs(x)
  41         subl    $0x7f800000,%eax        / ZF <-- 1      iff x is infinite
  42         jae     .nan_or_inf             / no jump iff arg. is finite
  43         movl    $0,%eax
  44         ret
  45 .nan_or_inf:
  46         jnz     .got_nan                / no jump if arg. infinite;
  47                                         / let nan waste time
  48         ret                             / %eax = 0 here
  49 .got_nan:
  50         movl    $1,%eax                 / %eax was 0, must be made 1 to
  51                                         / indicate TRUE 
  52         ret
  53         .align  4
  54         SET_SIZE(isnanf)
  55 


  16  * fields enclosed by brackets "[]" replaced with your own identifying
  17  * information: Portions Copyright [yyyy] [name of copyright owner]
  18  *
  19  * CDDL HEADER END
  20  */
  21 /*
  22  * Copyright 2011 Nexenta Systems, Inc.  All rights reserved.
  23  */
  24 /*
  25  * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
  26  * Use is subject to license terms.
  27  */
  28 
  29         .file "isnanf.s"
  30 
  31 #include "libm.h"
  32 LIBM_ANSI_PRAGMA_WEAK(isnanf,function)
  33         .weak _isnanf
  34         .type _isnanf,@function
  35 _isnanf = __isnanf

  36 
  37         ENTRY(isnanf)
  38         movl    4(%esp),%eax            / eax <-- x
  39         andl    $0x7fffffff,%eax        / eax <-- abs(x)
  40         subl    $0x7f800000,%eax        / ZF <-- 1      iff x is infinite
  41         jae     .nan_or_inf             / no jump iff arg. is finite
  42         movl    $0,%eax
  43         ret
  44 .nan_or_inf:
  45         jnz     .got_nan                / no jump if arg. infinite;
  46                                         / let nan waste time
  47         ret                             / %eax = 0 here
  48 .got_nan:
  49         movl    $1,%eax                 / %eax was 0, must be made 1 to
  50                                         / indicate TRUE 
  51         ret
  52         .align  4
  53         SET_SIZE(isnanf)
  54