| english:
¯¯¯¯¯¯¯¯
  The MemOptimizer package is FREEWARE.
   The purpose of this program is to periodically check your Amiga's free
  memory list(s) and automatically remove all memory fragments (chunks)
  which are smaller than a given threshold value. This will optimize memory
  allocations, as the lists become shorter and hence can be searched faster.
  => In patched mode (recommended) the removed chunks remain available for
     allocations via the freestack system provided by the memoptimizer.library,
     which gives fast access to the memory, even if there are 100s of chunks
     on the freestack.
  => Because the small chunks remain available, the large memory blocks in the
     system's freelist are protected from further fragmentation, as small memory
     allocations are satisfied from the freestack.
  => Additional some calculations are made to express the current fragmentation
     in such kind of numbers, which allow to compare the effects of MemOptimizer
     and the regular values without it.
  => Different from PoolMem and TLSFMem, MemOptimizer has proven to run stable
     even with any PowerUp and/or WarpOS software.
  => See Docs/MemOpt.html for full installation/usage details, Docs/MoLib.html
     contains the developer documentation for the memoptimizer.library.
  => If you wrote software using any functions of the memoptimizer.library,
     then feel free to distribute a standalone copy of the library enclosed
     with your package, but please mention the MemOptimizer.lha archive as
     its source and Aminet util/boot as the place to go for download.
  Find all my Software on Aminet:
  -------------------------------
   http://aminet.net/search?readme=rhosigma&sort=path
deutsch:
¯¯¯¯¯¯¯¯
  Das MemOptimizer Packet ist FREIWARE.
   Der Zweck dieses Programms ist der, periodisch die Speicherlisten deines
  Amiga's zu überprüfen und dabei automatisch alle Speicherfragmente (Chunks),
  welche kleiner als ein angegebener Schwellwert sind, zu entfernen. Dadurch
  werden Speicherreservierungen optimiert, da die Listen jetzt kürzer sind
  und daher schneller durchsucht werden können.
  => Im gepatchten Modus (empfohlen) bleiben die entfernten Speicherchunks aber
     weiterhin verfügbar über den von der memoptimizer.library bereitgestellten
     Speicherstapel. Die Verwaltung des gleichen erlaubt schnellen Zugriff auf
     den Speicher, selbst wenn sich 100te Chunks auf dem Stapel befinden.
  => Da die kleinen Speicherchunks verfügbar bleiben, sind außerdem die großen
     Speicherblöcke in den Systemspeicherlisten geschützt vor weiterer Fragmen-
     tierung, da kleinere Speicherreservierungen vom Speicherstapel genommen
     werden können.
  => Zusätzlich werden noch ein paar Berechnungen angestellt, um die jeweilige
     Fragmentierung in verständliche Zahlen zu fassen, damit man den Effekt von
     MemOptimizer auch mit den regulären Werten ohne diesen vergleichen kann.
  => Anders als PoolMem und TLSFMem, hat MemOptimizer auch ein zuverlässiges
     Laufzeitverhalten mit beliebiger PowerUp und/oder WarpOS Software bewiesen.
  => Siehe Docs/MemOpt.html für Installations- und Benutzungshinweise, darüber
     hinaus enthält Docs/MoLib.html auch die Entwicklerdokumentation für die
     memoptimizer.library. (Docs alle nur in englisch verfügbar.)
  => Wenn du Programme geschrieben hast, die irgendwelche Funktionen aus der
     memoptimizer.library benutzen, dann darfst du gerne eine Einzelkopie der
     Bibliothek deinem Programmpacket beilegen, aber bitte weise darauf hin,
     daß die Quelle das MemOptimizer.lha Archiv ist und dieses auf dem Aminet
     unter util/boot zum herunterladen bereit steht.
  Finde alle meine Software im Aminet:
  ------------------------------------
   http://aminet.net/search?readme=rhosigma&sort=path
===========================================================================
History:
¯¯¯¯¯¯¯¯
v1.000 (16.11.05)
       - initial Release
       - removes small memory chunks (by threshold) from exec's MemLists to
         speed up allocations
       - simple GUI to change shell given options and some statistic output
v1.139 (20.05.06)
       - optional use of »memoptimizer.library« for further enhancement of
         memory allocations
       - statistic outputs in GUI now features combined numerical & graphical
         (gauge like) display
v2.180 (30.06.06)
       - two new functions in »memoptimizer.library« added, see developer docs
       - freestack system improved for better internal function, it's almost
         self-maintaining now, so the removed chunk num/size displayed in the
         GUI should fall back to zero always within 1-2 loops (in patched mode),
         this avoids the unexpected flushes done when exceeding the given limit
v3.013 (21.01.07)
       - general rework of the freestack system of the »memoptimizer.library«,
         it's now calculating to satisfy any allocations rather than searching
         through endless chunk lists - much faster
       - new patch for AvailMem() added to avoid fluctuation of any free memory
         displays/monitors reported in earlier versions, free size on stack
         will be added to free system size (according to given memory attributes)
       - low memory handler added if running under OS3.0+ (V39+) which will
         handle re-merge of chunks dynamicly as required by the system
       - special handling of MEMF_REVERSE allocations implemented, see docs for
         »MoReverseNames« CLI utility for more info
       - the mainprogram MemOptimizer was carefully »handoptimized« to hold most
         frequently used pointers/counters/variables in registers rather than on
         stack or small data segment
       - please read the docs, much new info added
v3.056 (01.09.07)
       - optimizations in AvailMem()-Patch, will correctly handle MEMF_LARGEST
         for the freestack now, even if this is more theoretical, cause the
         largest block must be down below 4096 bytes to get a chance to satisfy
         the query with a block from the freestack, in most cases the system
         will probably refuse to work long time before you reach such a low
         memory situation
       - arithmetic overflow condition fixed in StackUsage()
       - MEMF_REVERSE fix in AllocRuntime(), was refused even if the calling
         task was allowed, if memory was taken from freestack (makes no sense
         here, cause memory chunks on freestack are unordered), now any allowed
         REVERSE allocations are put through to system's FreeList to make sure
         they're satified from the top of MemList
       - dangerous condition in ClearStack() fixed, a pointer was used after
         the memory it points to was already freed
       - as several people reported to me, MemOptimizer does also work fine
         under MorphOS, but you should run it in UNPATCHed mode, as it is not a
         wise idea to replace native PPC code with 68k routines
v3.062 (10.09.07)
       - fixed all Enforcer/MuForce Hits, which were simply a side effect of a
         wrong branch, which finally caused operation on an NULL pointer
       - REVERSE name checks only performed now, if at least one name is in
         list, makes no sense to obtain the Task/Command name first, just to
         find out later, that there is no name in the list to compare it with
       - keeping the freestack entries sorted in ascending order now, which
         will result in somewhat faster flush operation
v4.080 (21.03.10)
       - patches installed in SaferPatches (+similar) compatible way now
       - wrong branch instructions fixed for unsigned address checks
       - new library function - StackHitRate()
       - new patch + bugfix for AllocAbs()
       - new resource tracking functions implemented
       - new fast block clearing routines implemented (CPU sensitive)
       - general tuning to make library independent from master
       - improved Chunk recycling routines
       - ramlib/RAM check - load resources to upper memory area
       - logfile stuff and in-build GUI removed from master
v4.092 (03.04.10)
       - just some improvements for MoMeter to feature more layouts and let the
         user save the current state/position
v4.093 (20.12.10)
       - just a little improvement regarding priorities, after watching my
         system over several month now, I've adjusted the task, semaphore and
         low memory handler priorities of the master, library, GUI and MoMeter
v4.153 (02.06.11) - [not published]
       - many tests and experiments to further improve the chunk recycling and
         resource tracking routines
       - project went out of focus because of immense lack of time
v4.200 (12.05.15)
       - some more improvements in chunk recycling routines to allow for better
         re-merge behaviour with chunks in system's freelist
       - fixed an arithmetic overflow in fragmentation calculation
       - added DONOTWAIT and STARTPRI=-1 tooltypes to "SaveState" menu operation
         of MoMeter
 |