JP4088335B1 - 仮想キュー処理回路およびタスク処理装置 - Google Patents
仮想キュー処理回路およびタスク処理装置 Download PDFInfo
- Publication number
- JP4088335B1 JP4088335B1 JP2007543638A JP2007543638A JP4088335B1 JP 4088335 B1 JP4088335 B1 JP 4088335B1 JP 2007543638 A JP2007543638 A JP 2007543638A JP 2007543638 A JP2007543638 A JP 2007543638A JP 4088335 B1 JP4088335 B1 JP 4088335B1
- Authority
- JP
- Japan
- Prior art keywords
- task
- queue
- register
- circuit
- state
- 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.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F5/00—Methods or arrangements for data conversion without changing the order or content of the data handled
- G06F5/06—Methods or arrangements for data conversion without changing the order or content of the data handled for changing the speed of data flow, i.e. speed regularising or timing, e.g. delay lines, FIFO buffers; over- or underrun control therefor
- G06F5/10—Methods or arrangements for data conversion without changing the order or content of the data handled for changing the speed of data flow, i.e. speed regularising or timing, e.g. delay lines, FIFO buffers; over- or underrun control therefor having a sequence of storage locations each being individually accessible for both enqueue and dequeue operations, e.g. using random access memory
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Executing Machine-Instructions (AREA)
- Hardware Redundancy (AREA)
- Multi Processors (AREA)
Abstract
【選択図】図19
Description
この回路は、複数種類の仮想キューに対する複数個の要素の投入と抽出を制御するキュー制御回路と、各要素に対応して設けられ、投入先となる仮想キューとその投入順位を対応づけて保持する複数のキューレジスタを含む。
キュー制御回路は、順投入コマンドが入力されるときには、仮想キューの末尾に要素を投入する旨を該当要素のキューレジスタに設定し、逆投入コマンドが入力されるときには、仮想キューの先頭に要素を投入する旨を該当要素のキューレジスタに設定し、抽出コマンドが入力されるときには、仮想キューの先頭から要素を取り出す旨を該当要素のキューレジスタに設定する。各キューレジスタの設定情報に基づいて複数種類の仮想的なキューが管理されることになる。
この装置は、処理レジスタと、メモリから処理レジスタにデータをロードし、処理レジスタのデータにしたがってタスクを実行する実行制御回路と、タスクごとの状態データを保持する複数の状態レジスタと、タスク切換を実行するタスク切換回路と、所定の選択条件によりタスクを選択するタスク選択回路と、を備える。
状態レジスタは、タスクの実行状態に対応づけられる仮想キューと仮想キューへの投入順位を対応づけて保持する。タスク切換回路は、複数種類の仮想キューに対するタスクの投入と抽出を制御することにより、タスク切換を実行する。
実行中の第1のタスクがシステムコール命令を実行するとき、タスク選択回路は、READY(レディ)状態に対応する仮想キューの先頭に位置する第2のタスクを次の実行対象として選択する。
タスク切換回路は、第2のタスクの状態レジスタから仮想キューの設定をクリアし、第1のタスクの状態レジスタに対して、新たな実行状態に対応づけられる仮想キューとその投入順位を設定する。タスク切換回路は、処理レジスタのデータを所定の記憶領域に退避させると共に、第2のタスクについて記憶領域に退避されていたデータを処理レジスタにロードすることにより、実行対象となるタスクを切り換える。
まず、本実施例においてマルチタスクOSのタスクスケジューリングを電子回路により実現するタスク処理装置100について「基本例」として説明する。そのあと、両投入型アルゴリズムの実装により、一般的なソフトウェアのマルチタスクOSと同等のタスクスケジューリングを実現するタスク処理装置100について「改良例」として説明する。以下、「本実施例」というときには、原則として、「基本例」および「改良例」の両方を示すものとする。
{基本例}
[タスクの状態遷移]
マルチタスク処理において、各タスクは「状態(ステート)」を持つ。各タスクは、後述する複数の状態間を遷移し、常に、いずれかの状態となっている。状態遷移の契機となるのは、「システムコールの実行」と「割り込み要求信号の検出」である。システムコールとは各タスクが実行する命令のうちの特別な命令である。割り込み要求信号とは、キーボードの押下やマウスのクリック、通信データの受信など、周辺機器から所定データを受け取ったときに発生する信号である。もちろん、各タスクに割り当てられるタイムスライスが消費されたときにも状態遷移が発生する。
タスクが休止状態にあることを示す。一般タスクも特殊タスクもSTOP状態となり得る。以下、STOP状態にあるタスクのことを「STOP−タスク」とよぶ。
1−1.一般タスク
他のタスクが別のタスクの起動を指示するシステムコール(以下、「起動システムコール」とよぶ)を実行すると、STOP状態にある一般タスクは後述のREADY状態に遷移する。
1−2.特殊タスク
特殊タスクは、通常、STOP状態にある。後述のタスク切換回路210により割り込み要求信号が検出されると、特殊タスクはSTOP状態から後述のRUN状態に遷移する。このときRUN状態にあったタスクは入れ替わりにREADY状態に遷移する。
タスクが実行中であることを示す。すなわち、タスクがタイムスライスを割り当てられ、CPUの使用権を取得している状態である。一般タスクも特殊タスクもRUN状態となり得る。以下、RUN状態にあるタスクのことを「RUN−タスク」とよぶ。複数のタスクのうち、RUN状態になることができるタスクは常に1つだけであり、同時に2つのタスクがRUN状態となることはできない。
2−1.一般タスク
RUN状態にある一般タスクは、所定のシステムコールを実行するとRUN状態からREADY状態または後述するWAIT状態に遷移する。RUN状態にある一般タスクは、タイムスライスを消費したときにも、READY状態に遷移する。いずれの場合においても、RUN状態にあった一般タスクの代わりに、READY状態にある一般タスクがRUN状態に遷移する。割り込み要求信号が検出されると、RUN−タスクはREADY状態に遷移する。このときには、STOP状態にある特殊タスクがRUN状態に遷移する。
RUN−タスクが自らを終了させるシステムコール(以下、「終了システムコール」とよぶ)を実行すると、RUN−タスクはSTOP状態に遷移する。
2−2.特殊タスク
割り込み要求信号によりSTOP状態からRUN状態に遷移した特殊タスクは、自処理が完了するとSTOP状態に戻る。特殊タスクが取り得る状態はSTOP状態とRUN状態のみである。
タスクが実行可能な状態にあることを示す。READY状態にあるタスクは、OSから実行権を与えられればいつでもRUN状態に遷移できる。一般タスクのみREADY状態となり得る。以下、READY状態にあるタスクのことを「READY−タスク」とよぶ。
RUN状態にある一般タスクがシステムコールの実行によりRUN状態以外の状態に遷移するとき、または、RUN状態にある特殊タスクが自らの処理を終了してSTOP状態に遷移するとき、READY−タスクが入れ替わりにRUN状態に遷移する。一般タスクは、READY状態からのみRUN状態に遷移する。READY状態にあるタスクが複数存在するときには、コンテキスト情報の一部であるタスク優先順位に基づいて、いずれか一つのREADY−タスクがRUN状態に遷移する。タスク優先順位が同じとなるREADY−タスクが複数存在するときには、READY状態に移行したのが最も古いタスクがRUN状態に遷移する。
タスクが所定のWAIT解除条件の成立を待っている状態を示す。WAIT解除条件が成立すると、WAIT状態にあるタスクはREADY状態に遷移する。一般タスクのみWAIT状態となり得る。以下、WAIT状態にあるタスクのことを「WAIT−タスク」とよぶ。WAIT解除条件に関しては後に詳述する。
[システムコール]
(1)起動系システムコール
STOP状態とREADY状態の間の遷移に関連するシステムコールである。
1−1.起動システムコール
RUN−タスクであるタスクAが別の一般タスクBを起動させるシステムコールである。このとき、STOP状態にある一般タスクBはREADY状態に遷移する。
1−2.終了システムコール
このシステムコールを実行したタスクは、自己の処理を終了させ、RUN状態からSTOP状態に遷移する。終了システムコールは、あるタスクが別のタスクを終了させる命令であってもよい。
(2)WAIT系システムコール
RUN状態とWAIT状態の間の遷移に関連するシステムコールである。
2−1.ウェイトセマフォシステムコール
セマフォ(後述)の獲得を要求するシステムコールである。
2−2.ウェイトミューテクスシステムコール
ミューテクス(後述)の獲得を要求するシステムコールである。
2−3.ウェイトイベントシステムコール
イベント(後述)の成立を待つシステムコールである。イベントIDのほか、待機フラグパターン(後述)やフラグ条件(後述)を変数として実行される。
いずれの場合においても、WAIT系システムコールにより、さまざまなWAIT解除条件が設定される。WAIT系システムコールの実行時において、既にWAIT解除条件が成立する状況にあるときには、システムコールを実行したRUN−タスクはREADY状態に遷移する。一方、WAIT解除条件が成立していないときには、RUN−タスクは、WAIT解除条件の成立を待機するWAIT状態に遷移する。
(3)SET系システムコール
WAIT状態とREADY状態の間の遷移に関連するシステムコールである。SET系システムコールの実行は、WAIT解除条件の成立契機となる。
3−1.リリースセマフォシステムコール
セマフォを解放するシステムコールである。
3−2.リリースミューテクスシステムコール
ミューテクスを解放するシステムコールである。
3−3.セットイベントシステムコール
イベントのカレントフラグパターン(後述)を設定するシステムコールである。
3−4.クリアフラグシステムコール
カレントフラグパターンをゼロクリアするためのシステムコールである。
本実施例においては、以上の計9種類のシステムコールを対象として説明するが、これ以外にもさまざまなシステムコールを実装可能であることはいうまでもない。
[一般的なRTOSの設計思想]
このRTOSはマルチタスクOSである。一般的なRTOSはソフトウェアとして実現される。タスクAからタスクBへRUN−タスクを切り換える場合を例として説明する。タスクAがCPUを占有しているので、RTOSはCPUに割り込みをかけて、CPUの使用権をタスクAから取り上げる。その上で、タスクAのコンテキスト情報をTCBに退避させる。RTOSは、次のRUN−タスクとしてタスクBを選択し、タスクBのTCBからコンテキスト情報をCPUのレジスタにロードする。ロードが完了すると、RTOSはCPUの使用権をタスクBに渡す。このように、RTOSは、一時的にCPUの使用権を取得することにより、タスクAからタスクBへのタスクスイッチを実行する。特殊タスクの実行に関しても同様である。この場合にも、RUN−タスクのコンテキスト情報をTCBに退避させた後、特殊タスクにCPUの使用権を渡すことによりタスクスイッチを実現している。
RTOSは、ソフトウェアとして実現されるため、自らの処理を実行するためにはCPUの使用権を必要とする。いいかえれば、RTOSとタスクは、CPUの使用に関して競合関係にある。以下、このようにソフトウェアによって実現されるRTOSのことを「ソフトウェアRTOS」とよぶ。
CPU84は、メモリアクセスや命令の実行等を統括的に制御する実行制御回路90と、タスクのコンテキスト情報など各種データを格納する処理レジスタ92、演算を実行する演算回路94を含む。処理レジスタ92は複数種類のレジスタの集合であり、特殊レジスタ88と汎用レジスタ86に大別される。特殊レジスタ88は、プログラムカウンタ、スタックポインタ、フラグ等を保持するレジスタである。汎用レジスタ86は、作業用のデータを保持するレジスタであり、R0〜R15までの計16レジスタを含む。特殊レジスタ88は、ユーザ用とシステム用の2面が存在するが、汎用レジスタ86は一面のみである。以下、処理レジスタ92に格納されるデータのことを「処理データ」とよぶ。
<タスクAのコンテキスト情報の退避>
2.実行制御回路90は、汎用レジスタ86のデータを図示しないスタックに退避させる。
3.実行制御回路90は、図示しない記憶媒体、たとえば、別のレジスタから、RTOSのための処理データを汎用レジスタ86にロードする。この段階で、処理レジスタ92の処理データは、完全にRTOS用の処理データに入れ替わる。
4.RTOSは、メモリからタスクAのTCBを検出し、スタックに退避されている処理データをTCBに書き込む。また、ユーザ用の特殊レジスタ88の処理データもコンテキスト情報の一部としてTCBに書き込む。こうして、タスクAの処理データがTCBに退避される。RTOSは、タスクAが「RUN」から「READY(またはWAIT)」に状態遷移したことをタスクAのTCBに記録する。
<タスクBのコンテキスト情報のロード>
2.RTOSは、RTOS処理用のデータを汎用レジスタ86から図示しない記録媒体に退避させる。
3.実行制御回路90は、スタックのコンテキスト情報を汎用レジスタ86にロードする。実行制御回路90は、特殊レジスタ88をシステム用からユーザ用に切り換える。こうして、タスクBの処理データが処理レジスタ92にロードされる。
[タスク処理装置100によるRTOSのハードウェア化]
一般的なソフトウェアRTOSと異なり、本実施例におけるRTOSは、主として、CPUとは別個のハードウェアとして実現される。以下、ハードウェアによって実現されるRTOSのことを、「ハードウェアRTOS」とよぶ。本実施例のRTOSは、主として、CPUとは別個のハードウェアであるため、自らの処理を実行するためにはCPUの使用権を実質的にほとんど必要としない。いいかえれば、RTOSとタスクは、CPUの使用に関してほとんど競合関係にない。図2に示した一般的なソフトウェアRTOSの場合、CPUはタスク実行用回路であるとともに、RTOS実行用回路でもあった。これに対し、本実施例におけるハードウェアRTOSの場合、CPUはタスク実行回路として明確化され、タスクスケジューリング機能は後述の退避回路120とタスク制御回路200を中心として実現することができる。
タスク処理装置100は、CPU150に加えて退避回路120とタスク制御回路200を含む。CPU150はタスクの実行主体であり、退避回路120とタスク制御回路200が図4に示したRTOSの役割を担う回路である。タスクススケジューリング処理は、タスク制御回路200により主導される。
以下、システムコールと割り込み要求信号のそれぞれについてタスクスイッチの実行方法を説明する。
[1]システムコール実行
<タスクAのコンテキスト情報の退避>
<タスクBのコンテキスト情報のロード>
[2]割り込み要求信号の発生
(A)処理データの退避・ロード
(B)タスクの状態遷移およびRUN−タスクの選択
というタスクスイッチの中核となる処理をハードウェアにより実現している。(A)および(B)に関し、メモリ上のTCBにアクセスする必要がなくなることもタスクスイッチの高速化に寄与している。また、タスク処理装置100を実現するにあたり、CPU150については、CPUクロックを停止および再開する機能を追加するだけでよい。なお、これらの機能がすべてハードウェアによって実現されることは、本発明の範囲を限定するものではない。たとえば、(A)または(B)の主たる機能をハードウェアにより実現し、ハードウェアの機能を補助するためにRTOSの一部の機能をソフトウェアで実現してもよいことは当業者には理解されるところである。
図3のCPU84と異なり、処理レジスタ154は特殊レジスタ156と汎用レジスタ158共に一面だけの構成となっている。処理レジスタ154にはそれぞれロード選択回路112からの入力バス、退避レジスタ110への出力バス、タスク切換回路210からの書き込み信号(WT)用の信号線が追加されている。実行制御回路152は、出力セレクタ164に対する制御信号(CTRL)により、処理レジスタ92のうちの所望のレジスタのデータを演算回路160に入力する。演算結果は入力セレクタ162への入力となる。実行制御回路152は、入力セレクタ162に対する制御信号(CTRL)により、処理レジスタ154のうちの所望のレジスタに演算結果を入力する。実行制御回路152は、特殊レジスタ156のプログラムカウンタを更新しながら、タスクを実行する。
第2ANDゲート174の入力は原クロック(CLK0)と第1ANDゲート172の出力で、後者は負論理である。第1ANDゲート172の出力は停止完了信号(HC)である。停止完了信号(HC)は通常は0なので、第2ANDゲート174は、入力された原クロック(CLK0)をCPUクロック(CLK)としてそのまま出力する。CPU150は、第2ANDゲート174の出力するCPUクロックを受けて動作する。第1ANDゲート172の出力が「1」のとき、いいかえれば、停止完了信号(HC)=1のときには、第2ANDゲート174の出力はゼロに固定され、CPUクロック(CLK)が停止する。
割り込み要求信号(INTR)が発生したとき、タスク切換回路210は実行制御回路152に停止要求信号(HR)をアサートする。すなわち、ORゲート176の出力は、システムコールが実行されるか、停止要求信号(HR)がアサートされたときに「1」となる。
同図においては、まず、時刻t0において、タスク切換回路210は外部からの割り込み要求信号(INTR)を検出している。タスク切換回路210は、特殊タスクを実行させるため、実行制御回路152に停止要求信号(HR)をアサートする。入力タイミングt1は、検出タイミングt0とほとんど同時である。時刻t1では、CPU150のステートマシンは「タスク実行中」であり、CBUSY=1である。HR=1より、ORゲート176は「1」を出力するが、CBUSY=1ゆえにCPU150は停止しない。そのため、HR=1が入力されても、しばらくはCPUクロック(CLK)は原クロック(CLK0)に同期して出力される。
なお、別の処理方法として、タスク制御回路200の動作クロックが所定回数変化したことを条件とする代わりに、タスク制御回路200がタスクスイッチを完了させたことを条件として、HRをネゲートしてもよい。そして、実行制御回路152が、HRがネゲートされたことを条件として、HCをネゲートさせてもよい。HC=0となると、実行制御回路152はCPUクロック(CLK)を再開させる。こうして、タスクの実行を再開させてもよい。
同図においては、まず、時刻t0において、命令復号器170がシステムコールを検出し、SC_DETECTを0から1に変化させている。時刻t0では、CPU150のステートマシンは「タスク実行中」であり、CBUSY=1である。SC_DETECT=1より、ORゲート176は「1」を出力するが、CBUSY=1ゆえにCPU150は停止しない。そのため、SC_DETECT=1が出力されても、しばらくはCPUクロック(CLK)は原クロック(CLK0)に同期して出力される。
なお、別の処理方法として、WT:1→0の立ち下がり検出を条件とする代わりに、タスク制御回路200がタスクスイッチを完了させ、HRをネゲートしたことを条件として、実行制御回路152が、HCをネゲートしてもよい。HC=0となったことを条件として、SC_DETECTをリセットする。実行制御回路152はCPUクロック(CLK)を再開させ、CBUSYは0から1に変化する。
CPU150は、複数の命令をメモリから処理レジスタ154に順次読み出しながら実行することにより、タスクを実行する。このタスクの実行単位である命令は、以下の4つのフェーズに分解される。
1.F(フェッチ):メモリから命令を取り出す。
2.D(デコード):命令を解釈する。
3.E(エグゼキューション):命令を実行する。
4.WB(ライトバック):実行結果をメモリに書き込む。
なお、別の処理方法として、システムコール命令が実行完了するタイミングで、CPUビジー信号を「0」とし、CPUクロックの供給を停止してもよい。この場合、システムコール命令と同時に実行されていた別の命令は実行途中のまま停止する。中途停止された命令の中間的な処理結果は処理レジスタ154に記録されたあと、退避レジスタ110に退避される。次回、このタスクがRUN−タスクとなるときには、中途停止された命令の続きが実行される。たとえば、ある命令が、フェッチを終了した段階で中途停止された場合、メモリから読み出された命令やオペランドは退避レジスタ110に退避される。タスク再開時には、退避レジスタ110のデータが処理レジスタ154にロードされ、デコードステージから続きの処理が実行されることになる。
状態記憶部220は、状態レジスタ250とタイマ252を含む、状態記憶部220は、タスクの状態データを保持する。また、タイマ252は、タスクがREADY状態またはWAIT状態に遷移したときに開始するタイマである。タスクがREADY状態に遷移してから経過した時間のことを「READY経過時間」、タスクがWAIT状態に遷移してから経過した時間のことを「WAIT経過時間」とよぶ。タイマ252は、その値をTIM信号として常時出力する。タスク切換回路210は、タスクスイッチに際して、あるタスクがREADY状態またはWAIT状態に変化したときには、そのタスクのタイマ252を駆動して時間計測を開始させる。
(A)タスクIDレジスタ254:タスクIDを保持する。タスクIDレジスタ254からはタスクIDを示すID信号がタスク選択回路230に常時出力される。以下、タスクAのタスクIDレジスタ254からタスク選択回路230に出力されるID信号のことを「ID_A信号」と表記する。状態記憶部220から出力される他の信号についても同様である。
(B)タスク優先順位レジスタ256:タスク優先順位を保持する。タスク優先順位レジスタ256からはタスク優先順位を示すPR信号が常時出力される。「0」が最高優先順位であり、値が大きいほどタスク優先順位が低いことを示す。
(C)タスク状態レジスタ258:タスク状態を示す。STOP、READY、RUN、WAIT、IDLEのいずれかがST信号として常時出力される。なお、IDLEとは、タスクが初期化される前の状態である。
(D)タスク起動アドレスレジスタ260:メモリにおけるタスクのTCBアドレスを示す。出力はAD信号である。
(E)待機理由レジスタ262:タスクがWAIT状態にあるとき、WAIT解除条件の一部として待機の理由を示す。待機理由は、「セマフォ待ち」、「イベント待ち」、「ミューテックス待ち」のいずれかである。出力はWR信号である。
(F)セマフォIDレジスタ264:タスクがセマフォ待ちを理由として、WAIT状態にあるとき、待ち対象のセマフォ(以下、単に「待機セマフォ」)のセマフォIDを保持する。出力はSID信号である。
(G)ミューテックスIDレジスタ265:タスクがミューテックス待ちを理由として、WAIT状態にあるとき、待ち対象のミューテックス(以下、単に「待機ミューテックス」)のミューテックスIDを保持する。出力はMID信号である。
(H)イベントIDレジスタ266:タスクがイベント待ちを理由として、WAIT状態にあるとき、待ち対象のイベント(以下、単に「待機イベント」)のイベントIDを保持する。出力はEID信号である。
(I)待機フラグレジスタ268:タスクがイベント待ちを理由として、WAIT状態にあるとき、待機フラグパターンを保持する。出力はFL信号である。
(J)フラグ条件レジスタ270:タスクがイベント待ちを理由として、WAIT状態にあるとき、フラグ条件を保持する。出力はFLC信号である。待機フラグパターンやフラグ条件については後述する。
(K)フラグ初期化レジスタ272:待機フラグパターンの有無を示すデータを保持する。出力はFLI信号である。
(L)タイムアウトカウンタ274:WAIT系システムコールにおいてはタイムアウト値が変数として指定される。タイムアウトカウンタ274は、タイムアウト値を保持する。タスク切換回路210は、各タイムアウトカウンタ274のタイムアウト値を定期的にデクリメントする。出力はTO信号である。タスク切換回路210がタイムアウト値をデクリメントする代わりに、タイムアウトカウンタ274自体が自律的に自らのタイムアウト値を定期的にデクリメントしてもよい。
(A)実行選択回路232:タスクスイッチに際して、次のRUN−タスクを選択する。実行選択回路232は、状態記憶部220から常時出力される状態データにより常にいずれかのタスクをRUN−タスクとして選択している。実行選択回路232の入力信号は、ID、ST、PR、TIMの4種類である。出力は、次のRUN−タスクのタスクIDである。詳細な回路構成については図12に関連して詳述する。
(B)セマフォ選択回路234:リリースセマフォシステムコールの実行により、WAIT状態からREADY状態に遷移すべきタスクを選択する。リリースセマフォシステムコールにより解放されるセマフォ(以下、単に「解放セマフォ」)のセマフォIDをタスク切換回路210から入力される。状態記憶部220からの入力信号は、ID、ST、WR、PR、SID、TIMの6種類である。出力信号は、WAIT状態からREADY状態に遷移するタスクのタスクIDである。該当するタスクが存在しなければ、−1などの所定値を出力する。より具体的な回路構成については図13に関連して詳述する。
(C)イベント選択回路236:セットイベントシステムコールの実行により、WAIT状態からREADY状態に遷移するタスクを選択する。セットイベントシステムコールによりセットされるイベント(以下、単に「設定イベント」)のイベントIDをタスク切換回路210から入力される。状態記憶部220からの入力信号は、ID、ST、WR、EID、FL、FLCの6種類である。出力信号は、WAIT状態からREADY状態に遷移するタスクのタスクIDと、そのタスクのFL、FLCを出力する。
(D)タイムアウト検出回路238:WAIT状態のタスクのうち、タイムアウトカウンタ274のタイムアウト値がゼロとなったタスクを検出する。タイムアウト検出回路238は、タイムアウト値が更新されるごとに駆動される。タイムアウト検出回路238の入力信号は、ID、ST、TOの3種類である。出力信号は、該当するタスクのタスクIDである。該当するタスクが存在しなければ、−1などの所定値を出力する。
(E)ミューテックス回路240:リリースミューテックスシステムコールの実行により、WAIT状態からREADY状態に遷移するタスクを選択する。リリースミューテックスシステムコールにより解放されるミューテックス(以下、単に「解放ミューテックス」)のミューテックスIDをタスク切換回路210から入力される。状態記憶部220からの入力信号は、ID、ST、WR、PR、SID、TIMの6種類である。出力信号は、WAIT状態からREADY状態に遷移するタスクのタスクIDである。該当するタスクが存在しなければ、−1などの所定値を出力する。
(F)検索回路242:タスク切換回路210からタスクIDを入力されると、そのタスクの全状態データを出力する。
[RUN−タスク選択]
[1]一般的なソフトウェアRTOSによるRUN−タスクの選択
タスクレディリストは、メモリ上に形成され、各READY−タスクのTCBをポインタによって連結したリストである。優先順位ポインタ280は、タスク優先順位ごとに設けられ、該当タスク優先順位のタスクのTCBの先頭アドレスを指す。同図のタスクレディリストの場合、タスク優先順位「0」の優先順位ポインタ280は、タスクAのTCBをアドレスし、タスク優先順位「1」の優先順位ポインタ280は、タスクBのTCBをアドレスしている。タスクAのTCBは、更に、タスクDのTCBをアドレスしている。 一般的なソフトウェアRTOSは、このタスクレディリストを走査しながら、次のRUN−タスクを選択する。このとき、RTOSは、
A.RUN−タスクをRUNからREADYに状態遷移させる。
B.次のRUN−タスクを選択し、そのタスクのタスク状態をREADYからRUNに状態遷移させる。
という2段階の処理を行う。ソフトウェアRTOSによる各処理を分解すると以下の通りである。
<RUN−タスクの状態遷移>
A1.RTOSは、RUN−タスクのタスクIDをメモリに保持している。このタスクIDをもとに、タスクJのTCBのアドレスを取得する。
A2.TCBにアクセスし、タスクJのタスク優先順位を取得する。タスク優先順位は「0」であったとする。
A3.図11に示すタスクレディリストのうち、タスクJのタスク優先順位に対応する優先順位ポインタ280を取得する。
A4.取得した優先順位ポインタ280が示すTCBを検出する。ここではタスクAのTCBが検出される。
A5.タスクAのTCBが持つポインタをたどっていき、最後尾のTCBを検出する。同図においては、タスクFが最後尾である。
A6:タスクFのTCBのポインタがタスクJのTCBをアドレスするように設定する。こうして、タスクJのTCBがタスクレディリストに追加される。
A7.タスクJのTCBに「READY」を設定する。また、処理データは、TCBのレジスタ格納エリアにコピーされる。
<READY−タスクの状態遷移>
B2.タスクAをタスクレディリストからはずす。具体的には、タスク順位「0」の優先順位ポインタ280がタスクAではなくタスクDのTCBをアドレスするように書き換える。また、タスクAのポインタがタスクDをアドレスしないようにNULL設定する。こうして、タスクAのTCBがタスクレディリストから外される。
B3.タスクAのTCBに「RUN」を設定する。また、タスクAのTCBのレジスタ格納エリアに退避されていた処理データが処理レジスタにロードされる。
1.READY−タスクであること(第1条件)。
2.READY−タスクのうち、最もタスク優先順位の高いタスクであること(第2条件)。
3.最もタスク優先順位の高いタスクが複数存在するときには、READY状態になった時期が最も古いタスクであること(第3条件)。
このような3つの条件のことを、まとめて「RUNタスク選択条件」とよぶことにする。タスク処理装置100の実行選択回路232は、このようなRTOSのタスクスケジューリング機能をハードウェアにより実現している。
[2]基本例のハードウェアRTOSによるRUN−タスクの選択
ここでは、タスク0〜タスク7の8つのタスクから、RUN−タスクを選択するとして説明する。実行選択回路232は、4つの第1比較回路290(290a〜290d)、2つの第2比較回路292(292a、292b)、1つの第3比較回路294を含む。また、8つの判定回路296(296a〜296h)も含む。
判定回路296は、タスクの状態を示すST信号を入力とし、READYであれば「1」、READY以外であれば「0」を示すCID信号を出力する。判定回路296は、上記RUNタスク選択条件のうちの第1条件に基づく判定を行っている。第1比較回路290は、2つのタスクのID、PR、TIM、および、判定回路296からのCID信号を入力とする。
第1の判定:まず、判定回路296aと判定回路296bのそれぞれから出力されるCID信号を比較する。いずれか一方が「1」であれば、いいかえれば、いずれか一方のタスクだけがREADY状態であれば、第1比較回路290aは、そのタスクのID、PR、TIMを出力する。いずれも「0」であれば、すなわち、いずれのタスクもREADY状態でなければ、第1比較回路290aは、ID=PR=TIM=NULLを出力する。これは、いずれのタスクも選択されなかったことを示す。いすれも「1」であれば、すなわち、いずれのタスクもREADY状態であれば、次の第2の判定が実行される。
第2の判定:タスク0のPR信号とタスク1のPR信号を比較し、タスク優先順位が上位となるタスクを選択する。たとえば、タスク0のタスク優先順位が「1」、タスク1のタスク優先順位が「2」であれば、タスク0のID、PR、TIMを出力する。第2の判定により、タスク優先順位が上位のタスクがRUN−タスクの候補として選択されることになる。タスク0とタスク1のタスク優先順位が同じであれば、次の第3の判定が実行される。
第3の判定:タスク0のTIM信号とタスク1のTIM信号を比較し、READY経過時間が長い方のタスクを選択する。READY経過時間が同じであれば、タスク0を選択するものとする。経過時間の大小を比較するだけで判定できるため、タスクレディリストのようなTCBの順序管理が不要となる。
<RUN−タスクの状態遷移>
A1.タスク切換回路210は、タスクJのタスク状態レジスタ258に「READY」を設定する。
A2.タスク切換回路210は、タスクJのタイマ252をセットしてREADY経過時間の計測を開始させる。
こうして、タスクJはRUN→READYに状態遷移する。処理データは、先述したようにタスクJの退避レジスタ110に退避される。処理レジスタ154と退避レジスタ110をつなぐバスは、処理データをパラレルに伝送可能であるため、A1とA2の処理は1クロック時間で実行可能である。
<READY−タスクの状態遷移>
こうして、特定されたタスクはREADY→RUNに状態遷移する。特定されたタスクの処理データは退避レジスタ110から処理レジスタ154にロードされる。退避レジスタ110と処理レジスタ154をつなぐバスも、処理データをパラレルに伝送可能なビット数であるため、B1の処理は1クロック時間で実行可能である。
[セマフォ処理]
ウェイトセマフォリストを説明する前に、セマフォについて簡単に説明する。セマフォテーブル212には、セマフォIDとセマフォカウンタが対応づけて記録される。セマフォカウンタは、初期値として有限数に設定される。たとえば、セマフォID=4、セマフォカウンタ=3として設定されているとする。いずれかのタスクがセマフォID=4のセマフォを待機セマフォとしてウェイトセマフォシステムコールを実行すると、タスク切換回路210は待機セマフォのセマフォカウンタをデクリメントする。セマフォカウンタはウェイトセマフォイベントコールにより獲得要求されるごとにデクリメントされ、0になると獲得できなくなる。セマフォカウンタが0となっているセマフォを待機セマフォとしてウェイトセマフォシステムコールを実行したタスクは、WAIT状態に状態遷移する。
セマフォカウンタ>0のとき:ウェイトセマフォシステムコールを実行したタスクは、RUN→READYに遷移する。このときセマフォカウンタはデクリメントされる。
セマフォカウンタ=0のとき:ウェイトセマフォシステムコールを実行したタスクは、RUN→WAITに遷移する。セマフォカウンタはデクリメントされない。
ウェイトセマフォシステムコールを実行したタスクがWAIT状態からREADY状態に遷移するためには、別のタスクがリリースセマフォシステムコールを実行する必要がある。
[1]一般的なソフトウェアRTOSによるセマフォ処理
一般的なソフトウェアRTOSは、リリースセマフォシステムコールが実行されたとき、このウェイトセマフォリストを走査しながら、WAIT状態からREADY状態に遷移させるべきセマフォ待ちタスクを選択する。ウェイトセマフォシステムコールおよびリリースセマフォシステムコール実行時におけるRTOSの処理は以下の通りである。
<ウェイトセマフォシステムコールの実行>
A1.RTOSは、RUN−タスクのタスクIDをメモリに保持している。このタスクIDをもとに、タスクJのTCBのアドレスを取得する。
A2.ウェイトセマフォシステムコールにおいて指定された待機セマフォのセマフォカウンタを検出する。以下、セマフォカウンタの値に応じて処理は分岐する。
(セマフォカウンタ>0のとき)
A3.RTOSは、待機セマフォのセマフォカウンタをデクリメントする。
A4.タスクJのTCBに「READY」を設定する。この場合、タスクJのTCBはタスクレディリストに追加される。
(セマフォカウンタ=0のとき)
A3.TCBにアクセスし、タスクJのタスク優先順位を取得する。タスク優先順位は「0」であったとする。
A4.ウェイトセマフォリストのうち、タスクJのタスク優先順位に対応する優先順位ポインタを取得する。
A5.取得した優先順位ポインタが示すTCBを検出する。ここではタスクAのTCBが検出される。
A6.タスクAのTCBが持つポインタをたどっていき、最後尾のTCBを検出する。同図においては、タスクFが最後尾である。
A7:タスクFのTCBのポインタがタスクJのTCBをアドレスするように設定する。こうして、タスクJのTCBがウェイトセマフォリストに追加される。
A8.タスクJのTCBに「WAIT」を設定する。また、待機セマフォのセマフォIDも設定する。
<リリースセマフォシステムコールの実行>
(検出されたとき)
B2.検出されたタスクがタスクEであるとして説明する。タスクEのTCBに「READY」を設定する。また、待機セマフォのセマフォIDをクリアする。
B3.タスクEのTCBをウェイトセマフォリストから外す。
B4.セマフォを解放したタスクの状態をRUN→READYに状態遷移させる。このタスクのTCBは、タスクレディリストに追加される。
(検出されなかったとき)
B2.セマフォカウンタをインクリメントする。
B3.セマフォを解放したタスクの状態をRUN→READYに状態遷移させる。このタスクのTCBは、タスクレディリストに追加される。
1.WAIT−タスクであること(第1条件)。
2.WAIT−タスクのうち、解放セマフォを待機セマフォとするタスクであること(第2条件)
3.そのようなタスクが複数存在するときには、最もタスク優先順位の高いタスクであること(第3条件)。
4.最もタスク優先順位の高いタスクが複数存在するときには、WAIT状態になった時期が最も古いタスクであること(第4条件)。
このような4つの条件のことを、まとめて「セマフォ待機解除条件」とよぶことにする。タスク処理装置100のセマフォ選択回路234は、このようなRTOSのタスクスケジューリング機能をハードウェアにより実現している。
[2]基本例のハードウェアRTOSによるセマフォ処理
ここでも、タスク0〜タスク7の8つのタスクを前提として説明する。セマフォ選択回路234は、4つの第1比較回路300(300a〜300d)、2つの第2比較回路302(302a、302b)、1つの第3比較回路304を含む。また、8つの判定回路306(306a〜306h)も含む。
判定回路306は、状態記憶部220からのST、WR、SID信号とタスク切換回路210からのセマフォIDを示す信号を入力とする回路である。ここで入力されるセマフォIDは、解放セマフォのセマフォIDである。判定回路306は、解放セマフォを待機セマフォとするセマフォ待ちタスクであれば「1」、そうでなければ「0」を示すCID信号を出力する。判定回路306は、上記セマフォ待機解除条件のうちの第1条件と第2条件に関する判定結果を出力する回路である。第1比較回路300は、2つのタスクのID、PR、TIM、および、判定回路306からのCID信号を入力とする。
<ウェイトセマフォシステムコールの実行>
A1.タスク切換回路210は、ウェイトセマフォシステムコールにおいて指定されたセマフォのセマフォカウンタをセマフォテーブル212から検出する。以下、セマフォカウンタの値に応じて処理は分岐する。
(セマフォカウンタ>0のとき)
A2.タスク切換回路210は、セマフォテーブル212のセマフォカウンタをデクリメントする。
A3.タスクJのタスク状態レジスタ258に「READY」を設定する。このとき、タスク切換回路210は、RUN−タスクのタイマ252をセットしてREADY経過時間の計測を開始させる。
(セマフォカウンタ=0のとき)
A2.タスク切換回路210は、タスクJのタスク状態レジスタ258に「WAIT」、待機理由レジスタ262に「セマフォ待ち」、セマフォIDレジスタ264に待機セマフォのセマフォIDをセットし、タイマ252をセットしてWAIT経過時間の計測を開始させる。
こうして、ウェイトセマフォシステムコールを実行したタスクはRUN→READYまたはWAITに状態遷移する。
<リリースセマフォシステムコールの実行>
(いずれかの判定回路306が「1」を出力し、第3比較回路304がいずれかのタスクIDを出力したとき)
B2.検出されたタスクのタスク状態レジスタ258に「READY」を設定し、待機理由レジスタ262とセマフォIDレジスタ264をクリアし、タイマ252にREADY経過時間を計測させる。
B3.システムコールを実行したタスクのタスク状態レジスタ258に「READY」に設定し、READY経過時間の計測を開始する。
(いずれの判定回路306も「1」を出力せず、第3比較回路304がいずれのタスクIDも出力しないとき)
B2.タスク切換回路210はセマフォテーブル212のセマフォカウンタをインクリメントする。
B3.システムコールを実行したタスクの状態をRUN→READYに状態遷移させる。
[ミューテックス処理]
1.セマフォカウンタは1以上の整数を設定可能である。これに対し、ミューテックスはセマフォカウンタが1または0の特殊なセマフォである。セマフォカウンタが2以上のときには、同一セマフォを2以上のタスクが獲得できる。しかし、ミューテックスの場合、あるミューテックスを獲得できるタスクは常に1つだけである。
2.リリースセマフォシステムコールによりセマフォを解放できるタスクは、ウェイトセマフォシステムコールによりセマフォを獲得したタスクに限らない。これに対し、リリースミューテックスシステムコールによりミューテックスを解放できるタスクは、ウェイトミューテックスシステムコールによりミューテックスを獲得したタスクだけである。
1.WAIT−タスクであること(第1条件)。
2.WAIT−タスクのうち、解放ミューテックスを待機ミューテックスとするタスクであること(第2条件)
3.そのようなタスクが複数存在するときには、最もタスク優先順位の高いタスクであること(第3条件)。
4.最もタスク優先順位の高いタスクが複数存在するときには、WAIT状態になった時期が最も古いタスクであること(第4条件)。
このような4つの条件のことを、まとめて「ミューテックス待機解除条件」とよぶことにする。
<ウェイトミューテックスシステムコールの実行>
A1.タスク切換回路210は、ウェイトミューテックスシステムコールにおいて指定されたミューテックスが占有されているか検出する。以下、ミューテックスの占有状態に応じて処理は分岐する。
(ミューテックスが占有されていないとき)
A2.タスク切換回路210は、ミューテックスの占有データとして、システムコールを実行したタスクのタスクIDを記録する。
A3.タスクJのタスク状態レジスタ258に「READY」を設定する。このとき、タスク切換回路210は、RUN−タスクのタイマ252をセットしてREADY経過時間の計測を開始させる。
(ミューテックスが占有されているとき)
A2.タスク切換回路210は、タスクJのタスク状態レジスタ258に「WAIT」、待機理由レジスタ262に「ミューテックス待ち」、ミューテックスIDレジスタ265に待機ミューテックスのミューテックスIDをセットし、タイマ252をセットしてWAIT経過時間の計測を開始させる。
<リリースミューテックスシステムコールの実行>
(いずれかの判定回路が「1」を出力し、ミューテックス回路240からいずれかのタスクIDを出力したとき)
B2.検出されたタスクのタスク状態レジスタ258に「READY」を設定し、待機理由レジスタ262とミューテックスIDレジスタ265をクリアし、タイマ252をREADY経過時間を計測させる。
B3.システムコールを実行したタスクのタスク状態レジスタ258に「READY」に設定し、READY経過時間の計測を開始する。
(いずれの判定回路も「1」を出力せず、ミューテックス回路240がいずれのタスクIDも出力しないとき)
B2.タスク切換回路210はセマフォテーブル212において、ミューテックスを非占有状態に設定する。
B3.システムコールを実行したタスクの状態をRUN→READYに状態遷移させる。
[イベント処理]
セットイベントシステムコールは、カレントフラグパターンを設定変更するシステムコールであり、イベントIDとフラグパターン(以下、「セットフラグパターン」とよぶ)をパラメータとする。セットイベントシステムコールが実行されると、該当イベントについて、カレントフラグパターンは、セットフラグパターンとの論理和に変更される。たとえば、カレントフラグパターン「00001100」、セットフラグパターン「00000101」のときには、カレントフラグパターンは、「00001101」となる。以下、各フラグパターンについて左から第0ビット、第1ビット、・・・、第7ビットとよぶ。
[1]一般的なソフトウェアRTOSによるイベント処理
<ウェイトイベントシステムコールの実行>
A2.カレントフラグパターンと待機フラグパターンをフラグ条件にしたがって比較し、WAIT解除条件の成否を判定する。
(WAIT解除条件が成立するとき)
A3.システムコールを実行したタスクのタスク状態をRUN→READYに状態遷移させる。
(WAIT解除条件が成立しないとき)
A3.イベントテーブルに、システムコールを実行したタスクのタスクIDを記録する。
A4.イベントテーブルに待機フラグパターンを記録する。
A5.イベントテーブルにフラグ条件を記録する。
A6.システムコールを実行したタスクのタスク状態をRUN→WAITに状態遷移させる。
<セットイベントシステムコールの実行>
B2.カレントフラグパターンとセットフラグパターンの論理和を新たなカレントフラグパターンとして記録する。
(設定イベントについてイベント待ちタスクが存在しないとき、または、存在したとしても待機フラグパターンとフラグ条件からWAIT解除条件が成立しないとき)
B3.システムコールを実行したタスクのタスク状態をRUN→READYに状態遷移させる。
(設定イベントについてイベント待ちタスクが存在し、WAIT解除条件が成立するとき)
B3.イベントを待機していたタスクのタスク状態をWAIT→READYに状態遷移させる。
B4.イベントテーブルにおける待機タスクID、待機フラグパターン、フラグ条件をクリアする。
B5.システムコールを実行したタスクのタスク状態をRUN→READYに状態遷移させる。また、RUN−タスクの選択が行われる。
1.WAIT−タスクであること(第1条件)。
2.WAIT−タスクのうち、設定イベントを待機イベントとするタスクであること(第2条件)。
3.待機フラグパターンとカレントフラグパターン、フラグ条件を比較してWAIT解除条件が成立するタスクであること(第3条件)
このような3つの条件のことを、まとめて「イベント待機解除条件」とよぶことにする。
[2]基本例のハードウェアRTOSによるイベント処理
<ウェイトイベントシステムコールの実行>
A2.タスク切換回路210は、カレントフラグパターンと待機フラグパターンをフラグ条件にしたがって比較し、WAIT解除条件の成否を判定する。
(WAIT解除条件が成立するとき)
A3.システムコールを実行したタスクのタスク状態レジスタ258に「READY」を設定する。
(WAIT解除条件が成立しないとき)
A3.タスク切換回路210は、システムコールを実行したタスクのタスク状態レジスタ258に「WAIT」、待機理由レジスタ262に「イベント待ち」、イベントIDレジスタ266に待機イベントのイベントID、待機フラグレジスタ268に待機フラグパターン、フラグ条件レジスタ270にフラグ条件をそれぞれ設定する。
<セットイベントシステムコールの実行>
B2.タスク切換回路210は、イベントテーブル214のカレントフラグパターンにセットフラグパターンを論理加算する。
B3.イベント選択回路236は、入力されたイベントIDについて、イベント待機条件が成立するタスクを選択する。このとき、タスク優先順位やWAIT経過時間に関わらず複数のタスクが選択されてもよい。
(イベント待機解除条件を満たすタスクが存在するとき)
B4.イベント待ちタスクのタスク状態レジスタ258に「READY」を設定し、イベントIDレジスタ266、待機フラグレジスタ268、フラグ条件レジスタ270をクリアする。
B5.システムコールを実行したタスクのタスク状態をRUN→READYに状態遷移させる。
(イベント待機解除条件を満たすタスクが存在しないとき)
B4.システムコールを実行したタスクのタスク状態をRUN→READYに状態遷移させる。
[タイムアウト処理]
[1]一般的なソフトウェアRTOSによるタイムアウト処理
[2]基本例のハードウェアRTOSによるタイムアウト処理
[有限ステートマシンとしてのタスク切換回路210]
初期化処理(A1)においては、全タスクがIDLE状態にある。初期化処理が完了すると(S10)、いずれかのタスクがRUN−タスクとなりタスク実行状態(A2)となる。割り込み要求信号が検出されると(S12)、特殊タスクがRUN−タスクとなり、割り込み処理(A3)が実行される。割り込み処理が終了すると(S14)、タスク切換回路210は、一般タスクからRUN−タスクを選択し、A2に遷移する。
基本例に関連して、更に、タスク処理装置100の主要素である退避回路120とタスク制御回路200のうち一方のみを実装する場合について付言する。
[タスク制御回路200を搭載しないタイプのタスク処理装置100]
タスク制御回路200を搭載しない代わりに、レジスタ切換制御回路322と処理データ保持部320を追加している。タスク制御回路200を搭載しないため、タスクスケジューリング機能はソフトウェアRTOSにより実現される。したがって、RTOSはタスクスイッチに際して、CPU150の使用権を一時的に取得する必要が生じる。処理データ保持部320は、通常、RTOSのための処理データを保持する。RTOSがCPU150の使用権を取得するときには、処理データ保持部320は処理データ保持部320にあるRTOS用の処理データと特殊レジスタ156のタスク用の処理データを入れ替える。以下、タスクAからタスクBへタスクスイッチするとして、その処理過程を説明する。
A2.レジスタ切換制御回路322は、タスクAの処理データを処理データ保持部320に移動させ、処理データ保持部320のRTOS用処理データを処理レジスタ154にロードする。この段階で、RTOSがCPU150の使用権を取得する。
A3.レジスタ切換制御回路322は、退避レジスタ110aに書き込み信号を入力し、処理データ保持部320のタスクA用処理データを退避レジスタ110に退避させる。
A4.RTOSは、汎用レジスタ158に記録されているシステムコールの変数やIDに基づき、システムコールに対応する処理を実行する。また、タスクAのTCBのタスク状態データを「READY」に設定し、タスクレディリストにタスクAのTCBを追加する。
B2.RTOSはレジスタ切換制御回路322に指示して、タスクBを指定したタスク選択信号をロード選択回路112に入力させる。退避レジスタ110bから処理データ保持部320に処理データが移動される。
B3.レジスタ切換制御回路322は、処理データ保持部320のタスクB用処理データと処理レジスタ154のRTOS用処理データを入れ替える。これにより、タスクBがCPU150の使用権を取得する。
[退避回路120を搭載しないタイプのタスク処理装置100]
退避回路120を搭載しない代わりに、割込インタフェース回路324を追加している。退避回路120を搭載しないため、処理データはメモリのTCBに退避される。処理データの退避・ロードに関してはソフトウェアベースのRTOSにより実現される。したがって、RTOSはタスクスイッチに際して、CPU150の使用権を一時的に取得する必要が生じる。以下、タスクAからタスクBへタスクスイッチするとして、その処理過程を説明する。
{改良例}
なお、再実行優先型タスクスケジューリングに限らず、両投入型キューアルゴリズムは一般的なアプリケーションプログラムにおいても有用である。このため、両投入型キューアルゴリズムのハードウェア実装は、さまざまなコンピュータプログラムの処理速度を向上させる上で有効である。
改良例におけるタスク処理装置100も、CPU150に加えて退避回路120とタスク制御回路200を含む。ただし、改良例におけるタスク切換回路210は、メイン回路400、書込回路402、キュー制御回路404および最大値選択回路406を含む。メイン回路400は、基本例におけるタスク切換回路210とほぼ同等の機能を備える回路である。このため、改良例におけるタスク切換回路210は、基本例におけるタスク切換回路210としてのメイン回路400に書込回路402、キュー制御回路404および最大値選択回路406を追加した構成となっている。各状態記憶部220からは全タスクの全状態データが、タスク選択回路230だけではなく、最大値選択回路406やキュー制御回路404にも常時出力されている。
タスク制御回路200の基本構成は、図10に示した回路構成とほぼ同等である。各タスクに対応づけられる状態レジスタ250は、タスクIDレジスタ410、タスク優先順位レジス412、キュー順序レジスタ414、キュー識別レジスタ416を含む。状態レジスタ250は、そのほかのレジスタを含んでもよいが、ここでは両投入型キューアルゴリズムに関わるレジスタ群を中心として説明する。
(A)タスクIDレジスタ410:タスクIDを保持する。基本例に示したタスクIDレジスタ254と同等である。タスクIDレジスタ410からはタスクIDを示すEID_S信号が常時出力される。
(B)タスク優先順位レジスタ412:タスク優先順位(PR)を保持する。基本例に示したタスク優先順位レジスタ256と同様である。PR_S信号として常時出力される。
(C)キュー順序レジスタ414:後述する仮想キューへの投入順位を示す「順序値(ODR)」を保持する。順序値が大きいほど、仮想キューの深くに投入されていることを示すが、詳しくは後述する。順序値は、ODR_S信号として常時出力される。
(D)キュー識別レジスタ416:仮想キューを識別する「キューID(QID)」を保持する。QID_S信号として常時出力される。
タスク優先順位レジスタ412と、キュー順序レジスタ414、キュー識別レジスタ416は、特に、仮想キューを管理するためのキューレジスタとして機能する。
タスクA:QID=0、ODR=0
タスクB:QID=0、ODR=1
タスクC:QID=0、ODR=2
タスクD:QID=1、ODR=0
として設定されているときには、仮想キュー(0)には、タスクC、B、Aの順に投入されており、仮想キュー(1)には、タスクDだけが投入されていることを示す。QIDとODRの数値範囲によって仮想キューの数やサイズを柔軟に変更できる。
キュー制御回路404の回路構成については、次の図20に関連して詳述する。
キュー制御回路404は、複数のレジスタ値生成回路420の集合体である。各レジスタ値生成回路420は同じ回路である。レジスタ値生成回路420は、タスクごとに対応づけられている。状態レジスタ250ごとに対応づけられているともいえる。レジスタ値生成回路420_Enは、タスクID=Enのタスク(以下、「タスク(En)」のように表記する)に対応づけられる。レジスタ値生成回路420には、該当タスクのタスクIDがELM_ID信号として固定的に入力される。
レジスタ値生成回路420_Enは、タスク(En)の順序値、キューID、タスク優先順位をそれぞれQID_N_En、ODR_N_En、PR_N_Enとして出力し、書込回路402によりWTがアサートされたときに状態レジスタ250_Enに書き込まれる。
書込回路402がWTをアサートすると、全てのレジスタ値生成回路420のQID_N_En、ODR_N_En、PR_N_Enが全ての状態レジスタ250に書き込まれる。CMDにより影響を受けるタスクについてのレジスタ値生成回路420は、後述するアルゴリズムにて指定される新たなデータを状態レジスタ250に書き込む。一方、CMDにより影響を受けないタスクについてのレジスタ値生成回路420も、状態レジスタ250に書き込まれているデータと同じデータを再出力して書き込みを実行する。
なお、レジスタ値生成回路420のWTは、各状態レジスタ250ではなくキュー制御回路404に直接入力されてもよい。この場合、キュー制御回路404に内蔵されるレジスタ値生成回路420のうち、CMDにより状態変更すべきタスクについてのレジスタ値生成回路420だけが、新たなデータを状態レジスタ250に書き込むとしてもよい。
レジスタ値生成回路420の具体的な処理内容については後述する。
ここでは、仮想キュー(Q0)と仮想キュー(Q1)の2つの仮想キューを想定している。仮想キュー(Q0)は、タスク優先順位PR=0のタスクが投入される優先キュー(以下、「優先キュー(Q0:0)」と表記する)とタスク優先順位PR=1のタスクが投入される優先キュー(Q0:1)の2つの優先キューの集合である。仮想キュー(Q1)についても同様であり、実質的には4つの優先キューが想定される。たとえば、仮想キュー(Q0)はREADY状態、仮想キュー(Q1)はWAIT状態に対応づけられてもよい。
図21に示した仮想キューへの各タスクの投入状態は、状態レジスタ250の設定により表現される。図21に示した状態においては、タスク(E0)〜タスク(E7)のうち、仮想キューに投入されているのはタスク(E0)〜タスク(E3)である。このため、それ以外のタスクのキュー識別レジスタ416には未投入を示す「Non」が設定される。仮想キュー(Q0)に投入されるタスク(E0)、タスク(E3)、タスク(E2)のキュー識別レジスタ416には「Q0」が設定される。また、仮想キュー(1)に投入されるタスク(E1)のキュー識別レジスタ416には「Q1」が設定される。キュー識別レジスタ416の設定内容により、どのタスクがどの仮想キューに投入されているかを表現する。
以上の設定に基づいて、順投入、逆投入、抽出における処理内容について詳述する。
[順投入]
ここでは、仮想キュー(Q1)にタスク優先順位PR=0のタスク(E4)を順投入するとして説明する。メイン回路400は、CMD=ENQ_TL(順投入コマンド)として、EID_C=E4、QID_C=Q1、PR_C=0を設定する。キュー制御回路404に内蔵されるレジスタ値生成回路420_E4は、EID_C=ELM_ID=E4を検出すると、QID_N_E4=QID_C=Q1、ODR_N_E4=0、PR_N_E4=PR_C=0を出力する。QID_N_E4はタスク(E4)の投入先となる仮想キューのQID、ODR_N_E4は投入時における順序値、PR_N_E4はタスク(E4)のタスク優先順位である。順投入されるタスクについてのODR_Nは、常に「0」に設定される。これは、キューに対する最新の投入を示す順序値である。
同図において下線を付与している部分が、図22に示した状態レジスタ250の設定内容から変化した箇所である。タスク(E4)の仮想キュー(Q1)への順投入により、キュー識別レジスタ416_E4にはQID_N_E4により「Q1」が設定される。タスク(E4)のODRは「0」、PRは「0」である。タスク(E4)の順投入により、仮想キュー(Q1)に既に投入されていたタスク(E1)のODRは、「0」から「1」にインクリメントされる。変更後の状態レジスタ250の設定内容により、図23に示した仮想キュー(Q1)の状態が表現される。
ここでは、仮想キュー(Q0)にタスク優先順位PR=1のタスク(E5)を順投入するとして説明する。メイン回路400は、CMD=ENQ_TL(順投入コマンド)として、EID_C=E5、QID_C=Q0、PR_C=1を設定する。レジスタ値生成回路420_E5は、QID_N_E5=QID_C=Q0、ODR_N_E5=0、PR_N_E5=PR_C=1を出力する。
同図において下線を付与している部分が、図24に示した状態レジスタ250の設定内容から変化した箇所である。まず、タスク(E5)の仮想キュー(Q0)への順投入により、キュー識別レジスタ416_E5には新たに「Q0」が設定される。タスク(E5)のODRは「0」、PRは「1」である。タスク(E5)の順投入により、仮想キュー(Q0)に元々投入されていたタスク(E0)、タスク(E1)、タスク(E3)のODRは、それぞれインクリメントされる。
メイン回路400は、順投入させるタスク(以下、「順投入タスク」とよぶ)についての投入条件を設定する(S10)。具体的には、CMD=ENQ_TLとして、EID_C、QID_C、PR_Cを設定する。キュー制御回路404のうち、順投入タスクに対応するレジスタ値生成回路420は、順投入タスクのタスク優先順位レジスタ412、キュー順序レジスタ414、キュー識別レジスタ416にそれぞれ、PR_C、0、QID_Cを設定する(S12)。
[逆投入]
最大値選択回路406は、逆投入処理のためにメイン回路400により駆動される回路である。最大値選択回路406は、CND信号としてQID_C=Qnを入力されたとき、仮想キュー(Qn)における最大順序値をODR_A2に出力し、ODR_A2_ENをアサートする。最大値選択回路406は、基本例に示した実行選択回路232やセマフォ選択回路234と同じく、複数段の比較回路から構成される。最大値選択回路406は、4つの第1比較回路422(422a、422b等)、2つの第2比較回路424(424a等)、1つの第3比較回路(図示せず)を含む。また、8つの判定回路426(426a、426b、426c、426d等)を含む。
第1の判定:判定回路426aは、タスク0が仮想キュー(Qn)に投入済みであればEID_11A_ENをアサートする。判定回路426bは、タスク1が仮想キュー(Qn)に投入済みであればEID_11B_ENをアサートする。第1比較回路422aは、まず、判定回路426aと判定回路426bのそれぞれから出力されるEID_11_EN信号を参照する。いずれか一方が「1」であれば、いずれか一方のタスクだけが仮想キュー(Qn)に投入されていることになる。このとき、第1比較回路422aは、仮想キュー(Qn)に投入されている方のタスクのタスクID(EID_S)と順序値(ODR_S)をそれぞれEID_21A、ODR_21Aとして出力し、EID_21A_ENをアサートする。
判定回路426aと判定回路426bが共に「0」を出力するときには、どちらのタスクも仮想キュー(Qn)に投入されていない。このとき、EID_21A_ENはネゲートされ、以後、タスク0とタスク1のいずれも第2比較回路424aにおいて考慮の対象とはならない。
判定回路426aと判定回路426bが共に「1」を出力するときには、どちらのタスクも仮想キュー(Qn)に投入済である、このとき、次の第2の判定が実行される。
なお、第1比較回路422、第2比較回路424、第3比較回路には、優先順位判定を無効化するためのPR無効信号が入力されてもよい。PR無効信号がアサートされているときには、各比較回路は、優先順位を判定条件から除外してタスクを選択する。図32に示す各比較回路についても同様である。
ここでは、仮想キュー(Q0)にタスク優先順位PR=1のタスク(E6)を逆投入するとして説明する。まず、メイン回路400は、投入先のQID=Q0をQID_C信号により最大値選択回路406に入力する。最大値選択回路406は、仮想キュー(Q0)の最大順序値をキュー制御回路404にODR_A2として出力し、ODR_A2_ENをアサートする。図25によると、仮想キュー(Q0)の最大順序値はタスク(E3)の「3」であるため、ODR_A2=3となる。
同図において下線を付与している部分が、図26に示した状態レジスタ250の設定内容から変化した箇所である。まず、タスク(E6)の仮想キュー(Q0)への逆投入により、キュー識別レジスタ416_E6には新たに「Q0」が設定される。タスク(E6)のODRは「4」、PRは「1」である。タスク(E6)の逆投入により、他のタスクの状態データは影響を受けない。
メイン回路400は、まず、逆投入先となる仮想キューのQID=Qnを最大値選択回路406に入力する(S20)。メイン回路400は、仮想キュー(Qn)の最大順序値をキュー制御回路404に出力する(S22)。メイン回路400は、逆投入させるタスク(以下、「逆投入タスク」とよぶ)についての投入条件を設定する(S24)。具体的には、CMD=ENQ_TP(逆投入コマンド)として、EID_C、QID_C、PR_Cを設定する。キュー制御回路404のうち、逆投入タスクに対応するレジスタ値生成回路420は、逆投入タスクのタスク優先順位レジスタ412、キュー順序レジスタ414、キュー識別レジスタ416にそれぞれ、PR_C、最大順序値+1、QID_Cを設定する(S26)。ただし、最大順序値=0であってODR_A2_ENがネゲートされているとき、すなわち、仮想キュー(Qn)にタスクが未投入であるときには、キュー順序レジスタ414には初投入を示す順序値「0」を設定する。
[抽出]
タスク選択回路230の基本構成は、基本例として図12に関連して説明した通りである。改良例におけるタスク選択回路230は、メイン回路400からの問い合わせを受けたときに、抽出タスクを特定する。ここでは、この抽出タスクを特定するための仕組みに関わる回路構成について説明する。タスク選択回路230は、CND信号としてQID_C=Qnを入力されたとき、仮想キュー(Qn)において最もタスク優先順位の高い優先キューから抽出タスクを選択し、抽出タスクのタスクID、タスク優先順位、順序値をそれぞれEID_A1、PR_A1、ODR_A1に出力し、EID_A1_ENをアサートする。タスク選択回路230は、基本例に示した実行選択回路232やセマフォ選択回路234と同じく、複数段の比較回路から構成される。タスク選択回路230は、4つの第1比較回路430(430a、430b等)、2つの第2比較回路432(432等)、1つの第3比較回路(図示せず)を含む。また、8つの判定回路434(434a、434b、434c、434d等)を含む。
第1の判定:判定回路434aは、タスク0が仮想キュー(Qn)に投入済みであればEID_11A_ENをアサートする。判定回路434bは、タスク1が仮想キュー(Qn)に投入済みであればEID_11B_ENをアサートする。第1比較回路430aは、まず、判定回路434aと判定回路434bのそれぞれから出力されるEID_11_EN信号を参照する。いずれか一方が「1」であれば、いずれか一方のタスクだけが仮想キュー(Qn)に投入されていることになる。このとき、第1比較回路430aは、仮想キュー(Qn)に投入されている方のタスクのタスクID(EID_S)、タスク優先順位(PR_S)および順序値(ODR_S)をそれぞれEID_21A、PR_11A、ODR_21Aとして出力し、EID_21A_ENをアサートする。
判定回路434aと判定回路434bが共に「0」を出力するときには、どちらのタスクも仮想キュー(Qn)に投入されていない。このとき、EID_21A_ENはネゲートされ、以後、タスク0とタスク1のいずれも第2比較回路432aにおいて考慮の対象とはならない。
判定回路434aと判定回路434bが共に「1」を出力するときには、どちらのタスクも仮想キュー(Qn)に投入済である、このとき、次の第2の判定が実行される。
こでは、仮想キュー(Q0)からタスクを1つ抽出するとして説明する。メイン回路400は、QID_C=Q0をタスク選択回路230に入力する。図29によると、仮想キュー(Q0)のうち最も高いタスク優先順位に対応する優先キュー(Q0:0)には、順序値「1」のタスク(E0)と順序値「3」のタスク(E3)が投入されている。タスク選択回路230は、順序値が大きい方のタスク(E3)を抽出タスクとして選択する。タスク選択回路230は、EID_A1=E3、PR_A1=0、ODR_A1=3として、EID_A1_ENをアサートする。
同図において下線を付与している部分が、図30に示した状態レジスタ250の設定内容から変化した箇所である。まず、タスク(E3)の仮想キュー(Q0)からの抽出により、キュー識別レジスタ416_E3には新たに「Non」が設定される。また、キュー順序レジスタ414とタスク優先順位レジスタ412にはそれぞれリセット値として「0」が設定される。タスク(E3)の抽出により、仮想キュー(Q0)に元々投入されていたタスク(E0)、タスク(E2)、タスク(E5)、タスク(E6)のうち、抽出タスク(E3)よりも順序値が大きかったタスク(E6)のODRはデクリメントされる。
メイン回路400は、まず、抽出先となる仮想キューのQID=Qnをタスク選択回路230に入力する(S30)。タスク選択回路230は、仮想キュー(Qn)から抽出タスクを選択する(S32)。メイン回路400は、抽出タスクのタスクID=Enをキュー制御回路404に入力すると、キュー制御回路404は、抽出タスク(En)の状態データからQID=Qnをクリアする(S34)。このとき、PRやODRを「0」にリセットするが、必ずしもリセットはしなくてもよい。
実装上、仮想キューの途中からでもタスクを取り出すことができる。たとえば、図33において、仮想キュー(Q0)の真ん中からタスク(E2)を取り出す必要が発生したとする。タスク(E2)は、あるフラグAがオンに設定されていることを条件として動作可能なタスクであるとする。このフラグAがオフにされたとき、タスク(E2)を仮想キュー(Q0)の途中から取り出す必要が発生する。あるいは、タスク(E2)についてあらかじめ設定されていた待ち時間がタイムアウトしたときにも、タスク(E2)を仮想キュー(Q0)の途中から取り出す必要が発生する。この場合には、タスク(E2)のQIDをクリアし、タスク(E2)の順序値「2」よりも順序値が大きいタスクのODRをデクリメントすることにより、タスク(E2)を仮想キュー(Q0)の途中からでも取り出すことができる。図33の場合、タスク(E6)のODRが「2」となる。仮想キューがハードウェアによって物理的な制約を受けないかたちで形成されるため、キューの途中からでも投入・抽出処理が可能となる。
ここでは、READY状態に対応する仮想キュー(Q0)とWAITセマフォ状態に対応する仮想キュー(Q1)の2つの仮想キューを想定している。仮想キュー(Q0)は、タスク優先順位PR=0のタスクを投入するための優先キュー(以下、「優先キュー(Q0:0)」と表記する)とタスク優先順位PR=1のタスクを投入するための優先キュー(Q0:1)の2つの優先キューの集合体である。仮想キュー(Q1)についても同様であり、実質的には4つの優先キューが想定される。
タスク(E3)がウェイトセマフォシステムコールを実行すると、タスク(E3)は優先キュー(Q1:0)に順投入される(S4)。次に、タスク選択回路230は新たなRUN−タスクを選択する。タスク選択回路230は、READY状態にあるタスクのうち、タスク優先順位が最も高いタスクを選択するが、ここではタスク(E0)、タスク(E2)、タスク(E1)のタスク優先順位は同じである。この場合、優先キュー(Q0:1)からタスク(E1)が抽出される(S5)。タスク(E1)は、新たなRUN−タスクとなる。このような処理方法によれば、タスク優先順位PR=0を設定するほどではないが、いったん実行されたらなるべく連続的に実行させたいというタスク(E1)の仕様に対応できる。
Claims (10)
- キューIDにより識別される複数種類の仮想キューに対して、要素IDにより識別される複数個の要素の投入と抽出を制御するキュー制御回路と、
各要素に対応して設けられるレジスタであって、投入先となる仮想キューのキューIDと投入順位を示す順序値とを対応づけて保持する複数のキューレジスタと、を備え、
前記キュー制御回路は、
要素IDおよびキューIDを指定する順投入コマンドが入力されるとき、前記指定された要素IDの該当キューレジスタに対して、前記指定されたキューIDに対応する仮想キューの末尾への投入であることを示す末尾順序値と前記指定されたキューIDを設定し、
要素IDおよびキューIDを指定する逆投入コマンドが入力されるとき、前記指定された要素IDの該当キューレジスタに対して、前記指定されたキューIDに対応する仮想キューの先頭への投入であることを示す先頭順序値と前記指定されたキューIDを設定し、
キューIDを指定する抽出コマンドが入力されるとき、前記指定されたキューIDおよび先頭順序値を保持するキューレジスタからキューIDをクリアして該当要素を抽出対象とすることにより、各キューレジスタの設定情報に基づいて前記複数種類の仮想キューを管理することを特徴とする仮想キュー処理回路。 - 前記キュー制御回路は、前記順投入コマンドまたは前記逆投入コマンドのいずれかが入力されるときには、コマンドにより指定されたキューIDを保持する他のキューレジスタの順序値を調整することを特徴とする請求項1に記載の仮想キュー処理回路。
- キューIDが指定されるとき、前記複数のキューレジスタからパラレルに出力されるキューIDと順序値を参照して、前記指定されたキューIDおよび先頭順序値に対応する要素IDを出力する抽出候補回路、を更に備え、
前記キュー制御回路は、前記抽出候補回路から出力された要素IDの該当キューレジスタからキューIDをクリアすることを特徴とする請求項1に記載の仮想キュー処理回路。 - 仮想キューは、更に、抽出の優先度に応じて複数の優先キューの集合として定義され、
前記キューレジスタは、優先キューを特定するための優先度も保持し、
前記キュー制御回路は、
要素IDおよびキューIDに加えて優先度を指定する順投入コマンドが入力されるとき、前記指定された要素IDの該当キューレジスタに対して、前記指定された優先度も設定し、
要素IDおよびキューIDに加えて優先度を指定する逆投入コマンドが入力されるとき、前記指定された要素IDの該当キューレジスタに対して、前記指定された優先度も設定し、
キューIDを指定する抽出コマンドが入力されるとき、前記指定されたキューIDを保持し、そのうち最も高い優先度が設定され、かつ、そのうち最も先頭に近い順序値を設定されているキューレジスタからキューIDをクリアすることを特徴とする請求項1に記載の仮想キュー処理回路。 - 前記キュー制御回路は、キューIDを指定する前記抽出コマンドが入力されるときには、前記指定されたキューIDを保持する他のキューレジスタの順序値を調整することを特徴とする請求項4に記載の仮想キュー処理回路。
- キューIDが指定されるとき、前記複数のキューレジスタからパラレルに出力されるキューID、順序値および優先度に基づいて、前記指定されたキューIDを保持し、そのうち最も高い優先度が設定され、かつ、そのうち最も先頭に近い順序値を保持するキューレジスタに対応する要素IDを出力する抽出候補回路、を更に備え、
前記キュー制御回路は、前記抽出候補回路から出力された要素IDの該当キューレジスタからキューIDをクリアすることを特徴とする請求項5に記載の仮想キュー処理回路。 - タスク実行のためのデータを一時的に保持する処理レジスタと、
命令(instruction)およびオペランドをメモリから前記処理レジスタにロードし、前記処理レジスタの命令とオペランドにしたがってタスクを実行する実行制御回路と、
タスクスケジューリングのための状態データを保持するレジスタであって、複数のタスクに対してそれぞれ対応づけられる複数の状態レジスタと、
タスクの実行状態に対応づけられる複数種類の仮想キューに対して、タスクIDにより識別される複数個のタスクの投入と抽出を制御することにより、タスクの実行状態を管理するタスク切換回路と、
複数の前記状態レジスタからパラレルに出力される状態データを入力として、所定の選択条件によりタスクを選択するタスク選択回路と、を備え、
前記状態レジスタは、状態データの一部として、該当タスクの実行状態に対応づけられる仮想キューのキューIDと仮想キューへの投入順位を示す順序値とを対応づけて保持し、
前記実行制御回路は、実行中の第1のタスクが所定のシステムコール命令を実行するとき、所定のシステムコール信号を前記タスク切換回路に送信し、
前記タスク選択回路は、READY(レディ)状態に対応する仮想キューであるレディキューのキューIDおよび前記レディキューの先頭位置を示す先頭順序値を保持する状態レジスタを特定し、前記特定した状態レジスタに対応する第2のタスクを次の実行対象として選択し、
前記タスク切換回路は、前記システムコール信号を受信するとき、前記第2のタスクの状態レジスタからキューIDをクリアし、前記第1のタスクの状態レジスタに対して、RUN(ラン)状態とは異なる別の実行状態に対応づけられる仮想キューのキューIDと順序値を設定し、前記処理レジスタのデータを所定の記憶領域に退避させると共に、前記第2のタスクについて前記記憶領域に退避されていたデータを前記処理レジスタにロードすることを特徴とするタスク制御装置。 - 前記タスク切換回路は、前記第1のタスクを前記別の実行状態としてREADY状態に移行させるときには、前記第1のタスクの状態レジスタに対して前記レディキューのキューIDと先頭順序値を設定することを特徴とする請求項7に記載のタスク制御装置。
- 前記タスク選択回路は、WAIT(ウェイト)解除条件の成立待機状態であるWAIT状態に対応づけられる仮想キューとしてウェイトキューが設定される場合において、前記WAIT解除条件が成立するとき、前記ウェイトキューのキューIDと先頭順序値を保持する状態レジスタに該当するタスクを選択し、
前記タスク切換回路は、前記選択されたタスクの状態レジスタに対して、レディキューのキューIDと前記レディキューの末尾への投入を示す末尾順序値を設定することを特徴とする請求項7に記載のタスク制御装置。 - 前記状態レジスタは、状態データの一部としてタスク優先度を保持し、
前記タスク選択回路は、タスク切り換えに際してレディキューのキューIDを設定されているタスクが複数あるときには、それらのうち最も高いタスク優先度を設定され、かつ、それらのうち最も先頭に近い順序値を設定されているタスクを実行対象として選択することを特徴とする請求項7に記載のタスク処理装置。
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/JP2007/000874 WO2009022369A1 (ja) | 2007-08-10 | 2007-08-10 | 仮想キュー処理回路およびタスク処理装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP4088335B1 true JP4088335B1 (ja) | 2008-05-21 |
JPWO2009022369A1 JPWO2009022369A1 (ja) | 2010-11-04 |
Family
ID=39509544
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2007543638A Active JP4088335B1 (ja) | 2007-08-10 | 2007-08-10 | 仮想キュー処理回路およびタスク処理装置 |
Country Status (5)
Country | Link |
---|---|
US (2) | US8996761B2 (ja) |
JP (1) | JP4088335B1 (ja) |
CN (1) | CN101796487B (ja) |
TW (3) | TWI520056B (ja) |
WO (1) | WO2009022369A1 (ja) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2013175610A1 (ja) | 2012-05-24 | 2013-11-28 | カーネロンシリコン株式会社 | タスク処理装置 |
CN111526172A (zh) * | 2019-02-03 | 2020-08-11 | 上海登临科技有限公司 | 一种多设备管理方法和管理系统 |
Families Citing this family (22)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4088335B1 (ja) | 2007-08-10 | 2008-05-21 | ネットクリアスシステムズ株式会社 | 仮想キュー処理回路およびタスク処理装置 |
US8689231B2 (en) * | 2009-06-30 | 2014-04-01 | Sap Ag | System and method for ordering tasks with complex interrelationships |
KR101859226B1 (ko) * | 2009-12-28 | 2018-05-18 | 삼성전자주식회사 | 무선 통신 시스템에서 신호 송신 방법 및 장치 |
US20110185365A1 (en) * | 2010-01-28 | 2011-07-28 | International Business Machines Corporation | Data processing system, method for processing data and computer program product |
US8677361B2 (en) * | 2010-09-30 | 2014-03-18 | International Business Machines Corporation | Scheduling threads based on an actual power consumption and a predicted new power consumption |
JP2012173870A (ja) | 2011-02-18 | 2012-09-10 | Toshiba Corp | 半導体装置及びメモリ保護方法 |
US8930584B2 (en) * | 2012-08-09 | 2015-01-06 | Oracle International Corporation | System and method for providing a linearizable request manager |
US9342369B2 (en) * | 2013-01-07 | 2016-05-17 | Wal-Mart Stores, Inc. | System and method for increasing throughput of a PaaS system |
US9104455B2 (en) | 2013-02-19 | 2015-08-11 | International Business Machines Corporation | Virtual machine-to-image affinity on a physical server |
GB2552084B (en) * | 2014-01-29 | 2018-08-01 | Illinois Tool Works | A locker system |
WO2016018399A1 (en) * | 2014-07-31 | 2016-02-04 | Hewlett-Packard Development Company, L.P. | Prioritization processing |
WO2016075721A1 (ja) * | 2014-11-11 | 2016-05-19 | ルネサスエレクトロニクス株式会社 | 命令実行制御システム及び命令実行制御方法 |
US9405702B2 (en) * | 2014-11-14 | 2016-08-02 | Cavium, Inc. | Caching TLB translations using a unified page table walker cache |
US9720773B2 (en) * | 2015-03-04 | 2017-08-01 | Cavium, Inc. | Managing reuse information in caches |
US9898321B2 (en) * | 2015-07-23 | 2018-02-20 | At&T Intellectual Property I, L.P. | Data-driven feedback control system for real-time application support in virtualized networks |
US10298511B2 (en) * | 2016-08-24 | 2019-05-21 | Apple Inc. | Communication queue management system |
CN107870779B (zh) * | 2016-09-28 | 2023-12-12 | 北京忆芯科技有限公司 | 调度方法与装置 |
CN107870866B (zh) * | 2016-09-28 | 2023-09-26 | 厦门鑫忆讯科技有限公司 | Io命令调度方法与nvm接口控制器 |
US10303575B2 (en) | 2017-01-10 | 2019-05-28 | International Business Machines Corporation | Time-slice-instrumentation facility |
US10951539B2 (en) * | 2018-03-29 | 2021-03-16 | Mitsubishi Electric Corporation | Data processing device |
CN113515516A (zh) * | 2021-08-09 | 2021-10-19 | 北京字节跳动网络技术有限公司 | 一种数据处理方法、装置、计算机设备和计算机存储介质 |
CN117118924B (zh) * | 2023-10-24 | 2024-02-09 | 苏州元脑智能科技有限公司 | 网络提交队列监测装置、方法、计算机设备及存储介质 |
Family Cites Families (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4497023A (en) * | 1982-11-04 | 1985-01-29 | Lucasfilm Ltd. | Linked list of timed and untimed commands |
US5410722A (en) * | 1993-01-21 | 1995-04-25 | Conner Peripherals, Inc. | Queue system for dynamically allocating and moving memory registers between a plurality of pseudo queues |
US6154826A (en) * | 1994-11-16 | 2000-11-28 | University Of Virginia Patent Foundation | Method and device for maximizing memory system bandwidth by accessing data in a dynamically determined order |
JPH11234302A (ja) | 1998-02-18 | 1999-08-27 | Net Kuriasu Systems Kk | 待ち行列装置 |
US6128672A (en) * | 1998-03-10 | 2000-10-03 | Motorola, Inc. | Data transfer using software interrupt service routine between host processor and external device with queue of host processor and hardware queue pointers on external device |
JPH11272480A (ja) | 1998-03-24 | 1999-10-08 | Nippon Telegr & Teleph Corp <Ntt> | オンチップリアルタイムos |
JP3076303B2 (ja) | 1998-06-17 | 2000-08-14 | 茨城日本電気株式会社 | 情報処理装置 |
JP2000276362A (ja) | 1999-03-29 | 2000-10-06 | Nec Kofu Ltd | プロセス管理方式 |
JP2001075820A (ja) | 1999-09-07 | 2001-03-23 | Oki Electric Ind Co Ltd | リアルタイムos装置 |
JP3938343B2 (ja) * | 2002-08-09 | 2007-06-27 | インターナショナル・ビジネス・マシーンズ・コーポレーション | タスク管理システム、プログラム、及び制御方法 |
CN100367218C (zh) * | 2006-08-03 | 2008-02-06 | 迈普(四川)通信技术有限公司 | 多核并行先进先出队列处理系统及方法 |
JP4088335B1 (ja) | 2007-08-10 | 2008-05-21 | ネットクリアスシステムズ株式会社 | 仮想キュー処理回路およびタスク処理装置 |
-
2007
- 2007-08-10 JP JP2007543638A patent/JP4088335B1/ja active Active
- 2007-08-10 US US12/281,990 patent/US8996761B2/en active Active
- 2007-08-10 WO PCT/JP2007/000874 patent/WO2009022369A1/ja active Application Filing
- 2007-08-10 CN CN200780100231.8A patent/CN101796487B/zh active Active
-
2008
- 2008-04-01 TW TW103103900A patent/TWI520056B/zh active
- 2008-04-01 TW TW103114180A patent/TWI522907B/zh active
- 2008-04-01 TW TW097111803A patent/TWI438679B/zh active
-
2011
- 2011-12-21 US US13/334,042 patent/US9047120B2/en active Active
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2013175610A1 (ja) | 2012-05-24 | 2013-11-28 | カーネロンシリコン株式会社 | タスク処理装置 |
US9753779B2 (en) | 2012-05-24 | 2017-09-05 | Renesas Electronics Corporation | Task processing device implementing task switching using multiple state registers storing processor id and task state |
CN111526172A (zh) * | 2019-02-03 | 2020-08-11 | 上海登临科技有限公司 | 一种多设备管理方法和管理系统 |
Also Published As
Publication number | Publication date |
---|---|
TWI438679B (zh) | 2014-05-21 |
CN101796487B (zh) | 2013-10-09 |
US8996761B2 (en) | 2015-03-31 |
TW200907794A (en) | 2009-02-16 |
US9047120B2 (en) | 2015-06-02 |
TWI522907B (zh) | 2016-02-21 |
TWI520056B (zh) | 2016-02-01 |
CN101796487A (zh) | 2010-08-04 |
US20110252428A1 (en) | 2011-10-13 |
US20120096472A1 (en) | 2012-04-19 |
WO2009022369A1 (ja) | 2009-02-19 |
JPWO2009022369A1 (ja) | 2010-11-04 |
TW201432562A (zh) | 2014-08-16 |
TW201421357A (zh) | 2014-06-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP4088335B1 (ja) | 仮想キュー処理回路およびタスク処理装置 | |
JP4119945B2 (ja) | タスク処理装置 | |
JP6153925B2 (ja) | タスク処理装置 | |
US10949249B2 (en) | Task processor | |
JP4127848B2 (ja) | タスク処理装置 | |
JP5155336B2 (ja) | タスク処理装置 | |
JP2018180768A (ja) | 半導体装置 | |
JP2017123190A (ja) | タスク処理装置 | |
JP5204740B2 (ja) | タスク処理装置 | |
JP2008269597A (ja) | タスク処理装置 | |
JP2019003710A (ja) | タスク処理装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20080219 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20080222 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 4088335 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
RD02 | Notification of acceptance of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: R3D02 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
S111 | Request for change of ownership or part of ownership |
Free format text: JAPANESE INTERMEDIATE CODE: R313113 |
|
S531 | Written request for registration of change of domicile |
Free format text: JAPANESE INTERMEDIATE CODE: R313531 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
R350 | Written notification of registration of transfer |
Free format text: JAPANESE INTERMEDIATE CODE: R350 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
R360 | Written notification for declining of transfer of rights |
Free format text: JAPANESE INTERMEDIATE CODE: R360 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
R370 | Written measure of declining of transfer procedure |
Free format text: JAPANESE INTERMEDIATE CODE: R370 |
|
S111 | Request for change of ownership or part of ownership |
Free format text: JAPANESE INTERMEDIATE CODE: R313113 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
R360 | Written notification for declining of transfer of rights |
Free format text: JAPANESE INTERMEDIATE CODE: R360 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
R370 | Written measure of declining of transfer procedure |
Free format text: JAPANESE INTERMEDIATE CODE: R370 |
|
S111 | Request for change of ownership or part of ownership |
Free format text: JAPANESE INTERMEDIATE CODE: R313113 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
R350 | Written notification of registration of transfer |
Free format text: JAPANESE INTERMEDIATE CODE: R350 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110228 Year of fee payment: 3 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120229 Year of fee payment: 4 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20130228 Year of fee payment: 5 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20140228 Year of fee payment: 6 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
S111 | Request for change of ownership or part of ownership |
Free format text: JAPANESE INTERMEDIATE CODE: R313113 |
|
S531 | Written request for registration of change of domicile |
Free format text: JAPANESE INTERMEDIATE CODE: R313531 |
|
R350 | Written notification of registration of transfer |
Free format text: JAPANESE INTERMEDIATE CODE: R350 |
|
S531 | Written request for registration of change of domicile |
Free format text: JAPANESE INTERMEDIATE CODE: R313531 |
|
R350 | Written notification of registration of transfer |
Free format text: JAPANESE INTERMEDIATE CODE: R350 |
|
RD02 | Notification of acceptance of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: R3D02 |