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



On 10-Jan-2012 02:03 , PAPWORTH Paul wrote:
I'm unable to understand why in an RPG programme that writes to a
file in a loop, that after the first write we get the following
errors

MCH3601 Undefined pointer error <<SNIP>>

The message MCH3601 is an error suggesting that a pointer is "not set for location referenced" and that the null [or disabled] pointer was being "used, either directly or as a basing pointer, that has not been set to an address." That information is available to anyone who can DSPMSGD MCH3601 MSGF(QCPFMSG). Not very interesting nor informative.

While knowing that effectively the second write gets the error, what really matters generally, after knowing that generic pointer exception was signaled, is what signaled the exception and what was the target of the exception in any particular scenario. That information is available from F6=Print after F1=Help on that specific message, or from a spooled joblog. Knowing that, there is the possibility to infer better where to investigate further [in a trace and\or debug].

The processing before the write is complex and involves a number of
RPG ILE programmes and RPG service programmes. The Activation groups
look OK (Named) however interspaced in the processing are a couple
of RPG (OPM) programmes. Is it possible that these could be the cause
of our problem. We are at Version 6.

Yes. Any program on the stack with a pointer to storage in a previous call stack entry [e.g. parameters passed by reference] has the potential to update the storage in that prior program. Improper updates to storage via these pointers can corrupt contents of variables in adjacent automatic storage for example. Corrupted storage could be HLL run-time variables, including pointers, used to implement something like the .WRITE procedure. As an integrity measure by the OS, any pointer which is modified by any means other than a proper /method/ would be deactivated such that the next reference to the pointer will incur the LIC exception 2401; i.e. the MCH3601.

Another possible origin for an MCH3601 is more mundane and alluded by another reply; i.e. involving activity directed to a file that has already been closed. However I believe a file previously closed as detected by WRITE, will be manifest as a Data Management error to the program, even if the MCH3601 remains logged.

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.