1 | .sect .text; .sect .rom; .sect .data; .sect .bss
|
---|
2 | .define __echo, __notify, __send, __receive, __sendrec
|
---|
3 |
|
---|
4 | ! See src/kernel/ipc.h for C definitions
|
---|
5 | SEND = 1
|
---|
6 | RECEIVE = 2
|
---|
7 | SENDREC = 3
|
---|
8 | NOTIFY = 4
|
---|
9 | ECHO = 8
|
---|
10 | SYSVEC = 33 ! trap to kernel
|
---|
11 |
|
---|
12 | SRC_DST = 8 ! source/ destination process
|
---|
13 | ECHO_MESS = 8 ! echo doesn't have SRC_DST
|
---|
14 | MESSAGE = 12 ! message pointer
|
---|
15 |
|
---|
16 | !*========================================================================*
|
---|
17 | ! IPC assembly routines *
|
---|
18 | !*========================================================================*
|
---|
19 | ! all message passing routines save ebp, but destroy eax and ecx.
|
---|
20 | .define __echo, __notify, __send, __receive, __sendrec
|
---|
21 | .sect .text
|
---|
22 | __send:
|
---|
23 | push ebp
|
---|
24 | mov ebp, esp
|
---|
25 | push ebx
|
---|
26 | mov eax, SRC_DST(ebp) ! eax = dest-src
|
---|
27 | mov ebx, MESSAGE(ebp) ! ebx = message pointer
|
---|
28 | mov ecx, SEND ! _send(dest, ptr)
|
---|
29 | int SYSVEC ! trap to the kernel
|
---|
30 | pop ebx
|
---|
31 | pop ebp
|
---|
32 | ret
|
---|
33 |
|
---|
34 | __receive:
|
---|
35 | push ebp
|
---|
36 | mov ebp, esp
|
---|
37 | push ebx
|
---|
38 | mov eax, SRC_DST(ebp) ! eax = dest-src
|
---|
39 | mov ebx, MESSAGE(ebp) ! ebx = message pointer
|
---|
40 | mov ecx, RECEIVE ! _receive(src, ptr)
|
---|
41 | int SYSVEC ! trap to the kernel
|
---|
42 | pop ebx
|
---|
43 | pop ebp
|
---|
44 | ret
|
---|
45 |
|
---|
46 | __sendrec:
|
---|
47 | push ebp
|
---|
48 | mov ebp, esp
|
---|
49 | push ebx
|
---|
50 | mov eax, SRC_DST(ebp) ! eax = dest-src
|
---|
51 | mov ebx, MESSAGE(ebp) ! ebx = message pointer
|
---|
52 | mov ecx, SENDREC ! _sendrec(srcdest, ptr)
|
---|
53 | int SYSVEC ! trap to the kernel
|
---|
54 | pop ebx
|
---|
55 | pop ebp
|
---|
56 | ret
|
---|
57 |
|
---|
58 | __notify:
|
---|
59 | push ebp
|
---|
60 | mov ebp, esp
|
---|
61 | push ebx
|
---|
62 | mov eax, SRC_DST(ebp) ! ebx = destination
|
---|
63 | mov ecx, NOTIFY ! _notify(srcdst)
|
---|
64 | int SYSVEC ! trap to the kernel
|
---|
65 | pop ebx
|
---|
66 | pop ebp
|
---|
67 | ret
|
---|
68 |
|
---|
69 | __echo:
|
---|
70 | push ebp
|
---|
71 | mov ebp, esp
|
---|
72 | push ebx
|
---|
73 | mov ebx, ECHO_MESS(ebp) ! ebx = message pointer
|
---|
74 | mov ecx, ECHO ! _echo(srcdest, ptr)
|
---|
75 | int SYSVEC ! trap to the kernel
|
---|
76 | pop ebx
|
---|
77 | pop ebp
|
---|
78 | ret
|
---|
79 |
|
---|