WikiPatents - Community Patent Review
Create Free Account  |  License or Sell Your Patent  |  WikiPatents Marketplace  |  WikiPatents Blog
Username:  Password:  
    
Advanced Search
Numerical control system with downloading capability    
United States Patent4138718   
Link to this pagehttp://www.wikipatents.com/4138718.html
Inventor(s)Toke; Ronald J. (Bratenahl Village, OH); Donze; William A. (Mentor, OH)
AbstractA numerical control system which employs a programmed numerical control processor to perform the numerical control functions is coupled to a bulk storage device by a host computer. The bulk storage device stores a download library which includes not only part programs, but also system software programs and diagnostic programs which may be downloaded to the numerical control system upon request. By downloading a system software program the numerical control capabilities of the system can be completely reconfigured to, in essence, provide a new machine.
   














 Title Information Submit all comments and votes
 
Patent Text Patent PDF Print Page Summary File History
Plain text PDF images Print Summary File History
Drawing from US Patent 4138718
Numerical control system with downloading capability - US Patent 4138718 Drawing
Numerical control system with downloading capability
Inventor     Toke; Ronald J. (Bratenahl Village, OH); Donze; William A. (Mentor, OH)
Owner/Assignee     Allen-Bradley Company (Milwaukee, WI)
Patent assignment
All assignments
Publication Date     February 6, 1979
Application Number     05/850,927
PAIR File History     Application Data   Transaction History
Image File Wrapper   Patent Term   Fees
Litigation
Filing Date     November 14, 1977
US Classification     700/7 700/169 700/177
Int'l Classification     G06F 003/02 G06F 013/00
Examiner     Springborn; Harvey E.
Assistant Examiner    
Attorney/Law Firm     Quarles & Brady
Address
Parent Case    
Priority Data    
USPTO Field of Search     364/200 MS File 364/900 MS File
Patent Tags     numerical control downloading capability
   
Enter a comma (,) or semicolon (;) between multiple tag words/phrases.
Describe this patent:
 Amusing   
 Clever   
 Complex   
 Efficient   
 Historic   
 Important   
 Innovative   
 Interesting   
 Practical   
 Simple   
[no votes]
Patent WIKI

Share information and news about this patent, including information and news about the technology, inventors, company, ligation and licensing.

 References Submit all comments and votes
 
*references marked with an asterisk below are user-added references
 U.S. References
 
Add a new US reference:  
ReferenceRelevancyCommentsReferenceRelevancyComments
3810104
Markley
700/7
May,1974

[0 after 0 votes]
3744031
Avery
700/160
Jul,1973

[0 after 0 votes]
3626385
Bouman
62/341
Dec,1971

[0 after 0 votes]
 Foreign References
 Other References
 Market Review Submit all comments and votes
   
Market Size
Estimate the gross annual revenues of the relevant market sector:
> $10B
$5B - $10B
$2B - $5B
$500M - $2B
$100M - $500M
$10M - $100M
$1M - $10M
$500K - $1M
$100K - $500K
< $100K
[No votes]
$0
 
$0   $2.5B   $5B   $7.5B   $10B
Market Share
Estimate the percentage of the relevant market sector this invention will capture:
75% - 100%
50% - 74.99%
25% - 49.99%
10 - 24.99%
5 - 9.99%
2 - 4.99%
1 - 1.99%
< 1%
[No votes]
0.0%
 
0%   25%   50%   75%   100%
Reasonable Royalty
What percentage of gross sales should the inventor or assignee be paid?
75% - 100%
50% - 74.99%
25% - 49.99%
10 - 24.99%
5 - 9.99%
2 - 4.99%
1 - 1.99%
< 1%
[No votes]
0.0%
 
0%   25%   50%   75%   100%
Public's "Guesstimation" of Royalty Value
Market SizeN/A[No votes]
xMarket ShareN/A[No votes]
xReasonable RoyaltyN/A[No votes]

N/A

License Availablity
If you are NOT the owner or assignee, answer here:
Yes, license is available for purchase

No, license is not currently available



[No votes]
License Availablity
If you ARE the owner or assignee, answer here:
Yes, license is available for purchase

No, license is not currently available



[No votes]
Competitive Advantage
Does this invention have a significant competitive advantage over similar technologies?
Yes

No



[No votes]
Most helpful competitive advantage comment
[No comments]

Commercial Alternatives
Are there viable commercial alternatives for this invention?
Yes

No



[No votes]
Most helpful commercial alternative comment
[No comments]

 Technical Review Submit all comments and votes
 Claims Submit all comments and votes
 


We claim:

1. A numerical control system, the combination comprising:

a read/write memory for storing programs including an executive system program;

an N/C processor coupled to said read/write memory by a data bus and an address bus, said N/C processor being operable to write data into said read/write memory through said data bus;

a read-only memory coupled to said N/C processor and storing a resident communications program;

means coupled to said N/C processor for initiating the transfer of said resident communications program from said read-only memory to said read/write memory;

means associated with said N/C processor which is responsive to said initiating means for sequentially transferring each instruction in said resident communications program to said read/write memory and for causing said N/C processor to commence executing said resident communication program;

host processor means coupled to said N/C processor;

storage means for storing executive system programs for numerical control systems, said storage means being coupled to said host processor to download selected executive system programs to said N/C processor;

wherein said N/C processor is operable in response to said resident communications program to transmit to said host processor a request for a selected executive system program and to receive and store in said read/write memory the downloaded instructions of said selected executive system program.

2. The numerical control system as recited in claim 1 in which a keyboard is coupled to said N/C processor for enabling the manual selection of the executive system program to be downloaded.

3. The numerical control system as recited in claim 1 in which the host processor is located remotely from the N/C processor and the downloaded executive system program is coupled to the N/C processor through a data link.

4. The numerical control system as recited in claim 1 in which said means for sequentially transferring the resident communications program to said read/write memory includes a transfer counter which connects to said read-only memory to address memory locations therein and said transfer counter is repeatedly incremented to successively address each program instruction stored in said read-onl-memory.

5. The numerical control system as recited in claim 4 in which said N/C processor performs functions in response to the execution of microroutines stored in a second read-only memory and said means for initiating the transfer of the resident communications program is a manually operable switch, which when operated, causes the N/C processor to execute a selected one of said microroutines.

6. The numerical control processor as recited in claim 5 in which said N/C processor operates in response to said one selected microroutine to read program instructions addressed by said transfer counter out of said read-only memory and write them into said read/write memory.

7. A control system, the combination comprising:

a processor which is operable in response to program instructions stored in an associated read/write memory;

a host processor coupled to said processor by a data link;

a storage device coupled to said host processor for storing a download library comprised of a plurality of executive system programs for said processor to enable it to control the operation of a machine tool;

means for generating a download command to said host processor, which command includes a code that identifies one of said executive system programs, said host processor being responsive to said received download command to read the selected executive system program out of said storage device and download it to said processor read/write memory through said data link;

second memory means coupled to said processor read/write memory for storing a resident communication program; and

means forming part of said processor for transferring said resident communications program from said second memory means to said read/write memory and means for sequentially reading the instructions of said resident communications program out of said read/write memory and executing them;

wherein said processor operates in response to the execution of said resident communications program instructions to store instructions of said downloaded executive system program received through said data link in its associated read/write memory.

8. The control system as recited in claim 7 in which said means for generating a download command includes a keyboard coupled to said processor and said processor is operable in response to instructions in said resident communication program to input data from said keyboard, to form a download command using said data, and to coupled the download command to the host processor through said data link.

9. The control system as recited in claim 7 in which said second memory means is an indestructible memory.
 Description Submit all comments and votes
 


BACKGROUND OF THE INVENTION

The field of the invention is numerical control systems, and particularly, numerical control systems of the type which employ programmed processors as the means for carrying out the numerical control functions.

Such a numerical control system is known in the art as a computer numerical control or "CNC" and they are characterized generally by their use of a programmed minicomputer or microprocessor in lieu of hardwired logic circuitry. Such a system which employs a programmed processor is disclosed in U.S. Pat. No. 4,038,533 which issued on July 26, 1977 and is entitled "Industrial Control Processor System." Although CNC systems are programmable and do therefore offer a certain amount of flexibility, as a practical matter the system program which determines the basic operational characteristics of the system is seldom altered once the system is attached to a specific machine tool. For example, the CNC system may be programmed to provide full contouring for a three-axis milling machine without automatic tool changer and with certain "canned cycles." That software system is usually not altered during the life of the machine despite the fact that for much of the time the machine tool may not require contouring capability and could make better use of the memory space occupied by the circular and linear interpolation programs.

The flexibility afforded by the use of a programmable processor in a numerical control system has thus never been fully realized in prior systems.

SUMMARY OF THE INVENTION

The present invention relates to a numerical control system in which a system program may be readily downloaded from a library stored in a bulk storage device. More specifically, the invented numerical control system includes a main memory, a processor, a read-only memory which stores a resident communication program, means for transferring the resident communications program from the read-only memory to the main memory and for initiating the execution of said program by the numerical control system processor, a storage device for storing a plurality of programs including a system program for the numerical control system, and a host processor coupled to said storage device and said numerical control system processor and being responsive to a download command generated by said numerical control system processor during its execution of the resident communications program to download said system program to the main memory, wherein the numerical control system processor jumps from the resident communications program to said downloaded system program after the download has been completed.

A general object of the invention is to download a system program to the memory of a CNC system. If the main memory is completely empty, as for example, after a prolonged power failure or a malfunction which erases part or all of the system program, a new system program can be downloaded from the download library in the storage device by initiating the execution of the resident communications program.

Another object of the invention is to enable the operator to select a system program from the download library. A manual data entry means such as a keyboard is associated with the numerical control processor and the download command is selected by the operator to identify a specific program in the download library. In this manner different system programs may be downloaded to alter the capabilities of the numerical control system to meet the requirements of the machine tool to which it is attached and the part being machined.

The foregoing and other objects and advantages of the invention will appear from the following description. In the description reference is made to the accompanying drawings which form a part hereof, and in which there is shown by way of illustration a preferred embodiment of the invention. Such embodiment does not necessarily represent the full scope of the invention, however, and reference is made to the claims herein for interpreting the breadth of the invention.

BRIEF DESCRIPTION OF THE DRAWINGS

FIG. 1 is a perspective view of the system of the present invention connected to a machine tool;

FIG. 2 is a perspective view of the numerical control system which forms part of the system of FIG. 1 with the enclosure door open;

FIG. 3 is a block diagram of the system of FIG. 1;

FIGS. 4a and 4b are a block diagram of the industrial control processor which forms part of the system of FIG. 3;

FIG. 5 is a block diagram of the arithmetic and logic processor which forms part of the industrial control processor of FIG. 4b;

FIG. 6 is a block diagram of the input/output circuitry which forms a part of the industrial control processor of FIG. 4b;

FIG. 7 is a schematic diagram of the priority encoder circuit which forms part of the industrial control processor of FIG. 4a;

FIGS. 8a-c are a flow chart of the resident communications program which forms part of the industrial control processor of FIG. 4;

FIG. 9 is a flow chart of a system program which may be stored in the numerical control processor memory;

FIG. 10 is a flow chart of the main controller routine which forms part of the software system of FIG. 9;

FIGS. 11a and 11b is a flow chart of the block execute routine which forms part of the software system of FIG. 9;

FIGS. 12a and 12b is a flow chart of the ten millisecond timed interrupt routine which forms part of the software system of FIG. 9;

FIGS. 13a and 13b is a flow chart of a program called COMPAC which is stored in the download library;

FIG. 14 is a flow chart of the download program (DNLDNC) stored in the host computer memory of FIG. 3;

FIG. 15 is a representation of the contents of the numerical control system memory at one stage of the download procedure; and

FIG. 16 is a block diagram of the host computer of FIG. 1.

DESCRIPTION OF THE PREFERRED EMBODIMENT

Referring to FIG. 1, a numerical control system is housed in a cabinet 1 and connected through a cable 2 to a multi-function machine tool with automatic tool changer 3. The numerical control system controls the motion of a cutting tool 4 along two or more axes of motion in response to a part program which is read from a tape reader 5. In addition, the numerical control system operates in response to commands read from the tape reader 5 to control auxiliary functions on the machine tool 3, such as automatic tool selection and changing from a tool magazine 6, pallet selection and changing, spindle speed and coolant operation. The implementation of such auxiliary functions involves the sensing of one-bit signals generated by numerous input devices such as limit switches, selector switches, and photo-electric cells, which are mounted to the machine tool 3, and the operation of numerous output devices such as solenoids, lights, relays and motor starters. The numbers and types of such input and output devices, as well as the manner in which they are operated, will vary considerably from machine to machine.

The numerical control system includes a programmable interface which allows it to be easily interfaced with machine tools of any make and model. This interface is accomplished by entering a control program comprised of programmable controller-type instructions through a keyboard 7. When this control program is executed the system operates as a programmable controller to selectively sense the status of the particular input devices on the machine tool to be controlled and to selectively operate the output devices thereon to provide the desired manner of operation.

Mounted to the door of the cabinet 1 immediately above the keyboard 7 is an associated cathode ray tube (CRT) display 9. Mounted to the right of the keyboard 7 and CRT display 9 is a main control panel 10 which includes a variety of pushbuttons and selector switches for providing standard operator controls such as mode selection, feedrate override, spindle speed override, jog select, axis select, etc. One of the pushbuttons enables the keyboard 7 to enter data.

Referring particularly to FIGS. 2 and 3, the elements of the numerical control system are mounted within the cabinet 1 to allow easy access for inspection, testing and maintenance. The keyboard 7 is mounted to the cabinet door 11 along with the tape reader 5, CRT display 9 and main control panel 10. A secondary control panel 12 mounts immediately above the tape reader 5 and all of these system I/O devices are connected to a numerical control processor 13 which is housed at the bottom of the cabinet 1. More specifically, the tape reader 5 connects through a cable 14, the secondary control panel 12 connects through a cable 15, the keyboard 7 connects through a cable 25, the CRT display 9 connects through a cable 17, and the main control panel 10 connects through a cable 18 to a wire harness 19 which leads to the processor 13. A processor front panel 26 provides a number of manually operable pushbuttons and visual indicators which relate to the operation of the processor 13 and which are connected thereto through a bus 27.

Two input/output (I/O) interface racks 20 and 21 are mounted in the cabinet 1 above the processor 13 and are connected thereto by a wiring harness 22 which extends upward along their left-hand side. A main power supply 23 mounts above the I/O interface rack 21 and a memory power supply 24 mounts on the left side wall of the cabinet 1.

The I/O interface racks 20 and 21 mount a variety of input circuits and output circuits on closely spaced, vertically disposed printed circuit boards (not shown in the drawings). These input and output circuits serve to couple the industrial control processor 13 with the cable 2 that leads to the machine tool 3 and may include input circuits for sensing the status of limit, selector and pushbutton switches such as that disclosed in U.S. Pat. No. 3,643,115 entitled "Interface Circuit for Industrial Control Systems," and output circuits for driving solenoids and motors such as that disclosed in U.S. Pat. No. 3,745,546 entitled "Controller Output Circuit." The input circuits also include position feedback accumulators which receive feedback data from the position transducers on the machine tool 3 and the output circuits include registers for providing axis motion command words to the machine tool servo mechanisms.

Referring particularly to FIGS. 1-3, the numerical control system 1 is connected to a host computer 500 through a cable 501 in what is known in the art as a DNC configuration. The cable 501 connects to a universal asynchronous receiver/transmitter (UAR/T) 8 which is mounted within the numerical control processor housing 13 and it in turn is connected to the numerical control processor 13 through the wire harness 19. The UAR/T 8 is treated as another input/output device by the processor 13 as will be described in more detail hereinafter.

The host computer 500 is a general purpose digital computer such as the Model 7/32 manufactured by Interdata, Inc. As will be described in more detail hereinafter, it is coupled to the cable 501 by a UAR/T 502 which connects to an I/O port on a computer processor 550. The processor 550 is coupled to a read/write memory 551 through a bus 552 and a bulk storage device 507 in the form of a disc couples to the memory 551 and it serves to store not only a large number of part programs, but also, a variety of numerical control system software packages which may be downloaded to the numerical control system 1. Programs stored in the host computer memory 551 enable the computer to communicate with the numerical control system 1 and to manage the library of programs stored in the bulk storage 507.

As will be described in more detail hereinafter, an operator at the numerical control system 1 can call up a particular part program or a particular numerical control software system by generating commands through the keyboard 7. Referring particularly to FIG. 3, a communications package stored in a numerical control system memory 34 couples these commands to the host computer 500, which in turn reads the selected part program or numerical control system software package out of the bulk storage 507 and downloads it to the numerical control system 1. The downloaded program is stored in the memory 34 at a location determined by the communications package. To better understand the nature of a numerical control software system package which can be downloaded from the bulk storage 507 to the memory 34, a description of a preferred numerical control system -- both hardware and software -- will now be made. This preferred numerical control system is sold commercially by the Allen-Bradley Company as the Model 7300 B and it is described in detail in U.S. Pat. No. 4,038,533.

Referring particularly to FIGS. 4a and 4b, the numerical control processor 13 is organized around a sixteen-bit bidirectional processor data bus 30. Data is moved from one element of the processor to another through this data bus 30 in response to the execution of a micro-instruction which is held in a 24-bit micro-instruction register 31. Each such micro-instruction indicates the source of the data to be applied to the data bus 30, the destination of the data, and any operations that are to be performed on that data. The micro-instructions are stored in a micro-program read-only memory 32, and one is read out every 200 nano-seconds through a bus 33 to the micro-instruction register 31. The read-only memory 32 stores a large number of separately addressable, or selectable, micro-routines, each of which is comprised of a set of micro-instructions. To enable the processor 13 to perform a desired function, the appropriate micro-routine is stored in the read-only memory 32 and it is selected for execution by a 16-bit macro-instruction which is stored in a read/write main memory 34.

The main memory 34 is comprised of 4K by 1 dynamic MOS RAMs which are organized to store up to 32,000 16-bit words. Macro-instructions and data are read out of and written into the main memory 34 through a 16-bit memory data register 35 which connects to the processor data bus 30. The memory words are selected, or addressed, through a 15-bit memory address register 36 which also connects to the processor data bus 30. To write into the main memory 34, an address is first loaded into the memory address register 36 by applying a logic high voltage to its clock lead 29. The data to be loaded appears on the processor data bus 30 and is gated through the memory data register by applying a logic high voltage to its data in clock lead 27. A logic high voltage is then applied to a read/write control line 34' on the memory 34 to complete the loading operation. Data or a macro-instruction is read out of an addressed line of the main memory 34 when a READ micro-instruction is executed. A logic low voltage is applied to the read/write control line 34' and a logic high voltage is applied to a data out enable line 28 on the memory data register 35. The data word is momentarily stored in the register 35 and is subsequently transferred through the processor data bus 30 to the desired destination.

In response to the execution of a micro-routine called FETCH, which includes the READ micro-instruction, a macro-instruction is read from the main memory 34 and coupled to a 16-bit macro-instruction register 37 through the data bus 30. The macro-instruction is stored in the register 37 by a logic high voltage which is applied to a macro-instruction register clock line 37'. Certain of the macro-instructions include operation codes which are coupled through an instruction register bus 39 to a macro-decoder circuit 38, and other instructions also include a bit pointer code which is coupled through the same instruction register bus 39 to a bit pointer circuit 40. The bit pointer circuit 40 is a binary decoder having four inputs connected to the least significant digit outputs of the macro-instruction register 37 and having a set of 16 outputs connected to respective leads in the processor data bus 30. In response to the execution of a selected micro-instruction (MASK), a logic high voltage is applied to a terminal 41, and the bit pointer circuit 40 drives a selected one of the sixteen leads in the processor data bus 30 to a logic low voltage. The bit pointer circuit 40 facilitates the execution of certain programmable controller type macro-instructions.

In response to an operation code in a macro-instruction stored in the register 37, one of the micro-routines in the read-only memory 32 is selected. The operation code is applied to the macro-decoder circuit 38 which enables one of four mapper proms 42-45 and addresses a selected line in the enabled mapper prom. Each line of the mapper proms 42-45 stores a twelve-bit micro-routine starting address, which when read out, is coupled through a micro-program address bus 46 to preset a twelve-bit micro-program sequencer 47. The sequencer 47 is a presettable counter which includes a load terminal 52, an increment terminal 53 and a clock terminal 54. The clock terminal 54 is driven by a five-megahertz clock signal which is generated by a processor clock circuit 85 that is coupled to the sequencer 47 through an AND gate 86. Each time a logic high clock pulse is applied to the terminal 54 on the micro-program sequencer 47, it is either preset to an address which appears on the bus 46 or it is incremented one count. Concurrently, the micro-instruction register 31 is clocked through a line 88 and AND gate 88' to read and store the micro-instruction which is addressed by the micro-program sequencer 47. The AND gates 86 and 88 can be disabled in response to selected codes in a micro-instruction to decouple the 5 mHz clock. Such decoupling of the clock 85 from the sequencer 47 occurs, for example, during input and output operations to allow data one micro-second to propagate.

Each micro-second which is read out of the read-only memory 32 to the micro-instruction register 31 is coupled through a micro-instruction bus 31a to a micro-instruction decoder circuit 48 which is also coupled to the clock line 88. The micro-instructions are decoded and executed before the next clock pulse is applied to the terminal 54 on the micro-program sequencer 47. Each micro-instruction is comprised of a plurality of separate codes called micro-orders which are each separately decoded to enable one of the processor elements.

Each micro-routine stored in the micro-program read-only memory 32 is terminated with a special micro-instruction which includes a code, or micro-order, identified hereinafter by the mnemonic EOX or EOXS. When coupled to the micro-instruction decoder circuit 48, this code causes a logic high voltage to be generated on an EOX line 49 to a priority mapper prom 50. If the industrial control processor 13 is in the RUN mode, the starting address of the FETCH micro-routine is read from the priority mapper prom 50 and is applied to the micro-sequencer 47 through the bus 46. The micro-instruction decoder circuit 48 also generates a logic high voltage on a preset line 51 which connects to the load terminal 52 on the micro-program sequencer 47 to preset the sequencer 47 to the starting address of the FETCH micro-routine.

As indicated above, the FETCH micro-routine functions to read the next macro-instruction to be executed from the main memory 34, couple it to the macro-instruction register 37, and initiate the execution of that macro-instruction. The last micro-instruction in the FETCH micro-routine includes a code which is identified hereinafter by the mnemonic MAP. This micro-instruction code causes the micro-instruction decoder circuit 48 to generate a logic high voltage to the macro-decoder circuit 38 through a MAP line 52 and to thereby initiate decoding of the macro-instruction which is stored in the macro-instruction register 37. A logic high voltage is also generated on the preset line 51 to load the micro-program sequencer 47 with the starting address of the micro-routine called for by the decoded macro-instruction.

As shown in FIG. 4b, mathematical and logical operations are performed by the industrial control processor 13 in an arithmetic and logic processor 55 which connects to the processor data bus 30 and to the micro-instruction decoder circuit 48 through a bus 56. Referring particularly to FIG. 5, the arithmetic and logic processor 55 includes a 16-bit "L" register 57 which has inputs that connect to the leads in the processor data bus 30 and a corresponding set of outputs which connect through a bus 58 to the "B" inputs of a 16-bit arithmetic and logic unit (ALU) 59. Data on the bus 30 is clocked into the L register 57 when a logic high is applied to a lead 60 and the L register 57 is cleared when a logic high is applied to a lead 61. The leads 60 and 61 connect to the micro-instruction decoder circuit 48 through the bus 56 and are thus controlled by selected micro-instructions.

The ALU 59 is comprised of four commercially available arithmetic logic units combined with a commercially available full carry look-ahead circuit to perform high speed functions such as add, substract, decrement and straight transfer. The ALU 59 has a set of 16 "A" inputs which connect directly to the leads in the processor data bus 30 and a set of four function-select lines 62 which connect to the micro-instruction decoder circuit 48 through the bus 56. In response to selected micro-instructions, the ALU 59 performs functions on data applied to its A and B inputs and generates the 16-bit results to a shifter circuit 63 through a bus 64.

Also, the ALU 59 generates signals to an ALU decoder 114 which indicate when the result of a logical or arithmetic function is zero, all "ones," odd, negative or when it causes an overflow or a carry. The existence of such a condition is separately tested by micro-orders, or codes in micro-instructions which enable the ALU decoder 114 through the bus 56. The existence of the tested condition results in the generation of a logic high on a skip line 115 which connects to the decoder 48.

The existence of an overflow condition in the ALU 59 can also be stored in an overflow flip-flop 116 when a logic high is applied to its clock terminal through a line 117 by the decoder circuit 48. The Q output on the flip-flop 116 connects to the ALU decoder 114 and its condition can be tested by an appropriate micro-order. A system flag flip-flop 118 connects to the ALU decoder 114 and it can be clocked in response to an appropriate micro-order through a line 119 from the micro-instruction decoder 48. The flag flip-flop 118 may be set in response to one of the tested ALU conditions, and its state, or condition can in turn be tested by an appropriate micro-order acting through the ALU decoder 114.

The shifter circuit 63 is comprised of eight commercially available, dual four-line-to-one-line data selectors having their inputs connected to selected leads in the bus 64. Sixteen outputs on the shifter 63 connect to a 16-lead ALU data bus 65 and a pair of control leads 66 connect it to the micro-instruction decoder circuit 48. In response to selected micro-instructions, the shifter 63 passes the sixteen-bit data word from the ALU 59 directly to the ALU data bus 65, or it shifts or rotates that data one or four bits.

The 16-bit data word on the ALU bus 65 is coupled to a 16-bit "A" register 67, a 16-bit "B" register 68, or a random access memory bank 69. The data is clocked into the A register 67 by applying a logic high voltage to a lead 70 which connects the A register 67 to the micro-instruction decoder circuit 47, or the data is clocked into the B register 68 by applying a logic high voltage to a lead 71 which connects the B register 68 to the micro-instruction decoder circuit 48. The sixteen outputs of the A register 67 connect to the "A" inputs on a 16-bit multiplexer 72 and the 16 outputs on the B register 68 connect to the "B" inputs on the multiplexer 72. Sixteen outputs on the multiplexer 72 connect to the leads in the processor data bus 30, and when a logic high voltage is applied to an enable lead 73 thereon, the contents of either the A register 67 or the B register 68 are coupled to the processor data bus 30. The selection is made through a select lead 74 which, along with the enable lead 73, connect to the micro-instruction decoder circuit 48. In response to the execution of selected micro-instructions, therefore, the A register 67 or the B register 68 may provide the source of data to the processor data bus 30 through the multiplexer 72, or they may be designated by selected micro-instructions as the destination of data on the processor bus 30 which is coupled through the ALU 59 and the shifter circuit 63.

The random access memory 69 is comprised of four commercially available 64-bit (16.times.4) random access memories which are arranged to provide 16 16-bit registers identified hereinafter as the "P" register and the R1-R15 registers. A sixteen-bit data word is written into the random access memory 69 from the ALU data bus 65 when a logic high voltage is applied to a read-write line 75. On the other hand, the contents of one of the 16 registers in the memory 69 are read out through a bus 76 to a 16-bit data latch 77 when the line 75 is at a logic low voltage and the data latch 77 stores this word when a logic high voltage is applied to its clock line 78. The lines 75 and 78 connect to the micro-instruction decoder circuit 48 and both the random access memory 69 and the data latch 77 are thus responsive to selected micro-instructions.

The particular register in the random access memory 69 which is to be accessed is determined by a four-bit address code which is applied to a set of terminals 79. The address terminals 79 are connected to the outputs of a four-bit multiplexer 80 which has a set of "A" inputs connected to receive bits 4-7 of the micro-instruction (source field) and a set of four "B" inputs which are connected to receive bits 9-12 of the micro-instruction (destination field) through the micro-instruction bus 31a. The multiplexer 80 is enabled through a lead 81 which connects to the micro-instruction decoder circuit 48 and the four-bit address on the A or B inputs is selected by the logic signal applied to a lead 82 which connects to receive a 5 mHz "destination" signal from the clock circuit 85. When the random access memory 69 is identified as the source of data, the address of the particular register in the memory 69 from which the data is to be read appears at the A inputs of the multiplexer 80, and when the random access memory 69 is identified as the destination of data, the address of the particular register into which the data is to be written appears on the B inputs.

Data read from the random access memory 69 and stored in the data latch 77 is coupled to the processor data bus 30 by a set of 16 gates 83. The gates 83 are enabled through a lead 84 which connects to, and is controlled by, the micro-instruction decoder circuit 48. For example, the P register in the memory 69 serves as the macro-program counter, and when the FETCH micro-routine is executed, the contents of the P register is read out through the data latch 77 and the gates 83 to the processor data bus 30 where it is coupled to the main memory address register 36.

The arithmetic and logic processor 55 also includes a 10-bit binary transfer counter 141 which has its inputs connected to the ten least significant digit leads in the processor data bus 30. A constant can be loaded into the transfer counter 141 by a micro-order which designates it as the destination of the data and which enables it through an enable lead 142. The same micro-order generates a logic high voltage to a preset terminal through a lead 143. The transfer counter 141 can be incremented through a lead 144 and an output signal is generated on respective leads 156 and 157 when a count of 15 or 1,023 is reached. The leads 142-144, 156 and 157 connect to the micro-instruction decoder 48.

Connected to the processor data bus 30 and the transfer counter 141 is a resident communication program read-only memory 158. The ROM 158 is a 4-bit by 1024 line read-only memory which has its address terminals connected to the counter 141 through a nine-lead bus 159 and its four data output terminals connected to the four least significant leads in the data bus 30. The ROM 158 is enabled to read a four-bit byte of data onto the bus 30 when a logic high voltage is applied to an enable terminal 159 by the micro-instruction decoder 48.

Referring again to FIGS. 3 and 4b, data is coupled to and is received from the I/O interface racks 20 and 21 and the system I/O devices 5, 7, 8, 9 and 10 through an input/output interface circuit 87 which connects to the processor data bus 30. Referring particularly to FIG. 6, the I/O interface circuit 87 includes a set of sixteen data output gates 90 which have inputs connected to the leads in the processor data bus 30 and outputs which connect to a 16-bit input/output data bus 91. An enable line 92 connects a second input on each of the data output gates 90 to the micro-instruction decoder circuit 48, and when driven to a logic high voltage, a 16-bit data word on the processor data bus 30 is coupled to the input/output data bus 91. The input/output data bus 91 connects to the wiring harness 19 and 22 which couple the industrial control processor 13 to the interface racks 20 and 21 and to the respective system I/O devices such as the CRT display 9.

The input/output interface circuit 87 also includes a six-bit input/output address register 93 which connects to the six least significant digit leads in the processor data bus 30. The I/O address register 93 connects to the micro-instruction decoder circuit 48 through a clock lead 94 and when a logic high voltage is generated on the clock lead 94, a six-bit I/O address is clocked into the register 93 from the processor data bus 30. Six output terminals on the register 93 connect to leads in a six-bit I/O address bus 95. The I/O address bus 95 joins the wiring harness 22, and the I/O address stored in the register 93 is thus coupled through the bus 95 to the I/O interface racks 20 and 21. A clear line 96 connects the address register 93 to the micro-instruction decoder circuit 48, and when a logic high voltage is generated thereon, the register 93 is reset to zero. As will be described in more detail hereinafter, when an OTA macro-instruction is executed, the I/O address (rack number and slot number) is loaded into the output address register 93 and is applied to the I/O address bus 95. The addressed device acknowledges receipt of its address and a 16-bit data word may then be applied to the processor data bus 30 and gated onto the input/output data bus 91 to the addressed device.

Data is coupled into the industrial control processor 13 through a 16-bit multiplexer 97 which forms part of the input/output interface circuit of FIG. 6. A set of 16 "B" input terminals on the multiplexer 97 connect to the input/output data bus 91 and a set of 16 output terminals thereon connect to the respective leads in the processor data bus 30. The six least significant digit inputs of a set of 16 "A" inputs on the multiplexer 97 connect to an interrupt address bus 95a. An enable line 98 and a select line 99 on the multiplexer 97 connect to the micro-instruction decoder circuit 48. When a logic high voltage is generated on the enable line 98, the data on either the I/O data bus 91 or the interrupt address bus 95a is coupled to the processor data bus 30. The selection is made by the logic state of the select line 99 which is also controlled by selected micro-instructions through the decoder circuit 48.

Decoding of the I/O address for the system I/O devices 5, 7, 8, 9 and 10 is accomplished in the input/output interface circuit of FIG. 6. The three most significant digit leads of the input/output address bus 95 connect to the respective inputs on three exclusive NOR gates 102-104 and the three least significant digit leads therein connect to the inputs of a BCD decoder 105. A second input on each of the exclusive NOR gates 102-104 connects through respective switches 106-108 to a logic low voltage supply terminal 109 and an output terminal on each of the gates 102-104 connects to respective inputs on an AND gate 110. An output on the AND gate 110 connects to an enable terminal 112 on the BCD decoder 105, and when a logic high voltage is generated thereat, the three-bit binary coded decimal number applied to the inputs of the decoder 105 is decoded. As a result, a logic low voltage is generated at one of eight terminals 113, the five least significant of which connect to the respective system I/O devices 5, 7, 8, 9 and 10 through the wire harness 19. The three switches 106-108 are set to indicate the rack number (which in the preferred embodiment is number 1), and when this number appears on the three most significant digit leads of the I/O address bus 95, one of the system I/O devices is addressed.

The input/output interface circuit 87 of FIG. 6 also includes a timed interrupt circuit 162. The circuit 162 includes an R-S flip-flop 163 having a set terminal connected through a lead 164 to the processor clock circuit 85 (FIG. 4b). Every 10.25 milliseconds a logic high clock pulse is applied to set the flip-flop 163 and a logic high voltage is generated at its Q output terminal and applied to an interrupt request line 160. The interrupt request line connects to a priority encoder circuit 127 (FIG. 4a) as will be described hereinafter, and when the interrupt is granted, a logic high voltage is generated on an interrupt acknowledge line 161. The interrupt acknowledge signal is gated through an AND gate 166 and clocked into a d.c. flip-flop 167 connects through a lead 168 to one input on each of six AND gates 169 and through a lead 170 to an AND gate 171. The outputs of the AND gates 169 connect to the respective leads in the interrupt address bus 95a and their respective second input terminals are connected to logic high and logic low voltage sources in such fashion as to generate the octal address seventeen on the bus 95a when the d.c. flip-flop 167 is set. Thus, every 10.24 milliseconds the circuit 162 generates an interrupt request to the priority encoder 127 and when an acknowledge signal is received it asserts the I/O address seventeen on the interrupt address bus 95a.

Circuits similar to the timed interrupt circuit 162 reside in the keyboard 7, the UAR/T 8 and the tape reader 5. Each of these system I/O devices connect to the interrupt request line 160 and each is connected in "daisy chain" fashion to the interrupt acknowledge line 161. As shown in FIG. 6, the interrupt acknowledge line 161 is coupled through the interrupt circuit 162 by an AND gate 172 which is controlled by the Q output terminal on the R--S flip-flop 163. Thus, when the circuit 162 requests the interrupt, it not only responds to the resulting interrupt acknowledge signal, but it also prevents that signal from being coupled to subsequent system I/O devices in the daisy chain. In this manner, only one interrupting I/O device is serviced at a time. As will be described in more detail hereinafter, when an interrupt is acknowledged by the priority encoder circuit 127, it also initiates the execution of an interrupt service micro-routine which loads the I/O address of the interrupting device into register R4 of the memory 69. This I/O address is then employed to locate the starting address in the main read/write memory 34 of a macro-routine which services that particular system I/O device. For example, the timed interrupt circuit 162 calls up a ten millisecond timed interrupt routine.

It should be apparent from the description thus far that the various elements of the industrial control processor 13 are operated in sequence in response to micro-instructions which are read from the micro-program read-only memory 32 into the micro-instruction register 31 and which are then decoded by the decoder circuit 48. The address of the first micro-instruction in any micro-routine to be executed is loaded into the micro-program sequencer 47 from one of the mapper prom 42-45 or 50 and as the micro-instructions are executed, the micro-program sequencer 47 is incremented one count to read out the next micro-instruction in the micro-routine until an EOX or EOXS code is detected which indicates the end of the micro-routine.

Referring particularly to FIG. 4b, to enable the use of JUMP micro-instructions, and to thus allow one level of micro-subroutine, a 12-bit save register 120 is connected to the outputs of the micro-program sequencer 47 through a bus 121, and a twelve-bit multiplexer 122 is connected to the inputs of the sequencer 47 through the address bus 46. The save register includes a clock lead 123 which connects to the micro-instruction decoder circuit 48, and when selected JUMP micro-instructions are executed, the address stored in the micro-program sequencer 47 is stored in the save register 120. The outputs of the save register 120 connect to a set of 12 "A" inputs on the multiplexer 122, and when a return call micro-instruction is subsequently executed, the address stored in the save register is coupled through the multiplexer 122 and loaded back into the micro-program sequencer 47. The multiplexer 122 also includes a set of "B" inputs which connect to the micro-instruction bus 31a, and when a JUMP micro-instruction is executed, the target address in the instruction is coupled from the micro-instruction register 31 to the micro-program sequencer 47 through the multiplexer 122. The multiplexer 122 is controlled by the data select lead 124 and an enable lead 125, both of which connect to the micro-instruction decoder circuit 48.

Referring to FIG. 4b, the micro-instruction bus 31a also couples to the processor data bus 30 through a set of 16 AND gates 158. One input on each gate 158 connects to a lead in the bus 31a and a second input on each is commonly connected through a lead 159 to the micro-instruction decoder circuit 48. Their outputs connect to the respective leads in the processor data bus 30.

Referring particularly to FIG. 4a, the switches, lights and other control and indicating devices on the processor front panel 26 and the secondary control panel 12 are coupled to the processor data bus 30 by a control panel interface circuit 126. The control panel interface circuit 126 in turn is connected to inputs of a priority encoder 127 through a seventeen-lead bus 128 and five outputs on the priority encoder 127 connect to the priority mapper prom 50 through a bus 129. The control panel interface circuit 126 receives signals from panels 12 and 26 through the cables 15 and 27, and it receives signals through the processor data bus 30. In response, it generates a logic low on one or more of the leads in the cable 128 which determine the mode in which the industrial control processor 13 is to operate.

Referring particularly to FIG. 7, the priority encoder 127 includes a first three-bit binary encoder 130 which has a set of eight inputs, seven of which connect to the bus 128. The eighth input connects to the interrupt request line 160 from the I/O interface circuit 87. An eight-bit data latch 131 also has a set of eight inputs which connect to leads in the bus 128 and its eight output terminals connect to respective inputs on a second three-bit binary encoder circuit 132. Three output terminals 133 on the first binary encoder 130 connect to respective first inputs on three NAND gates 134-136. Similarly, three output terminals 137 on the second encoder 132 connect to respective second inputs on the NAND gates 134-136 and a fourth output terminal 138 on the second encoder 132 connects to an enable terminal 139 on the first binary encoder 130. The fourth output 138, the outputs of the respective NAND gates 134-136 and a seventeenth lead 140 in the bus 128 connect to respective leads in the bus 129 which in turn connects to the priority mapper prom 50. The lea