DATE January 13, 1960 SUBJECT Complementing Checkerboard Program TO PDP Distribution List FROM John C. Conley This is a utility program for checking the performance and reliability of the magnetic core memory. It works the memory in the roughest way possible and is self-checking for easy location of faulty or weak cores. The memory is loaded in a fixed order from the test word, using both the test word and its complement. The content of each register is then checked, and if correct the content is complemented and stored. The program after initial loading is in a continuous loop of checking, complementing, storing and then checking again, complementing and storing. This will continue indefinitely until the machine is stopped manually or on the location of an error during checking. The memory plane is loaded in the following order, assuming that the test word is all l's and that the skip instruction in register 1717 is skip on AC positive. This instruction is set by the program and may be a skip on either positive or negative. If negative the loading will be the complement of that shown. Any combination of l's and o's may be used in the test word. ## MEMORY PLANE | | | | | | | | | | | - | | - | | - | | | | | | | |------------------------|---|---|---|------------|-----|-----|----|----|----|----|-----|----|-----|-----|----|----|----|-------|----|----| | Register | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 20 | 35 | 36 | 37 | | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | <br>0 | 0 | 1 | | 40 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | <br>1 | 1 | 0 | | 100 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | | | | : | | | | The second | | | | | | | | | | | | | | | | | | 1640<br>1700)<br>1740) | 0 | 1 | | Pr | og: | rar | n: | is | in | th | ese | re | gis | ter | 3 | , | | | | | ## OPERATING INSTRUCTIONS - 1. Set Test Word to configuration of 1's and 0's you want to use. - 2. Set Test Address to 1700. - 3. Push start switch on console. - 4. The machine will halt at 1745 (PC = 1746) if an error is detected. The AC will show the address of the register containing the error. - 5. To locate faulty core, set Test Address to address shown in AC. Push examine switch and locate, core which is incorrect. For example, if 1's and 0's have been loaded, faulty core will have a 1 while the rest of the register shows 0's or just the reverse of this. - 6. To determine what should be in any register examine program registers 1717 and 1737. If they are the same memory should contain what was loaded initially, if they are different the program is in the complement cycle and the complement of what was loaded should be in memory. - NOTE: If this examination is made after a halt at 1745, all registers before the address shown in the AC will have been complemented and so be the reverse of the statement above. Those registers after the address in the AC will be as explained above. | еу | Address | Instruction | Code | Comments | |-----|------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------|-----------------------------------------------------------------------------| | | 1700<br>1701<br>1702 | LAC L<br>DAC D<br>DAC G | 20-1767)<br>24-1737)<br>24-1717) | Sets skip instruction for initial lead and check of memory registers 0-157? | | | 1703<br>1704 | LAC T<br>DAC F | 20 <b>-</b> 1777)<br>24 <b>-</b> 1716) | Puts in dummy instruction for initial loading of memory | | E | 1705<br>1706 | LAC Z<br>DAC Q | 20 <b>-</b> 1772)<br>24 <b>-</b> 1775) | Designates first register to be loaded or checked | | A | 1707<br>1710<br>1711<br>1712<br>1713<br>1714<br>1715 | LAC Q<br>RAR 5<br>XOR Q<br>DAC M<br>RAR 1<br>XOR M<br>RAR 1 | 20-1775)<br>67-1037)<br>06-1775)<br>24-1770)<br>67-1001)<br>06-1770)<br>67-1001) | Determines what should be in each memory register | | F | 1716 | (Dummy<br>JMP D | 76-000<br>60-1737 | | | C B | 1717<br>1720<br>1721<br>1722<br>1723<br>1724<br>1725 | (SPA<br>SNA<br>JMP C<br>LAT<br>JMP B<br>LAT & CMA<br>DAC* Q<br>IDX Q | 64)<br>60-1723)<br>76-2200)<br>60-1724)<br>76-3200)<br>25-1775)<br>44-1775) | Loads memory initially | | | 1726 | SAS V | 52-1771 | Checks for last register | | | 1727 | JMP A | 60-1707 | | | | 1730 | LAC R | 20-1774 | | | | 1731 | DAC F | 24-1716 | | | | 1732<br>1733<br>1734<br>1735 | LAT<br>DAC W<br>CMA<br>DAC P | 76-2200)<br>24-1776)<br>76-1000)<br>24-1773) | Sets constants from TW for checking | | | 1736 | JMP E | 60-1705 | Start checking | | D | 1737 | (SPA<br>(SNA | 64-0200<br>64-0400 | | | l | Complementing | Checkerboard | cont'd. | |---|---------------|--------------|---------| | | | | | | roy. | Address | Instruction | Code | Comments | |--------|--------------------------------------------------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------| | N<br>H | 1740<br>1741<br>1742<br>1743<br>1744<br>1745<br>1746<br>1747<br>1750<br>1751<br>1752 | JMP H LAC *Q SAD W JMP J LAC Q Halt LAC *Q SAS P JMP N CMA DAC *Q | 60-1746)<br>21-1775)<br>50-1776)<br>60-1751)<br>20-1775)<br>76-0400)<br>21-1775)<br>52-1773)<br>60-1744)<br>76-1000)<br>25-1775) | Checks memory register and reloads complement. If error is detected halts at 1745 with address of incorrect register in AC | | | 1753<br>1754 | IDX Q<br>SAS V | 44-1775)<br>52 <b>-1771</b> ) | Checks for last register | | Page A | 1755 | JMP A | 60-1707 | | | | 1 1756 | LAC K | 20-1766) | | | | 1757<br>1760 | DAC D<br>DAC M | 24-1737)<br>24-1770) | Changes skip instruction after each | | | 1761<br>1762 | LAC L<br>DAC K | 20-1767) | complete run through of memory for next check and complement cycle | | | 1763<br>1764 | LAC M<br>DAC L | 20-1770) | nox oncor and comprenent cycle | | J. C. | | | | | | 31 | 1765 | JMP E | 60-1705 | | | K | 1766 | SPA | 64-0200 | | | L | 1767 | SNA | 611-01100 | | | M | 1770 | , | | | | Л | 1771 | | 001700 | | | Z | 1772 | | 000000 | | | P | 1773 | | | | | R | 1774 | | 60-1737 | | | Q | 1775 | | | | | W | 1776 | | | | | T | 1777 | | 76-0000 | | | | Design Control | | | |