Hi Barbara,

does adding Options(*Varsize) to a CONST or VALUE parameter have any effect?
I mean are only the used bytes copied or is always the complete field length
copied?

Birgitta

-----Ursprungliche Nachricht-----
Von: rpg400-l-bounces@xxxxxxxxxxxx
[mailto:rpg400-l-bounces@xxxxxxxxxxxx]Im Auftrag von Barbara Morris
Gesendet: Donnerstag, 13. Januar 2005 23:37
An: rpg400-l@xxxxxxxxxxxx
Betreff: Re: Service Program Argument Optimization


Jon Paris wrote:
>
> Which is exactly why keeping one pointer per parm and loading it during
the
> initialization phase is a good trade off!
>
> Barbara can tell us for sure, if this is true for RPG IV but I'd be
> surprised if it wasn't.
>

Actually I can't tell for sure.  The RPG compiler is just an
intermediate stage in the actual compile.

The RPG compiler doesn't generate code to load addresses during
initialization and save them in pointers.  It generates code to load
addresses as it needs them.  But I imagine the optimizating translator
is probably able to do some wizardry with address loading.

Regarding passing string parameters by value or by const: if you have
varying length parameters, it is almost always better to pass them by
const and copy them to a temp within the procedure (if you need to).
The copy within the procedure will only have to copy the current length
of the varying parameter.

A thought experiment:

To pass a string parameter, there are a few of places that data is
copied:
1. Converting from the passed parameter to a temporary, if the passed
parameter does not match exactly.  If the prototyped parameter is
varying length, only the length of the passed parameter has to be
copied.  If the prototyped parameter is fixed length, blank padding may
also be required.
2. Passing the parameter.  This is either setting the 16-byte pointer or
copying the entire variable/temporary; if it's a varying length
temporary, the whole temporary must be copied, not just the current
length.
3. Copying within the procedure if you pass CONST and need to modify it
or take its address.

Consider the case of passing an x-byte-long parameter (varying or fixed,
doesn't matter) to a FIXED/VARYING 32767 parm, VALUE or CONST, where the
procedure needs to be able to change it.

                 Fixed-VALUE    |   Fixed-CONST  |  Varying-VALUE |
Varying-CONST

---------------+----------------+----------------+----------------
1. Conversion    x              |  x             |   x            |    x
2. Passing       32767          |  16            |   32769        |
16
3. Copying       0              |  32767         |   0            |    x

---------------+----------------+----------------+----------------
   Total         x + 32767      |  x + 32783     |   x + 32769    |
2x + 16


For a few values of x:
  x =     1      32768           32784               32770
18
  x =    10      32777           32793               32779
36
  x = 32766      65533           65549               65535
65548

If you don't need to modify/%addr within the procedure:
  x =     1      32768              17               32770
17
  x =    10      32777              26               32779
26
  x = 32766      65533           32782               65535
32782

I don't know if performance tests would show results that conform to
this; this is just a thought-experiment.

--
This is the RPG programming on the AS400 / iSeries (RPG400-L) mailing list
To post a message email: RPG400-L@xxxxxxxxxxxx
To subscribe, unsubscribe, or change list options,
visit: http://lists.midrange.com/mailman/listinfo/rpg400-l
or email: RPG400-L-request@xxxxxxxxxxxx
Before posting, please take a moment to review the archives
at http://archive.midrange.com/rpg400-l.





As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.