Welcome to the Datatron 205 and 220 Blog

This blog is a companion to T J Sawyer's Web Page that outlines the history of the Burroughs Datatron 205 and Paul Kimpel's incredible 205 and 220 emulators. Please visit those sites and return here to post any comments.

Sunday, March 29, 2015

Using the retro-205 Cardatron

This is the second part of a two-part post on the punched-card facilities of the ElectroData/Burroughs Datatron 205 and the Cardatron device that implemented those facilities. The first part of this post reviewed the development of I/O interfaces for the Datatron and described how its Cardatron device was able to connect standard IBM punched-card equipment to the 205.

This second part discusses how the Cardatron and punched-card equipment have been implemented in the retro-205 emulator and how to operate them.

Emulator version 0.04a, with the Cardatron features described below, was released on 7 March and is available from the hosting site at http://www.phkimpel.us/ElectroData/205/webUI/D205.html. The open-source project is presently hosted on Google Code at https://code.google.com/p/retro-205/ GitHub at https://github.com/pkimpel/retro-205/. [Updated 2015-04-11]

Cardatron User Interface


As discussed in the first part of this post, the Cardatron consisted of a central Control Unit and up to seven Input or Output Units. Each Input or Output Unit controlled one IBM card machine.

Cardatron Control Unit

The Control Unit is the interface between the Input and Output Units and the 205 Processor and memory. It also routes I/O commands to the appropriate Input or Output Unit and assures that only one unit is communicating with Processor at a time. In the emulator, the Control Unit has a small window showing its status:

Cardatron Control Unit

The OU lamp is on if last I/O was to an Output Unit and off if to an Input Unit.

The UDn lamps indicate in binary the unit number last addressed. The emulator presently supports the following units:
  • Input Unit 1: IBM 087/089 collator, 240 cards/minute.
  • Output Unit 1: IBM 523 card punch, 100 cards/minute.
  • Output Unit 2: IBM 407 tabulator/printer, 150 lines/minute. In the next release this printer will be moving to Output Unit 3 for compatibility with MEASY and the Algol-58 compiler.
Eventually, I would like to make the units user-configurable, but at present they are hardwired in the emulator source.

The RDn lamps indicate the current "relay designate" settings. The four bits of the "r-digit" in a CDW (54) instruction would set these relays, which in turn could be sensed by the card machine for special action, typically carriage control.

The GENERAL CLEAR button clears both the Cardatron Control Unit and the Processor. It does not clear the individual Input and Output Units.

The INPUT SETUP button causes a CDR instruction (0 00u0 44 0000) to be forced into the C register of the Processor. This provides a convenient way to preset the Processor to read a card from unit "u" when START or CONT was pressed on one of the control panels. The unit number for "u" was determined by a switch in Control Unit. For the retro-205 emulator, this button unconditionally selects Input Unit 1.

See the section "Loading Object Decks," below, for details on how the Control Unit is normally used with the emulator.

Cardatron Input Unit

The Input Unit interfaced card readers to the Control Unit. In the emulator, each Input Unit has a window that combines the controls for the unit and its reader:

Cardatron Input Unit for Punched Cards

The START and STOP buttons control the ready status of the reader. The reader will not feed cards unless the START button is clicked and is illuminated. You can stop and start the reader while it is reading cards.

The NO FORMAT button lights and the reader goes not ready if the Input Unit cannot determine a format band from the card that was just read. Pressing START in this situation will restart the reader and cause the no-format card to be skipped.

The SM (Start Machine) lamp lights while the card reader is in the process of reading a card and transferring the numeric and zone column data to the buffer drum. The lamp goes out after the card is read and the unit is waiting for the Processor to read the buffer.

The RLO (Reload Lockout) lamp lights when reload lockout is in effect for the unit.

The FLO (Format Lockout) lamp lights when reload lockout has been initiated by a 8-punch in the format column of the card instead of the low-order bit in the k-digit of a CDR or CDRF instruction. Whenever FLO is lit, RLO will also be lit. The following ASCII characters in the format column can be used to initiate format lockout:
  • "`" = 1-8 punch (grave accent)
  • ":" = 2-8 punch
  • "#" = 3-8 punch
  • "@" = 4-8 punch
  • "'" = 5-8 punch (apostrophe)
  • "=" = 6-8 punch
  • """ = 7-8 punch (double quote)
The FSn lamps indicate the binary code for the currently-selected format band.

The FORMAT SELECT pull-down list is an artifact of the emulator and did not exist on the Cardatron, although its effect could be produced through special plugboard wiring on the card machine. It overrides the characters in the format column and specifies directly the format band to be used for reading cards. When set to "By Col" (the default), the format band number will be determined from the character in the card column specified by the FORMAT COL control. Any other setting will specify the number of the format band to be used, regardless of what is on the card being read.

This control is provided in the emulator as a convenience for reading text file "decks" that may not have a column set aside to select a format band.

The FORMAT COL pull-down list specifies the card column from which the format band selection (and possibly, format lockout signal) will be taken. Since columns 1 and 80 were common choices for format columns, 80 appears first in the list.

The CLEAR button clears the Input Unit and resets it to a default status. It does not, however, empty the input hopper.

The file-picker control (with a button typically labeled Browse... or Choose Files) is used to select one or more text files from your local file system that will be loaded into the "input hopper" of the reader. You can select multiple files, one at a time, to stack them in the input hopper. In most browsers, you can also select multiple files at once, but the order in which the files will appear in the input hopper may be indeterminate. The control will display the name of the last single file loaded.

The INPUT HOPPER progress bar below the file-picker control shows the relative amount of data left in the input hopper of the reader. The bar advances to its far right position each time a file is loaded into the reader. As cards are read, the bar diminishes to its left in proportion to the amount of data that has been read.

When the reader is in a not-ready condition (the STOP lamp is lit), clicking anywhere in the progress bar will display a dialog box asking if you want to empty the input hopper. If you reply in the affirmative, the entire hopper will be cleared, regardless of the number of decks (text files) remaining in it.

The area below the progress bar displays the last two cards that have been read, with the last card on the bottom.

Cardatron Output Unit for Line Printer

Output Units are used for both card punches and line printers. The user interface differs slightly between the two. Each printer device has a window that combines the controls for the Output Unit and the printer:

Cardatron Output Unit for a Line Printer

The START and STOP buttons control the ready status of the printer, similar to that for the card reader. The printer can be stopped and started while it is in operation, but it will not print unless the START lamp is lit. The lamp is lit and the device is made ready automatically when the emulator is powered up.

The END OF SUPPLY button lights and the printer goes not-ready when it is "out of paper." At present, the paper capacity is 150,000 lines -- about equivalent to a box of the pin-feed paper that was used with printers of the time. The output of the printer is held in memory so that it can be copied or saved later. The capacity limit prevents memory from being flooded endlessly with line images. When the limit is reached, the printer stops and this button lights. Clicking the button will allow one additional line to be printed each time it is clicked, but continuous operation of the printer will not resume until the output area is cleared by one of the two methods discussed below.

The FEED SUPPLY button performs two functions. The first is that clicking the button while the printer is in a not-ready status will simulate a form feed. The second is that clicking the button three times in succession while the printer is in a not-ready status will display a dialog box asking if you want to clear the output area. Make sure you have copied or saved any data from the output area you wish to keep before responding in the affirmative. This is one way to clear the output area and reset the end-of-supply condition discussed above.

The CLEAR button clears the Output Unit and resets it to a default status. It does not, however, clear the output area.

The SM (Start Machine) lamp lights while the printer is in the process of transferring the numeric and zone column data from the buffer drum and printing a line. The lamp goes out after the line is printed and the unit is ready for the Processor to send another line of data.

The FSn lamps indicate the binary code for the currently-selected format.

The GREENBAR checkbox controls whether the output area is formatted with greenbar shading, similar to that traditionally pre-printed on the pin-feed paper used with line printers. Uncheck this box if you plan to copy the printed output to another program or save it to a file, as for some browsers (particularly Firefox), the greenbar formatting causes additional blank lines to be included in the data that is copied or saved. You can check or uncheck this box at any time, even while the printer is operating.

The ALGOL GLYPHS checkbox for the Output Unit controls which set of ASCII characters the emulator uses when outputting the internal 205 codes corresponding to the four characters discussed below. If the box is unchecked, the commercial character set is used; if the box is checked, the FORTRAN (scientific) set is used. This setting also can be changed at any time, even while the printer is operating.

The IBM 407 print wheels had 48 characters plus the space. IBM offered print wheels with different character sets, which were used for different applications. The two that were most commonly used with the Cardatron were the standard commercial set (wheel configuration A) and the FORTRAN set (wheel configuration F). Wheel configuration A had the following characters:

0123456789 ABCDEFGHIJKLMNOPQRSTUVWXYZ $#%.,-*/@&¤

The "¤" glyph is termed the "lozenge". There are 47 glyphs shown above. A space, as with most impact printers, was generated by printing nothing in a column, so what was on the 48th print wheel position? That was another asterisk used by the 407 to replace leading zeroes in an amount for check protection (e.g., "$******123.45").

Wheel configuration F substituted the following characters for use with FORTRAN and other "scientific" languages (such as Algol):
  • & : +
  • # : =
  • % : (
  • ¤ : )
See the IBM FORTRAN II General Information Manual, Appendix B, for more information on these character sets.

Below the checkboxes is the SUPPLY REMAINING progress bar, which shows the relative output capacity remaining from the 150,000-line limit. The bar will diminish to the left as lines are printed.
The output area occupies the remainder of the window, showing the data as it is being printed. Lines scroll off the top of this area, but are retained in the browser's memory. When the printer is not operating, you can scroll back to view earlier lines and copy them for pasting into another program. The output area is an HTML frame, and many browsers will allow you to save the text directly from it to a file on your local workstation.

Another option for capturing the text that has been printed is to double-click anywhere in the output area. As with the output areas for the Flexowriter and paper-tape punch, this will do two things:
  1. A new, temporary window will be opened and the entire text of the output area will be copied into this new window. If the GREENBAR box is checked, this text will not show the green shading, but will also not have any extra blank lines.
  2. The output area will be cleared. This is the second way to reset the end-of-supply condition discussed above.
    Double-clicking the output area can be done at any time, even while the printer is operating. You can copy, save, or print the text in the temporary window as you wish. When you are finished, simply close the temporary window.

    Cardatron Output Unit for Punched Cards

    Like printer devices, each card punch device has a window that combines the controls for the Output Unit and the punch:

    Cardatron Output Unit for Punched Cards

    The layout and operation of this window is identical to that for printer devices, except that it does not contain the GREENBAR checkbox and green shading is never applied to the output area. The capacity limit of the output area for a card punch is 150,000 cards.

    Loading Object Decks


    One of the more common uses of a card reader on the 205 was loading program object decks into memory so the program could be executed. This section describes how to do that using the retro-205 emulator.

    Standard practice was to create object decks so that they could be loaded using the hard-wired format band number 6, since this did not require any of the programmable format bands to be loaded first. Therefore, there needs to be a "6" in some column of each card, and the most likely choice is column 1.

    A common practice, though, was to punch 6s in columns 1-3. Format band 6 read seven full, 11-digit words (backwards, of course) from columns 4-80, plus only the low-order three digits of a word from columns 1-3. That partial word was of very limited use when loading an object deck, so filling those three columns with 6s allows the deck to be loaded with the Cardatron Input Unit set to select the format from any of those columns.

    A well-designed object deck was also self-locating in memory. The first word read from the first card (i.e., the one in columns 72-80) typically had a sign with a value in the 4-7 range, indicating an instruction to be executed rather than a word to be read into memory. The address in that instruction would specify where in memory the program should start. Once again, see the three-card memory-clear program cited in the first part of this post for a good example of how this was done:

    https://drive.google.com/open?id=1VHIFHZ8osHTARGBhJxTDN3A1UAmew0lf17Dk-FhEz-8&authuser=0

    To load an object deck perform the following steps in the order listed:
    1. First, make sure the reader is not ready and that its "input hopper" is empty.
    2. Set the FORMAT COL control on the reader to the column from which format 6 will be sensed -- typically column 1. Alternatively, you can set the FORMAT SELECT control to 6, but this is not usually the best method to use.
    3. Use the file picker control on the reader to select from your local system the text file containing the object deck.
    4. Click the START button on the reader. The reader should feed the first card image and the FSn lamps should indicate format number 6.
    The reader is now ready, but the initial CDR (44) instruction to command the reader must be entered into the Processor manually. This could not be done easily on the Supervisory Panel, as the Cardatron unit number is sensed from the third digit in the instruction word, and that digit cannot be entered in the C register. Therefore, you need to go to the Control Console and do the following:
    1. Press the CLEAR button to clear the Processor.
    2. Set the INPUT knob on the right side of the Console panel to KEYBOARD.
    3. Click the CONT button. This will attempt the execute the instruction in the C register. Since that register was just cleared, the instruction will be 0 0000 00 0000, i.e., a PTR that will attempt to read from the currently-selected Console device to address 0000. Since that is the keyboard, the KEYBOARD annunciator will light.
    4. On your workstation's keyboard, enter: 6 0010 44 0000 and press Enter. This will read one card from Input Unit 1 to address 0000. If loading from a different unit, change the 1 to the appropriate unit number.
    5. The load deck should relocate that 0000 address and include additional instruction words to read the remainder of the cards automatically.
    The 0.04a version of the emulator implements a simpler way to bootstrap the deck once it has been loaded into the reader. Thanks to Tom Sawyer for pointing out this method to me.
    Load the deck into the reader using the first four steps above. Instead of the five steps immediately above, however, do the following:
    1. Click GENERAL CLEAR on the Cardatron Control Unit.
    2. Click INPUT SETUP on the Cardatron Control Unit. This will preset the Processor for a CDR (44) instruction for Input Unit 1 and address 0000.
    3. Click START on the Supervisory Panel or CONT on the Control Console to start the load.
    Depending on how the load deck is constructed, it may be possible to place a data deck for the program in the reader after the load deck so that the data will be available immediately to the program. The two conditions that may permit this are:
    • Format of the data cards must be sensed from the same column as the Input Unit used to load the program.
    • If the program must load one or more input format bands (typically the case), those bands must be loaded before the card reader is able to read the first data card. One way this can be done is to have the last card of the load deck put the reader in reload-lockout to prevent the first card in the data deck from being read automatically by the Input Unit. The initialization code in the program could then load the format band(s) in the Input Unit, maintaining reload-lockout until the CDRF (48) instruction for the last band to be loaded. The last (or only) CDRF releases reload-lockout, allowing the first card to be read asynchronously by the Input Unit with the appropriate format band now correctly loaded.
    If at either of these conditions could not be met, then the load deck should be loaded and read separately. Once the reader is empty and the program has loaded its input format band(s), the data deck can be loaded into the reader.

    In Other News...


    Tom Sawyer and I have been having some problems with the HTML5 Application Cache (App Cache) feature in Firefox, so in release 0.04a I have disabled the emulator's use of it. This should not affect your ability to use the emulator when you can actively connect to the hosting site, but it will prevent you from using it when a connection to the hosting site is not available. I hope to have that capability reinstated in the next release.

    Last week Google announced that it is terminating its free Google Code project hosting service. Projects will become read-only in August 2015 and the service will be shut down completely in January 2016. The retro-205 emulator project, of course, uses Google Code, so now we need to find a new home for it.

    I am currently evaluating other project hosting services and hope to make a decision in the coming week. I also need to move the retro-b5500 emulator project, and intend for both projects to end up on the same service. Once the 205 project is moved to its new home, I'll make an announcement on this blog. The project site on Google Code will also have a forwarding reference to the new site.

    Since completing the implementation of the Cardatron and punched-card interfaces described above, I have been working on resurrection of Donald Knuth's EASY and MEASY assemblers. These are the assemblers used to develop his Algol-58 compiler for the 205. That effort is progressing well, and I hope to have a report on it in the next few weeks.

    The next big development task for emulator is implementation of the 205's magnetic tape subsystem. This is a necessary capability for both the MEASY assembler and the Algol-58 compiler. This is also a large task, and it may be a couple of months before it is available.

    Friday, March 27, 2015

    The Mighty CARDATRON

    The 1950s through the 1970s were the age of punched-card interfaces for computer systems. Their use started to fall off in the 1980s, and by the early 1990s punched cards were more or less extinct. During their time, though, at least in the United States, punched cards and their related equipment were the primary (and sometimes the only) interface between people and the computer.

    This is Paul Kimpel again, with another update on the development of the retro-205 emulator for the ElectroData/Burroughs Datatron 205. The past two months have largely been devoted to implementing a punched-card and line-printer interface for the emulator. This is a large subject. A combined introduction to the punch-card facilities of the Datatron and a description of their implementation in the retro-205 emulator is too long for one post, so I have split it into two parts.

    This first part briefly discusses the development of I/O interfaces for the Datatron, introduces the punched-card equipment it used, and describes how punched-card I/O was handled. The second part, to be published within the next couple of days, will describe how punched-card support has been implemented in the retro-205 emulator.

    Background


    The earliest models of the Datatron computer system, the Consolidated Electrodynamics 201 through the ElectroData 203, supported so-called "Console I/O" -- input from punched paper tape and output to paper tape or the Flexowriter typewriter. It was termed Console I/O because the data went through the desk-sized Control Console, which contained relay-based circuits to route and synchronize the signals between the Processor and peripheral units. It was slow, and the preparation and editing of paper tapes was cumbersome.

    The first punched-card interface for the Datatron was a device known as the Punched Card Converter. This was a very basic device, handling only numeric data from and to cards. It stood between the Datatron Processor and up to two IBM punched card machines, one for input and one for output:
    • For input, the IBM Type 514, 523, or 528 punches and reproducers
    • For punched-card output, also the IBM Type 514, 523, and 528
    • For printed output, the IBM Type 402 tabulator or 419 numerical accounting machine
    The Punched Card Converter offered no buffering of the data, so the Processor was stalled while the IBM machine was in operation, and throughput suffered accordingly. It also had little formatting or data conversion capability. There were knobs to control the number of words per card read on input or punched/printed on output, but that was it. A more capable interface to IBM machines was needed.

    ElectroData eventually produced that more capable interface, calling it the CARDATRON, apparently in consonance with the DATATRON name of its host system. ElectroData seemed to prefer these names in all capitals, but in the rest of this post I'll capitalize just their first letters.

    Cardatron Architecture


    The Cardatron first appeared ca. 1956, about the time that Burroughs acquired ElectroData. As mentioned above, system models through the 203 used Console I/O and, later on, the Punched Card Converter. A 204 was a 203 with the necessary changes to support magnetic tape. A 205 was a 204 with additional changes to support the Cardatron. The Cardatron worked well enough that it was carried forward essentially unchanged to the 205's successor, the Burroughs 220.

    Like the Punched Card Converter, the Cardatron stood between the Processor and a number of IBM punched-card machines. Unlike the earlier interface, it could connect a maximum of seven card machines in any combination of input and output devices. The machines supported were:
    • For input, the IBM Type 087 and 089 collators, or the 523 summary punch
    • For punched-card output, the IBM Type 523 (although the same machine could not be used for both input and output)
    • For printed output, the IBM Type 407 tabulator
    The Cardatron had two main functions:
    1. Buffering. The 205 was not that fast, but the IBM machines were considerably slower. The 087 and 089 could read at 240 cards/minute (twice that if merging from both input hoppers), the 523 could read or punch at 100 cards/minute, and the 407 could print at 150 lines/minute. Buffering allowed the 205 Processor to continue executing while the Cardatron drove the IBM machine asynchronously. Only one card image or print line per machine could be buffered at a time.
    2. Formatting. The 205 had an 11-digit word. That word could hold a signed 10-digit number or five alphanumeric characters at two digits per character. The 205 had little in the way of character-level manipulation, just digit-wise shift/rotate and an Extract instruction that could do digit-wise masking operations somewhat like logical AND. The Cardatron provided the mechanism to take variably-sized numeric and alphanumeric fields on the card and map them to full words in the 205 memory, discarding unwanted zones or whole columns from the card, supplying zero digits to left- or right-justify fields in memory, and mapping a zone punch to the sign digit in memory. To accomplish this, it used a set of programmable format bands that were loaded into the Cardatron from the Processor.
    A Cardatron system consisted of a Control Unit and any combination of up to seven Input or Output Units. Each unit occupied a full-size cabinet. Each Input or Output Unit controlled one IBM card machine.

    The Control Unit provided the data path to the Processor and a switching network to select individual Input and Output Units. The unit was selected by the value of the third digit in an I/O instruction word. See the section "Cardatron Instructions" below for details on the instruction word formats and the additional digits in those words used to control Cardatron I/O.

    The Processor could transfer data to or from only one unit at a time, but once the relatively fast data transfer was completed between the Processor and Cardatron, the Input or Output Unit drove the IBM machine asynchronously. Thus, it was possible for the Cardatron to have multiple simultaneous operations in progress with the card machines at a time.

    Each Input or Output Unit contained a small drum that rotated at 21,600 RPM. The drum had six read/write tracks, or bands that could hold 316 digits each (slightly less than 29 11-digit words). Additional read-only tracks provided timing signals to the unit. The first of the six bands was used to buffer data going to or from the card machine. The remaining bands, numbered 1 through 5, were used to store strings of formatting codes.

    A card image or print line was transferred between the card machine and the Processor under control of one of the format bands. On output, the band was selected by the second numeric digit in the CDW (54) instruction word. On input, however, the format band was selected by a punch on the card being read. This approach was somewhat controversial, as it required the customer to plan their card layout around the need to reserve one column for format control. The column containing the format punch was designated by a manual setting in the Input Unit. Columns 1, 2, and 80 were apparently the most common choices.

    An Input Unit had two further capabilities:
    • Fixed Format Bands. There were two additional pseudo bands. These bands were not stored on the drum, but were hard-wired in the Cardatron Input Unit's logic. Format 6 was an all-numeric format that could read up to seven full 11-digit words plus a partial three-digit word from a card. It was typically used for loading object programs or raw data into the system. Format 7 was "reject format." The data from the card was not passed to the Processor, and the Input Unit automatically proceeded to read the next card.
    • Reload Lockout. If the second digit (called the "k-digit") of the CDR (44) instruction was odd, the Input Unit was placed in a "reload lockout" condition. The data from the card was transferred to the Processor, but the data remained on the Input Unit's buffer drum and the next card was not fed from the card machine. This feature was generally used in one of two ways:
      • To reread the same data into a different starting address on the memory drum.
      • To hold the data on the buffer drum while the format band was reloaded, so that the data could be read again under a different format.
    Reload lockout was released once a CDR (44) or CDRF (48) was executed with an even value in the k-digit of the instruction word.

    Additional control over data formatting could be accomplished through wiring of the plugboards in the IBM machines. ElectroData and Burroughs had standard plugboard configurations that transferred all columns of a card or line of print as is, but some sites developed their own plugboard wiring to satisfy special requirements.

    Cardatron Formatting Facilities


    The first concept behind Cardatron formatting and data conversion is that the I/O took place in two phases:
    • For input, the first phase asynchronously read a card and transferred its data to the data band on the buffer drum. The second phase transferred the data from the buffer drum to the Processor when the Processor requested it by executing a CDR (44) instruction. Note that this meant the Input Unit generally read the card asynchronously before the Processor asked for its data.
    • For output, the first phase transferred the data from the Processor to the data band on the buffer drum under control of a CDW (54) instruction and released the Processor for further execution. The second phase asynchronously transferred the data from the buffer drum to the card machine.
    The data transfer in both phases was controlled by the digits of the selected format band. Transfer between the Input or Output Unit and the Processor was limited by the speed of rotation of the unit's buffer drum, or one word per 2.78 ms. That rate could be achieved when transferring data to or from one of the high-speed memory loops, which had an average access time of 0.84 ms, but otherwise the rate was controlled by the average access time to main memory, 8.4 ms. A single I/O typically transferred 10-20 words, so even transfers to and from main memory took less time than the fastest card machine cycles.

    The second concept behind Cardatron formatting is that each column on a card or line of print was divided into two parts, a numeric digit and a zone digit. The Cardatron allowed you to copy digits, delete digits, and insert zero digits in the path between the card machine and the Processor.

    A standard punched card consisted of 80 columns and 12 rows. From the top of the card, these are known as the 12, 11, and 0-9 rows. The numeric portion of a column is considered to be the bottom nine rows, 1-9. The zone portion of a column is considered to be the top three rows, 12, 11, and 0. For numeric data, a negative number was generally indicated by an 11 punch over the leading digit of the field, and a non-negative number was generally indicated by a 12-punch or no zone punch at all.

    As an Input Unit was reading a card, it split each column into the numeric and zone halves, and then encoded each half so that one column occupied two (not necessarily contiguous) digits on the buffer drum. An Output Unit took one or two digits from the buffer drum (as controlled by the format band) to produce one column for punching or printing on the card machine. The actual process was a little more complex than that, but the central idea is that the numeric and zone portions of a column on the card machine were stored and manipulated as separate digits on the buffer drum. The conversion process and encoding of digits on the buffer drum are detailed in United States Patents 3,000,556 (September 16, 1961, L.L. Bewley et al) and 3,072,328, (January 8, 1963, L.L. Bewley et al).

    The third concept behind Cardatron formatting is that each data digit on the buffer drum was paired with the corresponding format digit on the selected format band. Thus the handling of data digit 1 was controlled by format digit 1, data digit 2 by format digit 2, and so forth. Not all data digits were necessarily associated with columns on the card -- digits could be deleted and zero digits could be inserted into the data stream as determined by the format band digits.

    Digits on the data band could have the values 0-9, 11, and 12. Those last two values where used to encode multiple punches in the numeric part of a column for certain special characters, e.g., 11-3-8 for "$". Digits on the format bands were restricted to values 0 to 3. The formatting digits were interpreted somewhat differently for Input and Output Units. For an Input Unit, format digits mapped the numeric and zone digits coming from the card to digits in the destination computer word as follows:
    • 0 caused a 0 digit to be inserted in the corresponding data digit position on the buffer drum. The 0 digit was inserted on the drum before the next digit coming from the card. In effect, this code caused a padding zero digit to be inserted into the computer word.
    • 1 caused the numeric or zone digit coming from the card to be recorded in the corresponding data digit on the buffer drum. The digit was not simply copied, but encoded in a special way as described in Patent 3,000,556. In effect, this copied the digit to the computer word, but a transformation took place for alphanumeric data to account for the numeric/zone representation of characters on a card vs. the two-digit alphanumeric coding used internally by the 205. Generally, though, two 1 digits in succession transferred one alphanumeric column from the card to the computer word.
    • 2 caused the numeric or zone digit coming from the card to be dropped and replaced by a 0 digit in the corresponding data digit on the buffer drum. This code is effectively a combination of format digits 1 and 3. In effect, this code replaced the digit coming from the card with a zero in the computer word.
    • 3 caused the numeric or zone digit coming from the card to be dropped. In effect, this code prevented storing the digit coming from the card in the computer word.
    For an Output Unit, data digits coming from a computer word are mapped to numeric and zone digits for a card or print column, and the format digits operated as follows:
    • 0 caused a 0 digit to be inserted in the corresponding data digit position on the buffer drum. This digit was inserted before the next digit coming from the computer word. In effect, this code caused the corresponding numeric or zone portion of a column to have no punch. Two 0 codes in succession generally resulted a blank column on output.
    • 1 caused the digit from the computer word to be recorded in the corresponding data digit on the buffer drum. As with input, a special transformation occurred to handle the differences between the internal 205 alphanumeric coding and card numeric/zone coding, as described in Patent 3,072,328. In effect, this code copied the digit from the word to the corresponding numeric or zone position in the next card column. Generally, two 1 digits in succession transferred one alphanumeric character from the computer word to the card or print line.
    • 2 caused one digit from the computer word to be stored in the corresponding data digit on the buffer drum such that it would be punched/printed as one numeric column on the output device. In effect, this code caused the digit from the computer word to generate both a numeric and zone code for the output column. The behavior of this code, as opposed to a 3-1 combination, was designed to supply a 0 punch for a 0 digit, which would not normally happen for format digit 1, since strictly speaking 0 is a zone punch, not a numeric punch.
    • 3 caused the next digit from the computer word to be dropped. This was often used to strip leading numeric zeroes from a computer word so that either a shorter field could be formatted on the output device, or the zone punch for the sign digit could be properly positioned, or both.
    The next characteristic of Cardatron formatting, and a highly unusual one, is that data and format digits on the buffer drum mapped to columns on the IBM machine backwards. That is, data and format digit 1 corresponded to the numeric portion of column 80 on a punched card, or the last print position on the printer. The reason for this may be that during input, digits coming from the Cardatron entered the sign position of the Processor's D register and were shifted right; on output, digits going to the Cardatron exited the low end of the A register and were also shifted right. Starting at the end of the card made it somewhat easier to deal with leading zeroes in words and to position the sign digit properly.

    Another characteristic of Cardatron formatting was that, since data in the Input or Output Unit was processed in reverse order, but words were fetched or stored on the memory drum in ascending order, fields on the card were mapped in reverse order to words in memory -- the last field on the IBM machine was at the first address in memory. This may be counter-intuitive, but since both input and output worked the same way, words came into the system and went out in the same relative order. The reverse ordering of fields also meshed well with the indexing and decrement-and-branch behavior of the B register.

    The way these format digits interacted with card or print columns can be difficult to envision from a brief description such as the foregoing. A small example might help illuminate how it worked. Since Cardatron formatting worked from right to left on the card, we'll just consider a couple of fields at the end of a card:
    • Columns 72-76 contain a five-digit numeric field with the sign indicated by a zone punch over column 72.
    • Column 77 is not used.
    • Columns 78-80 are a three-character alphanumeric field.
    Thus, the last portion of the card could be visualized as the following string, where S is a signed numeric digit, N is an unsigned numeric digit, X is an ignored column, and A is an alphanumeric column:

    ...SNNNNXAAA

    We want the alphanumeric field to end up left justified over spaces in one word of main memory and the numeric field to be right-justified over zeroes in the next word. Since the data is read backwards, if the CDR (44) instruction specifies address 4000, the alphanumeric field will be stored in 4000 and the numeric field will be in 4001.

    The following digits in the format band will do this transformation between the card columns and computer words, again reading from right to left. The vertical-bar characters (not part of the format band coding) show where word boundaries in memory will coincide with the format digits:

    ...|100000131313131|3301111110000|

    • The four 0 digits on the end simply shift four zeroes into the D register starting from the sign (left-most) digit and moving to the right. The internal 205 code for a space is 00, so this inserts the two spaces necessary to left-justify the three-character alphanumeric field in its computer word. 
    • Next, the six 1 digits alternately copy the numeric and zone digits from the last three columns on the card and shift those into the D register as well, pushing the spaces to the right. The codes for the numeric and zone digits undergo transformations going from the card to the Cardatron buffer drum and from the buffer drum to the D register in order to translate the characters to internal 205 character codes. 
    • Then the 0 in the format band shifts in a 0 for the sign digit, completing the first word, which will be stored at location 4000 in the 205's memory. 
    • The 33 digit pair deletes the numeric and zone codes for the unused column 77 on the card. 
    • Next, the four pairs of 31 format digits alternately copy the numeric portions of card columns 73-76 and discard the zone portions. This shifts the low-order four digits of the numeric field into the D register. 
    • The next 1 digit copies the numeric portion of card column 72 to the D register. 
    • The five 0 digits shift as many zeroes into the D register. The purpose of these 0 digits is to right-justify the number in the word. We now have ten digits shifted into the D register. 
    • The final 1 digit shifts the zone from the card column 72 into the sign digit, completing the word that will be stored at location 4001.

    Unfortunately a good publicly-accessible reference for the 205 Cardatron is not presently available. A quite usable description, however, can be found in Section 6 of the Burroughs 220 Operational Characteristics manual, available at:

    http://bitsavers.org/pdf/burroughs/electrodata/220/5020A_B220_OperCharac_Aug60.pdf.

    Format band coding had to be prepared by the programmer and loaded into the 205's drum memory. All 11 digits of a word were used to store the format band digits, so the 316 digits of a band required 29 words in memory. Sign-digits in the data other than 0 or 1 had special meaning during input from an I/O device, however, and format band data typically had 2s and 3s in the sign digits of their words, so special handling was required to load programs that contained format bands.

    During input from Console and Cardatron devices, the sign digit of the words being read were examined before being stored in memory and acted upon as follows:
    • Digits 0, 1, 8, 9 -- word is stored normally with the sign digit as is.
    • Digit 2 -- the current contents of the B register are added to the word and the sign digit is replaced by 0 before the word is stored in memory. B-register modification was typically used to adjust relocatable addresses in instruction words.
    • Digit 3 -- same as Digit 2, except the sign digit is replaced by 1 before the word is stored in memory.
    • Digit 4 -- the word is not stored in memory, but is transferred to the C register and then executed as an instruction. For Cardatron input, the op code in the word must be 44 for CDR (alas, the documentation does not say what happens if the op code was anything else). The input operation continues with the next word from the device. Words with this sign digit were typically used to change the address at which the following words would be stored.
    • Digit 5 -- same as Digit 4, except the B register is added to the word before it is transferred to the C register and executed.
    • Digit 6 -- the word is not stored in memory, but is transferred to the C register and then executed as an instruction. Unlike the action for Digits 4 and 5, a word with this sign digit caused data transfer from the device to stop and the I/O operation to be terminated. The word could contain any op code, but most frequently it was an unconditional branch (20) or another input command.
    • Digit 7 -- same as Digit 6, except the B register is added to the word before it is transferred to the C register and executed.
    This modifying behavior of sign digits in a data input stream was an interesting idea, and permitted control over an I/O operation somewhat like the channel programs for the IBM 709 and later systems. The differences with the 205 approach were that the I/O commands were embedded in the data itself instead of being stored separately, and that the words could be modified by the contents of the B register before being stored in memory.

    Note that words with sign digits having values of 2 or 3 normally caused the input word to be modified by the B register and the sign digit to be changed to a 0 or 1. This is something you definitely do not want to have happen to a format band as it is being loaded into memory, so some overrides to the default behavior were necessary.

    For input from Console devices, there was a switch on the Sub-Maintenance panel that could be set to suppress the interpretation of signs in the data stream. The retro-205 emulator does not presently implement this switch.

    For input from Cardatron devices, the second digit (k-digit) of the CDR (44) instruction word could be used to control the interpretation of sign digits in the words being read. If the high-order bit in the word was set, then B-register modification of input words with signs 2, 3, 5, and 7 was suppressed, and signs of 2 or 3 were stored as is. Note that the low-order bit of the k-digit still controlled reload lockout.

    For an example of how sign digits in words coming from the Cardatron could control and redirect data during an I/O, see this analysis of a small, three-card program that clears the 205 memory drum:


    Note that this program uses the hard-wired format band 6, which acted as if it consisted (right-to-left) of 80 pairs of 31 digits, preceded by 154 0 digits to fill out the format band. This band will transfer 14 words of data to the 205 memory, unless the transfer is stopped sooner by a sign-6 or -7 instruction word (which would normally be the case).

    Cardatron Instructions


    There were six instructions in the 205 Processor for commanding the Cardatron. In the following discussion, "s" is the sign digit, "r" is the relay-designate digit, "k" represents the k-digit discussed above, "u" is the Cardatron unit number (1-7), "p" is the standard breakpoint control digit, "x" is a digit that is ignored, and "aaaa" is the effective address of the instruction, which may be modified by the B register if the sign digit in the instruction word is odd.

    CDR: Card Read (s xkup 44 aaaa)
    Read words from Input Unit "u" to memory starting at address "aaaa". The k-digit may indicate reload lockout or sign-handling override. The number of words read is determined by the format band selected by the card, but that number may be reduced if the incoming data contains a word with a sign of 6 or 7.
    CDRI: Card Read Interrogate (s xxup 45 aaaa)
    Interrogate the status of Input Unit "u". If a card has been read and the unit's buffer drum is loaded and ready to transfer data to the Processor, branch to "aaaa" after clearing the R register and storing the current control counter in the high-order four digits of R. If the buffer is not loaded and ready to transfer data, continue with the next instruction in sequence.
    CDRF: Card Read Format (s xkup 48 aaaa)
    Load a format band on Input Unit "u" from 29 words in memory starting at "aaaa". The band number and reload lockout control are encoded in the k-digit. Odd values of k set reload lockout and even values release it. k-digit values 0-1 load band 1, 2-3 load band 2, 4-5 load band 3, 6-7 load band 4 and 8-9 load band 5. Use of the high-order bit of the k-digit to control sign digit transfer and B-register modification is not relevant for this instruction. 
    CDW: Card Write (s rkup 54 aaaa)
    Write words to Output Unit "u" from memory starting at address "aaaa". The k-digit specifies the format band as for CDRF (48) above. The r-digit sets a group of four relays that were generally used to convey carriage-control information to a line printer. The number of words written is determined by the format band. The low-order bit of the k-digit is not relevant for this instruction.
    CDWI: Card Write Interrogate (s xxup 55 aaaa)
    Interrogate the status of Output Unit "u". If the unit's buffer drum is ready to receive data from the Processor, branch to "aaaa" after clearing the R register and storing the current control counter in the high-order four digits of R. If the buffer is loaded and the unit is still busy writing to the card machine, continue with the next instruction in sequence.
    CDWF: Card Write Format (s xkup 58 aaaa)
    Load a format band on Output Unit "u" from 29 words in memory starting at "aaaa". The k-digit specifies the band number as for CDRF (48) above. The low-order bit of the k-digit is not relevant for this instruction.
    This ends the first part of the discussion on punched cards and the Cardatron. Stay tuned for the second part on how the Cardatron has been implemented in the retro-205 emulator.