|
There are roughly 12,500 lines of code in the start up of the RPG program logic cycle. Back when they were first doing ILE, they said that the dynamic call was about 2500 lines of code. The new bound call is about 250 lines of code. So the procedure call is 10 times faster than the dynamic call (based on the original implementation, but it is probably faster today). Subsequent calls to a bound procedure run a few dozen lines of code (faster than that first bound call). However, if you add the 12,500 lines of cycle code to the 2,500 lines of dynamic call you end up with 15,000 lines of code for a dynamic call. If you change the dynamic call to a bound call you end up with 12,750 lines of code on that bound call to an RPG IV module. A difference of less what 15 percent give or take? In other words, unnoticeable by humans. And that's just lines of code, not the speed in which those lines execute. I would be the performance ratio of dynamic call to an RPG IV module version bound call is narrower. In fact, I've heard some people say that CALLB to a module can be slower in some situations than a regular old CALL. -Bob Cozzi -----Original Message----- From: rpg400-l-bounces+cozzi=rpgiv.com@xxxxxxxxxxxx [mailto:rpg400-l-bounces+cozzi=rpgiv.com@xxxxxxxxxxxx] On Behalf Of Krish Thirumalai Sent: Friday, January 07, 2005 2:03 PM To: RPG programming on the AS400 / iSeries Subject: Re: General ILE question - *LR I was following a thread based on an article you had written in 2003 CALL or CALLB ?(http://tinyurl.com/3zjds) and agree that in some instances it does not make sense or the time to convert and in most instances the performance improvements are not noticeable. Correct me if I am wrong but isn't a bound call faster than a dynamic call? Wouldn't you still get that benefit even if calling to a main line as opposed to a procedure? We need to keep this broken up code as fast as possible. We wanted to make the calls to the new programs faster by using bound calls instead of dynamic calls. One of my colleagues remembers that at a COMMON conference, in the intro to ILE class, they stated that one of the easiest benefits you can get from ILE is to change CALL to CALLB on programs that are not called by many programs but called extensively by the ones that do allowing for a faster call and thus better efficiency. Is that an incorrect assumption On Fri, 7 Jan 2005 11:27:49 -0600, Bob Cozzi <cozzi@xxxxxxxxx> wrote: > Right, RPG IV sucks when it comes to file sharing between modules. It just > really, really sucks. > One way to work around this, and it is not by any means perfect, is to > declare externally described data structures and then EXPORT/IMPORT the > between the modules. These DS's would be EXTNAME(myfile) and the files in > each module would then read into and from these data structure automatically > (the subfield names would match those of the input/output fields). Using > PREFIX and QUALIFIED DS's would be even better. > -Bob > > > -----Original Message----- > From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx] > On Behalf Of Krish Thirumalai > Sent: Friday, January 07, 2005 10:53 AM > To: RPG programming on the AS400 / iSeries > Subject: Re: General ILE question - *LR > > We have a mammoth RGPLE program that is currently using a very > subprocedures, but the main line portion of the code is still pretty > big and is getting to be a maintenance nightmare. > > We want to rewrite this program into several modules based on > different functionality, so that we can do some concurrent development > and make development/maintenance easier. We have figured out which > subroutines are common and which are not. > > Not sure what the easiest way to break this down since the program > currently uses around 100 files and we want to share the ODP and be > able to share data between these modules without having to chain back > to the same files in each module if we break these down. > > On Fri, 7 Jan 2005 10:37:30 -0600, Bob Cozzi <cozzi@xxxxxxxxx> wrote: > > I suppose the first question is why do you want to do this? > > What can you possible gain from making a module that has the RPG logic > cycle > > in it a bound call? > > Leave it a stand-alone program and dynamic call, you'll be better off. > > The only time you use multiple modules is when the NOMAIN keyword is > > specified on the header specification of the secondary modules. > > If you haven't begun using subprocedures, don't move to multiple modules. > > The "correct" order (in my view) is to begin using subprocedures first, > then > > move to using multiple modules. The capability to call a module by name > > using CALLB or a prototype is an anomaly due to the way RPG is structured > > and should always be avoided. > > -Bob Cozzi > > > > > > -----Original Message----- > > From: rpg400-l-bounces@xxxxxxxxxxxx [mailto:rpg400-l-bounces@xxxxxxxxxxxx] > > On Behalf Of Krish Thirumalai > > Sent: Friday, January 07, 2005 10:24 AM > > To: RPG programming on the AS400 / iSeries > > Subject: General ILE question - *LR > > > > I have a general ILE question. Say I am creating a module that is > > bound by copy to the calling program. The module has a mainline that > > logic will flow through each time it is called. Do I want to set > > *INLR on each time when logic reaches the end of the mainline or > > should I always just RETURN? Does turning on *INLR really do anything > > if the program is a module? > > > > Thanks > > > > Krish > > -- > > 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 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 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 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.