summaryrefslogtreecommitdiff
path: root/microkernel/mach/rpc.mdwn
blob: 3615fc1280e83cdf3bc8627d42efdd4e2536ed7c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
[[!meta copyright="Copyright © 2002, 2003, 2007, 2008, 2010, 2011, 2012 Free
Software Foundation, Inc."]]

[[!meta license="""[[!toggle id="license" text="GFDL 1.2+"]][[!toggleable
id="license" text="Permission is granted to copy, distribute and/or modify this
document under the terms of the GNU Free Documentation License, Version 1.2 or
any later version published by the Free Software Foundation; with no Invariant
Sections, no Front-Cover Texts, and no Back-Cover Texts.  A copy of the license
is included in the section entitled [[GNU Free Documentation
License|/fdl]]."]]"""]]

Read about the [[general concept of a *remote procedure call* (RPC)|/rpc]].

Uses Mach's [[IPC]] [[mechanism]].

The [[port]] abstraction allows RPCs to be executed on another computer
transparently.  This can be implemented with user [[task]]s, but there is an
implementation in the kernel possible, too, which is called *NORMA*, but is not
avilable in [[GNU Mach|gnumach]].

The RPC stub code is generated by [[MIG]] to send appropriate [[message]]s.


# Tracing

  * [[hurd/debugging/rpctrace]]

  * [[open_issues/librpci]]