0

我正在尝试实现一个名为 getprocs() 的系统调用,它返回实际进程的数量。我已经实现了添加新系统调用的所有必要条件。这个系统调用所做的是获取表中的进程并将它们复制到结构数组中。该结构称为 uproc,其成员是 int pid、int ppid 和 char name。然后,我在 ac 文件中创建了一个程序,该程序尝试以树格式打印进程,但我在打印进程名称时遇到了麻烦。我不知道从哪里开始。下面我附上了我的代码,我在其中定义了 getprocs()、struct uproc,以及我尝试打印进程的程序。我还包括它向我抛出的错误。

proc.c 中的 getprocs() 定义:

int 
sys_getprocs(void)
{
int max;
struct uproc *p;
int i = 0;
argint(0, &max);
argptr(1, (char **)&p, max*sizeof(struct uproc));
struct proc *ptr = ptable.proc;
for(; ptr < &ptable.proc[NPROC]; ptr++) {
  if(!(ptr->state == UNUSED)) {
    continue;
  }
  p[i].pid = ptr->pid;
  p[i].ppid = ptr->parent->pid;
  strncpy(p[i].name, ptr->name, 16);
  i++;
}
return i;
}

uproc.h 中的结构 uproc:

struct uproc {
    int pid;
    int ppid;
    char name[16];
 };

尝试在 pstree.c 中打印进程的程序:

#include "types.h"
#include "stat.h"
#include "user.h"
#include "uproc.h"

int main() {
  printf(20, "Made it into main\n");
  int maxElements = 64;
  struct uproc *processes = malloc(maxElements*sizeof(struct uproc));
  int N = getprocs(maxElements, &processes);
  int i = 0;

  printf(10, "Starting\n");
  for(; i < N; i++) {
    printf(16, processes[i].name);     
  }

  return 0;
 }

没有任何内容打印到屏幕上,尝试运行 pstree 后出现以下错误:

pid 3 pstree:cpu 1 上的陷阱 14 err 4 eip 0x6da addr 0x42444cb--kill proc

4

2 回答 2

1
  1. 对于sys_getprocs,改变这个...

    if(!(ptr->state == UNUSED)) {
        continue;
    }
    

    至...

    if((ptr->state == UNUSED)) {
        continue;
    }
    

    因为你想获取所有正在运行的进程。

  2. main,改变...

    int N = getprocs(maxElements, &processes);

    至...

    int N = getprocs(maxElements, processes);

    因为进程已经定义为指针

更改代码的这两部分应该可以使程序正常工作。

于 2019-02-04T04:28:27.590 回答
-2

您应该使用 exit() 而不是 return 0。它应该可以工作。

于 2016-10-16T21:53:48.713 回答