kernel+libc: Add the pstat() system call
Luna-specific, but I like it.
This commit is contained in:
parent
0dbfbe6395
commit
1506331872
@ -31,6 +31,7 @@ set(SOURCES
|
||||
src/sys/file.cpp
|
||||
src/sys/id.cpp
|
||||
src/sys/mkdir.cpp
|
||||
src/sys/pstat.cpp
|
||||
src/sys/waitpid.cpp
|
||||
src/sys/getdents.cpp
|
||||
src/sys/stat.cpp
|
||||
|
41
kernel/src/sys/pstat.cpp
Normal file
41
kernel/src/sys/pstat.cpp
Normal file
@ -0,0 +1,41 @@
|
||||
#include "memory/MemoryManager.h"
|
||||
#include "sys/Syscall.h"
|
||||
#include "thread/Scheduler.h"
|
||||
#include <bits/pstat.h>
|
||||
|
||||
static void set_timespec(struct timespec& ts, u64 ticks)
|
||||
{
|
||||
ts.tv_sec = ticks / 1000;
|
||||
ts.tv_nsec = (ticks % 1000) * 1000 * 1000;
|
||||
}
|
||||
|
||||
Result<u64> sys_pstat(Registers*, SyscallArgs args)
|
||||
{
|
||||
pid_t pid = (pid_t)args[0];
|
||||
struct process* ps = (struct process*)args[1];
|
||||
|
||||
// If pid == -1, return the PID of the last spawned thread.
|
||||
if (pid == -1) return g_threads.expect_last()->id;
|
||||
|
||||
auto* thread = TRY(Result<Thread*>::from_option(Scheduler::find_by_pid(pid), ESRCH));
|
||||
|
||||
struct process proc;
|
||||
proc.ps_pid = (pid_t)thread->id;
|
||||
proc.ps_ppid = thread->parent ? (pid_t)thread->parent->id : 0;
|
||||
proc.ps_uid = thread->auth.uid;
|
||||
proc.ps_gid = thread->auth.gid;
|
||||
proc.ps_euid = thread->auth.euid;
|
||||
proc.ps_egid = thread->auth.egid;
|
||||
proc.ps_state = (int)thread->state;
|
||||
proc.ps_flags = thread->is_kernel ? PS_FLAG_KRNL : 0;
|
||||
set_timespec(proc.ps_time, thread->ticks);
|
||||
set_timespec(proc.ps_ktime, thread->ticks_in_kernel);
|
||||
set_timespec(proc.ps_utime, thread->ticks_in_user);
|
||||
strlcpy(proc.ps_name, thread->name.chars(), sizeof(proc.ps_name));
|
||||
strlcpy(proc.ps_cwd, thread->current_directory_path.is_empty() ? "/" : thread->current_directory_path.chars(),
|
||||
sizeof(proc.ps_cwd));
|
||||
|
||||
if (!MemoryManager::copy_to_user_typed(ps, &proc)) return err(EFAULT);
|
||||
|
||||
return (u64)pid;
|
||||
}
|
@ -25,6 +25,7 @@ set(SOURCES
|
||||
src/sys/ioctl.cpp
|
||||
src/sys/utsname.cpp
|
||||
src/sys/mount.cpp
|
||||
src/sys/pstat.cpp
|
||||
)
|
||||
|
||||
if(${LUNA_ARCH} STREQUAL "x86_64")
|
||||
|
34
libc/include/bits/pstat.h
Normal file
34
libc/include/bits/pstat.h
Normal file
@ -0,0 +1,34 @@
|
||||
/* bits/pstat.h: The process structure and flags for the pstat() system call. */
|
||||
|
||||
#ifndef _BITS_PSTAT_H
|
||||
#define _BITS_PSTAT_H
|
||||
|
||||
#include <bits/timespec.h>
|
||||
#include <sys/types.h>
|
||||
|
||||
#define PS_IDLE 1
|
||||
#define PS_RUNNABLE 2
|
||||
#define PS_SLEEPING 3
|
||||
#define PS_WAITING 4
|
||||
#define PS_ENDED 5
|
||||
|
||||
#define PS_FLAG_KRNL 1
|
||||
|
||||
struct process
|
||||
{
|
||||
pid_t ps_pid;
|
||||
pid_t ps_ppid;
|
||||
uid_t ps_uid;
|
||||
uid_t ps_euid;
|
||||
gid_t ps_gid;
|
||||
gid_t ps_egid;
|
||||
int ps_state;
|
||||
int ps_flags;
|
||||
struct timespec ps_time;
|
||||
struct timespec ps_ktime;
|
||||
struct timespec ps_utime;
|
||||
char ps_name[129];
|
||||
char ps_cwd[256];
|
||||
};
|
||||
|
||||
#endif
|
23
libc/include/sys/pstat.h
Normal file
23
libc/include/sys/pstat.h
Normal file
@ -0,0 +1,23 @@
|
||||
/* sys/pstat.h: The pstat() system call. */
|
||||
|
||||
#ifndef _SYS_PSTAT_H
|
||||
#define _SYS_PSTAT_H
|
||||
|
||||
#include <bits/pstat.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C"
|
||||
{
|
||||
#endif
|
||||
|
||||
/* Retrieve information about a process. */
|
||||
pid_t pstat(pid_t pid, struct process* ps);
|
||||
|
||||
/* Get a string representing a process' state. */
|
||||
const char* ps_state_name(int state);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
26
libc/src/sys/pstat.cpp
Normal file
26
libc/src/sys/pstat.cpp
Normal file
@ -0,0 +1,26 @@
|
||||
#include <bits/errno-return.h>
|
||||
#include <sys/pstat.h>
|
||||
#include <sys/syscall.h>
|
||||
#include <unistd.h>
|
||||
|
||||
extern "C"
|
||||
{
|
||||
pid_t pstat(pid_t pid, struct process* ps)
|
||||
{
|
||||
long rc = syscall(SYS_pstat, pid, ps);
|
||||
__errno_return(rc, pid_t);
|
||||
}
|
||||
|
||||
const char* ps_state_name(int state)
|
||||
{
|
||||
switch (state)
|
||||
{
|
||||
case PS_IDLE: return "Idle";
|
||||
case PS_RUNNABLE: return "Running";
|
||||
case PS_SLEEPING: return "Sleeping";
|
||||
case PS_WAITING: return "Waiting";
|
||||
case PS_ENDED: return "Zombie";
|
||||
default: return "???";
|
||||
}
|
||||
}
|
||||
}
|
@ -5,7 +5,7 @@
|
||||
_e(lseek) _e(mkdir) _e(execve) _e(fork) _e(waitpid) _e(getppid) _e(fcntl) _e(getdents) _e(getuid) _e(geteuid) \
|
||||
_e(getgid) _e(getegid) _e(setuid) _e(setgid) _e(seteuid) _e(setegid) _e(fchmodat) _e(fchownat) _e(ioctl) \
|
||||
_e(fstatat) _e(chdir) _e(getcwd) _e(unlinkat) _e(uname) _e(sethostname) _e(dup2) _e(pipe) _e(mount) \
|
||||
_e(umount)
|
||||
_e(umount) _e(pstat)
|
||||
|
||||
enum Syscalls
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user