JP2005229276A - Programmable logic circuit - Google Patents
Programmable logic circuit Download PDFInfo
- Publication number
- JP2005229276A JP2005229276A JP2004035043A JP2004035043A JP2005229276A JP 2005229276 A JP2005229276 A JP 2005229276A JP 2004035043 A JP2004035043 A JP 2004035043A JP 2004035043 A JP2004035043 A JP 2004035043A JP 2005229276 A JP2005229276 A JP 2005229276A
- Authority
- JP
- Japan
- Prior art keywords
- data
- setting information
- unit
- logic circuit
- signal
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Landscapes
- Logic Circuits (AREA)
Abstract
Description
本発明は、プログラムすることにより所定の論理演算の機能を実現できるプログラマブル論理回路に関するものであり、特に、動的に内部構成を変化させながら処理を行うダイナミックプログラマブル論理回路に関するものである。 The present invention relates to a programmable logic circuit capable of realizing a predetermined logic operation function by programming, and more particularly to a dynamic programmable logic circuit that performs processing while dynamically changing an internal configuration.
従来のプログラマブル論理回路として、特許文献1に記載のものがある。この従来のプログラマブル論理回路は、動的相互接続アレーとラッチ回路とダイナミックロジックコアを用いて、具現化すべき回路を段階的に実行する動的再構成可能なフィールドプログラマブルロジックデバイスである。前記従来のプログラマブル論理回路においては、大規模な論理回路を実現する場合に、複数の前記プログラマブル論理回路を直列に接続して、各レベルの論理処理を順番に実行するようにしている。
There exists a thing of
この場合に、前記従来のプログラマブル論理回路においては、回路レベルを示す回路レベルカウンタと内部レベルを示す内部カウンタを用いて、第1のチップの内部レベルが規定のレベルまで達すると、次のチップを動作させるように制御している。すなわち、前記従来のプログラマブル論理回路においては、チップ単位に回路レベルを分割して具現化している。
しかしながら、従来のプログラマブル論理回路においては、より大規模な論理回路を実現しようとすると、処理並列度を1チップに収まる程度に抑える必要があるため、処理時間が増加するという問題がある。また、従来のプログラマブル論理回路においては、処理時間を短縮するため、単一のチップに含まれるダイナミックロジックモジュールの個数を増加させることで処理並列度を高めると、これに比例して動的相互接続アレーの接続点が増加し必要となる設定情報が増大するため、実装回路面積が増大してしまうという問題がある。 However, in the conventional programmable logic circuit, there is a problem that the processing time increases because it is necessary to suppress the processing parallelism to a single chip in order to realize a larger-scale logic circuit. Also, in conventional programmable logic circuits, in order to shorten the processing time, increasing the number of dynamic logic modules contained in a single chip to increase the processing parallelism, the dynamic interconnection is proportional to this. Since the number of array connection points increases and the necessary setting information increases, there is a problem that the mounting circuit area increases.
本発明は、かかる点に鑑みてなされたものであり、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することを目的とする。 The present invention has been made in view of this point, and an object of the present invention is to provide a low-cost programmable logic circuit having high area efficiency and capable of realizing a large-scale logic circuit at high speed.
請求項1に記載のプログラマブル論理回路は、並列に接続されている複数の単位論理回路と、外部から受け取る入力信号を前記複数の単位論理回路に供給する入力信号制御手段と、前記複数の単位論理回路の出力信号を外部に供給する出力信号制御手段と、を具備し、前記入力信号制御手段は、前記入力信号に基づいて制御信号を前記複数の単位論理回路に与える手段と、インデクス指示信号を受けた時にインデクス情報を前記複数の単位論理回路に与える手段と、を有し、前記複数の単位論理回路の各々が、第1の設定情報のいずれかに基づいて機能の変更が可能であって前記入力信号に所定の論理演算処理を行ってデータを生成する論理演算手段と、第2の設定情報のいずれかに基づいて前記論理演算手段からの前記データの整列と複製と反転処理を行ってデータを生成して前記出力信号として前記出力信号制御手段に与えるデータ処理手段と、前記第1及び第2の設定情報を記憶する記憶手段と、前記制御信号及び前記インデクス情報のいずれかを受けた時に当該制御信号及び当該インデクス情報のいずれかに基づいて前記記憶手段における前記第1及び第2の設定情報の格納位置アドレスの先頭位置を示す先頭位置アドレスを記憶するメモリ制御手段と、を具備し、前記複数の単位論理回路の各々が、前記メモリ制御手段に記憶されている前記先頭位置アドレスに基づいて前記記憶手段から順次に読み出す前記第1及び第2の設定情報のいずれかに基づいて前記論理演算手段と前記データ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行う構成を採る。
The programmable logic circuit according to
この構成によれば、複数の単位論理回路の各々が制御信号及びインデクス指示信号に基づいて記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算回路とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うため、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することができる。 According to this configuration, each of the plurality of unit logic circuits sequentially reads from the storage means based on the control signal and the index instruction signal, and based on the first and second setting information, a part of the logic operation circuit and the data processing means Alternatively, it is possible to provide a low-cost programmable logic circuit having high area efficiency and capable of realizing a large-scale logic circuit at high speed because all functions are sequentially changed and a predetermined sequential circuit is operated. it can.
請求項2に記載のプログラマブル論理回路は、請求項1に記載の発明において、前記論理演算手段が、前記第1の設定情報に基づいて機能の変更が可能であって前記入力信号に所定の論理演算処理を行って前記データを生成するロジックセルを具備する構成を採る。 A programmable logic circuit according to a second aspect of the present invention is the programmable logic circuit according to the first aspect, wherein the logical operation means can change the function based on the first setting information, and the input signal has a predetermined logic. A configuration including a logic cell that performs arithmetic processing to generate the data is employed.
この構成によれば、複数の単位論理回路の各々が制御信号及びインデクス指示信号に基づいて記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算回路とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うため、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することができる。 According to this configuration, each of the plurality of unit logic circuits sequentially reads from the storage means based on the control signal and the index instruction signal, and based on the first and second setting information, a part of the logic operation circuit and the data processing means Alternatively, it is possible to provide a low-cost programmable logic circuit having high area efficiency and capable of realizing a large-scale logic circuit at high speed because all functions are sequentially changed and a predetermined sequential circuit is operated. it can.
請求項3に記載のプログラマブル論理回路は、請求項1又は請求項2に記載の発明において、前記データ処理手段が、前記第2の設定情報に基づいて前記論理演算手段からの前記データの整列と複製と反転処理を行って前記データを生成するクロスコネクトスイッチを具備する構成を採る。 A programmable logic circuit according to a third aspect of the present invention is the programmable logic circuit according to the first or second aspect, wherein the data processing means is arranged to arrange the data from the logical operation means based on the second setting information. A configuration including a cross-connect switch that performs duplication and inversion processing to generate the data is adopted.
この構成によれば、複数の単位論理回路の各々が制御信号及びインデクス指示信号に基づいて記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算回路とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うため、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することができる。 According to this configuration, each of the plurality of unit logic circuits sequentially reads from the storage means based on the control signal and the index instruction signal, and based on the first and second setting information, a part of the logic operation circuit and the data processing means Alternatively, it is possible to provide a low-cost programmable logic circuit having high area efficiency and capable of realizing a large-scale logic circuit at high speed because all functions are sequentially changed and a predetermined sequential circuit is operated. it can.
請求項4に記載のプログラマブル論理回路は、請求項3に記載の発明において、前記データ処理手段が、前記クロスコネクトスイッチからの前記データを保持し前記出力信号として前記出力信号制御手段に与えるフリップフロップを具備する構成を採る。 A programmable logic circuit according to a fourth aspect is the flip-flop according to the third aspect, wherein the data processing means holds the data from the cross-connect switch and supplies the data to the output signal control means as the output signal. The structure which comprises is taken.
この構成によれば、複数の単位論理回路の各々が制御信号及びインデクス指示信号に基づいて記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算回路とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うため、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することができる。 According to this configuration, each of the plurality of unit logic circuits sequentially reads from the storage means based on the control signal and the index instruction signal, and based on the first and second setting information, a part of the logic operation circuit and the data processing means Alternatively, it is possible to provide a low-cost programmable logic circuit having high area efficiency and capable of realizing a large-scale logic circuit at high speed because all functions are sequentially changed and a predetermined sequential circuit is operated. it can.
請求項5に記載のプログラマブル論理回路は、並列に接続されている複数の単位論理回路と、前記複数の単位論理回路における一の前記単位論理回路と当該一の前記単位論理回路に対して物理的配置上で隣接する他の前記単位論理回路とを接続する接続手段と、外部から受け取る入力信号を前記複数の単位論理回路に供給する入力信号制御手段と、前記複数の単位論理回路の出力信号を外部に供給する出力信号制御手段と、を具備し、前記入力信号制御手段は、前記入力信号に基づいて制御信号を前記複数の単位論理回路に与える手段と、インデクス指示信号を受けた時にインデクス情報を前記複数の単位論理回路に与える手段と、を有し、前記複数の単位論理回路の各々が、第1の設定情報のいずれかに基づいて機能の変更が可能であって前記入力信号又は隣接の前記他の単位論理回路からのデータに所定の論理演算処理を行ってデータを生成する論理演算手段と、第2の設定情報のいずれかに基づいて前記論理演算手段からの前記データの整列と複製と反転処理を行ってデータを生成して前記出力信号として前記出力信号制御手段に与えるデータ処理手段と、前記第1及び第2の設定情報を記憶する記憶手段と、前記制御信号及び前記インデクス情報のいずれかを受けた時に当該制御信号及び当該インデクス情報のいずれかに基づいて前記記憶手段における前記第1及び第2の設定情報の格納位置アドレスの先頭位置を示す先頭位置アドレスを記憶するメモリ制御手段と、を具備し、前記複数の単位論理回路の各々が、前記メモリ制御手段に記憶されている前記先頭位置アドレスに基づいて前記記憶手段から順次に読み出す前記第1及び第2の設定情報のいずれかに基づいて前記論理演算手段と前記データ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行う構成を採る。 The programmable logic circuit according to claim 5 is physically connected to a plurality of unit logic circuits connected in parallel, one unit logic circuit in the plurality of unit logic circuits, and the one unit logic circuit. Connection means for connecting the other unit logic circuits adjacent to each other in arrangement, input signal control means for supplying an input signal received from the outside to the plurality of unit logic circuits, and output signals of the plurality of unit logic circuits. Output signal control means for supplying to the outside, and the input signal control means is means for providing a control signal to the plurality of unit logic circuits based on the input signal, and index information when receiving an index instruction signal. For each of the plurality of unit logic circuits, the function of each of the plurality of unit logic circuits being changeable based on any one of the first setting information, A logical operation means for generating data by performing a predetermined logical operation process on the input signal or data from the other unit logic circuit adjacent thereto, and from the logical operation means based on either of the second setting information Data processing means for performing data alignment, duplication, and inversion processing to generate data and giving the output signal to the output signal control means; storage means for storing the first and second setting information; and A leading position indicating the leading position of the storage position address of the first and second setting information in the storage unit based on either the control signal or the index information when receiving either the control signal or the index information Memory control means for storing an address, wherein each of the plurality of unit logic circuits stores the head position address stored in the memory control means. In accordance with one of the first and second setting information sequentially read out from the storage means based on the data, a part or all of the functions of the logical operation means and the data processing means are sequentially changed in a predetermined order. A configuration for operating the circuit is adopted.
この構成によれば、複数の単位論理回路の各々が制御信号及びインデクス指示信号に基づいて記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算回路とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うため、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することができる。 According to this configuration, each of the plurality of unit logic circuits sequentially reads from the storage means based on the control signal and the index instruction signal, and based on the first and second setting information, a part of the logic operation circuit and the data processing means Alternatively, it is possible to provide a low-cost programmable logic circuit having high area efficiency and capable of realizing a large-scale logic circuit at high speed because all functions are sequentially changed and a predetermined sequential circuit is operated. it can.
請求項6に記載のプログラマブル論理回路は、請求項5に記載の発明において、前記論理演算手段が、前記第1の設定情報に基づいて機能の変更が可能であって前記入力信号又は隣接の前記他の単位論理回路からの前記データに所定の論理演算処理を行って前記データを生成するロジックセルを具備する構成を採る。 A programmable logic circuit according to a sixth aspect is the programmable logic circuit according to the fifth aspect, wherein the logical operation means can change the function based on the first setting information, and the input signal or the adjacent one A configuration is adopted in which a logic cell that generates predetermined data by performing predetermined logical operation processing on the data from another unit logic circuit is adopted.
この構成によれば、複数の単位論理回路の各々が制御信号及びインデクス指示信号に基づいて記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算回路とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うため、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することができる。 According to this configuration, each of the plurality of unit logic circuits sequentially reads from the storage means based on the control signal and the index instruction signal, and based on the first and second setting information, a part of the logic operation circuit and the data processing means Alternatively, it is possible to provide a low-cost programmable logic circuit having high area efficiency and capable of realizing a large-scale logic circuit at high speed because all functions are sequentially changed and a predetermined sequential circuit is operated. it can.
請求項7に記載のプログラマブル論理回路は、請求項5又は請求項6に記載の発明において、前記データ処理手段が、前記第2の設定情報に基づいて前記論理演算手段からの前記データの整列と複製と反転処理を行って前記データを生成するクロスコネクトスイッチを具備する構成を採る。 A programmable logic circuit according to a seventh aspect is the programmable logic circuit according to the fifth or sixth aspect, wherein the data processing means is arranged to arrange the data from the logical operation means based on the second setting information. A configuration including a cross-connect switch that performs duplication and inversion processing to generate the data is adopted.
この構成によれば、複数の単位論理回路の各々が制御信号及びインデクス指示信号に基づいて記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算回路とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うため、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することができる。 According to this configuration, each of the plurality of unit logic circuits sequentially reads from the storage means based on the control signal and the index instruction signal, and based on the first and second setting information, a part of the logic operation circuit and the data processing means Alternatively, it is possible to provide a low-cost programmable logic circuit having high area efficiency and capable of realizing a large-scale logic circuit at high speed because all functions are sequentially changed and a predetermined sequential circuit is operated. it can.
請求項8に記載のプログラマブル論理回路は、請求項7に記載の発明において、前記データ処理手段が、前記クロスコネクトスイッチからの前記データを保持し前記出力信号として前記出力信号制御手段に与えるフリップフロップを具備する構成を採る。 The programmable logic circuit according to claim 8 is the flip-flop according to the invention according to claim 7, wherein the data processing means holds the data from the cross-connect switch and supplies the data to the output signal control means as the output signal. The structure which comprises is taken.
この構成によれば、複数の単位論理回路の各々が制御信号及びインデクス指示信号に基づいて記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算回路とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うため、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することができる。 According to this configuration, each of the plurality of unit logic circuits sequentially reads from the storage means based on the control signal and the index instruction signal, and based on the first and second setting information, a part of the logic operation circuit and the data processing means Alternatively, it is possible to provide a low-cost programmable logic circuit having high area efficiency and capable of realizing a large-scale logic circuit at high speed because all functions are sequentially changed and a predetermined sequential circuit is operated. it can.
以上説明したように、本発明によれば、複数の単位論理回路の各々が、制御信号及びインデクス指示信号に基づいて記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算手段とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うため、高い面積効率を有し、大規模な論理回路を高速に実現可能である低価格のプログラマブル論理回路を提供することができる。 As described above, according to the present invention, each of the plurality of unit logic circuits is logically operated based on the first and second setting information sequentially read from the storage means based on the control signal and the index instruction signal. And a part of or all of the functions of the data processing means are sequentially changed to perform the operation of a predetermined sequential circuit, so that it has high area efficiency and can realize a large-scale logic circuit at high speed at low cost. A logic circuit can be provided.
本発明の骨子は、複数の単位論理回路の各々が、記憶手段から順次に読み出す第1及び第2の設定情報に基づいて論理演算手段とデータ処理手段の一部又は全ての機能を順次に変更して所定の順序回路の動作を行うことである。 The essence of the present invention is that a part or all of the functions of the logic operation means and the data processing means are sequentially changed based on the first and second setting information that each of the plurality of unit logic circuits sequentially reads from the storage means. Thus, the operation of a predetermined sequential circuit is performed.
以下、本発明の実施の形態について、図面を参照して詳細に説明する。 Hereinafter, embodiments of the present invention will be described in detail with reference to the drawings.
(一実施の形態)
図1は、本発明の一実施の形態に係るプログラマブル論理回路の構成を示すブロック図である。
(One embodiment)
FIG. 1 is a block diagram showing a configuration of a programmable logic circuit according to an embodiment of the present invention.
図1に示すように、本発明の一実施の形態に係るプログラマブル論理回路100は、複数のプロセッサエレメント101、複数のメモリ装置102、入出力制御部103、制御バス104、入力バス105及び出力バス106を具備している。プログラマブル論理回路100には、クロック生成回路107及びユーザー回路108が接続されている。
As shown in FIG. 1, a
複数のプロセッサエレメント101と複数のメモリ装置102とは、1対1で接続されている。1対1で接続されているプロセッサエレメント101とメモリ装置102とは、単位論理回路を構成している。複数の単位論理回路は、並列に接続されている。
The plurality of
複数のプロセッサエレメント101の各々は、1次元的に1列状に配置されており、物理配置上で隣接する2つの他のプロセッサエレメント101と接続線101aで接続されている。すなわち、複数の単位論理回路は、1次元的に1列状に配置されており、複数の単位論理回路における一の前記単位論理回路と当該一の前記単位論理回路に対して物理的配置上で隣接する他の前記単位論理回路とは、接続線101aで接続されている。
Each of the plurality of
プロセッサエレメント101は、接続線を用いて隣接する2つの他のプロセッサエレメント101との間でデータの受け渡しを行う。
The
入出力制御部103は、外部とのインターフェース回路となっており、ユーザー回路108と接続されている。入出力制御部103は、ユーザー回路108から入力信号1081及びインデクス指示信号1082を受ける。制御バス104は、入出力制御部103及びプロセッサエレメント101と接続されている。制御バス104は、初期化及び起動等の制御信号を入出力制御部103から受け取り、各プロセッサエレメント101に転送する。入力バス105は、入出力制御部103及びプロセッサエレメント101と接続されている。入力バス105は、論理演算に用いるデータを入出力制御部103から受け取り、各プロセッサエレメント101に転送する。
The input /
出力バス106は、入出力制御部103及びプロセッサエレメント101と接続されている。出力バス106は、演算結果のデータをプロセッサエレメント101から受け取り、入出力制御部103に転送する。クロック生成回路107は、内部クロック信号109及びユーザークロック信号110を生成する。ユーザークロック信号110は、ユーザー回路108及び入出力制御部103で使用される。内部クロック信号109は、ユーザークロック信号110の逓倍の周波数となっており、プログラマブル論理回路100の内部で使用される。インデクスバス111は、入出力制御部103及びプロセッサエレメント101と接続されている。
The
次に、本プログラマブル論理回路100の機能に関して、図面を参照して説明する。
Next, functions of the
図1において、プログラマブル論理回路100が行う論理演算処理の内容は、メモリ装置102に設定情報として保持されている。各プロセッサエレメント101は、メモリ装置102の設定情報を順次に読み出して、対応する論理演算処理を行う。プログラマブル論理回路100は、ユーザー回路108からユーザークロック信号110に同期して起動信号及び論理演算に用いるデータを受ける。これから一定時間経過後に、プログラマブル論理回路100は、論理演算処理後のデータをユーザー回路108にユーザークロック信号110に同期して与える。
In FIG. 1, the contents of the logical operation processing performed by the
次に、プログラマブル論理回路100の内部ブロックの機能に関して、図面を参照して説明する。
Next, functions of internal blocks of the
図1において、各メモリ装置102には、隣接のプロセッサエレメント101の設定情報が格納されている。メモリ装置102は、プロセッサエレメント101から制御信号とメモリアドレスが入力されると、アドレスで指定された設定情報をプロセッサエレメント101に与える。プロセッサエレメント101は、この設定情報に基づいて、実行する処理内容を決定する。
In FIG. 1, each
プロセッサエレメント101は、制御バス104から初期化信号が入力されると、メモリ装置102の特定のアドレスを読み出し、入力される読み出しデータから設定情報の格納位置アドレスを抽出して保持する。この格納位置アドレスは、設定情報の先頭位置を示すアドレスである。
When an initialization signal is input from the
また、プロセッサエレメント101は、制御バス104から起動信号が入力されると、メモリ装置102の前記保持した格納位置アドレスから順次に設定情報を読み出す。さらに、プロセッサエレメント101は、入力バス105及び隣接のプロセッサエレメント101から論理処理用のデータを受け取り、設定情報に基づいてデータの論理処理を行った後にデータの整列、複製及び反転処理を行い、かつ、処理後のデータの保持を行う。また、プロセッサエレメント101は、保持した処理後のデータを出力バス106及び隣接のプロセッサエレメント101に出力する。
Further, when an activation signal is input from the
このようにして、複数のプロセッサエレメント101は、データの受け渡しを行う。入出力制御部103は、ユーザー回路108からユーザークロック信号110に同期した起動信号及び論理処理用データを受け取り、このデータを内部クロック信号109に同期させて入力バス105に与える。また、入出力制御部103は、ユーザー回路108からユーザークロック信号110に同期した初期化信号を受け取り、このデータを内部クロック信号109に同期させて入力バス105に出力する。また、入出力制御部103は、出力バス106から内部クロック信号109に同期した論理処理後のデータを受け取り、このデータをユーザークロック信号110に同期させてユーザー回路108に出力する。このようにして、入出力制御部103は、ユーザー回路108との制御信号、論理処理用及び処理結果のデータの受け渡しを行う。
In this way, the plurality of
次に、プログラマブル論理回路100の内部のプロセッサエレメント101の構成について、図面を参照して説明する。
Next, the configuration of the
図2は、プロセッサエレメント101の構成を示している。図2に示すように、プロセッサエレメント101は、ロジックエレメント200及びメモリ制御部201を具備している。プロセッサエレメント101は、メモリ装置102、制御バス104、入力バス105及び出力バス106と接続されている。メモリ制御部201は、メモリ装置102、ロジックエレメント200及び制御バス104と接続されている。ロジックエレメント200は、隣接のプロセッサセレメント101のロジックエレメント200及びメモリ制御部201、入力バス105及び出力バス106と接続されている。
FIG. 2 shows the configuration of the
次に、プロセッサエレメント101の機能について、図面を参照して説明する。図2において、メモリ制御部201は、制御バス104から初期化信号を受けると、前述した格納位置アドレスの抽出及び保持の処理を行う。メモリ制御部201は、制御バス104から起動信号が入力されると、メモリ装置102の前記保持した格納位置アドレスから順次に設定情報を読み出し、一時的に記憶してロジックエレメント200に転送する。
Next, functions of the
ロジックエレメント200は、入力バス105及び隣接のプロセッサエレメント101からデータを受け取り、メモリ制御部201から転送される設定情報に基づいてデータの論理処理を行った後にデータの整列、複製及び反転処理を行い、かつ、処理後のデータの保持を行う。また、ロジックエレメント200は、メモリ制御部201から転送される設定情報に基づいて、出力バス106及び隣接のプロセッサエレメント101に処理後のデータを出力する。
The
次に、プロセッサエレメント101の内部のロジックエレメント200の構成及び設定情報の構成について、図面を参照して説明する。
Next, the configuration of the
図3には、ロジックエレメント200の構成が示されている。図4には、設定情報とメモリ装置102の構成が示されている。
FIG. 3 shows the configuration of the
図3において、ロジックエレメント200は、ロジックセル(論理演算回路)300、クロスコネクトスイッチ(データ処理装置)301及びフリップフロップ302を具備している。ロジックエレメント200は、メモリ制御部201、入力バス105及び出力バス106と接続されている。ロジックセル300は、メモリ制御部201、フリップフロップ302及びクロスコネクトスイッチ301と接続されている。クロスコネクトスイッチ301は、メモリ制御部201、ロジックセル300、フリップフロップ302、入力バス105及び隣接のロジックエレメント200の内部のロジックセル300と接続されている。フリップフロップ302は、ロジックセル300、クロスコネクトスイッチ301及び出力バス106と接続されている。
In FIG. 3, the
なお、ロジックセル300は、論理演算回路を構成している。また、クロスコネクトスイッチ301は、データ処理装置を構成している。また、クロスコネクトスイッチ301及びフリップフロップ302は、データ処理装置を構成している。
The
図4は、メモリ装置の構成を示している。図4において、メモリ装置102の内部の先頭部分には、設定情報の格納アドレス情報が格納されている。メモリ装置102の内部における先頭部分以外の特定領域には、設定情報が格納されている。
FIG. 4 shows the configuration of the memory device. In FIG. 4, the storage address information of the setting information is stored at the top portion inside the
図4において、ビット25〜28はロジックセル300の設定情報であり、ビット0〜24はクロスコネクトスイッチ301の接続情報である。ビット0〜24は、5ビット単位にクロスコネクトスイッチ301の5つの出力に対応する4ビットの接続情報及び1ビットの反転制御情報から構成されている。
In FIG. 4,
次に、ロジックエレメント200の機能について、図面を参照して説明する。図3において、ロジックセル300は、フリップフロップ302から入力されるデータに対し、メモリ制御部201から転送される設定情報によって指定される特定の論理処理を行い、クロスコネクトスイッチ301、隣接のプロセッサエレメント101のロジックエレメント200へ処理後のデータを出力する。クロスコネクトスイッチ301は、ロジックセル300、入力バス105、隣接のプロセッサエレメント101のロジックエレメント200から入力されるデータに対し、メモリ制御部201から転送される設定情報によって指定される特定のデータの整列、複製及び反転処理を行い、フリップフロップ302へ処理後のデータを出力する。フリップフロップ302は、クロスコネクトスイッチ301から入力されるデータを、内部クロック信号109のタイミングで保持する。フリップフロップ302は、保持したデータをロジックセル300及び出力バス106に出力する。
Next, the function of the
次に、ロジックセル300の機能及び動作について、具体例を用いて説明する。
Next, functions and operations of the
図5において、ロジックセル300に対し設定情報の2ビット及び入力データの2ビットが入力され、ロジックセル300は出力データの1ビットを出力している。図6は、この場合のロジックセル300の機能及び動作の例を示している。図6において、設定情報が00である時には、ロジックセル300は入力データの論理和(OR)を出力する。設定情報が01である時には、ロジックセル300は入力データの論理積(AND)を出力する。設定情報が10である時には、ロジックセル300は入力データの排他的論理和(XOR)を出力する。設定情報が11である時には、ロジックセル300は入力データの論理和の反転データ(NOR)を出力する。このように、ロジックセル300は、設定情報に基づいて、異なる複数の論理機能を実現可能な回路である。
In FIG. 5, 2 bits of setting information and 2 bits of input data are input to the
次に、クロスコネクトスイッチ301の機能について、具体例を用いて説明する。
Next, the function of the
図7には、クロスコネクトスイッチ301の内部ブロック及び機能の例が示されている。図7において、クロスコネクトスイッチ301の内部の相互接続部700に対し設定情報の4ビット並びに入力データA、B、Cの3ビット及びロウレベルが入力され、相互接続部700から出力データOUT1、OUT2の2ビットが出力されている。さらに、相互接続部700の各出力データは、設定情報の1ビットと排他的論理和(XOR)がとられ、外部に出力される。このXORは、クロスコネクトスイッチ301からの出力データを設定情報に基づいてビット単位に反転するためのものである。この場合、出力数は2であるのでXOR部分に2ビットの設定情報が使用されるため、クロスコネクトスイッチ301の全体で使用する設定情報は合計6ビットとなる。
FIG. 7 shows an example of internal blocks and functions of the
図8は、この場合の相互接続部700の機能例を示している。図8において、相互接続部700は、設定情報のMSBの2ビットがOUT1に出力されるデータを選択し、LSBの2ビットがOUT2に出力されるデータを選択している。相互接続部700は、設定情報が00である時には入力データAを出力し、設定情報が01である時には入力データBを出力する。相互接続部700は、設定情報が10である時には入力データCを出力し、設定情報が11である時にはロウレベルを出力する。
FIG. 8 shows an example of the function of the
このように、クロスコネクトスイッチ301は、設定情報に基づいて複数の入力データの整列、複製及び反転処理が可能であり、また、設定情報に設定された固定値を出力することも可能な回路である。
As described above, the
次に、プログラマブル論理回路100の動作について、図面を参照して説明する。図9及び図10には、プログラマブル論理回路100の動作タイミングの例が示されている。図9には、外部からの初期化の動作が表されている。図10には、外部からの起動及び実際の論理処理の動作が表されている。
Next, the operation of the
まず、T1期間において、入出力制御部103は、ユーザー回路108からユーザークロック信号110に同期した初期化信号900を受けて内部初期化信号901として保持する。T2期間において、入出力制御部103は、保持した内部初期化信号901を内部クロック信号109に同期させて制御バス104に出力する。制御バス104の内部初期化信号902は、すべてのプロセッサエレメント101のメモリ制御部201に入力される。
First, in the T1 period, the input /
T3期間において、プロセッサエレメント101のメモリ制御部201は、入力された内部初期化信号902をトリガにして、メモリ装置102の特定のアドレス904に対し、読み出し信号903を出力する。その後、メモリ制御部201は、入力される読み出しデータ905を保持データ906として一度保持し、この保持データ906から設定情報の格納位置アドレス907を抽出して保持する。T1〜T3の動作により、設定情報の格納位置アドレス907が各プロセッサエレメント101に記憶され、いつでも処理を実行できる状態となる。
In the T3 period, the
T4期間において、プログラマブル論理回路100は、起動待ち状態である。T5期間において、入出力制御部103は、ユーザー回路108からユーザークロック信号110に同期した起動信号1000及び内部処理用データ1001を受け取って内部起動信号1002及び内部処理用データ1003として保持する。T6期間において、入出力制御部103は、保持した内部起動信号1002を内部クロック信号109に同期させて制御バス104に出力する。また、入出力制御部103は、保持した内部処理用データ1003を内部クロック信号109に同期させて入力バス105に出力する。
In the period T4, the
制御バス104の内部起動信号1004は、すべてのプロセッサエレメント101のメモリ制御部201に入力される。入力バス105の論理処理用データ1005は、すべてのプロセッサエレメント101のロジックエレメント200に入力される。T7期間において、各プロセッサエレメント101のメモリ制御部201は、入力された内部起動信号1004をトリガにして、メモリ装置102のT3期間において保持した格納位置アドレス1007に対し読み出し信号903を出力する。T8期間において、各メモリ制御部201は、メモリ装置102から出力される読み出しデータ905を保持データ906として保持する。同時に、メモリ制御部201は、メモリ装置102の次のアドレスに対し、読み出し信号903を出力する。
The internal activation signal 1004 of the
T9期間において、各メモリ制御部201は、保持データ906をロジックエレメント200に出力する。また、各メモリ制御部201は、メモリ装置102から出力される読み出しデータ905を保持する。同時に、各メモリ制御部201は、メモリ装置102の次のアドレスに対し、読み出し信号を出力する。各ロジックエレメント200は、入力される保持データ(設定情報)906に基づいて、入力バス105からの論理処理用データ1005の整列、複製及び反転処理を行い、処理後のデータを内部のフリップフロップ302に保持する。
In the T9 period, each
T10期間において、各メモリ制御部201は、保持データ906をロジックエレメント200に出力する。また、各メモリ制御部201は、メモリ装置102から出力される読み出しデータ905を内部に保持する。同時に、各メモリ制御部201は、メモリ装置102の次のアドレスに対して読み出し信号を出力する。
In the T10 period, each
各ロジックエレメント200は、フリップフロップ302、入力バス105及び隣接のプロセッサエレメント101からの論理処理用データ1005を、入力される保持データ(設定情報)906に基づいて論理処理を行って、処理後のデータをフリップフロップ302に保持する。以下、T10期間の処理を繰り返すことにより、一つの論理処理を実現する。
Each
すべての期間において、フリップフロップ302のデータは、出力バス106に出力されており、入出力制御部103は、このデータを常に内部クロック信号109に同期して保持している。入出力制御部103は、保持データをユーザークロック信号110に同期してユーザー回路108に出力する。ユーザー回路108は、入力されるデータのフラグを参照し、出力データ(論理処理後のデータ)を保持する、又は、決められた期間後のデータを保持する。
In all periods, the data of the flip-
次に、特定の論理処理機能をプログラマブル論理回路100にマッピングした例を、図面を参照して説明する。説明を簡潔に行うため、動作例で示したT9、T10期間のロジックエレメント200の動作のみを説明する。
Next, an example in which a specific logic processing function is mapped to the
図11は、2入力2出力のロジックセル300の機能を示している。図12は、ロジックセル300を持つプログラマブル論理回路100に対して、4ビットの比較回路をマッピングした場合の例を示している。図12において、縦方向には物理的に異なる4つのプロセッサエレメント101が示されており、横方向には同一のプロセッサエレメント101が各サイクルでどのような処理を行うかが示されている。
FIG. 11 shows the function of the
図13は、4ビットの比較回路を示している。図13に示すように、入力データとして、IN0〜7の8ビットデータがあり、IN0〜3とIN4〜7の比較結果が1ビットのデータとして出力される。 FIG. 13 shows a 4-bit comparison circuit. As shown in FIG. 13, there are 8-bit data of IN0 to IN7 as input data, and the comparison result of IN0 to 3 and IN4 to 7 is output as 1-bit data.
図12において、ロジックセル(LC)300の入力及び出力は、上側がLSBであり、下側がMSBである。また、ロジックセル(LC)300の下部に記載されているデータは、ロジックセル(LC)300に対する設定情報である。複数のロジックセル(LC)300は、図13に示すように動作する。まず、サイクル1及び2において、複数のロジックセル(LC)300は入力データをビット単位に整列する。サイクル3において、複数のロジックセル(LC)300は各ビットに対してXNORの処理を行う。サイクル4において、複数のロジックセル(LC)300はサイクル3の結果に対してAND処理を行う。サイクル5において、複数のロジックセル(LC)300はサイクル4の結果に対してAND処理を行う。サイクル6において、複数のロジックセル(LC)300は比較結果を出力する。結果として、内部クロック信号109の6サイクルで出力が確定される。内部クロック信号109のクロック数がユーザークロック信号110のクロック数の6倍である時に、ユーザー回路108からは、1クロックで比較処理が完了したように見える。
In FIG. 12, the input and output of the logic cell (LC) 300 are LSB on the upper side and MSB on the lower side. The data described in the lower part of the logic cell (LC) 300 is setting information for the logic cell (LC) 300. The plurality of logic cells (LC) 300 operate as shown in FIG. First, in
次に、入出力制御部103がユーザー回路108からインデクス指示信号1082を受けた時における動作について、図面を参照して説明する。
Next, the operation when the input /
図1に示すように、ユーザーは、ユーザー回路108を操作することにより、第1及び第2の設定情報のうちの所望のものを優先的に指定するためのインデクス指示信号をユーザー回路108に生成させることができる。ユーザー回路108は、インデクス指示信号1082を入出力制御部103に与える。
As shown in FIG. 1, the user operates the
図2及び図3に示すように、入出力制御部103は、インデクス指示信号1082を受けた時にこのインデクス指示信号1082に応じたインデクス情報を生成してインデクスバス111を介してプロセッサエレメント101のメモリ制御部201に与える。
As shown in FIGS. 2 and 3, the input /
メモリ制御部201は、インデクス情報を受けた時にインデクス情報に基づいてメモリ装置102の特定のアドレスを読み出し、設定情報の格納位置アドレスの先頭位置を示す先頭位置アドレスを抽出して記憶する。
When receiving the index information, the
ロジックエレメント200は、入出力制御部103からデータ及び制御信号を受けると、メモリ制御部201に記憶されている設定情報の格納位置アドレスの先頭位置を示す先頭位置アドレスに基づいて、前述のように、メモリ装置102から順次に読み出す設定情報のいずれかに基づいてロジックセル300とクロスコネクトスイッチ301の一部又は全ての機能を順次に変更して所定の順序回路の動作を行う。
When receiving the data and control signal from the input /
このように、プログラマブル論理回路100は、単体動作を行うプロセッサエレメント101の集合体であり、各プロセッサエレメント101は、主に隣接のプロセッサエレメント101との間で連帯動作を行う。また、複数の隣接のプロセッサエレメント101が一つのグループとして、一つの論理処理を行うことも可能である。
As described above, the
以上説明したように、本発明の一実施の形態に係るプログラマブル論理回路100は、複数のプロセッサエレメント101が独立に動作することも連帯動作することも可能であり、複数種類の論理処理を同時に並列的に行うことが可能であり、かつ、一つの論理処理を連帯して行うことも可能となっている。
As described above, the
また、本発明の一実施の形態に係るプログラマブル論理回路100は、同一のエレメントが1次元的に1列状に配列されているため、実装規模に応じて柔軟に対応可能であり、拡張性が高い。また、本発明の一実施の形態に係るプログラマブル論理回路100は、データの送受を隣接のプロセッサエレメント101の間に限定することにより、設定情報を大幅に削減することが可能となり、回路面積を削減でき、かつ、実装するLSIのコスト及び消費電力を削減できる。
In addition, the
また、本発明の一実施の形態に係るプログラマブル論理回路100は、実装エレメント数に関係なく、任意のプロセッサエレメント101のフリップフロップから隣接する他のプロセッサエレメント101のフリップフロップまでの配線距離が最小限かつ一定であるため、動作周波数を限界にまで引き上げることが可能となり、従来のプログラマブルロジックに比して、高速動作が可能となっている。
In addition, the
また、本発明の一実施の形態に係るプログラマブル論理回路100は、同一の回路上で、繰り返し機能を変更しながら処理を行うため、回路面積を削減でき、かつ、実装するLSIのコスト及び消費電力を削減できる。
In addition, since the
なお、本発明の一実施の形態において、内部クロック信号109は、必ずしもユーザークロック信号110の逓倍である必要がなく、例えば、入出力制御部103に適切なクロック乗せ換え回路を用いることで、ユーザークロック信号110に同期しないクロック信号を内部クロック信号として用いてもよい。
In the embodiment of the present invention, the
また、本発明の一実施の形態において、メモリ装置102は、プログラマブル論理回路100の内部に存在する必要がなく、プログラマブル論理回路100の外部に存在する構成でもよい。また、本発明の実施の形態1において、クロック生成回路107は、プログラマブル論理回路100の内部に配設してもよい。
In one embodiment of the present invention, the
また、本発明の一実施の形態において、メモリ装置102とプロセッサエレメント101との間にマルチプレクサなどの選択回路を挿入して、設定によりメモリ装置102と各プロセッサエレメント101との接続を変更可能にしてもよい。ただし、この場合にはデータの処理の遅延量が増加するため、周波数を維持するためには、パイプライン等を用いて高速化を図る必要がある。
In one embodiment of the present invention, a selection circuit such as a multiplexer is inserted between the
また、本発明の一実施の形態において、図3に示すロジックエレメント200の内部の各ブロック、ロジックセル300、クロスコネクトスイッチ301及びフリップフロップ302の間の接続及び前記各ブロックと入力バス105、出力バス106及び隣接のロジックエレメント200との接続は、図3のものに限定されるものではなく、例えば、ロジックセル300とクロスコネクトスイッチ301の間にフリップフロップを設けて、さらに動作周波数を高めてもよい。また、本発明の実施の形態1において、入力バス105からのデータはクロスコネクトスイッチ301ではなく、ロジックセル300又はフリップフロップ302に入力してもよい。
Further, in one embodiment of the present invention, each block inside the
また、本発明の一実施の形態において、複数のプロセッサエレメント101の各々は、他のプロセッサエレメント101に接続されていなくてもよい。
In one embodiment of the present invention, each of the plurality of
本発明は、電子装置を制御する制御装置などに適用することができる。 The present invention can be applied to a control device for controlling an electronic device.
100 プログラマブル論理回路
101 プロセッサエレメント
101a 接続線
102 メモリ装置
103 入出力制御部
104 制御バス
105 入力バス
106 出力バス
111 インデクスバス
200 ロジックエレメント
201 メモリ制御部
300 ロジックセル
301 クロスコネクトスイッチ
302 フリップフロップ
DESCRIPTION OF
Claims (8)
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2004035043A JP3837136B2 (en) | 2004-02-12 | 2004-02-12 | Programmable logic circuit |
US10/589,078 US7365566B2 (en) | 2004-02-12 | 2005-02-08 | Programmable logic circuit |
PCT/JP2005/001837 WO2005078933A1 (en) | 2004-02-12 | 2005-02-08 | Programmable logic circuit |
KR1020067016161A KR100840030B1 (en) | 2004-02-12 | 2005-02-08 | Programmable logic circuit |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2004035043A JP3837136B2 (en) | 2004-02-12 | 2004-02-12 | Programmable logic circuit |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2005229276A true JP2005229276A (en) | 2005-08-25 |
JP3837136B2 JP3837136B2 (en) | 2006-10-25 |
Family
ID=35003658
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2004035043A Expired - Fee Related JP3837136B2 (en) | 2004-02-12 | 2004-02-12 | Programmable logic circuit |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP3837136B2 (en) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2008066875A (en) * | 2006-09-05 | 2008-03-21 | Fuji Xerox Co Ltd | Data processing unit |
JP2010251925A (en) * | 2009-04-13 | 2010-11-04 | Canon Inc | Data processing apparatus and method for controlling the same |
-
2004
- 2004-02-12 JP JP2004035043A patent/JP3837136B2/en not_active Expired - Fee Related
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2008066875A (en) * | 2006-09-05 | 2008-03-21 | Fuji Xerox Co Ltd | Data processing unit |
JP2010251925A (en) * | 2009-04-13 | 2010-11-04 | Canon Inc | Data processing apparatus and method for controlling the same |
Also Published As
Publication number | Publication date |
---|---|
JP3837136B2 (en) | 2006-10-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP4971998B2 (en) | Semiconductor integrated circuit, program conversion device, and mapping device | |
JP4484756B2 (en) | Reconfigurable circuit and processing device | |
JP2004336558A (en) | Data format conversion circuit | |
JP2004523056A5 (en) | ||
KR100840030B1 (en) | Programmable logic circuit | |
CN112486453A (en) | Asynchronous first-in first-out register and chip | |
JP3837136B2 (en) | Programmable logic circuit | |
US7509479B2 (en) | Reconfigurable global cellular automaton with RAM blocks coupled to input and output feedback crossbar switches receiving clock counter value from sequence control unit | |
JP2005057452A (en) | Programmable logic circuit | |
JP3837135B2 (en) | Programmable logic circuit | |
TWI502603B (en) | Integrated circuit | |
US7742469B2 (en) | Data input circuit and semiconductor device utilizing data input circuit | |
JP4866194B2 (en) | Integrated circuit and input data control method for reconfigurable circuit | |
CN101351770B (en) | A slave and a master device, a system incorporating the devices and a method of operating the slave device | |
JP2004200311A (en) | Logic verifying device | |
JP2005057451A (en) | Programmable logic circuit | |
JP6493044B2 (en) | Multiprocessor system | |
JP4826403B2 (en) | Synchronization circuit | |
JP2008219728A (en) | Reconstructible arithmetic processing circuit | |
JPH08329671A (en) | Semiconductor delaying device | |
JP2003337694A (en) | Shift circuit | |
JP2004318241A (en) | Status output circuit and status output circuit group | |
JP2006003759A (en) | Microcontroller | |
JP2008135047A (en) | Interface for multiprocessor | |
JP2007067292A (en) | Semiconductor device, input pad cell array and output pad cell array |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20060725 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20060728 |
|
R150 | Certificate of patent or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20090804 Year of fee payment: 3 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100804 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110804 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110804 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120804 Year of fee payment: 6 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20130804 Year of fee payment: 7 |
|
LAPS | Cancellation because of no payment of annual fees |