|
Hello, all: Although I do not have many problems with the inherent limitation of 16 MB for the "segment size" for most objects above the MI layer, I do have a few "pet peeves" about "arbitrary" limits in OS/400. For example, why are *DTAARAs limited to a measly 2000 bytes? Since the *DTAARA is implemented by a "space" object at the MI layer, there is no good reason not to allow users to create a *DTAARA of up to 16 MB in size, and to allow us to use the RTVDTAARA command, or the QWCRDTAA API, to "substring" anywhere within that (up to 16MB) space. (This is apparently something that goes way back to the S/3, S/32, S/34 or S/36 architectures.) There is an old saying in Computer Science, that goes something like this: "More sins are committed in the name of compatibility...". You get the idea... Of course, for years, we have suffered with the limit of only 25 libraries in the user portion of the "library list." Now, finally, after all these years, in OS/400 V5R1, IBM has addressed this "limit" by increasing the limit by a factor of 10, to 250 libraries in the library list. Of course, there are some coding changes that will be required for applications to co-exist with the new longer library lists, and it is not entirely clear how "smooth" the transition will be. However, here too, I would like to ask the question, why "250" libraries? Why not raise the bar to, say, 500 or 1000 libraries? Why place "arbitrary" limits on things like the "library list"? Of course, I can still remember back when, around OS/400 V1R2, the maximum size of any database file (physical file member) was limited to 2 GB of data. That is 2 Gigabytes total, and not the total number of records in the database file. Of course, in those days, circa 1989, disk drives were much smaller in capacity and much more expensive, per byte, than today. And, IBM began to relax many of these "limits" starting in V2 of OS/400, and continuing in V3 and V4. So now, the limits on a file size are much larger, so that, in effect, they can grow to practically an "unlimited" size, limited only by how much disk space you want to buy, and how much room you have to plug-in more DASD, etc. Recently, there has been much discussion in this list about the "limits" of space objects to 16 MB per space object (such as the *USRSPC object). I recall that, in OS/400 V1R1 and all the way until V2R3, the size of the EPM "heap" (AS/400 Pascal and the original C/400 ran in the Extended Program Model or EPM environment) was also limited to a maximum of 16 MB. This imposed some rather harsh restrictions on many applications that use dynamic linked lists and similar modern data structures. What I did to "get around" this limitation was to, in effect, write my own heap storage manager, using an MI routine to create an MI space object, (which I later converted to use *USRSPC objects, when these became available), and used my own "new" or "malloc" routine to allocate from within the 16 MB user space. One "trick" I used was to NEVER try to "dispose" or "free" any allocated memory, but rather, to use "sunset garbage collection", which means, when the sun sets, (the job ends), we "collect all the garbage" (delete all of the *USRSPC objects). Thus, the "new" or "malloc" routine had only to increment a space pointer, by the size of the amount requested, plus rounding to a 16 byte boundary, so that pointers in data structures would be properly aligned, and, to check that the size of the allocated object would "fit" within the current 16M *USRSPC. If not, then create another *USRSPC, chain them together, and then start allocating from this new *USRSPC object. Thus, at any one time, there is only one "current" *USRSPC object from which current allocations are performed. Later, with V2R3, IBM introduced the Integrated Language Environment (ILE), although at that time, the only ILE language was ILE C/400. However, IBM also introduced several new OPM MI instructions to support the new ILE heap model, including CRTHSS (Create Heap Space), which created a heap space (of up to 16 MB), ALCHSS (Allocate Space from a "heap"), DLCHSS ("Deallocate space from a heap"), and DESHS (Destroy Heap Space), which deleted an entire ILE heap space. So, I converted my own heap space manager from using *USRSPC objects to using the new ILE heap spaces and instructions. This has the added advantage that, at the "end of job" (when the "sun sets"), OS/400 automatically cleans up all of the heap spaces. The bottom line is that I have never had a problem with allocating dynamic data structures (linked lists, trees, etc.) whose agregate size far exceeds the 16 MB "limit" imposed by the size of any single "segment" in OS/400. You just have to take that into consideration at the appropriate "level" in the design of your application. Most applications that use dynamic storage will usually have their own "storage management" layer anyway, to isolate the rest of the application(s) from the vagaries of the particular platform and OS that the application is running on. For those who really need a single contiguous large address space, where you can increment pointers or index large arrays to your heart's content, you now have the "teraspace", as of V4R4 and above (or was it V4R5?). And, if you really need a "persistant" contiguous "data space" (array), you can, of course, store the data in an IFS stream file, which is what most applications in the Unix world would normally do anyway. For example, in Unix, using the standard Unix file system I/O APIs, you can directly "seek" to any byte offset within the file, and then read or write for any number of bytes desired. (Recall that the Unix File System is byte stream oriented, rather than "record oriented", as are most IBM operating system file systems.) Thus, the Unix style APIs make it pretty easy to envision the contents of the file as some sort of a big "byte space", similar to the way the OS/400 APIs for accessing the contents of a *USRSPC allow you to store and retrieve "substrings" within the *USRSPC object space. And now, apparently with V5R1, you can use the "mmap" API, (from the Unix and Linux worlds), to "map" the contents of the file into a teraspace, so that you can linearly address it, if that is what you really want to do. And, as of V4R5 and above, you even have "journaling" of IFS files, so you can even "mirror" changes to a byte-stream file in the IFS, for example, for "high availability", to another AS/400, etc. Well, that's all for now. I would like to see this whole "thread" or topic put to rest. So, what's the "big deal"? Regards, 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 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.