diff options
author | Roland McGrath <roland@redhat.com> | 1995-05-10 15:03:48 +0000 |
---|---|---|
committer | Roland McGrath <roland@redhat.com> | 1995-05-10 15:03:48 +0000 |
commit | 7acd99c5e6267c98f03fead512f0b5a9d434044b (patch) | |
tree | 2cf78b8d923f84f7630c1cd2284ddfe9843f2320 /getloadavg.c | |
parent | d6c62b351f1f2467ec749051c620f57b8a90d095 (diff) | |
download | gunmake-7acd99c5e6267c98f03fead512f0b5a9d434044b.tar.gz |
AIX support from Tim Bell <tbel@afsmail.cern.ch>:
[_AIX] (LOAD_AVE_TYPE, FSCALE, NLIST_STRUCT): Define these for AIX.
(getloadavg) [_AIX]: Use `knlist' instead of `nlist'.
Diffstat (limited to 'getloadavg.c')
-rw-r--r-- | getloadavg.c | 46 |
1 files changed, 32 insertions, 14 deletions
diff --git a/getloadavg.c b/getloadavg.c index f03e22e..3d805ab 100644 --- a/getloadavg.c +++ b/getloadavg.c @@ -210,6 +210,10 @@ extern int errno; #define LOAD_AVE_TYPE long #endif +#ifdef _AIX +#define LOAD_AVE_TYPE long +#endif + #endif /* No LOAD_AVE_TYPE. */ #ifdef OSF_ALPHA @@ -254,6 +258,10 @@ extern int errno; #define FSCALE 100.0 #endif +#ifdef _AIX +#define FSCALE 65536.0 +#endif + #endif /* Not FSCALE. */ #if !defined (LDAV_CVT) && defined (FSCALE) @@ -315,6 +323,10 @@ extern int errno; #define NLIST_STRUCT #endif +#ifdef _AIX +#define NLIST_STRUCT +#endif + #endif /* defined (NLIST_STRUCT) */ @@ -340,7 +352,7 @@ extern int errno; #define LDAV_SYMBOL "_Loadavg" #endif -#if !defined(LDAV_SYMBOL) && ((defined(hpux) && !defined(hp9000s300)) || defined(_SEQUENT_) || defined(SVR4) || defined(ISC) || defined(sgi) || (defined (ardent) && defined (titan))) +#if !defined(LDAV_SYMBOL) && ((defined(hpux) && !defined(hp9000s300)) || defined(_SEQUENT_) || defined(SVR4) || defined(ISC) || defined(sgi) || (defined (ardent) && defined (titan)) || defined (_AIX)) #define LDAV_SYMBOL "avenrun" #endif @@ -790,23 +802,29 @@ getloadavg (loadavg, nelem) #endif /* NLIST_STRUCT */ #ifndef SUNOS_5 - if (nlist (KERNEL_FILE, nl) >= 0) - /* Omit "&& nl[0].n_type != 0 " -- it breaks on Sun386i. */ - { + if ( +#ifndef _AIX + nlist (KERNEL_FILE, nl) +#else /* _AIX */ + knlist (nl, 1, sizeof (nl[0])) +#endif + >= 0) + /* Omit "&& nl[0].n_type != 0 " -- it breaks on Sun386i. */ + { #ifdef FIXUP_KERNEL_SYMBOL_ADDR - FIXUP_KERNEL_SYMBOL_ADDR (nl); + FIXUP_KERNEL_SYMBOL_ADDR (nl); #endif - offset = nl[0].n_value; - } -#endif /* !SUNOS_5 */ -#else /* sgi */ - int ldav_off; + offset = nl[0].n_value; + } +#endif /* !SUNOS_5 */ +#else /* sgi */ + int ldav_off; - ldav_off = sysmp (MP_KERNADDR, MPKA_AVENRUN); - if (ldav_off != -1) - offset = (long) ldav_off & 0x7fffffff; + ldav_off = sysmp (MP_KERNADDR, MPKA_AVENRUN); + if (ldav_off != -1) + offset = (long) ldav_off & 0x7fffffff; #endif /* sgi */ - } + } /* Make sure we have /dev/kmem open. */ if (!getloadavg_initialized) |