JP2000124317A - Information-processing system - Google Patents

Information-processing system

Info

Publication number
JP2000124317A
JP2000124317A JP10299236A JP29923698A JP2000124317A JP 2000124317 A JP2000124317 A JP 2000124317A JP 10299236 A JP10299236 A JP 10299236A JP 29923698 A JP29923698 A JP 29923698A JP 2000124317 A JP2000124317 A JP 2000124317A
Authority
JP
Japan
Prior art keywords
circuit
information
programmable logic
identifier
logic circuit
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
Application number
JP10299236A
Other languages
Japanese (ja)
Other versions
JP3573193B2 (en
Inventor
Yoshio Nishihara
義雄 西原
Yoshihide Sato
嘉秀 佐藤
Kiichi Yamada
紀一 山田
Hiroyuki Miyake
弘之 三宅
Eigo Nakagawa
英悟 中川
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Fujifilm Business Innovation Corp
Original Assignee
Fuji Xerox Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Fuji Xerox Co Ltd filed Critical Fuji Xerox Co Ltd
Priority to JP29923698A priority Critical patent/JP3573193B2/en
Publication of JP2000124317A publication Critical patent/JP2000124317A/en
Application granted granted Critical
Publication of JP3573193B2 publication Critical patent/JP3573193B2/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Landscapes

  • Logic Circuits (AREA)
  • Microcomputers (AREA)
  • Stored Programmes (AREA)
  • Design And Manufacture Of Integrated Circuits (AREA)

Abstract

PROBLEM TO BE SOLVED: To reduce time for reconfiguring a circuit into a programmable logic circuit, and at the same time to efficiently utilize the circuit existing on the programmable logic circuit. SOLUTION: An information-processing system stores a plurality of circuit information for configuring a programmable logic circuit 104 into a storage means 200. An acquisition means 105 stores the information of a circuit being configured on the programmable logic circuit 104, and at the same time passes specified circuit information from an application program and the information of the circuit being configured in the programmable logic circuit to an editing means 300, acquires the circuit information of a specified circuit which arrives from the editing means 300, and configures a specified circuit in the programmable logic circuit according to the circuit information. The editing means 300 generates circuit information of a circuit being specified by specified information from the acquisition means 105 in a state which can be utilized without reconfiguring a circuit which is configured in the programmable logic circuit 104 through the use of the circuit information acquired from the storage means 200.

Description

【発明の詳細な説明】DETAILED DESCRIPTION OF THE INVENTION

【0001】[0001]

【発明の属する技術分野】この発明は、アプリケーショ
ンプログラムによる処理の少なくとも一部分を、回路構
成を再構成できるプログラマブル論理回路で処理するこ
とが可能である情報処理システムに関する。
BACKGROUND OF THE INVENTION 1. Field of the Invention The present invention relates to an information processing system capable of processing at least a part of processing by an application program by a programmable logic circuit whose circuit configuration can be reconfigured.

【0002】[0002]

【従来の技術】デジタル回路装置、特に特定用途向け集
積回路(ASIC)の分野において、製品の開発期間を
短縮するために、フィールドプログラマブルゲートアレ
イ(FPGA)やプログラマブルロジックデバイス(P
LD)などで構成されたプログラマブル論理回路が広く
使われている。
2. Description of the Related Art In the field of digital circuit devices, in particular, application specific integrated circuits (ASICs), field programmable gate arrays (FPGAs) and programmable logic devices (PGAs) have been developed in order to shorten the development period of products.
2. Description of the Related Art Programmable logic circuits including LDs) are widely used.

【0003】これらのプログラマブル論理回路は、論理
回路を記述する回路情報をこれらに読み込ませること
で、内部の論理回路と論理回路間の結線を自由に構成す
ることができる。このため、プログラマブル論理回路を
用いることで、従来は回路設計の終了後に数週間から数
か月を必要とした集積回路の作製時間が不要になるとい
うメリットがある。特に、米国特許第4,700,18
7号の発明のような電気的に再構成可能なプログラマブ
ル論理回路は、一度作製した回路を必要に応じて自由に
何度でも変更できるという利点があり、プログラマブル
論理回路は、ますます広く使われるようになってきてい
る。
[0003] These programmable logic circuits can freely configure internal logic circuits and connections between the logic circuits by reading circuit information describing the logic circuits. For this reason, the use of the programmable logic circuit has an advantage that the time required to manufacture an integrated circuit, which conventionally required several weeks to several months after the completion of circuit design, is not required. In particular, US Pat. No. 4,700,18
An electrically reconfigurable programmable logic circuit such as the invention of No. 7 has an advantage that a circuit once manufactured can be freely changed as many times as necessary, and the programmable logic circuit is increasingly used. It is becoming.

【0004】この種のプログラマブル論理回路の回路を
設計する装置のひとつとして、特開平6−232259
号公報に開示される「FPGA回路設計装置及び方法」
の例がある。これを従来例1として図18及び図19を
参照しながら説明する。
Japanese Patent Application Laid-Open No. 6-232259 discloses an apparatus for designing such a programmable logic circuit.
Patent Document "FPGA circuit design apparatus and method"
There is an example. This will be described as Conventional Example 1 with reference to FIGS.

【0005】図18は、大規模FPGA回路を設計する
CADシステムの構成図を示したものである。この装置
は、予め、配置配線情報および論理機能情報を有したF
PGA機能モジュールよりなるハードマクロセルを、複
数個、登録したデータベース12を有し、このデータベ
ースに登録された複数のハードマクロセルを用いて配
置、配線することで、より大規模のFPGA集積回路を
設計するものである。
FIG. 18 shows a configuration diagram of a CAD system for designing a large-scale FPGA circuit. This device has an F that has placement and wiring information and logic function information in advance.
It has a database 12 in which a plurality of hard macrocells composed of PGA function modules are registered, and a larger-scale FPGA integrated circuit is designed by arranging and wiring using a plurality of hard macrocells registered in the database. Things.

【0006】この装置においては、マンマシンインター
フェースとしてのデータ入出力装置10に対して設計者
が操作してファイル管理プログラム群11を動作させ
る。このファイル管理プログラム群11は、論理ファイ
ル管理プログラム、ライブラリ管理プログラム、配置配
線管理プログラム等を有し、これらにより、管理対象で
あるデータベース12を管理する。
In this device, a designer operates a data input / output device 10 as a man-machine interface to operate a file management program group 11. The file management program group 11 has a logical file management program, a library management program, a placement and routing management program, and the like, and manages the database 12 to be managed by these.

【0007】データベース12は、FPGAの論理機能
情報を多数登録した論理ファイルと、機能モジュールと
してのFPGAセルを登録したセルライブラリと、FP
GA内外の配置配線情報を登録した配置配線ファイルと
からなる。セルライブラリには、予め配置配線情報およ
び論理機能情報を持ち、ペリフェラル回路等として特定
の機能を実行するハードマクロセルを予め多数登録す
る。このデータベース12の各ファイルの内容は、適
宜、診断システム13により読み出されて診断され、そ
の診断データ14が出力される。
The database 12 includes a logic file in which a large number of logic function information of the FPGA is registered, a cell library in which FPGA cells as function modules are registered,
It consists of a placement and routing file in which placement and routing information inside and outside the GA is registered. In the cell library, a large number of hard macro cells which have arrangement / wiring information and logic function information in advance and execute a specific function as a peripheral circuit or the like are registered in advance. The contents of each file in the database 12 are read and diagnosed by the diagnostic system 13 as appropriate, and the diagnostic data 14 is output.

【0008】そして、このデータベースに登録される各
ファイルの内容に従い、図面入力システム、ネットリス
ト生成システム、レイアウトシステム、セル内配置配線
システム、出力プログラムを順次用いることにより、大
規模FPGA回路を実現するための設計図面及びそのプ
ログラムを出力させる。
A large-scale FPGA circuit is realized by sequentially using a drawing input system, a netlist generation system, a layout system, an in-cell arrangement and wiring system, and an output program in accordance with the contents of each file registered in the database. And output a design drawing and a program therefor.

【0009】このCADシステムによって設計された1
チップのFPGAによるマイクロコンピュータシステム
の構成例を図19に示す。このFPGAチップ20は、
CPU21、ROM22、RAM23、I/Oポート2
4、処理すべきプログラムの経過時間を計るPIT(P
rogrammable Interval Time
r)25、同時に発生した複数の装置からの割り込み信
号を制御するPIC(Programmable In
terrupt Controller)26、CPU
21と必要なメモリアクセスの調停を行うDMAC(D
irectMemory Access Contro
ller)27のそれぞれが、アドレス/データバス2
8および制御信号線29に接続されて構成される。
[0009] The 1 designed by this CAD system
FIG. 19 shows a configuration example of a microcomputer system using a chip FPGA. This FPGA chip 20
CPU21, ROM22, RAM23, I / O port 2
4. PIT (P
programmable Interval Time
r) 25, a PIC (Programmable In) that controls interrupt signals from a plurality of devices that occurred simultaneously.
terruptController) 26, CPU
21 and a DMAC (D
directMemory Access Contro
each of the address / data bus 2
8 and the control signal line 29.

【0010】このうち、I/Oポート24、PIT2
5、PIC26、DMAC27に相当するハードマクロ
セルが、あらかじめデータベース12のセルライブラリ
に登録されており、これらは、このハードマクロセルを
そのまま読み出してFPGAチップ20上にマッピング
するのみで、これらのFPGAセル内の配置配線処理を
終えることができる。
The I / O port 24, PIT2
5, hard macro cells corresponding to the PIC 26 and the DMAC 27 are registered in advance in the cell library of the database 12, and these are simply read out as they are and mapped onto the FPGA chip 20. The placement and routing process can be completed.

【0011】以上のようにして、この従来例1によれ
ば、あらかじめ配置配線情報及び論理機能情報を有した
FPGA機能モジュールよりなるハードマクロセルを複
数登録したライブラリを有し、このライブラリに登録さ
れた複数のハードマクロセルを用いて配置、配線を行う
ことで、既存のFPGA回路を設計財産として活かし、
システム設計の負担を軽減して開発期間を短縮した設計
ができる。
As described above, according to the conventional example 1, there is provided a library in which a plurality of hard macro cells each including an FPGA function module having arrangement and wiring information and logic function information are registered in advance, and registered in this library. By arranging and wiring using multiple hard macro cells, the existing FPGA circuit can be utilized as a design property,
A design with a reduced development period by reducing the burden of system design can be achieved.

【0012】ところで、以上説明した従来例1は、1個
のFPGAチップを設計する際の発明に関するものであ
るが、最近の論理回路は複雑さが増し、一つのプログラ
マブル論理回路装置では実現できない規模にまで回路規
模が大きくなっている。
The prior art 1 described above relates to the invention when one FPGA chip is designed. However, the complexity of recent logic circuits increases, and the scale cannot be realized by one programmable logic circuit device. The circuit scale has increased up to.

【0013】この問題を解決するためのひとつの方法と
して、異なる時間に異なる論理回路を実現するために、
プログラマブル論理回路を処理の途中で再構成すること
が提案されている。この方法を用いることにより、携帯
情報端末のように、装置が小型であるため、内蔵できる
回路規模に制約がある場合でも、様々な処理が比較的高
速に行えるという利点がある。
One way to solve this problem is to implement different logic circuits at different times,
It has been proposed to reconfigure a programmable logic circuit during processing. By using this method, there is an advantage that various processes can be performed at a relatively high speed even when the size of a circuit that can be built in is limited because the device is small like a portable information terminal.

【0014】しかし、プログラマブル論理回路を再構成
するときには、回路全体の回路情報を再度読み込ませる
ため、再構成に時間がかかるという欠点がある。さら
に、処理の途中で再構成することは、処理を一時中断
し、その時のデータをプログラマブル論理回路の外部の
記憶装置に待避させ、新たな回路情報を読み込んで再構
成し、再構成前のデータと再構成に伴う新しいデータを
入力するという余分な処理が必要で、データを出し入れ
する処理は冗長なものとになる。
However, when reconfiguring a programmable logic circuit, the circuit information of the entire circuit is read again, so that there is a disadvantage that the reconfiguration takes time. Further, reconfiguring in the middle of the process means that the process is temporarily suspended, the data at that time is saved in a storage device outside the programmable logic circuit, new circuit information is read and reconfigured, and the data before reconfiguration is reconstructed. And extra processing of inputting new data accompanying the reconstruction is necessary, and the processing of taking data in and out becomes redundant.

【0015】この問題を解決するために、米国アトメル
社の「CONFIGURABLELOGIC」という名
のデータブックに記載されているプログラマブル論理回
路、および米国ザイリンクス社の「THE PROGR
AMMABLE LOGIC」という名のデータブック
に記載されているプログラマブル論理回路では、データ
を記憶するためのデータ記憶装置を有し、回路の動作中
でも外部の記憶装置から回路情報の一部を読み込んで部
分的に再構成を行うことで、再構成するための時間を最
小に留めるようにしている。
In order to solve this problem, a programmable logic circuit described in a data book named "CONFIGURABLE LOGIC" by Atmel Corporation of the United States and "THE PROGR by Xilinx Corporation of the United States" have been proposed.
A programmable logic circuit described in a data book named "AMMABLE LOGIC" has a data storage device for storing data, and reads part of circuit information from an external storage device during operation of the circuit to partially store the circuit information. By performing the reconfiguration, the time required for the reconfiguration is minimized.

【0016】このようなプログラマブル論理回路を情報
処理システムに用いるときの問題は、所望の論理回路を
構成するための回路情報を格納先から取り出し、必要に
応じて複数の回路情報を合成して処理に適切な形式に変
換し、所望の論理回路を再構成することを高速かつ効率
的に行わねばならないことである。
A problem when such a programmable logic circuit is used in an information processing system is that circuit information for forming a desired logic circuit is extracted from a storage destination, and a plurality of pieces of circuit information are synthesized as necessary. And to reconfigure the desired logic circuit at high speed and efficiently.

【0017】上述した複数の回路情報をプログラマブル
論理回路に異なる時間に再構成して所定の処理を行う情
報システムは、ネットワークに接続して利用することが
できる。その例として、特開平10−78932号公報
に記載される「リコンフィグラブル・ネットワークコン
ピュータ」があり、それを従来例2として図20を参照
しながら説明する。
The above-described information system for reconfiguring a plurality of pieces of circuit information into programmable logic circuits at different times and performing predetermined processing can be used by connecting to a network. As an example, there is a "reconfigurable network computer" described in Japanese Patent Application Laid-Open No. 10-78932, which will be described as Conventional Example 2 with reference to FIG.

【0018】この従来例2の情報処理システムは、通信
ネットワークNETに接続された複数のコンピュータで
構成され、その内の少なくとも一つがアプリケーション
プログラムを配布するコンピュータ(アプリケーション
・サーバ)SBであり、残りのコンピュータが前記アプ
リケーションプログラムをダウンロードし、実行するク
ライアントとなるコンピュータ(クライアント・コンピ
ュータ)CLで構成されたシステムである。複数のクラ
イアント・コンピュータCLの一部に、プログラムによ
り機能を随時変更し再構成することが可能な拡張ハード
ウェア(拡張HW)31が搭載されている。
The information processing system according to the second conventional example is composed of a plurality of computers connected to a communication network NET, at least one of which is a computer (application server) SB for distributing an application program, and the remaining ones. The computer is a system configured by a computer (client computer) CL which is a client that downloads and executes the application program. An extended hardware (extended HW) 31 capable of changing and reconfiguring functions at any time by a program is mounted on a part of the plurality of client computers CL.

【0019】サーバSBに格納されたアプリケーション
プログラムAPにおいては、その一部の機能に対して、
拡張ハードウェアのプログラムコード(拡張コード)
と、クライアント・コンピュータCLのメインのプロセ
ッサ(メインP)32のコードが含まれている。
In the application program AP stored in the server SB, some of its functions are
Extended hardware program code (extended code)
And the code of the main processor (main P) 32 of the client computer CL.

【0020】クライアント・コンピュータCLのOS
は、拡張ハードウェア31が実装されているか否かを判
断する機能を持ち、拡張ハードウエア31が実装されて
いる場合には、図20の上側のクライアント・コンピュ
ータCLのように、アプリケーションプログラムAPの
中からハードウェア構成に適したコードのみ取り出すコ
ード選択機能33を持っている。また、図20の下側の
クライアント・コンピュータCLのように、拡張ハード
ウェア31を持たない場合には、コード選択機能33に
より、メインプロセッサ32のコードが選択されてアプ
リケーションを利用できる。
OS of the client computer CL
Has a function of determining whether or not the extension hardware 31 is installed. When the extension hardware 31 is installed, the application program AP has the function as shown in the upper client computer CL in FIG. It has a code selection function 33 for extracting only codes suitable for the hardware configuration from the inside. When the client does not have the extended hardware 31 like the client computer CL on the lower side of FIG. 20, the code of the main processor 32 is selected by the code selection function 33 and the application can be used.

【0021】別の構成では、拡張ハードウェア31で実
現する機能を、クライアント・コンピュータCL上に後
から動的に追加/削除が可能なOSの拡張機能あるいは
動的ライブラリとして実現し、アプリケーションプログ
ラムAPがOSに対し処理中に利用する拡張機能あるい
は動的ライブラリの種類を登録する。OSは、拡張機能
あるいは動的ライブラリがクライアント上に存在する場
合にはそれを用い、存在しない場合にはネットワークN
ET上のサーバSBから必要とする拡張機能あるいは動
的ライブラリを転送し、利用する。
In another configuration, the function realized by the extended hardware 31 is realized as an OS extended function or a dynamic library that can be dynamically added / deleted later on the client computer CL, and the application program AP Registers the type of an extended function or a dynamic library used during processing with the OS. The OS uses the extended function or the dynamic library if it exists on the client, and uses the network N if it does not exist.
The required extended function or dynamic library is transferred from the server SB on the ET and used.

【0022】また、メインプロセッサ32用のコード、
拡張ハードウェア31用のコードは、一体となっている
のではなく、アプリケーションプログラムAPまたはO
Sの拡張機能または動的ライブラリ毎に、個々のコード
をホストコンピュータに上に備えることもできる。
Further, a code for the main processor 32,
The code for the extension hardware 31 is not integrated, but is
Individual code can also be provided on the host computer for each S extension or dynamic library.

【0023】さらに、従来例2の場合には、拡張ハード
ウエアを構成するプログラマブル論理回路の構成が、ク
ライアント間で異なる場合は、拡張コードを、適当なゲ
ート数と入出力端子数の論理回路の機能をブール式等で
記述した基本モジュールと、それらの接続関係を表現し
たコードとすることもできる。なお、基本モジュール
は、他の回路が参照して設計財産として再利用すること
ができる。
Further, in the case of the conventional example 2, if the configuration of the programmable logic circuit constituting the extension hardware differs between the clients, the extension code is replaced by a logic circuit having an appropriate number of gates and input / output terminals. Basic modules in which functions are described by Boolean expressions or the like, and codes expressing their connection relations can also be used. The basic module can be reused as a design property by referring to another circuit.

【0024】さらに、この基本モジュールを、それぞれ
プログラマブル論理回路の基本プログラムに割り付ける
機能と、複数のプログラマブル論理回路チップにまたが
る大きな拡張コードの場合には、基本モジュールを接続
の度合いに応じて分割し、各プログラマブル論理回路チ
ップに配置配線する機能を、サーバまたはクライアント
上に持つ。
Furthermore, the function of allocating the basic module to the basic program of the programmable logic circuit, and in the case of a large extension code extending over a plurality of programmable logic circuit chips, the basic module is divided according to the degree of connection. The function of arranging and wiring each programmable logic circuit chip is provided on the server or the client.

【0025】また、拡張ハードウェアを利用する複数の
アプリケーションを同時に実行できるように、必要のな
くなったハードウェア資源を別のアプリケーションプロ
グラムのために再利用するハードウェア資源の管理機能
と、拡張ハードウェアに入りきらない拡張コードを時分
割で入れ替えるコード入れ替え機能を持つ。
Also, a hardware resource management function for reusing the unnecessary hardware resources for another application program so that a plurality of applications using the extended hardware can be executed at the same time; It has a code replacement function that replaces extended codes that cannot fit in by time sharing.

【0026】また、クライアント上で実行されるアプリ
ケーションプログラム毎に適宜設定されるプライオリテ
ィ値、メインプロセッサの処理能力値、拡張ハードウェ
アの処理能力値、ハードウェア資源量、コード入れ替え
のために必要な処理能力値を基に、ハードウェア資源に
入りきらない複数のアプリケーションプログラムに対し
て選択する拡張ハードウェア管理機能を持つ。
Also, a priority value appropriately set for each application program executed on the client, a processing capacity value of the main processor, a processing capacity value of the extended hardware, a hardware resource amount, and processing required for code replacement. It has an extended hardware management function for selecting a plurality of application programs that cannot fit in the hardware resources based on the capability value.

【0027】複数のアプリケーションが同時に同じ拡張
コードを拡張ハードウェアで利用する場合には、内部状
態のみを時分割で切り替えて機能を共有する。
When a plurality of applications use the same extension code at the same time with the extension hardware, the function is shared by switching only the internal state by time division.

【0028】以上のように、従来例2の場合には、ネッ
トワークで接続されたコンピュータ上で、サーバから配
布されたアプリケーションプログラムをクライアント側
で実行する際、クライアント側に、プログラムにより機
能を随時変更し、再構成可能な拡張ハードウェアを搭載
し、サーバに格納されたアプリケーションプログラムに
は、クライアントのメインプロセッサコードと拡張コー
ドを含ませ、拡張ハードウェアの有無、種類を判断した
コード選択機能によって、クライアント側の計算機の構
成を変え、処理に適した構成にすることでアプリケーシ
ョンプログラムを高速に処理できる。
As described above, in the case of the conventional example 2, when the application program distributed from the server is executed on the client side on the computer connected via the network, the function is changed by the program on the client side as needed. Then, with reconfigurable expansion hardware, the application program stored in the server contains the main processor code and expansion code of the client, and the code selection function that determines the presence or absence of the expansion hardware and the type, The application program can be processed at high speed by changing the configuration of the computer on the client side and making the configuration suitable for processing.

【0029】また、ネットワーク上で、クライアント側
に特殊なハードウエアを必要とする新しいサービスを開
始しようとする場合には、従来は、クライアント側のユ
ーザはそのために新しいハードウエアを導入する必要が
あり、また、サービスの提供者は、新しいハードウエア
をもつ一部のユーザに対してのみ、新しいサービスを提
供することになったが、上述の従来例2を実施すること
により、新しいハードウエアを導入することなく、新し
いサービスを開始することが可能となる。
Further, when a new service requiring special hardware on the client side is to be started on the network, conventionally, the user on the client side has to introduce new hardware for that purpose. In addition, the service provider will provide the new service only to some users who have the new hardware, but by implementing the above-mentioned conventional example 2, the new hardware is introduced. Without having to start a new service.

【0030】[0030]

【発明が解決しようとする課題】しかしながら、従来例
2においては、新たなアプリケーションで必要とする拡
張コードが、すでに拡張ハードウェアに構成されている
拡張コードの一部分と共通の場合でも、全体の拡張コー
ドをサーバーから転送して再構成する必要があり、転送
および再構成に要する時間分だけ処理時間が長くなり、
処理速度の低下を招く問題があった。さらに、拡張ハー
ドウエア上に同じ回路が重複して再構成されるので、拡
張ハードウエアの利用効率が悪いという問題があった。
However, in the second conventional example, even if the extension code required for a new application is common to a part of the extension code already configured in the extension hardware, the entire extension is required. The code has to be transferred from the server and reconstructed, and the processing time is increased by the time it takes to transfer and reconstruct,
There is a problem that the processing speed is reduced. Further, since the same circuit is redundantly reconfigured on the extension hardware, there is a problem that the utilization efficiency of the extension hardware is low.

【0031】この発明は、上記の点にかんがみ、プログ
ラマブル論理回路上に構成されている回路を、できるだ
け利用することができるようにプログラマブル論理回路
の回路情報を生成することにより、処理速度の低下の問
題を解決すると共に、プログラマブル論理回路上に構成
されている回路の利用効率の向上を図ることを目的とす
る。
In view of the above, the present invention reduces the processing speed by generating circuit information of a programmable logic circuit so that a circuit configured on the programmable logic circuit can be used as much as possible. It is an object of the present invention to solve the problem and to improve the use efficiency of a circuit configured on a programmable logic circuit.

【0032】[0032]

【課題を解決するための手段】上記課題を解決するた
め、第1の発明による情報処理システムは、アプリケー
ションプログラムによる処理の少なくとも一部分を、プ
ログラマブル論理回路で処理する情報処理システムにお
いて、前記プログラマブル論理回路を備え、前記アプリ
ケーションプログラムからの命令により、前記プログラ
マブル論理回路に構成された回路を用いて処理を実行す
る処理手段と、前記プログラマブル論理回路に前記回路
を構成するための複数個の回路情報を記憶する記憶手段
と、指定情報により指定される一つの回路の回路情報
を、前記記憶手段に記憶された複数の回路情報を用いて
生成する機能を備える編集手段と、前記プログラマブル
論理回路に構成する回路を特定するために前記アプリケ
ーションプログラムにより指定される情報を、前記指定
情報として、前記編集手段に渡し、前記編集手段から到
来する前記指定情報により指定された回路の回路情報を
取得し、この回路情報により前記処理手段のプログラマ
ブル論理回路に前記指定された回路を構成すると共に、
前記プログラマブル論理回路に構成されている回路の情
報を記憶する取得手段と、を備え、前記編集手段は、前
記指定情報により指定される回路の回路情報を生成する
際に、前記取得手段から得た前記プログラマブル論理回
路に構成されている回路の情報を参照して、前記プログ
ラマブル論理回路に構成されている回路部分は再構成す
ることなく利用する状態で、前記回路情報を生成するこ
とを特徴とする。
According to a first aspect of the present invention, there is provided an information processing system for processing at least a part of an application program by a programmable logic circuit. Processing means for executing a process using a circuit configured in the programmable logic circuit in accordance with an instruction from the application program, and storing a plurality of circuit information for configuring the circuit in the programmable logic circuit Storage means for performing the operation, editing means having a function of generating circuit information of one circuit specified by the specification information using a plurality of circuit information stored in the storage means, and a circuit configured in the programmable logic circuit To identify the application program The specified information is passed to the editing means as the specified information, and the circuit information of the circuit specified by the specified information arriving from the editing means is obtained. Configure the circuit specified above,
Obtaining means for storing information of a circuit configured in the programmable logic circuit, wherein the editing means obtains the circuit information of the circuit specified by the specification information from the obtaining means. The circuit information is generated in a state in which a circuit portion configured in the programmable logic circuit is used without being reconfigured with reference to information of a circuit configured in the programmable logic circuit. .

【0033】また、第2の発明による情報処理システム
は、上記第1の発明において、前記取得手段に記憶され
る前記プログラマブル論理回路に構成されている回路情
報には、回路の識別子と、その回路の前記プログラマブ
ル論理回路上の配置情報とを含み、前記編集手段は、前
記回路の識別子および前記配置情報を参照することによ
り、前記指定情報により指定される回路の回路情報が、
前記プログラマブル論理回路に構成されている回路を利
用できる状態で生成できる場合には、前記プログラマブ
ル論理回路に構成されている回路部分は再構成すること
なく利用する状態で、前記回路情報を生成することを特
徴とする。
The information processing system according to a second aspect of the present invention is the information processing system according to the first aspect, wherein the circuit information stored in the acquisition means included in the programmable logic circuit includes a circuit identifier and a circuit identifier of the circuit. And the layout information on the programmable logic circuit, the editing means refers to the identifier of the circuit and the layout information, whereby the circuit information of the circuit specified by the specification information,
In a case where a circuit configured in the programmable logic circuit can be generated in a usable state, the circuit information is generated in a state where the circuit part configured in the programmable logic circuit is used without being reconfigured. It is characterized by.

【0034】第3の発明による情報処理システムは、上
記第1の発明において、前記記憶手段に記憶される複数
個の回路情報のそれぞれは、自己の回路情報の識別子を
備えるとともに、当該回路情報の一部または全部を他の
回路情報で構成する場合には、前記プログラマブル論理
回路に回路を構成するための回路データとして、当該他
の回路情報の識別子を参照識別子として備えるものであ
り、前記編集手段は、前記取得手段からの前記指定情報
により指定される回路の回路情報を、当該指定された回
路の回路情報と前記参照識別子で示される他の回路情報
とを前記記憶手段から入手して生成するものであって、
前記編集手段は、前記記憶手段から入手した前記参照識
別子により指定される回路の存在を、その参照識別子に
より前記取得手段に照会することにより、前記プログラ
マブル論理回路に当該参照識別子で示される回路が構成
されていることを認識すると共に、前記取得手段から
の、そのプログラマブル論理回路に構成されている回路
の配置情報を取得し、前記記憶手段から取得した回路情
報を用いて、前記プログラマブル論理回路に構成されて
いる回路部分は再構成することなく利用する状態で、前
記回路情報を生成することを特徴とする。
In the information processing system according to a third aspect of the present invention, in the first aspect, each of the plurality of circuit information stored in the storage means has an identifier of its own circuit information, and When a part or the whole is configured by other circuit information, an identifier of the other circuit information is provided as a reference identifier as circuit data for configuring a circuit in the programmable logic circuit. Generating the circuit information of the circuit specified by the specification information from the acquisition unit by obtaining the circuit information of the specified circuit and other circuit information indicated by the reference identifier from the storage unit Thing,
The editing unit refers to the obtaining unit by using the reference identifier for the existence of the circuit specified by the reference identifier obtained from the storage unit, thereby configuring the circuit indicated by the reference identifier in the programmable logic circuit. And from the acquisition means, obtains the layout information of the circuit configured in the programmable logic circuit, and configures the programmable logic circuit using the circuit information obtained from the storage means. The circuit information is generated in a state where the circuit portion used is used without being reconfigured.

【0035】また、第4の発明の情報処理装置は、上記
第3の発明において、前記編集手段は、前記取得手段か
らの指定情報に対応して、この指定情報により指定され
る回路の回路情報を、その識別子により前記記憶手段に
照会し、前記記憶手段は、前記編集手段からの照会に応
じて、その照会時の識別子で示される回路情報が参照識
別子を含む場合には、その参照識別子を前記編集手段に
返し、前記編集手段は、前記記憶手段から入手した参照
識別子により指定される回路の存在を、その参照識別子
により前記取得手段に照会し、前記取得手段は、前記編
集手段からの照会に応じて、その照会時の参照識別子で
示される回路が前記プログラマブル論理回路に存在する
場合には、その回路の前記プログラマブル論理回路上の
配置情報を編集手段に返し、前記配置情報を受け取った
前記編集手段は、前記記憶手段から入手した前記プログ
ラマブル論理回路に存在しない回路の参照識別子を用い
て、前記記憶手段から当該参照識別子で示される前記他
の回路情報を取得し、前記プログラマブル論理回路に構
成されている回路部分は再構成することなく利用する状
態で、前記回路情報を生成することを特徴とする。
According to a fourth aspect of the present invention, in the information processing apparatus according to the third aspect, the editing means corresponds to the designation information from the acquisition means, and stores the circuit information of a circuit designated by the designation information. Is referred to the storage means by the identifier, and the storage means, in response to the inquiry from the editing means, if the circuit information indicated by the identifier at the time of the inquiry includes a reference identifier, the storage means Returning to the editing means, the editing means inquires of the obtaining means by using the reference identifier for the existence of the circuit specified by the reference identifier obtained from the storage means, wherein the obtaining means In the case where the circuit indicated by the reference identifier at the time of the inquiry exists in the programmable logic circuit, the layout information of the circuit on the programmable logic circuit is edited by the editor. And the editing means having received the arrangement information uses the reference identifier of the circuit which does not exist in the programmable logic circuit obtained from the storage means, and the other circuit information indicated by the reference identifier from the storage means. And the circuit information is generated in a state where the circuit portion configured in the programmable logic circuit is used without being reconfigured.

【0036】第5の発明による情報処理システムは、上
記第1の発明において、前記記憶手段に記憶される複数
個の回路情報のそれぞれは、自己の回路情報の識別子を
備えるとともに、当該回路情報の一部または全部を他の
回路情報で構成する場合には、前記プログラマブル論理
回路に回路を構成するための回路データとして、当該他
の回路情報の識別子を参照識別子として備えるものであ
り、前記編集手段は、前記取得手段からの前記指定情報
により指定される回路の回路情報を、当該指定された回
路の回路情報と前記参照識別子で示される他の回路情報
とを前記記憶手段から入手して生成するものであって、
前記取得手段は、前記指定情報と共に、前記プログラマ
ブル論理回路に構成されている回路の情報を前記編集手
段に送り、前記編集手段は、前記取得手段からの指定情
報に対応して、この指定情報により指定される回路の回
路情報を、その識別子により前記記憶手段に照会し、前
記記憶手段は、前記編集手段からの照会に応じて、その
照会時の識別子で示される回路情報が参照識別子を含む
場合には、その参照識別子を前記編集手段に返し、前記
編集手段は、前記記憶手段から入手した参照識別子によ
り指定される回路の存在を、その参照識別子により前記
取得手段から得た前記プログラマブル論理回路に構成さ
れている回路の情報を参照することにより、前記指定情
報で指定される回路の回路情報の参照識別子で示される
回路が前記プログラマブル論理回路に存在するかどうか
を識別し、前記記憶手段から入手した前記プログラマブ
ル論理回路に存在しない回路の参照識別子を用いて、前
記記憶手段から当該参照識別子で示される前記他の回路
情報を取得し、前記プログラマブル論理回路に構成され
ている回路部分は再構成することなく利用する状態で、
前記回路情報を生成することを特徴とする。
According to a fifth aspect of the present invention, in the information processing system according to the first aspect, each of the plurality of circuit information stored in the storage means includes an identifier of its own circuit information, and When a part or the whole is configured by other circuit information, an identifier of the other circuit information is provided as a reference identifier as circuit data for configuring a circuit in the programmable logic circuit. Generating the circuit information of the circuit specified by the specification information from the acquisition unit by obtaining the circuit information of the specified circuit and other circuit information indicated by the reference identifier from the storage unit Thing,
The acquisition unit sends information of a circuit configured in the programmable logic circuit to the editing unit together with the designation information, and the editing unit responds to the designation information from the acquisition unit, and When the circuit information of the designated circuit is referred to the storage unit by the identifier, the storage unit responds to the inquiry from the editing unit, and the circuit information indicated by the identifier at the time of the inquiry includes the reference identifier. Returns the reference identifier to the editing means, and the editing means determines the presence of the circuit specified by the reference identifier obtained from the storage means in the programmable logic circuit obtained from the acquisition means by the reference identifier. By referring to the information of the configured circuit, the circuit indicated by the reference identifier of the circuit information of the circuit specified by the specification information is referred to as the program. Identifying whether or not the circuit exists in the mable logic circuit, and using the reference identifier of the circuit not existing in the programmable logic circuit obtained from the storage means, obtaining the other circuit information indicated by the reference identifier from the storage means However, the circuit portion configured in the programmable logic circuit is used without being reconfigured,
The circuit information is generated.

【0037】第6の発明による情報処理システムは、上
記第1の発明において、前記記憶手段に記憶される複数
個の回路情報のそれぞれは、回路データ部と、その付加
情報部とからなり、前記付加情報部は、自己の回路情報
の識別子を含むとともに、当該回路情報の一部または全
部を他の回路情報で構成する場合には、当該他の回路情
報の識別子を参照識別子として含むものであり、前記回
路データ部は、前記プログラマブル論理回路のコンフィ
ギュレーションメモリのアドレスと、そのアドレスに格
納される回路データとの対で記述されるものであって、
当該回路情報の一部または全部を他の回路情報で構成す
る場合には、その回路情報の一部または全部の回路デー
タは、前記参照識別子を用いて記述したものとされると
ともに、前記参照識別子が、前記回路情報において前記
他の回路情報を参照する位置に対応するアドレスの回路
データとして記述されており、前記編集手段は、前記取
得手段からの前記指定情報に対応して、当該指定情報に
より指定される回路の回路情報を、その識別子により前
記記憶手段に照会し、前記記憶手段は、前記編集手段か
らの照会に応じて、その照会時の前記識別子で示される
回路情報の前記付加情報部が参照識別子を含む場合に
は、その参照識別子を前記編集手段に返し、前記編集手
段は、前記記憶手段から入手した前記参照識別子を用い
て、前記記憶手段から前記他の回路情報を取得し、取得
した他の回路情報は、指定情報により指定された回路の
回路情報の回路データとして参照識別子が記述されたア
ドレスと、前記処理手段に存在する参照識別子で示され
る回路のアドレスとの差分アドレスを、前記参照識別子
に対応する前記他の回路情報の回路データ部のすべての
アドレスに加えて、前記参照識別子が記述された回路情
報に結合することを特徴とする。
According to a sixth aspect of the present invention, in the information processing system according to the first aspect, each of the plurality of circuit information stored in the storage means includes a circuit data portion and an additional information portion thereof. The additional information section includes an identifier of its own circuit information and, when a part or all of the circuit information is configured by other circuit information, includes the identifier of the other circuit information as a reference identifier. The circuit data portion is described by a pair of an address of a configuration memory of the programmable logic circuit and circuit data stored at the address,
When part or all of the circuit information is constituted by other circuit information, part or all of the circuit information of the circuit information is described using the reference identifier and the reference identifier is used. Is described in the circuit information as circuit data of an address corresponding to a position to refer to the other circuit information, and the editing unit responds to the designation information from the acquisition unit, and according to the designation information, The storage unit is queried for the circuit information of the designated circuit by the identifier, and the storage unit responds to the inquiry from the editing unit, and the additional information section of the circuit information indicated by the identifier at the time of the inquiry Contains a reference identifier, the reference identifier is returned to the editing unit, and the editing unit uses the reference identifier obtained from the storage unit to store the reference identifier. The other circuit information is obtained, and the obtained other circuit information is indicated by an address in which a reference identifier is described as circuit data of circuit information of the circuit specified by the specification information, and a reference identifier existing in the processing unit. A difference address from the address of the circuit to be connected to all the addresses of the circuit data portion of the other circuit information corresponding to the reference identifier, and combining the address with the circuit information in which the reference identifier is described. .

【0038】第7の発明による情報処理システムは、上
記第1〜第6の発明のいずれかにおいて、前記記憶手段
を構成する部分と、前記編集手段を構成する部分と、前
記取得手段および処理手段を構成する部分とが、ネット
ワークを介して接続されていることを特徴とする。
According to a seventh aspect of the present invention, in the information processing system according to any one of the first to sixth aspects, a part constituting the storage means, a part constituting the editing means, the acquisition means and the processing means Are connected via a network.

【0039】[0039]

【作用】第1の発明の情報処理システムにおいては、ア
プリケーションプログラムの実行時に、当該アプリケー
ションプログラムにより、処理手段のプログラマブル論
理回路で処理を実行させるために、当該プログラマブル
論理回路に構成する回路を特定するための情報が取得手
段に送られる。取得手段は、この情報を、回路情報の指
定情報として編集手段に渡す。編集手段は、この指定情
報を記憶手段に送る。
In the information processing system according to the first aspect of the present invention, when the application program is executed, the circuit constituting the programmable logic circuit is specified by the application program so that the program is executed by the programmable logic circuit of the processing means. Is sent to the acquisition means. The acquisition means passes this information to the editing means as circuit information designation information. The editing means sends the specified information to the storage means.

【0040】すると、記憶手段は、指定情報で指定され
る回路情報を編集手段に返す。編集手段は、これを受け
取り、指定された回路情報を生成するために、記憶手段
の他の回路情報も必要と判断すると、当該他の回路情報
も記憶手段から取得するようにする。この際に、編集手
段は、取得手段から得たプログラマブル論理回路に構成
されている回路の情報を参照し、指定された回路情報
が、プログラマブル論理回路に構成されている回路を含
んでいるかどうかを判別する。
Then, the storage returns the circuit information specified by the specified information to the editing means. When the editing unit receives this and determines that other circuit information of the storage unit is necessary to generate the specified circuit information, the editing unit acquires the other circuit information from the storage unit. At this time, the editing unit refers to the information of the circuit configured in the programmable logic circuit obtained from the acquisition unit, and determines whether the specified circuit information includes the circuit configured in the programmable logic circuit. Determine.

【0041】そして、編集手段は、記憶手段から取得し
た複数個の回路情報から、指定された回路情報を、プロ
グラマブル論理回路に構成されている回路部分を利用す
る状態で、すなわち、プログラマブル論理回路に構成さ
れている回路部分を除いて、生成し、それを指定情報に
より要求された情報として取得手段に返す。取得手段
は、編集手段から取得した回路情報を処理手段のプログ
ラマブル論理回路に再構成する。
The editing means converts the designated circuit information from the plurality of pieces of circuit information obtained from the storage means into a state in which the circuit part configured in the programmable logic circuit is used, that is, to the programmable logic circuit. Except for the configured circuit part, it is generated and returned to the acquisition means as information requested by the designated information. The acquisition unit reconfigures the circuit information acquired from the editing unit into a programmable logic circuit of the processing unit.

【0042】処理手段は、このプログラマブル論理回路
に再構成された回路を用いてアプリケーションプログラ
ムにより指示された処理を実行することができる。
The processing means can execute the processing specified by the application program using the circuit reconfigured into the programmable logic circuit.

【0043】以上のようにして、この第1の発明の情報
処理システムにおいては、アプリケーションプログラム
の実行時に、取得手段に指定情報を渡すと、この取得手
段からの要求に応じて、編集手段が、処理手段のプログ
ラマブル論理回路に既に構成されている回路をそのまま
利用する状態で、処理手段のプログラマブル論理回路に
構成すべき回路情報を自動的に生成して取得手段に返
し、取得手段がプログラマブル論理回路に回路情報を再
構成するように動作する。
As described above, in the information processing system according to the first aspect of the present invention, when the designation information is passed to the acquisition unit when the application program is executed, the editing unit responds to the request from the acquisition unit. In a state in which the circuit already configured in the programmable logic circuit of the processing means is used as it is, circuit information to be configured in the programmable logic circuit of the processing means is automatically generated and returned to the obtaining means, and the obtaining means is configured by the programmable logic circuit. To reconfigure the circuit information.

【0044】したがって、プログラマブル論理回路上に
既に構成されている回路を再構成する必要がないので、
その分の再構成時間が短縮化され、処理時間の短縮化に
供給すると共に、プログラマブル論理回路上に構成され
ている回路の効率的な利用を図ることができる。
Therefore, it is not necessary to reconfigure a circuit already configured on the programmable logic circuit.
The reconfiguration time is shortened by that amount, and the processing time can be reduced, and the circuit configured on the programmable logic circuit can be efficiently used.

【0045】また、この発明によれば、アプリケーショ
ンプログラムの指示に従って、取得手段と編集手段と
が、記憶手段の情報を用いて、必要な回路情報を生成す
るようにするので、予め回路情報をアプリケーションプ
ログラム内などに格納しておく必要はない。
Further, according to the present invention, the acquisition means and the editing means generate necessary circuit information using the information of the storage means in accordance with the instruction of the application program. It is not necessary to store it in the program.

【0046】また、第2の発明の情報処理システムにお
いては、取得手段には、プログラマブル論理回路に構成
されている回路の回路配置情報が記憶されており、編集
手段は、この回路配置情報から、指定情報により指定さ
れた回路が、既にプログラマブル論理回路上に在る回路
を用いて構成することができるか否かを判定して、必要
な回路情報を生成することができる。
Further, in the information processing system according to the second aspect of the present invention, the acquisition means stores circuit arrangement information of a circuit formed in the programmable logic circuit, and the editing means uses the circuit arrangement information based on the circuit arrangement information. Necessary circuit information can be generated by determining whether the circuit specified by the specified information can be configured using a circuit already on the programmable logic circuit.

【0047】したがって、プログラマブル論理回路上に
構成されている回路の効率的な利用を、確実に、図るこ
とができる。
Therefore, efficient use of the circuit formed on the programmable logic circuit can be ensured.

【0048】また、第3の発明の情報処理システムにお
いては、記憶手段に記憶される回路情報の構造は、他の
回路を参照しない回路データの構成の回路情報を最下層
の回路情報として、いわゆるツリー構造となる。
In the information processing system according to the third aspect of the present invention, the structure of the circuit information stored in the storage means is a so-called circuit information having a configuration of circuit data which does not refer to other circuits, which is a so-called lowermost circuit information. It has a tree structure.

【0049】すなわち、各回路情報は、自己の識別子と
して例えば回路名を備える。そして、各回路情報は、そ
の一部または全部を他の回路情報で構成する場合には、
回路データとして、当該他の回路情報の識別子を参照識
別子として備える。参照識別子は、他の回路情報の回路
名を用いることができる。参照識別子で示される他の回
路情報も、その一部または全部を他の回路情報で構成す
ることができる。そして、最下層の回路情報は、参照識
別子を回路データに持たない構造となる。取得手段が記
憶するプログラマブル論理回路に構成されている回路の
情報は、例えば回路名として、この参照識別子を持つ。
That is, each circuit information has, for example, a circuit name as its own identifier. Then, when each circuit information is configured partially or entirely with other circuit information,
As circuit data, an identifier of the other circuit information is provided as a reference identifier. As the reference identifier, the circuit name of other circuit information can be used. Other circuit information indicated by the reference identifier can also be partially or entirely composed of other circuit information. Then, the circuit information of the lowest layer has a structure in which the circuit data does not have the reference identifier. The information of the circuit configured in the programmable logic circuit stored in the acquisition unit has this reference identifier, for example, as a circuit name.

【0050】そして、編集手段は、取得手段から渡され
た指定情報で示される回路情報の識別子により記憶手段
に回路情報の照会を行う。記憶手段は、編集手段から回
路情報の識別子を受け取ると、その回路情報を編集手段
に返すとともに、その識別子で示される回路情報が参照
識別子を含む場合には、その参照識別子を編集手段に返
す。
Then, the editing unit inquires the storage unit of the circuit information based on the identifier of the circuit information indicated by the designation information passed from the obtaining unit. When receiving the identifier of the circuit information from the editing means, the storage means returns the circuit information to the editing means, and when the circuit information indicated by the identifier includes a reference identifier, returns the reference identifier to the editing means.

【0051】編集手段は、受け取った参照識別子により
指定される回路がプログラマブル論理回路に存在するか
否かを、その参照識別子により取得手段に照会する。取
得手段は、この編集手段からの照会に応じて、その照会
時の参照識別子で示される回路がプログラマブル論理回
路に存在する場合には、そのプログラマブル論理回路上
の配置情報を編集手段に返す。
The editing means inquires of the obtaining means by using the reference identifier whether the circuit specified by the received reference identifier exists in the programmable logic circuit. In response to the inquiry from the editing means, if the circuit indicated by the reference identifier at the time of the inquiry exists in the programmable logic circuit, the obtaining means returns the arrangement information on the programmable logic circuit to the editing means.

【0052】編集手段は、この配置情報を受け取ると、
記憶手段から取得した回路情報を用いて、前記プログラ
マブル論理回路に構成されている回路部分は再構成する
ことなく利用する状態で、前記回路情報を生成する。
When the editing means receives the arrangement information,
Using the circuit information obtained from the storage unit, the circuit information is generated in a state where the circuit part configured in the programmable logic circuit is used without being reconfigured.

【0053】この第3の発明によれば、指定された回路
情報を構成する複数の回路の一部をプログラマブル論理
回路に存在している回路を用いるようにすることがで
き、そのプログラマブル論理回路に存在している回路の
再構成が不要になると共に、当該回路の効率的な利用を
図ることができる。
According to the third aspect, a part of the plurality of circuits constituting the designated circuit information can be made to use a circuit existing in the programmable logic circuit. Reconfiguration of an existing circuit becomes unnecessary, and efficient use of the circuit can be achieved.

【0054】また、第4の発明においては、編集手段
は、記憶手段から受け取った参照識別子により指定され
る回路がプログラマブル論理回路に存在するか否かを、
その参照識別子により取得手段に照会し、取得手段から
の返答により、指定情報で指定された回路情報のうちの
プログラマブル論理回路に構成されている回路を認識す
る。そして、指定情報で指定された回路情報のうちの、
プログラマブル論理回路上に構成されていない他の回路
情報を、記憶手段から取得したその参照識別子を用い
て、記憶手段から取得する。そして、前記プログラマブ
ル論理回路に構成されている回路部分を除く回路部分の
回路情報を、指定された回路情報として生成する。
In the fourth invention, the editing means determines whether or not the circuit designated by the reference identifier received from the storage means exists in the programmable logic circuit.
The acquisition means is inquired by the reference identifier, and the circuit constituted by the programmable logic circuit among the circuit information designated by the designation information is recognized by the response from the acquisition means. Then, of the circuit information specified by the specification information,
Other circuit information not configured on the programmable logic circuit is obtained from the storage unit using the reference identifier obtained from the storage unit. Then, circuit information of a circuit portion other than the circuit portion configured in the programmable logic circuit is generated as designated circuit information.

【0055】この第4の発明によれば、記憶手段から
は、プログラマブル論理回路上に存在しない回路情報の
みを取得するだけでよく、プログラマブル論理回路上に
存在している回路情報の記憶手段からの取得時間分だ
け、処理を早くすることができる。
According to the fourth aspect, only the circuit information that does not exist on the programmable logic circuit needs to be obtained from the storage means, and only the circuit information existing on the programmable logic circuit is obtained from the storage means. Processing can be accelerated by the acquisition time.

【0056】また、第5の発明においては、取得手段か
らのプログラマブル論理回路に構成されている回路の情
報は、回路情報の指定情報と共に、編集手段に送られ
る。したがって、編集手段は、第3の発明のように、記
憶手段から取得した参照識別子を取得手段に照会するこ
となく、この編集手段の中で、プログラマブル論理回路
に構成されている回路を確認することにより、前述した
第3の発明と同様にして、プログラマブル論理回路に構
成されている回路を、できるだけ利用しながら、必要な
回路情報を生成することができる。
Further, in the fifth invention, the information of the circuit formed in the programmable logic circuit from the acquiring means is sent to the editing means together with the designation information of the circuit information. Therefore, as in the third invention, the editing means does not refer to the acquisition means for the reference identifier acquired from the storage means, but checks the circuit constituted by the programmable logic circuit in the editing means. Thus, in the same manner as in the above-described third aspect, it is possible to generate necessary circuit information while using a circuit configured as a programmable logic circuit as much as possible.

【0057】また、第6の発明においては、回路情報の
回路データ部は、プログラマブル論理回路のコンフィギ
ュレーションメモリのアドレスと、そのアドレスに格納
される回路データとの対で記述されているとともに、回
路情報の一部または全部が他の回路情報で構成される場
合には、参照識別子が、回路情報において他の回路情報
を参照する位置に対応するアドレスの回路データとして
記述されている。
In the sixth invention, the circuit data portion of the circuit information is described by a pair of an address of a configuration memory of the programmable logic circuit and circuit data stored at the address, and When a part or all of the information is constituted by other circuit information, the reference identifier is described as circuit data of an address corresponding to a position where the other circuit information is referred to in the circuit information.

【0058】したがって、編集手段は、回路データ部の
データ内容に従って、参照識別子で示される回路情報を
割り付けることにより、指定情報で指定された回路の回
路情報を、迅速に組み立てることができる。
Therefore, the editing means can quickly assemble the circuit information of the circuit specified by the specified information by allocating the circuit information indicated by the reference identifier according to the data content of the circuit data portion.

【0059】特に、指定情報で指定された回路の回路情
報にプログラマブル論理回路に既に構成されている回路
を含む場合に、その回路部分をそのまま利用する状態と
なるように回路情報を生成するとき、プログラマブル論
理回路に存在する一つの参照識別子で示される回路のア
ドレスと、記憶手段から取得したその他の参照識別子で
示される回路のアドレスとの差分アドレスを、前記他の
回路情報の回路データ部のすべてのアドレスに加えて、
前記参照識別子が記述された回路情報に結合することに
より必要な回路情報を生成する。
In particular, when the circuit information of the circuit specified by the specification information includes a circuit already configured in the programmable logic circuit, when generating the circuit information so as to use the circuit portion as it is, The difference address between the address of the circuit indicated by one reference identifier existing in the programmable logic circuit and the address of the circuit indicated by the other reference identifier acquired from the storage means is stored in the circuit data portion of the other circuit information. In addition to the address of
The required circuit information is generated by combining the reference identifier with the described circuit information.

【0060】このように、第6の発明によれば、単に、
アドレスにオフセットを付加するだけで、参照識別子で
示される回路情報を、その参照識別子が記述された回路
情報に結合することができ、配置配線の演算時間がほと
んど不要になる。このため、編集手段では、短時間で回
路情報を生成することができる。
As described above, according to the sixth aspect, simply:
By simply adding an offset to the address, the circuit information indicated by the reference identifier can be combined with the circuit information in which the reference identifier is described, and almost no calculation time for arrangement and wiring is required. Therefore, the editing unit can generate the circuit information in a short time.

【0061】さらに、プログラマブル論理回路に構成さ
れている回路の部分の回路情報の部分は、その他の回路
情報にアドレスに前述のようなオフセットを付加するこ
とにより、生成する回路情報に含ませないようにするこ
とができる。したがって、プログラマブル論理回路に存
在する回路を利用する状態での回路情報の生成が容易に
なるものである。
Further, by adding the above-described offset to the address to the other circuit information, the circuit information part of the circuit part configured in the programmable logic circuit is not included in the generated circuit information. Can be Therefore, it is easy to generate circuit information in a state where a circuit existing in the programmable logic circuit is used.

【0062】また、第7の発明の情報処理システムにお
いては、記憶手段を構成する部分と、編集手段を構成す
る部分と、取得手段および処理手段を構成する部分と
が、ネットワークを介して接続されており、一つの情報
処理装置内に編集手段や記憶手段を持つ必要がない。こ
のため、取得手段および処理手段とアプリケーションプ
ログラムで動作する情報処理装置から見ると、指定情報
をネットワークを通じて送出すると、その指定情報に対
応した回路情報が自動的に送られてくるシステムの構造
となり、記憶手段部分、編集手段部分、取得手段および
処理手段の部分の構成は、それぞれ任意にできる。
In the information processing system according to the seventh aspect of the present invention, a part constituting storage means, a part constituting editing means, and a part constituting acquisition means and processing means are connected via a network. Therefore, there is no need to have an editing unit and a storage unit in one information processing apparatus. For this reason, from the viewpoint of the information processing device operating with the acquisition unit and the processing unit and the application program, when the designated information is transmitted through the network, the circuit structure corresponding to the designated information is automatically transmitted, and the system has a structure. The configurations of the storage unit, the editing unit, the acquisition unit, and the processing unit can be arbitrarily set.

【0063】[0063]

【発明の実施の形態】以下、この発明による情報処理シ
ステムの実施の形態を、図を参照しながら説明する。
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS An embodiment of an information processing system according to the present invention will be described below with reference to the drawings.

【0064】[情報処理システム全体の構成の概要]こ
の発明による、少なくとも処理の一部分が、回路構成を
再構成できるプログラマブル論理回路を保有する処理手
段で処理される情報処理システムの第1の実施の形態の
主要な概念構成を図1に示す。
[Outline of Configuration of Entire Information Processing System] A first embodiment of an information processing system according to the present invention in which at least a part of the processing is processed by processing means having a programmable logic circuit capable of reconfiguring a circuit configuration. FIG. 1 shows the main conceptual configuration of the embodiment.

【0065】この場合の情報処理システムは、情報処理
部100と、記憶部200と、編集部300とからな
る。これら情報処理部100と、記憶部200と、編集
部300とは、一つの情報処理装置内に構成されること
もできるし、それぞれ別々の装置として、互いにネット
ワークを介して接続するようにして構成することもでき
る。
The information processing system in this case includes an information processing unit 100, a storage unit 200, and an editing unit 300. The information processing unit 100, the storage unit 200, and the editing unit 300 may be configured in one information processing device, or may be configured as separate devices and connected to each other via a network. You can also.

【0066】また、記憶部200と編集部300とを一
つのコンピュータシステムにより構成し、これと、コン
ピュータシステムからなる情報処理部100とをネット
ワークを通じて接続して、情報処理システムを構成する
ようにすることもできる。
Further, the storage section 200 and the editing section 300 are constituted by one computer system, and the information processing section 100 constituted by the computer system is connected through a network to constitute the information processing system. You can also.

【0067】以下に説明する例では、これら情報処理部
100、記憶部200、編集部300は、それぞれ別々
の装置として、互いにネットワークを介して接続する場
合として説明する。
In the example described below, the information processing unit 100, the storage unit 200, and the editing unit 300 will be described as being separate devices and connected to each other via a network.

【0068】情報処理部100においては、アプリケー
ションプログラム101は、実行しようとする一連の処
理を複数個の処理に分割し、分割した処理をCPU10
2またはプログラマブル論理回路を保有するハードウエ
ア処理部103で実行する。アプリケーションプログラ
ム101には、CPU102で行う処理は、CPU10
2の命令コードで記述され、また、ハードウエア処理部
103で行う処理は、これが保有するプログラマブル論
理回路104に構成する回路名と、その回路を構成要素
の一部として構成されたハードウエア処理部103の制
御コードで記述されている。
In the information processing section 100, the application program 101 divides a series of processes to be executed into a plurality of processes, and
2 or a hardware processing unit 103 having a programmable logic circuit. In the application program 101, processing performed by the CPU 102 includes the CPU 10
The processing described in the instruction code 2 is performed by the hardware processing unit 103. The processing name included in the programmable logic circuit 104 owned by the hardware processing unit 103 and the hardware processing unit configured as a part of the circuit. This is described by the control code 103.

【0069】ハードウエア処理部103は、処理手段を
構成するもので、プログラマブル論理回路104とし
て、この例ではFPGAタイプのプログラマブル論理回
路を保有し、このプログラマブル論理回路104に構成
された回路を利用して処理を行う。
The hardware processing section 103 constitutes processing means, and has a programmable logic circuit of an FPGA type in this example as the programmable logic circuit 104, and utilizes the circuit configured in the programmable logic circuit 104. Process.

【0070】取得手段を構成する回路情報取得部105
は、アプリケーションプログラム101からの、ハード
ウエア処理部103のプログラマブル論理回路104に
構成する回路の要求(回路の指定情報)を受けて、その
回路を構成するための回路情報を編集部300に要求
し、その要求した回路情報を編集部300から取得す
る。後で説明するように、回路情報はヘッダ部とコード
部(回路データ部)で構成されている。
Circuit information acquisition section 105 constituting acquisition means
Receives a request for a circuit included in the programmable logic circuit 104 of the hardware processing unit 103 (designation information of the circuit) from the application program 101, and requests the editing unit 300 for circuit information for configuring the circuit. The requested circuit information is acquired from the editing unit 300. As described later, the circuit information includes a header section and a code section (circuit data section).

【0071】そして、回路情報取得部105は、取得し
た回路情報のコード部に記述されている回路データを、
ハードウエア処理部103にロードして、そのプログラ
マブル論理回路104に回路を構成する。さらに、回路
情報取得部105は、回路情報のヘッダ部に記述されて
いる入出力ポート情報をアプリケーションプログラム1
01に提供する。
Then, the circuit information obtaining unit 105 converts the circuit data described in the code part of the obtained circuit information into
The program is loaded into the hardware processing unit 103 and a circuit is configured in the programmable logic circuit 104. Further, the circuit information obtaining unit 105 converts the input / output port information described in the header of the circuit information into the application program 1.
01.

【0072】アプリケーションプログラム101は、こ
の回路情報取得部105からの入出力ポート情報に基づ
いて、ハードウエア処理部103のプログラマブル論理
回路104に構成された回路に、データを入出力する。
The application program 101 inputs / outputs data to / from a circuit configured in the programmable logic circuit 104 of the hardware processing unit 103 based on the input / output port information from the circuit information acquisition unit 105.

【0073】また、回路情報取得部105は、そのとき
にハードウエア処理部103のプログラマブル論理回路
104に、どのような回路がどのように配置されている
かの情報を、構成回路メモリ106に格納して保存して
いる。保存情報は、プログラマブル論理回路104に存
在している回路名と、その回路がプログラマブル論理回
路上に構成されている領域の配置アドレス情報とからな
る。
The circuit information acquiring unit 105 stores information on what kind of circuit is arranged in the programmable logic circuit 104 of the hardware processing unit 103 at that time in the constituent circuit memory 106. And saved. The storage information includes a circuit name existing in the programmable logic circuit 104 and arrangement address information of an area where the circuit is configured on the programmable logic circuit.

【0074】さらに、この実施の形態では、回路情報取
得部105は、後述する編集部300からの照会に応じ
て、そのときにプログラマブル論理回路104にどのよ
うな回路がどのように配置されているかの情報を編集部
300に返す機能を備えている。
Further, in this embodiment, the circuit information acquiring unit 105 determines what kind of circuit is arranged in the programmable logic circuit 104 at that time in response to an inquiry from the editing unit 300 described later. Is returned to the editing unit 300.

【0075】記憶部200は、プログラマブル論理回路
104の回路を構成する複数の回路情報を格納する。後
述するように、この場合、回路情報は、他の回路情報を
参照することにより、記述することができる、いわゆる
ツリーデータ構造によって記憶部200に記憶すること
ができるようにされており、これにより、過去に生成さ
れた回路情報資源を有効に活用することができるととも
に、記憶部200の記憶素子の記憶容量の削減を図って
いる。
The storage section 200 stores a plurality of pieces of circuit information constituting the circuit of the programmable logic circuit 104. As will be described later, in this case, the circuit information can be described by referring to other circuit information, and can be stored in the storage unit 200 by a so-called tree data structure. In addition, the circuit information resources generated in the past can be effectively used, and the storage capacity of the storage element of the storage unit 200 is reduced.

【0076】この記憶部200は、この例の場合には、
後述するように、情報処理部100に接続されるネット
ワーク上のコンピュータシステムに設けるが、情報処理
部100と一体のコンピュータシステム内に設けてもよ
い。
In this case, the storage unit 200 stores
As described later, the information processing unit 100 is provided in a computer system on a network connected to the information processing unit 100, but may be provided in a computer system integrated with the information processing unit 100.

【0077】編集部300は、情報処理部100の回路
情報取得部105から要求された回路の回路情報を生成
するために必要な回路情報を、記憶部200から取得す
る。そして、取得した回路情報を、必要に応じて、編集
して、プログラマブル論理回路104に再構成する回路
の回路情報を生成する。
The editing section 300 acquires from the storage section 200 the circuit information necessary for generating the circuit information of the circuit requested by the circuit information acquiring section 105 of the information processing section 100. Then, the acquired circuit information is edited as necessary, and circuit information of a circuit to be reconfigured into the programmable logic circuit 104 is generated.

【0078】この回路情報の編集、生成の際に、編集部
300は、回路情報取得部105に対して、再構成のた
めに回路情報を生成しようとする回路中に、そのときに
プログラマブル論理回路104に存在している回路を含
むかどうかを判別するための問い合わせを行う。
At the time of editing and generating the circuit information, the editing unit 300 instructs the circuit information obtaining unit 105 to output the programmable logic circuit to the circuit for which circuit information is to be generated for reconfiguration. An inquiry is made to determine whether or not a circuit existing at 104 is included.

【0079】そして、再構成しようとする回路中に、プ
ログラマブル論理回路104に存在している回路が含ま
れる場合には、そのプログラマブル論理回路104に存
在している回路を、そのまま利用する状態で、新回路を
再構成するようにする回路情報を生成する。したがっ
て、回路情報としては、プログラマブル論理回路上に存
在している回路部分は空間として生成される。生成した
回路情報は、回路情報取得部105に提供する。
When a circuit to be reconfigured includes a circuit existing in the programmable logic circuit 104, the circuit existing in the programmable logic circuit 104 is used as it is. Generate circuit information for reconfiguring the new circuit. Therefore, as the circuit information, the circuit portion existing on the programmable logic circuit is generated as a space. The generated circuit information is provided to the circuit information acquisition unit 105.

【0080】編集部300から回路情報の提供を受けた
回路情報取得部105は、ハードウエア処理部103に
ロードして、その回路情報による回路を、プログラマブ
ル論理回路104に再構成する。そして、再構成した回
路の配置アドレスを含む回路情報が、構成回路メモリ1
06に記憶される。
The circuit information obtaining unit 105, which has been provided with the circuit information from the editing unit 300, loads the circuit information into the hardware processing unit 103 and reconfigures a circuit based on the circuit information into a programmable logic circuit 104. Then, the circuit information including the arrangement address of the reconfigured circuit is stored in the constituent circuit memory 1.
06 is stored.

【0081】後で詳細に説明するように、回路情報は他
の回路情報を参照することができるデータ構造であるの
で、編集部300は、記憶部200に要求する回路情報
を照会して参照関係を解決する参照解決処理と、参照解
決処理の結果に基づいて、回路情報を編集する再配置処
理を行う。
As will be described in detail later, since the circuit information has a data structure capable of referring to other circuit information, the editing unit 300 refers to the circuit information requested from the storage unit 200 and refers to the reference information. And a rearrangement process for editing the circuit information based on the result of the reference solution process.

【0082】この編集部300は、この例の場合には、
後述するように、情報処理部100に接続されるネット
ワーク上のコンピュータシステムに設けるが、情報処理
部100と一体のコンピュータシステム内に設けてもよ
い。
The editing unit 300, in this case,
As described later, the information processing unit 100 is provided in a computer system on a network connected to the information processing unit 100, but may be provided in a computer system integrated with the information processing unit 100.

【0083】[記憶部200に記憶される回路情報の構
造]記憶部200が格納する回路情報201は、図2に
示すように、付加情報部であるヘッダ部202と、回路
データ部であるコード部203からなる。ヘッダ部20
2には、回路名情報204と、入出力ポート情報205
とが記述される。
[Structure of Circuit Information Stored in Storage Unit 200] As shown in FIG. 2, the circuit information 201 stored in the storage unit 200 includes a header unit 202 serving as an additional information unit and a code unit serving as a circuit data unit. It comprises a unit 203. Header section 20
2 includes circuit name information 204 and input / output port information 205
Is described.

【0084】回路名情報204には、自己の回路情報の
識別子IDとして、この例では、当該回路情報201が
プログラマブル論理回路104に構成する回路名(以
下、自回路名と呼ぶ)が記述されている。この自己の回
路情報の識別子IDとしての自回路名は、その回路情報
201に付けられた名前でもある。この例では、アプリ
ケーションプログラム101は、後述するように、プロ
グラマブル論理回路104に構成する回路の指定情報と
して、この回路情報の識別子IDとしての自回路名を用
いる。
In the circuit name information 204, in this example, the circuit name of the programmable logic circuit 104 (hereinafter referred to as “own circuit name”) is described as the identifier ID of its own circuit information. I have. The own circuit name as the identifier ID of the own circuit information is also the name given to the circuit information 201. In this example, as described later, the application program 101 uses its own circuit name as an identifier ID of the circuit information as designation information of a circuit included in the programmable logic circuit 104.

【0085】自回路名に加えて、ヘッダ部202の回路
名情報204には、その回路情報201が参照する他の
回路情報を特定するための参照識別子refIDとし
て、その参照する回路情報の回路名(以下、参照回路名
と呼ぶ)も記述される。自己の回路情報の識別子IDと
してヘッダ部202に記述される自回路名はひとつであ
るが、参照回路名は、参照する回路情報の数に応じて、
複数の参照回路名がヘッダ部202に記述されることも
ある。
In addition to the own circuit name, the circuit name information 204 of the header section 202 includes, as a reference identifier refID for specifying other circuit information referred to by the circuit information 201, the circuit name of the referenced circuit information. (Hereinafter, referred to as a reference circuit name). Although the own circuit name described in the header section 202 as the identifier ID of the own circuit information is one, the reference circuit name is determined according to the number of the circuit information to be referred to.
A plurality of reference circuit names may be described in the header section 202.

【0086】ヘッダ部202の入出力ポート情報205
は、回路名情報204の記述の後に記述される。この入
出力ポート情報205は、回路に対する信号の流れの方
向に応じて、入力(IN)、出力(OUT)または双方
向(IN/OUT)から選ばれるポートの種類206、
論理セル(後に説明する)を単位にしたポートの位置座
標(X,Y)207、およびポートのデータ幅(ビット
数)208で構成される。
Input / output port information 205 of header section 202
Is described after the description of the circuit name information 204. The input / output port information 205 includes a port type 206 selected from input (IN), output (OUT) or bidirectional (IN / OUT) according to the direction of signal flow to the circuit.
It is composed of port position coordinates (X, Y) 207 in units of logic cells (described later) and port data width (number of bits) 208.

【0087】コード部(回路データ部)203は、アド
レスADRとデータDTの対の集まりで構成される。ア
ドレスADRは、プログラマブル論理回路104を構成
する論理セルや配線の状態を決定するコンフィギュレー
ションメモリ(後に説明する)のアドレスである。デー
タDTは、書き込まれたコンフィギュレーションメモリ
のアドレスに対応する論理セルや配線の状態を決める。
The code section (circuit data section) 203 is composed of a set of pairs of an address ADR and data DT. The address ADR is an address of a configuration memory (described later) that determines a state of a logic cell or wiring configuring the programmable logic circuit 104. The data DT determines the state of a logic cell or a wiring corresponding to the written address of the configuration memory.

【0088】記憶部200に格納されている各回路情報
201のコード部203のアドレスは、ある特定のアド
レス(例えば16ビットアドレスであれば0x0000
など:Oxは16進表示を意味している。以下同じ)か
ら開始する。後述するように、このアドレスに一定の値
を加えてオフセットすることで、コード部のアドレス
は、ハードウエア処理部103のプログラマブル論理回
路104上に実際に構成する回路位置に対応したアドレ
スに変換される。
The address of the code section 203 of each circuit information 201 stored in the storage section 200 is a specific address (for example, 0x0000 for a 16-bit address).
Etc .: Ox means hexadecimal notation. The same applies hereinafter). As will be described later, by adding a fixed value to this address and offsetting, the address of the code part is converted into an address corresponding to the circuit position actually configured on the programmable logic circuit 104 of the hardware processing unit 103. You.

【0089】ヘッダ部202の回路名情報204に、参
照回路名が記述されている場合には、その参照回路名で
示される回路情報が、その参照回路名が記述されている
回路情報で構成される回路において、どのように結合さ
れるかを決める参照回路情報がコード部203に記述さ
れる。
When the reference circuit name is described in the circuit name information 204 of the header section 202, the circuit information indicated by the reference circuit name is constituted by the circuit information in which the reference circuit name is described. In the circuit, reference circuit information that determines how the circuits are connected is described in the code section 203.

【0090】この参照回路情報は、アドレス(参照アド
レスと呼ぶ)と参照回路名の対として参照元の回路情報
のコード部に記述される。例えば、図2の例のアドレス
iと参照回路名pや、アドレスkと参照回路名qなどの
ように記述される。後述もするように、編集部300
は、参照回路名により参照された回路情報のコード部の
開始アドレスに、参照回路情報の参照アドレスを加えて
オフセットした回路データを、参照元の回路情報のコー
ド部に結合することにより、参照回路を参照元回路に結
合する。
The reference circuit information is described in the code portion of the reference source circuit information as a pair of an address (referred to as a reference address) and a reference circuit name. For example, it is described as the address i and the reference circuit name p, the address k and the reference circuit name q in the example of FIG. As will be described later, the editing unit 300
The reference circuit is obtained by adding the reference address of the reference circuit information to the start address of the code part of the circuit information referred to by the reference circuit name, and combining the offset circuit data with the code part of the reference source circuit information. Is connected to the reference source circuit.

【0091】また、後で説明するように、アドレスAD
Rと論理セルは一定の対応関係があるので、編集部30
0は、参照アドレスから参照回路の入出力ポート位置の
オフセット座標を算出して、参照回路の入出力ポート位
置座標にオフセット座標を加えてオフセットした参照回
路の入出力ポート情報を、参照元回路の回路情報のヘッ
ダ部に結合する。
As will be described later, the address AD
Since there is a certain correspondence between R and the logic cell, the editing unit 30
0 calculates the offset coordinates of the input / output port position of the reference circuit from the reference address, and adds the offset coordinates to the input / output port position coordinates of the reference circuit, and outputs the input / output port information of the reference circuit. Link to the header of circuit information.

【0092】参照する他の回路情報を用いない回路情報
は、ヘッダ部202に参照回路名を持たない。基本回路
モジュールのような最小単位の回路情報は、ヘッダ部2
02に参照回路名を持たない回路情報である。参照回路
名により参照される他の回路情報が、そのヘッダ部20
2に参照回路名を持つ場合もある。このような多層構造
のツリー構造の場合には、編集部300では、最下層の
回路情報から順次に回路情報を結合することにより、取
得部105から指定された回路名の回路情報を生成する
ようにする。
Circuit information that does not use other circuit information to be referenced does not have a reference circuit name in the header section 202. The circuit information of the minimum unit such as the basic circuit module is stored in the header 2
02 has no reference circuit name. Other circuit information referred to by the reference circuit name is stored in the header section 20.
2 may have a reference circuit name. In the case of such a multi-layer tree structure, the editing unit 300 generates circuit information of the circuit name specified by the acquisition unit 105 by sequentially combining circuit information from the lowest layer circuit information. To

【0093】なお、回路情報取得部105の構成回路メ
モリ106に格納されるプログラマブル論理回路に構成
されている回路の情報は、アプリケーションプログラム
101で指示された回路名の回路情報であるが、その回
路データ部203のアドレスが、プログラマブル論理回
路104上の配置アドレスに変換されたものとなる。し
たがって、当該回路名の回路情報が参照回路を含むもの
であれば、その参照回路部分は、参照アドレスと、参照
回路名とからなっている。そして、その回路情報のヘッ
ダ部202には、その参照回路名が記述されている。
The circuit information of the programmable logic circuit stored in the constituent circuit memory 106 of the circuit information acquisition unit 105 is the circuit information of the circuit name specified by the application program 101. The address of the data section 203 is converted into an arrangement address on the programmable logic circuit 104. Therefore, if the circuit information of the circuit name includes the reference circuit, the reference circuit portion includes the reference address and the reference circuit name. Then, the reference circuit name is described in the header section 202 of the circuit information.

【0094】[情報処理システムのハードウエア構成]
図3は、この実施の形態の情報処理システムのハードウ
エア構成例を示すブロック図である。この実施の形態の
情報処理システムにおいて、情報処理部100は、CP
U111のホストバス111Bに、チップセット112
に含まれるメモリコントローラ(図示せず)を介して、
例えばDRAMで構成されるメインメモリ113が接続
される。
[Hardware Configuration of Information Processing System]
FIG. 3 is a block diagram illustrating a hardware configuration example of the information processing system according to the present embodiment. In the information processing system of this embodiment, the information processing unit 100
The chipset 112 is connected to the host bus 111B of the U111.
Via a memory controller (not shown) included in
For example, a main memory 113 composed of a DRAM is connected.

【0095】ホストバス111Bは、また、チップセッ
ト112に含まれるホスト−PCIバスブリッジ(図示
せず)を介して、PCIバス114に接続される。PC
Iバス114には、プログラマブル論理回路インターフ
ェース115を介してプログラマブル論理回路116
と、ハードディスクインターフェース117を介してハ
ードディスクドライブ118と、通信インターフェース
119とが接続される。プログラマブル論理回路116
は、図1のハードウエア処理部103のプログラマブル
論理回路104に相当する。
The host bus 111B is connected to a PCI bus 114 via a host-PCI bus bridge (not shown) included in the chipset 112. PC
The I bus 114 has a programmable logic circuit 116 via a programmable logic circuit interface 115.
The hard disk drive 118 and the communication interface 119 are connected via the hard disk interface 117. Programmable logic circuit 116
Corresponds to the programmable logic circuit 104 of the hardware processing unit 103 in FIG.

【0096】通信インターフェース119は、LANや
インターネットなどのネットワーク400を介して、複
数個のコンピュータシステム500に接続される。コン
ピュータシステム500は、少なくとも、CPU(図示
せず)、メインメモリ(図示せず)、およびハードディ
スクドライブ(図示せず)などの記憶装置を保有する。
[0096] The communication interface 119 is connected to a plurality of computer systems 500 via a network 400 such as a LAN or the Internet. The computer system 500 has at least a storage device such as a CPU (not shown), a main memory (not shown), and a hard disk drive (not shown).

【0097】ハードディスクドライブ118により読み
書きされるハードディスクには、アプリケーションプロ
グラム(図示せず)が格納されている。アプリケーショ
ンプログラムは、ハードディスクインターフェース11
7、PCIバス114およびチップセット112に含ま
れるホスト−PCIブリッジ(図示せず)を介して、ハ
ードディスクドライブ118からメインメモリ113に
ロードされてCPU111によって実行される。
The hard disk read / written by the hard disk drive 118 stores an application program (not shown). The application program is stored in the hard disk interface 11
7, loaded from the hard disk drive 118 to the main memory 113 via the PCI bus 114 and a host-PCI bridge (not shown) included in the chipset 112, and executed by the CPU 111.

【0098】また、アプリケーションプログラムは、ネ
ットワーク400に接続されるいずれかのコンピュータ
システム500の記憶装置(図示せず)に格納されてい
る場合もある。この場合は、情報処理部100が、アプ
リケーションプログラムを、ネットワーク400に接続
されるコンピュータシステム500から、通信インター
フェース119を介してメインメモリ113に取得して
実行する。
The application program may be stored in a storage device (not shown) of one of the computer systems 500 connected to the network 400. In this case, the information processing unit 100 acquires the application program from the computer system 500 connected to the network 400 to the main memory 113 via the communication interface 119 and executes the application program.

【0099】ネットワーク400に接続されるいずれか
のコンピュータシステム500の記憶装置(図示せず)
は、回路情報を格納して、図1の記憶部200を構成す
る。また、情報処理部100のハードディスクドライブ
118が、回路情報を格納して、図1の記憶部200を
構成することもある。
Storage device (not shown) of one of computer systems 500 connected to network 400
Configures the storage unit 200 of FIG. 1 by storing circuit information. The hard disk drive 118 of the information processing unit 100 may store the circuit information and configure the storage unit 200 of FIG.

【0100】コンピュータシステム500が、図1の記
憶部200として格納する回路情報を検索したり、ネッ
トワーク400を介して他のコンピュータシステム50
0へ転送する機能は、コンピュータシステム500の機
能のひとつとしてソフトウエア的に実装される。
The computer system 500 searches for circuit information stored as the storage unit 200 in FIG.
The function of transferring to “0” is implemented as software as one of the functions of the computer system 500.

【0101】図1の編集部300は、ネットワーク40
0に接続されるいずれかのコンピュータシステム500
の機能のひとつとして、ソフトウエア的に実装される。
図1の編集部300を構成するコンピュータシステム5
00と、図1の記憶部200を構成するコンピュータシ
ステム500は、同じコンピュータシステムであっても
よいし、別のコンピュータシステムであってもよい。
The editing unit 300 shown in FIG.
0 connected to any computer system 500
It is implemented as software as one of the functions.
Computer system 5 constituting editing unit 300 of FIG.
00 and the computer system 500 configuring the storage unit 200 in FIG. 1 may be the same computer system or different computer systems.

【0102】図1の編集部300を構成するコンピュー
タシステム500と、図1の記憶部200を構成するコ
ンピュータシステム500が、別のコンピュータシステ
ムである場合は、ネットワーク400を介して互いに通
信する。
When the computer system 500 constituting the editing unit 300 of FIG. 1 and the computer system 500 constituting the storage unit 200 of FIG. 1 are different computer systems, they communicate with each other via a network 400.

【0103】情報処理部100の図1の回路情報取得部
105は、通信インターフェース119を介してネット
ワーク400に接続されたいずれかのコンピュータシス
テムで構成される編集部300と通信する機能と、PC
Iバス114に接続されたプログラマブル論理回路イン
ターフェース115を介してプログラマブル論理回路1
16に回路データをロードする機能とを含んだ機能とし
て、ソフトウエア的に情報処理部100に実装される。
The circuit information acquisition unit 105 of FIG. 1 of the information processing unit 100 has a function of communicating with the editing unit 300 constituted by any computer system connected to the network 400 via the communication interface 119, and a PC
A programmable logic circuit 1 via a programmable logic circuit interface 115 connected to the I bus 114
16 is implemented in software in the information processing unit 100 as a function including a function of loading circuit data.

【0104】このように、回路情報取得部105は、情
報処理部100にソフトウエア的に実装されるので、情
報処理部100で実行されるアプリケーションプログラ
ムと通信することができる。
As described above, since the circuit information acquisition unit 105 is implemented in software in the information processing unit 100, it can communicate with an application program executed in the information processing unit 100.

【0105】図1のハードウエア処理部103は、プロ
グラマブル論理回路インターフェース115とプログラ
マブル論理回路116とで構成される。ハードウエア処
理部103は、PCIバス114に接続されたプログラ
マブル論理回路インターフェース115を介して、CP
U111で実行されるアプリケーションプログラムと通
信する機能を持つ。
The hardware processing section 103 shown in FIG. 1 comprises a programmable logic circuit interface 115 and a programmable logic circuit 116. The hardware processing unit 103 transmits the CP via the programmable logic circuit interface 115 connected to the PCI bus 114.
It has a function of communicating with the application program executed in U111.

【0106】[FPGAタイプのプログラマブル論理回
路の説明]前述したように、この実施の形態において
は、FPGAタイプのプログラマブル論理回路を、プロ
グラマブル論理回路116(図1のプログラマブル論理
回路104)を用いる。このFPGAタイプのプログラ
マブル論理回路50の平面構造を図4に、内部構造のブ
ロック図を図5に示す。
[Description of Programmable Logic Circuit of FPGA Type] As described above, in this embodiment, a programmable logic circuit 116 (programmable logic circuit 104 in FIG. 1) is used as a programmable logic circuit of the FPGA type. FIG. 4 shows a plan structure of the programmable logic circuit 50 of the FPGA type, and FIG. 5 shows a block diagram of the internal structure.

【0107】このプログラマブル論理回路50は、回路
情報を格納するためのコンフィギュレーションメモリ6
1と、論理セル51や配線領域52からなる回路素子6
2と、入出力端子53とで構成される。
This programmable logic circuit 50 has a configuration memory 6 for storing circuit information.
1 and a circuit element 6 composed of a logic cell 51 and a wiring region 52
2 and an input / output terminal 53.

【0108】コンフィギュレーションメモリ61は、E
EPROM、SRAMなどの書き換え可能なメモリ素子
で構成されている。回路データは、アドレスADRとデ
ータDTの対で構成される。コンフィギュレーションメ
モリ61にアドレスADRを与えて、そのアドレスAD
Rに対応するメモリセルに、アドレスADRと対になっ
たデータDTが格納されると、このデータDTに従っ
て、論理セル51内の回路構成や、論理セル51と入出
力端子53を相互に接続する配線領域52の接続状態が
再構成される。コンフィギュレーションメモリ61の一
部分を書き換えることにより、プログラマブル論理回路
50が動作中であっても、回路を部分的に再構成するこ
とができる。
The configuration memory 61 stores E
It is composed of rewritable memory elements such as EPROM and SRAM. The circuit data is composed of a pair of an address ADR and data DT. An address ADR is given to the configuration memory 61 and the address AD
When the data DT paired with the address ADR is stored in the memory cell corresponding to R, the circuit configuration in the logic cell 51 and the logic cell 51 and the input / output terminal 53 are interconnected according to the data DT. The connection state of the wiring region 52 is reconfigured. By rewriting a part of the configuration memory 61, the circuit can be partially reconfigured even when the programmable logic circuit 50 is operating.

【0109】プログラマブル論理回路50に再構成され
た回路素子62に、入出力端子53を介して、処理すべ
きデータが入力され、また、その処理結果が出力され
る。データ入力先の論理セルと、データ出力元の論理セ
ルを、論理セルの位置に対応するセル座標を示した制御
コードによって、アプリケーションプログラム(図1の
例では、アプリケーションプログラム101)が指定す
る。
The data to be processed is input to the circuit element 62 reconfigured in the programmable logic circuit 50 via the input / output terminal 53, and the processing result is output. An application program (the application program 101 in the example of FIG. 1) specifies a logic cell as a data input destination and a logic cell as a data output source by a control code indicating a cell coordinate corresponding to the position of the logic cell.

【0110】[実施の形態の情報処理システムの処理動
作の説明]以上のように構成された実施の形態の情報処
理システムの処理動作を、図1の構成図と、図6〜図1
0に示したフローチャートを用いて説明する。
[Explanation of the processing operation of the information processing system of the embodiment] The processing operation of the information processing system of the embodiment configured as described above is shown in the configuration diagram of FIG.
This will be described with reference to the flowchart shown in FIG.

【0111】情報処理装置(図示せず)で起動したアプ
リケーションプログラム101は、一連の処理を、CP
U102またはハードウエア処理部103のプログラマ
ブル論理回路104で実行する。アプリケーションプロ
グラム101からCPU102への処理の指示は、通常
の計算機を用いた処理と同じ手順で行われる。
An application program 101 started by an information processing apparatus (not shown) executes a series of processing by a CP.
The processing is executed by the U102 or the programmable logic circuit 104 of the hardware processing unit 103. The instruction of the processing from the application program 101 to the CPU 102 is performed in the same procedure as the processing using a normal computer.

【0112】以下の説明は、アプリケーションプログラ
ム101が処理を実行するために必要な回路を、既にプ
ログラマブル論理回路104に構成されている回路を用
いて、プログラマブル論理回路104に再構成する場合
の例である。すなわち、情報処理システムが、プログラ
マブル論理回路104に構成されている回路を参照して
回路情報を生成し、その回路情報に基づいてハードウエ
ア処理部103のプログラマブル論理回路104に回路
を構成し、その構成された回路を用いて処理を行う手順
を示すものである。
The following description is an example of a case where a circuit necessary for the application program 101 to execute a process is reconfigured into a programmable logic circuit 104 using a circuit already configured in the programmable logic circuit 104. is there. That is, the information processing system generates circuit information with reference to the circuit configured in the programmable logic circuit 104, configures the circuit in the programmable logic circuit 104 of the hardware processing unit 103 based on the circuit information, and It shows a procedure for performing processing using the configured circuit.

【0113】(回路情報要求)図6のフローチャートに
示すように、情報処理装置(図示せず)で起動したアプ
リケーションプログラム101が、ハードウエア処理部
103で実行する処理に必要な回路の指定情報を回路情
報取得部105に指示する(ステップS101)。この
例では、回路の指定情報として、その回路名(自回路
名)が用いられる。
(Circuit Information Request) As shown in the flowchart of FIG. 6, the application program 101 started by the information processing apparatus (not shown) sends the circuit designation information necessary for the processing executed by the hardware processing unit 103. An instruction is given to the circuit information acquisition unit 105 (step S101). In this example, the circuit name (own circuit name) is used as the circuit designation information.

【0114】アプリケーションプログラム101から、
回路の指定情報としての回路名を受け取った回路情報取
得部105は、その回路名を編集部300へ伝え、ハー
ドウエア処理部103が必要とする回路を構成すること
ができる回路情報の編集を編集部300へ指示する(ス
テップS102)。
From the application program 101,
The circuit information acquisition unit 105 that has received the circuit name as the circuit designation information transmits the circuit name to the editing unit 300, and edits the circuit information that can configure the circuit required by the hardware processing unit 103. An instruction is given to the unit 300 (step S102).

【0115】(参照解決処理)編集部300は、取得部
105から受け取った回路名を記憶部200に渡して、
照会することにより、その回路名の回路情報を取得する
のであるが、上述したように、この例の場合には、その
回路名で指定される回路情報が、他の回路情報を参照す
るものである場合があることから、その参照回路名を知
るための処理として参照解決の処理が行われる(ステッ
プS103)。
(Reference Resolution Processing) The editing unit 300 passes the circuit name received from the acquisition unit 105 to the storage unit 200, and
By inquiring, the circuit information of the circuit name is acquired. As described above, in this example, the circuit information specified by the circuit name refers to other circuit information. Since there is a case, reference resolution processing is performed as processing for knowing the reference circuit name (step S103).

【0116】この参照解決の処理手順を図7、図8およ
び図9のフローチャートを参照して説明する。図7は、
この参照解決処理として編集部300で実行される処理
のフローチャートであり、図8は、参照解決処理として
記憶部200で実行される処理のフローチャートであ
り、図9は、参照解決処理として回路情報取得部105
で実行される処理である。
The processing procedure of this reference solution will be described with reference to the flowcharts of FIGS. 7, 8 and 9. FIG.
FIG. 8 is a flowchart of a process executed by the editing unit 300 as the reference solution process, FIG. 8 is a flowchart of a process executed by the storage unit 200 as the reference solution process, and FIG. Part 105
This is the process executed by

【0117】まず、図7に示すように、編集部300
は、回路情報取得部105から得た回路名を記憶部20
0に問い合わせる(ステップS111)。
First, as shown in FIG.
Stores the circuit name obtained from the circuit information acquisition unit 105 in the storage unit 20
0 is inquired (step S111).

【0118】図8に示すように、記憶部200は、この
編集部300からの回路名の照会が有ったことを検知す
ると(ステップS121)、その回路名を取得し(ステ
ップS122)、その回路名に対応する回路情報201
のヘッダ部202を調べて、参照回路が有るか否かを、
参照回路名が記述されているか否かにより判別する(ス
テップS123)。そして、参照回路名が記述されてい
る場合は、ヘッダ部202に記述されている参照回路名
を編集部300に答える(ステップS124)。
As shown in FIG. 8, when the storage unit 200 detects that there is an inquiry about the circuit name from the editing unit 300 (step S121), the storage unit 200 acquires the circuit name (step S122), and Circuit information 201 corresponding to the circuit name
By examining the header section 202 of the
It is determined based on whether or not a reference circuit name is described (step S123). If the reference circuit name is described, the reference circuit name described in the header section 202 is answered to the editing section 300 (step S124).

【0119】そして、記憶部200は、編集部300か
らの回路名の照会の終了通知が来ない時には、ステップ
S121に戻って、更なる編集部300からの回路名の
照会を待ち、編集部300から回路名の照会の終了通知
が来たときに、この図8の参照解決の処理ルーチンを終
了する(ステップS125)。
When the end notification of the inquiry of the circuit name is not received from the editing unit 300, the storage unit 200 returns to step S121 and waits for the inquiry of the circuit name from the further editing unit 300. When the notification of the end of the inquiry of the circuit name is received from, the reference resolution processing routine of FIG. 8 is ended (step S125).

【0120】編集部300は、ステップS111での回
路名の照会に対して、記憶部200からの参照回路名の
返答があるか否か判別し(ステップS112)、参照回
路名の返答がなければ、この参照解決処理を終了する。
また、参照回路名の返答がある場合は、記憶部200か
らの参照回路名を取得保持する(ステップS113)。
そして、取得した参照回路名を回路情報取得部105に
照会する(ステップS114)。
The editing section 300 determines whether or not there is a reply of the reference circuit name from the storage section 200 in response to the inquiry of the circuit name in step S111 (step S112). Then, the reference resolution processing ends.
If there is a reply of the reference circuit name, the reference circuit name is obtained and stored from the storage unit 200 (step S113).
Then, the acquired reference circuit name is referred to the circuit information acquisition unit 105 (step S114).

【0121】図9に示すように、回路情報取得部105
は、この編集部300からの参照回路名による照会をス
テップS131で検知すると、その参照回路名を取得し
て(ステップS132)、構成回路メモリ106に記憶
してあるプログラマブル論理回路104上に構成されて
いる回路の回路名を調べ、その参照回路名の回路がプロ
グラマブル論理回路104上に構成されているか否かを
判別する(ステップS133)。
As shown in FIG. 9, the circuit information obtaining unit 105
When detecting the inquiry by the reference circuit name from the editing unit 300 in step S131, the reference circuit name is acquired (step S132) and is configured on the programmable logic circuit 104 stored in the configuration circuit memory 106. The circuit name of the reference circuit is checked, and it is determined whether or not the circuit of the reference circuit name is configured on the programmable logic circuit 104 (step S133).

【0122】そして、プログラマブル論理回路104上
に、当該参照回路名の回路が構成されているときは、構
成回路メモリ106に記憶してある、その参照回路名の
回路のプログラマブル論理回路104上の配置アドレス
を調べて、編集部300に、その配置アドレスを答える
(ステップS134)。当該参照回路名の回路が構成さ
れていない場合は、この例では、編集部300に、プロ
グラマブル論理回路104上に対応回路が存在しない旨
を返す。なお、配置アドレスを返さないことにより、プ
ログラマブル論理回路104上に対応回路が存在しない
旨を表すようにしてもよい。
When the circuit having the reference circuit name is formed on the programmable logic circuit 104, the arrangement of the circuit having the reference circuit name stored in the constituent circuit memory 106 on the programmable logic circuit 104 is performed. The address is checked, and the layout address is returned to the editing unit 300 (step S134). If the circuit with the reference circuit name is not configured, in this example, the editing unit 300 is notified that there is no corresponding circuit on the programmable logic circuit 104. Note that, by not returning the arrangement address, the fact that the corresponding circuit does not exist on the programmable logic circuit 104 may be indicated.

【0123】編集部300は、この回路情報取得部10
5からの参照回路名の回路の配置アドレスあるいは対応
回路存在なしの返答により、照会した参照回路名の回路
がプログラマブル論理回路104に構成されているか否
かを判別し(ステップS115)、照会した参照回路名
の回路がプログラマブル論理回路104に構成されてい
る場合には、回路情報取得部105からの、その回路配
置アドレスを回路名と共に一時保存する(ステップS1
16)。そして、次のステップS120に進む。
The editing unit 300 is provided with the circuit information obtaining unit 10
5 is used to determine whether the circuit of the reference circuit name inquired is configured in the programmable logic circuit 104 based on the response of the arrangement address of the circuit of the reference circuit name or the absence of the corresponding circuit (step S115). If the circuit with the circuit name is configured in the programmable logic circuit 104, the circuit arrangement address from the circuit information acquisition unit 105 is temporarily stored together with the circuit name (step S1).
16). Then, the process proceeds to the next step S120.

【0124】一方、ステップS115において、照会し
た参照回路名の回路がプログラマブル論理回路104に
構成されていないと判別された場合には、編集部300
は、記憶部200から受け取った参照回路名に対応する
回路が、さらに参照している参照回路名を知るために、
受け取った参照回路名を再び記憶部200に問い合わせ
る(ステップS117)。
On the other hand, if it is determined in step S115 that the circuit having the referred reference circuit name is not configured in the programmable logic circuit 104, the editing unit 300
In order for the circuit corresponding to the reference circuit name received from the storage unit 200 to know the reference circuit name further referred to,
The storage unit 200 is again inquired about the received reference circuit name (step S117).

【0125】この照会に対して、記憶部200は、前述
した図8のフローチャートのステップS121以降を再
び実行して、その参照回路名に対応する回路情報のヘッ
ダ部を調べて、参照回路名が記述されている場合は、参
照回路名を編集部に答え、参照回路名が記述されていな
い場合は、次の処理に移る。
In response to this inquiry, the storage unit 200 executes the steps after step S121 in the flowchart of FIG. 8 again to check the header part of the circuit information corresponding to the reference circuit name, and finds that the reference circuit name is When the reference circuit name is described, the reference circuit name is answered to the editing unit. When the reference circuit name is not described, the process proceeds to the next processing.

【0126】編集部300は、記憶部200に照会した
回路名に参照回路があるか否かを記憶部200からの参
照回路名の返答があるかないかにより判別し(ステップ
S118)、参照回路名の返送があれば、それを取得し
て一時保持する(ステップS119)。参照回路がなけ
れば、次の処理ステップS120に進む。
The editing unit 300 determines whether or not there is a reference circuit in the circuit name inquired of the storage unit 200 based on whether or not there is a reply of the reference circuit name from the storage unit 200 (step S118). Is returned, it is acquired and temporarily stored (step S119). If there is no reference circuit, the process proceeds to the next processing step S120.

【0127】ステップS120では、回路情報取得部1
05から受け取った指定回路の回路情報を生成するため
の全ての参照回路名の、回路情報取得部105や記憶部
200への照会が終了したか否か判別し、終了していな
ければ、ステップS114に戻り、上述の動作を繰り返
す。そして、編集部300は、回路が参照する参照回路
名をすべて知ったら、この参照解決の処理を終了する。
In step S120, the circuit information obtaining section 1
It is determined whether or not the inquiry to the circuit information acquisition unit 105 and the storage unit 200 has been completed for all the reference circuit names for generating the circuit information of the designated circuit received from step S05. And the above operation is repeated. When the editing unit 300 knows all the reference circuit names referred to by the circuits, the editing unit 300 ends the reference resolution processing.

【0128】この編集部300での参照解決の終了によ
り、記憶部200および取得部105でも、参照解決の
処理を終了する(ステップS125およびステップS1
35)。
When the reference resolution is completed by the editing unit 300, the storage unit 200 and the acquisition unit 105 also terminate the reference resolution processing (steps S125 and S1).
35).

【0129】この結果、回路情報取得部105が編集部
300に要求した回路名の回路を構成するために必要な
全ての回路名と、そのうちハードウエア処理部103の
プログラマブル論理回路104に構成されている回路名
とその回路配置アドレスとを、編集部300が入手する
ことができる。
As a result, all the circuit names required to configure the circuit having the circuit name requested by the circuit information acquisition unit 105 to the editing unit 300 and, among them, the programmable logic circuit 104 of the hardware processing unit 103 The editing unit 300 can obtain the name of the circuit and the circuit arrangement address.

【0130】(再配置処理)次に、図6に示すように、
編集部300は、上述の参照解決の処理で得られた情報
に基づいて、記憶部200から回路情報取得部105が
編集部300に要求した回路名の回路情報を生成するた
めに必要な回路情報を取得し、それらの回路情報を結合
して、再配置の処理を行う(ステップS104)。再配
置の処理の手順を図10に示す。
(Relocation Processing) Next, as shown in FIG.
The editing unit 300 uses the circuit information necessary for generating the circuit information of the circuit name requested from the storage unit 200 by the circuit information acquisition unit 105 to the editing unit 300 based on the information obtained in the above-described reference resolution processing. Are acquired, the circuit information is combined, and a rearrangement process is performed (step S104). FIG. 10 shows the procedure of the rearrangement process.

【0131】編集部300は、まず、指定された回路の
回路情報は、プログラマブル論理回路104上にある回
路を利用して生成するか否かを判別し(ステップS14
0)、プログラマブル論理回路に構成されている回路を
利用しない場合には、ステップS142以降を実行す
る。
The editing section 300 first determines whether or not circuit information of a designated circuit is generated by using a circuit on the programmable logic circuit 104 (step S14).
0) If the circuit configured in the programmable logic circuit is not used, step S142 and subsequent steps are executed.

【0132】プログラマブル論理回路104に構成され
ている回路を利用する場合には、記憶部200から取得
したその指定回路名の回路情報の回路データ部203か
ら、利用する回路の参照回路名のアドレス、すなわち、
参照アドレスを抽出し、プログラマブル論理回路104
に構成されている回路の配置アドレスから、その参照ア
ドレスを引くことにより、オフセットアドレスを算出す
る(ステップS141)。
When a circuit configured in the programmable logic circuit 104 is used, the address of the reference circuit name of the circuit to be used is obtained from the circuit data section 203 of the circuit information of the specified circuit name acquired from the storage section 200. That is,
The reference address is extracted, and the programmable logic circuit 104 is extracted.
The offset address is calculated by subtracting the reference address from the arrangement address of the circuit configured in (1) (step S141).

【0133】この処理は、プログラマブル論理回路10
4上の利用する回路の配置位置を変えずに、そのまま利
用することができるようにするため、当該利用する回路
の位置を基準にして、指定回路の、前記利用する回路以
外の他の回路情報を結合して生成するようにするための
ものである。このステップS141の後は、ステップS
142以降に進む。
This processing is performed by the programmable logic circuit 10.
4 so that the circuit to be used can be used without changing the arrangement position of the circuit to be used on the basis of the position of the circuit to be used. Is generated by combining the above. After step S141, step S141
Go to step 142 and subsequent steps.

【0134】なお、ステップS140でプログラマブル
論理回路104上に構成されている回路を利用しない場
合には、オフセットアドレスはゼロアドレス(例えば0
x0000)の状態が保持される。
If the circuit configured on the programmable logic circuit 104 is not used in step S140, the offset address is set to the zero address (for example, 0
(x0000).

【0135】すなわち、編集部300は、回路情報取得
部105から受け取った指定回路の回路情報と、その指
定回路を参照元回路として参照する参照回路の回路情報
を記憶部200に要求する。また、参照回路を参照元回
路として、さらに参照回路があれば、その参照回路の回
路情報も要求し、必要なすべての回路情報を取得する
(ステップS142)。
That is, the editing unit 300 requests the storage unit 200 for the circuit information of the designated circuit received from the circuit information acquisition unit 105 and the circuit information of the reference circuit that refers to the designated circuit as a reference source circuit. In addition, if there is a reference circuit with the reference circuit as a reference source circuit, if there is a reference circuit, circuit information of the reference circuit is also requested, and all necessary circuit information is acquired (step S142).

【0136】ここで、プログラマブル論理回路104に
ある回路の回路情報も記憶部200から取得してもよい
が、この実施の形態の場合には、プログラマブル論理回
路104上に存在すると認識された参照回路の回路情報
は、回線情報の生成に不要であり、その回路情報の記憶
部200から編集部300への転送時間が無駄になるた
め、記憶部200には要求しない。
Here, the circuit information of the circuit in the programmable logic circuit 104 may also be obtained from the storage unit 200. In the case of this embodiment, however, the reference circuit recognized as existing in the programmable logic circuit 104 The circuit information is unnecessary for generation of the line information, and the transfer time of the circuit information from the storage unit 200 to the editing unit 300 is wasted.

【0137】記憶部200は、要求された回路名の回路
情報を編集部300に提供するので、編集部300はこ
れを受け取る(ステップS143)。なお、指定回路の
回路情報は、参照解決の最初の回路名の照会の際に、記
憶部200から取得するようにしてもよい。
The storage unit 200 provides the circuit information of the requested circuit name to the editing unit 300, and the editing unit 300 receives the information (step S143). Note that the circuit information of the designated circuit may be obtained from the storage unit 200 at the time of inquiring the first circuit name for reference resolution.

【0138】以上のようにして、記憶部200から回路
情報を取得すると、編集部300は、その回路は、プロ
グラマブル論理回路104上に存在する回路であるか否
か判別し(ステップS144)、存在しない回路であれ
ば、編集部300は、受け取った参照回路の回路データ
のアドレスに、参照元回路の参照アドレスと、ステップ
S141で算出したオフセットアドレスを加えてオフセ
ットして、参照元の回路情報のコード部に結合する(ス
テップS145)。この処理については、具体例を挙げ
て後で詳述する。
When the circuit information is obtained from the storage unit 200 as described above, the editing unit 300 determines whether or not the circuit is a circuit existing on the programmable logic circuit 104 (step S144). If not, the editing unit 300 adds the reference address of the reference source circuit and the offset address calculated in step S141 to the address of the received circuit data of the reference circuit, and performs offsetting. Link to the code part (step S145). This processing will be described later in detail with a specific example.

【0139】なお、このステップS145では、ステッ
プS140でプログラマブル論理回路104上に構成さ
れている回路を利用しないとされた場合には、オフセッ
トアドレスがゼロアドレスであるので、このゼロアドレ
スがオフセットアドレスとして加算される。つまり、オ
フセットアドレスは加算されない。
In step S145, if it is determined in step S140 that the circuit formed on the programmable logic circuit 104 is not used, the offset address is a zero address. Is added. That is, the offset address is not added.

【0140】以上の結合の結果、生成される回路が、プ
ログラマブル論理回路104上の回路構成領域に収まる
か否か判別し(ステップS146)、収まらなければ、
ステップS147に進んで、再配置の処理をすべてやり
直す。すなわち、プログラマブル論理回路104上に構
成されている回路は利用できないので、当該利用しよう
とした回路部分をも含めて、再配置をやり直す。そし
て、この再配置の処理ルーチンを終了する。
As a result of the above combination, it is determined whether or not the generated circuit fits in the circuit configuration area on the programmable logic circuit 104 (step S146).
Proceeding to step S147, all the rearrangement processes are redone. That is, since the circuit configured on the programmable logic circuit 104 cannot be used, the rearrangement is performed again including the circuit portion to be used. Then, the rearrangement processing routine ends.

【0141】また、ステップS144で、参照回路がプ
ログラマブル論理回路104に構成されていると判別さ
れた場合には、回路データを参照元の回路情報のコード
部に結合するステップS145は行わずに、ステップS
146に進む。
If it is determined in step S144 that the reference circuit is constituted by the programmable logic circuit 104, step S145 for linking the circuit data to the code part of the circuit information of the reference source is not performed, and Step S
Proceed to 146.

【0142】ステップS146で、結合後の回路がプロ
グラマブル論理回路104上の回路構成領域に収まると
判断されたときには、ステップS148に進む。編集部
300では、ステップS148においては、参照アドレ
スから、あるいはプログラマブル論理回路104の回路
を利用する場合には、参照アドレスと前記オフセットア
ドレスとから、参照回路の入出力ポート位置のオフセッ
トセル座標を算出して、参照回路の入出力ポート位置座
標にオフセットセル座標を加えて、参照元回路の回路情
報のヘッダ部に結合する。この処理についても、具体例
について後で詳述する。
If it is determined in step S146 that the combined circuit fits in the circuit configuration area on the programmable logic circuit 104, the flow advances to step S148. In step S148, the editing unit 300 calculates the offset cell coordinates of the input / output port position of the reference circuit from the reference address or, if the circuit of the programmable logic circuit 104 is used, from the reference address and the offset address. Then, the offset cell coordinates are added to the input / output port position coordinates of the reference circuit, and the result is coupled to the header part of the circuit information of the reference source circuit. As for this processing, a specific example will be described later in detail.

【0143】編集部300は、全ての回路名に対して上
記の手順が行われるまで、上記の手順を繰り返す(ステ
ップS149)。
The editing section 300 repeats the above procedure until the above procedure is performed for all circuit names (step S149).

【0144】以上のようにして再配置の処理が終わる
と、図6に示すように、編集部300は、生成した回路
情報を、回路情報取得部105へ提供する(ステップS
105)。この生成された回路情報は、プログラマブル
論理回路104上の回路を利用する場合には、ステップ
S145がバイパスされるため、その回路部分の回路情
報は含まない。
When the rearrangement process is completed as described above, as shown in FIG. 6, the editing unit 300 provides the generated circuit information to the circuit information acquisition unit 105 (Step S).
105). When the circuit on the programmable logic circuit 104 is used, the generated circuit information does not include the circuit information of the circuit part because the step S145 is bypassed.

【0145】(ロード)回路情報取得部105は、編集
部300から入手した回路情報のコード部に記述されて
いる回路データを、ハードウエア処理部103にロード
して、プログラマブル論理回路104に回路を再構成し
(ステップS106)、ヘッダ部に記述されている入出
力ポート情報を、アプリケーションプログラム101に
提供する(ステップS107)。
(Load) The circuit information acquisition unit 105 loads the circuit data described in the code part of the circuit information obtained from the editing unit 300 into the hardware processing unit 103 and stores the circuit data in the programmable logic circuit 104. Reconfigure (step S106), and provide the input / output port information described in the header section to the application program 101 (step S107).

【0146】プログラマブル論理回路104に存在して
いた回路を利用する状態で、回路情報が生成された場合
には、前記存在していた回路は、そのままに、その回路
部分に他の回路部分が結合する形態で、指定された回路
がプログラマブル論理回路104上に形成される。そし
て、この形成された回路の配置アドレスを含む回路情報
が、構成回路メモリ106に記憶される。
When circuit information is generated in a state where a circuit existing in the programmable logic circuit 104 is used, another circuit part is coupled to the existing circuit as it is. In this manner, the specified circuit is formed on the programmable logic circuit 104. Then, the circuit information including the arrangement address of the formed circuit is stored in the constituent circuit memory 106.

【0147】(アプリケーションによる処理)ハードウ
エア処理部103は、入出力ポート情報に基づいたアプ
リケーションプログラム101からの制御コードに従っ
て、プログラマブル論理回路104に再構成された回路
とデータの入出力を行い、プログラマブル論理回路10
4に再構成された回路を用いた情報処理を行う(ステッ
プS108)。
(Processing by Application) The hardware processing unit 103 inputs and outputs data to and from the reconfigured circuit in the programmable logic circuit 104 according to the control code from the application program 101 based on the input / output port information. Logic circuit 10
Then, information processing using the circuit reconfigured as No. 4 is performed (step S108).

【0148】[情報処理システムによる処理の実施例:
線画処理]次に、上述の実施の形態の情報処理システム
を、画像処理に適用したより詳細な実施例について説明
する。この実施例では、2値化処理、エッジ検出処理お
よび反転処理の三種類の処理を、次に説明する三種類の
画像フィルタを用いて画像データに行うことにより多階
調画像を線画像に変換する線画処理の場合を示す。以下
に説明する場合は、上記のエッジ検出処理で用いられる
回路名「Laplace」のエッジ検出回路が、ハード
ウエア処理部103のプログラマブル論理回路104
に、すでに、構成されている場合である。始めに、上記
の三種類の画像フィルタについて説明する。
[Example of Processing by Information Processing System:
Line Drawing Processing] Next, a more detailed example in which the information processing system of the above embodiment is applied to image processing will be described. In this embodiment, a multi-tone image is converted into a line image by performing three types of processing, namely, binarization processing, edge detection processing, and inversion processing on image data using three types of image filters described below. This is the case of the line drawing process. In the following description, the edge detection circuit having the circuit name “Laplace” used in the above-described edge detection processing is replaced with the programmable logic circuit 104 of the hardware processing unit 103.
In this case, it is already configured. First, the above three types of image filters will be described.

【0149】[フィルタの説明]画像処理のひとつであ
る空間フィルタ処理は、単位画素から構成される画像フ
ァイルの単一もしくは複数画素に対して演算を行う。こ
れは、ある画素(データxl,m )の近傍の画素(データ
l,m )に、マスクデータfilterl,m を掛けて足し合わ
せ、係数Nを乗じたものを処理後の画素値xl,m として
得る処理として、次の式(1)のように表すことができ
る。ここで、マスクデータfilterl,m や係数Nの値を変
えることにより、空間フィルタは様々な処理を実行する
ことが可能である。
[Explanation of Filter] In the spatial filter processing which is one of the image processing, an operation is performed on one or a plurality of pixels of an image file composed of unit pixels. This is the pixel (data x l, m) near the pixel (data p l, m) of the mask data filter l, summed over the m, the pixel value x after processing are multiplied by coefficients N The processing to be obtained as l and m can be expressed as in the following equation (1). Here, the spatial filter can execute various processes by changing the values of the mask data filter l, m and the coefficient N.

【0150】 xl,m =N×{l-1〜l+1}Σ{m-1〜m+1}Σ(pl,m ×filterl,m ) …(1) ただし、{l-1〜l+1}Σ()は、()内の値の、(l-1) か
ら(l+1) までの総和の演算を意味し、同様に、{m-1〜m+
1}Σ()は、()内の値の、(m-1) から(m+1)までの総
和の演算を意味している。
X l, m = N × {l−1 to l + 1} {{m−1 to m + 1}} (p l, m × filter l, m ) (1) where {l− 1 ~ l + 1} Σ () means the summation of the values in () from (l-1) to (l + 1). Similarly, {m-1 to m +
1} Σ () means the operation of the sum of the values in () from (m-1) to (m + 1).

【0151】(エッジ検出Laplacianフィル
タ)図11は、2次微分によりエッジを検出するLap
lacianフィルタと呼ばれる画像フィルタのマスク
データの例である。このフィルタ処理を施すことによ
り、画像の輪郭検出を行うことができる。
(Edge detection Laplacian filter) FIG. 11 shows a Lap detection filter for detecting an edge by the second derivative.
It is an example of mask data of an image filter called a lacian filter. By performing this filter processing, it is possible to detect an outline of an image.

【0152】図12は、図11のLaplacianフ
ィルタ処理を実現する回路(回路名Laplace)の
回路構成の一例である。まず、元の画像ファイルからフ
ィルタ処理を行うマスク領域のうち、p[l][m],p[l-
1][m],p[l][m-1],p[l][m+1],p[l+1][m]の5画素
分のデータを、例えば1画素あたり8ビットデータとし
て、回路に転送する。
FIG. 12 shows an example of a circuit configuration of a circuit (circuit name Laplace) for realizing the Laplacian filter processing of FIG. First, p [l] [m] and p [l-
1] [m], p [l] [m-1], p [l] [m + 1], p [l + 1] [m] for 5 pixel data, for example, 8 bit data per pixel To the circuit.

【0153】転送された5画素分のデータは、回路の入
力ポートLaplaceIn0、LaplaceIn
1、LaplaceIn2、LaplaceIn3、L
aplaceIn4にそれぞれ入力され、最初のクロッ
クでレジスタ301、302、303、304、305
に入力される。入力されたデータは、レジスタの出力D
1、D2、D3、D4、D5とされ、出力D1とD2が
加算器311に入力され、出力D3とD4が加算器31
2に入力される。そして、加算器311、312および
313による演算によって、加算器313の出力A13
は、 A13=p[l-1][m]+p[l][m-1]+p[l][m+1]+p[l+
1][m] となる。
The transferred data for five pixels is input to the input ports LaplaceIn0 and LaplaceIn of the circuit.
1, LaplaceIn2, LaplaceIn3, L
Each of the registers 301, 302, 303, 304, and 305 is input to the
Is input to The input data is the output D of the register.
1, D2, D3, D4, and D5, outputs D1 and D2 are input to an adder 311, and outputs D3 and D4 are added to an adder 31.
2 is input. The output A13 of the adder 313 is calculated by the adders 311, 312 and 313.
A13 = p [l-1] [m] + p [l] [m-1] + p [l] [m + 1] + p [l +
1] [m].

【0154】一方、シフタ321は、レジスタ305の
出力D5を上位に2ビットシフトして接続し、下位2ビ
ットは常に0を入力することで、シフタ321の出力A
14は、 A14=4×p[l][m] となる。
On the other hand, the shifter 321 shifts the output D5 of the register 305 upward by 2 bits and connects it, and always inputs 0 to the lower 2 bits.
14 is A14 = 4 × p [l] [m].

【0155】そして、減算器314によりシフタ321
の出力A14から、加算器313の出力A13の減算が
行われ、この減算器314の出力A15は、A15=4
×p[l][m]−(p[l-1][m]+p[l][m-1]+p[l]
[m+1]+p[l+1][m])となり、結果が出力ポートLap
laceOut0に出力される。以上で、単位マスク領
域でのLaplacianフィルタ処理が終了する。以
降この処理を繰り返すことで、画像全体の処理が施され
る。
The shifter 321 is operated by the subtractor 314.
Is subtracted from the output A14 of the adder 313, and the output A15 of the subtractor 314 is A15 = 4
× p [l] [m]-(p [l-1] [m] + p [l] [m-1] + p [l]
[m + 1] + p [l + 1] [m]), and the result is output port Lap
It is output to placeOut0. Thus, the Laplacian filter processing in the unit mask area is completed. Thereafter, by repeating this processing, processing of the entire image is performed.

【0156】(2値化Binaryフィルタ)図13
は、2値化フィルタ処理を実現する回路(回路名Bin
ary)の回路構成例を示すものである。この例では、
1画素当りのデータが8ビットの画像データを処理す
る。また、用いるプログラマブル論理回路104の論理
セルは、入出力とも8ビットの信号線を持つ。よって、
以下に示す8ビットのレジスタと、インバータとは、ひ
とつの論理セルで実現され、8ビットのコンパレータと
セレクタとは、ふたつの論理セルで実現される。
(Binary Binary Filter) FIG.
Is a circuit for realizing the binarization filter processing (circuit name Bin)
2) shows an example of the circuit configuration of FIG. In this example,
Data per pixel processes image data of 8 bits. The logic cell of the programmable logic circuit 104 used has an input / output signal line of 8 bits. Therefore,
An 8-bit register and an inverter described below are realized by one logical cell, and an 8-bit comparator and selector are realized by two logical cells.

【0157】図13において、1画素分のデータが、入
力ポートBinaryIn0に入力され、最初のクロッ
クでレジスタ401に保持される。レジスタ402に
は、事前に2値化の閾値となる値が保持されている。
In FIG. 13, data for one pixel is input to the input port BinaryIn0, and is held in the register 401 at the first clock. The register 402 holds a value that is a threshold value for binarization in advance.

【0158】次のクロックで、コンパレータ403は、
レジスタ401に保持されている入力データと、レジス
タ402に保持されている閾値を比較する。もし、入力
データの値が閾値より小さいときは、「<」出力がロー
レベル状態となる。それ以外の場合は、「<」出力はデ
フォルトのハイレベル状態を保持する。
At the next clock, the comparator 403
The input data held in the register 401 is compared with the threshold value held in the register 402. If the value of the input data is smaller than the threshold, the “<” output is in a low level state. Otherwise, the "<" output retains the default high state.

【0159】コンパレータ403の「<」出力は、セレ
クタ404のS入力へ入力される。S入力がハイレベル
状態のときは、8ビットの「0xFF(16進表示)」
が入力されているA入力の値が8ビットのY出力から出
力され、S入力がローレベル状態のときは、8ビットの
「0x00」が入力されているB入力の値が8ビットの
Y出力から出力される。
The “<” output of the comparator 403 is input to the S input of the selector 404. When the S input is in the high level state, the 8-bit “0xFF (hexadecimal notation)”
Is output from the 8-bit Y output, and when the S input is in a low level state, the value of the B input to which 8-bit "0x00" is input is changed to the 8-bit Y output. Output from

【0160】すなわち、入力データが閾値より小さいと
きは、セレクタ404のS入力がローレベル状態となっ
て、Y出力が接続されているBinaryOut0よ
り、8ビットの「0x00」が出力され、それ以外の場
合は、セレクタ404のS入力がハイレベル状態となっ
て、Y出力が接続されているBinaryOut0よ
り、8ビットの「0xFF」が出力されることにより、
画素が2値化される。
That is, when the input data is smaller than the threshold value, the S input of the selector 404 goes to a low level state, and BinaryOut0 to which the Y output is connected outputs 8-bit "0x00". In this case, the S input of the selector 404 becomes a high level state, and 8-bit “0xFF” is output from BinaryOut0 to which the Y output is connected.
Pixels are binarized.

【0161】(反転Inverseフィルタ)図14
は、反転処理を実現する回路(回路名Inverse)
の回路構成例を示すものである。この実施例では、1画
素当りのデータが8ビットの画像データを処理する。
(Inverted Inverse Filter) FIG.
Is a circuit that implements inversion processing (circuit name Inverse)
2 shows an example of the circuit configuration of FIG. In this embodiment, image data of 8 bits per pixel is processed.

【0162】図14において、1画素分のデータが、入
力ポートInverseIn0に入力され、データ各ビ
ットの値を反転したデータがInverseOut0か
ら出力される。すなわち、画素が反転される。
In FIG. 14, data for one pixel is input to the input port InverseIn0, and data obtained by inverting the value of each data bit is output from InverseOut0. That is, the pixels are inverted.

【0163】[FPGAタイプのプログラマブル論理回
路のアドレス構成]この実施例で用いるFPGAタイプ
のプログラマブル論理回路は、列方向に32個を、ま
た、行方向に32個を、それぞれ配置した合計1024
個の論理セルで構成される。ひとつの論理セルは、64
アドレスのコンフィギュレーションメモリで設定され、
1アドレスのコンフィギュレーションメモリは8ビット
のデータを保持する。すなわち、ひとつの論理セルは、
64バイトの回路データで設定される。
[Address Configuration of FPGA-type Programmable Logic Circuit] The FPGA-type programmable logic circuit used in this embodiment has a total of 1024 in which 32 are arranged in the column direction and 32 are arranged in the row direction.
It is composed of logic cells. One logic cell is 64
Is set in the configuration memory of the address,
The configuration memory of one address holds 8-bit data. That is, one logic cell is
It is set with 64 bytes of circuit data.

【0164】図15にコンフィギュレーションメモリの
アドレス設定の方法を示す。プログラマブル論理回路の
セル座標は、左下を原点(0,0)として定義される。
ひとつの論理セルを設定するコンフィギュレーションメ
モリは、8×8のメモリ空間に対応し、プログラマブル
論理空間全体で256×256のメモリ空間を構成す
る。アドレスは、16ビットアドレスで「0x000
0」を開始アドレスとして、セル座標の原点(0,0)
から「0xFFFF」まで定義される。
FIG. 15 shows a method of setting the address of the configuration memory. The cell coordinates of the programmable logic circuit are defined with the lower left as the origin (0,0).
The configuration memory for setting one logic cell corresponds to an 8 × 8 memory space, and the entire programmable logic space forms a 256 × 256 memory space. The address is a 16-bit address "0x000
0 ”as the start address, the origin of the cell coordinates (0, 0)
To “0xFFFF”.

【0165】このとき、アドレスとセル座標は次の関係
を持つ。すなわち、図15の表に示すように、16ビッ
トアドレスA[15:0]の上位8ビットA[15:
8]が、256×256のメモリ空間の列アドレスに、
下位8ビットA[7:0]が、当該メモリ空間の行アド
レスに、それぞれ対応する。
At this time, the address and the cell coordinates have the following relationship. That is, as shown in the table of FIG. 15, the upper 8 bits A [15:] of the 16-bit address A [15: 0].
8] at the column address of the 256 × 256 memory space,
The lower 8 bits A [7: 0] correspond to the row addresses in the memory space, respectively.

【0166】そして、16ビットアドレスA[15:
0]の5ビットA[15:11](8ビットの列アドレ
スの上位5ビット)が列セル座標に、3ビットA[1
0:8](8ビットの列アドレスの下位3ビット)が列
メモリ座標に、それぞれ対応する。また、16ビットア
ドレスA[15:0]の5ビットA[7:3](8ビッ
トの行アドレスの上位5ビット)が行セル座標に、3ビ
ットA[2:0](8ビットの行アドレスの下位3ビッ
ト)が行メモリ座標に、それぞれ対応する。この関係を
用いることにより、参照アドレスから入出力ポート情報
のオフセットセル座標を簡単に知ることができる。
Then, the 16-bit address A [15:
0] is the 3 bits A [1] in the column cell coordinates.
0: 8] (lower 3 bits of an 8-bit column address) respectively correspond to column memory coordinates. Also, 5-bit A [7: 3] of the 16-bit address A [15: 0] (upper 5 bits of the 8-bit row address) is used as 3-bit A [2: 0] (8-bit row The lower 3 bits of the address) correspond to the row memory coordinates, respectively. By using this relationship, the offset cell coordinates of the input / output port information can be easily known from the reference address.

【0167】(線画処理の手順)次に、線画処理を行う
アプリケーションプログラム101の処理手順を説明す
る。アプリケーションプログラム101は、図16に示
すように、線画処理に先立って、別の画像処理を行い、
プログラマブル論理回路104のアドレス「0x201
8」にエッジ検出回路(回路名Laplace)を構成
している。図16の回路名「画像処理」の回路情報は、
回路情報取得部105の構成回路メモリ106に記憶さ
れている内容に等しい。
(Procedure of Line Drawing Processing) Next, the processing procedure of the application program 101 for performing line drawing processing will be described. The application program 101 performs another image processing prior to the line drawing processing as shown in FIG.
The address “0x201” of the programmable logic circuit 104
8 "constitutes an edge detection circuit (circuit name" Laplace "). The circuit information of the circuit name “image processing” in FIG.
It is equal to the contents stored in the constituent circuit memory 106 of the circuit information acquisition unit 105.

【0168】(線画処理参照解決)アプリケーションプ
ログラム101は、回路情報取得部105に、線画処理
の回路名「LineArt」を伝えて、ハードウエア処
理部103に、線画処理回路を構成するように指示する
(前述の図6のステップS101)。
(Line Image Processing Reference Solution) The application program 101 transmits the circuit name “LineArt” of the line image processing to the circuit information acquisition unit 105 and instructs the hardware processing unit 103 to configure the line image processing circuit. (Step S101 in FIG. 6 described above).

【0169】すると、前述したように、回路情報取得部
105は、線画処理の回路名「LineArt」を編集
部300に伝え、編集部300は、図6、図7、図8、
図9および図10に示した手順に従って、参照解決処理
と再配置処理を行い、記憶部200に記憶されている回
路情報を用いて、線画処理の回路の回路情報を生成す
る。
Then, as described above, the circuit information acquisition unit 105 transmits the circuit name “LineArt” of the line drawing processing to the editing unit 300, and the editing unit 300
According to the procedure shown in FIGS. 9 and 10, reference resolution processing and rearrangement processing are performed, and circuit information of a circuit for line drawing processing is generated using circuit information stored in the storage unit 200.

【0170】この例の場合、図16に示すように、回路
名「LineArt」の回路情報には、参照回路名「B
inary」、「Laplace」および「Inver
se」が、そのヘッダ部に記述されており、そして、コ
ード部(回路データ部)には、回路名「Binary」
を、参照アドレス「0x0000」、「0x001
0」、「0x0020」、「0x0030」、「0x0
040」において、回路名「Laplace」を、アド
レス「0x1800」において、回路名「Invers
e」を、アドレス「0x3800」において、それぞれ
参照するように記述されている。
In the case of this example, as shown in FIG. 16, the circuit information of the circuit name “LineArt” includes the reference circuit name “B
inary "," Laplace "and" Inver "
“se” is described in the header portion, and the code portion (circuit data portion) has a circuit name “Binary”.
With reference addresses “0x0000”, “0x001”
0, 0x0020, 0x0030, 0x0
040 ”and the circuit name“ Inverses ”at the address“ 0x1800 ”.
"e" is described at an address "0x3800" so as to be referred to.

【0171】このため、参照解決の処理(図6のステッ
プS103、図7〜図9参照)において、記憶部200
は、編集部300からの回路名「LineArt」の照
会に対して、参照回路名「Binary」、「Lapl
ace」および「Inverse」を返す。
Therefore, in the reference solution processing (step S103 in FIG. 6, see FIGS. 7 to 9), the storage unit 200
Responds to the inquiry of the circuit name “LineArt” from the editing unit 300, by referring to the reference circuit names “Binary” and “Lapl”.
ace "and" Inverse ".

【0172】次に、編集部300は、この記憶部200
から取得した参照回路名を用いて、それらの参照回路名
の回路が、ハードウエア処理部103のプログラマブル
論理回路104上に構成されていないかを、回路情報取
得部105に照会する(ステップS114)。
Next, the editing unit 300 stores the data in the storage unit 200
Inquiry is made to the circuit information acquisition unit 105 as to whether or not the circuits having the reference circuit names are configured on the programmable logic circuit 104 of the hardware processing unit 103 using the reference circuit names acquired from (step S114). .

【0173】もし、参照回路がプログラマブル論理回路
104上に構成されていれば、編集部300は、その配
置アドレスを取得保持した後(ステップS116)、次
の参照回路が、プログラマブル論理回路104上に構成
されていないかを、回路情報取得部105に照会する。
If the reference circuit is configured on the programmable logic circuit 104, the editing unit 300 acquires and holds the arrangement address (step S116), and then places the next reference circuit on the programmable logic circuit 104. An inquiry is made to the circuit information acquisition unit 105 as to whether or not it is configured.

【0174】また、もし、参照回路がプログラマブル論
理回路104上に構成されていなければ、参照回路がさ
らに他の回路を参照していないかを記憶部200に照会
する(ステップS117)。この照会の結果、他の回路
を参照していれば、その参照回路に対しても、上述の参
照解決の処理を行う。すべての参照回路に対して参照解
決の処理を行った時点で、参照解決が終了する。
If the reference circuit is not configured on the programmable logic circuit 104, the storage unit 200 is inquired as to whether the reference circuit refers to another circuit (step S117). As a result of this inquiry, if another circuit is referred to, the above-described reference resolution processing is performed for the reference circuit. When the reference resolution processing is performed on all the reference circuits, the reference resolution ends.

【0175】この実施例の場合は、始めに、回路名「B
inary」の2値化回路についてを、プログラマブル
論理回路104上に構成されているかを調べる。この例
の場合、回路名「Bianry」の2値化回路は、プロ
グラマブル論理回路104上に構成されていないので、
回路情報取得部105は、その旨を編集部300に返
す。そこで、編集部300は、記憶部200に、その回
路名「Bianry」についての参照回路の照会を行
う。このとき、回路名「Binary」の2値化回路
は、他の回路を参照していないので、記憶部200から
参照回路名は編集部300には帰ってこない。
In the case of this embodiment, first, the circuit name "B
It is checked whether the binary circuit of “inary” is configured on the programmable logic circuit 104. In the case of this example, since the binarization circuit with the circuit name “Bianry” is not configured on the programmable logic circuit 104,
The circuit information acquisition unit 105 returns the fact to the editing unit 300. Therefore, the editing unit 300 inquires the storage unit 200 of a reference circuit for the circuit name “Bianry”. At this time, since the binarized circuit with the circuit name “Binary” does not refer to another circuit, the reference circuit name from the storage unit 200 does not return to the editing unit 300.

【0176】次に、編集部300は、回路名「Lapl
ace」のエッジ検出回路を、回路情報取得部105に
照会すると、それは、プログラマブル論理回路104上
に存在するので、回路情報取得部105は、その配置ア
ドレス「0x2018」を編集部300に返す。そこ
で、編集部300は、回路名「Laplace」の回路
は、プログラマブル論理回路104上に在ることを認識
し、その配置アドレスを取得して、保持する(図7のス
テップS115、S116)。このエッジ検出回路「L
aplace」についての記憶部200への参照回路の
照会は、プログラマブル論理回路104に、この回路が
存在するため、必要ないので行われない。
Next, the editing unit 300 outputs the circuit name "Lapl
When the circuit information acquisition unit 105 is queried for the edge detection circuit of “ace”, the circuit information acquisition unit 105 returns the layout address “0x2018” to the editing unit 300 because it exists on the programmable logic circuit 104. Therefore, the editing unit 300 recognizes that the circuit with the circuit name “Laplace” exists on the programmable logic circuit 104, acquires and stores the arrangement address (steps S115 and S116 in FIG. 7). This edge detection circuit “L
Inquiry of the reference circuit to the storage unit 200 for “place” is not performed because the programmable logic circuit 104 does not need this reference because this circuit exists.

【0177】最後に、編集部300は、回路名「Inv
erse」の反転回路を回路情報取得部105に照会す
ると、それはプログラマブル論理回路104上に構成さ
れていないので、編集部300には、その旨の返事が帰
ってくる。そこで、編集部300は、記憶部200に、
回路名「Invers」を照会すると、回路名「Inv
erse」の反転回路は他の回路を参照していないの
で、参照回路名は帰ってこない。以上で、すべての参照
回路に対する照会が終わったので、参照解決を終了す
る。
[0177] Finally, the editing unit 300 outputs the circuit name "Inv
When the circuit information obtaining unit 105 is inquired of the inversion circuit of “erse”, since it is not configured on the programmable logic circuit 104, a reply to that effect is returned to the editing unit 300. Therefore, the editing unit 300 stores in the storage unit 200
When the circuit name “Invers” is queried, the circuit name “Inv”
The reference circuit name does not return because the inversion circuit of "erse" does not refer to another circuit. As described above, the reference to all the reference circuits has been completed, and the reference resolution ends.

【0178】(線画処理再配置)編集部300は、2値
化回路「Binary」、エッジ検出回路「Lapla
ce」、反転回路「Inverse」のそれぞれの回路
の参照関係に基づいて、各回路モジュールの相対関係を
決定する。
(Line drawing processing rearrangement) The editing unit 300 includes a binarization circuit “Binary” and an edge detection circuit “Lapla”.
ce ”and the inversion circuit“ Inverse ”, the relative relationship of each circuit module is determined based on the reference relationship of the respective circuits.

【0179】すなわち、エッジ検出回路「Laplac
e」は、すでに、処理部103のプログラマブル論理回
路104の配置アドレス「0x2018」に構成されて
いるので、編集部300は、残りの2値化回路「Bin
ary」、反転回路「Inverse」の回路情報を記
憶部200から取得し、相対位置関係に基づいて各回路
モジュールの回路情報の位置座標を平行移動する。
That is, the edge detection circuit “Laplac”
Since “e” is already configured at the arrangement address “0x2018” of the programmable logic circuit 104 of the processing unit 103, the editing unit 300 outputs the remaining binarization circuit “Bin
ary ”and the circuit information of the inversion circuit“ Inverse ”are acquired from the storage unit 200, and the position coordinates of the circuit information of each circuit module are translated based on the relative positional relationship.

【0180】回路情報は再配置可能な形式で記述されて
いるので、エッジ検出回路「Laplace」の配置位
置を基準にした回路モジュールの原点位置に対応するオ
フセットアドレスを求める(図10のステップS14
1)。
Since the circuit information is described in a relocatable format, an offset address corresponding to the origin position of the circuit module based on the position of the edge detection circuit "Laplace" is obtained (step S14 in FIG. 10).
1).

【0181】この実施例の場合には、このオフセットア
ドレスは、(0x2018−0x1800=0x081
8)である。参照回路のそれぞれの配置アドレスは、こ
のオフセットアドレスと参照アドレスとを加算すること
により得る。
In the case of this embodiment, this offset address is (0x2018-0x1800 = 0x081).
8). Each location address of the reference circuit is obtained by adding the offset address and the reference address.

【0182】すなわち、回路名「LineArt」の回
路情報は、図16に示すように構成されているので、5
個の2値化回路「Binary」は、それぞれ、「0x
0000+0x0818」、「0x0010+0x08
18」、「0x0020+0x0818」、「0x00
30+0x0818」、「0x0040+0x081
8」だけ、それぞれアドレスをオフセットして配置アド
レスを定め、また、反転回路「Inverse」は、
「0x3800+0x0818」だけオフセットして配
置アドレスを定め、それぞれ回路名「LineArt」
の回路情報として結合する。
That is, since the circuit information of the circuit name “LineArt” is configured as shown in FIG.
Of the binarization circuits “Binary” are “0x
0000 + 0x0818 "," 0x0010 + 0x08
18 "," 0x0020 + 0x0818 "," 0x00
30 + 0x0818 "," 0x0040 + 0x081 "
8 "to determine the arrangement address by offsetting the address, and the inverting circuit" Inverse "
The layout address is determined by offsetting by “0x3800 + 0x0818”, and the circuit name is respectively “LineArt”
As circuit information.

【0183】この場合、エッジ検出回路「Laplac
e」は、プログラマブル論理回路104上の配置アドレ
ス「0x1800+0x0818=0x0218」に存
在するので、この部分は、回路名「LineArt」の
回路情報では、回路情報がなく、空間となるが、入出力
ポートについては、結合されているので(ステップS1
46)、プログラマブル論理回路104上では、3つの
回路は、結合されて、線画処理回路が生成されることに
なる。
In this case, the edge detection circuit “Laplac
Since “e” exists at the arrangement address “0x1800 + 0x0818 = 0x0218” on the programmable logic circuit 104, this part is a space without circuit information in the circuit information of the circuit name “LineArt”. Are combined (step S1
46) On the programmable logic circuit 104, the three circuits are combined to generate a line drawing processing circuit.

【0184】以上のようにして、再配置を終了した2値
化回路「Binary」の回路データと、反転回路「I
nverse」の回路データと、プログラマブル論理回
路に構成されいるエッジ検出回路「Laplace」に
対応する空間とから成る回路情報全体を、線画処理回路
「LineArt」として、回路情報取得部105に転
送する。回路情報取得部105では受け取った回路情報
を、プログラマブル論理回路104にダウンロードし、
回路再構成を行う。
As described above, the circuit data of the binarization circuit “Binary” for which the rearrangement has been completed and the inversion circuit “I”
The entire circuit information including the circuit data of “nverse” and the space corresponding to the edge detection circuit “Laplace” configured in the programmable logic circuit is transferred to the circuit information acquisition unit 105 as a line drawing processing circuit “LineArt”. The circuit information acquisition unit 105 downloads the received circuit information to the programmable logic circuit 104,
Perform circuit reconfiguration.

【0185】これにより、前述したように、2値化回路
「Binary」と、エッジ検出回路「Laplac
e」と、反転回路「Inverse」とからなる線画処
理回路「LineArt」がプログラマブル論理回路1
04上に生成される。プログラマブル論理回路104上
に構成された線画処理回路「LineArt」を、図1
7に示す。
Thus, as described above, the binarization circuit "Binary" and the edge detection circuit "Laplac"
e) and a line drawing processing circuit “LineArt” composed of an inversion circuit “Inverse”
04. A line drawing processing circuit “LineArt” configured on the programmable logic circuit 104 is shown in FIG.
FIG.

【0186】(線画処理アプリケーション実行)以上
で、アプリケーションプログラム101が要求した線画
処理回路が、プログラマブル論理回路104上に再構成
されたので、この回路を使って、処理を実行すること
で、所望の線画処理を行われる。
(Execution of Line Drawing Processing Application) Since the line drawing processing circuit requested by the application program 101 has been reconfigured on the programmable logic circuit 104, by executing processing using this circuit, a desired processing is performed. Line drawing processing is performed.

【0187】[他の実施の形態]上述の実施の形態にお
ける参照解決の処理では、編集部300が、回路情報取
得部105に参照回路がプログラマブル論理回路104
上に構成されているかどうかを照会するようにしたが、
参照解決の処理は、次のようにすることもできる。
[Other Embodiments] In the reference resolution processing in the above-described embodiment, the editing section 300 causes the circuit information acquisition section 105 to change the reference circuit to the programmable logic circuit 104.
Query whether it is configured above,
The reference resolution processing can also be performed as follows.

【0188】すなわち、回路情報取得部105は、プロ
グラマブル論理回路104上に構成されている回路の情
報を構成回路メモリ106に格納しているので、アプリ
ケーションプログラム101からの回路の指定情報を受
け、編集部300に、当該回路の生成を要求するとき
に、プログラマブル論理回路104上に構成されている
回路名および配置アドレス情報を併せて、編集部300
に通知することができる。これにより、編集部300か
らの回路情報取得部105への照会を無くすことができ
る。
That is, since the circuit information acquiring unit 105 stores the information of the circuits configured on the programmable logic circuit 104 in the constituent circuit memory 106, the circuit information acquiring unit 105 receives the circuit designation information from the application program 101 and edits the information. When requesting the unit 300 to generate the circuit, the editing unit 300 adds together the circuit name and arrangement address information configured on the programmable logic circuit 104.
Can be notified. Thereby, the inquiry from the editing unit 300 to the circuit information acquisition unit 105 can be eliminated.

【0189】この場合には、編集部300は、回路情報
取得部105から通知された回路名および配置アドレス
の情報を記憶するための内部記憶部が必要になる。この
場合の参照解決の手順は、参照回路が処理部103のプ
ログラマブル論理回路104上に構成されているかどう
かを、回路情報取得部105に照会する代わりに、内部
記憶部に照会する以外は上述の手順と同じである。
In this case, the editing unit 300 needs an internal storage unit for storing the information of the circuit name and the arrangement address notified from the circuit information acquisition unit 105. The reference resolution procedure in this case is the same as that described above except that the reference circuit is configured on the programmable logic circuit 104 of the processing unit 103, instead of querying the circuit information acquisition unit 105, instead of querying the internal storage unit. Same as the procedure.

【0190】また、上述の実施の形態の説明では、プロ
グラマブル論理回路104上に、アプリケーションプロ
グラム101により指定された回路を構成する参照回路
が、プログラマブル論理回路104上に構成されている
場合についてのみ言及したが、指定された回路そのもの
がプログラマブル論理回路104上に構成されている場
合には、編集部300では、回路情報を再構成する必要
は全くなく、そのプログラマブル論理回路104上に存
在する回路を、そのまま利用することができる。
In the above description of the embodiment, reference is made only to the case where the reference circuit constituting the circuit specified by the application program 101 is formed on the programmable logic circuit 104. However, when the specified circuit itself is configured on the programmable logic circuit 104, the editing unit 300 does not need to reconfigure the circuit information at all, and the circuit existing on the programmable logic circuit 104 is deleted. , Can be used as is.

【0191】すなわち、回路情報取得部105は、ハー
ドウエア処理部103のプログラマブル論理回路104
上に構成されている回路の情報を、構成回路メモリ10
6に保持しているので、回路情報取得部105は、アプ
リケーションプログラム101からの指定情報で指定さ
れる回路が、構成回路メモリ106上に存在する回路で
あるかどうかを検知することができる。
That is, the circuit information acquisition unit 105 is the programmable logic circuit 104 of the hardware processing unit 103.
The information of the circuit configured above is stored in the constituent circuit memory 10.
6, the circuit information acquisition unit 105 can detect whether the circuit specified by the specification information from the application program 101 is a circuit existing on the component circuit memory 106.

【0192】そして、もしも、指定された回路が、プロ
グラマブル論理回路104に存在するときには、上述し
たような編集部300への回路情報の編集指示を行う必
要はなく、プログラマブル論理回路104上に存在して
いる回路を用いて処理を行うことができる。ただし、そ
の場合には、回路情報取得部105は、アプリケーショ
ンプログラム101に対して、その存在している回路の
入力ポートおよび出力ポートの位置情報を知らせる。こ
れにより、アプリケーションプログラム101は、その
回路の入力ポートに必要な入力データを入力し、出力ポ
ートから処理結果を得るようにして処理を実行すること
ができる。
If the designated circuit exists in the programmable logic circuit 104, it is not necessary to instruct the editing unit 300 to edit the circuit information as described above, and the designated circuit exists in the programmable logic circuit 104. The processing can be performed by using the circuit. However, in that case, the circuit information acquisition unit 105 notifies the application program 101 of the position information of the input port and the output port of the existing circuit. As a result, the application program 101 can execute processing by inputting necessary input data to the input port of the circuit and obtaining a processing result from the output port.

【0193】[0193]

【発明の効果】以上説明したように、この発明によれ
ば、すでにプログラマブル論理回路に構成されている回
路を、そのまま利用する状態で、再構成する回路の回路
情報を生成するので、当該回路情報による再構成には、
プログラマブル論理回路上にある回路の構成時間を省く
ことができ、再構成の時間を短縮することができる。ま
た、プログラマブル論理回路上の回路を利用することが
できるため、プログラマブル論理回路の使用効率もあげ
ることができる。
As described above, according to the present invention, circuit information of a circuit to be reconfigured is generated in a state where a circuit already configured as a programmable logic circuit is used as it is, so that the circuit information The reconstruction by
The time required to configure a circuit on the programmable logic circuit can be saved, and the time required for reconfiguration can be reduced. Further, since the circuit on the programmable logic circuit can be used, the use efficiency of the programmable logic circuit can be improved.

【0194】また、この発明によれば、アプリケーショ
ンプログラムの少なくとも一部を、プログラマブル論理
回路で処理する情報処理システムにおいて、予め、プロ
グラマブル論理回路の回路情報を持つことが不要である
情報処理システムが提供できる。
According to the present invention, in an information processing system for processing at least a part of an application program by a programmable logic circuit, there is provided an information processing system which does not need to have circuit information of the programmable logic circuit in advance. it can.

【0195】また、この発明によれば、アプリケーショ
ンプログラムを開始する前に、事前に回路情報を生成し
ておく必要がなく、プログラマブル論理回路上にその回
路情報の生成の際に存在する回路を利用しながら、効率
的な再構成のための回路情報の生成ができる。
Further, according to the present invention, it is not necessary to generate circuit information in advance before starting an application program, and a circuit existing on the programmable logic circuit when the circuit information is generated can be used. Meanwhile, it is possible to generate circuit information for efficient reconfiguration.

【図面の簡単な説明】[Brief description of the drawings]

【図1】この発明による情報処理システムの実施の形態
の全体の概要を示すブロック図である。
FIG. 1 is a block diagram showing an overall outline of an embodiment of an information processing system according to the present invention.

【図2】実施の形態における回路情報管理を説明するた
めの図である。
FIG. 2 is a diagram for describing circuit information management in the embodiment.

【図3】この発明による情報処理システムの実施の形態
のハードウエア構成図である。
FIG. 3 is a hardware configuration diagram of an embodiment of an information processing system according to the present invention.

【図4】FPGAタイプのプログラマブル論理回路を説
明するための図である。
FIG. 4 is a diagram for explaining an FPGA type programmable logic circuit;

【図5】FPGAタイプのプログラマブル論理回路を説
明するための図である。
FIG. 5 is a diagram illustrating an FPGA type programmable logic circuit.

【図6】この発明による情報処理システムの実施の形態
による具体的な処理手順のフローチャートである。
FIG. 6 is a flowchart of a specific processing procedure according to the embodiment of the information processing system according to the present invention;

【図7】図6のフローチャートの一部の処理の詳細な手
順のフローチャートである。
FIG. 7 is a flowchart of a detailed procedure of a part of the process of the flowchart of FIG. 6;

【図8】図6のフローチャートの一部の処理の詳細な手
順のフローチャートである。
FIG. 8 is a flowchart of a detailed procedure of a part of the process of the flowchart of FIG. 6;

【図9】図6のフローチャートの一部の処理の詳細な手
順のフローチャートである。
FIG. 9 is a flowchart of a detailed procedure of a part of the process of the flowchart of FIG. 6;

【図10】図6のフローチャートの一部の処理の詳細な
手順のフローチャートである。
FIG. 10 is a flowchart of a detailed procedure of a part of the process of the flowchart of FIG. 6;

【図11】この発明による情報処理システムの実施の形
態で用いる具体的な処理の例を説明するための図であ
る。
FIG. 11 is a diagram for explaining an example of a specific process used in the embodiment of the information processing system according to the present invention.

【図12】プログラマブル論理回路に構成された回路例
を示す図である。
FIG. 12 is a diagram illustrating an example of a circuit configured in a programmable logic circuit.

【図13】プログラマブル論理回路に構成された回路例
を示す図である。
FIG. 13 is a diagram illustrating a circuit example configured in a programmable logic circuit.

【図14】プログラマブル論理回路に構成された回路例
を示す図である。
FIG. 14 is a diagram showing an example of a circuit configured in a programmable logic circuit.

【図15】実施の形態において、プログラマブル論理回
路に回路構成するためのアドレス配置を説明するための
図である。
FIG. 15 is a diagram illustrating an address arrangement for forming a circuit in a programmable logic circuit in the embodiment;

【図16】この発明による情報処理システムの実施の形
態で用いる具体的な処理手順の説明に用いる図である。
FIG. 16 is a diagram illustrating a specific processing procedure used in the embodiment of the information processing system according to the present invention;

【図17】プログラマブル論理回路に構成された回路例
を示す図である。
FIG. 17 is a diagram illustrating an example of a circuit configured in a programmable logic circuit.

【図18】従来の情報処理システムの一例を説明するた
めの図である。
FIG. 18 is a diagram illustrating an example of a conventional information processing system.

【図19】図18の従来例で生成されるプログラマブル
論理回路の回路例を示す図である。
19 is a diagram illustrating a circuit example of a programmable logic circuit generated in the conventional example of FIG. 18;

【図20】従来の情報処理システムの他の例を説明する
ための図である。
FIG. 20 is a diagram for explaining another example of the conventional information processing system.

【符号の説明】 100 情報処理部 101 アプリケーションプログラム 102 CPU 103 ハードウエア処理部(処理手段) 104 プログラマブル論理回路 105 回路情報取得部(取得手段) 106 構成回路メモリ 200 記憶部 300 編集部 201 回路情報 202 ヘッダ部(付加情報部) 203 コード部(回路データ部) ADR アドレス DT 回路データ 400 ネットワーク 500 コンピュータシステムDESCRIPTION OF SYMBOLS 100 information processing section 101 application program 102 CPU 103 hardware processing section (processing means) 104 programmable logic circuit 105 circuit information acquisition section (acquisition means) 106 constituent circuit memory 200 storage section 300 editing section 201 circuit information 202 Header part (additional information part) 203 Code part (circuit data part) ADR address DT Circuit data 400 Network 500 Computer system

───────────────────────────────────────────────────── フロントページの続き (72)発明者 山田 紀一 神奈川県足柄上郡中井町境430 グリーン テクなかい富士ゼロックス株式会社内 (72)発明者 三宅 弘之 神奈川県足柄上郡中井町境430 グリーン テクなかい富士ゼロックス株式会社内 (72)発明者 中川 英悟 神奈川県足柄上郡中井町境430 グリーン テクなかい富士ゼロックス株式会社内 Fターム(参考) 5F064 AA08 BB09 BB13 BB15 DD01 DD25 DD47 HH06 HH11 HH12 ──────────────────────────────────────────────────続 き Continuing on the front page (72) Inventor Kiichi Yamada 430 Sakai Nakai-cho, Kanagawa Prefecture Green Tech Nakai Fuji Xerox Co., Ltd. (72) Inventor Hiroyuki Miyake 430 Sakai-Nakai-cho Sakaigami, Kanagawa Prefecture Green Tech Nakai Fuji Xerox Co., Ltd. In-house (72) Inventor Eigo Nakagawa 430, Nakai-cho, Ashigami-gun, Kanagawa Prefecture Green Tech Nakai Fuji Xerox Co., Ltd. F-term (reference) 5F064 AA08 BB09 BB13 BB15 DD01 DD25 DD47 HH06 HH11 HH12

Claims (7)

【特許請求の範囲】[Claims] 【請求項1】アプリケーションプログラムによる処理の
少なくとも一部分を、プログラマブル論理回路で処理す
る情報処理システムにおいて、 前記プログラマブル論理回路を備え、前記アプリケーシ
ョンプログラムからの命令により、前記プログラマブル
論理回路に構成された回路を用いて処理を実行する処理
手段と、 前記プログラマブル論理回路に前記回路を構成するため
の複数個の回路情報を記憶する記憶手段と、 指定情報により指定される一つの回路の回路情報を、前
記記憶手段に記憶された複数の回路情報を用いて生成す
る機能を備える編集手段と、 前記プログラマブル論理回路に構成する回路を特定する
ために前記アプリケーションプログラムにより指定され
る情報を、前記指定情報として、前記編集手段に渡し、
前記編集手段から到来する前記指定情報により指定され
た回路の回路情報を取得し、この回路情報により前記処
理手段のプログラマブル論理回路に前記指定された回路
を構成すると共に、前記プログラマブル論理回路に構成
されている回路の情報を記憶する取得手段と、 を備え、 前記編集手段は、前記指定情報により指定される回路の
回路情報を生成する際に、前記取得手段から得た前記プ
ログラマブル論理回路に構成されている回路の情報を参
照して、前記プログラマブル論理回路に構成されている
回路部分は再構成することなく利用する状態で、前記回
路情報を生成することを特徴とする情報処理システム。
An information processing system for processing at least a part of processing by an application program by a programmable logic circuit, comprising: the programmable logic circuit, wherein a circuit configured in the programmable logic circuit is executed by an instruction from the application program. Processing means for performing processing using the same; storage means for storing a plurality of pieces of circuit information for configuring the circuit in the programmable logic circuit; circuit information of one circuit designated by designation information; Editing means having a function of generating using a plurality of circuit information stored in the means, information specified by the application program to specify a circuit to be configured in the programmable logic circuit, as the specified information, Hand over to the editing means,
The circuit information of the circuit designated by the designation information coming from the editing means is obtained, and the circuit information is used to configure the designated circuit in the programmable logic circuit of the processing means, and to be configured in the programmable logic circuit. Acquiring means for storing information of a circuit being provided, wherein the editing means is configured in the programmable logic circuit obtained from the acquiring means when generating circuit information of the circuit specified by the designation information. An information processing system for generating the circuit information in a state where the circuit part configured in the programmable logic circuit is used without being reconfigured with reference to the information of the circuit in question.
【請求項2】前記取得手段に記憶される前記プログラマ
ブル論理回路に構成されている回路情報には、回路の識
別子と、その回路の前記プログラマブル論理回路上の配
置情報とを含み、 前記編集手段は、前記回路の識別子および前記配置情報
を参照することにより、前記指定情報により指定される
回路の回路情報が、前記プログラマブル論理回路に構成
されている回路を利用できる状態で生成できる場合に
は、前記プログラマブル論理回路に構成されている回路
部分は再構成することなく利用する状態で、前記回路情
報を生成することを特徴とする請求項1に記載の情報処
理システム。
2. The circuit information included in the programmable logic circuit stored in the acquisition unit includes a circuit identifier and information on the arrangement of the circuit on the programmable logic circuit. By referring to the identifier of the circuit and the placement information, when the circuit information of the circuit specified by the specification information can be generated in a state where the circuit configured in the programmable logic circuit can be used, The information processing system according to claim 1, wherein the circuit information is generated in a state where a circuit portion configured in a programmable logic circuit is used without being reconfigured.
【請求項3】前記記憶手段に記憶される複数個の回路情
報のそれぞれは、自己の回路情報の識別子を備えるとと
もに、当該回路情報の一部または全部を他の回路情報で
構成する場合には、前記プログラマブル論理回路に回路
を構成するための回路データとして、当該他の回路情報
の識別子を参照識別子として備えるものであり、 前記編集手段は、前記取得手段からの前記指定情報によ
り指定される回路の回路情報を、当該指定された回路の
回路情報と前記参照識別子で示される他の回路情報とを
前記記憶手段から入手して生成するものである請求項1
に記載の情報処理システムにおいて、 前記編集手段は、前記記憶手段から入手した前記参照識
別子により指定される回路の存在を、その参照識別子に
より前記取得手段に照会することにより、前記プログラ
マブル論理回路に当該参照識別子で示される回路が構成
されていることを認識すると共に、前記取得手段から
の、そのプログラマブル論理回路に構成されている回路
の配置情報を取得し、前記記憶手段から取得した回路情
報を用いて、前記プログラマブル論理回路に構成されて
いる回路部分は再構成することなく利用する状態で、前
記回路情報を生成することを特徴とする情報処理システ
ム。
3. A method according to claim 1, wherein each of the plurality of circuit information stored in said storage means has an identifier of its own circuit information, and a part or all of said circuit information is constituted by other circuit information. And an identifier of the other circuit information as a reference identifier as circuit data for configuring a circuit in the programmable logic circuit, wherein the editing unit is a circuit specified by the specification information from the acquisition unit. And generating the circuit information of (a) by obtaining circuit information of the designated circuit and other circuit information indicated by the reference identifier from the storage means.
The information processing system according to claim 1, wherein the editing unit refers to the acquisition unit by using the reference identifier for the existence of the circuit specified by the reference identifier obtained from the storage unit. While recognizing that the circuit indicated by the reference identifier is configured, from the obtaining unit, obtain the arrangement information of the circuit configured in the programmable logic circuit, and use the circuit information obtained from the storage unit. An information processing system, wherein the circuit information is generated in a state where a circuit portion included in the programmable logic circuit is used without being reconfigured.
【請求項4】請求項3に記載の情報処理システムにおい
て、 前記編集手段は、前記取得手段からの指定情報に対応し
て、この指定情報により指定される回路の回路情報を、
その識別子により前記記憶手段に照会し、 前記記憶手段は、前記編集手段からの照会に応じて、そ
の照会時の識別子で示される回路情報が参照識別子を含
む場合には、その参照識別子を前記編集手段に返し、 前記編集手段は、前記記憶手段から入手した参照識別子
により指定される回路の存在を、その参照識別子により
前記取得手段に照会し、 前記取得手段は、前記編集手段からの照会に応じて、そ
の照会時の参照識別子で示される回路が前記プログラマ
ブル論理回路に存在する場合には、その回路の前記プロ
グラマブル論理回路上の配置情報を編集手段に返し、 前記配置情報を受け取った前記編集手段は、前記記憶手
段から入手した前記プログラマブル論理回路に存在しな
い回路の参照識別子を用いて、前記記憶手段から当該参
照識別子で示される前記他の回路情報を取得し、前記プ
ログラマブル論理回路に構成されている回路部分は再構
成することなく利用する状態で、前記回路情報を生成す
ることを特徴とする情報処理システム。
4. The information processing system according to claim 3, wherein the editing unit, in response to the specification information from the acquisition unit, stores circuit information of a circuit specified by the specification information.
Inquiring the storage means by the identifier, the storage means edits the reference identifier when the circuit information indicated by the identifier at the time of the inquiry includes the reference identifier in response to the inquiry from the editing means. Returning to the means, the editing means inquires of the obtaining means by using the reference identifier for the existence of the circuit specified by the reference identifier obtained from the storage means, and the obtaining means responds to the inquiry from the editing means When the circuit indicated by the reference identifier at the time of the inquiry is present in the programmable logic circuit, the layout information of the circuit on the programmable logic circuit is returned to the editing means, and the editing means receiving the layout information Using the reference identifier of a circuit that does not exist in the programmable logic circuit obtained from the storage means, An information processing system comprising: acquiring the other circuit information indicated by (1), and generating the circuit information in a state where a circuit portion included in the programmable logic circuit is used without being reconfigured.
【請求項5】前記記憶手段に記憶される複数個の回路情
報のそれぞれは、自己の回路情報の識別子を備えるとと
もに、当該回路情報の一部または全部を他の回路情報で
構成する場合には、前記プログラマブル論理回路に回路
を構成するための回路データとして、当該他の回路情報
の識別子を参照識別子として備えるものであり、 前記編集手段は、前記取得手段からの前記指定情報によ
り指定される回路の回路情報を、当該指定された回路の
回路情報と前記参照識別子で示される他の回路情報とを
前記記憶手段から入手して生成するものである請求項1
に記載の情報処理システムにおいて、 前記取得手段は、前記指定情報と共に、前記プログラマ
ブル論理回路に構成されている回路の情報を前記編集手
段に送り、 前記編集手段は、前記取得手段からの指定情報に対応し
て、この指定情報により指定される回路の回路情報を、
その識別子により前記記憶手段に照会し、 前記記憶手段は、前記編集手段からの照会に応じて、そ
の照会時の識別子で示される回路情報が参照識別子を含
む場合には、その参照識別子を前記編集手段に返し、 前記編集手段は、前記記憶手段から入手した参照識別子
により指定される回路の存在を、その参照識別子により
前記取得手段から得た前記プログラマブル論理回路に構
成されている回路の情報を参照することにより、前記指
定情報で指定される回路の回路情報の参照識別子で示さ
れる回路が前記プログラマブル論理回路に存在するかど
うかを識別し、前記記憶手段から入手した前記プログラ
マブル論理回路に存在しない回路の参照識別子を用い
て、前記記憶手段から当該参照識別子で示される前記他
の回路情報を取得し、前記プログラマブル論理回路に構
成されている回路部分は再構成することなく利用する状
態で、前記回路情報を生成することを特徴とする情報処
理システム。
5. When each of a plurality of circuit information stored in said storage means has an identifier of its own circuit information and a part or all of said circuit information is constituted by other circuit information, And an identifier of the other circuit information as a reference identifier as circuit data for configuring a circuit in the programmable logic circuit, wherein the editing unit is a circuit specified by the specification information from the acquisition unit. And generating the circuit information of (a) by obtaining circuit information of the designated circuit and other circuit information indicated by the reference identifier from the storage means.
The information processing system according to claim 1, wherein the acquisition unit sends information of a circuit configured in the programmable logic circuit to the editing unit together with the designation information, and the editing unit sends the designation information from the acquisition unit to the designation information from the acquisition unit. Correspondingly, the circuit information of the circuit specified by this specification information is
Inquiring the storage means by the identifier, the storage means edits the reference identifier when the circuit information indicated by the identifier at the time of the inquiry includes the reference identifier in response to the inquiry from the editing means. Returning to the means, the editing means refers to the information of the circuit configured in the programmable logic circuit obtained from the obtaining means by using the reference identifier of the existence of the circuit specified by the reference identifier obtained from the storage means. By doing so, it is determined whether the circuit indicated by the reference identifier of the circuit information of the circuit specified by the specification information exists in the programmable logic circuit, and the circuit not existing in the programmable logic circuit obtained from the storage means Acquiring the other circuit information indicated by the reference identifier from the storage means using the reference identifier of the Maburu circuit portion configured in a logic circuit in a state of use, without the need to reconfigure, an information processing system and generating the circuit information.
【請求項6】請求項1に記載の情報処理システムにおい
て、 前記記憶手段に記憶される複数個の回路情報のそれぞれ
は、回路データ部と、その付加情報部とからなり、 前記付加情報部は、自己の回路情報の識別子を含むとと
もに、当該回路情報の一部または全部を他の回路情報で
構成する場合には、当該他の回路情報の識別子を参照識
別子として含むものであり、 前記回路データ部は、前記プログラマブル論理回路のコ
ンフィギュレーションメモリのアドレスと、そのアドレ
スに格納される回路データとの対で記述されるものであ
って、当該回路情報の一部または全部を他の回路情報で
構成する場合には、その回路情報の一部または全部の回
路データは、前記参照識別子を用いて記述したものとさ
れるとともに、前記参照識別子が、前記回路情報におい
て前記他の回路情報を参照する位置に対応するアドレス
の回路データとして記述されており、 前記編集手段は、前記取得手段からの前記指定情報に対
応して、当該指定情報により指定される回路の回路情報
を、その識別子により前記記憶手段に照会し、 前記記憶手段は、前記編集手段からの照会に応じて、そ
の照会時の前記識別子で示される回路情報の前記付加情
報部が参照識別子を含む場合には、その参照識別子を前
記編集手段に返し、 前記編集手段は、前記記憶手段から入手した前記参照識
別子を用いて、前記記憶手段から前記他の回路情報を取
得し、取得した他の回路情報は、指定情報により指定さ
れた回路の回路情報の回路データとして参照識別子が記
述されたアドレスと、前記処理手段に存在する参照識別
子で示される回路のアドレスとの差分アドレスを、前記
参照識別子に対応する前記他の回路情報の回路データ部
のすべてのアドレスに加えて、前記参照識別子が記述さ
れた回路情報に結合することを特徴とする情報処理シス
テム。
6. The information processing system according to claim 1, wherein each of the plurality of circuit information stored in the storage means includes a circuit data part and an additional information part thereof, and the additional information part is In the case where a part or all of the circuit information is configured by other circuit information, the identifier of the other circuit information is included as a reference identifier. The unit is described as a pair of an address of a configuration memory of the programmable logic circuit and circuit data stored at the address, and a part or all of the circuit information is configured by other circuit information. In this case, part or all of the circuit data of the circuit information is described using the reference identifier, and the reference identifier is The information is described as circuit data of an address corresponding to a position referring to the other circuit information, and the editing unit corresponds to the specification information from the acquisition unit, and the circuit specified by the specification information The memory information is referred to the storage means by the identifier, and the storage means responds to the inquiry from the editing means, and the additional information section of the circuit information indicated by the identifier at the time of the inquiry refers to the reference identifier. If it includes, the reference identifier is returned to the editing unit, and the editing unit acquires the other circuit information from the storage unit using the reference identifier acquired from the storage unit, and acquires the acquired other circuit information. The circuit information is indicated by an address in which a reference identifier is described as circuit data of circuit information of the circuit specified by the specification information, and a reference identifier existing in the processing means. A difference address from the address of the circuit to be connected to all the addresses of the circuit data portion of the other circuit information corresponding to the reference identifier, and combining the address with the circuit information in which the reference identifier is described. Information processing system.
【請求項7】請求項1〜6のいずれかに記載の情報処理
システムにおいて、 前記記憶手段を構成する部分と、前記編集手段を構成す
る部分と、前記取得手段および処理手段を構成する部分
とが、ネットワークを介して接続されていることを特徴
とする情報処理システム。
7. The information processing system according to claim 1, wherein a part constituting said storage means, a part constituting said editing means, and a part constituting said obtaining means and processing means. Is connected through a network.
JP29923698A 1998-10-21 1998-10-21 Information processing system Expired - Fee Related JP3573193B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP29923698A JP3573193B2 (en) 1998-10-21 1998-10-21 Information processing system

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP29923698A JP3573193B2 (en) 1998-10-21 1998-10-21 Information processing system

Publications (2)

Publication Number Publication Date
JP2000124317A true JP2000124317A (en) 2000-04-28
JP3573193B2 JP3573193B2 (en) 2004-10-06

Family

ID=17869919

Family Applications (1)

Application Number Title Priority Date Filing Date
JP29923698A Expired - Fee Related JP3573193B2 (en) 1998-10-21 1998-10-21 Information processing system

Country Status (1)

Country Link
JP (1) JP3573193B2 (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2005222142A (en) * 2004-02-03 2005-08-18 Nec Corp Array type processor
WO2006115213A1 (en) * 2005-04-21 2006-11-02 Matsushita Electric Industrial Co., Ltd. Circuit updating system
US7424595B2 (en) 2000-06-06 2008-09-09 Tadahiro Ohmi System for managing circuitry of variable function information processing circuit and method for managing circuitry of variable function information processing circuit
WO2009147789A1 (en) * 2008-06-06 2009-12-10 日本電気株式会社 Circuit design system and circuit design method

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7424595B2 (en) 2000-06-06 2008-09-09 Tadahiro Ohmi System for managing circuitry of variable function information processing circuit and method for managing circuitry of variable function information processing circuit
JP2005222142A (en) * 2004-02-03 2005-08-18 Nec Corp Array type processor
US7650484B2 (en) 2004-02-03 2010-01-19 Nec Corporation Array—type computer processor with reduced instruction storage
JP4502650B2 (en) * 2004-02-03 2010-07-14 日本電気株式会社 Array type processor
WO2006115213A1 (en) * 2005-04-21 2006-11-02 Matsushita Electric Industrial Co., Ltd. Circuit updating system
US8189773B2 (en) 2005-04-21 2012-05-29 Panasonic Corporation Circuit updating system
WO2009147789A1 (en) * 2008-06-06 2009-12-10 日本電気株式会社 Circuit design system and circuit design method
JP5158195B2 (en) * 2008-06-06 2013-03-06 日本電気株式会社 Circuit design system and circuit design method
US8640071B2 (en) 2008-06-06 2014-01-28 Nec Corporation Circuit design system and circuit design method

Also Published As

Publication number Publication date
JP3573193B2 (en) 2004-10-06

Similar Documents

Publication Publication Date Title
JP3809727B2 (en) Information processing system, circuit information management method, and circuit information storage device
JP3587095B2 (en) Information processing equipment
CN100524287C (en) A single chip protocol converter
JP4896243B2 (en) Method of programming mask programmable logic device and device programmed by the method
JP5937845B2 (en) Method and apparatus for installing and routing a partial reconfiguration module
Otero et al. Dreams: A tool for the design of dynamically reconfigurable embedded and modular systems
JP2003518666A (en) A method for implementing physical design for dynamically reconfigurable logic circuits.
JP2022549527A (en) Data processing method, apparatus, distributed dataflow programming framework and related components
JP5373620B2 (en) Data transfer control device, data transfer device, data transfer control method, and semiconductor integrated circuit using reconfiguration circuit
JP3832557B2 (en) Circuit reconfiguration method and information processing system for programmable logic circuit
US8106679B2 (en) Data processing system
CN116541065A (en) Software system construction method, device, equipment and computer readable storage medium
Wigley et al. The management of applications for reconfigurable computing using an operating system
Hagemeyer et al. A design methodology for communication infrastructures on partially reconfigurable FPGAs
JP3573193B2 (en) Information processing system
JP2006172219A (en) Automated design device for semiconductor integrated circuit, automated design method for semiconductor integrated circuit, and automated design program for semiconductor integrated circuit
JP3664215B2 (en) Information processing system
JP3544129B2 (en) Information processing system
US20110246158A1 (en) Method for simulating a complex system with construction of at least one model including at least one modelled router, corresponding computer software package and storage means
JP4664724B2 (en) Semiconductor integrated circuit device and semiconductor integrated circuit device design apparatus
Werner et al. Virtualized on-chip distributed computing for heterogeneous reconfigurable multi-core systems
JPH1078932A (en) Reconfigurable network computer
Silva et al. Generation of partial FPGA configurations at run-time
JP2000091435A (en) Electronic data processing system
Rossmeissl et al. Partial bitstream 2-d core relocation for reconfigurable architectures

Legal Events

Date Code Title Description
A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20040318

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20040514

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: 20040609

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20040622

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: 20080709

Year of fee payment: 4

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20090709

Year of fee payment: 5

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20100709

Year of fee payment: 6

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110709

Year of fee payment: 7

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20110709

Year of fee payment: 7

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20120709

Year of fee payment: 8

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20130709

Year of fee payment: 9

LAPS Cancellation because of no payment of annual fees