Rev 1073 | Rev 1091 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed
| Rev 1073 | Rev 1089 | ||
|---|---|---|---|
| Line 12... | Line 12... | ||
| 12 | ipc_call_t call; |
12 | ipc_call_t call; |
| 13 | ipc_callid_t callid; |
13 | ipc_callid_t callid; |
| 14 | 14 | ||
| 15 | ipcarg_t retval, arg1, arg2; |
15 | ipcarg_t retval, arg1, arg2; |
| 16 | 16 | ||
| 17 | printf("Name service started.\n"); |
17 | printf("NS:Name service started.\n"); |
| 18 | while (1) { |
18 | while (1) { |
| - | 19 | call.taskid = -1; |
|
| 19 | callid = ipc_wait_for_call(&call, 0); |
20 | callid = ipc_wait_for_call(&call, 0); |
| - | 21 | printf("NS:Call task=%llX,phone=%lX..", |
|
| 20 | printf("Received call from: %P..%llX\n", &call.taskid,call.taskid); |
22 | call.taskid,call.data.phoneid); |
| 21 | switch (IPC_GET_METHOD(call.data)) { |
23 | switch (IPC_GET_METHOD(call.data)) { |
| - | 24 | case IPC_M_PHONE_HUNGUP: |
|
| - | 25 | printf("Phone hung up.\n"); |
|
| - | 26 | retval = 0; |
|
| - | 27 | break; |
|
| 22 | case IPC_M_CONNECTTOME: |
28 | case IPC_M_CONNECT_TO_ME: |
| 23 | printf("Somebody wants to connect with phoneid %zd...accepting\n", IPC_GET_ARG3(call.data)); |
29 | printf("Somebody connecting phid=%zd.\n", IPC_GET_ARG3(call.data)); |
| 24 | service = IPC_GET_ARG3(call.data); |
30 | service = IPC_GET_ARG3(call.data); |
| 25 | retval = 0; |
31 | retval = 0; |
| 26 | break; |
32 | break; |
| 27 | case IPC_M_CONNECTMETO: |
33 | case IPC_M_CONNECT_ME_TO: |
| 28 | printf("Somebody wants to connect to: %zd\n", |
34 | printf("Connectmeto: %zd\n", |
| 29 | IPC_GET_ARG1(call.data)); |
35 | IPC_GET_ARG1(call.data)); |
| 30 | retval = 0; |
36 | retval = 0; |
| 31 | break; |
37 | break; |
| 32 | case NS_PING: |
38 | case NS_PING: |
| 33 | printf("Ping...%P %P\n", IPC_GET_ARG1(call.data), |
39 | printf("Ping...%P %P\n", IPC_GET_ARG1(call.data), |
| 34 | IPC_GET_ARG2(call.data)); |
40 | IPC_GET_ARG2(call.data)); |
| 35 | retval = 0; |
41 | retval = 0; |
| 36 | arg1 = 0xdead; |
42 | arg1 = 0xdead; |
| 37 | arg2 = 0xbeef; |
43 | arg2 = 0xbeef; |
| 38 | break; |
44 | break; |
| - | 45 | case NS_HANGUP: |
|
| - | 46 | printf("Closing connection.\n"); |
|
| - | 47 | retval = EHANGUP; |
|
| - | 48 | break; |
|
| 39 | case NS_PING_SVC: |
49 | case NS_PING_SVC: |
| 40 | printf("Pinging service %d\n", service); |
50 | printf("NS:Pinging service %d\n", service); |
| 41 | ipc_call_sync(service, NS_PING, 0xbeef, 0); |
51 | ipc_call_sync(service, NS_PING, 0xbeef, 0); |
| 42 | printf("Got pong\n"); |
52 | printf("NS:Got pong\n"); |
| 43 | break; |
53 | break; |
| 44 | default: |
54 | default: |
| 45 | printf("Unknown method: %zd\n", IPC_GET_METHOD(call.data)); |
55 | printf("Unknown method: %zd\n", IPC_GET_METHOD(call.data)); |
| 46 | retval = ENOENT; |
56 | retval = ENOENT; |
| 47 | break; |
57 | break; |