From 6de3486c2c78cfbb2e9a9038593b60cfccf671a6 Mon Sep 17 00:00:00 2001 From: Matt Smith Date: Fri, 9 Apr 2010 13:32:46 -0500 Subject: [PATCH] Move contents of afs_osi_gcpags to per-OS files Moved the relevant chunks from src/afs/afs_osi_gcpags.c to osi_gcpags.c located in each of the OS subdirectories. Also updated libafs and libuafs to reflect these changes. Change-Id: I537d92952718ef3b3bb0583daf7993288716652c Reviewed-on: http://gerrit.openafs.org/1727 Reviewed-by: Derrick Brashear Tested-by: Derrick Brashear --- src/afs/AIX/osi_gcpags.c | 218 ++++++++++++ src/afs/DARWIN/osi_gcpags.c | 96 +++++ src/afs/DFBSD/osi_gcpags.c | 38 ++ src/afs/FBSD/osi_gcpags.c | 55 +++ src/afs/HPUX/osi_gcpags.c | 92 +++++ src/afs/IRIX/osi_gcpags.c | 82 +++++ src/afs/LINUX/osi_gcpags.c | 142 ++++++++ src/afs/LINUX24/osi_gcpags.c | 38 ++ src/afs/NBSD/osi_gcpags.c | 38 ++ src/afs/OBSD/osi_gcpags.c | 38 ++ src/afs/SOLARIS/osi_gcpags.c | 36 ++ src/afs/SUNOS/osi_gcpags.c | 49 +++ src/afs/UKERNEL/osi_gcpags.c | 38 ++ src/afs/afs_osi_gcpags.c | 523 ---------------------------- src/libafs/Makefile.common.in | 6 +- src/libafs/MakefileProto.AIX.in | 1 + src/libafs/MakefileProto.DARWIN.in | 1 + src/libafs/MakefileProto.DFBSD.in | 1 + src/libafs/MakefileProto.DUX.in | 1 + src/libafs/MakefileProto.FBSD.in | 1 + src/libafs/MakefileProto.HPUX.in | 1 + src/libafs/MakefileProto.IRIX.in | 1 + src/libafs/MakefileProto.LINUX.in | 1 + src/libafs/MakefileProto.NBSD.in | 1 + src/libafs/MakefileProto.OBSD.in | 1 + src/libafs/MakefileProto.SOLARIS.in | 1 + src/libuafs/Makefile.common.in | 10 + 27 files changed, 983 insertions(+), 527 deletions(-) create mode 100644 src/afs/AIX/osi_gcpags.c create mode 100644 src/afs/DARWIN/osi_gcpags.c create mode 100644 src/afs/DFBSD/osi_gcpags.c create mode 100644 src/afs/FBSD/osi_gcpags.c create mode 100644 src/afs/HPUX/osi_gcpags.c create mode 100644 src/afs/IRIX/osi_gcpags.c create mode 100644 src/afs/LINUX/osi_gcpags.c create mode 100644 src/afs/LINUX24/osi_gcpags.c create mode 100644 src/afs/NBSD/osi_gcpags.c create mode 100644 src/afs/OBSD/osi_gcpags.c create mode 100644 src/afs/SOLARIS/osi_gcpags.c create mode 100644 src/afs/SUNOS/osi_gcpags.c create mode 100644 src/afs/UKERNEL/osi_gcpags.c delete mode 100644 src/afs/afs_osi_gcpags.c diff --git a/src/afs/AIX/osi_gcpags.c b/src/afs/AIX/osi_gcpags.c new file mode 100644 index 0000000000..416b299ea3 --- /dev/null +++ b/src/afs/AIX/osi_gcpags.c @@ -0,0 +1,218 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ +#include /* for vm_att(), vm_det() */ + +#if AFS_GCPAGS + +/* afs_osi_TraverseProcTable() - Walk through the systems process + * table, calling afs_GCPAGs_perproc_func() for each process. + */ + + #ifdef AFS_AIX51_ENV +#define max_proc v.ve_proc +#endif +void +afs_osi_TraverseProcTable(void) +{ + afs_proc_t *p; + int i; + + /* + * For binary compatibility, on AIX we need to be careful to use the + * proper size of a struct proc, even if it is different from what + * we were compiled with. + */ + if (!afs_gcpags_procsize) + return; + +#ifndef AFS_AIX51_ENV + simple_lock(&proc_tbl_lock); +#endif + for (p = (afs_proc_t *)v.vb_proc, i = 0; p < max_proc; + p = (afs_proc_t *)((char *)p + afs_gcpags_procsize), i++) { + +#ifdef AFS_AIX51_ENV + if (p->p_pvprocp->pv_stat == SNONE) + continue; + if (p->p_pvprocp->pv_stat == SIDL) + continue; + if (p->p_pvprocp->pv_stat == SEXIT) + continue; +#else + if (p->p_stat == SNONE) + continue; + if (p->p_stat == SIDL) + continue; + if (p->p_stat == SEXIT) + continue; +#endif + + /* sanity check */ + + if (PROCMASK(p->p_pid) != i) { + afs_gcpags = AFS_GCPAGS_EPIDCHECK; + break; + } + + /* sanity check */ + + if ((p->p_nice < P_NICE_MIN) || (P_NICE_MAX < p->p_nice)) { + afs_gcpags = AFS_GCPAGS_ENICECHECK; + break; + } + + afs_GCPAGs_perproc_func(p); + } +#ifndef AFS_AIX51_ENV + simple_unlock(&proc_tbl_lock); +#endif +} + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + +/* GLOBAL DECLARATIONS */ + +/* + * LOCKS: the caller must do + * simple_lock(&proc_tbl_lock); + * simple_unlock(&proc_tbl_lock); + * around calls to this function. + */ + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pproc) +{ + afs_ucred_t *pcred = 0; + + /* + * pointer to process user structure valid in *our* + * address space + * + * The user structure for a process is stored in the user + * address space (as distinct from the kernel address + * space), and so to refer to the user structure of a + * different process we must employ special measures. + * + * I followed the example used in the AIX getproc() system + * call in bos/kernel/proc/getproc.c + */ + struct user *xmem_userp; + + struct xmem dp; /* ptr to xmem descriptor */ + int xm; /* xmem result */ + + if (!pproc) { + return pcred; + } + + /* + * The process private segment in which the user + * area is located may disappear. We need to increment + * its use count. Therefore we + * - get the proc_tbl_lock to hold the segment. + * - get the p_lock to lockout vm_cleardata. + * - vm_att to load the segment register (no check) + * - xmattach to bump its use count. + * - release the p_lock. + * - release the proc_tbl_lock. + * - do whatever we need. + * - xmdetach to decrement the use count. + * - vm_det to free the segment register (no check) + */ + + xmem_userp = NULL; + xm = XMEM_FAIL; + /* simple_lock(&proc_tbl_lock); */ +#ifdef __64BIT__ + if (pproc->p_adspace != vm_handle(NULLSEGID, (int32long64_t) 0)) { +#else + if (pproc->p_adspace != NULLSEGVAL) { +#endif + +#ifdef AFS_AIX51_ENV + simple_lock(&pproc->p_pvprocp->pv_lock); +#else + simple_lock(&pproc->p_lock); +#endif + + if (pproc->p_threadcount && +#ifdef AFS_AIX51_ENV + pproc->p_pvprocp->pv_threadlist) { +#else + pproc->p_threadlist) { +#endif + + /* + * arbitrarily pick the first thread in pproc + */ + struct thread *pproc_thread = +#ifdef AFS_AIX51_ENV + pproc->p_pvprocp->pv_threadlist; +#else + pproc->p_threadlist; +#endif + + /* + * location of 'struct user' in pproc's + * address space + */ + struct user *pproc_userp = pproc_thread->t_userp; + + /* + * create a pointer valid in my own address space + */ + + xmem_userp = (struct user *)vm_att(pproc->p_adspace, pproc_userp); + + dp.aspace_id = XMEM_INVAL; + xm = xmattach(xmem_userp, sizeof(*xmem_userp), &dp, SYS_ADSPACE); + } + +#ifdef AFS_AIX51_ENV + simple_unlock(&pproc->p_pvprocp->pv_lock); +#else + simple_unlock(&pproc->p_lock); +#endif + } + /* simple_unlock(&proc_tbl_lock); */ + if (xm == XMEM_SUCC) { + + static afs_ucred_t cred; + + /* + * What locking should we use to protect access to the user + * area? If needed also change the code in AIX/osi_groups.c. + */ + + /* copy cred to local address space */ + cred = *xmem_userp->U_cred; + pcred = &cred; + + xmdetach(&dp); + } + if (xmem_userp) { + vm_det((void *)xmem_userp); + } + + return pcred; +} + + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/DARWIN/osi_gcpags.c b/src/afs/DARWIN/osi_gcpags.c new file mode 100644 index 0000000000..c19ce92228 --- /dev/null +++ b/src/afs/DARWIN/osi_gcpags.c @@ -0,0 +1,96 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* afs_osi_TraverseProcTable() - Walk through the systems process + * table, calling afs_GCPAGs_perproc_func() for each process. + */ + + +#if (defined(AFS_DARWIN_ENV) && !defined(AFS_DARWIN80_ENV) +void +afs_osi_TraverseProcTable(void) +{ + afs_proc_t *p; + LIST_FOREACH(p, &allproc, p_list) { + if (p->p_stat == SIDL) + continue; + if (p->p_stat == SZOMB) + continue; + if (p->p_flag & P_SYSTEM) + continue; + afs_GCPAGs_perproc_func(p); + } +} +#endif + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + +#if defined(AFS_DARWIN80_ENV) + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + static afs_ucred_t cr; + struct ucred *pcred; + + if (pr == NULL) { + return NULL; + } + pcred = proc_ucred(pr); + cr.cr_ref = 1; + afs_set_cr_uid(&cr, afs_cr_uid(pcred)); + cr.cr_ngroups = pcred->cr_ngroups; + memcpy(cr.cr_groups, pcred->cr_groups, + NGROUPS * sizeof(gid_t)); + return &cr; +} +#else + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + static afs_ucred_t cr; + + if (pr == NULL) { + return NULL; + } + + if ((pr->p_stat == SSLEEP) || (pr->p_stat == SRUN) + || (pr->p_stat == SSTOP)) { + pcred_readlock(pr); + cr.cr_ref = 1; + afs_set_cr_uid(&cr, afs_cr_uid(pr->p_cred->pc_ucred)); + cr.cr_ngroups = pr->p_cred->pc_ucred->cr_ngroups; + memcpy(cr.cr_groups, pr->p_cred->pc_ucred->cr_groups, + NGROUPS * sizeof(gid_t)); + pcred_unlock(pr); + rv = &cr; + } + + return rv; +} + +#endif + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/DFBSD/osi_gcpags.c b/src/afs/DFBSD/osi_gcpags.c new file mode 100644 index 0000000000..a6df357004 --- /dev/null +++ b/src/afs/DFBSD/osi_gcpags.c @@ -0,0 +1,38 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + + if (pr == NULL) { + return NULL; + } + rv = pr->p_cred; + + return rv; +} + +#endif /* AFS_GCPAGS */ + diff --git a/src/afs/FBSD/osi_gcpags.c b/src/afs/FBSD/osi_gcpags.c new file mode 100644 index 0000000000..ef0e08797f --- /dev/null +++ b/src/afs/FBSD/osi_gcpags.c @@ -0,0 +1,55 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* afs_osi_TraverseProcTable() - Walk through the systems process + * table, calling afs_GCPAGs_perproc_func() for each process. + */ + + void +afs_osi_TraverseProcTable(void) +{ + afs_proc_t *p; + LIST_FOREACH(p, &allproc, p_list) { + if (p->p_stat == SIDL) + continue; + if (p->p_stat == SZOMB) + continue; + if (p->p_flag & P_SYSTEM) + continue; + afs_GCPAGs_perproc_func(p); + } +} + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + /* + * This whole function is kind of an ugly hack. For one, the + * 'const' is a lie. Also, we should probably be holding the + * proc mutex around all accesses to the credentials structure, + * but the present API does not allow this. + */ + return pr->p_ucred; +} + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/HPUX/osi_gcpags.c b/src/afs/HPUX/osi_gcpags.c new file mode 100644 index 0000000000..a8ed8ebb1d --- /dev/null +++ b/src/afs/HPUX/osi_gcpags.c @@ -0,0 +1,92 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* afs_osi_TraverseProcTable() - Walk through the systems process + * table, calling afs_GCPAGs_perproc_func() for each process. + */ + + +/* + * NOTE: h/proc_private.h gives the process table locking rules + * It indicates that access to p_cred must be protected by + * mp_mtproc_lock(p); + * mp_mtproc_unlock(p); + * + * The code in sys/pm_prot.c uses pcred_lock() to protect access to + * the process creds, and uses mp_mtproc_lock() only for audit-related + * changes. To be safe, we use both. + */ + +void +afs_osi_TraverseProcTable(void) +{ + register proc_t *p; + int endchain = 0; + + MP_SPINLOCK(activeproc_lock); + MP_SPINLOCK(sched_lock); + pcred_lock(); + + /* + * Instead of iterating through all of proc[], traverse only + * the list of active processes. As an example of this, + * see foreach_process() in sys/vm_sched.c. + * + * We hold the locks for the entire scan in order to get a + * consistent view of the current set of creds. + */ + + for (p = proc; endchain == 0; p = &proc[p->p_fandx]) { + if (p->p_fandx == 0) { + endchain = 1; + } + + if (system_proc(p)) + continue; + + mp_mtproc_lock(p); + afs_GCPAGs_perproc_func(p); + mp_mtproc_unlock(p); + } + + pcred_unlock(); + MP_SPINUNLOCK(sched_lock); + MP_SPINUNLOCK(activeproc_lock); +} + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * p) +{ + if (!p) + return; + + /* + * Cannot use afs_warnuser() here, as the code path + * eventually wants to grab sched_lock, which is + * already held here + */ + + return p_cred(p); +} + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/IRIX/osi_gcpags.c b/src/afs/IRIX/osi_gcpags.c new file mode 100644 index 0000000000..6b456d7ab0 --- /dev/null +++ b/src/afs/IRIX/osi_gcpags.c @@ -0,0 +1,82 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* afs_osi_TraverseProcTable() - Walk through the systems process + * table, calling afs_GCPAGs_perproc_func() for each process. + */ + + +#ifdef AFS_SGI65_ENV +/* TODO: Fix this later. */ +static int +SGI_ProcScanFunc(void *p, void *arg, int mode) +{ + return 0; +} +#else /* AFS_SGI65_ENV */ +static int +SGI_ProcScanFunc(proc_t * p, void *arg, int mode) +{ + afs_int32(*perproc_func) (afs_proc_t *) = arg; + int code = 0; + /* we pass in the function pointer for arg, + * mode ==0 for startup call, ==1 for each valid proc, + * and ==2 for terminate call. + */ + if (mode == 1) { + code = perproc_func(p); + } + return code; +} +#endif /* AFS_SGI65_ENV */ + +void +afs_osi_TraverseProcTable(void) +{ + procscan(SGI_ProcScanFunc, afs_GCPAGs_perproc_func); +} + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + +#if defined(AFS_SGI65_ENV) +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * p) +{ + return NULL; +} + +#else +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + + if (pr == NULL) { + return NULL; + } + rv = pr->p_cred; + + return rv; +} +#endif + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/LINUX/osi_gcpags.c b/src/afs/LINUX/osi_gcpags.c new file mode 100644 index 0000000000..f5e761862a --- /dev/null +++ b/src/afs/LINUX/osi_gcpags.c @@ -0,0 +1,142 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* afs_osi_TraverseProcTable() - Walk through the systems process + * table, calling afs_GCPAGs_perproc_func() for each process. + */ + + +#if defined(AFS_LINUX22_ENV) +#ifdef EXPORTED_TASKLIST_LOCK +extern rwlock_t tasklist_lock __attribute__((weak)); +#endif +void +afs_osi_TraverseProcTable(void) +{ +#if !defined(LINUX_KEYRING_SUPPORT) && (!defined(STRUCT_TASK_HAS_CRED) || defined(EXPORTED_RCU_READ_LOCK)) + struct task_struct *p; + +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) && defined(EXPORTED_TASKLIST_LOCK) + if (&tasklist_lock) + read_lock(&tasklist_lock); +#endif /* EXPORTED_TASKLIST_LOCK */ +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,16) +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) && defined(EXPORTED_TASKLIST_LOCK) + else +#endif /* EXPORTED_TASKLIST_LOCK && LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) */ + rcu_read_lock(); +#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,16) */ + +#ifdef DEFINED_FOR_EACH_PROCESS + for_each_process(p) if (p->pid) { +#ifdef STRUCT_TASK_STRUCT_HAS_EXIT_STATE + if (p->exit_state) + continue; +#else + if (p->state & TASK_ZOMBIE) + continue; +#endif + afs_GCPAGs_perproc_func(p); + } +#else + for_each_task(p) if (p->pid) { +#ifdef STRUCT_TASK_STRUCT_HAS_EXIT_STATE + if (p->exit_state) + continue; +#else + if (p->state & TASK_ZOMBIE) + continue; +#endif + afs_GCPAGs_perproc_func(p); + } +#endif +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) && defined(EXPORTED_TASKLIST_LOCK) + if (&tasklist_lock) + read_unlock(&tasklist_lock); +#endif /* EXPORTED_TASKLIST_LOCK */ +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,16) +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) && defined(EXPORTED_TASKLIST_LOCK) + else +#endif /* EXPORTED_TASKLIST_LOCK && LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) */ + rcu_read_unlock(); +#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,16) */ +#endif +} + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + +#if !defined(LINUX_KEYRING_SUPPORT) && (!defined(STRUCT_TASK_HAS_CRED) || defined(EXPORTED_RCU_READ_LOCK)) +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + static afs_ucred_t cr; + + if (pr == NULL) { + return NULL; + } + + if ((pr->state == TASK_RUNNING) || (pr->state == TASK_INTERRUPTIBLE) + || (pr->state == TASK_UNINTERRUPTIBLE) + || (pr->state == TASK_STOPPED)) { + /* This is dangerous. If anyone ever crfree's the cred that's + * returned from here, we'll go boom, because it's statically + * allocated. */ + atomic_set(&cr.cr_ref, 1); + afs_set_cr_uid(&cr, task_uid(pr)); +#if defined(AFS_LINUX26_ENV) +#if defined(STRUCT_TASK_HAS_CRED) + get_group_info(pr->cred->group_info); + set_cr_group_info(&cr, pr->cred->group_info); +#else + get_group_info(pr->group_info); + set_cr_group_info(&cr, pr->group_info); +#endif +#else + cr.cr_ngroups = pr->ngroups; + memcpy(cr.cr_groups, pr->groups, NGROUPS * sizeof(gid_t)); +#endif + rv = &cr; + } + + return rv; +} +#endif + +#else + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + + if (pr == NULL) { + return NULL; + } + rv = pr->p_cred; + + return rv; +} + +#endif /* AFS_LINUX22_ENV */ + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/LINUX24/osi_gcpags.c b/src/afs/LINUX24/osi_gcpags.c new file mode 100644 index 0000000000..96ebfe4564 --- /dev/null +++ b/src/afs/LINUX24/osi_gcpags.c @@ -0,0 +1,38 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + + if (pr == NULL) { + return NULL; + } + rv = pr->p_cred; + + return rv; +} + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/NBSD/osi_gcpags.c b/src/afs/NBSD/osi_gcpags.c new file mode 100644 index 0000000000..96ebfe4564 --- /dev/null +++ b/src/afs/NBSD/osi_gcpags.c @@ -0,0 +1,38 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + + if (pr == NULL) { + return NULL; + } + rv = pr->p_cred; + + return rv; +} + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/OBSD/osi_gcpags.c b/src/afs/OBSD/osi_gcpags.c new file mode 100644 index 0000000000..96ebfe4564 --- /dev/null +++ b/src/afs/OBSD/osi_gcpags.c @@ -0,0 +1,38 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + + if (pr == NULL) { + return NULL; + } + rv = pr->p_cred; + + return rv; +} + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/SOLARIS/osi_gcpags.c b/src/afs/SOLARIS/osi_gcpags.c new file mode 100644 index 0000000000..0df5db6c0b --- /dev/null +++ b/src/afs/SOLARIS/osi_gcpags.c @@ -0,0 +1,36 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + + if (pr == NULL) { + return NULL; + } + rv = pr->p_cred; + + return rv; +} + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/SUNOS/osi_gcpags.c b/src/afs/SUNOS/osi_gcpags.c new file mode 100644 index 0000000000..31110601b0 --- /dev/null +++ b/src/afs/SUNOS/osi_gcpags.c @@ -0,0 +1,49 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +#if defined(AFS_SUN5_ENV) +void +afs_osi_TraverseProcTable(void) +{ + afs_proc_t *prp; + for (prp = practive; prp != NULL; prp = prp->p_next) { + afs_GCPAGs_perproc_func(prp); + } +} +#endif + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + + if (pr == NULL) { + return NULL; + } + rv = pr->p_cred; + + return rv; +} + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/UKERNEL/osi_gcpags.c b/src/afs/UKERNEL/osi_gcpags.c new file mode 100644 index 0000000000..96ebfe4564 --- /dev/null +++ b/src/afs/UKERNEL/osi_gcpags.c @@ -0,0 +1,38 @@ +/* + * Copyright 2000, International Business Machines Corporation and others. + * All Rights Reserved. + * + * This software has been released under the terms of the IBM Public + * License. For details, see the LICENSE file in the top-level source + * directory or online at http://www.openafs.org/dl/license10.html + */ + +#include +#include "afs/param.h" + +#include "afs/sysincludes.h" /* Standard vendor system headers */ +#include "afsincludes.h" /* Afs-based standard headers */ +#include "afs/afs_stats.h" /* afs statistics */ + +#if AFS_GCPAGS + +/* return a pointer (sometimes a static copy ) to the cred for a + * given afs_proc_t. + * subsequent calls may overwrite the previously returned value. + */ + + +const afs_ucred_t * +afs_osi_proc2cred(afs_proc_t * pr) +{ + afs_ucred_t *rv = NULL; + + if (pr == NULL) { + return NULL; + } + rv = pr->p_cred; + + return rv; +} + +#endif /* AFS_GCPAGS */ diff --git a/src/afs/afs_osi_gcpags.c b/src/afs/afs_osi_gcpags.c deleted file mode 100644 index 2a1306574c..0000000000 --- a/src/afs/afs_osi_gcpags.c +++ /dev/null @@ -1,523 +0,0 @@ -/* - * Copyright 2000, International Business Machines Corporation and others. - * All Rights Reserved. - * - * This software has been released under the terms of the IBM Public - * License. For details, see the LICENSE file in the top-level source - * directory or online at http://www.openafs.org/dl/license10.html - */ - -#include -#include "afs/param.h" - - -#include "afs/sysincludes.h" /* Standard vendor system headers */ -#include "afsincludes.h" /* Afs-based standard headers */ -#include "afs/afs_stats.h" /* afs statistics */ -#ifdef AFS_AIX_ENV -#include /* for vm_att(), vm_det() */ -#endif - -#if AFS_GCPAGS - -/* afs_osi_TraverseProcTable() - Walk through the systems process - * table, calling afs_GCPAGs_perproc_func() for each process. - */ - -#if defined(AFS_SUN5_ENV) -void -afs_osi_TraverseProcTable(void) -{ - afs_proc_t *prp; - for (prp = practive; prp != NULL; prp = prp->p_next) { - afs_GCPAGs_perproc_func(prp); - } -} -#endif - -#if defined(AFS_HPUX_ENV) - -/* - * NOTE: h/proc_private.h gives the process table locking rules - * It indicates that access to p_cred must be protected by - * mp_mtproc_lock(p); - * mp_mtproc_unlock(p); - * - * The code in sys/pm_prot.c uses pcred_lock() to protect access to - * the process creds, and uses mp_mtproc_lock() only for audit-related - * changes. To be safe, we use both. - */ - -void -afs_osi_TraverseProcTable(void) -{ - register proc_t *p; - int endchain = 0; - - MP_SPINLOCK(activeproc_lock); - MP_SPINLOCK(sched_lock); - pcred_lock(); - - /* - * Instead of iterating through all of proc[], traverse only - * the list of active processes. As an example of this, - * see foreach_process() in sys/vm_sched.c. - * - * We hold the locks for the entire scan in order to get a - * consistent view of the current set of creds. - */ - - for (p = proc; endchain == 0; p = &proc[p->p_fandx]) { - if (p->p_fandx == 0) { - endchain = 1; - } - - if (system_proc(p)) - continue; - - mp_mtproc_lock(p); - afs_GCPAGs_perproc_func(p); - mp_mtproc_unlock(p); - } - - pcred_unlock(); - MP_SPINUNLOCK(sched_lock); - MP_SPINUNLOCK(activeproc_lock); -} -#endif - -#if defined(AFS_SGI_ENV) - -#ifdef AFS_SGI65_ENV -/* TODO: Fix this later. */ -static int -SGI_ProcScanFunc(void *p, void *arg, int mode) -{ - return 0; -} -#else /* AFS_SGI65_ENV */ -static int -SGI_ProcScanFunc(proc_t * p, void *arg, int mode) -{ - afs_int32(*perproc_func) (afs_proc_t *) = arg; - int code = 0; - /* we pass in the function pointer for arg, - * mode ==0 for startup call, ==1 for each valid proc, - * and ==2 for terminate call. - */ - if (mode == 1) { - code = perproc_func(p); - } - return code; -} -#endif /* AFS_SGI65_ENV */ - -void -afs_osi_TraverseProcTable(void) -{ - procscan(SGI_ProcScanFunc, afs_GCPAGs_perproc_func); -} -#endif /* AFS_SGI_ENV */ - -#if defined(AFS_AIX_ENV) -#ifdef AFS_AIX51_ENV -#define max_proc v.ve_proc -#endif -void -afs_osi_TraverseProcTable(void) -{ - afs_proc_t *p; - int i; - - /* - * For binary compatibility, on AIX we need to be careful to use the - * proper size of a struct proc, even if it is different from what - * we were compiled with. - */ - if (!afs_gcpags_procsize) - return; - -#ifndef AFS_AIX51_ENV - simple_lock(&proc_tbl_lock); -#endif - for (p = (afs_proc_t *)v.vb_proc, i = 0; p < max_proc; - p = (afs_proc_t *)((char *)p + afs_gcpags_procsize), i++) { - -#ifdef AFS_AIX51_ENV - if (p->p_pvprocp->pv_stat == SNONE) - continue; - if (p->p_pvprocp->pv_stat == SIDL) - continue; - if (p->p_pvprocp->pv_stat == SEXIT) - continue; -#else - if (p->p_stat == SNONE) - continue; - if (p->p_stat == SIDL) - continue; - if (p->p_stat == SEXIT) - continue; -#endif - - /* sanity check */ - - if (PROCMASK(p->p_pid) != i) { - afs_gcpags = AFS_GCPAGS_EPIDCHECK; - break; - } - - /* sanity check */ - - if ((p->p_nice < P_NICE_MIN) || (P_NICE_MAX < p->p_nice)) { - afs_gcpags = AFS_GCPAGS_ENICECHECK; - break; - } - - afs_GCPAGs_perproc_func(p); - } -#ifndef AFS_AIX51_ENV - simple_unlock(&proc_tbl_lock); -#endif -} -#endif - -#if (defined(AFS_DARWIN_ENV) && !defined(AFS_DARWIN80_ENV)) || defined(AFS_FBSD_ENV) -void -afs_osi_TraverseProcTable(void) -{ - afs_proc_t *p; - LIST_FOREACH(p, &allproc, p_list) { - if (p->p_stat == SIDL) - continue; - if (p->p_stat == SZOMB) - continue; - if (p->p_flag & P_SYSTEM) - continue; - afs_GCPAGs_perproc_func(p); - } -} -#endif - -#if defined(AFS_LINUX22_ENV) -#ifdef EXPORTED_TASKLIST_LOCK -extern rwlock_t tasklist_lock __attribute__((weak)); -#endif -void -afs_osi_TraverseProcTable(void) -{ -#if !defined(LINUX_KEYRING_SUPPORT) && (!defined(STRUCT_TASK_HAS_CRED) || defined(EXPORTED_RCU_READ_LOCK)) - struct task_struct *p; - -#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) && defined(EXPORTED_TASKLIST_LOCK) - if (&tasklist_lock) - read_lock(&tasklist_lock); -#endif /* EXPORTED_TASKLIST_LOCK */ -#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,16) -#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) && defined(EXPORTED_TASKLIST_LOCK) - else -#endif /* EXPORTED_TASKLIST_LOCK && LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) */ - rcu_read_lock(); -#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,16) */ - -#ifdef DEFINED_FOR_EACH_PROCESS - for_each_process(p) if (p->pid) { -#ifdef STRUCT_TASK_STRUCT_HAS_EXIT_STATE - if (p->exit_state) - continue; -#else - if (p->state & TASK_ZOMBIE) - continue; -#endif - afs_GCPAGs_perproc_func(p); - } -#else - for_each_task(p) if (p->pid) { -#ifdef STRUCT_TASK_STRUCT_HAS_EXIT_STATE - if (p->exit_state) - continue; -#else - if (p->state & TASK_ZOMBIE) - continue; -#endif - afs_GCPAGs_perproc_func(p); - } -#endif -#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) && defined(EXPORTED_TASKLIST_LOCK) - if (&tasklist_lock) - read_unlock(&tasklist_lock); -#endif /* EXPORTED_TASKLIST_LOCK */ -#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,16) -#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) && defined(EXPORTED_TASKLIST_LOCK) - else -#endif /* EXPORTED_TASKLIST_LOCK && LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18) */ - rcu_read_unlock(); -#endif /* LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,16) */ -#endif -} -#endif - -/* return a pointer (sometimes a static copy ) to the cred for a - * given afs_proc_t. - * subsequent calls may overwrite the previously returned value. - */ - -#if defined(AFS_SGI65_ENV) -const afs_ucred_t * -afs_osi_proc2cred(afs_proc_t * p) -{ - return NULL; -} -#elif defined(AFS_HPUX_ENV) -const afs_ucred_t * -afs_osi_proc2cred(afs_proc_t * p) -{ - if (!p) - return; - - /* - * Cannot use afs_warnuser() here, as the code path - * eventually wants to grab sched_lock, which is - * already held here - */ - - return p_cred(p); -} -#elif defined(AFS_AIX_ENV) - -/* GLOBAL DECLARATIONS */ - -/* - * LOCKS: the caller must do - * simple_lock(&proc_tbl_lock); - * simple_unlock(&proc_tbl_lock); - * around calls to this function. - */ - -const afs_ucred_t * -afs_osi_proc2cred(afs_proc_t * pproc) -{ - afs_ucred_t *pcred = 0; - - /* - * pointer to process user structure valid in *our* - * address space - * - * The user structure for a process is stored in the user - * address space (as distinct from the kernel address - * space), and so to refer to the user structure of a - * different process we must employ special measures. - * - * I followed the example used in the AIX getproc() system - * call in bos/kernel/proc/getproc.c - */ - struct user *xmem_userp; - - struct xmem dp; /* ptr to xmem descriptor */ - int xm; /* xmem result */ - - if (!pproc) { - return pcred; - } - - /* - * The process private segment in which the user - * area is located may disappear. We need to increment - * its use count. Therefore we - * - get the proc_tbl_lock to hold the segment. - * - get the p_lock to lockout vm_cleardata. - * - vm_att to load the segment register (no check) - * - xmattach to bump its use count. - * - release the p_lock. - * - release the proc_tbl_lock. - * - do whatever we need. - * - xmdetach to decrement the use count. - * - vm_det to free the segment register (no check) - */ - - xmem_userp = NULL; - xm = XMEM_FAIL; - /* simple_lock(&proc_tbl_lock); */ -#ifdef __64BIT__ - if (pproc->p_adspace != vm_handle(NULLSEGID, (int32long64_t) 0)) { -#else - if (pproc->p_adspace != NULLSEGVAL) { -#endif - -#ifdef AFS_AIX51_ENV - simple_lock(&pproc->p_pvprocp->pv_lock); -#else - simple_lock(&pproc->p_lock); -#endif - - if (pproc->p_threadcount && -#ifdef AFS_AIX51_ENV - pproc->p_pvprocp->pv_threadlist) { -#else - pproc->p_threadlist) { -#endif - - /* - * arbitrarily pick the first thread in pproc - */ - struct thread *pproc_thread = -#ifdef AFS_AIX51_ENV - pproc->p_pvprocp->pv_threadlist; -#else - pproc->p_threadlist; -#endif - - /* - * location of 'struct user' in pproc's - * address space - */ - struct user *pproc_userp = pproc_thread->t_userp; - - /* - * create a pointer valid in my own address space - */ - - xmem_userp = (struct user *)vm_att(pproc->p_adspace, pproc_userp); - - dp.aspace_id = XMEM_INVAL; - xm = xmattach(xmem_userp, sizeof(*xmem_userp), &dp, SYS_ADSPACE); - } - -#ifdef AFS_AIX51_ENV - simple_unlock(&pproc->p_pvprocp->pv_lock); -#else - simple_unlock(&pproc->p_lock); -#endif - } - /* simple_unlock(&proc_tbl_lock); */ - if (xm == XMEM_SUCC) { - - static afs_ucred_t cred; - - /* - * What locking should we use to protect access to the user - * area? If needed also change the code in AIX/osi_groups.c. - */ - - /* copy cred to local address space */ - cred = *xmem_userp->U_cred; - pcred = &cred; - - xmdetach(&dp); - } - if (xmem_userp) { - vm_det((void *)xmem_userp); - } - - return pcred; -} - -#elif defined(AFS_DARWIN80_ENV) -const afs_ucred_t * -afs_osi_proc2cred(afs_proc_t * pr) -{ - afs_ucred_t *rv = NULL; - static afs_ucred_t cr; - struct ucred *pcred; - - if (pr == NULL) { - return NULL; - } - pcred = proc_ucred(pr); - cr.cr_ref = 1; - afs_set_cr_uid(&cr, afs_cr_uid(pcred)); - cr.cr_ngroups = pcred->cr_ngroups; - memcpy(cr.cr_groups, pcred->cr_groups, - NGROUPS * sizeof(gid_t)); - return &cr; -} -#elif defined(AFS_FBSD_ENV) -const afs_ucred_t * -afs_osi_proc2cred(afs_proc_t * pr) -{ - /* - * This whole function is kind of an ugly hack. For one, the - * 'const' is a lie. Also, we should probably be holding the - * proc mutex around all accesses to the credentials structure, - * but the present API does not allow this. - */ - return pr->p_ucred; -} -#elif defined(AFS_DARWIN_ENV) -const afs_ucred_t * -afs_osi_proc2cred(afs_proc_t * pr) -{ - afs_ucred_t *rv = NULL; - static afs_ucred_t cr; - - if (pr == NULL) { - return NULL; - } - - if ((pr->p_stat == SSLEEP) || (pr->p_stat == SRUN) - || (pr->p_stat == SSTOP)) { - pcred_readlock(pr); - cr.cr_ref = 1; - afs_set_cr_uid(&cr, afs_cr_uid(pr->p_cred->pc_ucred)); - cr.cr_ngroups = pr->p_cred->pc_ucred->cr_ngroups; - memcpy(cr.cr_groups, pr->p_cred->pc_ucred->cr_groups, - NGROUPS * sizeof(gid_t)); - pcred_unlock(pr); - rv = &cr; - } - - return rv; -} -#elif defined(AFS_LINUX22_ENV) -#if !defined(LINUX_KEYRING_SUPPORT) && (!defined(STRUCT_TASK_HAS_CRED) || defined(EXPORTED_RCU_READ_LOCK)) -const afs_ucred_t * -afs_osi_proc2cred(afs_proc_t * pr) -{ - afs_ucred_t *rv = NULL; - static afs_ucred_t cr; - - if (pr == NULL) { - return NULL; - } - - if ((pr->state == TASK_RUNNING) || (pr->state == TASK_INTERRUPTIBLE) - || (pr->state == TASK_UNINTERRUPTIBLE) - || (pr->state == TASK_STOPPED)) { - /* This is dangerous. If anyone ever crfree's the cred that's - * returned from here, we'll go boom, because it's statically - * allocated. */ - atomic_set(&cr.cr_ref, 1); - afs_set_cr_uid(&cr, task_uid(pr)); -#if defined(AFS_LINUX26_ENV) -#if defined(STRUCT_TASK_HAS_CRED) - get_group_info(pr->cred->group_info); - set_cr_group_info(&cr, pr->cred->group_info); -#else - get_group_info(pr->group_info); - set_cr_group_info(&cr, pr->group_info); -#endif -#else - cr.cr_ngroups = pr->ngroups; - memcpy(cr.cr_groups, pr->groups, NGROUPS * sizeof(gid_t)); -#endif - rv = &cr; - } - - return rv; -} -#endif -#else -const afs_ucred_t * -afs_osi_proc2cred(afs_proc_t * pr) -{ - afs_ucred_t *rv = NULL; - - if (pr == NULL) { - return NULL; - } - rv = pr->p_cred; - - return rv; -} -#endif - -#endif /* AFS_GCPAGS */ diff --git a/src/libafs/Makefile.common.in b/src/libafs/Makefile.common.in index 907fb81d6a..b4f9dd3a31 100644 --- a/src/libafs/Makefile.common.in +++ b/src/libafs/Makefile.common.in @@ -99,7 +99,6 @@ AFSAOBJS = \ afs_osi.o \ afs_osidnlc.o \ afs_osi_alloc.o \ - afs_osi_gcpags.o \ afs_osi_pag.o \ afs_osi_uio.o \ afs_osi_vget.o \ @@ -192,7 +191,6 @@ AFSPAGOBJS = \ afs_lock.o \ afs_osi.o \ afs_osi_alloc.o \ - afs_osi_gcpags.o \ afs_osi_pag.o \ afs_pag_call.o \ afs_pag_cred.o \ @@ -274,8 +272,6 @@ afs_osi.o: $(TOP_SRC_AFS)/afs_osi.c $(CRULE_OPT) afs_osi_alloc.o: $(TOP_SRC_AFS)/afs_osi_alloc.c $(CRULE_OPT) -afs_osi_gcpags.o: $(TOP_SRC_AFS)/afs_osi_gcpags.c - $(CRULE_OPT) afs_osi_pag.o: $(TOP_SRC_AFS)/afs_osi_pag.c $(CRULE_OPT) afs_osi_uio.o: $(TOP_SRC_AFS)/afs_osi_uio.c @@ -473,6 +469,8 @@ afs_pag_user.o: $(TOP_SRC_AFS)/afs_user.c # in the per-platform Makefiles. osi_groups.o: $(TOP_SRCDIR)/afs/$(MKAFS_OSTYPE)/osi_groups.c $(CRULE_NOOPT) +osi_gcpags.o: $(TOP_SRCDIR)/afs/$(MKAFS_OSTYPE)/osi_gcpags.c + $(CRULE_NOOPT) osi_inode.o: $(TOP_SRCDIR)/afs/$(MKAFS_OSTYPE)/osi_inode.c $(CRULE_NOOPT) osi_file.o: $(TOP_SRCDIR)/afs/$(MKAFS_OSTYPE)/osi_file.c diff --git a/src/libafs/MakefileProto.AIX.in b/src/libafs/MakefileProto.AIX.in index ab60fb548b..967dbc64da 100644 --- a/src/libafs/MakefileProto.AIX.in +++ b/src/libafs/MakefileProto.AIX.in @@ -16,6 +16,7 @@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ AFS_OS_OBJS = \ osi_assem.o \ osi_config.o \ + osi_gcpags.o \ osi_groups.o \ osi_file.o \ osi_inode.o \ diff --git a/src/libafs/MakefileProto.DARWIN.in b/src/libafs/MakefileProto.DARWIN.in index 64823fd47b..4f070862a8 100644 --- a/src/libafs/MakefileProto.DARWIN.in +++ b/src/libafs/MakefileProto.DARWIN.in @@ -21,6 +21,7 @@ AFS_OS_OBJS = \ osi_misc.o \ osi_file.o \ osi_inode.o \ + osi_gcpags.o \ osi_groups.o \ osi_sleep.o \ osi_vm.o \ diff --git a/src/libafs/MakefileProto.DFBSD.in b/src/libafs/MakefileProto.DFBSD.in index d9293e401d..5f24c4c354 100644 --- a/src/libafs/MakefileProto.DFBSD.in +++ b/src/libafs/MakefileProto.DFBSD.in @@ -11,6 +11,7 @@ include @TOP_OBJDIR@/src/config/Makefile.config # OS specific object files: AFS_OS_OBJS = \ + osi_gcpags.o \ osi_groups.o \ osi_file.o \ osi_inode.o \ diff --git a/src/libafs/MakefileProto.DUX.in b/src/libafs/MakefileProto.DUX.in index 1f788b7b64..f750fe9140 100644 --- a/src/libafs/MakefileProto.DUX.in +++ b/src/libafs/MakefileProto.DUX.in @@ -15,6 +15,7 @@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ # OS specific object files: AFS_OS_OBJS = \ + osi_gcpags.o \ osi_groups.o \ osi_file.o \ osi_inode.o \ diff --git a/src/libafs/MakefileProto.FBSD.in b/src/libafs/MakefileProto.FBSD.in index e10e464883..49a1f970f0 100644 --- a/src/libafs/MakefileProto.FBSD.in +++ b/src/libafs/MakefileProto.FBSD.in @@ -15,6 +15,7 @@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ # OS specific object files: AFS_OS_OBJS = \ + osi_gcpags.o \ osi_groups.o \ osi_file.o \ osi_inode.o \ diff --git a/src/libafs/MakefileProto.HPUX.in b/src/libafs/MakefileProto.HPUX.in index cc06c03de8..818cf589b9 100644 --- a/src/libafs/MakefileProto.HPUX.in +++ b/src/libafs/MakefileProto.HPUX.in @@ -16,6 +16,7 @@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ # OS specific object files: AFS_OS_OBJS = \ osi_debug.o \ + osi_gcpags.o \ osi_groups.o \ osi_inode.o \ osi_file.o \ diff --git a/src/libafs/MakefileProto.IRIX.in b/src/libafs/MakefileProto.IRIX.in index a972c23459..00ec707c71 100644 --- a/src/libafs/MakefileProto.IRIX.in +++ b/src/libafs/MakefileProto.IRIX.in @@ -16,6 +16,7 @@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ # OS specific object files: AFS_OS_OBJS = \ base64.o \ + osi_gcpags.o \ osi_groups.o \ osi_idbg.o \ osi_file.o \ diff --git a/src/libafs/MakefileProto.LINUX.in b/src/libafs/MakefileProto.LINUX.in index 5a35d9d47b..f2cdaf112f 100644 --- a/src/libafs/MakefileProto.LINUX.in +++ b/src/libafs/MakefileProto.LINUX.in @@ -23,6 +23,7 @@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ AFS_OS_OBJS = \ osi_alloc.o \ osi_cred.o \ + osi_gcpags.o \ osi_groups.o \ osi_inode.o \ osi_file.o \ diff --git a/src/libafs/MakefileProto.NBSD.in b/src/libafs/MakefileProto.NBSD.in index ae28384771..72fa2b515a 100644 --- a/src/libafs/MakefileProto.NBSD.in +++ b/src/libafs/MakefileProto.NBSD.in @@ -15,6 +15,7 @@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ # OS specific object files: AFS_OS_OBJS = \ + osi_gcpags.o \ osi_groups.o \ osi_file.o \ osi_inode.o \ diff --git a/src/libafs/MakefileProto.OBSD.in b/src/libafs/MakefileProto.OBSD.in index af63407a37..60419b430a 100644 --- a/src/libafs/MakefileProto.OBSD.in +++ b/src/libafs/MakefileProto.OBSD.in @@ -36,6 +36,7 @@ KOBJ = MODLOAD # OS specific object files: AFS_OS_OBJS = \ + osi_gcpags.o \ osi_groups.o \ osi_file.o \ osi_misc.o \ diff --git a/src/libafs/MakefileProto.SOLARIS.in b/src/libafs/MakefileProto.SOLARIS.in index cebb5e568f..2de2c4c517 100644 --- a/src/libafs/MakefileProto.SOLARIS.in +++ b/src/libafs/MakefileProto.SOLARIS.in @@ -15,6 +15,7 @@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ # OS specific object files: AFS_OS_OBJS = \ + osi_gcpags.o \ osi_groups.o \ osi_inode.o \ osi_file.o \ diff --git a/src/libuafs/Makefile.common.in b/src/libuafs/Makefile.common.in index 1c6a63c42f..ecb5a74877 100644 --- a/src/libuafs/Makefile.common.in +++ b/src/libuafs/Makefile.common.in @@ -144,6 +144,7 @@ UAFSOBJ = \ $(UOBJ)/osi_vnodeops.o \ $(UOBJ)/osi_vm.o \ $(UOBJ)/osi_groups.o \ + $(UOBJ)/osi_gcpags.o \ $(UOBJ)/afsaux.o \ $(UOBJ)/Kvice.xdr.o \ $(UOBJ)/xdr_arrayn.o \ @@ -276,6 +277,7 @@ AFSWEBOBJ = \ $(WEBOBJ)/osi_vnodeops.o \ $(WEBOBJ)/osi_vm.o \ $(WEBOBJ)/osi_groups.o \ + $(WEBOBJ)/osi_gcpags.o \ $(WEBOBJ)/afsaux.o \ $(WEBOBJ)/Kvice.xdr.o \ $(WEBOBJ)/xdr_arrayn.o \ @@ -404,6 +406,7 @@ AFSWEBOBJKRB = \ $(WEBOBJ)/osi_vnodeops.o \ $(WEBOBJ)/osi_vm.o \ $(WEBOBJ)/osi_groups.o \ + $(WEBOBJ)/osi_gcpags.o \ $(WEBOBJ)/afsaux.o \ $(WEBOBJ)/Kvice.xdr.o \ $(WEBOBJ)/xdr_arrayn.o \ @@ -535,6 +538,7 @@ JUAFSOBJ = \ $(JUAFS)/osi_vnodeops.o \ $(JUAFS)/osi_vm.o \ $(JUAFS)/osi_groups.o \ + $(JUAFS)/osi_gcpags.o \ $(JUAFS)/afsaux.o \ $(JUAFS)/Kvice.xdr.o \ $(JUAFS)/xdr_arrayn.o \ @@ -767,6 +771,8 @@ $(UOBJ)/osi_vm.o: $(TOP_SRC_AFS)/UKERNEL/osi_vm.c $(CRULE1) $(UOBJ)/osi_groups.o: $(TOP_SRC_AFS)/UKERNEL/osi_groups.c $(CRULE1) +$(UOBJ)/osi_gcpags.o: $(TOP_SRC_AFS)/UKERNEL/osi_gcpags.c + $(CRULE1) $(UOBJ)/Kcallback.ss.o: $(TOP_OBJ_FSINT)/Kcallback.ss.c $(CRULE1) $(UOBJ)/Kvice.xdr.o: $(TOP_OBJ_FSINT)/Kvice.xdr.c @@ -1034,6 +1040,8 @@ $(WEBOBJ)/osi_vm.o: $(TOP_SRC_AFS)/UKERNEL/osi_vm.c $(CRULE2) $(WEBOBJ)/osi_groups.o: $(TOP_SRC_AFS)/UKERNEL/osi_groups.c $(CRULE2) +$(WEBOBJ)/osi_gcpags.o: $(TOP_SRC_AFS)/UKERNEL/osi_gcpags.c + $(CRULE2) $(WEBOBJ)/Kcallback.ss.o: $(TOP_OBJ_FSINT)/Kcallback.ss.c $(CRULE2) $(WEBOBJ)/Kvice.xdr.o: $(TOP_OBJ_FSINT)/Kvice.xdr.c @@ -1311,6 +1319,8 @@ $(JUAFS)/osi_vm.o: $(TOP_SRC_AFS)/UKERNEL/osi_vm.c $(CRULE1) $(JUAFS)/osi_groups.o: $(TOP_SRC_AFS)/UKERNEL/osi_groups.c $(CRULE1) +$(JUAFS)/osi_gcpags.o: $(TOP_SRC_AFS)/UKERNEL/osi_gcpags.c + $(CRULE1) $(JUAFS)/Kcallback.ss.o: $(TOP_OBJ_FSINT)/Kcallback.ss.c $(CRULE1) $(JUAFS)/Kvice.xdr.o: $(TOP_OBJ_FSINT)/Kvice.xdr.c