Wanted: SIMH VAX VMS tape image tester, take 2

Chuck Guzis cclist at sydex.com
Fri Dec 19 13:37:13 CST 2014


On 12/19/2014 08:20 AM, Al Kossow wrote:
> On 12/19/14 8:18 AM, Al Kossow wrote:
>> On 12/18/14 11:07 PM, Chuck Guzis wrote:
>>> Okay, I think I've gotten the SIMH image thing straightened out--and
>>> I've added a descriptive record after the EOM marker in the image.
>>
>> looks OK, but it may be difficult to parse
>
> you may want to consider JSON
>
> http://www.json.org/xml.html

Basically, what I've got now is code that adds the "TAPEINFO" line and 
the created-by line--everything else is read from an external file.  For 
all the application cares, that file could be your favorite 
chocolate-chip recipe.

The issue of what to do with the content and how it should be formatted 
is one that bears a lot of consideration.

A human-readable ultra lightweight markup language is my choice.  JSON 
does require a parser of some sort, so perhaps not a good choice.

What, in my opinion, is needed is a simple way to describe what you've 
got, what you think about it (e.g. "Could be a tape from a Super 
Whiz-bang 88 system, popular in the 1830s" or "Tape was covered in green 
mold; this is what we did to recover it."), any external label contents, 
etc.  I think a CRC over the data contents might be useful for giving 
some sort of integrity assurance.

So, maybe a few standardized tags, then free form narrative after that 
I initially proposed the standardized tags be of a simple but 
unambiguous form; i.e. colon in the first position of a line, 
immediately followed by a keyword.  Pretty much self-descriptive.

Plain old 7-bit ASCII is fine and unlikely to change over time.

Here are the very basic SIMH-format issues as I see them.

1.  There's no way to express "soft errors".  Some interfaces allow for 
flagging individual frames that contain parity errors, for example. 
Others allow for retrieving the uncorrected data.

2.  The SIMH standard says that a hard error is signified by setting bit 
7 in the high-order byte of the block length being set *and* a non-zero 
block length.  What if the interface doesn't allow for the return of raw 
data?  What's the block length then?  Even so, where does one put the 
diagnostic information?

3.  Some devices either encode a block number or maintain an internal 
counter for the block number.  There's no place for that in the spec.

4.  One can't recognize a SIMH tape image by reading the first few bytes 
of it--there's no header of any sort.

5. Non textual (i.e. photos) metadata has no provision made for it.

I do realize that the interests of those who simply want a simulation 
capability and those who are interested in archiving do not necessarily 
converge.  Can we come up with a format that satisfies both groups?

--Chuck




More information about the cctalk mailing list