home *** CD-ROM | disk | FTP | other *** search
/ CBM Funet Archive / cbm-funet-archive-2003.iso / cbm / c128 / utilities / lrr270.sfx / lrr270.txt < prev   
Text File  |  1998-02-16  |  26KB  |  454 lines

  1. LITTLE RED READER  Version 2.70  [February 16, 1998]
  2.  
  3. MS-DOS file reader/writer for the C128 and 1571/81/FD drives.
  4.  
  5. by Craig Bruce  (csbruce@pobox.com)
  6.  
  7. Little Red Reader (LRR) is a program for the C128 that will read and write
  8. files to and from MS-DOS floppy disks using a 1571, 1581, CMD FD-2000, or CMD
  9. FD-4000 disk drive.  With the FD drives, you can use High Density (HD) MS-DOS
  10. disks. The program copies files from drive to drive (no internal buffering),
  11. so you need a second disk drive (either real or virtual) to copy files to.
  12. You can use RAMDOS for the second drive if you have an REU and you execute a
  13. GRAPHIC CLR after starting it up.  The menu-driven full-screen user interface
  14. is written in BASIC so it is mildly sluggish, but the actual file copying is
  15. written in machine language and operates as fast as the disk drives will go.
  16.  
  17. 1. INTRODUCTION
  18.  
  19. This document presents a program that reads and writes MS-DOS files and the
  20. root directory of MS-DOS disks.  The program copies only from drive to drive
  21. without buffering file data internally.  This is simpler and imposes no limits
  22. on the size of the files transferred, although it requires the use of two disk
  23. drives (or a logical drive).  The user-interface code is written in BASIC and
  24. presents a full-screen file selection menu.  The grunt-work code is written in
  25. assembly language and operates at maximum velosity.
  26.  
  27. The program also allows MS-DOS files to be deleted and to allows the copying
  28. of Commodore-DOS files between CBM-DOS disks (this makes it more convenient to
  29. use the program with a temporary logical drive like RAMDOS).  Also, since I
  30. have a CMD FD-4000 floppy disk drive, I know that this program works with
  31. MS-DOS disks with this drive (for both the 720K and 1.44M MS-DOS formats).
  32. The FD disk drives are logically referred to below as being the 1581.
  33.  
  34. The Burst Command Instruction Set of the 1571/81 is used to read the MS-DOS
  35. disk blocks and the standard kernel routines are used for outputting the data.
  36. (I am an operating systems specialist, so I call it a kernEl!) Thus, the
  37. MS-DOS files must be read from a 1571 or 1581 disk drive, but the output
  38. device may be any disk drive type, the screen or a printer, or a virtual drive
  39. type such as RAMLink, RAMDrive, or RAMDOS (for the REU).  It is interesting to
  40. note that the data can be read in from an MS-DOS disk faster than it can be
  41. written out to a 1571, 1581, or even a RAMDOS file.  A RAMLink can swallow the
  42. data only slightly faster than it can be read.
  43.  
  44. Little Red Reader (LRR) supports double density 3.5" disks formatted with 80
  45. tracks, 9 sectors per track, and 2 sides with a 1581 and 5.25" double density
  46. disks formatted with 40 tracks, 9 sectors per track, and 2 sides with a 1571,
  47. and more recently, high density 3.5" disks formatted with 80 tracks, 18
  48. sectors per track, 2 sides, and a "12-bit FAT".  A limit of 224 directory
  49. entries and 9 File Allocation Table (FAT) sectors is imposed.  There must be 2
  50. copies of the FAT and the cluster size may be 1 or 2 sectors.  The sector size
  51. must be 512 bytes.
  52.  
  53. The program runs on either the 40 or 80-column screens, but you will get much
  54. better performance from the BASIC portion of the program by being in 80-column
  55. mode and FAST mode.  A modification that someone might want to make would be
  56. to spread-out the display for the 80-column screen and add color to the rather
  57. bland display.
  58.  
  59. Oh, about the name.  It is a play on the name of another MS-DOS file copier
  60. available for the C-128.  "Little" means that it is smaller in scope than the
  61. other program, and "Red" is a different primary color to avoid any legal
  62. complications.  It is also the non-white color of the flag of the country of
  63. origin of this program (no, I am not Japanese).  Also, this program is Public
  64. Domain Software, as is all software I develop for 8-bit Commodore Computers.
  65. Feel free to E-mail me if you have questions or comments about this article.
  66.  
  67. 2. USER GUIDE
  68.  
  69. LOAD and RUN the "lrr270" BASIC program file.  When the program is first run,
  70. it will display an "initializing" message and will load in the binary machine
  71. language package from the "current" Commodore DOS drive (the current drive is
  72. obtained from PEEK(186) - the last device accessed).  The binary package is
  73. loaded only on the first run and is not reloaded on subsequent runs if the
  74. package ID field is in place.
  75.  
  76. The system is designed to have two file selection menus: one for the MS-DOS
  77. disk drive, and one for the Commodore-DOS disk drive (which may be a logical
  78. disk drive).  The idea for copying is that you select the files in one of
  79. these menus, and then program knows to copy them to the disk for the other
  80. menu.
  81.  
  82. 2.1. MS-DOS MENU
  83.  
  84. The main screen of the program is then displayed.  The main screen of the
  85. program will look something vaguely like this:
  86.  
  87.    MS-DEV=9    MS-TYPE=1581    CBM-DEV=8
  88.  
  89.    NUM  S  TRN  TYP  FILENAME  EXT  LENGTH
  90.    ---  -  ---  ---  --------  ---  ------
  91.      1  *  ASC  SEQ  HACK4     TXT  120732
  92.      2     BIN  PRG  RAMDOS    SFX   34923
  93.  
  94.    D=DIRECTORY  M=MS-DEV  F=CBM-DEV Q=QUIT
  95.    T=TOGGLE-COLUMN, C=COPY-FILES, +/- PAGE
  96.  
  97. except that immediately after starting up, "<directory not loaded>" will be
  98. displayed rather than filenames.  The "MS-DEV" and "MS-TYPE" fields give the
  99. device number and type of the drive containing the MS-DOS disk to copy from,
  100. and the "CBM-DEV" gives the device number of the drive/virtual drive/character
  101. device to copy file data to.  The number of bytes free on the drive are also
  102. displayed (which is useful to know when writing files) and there are some more
  103. commands.
  104.  
  105. Information about all MS-DOS files in the root directory of the MS-DOS disk is
  106. displayed in columns below the drive information.  "NUM" gives the number of
  107. the MS-DOS file in the directory listing, and "S" indicates whether the file
  108. is "selected" or not.  If the file is selected, an asterisk (*) is displayed;
  109. otherwise, a blank is displayed.  When you later enter Copy Mode, only the
  110. files that have been "selected" are copied.
  111.  
  112. The "TRN" field indicates the character translation scheme to be used when the
  113. file is copied.  A value of "BIN" (binary) means no translation and a value of
  114. "ASC" (ascii) means the file characters are to be translated from MS-DOS ASCII
  115. (or "ASCII-CrLf") to PETSCII.  The "TYP" field indicates the type of
  116. Commodore-DOS file to create for writing the MS-DOS file contents into.  The
  117. possible values are "SEQ" (sequential) and "PRG" (program).  The values of the
  118. TRN and TYP fileds are set independently, so you can copy binary data to SEQ
  119. files and ascii data to PRG files if you wish.
  120.  
  121. The "FILENAME" and "EXT" fields give the filename and extension type of the
  122. MS-DOS files and "LENGTH" gives the exact length of the files in bytes.  Note
  123. that if you perform "ASC" translation on a file, its PETSCII version will have
  124. a shorter length.
  125.  
  126. 2.2. USER COMMANDS
  127.  
  128. The bottom of the screen gives the command summary.  After starting the
  129. program, you will want to setup the MS-DOS and CBM-DOS drives with the "M" and
  130. "F" commands.  Simply press the (letter) key corresponding to the command name
  131. to activate the command.  Pressing M will prompt you for the MS-DOS Drive
  132. Number and the MS-DOS Drive Type.  In both cases, type the number and press
  133. RETURN.  (Sorry for insulting all non-novices out there, but I want to be
  134. complete).  The MS-DOS drive number cannot be the same as the CBM-DOS drive
  135. number (since the program copies from drive-to-drive without internal
  136. buffering).  For the drive type, enter an "8", "81", or "1581" for a 1581
  137. drive or FD-series drive, or a "7", "71", or "1571" for a 1571 drive.
  138.  
  139. Pressing F will prompt you for the CBM-DOS device number.  You may enter a
  140. number from 0 to 30, except that it must not be the MS-DOS drive number.
  141. Enter a "1" for Cassette Drive (God forbid!), a "3" for the screen, a "4" for
  142. the printer (with an automatic secondary address of 7 (lowercase)), any number
  143. above 7 for a Commodore disk drive or special virtual drive, or a value of "0"
  144. for the special "null" drive.  A CBM-DEV value of 0 will case the program to
  145. read MS-DOS files and do nothing with the output.  You can use this feature to
  146. check out the raw reading speed of the program.
  147.  
  148. After setting up the drives, press D to read in the root directory off the
  149. MS-DOS disk.  The data will come blazing in from the disk but BASIC will take
  150. its good ole time sifting through it.  Filenames are displayed on the screen
  151. as they are scanned in.  The program will (eventually) return to the main
  152. screen and display the formatted file information.  One note: the process of
  153. logging in a 1581 MS-DOS disk takes about 12 seconds (on my 1581, anyway), so
  154. be patient.  An MS-DOS disk will have to be "logged in" every time you change
  155. MS-DOS disks.  (Disks are logged in automatically).
  156.  
  157. A couple of notes about accessing MS-DOS disks: don't try to access a device
  158. that is not present because the machine language routines cannot handle this
  159. error for some reason and will lock up, requiring a STOP+RESTORE.  Also, make
  160. sure that an actual MS-DOS disk is loaded into the drive.  If you accidentally
  161. place Commodore-DOS disk into the MS-DOS drive, the 1581 will report an
  162. invalid boot parameters error (#60), but a 1571 will lock up (since I don't
  163. check the sector size and my burst routines are expecting 512 bytes to come
  164. out of a sector whereas Commodore disks have only 256 bytes per sector).
  165.  
  166. Now you are ready to pick what files you want copied and how you want them
  167. copied.  You will notice that a "cursor" appears in the "S" column of the
  168. first file.  You may move the cursor around with the cursor keys: UP, DOWN,
  169. LEFT, RIGHT, HOME, and CLR.  CLR (SHIFT-HOME) will move the cursor back to the
  170. first file on the first screen.  You can move the cursor among the select,
  171. translation, and file-type columns of all the files.  Pressing a SPACE or a
  172. RETURN will toggle the value of the field that the cursor is on.  To toggle
  173. all of the values of the "cursor" column (including files on all other
  174. screens), press T.  You will notice that moving the cursor around and toggling
  175. fields is a bit sluggish, especially if you are in Slow mode on the 40-column
  176. screen.  Did I mention that this program will run on either the 40 or
  177. 80-column screen?  Toggling an entire column can take a couple of seconds.
  178.  
  179. If there are more than 18 MS-DOS files, you can press the "+" and "-" keys to
  180. move among all of the screens of files.  The cursor movement keys will wrap
  181. around on the current screen.  "+" is page forward, and "-" is page backward.
  182. The screens wrap around too.
  183.  
  184. After you have selected all of the files you want to copy and their
  185. translation and file-type fields have been set, press the C key to go into
  186. Copy Mode (next section).  After copying, you are returned to the main screen
  187. with all of the field settings still intact.  To exit from the program, press
  188. Q.
  189.  
  190. Additional commands are: "R" (remove == delete), "/" (change menu), and "X"
  191. (copy CBM files == "Xerox").  The remove command is used to delete selected
  192. files from the MS-DOS disk.  After selecting this option, you will get an
  193. annoying "are you sure" question and the the selected files will quickly
  194. disappear and the changes will finally be written to disk.  Deleting a batch
  195. of MS-DOS files is much quicker than deleting Commodore-DOS files since MS-DOS
  196. disks use a File Allocation Table rather than the linked list of blocks
  197. organization that CBM uses.  In order to make the BASIC program execute
  198. quicker, after deleting, the original order of the filenames in the directory
  199. listing will be changed.  Be forewarned that the delete operation is
  200. non-recoverable.
  201.  
  202. The change menu command is used to move back and forth between the
  203. Commodore-DOS and MS-DOS menus.
  204.  
  205. 2.3. COPYING MS-DOS TO CBM-DOS
  206.  
  207. When you enter copy mode, the screen will clear and the name of each selected
  208. file is displayed as it is being copied.  If an error is encountered on either
  209. the MS-DOS or CBM-DOS drive during copying, an error message will be displayed
  210. and copying will continue (after you press a key for MS-DOS errors).
  211.  
  212. To generate a CBM-DOS filename from an MS-DOS filename, the eight filename
  213. characters are taken (including spaces) and a dot (.) and the three characters
  214. of the extension are appended.  Then, all spaces are removed, and if the name
  215. ends with a dot (.) character, then that dot character is removed as well.  I
  216. think this is fairly reasonable.
  217.  
  218. If there already is a file with the same filename on the CBM-DOS disk, then
  219. you will be prompted if you want to overwrite the file or not.  Entering an
  220. "n" will abort the copying of that file and go on to the next file, and
  221. entering a "y" (or anything else) will cause the CBM-DOS file to be
  222. "scratched" and then re-written.
  223.  
  224. The physical copying of the file is done completely in machine language and
  225. nothing is displayed on the screen while this is happening, but you can follow
  226. things by looking at das blinkin lichtes and listening for clicks and grinds.
  227. You will probably be surprised by the MS-DOS file reading speed (I mean in a
  228. good way).  The disk data is read in whole tracks and cached in memory and the
  229. directory information and the FAT are retained in memory as well.  The result
  230. is that minimal time is spent reading disk data, and no costly seeks are
  231. required for opening a new MS-DOS file.  A result is that small files are
  232. copied one after another very quickly.  You will have to wait, however, on the
  233. relatively slow standard kernel/Commodore-DOS file writing.
  234.  
  235. A few changes had to be made to the program to accomodate the RAMDOS program.
  236. RAMDOS uses memory from $2300 to $3FFF of RAM0, which is not really a good
  237. place for a device driver, and it uses some of the zero-page locations that I
  238. wanted to use.  But, difficulties were overcome.  The importance of RAMDOS
  239. compatibility is that if you only have one disk drive but you have an REU, you
  240. can use RAMDOS to store the MS-DOS files temporarily.  Since the new version
  241. has greater memory requirements, after starting up "ramdos" (if you use it)
  242. you will have to execute the "graphic clr" BASIC command.  If you only have
  243. one disk drive and no REU, you are SOL (Out of Luck) unless you can get a
  244. RamDisk-type program for an unexpanded 128.  The RAMDOS program is available
  245. from FTP site "ftp.jbrain.com" in directory
  246. "/pub/cbm/software/utils/128/OLDIES92" in file "ramdosii.sfx".  One note I
  247. found out about RAMDOS: you cannot use a
  248.  
  249. DOPEN#1,(CF$),U(CD),W
  250.  
  251. with it like you are supposed to be able to; you have to use a
  252.  
  253. DOPEN#1,(CF$+",W"),U(CD)
  254.  
  255. Here is a table of copying speeds for copying from 1571s and 1581s with ASC
  256. and BIN translation modes.  All figures are in bytes/second.  These results
  257. were obtained from copying a 127,280 byte text file (the text of C= Hacking
  258. Issue #3).
  259.  
  260.    FROM  \ TO: "null"     RAMLink     RAMDOS     JD1581     JD1571
  261.    -------+    ------     -------     ------     ------     ------
  262.    81-bin {CBM--}      5772        3441       2146        n/a        644
  263.    81-asc {CBM--}      5772        3434       2164        n/a        661
  264.    71-bin {CBM--}      4323        2991       1949       1821        n/a
  265.    71-asc {CBM--}      4323        2982       1962       1847        n/a
  266.  
  267. The "null" device is that "0" CBM-DOS device number, and a couple of entries
  268. are "n/a" since I only have one 1571 and one 1581.  Note that my 71 and 81 are
  269. JiffyDOS-ified, so the performance of a stock 71/81 will be poorer.  JiffyDOS
  270. gives about a 2x performance improvement for the standard file accessing calls
  271. (open, close, chrin, chrout).  RAMDOS doesn't seem to be as snappy as you
  272. might think.
  273.  
  274. The "null" figures are quite impressive, but the raw sector reading speed
  275. without the overhead of mucking around with file organization is 6700
  276. bytes/sec for a 1581 and 4600 B/s for a 71.  The reason that the 1571 operates
  277. so quickly is that I use a sector interleave of 4 (which is optimal) for
  278. reading the tracks.  I think that other MS-DOS file copier program uses an
  279. interleave of 1 (which is not optimal).  I lose some of the raw performance
  280. because I copy the file data internally once before outputting it (to simplify
  281. some of the code).
  282.  
  283. In a couple of places you will notice that ASC translation gives slightly
  284. better or slightly worse performance than BIN.  This is because although
  285. slightly more work is required to translate the characters, slightly fewer
  286. characters will have to be written to the CBM-DOS file, since PETSCII uses
  287. only CR where MS-DOS ASCII uses CR and LF to represent end-of-line.
  288. Translation is done by using a table (that you can change if you wish).  Many
  289. entries in this table contain a value of zero, which means that no character
  290. will be output on translation.  Most of the control characters and all of the
  291. characters of value 128 (0x80) or greater are thrown away on being translated.
  292. The table is set up so that CR characters are thrown away and the LF character
  293. is translated to a CBM-DOS CR character.  Thus, both MS-DOS ASCII files and
  294. UNIX ASCII files can be translated correctly.
  295.  
  296. 2.4. COMMODORE-DOS MENU
  297.  
  298. The Commodore-DOS menu, which displays the names of the Commodore files
  299. selected for various operations, looks and works pretty much the same as the
  300. MS-DOS menu:
  301.  
  302.    CBMDOS  MS=10:1581  CBM=8  FREE=3211476
  303.  
  304.    NUM  S  TRN  FILENAME         T  LENGTH
  305.    ---  -  ---  ---------------- -  ------
  306.      1  *  BIN  LRR-128          P    9876
  307.      2     ASC  COM-HACKING-005  S  175412
  308.  
  309.    D=DIR M=MSDEV F=CBMDEV C=COPY Q=QUIT
  310.    T=TOGGLE R=REMOVE X=CBMCPY /=MENU +-=PG
  311.  
  312. You'll notice, however, that the filetype field ("T" here) is moved and is
  313. unchangable.  Also, the file lengths are not exact; they are reported as the
  314. block count of the file multiplied by 254.  This menu is not maintained for
  315. files being copied to the CBM-DOS disk from an MS-DOS disk.  You'll have to
  316. re-execute the Directory instruction to get an updated listing.
  317.  
  318. The "D" (directory) command has local effect when in this menu.  The
  319. Commodore-DOS directory will be loaded from the current CBM device number.
  320. Note that in order for this to work, the CBM device must be number eight or
  321. greater (a disk drive).  Originally, the subroutine for this command was
  322. written using only GET#'s from the disk and was very slow.  It was modified,
  323. however, to call a machine language subroutine to read the information for a
  324. directory entry from the directory listing, and hence the subroutine now
  325. operates at a tolerable speed.
  326.  
  327. The "C" (copy) command also has a different meaning when in this menu.  It
  328. means to copy the selected CBM files to the MS-DOS disk.  See details below.
  329.  
  330. The copy CBM files ("X") command is used to copy the files in the CBM-DOS menu
  331. to another CBM-DOS disk unit.  Select the files you want to copy and then
  332. press X.  You will then be asked what device number you want to copy the files
  333. to.  The device can be another disk drive or any other device (except the
  334. keyboard).  Using device number 0 does not mean the "null" device as it does
  335. with copying MS-DOS to CBM.  If you are copying to a disk device and the file
  336. already exists, then you will be asked if you wish to overwrite the file.  You
  337. cannot copy to the same disk unit.  Also, all files are copied in binary mode
  338. (regardless of what translation you have selected for a file).
  339.  
  340. The copy CBM files command was included since all of the low-level gear needed
  341. to implement it (specifically "commieIn" and "commieOut" below) was also
  342. required by other functions.  This command can be very convenient when working
  343. with RAMDOS.  For example, if you only had a 1571 as device 8 but you have a
  344. RAM expander and have installed RAMDOS as device 9, then you would copy MS-DOS
  345. files to RAMDOS using the MS-DOS menu, and then you would go to the
  346. Commodore-DOS menu ("/"), read the directory, select all files, insert an
  347. Commodore-DOS diskette into your 1571, and then use "X" to copy from the
  348. RAMDOS device to the 1571.
  349.  
  350. The remove command ("R") does not work for this directory.  You can SCRATCH
  351. your CBM-DOS files your damn self.
  352.  
  353. 2.5. COPY CBM-DOS TO MS-DOS
  354.  
  355. Before you can copy selected CBM-DOS files to an MS-DOS disk, the MS-DOS disk
  356. directory must be already loaded (from the MS-DOS menu).  This is required
  357. since the directory and FAT information are kept in memory at all times during
  358. the execution of this program.
  359.  
  360. When you enter copy mode, the screen will clear and the name of each selected
  361. file is displayed as it is being copied.  If an error is encountered on either
  362. the MS-DOS or CBM-DOS drive during copying, an error message will be displayed
  363. and copying will continue (after you press a key for MS-DOS errors).  Please
  364. note that not a whole lot of effort was put into error recovery.
  365.  
  366. To generate an MS-DOS filename from an CBM-DOS filename, the following
  367. algorithm is used.  The filename is searched from right to left for the last
  368. "." character.  If there is no "." character, then the entire filename, up to
  369. 11 characters, is used as the MS-DOS filename.  Characters 9 to 11 will be
  370. used as the extension.  If there is a "." character, the all characters before
  371. it, up to eight, will be used as the MS-DOS filename and all characters after
  372. the final ".", up to three, will be used as the MS-DOS extension.
  373.  
  374. Then, the newly generated MS-DOS filename is scanned for any extra "."
  375. characters or embedded spaces.  If any are found, they are replaced by the
  376. underscore character ("_", which is the backarrow character on a Commodore
  377. display).  Finally, all trailing underscores are removed from the end of both
  378. the filename and extension portions of the MS-DOS filename.  Also, all
  379. characters are converted to lowercase PETSCII (which is uppercase ASCII) when
  380. they are copied into the MS-DOS filename.  Note that if the Commodore filename
  381. is not in the 8/3 format of MS-DOS, then something in the name may be lost.
  382. Some examples of filename conversion follow:
  383.  
  384. CBM-DOS FILENAME       MS-DOS FILENAME
  385. ----------------       ---------------
  386. "lrr.bin"              "lrr.bin"
  387. "lrr.128.bin"          "lrr_128.bin"
  388. "hello there.text"     "hello_th.tex"
  389. "long_filename"        "long_fil.ena"
  390. "file 1..3.s__5"       "file_1.s"
  391.  
  392. It would have been time-consuming to have the program scan the MS-DOS
  393. directory for a filename already existing on the disk, so LRR will put
  394. multiple files on a disk with the same filename without complaining.  This
  395. also gets rid of the problem of asking you if you want to overwrite the old
  396. file or generate a new name.  However, in order to retrieve the file from disk
  397. on an MS-DOS machine, you will probably have to use the RENAME command to
  398. rename the first versions of the file on the disk to something else so MS-DOS
  399. will scan further in the directory for the last version of the file with the
  400. same filename.  There is no rename command in LRR because I never thought of
  401. it in time.  It would have been fairly easy to put in.
  402.  
  403. The date generated for a new MS-DOS file will be set from the default time.
  404.  
  405. The physical copying of the file is done completely in machine language and
  406. nothing is displayed on the screen while this is happening, but you can follow
  407. things by looking at the blinking lights and listening for clicks and grinds.
  408.  
  409. Since the FAT and directory are maintained in RAM during the entire copying
  410. process and are only flushed to disk after the entire batch of files are
  411. copied, copying is made more efficient, since there will be no costly seek
  412. back to track 0 after writing each file (like MS-DOS does).  If you have a
  413. number of small files to copy, then they will be knocked off in quick
  414. succession, faster than many MS-DOS machines will copy them.
  415.  
  416. To simplify the implementation, the current track of disk blocks for writing
  417. is not maintained like it is for reading.  Also, a writing interleave of 1:1
  418. is used for a 1571, which is not optimal.  However, since writing is such a
  419. slow operation anyway, and since the 1571 is particularly bad by insisting on
  420. verifying blocks, not much more overhead is introduced than is already
  421. present.
  422.  
  423. An interesting note about writing MS-DOS disks is that you can terminate LRR
  424. in the middle of a copy (with STOP+RESTORE) or in the middle of copying a
  425. batch of files, and the MS-DOS disk will remain in a perfectly consistent
  426. state afterwards.  The state will be as if none of the files were copied.  The
  427. reason is that the control information (the FAT and directory) is maintained
  428. internally and is flushed only after copying is all completed.  But don't
  429. terminate LRR while it is flushing the control information.
  430.  
  431. Here is a table of copying speeds for copying to 1571, 1581, and CMD FD-4000
  432. disk units with ASC and BIN translation modes.  All figures are in bytes/
  433. second, which includes both reading the byte from a C= disk and writing it to
  434. the MS-DOS disk.  The average speed for either the read or write operation
  435. individually will be twice the speed given below.  These results were obtained
  436. from copying a 156,273 byte text file (the text of C= Hacking Issue #4).
  437.  
  438.    FROM   \ TO: FD-bin     FD-asc     81-bin     81-asc     71-bin     71-asc
  439.    --------+    ------     ------     ------     ------     ------     ------
  440.    RAMLink {CBM--}     2,332      2,200      2,332      2,200      1,594      1,559
  441.    RAMDOS  {CBM--}     1,070      1,053      1,604      1,600      1,561      1,510
  442.    FD4000  {CBM--}         -          -      1,645      1,597      1,499      1,464
  443.    JD1581  {CBM--}     1,662      1,619          -          -      1,474      1,440
  444.    JD1571  {CBM--}     1,050      1,024        953        933          -          -
  445.  
  446. These figures are for transfer speed only, not counting the couple of seconds
  447. of opening files and flushing the directory.  Note that all my physical drives
  448. are JiffyDOS-ified, so your performance may be slower.  I am at a loss to
  449. explain why an FD-4000 is so much slower than a 1581 for copying from a RAMDOS
  450. file, but the same speed or better for copying from anything else.
  451.  
  452. ---------------------------------------------------------End-of-Document------
  453.  
  454.