2 copies of taskcall.c removed
- taskcall.c is 3x in the trunk as part of libc, libsysutil and libsys. It should be only part of libsys. - only system process should be linked with libsys, therefore using raw _taskcall() in service.c is replaced by _syscall() - the same for minix_rs.c - lib/other/sys_eniop.c can go without replacement as it is part of syslib
This commit is contained in:
parent
769e5f373a
commit
ee4cff8d66
@ -88,11 +88,9 @@ libc_FILES=" \
|
||||
strtok_r.c \
|
||||
strtoll.c \
|
||||
swab.c \
|
||||
sys_eniop.c \
|
||||
syscall.c \
|
||||
sysconf.c \
|
||||
syslog.c \
|
||||
taskcall.c \
|
||||
telldir.c \
|
||||
termcap.c \
|
||||
ttyname.c \
|
||||
|
@ -16,10 +16,10 @@
|
||||
#include <stdlib.h>
|
||||
#include <errno.h>
|
||||
#include <string.h>
|
||||
#include <lib.h>
|
||||
|
||||
int minix_rs_lookup(const char *name, endpoint_t *value)
|
||||
{
|
||||
int r;
|
||||
message m;
|
||||
size_t len_key;
|
||||
|
||||
@ -28,12 +28,11 @@ int minix_rs_lookup(const char *name, endpoint_t *value)
|
||||
m.RS_NAME = (char *) name;
|
||||
m.RS_NAME_LEN = len_key;
|
||||
|
||||
r = _taskcall(RS_PROC_NR, RS_LOOKUP, &m);
|
||||
|
||||
if(r == OK) {
|
||||
if (_syscall(RS_PROC_NR, RS_LOOKUP, &m) != -1) {
|
||||
*value = m.RS_ENDPOINT;
|
||||
return OK;
|
||||
}
|
||||
|
||||
return r;
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
@ -1,14 +0,0 @@
|
||||
#include "../syslib/syslib.h"
|
||||
|
||||
/*===========================================================================*
|
||||
* sys_enable_iop *
|
||||
*===========================================================================*/
|
||||
PUBLIC int sys_enable_iop(proc_nr_e)
|
||||
endpoint_t proc_nr_e; /* number of process to allow I/O */
|
||||
{
|
||||
message m_iop;
|
||||
m_iop.IO_ENDPT = proc_nr_e;
|
||||
return _taskcall(SYSTASK, SYS_IOPENABLE, &m_iop);
|
||||
}
|
||||
|
||||
|
@ -1,20 +0,0 @@
|
||||
/* _taskcall() is the same as _syscall() except it returns negative error
|
||||
* codes directly and not in errno. This is a better interface for MM and
|
||||
* FS.
|
||||
*/
|
||||
|
||||
#include <lib.h>
|
||||
#include <minix/syslib.h>
|
||||
|
||||
PUBLIC int _taskcall(who, syscallnr, msgptr)
|
||||
endpoint_t who;
|
||||
int syscallnr;
|
||||
register message *msgptr;
|
||||
{
|
||||
int status;
|
||||
|
||||
msgptr->m_type = syscallnr;
|
||||
status = _sendrec(who, msgptr);
|
||||
if (status != 0) return(status);
|
||||
return(msgptr->m_type);
|
||||
}
|
@ -20,7 +20,6 @@ libsys_FILES=" \
|
||||
fkey_ctl.c \
|
||||
tsc_util.c \
|
||||
report.c \
|
||||
taskcall.c \
|
||||
read_tsc.s \
|
||||
read_tsc_64.c \
|
||||
ser_putc.c \
|
||||
|
@ -1,20 +0,0 @@
|
||||
/* _taskcall() is the same as _syscall() except it returns negative error
|
||||
* codes directly and not in errno. This is a better interface for MM and
|
||||
* FS.
|
||||
*/
|
||||
|
||||
#include <lib.h>
|
||||
#include <minix/syslib.h>
|
||||
|
||||
PUBLIC int _taskcall(who, syscallnr, msgptr)
|
||||
endpoint_t who;
|
||||
int syscallnr;
|
||||
register message *msgptr;
|
||||
{
|
||||
int status;
|
||||
|
||||
msgptr->m_type = syscallnr;
|
||||
status = _sendrec(who, msgptr);
|
||||
if (status != 0) return(status);
|
||||
return(msgptr->m_type);
|
||||
}
|
@ -15,6 +15,7 @@
|
||||
#include <pwd.h>
|
||||
#include <unistd.h>
|
||||
#include <limits.h>
|
||||
#include <lib.h>
|
||||
#include <minix/config.h>
|
||||
#include <minix/com.h>
|
||||
#include <minix/const.h>
|
||||
@ -124,10 +125,10 @@ PRIVATE void print_usage(char *app_name, char *problem)
|
||||
|
||||
/* A request to the RS server failed. Report and exit.
|
||||
*/
|
||||
PRIVATE void failure(int num)
|
||||
PRIVATE void failure(void)
|
||||
{
|
||||
fprintf(stderr, "Request to RS failed: %s (error %d)\n", strerror(num), num);
|
||||
exit(num);
|
||||
fprintf(stderr, "Request to RS failed: %s (error %d)\n", strerror(errno), errno);
|
||||
exit(errno);
|
||||
}
|
||||
|
||||
|
||||
@ -1069,7 +1070,7 @@ PUBLIC int main(int argc, char **argv)
|
||||
message m;
|
||||
int result;
|
||||
int request;
|
||||
int i, s;
|
||||
int i;
|
||||
char *label, *progname = NULL;
|
||||
struct passwd *pw;
|
||||
|
||||
@ -1141,8 +1142,8 @@ PUBLIC int main(int argc, char **argv)
|
||||
m.RS_CMD_ADDR = (char *) &rs_start;
|
||||
|
||||
/* Build request message and send the request. */
|
||||
if (OK != (s=_taskcall(RS_PROC_NR, request, &m)))
|
||||
failure(-s);
|
||||
if (_syscall(RS_PROC_NR, request, &m) == -1)
|
||||
failure();
|
||||
else if(req_printep)
|
||||
printf("%d\n", m.RS_ENDPOINT);
|
||||
result = m.m_type;
|
||||
@ -1153,20 +1154,20 @@ PUBLIC int main(int argc, char **argv)
|
||||
case RS_RESTART:
|
||||
m.RS_CMD_ADDR = req_label;
|
||||
m.RS_CMD_LEN = strlen(req_label);
|
||||
if (OK != (s=_taskcall(RS_PROC_NR, request, &m)))
|
||||
failure(-s);
|
||||
if (_syscall(RS_PROC_NR, request, &m) == -1)
|
||||
failure();
|
||||
break;
|
||||
case RS_SHUTDOWN:
|
||||
if (OK != (s=_taskcall(RS_PROC_NR, request, &m)))
|
||||
failure(-s);
|
||||
if (_syscall(RS_PROC_NR, request, &m) == -1)
|
||||
failure();
|
||||
break;
|
||||
case RS_UPDATE:
|
||||
m.RS_CMD_ADDR = req_label;
|
||||
m.RS_CMD_LEN = strlen(req_label);
|
||||
m.RS_LU_STATE = req_lu_state;
|
||||
m.RS_LU_PREPARE_MAXTIME = req_prepare_maxtime;
|
||||
if (OK != (s=_taskcall(RS_PROC_NR, request, &m)))
|
||||
failure(-s);
|
||||
if (_syscall(RS_PROC_NR, request, &m) == -1)
|
||||
failure();
|
||||
break;
|
||||
default:
|
||||
print_usage(argv[ARG_NAME], "request is not yet supported");
|
||||
|
Loading…
x
Reference in New Issue
Block a user