On 02-Dec-2011 09:25 , mgarrison@xxxxxxxxxx wrote:
I have the following program (subset of the actual program but this
will compile for demonstration purposes) using the QGYOLSPL api to
retrieve a list of the spool files on our systems. When I run the
program it is crashing with escape error message MCH1210 Receiver
value too small to hold result which is not listed in the
documentation for the QGYOLSPL api. We are at v6r1.

The specifics of the error msgMCH1210 [e.g. from the spooled joblog or f6=print; or maybe the dump and QPDSPJOB if produced] were omitted. Nobody can know with accuracy, what describes the failure, without that information. If the error was in the user program, then of course the API would not be reporting that condition. Since the invocation specifies an [apparently valid] error code parameter, no errors should be signaled from the API to the user program; more likely the error is in the user program, where the API has no control.

Does anyone have any thoughts as to why I am receiving the error
message?

An overflow on an assignment to a numeric variable is the most likely origin :-) Thus if for example, the API were told to write a numeric value into an signed n-byte integer variable, but the API documentation requires that the receiver variable should be an unsigned n-byte integer, then half of the possible values would effect an overflow.

I have tried numerous things including copying from posted
on the net and without success I am now definitely into the WAG
stage.

Review of the full details of the MCH1210 might be helpful to enable a transition from a WAG toward a SWAG.

From an old discussion found on the web, and an old APAR, the likely origin is incorrect filtering; either by specification to the API, or by the program which performs the filtering for the API, such that the actual number of spooled files returned greatly exceeds what should have been included by the selection.?

With mention of filtering, a cursory review of the code <<snipped from this reply>> shows the third parameter [which is OUTPUT] is using the same uninitialized DS as the sixth parameter [which is INPUT] for the filtering. Using the same storage for both an input and an output parameter is by itself, very likely to lead to catastrophic errors. Thus that is very likely that is the cause of the problem, and very possibly causing the API to fail long before the API has even been able to setup error code processing to inform by error code versus error message.

Regards, Chuck

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:

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.