我想对内核(getlot和setlot)进行2个系统调用。他们必须在内核中的结构 proc 中读取并设置一些值。问题出在哪里?缺少什么?
在/usr/include/minix/callnr.h 中,我增加了 NCALLS 并添加了 2 个定义
#define NCALLS 80 /* number of system calls allowed */
#define SETLOT 78
#define GETLOT 79
In usr/src/mm/main.c
PUBLIC void do_setlot()
{
message msg;
msg = mm_in;
_taskcall(SYSTASK, SYS_SETLOT), &msg);
}
PUBLIC void do_getlot()
{
message msg;
msg = mm_in;
_taskcall(SYSTASK, SYS_GETLOT, &msg);
}
在/usr/src/mm/proto.h 中,我添加了两个原型
_PROTOTYPE( void do_setlot, (void));
_PROTOTYPE( void do_getlot, (void));
在/usr/src/mm/table.c 中,我添加了 _PROTOTYPE 的末尾 (int (*call_vec[NCALLS]), (void) )
do_setlot,
do_getlot,
在/usr/src/fs/table.c 中,我在末尾添加了 of_PROTOTYPE (int (*call_vec[]), (void) )
no_sys,
no_sys,
在/usr/include/minix/com.h 中,我创建了 2 个SYS_xxx定义
# define SYS_SETLOT 22
# define SYS_GETLOT 23
在/usr/src/kernel/system.c 中,我写道
FORWARD _PROTOTYPE( int do_procsetlot, (message *m_ptr) );
FORWARD _PROTOTYPE( int do_procgetlot, (message *m_ptr) );
然后添加了SYS_xxx以切换公共无效 sys_task()
case SYS_SETLOT: r = do_procsetlot(&m); break;
case SYS_GETLOT: r = do_procgetlot(&m); break;
在底部我写了 2 个定义
PRIVATE int do_procsetlot(m_ptr)
register message *m_ptr;
{
pid_t prid;
int i;
int tickets;
prid = m_ptr->m1_i1;
tickets = m_ptr->m1_i2;
if(tickets > LOT_MAX)
return EINVAL;
if(tickets < LOT_MIN)
return EINVAL;
for(i = 0 ; i <NR_PROCS; i++)
{
if(proc[i].p_pid == prid)
{
proc[i].tickets_number = tickets;
return 0;
}
{
return EINVAL;
}
PRIVATE int do_procgetlot(m_ptr)
register message *m_ptr;
{
int i;
pid_t prid;
prid = m_ptr->m1_i1;
for(i = 0 ; i< NR_PROCS; i++)
{
if(proc[i].p_pid == prid)
return proc[i].tickets_number;
}
return EINVAL;
}
最后,在制作hdboot后,我遇到了错误:
exec cc -c -I/usr/include main.c
exec cc -c -I/usr/include proc.c
exec cc -c -I/usr/include system.c
"system.c", line 1260: static not expected
make in /usr/src/kernel: Exit code 1
1260路是
PRIVATE int do_procgetlot(m_ptr)
这条消息已经有好几年了,但是...
您在do_procsetlot
底部有一个语法错误:
{
return EINVAL;
}
。应该是:
}
return EINVAL;
}
我希望你在2014年的某个时候自己想通了!
顺便说一句,Minix 2编译器完全支持ANSI C,所以你不需要所有的K&Risms。