X-Authentication-Warning: delorie.com: mail set sender to djgpp-workers-bounces using -f
X-Recipient: djgpp-workers AT delorie DOT com
Message-ID: <55608E9F.50406@gmx.de>
Date: Sat, 23 May 2015 16:28:47 +0200
From: "Juan Manuel Guerrero (juan DOT guerrero AT gmx DOT de)" <djgpp-workers AT delorie DOT com>
User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; de; rv:1.9.2.13) Gecko/20101206 SUSE/3.1.7 Thunderbird/3.1.7
MIME-Version: 1.0
To: djgpp-workers AT delorie DOT com
Subject: Order of arguments passed to sincos changed.
Content-Type: text/plain; charset=ISO-8859-15; format=flowed
Content-Transfer-Encoding: 7bit
X-Provags-ID:  V03:K0:5/oMfjcYrfWgp5reLehkw+taRBAvnCInzeQ+xEU2VemWz/DD5yG
 wKDIhHJ0Lwn/+OJAOws76rjF4Okr3OCASCSnxBl3163Q1ygWKtCJYlnzb2JT63Bmle9KVke
 Qk1/CpdhP48pqmlk2kCQYzNPGJo7JBEKPzqVgG3G4hjUCFmhAMw6W4+CtaCG3TM+bI5P3sy
 dARiEP50mpnEeyqDDyxlg==
X-UI-Out-Filterresults: notjunk:1;
Reply-To: djgpp-workers AT delorie DOT com

OFYI, I have applied the patch below.

Regards,
Juan M. Guerrero






2015-05-17  Juan Manuel Guerrero  <juan DOT guerrero AT gmx DOT de>


	* djgpp/include/math.h:  Order of arguments of sincos function changed to
	match the order used by GNU systems.

	* djgpp/src/libc/compat/math/sincos.S:  Order of arguments of sincos function
	changed to match the order used by GNU systems.

	* djgpp/src/libc/compat/math/sincos.txh:  Order of arguments of sincos function
	changed to match the order used by GNU systems.

	* djgpp/tests/libc/compat/math/makefile:  sincos test program added.

	* djgpp/tests/libc/compat/math/sincos.c:  sincos test program added.








Index: djgpp/include/math.h
===================================================================
RCS file: /cvs/djgpp/djgpp/include/math.h,v
retrieving revision 1.25
diff -U 5 -r1.25 math.h
--- djgpp/include/math.h	16 Nov 2013 21:48:26 -0000	1.25
+++ djgpp/include/math.h	23 May 2015 13:00:30 -0000
@@ -256,11 +256,11 @@

  double exp10(double _x);
  double pow10(double _x);
  double pow2(double _x);
  double powi(double _base, int _exp);
-void   sincos(double *_cos, double *_sin, double _x);
+void   sincos(double _x, double *_sin, double *_cos);

  /* These are in libm.a (Cygnus).  You must link -lm to get these */
  /* See libm/math.h for comments */

  #ifndef __cplusplus
Index: djgpp/src/docs/kb/wc205.txi
===================================================================
RCS file: /cvs/djgpp/djgpp/src/docs/kb/wc205.txi,v
retrieving revision 1.4
diff -U 5 -r1.4 wc205.txi
--- djgpp/src/docs/kb/wc205.txi	16 May 2015 18:50:04 -0000	1.4
+++ djgpp/src/docs/kb/wc205.txi	23 May 2015 13:00:30 -0000
@@ -12,12 +12,12 @@
  @code{free}. In DJGPP v2.05, memory management was replaced by the
  @strong{nmalloc} implementation written by Charles B. Falconer (1931-2012).
  nmalloc was already used for a rather long time for various DJGPP packages
  including DJGPP port of GCC.

-@subsection Update of DXE lookup
-
+@cindex Update of @acronym{DXE3} lookup
+@cindex @env{SYSTEM_DXE_PATH}, new search path for @acronym{DXE3} modules
  Updated handling of DXE search path for relative file names

  @itemize @bullet
  @item At first, directories from @env{LD_LIBRARY_PATH} are tried. The
  predefined value of @env{LD_LIBRARY_PATH} is currently kept for
@@ -32,11 +32,14 @@

  Both environment variables contain @strong{;} separated lists of directories.
  Before DJGPP-v2.05, only @env{LD_LIBRARY_PATH} was used. The result was DXE
  lookup failure when @env{LD_LIBRARY_PATH} was redefined by user.

-@subsection Bug Fixes
-
+@cindex @file{dir.h},  fixed a wrong structure packing directive
  @file{dir.h}: Fixed a wrong structure packing directive (bug introduced by
  djgpp-v2.01 back in 1996) that would infect other sources and headers with
  potentially adverse effects. NOTE: You might want to recompile your libraries.

+@cindex @file{math.h}, order of arguments of @code{sincos} changed
+@findex sincos AT r{, order of arguments of @code{sincos} changed}
+The Order of arguments passed to the @code{sincos} function has been changed to
+match the order used by the function version as implemented in @acronym{GNU} systems.
Index: djgpp/src/libc/compat/math/sincos.S
===================================================================
RCS file: /cvs/djgpp/djgpp/src/libc/compat/math/sincos.S,v
retrieving revision 1.4
diff -U 5 -r1.4 sincos.S
--- djgpp/src/libc/compat/math/sincos.S	17 Apr 2011 18:49:47 -0000	1.4
+++ djgpp/src/libc/compat/math/sincos.S	23 May 2015 13:00:30 -0000
@@ -1,25 +1,26 @@
+/* Copyright (C) 2015 DJ Delorie, see COPYING.DJ for details */
  /* Copyright (C) 2011 DJ Delorie, see COPYING.DJ for details */
  /* Copyright (C) 1999 DJ Delorie, see COPYING.DJ for details */
  NaN:
  	.long	0x00000000, 0xFFF80000

  	.globl	_sincos
  _sincos:

-	/* void sincos(double *cosine, double *sine, double x); */
+	/* void sincos(double x, double *sine, double *cosine); */

-	movl	16(%esp), %ecx
+	movl	8(%esp), %ecx

-	movl	4(%esp), %eax		/* Point to cosine. */
-	movl	8(%esp), %edx		/* Point to sine. */
+	movl	12(%esp), %edx		/* Point to sine. */
+	movl	16(%esp), %eax		/* Point to cosine. */

  	andl	$0x7FF00000, %ecx	/* Examine exponent of x. */
  	cmpl	$0x43E00000, %ecx	/* |x| >= 2^63 */
  	jae	bigarg

-	fldl	12(%esp)
+	fldl	4(%esp)
  	fsincos
  	fstpl	(%eax)			/* cos */
  	fstpl	(%edx)			/* sin */
  	ret

Index: djgpp/src/libc/compat/math/sincos.txh
===================================================================
RCS file: /cvs/djgpp/djgpp/src/libc/compat/math/sincos.txh,v
retrieving revision 1.2
diff -U 5 -r1.2 sincos.txh
--- djgpp/src/libc/compat/math/sincos.txh	29 Jan 2003 12:36:37 -0000	1.2
+++ djgpp/src/libc/compat/math/sincos.txh	23 May 2015 13:00:30 -0000
@@ -4,11 +4,11 @@
  @subheading Syntax

  @example
  #include <math.h>

-void   sincos(double *cosine, double *sine, double x);
+void   sincos(double x, double *sine, double *cosine);
  @end example

  @subheading Description

  This function computes the cosine and the sine of @var{x} in a single
diff -aprNU5 djgpp.orig/tests/libc/compat/math/makefile djgpp/tests/libc/compat/math/makefile
--- djgpp.orig/tests/libc/compat/math/makefile	1970-01-01 00:00:00 +0000
+++ djgpp/tests/libc/compat/math/makefile	2015-05-18 00:51:30 +0000
@@ -0,0 +1,5 @@
+TOP=../..
+
+SRC += sincos.c
+
+include $(TOP)/../makefile.inc
diff -aprNU5 djgpp.orig/tests/libc/compat/math/sincos.c djgpp/tests/libc/compat/math/sincos.c
--- djgpp.orig/tests/libc/compat/math/sincos.c	1970-01-01 00:00:00 +0000
+++ djgpp/tests/libc/compat/math/sincos.c	2015-05-18 00:51:30 +0000
@@ -0,0 +1,78 @@
+#include <math.h>
+#include <stdio.h>
+
+static double argument[] = {
+  -1.5707963267948966192313216916398L,  /* -90 degree.  */
+  -1.3089969389957471826927680763665L,  /* -75 degree.  */
+  -1.0471975511965977461542144610932L,  /* -60 degree.  */
+  -0.7853981633974483096156608458199L,  /* -45 degree.  */
+  -0.5235987755982988730771072305466L,  /* -30 degree.  */
+  -0.2617993877991494365385536152733L,  /* -15 degree.  */
+  +0.0000000000000000000000000000000L,  /* +0  degree.  */
+  +0.2617993877991494365385536152733L,  /* +15 degree.  */
+  +0.5235987755982988730771072305466L,  /* +30 degree.  */
+  +0.7853981633974483096156608458199L,  /* +45 degree.  */
+  +1.0471975511965977461542144610932L,  /* +60 degree.  */
+  +1.3089969389957471826927680763665L,  /* +75 degree.  */
+  +1.5707963267948966192313216916398L,  /* +90 degree.  */
+  +2.0943951023931954923084289221863L,  /* +120 degree. */
+  +2.6179938779914943653855361527329L,  /* +150 degree. */
+  +3.1415926535897932384626433832795L,  /* +180 degree. */
+  +3.1415926535897932384626433832795L,  /* +180 degree. */
+  +3.9269908169872415480783042290994L,  /* +225 degree. */
+  +4.7123889803846898576939650749193L,  /* +270 degree. */
+  +5.4977871437821381673096259207391L,  /* +315 degree. */
+  +6.283185307179586476925286766559L,   /* +360 degree. */
+};
+
+static double should_be[][2] = {
+  /*   sine value        cosine value   */
+  {-1.000000000000000, 0.000000000000000},
+  {-0.965925826289068, 0.258819045102521},
+  {-0.866025403784439, 0.500000000000000},
+  {-0.707106781186547, 0.707106781186548},
+  {-0.500000000000000, 0.866025403784439},
+  {-0.258819045102521, 0.965925826289068},
+  {0.000000000000000, 1.000000000000000},
+  {0.258819045102521, 0.965925826289068},
+  {0.500000000000000, 0.866025403784439},
+  {0.707106781186547, 0.707106781186548},
+  {0.866025403784439, 0.500000000000000},
+  {0.965925826289068, 0.258819045102521},
+  {1.000000000000000, 0.000000000000000},
+  {0.866025403784439, -0.500000000000000},
+  {0.500000000000000, -0.866025403784439},
+  {0.000000000000000, -1.000000000000000},
+  {0.000000000000000, -1.000000000000000},
+  {-0.707106781186547, -0.707106781186548},
+  {-1.000000000000000, -0.000000000000000},
+  {-0.707106781186548, 0.707106781186547},
+  {-0.000000000000000, 1.000000000000000}
+};
+
+static const size_t n_test_arguments = sizeof(argument) / sizeof(argument[0]);
+
+
+int main(void)
+{
+  unsigned int i, error_counter;
+
+  for (error_counter = i = 0; i < n_test_arguments; i++)
+  {
+    double sv, cv;
+    sincos(argument[i], &sv, &cv);
+    if (fabs(sv - should_be[i][0]) > 1.E-15 || fabs(cv - should_be[i][1]) > 1.E-15)
+    {
+      printf("sincos failed for %.15f\n"
+             "returned values: sine value   = %.15f,  should be = %.15f\n"
+             "                 cosine value = %.15f,  should be = %.15f\n",
+             argument[i], sv, should_be[i][0], cv, should_be[i][1]);
+      error_counter++;
+    }
+  }
+
+  if (error_counter == 0)
+    printf("sincos test passed.\n");
+
+  return error_counter;
+}