JPH01237826A - データ列検索装置 - Google Patents
データ列検索装置Info
- Publication number
- JPH01237826A JPH01237826A JP63063471A JP6347188A JPH01237826A JP H01237826 A JPH01237826 A JP H01237826A JP 63063471 A JP63063471 A JP 63063471A JP 6347188 A JP6347188 A JP 6347188A JP H01237826 A JPH01237826 A JP H01237826A
- Authority
- JP
- Japan
- Prior art keywords
- data
- data string
- address
- search
- section
- 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.)
- Pending
Links
- 230000015654 memory Effects 0.000 claims abstract description 44
- 238000013500 data storage Methods 0.000 description 41
- 238000000034 method Methods 0.000 description 41
- 238000005070 sampling Methods 0.000 description 10
- 238000010586 diagram Methods 0.000 description 8
- 238000004364 calculation method Methods 0.000 description 7
- 230000007274 generation of a signal involved in cell-cell signaling Effects 0.000 description 5
- 238000001514 detection method Methods 0.000 description 4
- 230000004913 activation Effects 0.000 description 3
- 230000003936 working memory Effects 0.000 description 3
- 230000000694 effects Effects 0.000 description 2
- 230000005055 memory storage Effects 0.000 description 2
- 238000007781 pre-processing Methods 0.000 description 2
- 230000003213 activating effect Effects 0.000 description 1
- 230000002457 bidirectional effect Effects 0.000 description 1
- 239000000470 constituent Substances 0.000 description 1
- 230000006870 function Effects 0.000 description 1
- 230000000717 retained effect Effects 0.000 description 1
Landscapes
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
(57)【要約】本公報は電子出願前の出願データであるた
め要約のデータは記録されません。
め要約のデータは記録されません。
Description
【発明の詳細な説明】
[発明の目的]
(産業上の利用分野)
本発明は、たとえばICカードなどのマイクロコンピュ
ータシステムにおいて、メモリ内のデータ列を検索する
データ列検索装置に関する。
ータシステムにおいて、メモリ内のデータ列を検索する
データ列検索装置に関する。
(従来の技術)
たとえばマイクロコンピュータシステムの中で、現在大
きな注目を浴びているものとして10カードがあげられ
る。ICカードは、CPUなどの制御部によってアクセ
スされるメモリを有し、そのメモリ内には複数のデータ
列が記憶されており、この記憶データ列のうち任意のデ
ータ列を選択的にアクセス対象とするようになっている
。
きな注目を浴びているものとして10カードがあげられ
る。ICカードは、CPUなどの制御部によってアクセ
スされるメモリを有し、そのメモリ内には複数のデータ
列が記憶されており、この記憶データ列のうち任意のデ
ータ列を選択的にアクセス対象とするようになっている
。
このようなICカードにおいて、メモリ内のデータ列を
検索する場合、特殊回路などにより検索処理を委ねるこ
とにより、検索処理の高速化を図ることが考えられる。
検索する場合、特殊回路などにより検索処理を委ねるこ
とにより、検索処理の高速化を図ることが考えられる。
従来のデータ列検索装置では、検索するデータ列のデー
タ列長をあらかじめ装置内に認識させておき、これに基
づき随時データ列を検索する方式%式% しかし、今日のデータファイルシステムにおいては、デ
ータ列の先頭にデータ列長情報を付加することにより、
可変長形式でデータ列を記憶するものもある。このよう
な可変長のデータ列に対しては従来のデータ列検索装置
では対応できない。
タ列長をあらかじめ装置内に認識させておき、これに基
づき随時データ列を検索する方式%式% しかし、今日のデータファイルシステムにおいては、デ
ータ列の先頭にデータ列長情報を付加することにより、
可変長形式でデータ列を記憶するものもある。このよう
な可変長のデータ列に対しては従来のデータ列検索装置
では対応できない。
(発明が解決しようとする課題)
本発明は、上記したように可変長のデータ列に対しての
検索を行なうことができないという問題点を解決すべく
なされたもので、可変長のデータ列に対しての検索を行
なうことができるデータ列検′索装置を提供することを
目的とする。
検索を行なうことができないという問題点を解決すべく
なされたもので、可変長のデータ列に対しての検索を行
なうことができるデータ列検′索装置を提供することを
目的とする。
[発明の構成]
(課題を解決するための手段)
本発明は、所定の処理を行なう制御部と、この制御部に
よってアクセスされ、それぞれデータ列長情報が付加さ
れている複数のデータ列を記憶するメモリ部とを有する
ものにおいて、前記メモリ部への供給アドレスを随時更
新しながら前記メモリ部内のデータ列を検索するデータ
列検索装置であって、アドレス更新情報および前記制御
部がら供給される第1アドレスデータに基づき第2アド
レスデータを生成するアドレス生成手段と、このアドレ
ス生成手段で生成された第2アドレスデータに基づき前
記メモリ部をアクセスするアクセス手段と、このアクセ
ス手段により前記メモリ部内のデータ列に付加されてい
るデータ列長情報を読出し、この読出したデータ列長情
報を前記アドレス更新情報とする手段とを具備している
。
よってアクセスされ、それぞれデータ列長情報が付加さ
れている複数のデータ列を記憶するメモリ部とを有する
ものにおいて、前記メモリ部への供給アドレスを随時更
新しながら前記メモリ部内のデータ列を検索するデータ
列検索装置であって、アドレス更新情報および前記制御
部がら供給される第1アドレスデータに基づき第2アド
レスデータを生成するアドレス生成手段と、このアドレ
ス生成手段で生成された第2アドレスデータに基づき前
記メモリ部をアクセスするアクセス手段と、このアクセ
ス手段により前記メモリ部内のデータ列に付加されてい
るデータ列長情報を読出し、この読出したデータ列長情
報を前記アドレス更新情報とする手段とを具備している
。
(作用)
次のデータ列の先頭アドレス(第2アドレスデータ)を
生成するために用いるデータ列長情報(アドレス更新情
報)として、現在のデータ列の先頭に付加されているデ
ータ列長情報を用いることにより、可変長のデータ列に
対しての検索を行なうことができ、メモリ記憶効率の高
い可変長記憶方式を維持しつつその検索処理が実現でき
る。
生成するために用いるデータ列長情報(アドレス更新情
報)として、現在のデータ列の先頭に付加されているデ
ータ列長情報を用いることにより、可変長のデータ列に
対しての検索を行なうことができ、メモリ記憶効率の高
い可変長記憶方式を維持しつつその検索処理が実現でき
る。
(実施例)
以下、本発明の一実施例について図面を参照して説明す
る。
る。
第2図は本発明に係るデータ列検索装置が適用されるI
Cカードなどのマイクロコンピュータシステムの構成を
示すものである。すなわち、1は本システム全体の制御
を司る制御部としてのCPU (セントラル・プロセッ
シング・ユニット)で、これには第1データバス21お
よび第1アドレスバス31が接続される。第1データバ
ス21および第1アドレスバス31には、プログラムメ
モリ4およびワーキングメモリ5が接続される。
Cカードなどのマイクロコンピュータシステムの構成を
示すものである。すなわち、1は本システム全体の制御
を司る制御部としてのCPU (セントラル・プロセッ
シング・ユニット)で、これには第1データバス21お
よび第1アドレスバス31が接続される。第1データバ
ス21および第1アドレスバス31には、プログラムメ
モリ4およびワーキングメモリ5が接続される。
また、第1データバス21および第1アドレスバス31
には、双方向性ゲート6を介して第2データバス22お
よび第2アドレスバス32が対応して接続される。第2
データバス22および第2アドレスバス32には、デー
タメモリ (メモリ部)7およびデータ列検索装置8が
接続される。データ列検索装置8には第1データバス2
1も接続される。また、CPUIおよび第1アドレスバ
ス3】にはアクセス信号生成部9が接続される。
には、双方向性ゲート6を介して第2データバス22お
よび第2アドレスバス32が対応して接続される。第2
データバス22および第2アドレスバス32には、デー
タメモリ (メモリ部)7およびデータ列検索装置8が
接続される。データ列検索装置8には第1データバス2
1も接続される。また、CPUIおよび第1アドレスバ
ス3】にはアクセス信号生成部9が接続される。
CPUIは、プログラムメモリ4に記憶されているプロ
グラムデータを所定のタイミングで随時読出し、これを
解読することにより種々の制御を実行する。ワーキング
メモリ5は、CPUIが制御実行中に一時的にデータを
記憶するためのもので、たとえばRAMで構成されてい
る。データメモリ7は、本システムの外部などから入力
されるデータ列を記憶するためのもので、たとえばEE
FROMなどの不揮発性メモリで構成されている。
グラムデータを所定のタイミングで随時読出し、これを
解読することにより種々の制御を実行する。ワーキング
メモリ5は、CPUIが制御実行中に一時的にデータを
記憶するためのもので、たとえばRAMで構成されてい
る。データメモリ7は、本システムの外部などから入力
されるデータ列を記憶するためのもので、たとえばEE
FROMなどの不揮発性メモリで構成されている。
さて、CPUIは、基本アクセスイネーブル信号(たと
えば280CPUにおけるメモリリクエスト、入出力リ
クエスト、リード・ライトの各イネーブル信号など)お
よびアドレスデータをアクセス信号生成部9に供給する
。これにより、アクセス信号生成部9はアクセス信号群
A1〜A4を生成する。アクセス信号群A1は、CPU
Iがプログラムメモリ4からプログラムデータを読出す
際にイネーブル状態となる。アクセス信号群A2は、C
PUユがワーキングメモリ5に対してアクセスする際に
イネーブル状態となる。アクセス信号群A3は、CPU
1がデータメモリ7に対してアクセスする際にイネーブ
ル状態となる。アクセス信号群A4は、データ列検索装
置8の起動およびデータ列検索装置8に必要となる各種
パラメータ設定のためのイネーブル信号である。
えば280CPUにおけるメモリリクエスト、入出力リ
クエスト、リード・ライトの各イネーブル信号など)お
よびアドレスデータをアクセス信号生成部9に供給する
。これにより、アクセス信号生成部9はアクセス信号群
A1〜A4を生成する。アクセス信号群A1は、CPU
Iがプログラムメモリ4からプログラムデータを読出す
際にイネーブル状態となる。アクセス信号群A2は、C
PUユがワーキングメモリ5に対してアクセスする際に
イネーブル状態となる。アクセス信号群A3は、CPU
1がデータメモリ7に対してアクセスする際にイネーブ
ル状態となる。アクセス信号群A4は、データ列検索装
置8の起動およびデータ列検索装置8に必要となる各種
パラメータ設定のためのイネーブル信号である。
また、後述するようにデータ列検索装置8がデータメモ
リ7に対してアクセスするため、データ列検索装置8内
で生成した生成アクセス信号群A5と、アクセス信号生
成部9から供給されたアクセス信号群A3とを選択する
ことによりアクセス信号群AI)を生成し、このアクセ
ス信号群Abをデータメモリ7に供給する。
リ7に対してアクセスするため、データ列検索装置8内
で生成した生成アクセス信号群A5と、アクセス信号生
成部9から供給されたアクセス信号群A3とを選択する
ことによりアクセス信号群AI)を生成し、このアクセ
ス信号群Abをデータメモリ7に供給する。
また、CPUIおよびデータ列検索装置8は、第2デー
タバス22および第2アドレスバス32を共有している
ため、CPUIからの制御により、アクセス信号群A4
を介してデータ列検索装置8が起動すると、データ列検
索装置8が動作中であることを信号S1によりゲート6
に通知する。
タバス22および第2アドレスバス32を共有している
ため、CPUIからの制御により、アクセス信号群A4
を介してデータ列検索装置8が起動すると、データ列検
索装置8が動作中であることを信号S1によりゲート6
に通知する。
これにより、ゲート6は、データ列検索装置8の動作中
には第1データバス21と第2データバス2□および第
1アドレスバス31と第2アドレスバス32をそれぞれ
非導通状態にする。なお、このときCPUIは、データ
列検索装置8から出力される停市ステータスを第1デー
タバス21を介して常に監視できるとともに、プログラ
ムメモリ4からのプログラムデータにより動作を続行で
き、またワーキングメモリ5へのアクセスも可能である
。
には第1データバス21と第2データバス2□および第
1アドレスバス31と第2アドレスバス32をそれぞれ
非導通状態にする。なお、このときCPUIは、データ
列検索装置8から出力される停市ステータスを第1デー
タバス21を介して常に監視できるとともに、プログラ
ムメモリ4からのプログラムデータにより動作を続行で
き、またワーキングメモリ5へのアクセスも可能である
。
データメモリ7は、たとえば第3図に示すように、エリ
ア定義部71およびエリア配置部7□からなっている。
ア定義部71およびエリア配置部7□からなっている。
エリア配置部72には複数のエリアが配置されており、
本システムの外部などからのデータ列の記憶に使用され
る。エリア定義部71には、エリア配置部72に配置さ
れている各エリアを定義するエリア定義情報が記憶され
る。
本システムの外部などからのデータ列の記憶に使用され
る。エリア定義部71には、エリア配置部72に配置さ
れている各エリアを定義するエリア定義情報が記憶され
る。
エリア定義情報は、たとえばエリア番号、エリア先頭ア
ドレス、エリアサイズおよびポインタなどからなる。こ
れにより、CPUIは、たとえば外部から書込みデータ
とともにアクセス対象となるエリアのエリア番号を受取
ると、該当するエリア番号をエリア定義部71から見付
け、対象エリアの先頭アドレスおよびサイズなど、アク
セスに必要な情報を認識する。たとえば、エリアCは先
頭アドレスがrc c cJで、サイズはrScバイト
」であるといったように対応づけられている。
ドレス、エリアサイズおよびポインタなどからなる。こ
れにより、CPUIは、たとえば外部から書込みデータ
とともにアクセス対象となるエリアのエリア番号を受取
ると、該当するエリア番号をエリア定義部71から見付
け、対象エリアの先頭アドレスおよびサイズなど、アク
セスに必要な情報を認識する。たとえば、エリアCは先
頭アドレスがrc c cJで、サイズはrScバイト
」であるといったように対応づけられている。
また、ポインタは、対応するエリア内のうち、どこまで
データ列の書込みに使用したかを示すもので、何も書込
まれていない状態では対応するエリアの先頭アドレスと
同一値となっている。たとえばエリアAにおいては、ポ
インタはraaaJという値となっているので、未書込
み状態であることを示す。エリアBにおいては、ポイン
タはrbbb’Jとなっているので、rbbbJから[
bbb’−IJの範囲には既にデータ列が書込まれてい
ることを示し、以降の書込みはrbbb’Jから開始す
ることを示す。また、エリアCについては、rbbbJ
となっている(この例では、rcccJから「bbb−
1」までScバイト)ため、エリアがデータ列で満杯に
なっていることを示す。
データ列の書込みに使用したかを示すもので、何も書込
まれていない状態では対応するエリアの先頭アドレスと
同一値となっている。たとえばエリアAにおいては、ポ
インタはraaaJという値となっているので、未書込
み状態であることを示す。エリアBにおいては、ポイン
タはrbbb’Jとなっているので、rbbbJから[
bbb’−IJの範囲には既にデータ列が書込まれてい
ることを示し、以降の書込みはrbbb’Jから開始す
ることを示す。また、エリアCについては、rbbbJ
となっている(この例では、rcccJから「bbb−
1」までScバイト)ため、エリアがデータ列で満杯に
なっていることを示す。
ここで、エリア内のデータ列記憶状態をエリアBについ
て第4図に示す。図示するように、たとえば4つのデー
タ列が記憶されており、各データ列は、1バイトのデー
タ列長(L) 、2バイトのキーデータ(Kおよびkと
いった各1バイトのデータで構成)、およびデータから
なる。ここに、データ列長しは、データ列長部からデー
タ部までの構成バイト数である。これらのうち、データ
列長しおよびキーデータに、にの具体的な数値を入れた
図を第5図に示す。なお、各数値はへキサ(Hex)で
表わしである。たとえばデータ4のデータ列は、データ
列長は0CH(12バイト)、キーデータは9A11.
64)1 (2バイト)である。
て第4図に示す。図示するように、たとえば4つのデー
タ列が記憶されており、各データ列は、1バイトのデー
タ列長(L) 、2バイトのキーデータ(Kおよびkと
いった各1バイトのデータで構成)、およびデータから
なる。ここに、データ列長しは、データ列長部からデー
タ部までの構成バイト数である。これらのうち、データ
列長しおよびキーデータに、にの具体的な数値を入れた
図を第5図に示す。なお、各数値はへキサ(Hex)で
表わしである。たとえばデータ4のデータ列は、データ
列長は0CH(12バイト)、キーデータは9A11.
64)1 (2バイト)である。
第1図はデータ列検索装置8の構成を示すものである。
すなわち、11は全体的な制御を司る制御部、12は検
索エリアサイズを記憶する検索エリアサイズ記憶部、1
3は検索エリアの残量を計算する検索エリア残量計算部
、14はデータ列長用マスクデータを記憶するデータ列
長用マスクデータ記憶部、15はデータ列長加工部、1
6はデータ列長を記憶するデータ列長記憶部、17はデ
ータ列長をチエツクするデータ列長チエツク部、18は
最小データ列長を記憶する最小データ列長記憶部、19
は検索エリア先頭アドレスを記憶する検索エリア先頭ア
ドレス記憶部、20は第1サンプリング用相対アドレス
を記憶する第1サンプリング用相対アドレス記憶部、2
1は第2サンプリング用相対アドレスを記憶する第2サ
ンプリング用相対アドレス記憶部である。
索エリアサイズを記憶する検索エリアサイズ記憶部、1
3は検索エリアの残量を計算する検索エリア残量計算部
、14はデータ列長用マスクデータを記憶するデータ列
長用マスクデータ記憶部、15はデータ列長加工部、1
6はデータ列長を記憶するデータ列長記憶部、17はデ
ータ列長をチエツクするデータ列長チエツク部、18は
最小データ列長を記憶する最小データ列長記憶部、19
は検索エリア先頭アドレスを記憶する検索エリア先頭ア
ドレス記憶部、20は第1サンプリング用相対アドレス
を記憶する第1サンプリング用相対アドレス記憶部、2
1は第2サンプリング用相対アドレスを記憶する第2サ
ンプリング用相対アドレス記憶部である。
22は次のデータ列先頭アドレスを生成する次データ列
先頭アドレス生成部、23はデータ列先頭アドレスを生
成するデータ列先頭アドレス生成部、24はカレントア
ドレスを生成するカレントアドレス生成部、25はカレ
ントアドレス生成部24で生成されたカレントアドレス
をデータメモリ7へ供給するアドレス出力部、26はア
クセスイネーブル信号選択部である。アクセスイネーブ
ル信号選択部26は、制御部11で生成された生成アク
セス信号群A5と、アクセス信号生成部9から供給され
たアクセス信号群A3とを選択することによりアクセス
信号群A6を生成し、このアクセス信号群A6をデータ
メモリ7に供給する。
先頭アドレス生成部、23はデータ列先頭アドレスを生
成するデータ列先頭アドレス生成部、24はカレントア
ドレスを生成するカレントアドレス生成部、25はカレ
ントアドレス生成部24で生成されたカレントアドレス
をデータメモリ7へ供給するアドレス出力部、26はア
クセスイネーブル信号選択部である。アクセスイネーブ
ル信号選択部26は、制御部11で生成された生成アク
セス信号群A5と、アクセス信号生成部9から供給され
たアクセス信号群A3とを選択することによりアクセス
信号群A6を生成し、このアクセス信号群A6をデータ
メモリ7に供給する。
27は第1キーデータを記憶する第1キーデータ記憶部
、28は第1マスクデータを記憶する第1マスクデータ
記憶部、29は第1サンプルデータを記憶する第1サン
プルデータ記憶部、3oは第1サンプルデータを加工す
る第1サンプルデータ加工部、31は第1キーデータ記
憶部27の内容と第1サンプルデータ加工部3oの出力
とを比較する第1比較部、32は第2キーデータを記憶
する第2キーデータ記憶部、33は第2マスクデータを
記憶する第2マスクデータ記憶部、34は第2サンプル
データを記憶する第2サンプルデータ記憶部、35は第
2サンプルデータを加工する第2サンプルデータ加工部
、36は第2キーデータ記憶部32の内容と第2サンプ
ルデータ加工部35の出力とを比較する第2比較部であ
る。
、28は第1マスクデータを記憶する第1マスクデータ
記憶部、29は第1サンプルデータを記憶する第1サン
プルデータ記憶部、3oは第1サンプルデータを加工す
る第1サンプルデータ加工部、31は第1キーデータ記
憶部27の内容と第1サンプルデータ加工部3oの出力
とを比較する第1比較部、32は第2キーデータを記憶
する第2キーデータ記憶部、33は第2マスクデータを
記憶する第2マスクデータ記憶部、34は第2サンプル
データを記憶する第2サンプルデータ記憶部、35は第
2サンプルデータを加工する第2サンプルデータ加工部
、36は第2キーデータ記憶部32の内容と第2サンプ
ルデータ加工部35の出力とを比較する第2比較部であ
る。
37は第1比較部31および第2比較部36の各比較結
果に基づき検索判定を行なう検索判定部、38はデータ
列番号指定用情報を記憶するデータ列番号指定用情報記
憶部、39は指定データ列番号を検出する指定データ列
番号検出部、40は検索済のデータ列数を記憶する検索
済データ列数記憶部である。
果に基づき検索判定を行なう検索判定部、38はデータ
列番号指定用情報を記憶するデータ列番号指定用情報記
憶部、39は指定データ列番号を検出する指定データ列
番号検出部、40は検索済のデータ列数を記憶する検索
済データ列数記憶部である。
さて、制御部11は、CPUIの制御により供給される
アクセス信号群A4により各部にパラメータデータを設
定し、本装置起動を認識する。パラメータデータは、C
PUIから第1データバス21を介して検索エリアサイ
ズ記憶部12、データ列長用マスクデータ記憶部14、
データ列長記憶部16、最小データ列長記憶部18、検
索エリア先頭アドレス記憶部19、第1サンプリング用
相対アドレス記憶部20、第2サンプリング用相対アド
レス記憶部21、第1キーデータ記憶部27、第1マス
クデータ記憶部28、第2キーデータ記憶部32、第2
マスクデータ記憶部33、データ列番号指定用情報記憶
部38にそれぞれセットされる。
アクセス信号群A4により各部にパラメータデータを設
定し、本装置起動を認識する。パラメータデータは、C
PUIから第1データバス21を介して検索エリアサイ
ズ記憶部12、データ列長用マスクデータ記憶部14、
データ列長記憶部16、最小データ列長記憶部18、検
索エリア先頭アドレス記憶部19、第1サンプリング用
相対アドレス記憶部20、第2サンプリング用相対アド
レス記憶部21、第1キーデータ記憶部27、第1マス
クデータ記憶部28、第2キーデータ記憶部32、第2
マスクデータ記憶部33、データ列番号指定用情報記憶
部38にそれぞれセットされる。
また、検索モードデータ記憶部(制御部11内にあり、
図示を省略)にもモードデータがセットされる。制御部
11は、このモードデータにより種々の検索専用タイミ
ングを生成するもので、それを第6図に示している。
図示を省略)にもモードデータがセットされる。制御部
11は、このモードデータにより種々の検索専用タイミ
ングを生成するもので、それを第6図に示している。
検索前処理は、データ列先頭アドレス生成部23によっ
て検索すべきデータ列の先頭アドレスを生成するプロセ
スである。なお、検索開始モードとして、常にエリアの
先頭から検索する第1検索モードと、前回に検索したデ
ータ列の次のデータ列から検索する第2検索モードとが
ある。これは、CPUIからアクセス信号群A4を介し
て制御部11に供給された起動信号のうち、第1検索モ
ード用のものであれば、検索エリア先頭アドレス記憶部
19からデータ列先頭アドレろ生成部23に供給される
検索エリア先頭アドレスをバスB1へ出力し、また第2
検索モード用のものであれば、次データ列先頭アドレス
生成部22がらデータ列先頭アドレス生成部23に供給
される次のデータ列の先頭アドレスをバスB、へ出力す
る。
て検索すべきデータ列の先頭アドレスを生成するプロセ
スである。なお、検索開始モードとして、常にエリアの
先頭から検索する第1検索モードと、前回に検索したデ
ータ列の次のデータ列から検索する第2検索モードとが
ある。これは、CPUIからアクセス信号群A4を介し
て制御部11に供給された起動信号のうち、第1検索モ
ード用のものであれば、検索エリア先頭アドレス記憶部
19からデータ列先頭アドレろ生成部23に供給される
検索エリア先頭アドレスをバスB1へ出力し、また第2
検索モード用のものであれば、次データ列先頭アドレス
生成部22がらデータ列先頭アドレス生成部23に供給
される次のデータ列の先頭アドレスをバスB、へ出力す
る。
なお、バスB1に出力されたアドレスデータは、次の検
索周期の検索前処理が行なわれるまで保持される。
索周期の検索前処理が行なわれるまで保持される。
第1データリードプロセスは、制御部11内の検索モー
ドデータ記憶部に設定されたモードデータによりキーデ
ータを1つ以上設定した際、第1キーデータの読出しを
行ない、これを第1サンプルデータ記憶部29に記憶す
るプロセスである。
ドデータ記憶部に設定されたモードデータによりキーデ
ータを1つ以上設定した際、第1キーデータの読出しを
行ない、これを第1サンプルデータ記憶部29に記憶す
るプロセスである。
この場合の読出しアドレスは、カレントアドレス生成部
24において、バスB、から供給されるデータ列先頭ア
ドレスと第1サンプリング用相対アドレス記憶部20か
ら供給される第1サンプリング用を口封アドレスとを加
算した結果で、カレントアドレス生成部24からバスB
2およびアドレス出力部25に出力され、このアドレス
出力部25から第2アドレスバス3□を介してデータメ
モリ7へ供給される。
24において、バスB、から供給されるデータ列先頭ア
ドレスと第1サンプリング用相対アドレス記憶部20か
ら供給される第1サンプリング用を口封アドレスとを加
算した結果で、カレントアドレス生成部24からバスB
2およびアドレス出力部25に出力され、このアドレス
出力部25から第2アドレスバス3□を介してデータメ
モリ7へ供給される。
第2データリードプロセスは、検索モードデータ記憶部
に設定されたモードデータによりキーデータを2つ設定
した際、第2キーデータの読出しを行ない、これを第2
サンプルデータ記憶部34に記憶するプロセスである。
に設定されたモードデータによりキーデータを2つ設定
した際、第2キーデータの読出しを行ない、これを第2
サンプルデータ記憶部34に記憶するプロセスである。
この場合の読出しアドレスは、カレントアドレス生成部
24において、バスB1から供給されるデータ列先頭ア
ドレスと第2サンプリング用相対アドレス記憶部21か
ら供給される第2サンプリング用相対アドレスとを加算
した結果で、データメモリ7へ供給する方法は第1デー
タリードプロセスの場合と同様である。
24において、バスB1から供給されるデータ列先頭ア
ドレスと第2サンプリング用相対アドレス記憶部21か
ら供給される第2サンプリング用相対アドレスとを加算
した結果で、データメモリ7へ供給する方法は第1デー
タリードプロセスの場合と同様である。
なお、検索モードデータ記憶部に設定されたモードデー
タによりキーデータによる検索を行なわないと認識する
と、前記第1および第2データリードプロセスは行なわ
ない。
タによりキーデータによる検索を行なわないと認識する
と、前記第1および第2データリードプロセスは行なわ
ない。
第3データリードプロセスは、検索モードデータ記憶部
に設定されたモードデータにより、データ列の先頭にデ
ータ列長部が1バイト以上存在するフォーマットのデー
タ列を検索すると設定した際、データ列の先頭1バイト
のデータを読出し、これをデータ列長記憶部16に記憶
するプロセスである。この場合の読出しアドレスは、カ
レントアドレス生成部24がバスB1から供給されるデ
ータ列先頭アドレスをバスB2、アドレス出力部25お
よび第2アドレスバス32を介してデータメモリ7へ供
給する。
に設定されたモードデータにより、データ列の先頭にデ
ータ列長部が1バイト以上存在するフォーマットのデー
タ列を検索すると設定した際、データ列の先頭1バイト
のデータを読出し、これをデータ列長記憶部16に記憶
するプロセスである。この場合の読出しアドレスは、カ
レントアドレス生成部24がバスB1から供給されるデ
ータ列先頭アドレスをバスB2、アドレス出力部25お
よび第2アドレスバス32を介してデータメモリ7へ供
給する。
第4データリードプロセスは、検索モードデータ記憶部
に設定されたモードデータにより、データ列の先頭にデ
ータ列長部が2バイト存在するフォーマットのデータ列
を検索すると設定した際、データ列の先頭データの次の
データを読出し、これをデータ列長記憶部16に記憶す
るプロセスである。この場合の読出しアドレスは、カレ
ントアドレス生成部24において、バスBlから供給さ
れるデータ列先頭アドレスを1つだけインクリメントし
た結果で、カレントアドレス生成部24からバスB2、
アドレス出力部25および第2アドレスバス3□を介し
てデータメモリ7へ供給される。
に設定されたモードデータにより、データ列の先頭にデ
ータ列長部が2バイト存在するフォーマットのデータ列
を検索すると設定した際、データ列の先頭データの次の
データを読出し、これをデータ列長記憶部16に記憶す
るプロセスである。この場合の読出しアドレスは、カレ
ントアドレス生成部24において、バスBlから供給さ
れるデータ列先頭アドレスを1つだけインクリメントし
た結果で、カレントアドレス生成部24からバスB2、
アドレス出力部25および第2アドレスバス3□を介し
てデータメモリ7へ供給される。
なお、検索モードデータ記憶部に設定されたモードデー
タにより、固定長で処理されるデータ列の検索で、特に
データ列の先頭にデータ列長部が存在しないフォーマッ
トのデータ列の検索であると設定すると、前記第3およ
び第4データリードプロセスは行なわない。
タにより、固定長で処理されるデータ列の検索で、特に
データ列の先頭にデータ列長部が存在しないフォーマッ
トのデータ列の検索であると設定すると、前記第3およ
び第4データリードプロセスは行なわない。
また、データ列長記憶部16は、たとえば16ビツトの
アドレス値を記憶する。先の第3データリードプロセス
において読出されたデータは、16ビツトのうち上位8
ビツトにセットされ、第4データリードプロセスにおい
て読出されたデータは、下位8ビツトにセットされる。
アドレス値を記憶する。先の第3データリードプロセス
において読出されたデータは、16ビツトのうち上位8
ビツトにセットされ、第4データリードプロセスにおい
て読出されたデータは、下位8ビツトにセットされる。
なン5、第6図(b)(e)(h)の形式を取る検索時
には、第3データリードプロセスにおいて読出されたデ
ータは、16ビツトのうち下位8ビツトにセットされ、
このとき上位8ビツトは常に「00H」というデータ値
が記憶される。
には、第3データリードプロセスにおいて読出されたデ
ータは、16ビツトのうち下位8ビツトにセットされ、
このとき上位8ビツトは常に「00H」というデータ値
が記憶される。
検索後処理は、制御部11が本装置の動作を停止するか
否かの判断と、次のデータ列の先頭アドレスを生成する
プロセスである。次のデータ列の先頭アドレスは以下の
ようにして生成する。まず、データ列長加工部15にお
いて、先の第3および第4データリードプロセスによっ
てデータ列長記憶部16に記憶されたデータ列長情報と
、先にCPUIからアクセス信号群A、1に基づいてデ
ータ列長用マスクデータ記憶部14にセットされたデー
タ列長用マスクデータを用いてデータ列長を算出し、そ
の算出結果をバスB3に出力する。この機能は、たとえ
ば2バイトのデータ列長情報を含んだデータ列で、かつ
2バイトデータのうち真のデータ列長を示す部分が下位
13ビツトで、上位3ビツトはデータ列属性フラグが割
当てられているといったフォーマットを持つデータ列の
検索時、上位3ビツトを無視して2バイトデータとして
以降の回路が使用できるようにするためのものである。
否かの判断と、次のデータ列の先頭アドレスを生成する
プロセスである。次のデータ列の先頭アドレスは以下の
ようにして生成する。まず、データ列長加工部15にお
いて、先の第3および第4データリードプロセスによっ
てデータ列長記憶部16に記憶されたデータ列長情報と
、先にCPUIからアクセス信号群A、1に基づいてデ
ータ列長用マスクデータ記憶部14にセットされたデー
タ列長用マスクデータを用いてデータ列長を算出し、そ
の算出結果をバスB3に出力する。この機能は、たとえ
ば2バイトのデータ列長情報を含んだデータ列で、かつ
2バイトデータのうち真のデータ列長を示す部分が下位
13ビツトで、上位3ビツトはデータ列属性フラグが割
当てられているといったフォーマットを持つデータ列の
検索時、上位3ビツトを無視して2バイトデータとして
以降の回路が使用できるようにするためのものである。
このようにして算出されたデータ列長は、バスB3を介
して次データ列先頭アドレス生成部22に供給される。
して次データ列先頭アドレス生成部22に供給される。
次データ列先頭アドレス生成部22は、バスB3を介し
て供給されるデータ列長とバスB1またはB2から供給
されるデータ列先頭アドレスとを加算し、その加算結果
を次のデータ列先頭アドレスとしてデータ列先頭アドレ
ス生成部23に出力する。なお、このときバスB2には
、カレントアドレス生成部24によりデータ列先頭アド
レスにデータ列長を示すデータのバイト数分加算した値
が出力されている。次データ列先頭アドレス生成部22
は、先の検索モードデータ記憶部に設定されたモードデ
ータにより、データ列長の値がデータ列長を示すデータ
のバイト数、を含むようなフォーマットのデータ列の検
索であった場合には、バスB1に供給されるデータを使
用し、またデータ列長の値がデータ列長を示すデータの
バイト数を含まないフォーマットのデータ列の検索であ
った場合には、バスB2に供給されるデータを使用する
。
て供給されるデータ列長とバスB1またはB2から供給
されるデータ列先頭アドレスとを加算し、その加算結果
を次のデータ列先頭アドレスとしてデータ列先頭アドレ
ス生成部23に出力する。なお、このときバスB2には
、カレントアドレス生成部24によりデータ列先頭アド
レスにデータ列長を示すデータのバイト数分加算した値
が出力されている。次データ列先頭アドレス生成部22
は、先の検索モードデータ記憶部に設定されたモードデ
ータにより、データ列長の値がデータ列長を示すデータ
のバイト数、を含むようなフォーマットのデータ列の検
索であった場合には、バスB1に供給されるデータを使
用し、またデータ列長の値がデータ列長を示すデータの
バイト数を含まないフォーマットのデータ列の検索であ
った場合には、バスB2に供給されるデータを使用する
。
一方、検索エリア残量計算部13においては、検索エリ
アサイズ記憶部12に設定された検索エリアサイズを受
入れるとともに、データ列長加工部15の出力データを
バスB3を介して受入れることにより、次データ列先頭
アドレス以降のエリア残量を随時算出する。ただし、先
の検索モードデータ記憶部に設定されたモードデータに
より、データ列長の値がデータ列長を示すデータのバイ
ト数を含むようなフォーマットのデータ列の検索であっ
た場合には、バスB3に供給されているデータをそのま
ま使用し、またデータ列長の値がデータ列長を示すデー
タのバイト数を含まないフォーマットのデータ列の検索
であった場合には、バスB3に供給されているデータに
データ列長を示すデータのバイト数分加えて、これを使
用する。
アサイズ記憶部12に設定された検索エリアサイズを受
入れるとともに、データ列長加工部15の出力データを
バスB3を介して受入れることにより、次データ列先頭
アドレス以降のエリア残量を随時算出する。ただし、先
の検索モードデータ記憶部に設定されたモードデータに
より、データ列長の値がデータ列長を示すデータのバイ
ト数を含むようなフォーマットのデータ列の検索であっ
た場合には、バスB3に供給されているデータをそのま
ま使用し、またデータ列長の値がデータ列長を示すデー
タのバイト数を含まないフォーマットのデータ列の検索
であった場合には、バスB3に供給されているデータに
データ列長を示すデータのバイト数分加えて、これを使
用する。
もし、このときエリア残量の値が零もしくは負となれば
、検索エリア残量計算部13は制御部11に対して停止
要求を出力する。
、検索エリア残量計算部13は制御部11に対して停止
要求を出力する。
検索済データ列数記憶部40は、本装置の起動時には初
期値(OOooHex)となっており、本プロセスによ
り1つだけインクリメントされる。
期値(OOooHex)となっており、本プロセスによ
り1つだけインクリメントされる。
また、データ列長チエツク部17においては、最小デー
タ列長記憶部18に設定された値とバスB3に出力され
た値とを比較し、前者よりも後者の方が小なる値となっ
ていれば、制御部11に対して停止要求を出力する。こ
れらの停止要求のうち、どれによる停止要求なのかがC
PUIから容易にわかるように、停止ステータスが制御
部11内で記憶される。
タ列長記憶部18に設定された値とバスB3に出力され
た値とを比較し、前者よりも後者の方が小なる値となっ
ていれば、制御部11に対して停止要求を出力する。こ
れらの停止要求のうち、どれによる停止要求なのかがC
PUIから容易にわかるように、停止ステータスが制御
部11内で記憶される。
さて、第1データリードプロセスにおいて、第1サンプ
ルデータ記憶部29に記憶された第1サンプルデータは
第1サンプルデータ加工部30に供給される。第1サン
プルデータ加工部30は、第1マスクデータ記憶部28
に設定された第1マスクデータを受入れ、先の第1サン
プルデータと論理積をとって、その結果を第1比較部3
1に供給する。第1比較部31は、第1サンプルデータ
加工部30の出力データと第1キーデータ記憶部27に
設定された第1キーデータとの比較を行ない、その比較
結果を信号S2として検索判定部37に供給する。
ルデータ記憶部29に記憶された第1サンプルデータは
第1サンプルデータ加工部30に供給される。第1サン
プルデータ加工部30は、第1マスクデータ記憶部28
に設定された第1マスクデータを受入れ、先の第1サン
プルデータと論理積をとって、その結果を第1比較部3
1に供給する。第1比較部31は、第1サンプルデータ
加工部30の出力データと第1キーデータ記憶部27に
設定された第1キーデータとの比較を行ない、その比較
結果を信号S2として検索判定部37に供給する。
また、第2データリードプロセスにおいて、第2サンプ
ルデータ記憶部34に記憶された第2サンプルデータは
第2サンプルデータ加工部35に供給される。第2サン
プルデータ加工部35は、第2マスクデータ記憶部33
に設定された第2マスクデータを受入れ、先の第2サン
プルデータと論理積をとって、その結果を第2比較部3
6に供給する。第2比較部36は、第2サンプルデータ
加工部35の出力データと第2キーデータ記憶部32に
設定された第2キーデータとの比較を行ない、その比較
結果を信号S3として検索判定部37に供給する。
ルデータ記憶部34に記憶された第2サンプルデータは
第2サンプルデータ加工部35に供給される。第2サン
プルデータ加工部35は、第2マスクデータ記憶部33
に設定された第2マスクデータを受入れ、先の第2サン
プルデータと論理積をとって、その結果を第2比較部3
6に供給する。第2比較部36は、第2サンプルデータ
加工部35の出力データと第2キーデータ記憶部32に
設定された第2キーデータとの比較を行ない、その比較
結果を信号S3として検索判定部37に供給する。
検索判定部37は、検索モードデータ記憶部に設定され
たモードデータにより、信号S2と信号S3とによる比
較結果の論理をとり、その結果を信号S4として制御部
11に供給する。なお、比較結果の論理は、論理和、す
なわち2つの比較結果のうちどちらか一方が一致してい
れば検索対象のデータ列であるとするものと、論理積、
すなわち2つの比較結果とも一致していなければ検索対
象のデータ列ではないとするものがある。
たモードデータにより、信号S2と信号S3とによる比
較結果の論理をとり、その結果を信号S4として制御部
11に供給する。なお、比較結果の論理は、論理和、す
なわち2つの比較結果のうちどちらか一方が一致してい
れば検索対象のデータ列であるとするものと、論理積、
すなわち2つの比較結果とも一致していなければ検索対
象のデータ列ではないとするものがある。
信号S4によって供給された結果、制御部11が検索対
象のデータ列であると認識すると、制御部11はデータ
列番号指定用情報記憶部38に設定されているデータ列
番号を1つ減算する。このとき、指定データ列番号検出
部39は、データ列番号指定用情報記憶部38の値をチ
エツクし、もしその値が零となれば制御部11に対して
停止要求を出力する。
象のデータ列であると認識すると、制御部11はデータ
列番号指定用情報記憶部38に設定されているデータ列
番号を1つ減算する。このとき、指定データ列番号検出
部39は、データ列番号指定用情報記憶部38の値をチ
エツクし、もしその値が零となれば制御部11に対して
停止要求を出力する。
また、第6図(g)(h)(i)で示すように、キーデ
ータによる検索を行なわない場合は、信号S2および信
号S3による比較結果は無視され、一義的に検索対象デ
ータ列であることを信号S4を介して出力する。また、
第6図(d)(e)(f)のように、第1キーデータの
み使用の検索時には、信号S4の結果は信号S2の結果
と同一となる。
ータによる検索を行なわない場合は、信号S2および信
号S3による比較結果は無視され、一義的に検索対象デ
ータ列であることを信号S4を介して出力する。また、
第6図(d)(e)(f)のように、第1キーデータの
み使用の検索時には、信号S4の結果は信号S2の結果
と同一となる。
以上のように、検索エリア残量計算部13、データ列長
チエツク部17、および指定データ列番号検出部39の
うち、いずれかが停止要求を出力すると、制御部11は
動作を停止し、信号S1によってゲート6を導通状態に
する。そして、CPUIは、第1データバス21を介し
て制御部11内の停止ステータス、データ列先頭アドレ
ス生成部23内の検索データ列先頭アドレス、検索エリ
ア残量計算部13内のエリア残量、指定データ列番号検
出部39内の指定データ列番号残量、および検索済デー
タ列数記憶部40内の検索済データ列数をそれぞれ読出
すことにより、検索結果を得ることができる。
チエツク部17、および指定データ列番号検出部39の
うち、いずれかが停止要求を出力すると、制御部11は
動作を停止し、信号S1によってゲート6を導通状態に
する。そして、CPUIは、第1データバス21を介し
て制御部11内の停止ステータス、データ列先頭アドレ
ス生成部23内の検索データ列先頭アドレス、検索エリ
ア残量計算部13内のエリア残量、指定データ列番号検
出部39内の指定データ列番号残量、および検索済デー
タ列数記憶部40内の検索済データ列数をそれぞれ読出
すことにより、検索結果を得ることができる。
第7図は制御部11内の検索モードデータ記憶部に設定
されるモードデータのフォーマットを示すものである。
されるモードデータのフォーマットを示すものである。
このモードデータは例えば1バイトデータである。第0
および第1ビツトを用いてデータ列に付加されているデ
ータ列長情報のバイト数を認識する。この第0および第
1ビツトが「00」または「11」であれば、固定長、
すなわち第3および第4データリードプロセスを行なわ
ずに、あらかじめデータ列長記憶部16に設定したデー
タ列長に基づいて、データ列先頭アドレスを順次更新し
ながら検索してゆく。「01」のときは、データ列長が
1バイトのフォーマットを持つデータ列を検索する。「
10」のときは、データ列長が2バイトのフォーマット
を持つデータ列を検索する。なお、「11」については
、固定長データをディクリメント運用することにより、
アドレスの大きい箇所から小さい箇所へ向っての検索を
行なう。
および第1ビツトを用いてデータ列に付加されているデ
ータ列長情報のバイト数を認識する。この第0および第
1ビツトが「00」または「11」であれば、固定長、
すなわち第3および第4データリードプロセスを行なわ
ずに、あらかじめデータ列長記憶部16に設定したデー
タ列長に基づいて、データ列先頭アドレスを順次更新し
ながら検索してゆく。「01」のときは、データ列長が
1バイトのフォーマットを持つデータ列を検索する。「
10」のときは、データ列長が2バイトのフォーマット
を持つデータ列を検索する。なお、「11」については
、固定長データをディクリメント運用することにより、
アドレスの大きい箇所から小さい箇所へ向っての検索を
行なう。
第2ビツトはデータ列長個別情報であり、検索するデー
タ列に付加されているデータ列長の値がそれ自身を含む
ものであれば「0」、含まないものであれば「1」にそ
れぞれ対応する。なお、第3ビツトは未使用であり、「
0」に固定されている。
タ列に付加されているデータ列長の値がそれ自身を含む
ものであれば「0」、含まないものであれば「1」にそ
れぞれ対応する。なお、第3ビツトは未使用であり、「
0」に固定されている。
第4および第5ビツトによりキーデータによる検索指定
を行なう。この第4および第5ビツトが「00」であれ
ば、キーデータ未使用となり、第1および第2データリ
ードプロセスは行なわれない。「01」であれば、キー
データを1つだけ使用することを示し、第1データリー
ドプロセスが行なわれる。「10」もしくは「11」で
あれば、キーデータを2つ使用することを示し、第1お
よび第2データリードプロセスが行なわれる。
を行なう。この第4および第5ビツトが「00」であれ
ば、キーデータ未使用となり、第1および第2データリ
ードプロセスは行なわれない。「01」であれば、キー
データを1つだけ使用することを示し、第1データリー
ドプロセスが行なわれる。「10」もしくは「11」で
あれば、キーデータを2つ使用することを示し、第1お
よび第2データリードプロセスが行なわれる。
′:jX6および第7ビツトは、第4および第5ビツト
で「10」もしくは「11」を指定した場合、検索判定
部37における信号S2および信号S3の論理を指定す
るものである。この第6および第7ビツトが「00」で
あると、論理積条件となり、第1キーデータと第2キー
データとが共に満足したとき検索対象データ列とする。
で「10」もしくは「11」を指定した場合、検索判定
部37における信号S2および信号S3の論理を指定す
るものである。この第6および第7ビツトが「00」で
あると、論理積条件となり、第1キーデータと第2キー
データとが共に満足したとき検索対象データ列とする。
「01」であると、排他的論理和条件となる。「10」
もしくは「11」であると、論理和条件となる。
もしくは「11」であると、論理和条件となる。
次に、第8図ないし第10図を用いて検索手順を説明す
る。第8図はアドレスr2000(Hex)Jからr2
1DO(Hex)Jに図示するようなデータ列が記憶さ
れていることを示し、第9図はアドレスrlo00 (
Hex)Jからrl IDO(Hex)Jに図示するよ
うなデータ列が記憶されていることを示している。
る。第8図はアドレスr2000(Hex)Jからr2
1DO(Hex)Jに図示するようなデータ列が記憶さ
れていることを示し、第9図はアドレスrlo00 (
Hex)Jからrl IDO(Hex)Jに図示するよ
うなデータ列が記憶されていることを示している。
第10図はモードデータおよび各設定データの組合せを
11通り例示し、それに対応する検索結果を示しである
。結果1は、第1検索モードで起動をかけた後、本装置
が停止したときの各読出しパラメータの値を示す。結果
2〜4は、その後第2検索モードで起動し、停止する動
作を繰返し、その停止時の各読出しパラメータの値を示
したものである。なお、マスクデータと被マスクデータ
とはビット単位の論理積を取るようになっている。
11通り例示し、それに対応する検索結果を示しである
。結果1は、第1検索モードで起動をかけた後、本装置
が停止したときの各読出しパラメータの値を示す。結果
2〜4は、その後第2検索モードで起動し、停止する動
作を繰返し、その停止時の各読出しパラメータの値を示
したものである。なお、マスクデータと被マスクデータ
とはビット単位の論理積を取るようになっている。
したがって、マスクデータの全てのビットが「1」のと
きは、彼マスクデータがそのまま使用されることになる
。
きは、彼マスクデータがそのまま使用されることになる
。
ケース1は、データ列長r I C1(He x) j
の固定長アップ方向検索で、キーデータは[10(He
x)Jおよび130 (Hex)Jである。
の固定長アップ方向検索で、キーデータは[10(He
x)Jおよび130 (Hex)Jである。
キーデータとしては、共に第1バイト目を参照するよう
になっている。検索エリア先頭アドレスはr2000
(Hex)J 、エリアサイズはro 1 EO(H,
e x)Jである。また、条件が一致したデータ列のう
ち3つ目で停止するようになっている。
になっている。検索エリア先頭アドレスはr2000
(Hex)J 、エリアサイズはro 1 EO(H,
e x)Jである。また、条件が一致したデータ列のう
ち3つ目で停止するようになっている。
さて、第1検索モードによる起動がかかると、第1図の
バスB1にはr2000 (Hex)Jが出力される。
バスB1にはr2000 (Hex)Jが出力される。
次に、第3データリードプロセスにより、r2001
(Hex)Jの値、すなわちrlO(Hex)Jが第1
サンプルデータ記憶部29に記憶される。次に、第4デ
ータリードプロセスにより、同様にrlO(Hex)J
か第2サンプルデータ記憶部34に記憶される。ここで
、第1マスクデータおよび第2マスクデータはζ共にr
FF (Hex)Jとなっているので、第1サンプルデ
ータ加工部30および第2サンプルデータ加工部35の
各出力にはrl O(Hex)Jの値が出力される。第
1キーデータは「10(Hex)J、第2キーデータは
「30(Hex)Jなので、信号S2は一致であること
を示し、信号S3は不一致であることを示す。ここで、
モードは論理和条件を示しているため、データ列番号指
定用情報はr0003 (Hex)Jからr0002
(Hex)J へ減算される。
(Hex)Jの値、すなわちrlO(Hex)Jが第1
サンプルデータ記憶部29に記憶される。次に、第4デ
ータリードプロセスにより、同様にrlO(Hex)J
か第2サンプルデータ記憶部34に記憶される。ここで
、第1マスクデータおよび第2マスクデータはζ共にr
FF (Hex)Jとなっているので、第1サンプルデ
ータ加工部30および第2サンプルデータ加工部35の
各出力にはrl O(Hex)Jの値が出力される。第
1キーデータは「10(Hex)J、第2キーデータは
「30(Hex)Jなので、信号S2は一致であること
を示し、信号S3は不一致であることを示す。ここで、
モードは論理和条件を示しているため、データ列番号指
定用情報はr0003 (Hex)Jからr0002
(Hex)J へ減算される。
このとき、検索エリア残量は、rolEO(Hex)J
から固定長分、すなわちroolo(Hex)Jを減算
した値r01DO(Hex)Jとなる。そして、次デー
タ列先頭アドレス生成部22の出力には次の値r201
0 (Hex)Jが出力される。
から固定長分、すなわちroolo(Hex)Jを減算
した値r01DO(Hex)Jとなる。そして、次デー
タ列先頭アドレス生成部22の出力には次の値r201
0 (Hex)Jが出力される。
この場合、停止条件ではないので、再び検索サイクルを
開始する。次の検索サイクルでは、第1サンプルデータ
および第2サンプルデータは共にr20 (Hex)J
となるため、データ列番号指定用情報はそのまま保持さ
れる。検索エリア残量は、減算されてrolcO(He
x)jとなり、次データ列先頭アドレス生成部22の出
力にはr2020 (l(ex)Jが出力される。この
場合も、停止条件は満足せず、再び検索サイクルを開始
する。
開始する。次の検索サイクルでは、第1サンプルデータ
および第2サンプルデータは共にr20 (Hex)J
となるため、データ列番号指定用情報はそのまま保持さ
れる。検索エリア残量は、減算されてrolcO(He
x)jとなり、次データ列先頭アドレス生成部22の出
力にはr2020 (l(ex)Jが出力される。この
場合も、停止条件は満足せず、再び検索サイクルを開始
する。
このようにして、データ列番号指定用情報がroooo
(Hex)Jとなった状態がケース1の結果1である
。このとき、検索されたデータ列の先頭アドレスはr2
030 (Hex)J 、またエリア残量はro IA
O(Hex)J 、検索済データ列数はr0004 (
Hex)J 、すなわち4つのデータ列であることをそ
れぞれ示す。
(Hex)Jとなった状態がケース1の結果1である
。このとき、検索されたデータ列の先頭アドレスはr2
030 (Hex)J 、またエリア残量はro IA
O(Hex)J 、検索済データ列数はr0004 (
Hex)J 、すなわち4つのデータ列であることをそ
れぞれ示す。
順に結果1〜4を見ていくと、データ列の第2バイト目
がrlO(Hex)jもしくは[31](Hex)Jと
なっているデータ列のうち、3Xn (n−整数)番目
で停止している。
がrlO(Hex)jもしくは[31](Hex)Jと
なっているデータ列のうち、3Xn (n−整数)番目
で停止している。
ケース2は、データ列の第2バイト目がr10(Hex
)Jで、かつ第3バイト目が[21CHex)Jとなっ
ているデータ列を順次検索した例である。
)Jで、かつ第3バイト目が[21CHex)Jとなっ
ているデータ列を順次検索した例である。
ケース3は、データ列の第2バイト目が[10(Hex
)Jであり、かつ第3バイト目の第4ビツト目力(「1
」となっているデータ列のうち、5xn (n−整数)
番目のものを検索した例である。ここで、結果2での停
止は、エリア残量が零となったことに起因しているもの
で、指定データ列番号残量はroool (Hex)J
となっている。このため、検索釘効データ列は結果1に
より得たもののみとなる。
)Jであり、かつ第3バイト目の第4ビツト目力(「1
」となっているデータ列のうち、5xn (n−整数)
番目のものを検索した例である。ここで、結果2での停
止は、エリア残量が零となったことに起因しているもの
で、指定データ列番号残量はroool (Hex)J
となっている。このため、検索釘効データ列は結果1に
より得たもののみとなる。
ケース4は、データ列の第4バイト目が「10(Hex
)Jとなっているデータ列を順次検索した例である。結
果3において停止したのは、エリア残量が零となったた
めで、指定データ列番号残昌は零となっていない。した
がって、検索有効データ列は結果1および結果2により
得たものとなる。
)Jとなっているデータ列を順次検索した例である。結
果3において停止したのは、エリア残量が零となったた
めで、指定データ列番号残昌は零となっていない。した
がって、検索有効データ列は結果1および結果2により
得たものとなる。
ケース5は、キーデータ無しの検索で、4Xn(n−整
数)番■のものを検索した例である。アドレスr210
0 (Hex)Jからro 0 B 0(Hex)J分
のエリアを検索している。また、データ列長は固定で、
r20 (Hex)Jである。
数)番■のものを検索した例である。アドレスr210
0 (Hex)Jからro 0 B 0(Hex)J分
のエリアを検索している。また、データ列長は固定で、
r20 (Hex)Jである。
この例では、結果2の停止条件はエリア残量が負になっ
たことである。したがって、検索有効データ列は結果1
により得たものとなる。
たことである。したがって、検索有効データ列は結果1
により得たものとなる。
ケース6は、2バイトのデータ列長が付加されているデ
ータ列フォーマットモードの検索例である。キーデータ
無しの検索で、3Xn (n−整数)番目のものを検索
する。なお、このフォーマット例では、2バイトのデー
タ列長、すなわち16ビツトのうち下位15ビツトを有
効データ列長とするために、データ列長用マスクデータ
がr7FFF (Hex)Jとなっている。この例では
、結果4の停止条件はエリア残量が零になったことであ
る。このとき、指定データ列番号残量は零ではないので
、検索a効データ列は結果1〜3により得たものである
。
ータ列フォーマットモードの検索例である。キーデータ
無しの検索で、3Xn (n−整数)番目のものを検索
する。なお、このフォーマット例では、2バイトのデー
タ列長、すなわち16ビツトのうち下位15ビツトを有
効データ列長とするために、データ列長用マスクデータ
がr7FFF (Hex)Jとなっている。この例では
、結果4の停止条件はエリア残量が零になったことであ
る。このとき、指定データ列番号残量は零ではないので
、検索a効データ列は結果1〜3により得たものである
。
ケース7は、ケース6と同様のフォーマットモードの検
索であり、データ列長2バイトのうち上位1ビツトが「
1」となっているデータ列の検索例である。ただし、デ
ータ列長の有効バイトは2バイトのうち下位1バイトと
するため、データ列長用マスクデータはroOFF (
Hex)Jとなっている。また、この例では、該当デー
タ列の数を調べるため、データ列番号指定用情報を[F
FFF (Hex)Jとしである。このとき、結果1で
は、エリア残量が零となったことにより停止したことを
示している。検索済データ列数はr0014 (Hex
)J 、また指定データ列番号残量がrFFFB (H
ex)Jとなっているので、該当データ列数はrFFF
F−FFFBJの計算により4つであることがわかる。
索であり、データ列長2バイトのうち上位1ビツトが「
1」となっているデータ列の検索例である。ただし、デ
ータ列長の有効バイトは2バイトのうち下位1バイトと
するため、データ列長用マスクデータはroOFF (
Hex)Jとなっている。また、この例では、該当デー
タ列の数を調べるため、データ列番号指定用情報を[F
FFF (Hex)Jとしである。このとき、結果1で
は、エリア残量が零となったことにより停止したことを
示している。検索済データ列数はr0014 (Hex
)J 、また指定データ列番号残量がrFFFB (H
ex)Jとなっているので、該当データ列数はrFFF
F−FFFBJの計算により4つであることがわかる。
ケース8は、1バイトのデータ列長(データ列長の値は
データ列長自身も含む)が付加されているデータ列フォ
ーマットモードの検索であり、キーデータ無しモードで
ある。そして、アドレスr2191 (Hex)Jから
ro04F(Hex)J分のエリアを順次検索する例で
ある。
データ列長自身も含む)が付加されているデータ列フォ
ーマットモードの検索であり、キーデータ無しモードで
ある。そして、アドレスr2191 (Hex)Jから
ro04F(Hex)J分のエリアを順次検索する例で
ある。
この例では、結果3の停止条件はエリア残量が負となっ
たことである。したがって、検索有効データ列は結果1
および2により得たものになる。
たことである。したがって、検索有効データ列は結果1
および2により得たものになる。
ケース9は、ケース4における条件のもとにダウン検索
を行なった例である。検索先頭アドレスはr21DO(
Hex)Jで、rolEO(Hex)J分のエリアを検
索する。この例では、結果3の停止条件はエリア残量が
零となったことである。そして、このとき指定データ列
番号残量は零ではないので、結果1および2により得た
ものが該当データ列となる(これはケース4の結果と同
一)。
を行なった例である。検索先頭アドレスはr21DO(
Hex)Jで、rolEO(Hex)J分のエリアを検
索する。この例では、結果3の停止条件はエリア残量が
零となったことである。そして、このとき指定データ列
番号残量は零ではないので、結果1および2により得た
ものが該当データ列となる(これはケース4の結果と同
一)。
ケース10は、2バイトのデータ列長(データ列長の値
はデータ列長自身を含まない)が付加されているデータ
列フォーマットモードの検索であり、キーデータ無しモ
ードである。ただし、この例では、最小データ列長をr
0018 (Hex)Jとしである。したがって、結果
2において停止したのは、アドレスr1030 (He
x)Jから始まるデータ列のデータ長の値がr0018
(Hex)Jに満たなかったことになる。なお、CPU
Iは、停止ステータスによりデータ列長不足が認識でき
る。
はデータ列長自身を含まない)が付加されているデータ
列フォーマットモードの検索であり、キーデータ無しモ
ードである。ただし、この例では、最小データ列長をr
0018 (Hex)Jとしである。したがって、結果
2において停止したのは、アドレスr1030 (He
x)Jから始まるデータ列のデータ長の値がr0018
(Hex)Jに満たなかったことになる。なお、CPU
Iは、停止ステータスによりデータ列長不足が認識でき
る。
ケース11は、1バイトのデータ列長(データ列長の値
はデータ列長自身を含まない)が付加されているデータ
列フォーマットモードの検索である。
はデータ列長自身を含まない)が付加されているデータ
列フォーマットモードの検索である。
このように、次のデータ列の先頭アドレスを生成するた
めに用いるデータ列長情報として、現在のデータ列の先
頭に付加されているデータ列長情報を用いることにより
、可変長のデータ列に対しての検索を行なうことができ
、メモリ記憶効率の高い可変長記憶方式を維持しつつそ
の検索処理が実現できる。
めに用いるデータ列長情報として、現在のデータ列の先
頭に付加されているデータ列長情報を用いることにより
、可変長のデータ列に対しての検索を行なうことができ
、メモリ記憶効率の高い可変長記憶方式を維持しつつそ
の検索処理が実現できる。
また、最小データ列長情報を有し、データ列長情報を読
出した際、この最小データ列長情報と比較し、読出した
データ列長情報が最小データ列長情報に満たない場合に
は検索動作を停止することにより、何らかの原因によっ
てデータ列中のデータ列長情報が変化してしまった場合
においても、安全に検索処理を行なうことが可能となり
、システムとしての安全性が高まる。
出した際、この最小データ列長情報と比較し、読出した
データ列長情報が最小データ列長情報に満たない場合に
は検索動作を停止することにより、何らかの原因によっ
てデータ列中のデータ列長情報が変化してしまった場合
においても、安全に検索処理を行なうことが可能となり
、システムとしての安全性が高まる。
[発明の効果]
以に詳述したように本発明によれば、可変長のデータ列
に対しての検索を行なうことができるデータ列検索装置
を提供できる。
に対しての検索を行なうことができるデータ列検索装置
を提供できる。
図は本発明の一実施例を説明するためのもので、第1図
はデータ列検索装置の構成を示すブロック図、第2図は
マイクロコンピュータシステムのfM成を示すブロック
図、第3図はデータメモリのフォーマットを示す図、第
4図および第5図はエリア内のデータ列記憶状態を示す
図、第6図は各検索モードにおける検索1周期あたりの
詳細プロセスを説明するための図、第7図は検索モード
データのフォーマットを示す図、第8図および第9図は
メモリ内に記憶されているデータ列のパターン例を示す
図、第10図は具体的動作を説明するだめの検索パラメ
ータと検索結果との対応を示す図である。 1・・・CPU (制御部)、4・・・プログラムメモ
リ、7・・・データメモリ (メモリ部)、8・・・デ
ータ列検索装置、11・・・制御部、14・・・データ
列長用マスクデータ記憶部、15・・・データ列長加工
部、16・・・データ列長記憶部、22・・・次データ
列先頭アドレス生成部、23・・・データ列先頭アドレ
ス生成部、24・・・カレントアドレス生成部、25・
・・アドレス出力部、27・・・第1キーデータ記憶部
、29・・・第1サンプルデータ記憶部、31・・・第
1比較部、32・・・第2キーデータ記憶部、34・・
・第2サンプルデータ記憶部、36・・・第2比較部、
37・・・検索判定部。 出願人代理人 弁理士 鈴江武彦 第2図 第3図 第4図 第5図 第6図 第6図 第7図
はデータ列検索装置の構成を示すブロック図、第2図は
マイクロコンピュータシステムのfM成を示すブロック
図、第3図はデータメモリのフォーマットを示す図、第
4図および第5図はエリア内のデータ列記憶状態を示す
図、第6図は各検索モードにおける検索1周期あたりの
詳細プロセスを説明するための図、第7図は検索モード
データのフォーマットを示す図、第8図および第9図は
メモリ内に記憶されているデータ列のパターン例を示す
図、第10図は具体的動作を説明するだめの検索パラメ
ータと検索結果との対応を示す図である。 1・・・CPU (制御部)、4・・・プログラムメモ
リ、7・・・データメモリ (メモリ部)、8・・・デ
ータ列検索装置、11・・・制御部、14・・・データ
列長用マスクデータ記憶部、15・・・データ列長加工
部、16・・・データ列長記憶部、22・・・次データ
列先頭アドレス生成部、23・・・データ列先頭アドレ
ス生成部、24・・・カレントアドレス生成部、25・
・・アドレス出力部、27・・・第1キーデータ記憶部
、29・・・第1サンプルデータ記憶部、31・・・第
1比較部、32・・・第2キーデータ記憶部、34・・
・第2サンプルデータ記憶部、36・・・第2比較部、
37・・・検索判定部。 出願人代理人 弁理士 鈴江武彦 第2図 第3図 第4図 第5図 第6図 第6図 第7図
Claims (1)
- 【特許請求の範囲】 所定の処理を行なう制御部と、この制御部によってアク
セスされ、それぞれデータ列長情報が付加されている複
数のデータ列を記憶するメモリ部とを有するものにおい
て、 前記メモリ部への供給アドレスを随時更新しながら前記
メモリ部内のデータ列を検索するデータ列検索装置であ
って、 アドレス更新情報および前記制御部から供給される第1
アドレスデータに基づき第2アドレスデータを生成する
アドレス生成手段と、 このアドレス生成手段で生成された第2アドレスデータ
に基づき前記メモリ部をアクセスするアクセス手段と、 このアクセス手段により前記メモリ部内のデータ列に付
加されているデータ列長情報を読出し、この読出したデ
ータ列長情報を前記アドレス更新情報とする手段と を具備したことを特徴とするデータ列検索装置。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP63063471A JPH01237826A (ja) | 1988-03-18 | 1988-03-18 | データ列検索装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP63063471A JPH01237826A (ja) | 1988-03-18 | 1988-03-18 | データ列検索装置 |
Publications (1)
Publication Number | Publication Date |
---|---|
JPH01237826A true JPH01237826A (ja) | 1989-09-22 |
Family
ID=13230179
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP63063471A Pending JPH01237826A (ja) | 1988-03-18 | 1988-03-18 | データ列検索装置 |
Country Status (1)
Country | Link |
---|---|
JP (1) | JPH01237826A (ja) |
-
1988
- 1988-03-18 JP JP63063471A patent/JPH01237826A/ja active Pending
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6782465B1 (en) | Linked list DMA descriptor architecture | |
JPS589982B2 (ja) | 情報検索装置 | |
JP3183669B2 (ja) | 可変長の文字ストリング用のプロセッサ | |
JP3003915B2 (ja) | 単語辞書検索装置 | |
US5379402A (en) | Data processing device for preventing inconsistency of data stored in main memory and cache memory | |
US4967391A (en) | Data string retrieval apparatus for IC card | |
JPH01237826A (ja) | データ列検索装置 | |
JPH01237824A (ja) | データ列検索装置 | |
JPH01237825A (ja) | データ列検索装置 | |
JP2721168B2 (ja) | データ列検索装置 | |
JPH01237828A (ja) | データ列検索装置 | |
JPH01237722A (ja) | データ列検索装置 | |
JPH01237827A (ja) | データ列検索装置 | |
JPS63727A (ja) | 情報検索方法 | |
JPS5856145A (ja) | デ−タ検索方式 | |
JPS59191649A (ja) | プログラムの生成方式 | |
JPS6046456B2 (ja) | デ−タアクセス装置 | |
JPS6145485A (ja) | 磁気バブルメモリ制御装置 | |
JPH04506125A (ja) | キャッシュを備えた計算機 | |
JPS5829046A (ja) | メモリソーティング回路 | |
JPH0232438A (ja) | キャッシュ付入出力制御装置 | |
JPS59180720A (ja) | 電子計算機のキ−入出力装置 | |
JPS6224327A (ja) | スタツクメモリ制御方式 | |
JPS60164856A (ja) | デ−タ検索装置 | |
JPS59223804A (ja) | プログラマブル・コントロ−ラ |