× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



This reminds me of a previous issue concerning procedures that return values which a prototype defines as a LARGE varying length character variable.
A program containing many statements that employ such a procedure could run into unfathomable automatic storage overflow exceptions.
Barbara eventually explained that this was an unavoidable consequence of the code the compiler generates to handle varying length return values, from which I concluded that such procedures were potentially a bad practice. I recall the practice being compounded when compiling as an optimized object.

Peter

-----Original Message-----
From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx] On Behalf Of Bruce Vining
Sent: Thursday, 27 November 2008 7:26 a.m.
To: RPG programming on the AS400 / iSeries
Subject: Re: Calling C from RPG: what am I doing wrong?

Scott,
 
As part of constructing the call interface there is always 16 bytes allocated for a return value.  This allocation is done by the caller and is true whether or not a return value is defined by the prototype.  If the caller prototype DOES have a return value defined and the return value is greater than 16 bytes in length, the caller initializes a pointer into the return value storage which is subsequently used to locate the return value.  If the caller is not aware of the return value being greater than 16 bytes in length, then this pointer is not initialized.  Any return value less than 16 bytes in length gets stored into the caller allocated storage and/or, in some cases, stored in a register to provider improved performance (which is why data type can be important).
 
When the called program is ready to return the greater than 16 byte value, it takes the pointer initialized by the caller and then "does some magic" and provides addressibility to the returned value.  Now the problem -- this pointer wasn't initialized in our scenario.  If that storage just happens to contain a valid pointer, well, undesireable results will most likely occur at some point in that job.  If that storage does not contain a valid pointer, probably the more likely case, then you're going to get a MCH and fall into an error path.
 
This convention for return value handling is independent of the high level language.  It is part of ILE implementation rather than a HLL compiler directly generating the correct code.
 
As for the hand slapping, perhaps I was a little too strong there :)  If there's a good reason for doing it, go ahead.  But you better remember to prototype that return value (which in your example they clearly would).
 
I also have to admit that I cheated a little bit here...  When I saw your post I was pretty sure about the above, but not sure enough (it's been awhile and I'm getting old) to post immediately. So I did confirm this with one of the ILE architects first :)

Bruce
Bruce Vining Services
507-206-4178

--- On Wed, 11/26/08, Scott Klement <rpg400-l@xxxxxxxxxxxxxxxx> wrote:

From: Scott Klement <rpg400-l@xxxxxxxxxxxxxxxx>
Subject: Re: Calling C from RPG: what am I doing wrong?
To: "RPG programming on the AS400 / iSeries" <rpg400-l@xxxxxxxxxxxx>
Date: Wednesday, November 26, 2008, 12:00 PM

Hi Bruce,

There is a case where storage could inadvertently be overwritten but
it is only when a value is being returned that exceeds 16 bytes in
length.

Really? Can you explain that? That makes little sense to me. The system reserves 16 bytes for a return value, even if none is declared, you just can't exceed the 16 bytes???

That's a very weird (and not very intuitive, and not documented
anywhere) thing.

I've had problems with undeclared return values before. If you resolve a routine via QleGetExp and call it without a return value (assuming the procedure declares a return value, but your prototype does not) I've had
nasty problems. But, my return values might've been longer than 16
bytes, I don't remember anymore.

I'm assuming that RPG calling C would have the same problems. The RPG side doesn't know that the C procedure is going to return something, because it wasn't included in the prototype.

Note that this is a VERY different symptom from declaring a return value on the prototype and not using it. If it's declared on the prototype, RPG knows about it, and even if you don't use the return value, the compiler will handle it properly.


And any developer returning "something" longer than 16 bytes by value
(as opposed to a 16-byte pointer to the "something")
should
have his or her hands slapped.

Then you have a LOT of hand slapping to do, my friend. It's a common practice in RPG. If you want to return a string from an RPG subprocedure and use it in an expression, you MUST declare it as a return value (which is by value). And more often than not, string values are longer than 16 bytes.
--
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.

--
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.

#####################################################################################
This correspondence is for the named person's use only. It may contain confidential or legally privileged information, or both. No confidentiality or privilege is waived or lost by any mistransmission. If you receive this correspondence in error, please immediately delete it from your system and notify the sender. You must not disclose, copy or rely on any part of this correspondence if you are not the intended recipient. Any views expressed in this message are those of the individual sender, except where the sender expressly, and with authority, states them to be the views of Veda Advantage. If you need assistance, please contact Veda Advantage on either :- Australia 133124 or New Zealand +64 9 367 6200

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.