/uspace/trunk/ns/Makefile |
---|
File deleted |
/uspace/trunk/init/init.c |
---|
28,10 → 28,10 |
#include "version.h" |
#include <ipc.h> |
#include <ns.h> |
#include <stdio.h> |
#include <unistd.h> |
#include <stdlib.h> |
#include <ns.h> |
/* |
static void test_printf(void) |
46,7 → 46,7 |
} |
*/ |
extern char _heap; |
/* |
static void test_mremap(void) |
{ |
printf("Writing to good memory\n"); |
61,6 → 61,7 |
printf("memory done\n"); |
} |
*/ |
/* |
static void test_sbrk(void) |
{ |
90,16 → 91,7 |
} |
*/ |
static void test_ping(void) |
{ |
ipcarg_t result; |
int retval; |
retval = ipc_call_sync(PHONE_NS, NS_PING, 0xbeef,&result); |
printf("Retval: %d - received: %P\n", retval, result); |
} |
/* |
static void got_answer(void *private, int retval, ipc_data_t *data) |
{ |
printf("Retval: %d...%s...%X, %X\n", retval, private, |
107,7 → 99,7 |
} |
static void test_async_ipc(void) |
{ |
ipc_call_t data; |
ipc_data_t data; |
int i; |
printf("Sending ping\n"); |
130,39 → 122,16 |
ipc_wait_for_call(&data, NULL); |
printf("Received call???\n"); |
} |
*/ |
static void got_answer_2(void *private, int retval, ipc_data_t *data) |
int main(int argc, char *argv[]) |
{ |
printf("Pong\n"); |
} |
static void test_advanced_ipc(void) |
{ |
int res; |
unsigned long long taskid; |
ipc_callid_t callid; |
ipc_call_t data; |
ipcarg_t arg1, arg2; |
printf("Asking 0 to connect to me...\n"); |
res = ipc_connect_to_me(0, 1, 2, &taskid); |
printf("Result: %d - taskid: %Q\n", res, taskid); |
// while (1) { |
printf("----------------\n"); |
ipc_call_async(PHONE_NS, NS_PING_SVC, 0, "prov", |
got_answer_2); |
callid = ipc_wait_for_call(&data, NULL); |
printf("Received ping\n"); |
ipc_answer(callid, 0, 0, 0); |
// } |
callid = ipc_wait_for_call(&data, NULL); |
} |
int main(int argc, char *argv[]) |
{ |
version_print(); |
// test_ping(); |
// test_async_ipc(); |
test_advanced_ipc(); |
ipc_call_sync_2(PHONE_NS, NS_PING, 0xaaaa, 0xbbbb, &arg1, &arg2); |
printf("Pong: %P %P\n", arg1, arg2); |
return 0; |
} |
/uspace/trunk/Makefile |
---|
37,8 → 37,7 |
libc \ |
libipc \ |
libadt \ |
init \ |
ns |
init |
BUILDS := $(addsuffix .build,$(DIRS)) |
CLEANS := $(addsuffix .clean,$(DIRS)) |
/uspace/trunk/libipc/include/ipc.h |
---|
52,9 → 52,9 |
ipcarg_t *result3); |
extern int ipc_call_sync(int phoneid, ipcarg_t method, ipcarg_t arg1, |
extern int ipc_call_sync(int phoneid, ipcarg_t method, ipcarg_t arg1, |
ipcarg_t *result); |
extern ipc_callid_t ipc_wait_for_call(ipc_call_t *data, int flags); |
extern int ipc_wait_for_call(ipc_call_t *data, int flags); |
extern void ipc_answer(ipc_callid_t callid, ipcarg_t retval, ipcarg_t arg1, |
ipcarg_t arg2); |
62,7 → 62,5 |
void ipc_call_async_2(int phoneid, ipcarg_t method, ipcarg_t arg1, |
ipcarg_t arg2, void *private, |
ipc_async_callback_t callback); |
int ipc_connect_to_me(int phoneid, int arg1, int arg2, |
unsigned long long *taskid); |
#endif |
/uspace/trunk/libipc/include/ns.h |
---|
29,7 → 29,6 |
#ifndef __LIBIPC__NS_H__ |
#define __LIBIPC__NS_H__ |
#define NS_PING 1024 |
#define NS_PING_SVC 1025 |
#include <kernel/ipc/ns.h> |
#endif |
/uspace/trunk/libipc/generic/ipc.c |
---|
117,7 → 117,6 |
call = malloc(sizeof(*call)); |
if (!call) { |
callback(private, ENOMEM, NULL); |
return; |
} |
callid = __SYSCALL4(SYS_IPC_CALL_ASYNC_FAST, phoneid, method, arg1, arg2); |
222,7 → 221,7 |
* @return Callid or 0 if nothing available and started with |
* IPC_WAIT_NONBLOCKING |
*/ |
ipc_callid_t ipc_wait_for_call(ipc_call_t *call, int flags) |
int ipc_wait_for_call(ipc_call_t *call, int flags) |
{ |
ipc_callid_t callid; |
237,11 → 236,3 |
return callid; |
} |
/** Ask destination to do a callback connection */ |
int ipc_connect_to_me(int phoneid, int arg1, int arg2, |
unsigned long long *taskid) |
{ |
return __SYSCALL4(SYS_IPC_CONNECT_TO_ME, phoneid, arg1, arg2, |
(sysarg_t) taskid); |
} |