2006-07-14 15:24:40 +08:00
|
|
|
/* taskstats_kern.h - kernel header for per-task statistics interface
|
|
|
|
*
|
|
|
|
* Copyright (C) Shailabh Nagar, IBM Corp. 2006
|
|
|
|
* (C) Balbir Singh, IBM Corp. 2006
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _LINUX_TASKSTATS_KERN_H
|
|
|
|
#define _LINUX_TASKSTATS_KERN_H
|
|
|
|
|
|
|
|
#include <linux/taskstats.h>
|
|
|
|
#include <linux/sched.h>
|
2006-07-14 15:24:46 +08:00
|
|
|
#include <net/genetlink.h>
|
2006-07-14 15:24:40 +08:00
|
|
|
|
|
|
|
#ifdef CONFIG_TASKSTATS
|
|
|
|
extern kmem_cache_t *taskstats_cache;
|
2006-07-14 15:24:41 +08:00
|
|
|
extern struct mutex taskstats_exit_mutex;
|
2006-07-14 15:24:40 +08:00
|
|
|
|
2006-07-14 15:24:44 +08:00
|
|
|
static inline void taskstats_exit_free(struct taskstats *tidstats)
|
2006-07-14 15:24:40 +08:00
|
|
|
{
|
|
|
|
if (tidstats)
|
|
|
|
kmem_cache_free(taskstats_cache, tidstats);
|
|
|
|
}
|
|
|
|
|
2006-07-14 15:24:44 +08:00
|
|
|
static inline void taskstats_tgid_init(struct signal_struct *sig)
|
|
|
|
{
|
|
|
|
sig->stats = NULL;
|
|
|
|
}
|
|
|
|
|
2006-10-29 01:38:53 +08:00
|
|
|
static inline void taskstats_tgid_alloc(struct task_struct *tsk)
|
2006-07-14 15:24:44 +08:00
|
|
|
{
|
2006-10-29 01:38:53 +08:00
|
|
|
struct signal_struct *sig = tsk->signal;
|
2006-07-14 15:24:44 +08:00
|
|
|
struct taskstats *stats;
|
|
|
|
|
2006-10-29 01:38:52 +08:00
|
|
|
if (sig->stats != NULL)
|
|
|
|
return;
|
|
|
|
|
2006-10-29 01:38:53 +08:00
|
|
|
/* No problem if kmem_cache_zalloc() fails */
|
2006-12-07 12:33:17 +08:00
|
|
|
stats = kmem_cache_zalloc(taskstats_cache, GFP_KERNEL);
|
2006-07-14 15:24:44 +08:00
|
|
|
|
2006-10-29 01:38:53 +08:00
|
|
|
spin_lock_irq(&tsk->sighand->siglock);
|
2006-07-14 15:24:44 +08:00
|
|
|
if (!sig->stats) {
|
|
|
|
sig->stats = stats;
|
|
|
|
stats = NULL;
|
|
|
|
}
|
2006-10-29 01:38:53 +08:00
|
|
|
spin_unlock_irq(&tsk->sighand->siglock);
|
2006-07-14 15:24:44 +08:00
|
|
|
|
|
|
|
if (stats)
|
|
|
|
kmem_cache_free(taskstats_cache, stats);
|
|
|
|
}
|
2006-07-14 15:24:40 +08:00
|
|
|
|
2006-07-14 15:24:44 +08:00
|
|
|
static inline void taskstats_tgid_free(struct signal_struct *sig)
|
|
|
|
{
|
2006-10-29 01:38:51 +08:00
|
|
|
if (sig->stats)
|
|
|
|
kmem_cache_free(taskstats_cache, sig->stats);
|
2006-07-14 15:24:44 +08:00
|
|
|
}
|
|
|
|
|
2006-07-14 15:24:47 +08:00
|
|
|
extern void taskstats_exit_alloc(struct taskstats **, unsigned int *);
|
|
|
|
extern void taskstats_exit_send(struct task_struct *, struct taskstats *, int, unsigned int);
|
2006-07-14 15:24:44 +08:00
|
|
|
extern void taskstats_init_early(void);
|
2006-07-14 15:24:40 +08:00
|
|
|
#else
|
2006-07-14 15:24:47 +08:00
|
|
|
static inline void taskstats_exit_alloc(struct taskstats **ptidstats, unsigned int *mycpu)
|
2006-07-14 15:24:40 +08:00
|
|
|
{}
|
2006-07-14 15:24:44 +08:00
|
|
|
static inline void taskstats_exit_free(struct taskstats *ptidstats)
|
2006-07-14 15:24:40 +08:00
|
|
|
{}
|
|
|
|
static inline void taskstats_exit_send(struct task_struct *tsk,
|
2006-07-14 15:24:44 +08:00
|
|
|
struct taskstats *tidstats,
|
2006-07-14 15:24:47 +08:00
|
|
|
int group_dead, unsigned int cpu)
|
2006-07-14 15:24:44 +08:00
|
|
|
{}
|
|
|
|
static inline void taskstats_tgid_init(struct signal_struct *sig)
|
|
|
|
{}
|
2006-10-29 01:38:53 +08:00
|
|
|
static inline void taskstats_tgid_alloc(struct task_struct *tsk)
|
2006-07-14 15:24:44 +08:00
|
|
|
{}
|
|
|
|
static inline void taskstats_tgid_free(struct signal_struct *sig)
|
2006-07-14 15:24:40 +08:00
|
|
|
{}
|
|
|
|
static inline void taskstats_init_early(void)
|
|
|
|
{}
|
|
|
|
#endif /* CONFIG_TASKSTATS */
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|