× 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: why the 16meg space size limit?
  • From: "Mark S. Waterbury" <mark_s_waterbury@xxxxxxxxx>
  • Date: Mon, 21 May 2001 18:00:39 -0600

Hello, all:

I just have to add my "two cents".  First of all, teraspaces are "fine" if
you really
need access to a very large "contiguous" chunk of memory, so that you can do
some (rather dumb) things like increment a pointer to walk through the
contents of
some vast data structure, array, etc., like many typical C or C++ programs
do,
usually on some Unix box or PC. So, IBM wanted to make it "easier" to "port"
the
(dumb) C programs to AS/400 and iSeries, and so, now we have "teraspaces".
;-)

However, if you are using any decent language with reasonable data
structuring
facilities, such as the ability to use pointers to create trees, linked
lists, etc., then,
why on Earth would you "need" to have a "contiguous" chunk of memory that
big,
in the first place??? (Let me explain...)

It is very easy to get chunks of memory, sub-allocated from within a
*USRSPC, or
from within an ILE heap space, and "chain" these together, in all sorts of
ways, to
create whatever larger data structures you want. You can even create
dynamically
sized, dynamically dimensioned "arrays" in this way, using linked list
structures.

Now, if you need to have a "persistent heap", then you would want to use
*USRSPC
objects, because they are permanent, unless you create them in QTEMP. If you
want
a "heap" that is automatically disposed of and "cleaned up" automatically at
"end of job"
then you can use the ILE heap. In fact, you can allocate multiple "heaps" of
up to 16 Mb
each, and yes, you can still chain together the little bits and pieces of
whatever it is that
you are "allocating" within these spaces.

If you are wanting to create a "persistent heap", then I advise against
storing actual
MI pointers within the data structures themselves. In this case, it would be
far better
to store some type of (segment, offset) tuple that represents the target
address, which
identifies which *USRSPC (space object) is to be used (segment #) and the
offset
within that space, because, that way, you can actually use SAVOBJ and RSTOBJ
to
save and restore all of the "component" *USRSPC objects, and of course,
after you
restore these objects (possibly on a different AS/400 machine), the original
"pointers"
would no longer be valid, because each of the *USRSPC objects would be
located at
a different virtual address anyway.  And, the code to convert between this
kind of
(segment, offset) notation and an actual MI pointer can be pretty efficient,
depending
on how you implement this in the programming language of your choice.

In OPM MI, you can create an array of pointers to spaces of 16 Mb each, and
when
addressing bytes within a space, you can handle the MCH0601 or equivalent
exceptions,
when you try to access beyond the end of a space, and have code that does
something
"appropriate", such as load a pointer to the "base" (beginning) of the next
*USRSPC,
and add an offset within that space object, etc.  Of course, this is not
quite as "easy" as
simply incrementing a pointer and marching through one "vast" teraspace.
However,
again, I must ask, what is it that you are doing that really requires such a
large space?

Also, if you were creating a compiler for a higher-level language, you could
do this
completely "under the covers" in the runtime routines and generated code,
and make it
appear totally "transparent" to the users of your "higher-level language";
the compiler just
emits the extra code where needed to convert between the (segment, offset)
format and
the "native" pointer format, whenever a pointer is picked up and used
(dereferenced).

And, consider the fact that many OS/400 "objects" at or above the MI layer
are actually
composed of one or more "spaces" (segments of up to 16 Mb each) below the MI
layer.
For example, a database "file" actually has at least 5 separate and distinct
components,
one containing the file description (fields, record layouts, etc.), one
containing the actual
data (for each member), one containing an "index" (for key-sequenced data),
etc.
So, this is really "no big deal".

Again, it all comes down to what is it that you want to do, that makes you
think that you
really "need" one very large, contiguously addressable sequence of bytes?

That's just my opinion.  And so, I don't think this is really all that much
of a "big deal".

Cheers,

Mark S. Waterbury


_________________________________________________________
Do You Yahoo!?
Get your free @yahoo.com address at http://mail.yahoo.com

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

Replies:

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.