File: current.c

package info (click to toggle)
oskit 0.97.20000202-1
  • links: PTS
  • area: main
  • in suites: potato
  • size: 58,008 kB
  • ctags: 172,612
  • sloc: ansic: 832,827; asm: 7,640; sh: 3,920; yacc: 3,664; perl: 1,457; lex: 427; makefile: 337; csh: 141; awk: 78
file content (88 lines) | stat: -rw-r--r-- 2,239 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
/*
 * Copyright (c) 1997, 1998, 1999 The University of Utah and the Flux Group.
 * 
 * This file is part of the OSKit Linux Glue Libraries, which are free
 * software, also known as "open source;" you can redistribute them and/or
 * modify them under the terms of the GNU General Public License (GPL),
 * version 2, as published by the Free Software Foundation (FSF).
 * 
 * The OSKit is distributed in the hope that it will be useful, but WITHOUT ANY
 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE.  See the GPL for more details.  You should have
 * received a copy of the GPL along with the OSKit; see the file COPYING.  If
 * not, write to the FSF, 59 Temple Place #330, Boston, MA 02111-1307, USA.
 */
/*
 * Code to initialize `current' from a stack-allocated task_struct.
 */

#include <oskit/types.h>
#include <oskit/principal.h>
#include <oskit/error.h>

#include <linux/malloc.h>
#include <linux/sched.h>
#include <linux/mm.h>

#include "current.h"

oskit_error_t
fs_linux_create_current(struct task_struct *ts)
{
	oskit_principal_t *prin;
	oskit_identity_t id;
	oskit_error_t err;
	int i;

	ts->state = TASK_RUNNING;

	ts->counter = 0;

	err = oskit_get_call_context(&oskit_principal_iid, (void *)&prin);
	if (!err) {
		err = oskit_principal_getid(prin, &id);
		if (err) {
			oskit_principal_release(prin);
			return err;
		}
		ts->fsuid = id.uid;
		ts->fsgid = id.gid;
		ts->uid = id.uid;
		ts->gid = id.gid;
		for (i = 0; i < id.ngroups && i < NGROUPS; i++)
			ts->groups[i] = id.groups[i];
		for ( ; i < NGROUPS; i++)
			ts->groups[i] = NOGROUP;
		oskit_principal_release(prin);
	}
	else {
		ts->fsuid = ts->fsgid = ts->uid = ts->gid = 0;
		
		for (i = 0; i < NGROUPS; i++)
			ts->groups[i] = NOGROUP;
	}
	ts->rlim[RLIMIT_FSIZE].rlim_cur = RLIM_INFINITY;
	ts->rlim[RLIMIT_FSIZE].rlim_max = RLIM_INFINITY;

        ts->link_count = 0;

	ts->fs = kmalloc(sizeof(struct fs_struct), GFP_KERNEL);
	if (ts->fs == NULL)
		return OSKIT_ENOMEM;
	atomic_set(&ts->fs->count, 0);
	ts->fs->umask = 0;
	ts->fs->root = NULL;
	ts->fs->pwd = NULL;

	current = ts;

	return 0;
}

void
fs_linux_destroy_current(void)
{
	kfree(current->fs);
	current = (struct task_struct *)0xdeadcccc;
}