1. Field of the Invention
The present invention relates to micro-controller integrated circuits including a customizable logic area and a predefined logic area that are accessible via the microprocessor. More particularly, the present invention relates to architecture to implement configurable bus arbitration schemes in multibus systems having customizable master and slave circuits.
2. The Prior Art
Due to the wide variety of available software applications, it is difficult to design a standard microcontroller product that includes all possible modules to efficiently address these applications. The application specific integrated circuit (ASIC) market addresses that need by allowing a user to specify custom modules. The initial development cost of an ASIC remains expensive. A known work-around consists of adding a customizable area of logic to an already predefined microcontroller logic, the customizable area being formed as a field programmable gate array or other logic that can be customized by, for example, modifying the metal interconnect layers. This last solution is a trade-off between the size of the logic, which is smaller than FPGA area for an equivalent function, and a front-end cost including the design of the metal layer and one time customization cost.
In such a prior-art architecture, the predefined logic implements a microcontroller function that cannot be modified but contains access points that connect to the customizable logic area. These access points are generally the system bus of the microcontroller.
Referring now to
The microprocessor 12 executes instructions that can be stored outside the chip by driving the address bus 34 to a value corresponding to the EBI module 14. The address decoder 22 asserts the corresponding selection signal 26. To fetch the instruction, the direction control (read/write) signal of the system bus is asserted for read operation mode. The value can be either logical 1 or 0 depending on the system bus protocol. The EBI module 14 then drives the external memory device to obtain the data required by the microprocessor 12. EBI bus portion 16 is driven by the EBI module 14, and by the address and control signal set. The off-chip memory returns the instruction to be executed on EBI bus portion 18. The EBI module returns the instruction data value on internal system bus 34 and the microprocessor 12 is then ready to execute the instruction.
If the instruction is a write instruction to one of the modules coupled to the system bus 34, the microprocessor 12 performs another similar fetch to obtain the destination address of the peripheral device to which the data must be written. The microprocessor 12 then executes the write instruction to the selected peripheral by asserting on the system address bus a value selecting (for example) the UART module 38. The address decoder 22 deselects the EBI 14 by clearing the associated selection signal 32 and asserts the selection signal 28 corresponding to the UART module 38.
Being selected for a write operation, the UART module 38 writes into its internal registers the value on the write data bus portion of system bus 34. The other modules receive this value but do not take any action because they are not selected. The UART module 38 converts the parallel internal stored data to a bit stream that is clocked out on I/O 40.
The instructions are sequentially executed and perform read or write operations on the system bus. The microprocessor 12 can also be triggered by a peripheral using the interrupt line 50 driven by the interrupt controller 36, which handles the priorities of the interrupt lines 52 and 54 coming from peripheral modules 38 and 42. For example if the expected result from a peripheral is known to have a latency of several tens of clock cycles, it is better to trigger the interrupt line rather than wait for the result by executing some kind of no-operation instruction, especially when several peripherals, such as UARTs and crypto-processors, have a long latency response compared to the clock cycle period.
The customizable logic area 42 can be designed using an FPGA-based architecture. Therefore, this logic will be able to be programmed in the field. The architecture can also be gate-array based. In this case, for the same area, the cell density is much higher than in an FPGA, but the functionality can be defined only once. To obtain the desired function, the metal layers must be designed according to the cells (gates) available on the gate array. In the gate array, the placement of the gates is always the same whatever the functionality.
As a consequence, it is cheaper to design a new micro-controller with this method rather than by generating a full masks reticle for each new circuit. Only the last layers are redesigned and manufacture time is significantly reduced.
The customizable logic area 42 needs to be connected to predefined logic to be accessible by the microprocessor 12. Therefore, the system bus 34 communicates with customizable logic 42. For example, if the system bus 34 selects data using non-tristate cells (i.e. multiplexers using NAND or other gates), these multiplexers will have dedicated inputs that will be driven by circuitry in the customizable logic area 42.
The same idea applies for the address decoder 22. Several signals 30 from the address decoder 22 are already decoded and routed to the customizable logic area 42. This kind of routing is necessary to enable the microprocessor 12 to gain access to the customizable logic area 42.
The present invention defines specific access points to provide more flexibility, especially in the domain of system bus arbitration.
Circuitry may be used to make individual circuits different from one another. Such differentiation circuitry includes circuitry to implement the arbitration algorithm used by the system bus of the microcontroller architecture built in the predefined area. If only one built-in arbitration scheme is available, there is a probability that it will not be efficient for a particular customer application. Therefore, there is a need for adding flexibility to these prior-art schemes.
According to one aspect of the invention, a multi-bus system includes customizable master and slave modules and customizable bus arbitration that may be wholly or partly implemented in the customizable logic area.
In one embodiment of the present invention, a multibus system comprises a customizable logic area having a configured custom master module and a configured custom slave module. This multibus system includes additional user arbitration circuitry disposed in the customizable logic area that uses multiplexers already disposed in a predefined logic area.
In an alternative embodiment of the present invention, a multibus system comprises a customizable logic area having a configured custom master module and a configured custom slave module. This multibus system includes a multiplexer formed in the customizable logic area and the output of a predefined slave arbiter being routed to the mulitplexer in the customizable logic area.
In another alternative embodiment of the present invention, a multibus system comprises a customizable logic area having a configured custom master module and a configured custom slave module. In this multibus system, a configuration is provided where additional arbitration capabilities within the customizable logic area are not required since the user does not want to implement its own slave arbitration algorithm. Accordingly, the customizable logic area does not include a custom user arbitration algorithm. The associated I/O terminals of the customizable logic area are connected together rather than to a multiplexer in the customizable logic area.
Persons of ordinary skill in the art will realize that the following description of the present invention is illustrative only and not in any way limiting. Other embodiments of the invention will readily suggest themselves to such skilled persons.
According to one aspect of the invention, more flexibility is provided for system bus arbitration when several masters are sharing slave modules in microcontroller systems employing a customizable logic area.
In a multi-bus system, data may be transferred between several masters and several slaves. Referring now to
In the exemplary system shown in
Each of slaves 70 and 72 can be accessed by both masters 62 and 66. It is therefore necessary to provide a circuit to arbitrate access requests when two masters simultaneously request access to the same slave. According to the select signals on busses 78 and 80 that the slave arbiters 82 and 84 received on address decode lines 86 and 88, the slave arbiters 82 and 84 provide command signals on lines 90 and 92, respectively. These commands enable selection of system bus 1 (master-162) or system bus 2 (master-266) by means of multiplexers 94 and 96. The address decoders 74 and 76, slave arbiters 82 and 84, and multiplexers 94 and 96 together form a bus matrix 98.
Each slave arbiter 82 and 84 can have a different arbitration algorithm to effectively assign more or less bandwidth for each of masters 62 and 66. This algorithm is hard-coded in the circuitry of each slave arbiter as is known in the art.
To provide more flexibility, a customizable area can be included in the circuitry of multi-system bus architectures. Accordingly, the predefined logic shown in
In the example of
As shown in
In the example shown in
To provide more flexibility in the microcontroller architecture, some user arbitration capabilities must be introduced into the customizable logic area 108 and links to those capabilities must be designed and included in the predefined logic area. Multiplexers may be introduced between the predefined slave arbiters and the bus multiplexers whose outputs are driving the slave modules. The select inputs of these additional multiplexers may be driven by configuration registers that are part of a predefined logic slave (not necessarily the slave whose arbitration must be modified) and are accessible by a predefined master (microprocessor). Alternately, the configuration registers may be formed in the customizable logic area 108.
Referring now to
The third address decoder 110 is added for the third address bus 106 that will be driven by the custom master 102 and is shown located in the predefined circuit area. The third (custom) slave 104, third slave arbiter 114 driven by decoded address lines 118, and third multiplexers 116 are also located in the predefined circuit area.
According to this aspect of the invention, additional arbitration capabilities are provided and are formed in the customizable area 108. A custom user slave arbiter 122 for the first bus is formed in the customizable logic region 108. The output of user slave arbiter 122 is provided to an input of multiplexer 124. The other input of multiplexer 124 is driven by the output of slave arbiter 82. The select input of multiplexer 124 is controlled by the output 126 of a configuration register that may be located in the predefined logic area.
As shown in
The configuration register that drives the select input of multiplexer 124 may also be located in the customizable logic area 108. In this case, the number of terminals at the interface between the customizable logic area 108 and the predefined logic area will increase. If the configuration register that drives the select input of multiplexer 124 is located in the predefined logic area, it will be mandatory to write into the configuration register the value that activates the selection of inputs driven by customizable logic in case the user wants to use the customizable logic area arbiter.
Referring now to
In
As in the circuit of
The configuration register that drives the select input of multiplexer 124 may also be alternatively located in the customizable logic area 108. In this case, the number of terminals at the interface between the customizable logic area 108 and the predefined logic area will increase. As in the circuit of
Referring now to
The present invention provides several advantages over the current solutions. The architecture of the present invention is flexible. In some cases, such as system bus arbitration, it is difficult to make a new function possible simply by redundancy (i.e., duplicate the function and link it to the existing bus system). According to the present invention, the links exist, making it easy to substitute an alternate function.
While embodiments and applications of this invention have been shown and described, it would be apparent to those skilled in the art that many more modifications than mentioned above are possible without departing from the inventive concepts herein. The invention, therefore, is not to be restricted except in the spirit of the appended claims.