2008-06-25 03:33:36 -04:00
|
|
|
/* PowerPC-32 gmp-mparam.h -- Compiler/machine parameter header file.
|
|
|
|
|
|
|
|
Copyright 1991, 1993, 1994, 1999, 2000, 2001, 2002, 2003, 2004, 2006 Free
|
|
|
|
Software Foundation, Inc.
|
|
|
|
|
|
|
|
This file is part of the GNU MP Library.
|
|
|
|
|
|
|
|
The GNU MP Library is free software; you can redistribute it and/or 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.
|
|
|
|
|
|
|
|
The GNU MP 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 Lesser General Public
|
|
|
|
License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public License
|
|
|
|
along with the GNU MP Library; see the file COPYING.LIB. If not, write to
|
|
|
|
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
|
|
MA 02110-1301, USA. */
|
|
|
|
|
|
|
|
#define BITS_PER_MP_LIMB 32
|
|
|
|
#define BYTES_PER_MP_LIMB 4
|
|
|
|
|
|
|
|
/* This file is supposed to be used for 604, 604e, 744x/745x/747x (G4+), i.e.,
|
|
|
|
32-bit PowerPC processors with reasonably fast integer multiply insns. The
|
|
|
|
values below are chosen to be best for the latter processors, since 604 is
|
|
|
|
largely irrelevant today.
|
|
|
|
|
|
|
|
In mpn/powerpc32/750/gmp-mparam.h there are values for 75x (G3) and for
|
|
|
|
7400/7410 (G4), both which have much slower multiply instructions. */
|
|
|
|
|
2009-06-02 17:25:21 -04:00
|
|
|
/* Generated by tuneup.c, 2009-06-02, gcc 4.1 */
|
2008-06-25 03:33:36 -04:00
|
|
|
|
|
|
|
#define MUL_KARATSUBA_THRESHOLD 14
|
|
|
|
#define MUL_TOOM3_THRESHOLD 73
|
2009-06-02 17:25:21 -04:00
|
|
|
#define MUL_TOOM4_THRESHOLD 169
|
|
|
|
#define MUL_TOOM7_THRESHOLD 321
|
2008-06-25 03:33:36 -04:00
|
|
|
|
|
|
|
#define SQR_BASECASE_THRESHOLD 0 /* always */
|
|
|
|
#define SQR_KARATSUBA_THRESHOLD 26
|
2009-06-02 17:25:21 -04:00
|
|
|
#define SQR_TOOM3_THRESHOLD 85
|
|
|
|
#define SQR_TOOM4_THRESHOLD 195
|
|
|
|
#define SQR_TOOM7_THRESHOLD 363
|
2008-06-25 03:33:36 -04:00
|
|
|
|
|
|
|
#define MULLOW_BASECASE_THRESHOLD 0 /* always */
|
2009-06-02 17:25:21 -04:00
|
|
|
#define MULLOW_DC_THRESHOLD 56
|
|
|
|
#define MULLOW_MUL_N_THRESHOLD 327
|
2008-06-25 03:33:36 -04:00
|
|
|
|
|
|
|
#define DIV_SB_PREINV_THRESHOLD 0 /* always */
|
2009-06-02 17:25:21 -04:00
|
|
|
#define DIV_DC_THRESHOLD 48
|
|
|
|
#define POWM_THRESHOLD 83
|
2008-06-25 03:33:36 -04:00
|
|
|
|
2009-06-02 17:25:21 -04:00
|
|
|
#define GCD_ACCEL_THRESHOLD 7
|
|
|
|
#define GCDEXT_THRESHOLD 22
|
2008-06-25 03:33:36 -04:00
|
|
|
#define JACOBI_BASE_METHOD 1
|
|
|
|
|
|
|
|
#define DIVREM_1_NORM_THRESHOLD 0 /* always */
|
|
|
|
#define DIVREM_1_UNNORM_THRESHOLD 0 /* always */
|
|
|
|
#define MOD_1_NORM_THRESHOLD 0 /* always */
|
|
|
|
#define MOD_1_UNNORM_THRESHOLD 0 /* always */
|
|
|
|
#define USE_PREINV_DIVREM_1 1
|
|
|
|
#define USE_PREINV_MOD_1 1
|
|
|
|
#define DIVREM_2_THRESHOLD 0 /* always */
|
|
|
|
#define DIVEXACT_1_THRESHOLD 0 /* always */
|
|
|
|
#define MODEXACT_1_ODD_THRESHOLD 0 /* always (native) */
|
|
|
|
|
2009-06-02 17:25:21 -04:00
|
|
|
#define GET_STR_DC_THRESHOLD 19
|
|
|
|
#define GET_STR_PRECOMPUTE_THRESHOLD 34
|
2008-06-25 03:33:36 -04:00
|
|
|
#define SET_STR_THRESHOLD 6418
|
|
|
|
|
2009-06-02 17:25:21 -04:00
|
|
|
#define MUL_FFT_TABLE { 304, 736, 896, 2560, 10240, 40960, 163840, 655360, 0 }
|
|
|
|
#define MUL_FFT_MODF_THRESHOLD 232
|
|
|
|
#define MUL_FFT_THRESHOLD 6144
|
|
|
|
|
|
|
|
#define SQR_FFT_TABLE { 272, 736, 896, 3584, 10240, 40960, 163840, 655360, 0 }
|
|
|
|
#define SQR_FFT_MODF_THRESHOLD 232
|
|
|
|
#define SQR_FFT_THRESHOLD 2304
|
|
|
|
|
|
|
|
/* Tuneup completed successfully, took 68 seconds */
|
2008-06-25 03:33:36 -04:00
|
|
|
|