JPH01237722A - データ列検索装置 - Google Patents

データ列検索装置

Info

Publication number
JPH01237722A
JPH01237722A JP63063465A JP6346588A JPH01237722A JP H01237722 A JPH01237722 A JP H01237722A JP 63063465 A JP63063465 A JP 63063465A JP 6346588 A JP6346588 A JP 6346588A JP H01237722 A JPH01237722 A JP H01237722A
Authority
JP
Japan
Prior art keywords
data
data string
search
section
address
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
Application number
JP63063465A
Other languages
English (en)
Inventor
Yasuo Iijima
康雄 飯島
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.)
Toshiba Corp
Original Assignee
Toshiba Corp
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 Toshiba Corp filed Critical Toshiba Corp
Priority to JP63063465A priority Critical patent/JPH01237722A/ja
Publication of JPH01237722A publication Critical patent/JPH01237722A/ja
Pending legal-status Critical Current

Links

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

(57)【要約】本公報は電子出願前の出願データであるた
め要約のデータは記録されません。

Description

【発明の詳細な説明】 [発明の目的コ (産業上の利用分野) 本発明は、たとえばICカードなどのマイクロコンピュ
ータシステムにおいて、メモリ内あデータ列を検索する
データ列検索装置に関する。
(従来の技術) たとえばマイクロコンビ亙−タシステムの中で、現在大
きな注目を浴びているものとしてICカードがあげられ
る。ICカード内のメモリは、複数のエリアに分割され
ており、これら各エリアはある固定フォーマットを有す
るエリア定義データ列によって管理されている。エリア
定義データ列の中には、エリア個々の識別情報であるエ
リア番号とともにエリアの物理的な位置および空間を規
定するデータがあり、外部からこのエリア番号を指定す
ることにより、ICカード内の制御部(CPU)は、外
部がアクセス対象としているエリアの物理的位置データ
などを検索し、そのデータに基づきメモリへのアクセス
を行なっている。
さて、ICカードの多目的利用が要求されている今日で
は、メモリ内に登録するエリアの数も増加し、それに伴
っ−てエリア定義データ列の数も□増加する。しかるに
、従来の本データ列の検索処理はソフトウェアによって
行なっていたので検索速度が遅く、よってICカードと
しての処理速度を低下させる原因となっていた。
(発明が解決しようとする課題) 本発明は、上記したようにICカードなどのデータ列の
検索を必要とするシステムにおいて、データ列の検索処
理をソフトウェアによって行なっていたので検索速度が
遅く、よってシステム全体の処理速度を低下させるとい
う問題点を解決すべくなされたもので、検索速度が大幅
に向上し、よってシステム全体の処理速度および稼働効
率が大幅に向上するデータ列検索装置を提供することを
目的とする。
[発明の構成] (課題を解決するための手段) 本発明のデータ列検索装置は、所定の処理を行なう制御
部と、この制御部によってアクセスされ、複数のデータ
列を記憶するメモリ部とを有するものにおいて、前記制
御部からの起動信号により起動し、所定のアドレス更新
情報および前記制御部から供給される第1のアドレスデ
ータに基づき第2の複数のアドレスデータを生成するア
ドレス生成手段と、このアドレス生成手段で生成された
第2の複数のアドレスデータに基づき前記メモリ部をア
クセスすることにより検索対象データ列を検索する検索
手段と、本装置の動作中、前記制御部が前記メモリ部に
対してアクセスすることを禁止するための信号を前記制
御部に供給する制御手段とを具備している。
(作用) 上記のように構成して、本装置が適用されるシステムの
制御部の命令の下に動作させるようにし、データ列の検
索処理をハードウェアによって行なうことにより、従来
のソフトウェアによるものに比して検索速度が大幅に向
上する。したがって、本装置が適用されるシステム全体
の処理速度および稼働効率が大幅に向上する。− (実施例) 以下、本発明の一実施例について図面を参照して説明す
る。
第2図は本発明に係るデータ列検索装置が適用されるI
Cカードなどのマイクロコンピュータシステムの構成を
示すものである。すなわち、1は本システム全体の制御
を司る制御部としてのCPU (セントラルやプロセッ
シング・ユニット)で、これにはデータバス2およびア
ドレスバス3が接続される。データバス2およびアドレ
スバス3には、プログラムメモリ4、ワーキングメモリ
5、データメモリ(メモリ部)6およびデータ列検索装
置7が接続される。また、CPUIおよびアドレスバス
3にはアクセス信号生成部8が接続される。
CPUIは、プログラムメモリ4に記憶されているプロ
グラムデータを所定のタイミングで随時読出し、これを
解読することにより種々の制御を実行する。ワーキング
メモリ5は、CPU1が制御実行中に一時的にデータを
記憶するためのもので、たとえばRAMで構成されてい
る。データメモリ6は、本システムの外部などから入力
されるデータ列を記憶するためのもので、たとえばEE
FROMなどの不揮発性メモリで構成されている。
さて、CPUIは、基本アクセスイネーブル信号(たと
えば280CPUにおけるメモリリクエスト、入出力リ
クエスト、リード・ライトの各イネーブル信号など)お
よびアドレスデータをアクセス信号生成部8に供給する
。これにより、アクセス信号生成部8はアクセス信号群
A1〜A4を生成する。アクセス信号群A1は、CPU
1がプログラムメモリ4からプログラムデータを読出す
際にイネーブル状態となる。アクセス信号群A2は、C
PU1がワーキングメモリ5に対してアクセスする際に
イネーブル状態となる。アクセス信号群A3は、CPU
Iがデータメモリ6に対してアクセスする際にイネーブ
ル状態となる。アクセス信号群A4は、データ列検索装
置7の起動およびデータ列検索装置7に必要となる各種
パラメータ設定のためのイネーブル信号である。
また、後述するようにデータ列検索装置7がデータメモ
リ6に対してアクセスするため、データ列検索装置7内
で生成した生成アクセス信号群A5と、アクセス信号生
成部8から供給されたアクセス信号群A3とを選択する
ことによりアクセス信号群A6を生成し、このアクセス
信号群A6をデータメモリ6に供給する。
また、CPU1およびデータ列検索装置7は、データバ
ス2およびアドレスバス3を共有しているため、CPU
1からの制御により、アクセス信号群A4を介してデー
タ列検索装置7が起動すると、データ列検索装置7は動
作中であることを信号S1によりCPUIに通知する。
これにより、CPUIは、データ列検索装置7の動作中
にはデータバス2およびアドレスバス3をデータ列検索
装置7のために解放する。
データメモリ6は、たとえば第3図に示すように、エリ
ア定義部6】およびエリア配置部62からなっている。
エリア配置部62には複数のエリアが配置されており、
本システムの外部などからのデータ列の記憶に使用され
る。エリア定義部61には、エリア配置部62に配置さ
れている各エリアを定義するエリア定義情報が記憶され
る。
エリア定a情報は、たとえばエリア番号、エリア先頭ア
ドレス、エリアサイズおよびポインタなどからなる。こ
れにより、CPUIは、たとえば外部から書込みデータ
とともにアクセス対象となるエリアのエリア番号を受取
ると、該当す、るエリア番号をエリア定義部6、から見
付け、対象エリアの先頭アドレスおよびサイズなど、ア
クセスに必要な情報を認識する。たとえば、エリアCは
先頭アドレスがre c cJで、サイズはrScバイ
ト」であるといったように対応づけられている。
また、ポインタは、対応するエリア内のうち、どこまで
データ列の書込みに使用したかを示すもので、何も書込
まれていない状態では対応するエリアの先頭アドレスと
同一値となっている。たとえばエリアAにおいては、ポ
インタはraaajという値となっているので、未書込
み状態であることを示す。エリアBにおいては、ポイン
タはrbbb’Jとなっているので、rbbbJからr
bbb’−IJの範囲には既にデータ列が書込まれてい
ることを示し、以降の書込みは「bbb′」から開始す
ることを示す。また、エリアCについては、「bbb」
となっている(この例では、rcccJから「bbb−
IJまでScバイト)ため、エリアがデータ列で満杯に
なっていることを示す。
ここで、エリア内のデータ列記憶状態をエリアBについ
て第4図に示す。図示するように、たとえば4つのデー
タ列が記憶されており、各データ列は、1バイトのデー
タ列長(L) 、2バイトのキーデータ(Kおよびkと
いった各1バイトのデータで構成)、およびデータから
なる。ここに、データ列長しは、データ列長部からデー
タ部までの構成バイト数である。これらのうち、データ
列長しおよびキーデータに、にの具体的な数値を入れた
図を第5図に示す。なお、各数値はへキサ(Hex)で
表わしである。たとえばデータ4のデータ列は、データ
列長はOCR(12バイト)、キーデータは9AH,6
4H(2バイト)である。
第1図はデータ列検索装置7の構成を示すものである。
すなわち、11は全体的な制御を司る制御部、12は検
索エリアサイズを記憶する検索エリアサイズ記憶部、1
3は検索エリアの残量を計算する検索エリア残量計算部
、14はデータ列長用マスクデータを記憶するデータ列
長用マスクデータ記憶部、15はデータ列長加工部、1
6はデータ列長を記憶するデータ列長記憶部、17はデ
ータ列長をチエツクするデータ列長チエツク部、18は
最小データ列長を記憶する最小データ列長記憶部、19
は検索エリア先頭アドレスを記憶する検索エリア先頭ア
ドレス記憶部、20はmlサンプリング用相対アドレス
を記憶する第1サンプリング用相対アドレス記憶部、2
1は第2サンプリング用相対アドレスを記憶する第2サ
ンプリング用相対アドレス記憶部である。
22は次のデータ列先頭アドレスを生成する次データ列
先頭アドレス生成部、23はデータ列先頭アドレスを生
成するデータ列先頭アドレス生成部、24はカレントア
ドレスを生成するカレントアドレス生成部、25はカレ
ントアドレス生成部24で生成されたカレントアドレス
をデータメモリ6へ供給するアドレス出力部、26はア
クセスイネーブル信号選択部である。アクセスイネーブ
ル信号選択部26は、制御部11で生成された生成アク
セス信号群A5と、アクセス信号生成部8から供給され
たアクセス14号n A 3とを選択することによりア
クセス信号群A6を生成し、このアクセス信号群A6を
データメモリ6に供給する。
27は第1キーデータを記憶する第1キーデータ記憶部
、28は第1マスクデータを記憶する第1マス・クデー
タ記憶部、29は第1サンプルデータを記憶する第1サ
ンプルデータ記憶部、30は第1サンプルデータを加工
する第1サンプルデータ加工部、31は第1キーデータ
記憶部27の内容と第1サンプ′ルデータ加工部30の
出力とを比較する第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は検索済のデータ列数を記憶する検索
済データ列数記憶部である。
さて、制御部11は、CPU1の制御により供給される
アクセス信号群A4により各部にパラメータデータを設
定し、本装置起動を認識する。パラメータデータは、C
PU1からデータバス2を介して検索エリアサイズ記憶
部12、データ列長用マスクデータ記憶部14、データ
列長記憶部16、最小データ列長記憶部18、検索エリ
ア先頭アドレス記憶部19、第1サンプリング用相対ア
ドレス記憶部20、第2サンプリング用相対アドレス記
憶部21、第1キーデータ記憶部27、第1マスクデー
タ記憶部28、第2キーデータ記憶部32、第2マスク
データ記憶部33、データ列番号指定用情報記憶部38
にそれぞれセットされる。
また、検索モードデータ記憶部(制御部11内にあり、
図示を省略)にもモードデータがセットされる。制御部
11は、このモードデータにより種々の検索専用タイミ
ングを生成するもので、それを第6図に示している。
検索前処理は、データ列先頭アドレス生成部23によっ
て検索すべきデータ列の先頭アドレスを生成するプロセ
スである。なお、検索開始モードとして、常にエリアの
先頭から検索する第1検索モードと、前回に検索したデ
ータ列の次のデータ列から検索する第2検索モードとが
ある。これは、CPUIからアクセス信号群A4を介し
て制御部11に供給された起動信号のうち、第1検索モ
ード用のものであれば、検索エリア先頭アドレス記憶部
19からデータ列先頭アドレス生成部23に供給される
検索エリア先頭アドレスをバスB、へ出力し、また第2
検索モード用のものであれば、次データ列先頭アドレス
生成部22からデータ列先頭アドレス生成部23に供給
される次のデータ列の先頭アドレスをバスBlへ出力す
る。
なお、バスBlに出力されたアドレスデータは、次の検
索周期の検索前処理が行なわれるまで保持される。
第1データリードプロセスは、制御部11内の検索モー
ドデータ記憶部に設定されたモードデータによりキーデ
ータを1つ以上設定した際、第1キーデータの読出しを
行ない、これを第1サンプルデータ記憶部29に記憶す
るプロセスである。
この場合の読出しアドレスは、カレントアドレス生成部
24において、バスB1から供給されるデータ列先頭ア
ドレスと第1サンプリング用相対アドレス記憶部20か
ら供給される第1サンプリング用招対アドレスとを加算
した結果で、カレントアドレス生成部24からバスB2
およびアドレス出力部25に出力され、このアドレス出
力部25からアドレスバス3を介してデータメモリ6へ
供給される。
第2データリードプロセスは、検索モードデータ記憶部
に設定されたモードデータによりキーデータを2つ設定
した際、第2キーデータの読出しを行ない、これを第2
サンプルデータ記憶部34に記憶するプロセスである。
この場合の読出しアドレスは、カレントアドレス生成部
24において、バスB1から供給されるデータ列先頭ア
ドレスと第2サンプリング用相対アドレス記憶部21か
ら供給される第2サンプリング用相対アドレスとを加算
した結果で、データメモリ6へ供給する方法は第1デー
タリードプロセスの場合と同様である。
なお、検索モー下データ記憶部に設定されたモードデー
タによりキーデータによる検索を行なわないと認識する
と、前記第1および第2データリードプロセスは行なわ
ない。
第3データリードプロセスは、検索モードデータ記憶部
に設定されたモードデータにより、データ列の先頭にデ
ータ列長部が1バイト以上存在するフォーマットのデー
タ列を検索すると設定した際、データ列の先頭1バイト
のデータを読出し、これをデータ列長記憶部16に記憶
するプロセスである。この場合の読出しアドレスは、カ
レントアドレス生成部24がバスB1から供給されるデ
ータ列先頭アドレスをバスB2、アドレス出力部25お
よびアドレスバス3を介してデータメモリ6へ供給する
第4データリードプロセスは、検索モードデータ記憶部
に設定されたモードデータにより、データ列の先頭にデ
ータ列長部が2バイト存在するフォーマットのデータ列
を検索すると設定した際、データ列の先頭データの次の
データを読出し、これをデータ列長記憶部16に記憶す
るプロセスである。この場合の読出しアドレスは、カレ
ントアドレス生成部24において、バスB1から供給さ
れるデータ列先頭アドレスを1つだけインクリメントし
た結果で、カレントアドレス生成部24からバスB2、
アドレス出力部25およびアドレスバス3を介してデー
タメモリ6へ供給される。
なお、検索モードデータ記憶部に設定されたモードデー
タにより、固定長で処理されるデータ列の検索で、特に
データ列の先頭にデータ列長部が存在しないフォーマッ
トのデータ列の検索であると設定すると、前記第3およ
び第4データリードプロセスは行なわない。
また、データ列長記憶部16は、たとえば16ビツトの
アドレス値を記憶する。先の第3データリードプロセス
において読出されたデータは、16ビツトのうち上位8
ビツトにセットされ、第4データリードプロセスにおい
て読出されたデータは、下位8ビツトにセットされる。
なお、第6図(b)(e)(h)の形式を取る検索時に
は、第3データリードプロセスにおいて読出されたデー
タは、16ビツトのうち下位8ビツトにセットされ、こ
のとき上位8ビツトは常にroOHJというデータ値が
記憶される。
検索後処理は、制御部11が本装置の動作を停止するか
否かの判断と、次のデータ列の先頭アドレスを生成する
プロセスである。次のデータ列の先頭アドレスは以下の
ようにして生成する。まず、データ列長加工部15にお
いて、先の第3および第4データリードプロセスによっ
てデータ列長記憶部16に記憶されたデータ列長情報と
、先にCPUIからアクセス信号群A4に基づいてデー
タ列長用マスクデータ記憶部14にセットされたデータ
列長用マスクデータを用いてデータ列長を算出し、その
算出結果をバスB3に出力する。この機能は、たとえば
2バイトのデータ列長情報を含んだデータ列で、かつ2
バイトデータのうち真のデータ列長を示す部分が下位1
3ビツトで、上位3ビツトはデータ列属性フラグが割当
てられているといったフォーマットを持つデータ列の検
索時、上位3ビツトを無視して2バイトデータとして以
降の回路が使用できるようにするためのものである。
このようにして算出されたデータ列長は、バスB3を介
して次データ列先頭アドレス生成部22に供給される。
次データ列先頭アドレス生成部22は、バスB3を介し
て供給されるデータ列長とバスB、またはB2から供給
されるデータ列先頭アドレスとを加算し、その加算結果
を次のデータ列先頭アドレスとしてデータ列先頭アドレ
ス生成部23に出力する。なお、このときバスB2には
、カレントアドレス生成部24によりデータ列先頭アド
レスにデータ列長を示すデータのバイト数分加算した値
が出力されている。次データ列先頭アドレス生成部22
は、先の検索モードデータ記憶部に設定されたモードデ
ータにより、データ列長の値がデータ列長を示すデータ
のバイト数を含むようなフォーマットのデータ列の検索
であった場合には、バスB、に供給されるデータを使用
し、またデータ列長の値がデータ列長を示すデータのバ
イト数を含まないフォーマットのデータ列の検索であっ
た場合には、バスB2に供給されるデータを使用する。
一方、検索エリア残量計算部13においては、検索エリ
アサイズ記憶部12に設定された検索エリアサイズを受
入れるとともに、データ列長加工部15の出力データを
バスB3を介して受入れることにより、次データ列先頭
アドレス以降のエリア残量を随時算出する。ただし、先
の検索モードデータ記憶部に設定されたモードデータに
より、データ列長の値がデータ列長を示すデータのバイ
ト数を含むようなフォーマットのデータ列の検索であっ
た場合には、バスB3に供給されているデータをそのま
ま使用し、またデータ列長の値がデータ列長を示すデー
タのバイト数を含まないフォーマットのデータ列の検索
であった場合には、バスB3に供給されているデータに
データ列長を示すデータのバイト数分加えて、これを使
用する。
もし、このときエリア残量の値が零もしくは負となれば
、検索エリア残量計算部13は制御部11に対して停止
要求を出力する。
検索済データ列数記憶部40は、本装置の起動時には初
期値(OOooHex)となっており、本プロセスによ
り1つだけインクリメントされる。
また、データ列長チエツク部17においては、最小デー
タ列長記憶部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に供給する。
また、第2データリードプロセスにおいて、第2サンプ
ルデータ記憶部34に記憶された第2サンプルデータは
第2サンプルデータ加工部35に供給される。第2サン
プルデータ加工部35は、5432マスクデ一タ記憶部
33に設定された第2マスクデータを受入れ、先の第2
サンプルデータと論理積をとって、その結果を第2比較
部36に供給する。第2比較部36は、第2サンプルデ
ータ加工部35の出力データと第2キーデータ記憶部3
2に設定された第2キーデータとの比較を行ない、その
比較結果を信号S3として検索判定部37に供給する。
検索判定部37は、検索モードデータ記憶部に設定され
たモードデータにより、信号S2と信号S3とによる比
較結果の論理をとり、その結果を信号S−tとして制御
部11に供給する。なお、比較結果の論理は、論理和、
すなわち2つの比較結果のうちどちらか一方が一致して
いれば検索対象のデータ列であるとするものと、論理積
、すなわち2つの比較結果とも一致していなければ検索
対象のデータ列ではないとするものがある。
信号S、1によって供給された結果、制御部11が検索
対象のデータ列であると認識すると、制御部11はデー
タ列番号指定用情報記憶部38に設定されているデータ
列番号を1つ減算する。このとき、指定データ列番号検
出部39は、データ列番号指定用情報記憶部38の値を
チエツクし、もしその値が零となれば制御部11に対し
て停止要求を出力する。
また、第6図(g)(h)(i)で示すように、キーデ
ータによる検索を行なわない場合は、信号S2および信
号S3による比較結果は無視され、一義的に検索対象デ
ータ列であることを信号s4を介して出力する。また、
第6図(d)(e)(f)のように、第1キーデータの
み使用の検索時には、信号S4の結果は信号s2の結果
と同一となる。
以上のように、検索エリア残量計算部13、データ列長
チエツク部17、および指定データ列番号検出部39の
うち、いずれかが停止要求を出力すると、制御部11は
動作を停止し、信号S1を介してCPUIに制御権を渡
す。そして、CPUIは、データバス2を介して制御部
11内の停止ステータス、データ列先頭アドレス生成部
23内の検索データ列先頭アドレス、検索エリア残量計
算部13内のエリア残量、指定データ列番号検出部39
内の指定データ列番号残量、および検索済データ列数記
憶部40内の検索済データ列数をそれぞれ読出すことに
より、検索結果を得ることができる。
第7図は制御部11内の検索モードデータ記憶部に設定
されるモードデータのフォーマットを示すものである。
このモードデータは例えば1バイトデータである。第0
および第1ビツトを用いてデータ列に付加されているデ
ータ列長情報のバイト数を認識する。この第0および第
1ビツトが「00」または「11」であれば、固定長、
すなわち第3および第4データリードプロセスを行なわ
ずに、あらかじめデータ列長記憶部16に設定したデー
タ列長に基づいて、データ列先頭アドレスを順次更新し
ながら検索してゆく。「01」のときは、データ列長が
1バイトのフォーマットを持つデータ列を検索する。「
10」のときは、データ列長が2バイトのフォーマット
を持つデータ列を検索する。なお、「11」については
、固定長データをディクリメント運用することにより、
アドレスの大きい箇所から小さい箇所へ向っての検索を
行なう。
第2ビツトはデータ列長個別情報であり、検索するデー
タ列に付加されているデータ列長の値がそれ自身を含む
ものであれば「0」、含まないものであれば「1」にそ
れぞれ対応する。なお、第3ビツトは未使用であり、「
0」に固定されている。
第4および第5ビツトによりキーデータによる検索指定
を行なう。この第4および第5ビツトが「00」であれ
ば、キーデータ未使用となり、第1および第2データリ
ードプロセスは行なわれない。「01」であれば、キー
データを1つだけ使用することを示し、第1データリー
ドプロセスが行なわれる。「10」もしくは「11」で
あれば、キーデータを2つ使用することを示し、第1お
よび第2データリードプロセスが行なわれる。
第6および第7ビツトは、第4および第5ビツトで「1
0」もしくは「11」を指定した場合、検索判定部37
における信号S2および信号S3の論理を指定するもの
である。この第6および第7ビツトが「00」であると
、論理積条件となり、第1キーデータと第2キーデータ
とが共に満足したとき検索対象データ列と、する。「0
1」であると、排他的論理和条件となる。「10」もし
くは「11」であると、論理和条件となる。
次に、第8図ないし第10図を用いて検索手順を説明す
る。第8図はアドレスr2000(Hex)Jからr2
1DO(Hex)Jに図示するようなデータ列が記憶さ
れていることを示し、第9図はアドレスr1000 (
Hex)JからrllDo (Hex)Jに図示するよ
うなデータ列が記憶されていることを示している。
第10図はモードデータおよび各設定データの組合せを
11通り例示し、それに対応する検索結果を示しである
。結果1は、第1検索モードで起動をかけた後、本装置
が停止したときの各読出しパラメータの値を示す。結果
2〜4は、その後第2検索モードで起動し、停止する動
作を繰返し、その停止時の各読出しパラメータの値を示
したものである。なお、マスクデータと被マスクデータ
とはビット単位の論理積を取るようになっている。
したがって、マスクデータの全てのと・ノドが「1」の
ときは、被マスクデータがそのまま使用されることにな
る。
ケース1は、データ列長rlO(Hex)Jの固定長ア
ップ方向検索で、キーデータは「10(Hex)Jおよ
びr30 (Hex)Jである。
キーデータとしては、共に第1バイト目を参照するよう
になっている。検索エリア先頭アドレスはr2000 
(Hex)J 、−r−リアサイズは「01EO(He
x)Jである。また、条件が一致したデータ列のうち3
つ目で停止するようになっている。
さて、第1検索モードによる起動がかかると、第1図の
バスB、にはr2000 (Hex)Jが出力される。
次に、第3データリードプロセスにより、r2001 
(Hex)Jの値、すなわちrlO(Hex)Jが第1
サンプルデータ記憶部29に記憶される。次に、第4デ
ータリードプロセスにより、同様にrlo (Hex)
Jが第2サンプルデータ記憶部34に記憶される。ここ
で、第1マスクデータおよび第2マスク、データは、共
にrFF (Hex)Jとなっているので、第1サンプ
ルデータ加工部30および第2サンプルデータ加工部3
5の各出力にはrlO(Hex)Jの値が出力される。
第1キーデータは「10(Hex)J、第2キーデータ
はr30 (Hex)」なので、信号S2は一致である
ことを示し、信号S 3は不一致であることを示す。こ
こで、モードは論理和条件を示しているため、データ列
各号指定用情報はro003 (Hex)Jからr00
02 (Hex)J へ減算される。
このとき、検索エリア残量は、ro I E 0(He
x)Jから固定長方、すなわちroolo(Hex)J
を減算した値r01DO(Hex)Jとなる。そして、
次データ列先頭アドレス生成部22の出力には次の値r
2010 (Hex)Jが出力される。
この場合、停止F条件ではないので、再び検索サイクル
を開始する。次の検索サイクルでは、第1サンプルデー
タおよび第2サンプルデータは共にr20 (Hex)
Jとなるため、データ列番号指定用情報はそのまま保持
される。検索エリア残量は、減算されてrolcO(H
ex)Jとなり、次データ列先頭アドレス生成部22の
出力にはr2020 (Hex)Jが出力される。この
場合も、停止条件は満足せず、再び検索サイクルを開始
する。
このようにして、データ列番号指定用情報がroooo
 (Hex)Jとなった状態がケース1の結果1である
。このとき、検索されたデータ列の先頭アドレスはr2
030 (Hex)J 、またエリア残量はrolAo
 (Hex)J 、検索済データ列数は「0004(H
ex)」、すなわち4つのデータ列であることをそれぞ
れ示す。
順に結果1〜4を見ていくと、データ列の第2バイト目
がrlO(Hex)Jもしくは「30(Hex)Jとな
っているデータ列のうち、3xn (n−整数)番目で
停止している。
ケース2は、データ列の第2バイト目が「10(Hex
)Jで、かつ第3バイト目が「21(Hex)Jとなっ
ているデータ列を順次検索した例である。
ケース3は、データ列の第2バイト目がrlO(Hex
)Jであり、かつ第3バイト目の第4ビツト目が「1」
となっているデータタリのうち、5Xn(n−整数)番
目のものを検索した例である。
ここで、結果2での停止は、エリア残量が零となったこ
とに起因しているもので、指定データ列番号残量はro
ool (Hex)Jとなっている。
このため、検索有効データ列は結果1により得たものの
みとなる。
ケース4は、データ列の第4バイト目が[10(Hex
)Jとなっているデータ列を順次検索した例である。結
果3において停止したのは、エリア残量が零となったた
めで、指定データ列番号残量は零となっていない。した
がって、検索有効データ列は結果1および結果2により
得たものとなる。
ケース5は、キーデータ無しの検索で、4Xn(n−整
数)番目のものを検索した例である。アドレスr210
0 (Hex)JからroOB。
(Hex)J分のエリアを検索している。また、データ
列長は固定で、r20 (Hex)Jである。
この例では、結果2の停止条件はエリア残量が負になっ
たことである。したがって、検索有効データ列は結果1
により得たものとなる。
ケース6は、2バイトのデータ列長が付加されているデ
ータ列フォーマットモードの検索例である。キーデータ
無しの検索で、3Xn (n−整数)番目のものを検索
する。なお、このフォーマット例では、2バイトのデー
タ列長、すなわち16ビツトのうち下位15ビツトを有
効データ列長とするために、データ列長用マスクデータ
がr7FFF (Hex)Jとなっている。この例では
、結果4の停止条件はエリア残量が零になったことであ
る。このとき、指定データ列番号残量は零ではないので
、検索有効データ列は結果1〜3により得たものである
ケース7は、ケース6と同様のフォーマットモードの検
索であり、データ列長2バイトのうち上位1ビツトが「
1」となっているデータ列の検索例である。ただし、デ
ータ列長の有効バイトは2バイトのうち下位1バイトと
するため、データ列長用マスクデータはroOFF (
Hex)Jとなっている。また、この例では、該当デー
タ列の数を調べるため、データ列番号指定用情報をrF
FFF (Hex)Jとしである。このとき、結果1で
は、エリア残量が零となったことにより停止したことを
示している。検索済データ列数はr0014 (Hex
)J 、また指定データ列番号残量がrFFFB (H
ex)Jとなっているので、該当データ列数はrF F
 F F −F F F BJの計算により4つである
ことがわかる。
ケース8は、1バイトのデータ列長(データ列長の値は
データ列長自身も含む)が付加されているデータ列フォ
ーマットモードの検索であり、キーデータ無しモードで
ある。そして、アドレスr2191 (Hex)Jから
r004F (H,ex)」分ノエリアを順次検索する
例である。この例では、結果3の停止条件はエリア残量
が負となったことである。したがって、検索有効データ
列は結果1および2により得たものになる。
ケース9は、ケース4における条件のもとにダウン検索
を行なった例である。検索先頭アドレスはr21DO(
Hex)Jで、ro 1 E 0(Hex)J分のエリ
アを検索する。この例では、結果3の停止条件はエリア
残量が零となったことである。そして、このとき指定デ
ータ列番号残量は零ではないので、結果1および2によ
り得たものが該当データ列となる(これはケース4の結
果と同一)。
ケース10は、2バイトのデータ列長(データ列長の値
はデータ列長自身を含まない)が付加されているデータ
列フォーマットモードの検索であり、キーデータ無しモ
ードである。ただし、この例では、最小データ列長をr
o018 (Hex)Jとしである。したがって、結果
2において停止したのは、アドレスr1030 (He
x)Jがら始まるデータ列のデータ長の値がr0018
(Hex)Jに満たなかったことになる。なお、CPU
Iは、停止ステータスによりデータ列長不足が認識でき
る。
ケース11は、1バイトのデータ列長(データ列長の値
はデータ列長自身を含まない)が付加されているデータ
列フォーマットモードの検索である。
[発明の効果] 以上詳述したように本発明によれば、たとえばICカー
ドなどのデータ列の検索を必要とするシステムにおいて
、データ列の検索処理をハードウェアによって行なうこ
とにより、検索速度が大幅に向上し、よってシステム全
体の処理速度および稼働効率が大幅に向上するデータ列
検索装置を提供できる。
【図面の簡単な説明】
図は本発明の一実施例を説明するためのもので、第1図
はデータ列検索装置の構成を示すブロック図、第2図は
マイクロコンピュータシステムの構成を示すブロック図
、第3図はデータメモリのフォーマットを示す図、第4
図および第5図はエリア内のデータ列記憶状態を示す図
、第6図は各検索モードにおける検索1周期あたりの詳
細プロセスを説明するための図、第7図は検索モードデ
ータのフォーマットを示す図、第8図および第9図はメ
モリ内に記憶されているデータ列のパターン例を示す図
、第10図は具体的動作を説明するための検索パラメー
タと検索結果との対応を示す図である。 1・・・CPU (制御部)、4・・・プログラムメモ
リ、6・・・データメモリ(メモリ部)、7・・・デー
タ列検索装置、11・・・制御部、14・・・データ列
長用マスクデータ記憶部、15・・・データ列長加工部
、16・・・データ列長記憶部、22・・・次データ列
先頭アドレス生成部、23・・・データ列先頭アドレス
生成部、24・・・カレントアドレス生成部、25・・
・アドレス出力部、27・・・第1キーデータ記憶部、
29・・・第1サンプルデータ記憶部、31・・・第1
比較部、32・・・第2キーデータ記憶部、34・・・
第2サンプルデータ記憶部、36・・・第2比較部、3
7・・・検索判定部。 出願人代理人 弁理士 鈴江武彦 第4因 第5図 第6図

Claims (1)

  1. 【特許請求の範囲】 所定の処理を行なう制御部と、この制御部によってアク
    セスされ、複数のデータ列を記憶するメモリ部とを有す
    るものにおいて、 前記制御部からの起動信号により起動し、所定のアドレ
    ス更新情報および前記制御部から供給される第1のアド
    レスデータに基づき第2の複数のアドレスデータを生成
    するアドレス生成手段と、このアドレス生成手段で生成
    された第2の複数のアドレスデータに基づき前記メモリ
    部をアクセスすることにより検索対象データ列を検索す
    る検索手段と、 本装置の動作中、前記制御部が前記メモリ部に対してア
    クセスすることを禁止するための信号を前記制御部に供
    給する制御手段と を具備したことを特徴とするデータ列検索装置。
JP63063465A 1988-03-18 1988-03-18 データ列検索装置 Pending JPH01237722A (ja)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP63063465A JPH01237722A (ja) 1988-03-18 1988-03-18 データ列検索装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP63063465A JPH01237722A (ja) 1988-03-18 1988-03-18 データ列検索装置

Publications (1)

Publication Number Publication Date
JPH01237722A true JPH01237722A (ja) 1989-09-22

Family

ID=13230015

Family Applications (1)

Application Number Title Priority Date Filing Date
JP63063465A Pending JPH01237722A (ja) 1988-03-18 1988-03-18 データ列検索装置

Country Status (1)

Country Link
JP (1) JPH01237722A (ja)

Similar Documents

Publication Publication Date Title
JP2825550B2 (ja) 多重仮想空間アドレス制御方法および計算機システム
JPH0271497A (ja) 内容でアドレス指定可能なメモリ・システム
JPH0664911B2 (ja) 内容でアドレス指定可能なメモリ・アレイ
JPS589982B2 (ja) 情報検索装置
US20220237041A1 (en) Parallel processing system performing in-memory processing
US4027288A (en) Self-managing variable field storage system for handling nested data structures
US3344404A (en) Multiple mode data processing system controlled by information bits or special characters
US4967391A (en) Data string retrieval apparatus for IC card
JPH01237722A (ja) データ列検索装置
JPH01237824A (ja) データ列検索装置
JPH01237825A (ja) データ列検索装置
JPH01237721A (ja) データ列検索装置
JPH01237827A (ja) データ列検索装置
JPH01237826A (ja) データ列検索装置
JPH01237828A (ja) データ列検索装置
JPS6145485A (ja) 磁気バブルメモリ制御装置
JP2604787B2 (ja) 二次元データ格納方式
KR200204909Y1 (ko) 분할된 내부 코드 메모리를 갖는 마이크로컨트롤러
JPS5856145A (ja) デ−タ検索方式
JPH0716189Y2 (ja) ブレーク回路
JPS633351A (ja) バツフア検索制御方式
JPS59191649A (ja) プログラムの生成方式
JPS589452B2 (ja) フア−ムウエアホウシキ
JPS63727A (ja) 情報検索方法
JPS5829046A (ja) メモリソーティング回路