JP5367020B2 - 情報処理装置、情報処理方法、プログラム及び情報記憶媒体 - Google Patents

情報処理装置、情報処理方法、プログラム及び情報記憶媒体 Download PDF

Info

Publication number
JP5367020B2
JP5367020B2 JP2011141186A JP2011141186A JP5367020B2 JP 5367020 B2 JP5367020 B2 JP 5367020B2 JP 2011141186 A JP2011141186 A JP 2011141186A JP 2011141186 A JP2011141186 A JP 2011141186A JP 5367020 B2 JP5367020 B2 JP 5367020B2
Authority
JP
Japan
Prior art keywords
processor
command
execution
executed
information processing
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
Application number
JP2011141186A
Other languages
English (en)
Other versions
JP2013008243A (ja
Inventor
努 寺西
友博 大戸
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.)
Sony Interactive Entertainment Inc
Original Assignee
Sony Interactive Entertainment Inc
Sony Computer Entertainment Inc
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 Sony Interactive Entertainment Inc, Sony Computer Entertainment Inc filed Critical Sony Interactive Entertainment Inc
Priority to JP2011141186A priority Critical patent/JP5367020B2/ja
Priority to US13/525,489 priority patent/US9934038B2/en
Publication of JP2013008243A publication Critical patent/JP2013008243A/ja
Application granted granted Critical
Publication of JP5367020B2 publication Critical patent/JP5367020B2/ja
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30181Instruction operation extension or modification
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/30076Arrangements for executing specific machine instructions to perform miscellaneous control operations, e.g. NOP
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/3017Runtime instruction translation, e.g. macros
    • G06F9/30174Runtime instruction translation, e.g. macros for non-native instruction set, e.g. Javabyte, legacy code
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45504Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Executing Machine-Instructions (AREA)
  • User Interface Of Digital Computer (AREA)
  • Debugging And Monitoring (AREA)

Description

本発明は、情報処理装置、情報処理方法、プログラム及び情報記憶媒体に関する。
処理の実行主体となる装置(以下、処理実行主体装置と呼ぶ。)のプロセッサとは異なる種類のプロセッサ(以下、他種プロセッサと呼ぶ。)で実行可能なコマンドが示す処理を、処理実行主体装置のプロセッサで実行できるようにするエミュレーション技術が知られている。
プロセッサの機能が拡張されて、他種プロセッサではできなかった処理内容の制御が、処理実行主体装置のプロセッサではできるようになることがある。また、他種プロセッサでは実行されてもよい処理が、処理実行主体装置のプロセッサでは実行されるべきではないということもある。しかし、従来のエミュレーション技術では、他種プロセッサで実行可能なコマンドの設定を行うにあたって、他種プロセッサでの処理の実行に影響を与えることなく、処理実行主体装置のプロセッサでの処理の実行を制御するような設定を行うことができなかった。
本発明は上記課題に鑑みてなされたものであって、その目的の1つは、他種プロセッサで実行可能なコマンドの設定を行うにあたって、他種プロセッサでの処理の実行に影響を与えることなく、処理実行主体装置のプロセッサでの処理の実行を制御するような設定を行えるようにすることにある。
上記課題を解決するために、本発明に係る情報処理装置は、処理の実行主体となる処理実行主体装置のプロセッサとは異なる種類のプロセッサである他種プロセッサで実行可能なコマンドを取得する取得手段と、前記取得手段により取得されるコマンドに対応付けられる、前記処理実行主体装置のプロセッサで実行可能な処理を特定する特定手段と、設定されているパラメータの値が前記他種プロセッサでの処理の実行に影響を与えない前記他種プロセッサにおける特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサによる処理の実行を制御する実行制御手段と、を含むことを特徴とする。
また、本発明に係る情報処理方法は、処理の実行主体となる処理実行主体装置のプロセッサとは異なる種類のプロセッサである他種プロセッサで実行可能なコマンドを取得する取得ステップと、前記取得ステップで取得されるコマンドに対応付けられる、前記処理実行主体装置のプロセッサで実行可能な処理を特定する特定ステップと、設定されているパラメータの値が前記他種プロセッサでの処理の実行に影響を与えない前記他種プロセッサにおける特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサによる処理の実行を制御する実行制御ステップと、を含むことを特徴とする。
また、本発明に係るプログラムは、処理の実行主体となる処理実行主体装置のプロセッサとは異なる種類のプロセッサである他種プロセッサで実行可能なコマンドを取得する取得手段、前記取得手段により取得されるコマンドに対応付けられる、前記処理実行主体装置のプロセッサで実行可能な処理を特定する特定手段、設定されているパラメータの値が前記他種プロセッサでの処理の実行に影響を与えない前記他種プロセッサにおける特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサによる処理の実行を制御する実行制御手段、としてコンピュータを機能させることを特徴とする。
また、本発明に係る情報記憶媒体は、処理の実行主体となる処理実行主体装置のプロセッサとは異なる種類のプロセッサである他種プロセッサで実行可能なコマンドを取得する取得手段、前記取得手段により取得されるコマンドに対応付けられる、前記処理実行主体装置のプロセッサで実行可能な処理を特定する特定手段、設定されているパラメータの値が前記他種プロセッサでの処理の実行に影響を与えない前記他種プロセッサにおける特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサによる処理の実行を制御する実行制御手段、としてコンピュータを機能させることを特徴とするプログラムを記憶したコンピュータ読み取り可能な情報記憶媒体である。
本発明によれば、設定されているパラメータの値が他種プロセッサでの処理の実行に影響を与えない他種プロセッサにおける特定のコマンドに設定されているパラメータの値に応じて処理実行主体装置のプロセッサによる処理の実行が制御されるので、他種プロセッサで実行可能なコマンドの設定を行うにあたって、他種プロセッサでの処理の実行に影響を与えることなく、処理実行主体装置のプロセッサでの処理の実行を制御するような設定を行えることとなる。
本発明の一態様では、前記実行制御手段は、前記特定のコマンドに設定されているパラメータの値が、前記処理実行主体装置のプロセッサによる他のコマンドが示す処理の実行でのパラメータの値として用いられるよう制御することを特徴とする。
また、本発明の一態様では、前記実行制御手段は、前記特定のコマンドに設定されているパラメータの値に対応付けられる処理を前記処理実行主体装置のプロセッサに実行させることを特徴とする。
また、本発明の一態様では、前記実行制御手段は、命令列として連続している複数の前記特定のコマンドのそれぞれに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサでの処理の実行を制御することを特徴とする。
また、本発明の一態様では、前記取得手段は、コマンドを含む情報を順次取得し、前記実行制御手段は、前記取得手段が所定の情報を取得した後に取得する、前記特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサでの処理の実行を制御することを特徴とする。
また、本発明の一態様では、前記実行制御手段は、設定されているパラメータの値が所定の開始値である前記特定のコマンドの直後のコマンドが示す処理から設定されているパラメータの値が所定の終了値である前記特定のコマンドの直前のコマンドが示す処理までを前記処理実行主体装置のプロセッサに実行させないよう制御することを特徴とする。
また、本発明の一態様では、前記実行制御手段は、前記他種プロセッサにおけるノーオペレーションコマンド、又は、前記他種プロセッサで実行されるプログラムのデバッグ用のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサでの処理の実行を制御することを特徴とする。
本発明の一実施形態に係る情報処理装置の構成図である。 本発明の一実施形態に係る情報処理装置で実現される機能の一例を示す機能ブロック図である。 一連のグラフィックスコマンドの一例を模式的に示す図である。 一連のグラフィックスコマンドの別の一例を模式的に示す図である。
以下、本発明の一実施形態について図面に基づき詳細に説明する。
図1は、本発明の一実施形態に係る情報処理装置10の構成図である。本実施形態に係る情報処理装置10は、例えば、ゲームコンソール等である。図1に示すように、本実施形態に係る情報処理装置10の制御部は、メインプロセッサ12及び複数のサブプロセッサ14(14−1、14−2、・・・、14−n)を含んでいる。メインプロセッサ12及びサブプロセッサ14はいずれもバス16に接続されており、バス16を介して相互にデータを送受信できるようになっている。バス16には、さらに、メインメモリ18、画像処理部20が接続され、入出力処理部22を介して、ネットワークボード24、ハードディスクドライブ26、DVD−ROMやBlu−ray(登録商標)ディスクなどの光ディスクを読み取る光ディスクドライブ28、コントローラ30、などが接続されている。なお、入出力処理部22には、これら以外のユニット(例えば、USB(Universal Serial Bus)ポートや、カメラユニットや、スピーカや、マイク等)が接続されていてももちろん構わない。
メインプロセッサ12は、システム等のプログラムを実行したり、光ディスクから読み出されるプログラム及びデータや、通信ネットワークを介して供給されるプログラム及びデータに基づいて、各種情報処理を行ったり、サブプロセッサ14に対する制御を行ったりする。サブプロセッサ14は、メインプロセッサ12からの指示に従って、各種情報処理を行ったり、情報処理装置10の各部を、光ディスクから読み出されるプログラム及びデータや、通信ネットワークを介して供給されるプログラム及びデータ等に基づいて制御したりする。また、本実施形態では、サブプロセッサ14にはDMAC(Direct Memory Access Controller)が内蔵されており、メインプロセッサ12を介さずに、メインメモリ18に対して直接アクセスできるようになっている。
メインメモリ18には、光ディスクドライブ28やハードディスクドライブ26から読み出されたプログラム及びデータや、通信ネットワークを介して供給されたプログラム及びデータが必要に応じて書き込まれる。メインメモリ18は、メインプロセッサ12やサブプロセッサ14のワークメモリとしても用いられる。また、本実施形態では、メインメモリ18には、本実施形態に係る情報処理装置10にインストールされるエミュレータプログラムも記憶されることとなる。
画像処理部20は、GPU(Graphical Processing Unit)とフレームバッファとを含んで構成される。GPUは、メインプロセッサ12やサブプロセッサ14から供給されるグラフィックスコマンドやデータに基づいてフレームバッファに画像を描画する。フレームバッファに描画された画像は、所定のタイミングでビデオ信号に変換されてモニタ32に出力される。なお、モニタ32には例えば家庭用テレビ受像機や、液晶ディスプレイが用いられる。
本実施形態に係るモニタ32は、左目用の画像と右目用の画像とが交互に表されるフレームシーケンシャル方式によって三次元画像表示(3D表示)を行うことができるようになっている。そして、本実施形態に係る情報処理装置10では、予め、画像をモニタ32に2D表示で出力するのか、3D表示で出力するのかが設定されている。そして、3D表示が設定されている際には、GPUは、入力されるグラフィックスコマンドのそれぞれについて、左目用の画像と右目用の画像の両方を、それぞれに対応付けられるフレームバッファ内の領域にレンダリングする。
入出力処理部22には、ネットワークボード24、ハードディスクドライブ26、光ディスクドライブ28、コントローラ30、等が接続される。入出力処理部22は、メインプロセッサ12及びサブプロセッサ14と、ネットワークボード24、ハードディスクドライブ26、光ディスクドライブ28、コントローラ30、等との間のデータ授受を制御する。
ネットワークボード24は入出力処理部22とネットワークとに接続されており、情報処理装置10が、ネットワークを介して外部とデータ通信するのを中継するようになっている。光ディスクドライブ28は、メインプロセッサ12及びサブプロセッサ14からの指示に従って、DVD−ROMやBlu−ray(登録商標)ディスクなどの光ディスクに記憶されたプログラムやデータを読み取る。また、ハードディスクドライブ26は一般的なハードディスク装置であり、ハードディスクに記憶されたプログラムやデータを読み取る。光ディスクやハードディスクには各種プログラムやデータがコンピュータ読み取り可能に記憶される。なお、情報処理装置10は、光ディスクやハードディスク以外の、他のコンピュータ読み取り可能な情報記憶媒体に記憶されたプログラムやデータを読み取り可能に構成してもよい。コントローラ30は、汎用操作入力手段であり、ユーザが各種操作を入力するために用いられる。入出力処理部22は、所定時間(例えば1/60秒)ごとにコントローラ30の各部の状態をスキャンし、その結果を表す操作状態をメインプロセッサ12やサブプロセッサ14に供給する。メインプロセッサ12やサブプロセッサ14は、ユーザによって行われた操作の内容をその操作状態に基づいて判断する。
本実施形態に係る情報処理装置10では、当該情報処理装置10とは異なる種類のプロセッサを備える装置(以下、他種装置と呼ぶ。)で実行可能なプログラムを実行するための仮想マシンとして機能するプロセスであるエミュレータが実行される。このエミュレータは、本実施形態に係る情報処理装置10にインストールされているエミュレータプログラムを起動することにより生成される。
本実施形態に係るエミュレータでは、他種装置が備える2種類のプロセッサ(CPU(Central Processing Unit)及びGPU(Graphic Processing Unit))がエミュレートされる。以下、他種装置が備えるCPUを他種CPUと呼び、他種装置が備えるGPUを他種GPUと呼ぶこととする。本実施形態に係る情報処理装置10が備えるメインプロセッサ12やサブプロセッサ14と他種CPUとは、命令セットが異なる。また、本実施形態に係る情報処理装置10が備える画像処理部20に含まれるGPUと他種GPUとも命令セットが異なる。
本実施形態では、他種CPUのエミュレートに関する処理はメインプロセッサ12によって実行される。また、本実施形態では、エミュレートされた他種CPUが出力するグラフィックスコマンド(他種GPUが実行可能なグラフィックスコマンド)が、メインメモリ18に書き込まれる。そして、サブプロセッサ14が、メインメモリ18に書き込まれたグラフィックスコマンドを、情報処理装置10の画像処理部20に含まれるGPUが実行可能なグラフィックスコマンドに変換する。そして、画像処理部20が、変換されたグラフィックスコマンドの実行を行う。
図2は、本実施形態に係る情報処理装置10で実現される機能のうち、他種GPUが実行可能なグラフィックスコマンドに応じた処理を画像処理部20に実行させることに関連する機能の一例を示す機能ブロック図である。なお、本実施形態に係る情報処理装置10では、図2に示す機能以外の機能も実現されている。図2に示すように、情報処理装置10は、当該機能に関しては、機能的に、取得部40、特定部42、実行制御部44、を含んでいる。これらの機能はサブプロセッサ14を主として実現される。
これらの機能は、情報処理システムである情報処理装置10で、本実施形態に係るプログラムが実行されることにより実現される。このプログラムは、コンピュータ通信ネットワーク経由で通信インタフェースを介して他のコンピュータからダウンロードされてもよいし、光ディスク(例えば、CD−ROMやDVD−ROMなど)、USBメモリ等のコンピュータ読み取り可能な情報記憶媒体に格納され、そこから光ディスクドライブやUSB(Universal Serial Bus)ポートなどを介して情報処理装置10にインストールされてもよい。
取得部40は、エミュレータによってエミュレートされた他種CPUが出力するグラフィックスコマンドを取得する。特定部42は、取得部40が取得するグラフィックスコマンドに対応付けられる処理であって、本実施形態に係る情報処理装置10が備える画像処理部20に含まれるGPUが実行可能な処理を特定する。
特定部42は、例えば、他種GPUが実行可能なグラフィックスコマンドと、画像処理部20に含まれるGPUが実行可能なグラフィックスコマンドと、が対応付けられた変換テーブルを参照して、他種GPUが実行可能なグラフィックスコマンドを、画像処理部20に含まれるGPUが実行可能なグラフィックスコマンドに変換する。このとき、他種GPUが実行可能なグラフィックスコマンドに、パラメータの値(例えば、少なくとも1つのオペランド)が設定されている場合は、そのパラメータの値を、画像処理部20に含まれるGPUが実行可能なグラフィックスコマンドが用いるパラメータの値に変換するようにしてもよい。特定部42は、例えば、テクスチャのフォーマット変換を行ったり、画像処理部20に含まれるGPUにより描画される画像の解像度に応じたパラメータの値の特定を行ったりしてもよい。このようにして、例えば、本実施形態に係る情報処理装置10でのGPUによるフレームバッファへの画像の描画を、他種装置での他種GPUによるフレームバッファへの画像の描画よりも高解像度で行うことが可能となる。また、本実施形態では、画像処理部20に含まれるフレームバッファにテクスチャがキャッシュされる。そして、1フレーム内で1つのテクスチャが複数回描画される際には、2回目以降の描画では、画像処理部20に含まれるフレームバッファにキャッシュされたテクスチャが再利用され、フレームバッファへのテクスチャの再度の配置は行われない。
実行制御部44は、特定部42により特定される処理の実行を本実施形態に係る情報処理装置10の画像処理部20に指示する。
また、本実施形態では、特定部42は、他種プロセッサにおける特定のコマンド(ここでは、例えば、ノーオペレーション(NOP)コマンド)については、そのコマンドに設定されているパラメータの値(例えば、オペランド)に応じた処理を特定する。例えば、NOPコマンドに設定されているパラメータの値がコマンドに対応付けられる場合には、特定部42は、そのコマンドが示す処理を特定する。また、NOPコマンドに設定されているパラメータの値が他のコマンドに用いられるパラメータの値に対応付けられる場合には、特定部42は、NOPコマンドに設定されているパラメータの値を、他のコマンドに用いられるパラメータの値として設定することを特定する。そして、本実施形態では、実行制御部44は、NOPコマンドに設定されているパラメータの値に応じて画像処理部20への指示を制御する。例えば、特定のコマンドに設定されているパラメータの値に対応付けられるコマンドが示す処理が特定部42により特定された場合には、実行制御部44は、その処理の実行を画像処理部20に指示する。また、例えば、既に画像処理部20に実行を指示した処理に用いられるパラメータの値が特定部42により特定された場合には、実行制御部44は、特定されたパラメータの値をその処理に用いるよう画像処理部20に指示する。このように、本実施形態に係るエミュレータでは、特定のコマンドに設定されているパラメータの値が、コマンドやパラメータの値などとして解釈されることとなる。
図3は、取得部40が取得する一連のグラフィックスコマンドの一例を模式的に示す図である。本実施形態では、取得部40によるグラフィックスコマンドの取得、特定部42による対応する処理の特定、実行制御部44による画像処理部20への指示の出力、という一連の処理が、各グラフィックスコマンドについて順次行われる。
そして、図3に示すように、例えば、取得部40が、メニュー画像の描画コマンドを取得した後に、NOPコマンドのパラメータの値に応じた処理の制御を開始することを表す特定の開始ビット列を取得し、その後に、パラメータの値として3D表示ではそのメニュー画像が配置される奥行きを設定する旨が設定されているNOPコマンド、パラメータの値としてメニュー画像が配置される奥行きを表す数値が設定されているNOPコマンドを取得した場合には、特定部42は、3D表示において上述の数値が表す奥行きでメニュー画像を配置する処理を特定し、実行制御部44は、その処理の実行指示を画像処理部20に出力する。なお、本実施形態では、パラメータの値として3D表示ではそのメニュー画像が配置される奥行きを設定する旨が設定されているNOPコマンドと、パラメータの値としてメニュー画像が配置される奥行きを表す数値が設定されているNOPコマンドとは、命令列として連続している。
本実施形態では、画像処理部20で実行可能なメニュー画像の描画コマンドを、実行制御部44が画像処理部20に出力する。そして、画像処理部20に含まれるGPUは、情報処理装置10において2D表示が設定されている場合には、2D表示でのメニュー画像のフレームバッファへの描画(1枚の画像の描画)を行い、情報処理装置10において3D表示が設定されている場合には、上述の数値が表す奥行きでメニュー画像が配置されるよう、左目用のメニュー画像と右目用のメニュー画像のフレームバッファへの描画を行う。
図3に例示する一連のグラフィックスコマンドのうち、NOPコマンドについては、他種GPUで実行される際には、何の処理も実行されない。また、他種GPUでは、NOPコマンドに設定されているパラメータの値は無視される。よって、NOPコマンドに設定されているパラメータの値は他種GPUでの処理の実行に影響を与えない。一方で、本実施形態に係る情報処理装置10におけるエミュレータでは、特定部42が、NOPコマンドについては、パラメータの値に応じた処理等を特定する。そして、実行制御部44が、NOPコマンドに設定されているパラメータの値に応じて画像処理部20に含まれるGPUで実行される処理の実行を制御する。実行制御部44は、例えば、NOPコマンドに設定されているパラメータの値に応じたコマンドを画像処理部20に含まれるGPUに出力したり、NOPコマンドに設定されているパラメータの値が画像処理部20に含まれるGPUによって実行される処理でのパラメータの値として用いられるよう制御したりする。また、図3の例では、本実施形態に係る情報処理装置10は、他種プロセッサでも実行されるメニュー画像の描画処理における、本実施形態に係る情報処理装置10の画像処理部20で実行可能な拡張機能(拡張処理)の設定(ここでは、奥行きの設定)を、NOPコマンドに設定されているパラメータの値に基づいて行っていることとなる。
このようにして、本実施形態によれば、例えば、3D表示の際における所与の奥行きでのメニュー画像の表示などといった、他種GPUでは実行できない処理を本実施形態に係る情報処理装置10の画像処理部20で実行させるような拡張コマンドの設定を、他種GPUでの処理の実行に影響を与えることなく行うことができることとなる。また、本実施形態では、取得部40が、特定の開始ビット列を取得した後に取得するNOPコマンドに設定されているパラメータの値に応じた処理が特定部42により特定されるので、NOPコマンドに設定されているパラメータの値を用いた処理の実行制御を行うか否かを開始ビット列により制御することができるようになっている。なお、取得部40が特定の終了ビット列を取得した際には、それ以後に取得するNOPコマンドについて、実行制御部44が設定されているパラメータの値を用いた処理の実行制御を行わないようにしてもよい。
なお、以上、他種GPUでは実行できない処理であって、2D表示の際には実行されないが、3D表示の際には実行されるような処理を本実施形態に係る情報処理装置10で行う際の拡張コマンドの設定手法について説明したが、同様にして、他種GPUでは実行できない処理であって、3D表示の際には実行されないが、2D表示の際には実行されるような処理についての拡張コマンドの設定も、本実施形態に係る情報処理装置10で行うことができる。例えば、他種GPUでは実行できないが情報処理装置10において実行可能であるポストエフェクト処理(例えば、輝度が高いと判定される画素に所定のRGB値を足すことで画像をぼかすブルームフィルタ処理や、所与の被写界深度とZバッファの値との違いが大きい画素ほど、より強いブラーをかけるようにするブラー処理、など)が、3D表示が設定されている場合には実行されずに、2D表示が設定されている場合には実行されるようにしてもよい。
例えば、取得部40が、メニュー画像の描画コマンドを取得した後に、NOPコマンドのパラメータの値に応じた処理の制御を開始することを表す特定の開始ビット列を取得し、その後に、パラメータの値として2D表示ではブルームフィルタ処理を実行する旨が設定されているNOPコマンドを取得した場合には、特定部42が、ブルームフィルタ処理を特定し、実行制御部44が、その処理の実行指示を画像処理部20に出力するようにしてもよい。そして、画像処理部20に含まれるGPUが、情報処理装置10において2D表示が設定されている場合には、ブルームフィルタ処理を実行し、情報処理装置10において3D表示が設定されている場合には、ブルームフィルタ処理を実行しないようにしてもよい。
情報処理装置10において3D表示が設定されている際に、ゲームにおいて用いられる画像の描画の後に、上述のポストエフェクト処理を実行してしまうと、ユーザが見づらい画像がモニタ32から出力されてしまうおそれがある。しかし、本実施形態に係る情報処理装置10によれば、上述のポストエフェクト処理に関するコマンドを、2D表示でのみ実行される拡張コマンドとして設定することで、情報処理装置10において3D表示が設定されている場合にはポストエフェクト処理が実行されないこととなるので、ユーザが見づらい画像がモニタ32から出力されることを防ぐことができる。
また、本実施形態に係る情報処理装置10では、他種GPUで実行される処理についてのコマンドの設定であって、2D表示の際には本実施形態に係る情報処理装置10でも実行されるが、3D表示の際には本実施形態に係る情報処理装置10では実行されない処理の範囲を指示するコマンド(以下、制限コマンドと呼ぶ。)の設定も可能である。制限コマンドの設定について、以下、説明する。
図4は、取得部40が取得する一連のグラフィックスコマンドの別の一例を模式的に示す図である。これらのグラフィックスコマンドは命令列として連続している。図4の例では、取得部40は、NOPコマンドのパラメータの値に応じた処理の制御を開始することを表す特定の開始ビット列を取得して、その後に、パラメータの値として、3D表示でのコマンドの実行の制限を開始する旨が設定されているNOPコマンド(以下、3D実行制限開始コマンドと呼ぶ。)を取得する。そして、取得部40は、その後、数個のグラフィックスコマンドを取得して、その後に、3D表示でのコマンドの実行を制限を終了する旨が設定されているNOPコマンド(以下、3D実行制限終了コマンドと呼ぶ。)を取得する。本実施形態では、3D実行制限開始コマンド及び3D実行制限終了コマンドが制限コマンドに相当する。そして、3D実行制限開始コマンドの直後のグラフィックスコマンドが示す処理から、3D実行制限終了コマンドの直前のグラフィックスコマンドが示す処理までが、制限コマンドで実行の制限が指示される範囲の処理となる。
図4に例示する一連のグラフィックスコマンドのうち、NOPコマンドについては、他種GPUで実行される際には、何の処理も実行されない。また、NOPコマンドに設定されているパラメータの値は無視される。そのため、制限コマンドで実行の制限が指示される範囲の処理については、他種GPUでは実行されることとなる。
一方で、本実施形態に係る情報処理装置10におけるエミュレータでは、情報処理装置10において2D表示が設定されている場合には、3D実行制限開始コマンドや3D実行制限終了コマンドに基づく、3D表示でのコマンドの実行を制限するか否かの制御自体は行われるが、制限コマンドで実行の制限が指示される範囲の処理については実行されることとなる。そして、情報処理装置10において3D表示が設定されている場合には、3D実行制限開始コマンドや3D実行制限終了コマンドにより、コマンドの実行を制限するか否かが制御されることとなり、制限コマンドで実行の制限が指示される範囲の処理については、特定部42による対応する処理の特定は行われるが、実行制御部44による特定された処理の画像処理部20への実行指示は行われないこととなる。以上のようにして、本実施形態に係る情報処理装置10では、制限コマンドの設定を行うことができる。
このようにして、例えば、他種プロセッサにおいて実行される処理であるが、情報処理装置10において3D表示が設定されている際に実行されるべきではない処理については、その処理についてのコマンドを3D実行制限開始コマンドと3D実行制限終了コマンドの間に設定することによって、情報処理装置10において3D表示が設定されている場合には実行されないようにすることができる。
また、本実施形態に係る情報処理装置10では、同様にして、他種GPUで実行される処理についてのコマンドの設定であって、3D表示の際には本実施形態に係る情報処理装置10でも実行されるが、2D表示の際には本実施形態に係る情報処理装置10では実行されないような処理についての制限コマンド(例えば、2D表示でのコマンドの実行の制限を開始する旨が設定されているNOPコマンド(2D実行制限開始コマンド)や2D表示でのコマンドの実行の制限を終了する旨が設定されているNOPコマンド(2D実行制限終了コマンド))の設定も可能である。そして、他種プロセッサにおいて実行される処理であるが、情報処理装置10において2D表示が設定されている際に実行されるべきではない処理については、その処理についてのコマンドを2D実行制限開始コマンドと2D実行制限終了コマンドの間に設定することによって、情報処理装置10において2D表示が設定されている場合には実行されないようにすることができる。
また、本実施形態に係る情報処理装置10では、同様にして、他種GPUで実行される処理についてのコマンドの設定であって、3D表示の際も2D表示の際も本実施形態に係る情報処理装置10では実行されないような処理についての制限コマンド(例えば、2D表示でも3D表示でもコマンドの実行の制限を開始する旨が設定されているNOPコマンド(実行制限開始コマンド)や2D表示でも3D表示でもコマンドの実行の制限を終了する旨が設定されているNOPコマンド(実行制限終了コマンド))の設定も可能である。そして、他種プロセッサにおいて実行される処理であるが、情報処理装置10において2D表示が設定されている際にも3D表示が設定されている際にも実行されるべきではない処理については、その処理についてのコマンドを実行制限開始コマンドと実行制限終了コマンドの間に設定することによって、情報処理装置10では実行されないようにすることができる。
また、ある処理(例えば、フィルタ処理)を実行するにあたって、他種GPUで実行するのに適したアルゴリズム(例えば、低精度低負荷のアルゴリズム)と、本実施形態に係る情報処理装置10で実行するのに適したアルゴリズム(例えば、高精度高負荷のアルゴリズム)と、が異なることがある。このような場合に、例えば、他種GPUで実行するのに適したアルゴリズムでの処理を示すコマンドを実行制限開始コマンドと実行制限終了コマンドの間に設定して、実行制限開始コマンドの直前のコマンド又は実行制限終了コマンドの直後のコマンドとして、本実施形態に係る情報処理装置10で実行するのに適したアルゴリズムで処理を実行する旨がパラメータの値として設定されているNOPコマンドを設定するようにしてもよい。このようにすれば、他種装置では他種GPUで実行するのに適したアルゴリズムにより処理が行われ、本実施形態に係る情報処理装置10では画像処理部20で実行するのに適したアルゴリズムにより処理が行われることとなる。
以上、他種GPUが実行可能なグラフィックスコマンドに応じた処理が画像処理部20で実行されることについて説明した。本実施形態に係る情報処理装置10では、以上の説明と同様の手法により、他種CPUが実行可能なコマンドに応じた処理がメインプロセッサ12で実行される。以下、このことについて説明する。
本実施形態に係る情報処理装置10で実現される機能のうち、他種CPUが実行可能なコマンドに応じた処理をメインプロセッサ12に実行させることに関連する機能の一例を示す機能ブロック図は、図2と同様の図となる。ただし、これらの機能は、本実施形態では、メインプロセッサ12を主として実現されることとなる。
これらの機能は、情報処理システムである情報処理装置10で、本実施形態に係るプログラムが実行されることにより実現される。このプログラムは、コンピュータ通信ネットワーク経由で通信インタフェースを介して他のコンピュータからダウンロードされてもよいし、光ディスク(例えば、CD−ROMやDVD−ROMなど)、USBメモリ等のコンピュータ読み取り可能な情報記憶媒体に格納され、そこから光ディスクドライブやUSB(Universal Serial Bus)ポートなどを介して情報処理装置10にインストールされてもよい。
取得部40は、エミュレートされたプログラムカウンタで指定されるメインメモリ18上のアドレスに配置されている、他種CPUが実行可能なコマンドを取得する。特定部42は、取得したコマンドに対応付けられる、メインプロセッサ12で実行可能な処理を特定する。そして、本実施形態では、メインプロセッサ12が、特定部42により特定された処理を実行する。本実施形態では、取得部40によるコマンドの取得、特定部42による対応する処理の特定、メインプロセッサ12による処理の実行、プログラムカウンタの値の更新、という一連の処理が、順次行われる。このことによって、他種装置で実行可能な一連のコマンドに応じた処理がメインプロセッサ12で実行されることとなる。
本実施形態では、特定部42は、特定のコマンド(ここでは、例えば、最終製品においては何の処理も実行されない、開発段階におけるデバッグ用のコマンドや、ノーオペレーション(NOP)コマンドなど。以下、特定コマンドと呼ぶ。)については、特定コマンドに設定されているパラメータの値(例えば、オペランド)に応じた処理の制御を実行制御部44に指示する。そして、実行制御部44が、この指示に応じて、メインプロセッサ12での処理の実行を制御する。例えば、取得部40が、特定コマンドを取得した際に、実行制御部44は、その特定コマンドに設定されているパラメータの値に応じたコマンドをメインプロセッサ12に実行させるようにしたり、特定コマンドに設定されているパラメータの値がメインプロセッサ12で実行される処理でのパラメータの値として用いられるよう制御したりする。
また、実行制御部44は、パラメータの値としてコマンドの実行を制限を開始する旨が設定されている特定コマンドの直後のコマンドが示す処理から、パラメータの値としてコマンドの実行の制限を終了する旨が設定されている特定コマンドの直前のコマンドが示す処理についてはメインプロセッサ12に実行させないよう制御する。
本実施形態では、特定部42は、例えば、他種CPUが実行可能なコマンドと、メインプロセッサ12が実行可能なグラフィックスコマンドと、が対応付けられた変換テーブルを参照して、他種CPUが実行可能なコマンドを、メインプロセッサ12が実行可能なコマンドに変換する。
特定コマンドについては、他種CPUで実行される際には、何の処理も実行されない。また、他種CPUでは、特定コマンドに設定されているパラメータの値は無視される。よって、特定コマンドに設定されているパラメータの値は他種CPUでの処理の実行に影響を与えない。一方で、本実施形態に係る情報処理装置10におけるエミュレータでは、特定部42が、特定コマンドについては、パラメータの値に応じた処理等を特定する。そして、実行制御部44が、特定コマンドに設定されているパラメータの値に応じてメインプロセッサ12で実行される処理の実行を制御する。
また、本実施形態では、予め、他種CPUのシステムコールと本実施形態に係る情報処理装置10のシステムコールとを変換するライブラリであるブリッジプログラムがメインメモリ18にロードされている。そして、取得部40がシステムコールのコマンドを取得した際には、このシステムコールに対応するブリッジプログラムのライブラリがコールされ、その結果、情報処理装置10のシステムコールが実行されることとなる。
なお、本発明は上述の実施形態に限定されるものではない。
例えば、モニタ32において3D表示を実現する方法はフレームシーケンシャル方式にには限定されない。例えば、モニタ32が、水平走査線ごとに偏光特性を変えるパッシブグラス方式によって3D表示を実現するようにしてもよい。また、モニタ32は、視差バリア方式によって3D表示が実現された裸眼3Dディスプレイであっても構わない。
例えば、本実施形態に係る情報処理装置10が、情報処理装置10外の装置に搭載されたプロセッサでの処理の実行を制御するようにしてもよい。また、本実施形態に係る情報処理システムが複数の筐体から構成されていてもよい。また、上記の具体的な文字列や図面中の具体的な文字列は例示であり、これらの文字列には限定されない。
10 情報処理装置、12 メインプロセッサ、14 サブプロセッサ、16 バス、18 メインメモリ、20 画像処理部、22 入出力処理部、24 ネットワークボード、26 ハードディスクドライブ、28 光ディスクドライブ、30 コントローラ、32 モニタ、40 取得部、42 特定部、44 実行制御部。

Claims (11)

  1. 処理の実行主体となる処理実行主体装置のプロセッサとは異なる種類のプロセッサである他種プロセッサで実行可能なコマンドを取得する取得手段と、
    前記取得手段により取得されるコマンドに対応付けられる、前記処理実行主体装置のプロセッサで実行可能な処理を特定する特定手段と、
    設定されているパラメータの値が前記他種プロセッサでの処理の実行に影響を与えない前記他種プロセッサにおける特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサによる処理の実行を制御する実行制御手段と、
    を含むことを特徴とする情報処理装置。
  2. 前記実行制御手段は、前記特定のコマンドに設定されているパラメータの値が、当該特定のコマンドとは異なるコマンドが示す処理の前記処理実行主体装置のプロセッサによる実行でのパラメータの値として用いられるよう制御する、
    ことを特徴とする請求項1に記載の情報処理装置。
  3. 前記実行制御手段は、前記処理実行主体装置のプロセッサで実行されるよう既に制御された処理の実行でのパラメータの値として、前記特定のコマンドに設定されているパラメータの値を用いるよう制御する、
    ことを特徴とする請求項1に記載の情報処理装置。
  4. 前記実行制御手段は、前記特定のコマンドに設定されているパラメータの値に対応付けられる処理を前記処理実行主体装置のプロセッサに実行させる、
    ことを特徴とする請求項1に記載の情報処理装置。
  5. 前記実行制御手段は、命令列として連続している複数の前記特定のコマンドのそれぞれに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサでの処理の実行を制御する、
    ことを特徴とする請求項1からのいずれか一項に記載の情報処理装置。
  6. 前記取得手段は、コマンドを含む情報を順次取得し、
    前記実行制御手段は、前記取得手段が所定の情報を取得した後に取得する、前記特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサでの処理の実行を制御する、
    ことを特徴とする請求項1からのいずれか一項に記載の情報処理装置。
  7. 前記実行制御手段は、設定されているパラメータの値が所定の開始値である前記特定のコマンドの直後のコマンドが示す処理から設定されているパラメータの値が所定の終了値である前記特定のコマンドの直前のコマンドが示す処理までを前記処理実行主体装置のプロセッサに実行させないよう制御する、
    ことを特徴とする請求項1からのいずれか一項に記載の情報処理装置。
  8. 前記実行制御手段は、前記他種プロセッサにおけるノーオペレーションコマンド、又は、前記他種プロセッサで実行されるプログラムのデバッグ用のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサでの処理の実行を制御する、
    ことを特徴とする請求項1からのいずれか一項に記載の情報処理装置。
  9. 処理の実行主体となる処理実行主体装置のプロセッサとは異なる種類のプロセッサである他種プロセッサで実行可能なコマンドを取得する取得ステップと、
    前記取得ステップで取得されるコマンドに対応付けられる、前記処理実行主体装置のプロセッサで実行可能な処理を特定する特定ステップと、
    設定されているパラメータの値が前記他種プロセッサでの処理の実行に影響を与えない前記他種プロセッサにおける特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサによる処理の実行を制御する実行制御ステップと、
    を含むことを特徴とする情報処理方法。
  10. 処理の実行主体となる処理実行主体装置のプロセッサとは異なる種類のプロセッサである他種プロセッサで実行可能なコマンドを取得する取得手段、
    前記取得手段により取得されるコマンドに対応付けられる、前記処理実行主体装置のプロセッサで実行可能な処理を特定する特定手段、
    設定されているパラメータの値が前記他種プロセッサでの処理の実行に影響を与えない前記他種プロセッサにおける特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサによる処理の実行を制御する実行制御手段、
    としてコンピュータを機能させることを特徴とするプログラム。
  11. 処理の実行主体となる処理実行主体装置のプロセッサとは異なる種類のプロセッサである他種プロセッサで実行可能なコマンドを取得する取得手段、
    前記取得手段により取得されるコマンドに対応付けられる、前記処理実行主体装置のプロセッサで実行可能な処理を特定する特定手段、
    設定されているパラメータの値が前記他種プロセッサでの処理の実行に影響を与えない前記他種プロセッサにおける特定のコマンドに設定されているパラメータの値に応じて前記処理実行主体装置のプロセッサによる処理の実行を制御する実行制御手段、
    としてコンピュータを機能させることを特徴とするプログラムを記憶したコンピュータ読み取り可能な情報記憶媒体。
JP2011141186A 2011-06-24 2011-06-24 情報処理装置、情報処理方法、プログラム及び情報記憶媒体 Active JP5367020B2 (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2011141186A JP5367020B2 (ja) 2011-06-24 2011-06-24 情報処理装置、情報処理方法、プログラム及び情報記憶媒体
US13/525,489 US9934038B2 (en) 2011-06-24 2012-06-18 Conditionally executing converted non-ISA instructions based on GPU display settings

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2011141186A JP5367020B2 (ja) 2011-06-24 2011-06-24 情報処理装置、情報処理方法、プログラム及び情報記憶媒体

Publications (2)

Publication Number Publication Date
JP2013008243A JP2013008243A (ja) 2013-01-10
JP5367020B2 true JP5367020B2 (ja) 2013-12-11

Family

ID=47362965

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2011141186A Active JP5367020B2 (ja) 2011-06-24 2011-06-24 情報処理装置、情報処理方法、プログラム及び情報記憶媒体

Country Status (2)

Country Link
US (1) US9934038B2 (ja)
JP (1) JP5367020B2 (ja)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10657698B2 (en) * 2017-06-22 2020-05-19 Microsoft Technology Licensing, Llc Texture value patch used in GPU-executed program sequence cross-compilation

Family Cites Families (13)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CA2045735A1 (en) * 1990-06-29 1991-12-30 Richard Lee Sites Computer performance by eliminating branches
US5758140A (en) * 1996-01-25 1998-05-26 International Business Machines Corporation Method and system for emulating instructions by performing an operation directly using special-purpose register contents
JP3616556B2 (ja) * 1999-06-29 2005-02-02 株式会社東芝 拡張命令を処理する並列プロセッサ
US6449712B1 (en) * 1999-10-01 2002-09-10 Hitachi, Ltd. Emulating execution of smaller fixed-length branch/delay slot instructions with a sequence of larger fixed-length instructions
US6789186B1 (en) * 2000-02-18 2004-09-07 Hewlett-Packard Development Company, L.P. Method and apparatus to reduce penalty of microcode lookup
US6957321B2 (en) * 2002-06-19 2005-10-18 Intel Corporation Instruction set extension using operand bearing NOP instructions
EP1378824A1 (en) * 2002-07-02 2004-01-07 STMicroelectronics S.r.l. A method for executing programs on multiple processors and corresponding processor system
US7899855B2 (en) * 2003-09-08 2011-03-01 Intel Corporation Method, apparatus and instructions for parallel data conversions
US8505002B2 (en) * 2006-09-29 2013-08-06 Arm Limited Translation of SIMD instructions in a data processing system
JP5217431B2 (ja) * 2007-12-28 2013-06-19 富士通株式会社 演算処理装置及び演算処理装置の制御方法
JP4657331B2 (ja) * 2008-08-27 2011-03-23 富士フイルム株式会社 3次元表示時における指示位置設定装置および方法並びにプログラム
US20120062554A1 (en) * 2010-08-06 2012-03-15 Takamasa Ueno Reproducing apparatus
JP5684621B2 (ja) * 2011-03-28 2015-03-18 京セラ株式会社 電子機器、表示制御方法及び表示制御プログラム

Also Published As

Publication number Publication date
US9934038B2 (en) 2018-04-03
JP2013008243A (ja) 2013-01-10
US20120331277A1 (en) 2012-12-27

Similar Documents

Publication Publication Date Title
JP2017517025A (ja) 複数のレンダーターゲット内でアクティブカラーサンプルカウントを変更することによりスクリーンの位置によって有効解像度を変動させること
US10621761B2 (en) Computer-readable recording medium, computer apparatus, and computer processing method for placing object in virtual space and displaying placed object according to display mode
JP3949674B2 (ja) 表示装置、表示方法、ならびに、プログラム
JP2016529593A (ja) 立体シーンのインターリーブ方式のタイル型レンダリング
JP2012147404A (ja) 情報処理装置
KR20160130455A (ko) 애니메이션 데이터 생성 방법, 장치, 및 전자 기기
JP7267429B2 (ja) 表示制御装置、表示制御方法及びプログラム
JP5367020B2 (ja) 情報処理装置、情報処理方法、プログラム及び情報記憶媒体
US11551383B2 (en) Image generating apparatus, image generating method, and program for generating an image using pixel values stored in advance
JP3639286B2 (ja) ゲームプログラム、及びゲーム装置
JP5328852B2 (ja) 画像処理装置、画像処理方法、プログラム及び情報記憶媒体
TWI566205B (zh) 圖形驅動程式在顯像圖框中近似動態模糊的方法
JP2009025919A (ja) 画像処理装置、画像処理方法
KR20120138185A (ko) 저해상도 그래픽 영상을 고해상도 그래픽 영상으로 실시간 변환하는 그래픽 영상 처리 장치 및 방법
JP2014239795A5 (ja)
JP2012174145A (ja) 情報処理プログラム、情報処理装置、情報処理方法及び情報処理システム
US11837199B2 (en) Image transmission apparatus, image transmission method, and program
TWI653081B (zh) 影像處理系統和方法
JP2017127679A5 (ja)
CN116016892A (zh) 智能眼镜的图像显示方法、装置、电子设备和存储介质
JP2005305042A (ja) ゲームソフトウエア及びゲーム装置
JP2016081394A (ja) 画像処理装置、画像処理方法
JP4554834B2 (ja) 画像処理装置及び方法並びにそのプログラム
JP2021193506A (ja) 画像描画処理装置、画像描画処理方法及び画像描画処理プログラム並びに電子ゲーム提供装置
JP2008134472A (ja) 情報処理装置、情報処理方法

Legal Events

Date Code Title Description
A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20130618

A521 Written amendment

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20130807

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

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20130910

R150 Certificate of patent or registration of utility model

Ref document number: 5367020

Country of ref document: JP

Free format text: JAPANESE INTERMEDIATE CODE: R150

Free format text: JAPANESE INTERMEDIATE CODE: R150

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

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