×
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.
Comment inline
At 11:43 AM 11/29/2004, you wrote:
A couple of notes that I think were not covered..
1) *CALC works well when you have similar jobs, using the same sets of
database files, and you have lots of memory in the pool. You have to keep
memory in the pool using the WRKSHRPOOL minimums, because the autotuner
basically cannot see the effect of the extra memory in use by *CALC and will
remove it without regard to *CALC.
When you are not using the same set of database files, *CALC will have
little effect - it is all about keeping records in memory (caching). When
you have a small amount of memory, *CALC will appear to have little effect.
Right - this goes along with your next point about like jobs. And it is
important to have the same kind of file access for an extended time to take
advantage of this. *CALC (turning on Expert Cache) is primarily a paging
option, as shown on the WRKSYSSTS screen, etc. I.e., it has to do with the
reading from and writing to disk. The pattern of file access is posted by
the DB processor. Random access will use smaller blocks for each I/O
request, totally sequential will use larger transfer block sizes. But
sequential access also implies using more memory - random allows exchange
brings, or using the same memory for subsequent reads.
You can use the MATRMD function to see this stuff, option x'14'. Here is a
little C code that will get the information into a variable - run it in
debug and set a breakpoint on the "return;" statement. When it stops, put
eval *RMD_template:x 6688
on the command line there. This is the full size of the variable - for 64
pools - you can use less, 104 for each pool plus 32 for some header info.
There are no RPG copy members for this function. Look under MI functions
under APIs under Programming in the V5R3 InfoCenter to get details on this.
To compile, you need C installed. Then paste this into a source member type
C and put a 14 on it. Use DBGVIEW(*ALL).
========================================
#include <stdlib.h>
#include <matrmd.mih>
int main(int argc, char * argv[])
{
_MATRMD_Template_T *RMD_template;
char control[8];
control[0] = _MATRMD_STORAGE_POOL_TUNE;
RMD_template = (_MATRMD_Template_T *)malloc(6688);
RMD_template->Template_Size = 6688;
matrmd(RMD_template, control);
free(RMD_template);
return;
}
=========================================
You could run this in CL, too. Make a character variable 6688 long. The
control variable is 8 long, hex 14 in position 1, x 00 in the rest. In
debug, be sure to use the ":x" after the variable to see it in hex.
Enough fun yet? ;-)
Vern
-snip-
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.