home *** CD-ROM | disk | FTP | other *** search
/ Club Amiga de Montreal - CAM / CAM_CD_1.iso / files / 426.lha / chipcache_v1.11 / ChipCache.txt < prev    next >
Text File  |  1990-10-07  |  11KB  |  285 lines

  1. *********************************************************************
  2. *                                                                   *
  3. *     A3000 MMU PATCH   VERSION 1.11 (1990-09-18) by F.Bürgel       *
  4. *                                                                   *
  5. *********************************************************************
  6.  
  7. This program is freely distributable. Please provide all these files:
  8.  
  9. ChipCacheXX    The actual executable.
  10. AddMem        A CLI command to add memory regions.
  11. am.script    A shell-script to add memory using ChipCache.
  12. CInfo        An executable (Chip Info).
  13. CInfo.txt    CInfo readme.
  14. ChipCache.txt    This text.
  15.  
  16. To get new releases and information or to report bugs,
  17. contact the author at
  18.  
  19.         UUCP    blatter@ifi.unizh.ch
  20.         BIX    hardwiz
  21.  
  22.  
  23.  
  24.  
  25.  
  26.       ChipCache V1.11  Description
  27. ---------------------------------------------------------------------
  28.  
  29. This is a small tool that can improve the performance of certain A3000
  30. configurations by turning on Instruction Cache in Chip-Memory.
  31. Furthermore, it allows you to make use of an additional 200kB of Fast
  32. Memory when running under Kickstart 1.3.  It is rather hacky and will
  33. probably not work on future releases of the A3000 Operating System.
  34. To prevent crashes, a number of checks are done.
  35.  
  36.  
  37. First version 1990-08-15
  38. Updates:
  39.  V1.09a (1990-09-17): 2nd issue of bad -RESET bug fixed by flushing
  40.  data cache after every switch.
  41.  Seems that 68030 can create shit entries in datacache.
  42.  
  43.  V1.10 (1990-09-18): AmigaDOS 2.x proper cache control implemented.
  44.  Former versions were unable to change cache status in 2.x
  45.  
  46.  V1.11 (1990-09-19): Showmem routine built in.
  47.  
  48.  
  49.  
  50.       ChipCache V1.11  History and About
  51. ---------------------------------------------------------------------
  52.  
  53. Let me first explain how I came to the idea for this tool.  Of course
  54. one of the first things I did with my new A3000 was to check out some
  55. graphics software to see the speed-improvements.  Thereby I made an
  56. interesting observation:  A demo that did not work on the A2620 unless
  57. you turned-off Instruction Cache worked perfectly with the Instruction
  58. Cache turned on!  I started to investigate on that until I finally
  59. came across a line of text in the 68030 manual that says:  'The CI bit
  60. will disable both caches in the corresponding pages'.
  61.  
  62. The problem is the following:  you MUST disable the Data Cache in all
  63. locations where other devices than the CPU can alter memory.  Imagine
  64. a word of data being read from memory by the CPU.  This word is stored
  65. in the Data Cache.  The next time the program reads the same memory
  66. location, the word is fetched from Data Cache instead from memory, to
  67. increase speed.  However, if the same memory location has been written
  68. to by disk DMA for example, then the value in the cache is not valid
  69. and incorrect data is being used by the processor.  Treating of such
  70. memory regions is done by means of either the MMU translation table
  71. (which in the A3000 is also used to map the Kickstart into the correct
  72. place), or by the memory controlling hardware.  Hardware Cache disable
  73. is done on a cycle-by-cycle basis through a pin on the 68030.
  74. Software Cache disable uses a special bit named Cache Inhibit in the
  75. MMU tree structure.  On the 68020/68851, this would only disable Data
  76. Cache.  On the 68030, this same bit also disables Instruction Cache.
  77. Why this is, I cannot tell and I'm afraid there is no sense in it.
  78. Under no circumstances, neither graphics DMA data, nor hardware
  79. registers will ever be used as program (Assembler instructions).
  80. [ There is one big exception to that:  Harddisk DMA.  BUT:  that
  81. problem is resolved by a different means:  The Instruction Cache is
  82. flushed after every harddisk DMA load.  So that point can be left out
  83. in the discussion.  ]
  84.  
  85. With a standard A3000 using the disk-Kickstart you have about 300Kb of
  86. FAST memory after boot-up.  Therefore you will very soon end up
  87. without FAST mem and code gets loaded into CHIP memory, causing heavy
  88. performane degradation.  This degradation results from two sources:
  89.  
  90.     - The Chip memory clock is only 7.16 MHz
  91.        compared to 25Mhz in FAST memory.
  92.  
  93.     - There is no Instruction Cache in Chip Memory
  94.  
  95. The latter can now be fixed using ChipCache at the cost of complete
  96. renounce of the Data Cache.
  97. Note that this is by no means a general improvement to the A3000.  It
  98. does in fact REDUCE the performance of a well-equiped A3000 that has
  99. lots of FAST memory, because it requires disabling the Data Cache.
  100.  
  101.  
  102.  
  103.  
  104.       ChipCache V1.11  Instructions
  105. ---------------------------------------------------------------------
  106.  
  107. ChipCache lets you
  108.  
  109.  - help the no-Cache-in-Chipmemory problem
  110.  - find out how much Kickstart-memory is unused and can
  111.      be used otherwise
  112.  - remove the write protection of that memory, allowing
  113.      write access to the system MMU translation table
  114.  
  115. * The CHIPMEMORY CACHE FUNCTION is completely undangerous and so you
  116.   may enter without risk:
  117.   
  118.       ChipCache
  119.   
  120.   which will present you an overview of the former and the new
  121.   system status.
  122.   Two parameters are changed: The Chipmemory Cache is turned on and
  123.   the Data Cache is turned off (see 'About').
  124.   The Chipmemory Cache function is of equal usefulness in both
  125.   Kickstart / AmigaDOS 1.3 and 2.0
  126.   
  127. * If you want to go BACK TO THE INITIAL STATE, just enter
  128.   
  129.       ChipCache -RESET
  130.   
  131.   You need not use capital letters for options and you may take
  132.   advantage of the abbreviations stated after the options names
  133.   presented by
  134.   
  135.       ChipCache ?
  136.   
  137. * Extensive experimenting showed me that despite the considerations
  138.   about Data Cache in Chip Memory, the machine may actually work ok.
  139.   THIS DOES NOT MEAN THAT I GUARANTEE THAT IT WORKS!
  140.   To allow you to experiment for yourself, I built-in option DATA.
  141.   USE IT AT YOUR OWN RISK! System crashs can cause 'Key already set'
  142.   problems!
  143.   It is quite safe to use it with low-level (non-multitasking)
  144.   software like Starglider and other games. Here, a speed increase
  145.   can be stated. To enable both Chipmemory and Data Cache enter
  146.   
  147.       ChipCache -DATA
  148.   
  149. * Since the Kickstart 1.3 uses only about 270kB of the 512kB that
  150.   are allocated for it, and we are very short of Fast Memory on the
  151.   standard A3000, I came to the idea to use the free space as system
  152.   memory. Unfortunately, this region is write protected by MMU code
  153.   that is set-up by the boot-rom.
  154.   Therefore, I built a tool that removes this write protection and
  155.   fitted it into ChipCache, too.
  156.   To take advantage of this also, you need first to find out where
  157.   exactly that usable memory is located.
  158.   To do so, enter
  159.   
  160.       ChipCache -SHOWMEM
  161.   
  162.   This will most probably give you the answer:
  163.   
  164.       Addable memory from $07FC5000 to $07FFFFFF.
  165.   
  166.   Note that this inquiry cannot be repeated after you used that
  167.   memory as system memory. It works only as long as this memory
  168.   has never been touched.
  169.   Then, you need to remove the writeprotection by entering
  170.   
  171.       ChipCache -NOWPRO
  172.   
  173.   As you can see now, the status of the write protection has changed
  174.   to inactive. Now you may add that memory to the system using
  175.   the AddMem tool. Enter
  176.   
  177.       AddMem $7fc5000 $7ffffff
  178.   
  179.   CAUTION: -    Attempting to AddMem to a region that does not contain
  180.           usable memory will instantly result in a crash.
  181.          -    From now on, you must pay attention to NOT use option
  182.           RESET since this would reinstall the writeprotection
  183.           and therefore crash the machine.
  184.   
  185.   Note: To overcome the problem that option RESET may not be used
  186.   while the additional memory is being used, option NOCHIPCACHE lets
  187.   you remove just the Chipmemory Cache, without touching the
  188.   writeprotection.
  189.   
  190.   
  191. * The memory part that is usually write-protected contains
  192.     - the new libraries, devices and resources the A3000
  193.           Kick '1.3' needs
  194.       - the system MMU translation table
  195.   Be careful not to overwrite any of these!
  196.   
  197.   If you want to look at the translation table, use CINFO (by me!)
  198.   to locate it.
  199.   If know what you're doing, you can change the translation table
  200.   after removing the write-protection!
  201.   Note also that the translation table is reset-proof, so you end up
  202.   in a reboot-crash-loop if you trash it!
  203.   
  204.   Have Fun!
  205.  
  206.  
  207.  
  208.  
  209.  
  210.       ChipCache V1.11  Options
  211. ---------------------------------------------------------------------
  212.  
  213. Usage: ChipCache [-DATA=D] [-NOWPRO=NP] [-RESET=R] [-NOCHIPCACHE=NC]
  214.                  [-SHOWMEM=S]
  215.  
  216. -DATA = D
  217. This option causes the Data Cache not to be turned off.
  218. The state your machine goes into using this option is not guaranteed
  219. to be stable. Use this option AT YOUR OWN RISK and be careful!
  220. The best thing is to start a low-level application immediately
  221. after activating ChipCache with Data Cache.
  222.  
  223. -RESET = R
  224. This option resets the chipmemory Cache (inhibts it) to normal mode.
  225. It will also turn on the Data Cache and set the write protection
  226. of the translation table memory.
  227. CAUTION: You must not use RESET when you have added memory because
  228.  this memory will then be write-protected!
  229.  
  230. -NOWPRO = NP
  231. This option causes the write protection of the top 256kb of FAST RAM
  232. (from $07fc0000 to $08000000) to be removed.
  233. You are able then to alter the translation table, or use some free
  234. memory for your own purposes.
  235.  
  236. -SHOWMEM = S
  237. This option will tell you the address range (if any) in the top FAST
  238. memory region that is unused and can be gained using AddMem.
  239. NOTE: This option will only work if you did not use the extra memory
  240.  region before, because it simply scans for the beginning of the
  241.  region containing only zeros.
  242.  
  243. -NOCHIPCACHE = NC
  244. This option reverts the chipcache function. Chipmemory Cache will
  245. be turned off.
  246.   
  247.   
  248.   
  249.   
  250.       ChipCache V1.11  Error messages
  251. ---------------------------------------------------------------------
  252. If ChipCache fails because either
  253.  - you gave invalid options / parameters
  254.  - there was an internal problem (e.g. incompatible OS version)
  255.  - you used it on a system it does not apply to
  256. then it returns an error code of 20.
  257. You may use this for script files like the Add200k tool supplied with
  258. ChipCache.
  259.  
  260.  
  261. Here is a list of all ChipCache error messages:
  262.  
  263. *** This is not an A3000!
  264.  
  265. *** Cannot recognize the A3000 translation table!
  266.     Either you have a different A3000 Boot-ROM than I, or
  267.     you are cheating, using ChipCache on a GVP-Board or so.
  268.  
  269. *** The translation table is somehow strange.
  270.     Hmmm... strange!
  271.  
  272. *** Translation table outside of expected memory page!
  273.     ROM OS version conflict. Please contact me.
  274.  
  275. *** Sorry, unable to handle the 68040!
  276.     I have not yet had the pleasure to try it out.
  277.  
  278. *** Input line too long!
  279.  
  280. *** Got unexpected argument.
  281.     Check for '-' before options.
  282.  
  283. *** Option RESET must be used alone!
  284.  
  285.