1997-03-30 01:32:35 +08:00
|
|
|
/* Test program for tsearch et al.
|
2025-01-02 02:14:45 +08:00
|
|
|
Copyright (C) 1997-2025 Free Software Foundation, Inc.
|
1997-03-30 01:32:35 +08:00
|
|
|
This file is part of the GNU C Library.
|
|
|
|
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
2001-07-06 12:58:11 +08:00
|
|
|
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.
|
1997-03-30 01:32:35 +08:00
|
|
|
|
|
|
|
The GNU C Library 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
|
2001-07-06 12:58:11 +08:00
|
|
|
Lesser General Public License for more details.
|
1997-03-30 01:32:35 +08:00
|
|
|
|
2001-07-06 12:58:11 +08:00
|
|
|
You should have received a copy of the GNU Lesser General Public
|
2012-02-10 07:18:22 +08:00
|
|
|
License along with the GNU C Library; if not, see
|
Prefer https to http for gnu.org and fsf.org URLs
Also, change sources.redhat.com to sourceware.org.
This patch was automatically generated by running the following shell
script, which uses GNU sed, and which avoids modifying files imported
from upstream:
sed -ri '
s,(http|ftp)(://(.*\.)?(gnu|fsf|sourceware)\.org($|[^.]|\.[^a-z])),https\2,g
s,(http|ftp)(://(.*\.)?)sources\.redhat\.com($|[^.]|\.[^a-z]),https\2sourceware.org\4,g
' \
$(find $(git ls-files) -prune -type f \
! -name '*.po' \
! -name 'ChangeLog*' \
! -path COPYING ! -path COPYING.LIB \
! -path manual/fdl-1.3.texi ! -path manual/lgpl-2.1.texi \
! -path manual/texinfo.tex ! -path scripts/config.guess \
! -path scripts/config.sub ! -path scripts/install-sh \
! -path scripts/mkinstalldirs ! -path scripts/move-if-change \
! -path INSTALL ! -path locale/programs/charmap-kw.h \
! -path po/libc.pot ! -path sysdeps/gnu/errlist.c \
! '(' -name configure \
-execdir test -f configure.ac -o -f configure.in ';' ')' \
! '(' -name preconfigure \
-execdir test -f preconfigure.ac ';' ')' \
-print)
and then by running 'make dist-prepare' to regenerate files built
from the altered files, and then executing the following to cleanup:
chmod a+x sysdeps/unix/sysv/linux/riscv/configure
# Omit irrelevant whitespace and comment-only changes,
# perhaps from a slightly-different Autoconf version.
git checkout -f \
sysdeps/csky/configure \
sysdeps/hppa/configure \
sysdeps/riscv/configure \
sysdeps/unix/sysv/linux/csky/configure
# Omit changes that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/powerpc/powerpc64/ppc-mcount.S: trailing lines
git checkout -f \
sysdeps/powerpc/powerpc64/ppc-mcount.S \
sysdeps/unix/sysv/linux/s390/s390-64/syscall.S
# Omit change that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S: last line does not end in newline
git checkout -f sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S
2019-09-07 13:40:42 +08:00
|
|
|
<https://www.gnu.org/licenses/>. */
|
1997-03-30 01:32:35 +08:00
|
|
|
|
1997-04-09 07:42:08 +08:00
|
|
|
#ifndef _GNU_SOURCE
|
|
|
|
# define _GNU_SOURCE 1
|
|
|
|
#endif
|
1997-03-30 01:32:35 +08:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
1997-04-09 07:42:08 +08:00
|
|
|
#include <string.h>
|
1997-03-30 01:32:35 +08:00
|
|
|
#include <search.h>
|
2003-09-18 02:23:49 +08:00
|
|
|
#include <tst-stack-align.h>
|
2019-05-02 17:42:51 +08:00
|
|
|
#include <support/check.h>
|
2024-12-23 05:12:00 +08:00
|
|
|
#include <libc-diag.h>
|
1997-03-30 01:32:35 +08:00
|
|
|
|
|
|
|
#define SEED 0
|
|
|
|
#define BALANCED 1
|
|
|
|
#define PASSES 100
|
|
|
|
|
|
|
|
#if BALANCED
|
|
|
|
#include <math.h>
|
|
|
|
#define SIZE 1000
|
|
|
|
#else
|
|
|
|
#define SIZE 100
|
|
|
|
#endif
|
|
|
|
|
|
|
|
enum order
|
|
|
|
{
|
|
|
|
ascending,
|
|
|
|
descending,
|
|
|
|
randomorder
|
|
|
|
};
|
|
|
|
|
|
|
|
enum action
|
|
|
|
{
|
|
|
|
build,
|
|
|
|
build_and_del,
|
|
|
|
delete,
|
|
|
|
find
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Set to 1 if a test is flunked. */
|
|
|
|
static int error = 0;
|
|
|
|
|
|
|
|
/* The keys we add to the tree. */
|
|
|
|
static int x[SIZE];
|
|
|
|
|
|
|
|
/* Pointers into the key array, possibly permutated, to define an order
|
|
|
|
for insertion/removal. */
|
|
|
|
static int y[SIZE];
|
|
|
|
|
|
|
|
/* Flags set for each element visited during a tree walk. */
|
|
|
|
static int z[SIZE];
|
|
|
|
|
|
|
|
/* Depths for all the elements, to check that the depth is constant for
|
|
|
|
all three visits. */
|
|
|
|
static int depths[SIZE];
|
|
|
|
|
|
|
|
/* Maximum depth during a tree walk. */
|
|
|
|
static int max_depth;
|
|
|
|
|
2003-09-18 02:23:49 +08:00
|
|
|
static int stack_align_check[2];
|
|
|
|
|
2019-05-02 17:42:51 +08:00
|
|
|
/* Used to compare walk traces between the two implementations. */
|
|
|
|
struct walk_trace_element
|
|
|
|
{
|
|
|
|
const void *key;
|
|
|
|
VISIT which;
|
|
|
|
int depth;
|
|
|
|
};
|
|
|
|
#define DYNARRAY_STRUCT walk_trace_list
|
|
|
|
#define DYNARRAY_ELEMENT struct walk_trace_element
|
|
|
|
#define DYNARRAY_PREFIX walk_trace_
|
|
|
|
#define DYNARRAY_INITIAL_SIZE 0
|
|
|
|
#include <malloc/dynarray-skeleton.c>
|
|
|
|
static struct walk_trace_list walk_trace;
|
|
|
|
|
1997-03-30 01:32:35 +08:00
|
|
|
/* Compare two keys. */
|
|
|
|
static int
|
|
|
|
cmp_fn (const void *a, const void *b)
|
|
|
|
{
|
2003-09-18 02:23:49 +08:00
|
|
|
if (!stack_align_check[0])
|
|
|
|
stack_align_check[0] = TEST_STACK_ALIGN () ? -1 : 1;
|
1997-03-30 01:32:35 +08:00
|
|
|
return *(const int *) a - *(const int *) b;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Permute an array of integers. */
|
|
|
|
static void
|
|
|
|
memfry (int *string)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0; i < SIZE; ++i)
|
|
|
|
{
|
|
|
|
int32_t j;
|
|
|
|
int c;
|
|
|
|
|
|
|
|
j = random () % SIZE;
|
|
|
|
|
|
|
|
c = string[i];
|
|
|
|
string[i] = string[j];
|
|
|
|
string[j] = c;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-02 17:42:51 +08:00
|
|
|
struct twalk_with_twalk_r_closure
|
|
|
|
{
|
|
|
|
void (*action) (const void *, VISIT, int);
|
|
|
|
int depth;
|
|
|
|
};
|
|
|
|
|
|
|
|
static void
|
|
|
|
twalk_with_twalk_r_action (const void *nodep, VISIT which, void *closure0)
|
|
|
|
{
|
|
|
|
struct twalk_with_twalk_r_closure *closure = closure0;
|
|
|
|
|
|
|
|
switch (which)
|
|
|
|
{
|
|
|
|
case leaf:
|
|
|
|
closure->action (nodep, which, closure->depth);
|
|
|
|
break;
|
|
|
|
case preorder:
|
|
|
|
closure->action (nodep, which, closure->depth);
|
|
|
|
++closure->depth;
|
|
|
|
break;
|
|
|
|
case postorder:
|
|
|
|
/* The preorder action incremented the depth. */
|
|
|
|
closure->action (nodep, which, closure->depth - 1);
|
|
|
|
break;
|
|
|
|
case endorder:
|
|
|
|
--closure->depth;
|
|
|
|
closure->action (nodep, which, closure->depth);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
twalk_with_twalk_r (const void *root,
|
|
|
|
void (*action) (const void *, VISIT, int))
|
|
|
|
{
|
|
|
|
struct twalk_with_twalk_r_closure closure = { action, 0 };
|
|
|
|
twalk_r (root, twalk_with_twalk_r_action, &closure);
|
|
|
|
TEST_COMPARE (closure.depth, 0);
|
|
|
|
}
|
|
|
|
|
1997-03-30 01:32:35 +08:00
|
|
|
static void
|
|
|
|
walk_action (const void *nodep, const VISIT which, const int depth)
|
|
|
|
{
|
|
|
|
int key = **(int **) nodep;
|
|
|
|
|
2019-05-02 17:42:51 +08:00
|
|
|
walk_trace_add (&walk_trace,
|
|
|
|
(struct walk_trace_element) { nodep, which, depth });
|
|
|
|
|
2003-09-18 02:23:49 +08:00
|
|
|
if (!stack_align_check[1])
|
|
|
|
stack_align_check[1] = TEST_STACK_ALIGN () ? -1 : 1;
|
|
|
|
|
1997-03-30 01:32:35 +08:00
|
|
|
if (depth > max_depth)
|
|
|
|
max_depth = depth;
|
|
|
|
if (which == leaf || which == preorder)
|
|
|
|
{
|
|
|
|
++z[key];
|
|
|
|
depths[key] = depth;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (depths[key] != depth)
|
|
|
|
{
|
|
|
|
fputs ("Depth for one element is not constant during tree walk.\n",
|
1997-04-01 06:56:24 +08:00
|
|
|
stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2019-05-02 17:42:51 +08:00
|
|
|
walk_tree_with (void *root, int expected_count,
|
|
|
|
void (*walk) (const void *,
|
|
|
|
void (*) (const void *, VISIT, int)))
|
1997-03-30 01:32:35 +08:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
memset (z, 0, sizeof z);
|
|
|
|
max_depth = 0;
|
|
|
|
|
2019-05-02 17:42:51 +08:00
|
|
|
walk (root, walk_action);
|
1997-03-30 01:32:35 +08:00
|
|
|
for (i = 0; i < expected_count; ++i)
|
|
|
|
if (z[i] != 1)
|
|
|
|
{
|
1997-04-01 06:56:24 +08:00
|
|
|
fputs ("Node was not visited.\n", stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
error = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if BALANCED
|
|
|
|
if (max_depth > log (expected_count) * 2 + 2)
|
|
|
|
#else
|
|
|
|
if (max_depth > expected_count)
|
|
|
|
#endif
|
|
|
|
{
|
1997-04-01 06:56:24 +08:00
|
|
|
fputs ("Depth too large during tree walk.\n", stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
error = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-02 17:42:51 +08:00
|
|
|
static void
|
|
|
|
walk_tree (void *root, int expected_count)
|
|
|
|
{
|
|
|
|
walk_trace_clear (&walk_trace);
|
|
|
|
walk_tree_with (root, expected_count, twalk);
|
|
|
|
TEST_VERIFY (!walk_trace_has_failed (&walk_trace));
|
|
|
|
size_t first_list_size;
|
|
|
|
struct walk_trace_element *first_list
|
|
|
|
= walk_trace_finalize (&walk_trace, &first_list_size);
|
2019-05-03 15:22:33 +08:00
|
|
|
TEST_VERIFY_EXIT (first_list != NULL);
|
2019-05-02 17:42:51 +08:00
|
|
|
|
|
|
|
walk_tree_with (root, expected_count, twalk_with_twalk_r);
|
2019-05-03 15:22:33 +08:00
|
|
|
TEST_VERIFY (!walk_trace_has_failed (&walk_trace));
|
2019-05-02 17:42:51 +08:00
|
|
|
|
|
|
|
/* Compare the two traces. */
|
|
|
|
TEST_COMPARE (first_list_size, walk_trace_size (&walk_trace));
|
|
|
|
for (size_t i = 0; i < first_list_size && i < walk_trace_size (&walk_trace);
|
|
|
|
++i)
|
|
|
|
{
|
|
|
|
TEST_VERIFY (first_list[i].key == walk_trace_at (&walk_trace, i)->key);
|
|
|
|
TEST_COMPARE (first_list[i].which, walk_trace_at (&walk_trace, i)->which);
|
|
|
|
TEST_COMPARE (first_list[i].depth, walk_trace_at (&walk_trace, i)->depth);
|
|
|
|
}
|
|
|
|
|
|
|
|
walk_trace_free (&walk_trace);
|
|
|
|
}
|
|
|
|
|
1997-03-30 01:32:35 +08:00
|
|
|
/* Perform an operation on a tree. */
|
|
|
|
static void
|
|
|
|
mangle_tree (enum order how, enum action what, void **root, int lag)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
if (how == randomorder)
|
|
|
|
{
|
|
|
|
for (i = 0; i < SIZE; ++i)
|
|
|
|
y[i] = i;
|
|
|
|
memfry (y);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < SIZE + lag; ++i)
|
|
|
|
{
|
|
|
|
void *elem;
|
|
|
|
int j, k;
|
|
|
|
|
|
|
|
switch (how)
|
|
|
|
{
|
|
|
|
case randomorder:
|
|
|
|
if (i >= lag)
|
|
|
|
k = y[i - lag];
|
|
|
|
else
|
2001-06-05 21:38:39 +08:00
|
|
|
/* Ensure that the array index is within bounds. */
|
|
|
|
k = y[(SIZE - i - 1 + lag) % SIZE];
|
|
|
|
j = y[i % SIZE];
|
1997-03-30 01:32:35 +08:00
|
|
|
break;
|
|
|
|
|
|
|
|
case ascending:
|
|
|
|
k = i - lag;
|
|
|
|
j = i;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case descending:
|
|
|
|
k = SIZE - i - 1 + lag;
|
|
|
|
j = SIZE - i - 1;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
/* This never should happen, but gcc isn't smart enough to
|
|
|
|
recognize it. */
|
|
|
|
abort ();
|
|
|
|
}
|
|
|
|
|
2024-12-23 05:12:00 +08:00
|
|
|
DIAG_PUSH_NEEDS_COMMENT_CLANG;
|
|
|
|
DIAG_IGNORE_NEEDS_COMMENT_CLANG (3.2, "-Wimplicit-fallthrough");
|
1997-03-30 01:32:35 +08:00
|
|
|
switch (what)
|
|
|
|
{
|
|
|
|
case build_and_del:
|
|
|
|
case build:
|
|
|
|
if (i < SIZE)
|
|
|
|
{
|
Update.
1997-05-31 02:33 Ulrich Drepper <drepper@cygnus.com>
* io/ftwtest-sh: More tests.
* misc/tsearch.c: Rewrite tdestroy_recursive.
* libio/libio.h: Define bits for libg++-2.8.
1997-05-30 22:21 Thorsten Kukuk <kukuk@vt.uni-paderborn.de>
* nis/nss_nis/nis-hosts.c: Same changes as in
nss/nss_files/files-hosts.c (Always use inet_pton).
* nis/nss_nisplus/nisplus-hosts.c: Likewise.
1997-05-30 09:50 Richard Henderson <rth@tamu.edu>
* manual/maint.texi: ECOFF hasn't been tested in ages and I don't
plan on doing so ever again. Don't say alpha-linuxecoff is known
to work.
* elf/dl-lookup.c: Include <alloca.h>.
* misc/tsearch.c: Include <string.h>.
* posix/execle.c: Include <alloca.h>.
* posix/execlp.c: Likewise.
* stdio-common/printf_fphex.c: Include <string.h>.
* sunrpc/xdr.c: Include <string.h>.
* sysdeps/generic/memccpy.c: Include only <string.h>.
* sunrpc/clnt_udp.c (clntudp_call): Make fromlen a size_t to fix
parameters to network functions.
* sunrpc/pmap_rmt.c (clnt_broadcast): Likewise.
* sunrpc/svc_tcp.c (svctcp_create): Likewise with `len'.
(rendezvous_request): Likewise.
* sunrpc/svc_udp.c (svcudp_bufcreate): Likewise.
(svcudp_recv): Similar, but go through a local variable. The old code
used &xprt->xp_addrlen. Someone should determine if the type of the
structure member should be changed instead.
* sunrpc/xdr_rec.c (xdrrec_create): Expunge a ptr->int cast warning
and transform a nonsense for-loop to a closed form calculation.
(fill_input_buf): Another ptr->int warning.
* sysdeps/alpha/Makefile: Temporarily turn on -mieee globally. This
will last until I figure out how to build a parallel libm_ieee.
* sysdeps/alpha/fpu/fclrexcpt.c,
* sysdeps/alpha/fpu/fegetenv.c,
* sysdeps/alpha/fpu/fegetround.c,
* sysdeps/alpha/fpu/feholdexcpt.c,
* sysdeps/alpha/fpu/fenvbits.h,
* sysdeps/alpha/fpu/fesetenv.c,
* sysdeps/alpha/fpu/fesetround.c,
* sysdeps/alpha/fpu/feupdateenv.c,
* sysdeps/alpha/fpu/fgetexcptflg.c,
* sysdeps/alpha/fpu/fraiseexcpt.c,
* sysdeps/alpha/fpu/fsetexcptflg.c,
* sysdeps/alpha/fpu/ftestexcept.c: New files. There is, btw, a small
kernel patch that must be applied as of 2.0.31-pre1 and 2.1.41 for
this to work properly.
* sysdeps/alpha/fpu/fpu_control.h: Update copyright. Change default
FP mode to round to nearest, no exceptions as for Intel.
* sysdeps/unix/sysv/linux/alpha/setfpucw.c: Add copyright.
(rdfpcr): Use excb rather than trapb. Be more efficient about
getting at the fpcr.
(wrfpcr): Likewise.
(__setfpucw): Reformat.
* sysdeps/ieee754/huge_val.h: Change GCC's HUGE_VAL definition to use
a single DI-mode integer instead of bytes. This produces better code
on Alpha. Similar for HUGE_VALF.
* sysdeps/ieee754/nan.h: Similar for NAN. Add NANF and NANL.
* sysdeps/libm-ieee754/s_log2.c: Missing */ and weak_alias.
* sysdeps/unix/alpha/sysdep.S: Tiny cleanups.
* sysdeps/unix/sysv/linux/alpha/syscall.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/brk.S: Don't use jmp macro to make
sure the stack frame is released the very instruction before the
real jump out.
* sysdeps/unix/sysv/linux/alpha/ieee_get_fp_control.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/ieee_set_fp_control.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/gnu/types.h: Undef some bits we may
have gotten from <linux/posix_types.h>.
* sysdeps/unix/sysv/linux/alpha/ioperm.c: Add definition for Miata.
1997-05-30 13:05 Ulrich Drepper <drepper@cygnus.com>
* misc/tst-tsearch.c (mangle_tree): Update casts to prevent
warnings.
1997-05-29 14:02 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysdeps/unix/sysv/linux/sys/ttydefaults.h (CEOL, CSTATUS): Use
correct value for _POSIX_VDISABLE.
1997-05-29 13:59 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* Makefile (manual/dir-add.texi): Force execution.
1997-05-29 13:57 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysexits.h: New file.
1997-05-29 13:55 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* stdlib/strfmon.c: Don't run past EOS after `='.
1997-02-27 10:34 Richard Henderson <rth@tamu.edu>
1997-05-31 08:47:04 +08:00
|
|
|
if (tfind (x + j, (void *const *) root, cmp_fn) != NULL)
|
1997-03-30 01:32:35 +08:00
|
|
|
{
|
1997-04-01 06:56:24 +08:00
|
|
|
fputs ("Found element which is not in tree yet.\n", stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
error = 1;
|
|
|
|
}
|
|
|
|
elem = tsearch (x + j, root, cmp_fn);
|
|
|
|
if (elem == 0
|
Update.
1997-05-31 02:33 Ulrich Drepper <drepper@cygnus.com>
* io/ftwtest-sh: More tests.
* misc/tsearch.c: Rewrite tdestroy_recursive.
* libio/libio.h: Define bits for libg++-2.8.
1997-05-30 22:21 Thorsten Kukuk <kukuk@vt.uni-paderborn.de>
* nis/nss_nis/nis-hosts.c: Same changes as in
nss/nss_files/files-hosts.c (Always use inet_pton).
* nis/nss_nisplus/nisplus-hosts.c: Likewise.
1997-05-30 09:50 Richard Henderson <rth@tamu.edu>
* manual/maint.texi: ECOFF hasn't been tested in ages and I don't
plan on doing so ever again. Don't say alpha-linuxecoff is known
to work.
* elf/dl-lookup.c: Include <alloca.h>.
* misc/tsearch.c: Include <string.h>.
* posix/execle.c: Include <alloca.h>.
* posix/execlp.c: Likewise.
* stdio-common/printf_fphex.c: Include <string.h>.
* sunrpc/xdr.c: Include <string.h>.
* sysdeps/generic/memccpy.c: Include only <string.h>.
* sunrpc/clnt_udp.c (clntudp_call): Make fromlen a size_t to fix
parameters to network functions.
* sunrpc/pmap_rmt.c (clnt_broadcast): Likewise.
* sunrpc/svc_tcp.c (svctcp_create): Likewise with `len'.
(rendezvous_request): Likewise.
* sunrpc/svc_udp.c (svcudp_bufcreate): Likewise.
(svcudp_recv): Similar, but go through a local variable. The old code
used &xprt->xp_addrlen. Someone should determine if the type of the
structure member should be changed instead.
* sunrpc/xdr_rec.c (xdrrec_create): Expunge a ptr->int cast warning
and transform a nonsense for-loop to a closed form calculation.
(fill_input_buf): Another ptr->int warning.
* sysdeps/alpha/Makefile: Temporarily turn on -mieee globally. This
will last until I figure out how to build a parallel libm_ieee.
* sysdeps/alpha/fpu/fclrexcpt.c,
* sysdeps/alpha/fpu/fegetenv.c,
* sysdeps/alpha/fpu/fegetround.c,
* sysdeps/alpha/fpu/feholdexcpt.c,
* sysdeps/alpha/fpu/fenvbits.h,
* sysdeps/alpha/fpu/fesetenv.c,
* sysdeps/alpha/fpu/fesetround.c,
* sysdeps/alpha/fpu/feupdateenv.c,
* sysdeps/alpha/fpu/fgetexcptflg.c,
* sysdeps/alpha/fpu/fraiseexcpt.c,
* sysdeps/alpha/fpu/fsetexcptflg.c,
* sysdeps/alpha/fpu/ftestexcept.c: New files. There is, btw, a small
kernel patch that must be applied as of 2.0.31-pre1 and 2.1.41 for
this to work properly.
* sysdeps/alpha/fpu/fpu_control.h: Update copyright. Change default
FP mode to round to nearest, no exceptions as for Intel.
* sysdeps/unix/sysv/linux/alpha/setfpucw.c: Add copyright.
(rdfpcr): Use excb rather than trapb. Be more efficient about
getting at the fpcr.
(wrfpcr): Likewise.
(__setfpucw): Reformat.
* sysdeps/ieee754/huge_val.h: Change GCC's HUGE_VAL definition to use
a single DI-mode integer instead of bytes. This produces better code
on Alpha. Similar for HUGE_VALF.
* sysdeps/ieee754/nan.h: Similar for NAN. Add NANF and NANL.
* sysdeps/libm-ieee754/s_log2.c: Missing */ and weak_alias.
* sysdeps/unix/alpha/sysdep.S: Tiny cleanups.
* sysdeps/unix/sysv/linux/alpha/syscall.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/brk.S: Don't use jmp macro to make
sure the stack frame is released the very instruction before the
real jump out.
* sysdeps/unix/sysv/linux/alpha/ieee_get_fp_control.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/ieee_set_fp_control.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/gnu/types.h: Undef some bits we may
have gotten from <linux/posix_types.h>.
* sysdeps/unix/sysv/linux/alpha/ioperm.c: Add definition for Miata.
1997-05-30 13:05 Ulrich Drepper <drepper@cygnus.com>
* misc/tst-tsearch.c (mangle_tree): Update casts to prevent
warnings.
1997-05-29 14:02 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysdeps/unix/sysv/linux/sys/ttydefaults.h (CEOL, CSTATUS): Use
correct value for _POSIX_VDISABLE.
1997-05-29 13:59 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* Makefile (manual/dir-add.texi): Force execution.
1997-05-29 13:57 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysexits.h: New file.
1997-05-29 13:55 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* stdlib/strfmon.c: Don't run past EOS after `='.
1997-02-27 10:34 Richard Henderson <rth@tamu.edu>
1997-05-31 08:47:04 +08:00
|
|
|
|| tfind (x + j, (void *const *) root, cmp_fn) == NULL)
|
1997-03-30 01:32:35 +08:00
|
|
|
{
|
|
|
|
fputs ("Couldn't find element after it was added.\n",
|
1997-04-01 06:56:24 +08:00
|
|
|
stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
error = 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (what == build || i < lag)
|
|
|
|
break;
|
|
|
|
|
|
|
|
j = k;
|
|
|
|
/* fall through */
|
|
|
|
|
|
|
|
case delete:
|
Update.
1997-05-31 02:33 Ulrich Drepper <drepper@cygnus.com>
* io/ftwtest-sh: More tests.
* misc/tsearch.c: Rewrite tdestroy_recursive.
* libio/libio.h: Define bits for libg++-2.8.
1997-05-30 22:21 Thorsten Kukuk <kukuk@vt.uni-paderborn.de>
* nis/nss_nis/nis-hosts.c: Same changes as in
nss/nss_files/files-hosts.c (Always use inet_pton).
* nis/nss_nisplus/nisplus-hosts.c: Likewise.
1997-05-30 09:50 Richard Henderson <rth@tamu.edu>
* manual/maint.texi: ECOFF hasn't been tested in ages and I don't
plan on doing so ever again. Don't say alpha-linuxecoff is known
to work.
* elf/dl-lookup.c: Include <alloca.h>.
* misc/tsearch.c: Include <string.h>.
* posix/execle.c: Include <alloca.h>.
* posix/execlp.c: Likewise.
* stdio-common/printf_fphex.c: Include <string.h>.
* sunrpc/xdr.c: Include <string.h>.
* sysdeps/generic/memccpy.c: Include only <string.h>.
* sunrpc/clnt_udp.c (clntudp_call): Make fromlen a size_t to fix
parameters to network functions.
* sunrpc/pmap_rmt.c (clnt_broadcast): Likewise.
* sunrpc/svc_tcp.c (svctcp_create): Likewise with `len'.
(rendezvous_request): Likewise.
* sunrpc/svc_udp.c (svcudp_bufcreate): Likewise.
(svcudp_recv): Similar, but go through a local variable. The old code
used &xprt->xp_addrlen. Someone should determine if the type of the
structure member should be changed instead.
* sunrpc/xdr_rec.c (xdrrec_create): Expunge a ptr->int cast warning
and transform a nonsense for-loop to a closed form calculation.
(fill_input_buf): Another ptr->int warning.
* sysdeps/alpha/Makefile: Temporarily turn on -mieee globally. This
will last until I figure out how to build a parallel libm_ieee.
* sysdeps/alpha/fpu/fclrexcpt.c,
* sysdeps/alpha/fpu/fegetenv.c,
* sysdeps/alpha/fpu/fegetround.c,
* sysdeps/alpha/fpu/feholdexcpt.c,
* sysdeps/alpha/fpu/fenvbits.h,
* sysdeps/alpha/fpu/fesetenv.c,
* sysdeps/alpha/fpu/fesetround.c,
* sysdeps/alpha/fpu/feupdateenv.c,
* sysdeps/alpha/fpu/fgetexcptflg.c,
* sysdeps/alpha/fpu/fraiseexcpt.c,
* sysdeps/alpha/fpu/fsetexcptflg.c,
* sysdeps/alpha/fpu/ftestexcept.c: New files. There is, btw, a small
kernel patch that must be applied as of 2.0.31-pre1 and 2.1.41 for
this to work properly.
* sysdeps/alpha/fpu/fpu_control.h: Update copyright. Change default
FP mode to round to nearest, no exceptions as for Intel.
* sysdeps/unix/sysv/linux/alpha/setfpucw.c: Add copyright.
(rdfpcr): Use excb rather than trapb. Be more efficient about
getting at the fpcr.
(wrfpcr): Likewise.
(__setfpucw): Reformat.
* sysdeps/ieee754/huge_val.h: Change GCC's HUGE_VAL definition to use
a single DI-mode integer instead of bytes. This produces better code
on Alpha. Similar for HUGE_VALF.
* sysdeps/ieee754/nan.h: Similar for NAN. Add NANF and NANL.
* sysdeps/libm-ieee754/s_log2.c: Missing */ and weak_alias.
* sysdeps/unix/alpha/sysdep.S: Tiny cleanups.
* sysdeps/unix/sysv/linux/alpha/syscall.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/brk.S: Don't use jmp macro to make
sure the stack frame is released the very instruction before the
real jump out.
* sysdeps/unix/sysv/linux/alpha/ieee_get_fp_control.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/ieee_set_fp_control.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/gnu/types.h: Undef some bits we may
have gotten from <linux/posix_types.h>.
* sysdeps/unix/sysv/linux/alpha/ioperm.c: Add definition for Miata.
1997-05-30 13:05 Ulrich Drepper <drepper@cygnus.com>
* misc/tst-tsearch.c (mangle_tree): Update casts to prevent
warnings.
1997-05-29 14:02 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysdeps/unix/sysv/linux/sys/ttydefaults.h (CEOL, CSTATUS): Use
correct value for _POSIX_VDISABLE.
1997-05-29 13:59 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* Makefile (manual/dir-add.texi): Force execution.
1997-05-29 13:57 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysexits.h: New file.
1997-05-29 13:55 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* stdlib/strfmon.c: Don't run past EOS after `='.
1997-02-27 10:34 Richard Henderson <rth@tamu.edu>
1997-05-31 08:47:04 +08:00
|
|
|
elem = tfind (x + j, (void *const *) root, cmp_fn);
|
1997-03-30 01:32:35 +08:00
|
|
|
if (elem == NULL || tdelete (x + j, root, cmp_fn) == NULL)
|
|
|
|
{
|
1997-04-01 06:56:24 +08:00
|
|
|
fputs ("Error deleting element.\n", stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
error = 1;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case find:
|
Update.
1997-05-31 02:33 Ulrich Drepper <drepper@cygnus.com>
* io/ftwtest-sh: More tests.
* misc/tsearch.c: Rewrite tdestroy_recursive.
* libio/libio.h: Define bits for libg++-2.8.
1997-05-30 22:21 Thorsten Kukuk <kukuk@vt.uni-paderborn.de>
* nis/nss_nis/nis-hosts.c: Same changes as in
nss/nss_files/files-hosts.c (Always use inet_pton).
* nis/nss_nisplus/nisplus-hosts.c: Likewise.
1997-05-30 09:50 Richard Henderson <rth@tamu.edu>
* manual/maint.texi: ECOFF hasn't been tested in ages and I don't
plan on doing so ever again. Don't say alpha-linuxecoff is known
to work.
* elf/dl-lookup.c: Include <alloca.h>.
* misc/tsearch.c: Include <string.h>.
* posix/execle.c: Include <alloca.h>.
* posix/execlp.c: Likewise.
* stdio-common/printf_fphex.c: Include <string.h>.
* sunrpc/xdr.c: Include <string.h>.
* sysdeps/generic/memccpy.c: Include only <string.h>.
* sunrpc/clnt_udp.c (clntudp_call): Make fromlen a size_t to fix
parameters to network functions.
* sunrpc/pmap_rmt.c (clnt_broadcast): Likewise.
* sunrpc/svc_tcp.c (svctcp_create): Likewise with `len'.
(rendezvous_request): Likewise.
* sunrpc/svc_udp.c (svcudp_bufcreate): Likewise.
(svcudp_recv): Similar, but go through a local variable. The old code
used &xprt->xp_addrlen. Someone should determine if the type of the
structure member should be changed instead.
* sunrpc/xdr_rec.c (xdrrec_create): Expunge a ptr->int cast warning
and transform a nonsense for-loop to a closed form calculation.
(fill_input_buf): Another ptr->int warning.
* sysdeps/alpha/Makefile: Temporarily turn on -mieee globally. This
will last until I figure out how to build a parallel libm_ieee.
* sysdeps/alpha/fpu/fclrexcpt.c,
* sysdeps/alpha/fpu/fegetenv.c,
* sysdeps/alpha/fpu/fegetround.c,
* sysdeps/alpha/fpu/feholdexcpt.c,
* sysdeps/alpha/fpu/fenvbits.h,
* sysdeps/alpha/fpu/fesetenv.c,
* sysdeps/alpha/fpu/fesetround.c,
* sysdeps/alpha/fpu/feupdateenv.c,
* sysdeps/alpha/fpu/fgetexcptflg.c,
* sysdeps/alpha/fpu/fraiseexcpt.c,
* sysdeps/alpha/fpu/fsetexcptflg.c,
* sysdeps/alpha/fpu/ftestexcept.c: New files. There is, btw, a small
kernel patch that must be applied as of 2.0.31-pre1 and 2.1.41 for
this to work properly.
* sysdeps/alpha/fpu/fpu_control.h: Update copyright. Change default
FP mode to round to nearest, no exceptions as for Intel.
* sysdeps/unix/sysv/linux/alpha/setfpucw.c: Add copyright.
(rdfpcr): Use excb rather than trapb. Be more efficient about
getting at the fpcr.
(wrfpcr): Likewise.
(__setfpucw): Reformat.
* sysdeps/ieee754/huge_val.h: Change GCC's HUGE_VAL definition to use
a single DI-mode integer instead of bytes. This produces better code
on Alpha. Similar for HUGE_VALF.
* sysdeps/ieee754/nan.h: Similar for NAN. Add NANF and NANL.
* sysdeps/libm-ieee754/s_log2.c: Missing */ and weak_alias.
* sysdeps/unix/alpha/sysdep.S: Tiny cleanups.
* sysdeps/unix/sysv/linux/alpha/syscall.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/brk.S: Don't use jmp macro to make
sure the stack frame is released the very instruction before the
real jump out.
* sysdeps/unix/sysv/linux/alpha/ieee_get_fp_control.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/ieee_set_fp_control.S: Likewise.
* sysdeps/unix/sysv/linux/alpha/gnu/types.h: Undef some bits we may
have gotten from <linux/posix_types.h>.
* sysdeps/unix/sysv/linux/alpha/ioperm.c: Add definition for Miata.
1997-05-30 13:05 Ulrich Drepper <drepper@cygnus.com>
* misc/tst-tsearch.c (mangle_tree): Update casts to prevent
warnings.
1997-05-29 14:02 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysdeps/unix/sysv/linux/sys/ttydefaults.h (CEOL, CSTATUS): Use
correct value for _POSIX_VDISABLE.
1997-05-29 13:59 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* Makefile (manual/dir-add.texi): Force execution.
1997-05-29 13:57 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* sysexits.h: New file.
1997-05-29 13:55 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* stdlib/strfmon.c: Don't run past EOS after `='.
1997-02-27 10:34 Richard Henderson <rth@tamu.edu>
1997-05-31 08:47:04 +08:00
|
|
|
if (tfind (x + j, (void *const *) root, cmp_fn) == NULL)
|
1997-03-30 01:32:35 +08:00
|
|
|
{
|
1997-04-01 06:56:24 +08:00
|
|
|
fputs ("Couldn't find element after it was added.\n", stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
error = 1;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
}
|
2024-12-23 05:12:00 +08:00
|
|
|
DIAG_POP_NEEDS_COMMENT_CLANG;
|
1997-03-30 01:32:35 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-08-04 00:14:21 +08:00
|
|
|
static int
|
|
|
|
do_test (void)
|
1997-03-30 01:32:35 +08:00
|
|
|
{
|
|
|
|
int total_error = 0;
|
2000-05-05 23:29:58 +08:00
|
|
|
static char state[8] = { 1, 2, 3, 4, 5, 6, 7, 8 };
|
1997-03-30 01:32:35 +08:00
|
|
|
void *root = NULL;
|
|
|
|
int i, j;
|
|
|
|
|
|
|
|
initstate (SEED, state, 8);
|
|
|
|
|
|
|
|
for (i = 0; i < SIZE; ++i)
|
|
|
|
x[i] = i;
|
|
|
|
|
|
|
|
/* Do this loop several times to get different permutations for the
|
|
|
|
random case. */
|
1997-04-01 06:56:24 +08:00
|
|
|
fputs ("Series I\n", stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
for (i = 0; i < PASSES; ++i)
|
|
|
|
{
|
1997-04-01 06:56:24 +08:00
|
|
|
fprintf (stdout, "Pass %d... ", i + 1);
|
1997-03-30 01:32:35 +08:00
|
|
|
fflush (stdout);
|
|
|
|
error = 0;
|
|
|
|
|
|
|
|
mangle_tree (ascending, build, &root, 0);
|
|
|
|
mangle_tree (ascending, find, &root, 0);
|
|
|
|
mangle_tree (descending, find, &root, 0);
|
|
|
|
mangle_tree (randomorder, find, &root, 0);
|
|
|
|
walk_tree (root, SIZE);
|
|
|
|
mangle_tree (ascending, delete, &root, 0);
|
|
|
|
|
|
|
|
mangle_tree (ascending, build, &root, 0);
|
|
|
|
walk_tree (root, SIZE);
|
|
|
|
mangle_tree (descending, delete, &root, 0);
|
|
|
|
|
|
|
|
mangle_tree (ascending, build, &root, 0);
|
|
|
|
walk_tree (root, SIZE);
|
|
|
|
mangle_tree (randomorder, delete, &root, 0);
|
|
|
|
|
|
|
|
mangle_tree (descending, build, &root, 0);
|
|
|
|
mangle_tree (ascending, find, &root, 0);
|
|
|
|
mangle_tree (descending, find, &root, 0);
|
|
|
|
mangle_tree (randomorder, find, &root, 0);
|
|
|
|
walk_tree (root, SIZE);
|
|
|
|
mangle_tree (descending, delete, &root, 0);
|
|
|
|
|
|
|
|
mangle_tree (descending, build, &root, 0);
|
|
|
|
walk_tree (root, SIZE);
|
|
|
|
mangle_tree (descending, delete, &root, 0);
|
|
|
|
|
|
|
|
mangle_tree (descending, build, &root, 0);
|
|
|
|
walk_tree (root, SIZE);
|
|
|
|
mangle_tree (randomorder, delete, &root, 0);
|
|
|
|
|
|
|
|
mangle_tree (randomorder, build, &root, 0);
|
|
|
|
mangle_tree (ascending, find, &root, 0);
|
|
|
|
mangle_tree (descending, find, &root, 0);
|
|
|
|
mangle_tree (randomorder, find, &root, 0);
|
|
|
|
walk_tree (root, SIZE);
|
|
|
|
mangle_tree (randomorder, delete, &root, 0);
|
|
|
|
|
|
|
|
for (j = 1; j < SIZE; j *= 2)
|
|
|
|
{
|
|
|
|
mangle_tree (randomorder, build_and_del, &root, j);
|
|
|
|
}
|
|
|
|
|
1997-04-01 06:56:24 +08:00
|
|
|
fputs (error ? " failed!\n" : " ok.\n", stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
total_error |= error;
|
|
|
|
}
|
|
|
|
|
1997-04-01 06:56:24 +08:00
|
|
|
fputs ("Series II\n", stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
for (i = 1; i < SIZE; i *= 2)
|
|
|
|
{
|
1997-04-01 06:56:24 +08:00
|
|
|
fprintf (stdout, "For size %d... ", i);
|
1997-03-30 01:32:35 +08:00
|
|
|
fflush (stdout);
|
|
|
|
error = 0;
|
|
|
|
|
|
|
|
mangle_tree (ascending, build_and_del, &root, i);
|
|
|
|
mangle_tree (descending, build_and_del, &root, i);
|
|
|
|
mangle_tree (ascending, build_and_del, &root, i);
|
|
|
|
mangle_tree (descending, build_and_del, &root, i);
|
|
|
|
mangle_tree (ascending, build_and_del, &root, i);
|
|
|
|
mangle_tree (descending, build_and_del, &root, i);
|
|
|
|
mangle_tree (ascending, build_and_del, &root, i);
|
|
|
|
mangle_tree (descending, build_and_del, &root, i);
|
|
|
|
|
1997-04-01 06:56:24 +08:00
|
|
|
fputs (error ? " failed!\n" : " ok.\n", stdout);
|
1997-03-30 01:32:35 +08:00
|
|
|
total_error |= error;
|
|
|
|
}
|
|
|
|
|
2003-09-18 02:23:49 +08:00
|
|
|
for (i = 0; i < 2; ++i)
|
|
|
|
if (stack_align_check[i] == 0)
|
|
|
|
{
|
|
|
|
printf ("stack alignment check %d not run\n", i);
|
|
|
|
total_error |= 1;
|
|
|
|
}
|
|
|
|
else if (stack_align_check[i] != 1)
|
|
|
|
{
|
|
|
|
printf ("stack insufficiently aligned in check %d\n", i);
|
|
|
|
total_error |= 1;
|
|
|
|
}
|
|
|
|
|
1997-03-30 01:32:35 +08:00
|
|
|
return total_error;
|
|
|
|
}
|
2015-08-04 00:14:21 +08:00
|
|
|
|
|
|
|
#define TEST_FUNCTION do_test ()
|
|
|
|
#include "../test-skeleton.c"
|