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


  • Subject: Re: iseries pgm call support
  • From: "Steve Richter" <srichter@xxxxxxxxxxxxx>
  • Date: Fri, 13 Jul 2001 15:40:21 -0400

Bob Donovan said:

>o How do the caller's obtain the address of the external module?   What if
>I need to change the external module ... will all of the caller's be
>updated with the new address (even if they are currently running)?
>


You would set a system pointer to the module and than an instruction
pointer. Same as a dynamic pgm call. If the module is subsequently
recreated, invalidating the instruction pointer, an exception would occur.

A solution: exception handling in the caller would reresolve the ptr and
retry the call.  This requires an enhancement to the machine to enable the
dynamic setting of an instruction pointer within a pgm so that the exception
handler could branch back to the code to be retried.

A 2nd solution: Another machine enhancement. Provide a bit in the 16 byte
pointer itself. If set and a destroyed object exception occurs, the machine
would auto resolve to the new version of the named object.  ( this is a
little tough to do because the original resolve template has to be retained.
( in case *libl was spcfd )  But hey, space is cheap.  The machine should
provide a "ptr plus" data object.  Large enough to contain the 16 byte ptr
plus the resolve template contents.


>o Can external modules define data?  If so, explain how you might support
>static or automatic variables.


Statics and globals. Arguably can be implemented as data in a usrspc in
qtemp of the job. Otherwise, the machine could provide some kind of run time
name resolution to the actual location of the variable in the global space
of the job/pgm. Very interesting topic of discussion though, the role of
globals in a structured modular pgm.


>
>As you address these details, I think you might come up with something that
>is pretty similar to the existing mechanisms for transferring control
>between code e.g., dynamic program calls and static binding).  If not, then
>I would agree that Roch needs to take a closer look.


If comparing against the dynamic pgm call than the comparison is based on
speed of the call,  the size of the pgm/module object and most important,
the default behavior of the system when entering and exiting the pgm/module
( close files, delete overrides: pgm yes. module no. )

If comparing against the static ile module I have to defer to those who know
more than I do.    If the static binding contributes to pgm structure and
design, that is something in its favor.  But if static binding is justified
because of run time efficiency and aux storage space constraints, well I
judge that reason as retired. Computers are 1000x faster now than when
static binding was first introduced.


enjoy your weekend,

Steve Richter



+---
| This is the MI Programmers Mailing List!
| To submit a new message, send your mail to MI400@midrange.com.
| To subscribe to this list send email to MI400-SUB@midrange.com.
| To unsubscribe from this list send email to MI400-UNSUB@midrange.com.
| Questions should be directed to the list owner/operator: dr2@cssas400.com
+---

As an Amazon Associate we earn from qualifying purchases.

This thread ...


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.