1
1
openmpi/opal/mca/paffinity/linux/paffinity_linux.h
Jeff Squyres d9e68c1f36 - Fixes for linux paffinity component, to be able to correctly handle
all the different cases (curses to RedHat for continually changing
  the glibc API!)
- Minor fixes for the Solaris paffinity component

This commit was SVN r6894.
2005-08-16 00:11:41 +00:00

108 строки
3.5 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$
*/
/**
* @file
*
* Processor affinity for Linux.
*
* Linux sucks. There are at least 3 different ways that
* sched_setaffinity is implemented (only one of which -- the most
* outdated -- is documented in the sched_setaffinity(2) man page):
*
*-----------------------------------------------------------------
* 1. int sched_setaffinity(pid_t pid, unsigned int len, unsigned
* long *mask);
*
* This originated in 2.5 kernels (which we won't worry about) and
* some distros back-ported it to their 2.4 kernels. It's unknown if
* this appears in any 2.6 kernels.
*
* 2. int sched_setaffinity (pid_t __pid, size_t __cpusetsize,
* const cpu_set_t *__cpuset);
*
* This appears to be in recent 2.6 kernels (confirmed in Gentoo
* 2.6.11). I don't know when #1 changed into #2. However, this
* prototype is nice -- the cpu_set_t type is accompanied by
* fdset-like CPU_ZERO(), CPU_SET(), CPU_ISSET(), etc. macros.
*
* 3. int sched_setaffinity (pid_t __pid, const cpu_set_t *__mask);
*
* (note the missing len parameter) This is in at least some Linux
* distros (e.g., MDK 10.0 with a 2.6.3 kernel, and SGI Altix, even
* though the Altix uses a 2.4-based kernel and therefore likely
* back-ported the 2.5 work but modified it for their needs). Similar
* to #2, the cpu_set_t type is accompanied by fdset-like CPU_ZERO(),
* CPU_SET(), CPU_ISSET(), etc. macros.
*-----------------------------------------------------------------
*
* This component has to figure out which one to use. :-\
*
* Also note that at least some distros of Linux have a broken
* CPU_ZERO macro (a pair of typos in /usr/include/bits/sched.h).
* MDK 9.2 is the screaming example, but it's pretty old and
* probably only matters because one of the developers uses that as
* a compilation machine :-) (it also appears to have been fixed in
* MDK 10.0, but they also changed from #2 to #3 -- arrgh!).
* However, there's no way of knowing where these typos came from
* and if they exist elsewhere. So it seems safest to extend this
* configure script to check for a bad CPU_ZERO macro. #$%#@%$@!!!
*/
#ifndef MCA_PAFFINITY_LINUX_EXPORT_H
#define MCA_PAFFINITY_LINUX_EXPORT_H
#include "ompi_config.h"
#include "opal/mca/mca.h"
#include "opal/mca/paffinity/paffinity.h"
/**
* Determine whether we have a working CPU_ZERO() macro or not. If
* not, use memset().
*/
#ifdef HAVE_CPU_ZERO
#define OMPI_CPU_ZERO(foo) CPU_ZERO(foo)
#else
#include <string.h>
#define OMPI_CPU_ZERO(foo) memset(foo, 0, sizeof(*foo))
#endif
#if defined(c_plusplus) || defined(__cplusplus)
extern "C" {
#endif
/**
* Globally exported variable
*/
OMPI_COMP_EXPORT extern const opal_paffinity_base_component_1_0_0_t
mca_paffinity_linux_component;
/**
* paffinity query API function
*/
const opal_paffinity_base_module_1_0_0_t *
opal_paffinity_linux_component_query(int *query);
#if defined(c_plusplus) || defined(__cplusplus)
}
#endif
#endif /* MCA_PAFFINITY_LINUX_EXPORT_H */