home *** CD-ROM | disk | FTP | other *** search
/ AmigActive 19 / AACD19.BIN / AACD / System / SnoopDos / Readme_3.6 < prev    next >
Text File  |  2001-02-04  |  5KB  |  104 lines

  1.  
  2.              SnoopDos 3.6 -- System and application monitor
  3.  
  4.      Copyright © Eddy Carroll, September 1994. Freely distributable.
  5.  
  6.      Updated on January 2000 by Luca Longone and Massimo Tantignone
  7.                 with permission of the original author.
  8.  
  9.      Updated again on March 2000 by Grzegorz Chmie and Thomas Richter.
  10.  
  11.      Updated to 3.4 on August 2000 by Thomas Richter.
  12.  
  13.      Updated to 3.6 on Febrary 2001 by Thomas Richter
  14.  
  15.  
  16.  * VERY IMPORTANT NOTE: this archive contains an updated version of the
  17.  * SnoopDos executable, with the version number bumped to 3.6. This was
  18.  * NOT made by the original SnoopDos author, Eddy Carroll, but instead
  19.  * by Luca Longone and Massimo Tantignone, and Grzegorz Chmie 
  20.  * and Thomas Richter (with Eddy Carroll's approval).
  21.  *
  22.  * NOTE ABOUT THE 3.6 UPDATE
  23.  *
  24.  *  Note that there's no 3.5 update, it was an internal release that never
  25.  *  made it to the public.
  26.  *  The 3.6 update fixes two major bugs. The first bug is that the LoadSeg()
  27.  *  patch did not kept care about overlayed files and therefore might have
  28.  *  trashed overlayed programs. Note that LoadSeg() takes actually three
  29.  *  arguments and not one!
  30.  *  The second bug is even more severe, and is only partially fixed by this
  31.  *  release. SnoopDos semaphore handling was and still is extremly fragile.
  32.  *  SnoopDos 3.4 and before could have run into a race condition caused by
  33.  *  a cycling semaphore lock-up of three partners the patch code did not and
  34.  *  cannot check for. SnoopDos, workbench and input device hung then
  35.  *  simultaneously.
  36.  *  There are other race conditions of this kind, and all of them could only
  37.  *  be fixed if the patch code of SnoopDos would be completely re-designed,
  38.  *  a job I currently cannot and will not do.
  39.  *  Therefore, SnoopDos 3.6 contains a workaround and uses now a semaphore
  40.  *  mechanism which may "time out". The net effect is that at least the most
  41.  *  common semaphore deadlock should be avoidable now, but at the price that
  42.  *  the SnoopDos main window cannot be guaranteed to be 100% accurately up-
  43.  *  dated. Hence, in case the main window seems to have forgotten to update
  44.  *  its snoop list, or the result codes of some snoop entries are missing, or
  45.  *  some reports seem to be missing at all, don't worry! The alternative in 
  46.  *  these cases would have been to deadlock your system. As a side effect,
  47.  *  the ugly layers semaphore check was disabled now as it is no longer
  48.  *  needed, and in fact never really worked as it was unable to detect a
  49.  *  cyclic deadlock of three or more partners.
  50.  *
  51.  *
  52.  *
  53.  * NOTE ABOUT THE 3.4 UPDATE
  54.  *
  55.  * This update fixes one feature, and one bug. The feature is that the
  56.  * stack swap code was removed from SnoopDos 3.2 and up, and since people
  57.  * tend not to read the instructions, SnoopDos crashed on some machines due
  58.  * to stack overflow. The 3.4 release checks therefore for its stack size
  59.  * and will increase it to the minimal recommended size.
  60.  * The bug is that a possible race condition when closing the main window
  61.  * was overlooked. The 3.3 and earlier releases could have caused some
  62.  * "hits" in case the main window was closed while some other program run
  63.  * in the patch routines.
  64.  *
  65.  *
  66.  * NOTE ABOUT THE 3.3 UPDATE
  67.  *
  68.  * This update fixes a flaw of the 3.2 release that somehow was unnoticed.
  69.  * The 3.2 release could not be run from Workbench, due to an unexpected
  70.  * re-define of the WBenchMsg variable to _WBenchMsg in some of the SAS/C
  71.  * headers which broke the new startup code. I really did not expect 
  72.  * this, sorry. Except the version number, and a slightly different compiler
  73.  * option, nothing changed.
  74.  *
  75.  * The 3.2 update was made to remove one additional frequent enforcer hit
  76.  * that appeared when the snoopdos patches have been called in the middle
  77.  * of a graphics operation. In that case, RastPort->Layer is NULL'd and
  78.  * the code didn't check. Fixed.
  79.  * Another improvement is that SnoopDos accepts now "NewIcons" style
  80.  * icons correctly for iconification.
  81.  * General house keeping work has been done, one header file has been
  82.  * enlarged to include all the required prototypes, and the code was 
  83.  * recompiled with the registerized parameter option, making it quite
  84.  * noticably shorter. (And maybe quite unnoticably faster as well :-)
  85.  *
  86.  * For the more suspicious people, the updated source code is on Aminet
  87.  * as well (util/moni/snoopdos32_src.lha). 
  88.  *
  89.  * The SnoopDos executable was recompiled for the plain 68000 again because
  90.  * I do not see the point why to go for an 68020 if it is not necessary.
  91.  * The code shrunk anyhow and I do not notice a speed improvement by using
  92.  * the 68020 switch.
  93.  *
  94.  * The original SnoopDos 3.0 documentation is included in this update
  95.  * without any modification, but please note that all references to PGP
  96.  * can't be applied to this update. If you need confirmation about the
  97.  * genuine nature of this update you can ask us or the original author.
  98.  *
  99.  * Luca Longone:       llong@tin.it, hexaee@tiscalinet.it
  100.  * Massimo Tantignone: tanti@intercom.it
  101.  * Grzegorz Chmie:     gchmiel@pnet.pl
  102.  * Thomas Richter:     thor@math.tu-berlin.de
  103.  * Eddy Carroll:       ecarroll@iol.ie
  104.