JP2009211190A - 情報処理装置 - Google Patents

情報処理装置 Download PDF

Info

Publication number
JP2009211190A
JP2009211190A JP2008051271A JP2008051271A JP2009211190A JP 2009211190 A JP2009211190 A JP 2009211190A JP 2008051271 A JP2008051271 A JP 2008051271A JP 2008051271 A JP2008051271 A JP 2008051271A JP 2009211190 A JP2009211190 A JP 2009211190A
Authority
JP
Japan
Prior art keywords
code
subroutine
content
management table
execution
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
JP2008051271A
Other languages
English (en)
Inventor
Shinya Iguchi
慎也 井口
Takatoshi Kato
崇利 加藤
Masaya Umemura
雅也 梅村
Nobuaki Obinata
宣昭 小日向
Yasushi Nagai
靖 永井
Hiroshi Nakakoshi
洋 中越
Keitaro Okazaki
啓太郎 岡崎
Hirotaka Moribe
博貴 森部
Takeshi Asahi
猛 朝日
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.)
Hitachi Ltd
Original Assignee
Hitachi Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Hitachi Ltd filed Critical Hitachi Ltd
Priority to JP2008051271A priority Critical patent/JP2009211190A/ja
Priority to US12/332,397 priority patent/US20090222798A1/en
Publication of JP2009211190A publication Critical patent/JP2009211190A/ja
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/40Transformation of program code
    • G06F8/52Binary to binary

Abstract

【課題】組込み機器への適用に適しており、コンテンツの実行速度を向上させ、また、低消費電力を実現する技術を提供する。
【解決手段】携帯電話機101は、コンテンツ107に含まれる複数のサブルーチンごとに、ネイティブコード131、第1コード119、第2コード121のうち、存在するコードの種類を管理するサブルーチン管理表203を記憶するメモリ117と、仮想マシン153と、第1コード119から第2コード121を生成するプリコンパイル回路173と、コンテンツ107の実行中に呼び出されたサブルーチンについて、存在するコードの種類に応じて処理を切り替えるサブルーチン管理回路171とを備える。サブルーチン管理回路171は、処理を切り替える際、サブルーチン管理表203を参照し、存在するコードの種類を判断する。
【選択図】図1

Description

本発明は、携帯電話、カーナビゲーション装置、及びテレビ受像機等の情報処理装置内で動作するJITコンパイラを備えた仮想マシンに関する。
近年、ユーザの要望するコンテンツは、ダウンロード可能なアプリケーションとして又はそのまま利用できるWebアプリケーションとして、ホームページ上で提供されることが多い。これらのコンテンツには、文書編集ソフト、表計算ソフト、及びメール送受信ソフト等のコンピュータプログラムだけでなく、ゲーム、小説、動画、アニメーション等のソフトウェアも含まれる。
しかしながら、このアプリケーション及びそれを表示するブラウザは、主に閲覧を目的として作られているため、画面デザイン、操作性、応答性の面において、Windows(登録商標)等のデスクトップアプリケーションに劣っていた。そこで、これらの課題を改善するため、JavaScript(登録商標。非特許文献1参照)、Ajax(非特許文献2参照)などの技術を用いて、既存のデスクトップアプリケーションと同等な性能を持つRich Internet Application(RIA、非特許文献3参照)と呼ばれるWebアプリケーションが開発されている。
また、高度なアニメーションや動画を表示させることができるメディアプレイヤーと呼ばれるアプリケーション実行環境が、ブラウザのプラグインとして、又は単体のアプリケーションとして開発されている。このメディアプレイヤーを用いることによっても、既存のデスクトップアプリケーションと同等なアプリケーション実行環境を実現することができる。
これらのブラウザ及びメディアプレイヤーは、CPUを内蔵し、ソフトウェアに制御されて動作するパーソナルコンピュータ(PC)以外の機器、いわゆる組込み機器においても広く用いられている。組込み機器としては、例えば、携帯電話機、その他の携帯情報機器、カーナビゲーション装置、家庭用電話機、携帯ゲーム機、家庭用ゲーム機、HDDレコーダ等の個人用機器、及びカラオケ機器、ロボット、鉄道等の輸送機器、ロケット、プラント制御装置等の業務用機器がある。
上記ブラウザ及びメディアプレイヤーは、HTML、XML、Java(登録商標)、JavaScript(登録商標)等の標準的な技術を採用していることから、コンテンツの作成時には、OS等のアーキテクチャの違いを意識する必要がない。従って、一度開発されたコンテンツは、任意の端末で変更せずに動作させることが原理的には可能となり、開発負担の大幅な軽減及び互換性の向上を実現している。
上記コンテンツを組込み機器向けに開発する際には、PC向けの場合とは異なり、CPUの処理速度、メモリの容量、画像表示能力等の面において、PCと比較してリソースが厳しく制限される点を考慮しなければならない。特に、RIAの開発においては、JavaScript等のスクリプト言語やJavaで動作を記述することが多い。しかし、スクリプト言語は、C++などと比較して、記述量が少ないため、開発効率は良いという利点がある一方で、同一環境での実行速度が数倍遅いという問題がある。実行速度が遅いという問題については、Javaで記述されたプログラム(Javaプログラム)にも共通する。
この問題の一因としては、スクリプト言語で記述されたコードを含むプログラム及びJavaプログラムが、組込み機器等の情報処理装置のOSが直接実行できるネイティブコードとは異なる形式で配布されることが挙げられる。Javaプログラムの場合、OSやハードウェア等のアーキテクチャに依存しないバイナリ形式のJavaバイトコードと呼ばれる中間コードに一旦コンパイルされ、この中間コードの状態で配布される。
すなわち、中間コードの形式のプログラムは、インタプリタ方式又はJust-In-Timeコンパイル(JITコンパイル)方式で実行される。具体的には、インタプリタ方式の場合、例えばソフトウェアで構成したインタプリタが、中間コードをネイティブコードに逐次変換し(例えば、コード単位で変換し)ながら実行する。JITコンパイル方式の場合、例えばソフトウェアで構成したJITコンパイラが、中間コードをネイティブコードに一旦変換し(例えば、サブルーチン単位で変換し)てから実行する。更に詳細には、インタプリタ方式とJITコンパイル方式のいずれにおいても、生成されたネイティブコードは、実際にはCPUによって実行される。PC等の多くの情報処理装置には、このインタプリタとJITコンパイラを備えた仮想マシンが搭載されている。JavaScriptの場合、ブラウザに搭載されたスクリプトエンジンがスクリプトを解釈し、インタプリタ形式で実行する態様が多い。いずれにしても、ネイティブコードへコンパイル済みの状態で配布されるプログラムと比較すれば、インタプリタ形式で実行する場合には処理完了までの時間が長くなり、JITコンパイルで実行する場合にはコンパイル完了までのオーバーヘッドが発生するため、実行速度が遅くなる。
今後、Java(登録商標)やスクリプト言語を用いたコンテンツの開発が大規模化してくると、この問題の解決が重要になる。以下、この問題を解決しようとする従来技術の例を示す。
(1)プロセッサの動作速度の向上
プロセッサの動作速度を上げれば、ソフトウェアで構成したインタプリタ及びJITコンパイラの動作速度も向上し、コンテンツの実行処理を高速化できると考えられる。
(2)インタプリタによる実行速度の向上
インタプリタ自体の動作速度を上げれば、スクリプト処理開始までのオーバーヘッドもなく、実行処理を高速化できると考えられる。例えば、非特許文献4には、インタプリタをハードウェア化して専用のプロセッサを構築することにより、高速化を図る製品が開示されている。
(3)無駄なコンパイルを行わない技術
下記特許文献1には、コンパイルの必要なメソッドだけをコンパイルし、無駄なコンパイルを行わない技術が開示されている。具体的には、インタプリタで実行中のメソッドを検出し、インタプリタによる実行を中断し又はマルチスレッドを利用して、インタプリタで実行していたバイトコードをネイティブコードへコンパイルし、コンパイルが終了すると、インタプリタによる処理の中断箇所からバイトコードを用いて実行を再開し又は生成したネイティブコードを用いて処理を実行するという技術である。
(4)コンパイルの要否の判断を高速化する技術
下記特許文献2には、バイトコードとネイティブコードがメモリ上に混在する場合において、コンパイルされているか否か及びネイティブコードの格納アドレスの検索を容易にすることにより、処理の高速化を図る技術が開示されている。具体的には、バイトコードがコンパイルされているか否かを判断するための情報と、コンパイルされたネイティブコードのアドレスを検索する検索テーブルをメモリ上に備えておき、バイトコードの実行時に、この検索テーブルを検索することにより、コンパイルの要否の判断やネイティブコードの格納アドレスの検索を容易(高速)に行うという技術である。
"Introduction to JavaScript"、[online]、Refsnes Data、[2008年2月7日検索]、インターネット<URL:http://www.w3schools.com/js/js#intro.asp> "Ajax(programming)"、[online]、2008年2月6日、Wikipedia、[2008年2月7日検索]、インターネット<URL:http://en.wikipedia.org/wiki/AJAX> "Rich Internet application"、[online]、2008年2月3日、Wikipedia、[2008年2月7日検索]、インターネット<URL:http://en.wikipedia.org/wiki/Rich#Internet#application> "Java processor"、[online]、2008年1月22日、Wikipedia、[2008年2月7日検索]、インターネット<URL:http://en.wikipedia.org/wiki/Java#processor> US6996814 B2 特開2006−202317号公報
しかしながら、(1)及び(2)の技術には、消費電力及びコストが増大することから、組込み機器への適用が難しいという問題がある。
(3)の技術においては、インタープリタによる処理を中断してコンパイルを行う場合、インタープリタを中断するまでの時間とコンパイルに要する時間がオーバーヘッドとなり、実行時間が増大(実行速度が低下)する。一方、インタープリタによる処理を行いながらコンパイルを行う場合、マルチスレッド処理を行うことになるため、インタープリタによる実行速度が低下するという問題がある。
(4)の技術には、JITコンパイル時のオーバーヘッドが解消されていないうえに、検索テーブルの検索時にCPUによるメモリへのアクセスが頻発することにより、実行速度が低下するという問題がある。
本発明は、組込み機器への適用に適しており、コンテンツの実行速度を向上させ、また、低消費電力を実現する技術を提供する。
本発明の情報処理装置は、コンテンツに含まれる複数のサブルーチンごとに、プロセッサで実行可能なネイティブコード、前記ネイティブコードの元となるOSに依存しない第1コード、前記第1コードを前記ネイティブコードへ変換する過程で生成される第2コードのうち、存在するコードの種類を管理するサブルーチン管理表を記憶するメモリと、前記第1コードをインタプリタ方式で実行するインタプリタ機能、及び前記第2コードをネイティブコードへ変換してから実行するJITコンパイル機能を備えた仮想マシンと、前記第1コードから前記第2コードを生成するプリコンパイル回路と、前記コンテンツの実行中に呼び出されたサブルーチンについて、前記サブルーチン管理表を参照した結果、ネイティブコードが存在するときは、該ネイティブコードがプロセッサで実行され、第2コードが存在するときは、該第2コードが前記仮想マシンのJITコンパイル機能で実行され、生成されたネイティブコードが前記メモリに格納され、又は第1コードが存在するときは、該第1コードが前記仮想マシンのインタプリタ機能で実行されるとともに、前記プリコンパイル回路で第2コードに変換され、該第2コードが前記メモリに格納されるように実行制御を行い、それらの制御によりサブルーチン実行する際に参照するコードの種類が変化したときは、変化後の種類が前記サブルーチン管理表に記録されるように記録制御を行うサブルーチン管理手段とを備えたことを特徴とする。
本発明の実施形態では、上記サブルーチン管理手段は、前記サブルーチンごとに所定の基準に基づいて定められる、第1コードを第2コードへ変換する優先度の高いサブルーチンから順に、その第1コードが第2コードに変換されるように前記実行制御を行う。
また別の実施形態では、前記メモリは、前記優先度に応じて、前記プリコンパイル回路の動作速度を定めた動作速度定義表を記憶し、さらに、前記プリコンパイル回路で処理される第1コードに対応するサブルーチンの優先度を用いて、前記動作速度定義表から動作速度を判断し、該動作速度に従って前記プリコンパイル回路が動作するように制御を行うプリコンパイル制御手段を備えたことを特徴とする。
前記優先度としては、前記コンテンツの実行中に呼び出されたサブルーチンごとの回数であり、又は前記コンテンツの実行中に各サブルーチンが呼び出された際のスタックフレームの数を所定の値から減じた値を採用することができる。または、前記優先度として、前記コンテンツに含まれる各サブルーチンの第1コードを第2コードへ変換するのに要する時間に基づいて、又は前記コンテンツの実行中に各サブルーチンが呼び出される頻度に基づいて、各サブルーチンの第1コード内に予め記述された値を採用することができる。
本発明におけるプリコンパイル制御手段は、前記プリコンパイル回路の動作速度を下げたとき、該プリコンパイル回路への供給電圧を、その動作を維持できる電圧値の範囲内で下げるように構成することができる。
本発明の実施形態では、前記プリコンパイル制御手段は、バス内のデータ伝送量又はプロセッサによる前記メモリへのアクセス頻度を監視し、前記データ伝送量又は前記アクセス頻度が所定の基準を超えている間、前記プリコンパイル回路の動作を停止するように構成してもよい。
また別の実施形態では、さらに、前記サブルーチン管理表の内容をサブルーチン管理表キャッシュとして記憶するキャッシュメモリを備え、前記サブルーチン管理手段は、前記サブルーチン管理表に替えて前記サブルーチン管理表キャッシュに基づいて前記実行制御及び前記記録制御を行い、所定のタイミングで、前記サブルーチン管理表と前記サブルーチン管理表キャッシュの間でデータの転送及び書き換えが行われるようにキャッシュ制御を行うことを特徴とする。
この実施形態においては、前記サブルーチン管理手段は、前記コンテンツの実行開始時には、実行対象のコンテンツに含まれるサブルーチンの情報が、前記優先度の高いものから順に、前記サブルーチン管理表から前記サブルーチン管理表キャッシュへ書き込まれ、前記コンテンツの実行中において、呼び出されたサブルーチンの情報が前記サブルーチン管理表キャッシュにない場合は、サブルーチン管理表キャッシュにある前記優先度の最も低いサブルーチンの情報が前記サブルーチン管理表へ書き戻され、前記呼び出されたサブルーチンの情報が前記サブルーチン管理表から前記サブルーチン管理表キャッシュへ書き込まれるように前記キャッシュ制御を行うように構成することができる。
本発明の実施形態では、前記第1コードは、スタックマシン用のコードであり、前記第2コードは、前記第1コードから生成されるレジスタマシン用のコードを含むことができる。
また別の実施形態では、前記第2コードは、前記サブルーチンの実行過程で呼び出される他のサブルーチンの第1コードを、呼び出し元のサブルーチンの第1コード内にインライン展開して成るコードを含んでもよい。
さらに別の実施形態では、前記メモリは、前記第1コードにおける不要な記述、文法上の瑕疵、又は誤記の修正方法を定めた修正辞書を記憶し、前記第2コードは、前記修正辞書に基づいて、前記第1コードを最適化したコードを含むことができる。
本発明におけるJITコンパイル機能は、前記第2コードの実行過程で呼び出される他のサブルーチンの第1コードのプリコンパイル結果である第2コードを、呼び出し元の第2コード内にインライン展開し、これをネイティブコードへ変換するように構成することができる。
本発明の実施形態では、前記メモリは、前記サブルーチンごとに複数のコンテンツとの対応関係を表すサブルーチン共用表を記憶し、前記サブルーチン管理手段は、前記優先度に替えて、前記サブルーチン共用表に基づいて、対応するコンテンツの数が多いサブルーチンから順に、その第1コードが第2コードに変換されるように前記実行制御を行うように構成することができる。
また別の実施形態では、前記サブルーチン管理手段は、前記優先度に替えて、前記コンテンツの実行中に呼び出されたサブルーチンのうち最後に呼び出されたサブルーチンから順に、その第1コードが第2コードに変換されるように前記実行制御を行うことができる。
さらに別の実施形態では、前記第1コードには、対応するサブルーチンの処理の内容を表す属性が予め記載されており、前記メモリは、前記属性ごとに前記第1コードから前記第2コードを生成する優先順位を定めた属性管理表を記憶し、前記サブルーチン管理手段は、前記コンテンツンの実行中に呼び出されたサブルーチンの第1コードに記載された属性を用いて前記属性管理表から前記優先順位を特定し、前記優先度に替えて、該優先順位に従って第1コードが第2コードに変換されるように前記実行制御を行うように構成してもよい。
またさらに別の実施形態では、前記コンテンツに対応する表示物を表示するディスプレイを備え、前記サブルーチン管理手段は、前記優先度に替えて、前記ディスプレイ上で、中央の表示物、最前面の表示物、又は最も大きい表示物に対応するコンテンツに含まれるサブルーチンの第1コードから優先的に第2コードが生成されるように前記実行制御を行うように構成してもよい。この場合には、前記ディスプレイ上に表示される矢印等の指示部を移動させ、及び前記表示物を前記指示部によって選択するための操作部をさらに備え、前記サブルーチン管理手段は、前記ディスプレイ上で、前記指示部と重っている表示物又は前記指示部によって選択された表示物に対応するコンテンツに含まれるサブルーチンの第1コードから優先的に第2コードが生成されるように前記実行制御を行うように構成してもよい。
本発明が実行対象として扱うコンテンツは、その一部若しくは全部がスクリプト若しくはJavaプログラムであってもよい。
本発明によれば、ネイティブコードへのコンパイルを高速化することによりコンテンツの実行速度を格段に向上させ、また、低消費電力処理を実現することができる。
以下、本発明の実施例において、複数のサブルーチンを含んで構成されるコンテンツとして、Javaプログラムを携帯電話機で実行する方法を説明する。その説明において、音声通話機能、メール送受信機能、スケジュール管理機能、及び撮像機能など、携帯電話機が通常備える機能については、図示及び説明を省略する。また、一般に、オブジェクト指向プログラミングでは、サブルーチンに相当するプログラムをメソッドと呼ぶことがあるが、ここではプログラミングの指向性にかかわらず、いずれもサブルーチンと呼ぶこととする。
[実施例1]
図1は、本発明を適用した携帯電話機101の基本構成を示す。
携帯電話機101は、バス103を解して互いに接続された各種のハードウェア105、並びにこれを制御するプログラム及び携帯電話機101で実行される複数のコンテンツ107等の各種のソフトウェア109を含んで構成される。
具体的には、携帯電話機101は、
ユーザによる操作の受け付け、画面表示、通信、及び入出力等の機能を有する周辺機能部111と、
ソフトウェア109に含まれる再生アプリ125等の各種のプログラムを実行するプロセッサ113と、
携帯電話機101の電源遮断中においても、ソフトウェア109の一部又は全部のデータを記録する不揮発性記録媒体115と、
起動中のソフトウェア109に関するデータを格納するメモリ117と、
Javaプログラムを構成する、プロセッサ113で実行可能なネイティブコードの元となるOSに依存しないJavaバイトコード(以下「第1コード」という。)119を、ネイティブコードに変換する過程で生成されるコード(以下「第2コード」という。)121に変換する第1コード処理部123と
を含んで構成される。
周辺機能部111としては、例えば、操作ボタン、タッチパネル、ディスプレイ、マイク、スピーカー、及びネットワーク接続手段を採用することができる。
不揮発性記録媒体115としては、例えば、フラッシュメモリ、ハードディスク読取装置(HDD)、Magnetoresistive Random Access Memory(MRAM)、Ferroelectric Random Access Memory(FeRAM)等の記録媒体を採用することができる。メモリ117としては、Static Random Access Memory(SRAM)、Dynamic Random Access Memory(DRAM)、MRAM等の記録媒体を採用することができる。これらのハードウェアは、製造時点における価格、記憶容量、消費電力、読み書きの速度等の条件を考慮して選ぶのがよい。
携帯電話機101は、ハードウェア105を制御するプログラム及び携帯電話機101で実行されるJavaプログラム等のソフトウェア109をメモリ117上に持つ。具体的には、ソフトウェア109には、Javaプログラム等のコンテンツ107(後述の第1コード119を含む。)、再生アプリ125、及びOS127、並びにコンテンツ107の実行時に適時参照される三種類の表として、コンテンツ管理表201、サブルーチン管理表203、及び動作速度定義表301が含まれる。
ソフトウェア109には、このほかにも、後述する、第1コード処理部123の処理により生成される第2コード121、及び仮想マシン129の処理により生成されるネイティブコード131が含まれる。さらに、サブルーチンのコードの種類(第1コード119、第2コード121、ネイティブコード131)に応じた処理命令や上記サブルーチン管理表203等の表の更新命令等の各種命令が組み合わされたサブルーチン管理プログラム133と、第1コード119から第2コード121を生成する後述のプリコンパイル回路173の制御命令等の各種命令が組み合わされたプリコンパイル制御プログラム135とを含む。
プロセッサ113は、サブルーチン管理プログラム133を実行することで、後述のサブルーチン管理回路171を制御し、サブルーチン管理回路171とともにサブルーチン管理手段を構成する。プロセッサ113は、また、プリコンパイル制御プログラム135を実行することで、プリコンパイル制御回路175を制御し、プリコンパイル制御回路175とともにサブルーチン制御手段を構成する。 コンテンツ107は、Javaプログラムを実行するのに必要なプログラム及びデータとして、例えば、第1コード119、各種バイナリデータ141、及びテキストデータ143により構成される。コンテンツ107の種類としては、ゲーム、動画、アニメーション、文書編集ソフト、及び表計算ソフトなど、機能の高低を問わず、様々なアプリケーションを採用することができる。
第1コード119は、コンテンツ107を実行する携帯電話機101のアーキテクチャ(例えば、OS)に依存しない形式のプログラムコードであり、複数のサブルーチンで構成される。なお、本実施例でいうサブルーチンには、メインルーチンが含まれる。Javaプログラムの第1コード119は、携帯電話機101のプロセッサ113が実行できる形式(ネイティブコード131)ではなく、アーキテクチャに依存しない形式にコンパイルされており、実行時には、携帯電話機101のプロセッサ113に対応する形式に再度コンパイルする必要がある。
各種バイナリデータ141は、動画、静止画、音声、ベクトル、3D描画データ、各種設定データ、及び文字列を含むことができる。テキストデータ143は、文字列形式のデータであり、例えばXML等の言語を用いれば、テキストデータを直接組み込んだ状態で、各種データを表現することができる。
再生アプリ125は、コンテンツ107を実行するブラウザや各種メディアプレイヤー等のプログラムである。この再生アプリ125は、コンテンツ107に含まれる動画、音声、静止画などのデータを再生する各種データ再生部151と、第1コード119及び第2コード121を実行するコード実行部153(仮想マシン)153、そしてこれらの機能がOS127及びハードウェア105にアクセスする際に利用するドライバI/F155を含んで構成されている。
コード実行部153(仮想マシン)153は、インタプリタ157及びJITコンパイラ159で構成され、後述する条件に応じていずれかを起動するとともに、必要に応じて第1コード処理部123にアクセスする。
インタプリタ157は、コンテンツ107の実行中に呼び出されたサブルーチンについて、その第1コード119を解析してネイティブコード131へ変換しながらプロセッサ113に順次実行させる処理を、例えば、コード単位で逐次実行するプログラムである。
JITコンパイラ159は、コンテンツ107の実行中に呼び出されたサブルーチンについて、その第2コードをネイティブコードへ一旦変換してから、そのネイティブコード131をCPUに実行させる処理を、例えば、サブルーチン単位又はループ処理単位で実行するプログラムである。
ドライバI/F155は、コード実行用I/F161及びデータ再生用I/F163で構成されている。コード実行用I/F161は、ハードウェア105の第1コード処理部123へアクセスするために利用される。データ再生用I/F163は、各種データ再生部151がコンテンツデータを再生する際に各種ハードウェア105へアクセスするために利用される。
OS127は、携帯電話機101等の組込み機器向けの基本ソフトウェアである。OS127の例としては、Linux、WindowsEmbedded、Symbian等のソフトウェアが挙げられる。また、OS127は、再生アプリ125がハードウェア105にアクセスするために必要なドライバ165を搭載している。
ドライバ165は、コード実行用ドライバ167及びデータ再生用ドライバ169で構成される。コード実行用ドライバ167は、コンテンツ107の実行時に再生アプリ125がハードウェア105へアクセスするための機能を提供する。データ再生用ドライバ169は、コンテンツ107の実行以外のデータ処理時に、再生アプリ125がハードウェア105へアクセスするための機能を提供する。
コード実行部153のインタプリタ157及びJITコンパイラ159は、必要に応じて、コード実行用I/F161を介してコード実行用ドライバ167へアクセスし、各種ハードウェア105を呼び出すことができる。その際、必要なハードウェア105が存在しなければ、ソフトウェアエミュレータを起動し、必要な機能を再現させることができる。従って、ハードウェア105では実現されない他のハードウェアの機能が必要になる場合は、ソフトウェア109として、ソフトウェアエミュレータを備えておくのがよい。
コンテンツ管理表201は、各コンテンツ107のIDとコンテンツ名を管理する。サブルーチン管理表203は、コンテンツ107を構成する各サブルーチンについて、第1コード119、第2コード121、及びネイティブコード131のうちで存在するコードの種類や、呼び出され(参照され)た回数、及び実行開始位置を表すメモリアドレス(先頭アドレス)等の情報を管理する。動作速度定義表301は、第1コード処理部123による処理の制御方法を定める。これらの表の詳細については後述する。
第1コード処理部123は、
サブルーチン管理プログラム133を実行するプロセッサ113の制御のもと、コンテンツ107を構成する各サブルーチンについて、第1コード、第2コード、及びネイティブコードのうち、存在するコードの種類や、呼び出された回数、及び先頭アドレス等の情報を、サブルーチン管理表203からキャッシュして管理するとともに、サブルーチンのコードの種類に応じた処理が実行されるように制御を行うサブルーチン管理手段を構成するサブルーチン管理回路171と、
第1コード119を第2コード121へ変換するプリコンパイル回路173と、
プリコンパイル制御プログラム135を実行するプロセッサ113の制御のもと、プリコンパイル回路173の動作を制御するプリコンパイル制御手段を構成するプリコンパイル制御回路175と
を含んで構成される。
サブルーチン管理回路171は、上記の情報を格納し、その内容を高速に検索するための記憶装置としてキャッシュメモリ(例えば、連想メモリ)177を備えている。本実施例では、キャッシュメモリ177上に格納される上記の情報をサブルーチン管理表キャッシュと呼ぶ。サブルーチン管理表とサブルーチン管理表キャッシュとの間では、所定のタイミングで、内容の書き換え又は入れ替えが行われる。これにより、サブルーチン管理表キャッシュには、少なくともメモリ117上に格納されるサブルーチン管理表203の情報の一部若しくは全部が格納される。サブルーチン管理表キャッシュの内容については後述する。
また、サブルーチン管理回路171は、コンテンツ107の実行中に呼び出されたサブルーチンについて、サブルーチン管理表キャッシュ205を参照した結果に応じて、以下の制御を行う。
(1)ネイティブコード131が存在するときは、そのネイティブコード131がプロセッサ113で実行されるように実行制御を行う。具体的には、実施例1では、呼び出されたサブルーチンのネイティブコード131の先頭アドレスをプロセッサ113に返す。
(2)第2コード121が存在するときは、その第2コード121が仮想マシン153のJITコンパイラ159で実行され、生成されたネイティブコード131がメモリ117に格納されるように実行制御を行う。具体的には、実施例1では、呼び出されたサブルーチンのコードの種類(第2コード121)をプロセッサ113に通知する。これにより、プロセッサ113が、JITコンパイラ159を動作させ、生成されるネイティブコード131をメモリ117へ格納させる。また、メモリ117への格納については、サブルーチン管理回路171が行ってもよい。
(3)第1コード119が存在するときは、その第1コード119が仮想マシン153のインタプリタ157で実行されるとともに、プリコンパイル回路173で第2コード121に変換され、その第2コード121がメモリ117に格納されるように実行制御を行う。具体的には、実施例1では、呼び出されたサブルーチンのコードの種類(第1コード119)をプロセッサ113に通知する。これにより、プロセッサ113が、インタプリタ157を動作させる。また、サブルーチン管理回路171は、プリコンパイル制御回路175にプリコンパイル回路173を制御させ、プリコンパイル回路173が呼び出されたサブルーチンの第1コード119から第2コード121を生成させる。生成された第2コード121のメモリ117への格納は、サブルーチン管理回路171、プリコンパイル制御回路175、及びプリコンパイル回路173のどれが行ってもよい。
さらに、上記(2)又は(3)の制御により、サブルーチン実行時の実行対象コードの種類が変化し(第1コード119が第2コード121に、第2コード121がネイティブコード131に変化し)たときは、変化後の種類がサブルーチン管理表キャッシュ205に記録されるように記録制御を行う。具体的には、実施例1では、サブルーチン管理回路171が、サブルーチン管理表キャッシュ205を書き換えることとする。
プリコンパイル回路173は、第1コード119をネイティブコード131にコンパイルする際に生成される第2コード121を得るための手段である。プリコンパイル回路173によるプリコンパイルにより生成される第2コード121とは、例えば、以下のとおりである。
(1)スタックマシン用の第1コード119から生成されるレジスタマシン用のコード
(2)サブルーチンの実行過程で呼び出される他のサブルーチンの第1コード119を、呼び出し元のサブルーチンの第1コード119内にインライン展開して成るコード
(3)メモリ117上に、第1コード119における不要な記述、文法上の瑕疵、又は誤記の修正方法を定めた修正辞書を記憶させておき、その修正辞書に基づいて第1コードを最適化したコード
ただし、上記以外の方法であっても、プリコンパイルの従来の方法があれば、それをプリコンパイル回路173によるプリコンパイルに適用することも勿論可能である。
図2は、メモリ117に格納されるコンテンツ管理表201及びサブルーチン管理表203と、キャッシュメモリ177に格納されるサブルーチン管理表キャッシュ205の構成を示す。以下、これらの表の内容について説明する。
コンテンツ管理表201は、コンテンツID欄207及びコンテンツ名欄209で構成される各種の項目を有する。コンテンツID欄207には、携帯電話機101内に保存されているコンテンツ107を識別するコンテンツIDが格納される。コンテンツ名欄209には、各コンテンツの名前が格納される。コンテンツ管理表201は、各コンテンツのIDと名前を管理するのに用いられる。
コンテンツIDの付与方法としては、例えば、携帯電話機101で利用可能なコンテンツダウンロードサービス等の各種サービス内で共通のIDを、サービス提供者が一元的に定める方法と、携帯電話機101内でのみ通用するIDを、携帯電話機101が独自に又はサービス提供者が付与する方法がある。後者の場合、例えば、コンテンツをダウンロードした順に、通し番号を付す方法がある。
サブルーチン管理表203は、各サブルーチンのコンパイルの状況等に応じた処理を選択する機能など、携帯電話機101の基本的な機能を実現するのに必要な基本構成211と、ハッシュ値管理等の付随的な機能を実現するために実装される拡張構成213を含んで構成される各種の項目を有する。
サブルーチン管理表203の基本構成211は、コンテンツID欄215、サブルーチンID欄217、JITフラグ欄219、優先度欄221、キャッシュ欄223、第1コードアドレス欄225、処理アドレス欄227で構成される各種の項目を有する。
コンテンツID欄215には、コンテンツ管理表201で管理するコンテンツ107ごとのコンテンツIDが格納される。
サブルーチンID欄217には、コンテンツ107に含まれる各サブルーチンを識別するIDが格納される。このIDの付与方法としては、携帯電話機101で利用可能なコンテンツダウンロードサービス等の各種サービス内で共通のIDを、サービス提供者が一元的に定める方法と、携帯電話機101内でのみ通用するIDを、携帯電話機101が独自に又はサービス提供者が付与する方法がある。後者の場合、例えば、コンテンツのダウンロード時に若しくはコンテンツの最初の実行時に、サブルーチンの先頭から通し番号若しくはランダムな番号を付す方法がある。
JITフラグ欄219には、各サブルーチンのコンパイル状況(存在するコードの種類)を表すJITフラグが格納される。JITフラグの種類及びその意味は、以下のとおりである。
(1)yes:JITコンパイル済みであり、ネイティブコード131が存在する
(2)pre:プリコンパイル済みであり、第2コード121が存在する
(3)no:コンパイルされておらず、第1コード119が存在する
(4)req:コンパイルされておらず(ただし、プロセッサ113からコンパイルの要求があった)、第1コード119が存在する。
そして、コンテンツ107の実行中にサブルーチンが呼び出されたときは、各サブルーチンのJITフラグのステータスに応じて、以下の処理が行われる。
(1)yes:プロセッサ113が、参照先のネイティブコードへジャンプする。また、2回目以降、呼び出し元が呼び出し先へ直接アクセスできるようにするため、呼び出し元のコードに呼び出し先のアドレスを記入する
(2)pre:プロセッサ113が、JITコンパイラ159を呼び出す。また、コンパイル完了後、生成されたネイティブコードへジャンプする
(3)no:プロセッサ113が、インタプリタを呼び出す
(4)req:プロセッサ113が、インタプリタを呼び出す。これとは別に、サブルーチン管理回路171が、プリコンパイル回路173に、その第1コード119から第2コード121を生成させる。
優先度欄221には、サブルーチン管理表203からサブルーチン管理表キャッシュ205に転送するサブルーチンの情報(以下「エントリ」という。)を決定するための判断材料、及びプリコンパイル回路173の制御方法を決定するための判断材料として用いられる、各サブルーチンのプリコンパイルの優先度が格納される。この実施例では、優先度として、コンテンツ107の実行中に呼び出されたサブルーチンごとの回数(参照回数)を用いる。従って、各サブルーチンが呼び出されるたびに、優先度に1が加算される。
優先度を扱う際の注意点として、メモリ117及びキャッシュメモリ177のいずれにおいても、格納できる優先度の範囲(桁数)が有限であることが挙げられる。対処方法としては、格納する優先度の上限を決めておき、いずれかのサブルーチンの優先度がその上限に達したら、全てのサブルーチンの優先度を所定の基準で小さくするのがよい。例えば、各優先度から一定の値を減算する方法や各優先度を一定の値で除算する方法を適用することができる。この優先度の調整処理は、処理のオーバーヘッドを軽減するため、例えば、プロセッサ113がアイドル時に行うのがよい。
キャッシュ欄223は、サブルーチン管理表キャッシュ205への各エントリのキャッシュ状況を管理するため、サブ項目として、ステート欄231と回数欄233を持つ。ステート欄231には、各エントリがサブルーチン管理表キャッシュ205に存在するかどうかを表すフラグが格納される。”yes”の場合は、サブルーチン管理表キャッシュ205にエントリが存在し、”no”の場合は、サブルーチン管理表キャッシュ205にエントリが存在しないことを表す。回数欄233には、各エントリがキャッシュメモリ177上に読み込まれた回数が格納される。
第1コードアドレス欄225には、各サブルーチンの第1コードの先頭アドレスが格納される。
処理アドレス欄227には、ネイティブコード131があるときはネイティブコード131の実行開始位置を表すメモリアドレス(先頭アドレス)、第2コード121があるときは第2コード121の先頭アドレスが格納される。
サブルーチン管理表203は、サブルーチン管理プログラム133を実行するプロセッサ113の制御のもとでサブルーチン管理回路171によって、変更内容の書き換えが行われる。サブルーチン管理回路171は、この処理のほかに、後述する各種機能を提供する。
次に、サブルーチン管理表203の拡張構成213について説明する。この拡張構成213には、ハッシュ値管理表237、第1コードサイズ管理表239、ダウンロード元管理表241、サブルーチン共用表243の4種類の表がある。これらの表は、必要な機能に応じて適宜組み合わせて利用される。
ハッシュ値管理表237は、サブルーチンID欄245とハッシュ値欄247で構成される各種の項目を有する。
サブルーチンID欄245には、各サブルーチンのサブルーチンIDが格納される。ハッシュ値欄247には、各サブルーチンの第1コードに付与されるハッシュ値が格納される。このハッシュ値の生成方法としては、例えば、それぞれの第1コード119全文に基づいてハッシュ関数を用いて生成する方式、又は各第1コードの改変を検出できる最小限の間隔で抽出した1バイトの値に基づいてハッシュ関数を用いて生成する方式が適用可能である。上記改変を検出できる最小限の間隔は、例えば、数バイトから数十バイトの間隔である。このハッシュ値は、コンテンツ107を提供するサーバ側で付与してもよいし、携帯電話機101内で、上記の方法により付与するように構成してもよい。
第1コードサイズ管理表239は、ブルーチンID欄251と第1コードサイズ欄253で構成される各種の項目を有する。サブルーチンID欄251には、各サブルーチンのサブルーチンIDが格納される。第1コードサイズ欄253には、各サブルーチンの第1コードのサイズが格納される。
ダウンロード元管理表241は、サーバURL欄255、サブルーチンID欄257、及びサーバ通知欄259で構成され各種の項目を有し、サブルーチンを含むコンテンツ107のダウンロード元であるサーバに関する情報を管理する。
サーバURL欄255には、ダウンロード元であるサーバのURLが格納される。サブルーチンID欄257には、各サブルーチンのサブルーチンIDが格納される。サーバ通知欄259には、各サブルーチンが携帯電話機101に存在すること(たとえば、ダウンロードが完了したこと)をサーバに通知したか否かを示すフラグが格納される。このフラグが、“yes”の場合は通知済み、“no”の場合は未通知であることを示す。
サブルーチン共用表243は、サブルーチンID欄261、共用数欄263、及び対応コンテンツID欄265で構成される各種の項目を有し、各サブルーチンを共用している複数のコンテンツ107を把握するために利用される。
サブルーチンID欄261には、各サブルーチンのサブルーチンIDが格納される。共用数欄263には、各サブルーチンを利用しているコンテンツの数が格納される。対応コンテンツID欄265には、各サブルーチンを利用するコンテンツのコンテンツIDが格納される。
サブルーチン共用表243は、コンテンツのダウンロード時及び削除時に、そのコンテンツに含まれる各サブルーチンが他のコンテンツで利用されているかどうかがサブルーチン管理回路171によって判断され、更新される。
サブルーチン管理表キャッシュ205は、コンテンツID欄271、サブルーチンID欄273、JITフラグ欄275、実行アドレス欄277、優先度欄279、及びキャッシュアウトカウント欄281で構成される各種の項目を有する。このサブルーチン管理表キャッシュ205は、サブルーチン管理表203の内容の一部又は全部を含んで構成されており、所定のタイミングで、サブルーチン管理手段を構成するサブルーチン管理回路171によって、サブルーチン管理表203との間でデータの入れ替え及び書き換えが行われる。
コンテンツID欄271には、各サブルーチンに対応するコンテンツIDが格納される。サブルーチンID欄273には、各サブルーチンのサブルーチンIDが格納される。JITフラグ欄275には、各サブルーチンのJITが格納される。実行アドレス欄277には、JITフラグの種類、すなわち各サブルーチンのコードの種類に応じて、以下のアドレスが格納される。
(1)yes:ネイティブコードの先頭アドレス
(2)pre:第2コードの先頭アドレス
(3)no,req:第1コードの先頭アドレス
JITフラグが変化した場合、上記の基準に基づいて、サブルーチン管理回路171によって、実行アドレス欄277が書き換えられる。
優先度欄279には、各サブルーチンの優先度(参照回数)が格納され、各サブルーチンが呼び出されるたびに、サブルーチン管理回路171によって1が加算される。キャッシュアウトカウント欄281には、優先度と同じ基準で増加する値であるキャッシュアウトカウントが格納される。
また、実施例では、優先度はコンテンツが終了しても値が保持されるが、キャッシュアウトカウントは、サブルーチン管理表203へのエントリの書き戻し時に値が0にクリアされるという相違点を持たせた。これにより、優先度は、1つのコンテンツ107内における各サブルーチンのプリコンパイルすべき順番を表し、キャッシュアウトカウントは、サブルーチン管理表キャッシュ205内における各サブルーチンのプリコンパイルすべき順番を表すことができる。
キャッシュアウトカウントをコンテンツ終了時まで保持させたい場合、サブルーチン管理表203の基本構成211内にキャッシュアウトカウントを記録する欄を別途設け、サブルーチン管理表キャッシュ205から書き戻されたエントリのキャッシュアウトカウントを管理すればよい。なお、キャッシュアウトカウントは、0以下には減算されず、一定の値を超えると加算されない。
図3は、プリコンパイル回路173の動作速度を定める動作速度定義表301の一例を示す。この表は、プリコンパイル対象のサブルーチンの第1コードを処理する際に、プリコンパイル制御回路175がプリコンパイル回路173の動作速度を制御するために利用される。
動作速度定義表301は、動作速度欄303、優先度範囲欄305、及びサブルーチン定義値欄307で構成される各種の項目を有する。
動作速度欄303には、プリコンパイル回路173の動作速度を表す値が格納される。本実施例では、この値が大きいほど、プリコンパイル回路173が高速で動作することを意味する。
優先度範囲欄305には、各動作速度が適用されるサブルーチンの優先度の範囲が格納される。例えば、優先度(実施例では参照回数)が0〜50の範囲内にあるサブルーチンの第1コードは、対応する動作速度“1”で動作するプリコンパイル回路173によってプリコンパイルされる。
サブルーチン定義値欄307には、例えば、以下の(1)〜(3)の情報に基づいて、各サブルーチンの第1コード119の生成時に付与される値が格納される。
(1)コンテンツ107に含まれる各サブルーチンの第1コード119を第2コード121へ変換するのに要する時間
(2)コンテンツ107に含まれる各サブルーチンの第1コード119をネイティブコード131へ変換するのに要する時間
(3)コンテンツ107の実行中に各サブルーチンが呼び出される頻度。
上記の情報に基づいて付与されるサブルーチン定義値は、例えば、Javaバイトコード等の第1コード119を生成する際に用いるコンパイラの機能によって、第1コード119内に記述することができる。例えば、任意の箇所にコメントとして埋め込んだり、ヘッダ情報として埋め込むことができる。実施例では、コンテンツ107の実行中に呼び出されたサブルーチンの第1コード119にサブルーチン定義値が記述されていれば、プリコンパイル回路173の動作速度をサブルーチン定義値で判断し、記述されていなければ優先度で判断することとしている。なお、サブルーチン定義値として“3”が付与されているサブルーチンの第1コード119は、動作速度“3”で動作するプリコンパイル回路173によってプリコンパイルされる。
動作速度定義表301を作成する際には、例えば、サブルーチンの優先度及びサブルーチン定義値の値が大きくなるに連れて、プリコンパイル回路173の動作速度が大きくなるようにするのがよい。具体的には、サブルーチンの優先度又はサブルーチン定義値の値が大きくなるに連れて、プリコンパイル回路173のクロック(動作周波数)を増加させる方法を採用することができる。また、サブルーチンの優先度又はサブルーチン定義値の値が小さくなるに連れて、プリコンパイル回路173のクロックを大きな値で分周する方法を採用することができる。
そして、サブルーチンの優先度又はサブルーチン定義値に基づいて決定される動作速度が小さければ、プリコンパイル制御回路175がプリコンパイル回路173を低速で動作させることにより、消費電力を低く抑えることができる。これに加えて、プリコンパイル回路173の動作速度を小さくするだけでなく、プリコンパイル回路173の動作を維持できる電圧値の範囲内で供給電圧を下げることにより、消費電力をさらに低く抑えることができる。
なお、本実施例では、プリコンパイル回路173の動作速度を決定するための判断材料として、サブルーチンごとの優先度とサブルーチン定義値を採用しているが、いずれか一方だけを、サブルーチンの第1コード119を第2コード121へ変換する優先度として採用し、その値によって動作速度を判断するように構成してもよい。
図4は、コンテンツ107の実行時におけるメモリ117、不揮発性記録媒体115、キャッシュメモリ177の構成、及びこれらを利用したハードウェア105の基本動作を示す。
メモリ117には、コンテンツ107、再生アプリ125、OS127、第2コード121、ネイティブコード131、サブルーチン管理表203、コンテンツ管理表201、動作速度定義表301、サブルーチン管理プログラム133、及びプリコンパイル制御プログラム135が格納されており、携帯電話機101の動作時に適宜参照され又は実行される。この図では、コンテンツ107として、Aコンテンツ107a,Bコンテンツ107b等の複数のコンテンツが格納されている状態を示す。また、メモリ117上のこれらのデータのうち、第2コード121及びネイティブコード131以外のデータについては、携帯電話機101の起動時及びコンテンツ107の起動時に、不揮発性記録媒体115からメモリ117上にロードされる。
キャッシュメモリ177上には、サブルーチン管理表203の一部又は全部を含んで構成されるサブルーチン管理表キャッシュ205が格納されている。
不揮発性記録媒体115には、OSイメージ401、再生アプリ125、コンテンツ107、その他のアプリ/データ403、サブルーチン管理プログラム133、及びプリコンパイル制御プログラム135等のデータが保存されている。これらのデータは、例えば、携帯電話機101の起動時やコンテンツ107の起動時等のタイミングで、メモリ117上に読み込まれ、携帯電話機101の電源遮断時やコンテンツ107の実行終了時等のタイミングで、メモリ117から変更箇所が書き戻される。
次に、第1コード処理部123の基本動作について説明する。まず、コンテンツ107の実行時にサブルーチンの呼び出しが発生すると、プロセッサ113がサブルーチン管理表キャッシュ205を参照する。サブルーチン管理回路171は、これに応じてサブルーチン管理表キャッシュ205内を検索し、呼び出し先のサブルーチンの情報をプロセッサ113に返す。プロセッサ113は、その情報に基づいて処理を実行する。
また、サブルーチン管理回路171は、サブルーチン管理表キャッシュ205を更新し、プリコンパイル制御回路175へ更新を通知する。
プリコンパイル制御回路175は、この更新内容とシステムの状態などを判断して、プリコンパイル回路173に、特定の第1コード119をプリコンパイルさせ、生成された第2コード121をメモリ117に保存させる。
なお、第2コード121は、後述するタイミングで、再生アプリ125内のJITコンパイラ159によってコンパイルされ、ネイティブコード131としてメモリ117上に格納される。
図5は、コンテンツ107の実行開始時におけるプロセッサ113及びサブルーチン管理回路171の処理のフローチャートを示す。携帯電話機101で、ユーザが操作ボタン等の周辺機能部111を操作するなど、何らかのきっかけによりコンテンツ107の実行が指示されると、プロセッサ113がサブルーチン管理回路171に本処理を要求し、これにより本処理が開始する。
まず、サブルーチン管理表キャッシュ205から、実行するコンテンツ107のコンテンツIDに対応しないエントリをサブルーチン管理表203へ書き戻する(ST501)。なお、実行対象のコンテンツ107のほかに、別のコンテンツを実行していなかった場合、サブルーチン管理表キャッシュ205にはエントリが存在しないと思われるため、このステップを省略することができる。
次に、サブルーチン管理表203から、実行するコンテンツ107のコンテンツIDに対応するエントリのうち、サブルーチン管理表キャッシュ205に存在しないものを、優先度の高いものから順に、サブルーチン管理表キャッシュ205に転送する(ST502)。
そして、コンテンツ107の実行開始時に実行されるサブルーチン(例えば、メインルーチン)のサブルーチンIDを、コンテンツ107から取得する(ST503)。
ST503の後、プロセッサ113及び第1コード処理部123によって実行されるサブルーチン管理表検索・実行処理が開始する(ST504)。
なお、携帯電話機101でコンテンツ107を初めて実行する場合において、サブルーチン管理表203内の優先度欄221の各エントリの値が“0”のときは、ST502の処理として、実行対象のコンテンツ107内で予め決めておいたサブルーチンのエントリをサブルーチン管理表キャッシュ205に転送すればよい。例えば、コンテンツ107に含まれるサブルーチンの先頭のエントリから順に所定の数のエントリを転送することができる。この場合、第1コード119の生成時に、呼び出し関係のあるサブルーチン同士をコンテンツ107内で隣接させておくことで、最初の実行においても効率的にサブルーチンの呼び出しが行えるようになり、キャッシュ効率が向上する。
図6は、プロセッサ113及びサブルーチン管理回路171によるサブルーチン管理表検索・実行処理(図5のST504)のフローチャートを示す。この処理では、サブルーチンの呼び出しが発生したときに、サブルーチン管理表203及びサブルーチン管理表キャッシュ205から該当するサブルーチンの情報を抽出して処理方式を選択し、その処理方式に応じて各コードが実行される。
まず、サブルーチン管理回路171は、サブルーチンの呼び出しが発生すると、サブルーチンIDを用いて、該当するサブルーチンをサブルーチン管理表キャッシュ205内で検索し(ST601)、該当するエントリが存在するかどうかを判断する(ST602)。この検索処理は、プロセッサ113が実行しても良いが、実施例のように、サブルーチン管理回路171が実行する構成にすれば、検索が終了するまでの間、プロセッサ113はI/O等の他の処理を実行することが可能となる。
サブルーチン管理回路171は、検索の結果、対応するエントリが存在しなければ(ST602の判断が“N”の場合)、後述するサブルーチン管理表キャッシュ更新処理を実行し(ST603)、ST602へ戻る。該当するエントリが存在すれば(ST602の判断が”Y”の場合)、エントリのキャッシュアウトカウントに“1”を加算し(ST604)、そのエントリの優先度に“1”を加算する(ST605)。このキャッシュアウトカウントと優先度の加算処理は、プロセッサ113で実行されるように構成してもよい。
次に、サブルーチン管理回路171は、エントリからJITフラグの情報を抽出し(ST606)、その値に応じて処理を分岐する(ST607)。JITフラグが“yes”の場合、サブルーチン管理表キャッシュ205から、対応するエントリの実行アドレスとして、サブルーチンのネイティブコード131の先頭アドレスを取得し、プロセッサ113へ渡す。これにより、プロセッサ113は、実行対象のサブルーチンのネイティブコード131へジャンプし(ST608)、このネイティブコードを実行する(ST609)。ST608又はST609の処理を行うとき、2回目以降の呼び出しを高速化するため、呼び出し元のコードがこのサブルーチンのネイティブコード131へジャンプできるように、呼び出し元のコードを変更してジャンプ先のアドレスを書き加えるように構成してもよい。このコード書き換え処理は、プロセッサ113及びサブルーチン管理回路171のどちらが行ってもよい。
プロセッサ113は、サブルーチンのネイティブコード131の実行中に別のサブルーチンの呼び出しがあるかどうかを判断し(ST610)、別のサブルーチンの呼び出しがさらに発生した場合(ST610の判断が“Y”の場合)、サブルーチン管理表検索・実行処理が再帰的に実行され(ST611)、ST609及びST610を繰り返す。一方、プロセッサ113は、別のサブルーチンの呼び出しがないままサブルーチンのネイティブコード131の実行が完了すると(ST610の判断が“N”の場合)、呼び出し元のサブルーチンの処理へ戻る。
サブルーチン管理回路171は、ST607の処理において、JITフラグが“pre”と判断された場合、サブルーチン管理表キャッシュ205の実行アドレスとして、サブルーチンの第2コード121の先頭アドレスをプロセッサ113へ渡す。プロセッサ113は、これに基づいて、第2コード121をJITコンパイラ159にコンパイルさせ(ST612)、エラーが発生しないかどうかをチェックする(ST613)。エラーの内容としては、例えば、ネイティブコード格納用のメモリ領域が不足した場合、及びコンパイルエラーが発生した場合などが考えられる。JITコンパイラ159によって生成されるネイティブコード131は、JITコンパイラ159によって、メモリ117へ順次格納され、又はJITコンパイルが完了してからまとめて格納される。
プロセッサ113は、JITコンパイル中にエラーが発生した場合(ST613の判断が“Y”の場合)、その第2コード121に対応する第1コード119をインタプリタ157に実行させる(ST617)。
プロセッサ113は、JITコンパイル中にエラーが発生しなかった場合(ST613の判断が“N”の場合)、それをサブルーチン管理回路171に通知する。これにより、サブルーチン管理回路171は、サブルーチン管理表キャッシュ205内のJITフラグを“yes”に変更し、生成されたネイティブコード131の先頭アドレスを実行アドレスとして記録する(ST614)。そして、プロセッサ113は、JITコンパイラ159に生成させたネイティブコード131へジャンプし、これを実行する(ST609)。以後、前述のとおり、ST609からST611の処理が繰り返される。なお、ネイティブコード131のメモリ117への格納は、図示のようにネイティブコード131への変換が完了してから行ってもよいし、コンパイルされたコードを逐次格納するように構成してもよい。
サブルーチン管理回路171は、ST607の処理において、JITフラグが“no”又は“req”と判断された場合、プリコンパイル回路173が別のサブルーチンの第1コード119をプリコンパイルしているかどうか、すなわちプリコンパイルをすぐに行える状態かどうかを判断する(ST615)。このような判断は、プリコンパイル回路173がいずれかのサブルーチンの第1コード119をプリコンパイルしているかどうかを示す、いわゆるフラグ等の情報を利用して行うことができる。
サブルーチン管理回路171は、プリコンパイル回路173が他のサブルーチンの第1コード119をプリコンパイルしている(JITフラグが“req”を示す別のサブルーチンのエントリが存在する)ことにより、すぐにはプリコンパイルを行えないと判断した場合(ST615の判断が“N”の場合)、サブルーチン管理表キャッシュ205のJITフラグを“req”に変更し(ST616)、プリコンパイル待ちの状態にする。この場合、後述の方法により選択されるサブルーチンの第1コード119から順に第2コード121が生成されることになる。なお、ST607の処理でJITフラグが“req”と判断された場合、呼び出されたサブルーチンは、それより前にも呼び出されたことがあり、且つ未だその第1コード119が第2コード121に変換されていないこと(プリコンパイル待ちの状態)を示す。この場合には、ST616の処理において、JITフラグ(req)を維持するように構成すればよい。
一方、サブルーチン管理回路171は、プリコンパイル回路173でプリコンパイルを行えると判断した場合(ST615の判断が“Y”の場合)、後述の方法により、プリコンパイル回路173に対し、処理対象のサブルーチンの第1コード119から第2コード121を生成させる。
その後、サブルーチン管理回路171は、呼び出されているサブルーチンの実行アドレスとして、そのサブルーチンの第1コード119の先頭アドレスをサブルーチン管理表キャッシュ205から抽出し、プロセッサ113へ渡す。プロセッサ113は、第1コード119の実行アドレスに基づいて、インタプリタ157に第1コード119を実行させる(ST617)。
プロセッサ113は、インタプリタ157に第1コード119を実行させている間、別のサブルーチンの呼び出しがさらに発生したかどうかを判断し(ST618)、別のサブルーチンの呼び出しがさらに発生した場合(ST618の判断が“Y”の場合)、サブルーチン管理表検索・実行処理が再帰的に実行され(ST619)、ST617及びST618を繰り返す。一方、プロセッサ113は、別のサブルーチンの呼び出しがないままインタプリタ157による処理(ST617)が完了すると(ST618の判断が“N”の場合)、呼び出し元のサブルーチンの処理へ戻る。
図7は、プリコンパイル時における第1コード処理部123の動作のフローチャートを示す。まず、携帯電話機101が起動すると、プリコンパイル制御回路175に対し、パラメータの初期設定が行われる(ST701)。パラメータの設定は、サブルーチン管理回路171及びプロセッサ113のどちらが行ってもよい。このパラメータとしては、例えば、動作速度定義表301の値である。なお、動作速度定義表301は、メモリ117上に格納されているので、パラメータを設定する処理を省略し、プリコンパイル制御回路175が必要に応じてメモリ117上の動作速度定義表301を参照するように構成してもよい。また、動作速度定義表301をキャッシュメモリ177上に格納しておき、これを参照するように構成してもよい。
パラメータの設定(ST701)が完了すると、サブルーチン管理回路171は、サブルーチン管理表キャッシュ205の内容が変更(更新)されるまで待機し(ST702の判断が“N”の場合)、サブルーチン管理表キャッシュ205の変更(更新)を検出すると(ST702の判断が“Y”の場合)、プリコンパイル制御回路175を起動する(ST703)。
次に、サブルーチン管理回路171は、メモリ117の空き容量が不十分かどうかを調べる(ST704)。メモリ117の空き容量が不十分であれば(ST704の判断が“N”の場合)、処理を終了する。メモリ117の空き容量の判定方法としては、例えば、メモリ117の使用量があらかじめ定めた閾値を超えた場合にメモリ不足と判定するなどの方法を適用することができる。
メモリ117の空き容量が十分あれば(ST704の判断が“Y”の場合)、メモリ117上にプリコンパイル対象のサブルーチンを利用するコンテンツ107が存在するかどうかを調べる(ST705)。メモリ117上に対応するコンテンツ107が存在しない場合(ST705の判断が“Y”の場合)は、処理を終了する。
メモリ117上にコンテンツ107が存在する場合(ST705の判断が“N”の場合)、サブルーチン管理回路171は、サブルーチン管理表キャッシュ205の更新(変更)をプリコンパイル制御回路175に通知する(ST706)。
プリコンパイル制御回路175は、サブルーチン管理回路171からの通知があると、サブルーチン管理表キャッシュ205内のエントリの更新(変更)部分を検査し(ST707)、JITフラグが“no”又は“req”のエントリが存在するかどうかを判断する(ST708)。
JITフラグが”no”又は”req”のエントリが存在しない場合(ST708の判断が“Y”の場合)は、処理を終了する。JITフラグが”no”又は”req”のエントリが存在する場合(ST708の判断が“N”の場合)、サブルーチン管理回路171は、プリコンパイル対象のエントリが複数存在するかどうか、すなわちJITフラグが“req”のエントリが複数存在するかどうかを調べる(ST709)。
プリコンパイル対象のエントリが複数存在する場合(ST709の判断が“Y”の場合)、サブルーチン管理回路171は、プリコンパイルの優先度を判断して対象エントリ選択する(ST710)。優先度としては、例えば、サブルーチン管理表203又はサブルーチン管理表キャッシュ205内にある優先度欄279の値を採用することができる。この場合、優先度の高いサブルーチンから順に、第1コード119を第2コード121へ変換するのがよい。
プリコンパイルの対象エントリが1つしかない場合(ST709の判断が“N”の場合)、又はST710でプリコンパイルの対象エントリを選択した場合、プリコンパイル制御回路175は、インタプリタ実行のバックグラウンドでプリコンパイルを実行できるシステム状態かどうかを調べる(ST711)。バックグラウンドで実行できない場合とは、例えば、
(1)バス103の負荷が予め定めた閾値より高い場合
(2)メモリ117を複数搭載する場合において、プリコンパイル対象の第1コード119が存在するメモリ17へのプロセッサ113によるアクセス頻度が、予め定めた閾値より高い場合
などが考えられる。
プリコンパイルをインタプリタ実行のバックグラウンドで実行できない場合(ST711の判断が“Y”の場合)は、システム状態が回復するまで待機する。プリコンパイルをインタプリタ実行のバックグラウンドで実行できる場合(ST711の判断が“N”の場合)、プリコンパイル制御回路175は、プリコンパイル回路173を起動し(ST712)、後述(図9)のプリコンパイル回路173の動作速度制御を開始する(ST713)。
プリコンパイル制御回路175は、プリコンパイル回路173の動作速度制御を開始すると、さらにシステム状態を監視し、システム状態が悪化したかどうかを検査する(ST714)。システム状態が悪化すると(ST714の判断が“Y”の場合)、プリコンパイル回路173にプリコンパイルを一時停止させる(ST715)。ここで、システム状態の悪化とは、例えば、バス103の負荷があらかじめ定めた閾値より高い場合や、メモリ117を複数搭載する場合において、プリコンパイル対象の第1コード119が存在するメモリ117へのプロセッサ113によるアクセス頻度が予め定めた基準より高い場合などが考えられる。
システム状態が悪化しなければ(ST714の判断が“N”の場合)、プリコンパイルを継続させ(ST716)、プリコンパイルが完了したかどうかを判断する(ST717)。プリコンパイルが完了していなければ(ST717の判断が“N”の場合)、ST713へ戻る。プリコンパイルが完了した場合(ST717の判断が“Y”の場合)、サブルーチン管理回路171は、プリコンパイル待ちの他のサブルーチンのエントリが存在するかどうかを調べる(ST718)。
プリコンパイル待ちの他のサブルーチンのエントリが存在する場合(ST718の判断が“Y”の場合)、ST709へ戻る。プリコンパイル待ちの他のサブルーチンのエントリが存在しない場合(ST718の判断が“N”の場合)、プリコンパイル制御回路175は、プリコンパイル回路を停止する(ST719)。そして、プリコンパイル制御回路175の動作が停止し(ST820)、処理が終了する。
図8は、プリコンパイルの開始から終了までの間におけるプリコンパイル回路173による処理のフローチャートを示す。この処理は、プリコンパイル制御回路175によってプリコンパイル回路173が起動されること(図7のST712)により開始する。
プリコンパイル回路173は、処理対象のサブルーチンの第1コード119のプリコンパイルを開始すると(ST801)、エラーが発生したかどうかを検出する(ST802)。エラーが発生した場合(ST802の判断が“Y”の場合)、途中まで生成したコードを破棄し(ST803)、プリコンパイル処理を中止する。エラーの内容としては、例えば、第2コード格納用のメモリ領域が不足した場合や、第1コードに不正な値が入っていた等の理由によりコンパイルエラーが発生した場合などの不具合が考えられる。
一方、プリコンパイルが正常に終了すると(ST802が“N”、ST804が“Y”の場合)、プリコンパイル回路173は、
(1)JITフラグを“pre”に変更すること
(2)実行アドレス欄277にサブルーチンの第2コード121の先頭アドレスを格納すること
をサブルーチン管理回路171へ指示する(ST805)。これに基づいて、サブルーチン管理回路171は、サブルーチン管理表キャッシュ205内のJITフラグを“pre”に変更し、生成された第2コード121の先頭アドレスを実行アドレス欄277に保存する。
そして、プリコンパイル回路173は、生成した第2コード121をメモリ117へ格納する(ST806)。メモリ117への格納方法としては、プリコンパイルの最中に生成される第2コード121をメモリ117へ逐次格納するように構成してもよい。また、メインルーチンについては、コンテンツ109の実行時に一度しか実行されない場合が多いため、プリコンパイルを行わず、インタプリタ157でのみ実行するように構成するのがよい。
図9は、プリコンパイル制御回路175によるプリコンパイル回路173の動作速度制御のフローチャートを示す。
プリコンパイル制御回路175は、プリコンパイル回路173が第1コード119のプリコンパイルを行う際(例えば、図7のST716など)、その第1コード119内にサブルーチン定義値が書き込まれているかどうかを調べる(ST901)。第1コード119内にサブルーチン定義値が存在する場合(ST901の判断が“Y”の場合)、その値を動作速度定義表(図3)に照らし、その値に応じた動作速度を抽出する(ST902)。
第1コード119内にサブルーチン定義値が存在しない場合(ST901の判断が“N”の場合)、その第1コード119に対応するサブルーチンの優先度を、サブルーチン管理表キャッシュ205から抽出し(ST903)、取得した優先度を動作速度定義表(図3)に照らし、その優先度に応じた動作速度を抽出する(ST904)。
プリコンパイル制御回路175は、STST902又はST904で抽出した動作速度の値に従って、プリコンパイル回路173の動作速度を制御するとともに、動作速度を下げる場合は、プリコンパイル回路173の動作を維持できる電圧値の範囲内で同回路173への供給電圧値を下げる(ST905)。
図10は、サブルーチン管理回路171によるサブルーチン管理表キャッシュ205の更新処理(図6のST603)のフローチャートを示す。この処理では、サブルーチンの呼び出しが発生した際に、必要に応じて、サブルーチン管理表203とサブルーチン管理表キャッシュ205との間のデータの入れ替えが行われる。
本処理が呼ばれると、まず、以下のようにパラメータを初期化する(ST1001)。
(1)探索位置[pos]=キャッシュの先頭
(2)最小キャッシュアウトカウント値[min]=予め定めた値(例えば、格納可能なキャッシュアウトカウントの最大値[max])
(3)最小キャッシュアウトカウント値を持つエントリ位置[posmin]=キャッシュの先頭。
続いて、posのエントリ[ent]のキャッシュアウトカウント[ent.Cnt]から1を減算し(ST1002)、最小キャッシュアウトカウント値[min]より小さいかどうかを判断する(ST1003)。
ent.Cntがminより小さい場合(ST1003の判断が“Y”の場合)、minにent.Cntを設定し(ST1004)、posminにposを設定する(ST1005)。
ent.Cntがminより大きい場合(ST1003の判断が“N”の場合)又はST1005の後、ent.Cntが0かどうかを判断し(ST1006)、ent.Cntが0ではない場合(判断が“N”の場合)は、全てのエントリを検索し終わったかどうかを判断する(ST1007)。全エントリの検索が終了していない場合(ST1007の判断が“N”の場合)、posに1を加算し(ST1008)、次のエントリについて上記の処理を行う。
ent.Cntが0の場合(ST1006の判断が“Y”の場合)、そのエントリをサブルーチン管理表203へ書き戻す(ST1007)。また、全エントリの検索が終了した場合(ST1007の判断が“Y”の場合)、posminのエントリをサブルーチン管理表203へ書き戻し(ST1010)、posにposminを設定する(ST1011)。
これらの処理により、キャッシュアウトカウント値の最も小さいエントリが、殆ど参照されていないエントリとして検出され、サブルーチン管理表キャッシュ205からサブルーチン管理表キャッシュ203へ書き戻すべきエントリを合理的に判断することができる。
ST1009又はST1011の後、プロセッサ113が参照しようとしているサブルーチンに対応するエントリをサブルーチン管理表203内で検索し(ST1012)、そのエントリをサブルーチン管理表キャッシュ805内のposが示す位置へ読み込み(ST1013)、サブルーチン管理表キャッシュ205の更新処理が終了する。
図11は、携帯電話機101の基本動作のシーケンシャル図を示す。このシーケンシャル図は、携帯電話機101が起動(電源ONなど)してからシステム停止に至るまでの処理の流れを表している。
まず、携帯電話機101が起動すると、プロセッサ113が携帯電話機101を初期化する(ST1101)。この処理では、各種のハードウェア105の初期化、及びメモリ117の内容の0クリア等の処理が行われる。
プロセッサ113は、初期化が完了すると、不揮発性記録媒体115から、OS127、再生アプリ125、コンテンツ管理表201、サブルーチン管理表203、及び動作速度定義表301をメモリ117へ転送する(ST1102)。
そして、サブルーチン管理回路171は、サブルーチン管理表203内のエントリを、優先度(実施例では参照回数)の多いものから順に、キャッシュメモリ177上のサブルーチン管理表キャッシュ205へ転送する(ST1103)。転送が完了すると、サブルーチン管理回路171は、サブルーチン管理表203から転送したエントリのキャッシュ欄223のサブ項目について、ステート欄231を“yes”に変更し、回数欄233に“1”を加算する(ST1104)。
次に、プロセッサ113は、サブルーチン管理表203内でキャッシュフラグ(ステート欄231)が“yes”のエントリに対応するコンテンツ107を、不揮発性記録媒体115からメモリ117へ転送する(ST1105)。これが完了すると、プロセッサ113及び第1コード処理部123によるコンテンツ107の実行等の通常動作が行われる(ST1106)。
通常動作(ST1106)の途中で、例えばユーザの操作により携帯電話機101の終了(電源OFFなど)が指示されると、サブルーチン管理回路171は、サブルーチン管理表キャッシュ205内の全エントリをサブルーチン管理表203へ書き戻す(ST1107)。そして、サブルーチン管理回路171は、サブルーチン管理表203内で、キャッシュ回数が“0”のエントリの優先度の値を半減させる(ST1108)。これにより、利用頻度の低いエントリのプリコンパイルの優先度を下げることができる。なお、優先度の半減は一例であり、例えば、優先度から一定の値を減算したり、一定の値で除算してもよい。
ST1108の後、プロセッサ113は、サブルーチン管理表203を不揮発性記録媒体115へ書き戻し(ST1109)、携帯電話機101を停止する(ST1110)。この際、サブルーチン管理表203の変更箇所のみを不揮発性記録媒体115へ書き戻すように構成してもよい。
図12は、サブルーチン管理回路171によるコンテンツ終了処理のフローチャートを示す。この処理は、例えば、ユーザによってコンテンツ107の終了が指示されたとき、別のコンテンツを実行するとき、及びサーバから別のコンテンツをダウンロードして実行するときのいずれかのタイミングで実行される。実施例の携帯電話機101は携帯型の組込み機器であるため、プロセッサ113やメモリ117等のハードウェア105のリソースが厳しく制限されるため、別のコンテンツを実行する際には、この終了処理を行うことにより、実行中のコンテンツ107を強制的に終了する。
まず、コンテンツ107の終了が指示されると、サブルーチン管理表キャッシュ205から終了するコンテンツ107に対応するエントリをサブルーチン管理表203へ書き戻す(ST1201)。そして、メモリ117の空き容量が十分にあるかどうかを検査する(ST1202)。容量が十分ある状態とは、例えば、別のコンテンツをメモリ117上にロードできるだけの容量が空いていることをいう。メモリ117上に十分な空き容量がある場合(ST1202の判断が“Y”の場合)、コンテンツ終了処理を終了する。
メモリ117上に十分な空き容量がない場合(ST1202の判断が“N”の場合)、不揮発性記録媒体115内にこのコンテンツ107が存在するかどうかを判断する(ST1203)。不揮発性記録媒体115内にこのコンテンツ107が存在する場合(ST1203の判断が“Y”の場合)、このコンテンツ107をメモリ117上から削除し(ST1204)、コンテンツ終了処理を終了する。
不揮発性記録媒体115内にこのコンテンツ107が存在しない場合(ST1204の判断が“N”の場合)、ユーザによる保存の指示があったかどうかを判断する(ST1205)。ユーザによる保存の指示があった場合(ST1205の判断が“Y”の場合)、不揮発性記録媒体115にコンテンツ107を保存し(ST1007)、そのコンテンツ107をメモリ117上から削除し(ST1204)、コンテンツ終了処理を終了する。
一方、ユーザによる保存の指示がなかった場合(ST1205の判断が“N”の場合)、コンテンツ107をメモリ117上から削除し(ST1204)、コンテンツ終了処理を終了する。なお、ST1204の処理では、サブルーチン共用表243に基づいて、終了するコンテンツ107の第1コード119が他のコンテンツとの間で共用されていると判断される場合、その共用されている第1コード119をメモリ117上に保持するように構成することができる。
なお、ST1202〜ST1206の処理は、プロセッサ113が行うように構成してもよい。
以上の説明(図1〜図12)を整理すると、実施例の携帯電話機101は、以下の構成を有する。
(1)Javaプログラム(コンテンツ)107に含まれる複数のサブルーチンごとに、プロセッサ113で実行可能なネイティブコード131、ネイティブコード131の元となるOSに依存しない第1コード(Javaバイトコード)119、第1コード119をネイティブコード131へコンパイルする過程で生成される第2コード121のうち、存在し実行するコードの種類を管理するサブルーチン管理表203を記憶するメモリ117を備える。また、このメモリ117には、サブルーチンごとに所定の基準に基づいて定められる、第1コード119から第2コード121を生成する優先度に応じて、プリコンパイル回路173の動作速度を定めた動作速度定義表が記憶される。
(2)サブルーチン管理表203の内容の一部をサブルーチン管理表キャッシュ205として記憶するキャッシュメモリ177を備える。
(3)第1コード119をインタプリタ方式で実行するインタプリタ157、及び第2コード121をコンパイルしてから実行するJITコンパイラ159を有する仮想マシン153を備える。
(4)第1コード119から第2コード121を生成するプリコンパイル回路173を備える。
(5)コンテンツ107の実行中に呼び出されたサブルーチンについて、サブルーチン管理表キャッシュ205を参照した結果、ネイティブコード131が存在するときは、そのネイティブコード131がプロセッサ113で実行され、第2コード121が存在するときは、その第2コード121が仮想マシン153のJITコンパイラ159で実行され、生成されたネイティブコード131がメモリ117に格納され、又は第1コード119が存在するときは、その第1コード119が仮想マシン153のインタプリタ157で実行されるとともに、プリコンパイル回路173で第2コード121に変換され、その第2コード121がメモリ117に格納されるように実行制御を行うサブルーチン管理手段(サブルーチン管理プログラム133及びサブルーチン管理回路171)を備える。
(6)また、サブルーチン管理回路171は、それらの制御によりサブルーチンのコードの種類が変化したときは、変化後の種類がサブルーチン管理表キャッシュ205に記録されるように記録制御を行う。また、この記録制御として、サブルーチン管理回路171は、コンテンツ107の実行中に呼び出されたサブルーチンごとの回数が、サブルーチン管理表キャッシュ205に優先度として記録されるように制御を行う。
(7)さらに、サブルーチン管理回路123は、コンテンツ107の起動時やサブルーチンの呼び出し時等の所定のタイミングで、サブルーチン管理表203とサブルーチン管理表キャッシュ205との間でデータの転送及び書き換えが行われるようにキャッシュ制御を行う。
(8)サブルーチン管理回路171は、サブルーチン管理プログラム133を実行するプロセッサ113の制御のもとで、サブルーチンごとに所定の基準に基づいて定められる、第1コード119を第2コード121へ変換する優先度の高いサブルーチンから順に、その第1コード119が第2コード121に変換されるように実行制御を行う。
(9)サブルーチンの優先度を用いて、動作速度定義表301から動作速度を判断し、その動作速度に従ってプリコンパイル回路173が動作するように制御を行うプリコンパイル制御手段(プリコンパイル制御プログラム135及びプリコンパイル制御回路175)を備える。また、プリコンパイル制御回路175は、プリコンパイル回路173の動作速度を下げたとき、プリコンパイル回路173への供給電圧を、その動作を維持できる電圧値の範囲内で下げる。実施例では、優先度として、コンテンツ107の実行中に呼び出されたサブルーチンごとの回数を採用している。
(10)サブルーチン管理回路171は、コンテンツの実行開始時において、サブルーチン管理表203に優先度が記録されている場合は、実行対象のコンテンツ107に含まれるサブルーチンの情報が、優先度の高いものから順に、サブルーチン管理表203からサブルーチン管理表キャッシュ205へ書き込まれるようにキャッシュ制御を行う。また、コンテンツ107の実行中において、呼び出されたサブルーチンの情報がサブルーチン管理表キャッシュ205にない場合は、サブルーチン管理表キャッシュ205にある優先度(実施例では、キャッシュアウトされるたびに値がクリアされる各エントリの参照回数であるキャッシュアウトカウントの値)の最も低いサブルーチンの情報がサブルーチン管理表203へ書き戻され、呼び出されたサブルーチンの情報がサブルーチン管理表203からサブルーチン管理表キャッシュ205へ書き込まれるようにキャッシュ制御を行う。
このように、第1コード119を第2コード121へ変換する処理(プリコンパイル)を、プリコンパイル専用の回路(プリコンパイル回路173)を用いて行うことにより、インタプリタ157による第1コード119の処理とは完全に独立した状態(プロセッサ113が使用されない状態)で、プリコンパイルを行うことができる。従って、プリコンパイル回路173とインタプリタ157による各処理を、同時に且つ高速に実行することができるため、コンテンツ107の実行速度の高速化を図ることができる。さらに、JITコンパイラ159は、予めプリコンパイルされた第2コード121をコンパイルすることになるため、JITコンパイル(ネイティブイコード131の生成)の処理速度の向上を図ることができる。
[実施例2]
次に、実施例2として、本発明を適用した携帯電話機101を用いて、コンテンツ配信サーバ1301から既存コンテンツ107の一部又は新しいコンテンツ1303の全部を受信する方法を説明する。実施例2においては、実施例1で説明した携帯電話機101の機能については説明を省略するとともに、同じ要素については同一の符号を付した。
図13は、携帯電話機101及びコンテンツ配信サーバ1301のそれぞれの構成及び連携方法を示す。携帯電話機101とコンテンツ配信サーバ1301は、インターネット等の通信ネットワークを介して接続される。
携帯電話機101は、サブルーチン管理表203の拡張構成213のうち、ハッシュ値管理表237及びダウンロード元管理表259については、これらを組み合わせて構成したクライアントサブルーチンリスト1305として有している。
クライアントサブルーチンリスト1305は、各サブルーチンのダウンロード元のURL(サーバURL)、サブルーチンID、ハッシュ値、及びサーバ通知状況を格納する。実施例2では、サブルーチンID、サブルーチン名、及びハッシュ値は、コンテンツ配信サーバ1301側でサブルーチンごとに付与される。
コンテンツ配信サーバ1301は、複数のコンテンツ107,1303等のほかに、
コンテンツ107,1303に含まれるサブルーチンごとに、サブルーチンID、サブルーチン名、及びハッシュ値を管理するサーバサブルーチンリスト1307と、
各サブルーチンに対して一意なIDを割り当てるサブルーチンIDカウンタ1309と、
サーバサブルーチンリスト1307に、各サブルーチンの情報が初めて登録されるとき及び変更されたサブルーチンの情報が登録されたときに、そのサブルーチンに対してハッシュ値を生成し、サーバサブルーチンリストへ登録するハッシュ値生成部1310と、
Webサーバが通常備える各種機能を有するとともに、携帯電話機101との間でコンテンツ等の情報通信を行うために必要な各種機能を有する配信機能部1311と
を含んで構成される。
サーバ側のコンテンツ1303も、第1コード1313と、テキストデータ及び各種バイナリデータ等で構成されるその他のデータ1315によって構成される。
ハッシュ値生成部1310によるハッシュ値の生成方法としては、例えば、各サブルーチンの第1コード1313の全文に基づいてハッシュ関数を用いて生成する方式、又は各第1コード1313の改変を検出できる最小限の間隔で抽出した1バイトの値に基づいてハッシュ関数を用いて生成する方式が適用可能である。上記改変を検出できる最小限の間隔は、例えば、数バイトから数十バイトの間隔である。
また、コンテンツ配信サーバ1301は、コンテンツ107,1301等のコンテンツIDとこれらに含まれるサブルーチンごとのサブルーチンIDとを管理する、コンテンツ管理表(図2)201と同様のサーバコンテンツ表(図示省略)を備えている。コンテンツ配信サーバ1301は、携帯電話機101へコンテンツ107,1301のサブルーチンの第1コード119,1313等のデータを送信する際に、各サブルーチンに対応するコンテンツIDの情報も併せて送信する。
次に、図13及び図14を用いて、携帯電話機101がコンテンツ配信サーバ1301からコンテンツ107,1303をダウンロードする方法を説明する。図13には、図14で説明する処理を図示したので、適時参照されたい。
図14は、携帯電話機101のサブルーチン管理部171(図1)によるコンテンツ登録処理のフローチャートを示す。この処理は、ユーザの指示により、携帯電話機101からコンテンツ配信サーバ1301側へコンテンツの配信を要求した場合に実行される。具体的には、ユーザが携帯電話機101を用いて、ダウンロード可能な複数のコンテンツ107,1303等が表示されたウェブサイトへアクセスし、所望のコンテンツをダウンロードする操作を行った場合に実行される。
まず、サブルーチン管理回路171は、ユーザの指示に応じて、コンテンツ配信サーバ1301に対し、ダウンロードしようとするコンテンツに関するサーバサブルーチンリスト1307の情報の送信を要求し(ST1401)、その情報が送信されるまで待機する(ST1402)。
サーバサブルーチンリスト1307の情報を受信すると(ST1402の判断が“Y”の場合)、サーバサブルーチンリスト1307とクライアントサブルーチンリスト1305とを比較し、ハッシュ値に基づいて、両リスト1305,1307内で重複するサブルーチンを検出する(ST1403)。ここで、重複するサブルーチンがない場合、そのコンテンツは、新しくダウンロードするコンテンツ1303である。
一方、重複するサブルーチンが存在する場合、ダウンロードしようとしているコンテンツは、既に携帯電話機101にダウンロードされているが、そのダウンロードの後に修正され若しくは追加されたサブルーチンを含むコンテンツ107、又は携帯電話機101にダウンロードされていないが、幾つかのサブルーチンが既にインストールされている別のコンテンツとの間で共用されているコンテンツ1303である。
サブルーチン管理回路171は、ST1403で検出したサブルーチンの重複情報をコンテンツ配信サーバ1301へ通知し(ST1405)、サーバ側から送信されるデータの受信が開始するまで待機する(ST1405)。コンテンツ配信サーバ1301からは、重複しないサブルーチンの第1コード119,1313等のデータが送信される。サブルーチン管理回路171は、受信を開始すると(ST1405の判断が“Y”の場合)、そのデータを不揮発性記録媒体115へダウンロードする(ST1406)。そして、ダウンロードが完了すると、ダウンロードしたデータをメモリ117上に転送する(ST1407)。
次に、サブルーチン管理回路171は、ダウンロードしたデータが、新しいコンテンツのデータかどうかを判断する(ST1408)。そして、新しいコンテンツ1303のデータ1313,1315をダウンロードした場合(ST1408の判断が“Y”の場合)、そのコンテンツ1303にコンテンツIDを割り当て、コンテンツ管理表201(図2)にその情報を登録する(ST1409)。この際、既存のコンテンツ107との間で幾つかのサブルーチンを共用することになった場合、その共用関係を動的にライブラリ化する(サブルーチン共用表243に登録する)ように構成しておくのがよい。
既存のコンテンツ107のデータをダウンロードした場合(ST1408の判断が“N”の場合)、又はST1409の後、サブルーチン管理手段を構成するサブルーチン管理回路171は、ダウンロードしたコンテンツ1303の各サブルーチンに関する情報に基づいて、サブルーチン管理表203を更新する(ST1410)。
サブルーチン管理表203の更新処理の際には、各項目に対して以下の値を格納する。
(1)コンテンツID欄215:サーバで割り当てられたコンテンツIDを格納する
(2)サブルーチンID欄217:サーバで割り当てられたサブルーチンIDを格納する
(3)JITフラグ欄219:“no”に設定する
(4)キャッシュ欄223:ステートは“no“、回数は“0”に設定する
(5)第1コードアドレス欄225:第1コード119の先頭アドレスを格納する
(6)処理アドレス欄227:“null(例えば、“−1”)”を格納する
次に、クライアントサブルーチンリスト1305を更新し(ST1411)、処理を終了する。具体的には、クライアントサブルーチンリスト1305の各項目に対して以下の値を格納する。
(1)サーバURL欄:ダウンロード元であるコンテンツ配信サーバ1301のURLを格納する
(2)サブルーチンID欄:サーバで割り当てられたサブルーチンIDを格納する
(3)ハッシュ値欄:サーバから受信したサーバサブルーチンリストの情報に基づいて、ハッシュ値を格納する
(4)サーバ通知欄:ST1404で重複するサブルーチンとして通知された場合は、“yes”に設定する。新たにダウンロードしたサブルーチンの場合は、“no”に設定する。
上記の構成によれば、携帯電話機101でコンテンツ107,1303をダウンロードするとき、そのコンテンツ107,1303に含まれる各サブルーチンの識別子(ここではハッシュ値)を用いて、サブルーチン単位でダウンロード済みかどうかを判断することができる。そして、ダウンロード済みのサブルーチンに関する情報をコンテンツ配信サーバ1301へ通知し、サーバ側で重複しない(未送信の)サブルーチンを特定して送信するように構成することにより、必要なデータだけをダウンロードすることができ、コンテンツ107,1303のダウンロード時の通信量を大幅に削減することができる。
また、携帯電話機101では、クライアントサブルーチンリスト1305内でサブルーチンの重複情報の通知の有無をフラグ(サーバ通知)で管理しているため、コンテンツのダウンロード時にコンテンツ配信サーバ1301から送信されるサーバサブルーチンリスト1307への返答の際には、未通知の重複情報だけを送信すればよくなり、通信量を削減することができる。
さらに、コンテンツ配信サーバ1301側で、携帯電話機101から送信されるサブルーチンの重複情報を携帯電話機101等の端末別に管理するのがよい。これにより、それ以降のコンテンツ107,1303等のダウンロード時には、そのコンテンツに関するサーバサブルーチンリスト1307のうち、未送信の情報だけを携帯電話機101側へ送信すればよくなり、通信量を削減することができる。
以上、本発明の実施例を説明したが、実現可能な実施形態はこれに限られない。以下、本発明の実施形態の変形例を示す。
[情報処理装置の例]
上記実施例では、本発明を携帯電話機に適用したが、本発明は、各種の情報処理装置に適用が可能である。特に、PCと比較して、CPUの処理速度、メモリの容量、及び画像表示能力など、実装可能な各種デバイスの能力が厳しく制限されるいわゆる組込み機器に適用すれば、本発明の効果が一層高まる。組込み機器の例としては、例えば、PDAや携帯ゲーム機等の携帯情報端末、携帯電話機、カーナビゲーション装置、家庭用電話機、家庭用ゲーム機、テレビ受像機、HDDレコーダ等の個人用機器、及びカラオケ機器、ロボット、鉄道等の輸送機器、ロケット、プラント制御装置等の業務用機器が挙げられる。これらのなかでも、携帯用に作られた組込み機器は、上記リソースの制限の問題が大きいため、本発明を適用するのが特に好ましい。
[キャッシュメモリを用いない構成]
実施例では、キャッシュメモリ177上にサブルーチン管理表キャッシュ205を持ち、このキャッシュ上でサブルーチンの形式の判断や優先度の検索を行ったが、キャッシュメモリ177を備えない構成も可能である。この場合、サブルーチン管理表キャッシュ205を用いて行う処理に替えて、メモリ117上のサブルーチン管理表203を用いて前述の各種の処理を行えばよい。
[プリコンパイルの有無の判断]
実施例では、各エントリーに関するコンパイルの状況については、JITフラグを用いて判断していたが、次のように行うこともできる。例えば、第1コード119を第2コード121へプリコンパイルしたとき、及び第2コード121をネイティブコード131へコンパイルしたときに、その変更内容を検出してハッシュ値をそれぞれ算出しておき、サブルーチン管理表キャッシュ205に別途設けた二つの欄でそれぞれ管理しておく。これにより、コンパイルの状況(サブルーチンのコードの種類)についての判断を、JITフラグの種類ではなく、プリコンパイルに関するハッシュ値の有無及びコンパイルに関するハッシュ値の有無に基づいて判定することができる。
[JITコンパイルの方法]
実施例では、仮想マシン129のJITコンパイラ159は、実行対象のサブルーチン(第2コード121)をネイティブコード131へ変換するだけであったが、次のような処理も可能である。すなわち、JITコンパイラ159は、実行対象のサブルーチンの実行過程で参照される他のサブルーチンがあるときは、その第1コード119のプリコンパイル結果である第2コード121を参照元のサブルーチンの第2コード121内にインライン展開し、これをネイティブコード131へ変換することができる。
[プリコンパイルの方法]
実施例では、プリコンパイルの方法として、サブルーチンの実行過程で参照される他のサブルーチンの第1コードを、参照元のサブルーチンの第1コード内にインライン展開する方法を示したが、この処理をさらに細かく制御することも可能である。例えば、各サブルーチンのファイル容量を、サブルーチン管理表203若しくはサブルーチン管理表キャッシュ205で管理することにより、又は第1コード119の所定の箇所(例えば、ヘッダ)に記述することにより、予め定めた閾値より容量の小さい第1コードだけをインライン展開することも可能である。
[プロセッサ113との接続方法]
実施例では、各種のハードウェア105を、バス103を介して接続する例を示したが、周辺機能部111とプロセッサ113間、サブルーチン管理回路171とプロセッサ113間など、各種のハードウェア105間を直結することも可能である。特に、サブルーチン管理回路171内のサブルーチン管理表キャッシュ205は、サブルーチンの呼び出しのたびにプロセッサ113によって参照されるため、サブルーチン管理回路171とプロセッサ113間を直結すれば、アクセス速度の向上及びバス103の負荷の低減を図ることができる。
[第1コード処理部123の構成]
実施例では、第1コード処理部123の構成として、サブルーチン管理回路171、プリコンパイル回路173、及びプリコンパイル制御回路175をそれぞれ別個に図示したが、これに限られない。これら三つの回路は、任意に組み合わせて1個の回路として又は2個の回路として構成することもできる。
[優先度]
優先度の変形例としては、以下の値を採用することができる。
(1)コンテンツ107の実行中に各サブルーチンが呼び出された際のメモリ117のスタックフレームの数を所定の値から減じた値
(2)サブルーチンごとの対応するコンテンツ107の数
(3)各サブルーチンの処理内容に応じて定められた値。
上記(1)の値を採用する場合、各サブルーチンに関する上記スタックフレームの数が、サブルーチン管理手段を構成するサブルーチン管理回路171によって、サブルーチン管理表203又はサブルーチン管理表キャッシュ205に書き込まれるように構成しておくのがよい。また、実施例における動作速度定義表301で定めた動作速度の値を基準にして、プリコンパイル回路173の動作速度が適切となるように、上記所定の値を調整するのがよい。或いは、これとは逆に、所定の値に基づいて算出される優先度を基準とし、動作速度定義表301における動作速度の値を調整してもよい。いずれの場合においても、プリコンパイル制御回路175は、サブルーチン管理表203又はサブルーチン管理表キャッシュ205に書き込まれている優先度を用いて、動作速度定義表301から動作速度を判断し、この動作速度でプリコンパイル回路173を動作させることができる。
この変形例においては、例えば、複数のサブルーチンが入れ子になっている場合、最後のほうで参照されるサブルーチンについては、そのスタックフレームが未処理の複数のサブルーチンのスタックフレーム上にプッシュされ(積み上げられ)るため、スタックフレームの数が大きくなり、これを所定の値から減じると、結果的に小さな値が得られる。これとは逆に、頻繁に参照され(早い段階で呼び出され)るサブルーチンについては、スタックフレームの数が小さくなり、これを所定の値から減じると、結果的に大きな値が得られる。従って、早くプリコンパイルすべきである頻繁に参照されるサブルーチンの優先度が高くなり、プリコンパイルを急ぐ必要のないあまり参照されないサブルーチンの優先度が低くなる。これにより、プリコンパイルの優先度の低いサブルーチンをプリコンパイルする際には、プリコンパイル回路175の動作速度を落とすことにより、消費電力を低く抑えることができる。
上記(2)の値を採用する場合、サブルーチンと複数のコンテンツ107との対応関係を表すサブルーチン共用表243(図2)を、少なくともメモリ117上又はキャッシュメモリ177があるときはキャッシュメモリ177上のいずれかに持たせておく。そして、サブルーチン管理回路171は、複数のコンテンツ107を同時に実行する場合において、いずれかのコンテンツ107の実行中にサブルーチンが呼び出されたが、処理待ちのサブルーチンの第1コード119があるときは、サブルーチン共用表243に基づいて、それらのサブルーチンのうち対応するコンテンツ107の数が多いサブルーチンから順に、プリコンパイル回路173がその第1コードから第2コードを生成するように制御を行うのがよい。
上記(3)の値を採用する場合、サブルーチンの第1コード119に、処理の内容を表す属性を予め記載しておく。また、メモリ117に、その属性ごとに第1コード119から第2コード121を生成する優先順位を定めた属性管理表を記憶しておく。そして、コンテンツの実行中にサブルーチンが呼び出されたが、プリコンパイル待ち(JITフラグが“req”)のサブルーチンが存在するときは、サブルーチン管理回路171は、それらのサブルーチンの第1コード119に記載された属性を用いて属性管理表から優先順位を特定し、その優先順位に従って第1コード119から第2コード121が生成されるように実行制御を行うことができる。
なお、実施例において優先度を用いて説明したその他の処理についても、上記(1)〜(3)の値を用いて実行することができる。
[JITフラグ]
実施例では、JITフラグが“pre”の場合は、存在する第2コードをJITコンパイラ159で実行していたが、図2に示すように、サブルーチン管理表203内の第1コードサイズ管理表239で各サブルーチンの第1コード119のサイズを管理している場合には、次のような処理を実行してもよい。例えば、JITコンパイラ159による処理対象の第2コード121の元となる第1コード119のサイズを、第1コードサイズ管理表239から判断し、第1コード119のサイズが、予め決めておいた閾値より大きい場合、以下のいずれかの処理を実行する。
(1)第1コード119をインタプリタ157で実行すると同時に、別スレッドで第2コード121をJITコンパイラ159によってネイティブコード131へ変換してメモリ117に格納する
(2)インタプリタ157で実行する。
コードサイズが大きい場合、JITコンパイルが完了するまで実行を待つよりも、上記のように第1コード119をインタプリタ157で逐次実行した方が、コンテンツの実行速度が向上するというメリットがある。
[コンテンツの種類]
実施例では、実行するコンテンツとしてJavaプログラムを採用しているが、採用するコンテンツは、その一部又は全部がJS(JavaScript)、PHP(Hypertext Preprocessor)、Perl(Practical Extraction and Report Language)、ActionScript、又はVBScript(Visual Basic Script)等のスクリプト言語で記述されたプログラム(スクリプト)であってもよい。従って、その一部にスクリプトを含むHtmlファイルを扱うことも可能である。これらのプログラムを採用する場合、ソースコードを第1コードとして扱い、前述のように、例えば呼び出し先のサブルーチンの第1コードを、呼び出し元の第1コード内にインライン展開するなどの方法により、第2コードを生成することができる。また、各スクリプトを実行するためのコード実行部153をソフトウェアで構成するのがよい。この場合において、いわゆるサーバサイドスクリプトに該当するプログラムを採用する場合には、再生アプリ125に又はこれとは別にサーバサイドスクリプトをクライアント端末で実行するための機能を持たせればよい。代替手段としては、コード実行部153にWEBサーバの機能を持たせることにより対応可能である。
また、HTMLファイルを第1コード119として扱う場合には、サブルーチン管理回路171が特定のタグで囲まれた領域をサブルーチンとして識別できるように構成しておき、識別したサブルーチンごとにハッシュ値を計算しておく構成を採用することができる。これにより、例えば、携帯電話機101がコンテンツ107としてHTMLファイルをダウンロードする際に、そのハッシュ値に基づいて、変更された(重複しない)サブルーチンを特定し、その変更部分だけをダウンロードすることができる。この方法を採用することにより、差分データの取得処理を高速化することができる。なお、このような処理を利用する組み込みシステムとしては、例えば、予め決められたウェブサイトのデータを定期的に取得するように構成されたWeb巡回ロボットなどが考えられる。
[キャッシュ更新処理]
実施例では、サブルーチン管理表キャッシュ205内の先頭位置から順にエントリを参照し、キャッシュアウトカウント値が0又は最小のエントリを1つ検出し、サブルーチン管理表203内にある対応するサブルーチンのエントリと書き換えていたが、次のようなアルゴリズムを採用することができる。すなわち、サブルーチン管理表203へ書き戻す方法としては、サブルーチン管理表キャッシュ205内を検索し、キャッシュアウトカウントが0のエントリを全て書き戻す方法、起動してから一定時間実行されていないコンテンツに対応するエントリを優先的に書き戻す方法がある。サブルーチン管理表キャッシュ205へ格納する方法としては、各サブルーチンから参照される別のサブルーチンを特定する呼び出し関係表を作成しておき、この表に基づいて、呼び出されたサブルーチンとそのサブルーチンから参照される別のサブルーチンの各エントリを格納する方法がある。
[サブルーチン定義値]
実施例では、第1コード生成時にコンパイラを用いてサブルーチン定義値を第1コード内に埋め込む方法を提示したが、これに限られない。例えば、プログラマ自身がソースコードにサブルーチン定義値を書き込んでもよい。或いは、或るサブルーチンの第1コードから呼び出される別のサブルーチンの数や頻度及び別のサブルーチンからこのサブルーチンが呼び出される回数や頻度を判断してサブルーチン定義値を付与するプログラムを用意し、これを用いてサブルーチン定義値をサブルーチンの第1コード内に書き込んでもよい。そのプログラムは、サブルーチンの第1コードを第2コードへ変換するのに要する時間に基づいてサブルーチンを定義値を付与するものであってもよい。
[プリコンパイルの順序]
実施例では、プリコンパイル対象の第1コード119が複数存在する場合、すなわちJITフラグが“req”のサブルーチンのエントリが処理待ちの状態で複数存在する場合、優先度の高いサブルーチンから順に第1コードをプリコンパイルしたが、これに限られない。プリコンパイルは、例えば、以下のいずれかの方法で行うことが可能である。
(1)コンテンツ107の実行中にサブルーチンが呼び出されたが、それより前に呼び出されたサブルーチンの第1コード119が第2コード121へ変換されていないとき(JITフラグが“req”のエントリが存在するとき)は、プリコンパイル回路173は、それらのサブルーチンのうち最後に呼び出されたサブルーチンの第1コード119から順に第2コード121へ変換することができる。
(2)コンテンツ107に対応する表示物を表示するディスプレイを備えておく。そして、コンテンツ107の実行中にサブルーチンが呼び出されたが、それより前に呼び出されたサブルーチンの第1コード119から第2コード121が生成されていないとき(プリコンパイル待ちのサブルーチンが存在するとき)は、サブルーチン管理回路171は、上記ディスプレイ上で、中央の表示物、最前面の表示物、又は最も大きい表示物に対応するコンテンツに含まれるサブルーチンの第1コード119から優先的に第2コード121が生成されるように実行制御を行うことができる。
(3)ディスプレイ上に表示される矢印等の指示部を移動させ、及び表示物を指示部によって選択するための操作部をさらに備えておく。そして、コンテンツ107の実行中にサブルーチンが呼び出されたが、プリコンパイル待ちのサブルーチンが存在するときは、サブルーチン管理回路171は、ディスプレイ上で、指示部と重っている表示物又は指示部によって選択された表示物に対応するコンテンツ107に含まれるサブルーチンの第1コード119から優先的に第2コード121が生成されるように実行制御を行うことができる。
本発明を適用した携帯電話機の基本構成を示す図。 コンテンツ管理表、サブルーチン管理表、及びサブルーチン管理表キャッシュの構成を示す図。 プリコンパイル回路の動作速度を定める動作速度定義表。 コンテンツの実行時におけるメモリ、不揮発性記録媒体、キャッシュメモリの構成、及びこれらを利用したハードウェアの基本動作を示す図。 コンテンツの実行開始時におけるサブルーチン管理回路の処理のフローチャート。 プロセッサ及びサブルーチン管理回路によるサブルーチン管理表検索・実行処理のフローチャート。 プリコンパイル時における第1コード処理部の動作のフローチャート。 プリコンパイルの開始から終了までの間におけるプリコンパイル回路173による処理のフローチャート。 プリコンパイル制御回路によるプリコンパイル回路の動作速度制御のフローチャート。 サブルーチン管理回路によるサブルーチン管理表キャッシュの更新処理のフローチャート。 携帯電話機の基本動作のシーケンシャル図。 サブルーチン管理回路によるコンテンツ終了処理のフローチャート。 携帯電話機及びコンテンツ配信サーバのそれぞれの構成及び連携方法を示す図。 サブルーチン管理部によるコンテンツ登録処理のフローチャート。
符号の説明
101…携帯電話機
103…バス
105…ハードウェア
107,1303…コンテンツ
109…ソフトウェア
111…周辺機能部
113…プロセッサ
115…不揮発性記録媒体
117…メモリ
119,1313…第1コード
121…第2コード
123…第1コード処理部
125…再生アプリ
127…OS、129…仮想マシン
131…ネイティブコード
133…サブルーチン管理プログラム
135…プリコンパイル制御プログラム
153…仮想マシン
159…JITコンパイラ
171…サブルーチン管理回路
173…プリコンパイル回路
177…連想メモリ
201…コンテンツ管理表
203…サブルーチン管理表
205…サブルーチン管理表キャッシュ
237…ハッシュ値管理表
239…第1コードサイズ管理表
241…ダウンロード元管理表
243…サブルーチン共用表
301…動作速度定義表
1301…コンテンツ配信サーバ
1305…クライアントサブルーチンリスト
1307…サーバサブルーチンリスト

Claims (19)

  1. コンテンツに含まれる複数のサブルーチンごとに、プロセッサで実行可能なネイティブコード、前記ネイティブコードの元となるOSに依存しない第1コード、前記第1コードを前記ネイティブコードへ変換する過程で生成される第2コードのうち、存在するコードの種類を管理するサブルーチン管理表を記憶するメモリと、
    前記第1コードをインタプリタ方式で実行するインタプリタ機能、及び前記第2コードをネイティブコードへ変換してから実行するJITコンパイル機能を備えた仮想マシンと、
    前記第1コードから前記第2コードを生成するプリコンパイル回路と、
    前記コンテンツの実行中に呼び出されたサブルーチンについて、前記サブルーチン管理表を参照した結果、ネイティブコードが存在するときは、該ネイティブコードがプロセッサで実行され、第2コードが存在するときは、該第2コードが前記仮想マシンのJITコンパイル機能で実行され、生成されたネイティブコードが前記メモリに格納され、又は第1コードが存在するときは、該第1コードが前記仮想マシンのインタプリタ機能で実行されるとともに、前記プリコンパイル回路で第2コードに変換され、該第2コードが前記メモリに格納されるように実行制御を行い、それらの制御によりサブルーチンを実行する際に参照するコードの種類が変化したときは、変化後の種類が前記サブルーチン管理表に記録されるように記録制御を行うサブルーチン管理手段と
    を備えた情報処理装置。
  2. 前記サブルーチン管理手段は、前記サブルーチンごとに所定の基準に基づいて定められる、第1コードを第2コードへ変換する優先度の高いサブルーチンから順に、その第1コードが第2コードに変換されるように前記実行制御を行う請求項1に記載の情報処理装置。
  3. 前記メモリは、前記優先度に応じて、前記プリコンパイル回路の動作速度を定めた動作速度定義表を記憶し、
    さらに、前記プリコンパイル回路で処理される第1コードに対応するサブルーチンの優先度を用いて、前記動作速度定義表から動作速度を判断し、該動作速度に従って前記プリコンパイル回路が動作するように制御を行うプリコンパイル制御手段を備えた
    請求項2に記載の情報処理装置。
  4. 前記優先度は、前記コンテンツの実行中に呼び出されたサブルーチンごとの回数であり、又は前記コンテンツの実行中に各サブルーチンが呼び出された際のスタックフレームの数を所定の値から減じた値である請求項2又は3に記載の情報処理装置。
  5. 前記優先度は、前記コンテンツに含まれる各サブルーチンの第1コードを第2コードへ変換するのに要する時間に基づいて、又は前記コンテンツの実行中に各サブルーチンが呼び出される頻度に基づいて、各サブルーチンの第1コード内に予め記述された値である請求項2又は3に記載の情報処理装置。
  6. 前記プリコンパイル制御手段は、前記プリコンパイル回路の動作速度を下げたとき、該プリコンパイル回路への供給電圧を、その動作を維持できる電圧値の範囲内で下げる請求項3乃至5のいずれかに記載の情報処理装置。
  7. 前記プリコンパイル制御手段は、バス内のデータ伝送量又はプロセッサによる前記メモリへのアクセス頻度を監視し、前記データ伝送量又は前記アクセス頻度が所定の基準を超えている間、前記プリコンパイル回路の動作を停止する請求項2乃至6のいずれかに記載の情報処理装置。
  8. さらに、前記サブルーチン管理表の内容をサブルーチン管理表キャッシュとして記憶するキャッシュメモリを備え、
    前記サブルーチン管理手段は、前記サブルーチン管理表に替えて前記サブルーチン管理表キャッシュに基づいて前記実行制御及び前記記録制御を行い、所定のタイミングで、前記サブルーチン管理表と前記サブルーチン管理表キャッシュの間でデータの転送及び書き換えが行われるようにキャッシュ制御を行う
    請求項1乃至7のいずれかに記載の情報処理装置。
  9. 前記サブルーチン管理手段は、
    前記コンテンツの実行開始時には、実行対象のコンテンツに含まれるサブルーチンの情報が、前記優先度の高いものから順に、前記サブルーチン管理表から前記サブルーチン管理表キャッシュへ書き込まれ、
    前記コンテンツの実行中において、呼び出されたサブルーチンの情報が前記サブルーチン管理表キャッシュにない場合は、サブルーチン管理表キャッシュにある前記優先度の最も低いサブルーチンの情報が前記サブルーチン管理表へ書き戻され、前記呼び出されたサブルーチンの情報が前記サブルーチン管理表から前記サブルーチン管理表キャッシュへ書き込まれるように前記キャッシュ制御を行う請求項8に記載の情報処理装置。
  10. 前記第1コードは、スタックマシン用のコードであり、
    前記第2コードは、前記第1コードから生成されるレジスタマシン用のコードを含む
    請求項1乃至9のいずれかに記載の情報処理装置。
  11. 前記第2コードは、前記サブルーチンの実行過程で呼び出される他のサブルーチンの第1コードを、呼び出し元のサブルーチンの第1コード内にインライン展開して成るコードを含む請求項1乃至10のいずれかに記載の情報処理装置。
  12. 前記メモリは、前記第1コードにおける不要な記述、文法上の瑕疵、又は誤記の修正方法を定めた修正辞書を記憶し、
    前記第2コードは、前記修正辞書に基づいて、前記第1コードを最適化したコードを含む
    請求項1乃至11のいずれかに記載の情報処理装置。
  13. 前記JITコンパイル機能は、前記第2コードの実行過程で呼び出される他のサブルーチンの第1コードのプリコンパイル結果である第2コードを、呼び出し元の第2コード内にインライン展開し、これをネイティブコードへ変換する請求項1乃至12のいずれかに記載の情報処理装置。
  14. 前記メモリは、前記サブルーチンごとに複数のコンテンツとの対応関係を表すサブルーチン共用表を記憶し、
    前記サブルーチン管理手段は、前記優先度に替えて、前記サブルーチン共用表に基づいて、対応するコンテンツの数が多いサブルーチンから順に、その第1コードが第2コードに変換されるように前記実行制御を行う
    請求項2乃至13のいずれかに記載の情報処理装置。
  15. 前記サブルーチン管理手段は、前記優先度に替えて、前記コンテンツの実行中に呼び出されたサブルーチンのうち最後に呼び出されたサブルーチンから順に、その第1コードが第2コードに変換されるように前記実行制御を行う請求項2乃至12のいずれかに記載の情報処理装置。
  16. 前記第1コードには、対応するサブルーチンの処理の内容を表す属性が予め記載されており、
    前記メモリは、前記属性ごとに前記第1コードから前記第2コードを生成する優先順位を定めた属性管理表を記憶し、
    前記サブルーチン管理手段は、前記コンテンツンの実行中に呼び出されたサブルーチンの第1コードに記載された属性を用いて前記属性管理表から前記優先順位を特定し、前記優先度に替えて、該優先順位に従って第1コードが第2コードに変換されるように前記実行制御を行う
    請求項2乃至13に記載の情報処理装置。
  17. 前記コンテンツに対応する表示物を表示するディスプレイを備え、
    前記サブルーチン管理手段は、前記優先度に替えて、前記ディスプレイ上で、中央の表示物、最前面の表示物、又は最も大きい表示物に対応するコンテンツに含まれるサブルーチンの第1コードから優先的に第2コードが生成されるように前記実行制御を行う
    請求項2乃至13のいずれかに記載の情報処理装置。
  18. 前記ディスプレイ上に表示される矢印等の指示部を移動させ、及び前記表示物を前記指示部によって選択するための操作部をさらに備え、
    前記サブルーチン管理手段は、前記ディスプレイ上で、前記指示部と重っている表示物又は前記指示部によって選択された表示物に対応するコンテンツに含まれるサブルーチンの第1コードから優先的に第2コードが生成されるように前記実行制御を行う
    請求項17に記載の情報処理装置。
  19. 前記コンテンツは、その一部若しくは全部がスクリプト若しくはJavaプログラムである請求項1乃至18のいずれかに記載の情報処理装置。
JP2008051271A 2008-02-29 2008-02-29 情報処理装置 Pending JP2009211190A (ja)

Priority Applications (2)

Application Number Priority Date Filing Date Title
JP2008051271A JP2009211190A (ja) 2008-02-29 2008-02-29 情報処理装置
US12/332,397 US20090222798A1 (en) 2008-02-29 2008-12-11 Information Processing Apparatus

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2008051271A JP2009211190A (ja) 2008-02-29 2008-02-29 情報処理装置

Publications (1)

Publication Number Publication Date
JP2009211190A true JP2009211190A (ja) 2009-09-17

Family

ID=41014191

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2008051271A Pending JP2009211190A (ja) 2008-02-29 2008-02-29 情報処理装置

Country Status (2)

Country Link
US (1) US20090222798A1 (ja)
JP (1) JP2009211190A (ja)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2014525632A (ja) * 2011-09-02 2014-09-29 マイクロソフト コーポレーション スクリプト・コードを有するマークアップ・コンテンツの高速プレゼンテーション
EP2945057A1 (en) 2014-05-15 2015-11-18 Fujitsu Limited Process execution method and information processing apparatus
US10481876B2 (en) 2017-01-11 2019-11-19 Microsoft Technology Licensing, Llc Methods and systems for application rendering

Families Citing this family (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8291393B2 (en) * 2007-08-20 2012-10-16 International Business Machines Corporation Just-in-time compiler support for interruptible code
US8578056B1 (en) * 2008-03-31 2013-11-05 Symantec Corporation Optimized application streaming for just in time compiled components
US8683465B2 (en) * 2009-12-18 2014-03-25 International Business Machines Corporation Virtual image deployment with a warm cache
US9003377B2 (en) 2010-01-07 2015-04-07 Microsoft Technology Licensing, Llc Efficient resumption of co-routines on a linear stack
CN101957770B (zh) * 2010-10-09 2015-09-02 中兴通讯股份有限公司 一种移动设备上应用程序的启动方法及装置
US20120311538A1 (en) * 2011-06-06 2012-12-06 Microsoft Corporation Capturing Rich Actionable Feedback on Working Software
US9244667B2 (en) 2012-08-10 2016-01-26 The Mathworks, Inc. Mechanism for transforming between type-independent and type-specific code
US9146750B2 (en) 2012-08-10 2015-09-29 The Mathworks, Inc. Mechanism for replacing an array creation routine within code
US9015681B1 (en) * 2012-08-10 2015-04-21 The Mathworks, Inc. Creating and using array creation routines or a family of routines separate from algorithmic code
GB2508433A (en) * 2012-12-03 2014-06-04 Ibm Migration of processes in heterogeneous computing environments using emulating and compiling source code on target system
US9348625B2 (en) * 2014-05-23 2016-05-24 Google Inc. Application access to native and bundled libraries
US11243803B2 (en) * 2019-04-30 2022-02-08 Automation Anywhere, Inc. Platform agnostic robotic process automation
US11113095B2 (en) 2019-04-30 2021-09-07 Automation Anywhere, Inc. Robotic process automation system with separate platform, bot and command class loaders
US11614731B2 (en) 2019-04-30 2023-03-28 Automation Anywhere, Inc. Zero footprint robotic process automation system
US11301224B1 (en) 2019-04-30 2022-04-12 Automation Anywhere, Inc. Robotic process automation system with a command action logic independent execution environment

Family Cites Families (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3602857B2 (ja) * 1991-04-23 2004-12-15 株式会社日立製作所 多機種対応型情報処理システム、および、方法
US6865734B2 (en) * 1997-10-06 2005-03-08 Sun Microsystems, Inc. Method and apparatus for performing byte-code optimization during pauses
US5933635A (en) * 1997-10-06 1999-08-03 Sun Microsystems, Inc. Method and apparatus for dynamically deoptimizing compiled activations
EP0943990A3 (en) * 1998-02-27 2004-12-22 Texas Instruments Incorporated Method and system of providing dynamic optimization information in a code interpretive runtime environment
US6735761B1 (en) * 1998-05-15 2004-05-11 International Business Machines Corporation Compile method frame detection method and device code discarding method and computer
US6760907B2 (en) * 1998-06-30 2004-07-06 Sun Microsystems, Inc. Code generation for a bytecode compiler
JP3470948B2 (ja) * 1999-01-28 2003-11-25 インターナショナル・ビジネス・マシーンズ・コーポレーション 動的コンパイル時期決定方法、バイトコード実行モード選択方法、及びコンピュータ
US6851109B1 (en) * 1999-05-06 2005-02-01 International Business Machines Corporation Process and system for dynamically compiling a partially interpreted method
US20030023958A1 (en) * 2001-07-17 2003-01-30 Patel Mukesh K. Intermediate language accelerator chip
US6996814B2 (en) * 2001-11-14 2006-02-07 Sun Microsystems, Inc. Method and apparatus for dynamically compiling byte codes into native code
US6954836B2 (en) * 2002-07-11 2005-10-11 Micron Technology, Inc. System and method for processor with predictive memory retrieval assist
US7100154B2 (en) * 2003-01-16 2006-08-29 International Business Machines Corporation Dynamic compiler apparatus and method that stores and uses persistent execution statistics
US7116438B2 (en) * 2003-05-22 2006-10-03 Hitachi, Ltd. Terminal for information processing
US8291375B2 (en) * 2004-03-29 2012-10-16 Sybase, Inc. Attribute-based component programming system and methodology for object-oriented languages
WO2005099342A2 (en) * 2004-04-19 2005-10-27 Securewave S.A. A generic framework for runtime interception and execution control of interpreted languages
US7669201B2 (en) * 2005-05-02 2010-02-23 Intermec Ip Corp. System and method for common file installation
US8146065B2 (en) * 2007-08-13 2012-03-27 International Business Machines Corporation Running time of short running applications by effectively interleaving compilation with computation in a just-in-time environment

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2014525632A (ja) * 2011-09-02 2014-09-29 マイクロソフト コーポレーション スクリプト・コードを有するマークアップ・コンテンツの高速プレゼンテーション
US10466989B2 (en) 2011-09-02 2019-11-05 Microsoft Technology Licensing, Llc. Fast presentation of markup content having script code
US11288048B2 (en) 2011-09-02 2022-03-29 Microsoft Technology Licensing, Llc. Fast presentation of markup content having script code
EP2945057A1 (en) 2014-05-15 2015-11-18 Fujitsu Limited Process execution method and information processing apparatus
US9672016B2 (en) 2014-05-15 2017-06-06 Fujitsu Limited Process execution method and information processing apparatus
US10481876B2 (en) 2017-01-11 2019-11-19 Microsoft Technology Licensing, Llc Methods and systems for application rendering

Also Published As

Publication number Publication date
US20090222798A1 (en) 2009-09-03

Similar Documents

Publication Publication Date Title
JP2009211190A (ja) 情報処理装置
CN109358936B (zh) 信息处理方法、装置、存储介质、电子设备及系统
US9942307B2 (en) Web application script migration
KR101038896B1 (ko) 서비스 프로그램을 생성하는 시스템, 방법 및 서비스 프로그램을 생성하기 위한 프로그램을 기록한 컴퓨터 판독가능 매체
CN108984174B (zh) 跨平台的应用创建方法、装置、服务器和存储介质
US20110119602A1 (en) Web server, web browser and web system
US20120185822A1 (en) Web browsing apparatus and method through storing and optimizing javascript® code
JP4294084B2 (ja) ソフトウェアアプリケーションを実行する方法及び記録媒体
US20130227388A1 (en) Persistent Storage of Profile Data for Script Compilation
US20140365861A1 (en) Prefetching binary data for use by a browser plugin
CN101729753B (zh) 一种java应用中加载图片的方法和装置
JP2009211187A (ja) 情報処理装置
CN114625439A (zh) 基于微前端架构的子应用运行方法、电子设备及存储介质
JP5437322B2 (ja) データ言語中の複数の言語の管理
JP2019523480A (ja) Nandストレージデバイスのためのプリエンプティブ圧縮解除スケジューリング
RU2742198C1 (ru) Сканирование привязок в разметке веб-страницы
WO2022078057A1 (zh) 应用包发布方法、应用方法、装置、介质、服务器及设备
KR101079966B1 (ko) 웹페이지에서의 동영상 재생을 지원하는 이동통신단말기 및 웹페이지에서의 동영상 재생 지원 방법
US8311801B2 (en) Technology for supporting modification of messages displayed by program
JP2003330900A (ja) アプリケーション並列処理システム及びアプリケーション並列処理方法
KR101325195B1 (ko) 검색 수행 시간 단축을 위한 장치, 방법 및 컴퓨터 판독 가능한 기록 매체
JP2009093212A (ja) Webブラウザを用いたコンテンツの再生を制御するプログラム、方法、及びWebサーバ
KR20090122703A (ko) 변환 프로그램 제공 서버 및 방법
CN112612531A (zh) 应用程序启动方法、装置、电子设备及存储介质
JP2007094871A (ja) メモリ管理装置及びメモリ管理方法