Discussion:
RPC parameters
Bilal ma
2016-01-13 11:17:10 UTC
Permalink
HI,Genode is new to me . I just start playing with it.
I was looking at the Hello program and the RPC mechanism. as i understood RPC does not support passing pointer as parameter how i can pass a parameter by reference where i need to change its value in the server side. I found in the rpc.h that the parameter could be input and output in the same time. How i can use this ? are there any implemented examples . should i defined an my output structure if the remote procedure return multiple outputs.
best.
Norman Feske
2016-01-14 10:26:56 UTC
Permalink
Hello,

> Genode is new to me . I just start playing with it.

welcome to the list!

> I was looking at the Hello program and the RPC mechanism. as i
> understood RPC does not support passing pointer as parameter
> how i can pass a parameter by reference where i need to change its value
> in the server side.

you can find a detailed description of the RPC mechanism in Section
8.12. "Remote procedure calls" of the manual [1]. In short, you have two
options:

1. Define a POD struct used as return type of your RPC functiion.
For an example, take a look that the Framebuffer::Session::mode
RPC function [2].

2. You can pass a reference to a POD object as RPC argument.
This is rarely used but you can find find an example in the
Raspberry-Pi-specific platform-session interface, namely the
setup_framebuffer RPC function [3].

[1] http://genode.org/documentation/genode-foundations-15-05.pdf
[2]
https://github.com/genodelabs/genode/blob/master/repos/os/include/framebuffer_session/framebuffer_session.h#L91
[3]
https://github.com/genodelabs/genode/blob/master/repos/os/include/spec/rpi/platform_session/platform_session.h#L39

Cheers
Norman

--
Dr.-Ing. Norman Feske
Genode Labs

http://www.genode-labs.com · http://genode.org

Genode Labs GmbH · Amtsgericht Dresden · HRB 28424 · Sitz Dresden
Geschäftsführer: Dr.-Ing. Norman Feske, Christian Helmuth
Bilal ma
2016-01-14 10:52:01 UTC
Permalink
Hi Norman,
Thank you for the examples, does it make difference if i don't pass my input-output POD struct by reference since it need to be copied to the server side, and later from the server to the client. from the point view of performance which one is the best if we add the option of placing my POD in shared memory.
best,
> Subject: Re: RPC parameters
> To: genode-***@lists.sourceforge.net
> From: ***@genode-labs.com
> Date: Thu, 14 Jan 2016 11:26:56 +0100
>
> Hello,
>
> > Genode is new to me . I just start playing with it.
>
> welcome to the list!
>
> > I was looking at the Hello program and the RPC mechanism. as i
> > understood RPC does not support passing pointer as parameter
> > how i can pass a parameter by reference where i need to change its value
> > in the server side.
>
> you can find a detailed description of the RPC mechanism in Section
> 8.12. "Remote procedure calls" of the manual [1]. In short, you have two
> options:
>
> 1. Define a POD struct used as return type of your RPC functiion.
> For an example, take a look that the Framebuffer::Session::mode
> RPC function [2].
>
> 2. You can pass a reference to a POD object as RPC argument.
> This is rarely used but you can find find an example in the
> Raspberry-Pi-specific platform-session interface, namely the
> setup_framebuffer RPC function [3].
>
> [1] http://genode.org/documentation/genode-foundations-15-05.pdf
> [2]
> https://github.com/genodelabs/genode/blob/master/repos/os/include/framebuffer_session/framebuffer_session.h#L91
> [3]
> https://github.com/genodelabs/genode/blob/master/repos/os/include/spec/rpi/platform_session/platform_session.h#L39
>
> Cheers
> Norman
>
> --
> Dr.-Ing. Norman Feske
> Genode Labs
>
> http://www.genode-labs.com · http://genode.org
>
> Genode Labs GmbH · Amtsgericht Dresden · HRB 28424 · Sitz Dresden
> Geschäftsführer: Dr.-Ing. Norman Feske, Christian Helmuth
>
> ------------------------------------------------------------------------------
> Site24x7 APM Insight: Get Deep Visibility into Application Performance
> APM + Mobile APM + RUM: Monitor 3 App instances at just $35/Month
> Monitor end-to-end web transactions and take corrective actions now
> Troubleshoot faster and improve end-user experience. Signup Now!
> http://pubads.g.doubleclick.net/gampad/clk?id=267308311&iu=/4140
> _______________________________________________
> genode-main mailing list
> genode-***@lists.sourceforge.net
> https://lists.sourceforge.net/lists/listinfo/genode-main
Norman Feske
2016-01-14 11:09:30 UTC
Permalink
Hello,

On 14.01.2016 11:52, Bilal ma wrote:
> Thank you for the examples, does it make difference if i don't pass my
> input-output POD struct by reference since it need to be copied to the
> server side, and later from the server to the client.
> from the point view of performance which one is the best if we add the
> option of placing my POD in shared memory.

the RPC mechanism always copies data. It does not use shared memory.
Please review Section 8.12.2. "Transferable argument types" to get a
picture how different argument types are handled.

If a reference is passed as argument, the following steps are taken:

1. The argument is copied into the message to be sent to the server.

2. The server instantiates a temporary object of the argument type
and copies the argument from the message to the temporary object.

3. The server-side RPC method is called with a reference to the
temporary object as argument.

4. Once the server-side RPC method returns, the new content of the
temporary object is copied to the reply message buffer.

By using the temporary object instance, it looks like you pass a
reference. But under the hood, the server operates on a different object.

You mentioned performance. If you need to transfer large amounts of bulk
data between components, you may consider shared memory. For a
description of how to set up shared memory between components, please
refer to Section 3.6.3. "Shared memory" in [1].

That said, I recommend you to think twice about introducing a new
session interface. Maybe an existing interface would do the job just
fine when looking at your problem from a slightly different angle? To
cite the intro of Chapter 4:

"The versatility of a component-based system does not come from
the existence of many components alone. Even more important is
the composability of components. Components can be combined only
if their interfaces match. To maximize composability, the number
of interfaces throughout the system should be as low as possible,
and all interfaces should be largely orthogonal to each other."

Whereas it is a nice exercise to design a custom RPC interface, I mostly
advise against it. In particular, if your interface is just a bunch of
getters and setters, the existing ROM and Report session interfaces may
accommodate you quite well.

[1] http://genode.org/documentation/genode-foundations-15-05.pdf

Cheers
Norman

--
Dr.-Ing. Norman Feske
Genode Labs

http://www.genode-labs.com · http://genode.org

Genode Labs GmbH · Amtsgericht Dresden · HRB 28424 · Sitz Dresden
Geschäftsführer: Dr.-Ing. Norman Feske, Christian Helmuth
Bilal ma
2016-01-14 11:48:34 UTC
Permalink
Thank you Norman, it is really more than sufficient answer. since i am still new with Geonde it may early to give an advise, regarding to the book ,it is an amazing effort ( i went through few parts of it since yesterday), but do you think that it will be better to include some more code examples. what i mean is making the book as reference to "how to develop in Genode".
thank you again for your answering. best.
> Subject: Re: RPC parameters
> To: genode-***@lists.sourceforge.net
> From: ***@genode-labs.com
> Date: Thu, 14 Jan 2016 12:09:30 +0100
>
> Hello,
>
> On 14.01.2016 11:52, Bilal ma wrote:
> > Thank you for the examples, does it make difference if i don't pass my
> > input-output POD struct by reference since it need to be copied to the
> > server side, and later from the server to the client.
> > from the point view of performance which one is the best if we add the
> > option of placing my POD in shared memory.
>
> the RPC mechanism always copies data. It does not use shared memory.
> Please review Section 8.12.2. "Transferable argument types" to get a
> picture how different argument types are handled.
>
> If a reference is passed as argument, the following steps are taken:
>
> 1. The argument is copied into the message to be sent to the server.
>
> 2. The server instantiates a temporary object of the argument type
> and copies the argument from the message to the temporary object.
>
> 3. The server-side RPC method is called with a reference to the
> temporary object as argument.
>
> 4. Once the server-side RPC method returns, the new content of the
> temporary object is copied to the reply message buffer.
>
> By using the temporary object instance, it looks like you pass a
> reference. But under the hood, the server operates on a different object.
>
> You mentioned performance. If you need to transfer large amounts of bulk
> data between components, you may consider shared memory. For a
> description of how to set up shared memory between components, please
> refer to Section 3.6.3. "Shared memory" in [1].
>
> That said, I recommend you to think twice about introducing a new
> session interface. Maybe an existing interface would do the job just
> fine when looking at your problem from a slightly different angle? To
> cite the intro of Chapter 4:
>
> "The versatility of a component-based system does not come from
> the existence of many components alone. Even more important is
> the composability of components. Components can be combined only
> if their interfaces match. To maximize composability, the number
> of interfaces throughout the system should be as low as possible,
> and all interfaces should be largely orthogonal to each other."
>
> Whereas it is a nice exercise to design a custom RPC interface, I mostly
> advise against it. In particular, if your interface is just a bunch of
> getters and setters, the existing ROM and Report session interfaces may
> accommodate you quite well.
>
> [1] http://genode.org/documentation/genode-foundations-15-05.pdf
>
> Cheers
> Norman
>
> --
> Dr.-Ing. Norman Feske
> Genode Labs
>
> http://www.genode-labs.com · http://genode.org
>
> Genode Labs GmbH · Amtsgericht Dresden · HRB 28424 · Sitz Dresden
> Geschäftsführer: Dr.-Ing. Norman Feske, Christian Helmuth
>
> ------------------------------------------------------------------------------
> Site24x7 APM Insight: Get Deep Visibility into Application Performance
> APM + Mobile APM + RUM: Monitor 3 App instances at just $35/Month
> Monitor end-to-end web transactions and take corrective actions now
> Troubleshoot faster and improve end-user experience. Signup Now!
> http://pubads.g.doubleclick.net/gampad/clk?id=267308311&iu=/4140
> _______________________________________________
> genode-main mailing list
> genode-***@lists.sourceforge.net
> https://lists.sourceforge.net/lists/listinfo/genode-main
Loading...