99 строки
2.6 KiB
C
99 строки
2.6 KiB
C
|
/*
|
||
|
* Copyright (c) 2004-2005 The Trustees of Indiana University.
|
||
|
* All rights reserved.
|
||
|
* Copyright (c) 2004-2005 The Trustees of the University of Tennessee.
|
||
|
* All rights reserved.
|
||
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
||
|
* University of Stuttgart. All rights reserved.
|
||
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
||
|
* All rights reserved.
|
||
|
* $COPYRIGHT$
|
||
|
*
|
||
|
* Additional copyrights may follow
|
||
|
*
|
||
|
* $HEADER$
|
||
|
*/
|
||
|
|
||
|
#include "ompi_config.h"
|
||
|
|
||
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
|
||
|
#include "include/constants.h"
|
||
|
#include "util/convert.h"
|
||
|
|
||
|
|
||
|
static bool init_done = false;
|
||
|
static unsigned int int_pos = -1;
|
||
|
|
||
|
|
||
|
static void ompi_sizet2int_init(void);
|
||
|
static void warn(void);
|
||
|
|
||
|
|
||
|
int ompi_sizet2int(size_t in, int *out, bool want_check)
|
||
|
{
|
||
|
#if SIZEOF_SIZE_T <= SIZEOF_INT
|
||
|
*out = in;
|
||
|
return OMPI_SUCCESS;
|
||
|
#else
|
||
|
int *pos = (int *) ∈
|
||
|
unsigned int i;
|
||
|
|
||
|
if (!init_done) {
|
||
|
ompi_sizet2int_init();
|
||
|
}
|
||
|
|
||
|
*out = pos[int_pos];
|
||
|
if (want_check) {
|
||
|
/* Remember that size_t is signed, so we don't need to check
|
||
|
for when in < 0 (in which case the internal checks would be
|
||
|
slightly different) */
|
||
|
for (i = 0; i < (sizeof(in) / sizeof(*out)); ++i) {
|
||
|
if (i != int_pos) {
|
||
|
if (pos[i] != 0) {
|
||
|
warn();
|
||
|
return OMPI_ERR_NOT_IMPLEMENTED;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return OMPI_SUCCESS;
|
||
|
#endif
|
||
|
}
|
||
|
|
||
|
|
||
|
static void ompi_sizet2int_init(void)
|
||
|
{
|
||
|
size_t bogus = 1;
|
||
|
int *i = (int *) &bogus;
|
||
|
|
||
|
for (int_pos = 0; int_pos < (sizeof(bogus) / sizeof(int)); ++int_pos) {
|
||
|
if (i[int_pos] == 1) {
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
init_done = true;
|
||
|
}
|
||
|
|
||
|
|
||
|
static void warn(void)
|
||
|
{
|
||
|
#if OMPI_ENABLE_DEBUG
|
||
|
/* Developer builds */
|
||
|
fprintf(stderr, "WARNING: A size_t value was attempted to be cast to an int (sizeof(size_t) == %ld, sizeof(int) == %ld), but data was lost in the conversion. This should never happen (i.e., we should never try to convert a value that will be 'too big'). Since this is a developer build, I'm going to abort, and you can check the corefile. Enjoy.\n", sizeof(size_t), sizeof(int));
|
||
|
abort();
|
||
|
#else
|
||
|
static bool warned = false;
|
||
|
|
||
|
if (!warned) {
|
||
|
fprintf(stderr, "Open MPI WARNING: A bad cast (size_t->int) occurred.\n");
|
||
|
fprintf(stderr, "Please inform the Open MPI developers. This message will not repeat.\n");
|
||
|
fprintf(stderr, "Attempting to continue (no guarantees about correctness...\n");
|
||
|
warned = true;
|
||
|
}
|
||
|
#endif
|
||
|
}
|