

(19) 日本国特許庁(JP)

## (12) 特許公報(B2)

(11) 特許番号

特許第6602579号  
(P6602579)

(45) 発行日 令和1年11月6日(2019.11.6)

(24) 登録日 令和1年10月18日(2019.10.18)

(51) Int.Cl.

F 1

G06F 13/38 (2006.01)  
G06F 15/78 (2006.01)G06F 13/38 G06F 15/78 G06F 13/38  
G06F 320A 514 350

請求項の数 18 (全 26 頁)

|           |                              |
|-----------|------------------------------|
| (21) 出願番号 | 特願2015-141224 (P2015-141224) |
| (22) 出願日  | 平成27年7月15日 (2015.7.15)       |
| (65) 公開番号 | 特開2017-21749 (P2017-21749A)  |
| (43) 公開日  | 平成29年1月26日 (2017.1.26)       |
| 審査請求日     | 平成30年5月24日 (2018.5.24)       |

|           |                                                    |
|-----------|----------------------------------------------------|
| (73) 特許権者 | 302062931<br>ルネサスエレクトロニクス株式会社<br>東京都江東区豊洲三丁目2番24号  |
| (74) 代理人  | 110000350<br>ポレール特許業務法人                            |
| (72) 発明者  | 三ツ石 直幹<br>神奈川県川崎市中原区下沼部1753番地<br>ルネサスエレクトロニクス株式会社内 |
| (72) 発明者  | 猪狩 誠司<br>東京都小平市上水本町五丁目20番1号<br>ルネサスシステムデザイン株式会社内   |
| 審査官       | 打出 義尚                                              |

最終頁に続く

(54) 【発明の名称】半導体装置およびシステム

## (57) 【特許請求の範囲】

## 【請求項1】

同期クロックに従って、送信または受信の順序的な通信を行うインターフェース回路を備える半導体装置であって、

前記インターフェース回路は、

送信状態および受信状態の少なくとも1つをイネーブルにする動作イネーブル状態を指定する第1のレジスタと、

データ転送時に、データ転送情報またはデータ転送の内容に基づき、前記インターフェース回路の少なくとも1つのモードを変更するように生成された情報に従って、前記動作イネーブル状態において、送信または受信の少なくとも1つのモードを変更するモード制御回路と、

を備え、

前記モード制御回路は、前記動作イネーブル状態において、送受信モード、送信モード、および受信モードのモード間でモードを変更する半導体装置。

## 【請求項2】

請求項1の半導体装置において、

前記インターフェース回路は、前記モードの変更に応じて、ステータス出力を行うよう構成される半導体装置。

## 【請求項3】

請求項1の半導体装置において、

10

20

さらに、送受信同時動作時において、送信抑止または受信抑止を指定することが可能な情報を有する第2のレジスタを備える半導体装置。

**【請求項4】**

請求項3の半導体装置において、

前記第2のレジスタは、さらに、コマンド受信およびデータ受信のいずれかを指定することが可能な情報を備える半導体装置。

**【請求項5】**

請求項1の半導体装置において、

前記インターフェース回路は、データ送信完了割り込み要求、コマンド受信完了割り込み要求およびデータ受信完了割り込み要求のいずれかを出力することが可能であるよう構成される半導体装置。10

**【請求項6】**

請求項1の半導体装置において、

さらに、データ転送装置を備え、

前記モード制御回路は、前記データ転送装置の所定の動作に応じた制御を受け、送信または受信の動作完了後に、少なくとも1つの前記モードの変更を行うよう構成される半導体装置。

**【請求項7】**

請求項5の半導体装置において、

さらに、データ転送装置を備え、20

前記データ転送装置は、前記データ送信完了割り込み要求、前記コマンド受信完了割り込み要求および前記データ受信完了割り込み要求のいずれかに基づいて起動するよう構成される半導体装置。

**【請求項8】**

請求項7の半導体装置において、

前記データ転送装置は、転送モード情報を格納するレジスタと、第1および第2の転送元アドレス情報を格納するレジスタと、転送先アドレス情報を格納するレジスタと、演算回路と、を含み、

前記第1の転送元アドレス情報に基づきリードしたデータと、前記第2の転送元アドレス情報とを、前記演算回路で演算した結果に基づきリードした転送データを前記転送先アドレス情報に基づきライトを行うよう構成される半導体装置。30

**【請求項9】**

請求項1の半導体装置において、

さらに、中央処理装置と割り込み制御回路とデータ転送装置とを有し、

前記インターフェース回路は、前記割り込み制御回路に対して割り込み要求を行い、

前記割り込み制御回路は、前記割り込み要求に応じて、前記中央処理装置に対して割り込み信号を出力し、または前記データ転送装置に対して起動要求を出力するよう構成される半導体装置。

**【請求項10】**

同期クロックに従って、送信または受信の順序的な通信を行う第1のインターフェース回路を備える第1の半導体装置と、40

前記同期クロックに従って、送信または受信の順序的な通信を行う第2のインターフェース回路を備える第2の半導体装置と、

を備えるシステムであって、

前記第2のインターフェース回路は、

送受信状態、送信状態、または受信状態を指定する第1のレジスタと、

データ転送時に、データ転送情報またはデータ転送の内容に基づき、前記第2のインターフェース回路の少なくとも一つのモードを変更するように生成された情報に従って、送受信、送信、または受信をイネーブルにする動作イネーブル状態において、送信または受信の少なくとも1つのモードを変更するモード制御回路と、

を備え、

前記モード制御回路は、前記動作イネーブル状態において、送受信モード、送信モード、および受信モードのモード間でモードを変更するシステム。

**【請求項 1 1】**

請求項1 0のシステムにおいて、

前記第2のインターフェース回路は、前記モードの変更に応じて、ステータスを出力し、前記第1のインターフェース回路は、前記ステータスを入力するよう構成されるシステム。

**【請求項 1 2】**

請求項1 0のシステムにおいて、

10

前記第2のインターフェース回路は、さらに、前記送受信状態において、送信抑止または受信抑止を指定することが可能な情報を有する第2のレジスタを備えるシステム。

**【請求項 1 3】**

請求項1 2のシステムにおいて、

前記第2のレジスタは、コマンド受信およびデータ受信のいずれかを指定することが可能な情報を備えるシステム。

**【請求項 1 4】**

請求項1 0のシステムにおいて、

前記第2のインターフェース回路は、前記第1のインターフェース回路から出力される1つの同期クロックに同期して、送信および受信の順序的な通信を行うよう構成されるシステム。

20

**【請求項 1 5】**

請求項1 0のシステムにおいて、

前記第2の半導体装置は、さらに、データ転送装置を備え、

前記モード制御回路は、前記データ転送装置の所定の動作に応じた制御を受け、送信または受信の動作完了後に、前記モードの変更を行うよう構成されるシステム。

**【請求項 1 6】**

請求項1 0のシステムにおいて、

前記第2の半導体装置は、さらに、データ転送装置を備え、

前記データ転送装置は前記第2のインターフェース回路のデータ送信完了割り込み要求、コマンド受信完了割り込み要求およびデータ受信完了割り込み要求のいずれかに基づいて起動するよう構成されるシステム。

30

**【請求項 1 7】**

請求項1 6のシステムにおいて、

前記データ転送装置は、転送モード情報を格納するレジスタと、第1および第2の転送元アドレス情報を格納するレジスタと、転送先アドレス情報を格納するレジスタと、演算回路と、を含み、

前記第1の転送元アドレス情報に基づきリードしたデータと、前記第2の転送元アドレス情報とを、前記演算回路で演算した結果に基づきリードした転送データを前記転送先アドレス情報に基づきライトを行うよう構成されるシステム。

40

**【請求項 1 8】**

請求項1 0のシステムにおいて、

前記第2の半導体装置は、さらに、中央処理装置と割り込み制御回路とデータ転送装置とを有し、

前記第2のインターフェース回路は、前記割り込み制御回路に対して割り込み要求を行い、

前記割り込み制御回路は、前記割り込み要求に応じて、前記中央処理装置に対して割り込み信号を出力し、または前記データ転送装置に対して起動要求を出力するよう構成されるシステム。

**【発明の詳細な説明】**

50

**【技術分野】****【0001】**

本開示は半導体装置に関し、例えばシリアルコミュニケーションインターフェース（Serial Communication Interface：以下、SCIという。）を備えた半導体装置に適用可能である。

**【背景技術】****【0002】**

半導体集積回路でなるマイクロコンピュータは、機器制御用途に広く用いられている。マイクロコンピュータ間の通信には、SCIが用いられる（例えば、特開2011-114630号公報）。SCIは、データを1ビットずつ送信または受信するものである。SCIには、クロック同期式モードとして、クロックの立ち上がりから次の立ち上がりまでを1ビットとして送受信を行う。1つのクロック線と送信線と受信線の3本で送受信同時動作を行う。クロック同期式は、比較的高速の通信に用いられる。10

**【先行技術文献】****【特許文献】****【0003】****【特許文献1】特開2011-114630号公報****【発明の概要】****【発明が解決しようとする課題】****【0004】**

SCIは、送信のみまたは受信のみを行うことも可能であるが、送受信から送信のみまたは受信のみに切り替えるには、SCIの再設定が必要になる。20

**【0005】**

その他の課題と新規な特徴は、本発明書の記述および添付図面が明らかになるであろう。

**【課題を解決するための手段】****【0006】**

本開示のうち代表的なものの概要を簡単に説明すれば下記の通りである。

すなわち、半導体装置は、送信または受信の順序的な通信を行うインターフェース回路を備える。インターフェース回路は、送信状態および受信状態の少なくとも1つの状態である動作イネーブル状態を指定するレジスタと、動作イネーブル状態において、送信または受信の少なくとも1つのモードを変更するモード制御回路と、を備える。30

**【発明の効果】****【0007】**

上記の半導体装置によれば、送信または受信のモードの変更を容易にすることができる。

**【図面の簡単な説明】****【0008】****【図1A】実施例に係るマイクロコンピュータの構成を説明するためのブロック図。**

【図1B】図1Aのマイクロコンピュータの主要なインターフェースを説明するためのブロック図。40

**【図2】図1AのSCIの構成を説明するためのブロック図。****【図3】図1AのSCIのレジスタ構成を説明するための図。****【図4】図1AのSCIのモード制御状態遷移を説明するための図。****【図5】図1Aの割り込みコントローラの構成を説明するためのブロック図。****【図6】図1AのDTCのデータ転送情報を説明するための図。****【図7】図1AのDTCの構成を説明するためのブロック図。**

【図8A】応用例に係るマイクロコンピュータシステムの構成を説明するためのブロック図。

**【図8B】図8Aのマイクロコンピュータシステムの接続関係を説明するためのブロック**

50

図。

【図9】図8Aのマイクロコンピュータシステムにおける通信動作の第1の例を説明するためのタイミング図。

【図10】図8Aのマイクロコンピュータシステムにおけるコマンド受信完了のためのデータ転送を説明するための図。

【図11】図8Aのマイクロコンピュータシステムにおけるコマンド受信完了のためのデータ転送を説明するための図。

【図12】図8Aのマイクロコンピュータシステムにおける通信動作の第2の例を説明するためのタイミング図。

【図13】実施形態に係る半導体装置の構成を説明するためのブロック図。 10

【発明を実施するための形態】

【0009】

以下、実施形態、実施例および応用例について、図面を用いて説明する。ただし、以下の説明において、同一構成要素には同一符号を付し繰り返しの説明を省略することがある。

【0010】

まず、本願発明者らが検討したSCIの課題について説明する。

クロック同期式モードの送受信同時動作の場合、送信または受信の一方に不所望の状態にある場合には、所望の動作を行うことができない。例えば、送信データが用意できていないときには、原理的に所望の送受信同時動作を実現できず、実装上、送受信の両方の動作を行わないようにすることが多い。 20

【0011】

送受信同時動作と、送信のみ動作または受信のみ動作を切り替える場合、SCIの設定変更を行う必要がある。設定変更にあたっては待機時間が必要になる場合もある。待機時間は、SCIが順序的な動作を行うための内部動作の初期化のためなどに必要なものであり、待機時間の計測を行う。設定変更や待機時間の計測は、正味の通信とは直接関係のない処理であり、また、データトランスファコントローラ(DTC)などのデータ転送装置に担わせることが難しく、処理の高速化も難しい。

【0012】

通信の内容は、マイクロコンピュータが利用されるシステムによって異なる。一般的に、制御用途では、コマンドとそれに付随するデータが含まれることが多い。コマンドを受ける側は、コマンドの内容を判断しなければ、その後の動作(送信または受信)を決めることができない。コマンドと、それに付随する通信のデータ長はシステムによって異なり、コマンドに対応してデータ長も異なることが考えられる。例えば、コマンドは8ビット単位、それに付随する通信は32ビット単位などである。 30

【0013】

例えば、送受信同時動作を行うシステムにおいて、コマンド送受信を行う場合は、対となるデータは存在しないことが多いので、送受信同時動作のままとして、コマンド受信側(スレーブ)はダミーの送信データを用意し、コマンド送信側(マスター)は受信したダミーの受信データを無視するようにしなければならない。ダミーの送信データおよび受信データに対する、これらの処理は、本来必要なないものである。または、マスターは送信のみ、スレーブは受信のみに設定変更を行わなければならない。この場合は、設定変更の処理や待機時間の計測などが必要になってしまう。 40

【0014】

<実施形態>

図13は実施形態に係る半導体装置の構成を示すブロック図である。

【0015】

半導体装置(SD)は、同期クロックに従って、送信または受信の順序的な通信を行うインターフェース回路(SI)を備える。インターフェース回路(SI)は、送信状態および受信状態の少なくとも1つの状態である動作イネーブル状態を指定するレジスタ(REG) 50

I S T E R ) と、動作イネーブル状態において、送信または受信の少なくとも 1 つのモードを変更するモード制御回路 ( M D C ) と、を備える。

半導体装置によれば、送受信から送信または受信のモードの変更を容易にし、待機時間などを不要にして、通信のモードを変更可能にする。

#### 【実施例】

##### 【0016】

図 1 A は実施例に係るマイクロコンピュータの構成を示すブロック図である。マイクロコンピュータ (Micro Controller Unit : 以下、 M C U という。) 1 0 は 1 つの半導体基板上に図 1 A に示す機能ブロックまたはモジュール等を備える半導体装置である。すなわち、 M C U 1 0 は、中央処理装置 (Central Processing Unit : 以下、 C P U という。) 1 1 、データ転送装置 (データトランスファコントローラ (Data Transfer Controller : 以下、 D T C という。) ) 1 2 、割り込みコントローラ (Interrupt Controller : I N T ) 1 3 、リードオンリメモリ (Read Only Memory : 以下、 R O M という。) 1 4 およびランダムアクセスメモリ (Random Access Memory : 以下、 R A M という。) 1 5 を備える。 M C U 1 0 は、さらに、バスコントローラ (Bus Controller : 以下、 B S C という。) 1 6 、タイマ (T I M E R ) 1 7 、 S C I 1 8 、 A / D (Analog/Digital) 変換器および D / A (Digital/Analog) 変換器などのアナログモジュール (A N A L O G ) 1 9 および出入力ポート (I / O ) 1 A を備える。

##### 【0017】

M C U 1 0 の動作の主体となる C P U 1 1 は、主に R O M 1 4 から命令を読み込んで動作する。 R O M 1 4 は電気的に書換が可能なメモリであるフラッシュメモリ等の不揮発性メモリで構成される。 D T C 1 2 は、 C P U 1 1 の設定に基づき、 C P U 1 1 に代ってデータ転送を行う。

##### 【0018】

I N T 1 3 は、 B S C 1 6 、タイマ 1 7 、 S C I 1 8 、アナログモジュール 1 9 などからの割り込み要求 (I N T R E Q ) 、および M C U 1 0 外部からの複数の外部割り込み要求信号に基づく、 I / O 1 A からの割り込み要求 (I N T R E Q ) を受けて、 C P U 1 1 に割り込み要求、または D T C 1 2 にデータ転送起動要求を出力する。割り込み信号による処理を開始したときまたは終了したときに、割り込みをクリアする信号である割込みクリア信号 (I N T C L R ) を、 B S C 1 6 、タイマ 1 7 、 S C I 1 8 、アナログ 1 9 、 I / O 1 A のそれぞれの割り込み信号または割り込み要因フラグに対応して出力する。

##### 【0019】

B S C 1 6 は、 C P U 1 1 および D T C 1 2 からのバスリクエスト信号を受けて M C U 内部バス 1 B の占有に対する調停をして、バス使用許可信号を出力する。 B S C 1 6 は、 C P U 1 1 および D T C 1 2 と、バスリクエスト、バスアクノレジ、バスコマンド、ウェイト、アドレス、データなどのインタフェースを行い、 M C U 内部バス 1 B に接続された、 R A M 1 5 やそのほかの機能ブロックまたはモジュールに対するリード / ライトを実現する。 R A M 1 5 は S R A M 等の揮発性メモリで構成される。

##### 【0020】

S C I 1 8 の送信データ出力 (T X D ) および受信データ入力 (R X D ) は、 M C U 1 0 の外部の S C I とシリアルバスによって入出力される。このとき、必要に応じて入出力ポートを介して、入出力するようにすることもできる。

##### 【0021】

図 1 B は図 1 A のマイクロコンピュータの主要なインタフェースを示すブロック図である。 S C I 1 8 は、 I N T 1 3 を介して、 D T C 起動要求 (D T C R E Q ) により D T C 1 2 を起動する。 S C I 1 8 のデータ転送起動要因として、コマンド受信完了 (コマンド受信データフル) 割り込み要求 (C R X I ) 、データ受信完了 (受信データフル) 割り込み要求 (D R X ) 、データ送信完了 (送信データエンプティ) 割り込み要求 (T X I ) を持つ。

##### 【0022】

10

20

30

40

50

D T C 1 2 は、 I N T 1 3 の示す D T C ベクタ番号 ( D T C V E C ) に対応した、データ転送情報を R A M 1 5 からリードして、データ転送を行う。データ転送情報は、データ転送起動要因に対応したものが用意される。後述のように、コマンド受信完了に対応したデータ転送によって、受信データフル ( 受信データ転送 ) 、送信データエンプティ ( 送信データ転送 ) で使用するデータ転送情報を切り替えるようにする。また、 D T C 1 2 はデータ転送時にアクノレジ信号 ( A C K ) を活性化するとともに、データ転送情報または転送データに応じてモード制御信号 ( M D C ) を出力する。このアクノレジ信号 ( A C K ) とモード制御信号 ( M D C ) は、 I N T 1 3 を介して、 S C I 1 8 に与えられ、これに基づき、 S C I 1 8 のモード制御部 ( S C I M D C ) は後述するモードの変更を行う。 S C I 1 8 は、モードと送受信の状態に従って、ステータス ( S T ) の出力を行う。

10

#### 【 0 0 2 3 】

なお、データ転送装置の起動要因が一意に決まる場合には、 S C I 1 8 とデータ転送装置を直接接続するようにしてもよい。これは、データ転送装置として、 D T C 1 2 と I N T 1 3 を一体化したものと理解することができる。

#### 【 0 0 2 4 】

( S C I )

図 2 は図 1 A の S C I の構成を示すブロック図である。 S C I 1 8 は、制御レジスタ 1 8 1 、モード制御部 ( S C I M D C ) 1 8 2 、送受信制御部 ( S C I C N T ) 1 8 3 、受信部 1 8 4 、送信部 1 8 5 、受信 F I F O 1 8 6 、送信 F I F O 1 8 7 等を備える。

20

#### 【 0 0 2 5 】

制御レジスタ 1 8 1 は、送受信の方式やフォーマットの指定を行うとともに、割り込み要求などの状態を表示するために、モードレジスタ ( S M R ) 、コントロールレジスタ ( S C R ) 、ステータスレジスタ ( S S R ) 、ファンクションコントロールレジスタ ( S F C R ) を有する。例えば、 S C R のトランスマッチトイネーブル ( T E ) ビット、レシーブトイネーブル ( R E ) ビットのいずれかが 1 にセットされた状態に応じて、 S C I 1 8 の動作トイネーブル状態 ( S C I イネーブル ) を指定する。この動作トイネーブル状態は、ほかの送受信の方式やフォーマットの指定がなされた後に指定する。換言すれば、動作トイネーブル状態では、送受信の方式やフォーマットの変更は行わない。

#### 【 0 0 2 6 】

S C I M D C 1 8 2 は、制御レジスタ 1 8 1 の S F C R の設定に基づき、コマンド / データの識別 ( C M D ) 、送信抑止 ( T D ) 、受信抑止 ( R D ) などのモード制御を行う。また、 S C I M D C 1 8 2 は、 D T C 1 2 のモード制御信号 ( M D C ) に応じて、モードの切り替えを行う。このとき、 S C I M D C 1 8 2 は、モード制御信号 ( M D C ) を S C I M D C 1 8 2 内部で一旦、次モードとして保持し、実行中の送受信が完了した時点で、 S F C R に反映するようとする。 S C I 1 8 がスレーブ側である場合は、モードに対応して I / O ポート ( 端子 1 8 D ) からステータス ( S T ) を出力する。コマンド受信が指定された状態での受信動作によって、ステータス ( S T ) 出力をビジー状態にする。コマンド受信完了によるデータ転送装置の動作によって、モードの切り替えを行ったときに、ステータス ( S T ) 出力をレディ状態にする。また、データ送信またはデータ受信動作によって、ステータス ( S T ) 出力をビジー状態にし、これらによるデータ転送装置の動作によって、モードの切り替え ( コマンド受信にモードを切り替え ) たときに、レディ状態にする。

30

#### 【 0 0 2 7 】

S C I C N T 1 8 3 は、制御レジスタ 1 8 1 および S C I M D C 1 8 2 に基づき、クロック部ボーレートジェネレータ ( B R G ) 1 8 8 からの同期クロック ( S C K ) に同期して、送信 / 受信 / 送受信動作を行う。また、 S C I 1 8 がマスター側である場合は、 I / O ポート ( 端子 1 8 D ) からステータス ( S T ) の入力を行い、ビジー状態の場合は、新たな送受信動作を開始しないようにする。

40

#### 【 0 0 2 8 】

送信動作は、送信 F I F O 1 8 7 に有効なデータが存在する状態で、同期クロック ( S

50

C K ) が入力されると、送信部 185 を介して送信データ ( T X D ) を出力端子 18A に出力する。送信 F I F O 187 に有効なデータがない状態で、同期クロック ( S C K ) が入力されると送信オーバランエラーを発生する。

#### 【 0029 】

受信動作は、同期クロック ( S C K ) に同期して、入力端子 18B から受信データ ( R X D ) を受信部 184 に入力し、単位データの入力が行われると、受信 F I F O 186 に転送する。受信 F I F O 186 が一杯の状態で、さらに受信データを入力すると受信オーバランエラーを発生する。

#### 【 0030 】

S C I C N T 183 は、送信オーバランエラーまたは受信オーバランエラーが発生すると、I N T 13 に割り込みを要求する。この割り込み処理ルーチンによって、C P U 11 は所要の処理を行い、S C I 18 は動作を再開することになる。10

#### 【 0031 】

S C I C N T 183 は、送信 F I F O 187 に所定の量の空きが生じた場合には送信データエンプティ割り込み要求 ( T X I ) を、受信 F I F O 186 に所定の量のデータが蓄積された場合は受信データフル割り込み要求 ( D R X I ) を発生する。この所定の量は、制御レジスタ 181 の設定によって指定することができる。

#### 【 0032 】

制御レジスタ 181において、T E ビット、R E ビットがいずれも 1 にセットされた動作イネーブル状態においては、同期クロック ( S C K ) は送受信に共通であるため、送信動作と受信動作は同時に動作する。この動作イネーブル状態を送受信同時動作イネーブル状態という。送受信同時動作イネーブル状態であっても、送信オーバランエラーまたは受信オーバランエラーが発生した状態では、送受信動作は行わない。20

#### 【 0033 】

S C I C N T 183 は、送受信同時動作イネーブル状態においても、コマンド受信 ( C M D = 1 ) の場合は、送信 F I F O 187 に有効なデータがなくても、送信オーバランエラーを発生させず、送信動作を行い、また、送信 F I F O 187 に有効なデータがあつても、送信 F I F O 187 を保持したまま送信動作を行う。この送信動作では、送信出力を 0 または 1 に固定する。これは、T E ビットを 0 に設定した場合と同様の動作である。また、S C I C N T 183 は、単位データの受信によって、コマンド受信完了割り込み要求 ( C R X I ) を発生させる。30

#### 【 0034 】

送受信同時動作イネーブル状態においても、送信抑止 ( T D = 1 ) の場合は、コマンド受信の場合と同様の動作になる。

#### 【 0035 】

S C I C N T 183 は、送受信同時動作イネーブル状態においても、受信抑止 ( R D = 1 ) の場合は、受信データは無視し、受信 F I F O 186 も保持する。このため、受信データフル、受信オーバランエラーも発生させない。これは、R E ビットを 0 に設定した場合と同様の動作である。

#### 【 0036 】

受信部 184 は、入力端子 18B に接続され、1 ビットずつ受信データ ( R X D ) を格納する。所定のデータ ( 例えは 8 ビット ) の受信が完了すると、そのデータを受信 F I F O 186 に転送する。後述の R D ビットが 1 にセットされている場合は、受信完了とみなさない。受信 F I F O 186 の内容は、M C U 内部バス 1B を介して、C P U 11 または D T C 12 からリードすることができる。40

#### 【 0037 】

送信 F I F O 187 は、M C U 内部バス 1B を介して、C P U 11 または D T C 12 により、送信データのライトが行われる。後述の T D R E フラグが 0 にクリアされ、送信が開始されると、送信 F I F O 187 の内容は送信部 185 に転送される。送信部 185 は出力端子 18A に接続され、1 ビットずつ送信データ ( T X D ) を出力する。50

**【0038】**

ボーレートジェネレータ（B R G）188は、送受信の基本となるタイミングを生成することができるようとする。ボーレートジェネレータ（B R G）188は、ビットレートレジスタ、ビットレートカウンタを有する。

**【0039】**

S C I C N T 183は、割り込み要求信号として、T X I（データ送信完了または送信データエンプティ割り込み要求）、C R X I（コマンド受信完了またはコマンド受信データフル割り込み要求）、D R X I（データ受信完了または受信データフル割り込み要求）、E R I（受信エラー割り込み要求）信号を出力する。T X I、C R X I、D R X I信号は、D T C 12のデータ転送要求として使用することができる。

10

**【0040】**

図3は図1AのS C Iのレジスタ構成を示す図である。図3では、クロック同期式モードに関係するビットのみを示す。調歩同期式モードやそのほかの方式も、図示はされない、コントロールビット、ステータスフラグによって、実現することができる。

**【0041】**

シリアルモードレジスタ（S M R）のビット1、0は、クロックセレクトビット（C K S 1、C K S 0）であり、内蔵ボーレートジェネレータ（B R G）188のクロックソースを選択する。

**【0042】**

シリアルコントロールレジスタ（S C R）のビット7は、トランスマットインタラプトイネーブル（T I E）であり、T I Eビットを1にセットすると、T X Iが許可される。ビット6は、レシーブインタラプトイネーブル（R I E）であり、R I Eビットを1にセットすると、R X IおよびE R Iが許可される。ビット5は、トランスマットトイネーブル（T E）であり、T Eビットを1にセットすると、送信動作が可能になる。ビット4は、レシーブトイネーブル（R E）であり、R Eビットを1にセットすると、受信動作が可能になる。ビット1は、クロックトイネーブル（C K E）であり、クロックソースおよびS C Kの入出力端子18Cの機能を選択する。C K Eビットが0にクリアされているときは、ボーレートジェネレータ（B R G）188からの内部クロックを使用し、入出力端子18CはS C Kの出力端子となる。C K Eビットが1にセットされているときは、外部クロックを使用し、入出力端子18CはS C Kの入力端子となる。

20

**【0043】**

M C U 10が適用されるシステムによって、S C I 18の動作は固定され、送信動作のみ（T E = 1、R E = 0）、受信動作のみ（T E = 0、R E = 1）、送受信同時動作（T E = R E = 1）のいずれかになる。送受信コントロールは通信状態の遷移を司るにあたって、送信動作のみ、受信動作のみ、送受信同時動作の3つの動作によって、参照するレジスタやビットを変更する必要があり、送受信等の通信動作中に不整合を生じることを防ぐため、T E、R Eビットの通信動作中の切り替えは禁止される。T E、R Eビットを設定した後、ボーレートジェネレータ（B R G）188による基本クロックの同期化などの時間を待つ必要がある。

30

**【0044】**

シリアルステータスレジスタ（S S R）のビット7は、トランスマットデータレジスタエンプティ（T D R E）フラグであり、送信F I F O 187の空きの状態を表示する。所定の空きがある場合に、T D R Eフラグは1にセットされる。また、C P U 11が、T D R Eフラグの1の状態をリードした後、0をライトしたとき、および、T X Iにより起動されたD T C 12で送信F I F O 187へ送信データを転送したときに0にクリアされる。T D R Eフラグが0にクリアされると送信動作を開始する。ビット6は、レシーブデータレジスタフル（R D R F）フラグであり、受信F I F O 186のデータの状態を表示する。受信F I F O 186に所定のデータが存在する場合に、R D R Fフラグは1にセットされる。また、C P U 11が、R D R Fフラグの1の状態をリードした後、0をライトしたとき、および、C R X IまたはD R X Iにより起動されたD T C 12で受信F I F O 1

40

50

86からデータを転送したときに0にクリアされる。ビット5は、オーバランエラー(O R E R)フラグであり、受信時にオーバランエラーが発生したことを表示する。具体的には、O R E Rフラグは、R D R Fフラグが1にセットされた状態で次のデータを受信したときに、1にセットされる。このとき、受信データレジスタ(R D R)はオーバランエラーが発生する前の受信データを保持し、後から受信したデータが失われる。O R E Rフラグに1がセットされた状態では、以降のシリアル送受信は行わないようになる。

#### 【0045】

T D R E フラグと T I E ビットがいずれも1にセットされると、T X I が発生する。R D R F フラグと R I E ビットが1にセットされると、後述の C M D ビットによって、C R X I または D R X I が発生する。また、O R E R フラグと R I E ビットが1にセットされると E R I が発生する。  
10

#### 【0046】

ファンクションコントロールレジスタ(S F C R)のビット5は、送信ディスエーブル(T D)であり、クロック同期式モードの送受信動作時、かつクロック入力の状態で、T D ビットが1にセットされている場合、T D R E フラグの状態によらず、クロック入力に従って、送受信動作を開始する。送信データは固定値(例えば00またはFF)とする。0または1に固定することで、信号変化を抑止し、不所望の消費電力増加を回避することができる。データを固定するのみで、そのほかの通信動作は、送受信同時動作になる。ビット4は、受信ディスエーブル(R D)であり、R D ビットを1にセットした場合は、受信を完了したとみなさず、R D R F、O R E R フラグは1にセットされない。ビット2は、コマンド受信(C M D)であり、受信完了時にコマンド受信完了またはデータ受信完了のいずれとみなすかを指定する。すなわち、C M D ビットが1にセットされている場合は、コマンド受信完了としてC R X I が発生し、C M D ビットが0にクリアされている場合は、D R X I が発生する。  
20

#### 【0047】

これらのC M D、T D、R D ビットは、D T C 1 2 からのモード制御信号(M D C)に応じた、S C I M D C 1 8 2 に従い、変更される。

#### 【0048】

図4は図1AのS C I のモード制御状態遷移を示す図である。リセット後は、T E、R E ビットが0にされた停止状態S T 1 である。C P U 1 1などにより、制御レジスタ181のS C R の設定を行い、T E、R E ビットの少なくとも1ビットを1にセットすると、動作イネーブル状態S T 2 になる。動作イネーブル状態S T 2 は、送信動作(T E = 1)、受信動作(R E = 1)または送受信動作(T E = R E = 1)のいずれかの状態である。  
30

#### 【0049】

まず、特に制限はされないものの、D T C 動作によるS F C R 設定(モード制御)によってC M D ビットを1にセットしてコマンド受信状態S T 2 1 にする。コマンド受信が完了すると、D T C 1 2 によるモード制御を待つ設定判定/待ち状態S T 2 2 になる。

#### 【0050】

このモード制御によってデータ受信状態S T 2 3 、データ送受信状態S T 2 4 、データ送信状態S T 2 5 のいずれかに遷移する。T D ビットを1にセットするとデータ受信状態S T 2 3 に、R D ビットを1にセットするとデータ送信状態S T 2 5 に、T D ビットおよびR D ビットのいずれも1にセットしない(0にクリアする)とデータ送受信状態S T 2 4 に遷移する。所要のデータ受信、データ送受信、データ送信を行うと、D T C 1 2 によるモード制御を待つ設定判定/待ち状態S T 2 6 になる。モード制御によってC M D ビットを1にセットして、コマンド受信状態S T 2 1 に遷移する。なお、動作イネーブル状態S T 2 では、送受信の方式やフォーマットの変更は行わないようになる。  
40

#### 【0051】

##### (I N T)

図5は図1Aの割り込みコントローラ(I N T)の構成を示すブロック図である。M C U 1 0 の割り込み要因には、内部割り込み、外部割り込みの2種類があり、それぞれ割り  
50

込み要因フラグを有する。ここでは、代表的に S C I 1 8 からの内部割り込み要因のみを示している。

#### 【 0 0 5 2 】

割り込みの要因フラグは、 S C I 1 8 と同様に、 タイマ 1 7、 アナログ 1 9 の機能ブロックが所定の状態になったときに、 または、 M C U 1 0 の外部割り込み入力端子が所定の状態になったときに、 1 にセットされる。割り込み要因フラグが 1 にセットされ、 対応する割り込み許可ビットが 1 にセットされていると、 I N T 1 3 に割り込み要求される。

#### 【 0 0 5 3 】

この割り込み要求 ( I N T R E Q ) は、 割り込み / D T C 判定回路 1 3 1 に入力される。割り込み / D T C 判定回路 1 3 1 には、 さらに D T C 許可レジスタ ( D T E R ) 1 3 2 の内容が入力され、 割り込み / D T C 判定回路 1 3 1 は、 割り込みが要求されたとき、 D T C 1 2 を起動するか、 C P U 1 1 に割り込みを許可するかを選択する。割り込み / D T C 判定回路 1 3 1 は、 D T C 許可レジスタ 1 3 2 の当該割り込み要因に対応した D T E ビットが 1 にセットされていると、 D T C 1 2 への起動を要求し、 C P U 1 1 への割り込みを要求しない。割り込み / D T C 判定回路 1 3 1 は、 D T C 許可レジスタ 1 3 2 の D T E ビットが 0 にクリアされていると、 C P U 1 1 への割り込みを要求し、 D T C 1 2 への起動を要求しない。

#### 【 0 0 5 4 】

割り込み / D T C 判定回路 1 3 1 の出力は、 C P U 1 1 への割り込み要求と D T C 1 2 への起動要求が独立にそれぞれ優先順位・マスクレベル判定回路 1 3 3 と優先順位判定回路 1 3 4 とに入力される。C P U の優先順位判定・マスクレベル判定回路 1 3 3 は、 プライオリティレジスタ、 割り込みマスクレベルなどに従って制御される。

#### 【 0 0 5 5 】

C P U 1 1 への割り込み要求、 D T C 1 2 への起動要求のそれぞれについて、 複数の割り込み要求が発生している場合に、 優先順位・マスクレベル判定回路 1 3 3 および優先順位判定回路 1 3 4 はそれぞれ優先順位を判定する。この判定の結果、 優先順位の最高のものが選択され、 ベクタ番号が生成される。優先順位・マスクレベル判定回路 1 3 3 は C P U 割り込み要求 ( C P U I N T ) とベクタ番号 ( V E C ) を出力し、 優先順位判定回路 1 3 4 は D T C 起動要求 ( D T C R E Q ) と D T C ベクタ番号 ( D T C V E C ) を出力する。

#### 【 0 0 5 6 】

D T C 起動要求 ( D T C R E Q ) は D T C 1 2 に入力され、 また D T C ベクタ番号 ( D T C V E C ) は ラッチ回路 1 3 5 に入力される。D T C 動作開始信号 ( D T C S T A ) および D T C 動作終了信号 ( D T C E N D ) が D T C 1 2 から出力され、 ラッチ回路 1 3 5 に入力される。すなわち、 D T C 1 2 が動作を開始すると、 D T C 動作開始信号 ( D T C S T A ) が活性状態になり、 ラッチ回路 1 3 5 は D T C ベクタ番号 ( D T C V E C ) のラッチおよび保持を行う。そして、 D T C 1 2 のデータ転送が終了して D T C 動作終了信号 ( D T C E N D ) が活性状態になり、 ラッチ回路 1 3 5 のラッチは解除される。

#### 【 0 0 5 7 】

また、 D T C ベクタ番号 ( D T C V E C ) と D T C 動作終了信号 ( D T C E N D ) は デコード回路 1 3 6 に入力され、 対応する割り込み要因フラグ ( 例えば S C I 1 8 の T D R E , R D R F , O R E R ) に対して D T C 1 2 からの割り込み要因クリア信号 ( I N T C L R ) または D T E クリア信号 ( D T E C L R ) が活性状態になって、 割り込み要因フラグまたは D T E ビットがクリアされる。

#### 【 0 0 5 8 】

所要の割り込み要因で、 D T C 1 2 を起動する場合、 C P U 1 1 は予め、 データ転送情報などを R A M 1 5 の所要のアドレスにライトするとともに、 当該割り込みの割り込み許可ビット ( 例えば S C I 1 8 の T I E , R I E ) と、 D T C 許可レジスタ 1 3 2 の当該割り込み要因に対応した D T E ビットを 1 にセットしておく。

#### 【 0 0 5 9 】

10

20

30

40

50

この状態で当該割り込み要因フラグが1にセットされると、DTC12が起動される。DTC12が所定のデータ転送などの動作を実行している状態では、DTC12は割り込み要因クリア信号(INTCLR)によってデータ転送毎に当該割り込み要因フラグを0にクリアする。このとき、CPU11に割り込みは要求されない。

#### 【0060】

所定のデータ転送などを終了した場合、DTC12はDTEクリア信号(DTECLR)によって動作終了時にDTEビットを0にクリアする。このとき、当該割り込み要因フラグは1に保持され、DTEビットが0にクリアされているので、CPU11に割り込みが要求される。CPU11は、所定のデータ転送の終了などに対応した処理を実行するとともに、データ転送情報やDTEビットの再設定を行う。

10

#### 【0061】

##### (DTC)

図6は図1AのDTCのデータ転送情報(転送情報セット)を示す図である。DTC12のデータ転送情報は、モードレジスタ(MR)、データレジスタ(DR)、第1および第2ソース(転送元)アドレスレジスタ(SAR1、SAR2)、デスティネーション(転送先)アドレスレジスタ(DAR)、転送カウントレジスタ(CR)からなる。

#### 【0062】

MRに保持した内容によって、この内の必要なものが使用される。CRは、ブロック転送カウントレジスタ(BTCR)、転送カウントレジスタ(TCR)に分割され、TCRは8ビットずつ上位(TCRH)、下位(TCRL)に分割されている。後述のデータ転送モードに従って動作する。これらのレジスタ(MR、CR)は、1組分の回路がDTC12の内部に存在し、特に制限はされないものの、CPU11のアドレス空間上には存在しない。これらに格納されるべきデータ転送情報は、必要組数がCPU11のアドレス空間上の、RAM15などの所定のデータ転送情報アドレス領域に配置される。

20

#### 【0063】

モードレジスタ(MR)のビット構成は以下の通りである。

ビット31～16は、データ転送モードの設定と、テーブル参照用の入力データの指定を行う。ビット15～0は、テーブル参照用のデータ転送機能のテーブル参照の指定と、通常データ転送機能のデータ転送の指定を行う。

#### 【0064】

30

ビット31は、TLUビットであり、通常データ転送またはテーブル参照用のデータ転送機能を選択する。TLUビットが0にクリアされた場合は、通常データ転送を行う。データ転送情報はMR、SAR2、DAR、CR(32ビット×4本)とされる。通常データ転送の説明において、ハードウェアとしてのSAR2を、データ転送情報としてはSARと記す。TLUビットが1にセットされた場合は、テーブル参照モードである。

#### 【0065】

ビット30は、BRMビットであり、TLUビットが1にセットされた場合に有効になり、分岐モードを指定する。データ転送情報はMR、SAR1、SAR2、DAR(32ビット×4本)とされる。CRは0とみなす。DTC12は、SAR1で指定したアドレスからリードしたデータに基づき、SAR2で指定したテーブルを参照する。DTC12は、テーブルからリードしたデータを、DARで指定した転送先アドレスにライトする。

40

#### 【0066】

ビット27は、MDC Eビットである。DTC12は、MDC Eビットが1にセットされた状態で、CR=0のデータ転送を行うと、モード制御信号(MDC)を出力する。

#### 【0067】

ビット26～24は、MDC[2:0]ビットである。TLUビットが0にクリアされ、MDC Eビットが1にセットされた状態で、CR=0のデータ転送時に、モード制御信号(MDC)を指定する。MDC[2]ビットがCMDビットに、MDC[1]ビットがTDビットに、MDC[0]ビットがRDビットに反映されるようにする。DTC12は、TLUビットおよびMDC Eビットがいずれも1にセットされた状態では、SAR2で

50

指定したテーブルからリードしたデータに基づき、モード制御信号（MDC）を出力する。

**【0068】**

ビット22～20は、SF[2:0]ビットであり、入力データの左シフトを8～0ビットで指定する。

**【0069】**

ビット17、16はISz[1:0]ビットであり、入力データのリードをバイトサイズ、ワードサイズ、ロングワードサイズのいずれで行うかを選択する。

**【0070】**

ビット15、ビット14は、SM1、SM0ビットであり、データ転送後にSARをインクリメントするか、デクリメントするか、固定にするかを指定する。 10

**【0071】**

ビット13、ビット12は、DM1、DM0ビットであり、データ転送後にDARをインクリメントするか、デクリメントするか、固定にするかを指定する。

**【0072】**

ビット11、ビット10は、TMD1、TMD0ビットであり、データ転送モードを選択する。TMD1、TMD0ビットを00にするとノーマルモードとなる。このノーマルモードでは、1回の起動で、SARで示されるアドレスからDARで示されるアドレスへ1回のデータ転送を行う。この後、SM1、SM0、DM1、DM0ビットの指定に基いてSAR、DARの操作が行われ、CRがデクリメントされる。これを起動要因が発生する毎に、CRで指定された回数だけ繰り返す。そして、CRで指定された回数のデータ転送が終了すると、DTC動作が禁止され、起動要因となった割り込みがCPU11に要求される。TMD1、TMD0ビットを01にするとリピートモードとなる。TMD1、TMD0ビットを10にするとブロック転送モードとなる。リピートモード、ブロック転送モードは、公知の技術で実現できる。 20

**【0073】**

ビット9はDIRビットであり、転送元または転送先のいずれをリピート領域、ブロック領域とするかを選択する。

**【0074】**

ビット7、6はSz1、Sz0ビットであり、1回のデータ転送をバイトサイズ、ワードサイズ、ロングワードサイズのいずれで行うかを選択する。 30

**【0075】**

ビット2はCREビットであり、CREビットを0にクリアした場合は、DTC起動要求(DTCREQ)に応じて、無制限にDTC12の動作を行う。ノーマルモードの場合はCRを使用しない。CREビットを1にセットした場合は、CRに初期設定した値に応じて、DTC12の動作を行う。

**【0076】**

ビット1はNXT1ビットであり、1つの起動要因に対してデータ転送を終了するか、次のデータ転送を行うかを選択する。このNXT1ビットを0にクリアした場合、データ転送情報リードおよびデータ転送後、データ転送情報をライトしてDTCの動作を終了する。また、このNXT1ビットを1にセットした場合、データ転送情報リードおよびデータ転送後、データ転送情報をライトして、さらに連続したアドレスからデータ転送情報をリードして、このデータ転送情報で指定されるデータ転送を行い、データ転送情報をライトする。これをチェイン転送と呼ぶ。ビット0はNXT0ビットであり、CRが0になったときに、チェイン転送を行うかを指定する。 40

**【0077】**

図7は図1AのDTCの構成を示すブロック図である。DTC12はデータ転送制御ブロック(DTCCNT)121、バスインターフェース(BIF)122、ベクタ生成ブロック(VG)123、ベクタアドレスレジスタ(VAR)124および演算器(ALU)12Aを備える。また、DTC12はモードレジスタ(MR)、第1ソースアドレスレジ 50

スタ (SAR1)、第2ソースアドレスレジスタ (SAR2)、デスティネーションアドレスレジスタ (DAR) およびデータ転送カウンタ (CR) を備える。

**【0078】**

D T C C N T 1 2 1 は、I N T 1 3 からのD T C 転送要求 (D T C R E Q ) およびM R の内容に基づき、D T C 1 2 の制御を行う。

**【0079】**

B I F 1 2 2 は、D T C 内部バス 1 2 B と、M C U 内部バス 1 B とのインターフェースを行う。このインターフェースには、バスリクエスト、バスアクノレジ、バスコマンド、ウェイト、アドレス、データなどを含む。また、B I F 1 2 2 は、データ転送制御ブロック (D T C C N T ) 1 2 1 が転送データの確認を行うのにも使用される。

10

**【0080】**

V G 1 2 3 は、I N T 1 3 から与えられる割込みD T C ベクタ番号 (D T C V E C ) に従って、ベクタアドレスを生成する。例えば、D T C V E C を4倍などとし、所定のオフセットを加算する。

**【0081】**

V A R 1 2 4 は、V G 1 2 3 で生成されたベクタアドレスが指し示すR A M 1 5 の領域からリードしたデータ転送情報の先頭アドレスを格納する。

**【0082】**

M R 、S A R 1 、S A R 2 、D A R 、C R は、V A R 1 2 4 に格納されたデータ転送情報の先頭アドレスが指し示すR A M 1 5 の領域から順次リードしたデータ転送情報を格納する。

20

**【0083】**

A L U 1 2 A は、論理演算、シフト、算術演算などの機能を持ち、所定の順序で、これらの演算の複数を実行にする。

**【0084】**

D T C 内部バス 1 2 B は、図示はされないものの、複数のバスを持っており、S A R 1 、S A R 2 、D A R 、C R の複数の内容を、A L U 1 2 A に与えて演算できるようにする。これらによって、リピートモードやブロック転送モードの演算を行う。リピートモード、ブロック転送モードのデータ転送動作の内容については、公知の技術で実現できるので、詳細な説明は省略する。

30

**【0085】**

I N T 1 3 からD T C 起動要求信号 (D T C R E Q ) が与えられると、D T C 1 2 は動作を開始する。D T C C N T 1 2 1 は、D T C 1 2 が動作を開始すると、D T C 動作開始信号 (D T C S T A ) を活性状態にする。D T C C N T 1 2 1 は、データ転送を行うとき、このバスサイクルに応じて、アクノレジ信号 (A C K ) を活性化する。また、D T C C N T 1 2 1 は、転送カウンタ (C R ) が0のとき、かつM R の設定に従い、モード制御信号 (M D C ) を所定の状態にし、S C I 1 8 のS F C R の設定を行う。D T C C N T 1 2 1 は、割り込み要因クリア信号 (I N T C L R ) またはD T E クリア信号 (D T E C L R ) を活性状態にし、起動要因となった割り込み要因フラグ又はD T E ピットをクリアし、動作を終了する。D T C C N T 1 2 1 は、D T C 1 2 が動作を終了すると、D T C 動作終了信号 (D T C E N D ) を活性状態にし、停止状態に戻る。

40

**【0086】**

<応用例>

図 8 A は応用例に係るマイクロコンピュータシステムの構成を示すブロック図である。図 8 B は図 8 A のマイクロコンピュータシステムの接続関係を示すブロック図である。マイクロコンピュータシステム 1 は、マスタM C U 1 0 M 、スレーブM C U 1 0 S 、モータ 2 0 、モータ 2 0 の位置を検出するエンコーダ 3 0 を含む。マイクロコンピュータシステム 1 は、例えばカメラシステムであり、カメラマスタM C U 1 0 M はカメラボディ用M C U であり、スレーブM C U 1 0 S はカメラレンズ用M C U である。

**【0087】**

50

実施例に係るMCU10は、マスタMCU10MおよびスレーブMCU10Sに適用される。スレーブMCU10Sは、焦点モータ(M)20の駆動用のタイマ17F、焦点モータ20の位置を検出するためのエンコーダ(ENCODER)の入力用のタイマ17D、インターバルタイマ機能を持つタイマ17Iを使用するものとする。また、各種設定のスイッチ(SWITCH)などを、入出力ポート(I/O)1Aで入力する。

#### 【0088】

図8Bに示すように、マスタMCU10MのSCI18、スレーブMCU10SのSCI18はクロック同期式モードの3本およびステータスを示す入出力ポートの1本の信号線でインターフェースを行う。マスタMCU10MのTXDを出力する端子18A、RXDを入力する端子18B、SCKを出力する端子18CおよびSTを入力する端子18Dのそれぞれが、スレーブMCU10SのRXDを入力する端子18B、TXDを出力する端子18A、SCKを入力する端子18CおよびSTを出力する端子18Dに接続される。マスタMCU10Mが同期クロック(SCK)を出力し、スレーブMCU10Sがステータス(ST)を出力する。

#### 【0089】

(通信動作の第1の例)

図9は図8Aのマイクロコンピュータシステムにおける通信動作の第1の例を示すタイミング図である。通信動作の第1の例はマスタ送信/スレーブ受信の場合である。図9において、網掛け部が、スレーブMCU10SのSCI18のモード制御を行う、DTC12の動作を示す。

#### 【0090】

まず、マスタMCU10MおよびスレーブMCU10SはそれぞれのSCI18のレジスタに送受信動作(TE=1、RE=1)として初期設定を行う(タイミングT1)。

#### 【0091】

マスタMCU10Mは、スレーブMCU10Sのステータス(ST)出力を入力して、これがビジー(BUSY)状態である場合は、送信を待機する。送信データ(コマンド)が設定され、ステータス(ST)入力がレディ(READY)状態になると、マスタMCU10Mは、コマンド(CMND)を送信する。このとき、マスタMCU10MはRDビットを1にセットし、受信データを無視するようとする。

#### 【0092】

スレーブMCU10Sは、CMDビットを1にセットし、TDビットを1にセットしてコマンド受信に設定する(タイミングT1)。送信データエンプティ割り込み要求(TXI)のセットは抑止され、送信 FIFO187へのデータ設定を行わず、送信データ(TXD)は、例えばハイレベルに固定され、ダミー(DUMMY)データが出力される。受信が開始されると、ステータス(ST)出力をビジー状態にする。SCI18は、コマンドの受信が完了されると、コマンド受信完了割り込み要求(CRXI)を発生し、INT13はDTC12にDTC起動要求(DTCREQ)を発生する。DTC12は、コマンドの受信データをリードして、これをSAR2に加算して、RAM15のテーブル領域をリードする。この内容は、DARで指定される送信データエンプティ(送信データ転送)、受信データフル(受信データ転送)によるデータ転送起動要求のDTCベクタ(TXIベクタ、DRXIベクタ)を設定する。本例では、ロングワード2個をブロック転送するものとする。2個のロングワードの一方が所定のデータの場合(例えば、00000000の場合)、対応するTDビットまたはRDビットを1にセットするように、モード制御信号(MDC)を活性化する。具体的には、送信データエンプティのDTCベクタが00000000の場合、TDビットを1にセットし、送信抑止とする。受信データフルのDTCベクタが00000000の場合、RDビットを1にセットし、受信抑止とする。CMDビットは0にクリアする。このモード制御信号(MDC)に従い、SCI18はSFCRの設定を行って、データ受信またはデータ送信に切り替えるとともに、ステータス(ST)出力をビジー状態にする。この場合、先のコマンドに応じて、マスタの送信/スレーブの受信、スレーブの送信/マスタの受信、マスタ/スレーブの送受信の3つの態様があ

10

20

30

40

50

る。本例では、マスタの送信 / スレーブの受信を行う場合であるので、マスタは R D ビットを 1 にセットして受信抑止（データ送信）に設定し、スレーブは T D ビットを 1 にセットして送信抑止（データ受信）に設定する（タイミング T 2）。

#### 【 0 0 9 3 】

マスタ M C U 1 0 M はコマンド送信完了後、送信データが設定され、ステータス（ S T ）入力がレディ状態になると、コマンドに対応した、所定の数のデータを送信する。

#### 【 0 0 9 4 】

スレーブ M C U 1 0 S は、データ受信の開始時に、ステータス（ S T ）出力をビジー状態にする。データの受信が完了に従い、受信データフル（受信データ転送）データ転送起動要求を行い、D T C 1 2 を起動する。D T C 1 2 は受信したデータを R A M 1 5 の所定のアドレスに転送する。C R にはコマンドに対応した、所定の数のデータを設定しておき、これに従った個数のデータ転送を行い、C R が 0 になると、M R で指定したモード制御信号（ M D C ）を出力し、S C I 1 8 のモード制御状態を遷移させる（タイミング T 3）。S C I 1 8 はこれによって、ステータス（ S T ）出力をレディ状態にする。C R が 0 のデータ転送が完了すると、C P U 1 1 に割り込みを要求する。

#### 【 0 0 9 5 】

図 1 0 は図 9 の第 1 の例におけるコマンド受信完了のためのデータ転送を示す図である。スレーブ M C U 1 0 S のコマンド受信完了のためのデータ転送においては、データ転送情報を以下のように C P U 1 1 が設定する。

#### 【 0 0 9 6 】

M R の T L U ビット、B R M ビット、M D C E ビットをいずれも 1 にセットする。S F [ 2 : 0 ] ビットは + 4 を指定する。I S z [ 1 : 0 ] ビットは、コマンドに対応したバイトサイズを指定する。S M 1 、S M 0 ビットは、S A R 2 固定を指定する。D M 1 、D M 0 ビットは、D A R 固定を指定する。T M D 1 、T M D 0 ビットはノーマルモードを指定する。S A R 1 は受信 F I F O 1 8 6 のアドレスを、S A R 2 は、データ送信エンプティ転送要求、データ受信フル転送要求のD T C ベクタのテーブル領域の先頭アドレスを指定する。D A R は、データ送信エンプティ転送要求、データ受信フル転送要求のD T C ベクタアドレスを指定する。これらは図 1 0 のデータ転送情報 C として格納される。

#### 【 0 0 9 7 】

図 1 0 において、細線の矢印はアドレスの指定を、二重線の矢印はデータのリード / ライトを示す。

( A ) コマンド受信完了によって、D T C が起動されると、対応するベクタ領域（ C R X I 割込みのベクタアドレスが指定する領域（ C R X I ベクタ））から、データ転送情報の先頭アドレスをリードする。

( B ) このアドレスに基づいて、データ転送情報アドレス領域からデータ転送情報 C をリードする。このデータ転送情報 C は、M R 、S A R 1 、S A R 2 、D A R に格納すべき内容である。S A R 1 には受信 F I F O 1 8 6 のアドレスが、S A R 2 にはテーブル領域の先頭アドレスが、D A R には T X I ベクタアドレスが格納される。

( C ) まず、S A R 1 で指定した受信 F I F O 1 8 6 から、I S z ビットで指定したバイトサイズの、コマンドをリードする。リードしたデータは、A L U 1 2 A で、S F [ 2 : 0 ] ビットで指定した 4 ビットの左シフトし、この結果を、S A R 2 に加算して転送元アドレスとして使用する。

( D ) S A R 2 で指定した、テーブル領域の転送元アドレスから転送データをリードする。本例では、T X I ベクタ n 、D R X I ベクタ n をリードする。

( E ) これを D A R で示す、T X I ベクタおよび D R X I ベクタ領域へのライトを行う。同時に、前記の通り、モード制御信号（ M D C ）を出力する。

例えば、D R X I ベクタ n は所要のデータ転送情報 m などを示す内容とする。

#### 【 0 0 9 8 】

これによって、コマンドに対応した、T X I および D R X I データ転送に応じた、データ転送情報を（データ転送情報 m 、m 1 、m 2 、m 3 などから）選択可能にできる。

10

20

40

50

**【0099】**

なお、コマンドはバイトサイズの場合、最大256通りを指定することができる。後続するデータの有無やデータ長、データの種類などを定義する。例えば、後続するデータをスレーブMCU10Sのタイム17D, 17F, 17IやI/Oポート1Aへライトすることを指示したり、スレーブMCU10Sのタイム17D, 17F, 17IやI/Oポート1Aの所望のデータを送信することを指示したりする。かかるコマンドは、当該マイクロコンピュータシステム1に適切なものを、任意に定義することができる。

**【0100】**

図11は図9の第1の例における受信データフル(受信データ転送)のためのデータ転送を示す図である。スレーブMCU10Sの受信データフル(受信データ転送)のためのデータ転送においては、データ転送情報を以下のように設定する。10

**【0101】**

MRのTLUビット、BRMビットを0にクリアし、MDCエビットを1にセットする。Sz[1:0]ビットは、コマンドに対応したバイトサイズを指定する。SM1、SM0ビットは、SAR固定を指定する。DM1、DM0ビットは、DARインクリメントを指定する。TMD1、TMD0ビットはノーマルモードを指定する。SARは受信 FIFO186のアドレスを、DARはデータ受信用のRAM15のアドレスを、CRはコマンドに対応したデータ数を指定する。これらは図11のデータ転送情報mとして格納される。

(A) 受信データフル(受信データ転送)によって、DTC12が起動されると、対応するベクタ領域(DRXI割込みのベクタアドレスが指定する領域(DRXIベクタ))から、データ転送情報先頭アドレスをリードする。これはコマンド受信完了によるデータ転送によって、所要の内容に更新され、データ転送情報mを示すようにされている。20

(B) このアドレスに基づいて、データ転送情報アドレス領域からデータ転送情報mをリードする。このデータ転送情報は、MR、SAR、DAR、CRの内容である。SARには受信 FIFO186のアドレスが、DARにはRAM15のアドレスが格納される。

(C) まず、SARで指定した受信 FIFO186から、Szビットで指定したバイトサイズの、受信データをリードする。リードした受信データは、DARで指定したRAM15などにライトする。これをCRで指定した回数繰り返し、CR=0となると、前記の通り、モード制御信号(MDC)を出力する。30

**【0102】****(通信動作の第2の例)**

図12は図8Aのマイクロコンピュータシステムにおける通信動作の第2の例を示すタイミング図である。通信動作の第2の例では、コマンドに対応したデータ転送が、スレーブの送信/マスターの受信の場合である。マスターMCU10MおよびスレーブMCU10Sはそれぞれ送受信動作として初期設定を行うこと、コマンドの送信/受信は、上述の第1の例と同様である。

**【0103】**

マスターMCU10Mは、所要のデータの数に相当する同期クロックを出力するため、TDビットを1にセットして、例えば送信データをハイレベルに固定してダミーのデータを送信する。40

**【0104】**

スレーブMCU10Sは、コマンド受信完了時のDTC12のモード制御によって、RDビットを1にセットしてデータ送信に設定するようにする(タイミングT2)。すなわち、RAM15のテーブル上の送信データエンプティのDTCベクタを00000000以外の所定のベクタにし、受信データフルのDTCベクタを00000000にする。

**【0105】**

スレーブMCU10Sは、コマンドに対応した、所定の数のデータを送信するため、送信データエンプティ(送信データ転送)データ転送要求に従い、DTC12Sを起動する。DTC12は、送信すべきデータをRAM15の所定のアドレスから送信 FIFO1850

7に転送する。データ送信の開始時に、ステータス( S T )出力をビジー状態にする。C Rで示される、予め決められた個数のデータ転送を行い、C Rが0になると、M Rで指定したモード制御信号( M D C )を出力し、S C I 1 8 Sのモード制御状態を遷移させる(タイミングT 3' )。このとき、モードの変更、またはS F C Rの変更は直ちに反映されず、送信データの出力完了後に(送信F I F O 1 8 7および送信部1 8 5にデータがなくなった状態で)反映する(タイミングT 3 )。言い換えると、モード制御入力を送受信に同期させて反映させる。S C I 1 8 Sはステータス( S T )出力をレディ状態にする。C Rが0のデータ転送が完了すると、S C I 1 8 SはC P U 1 1に割り込みを要求する。

#### 【 0 1 0 6 】

送信データエンプティ(送信データ転送)のためのデータ転送においては、データ転送情報 10 を以下のように設定する。

#### 【 0 1 0 7 】

M RのT L Uビット、B R Mビットを0にクリアし、M D C Eビットを1にセットする。S z [ 1 : 0 ]ビットは、コマンドに対応したバイトサイズを指定する。S M 1、S M 0ビットは、S A Rインクリメントを指定する。D M 1、D M 0ビットは、D A R固定を指定する。T M D 1、T M D 0ビットはノーマルモードを指定する。S A Rはデータ送信用のR A M 1 5 Sのアドレスを、D A Rは送信F I F O 1 8 7のアドレスを、C Rはコマンドに対応したデータ数を指定する。

#### 【 0 1 0 8 】

(通信動作の第3の例)  
通信動作の第3の例であるマスター/スレーブの送受信の場合は、図示を省略するが、スレーブM C U 1 0 Sは、T Dビット、R Dビットをいずれも0にクリアし、D T C 1 2が送信データ完了によるデータ転送時にはS F C Rの変更の制御を行わず、受信データ完了によるデータ転送時にはS F C Rの変更の制御を行うようとする。すなわち、R A M 1 5のテーブル上の送信データエンプティ、受信データフルのD T Cベクタを、いずれも0 0 0 0 0 0以外の所定のベクタにする。

#### 【 0 1 0 9 】

以上の実施例によれば以下の作用効果を得るものである。

(1) 送信および受信がイネーブルとされた状態( T E = R E = 1 )において(送受信同時動作を指定したまま)、T DビットまたはR Dビットを1に設定することにより、送信または受信の一方の動作を抑止可能にする。送信動作抑止の場合は、送信データの用意や送信開始の指定を必要とせず、同期クロック入力に対応して、任意データの送信と、受信動作を可能にする。受信動作抑止の場合は、受信した内容を無視しオーバランエラーも検出しないようにし、割り込み要求やデータ転送起動要求を行わないようとする。これにより、送受信同時動作かつ同期クロック入力での動作イネーブル状態において、一時的に、換言すれば、設定変更の待機時間などを不要としながら、送信動作抑止、受信動作抑止が可能になる。無駄な送信データの準備や、無駄な受信データの処理などを不要とし、処理を効率化できる。T EビットまたはR Eビットを切り替えると、S C I全体の動作との整合を図る必要があるのに対し、送受信同時動作の基本的な動作は変更せず、T DビットおよびR Dビットの制御対象を限定することで、論理を簡略化することができる。不所望の状態に陥る可能性を低減することができる。

(2) 受信動作において、コマンドを受信する動作であるか、データを受信する動作であるかを指定可能にし、これらの割り込み要求またはデータ転送起動要求を別々に要求するようとする。これによって、データ転送装置の起動要因を専用にすることが可能になる。コマンド受信する動作時は、送信動作抑止とすることにより、送信データの用意を不要にする。データ受信する動作時では、送信動作の抑止を指定可能にする。コマンド受信完了の割り込み要求、データ受信完了の割り込み要求を分離することにより、いずれかの判断を行うことなく、必要な処理を直ちに実行することができる。コマンド受信完了の割り込み要求に対してはデータ転送装置によるデータ転送を行い、データ受信完了の割り込み要求に対してはC P Uによる割り込み処理を行うなどの、好適な処理方法の選択を効率的

10

20

30

40

50

にすることができる。

#### 【0110】

(3) コマンド受信、データ受信のみ、データ送信のみ等のモードおよび起動要因に応じたデータ転送装置の動作によって、モードを切り替える。例えば、データ送信またはデータ受信に対応した、データ転送装置によるデータ転送の完了時に、コマンド受信に切り替える。

(4) モードに対応したステータスを出力可能にする。コマンド受信が指定された状態での受信動作によって、外部へのステータス出力を第2状態(ビジー)にする。コマンド受信完了によるデータ転送装置の動作によって、モードの切り替えを行ったときに、外部へのステータス出力を第1状態(レディ)にする。また、データ送信またはデータ受信動作によって、ステータス出力を第2状態(ビジー)にし、これらによるデータ転送装置の動作によって、モードの切り替え(コマンド受信にモードを切り替え)たときに、第1状態(レディ)にする。

これらによって、実際の通信処理に応じたモードを実現可能にするとともに、設定変更や待機時間を減らすことができる。モードと通信動作に応じて、データ転送装置を起動し、データ転送装置の制御によって、モードを切り替えるようにして、CPUの処理を不要にし、効率化と高速化を実現することができる。データ転送装置がCPUに代わって、SCIのモード制御や、コマンドの判定、データ転送を実行可能にすることで、CPUに割り込みを要求する頻度を低減したり、CPUを低消費電力状態にする期間を長くしたりすることができる。CPUが割り込み処理にあたって実行すべき、例外処理、スタックの退避・復帰操作、復帰命令の実行を不要とすることができ、プログラムの簡略化やシステムの効率化に寄与することができる。また、イベントの発生から所要の動作の実行までの時間を短縮し、いわゆる応答性を向上することができる。CPUより論理規模が小さく、かつ高速に処理を行うことができるデータ転送装置が動作し、CPUを低消費電力状態にすることで、低消費電力化を実現することができる。また、ソフトウェアの開発効率を向上することができる。

#### 【0111】

マイクロコンピュータシステムのそれぞれに適切なコマンドや通信方式に、柔軟に対応することができる。換言すれば、マイクロコンピュータへ与えるデータによって、マイクロコンピュータの送受信の態様を変更可能にすることができます。

#### 【0112】

以上、本発明者らによってなされた発明を実施形態、実施例および応用例に基づき具体的に説明したが、本発明は、実施形態、実施例および応用例に限定されるものではなく、種々変更可能であることはいうまでもない。

#### 【0113】

本実施例では、SCIの設定完了後の動作の許可として、TEビット、REビットを使用する仕様とし、これとは独立のTDビット、RDビットを設けたが、SCIの動作イネーブルビットを、送信および受信に共通に設け、TEビットおよびREビットと、TDビットおよびRDビットとの機能を併せるようにし、動作中に変更可能にしてもよい。コマンド受信および送信抑止の場合の送信出力は任意であってよいが、0または1に固定することが好ましい。CMDビットを1にセットした場合は、TDビットに関わらず、送信抑止としてもよい。CRXI、DRXIの割り込み要因フラグは共通のRDRFフラグとせずに、独立の割り込み要因フラグとしてもよい。RDビットを1にセットしたときに、RIEビットまたはRDRFフラグを0にクリアするようにしてもよい。TDビット、RDビットを指定するためのロングワードデータは、データ転送情報格納領域として使用しないデータとすればよい。本実施例では0000000としたが、これはCPUのリセットベクタと共にあり、データ転送情報格納領域として使用しないことを想定したものである。データ転送格納アドレスはロングワード単位と考える場合、下位の2ビットを使用してもよい。

#### 【0114】

10

20

30

40

50

受信 FIFO、送信 FIFO が受信データフル（受信データ転送）、送信データエンプティ（送信データ転送）を検出するための、空きやデータ量を、制御レジスタによって変更可能にしてもよい。また、コマンド受信のときの受信完了を判定する単位も、バイトサイズ以外に選択可能にしてもよい。コマンド受信完了によるデータ転送によって、ベクタ領域を書き換えるほか、データ転送情報を書き換えるようにしてもよい。CPUによって、CMD ビット、TD ビット、RD ビットを設定可能にしてもよい。任意のコマンドを CPU が処理するようにし、CMD ビット、TD ビット、RD ビットを設定するようにしてもよい。

#### 【0115】

本実施例では SCI を例に説明したが、これに限定されるものではなく、I<sup>2</sup>C (Intelligent Integrated Circuit)、SPI (Serial Peripheral Interface) 等のシリアル通信インターフェースに適用することができる。本実施例では DTC を例に説明したが、これに限定されるものではなく、DMAC (Direct Memory Access Controller) 等のメモリとレジスタ等の間でデータを転送するものであってもよい。DTC、割り込みコントローラの具体的な構成についても種々変更可能である。BSC や、バス権やウェイトなどのバス動作の詳細については省略したが、これらは適宜実装可能である。マスタMCU、スレーブMCU の一方のみに適用してもよい。この場合、スレーブMCU に適用するのが好ましい。

#### 【0116】

マイクロコンピュータの構成についても限定されない。そのほかや機能ブロックなども種々変更できる。以上の説明ではマイクロコンピュータに適用した場合について説明したが、それに限定されるものではなく、他の半導体装置、例えば、デジタルシグナルプロセッサ (DSP) に適用することができる。

#### 【0117】

<実施態様>

以下、実施態様について付記する。

(付記1)

同期クロックに従って送信または受信の順序的な通信を行うインターフェース回路を有する半導体装置であって、

前記インターフェース回路は、

送信状態及び受信状態の少なくとも一つの状態である動作イネーブル状態を指定する第1のレジスタと、

送信抑止または受信抑止を指定することが可能な情報を有する第2のレジスタと、を有し

前記第1のレジスタと前記第2のレジスタの状態に基づいて情報の送信または受信の少なくとも一つの動作を決定する

半導体装置。

#### 【0118】

(付記2)

同期クロックに従って、送信または受信の順序的な通信を行う第1のインターフェース回路を備える第1の半導体装置と、

前記同期クロックに従って、送信または受信の順序的な通信を行う第2のインターフェース回路を備える第2の半導体装置と、を備えるシステムであって、

前記第2のインターフェース回路は、

送信状態及び受信状態の少なくとも一つの状態である動作イネーブル状態を指定する第1のレジスタと、

送信抑止または受信抑止を指定することが可能な情報を有する第2のレジスタと、を有し

前記第1のレジスタと前記第2のレジスタの状態に基づいて情報の送信または受信の少

10

20

30

40

50

なくとも一つの動作を決定する  
システム。

## 【符号の説明】

## 【0119】

|                                           |    |
|-------------------------------------------|----|
| 1 . . . マイクロコンピュータシステム                    |    |
| 1 0 . . . マイクロコンピュータ                      |    |
| 1 1 . . . 中央処理装置 ( C P U )                |    |
| 1 2 . . . データトランスマルチポート ( D T C )         |    |
| 1 2 1 . . . データ転送制御ブロック ( D T C C N T )   |    |
| 1 2 2 . . . バスインターフェース ( B I F )          | 10 |
| 1 2 3 . . . ベクタ生成ブロック ( V G )             |    |
| 1 2 4 . . . ベクタアドレスレジスタ ( V A R )         |    |
| 1 2 A . . . 演算器 ( A L U )                 |    |
| 1 2 B . . . D T C 内部バス                    |    |
| 1 3 . . . 割り込みコントローラ ( I N T )            |    |
| 1 3 1 . . . 割り込み / D T C 判定回路             |    |
| 1 3 2 . . . D T C 許可レジスタ ( D T E R )      |    |
| 1 3 3 . . . 優先順位マスクレベル判定回路                |    |
| 1 3 4 . . . 優先順位判定回路                      |    |
| 1 3 5 . . . ラッチ回路                         | 20 |
| 1 3 6 . . . デコーダ回路                        |    |
| 1 4 . . . リードオンリーメモリ ( R O M )            |    |
| 1 5 . . . ランダムアクセスメモリ ( R A M )           |    |
| 1 6 . . . バスコントローラ ( B S C )              |    |
| 1 7 . . . タイマ ( T I M E R )               |    |
| 1 8 . . . シリアルコミュニケーションインターフェース ( S C I ) |    |
| 1 8 1 . . . 制御レジスタ                        |    |
| 1 8 2 . . . モード制御部 ( S C I M D C )        |    |
| 1 8 3 . . . 送受信制御部 ( S C I C N T )        |    |
| 1 8 4 . . . 受信部                           | 30 |
| 1 8 5 . . . 送信部                           |    |
| 1 8 6 . . . 受信 F I F O                    |    |
| 1 8 7 . . . 送信 F I F O                    |    |
| 1 8 8 . . . ポートジェネレータ ( B R G )           |    |
| 1 8 A . . . 出力端子                          |    |
| 1 8 B . . . 入力端子                          |    |
| 1 8 C . . . 入出力端子                         |    |
| 1 8 D . . . 入出力端子                         |    |
| 1 9 . . . アナログモジュール ( A N A L O G )       |    |
| 1 A . . . 入出力ポート ( I / O )                | 40 |
| 1 B . . . M C U バス                        |    |

【図 1 A】



【 図 1 B 】



【 図 2 】



【 図 3 】

|      | -    | -    | -  | - | - | Cks1 | Cks0 |
|------|------|------|----|---|---|------|------|
| TIE  | RIE  | TE   | RE | - | - | CKE  | -    |
| TDRE | RDRF | RDRE | -  | - | - | -    | -    |
|      | -    | TD   | RD | - | - | CMD  | -    |

【図4】



【図5】



【図6】



【図7】



【図 8 A】

図 8 A



【図 8 B】

図 8 B



【図 9】

図 9



【図 10】

図 10



【 図 1 1 】



【 図 1 2 】



【図13】



---

フロントページの続き

(56)参考文献 特開2009-110335(JP,A)  
特開2005-293283(JP,A)  
特開平08-185363(JP,A)  
米国特許出願公開第2015/0193367(US,A1)

(58)調査した分野(Int.Cl., DB名)

G 06 F 13 / 38  
G 06 F 15 / 78