Hello All,

I'm not sure you can help me with this but there is no point talking to
IBM support on this.  No one locally will understand what I'm doing and
since it is on 440 I can't get official support.

Problem 1
=========
In an effort to track what is happening on the heap, and because I
couldn't find any other way to solve this, I used the MATHSAT (Materialize
Heap Space Attributes) instruction to see what's happening on the heap.
The MI Reference shows this instruction as returning counts of the number
of allocations, reallocations, and deallocations occuring on the specified
heap.  The default heap has a heap ID of 0 and as far as I can tell the
default heap is used by the C functions malloc(), realloc(), and free().
Each activation group has its own heap (or possibly more than one).  The
default heap is created on the first use of malloc() or CEEGTST.

Here is the MI code:

    DCL SPCPTR @HEAP_INFO PARM;
      DCL DD HEAP_INFO BAS(@HEAP_INFO) CHAR(1000);
        DCL DD BYTES_PROV  DEF(HEAP_INFO) POS(1) BIN(4);
        DCL DD BYTES_AVAIL DEF(HEAP_INFO) POS(5) BIN(4);
    DCL SPCPTR @HEAP_ID PARM;
      DCL DD  HEAP_ID BAS(@HEAP_ID) CHAR(8);
        DCL DD ACT_GRP DEF(HEAP_ID) POS(1) BIN(4) UNSGND;
        DCL DD HEAP    DEF(HEAP_ID) POS(5) BIN(4) UNSGND;
    DCL OL ENTRY ( @HEAP_INFO, @HEAP_ID ) EXT PARM MIN(2);

    DCL CON HEAP_SPACE_ATTR CHAR(1) INIT(X'00');

 ENTRY * (ENTRY) EXT;

 BRK '0001';
    MATHSAT  @HEAP_INFO, @HEAP_ID, HEAP_SPACE_ATTR;

 BRK '0002';
    DEACTPG *;
    RTX *;
    PEND;

This is invoked from a C program that determines the activation group mark
(via MATAGPAT) and sets the heap ID to 0.  This is necessary to avoid
issues due to the OPM MI program running in the default activation group
but the program that allocates the heap storage is in a *NEW activation
group.  (I would prefer to do it all via C but IBM did not provide an
include for MATHSAT and the C compiler barfs with an invalid instruction
stream when I created one -- I think it objects to the _MATHSAT built-in
but that's a subject for another note.) I have a C structure that corectly
maps the heap space attributes according to the documentation in the 440
MI reference manual.  The address of this structure is passed as the first
parameter to the above MI program.

The C program also allocates storage from the default heap using both
malloc() and the CEEGTSTG API, it reallocates that storage using both
realloc() and CEECZST, and releases the storage using both free() and
CEEFRST.  There is one call to each function and I use separate pointers
for each class of function (i.e., one pointer for alloc(), realloc() and
free(), and another pointer for the CEE APIs).

Then it invokes the above MI program.  The program works (as in no
exceptions) however the counts of allocations, reallocations and
deallocations are not set correctly.  They are all zero with the exception
of the reallocation count which is 1.  Using debug I determined this is
set as a result of calling the CEECZST API.  CEEGTST, CEEFRST, alloc(),
realloc(), and free() have no effect on the counts.  The other fields in
the structure (e.g., allocation strategy bits) are set correctly. I've
looked at the raw data in hex in case the problem was due to misalignment
but the count fields are definitely zero.  Strange?  Broken?

Problem 2
=========
Since MATHSAT did not work as documented I tried the MATRMD instruction.
Option X'17' of this instruction returns storage allocation values for
every thread and task on the system.  The code is in C but is using the MI
built-in _MATRMD.  The include for MATRMD has an error and one of the
structures should be _Packed but is not thus the structure is thrown out
by padding bytes.  I fixed that :)

I retrieve the PCS pointer and materialize it to get the PCS name.  I use
this value to search the list of tasks and I print out the allocation
amount, deallocation amount, and the difference between them.  These
values are in pages rather than bytes.  So I use option X'12' of MATRMD to
get the page size in bytes.  Here is the problem.  I provide 64 bytes of
space for the materialization which is enough for the the control
information which includes the page size.  Most of the other fields in the
structre are set correctly (number of ASPs, number of disk units, etc.)
but the page size is ZERO!!  What use is that when the allocation values
returned by many of the MI functions are in pages.  How can you convert
from pages to bytes except by hardcoding a page size (IIRC it is 4096)
which is not nice.  Why is this value zero?

Questions
=========
Am I mad?  Should these instructions work as I expect?  Has anyone else
tried using these MI instructions?  Did they work for you?  These programs
are user-state because nothing in the documentation suggests that they
require system-state access.  I might try that to see if it helps.

I can supply the additional C code for those of you interested in
investigating this.

Regards,
Simon Coulter.

--------------------------------------------------------------------
   FlyByNight Software         AS/400 Technical Specialists
   http://www.flybynight.com.au/

   Phone: +61 3 9419 0175   Mobile: +61 0411 091 400        /"\
   Fax:   +61 3 9419 0175   mailto: shc@flybynight.com.au   \ /
                                                             X
                 ASCII Ribbon campaign against HTML E-Mail  / \
--------------------------------------------------------------------



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.