Rev 1285 | Rev 1335 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
1030 | palkovsky | 1 | #include <ipc.h> |
2 | #include <stdio.h> |
||
3 | #include <unistd.h> |
||
4 | #include <stdlib.h> |
||
5 | #include <ns.h> |
||
6 | #include <errno.h> |
||
1282 | palkovsky | 7 | /* |
8 | irq_cmd_t msim_cmds[1] = { |
||
9 | { CMD_MEM_READ_1, (void *)0xB0000000, 0 } |
||
10 | }; |
||
1030 | palkovsky | 11 | |
1282 | palkovsky | 12 | irq_code_t msim_kbd = { |
13 | 1, |
||
14 | msim_cmds |
||
15 | }; |
||
16 | */ |
||
1285 | palkovsky | 17 | /* |
18 | irq_cmd_t i8042_cmds[1] = { |
||
19 | { CMD_PORT_READ_1, (void *)0x60, 0 } |
||
20 | }; |
||
21 | |||
22 | irq_code_t i8042_kbd = { |
||
23 | 1, |
||
24 | i8042_cmds |
||
25 | }; |
||
26 | */ |
||
27 | |||
1030 | palkovsky | 28 | static int service; |
29 | |||
30 | int main(int argc, char **argv) |
||
31 | { |
||
32 | ipc_call_t call; |
||
33 | ipc_callid_t callid; |
||
1330 | palkovsky | 34 | char *as; |
1030 | palkovsky | 35 | |
36 | ipcarg_t retval, arg1, arg2; |
||
37 | |||
1089 | palkovsky | 38 | printf("NS:Name service started.\n"); |
1282 | palkovsky | 39 | // ipc_register_irq(2, &msim_kbd); |
1285 | palkovsky | 40 | // ipc_register_irq(1, &i8042_kbd); |
1030 | palkovsky | 41 | while (1) { |
42 | callid = ipc_wait_for_call(&call, 0); |
||
1091 | palkovsky | 43 | printf("NS:Call phone=%lX..", call.phoneid); |
44 | switch (IPC_GET_METHOD(call)) { |
||
1330 | palkovsky | 45 | case IPC_M_AS_SEND: |
46 | as = (char *)IPC_GET_ARG2(call); |
||
47 | printf("Received as: %P, size:%d\n", as, IPC_GET_ARG3(call)); |
||
48 | retval = ipc_answer(callid, 0,(sysarg_t)(1024*1024), 0); |
||
49 | if (!retval) { |
||
50 | printf("Reading shared memory..."); |
||
51 | printf("Text: %s", as); |
||
52 | } else |
||
53 | printf("Failed answer: %d\n", retval); |
||
54 | continue; |
||
55 | break; |
||
1259 | palkovsky | 56 | case IPC_M_INTERRUPT: |
1282 | palkovsky | 57 | printf("GOT INTERRUPT: %c\n", IPC_GET_ARG2(call)); |
1259 | palkovsky | 58 | break; |
1089 | palkovsky | 59 | case IPC_M_PHONE_HUNGUP: |
60 | printf("Phone hung up.\n"); |
||
61 | retval = 0; |
||
62 | break; |
||
63 | case IPC_M_CONNECT_TO_ME: |
||
1091 | palkovsky | 64 | printf("Somebody connecting phid=%zd.\n", IPC_GET_ARG3(call)); |
65 | service = IPC_GET_ARG3(call); |
||
1030 | palkovsky | 66 | retval = 0; |
67 | break; |
||
1089 | palkovsky | 68 | case IPC_M_CONNECT_ME_TO: |
1091 | palkovsky | 69 | printf("Connectme(%P)to: %zd\n", |
70 | IPC_GET_ARG3(call), IPC_GET_ARG1(call)); |
||
1061 | palkovsky | 71 | retval = 0; |
72 | break; |
||
1030 | palkovsky | 73 | case NS_PING: |
1091 | palkovsky | 74 | printf("Ping...%P %P\n", IPC_GET_ARG1(call), |
75 | IPC_GET_ARG2(call)); |
||
1030 | palkovsky | 76 | retval = 0; |
77 | arg1 = 0xdead; |
||
78 | arg2 = 0xbeef; |
||
79 | break; |
||
1089 | palkovsky | 80 | case NS_HANGUP: |
81 | printf("Closing connection.\n"); |
||
82 | retval = EHANGUP; |
||
83 | break; |
||
1030 | palkovsky | 84 | case NS_PING_SVC: |
1089 | palkovsky | 85 | printf("NS:Pinging service %d\n", service); |
1030 | palkovsky | 86 | ipc_call_sync(service, NS_PING, 0xbeef, 0); |
1089 | palkovsky | 87 | printf("NS:Got pong\n"); |
1030 | palkovsky | 88 | break; |
89 | default: |
||
1091 | palkovsky | 90 | printf("Unknown method: %zd\n", IPC_GET_METHOD(call)); |
1030 | palkovsky | 91 | retval = ENOENT; |
92 | break; |
||
93 | } |
||
1282 | palkovsky | 94 | if (! (callid & IPC_CALLID_NOTIFICATION)) { |
95 | printf("Answerinh\n"); |
||
1259 | palkovsky | 96 | ipc_answer(callid, retval, arg1, arg2); |
1282 | palkovsky | 97 | } |
1030 | palkovsky | 98 | } |
99 | } |