IP Force 特許公報掲載プロジェクト 2022.1.31 β版

知財求人 - 知財ポータルサイト「IP Force」

▶ コネクトフリー株式会社の特許一覧

特開2024-1328ソフトウェア開発装置およびソフトウェア開発プログラム
<>
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図1
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図2
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図3
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図4
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図5
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図6
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図7
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図8
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図9
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図10
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図11
  • 特開-ソフトウェア開発装置およびソフトウェア開発プログラム 図12
< >
(19)【発行国】日本国特許庁(JP)
(12)【公報種別】公開特許公報(A)
(11)【公開番号】P2024001328
(43)【公開日】2024-01-09
(54)【発明の名称】ソフトウェア開発装置およびソフトウェア開発プログラム
(51)【国際特許分類】
   G06F 8/30 20180101AFI20231226BHJP
【FI】
G06F8/30
【審査請求】有
【請求項の数】6
【出願形態】OL
(21)【出願番号】P 2023188125
(22)【出願日】2023-11-02
(62)【分割の表示】P 2019103139の分割
【原出願日】2019-05-31
【公序良俗違反の表示】
(特許庁注:以下のものは登録商標)
1.WCDMA
(71)【出願人】
【識別番号】514318600
【氏名又は名称】コネクトフリー株式会社
(74)【代理人】
【識別番号】110001195
【氏名又は名称】弁理士法人深見特許事務所
(72)【発明者】
【氏名】帝都 久利寿
(57)【要約】
【課題】仕様の異なる半導体デバイスを用いたコントローラの間でソフトウェアを共有化できるソリューションを提供する。
【解決手段】1または複数のパッドを有しているコントローラで実行される実行コードをソースコードから生成するソフトウェア開発装置が提供される。ソフトウェア開発装置は、ソースコードを解析して、1または複数のパッドに対する指定を抽出する解析手段と、対象となるコントローラのハードウェア情報を参照して、抽出されたパッドに対する指定に対応するコードを含む実行コードを生成する生成手段とを含む。
【選択図】図12
【特許請求の範囲】
【請求項1】
1または複数のパッドを有しているコントローラで実行される実行コードをソースコードから生成するソフトウェア開発装置であって、
前記ソースコードを解析して、前記1または複数のパッドに対する指定を抽出する解析手段と、
対象となるコントローラのハードウェア情報を参照して、抽出されたパッドに対する指定に対応するコードを含む実行コードを生成する生成手段とを備える、ソフトウェア開発装置。
【請求項2】
前記パッドは、前記コントローラ200と任意のハードウェアとの間の物理的なインターフェイスである、請求項1に記載のソフトウェア開発装置。
【請求項3】
前記ハードウェア情報は、前記コントローラに実装されている半導体デバイスのピンと前記パッドとの接続関係を特定するための情報を含む、請求項1または2に記載のソフトウェア開発装置。
【請求項4】
前記1または複数のパッドに対する指定は、前記1または複数のパッドのうち、利用すべきパッドを特定するための識別情報を含む、請求項1~3のいずれか1項に記載のソフトウェア開発装置。
【請求項5】
前記生成手段は、コントローラ間で共通に利用されるライブラリモジュールに代えて、対象のコントローラに固有なコードにより、前記実行コードを生成する、請求項1~4のいずれか1項に記載のソフトウェア開発装置。
【請求項6】
1または複数のパッドを有しているコントローラで実行される実行コードをソースコードから生成するソフトウェア開発プログラムであって、前記ソフトウェア開発プログラムはコンピュータに
前記ソースコードを解析して、前記1または複数のパッドに対する指定を抽出するステップと、
対象となるコントローラのハードウェア情報を参照して、抽出されたパッドに対する指定に対応するコードを含む実行コードを生成するステップとを実行させる、ソフトウェア開発プログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本開示は、ソフトウェア開発装置およびソフトウェア開発プログラムに関する。
【背景技術】
【0002】
近年の情報通信技術(Information and Communication Technology:ICT)の進歩は目覚ましく、インターネットなどのネットワークに接続されるデバイスは、従来のパーソナルコンピュータやスマートフォンといった情報処理装置に限らず、様々なモノ(things)に広がっている。このような技術トレンドは、「IoT(Internet of Things;モノのインターネット)」と称され、様々な技術およびサービスが提案および実用化されつつある。将来的には、地球上の数十億人と数百億または数兆のデバイスとが同時につながる世界が想定されている。このようなネットワーク化された世界を実現するためには、よりシンプル、より安全、より自由につながることができるソリューションを提供する必要がある。
【0003】
IoTで利用されるデバイス(「エッジデバイス」とも称される。)においても、半導体デバイスを用いて様々なプログラムが実行される。このような半導体デバイスとソフトウェアとの関係に関して、例えば、特開2006-213145号公報(特許文献1)は、ハードウェア的に同じECUを用いて、使用される指定端子ピンが異なる複数の仕様間でソフトウェアを共有化するための仕組みを開示する。
【先行技術文献】
【特許文献】
【0004】
【特許文献1】特開2006-213145号公報
【発明の概要】
【発明が解決しようとする課題】
【0005】
エッジデバイスを構成する半導体デバイスの進歩も目覚ましい。このような半導体デバイスの改良に伴って、仕様が変更される場合などもあり、ソフトウェアをどのように維持および管理するのかといった課題が生じ得る。
【0006】
上述の特許文献1に開示される仕組みは、同一のハードウェアを用いて、仕様の異なる複数の機能を単一のソフトウェアで実現することを目的とするものであり、同一のソフトウェアを仕様の異なる複数の半導体デバイスの間で共有化することを解決するようなものではない。
【0007】
本開示は、仕様の異なる半導体デバイスを用いたコントローラの間でソフトウェアを共有化できるソリューションを提供することを一つの目的とする。
【課題を解決するための手段】
【0008】
本開示のある形態に従えば、1または複数のパッドを有しているコントローラで実行される実行コードをソースコードから生成するソフトウェア開発装置が提供される。ソフトウェア開発装置は、ソースコードを解析して、1または複数のパッドに対する指定を抽出する解析手段と、対象となるコントローラのハードウェア情報を参照して、抽出されたパッドに対する指定に対応するコードを含む実行コードを生成する生成手段とを含む。
【0009】
パッドは、コントローラ200と任意のハードウェアとの間の物理的なインターフェイスであってもよい。
【0010】
ハードウェア情報は、コントローラに実装されている半導体デバイスのピンとパッドとの接続関係を特定するための情報を含んでいてもよい。
【0011】
1または複数のパッドに対する指定は、1または複数のパッドのうち、利用すべきパッドを特定するための識別情報を含んでいてもよい。
【0012】
生成手段は、コントローラ間で共通に利用されるライブラリモジュールに代えて、対象のコントローラに固有なコードにより、実行コードを生成するようにしてもよい。
【0013】
本開示の別の形態に従えば、1または複数のパッドを有しているコントローラで実行される実行コードをソースコードから生成するソフトウェア開発プログラムが提供される。ソフトウェア開発プログラムはコンピュータに、ソースコードを解析して、1または複数のパッドに対する指定を抽出するステップと、対象となるコントローラのハードウェア情報を参照して、抽出されたパッドに対する指定に対応するコードを含む実行コードを生成するステップとを実行させる。
【発明の効果】
【0014】
本開示によれば、仕様の異なる半導体デバイスを用いたコントローラの間でソフトウェアを共有化できる。
【図面の簡単な説明】
【0015】
図1】本実施の形態に従うIoTシステムの全体構成の一例を示す模式図である。
図2】本実施の形態に従うソフトウェア開発装置のハードウェア構成例を示す模式図である。
図3】本実施の形態に従うコントローラのハードウェア構成例を示す模式図である。
図4】本実施の形態に従うソフトウェア開発装置に接続されるコントローラに用いられるマイコンを説明するための図である。
図5】本実施の形態に従うソフトウェア開発装置に接続されるコントローラで提供されるパッドを説明するための図である。
図6図5に示すマイコンとパッドとの接続関係を示す図である。
図7図5および図6に示されるコントローラに向けられたソースコードの一例を示す図である。
図8】本実施の形態に従うソフトウェア開発装置に入力可能なソースコードの一例を示す図である。
図9】本実施の形態に従うソフトウェア開発装置の機能構成例を示すブロック図である。
図10】本実施の形態に従うソフトウェア開発装置により生成される実行コードのデータ構造を説明するための図である。
図11】本実施の形態に従うコントローラが提供するパッドの応用例を説明するための図である。
図12】本実施の形態に従うソフトウェア開発装置におけるソースコードから実行コードを生成する処理手順を示すフローチャートである。
【発明を実施するための形態】
【0016】
本開示に係る実施の形態について、図面を参照しながら詳細に説明する。なお、図中の同一または相当部分については、同一符号を付してその説明は繰り返さない。
【0017】
以下の説明においては、典型例として、本実施の形態に従うソフトウェア開発装置10
0をIoTシステムに適用した場合について説明するが、本開示はIoTシステムに限らず任意のシステムおよびコントローラに適用可能である。
【0018】
<A.IoTシステム1>
まず、本実施の形態に従うソフトウェア開発装置100およびエッジデバイス2を含むIoTシステム1の全体構成について説明する。
【0019】
図1は、本実施の形態に従うIoTシステム1の全体構成の一例を示す模式図である。図1を参照して、IoTシステム1においては、典型的には、ソフトウェア開発装置100においてエッジデバイス2で実行されるプログラム(実行コード)が生成される。生成されたプログラムは、ソフトウェア開発装置100からエッジデバイス2に含まれるコントローラ200へ転送される。
【0020】
ソフトウェア開発装置100には、統合開発環境(IDE:Integrated Development Environment)が提供されており、ユーザは統合開発環境上で任意のプログラムを作成できる。
【0021】
エッジデバイス2としては、どのようなデバイスであってもよいが、典型的には、工場設備、家庭内の各種装置、社会インフラ設備、車両などの移動体、任意の携帯デバイスなどが想定される。より具体的には、エッジデバイス2は、プロセッサを含むコントローラ200と、1または複数のハードウェアデバイス4を含む。ハードウェアデバイス4は、エッジデバイス2を構成する任意のセンサ、アクチュエータ、通信デバイスなどを含む。
【0022】
コントローラ200とハードウェアデバイス4との間は、配線(hard-wired)により電気的に接続されている。
【0023】
図1に示すIoTシステム1における典型的な処理手順としては、まず、ユーザがソフトウェア開発装置100を用いてソースコードを作成する((1)ソースコード作成)。そして、作成されたソースコードは、ソフトウェア開発装置100においてコンパイルされて、実行コードが生成される((2)実行コード生成)。生成された実行コードは、エッジデバイス2のコントローラ200へ転送される((3)実行コード転送)。転送された実行コードは、コントローラ200で実行される((4)実行コードの実行)。実行コードがコントローラ200で実行されことで、ハードウェアデバイス4との間で任意の信号が遣り取りされてもよい。
【0024】
このように、ソフトウェア開発装置100は、コントローラ200で実行される実行コードをソースコードから生成する。
【0025】
<B.ハードウェア構成例>
次に、本実施の形態に従うIoTシステム1に含まれるデバイスのハードウェア構成例について説明する。
【0026】
(b1:ソフトウェア開発装置100)
ソフトウェア開発装置100は、典型的には汎用コンピュータで実現される。
【0027】
図2は、本実施の形態に従うソフトウェア開発装置100のハードウェア構成例を示す模式図である。図2を参照して、ソフトウェア開発装置100は、主たるコンポーネントとして、プロセッサ102と、メインメモリ104と、入力部106と、ディスプレイ108と、ハードディスク110と、通信インターフェイス122とを含む。これらのコンポーネントは、内部バス120を介して接続されている。
【0028】
プロセッサ102は、例えば、CPU(Central Processing Unit)やGPU(Graphics Processing Unit)などで構成される。複数のプロセッサ102が配置されてもよいし
、複数のコアを有するプロセッサ102を採用してもよい。
【0029】
メインメモリ104は、DRAM(Dynamic Random Access Memory)やSRAM(Static Random Access Memory)などの揮発性記憶装置で構成される。ハードディスク110
は、プロセッサ102で実行される各種プログラムや各種データを保持する。なお、ハードディスク110に代えて、SSD(Solid State Drive)やフラッシュメモリなどの不
揮発性記憶装置を採用してもよい。ハードディスク110に格納されたプログラムのうち、指定されたプログラムがメインメモリ104上に展開され、プロセッサ102は、メインメモリ104上に展開されたプログラムに含まれるコンピュータ可読命令(computer-readable instructions)を順次実行することで、後述するような各種機能を実現する。
【0030】
典型的には、ハードディスク110には、ユーザが任意に作成するソースコード112と、統合開発環境を実現するためのソフトウェア開発プログラム114と、ソースコード112から生成される実行コード116とが格納される。ソフトウェア開発プログラム114は、ユーザが任意に作成するソースコード112から実行コード116を生成するものであり、プログラムの開発環境を提供するモジュールを含む。
【0031】
入力部106は、ソフトウェア開発装置100を操作するユーザの入力操作を受け付ける。入力部106は、例えば、キーボード、マウス、表示デバイス上に配置されたタッチパネル、ソフトウェア開発装置100の筐体に配置された操作ボタンなどであってもよい。
【0032】
ディスプレイ108は、プロセッサ102での処理結果などを表示する。ディスプレイ108は、例えば、LCD(Liquid Crystal Display)や有機EL(Electro-Luminescence)ディスプレイなどであってもよい。
【0033】
通信インターフェイス122は、コントローラ200とのデータ交換を担当する。通信インターフェイス122は、例えば、USB(Universal Serial Bus)ポート、IEEE1394などのシリアルポート、レガシーなパラレルポートといった有線接続端子を含む。あるいは、通信インターフェイス122は、イーサネット(登録商標)ポートを含んでいてもよい。
【0034】
なお、ソフトウェア開発装置100の全部または一部は、コンピュータ可読命令に相当する回路が組み込まれたASIC(Application Specific Integrated Circuit)などの
ハードワイヤード回路を用いて実現してもよい。さらにあるいは、FPGA(field-programmable gate array)上にコンピュータ可読命令に相当する回路を用いて実現してもよ
い。また、プロセッサ102およびメインメモリ、ASIC、FPGAなどを適宜組み合わせて実現してもよい。
【0035】
ソフトウェア開発装置100は、コンピュータ可読命令を含むソフトウェア開発プログラム114を格納する非一過性(non-transitory)のメディアから、当該格納しているプログラムなどを読み出すためのコンポーネントをさらに有していてもよい。メディアは、例えば、DVD(Digital Versatile Disc)などの光学メディア、USBメモリなどの半導体メディアなどであってもよい。
【0036】
なお、ソフトウェア開発プログラム114は、メディアを介してソフトウェア開発装置100にインストールされるだけではなく、ネットワーク上の配信サーバから提供される
ようにしてもよい。
【0037】
(b2:コントローラ200)
コントローラ200は、汎用コンピュータを用いて実現してもよいし、処理を実現するために必要なコンポーネントを含む半導体基板を用いて実現してもよい。
【0038】
図3は、本実施の形態に従うコントローラ200のハードウェア構成例を示す模式図である。図3を参照して、コントローラ200は、主たるコンポーネントとして、演算処理部210と、無線通信モジュール212と、USBコントローラ214と、通信コントローラ216と、1または複数のパッド220と電気的に接続されたIOドライバを含むマイコン218とを含む。
【0039】
演算処理部210は、プログラムを実行する演算部であり、主たるコンポーネントとして、プロセッサ202と、メインメモリ204と、フラッシュメモリ206とを含む。プロセッサ202は、例えば、CPUやGPUなどで構成される。複数のプロセッサ202が配置されてもよいし、複数のコアを有するプロセッサ202を採用してもよい。メインメモリ204は、DRAMやSRAMなどの揮発性記憶装置で構成される。フラッシュメモリ206は、プロセッサ202で実行されるプログラムや必要なデータを保持する不揮発性記憶装置である。フラッシュメモリ206に格納されたプログラムのうち、指定されたプログラムがメインメモリ204上に展開されて、プロセッサ202により実行されることで、各種機能が実現される。
【0040】
無線通信モジュール212は、他の任意のデバイスとの間の無線によるデータ交換を担当する。無線通信モジュール212は、デバイス、ルータ、移動体基地局などと無線通信するための処理回路およびアンテナなどを含んでもよい。無線通信モジュール212が対応する無線通信は、例えば、Wi-Fi(登録商標)、Bluetooth(登録商標)、ZigBee(登録商標)、LPWA(Low Power Wide Area)、GSM(登録商標)
、W-CDMA、CDMA200、LTE(Long Term Evolution)、第5世代移動通信
システム(5G)のいずれであってもよい。
【0041】
USBコントローラ214は、ソフトウェア開発装置100とのデータ交換を担当する。通信コントローラ216は、他の任意のデバイスとの間の有線によるデータ交換を担当する。通信コントローラ216は、例えば、シリアル通信、パラレル通信、GPIO(General-purpose input/output)などの公知のデータ交換方式に対応するようにしてもよい。
【0042】
マイコン218は、パッド220を介して電気的に接続された任意のデバイスとの間の電気信号の遣り取りを担当する。マイコン218は、演算処理部210からの指令に従って電気信号を出力する。また、マイコン218は、パッド220を介して与えられる電気信号を検知し、その検知結果を演算処理部210へ出力する。より具体的には、マイコン218は、信号生成回路、信号検知回路、バッファ回路などで構成される。
【0043】
パッド220は、露出して配置された導電体を有しており、コントローラ200と様々なハードウェアとの間の物理的なインターフェイスに相当する。
【0044】
コントローラ200は、図示しないバッテリからの電力により駆動されてもよい。
<C.課題および解決手段>
次に、本実施の形態に従うソフトウェア開発装置100が解決しようとする課題について説明する。
【0045】
図4は、本実施の形態に従うソフトウェア開発装置100に接続されるコントローラ200に用いられるマイコン218を説明するための図である。図4(A)および図4(B)には、それぞれマイコン218Aおよび218Bを採用する場合について例示する。
【0046】
図4に示すように、実質的に同じ機能を提供するマイコン218であっても、マイコン218自体の仕様(大きさやピン数)ならびに各機能が割り当てられるピン位置が異なる場合がある。
【0047】
例えば、図4(A)に示すマイコン218Aにおいては、I/O用の端子として、番号「5」,「6」,「7」,「12」,「13」,「14」のピンが用いられる。また、図4(B)に示すマイコン218Bにおいては、I/O用の端子として、番号「17」,「18」,「19」,「20」,「21」,「22」のピンが用いられる。
【0048】
図5は、本実施の形態に従うソフトウェア開発装置100に接続されるコントローラ200で提供されるパッド220を説明するための図である。図5に示すように、マイコン218の端子とパッド220とが電気的に接続される。マイコン218の端子とパッド220との位置関係に応じて、任意の組み合わせが可能である。
【0049】
図5(A)には、図4(A)に示すマイコン218Aを用いた構成例を示す。この構成例においては、番号「1」~「6」のパッド220は、番号「5」,「6」,「7」,「14」,「13」,「12」のピンとそれぞれ電気的に接続される。また、図5(B)には、図4(B)に示すマイコン218Bを用いた構成例を示す。この構成例においては、番号「1」~「6」のパッド220は、番号「22」,「21」,「20」,「19」,「18」,「17」のピンとそれぞれ電気的に接続される。
【0050】
図6は、図5に示すマイコンとパッドとの接続関係を示す図である。図6(A)は、図5(A)に示す接続関係を示し、図6(B)は、図5(B)に示す接続関係を示す。
【0051】
図6(A)と図6(B)とを比較して分かるように、マイコン218Aとマイコン218Bとの間では、番号「1」~「6」のパッド220に接続されるピン番号および論理ポートのいずれもが互いに異なっている。
【0052】
このようなハードウェアの相違によって、従来技術においては、コントローラ200で実行されるソフトウェアを共通化することが難しかった。
【0053】
図7は、図5および図6に示されるコントローラ200に向けられたソースコード112の一例を示す図である。図7に示されるソースコード112Aおよび112Bは、所定のメッセージを示す信号を番号「5」および「6」のパッド220を通じて出力する場合の処理を規定する。
【0054】
より具体的には、図7(A)に示されるソースコード112Aは、メッセージを示す変数の定義1121と、出力ポートを示す変数(OutPort1およびOutPort2)の定義1122とを含む。メッセージの値は、ファンクションgetText()により設定される(命令1123)。
【0055】
また、メッセージを示す信号の送出に使用されるパッド220に接続されるポートを有効化される(命令1124A)。命令1124Aは、マイコン218Aの論理ポート「IO_05」(OutPort1:ピン番号「13」)および「IO_04」(OutPort2:ピン番号「12」)を「Out」(出力)に設定する(図6(A)参照)。
【0056】
そして、命令1125が実行されることで、設定された2つの倫理ポートからメッセージを示す信号が送出される。
【0057】
これに対して、マイコン218Bを用いる構成において、番号「5」および「6」のパッド220は、マイコン218Bの論理ポート「IO_02」(ピン番号「18」)および「IO_01」(ピン番号「6」)と電気的に接続されているので、この構成の差異をソースコード112に反映する必要がある。
【0058】
具体的には、図7(B)に示される命令1124Bは、図7(A)に示される命令1124Aとは異なる論理ポートを有効する。命令1124Bは、マイコン218Bの論理ポート「IO_02」(OutPort1:ピン番号「18」)および「IO_01」(OutPort2:ピン番号「17」)を「Out」(出力)に設定する(図6(B)参照)。
【0059】
このように、コントローラ200に用いられるマイコン218の仕様が変更される毎にソースコード112を修正する必要が生じ得る。
【0060】
このような課題に対して、本実施の形態に従うソフトウェア開発装置100においては、任意のデバイスと電気的に接続されるパッド220を直接指定できるようになっている。
【0061】
図8は、本実施の形態に従うソフトウェア開発装置100に入力可能なソースコード112の一例を示す図である。図8に示されるソースコード112は、図7に示されるソースコード112Aおよび112Bと同様に、所定のメッセージを示す信号を番号「5」および「6」のパッド220を通じて出力する場合の処理を規定する。
【0062】
より具体的には、図8に示されるソースコード112は、メッセージを示す変数の定義1121と、利用されるパッドを示す変数(ActivePad1およびActivePad2)の定義1126とを含む。定義1126は、コントローラ200のパッド220に対する指定に相当し、1または複数のパッド220のうち、利用すべきパッドを特定するための識別情報(この例では、パッドの番号)を含む。
【0063】
メッセージの値は、ファンクションgetText()により設定される(命令1123)。
【0064】
また、メッセージを示す信号の送出に使用されるパッド220を特定する情報が設定される(命令1127)。命令1127は、利用されるパッド220の識別情報である「5」および「6」を変数ActivePad1およびActivePad2にそれぞれ設定する。
【0065】
そして、命令1128が実行されることで、設定された2つのパッド220からメッセージを示す信号が送出される。
【0066】
このように、本実施の形態に従うソフトウェア開発装置100においては、実際にデバイスと接続されるパッドを特定したソースコード112の作成が可能であり、このようにパッドを特定できることで、コントローラ200に実装されるマイコンなどの仕様の相違を抽象化できる。すなわち、コントローラ200に実装されるマイコンなどの仕様が変更された場合であっても、同一のソフトウェアをそのまま流用できる。
【0067】
このようなプログラミング構成を採用することで、コントローラ200のユーザは、ハ
ードウェアの仕様などを意識せず、ソフトウェア資産を継続して利用することができるという利点が得られる。また、コントローラ200のメーカやベンダは、使用するマイコンなどの仕様が変更されても、各パッドに予め設定されている要求を満たすように内部配線を設計さえすれば、ソースコードの変更や改修などを生じさせることがない。
【0068】
<D.ソフトウェア開発装置100の機能構成>
次に、本実施の形態に従うソフトウェアの機能構成について説明する。
【0069】
図9は、本実施の形態に従うソフトウェア開発装置100の機能構成例を示すブロック図である。図9に示す各機能は、典型的には、ソフトウェア開発装置100のプロセッサ102がソフトウェア開発プログラム114を実行することで実現される。
【0070】
図9を参照して、ソフトウェア開発プログラム114は、ソースコード112の入力を受けて、実行コード116(アセンブラコード)を生成する。より具体的には、ソフトウェア開発プログラム114は、プリプロセッサ1141と、コンパイラ1142と、オプティマイザ1143と、コードジェネレータ1144とを含む。
【0071】
プリプロセッサ1141は、ソースコード112に対する語句解析および構文解析を実行するとともに、コンパイラ1142、オプティマイザ1143およびコードジェネレータ1144の挙動を制御する。プリプロセッサ1141は、解析手段に相当し、ソースコード112を解析して、1または複数のパッド220に対する指定を抽出する。
【0072】
コンパイラ1142は、ソースコード112に対する語句解析および構文解析の結果に基づいて、オブジェクトコードに生成する。オプティマイザ1143は、生成されたオブジェクトコードを最適化する。コードジェネレータ1144は、オプティマイザ1143による最適化の結果に基づいて、最終的な実行コード116を出力する。
【0073】
コンパイラ1142、オプティマイザ1143およびコードジェネレータ1144は、生成手段に相当し、対象となるコントローラ200のハードウェア情報を参照して、抽出されたパッド220に対する指定に対応するコードを含む実行コードを生成する。
【0074】
ソフトウェア開発装置100は、実行コード116が実行されるコントローラ200のハードウェア情報を含むコンフィグレーション118を有している。コンフィグレーション118は、コントローラ200毎に用意され、対象とするコントローラ200に応じたものが選択される。
【0075】
コンフィグレーション118は、典型的には、図6に示すような実装されている半導体デバイス(典型的には、マイコン)のピンとパッドとの接続関係を特定するための情報を含む。ソフトウェア開発装置100は、実行コード116が実行されるコントローラ200の種別に応じて、対応するコンフィグレーション118を選択するとともに、選択したコンフィグレーション118の内容を参照して、ソースコード112において指定されているパッド220を利用するのに必要な経路情報などを決定する。すなわち、コンフィグレーション118は、コントローラ200を構成するハードウェアの相違を吸収するための設定情報を含む。
【0076】
なお、コントローラ200の種別は、ユーザが手動で選択してもよいし、ソフトウェア開発装置100とコントローラ200とを接続して、自動的に取得するようにしてもよい。コンフィグレーション118については、ソフトウェア開発プログラム114が予め指定されたサーバから追加取得するようにしてもよいし、コントローラ200のストレージなどに予め格納しておき、ソフトウェア開発装置100が必要に応じて読み出すようにし
てもよい。
【0077】
さらに、対象となるコントローラ200に適合するように、実行コード116を生成するようにしてもよい。
【0078】
図10は、本実施の形態に従うソフトウェア開発装置100により生成される実行コード116のデータ構造を説明するための図である。図10(A)を参照して、実行コード116Aは、1または複数のオブジェクトコード(図10(A)の例では、オブジェクトコード1161および1162)と、必要なライブラリモジュール1163とで構成される。ライブラリモジュール1163は、オブジェクトコード1161および1162から参照されるオブジェクトコードの一部となる。典型的には、ライブラリモジュール1163には、オブジェクトコード1161または1162から必要なデータが引き渡されて処理が実行され、その結果がオブジェクトコード1161または1162へ戻される。
【0079】
これに対して、図10(B)に示す例では、図10(A)に示す実行コード116Aにおいてライブラリモジュール1163が担当するコードが固有コード1165および1167として、オブジェクトコード1164および1166に組み込まれている。すなわち、オブジェクトコード1164および1166は、対象となるコントローラ200に特有な処理が実行するための固有コード1165および1167を含む。
【0080】
このように、オブジェクトコード1164および1166に対象となるコントローラ200に適合させて生成した命令(オブジェクトコード)を組み入れてもよい。すなわち、ソフトウェア開発装置100は、コントローラ間で共通に利用されるライブラリモジュール1163に代えて、対象のコントローラ200に固有なコードにより、実行コード116を生成するようにしてもよい。このような構成を採用することで、コントローラ200での実行エラーの発生の可能性を低減するとともに、処理の高速化も期待できる。
【0081】
<E.パッドの応用例>
次に、本実施の形態に従うコントローラ200が提供するパッド220の応用例について説明する。上述したように、本実施の形態においては、コントローラ200が有している1または複数のパッド220を特定して各種処理を実行することができる。このようなパッド220を利用することで、様々なハードウェアとの物理的なインターフェイスを実現できる。
【0082】
図11は、本実施の形態に従うコントローラ200が提供するパッド220の応用例を説明するための図である。図11を参照して、コントローラ200は行列状に配置された複数のパッド220を有しており、これらのパッド220と電気的に接続可能なアダプタ300を用意する。アダプタ300は、装着状態において、各パッド220と電気的に接続可能な位置に端子が配置可能になっている。
【0083】
行列状に配置された複数のパッド220の各々について、予め機能が定義されていてもよい。
【0084】
図11には、複数のパッド220のうち、一部のパッド(番号「6」~「10」および番号「16」~「20」)のみが利用される例を示す。アダプタ300に接続された任意のデバイスは、コントローラ200の特定のパッド220との間で信号を遣り取りすることになる。
【0085】
上述したように、コントローラ200に組み込まれるマイコン218の仕様が変更されたことで、パッド220のレイアウトおよび提供される機能を維持するための新たなハー
ドウェア構成が採用されたとしても、そのハードウェア構成を定義するコンフィグレーション118さえ用意すれば、ソースコード112をそのまま流用できる。すなわち、コントローラ200のハードウェア構成の変更をソフトウェアで吸収できる。
【0086】
このように、マイコンなどの半導体デバイスの進歩が生じても、コントローラ200の物理的なインターフェイス(パッド220)を維持するとともに、ソフトウェア資産についてもそのまま利用できる。その結果、アダプタ300を介してコントローラ200に接続される任意のデバイスから見た場合にも、コントローラ200とのインターフェイスは不変であり、システムを永続的に維持できる。
【0087】
<F.処理手順>
次に、本実施の形態に従うソフトウェア開発装置100におけるソースコード112から実行コード116を生成する処理手順について説明する。
【0088】
図12は、本実施の形態に従うソフトウェア開発装置100におけるソースコード112から実行コード116を生成する処理手順を示すフローチャートである。図12に示す各ステップは、典型的には、プロセッサ102がソフトウェア開発プログラム114を実行することで実現される。
【0089】
図12を参照して、ソフトウェア開発装置100は、入力されたソースコード112に対して語句解析および構文解析を実行する(ステップS100)。ソフトウェア開発装置100は、解析結果に基づいて、いずれかのパッド220が指定されているか否かを判断する(ステップS102)。すなわち、ソフトウェア開発装置100は、ソースコード112を解析して、1または複数のパッド220に対する指定を抽出する。
【0090】
いずれのパッド220も指定されていなければ(ステップS102においてNO)、ステップS104およびS106の処理はスキップされる。
【0091】
いずれかのパッド220が指定されていれば(ステップS102においてYES)、ソフトウェア開発装置100は、実行コード116の転送先のコントローラ200に対応するコンフィグレーション118を取得し(ステップS104)、取得したコンフィグレーション118を参照して、指定されているパッド220を利用するのに必要な経路情報を決定する(ステップS106)。この経路情報は、指定されているパッド220に接続されているマイコンのピン番号や論理ポートなどを解決するための情報を含む。
【0092】
そして、ソフトウェア開発装置100は、ソースコード112に含まれるモジュール単位にオブジェクトコードを生成し(ステップS108)、オブジェクトコードを結合して実行コード116として出力する(ステップS110)。そして、処理は終了する。
【0093】
このように、ソフトウェア開発装置100は、対象となるコントローラ200のハードウェア情報(一例として、コンフィグレーション118)を参照して、抽出されたパッド220に対する指定に対応するコードを含む実行コードを生成する。
【0094】
<G.変形例>
上述の説明においては、説明の便宜上、物理的なインターフェイスの典型例として、パッドについて説明したが、「パッド」という用語に限定されることなく、1または複数の任意の物理的なインターフェイス(信号を遣り取り可能な回路の一部)について同様に適用可能である。
【0095】
<H.利点>
本実施の形態によれば、コントローラ200が提供する物理的なインターフェイスのうち利用されるインターフェイスをソースコード112において定義できるとともに、コントローラ200のハードウェア構成の相違を吸収できる仕組みを提供できる。これによって、コントローラ200に接続されるデバイスから見れば、コントローラ200の種類に依存することなく同一のインターフェイスを維持できるとともに、コントローラ200の変更によらず、ソフトウェアもそのまま利用できる。
【0096】
今回開示された実施の形態はすべての点で例示であって制限的なものでないと考えられるべきである。本発明の範囲は上記した説明ではなくて請求の範囲によって示され、請求の範囲と均等の意味および範囲内でのすべての変更が含まれることが意図される。
【符号の説明】
【0097】
1 IoTシステム、2 エッジデバイス、4 ハードウェアデバイス、100 ソフトウェア開発装置、102,202 プロセッサ、104,204 メインメモリ、106 入力部、108 ディスプレイ、110 ハードディスク、112,112A,112B ソースコード、114 ソフトウェア開発プログラム、116,116A 実行コード、118 コンフィグレーション、120 内部バス、122 通信インターフェイス、200 コントローラ、206 フラッシュメモリ、210 演算処理部、212 無線通信モジュール、214 USBコントローラ、216 通信コントローラ、218,218A,218B マイコン、220 パッド、300 アダプタ、1121,1122,1126 定義、1123,1124A,1124B,1125,1127,1128 命令、1141 プリプロセッサ、1142 コンパイラ、1143 オプティマイザ、1144 コードジェネレータ、1161,1162,1164,1166 オブジェクトコード、1163 ライブラリモジュール、1165 固有コード。
図1
図2
図3
図4
図5
図6
図7
図8
図9
図10
図11
図12
【手続補正書】
【提出日】2023-12-01
【手続補正1】
【補正対象書類名】特許請求の範囲
【補正対象項目名】全文
【補正方法】変更
【補正の内容】
【特許請求の範囲】
【請求項1】
半導体デバイスで実行される実行コードを生成するためのソフトウェア開発装置であって、前記半導体デバイスは複数のピンを有しており、前記複数のピンのうち少なくとも一部の各々は、他のデバイスとの間で電気信号を遣り取りするためのインターフェイスであるパッドと電気的に接続されており、前記ソフトウェア開発装置は、
前記実行コードを生成するためのソースコードから、パッドを特定するための指定を抽出する手段と、
前記実行コードを実行させる対象である半導体デバイスにおける、論理ポートとパッドとの対応付けを規定する情報を含むハードウェア情報を取得する手段と、
前記取得されたハードウェア情報に基づいて実行コードを生成する手段とを備え、前記生成された実行コードにおいては、前記抽出されたパッドを特定するための指定に対応するピンを示す論理ポートが決定されている、ソフトウェア開発装置。
【請求項2】
前記ハードウェア情報は、半導体デバイス毎に予め複数種類が用意されている、請求項1に記載のソフトウェア開発装置。
【請求項3】
前記ハードウェア情報は、外部のサーバから追加可能に構成されている、請求項1または2に記載のソフトウェア開発装置。
【請求項4】
前記ハードウェア情報は、ピンとパッドとの対応付けを規定する情報をさらに含む、請求項1~3のいずれか1項に記載のソフトウェア開発装置。
【請求項5】
前記半導体デバイスのパッドは、当該パッドと電気的に接続される第2のパッドを含むアダプタと接続可能になっている、請求項1~4のいずれか1項に記載のソフトウェア開発装置。
【請求項6】
半導体デバイスで実行される実行コードを生成するためのソフトウェア開発プログラムであって、前記半導体デバイスは複数のピンを有しており、前記複数のピンのうち少なくとも一部の各々は、他のデバイスとの間で電気信号を遣り取りするためのインターフェイスであるパッドと電気的に接続されており、前記ソフトウェア開発プログラムはコンピュータに、
前記実行コードを生成するためのソースコードから、パッドを特定するための指定を抽出するステップと、
前記実行コードを実行させる対象である半導体デバイスにおける、論理ポートとパッドとの対応付けを規定する情報を含むハードウェア情報を取得するステップと、
前記取得されたハードウェア情報に基づいて実行コードを生成するステップとを実行させ、前記生成された実行コードにおいては、前記抽出されたパッドを特定するための指定に対応するピンを示す論理ポートが決定されている、ソフトウェア開発プログラム。