1f08c3bdfSopenharmony_ci/* 2f08c3bdfSopenharmony_ci * Copyright (C) Bull S.A. 2001 3f08c3bdfSopenharmony_ci * Copyright (c) International Business Machines Corp., 2001 4f08c3bdfSopenharmony_ci * 5f08c3bdfSopenharmony_ci * This program is free software; you can redistribute it and/or modify 6f08c3bdfSopenharmony_ci * it under the terms of the GNU General Public License as published by 7f08c3bdfSopenharmony_ci * the Free Software Foundation; either version 2 of the License, or 8f08c3bdfSopenharmony_ci * (at your option) any later version. 9f08c3bdfSopenharmony_ci * 10f08c3bdfSopenharmony_ci * This program is distributed in the hope that it will be useful, 11f08c3bdfSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 12f08c3bdfSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See 13f08c3bdfSopenharmony_ci * the GNU General Public License for more details. 14f08c3bdfSopenharmony_ci * 15f08c3bdfSopenharmony_ci * You should have received a copy of the GNU General Public License 16f08c3bdfSopenharmony_ci * along with this program; if not, write to the Free Software 17f08c3bdfSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 18f08c3bdfSopenharmony_ci */ 19f08c3bdfSopenharmony_ci 20f08c3bdfSopenharmony_ci/******************************************************************************/ 21f08c3bdfSopenharmony_ci/* */ 22f08c3bdfSopenharmony_ci/* Dec-03-2001 Created: Jacky Malcles & Jean Noel Cordenner */ 23f08c3bdfSopenharmony_ci/* These tests are adapted from AIX float PVT tests. */ 24f08c3bdfSopenharmony_ci/* */ 25f08c3bdfSopenharmony_ci/******************************************************************************/ 26f08c3bdfSopenharmony_ci#include <float.h> 27f08c3bdfSopenharmony_ci#include <stdio.h> 28f08c3bdfSopenharmony_ci#include <stdlib.h> 29f08c3bdfSopenharmony_ci#include <string.h> 30f08c3bdfSopenharmony_ci#include <errno.h> 31f08c3bdfSopenharmony_ci#include <limits.h> 32f08c3bdfSopenharmony_ci#include <unistd.h> 33f08c3bdfSopenharmony_ci#include <fcntl.h> 34f08c3bdfSopenharmony_ci#include <errno.h> 35f08c3bdfSopenharmony_ci#include <sys/signal.h> 36f08c3bdfSopenharmony_ci#include <math.h> 37f08c3bdfSopenharmony_ci 38f08c3bdfSopenharmony_ci/****************************************************************** 39f08c3bdfSopenharmony_ci * 40f08c3bdfSopenharmony_ci * genldexp 41f08c3bdfSopenharmony_ci * 42f08c3bdfSopenharmony_ci * generate input and output file for the ldexp function 43f08c3bdfSopenharmony_ci * double x multiplied by 2 raised to the power y 44f08c3bdfSopenharmony_ci * 45f08c3bdfSopenharmony_ci * 46f08c3bdfSopenharmony_ci */ 47f08c3bdfSopenharmony_ci 48f08c3bdfSopenharmony_cistatic int create_Result_file(void) 49f08c3bdfSopenharmony_ci{ 50f08c3bdfSopenharmony_ci 51f08c3bdfSopenharmony_ci int i, nbVal, tabInpi[20000]; 52f08c3bdfSopenharmony_ci double tabR[20000], tabInpd[20000]; 53f08c3bdfSopenharmony_ci char *F_name; 54f08c3bdfSopenharmony_ci char *F_namini; 55f08c3bdfSopenharmony_ci char *F_namind; 56f08c3bdfSopenharmony_ci int fp, fpi, fpd; 57f08c3bdfSopenharmony_ci 58f08c3bdfSopenharmony_ci F_name = "ldexp_out.ref"; 59f08c3bdfSopenharmony_ci F_namini = "ildexp_inp.ref"; 60f08c3bdfSopenharmony_ci F_namind = "ldexp_inp.ref"; 61f08c3bdfSopenharmony_ci nbVal = 20000; 62f08c3bdfSopenharmony_ci 63f08c3bdfSopenharmony_ci fpi = open(F_namini, O_RDONLY, 0777); 64f08c3bdfSopenharmony_ci fpd = open(F_namind, O_RDONLY, 0777); 65f08c3bdfSopenharmony_ci 66f08c3bdfSopenharmony_ci if (!fpi || !fpd) { 67f08c3bdfSopenharmony_ci printf("error opening file"); 68f08c3bdfSopenharmony_ci close(fpi); 69f08c3bdfSopenharmony_ci close(fpd); 70f08c3bdfSopenharmony_ci return -1; 71f08c3bdfSopenharmony_ci } else { 72f08c3bdfSopenharmony_ci for (i = 0; i < nbVal; i++) { 73f08c3bdfSopenharmony_ci read(fpi, &(tabInpi[i]), sizeof(int)); 74f08c3bdfSopenharmony_ci read(fpd, &(tabInpd[i]), sizeof(double)); 75f08c3bdfSopenharmony_ci tabR[i] = ldexp(tabInpd[i], tabInpi[i]); 76f08c3bdfSopenharmony_ci } 77f08c3bdfSopenharmony_ci close(fpi); 78f08c3bdfSopenharmony_ci close(fpd); 79f08c3bdfSopenharmony_ci 80f08c3bdfSopenharmony_ci fp = open(F_name, O_RDWR | O_CREAT | O_TRUNC, 0777); 81f08c3bdfSopenharmony_ci if (!fp) { 82f08c3bdfSopenharmony_ci printf("error opening file"); 83f08c3bdfSopenharmony_ci close(fp); 84f08c3bdfSopenharmony_ci return -1; 85f08c3bdfSopenharmony_ci } else { 86f08c3bdfSopenharmony_ci for (i = 0; i < nbVal; i++) { 87f08c3bdfSopenharmony_ci write(fp, &tabR[i], sizeof(double)); 88f08c3bdfSopenharmony_ci } 89f08c3bdfSopenharmony_ci 90f08c3bdfSopenharmony_ci close(fp); 91f08c3bdfSopenharmony_ci return 0; 92f08c3bdfSopenharmony_ci } 93f08c3bdfSopenharmony_ci } 94f08c3bdfSopenharmony_ci} 95f08c3bdfSopenharmony_ci 96f08c3bdfSopenharmony_ci/********************************************************************* 97f08c3bdfSopenharmony_ci * 98f08c3bdfSopenharmony_ci * create input data file 99f08c3bdfSopenharmony_ci * 100f08c3bdfSopenharmony_ci * the format of the data is double x int y 101f08c3bdfSopenharmony_ci */ 102f08c3bdfSopenharmony_ci 103f08c3bdfSopenharmony_cistatic int create_Data_file(void) 104f08c3bdfSopenharmony_ci{ 105f08c3bdfSopenharmony_ci int i, nbVal; 106f08c3bdfSopenharmony_ci double tabDD[20000], tabDI[20000], Inc; 107f08c3bdfSopenharmony_ci char *F_named, *F_namei; 108f08c3bdfSopenharmony_ci int fp, fpi; 109f08c3bdfSopenharmony_ci 110f08c3bdfSopenharmony_ci F_named = "ldexp_inp.ref"; 111f08c3bdfSopenharmony_ci F_namei = "ildexp_inp.ref"; 112f08c3bdfSopenharmony_ci nbVal = 20000; 113f08c3bdfSopenharmony_ci 114f08c3bdfSopenharmony_ci Inc = exp(1) / 10; 115f08c3bdfSopenharmony_ci 116f08c3bdfSopenharmony_ci for (i = 0; i < (nbVal); i++) { 117f08c3bdfSopenharmony_ci tabDD[i] = (Inc * i) + Inc; 118f08c3bdfSopenharmony_ci tabDI[i] = nbVal - i; 119f08c3bdfSopenharmony_ci } 120f08c3bdfSopenharmony_ci 121f08c3bdfSopenharmony_ci fp = open(F_named, O_RDWR | O_CREAT | O_TRUNC, 0777); 122f08c3bdfSopenharmony_ci fpi = open(F_namei, O_RDWR | O_CREAT | O_TRUNC, 0777); 123f08c3bdfSopenharmony_ci if (!fp || !fpi) { 124f08c3bdfSopenharmony_ci printf("error opening file"); 125f08c3bdfSopenharmony_ci close(fp); 126f08c3bdfSopenharmony_ci close(fpi); 127f08c3bdfSopenharmony_ci return -1; 128f08c3bdfSopenharmony_ci } else { 129f08c3bdfSopenharmony_ci for (i = 0; i < nbVal; i++) { 130f08c3bdfSopenharmony_ci write(fp, &tabDD[i], sizeof(double)); 131f08c3bdfSopenharmony_ci write(fpi, &tabDI[i], sizeof(int)); 132f08c3bdfSopenharmony_ci } 133f08c3bdfSopenharmony_ci close(fp); 134f08c3bdfSopenharmony_ci close(fpi); 135f08c3bdfSopenharmony_ci return 0; 136f08c3bdfSopenharmony_ci } 137f08c3bdfSopenharmony_ci} 138f08c3bdfSopenharmony_ci 139f08c3bdfSopenharmony_ciint main(int argc, char *argv[]) 140f08c3bdfSopenharmony_ci{ 141f08c3bdfSopenharmony_ci 142f08c3bdfSopenharmony_ci if (argc > 1) { 143f08c3bdfSopenharmony_ci switch (atoi(argv[1])) { 144f08c3bdfSopenharmony_ci case 1: 145f08c3bdfSopenharmony_ci if (create_Data_file() == 0) 146f08c3bdfSopenharmony_ci printf("Data file created\n"); 147f08c3bdfSopenharmony_ci else 148f08c3bdfSopenharmony_ci printf("problem during %s data file creation\n", 149f08c3bdfSopenharmony_ci argv[0]); 150f08c3bdfSopenharmony_ci break; 151f08c3bdfSopenharmony_ci 152f08c3bdfSopenharmony_ci case 2: 153f08c3bdfSopenharmony_ci if (create_Result_file() == 0) 154f08c3bdfSopenharmony_ci printf("Result file created\n"); 155f08c3bdfSopenharmony_ci else 156f08c3bdfSopenharmony_ci printf 157f08c3bdfSopenharmony_ci ("problem during %s result file creation\n", 158f08c3bdfSopenharmony_ci argv[0]); 159f08c3bdfSopenharmony_ci break; 160f08c3bdfSopenharmony_ci default: 161f08c3bdfSopenharmony_ci printf("Bad arglist code for: '%s'\n", argv[0]); 162f08c3bdfSopenharmony_ci return -1; 163f08c3bdfSopenharmony_ci break; 164f08c3bdfSopenharmony_ci } 165f08c3bdfSopenharmony_ci } else { 166f08c3bdfSopenharmony_ci if (create_Data_file() != 0) 167f08c3bdfSopenharmony_ci printf("problem during %s data file creation\n", 168f08c3bdfSopenharmony_ci argv[0]); 169f08c3bdfSopenharmony_ci if (create_Result_file() != 0) 170f08c3bdfSopenharmony_ci printf("problem during %s result file creation\n", 171f08c3bdfSopenharmony_ci argv[0]); 172f08c3bdfSopenharmony_ci } 173f08c3bdfSopenharmony_ci 174f08c3bdfSopenharmony_ci return (0); 175f08c3bdfSopenharmony_ci 176f08c3bdfSopenharmony_ci} 177