view docs/myram.doc @ 3140:03b580a02945

Allow CoCo3FPGA-specific build of superdesc.asm Added new conditional CC3FPGA and code to "level1/modules/superdesc.asm" to reflect changes needed to build the new SD card descriptors for the Coco3FPGA.
author Bill Pierce <merlinious999@gmail.com>
date Sat, 04 Feb 2017 11:06:26 +0100
parents 0e5881ce0d31
children
line wrap: on
line source

level2/modules/myram.asm
level2/modules/mr0.asm

RAM disk driver for NitrOS-9 Level 2
Copyright (C) 2014  Gene Heskett

                   See update message near bottom of file

These docs describe a new mram.dr for OS-9 level 2 systems. With a bit of
further editing, and the help of the conditional assembly commands in xsm,
this should now run on either cpu. Although the object grew a few bytes in
the conversion, the megaread times are very similar, averaging 10.5 seconds
on this 6309 native system. On a regular 6809 system, the os9 call F$Move
hasn't been optimized, so expect the megaread times to be at least doubled.

As there have been at least 70 people who downloaded the 6309 only version
which apparently worked well enough that I have NOT had any "I can't make it
work" messages (none, nada, zip), either nobody is using it, or it works
just fine which is exactly what its done for me here. This 6809 version
didn't work in its previous, missing one "y register restore" version on my
plain 512k machine at work earlier today. With that command added it is
currently running as a 1 megabyte drive on this machine as I type this.

1. In my experience, trying to format "rammer" seemed to be an exercice in
futility as it was the most blob sensitive util I've tried to use. In fairness
to rammer, this machine historicly has been a great blob detector.

2. The only ram driver I could make run reliably was the developers pack
version after it had been patched for a couple of bugs.

3. That driver served as the model for this one in that I didn't change the
method used to size the device. Having only one variable to control how big it
is sure simplifies things. That variable is of course "sct" in the dmode
report, meaning sectors per track. Its a one track device, just a variable
length of track.

4. Several things in the devpack ram.dr were hard coded. This prevented
it from being used at equivalent sizes above the 504k mark. At that point,
the FAT was a full sector, and above that required another sector.
Unforch, the position of the FD and root dirs was fixed.  Asking for memory
above that point also seemed to write rather willy-nilly to other, not owned
by ram, memory. Crashes, while not the order, did happen from time to time.

5. The really major effort in this was a total, start from scratch, re-write
of the init routine.  Wholesale hunks of code got moved around, lots more
smarts added, etc. Yes, its bigger, and yes with effort I could in all
probablility shrink it some. However this works reasonably well for sct=1b00
sized ramdisks. Thats 1.7 something megabytes in a 2 meg machine! With mfree
reporting 96k free, I can still do about everything except run umuse3. That
needs at least 128k plus a few more pages of system ram than most programs.

6. The reason RBF apparently ignores any and all error codes that I'd built
into the InitChecker routine is that OS9 in fact does call the Init function
first!  This means that you can copy or move anything you want to to /r0
without any errors.

However . . .

OS9 keeps a link count of users of the device, and if the aformentioned
copy operation was the only link, then when the copy is done and the link
count is reduced to zero, the "Term"inate routine is then called.
So /r0 was dynamicly initialized for the duration of the copy operation,
gave no errors because of that, and then was de-initialized at the end of
the copy by the closing of the only open path! By-by file!  I've been bit at
least 1000 times, probably more, many more!

Verified by setting the priority down to zip, initiating a copy while the
descriptor had been dmoded to about 1.5 megs, and running mmap repeatedly
while the copy was being done.  And by putting a call to F$regdmp (os9p4) in
the Term routine. It did execute.

Now there are folks out there who no doubt knew all this, so please bear with
me as I prevent this zero open paths automatic deinit of /r0.

I have been able to do the "autoinit" in a manner that doesn't deinit the
device after the write path is closed. And it doesn't prevent it from being
deinit'ed if and when you want to return the ramdisk memory to the machine 
memory pool.

Despite the statement in Kevins "Inside OS9 Level II" book to the effect
that the device table is not available to the programmer, it is in fact
available IF you are a device driver loaded in the os9boot file as it loads.
Otherwise the address returned from a load of the direct page offset $80-81
will be in some other block of memory instead of in the system's memory. And
while the exact offset of our entry may be available from some other var in
the direct page, I haven't found that define yet. So I searched to find our
assigned V$STAT memory assignment instead. It searches each 9 byte entry in
the device table till it either finds it and then incs the associated V$USRS
count, or reads a $0000, in which case BIG trouble. It will do an F$Exit and
report. I used E$DevOvf as the error in that event. You should NEVER see
that error unless something else has badly corrupted the system vars in
which case its reboot time, RIGHT NOW!

The major problem with attempts to locate our own entry in the device table
during the init routine is that our entry in the device table does not exist
until the Init routine of a device driver has been exec'd and has returned
to OS-9. This meant that the "stay resident" code had to be split up, a
single instruction setting a flag during the initialization, a quick, one
line test of the flag is done at every read or write function. If set, it
finds its own entry in the now valid device table and increments the link
(V$USRS) count in the table, one time only as that same piece of code then
clears the tested flag. Once done, the additional read/write overhead is
only the flag test which if zero, jumps immediately to the read or write it
came here to do. I'd guess not more than a 2% slowdown averaged over a 100k
write or read.

The current size is coded into your device descriptor as "sct", so if you want
it to survive a big file thru the C compiler, be sure to dmode it big enough
to handle the expected files before running the compiler. I'd suggest patching
the descriptor right on the disk so you can even afford to forget that most of
the time. You do have 2 megs don't you? I have set mine for "sct=1000", giving
a 1,024 kilobyte ramdisk when it does do the automatic initialization.

In the event of an overflow or "device full", it really does return an error
#248! The devpack one didn't as you all know well. Attempts to format it using
"format /r0" will get an illegal service request error exit when format
attempts to access it for recovering the device parms. It does not support any
getstt or setstt calls.

Speedwise, megaread is 10.5 seconds from /r0, 13 seconds from my Maxtor 7120s.
Both obviously limited by machine speed, not the drives. That would be mainly
in the OS-9 call "F$Move", the linkage between memory we own and some other
memory not currently in our process map.

My own megaread was redone in Basic09 early on because the drive I had at that
time had a couple of bad sectors in the first megabyte, so I had to re-read
the first 256k 4 times. That adds a couple of millisecs for seek time of
course.

There is one other item that caused me to go back and make the initial
allocation for the root directory another 8 sectors longer, seems that dcheck
didn't like the extended root directory caused by my stuffing about 700k worth
of small files into it. So now the allocation for the sector zero, FAT, root
FD, and root dir is $10 sectors total. And dcheck can't find anything at all
to fuss about with that same long list of small files copied to ram, without
pre"iniz"ing it.  I've been doing this on my hard drives for years, modifying
it with ded before I write anything else to the drive, it sure cuts down on
dchecks useless (but confusing to the newcomer) caterwalling and mewling
about extended root directories (not associated with a file type msgs) that
dcheck is truely famous for. Its only bug possibly. One I've been fussing
about, and wishing the author would fix for years!

If you do a "free /r0" on it, you'll find the volume name is "Gene's RamDisk",
I had to get my name in there someplace! And for those who have a copy of
"dtype", a kludge I wrote years ago to help me identify the 100's of disks I
had in various flavors of drive styles and os-9 levels/versions, it will ident
it as a floppy of course, but the rest of its report is accurate. That was a
last minute addition that didn't run it back above $300 bytes in 6309
versions.

UPDATE MESSAGE

The earlier version didn't attempt to set its "creation date" in the sector
zero information, and in fact due to a foible of os9, couldn't use the
regular F$Time call as it returned nothing. This one does, but the method
used requires it to be in the os9boot file to work, (the second reason in
fact) else it will copy garbage to that area of sector zero. That reason is
that in order to make the method recommended work, I must convince the
system that ram is indeed a system module for the approximatly 100
microseconds it takes the I$Attach call now used to execute.

Alan Dekok and company (of  Nitros9 fame) have, if a message I received is
correct, rendered my auto linking routine null and void, and possibly made a
crash, by expanding the format of the device table for additional data
entries. When that is confirmed, I'll release this newer, fixed version that
now also sets the create date correctly. It has to jump thru a few more hoops
than the older version in order to do the linking in a way that won't be
broken by newer versions of Nitros9 (1.21+). So of course it gained a couple
of bytes sizewise.  While I haven't tryed it yet, from messages I've
received, this new method won't break. I also did some tweeking of the
allocation mapping, and the required 8k blocks of memory which effects those
with only 128k will notice right away, memory usage is 1 256 byte page less
than it was when sct was an even $x800 or $x000, and the read errors because
it didn't get enough blocks of memory to hold the last $1f sectors when sct
was less than the above should be gone also. Setting sct=170 will cause it
to aquire enough blocks to hold $180 sectors instead of chopping it off at
$15F under those conditions like it did before. The fat will however reflect
the $170 you asked for. (Putting on my Jimmy Stewart hat here) So ya might
as well ask for the whole block!

END of UPDATE message

I hope this is of some help to the OS-9 community.
Cheers All, Gene Heskett, WDTV5@delphi.com

 
RAM disk driver for NitrOS-9 Level 2
Copyright (C) 2014  Gene Heskett

This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.